Lsys
LSYS is a tiny little language designed to produce L-systems.
Some LSYS code
A grammar for a classic L-system could look like this:
 a|a:ab|b:aThe code is split up into three slices, delimited by the '|'. The first slice dictates the initial axiom, 'a'. The second slice dictates the definition for 'a' to be 'ab'. The third slice dictates the definition for 'b' to be 'a'.
Once the code has been parsed, it can be used to generate a list, whose length is determined by the order N:
 N | output
 ----------
 1 | a
 2 | ab 
 3 | aba
 4 | abaab
 5 | abaababa
 6 | abaababaabaab
 7 | abaababaabaababaababaAnd so on and so forth...
LSYS in Sporth
LSYS is implemented as a Sporth UGen, which takes in 3 arguments. From left to right, they are:
- trigger signal, which iterates through the L-system
- The order N of the L-system (init-time only)
- The code itself.
The signal output by the LSYS ugen a number in the range of 0-35, which correspond to the base-36 numbering system:
 0123456789abcdefghijklmnopqrstuvwxyzIn the example above, the signal would be alternating between 10 and 11.
Here is an example of the lys ugen in action:
# L-systems Test
# Paul Batchleor
# August 2016
_tick var
0.1 dmetro _tick set
_tick get dup
8 "a|a:ab|b:a" lsys 10 eq *
0.01 0.01 0.01 tenvx 1000 0.4 sine *
_tick get dup
4 "a|a:ab|b:a" lsys 10 eq *
0.01 0.01 0.01 tenvx 500 0.4 sine *
_tick get dup
3 "a|a:ab|b:a" lsys 10 eq *
0.01 0.01 0.01 tenvx 1500 0.4 sine *
mixLSYS as a standalone
Using the C code found in Sporth , LSYS can also be compiled as a standalone application:
 gcc lsys.c -DLSYS_STANDALONE -o lsysIt can be fed in code and the order as command line arguments:
 ./lsys 5 "01|0:121|1:01|2:1Which will produce the following string:
 01101121011210101101121011210101121010110112101Previous: Prop | Back | Next: A list of Unit Generators in Sporth