forked from micknoise/Maximilian
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME
73 lines (43 loc) · 2.95 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
.__ .__.__ .__
_____ _____ ___ __|__| _____ |__| | |__|____ ____
/ \\__ \ \ \/ / |/ \| | | | \__ \ / \
| Y Y \/ __ \_> <| | Y Y \ | |_| |/ __ \| | \
|__|_| (____ /__/\_ \__|__|_| /__|____/__(____ /___| /
\/ \/ \/ \/ \/ \/
::::::::::::::::::::::::::What's Maximilian?
Maximilian is an audio synthesis and signal processing library written in C++. It's cross-platform compatible with MacOS, Windows, Linux and IOS systems. The main features are:
- sample playback, recording and looping
- read from WAV and OGG files.
- a selection of oscillators and filters
- enveloping
- multichannel mixing for 1, 2, 4 and 8 channel setups
- controller mapping functions
- effects including delay, distortion, chorus, flanging
- granular synthesis, including time and pitch stretching
- atom synthesis
- realtime music information retrieval functions: spectrum analysis, spectral features, octave analysis, Bark scale analysis, and MFCCs
- example projects for Windows and MacOS, using command line and OpenFrameworks environments
:::::::::::::::::::::::::::BASIC EXAMPLES
You can choose between using RTAudio and PortAudio drivers in player.h by uncommenting the appropriate line. To use PortAudio, you will need to compile the portAudio library from http://http://www.portaudio.com/ and link it with your executable.
Examples demonstrating different features can be found in the maximilian_examples folder. To try them, replace the contents of main.cpp with the contents of a tutorial file and compile.
:::MAC OSX XCODE PROJECT
You can run the examples using the 'maximilianTest' XCode 3 project provided.
::WINDOWS VISUAL STUDIO 2010 PROJECT
This is in the maximilianTestWindowsVS2010 folder. You will need to install the DirectX SDK, so that the program can use DirectSound.
:::COMMAND LINE COMPILATION IN MACOSX
> g++ -Wall -D__MACOSX_CORE__ -o maximilian main.cpp RtAudio.cpp player.cpp maximilian.cpp -framework CoreAudio -lpthread
> ./maximilian
::COMMAND LINE COMPILATION IN LINUX
With OSS:
> g++ -Wall -D__LINUX_OSS__ -o maximilian main.cpp RtAudio.cpp player.cpp maximilian.cpp -lpthread
With ALSA:
> g++ -Wall -D__LINUX_ALSA__ -o maximilian main.cpp RtAudio.cpp player.cpp maximilian.cpp -lasound -lpthread
With Jack:
> g++ -Wall -D__UNIX_JACK__ -o maximilian main.cpp RtAudio.cpp player.cpp maximilian.cpp `pkg-config --cflags --libs jack` -lpthread
then:
> ./maximilian
:::::::::::::::::::::::::::OPENFRAMEWORKS
Maximilian works well with the OpenFrameworks C++ creative coding toolkit (http://www.openframeworks.cc).
In the ofxMaxim directory you will find examples to run in Windows, OSX and iOS, including FFT analysis and granular synthesis.
You can install the ofxMaxim addon by copying the ofxMaxim/ofxMaxim folder into your openframeworks addons directory.
Important: when using Maximilian on OSX, link against the Accelerate framework.