SynthAModelerFireFaderLab
Current Requirements: Intel CPU and Mac OS X 10.6 or greater
Contents
Installing Synth-A-Modeler
- First install XCode Developer tools (see this link or go to the App Store) and make sure that command line tools are installed. (Alternative to XCode: [1] and choose a package GCC-10.6.pkg, GCC-10.7.pkg, etc.)
- Download "Qt libraries 4.8.4 for Mac (185 MB)" from the following link and install it (installation takes about 5 minutes).
- Download the file faust-0.9.58.zip from the Faust repository.
- Then open the Terminal program. Probably the ZIP file wound up in your Downloads directory, and you could move it into the current (i.e. home) directory by typing:
mv ~/Downloads/faust-0.9.58.zip .
- Unzip it by typing
unzip faust-0.9.58.zip
- Enter the new faust-0.9.58 directory by typing
cd faust-0.9.58
- Finally, run the following commands to compile and install Faust. You will have to enter the administrator password to install Faust:
make
sudo make install
- Then you will need to install the Jack Audio server. Download the 64/32 bit version from Jack Audio Server for OS X (after you install this you will need to restart).
- To download Synth-A-Modeler (SaM), click on the Zip button near the upper-lefthand corner of this page.
- Now open up the Terminal again, and make sure you are in your home directory by typing
cd ~
- Now, move SaM into your home directory by typing
mv ~/Downloads/SaM-master.zip .
- Extract Synth-A-Modeler using
unzip SaM-master.zip .
- To enter the Synth-A-Modeler directory, type
cd SaM-master
- Before you plug in your FireFader, run the command
ls /dev/cu*
for a list of the serial devices. Then, after plugging in the FireFader, run
ls /dev/cu*
again. The new path you see is the path to your FireFader. For instance, on my machine it is /dev/cu.usbmodem1d11. Then edit the file ~/SAM/PathToDevice.txt so that it contains only the new path, that is for me it contains only the following:
/dev/cu.usbmodem1d11
- Now copy PathToDevice.txt to your root directory by typing
sudo cp PathToDevice.txt /
(You will have to enter the administrator password to make this happen.)
Exploring Synth-A-Modeler
- To build all of the models stored in .MDL files into QT applications for the Jack audio server, run the command
make jackqt
Browse to your home directory in the Finder, and then go inside SaM-master. The make command should've caused the subdirectory jackqt to be created containing a compiled application for each model. (If that didn't work, then talk to one of us.)
- You should be able to run any model now by double-clicking on it in the Finder.
- Now, try editing the models. The make jackqt command should detect any .MDL files that have changed and recompile the corresponding applications.
Notes
- You can only run one model at a time!
Going Further
- Setup the Pure Data (pd) header files for Faust and try the make puredata command.
- Install the MaxMSP SDK and then try the make msp command (you might need to adjust where it is looking for the header files).
Then try to compile the guiro model by typing make jackqt SAMTARGET=guiro
Make sure that in the Jack settings, the frames/period is set to 32.
(Ran fine on Mac Book Pro Late 2008 Intel Core 2 Duo running OS X 10.8.2 at 32 samples per frame, MacBook Pro Intel Core i7 running OS X 10.7.5 with Qt version 4.7.4 at 32 samples per frame, and iMac running OS X 10.6.8 at 32 samples per frame, Ran fine on dual-core 2.53GHz Intel Core 2 Duo OS X 10.6.8)
Troubleshooting
Requires minimum Perl version 5.10
The following kinds of errors can for instance happen if you ever upgraded Faust but forgot to remove the older version of Faust: error: macro "max" passed 3 arguments, but takes just 2 or other particularly errors involving some standard template libraries, then please make sure you only have one version of Faust installed. You can remove all older versions of Faust by entering into each of their source directories and running sudo make uninstall (Then of course you will need to reinstall you favorite version of Faust 0.9.58 by going into its source directory and running sudo make install