The csound-expression package
Let's make music with text! We can use Csound to describe our music. Csound has so many fantastic sound generators. It's very efficient. But sometimes Csound is too low level. So many details: integer identifiers for instruments and arrays, should I use control rate or audio rate signals, lack of abstractions, no nested expressions and it has limited set of types. This library embeds Csound in Haskell. We can use powerful Csound's primitives and glue them together with Haskell abstractions. The module Csound.Base exports all types and functions.
Overview of the library http://github.com/anton-k/csound-expression/blob/master/tutorial/Overview.markdown
Introduction to Csound and library for Haskell users http://github.com/anton-k/csound-expression/blob/master/tutorial/CsoundInstro.markdown
There are examples in the source code archive http://github.com/anton-k/csound-expression/tree/master/examples.
Keep it simple and compact (as functional as possible).
Make it open (No dependency on Score-generation libraries. Score (or list of events) is represented with type class. You can use your favorite Score-generation library if you provide an instance for the CsdSco type class. Currently there is support for temporal-music-notation library (see temporal-csound package).
How to install (for Csound and Haskell users)
To use the library we need:
GHC - haskell compiler. This library uses GHC-specific features (www.haskell.org/ghc).
cabal-install to install haskell packages (www.haskell.org/cabal).
Csound compiler (version 5.13 or higher). You must get it installed on your system. Since we are going to generate the csound code we need to compile it to sound somehow. We can find out how to install the Csound on www.csounds.com. To test whether csound is installed open the command line and type:
It should print a long message with version and available flags and libraries.
If everything is installed to install the library we can open the command line terminal and type:
cabal install csound-expression
Acknowledgements (I'd like to mention those who supported me a lot with their music and ideas):
music: entertainment for the braindead, annsannat & alizbar, toe, iamthemorning, atoms for piece / radiohead, loscil, boards of canada, Hozan Yamamoto, Tony Scott and Shinichi Yuize.
ideas: Conal Elliott, Oleg Kiselyov, Paul Hudak, Gabriel Gonzalez, Rich Hickey and Csound's community.
WARNING: the library works best within ghci. The real-time sound rendering function dac spawns a child process in the background which may continue to execute after you stop the main process that runs the programm. It's not so in vim but it happens in the Sublime Editor and when you invoke runhaskell. So the best is to write you program in the separate file and then load it in the ghci and invoke the function main (which runs the sound rendering with the function dac).
- No changelog available
|Versions||0.0, 0.0.1, 0.0.2, 0.0.3, 0.1.0, 0.2.0, 0.3.0, 0.3.1, 0.3.2, 0.3.3, 0.3.4, 1.0.0, 1.0.1, 1.0.2, 1.0.3, 1.0.4, 1.1.1, 3.0.0, 3.0.1, 3.1.0, 3.1.1, 3.2.1|
|Dependencies||base (==4.*), Boolean (>=0.1.0), csound-expression-opcodes, csound-expression-typed (>=0.0.3), data-default, process|
|Source repository||head: git clone https://github.com/anton-k/csound-expression|
|Upload date||Thu Mar 27 13:13:30 UTC 2014|
|Downloads||1042 total (148 in last 30 days)|
- csound-expression-3.2.1.tar.gz [browse] (Cabal source package)
- Package description (included in the package)
For package maintainers and hackage trustees