-
Notifications
You must be signed in to change notification settings - Fork 3
Source code for evolutionary music engine to accompany forthcoming journal article
bobular/DarwinTunes
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
SOURCE CODE TO BE RELEASED UPON PUBLICATION (of a journal article describing the first DarwinTunes experiment) This directory contains the DarwinTunes song-generation source code. Moderate Linux and Perl knowledge is assumed. The author takes no responsibility for hearing loss. Please take care of your ears! Author: Bob MacCallum, http://twitter.com/bobmaccallum Please note that the DarwinTunes code has only been tested in Linux. It seems to run fine on a mid-range 2010 netbook. In order to run DarwinTunes on your own machine you'll need to install the following: 1. Perl modules: PDL and PDL::Audio::Scales 2. PerlGP (http://perlgp.org) - set the PERLGP_SCRATCH environment variable to "." without the quotes. To get started generating music, edit Individual.pm to set the tempo (if you are familiar with PerlGP's grammar description syntax you can set other things too). From within this directory: 1. Type "screen nice perlgp-run.pl -loop" and ctrl-a d to detach the screen (or just run it in a spare window without the 'screen'). 2. Run this script: ./rate-loops.pl You should hear music (you might need to install pulseaudio, esound or tweak the play-loops.pl script to suit your system). You can replace the esdcat command with sox -q -t raw -r 44100 -b 16 -c 2 -e signed-integer - -t alsa 3. Rate the loops with any integer you like, followed by <enter> (then you get to hear the next loop). If you follow the number with a period, the loop (and its Perl source) will be saved. 4. Repeat 3 indefinitely... 5. To stop the program: ctrl-c to stop rate-loops.pl screen -r then ctrl-c twice to kill the loop generation in the background 6. To restart the program, just run perlgp-run.pl again. 7. To completely wipe the project in this directory, stop all programs and type perlgp-wipe-expt.pl If you have Perl/PerlGP knowledge, you can add WAV sample files (keep them short-ish) in a hierarchical directory structure within 'samples' (keep directory names short and use letters and no numbers or punctuation). You can then edit the Grammar.pm file to allow use of the loadwav function. If you name kick, snare and hi-hat samples appropriately you can uncomment various bits of code (Individual.pm, Grammar.pm, search for 'house') early on in evolution to encourage some basic house beats. Have fun!
About
Source code for evolutionary music engine to accompany forthcoming journal article
Resources
Stars
Watchers
Forks
Releases
No releases published
Packages 0
No packages published