home *** CD-ROM | disk | FTP | other *** search
Unknown | 1999-04-22 | 52.9 KB |
open in:
MacOS 8.1
|
Win98
|
DOS
view JSON data
|
view as text
This file was not able to be converted.
This format is not currently supported by dexvert.
Confidence | Program | Detection | Match Type | Support
|
---|
100%
| file
| data
| default
|
|
hex view+--------+-------------------------+-------------------------+--------+--------+
|00000000| 0f 64 65 66 61 75 6c 74 | 20 73 65 74 74 69 6e 67 |.default| setting|
|00000010| 41 bd 00 00 70 6f 70 20 | 64 61 6e 63 65 72 73 20 |A...pop |dancers |
|00000020| 7b 0a 2f 2f 20 42 61 73 | 65 50 6f 70 20 61 74 74 |{.// Bas|ePop att|
|00000030| 72 69 62 75 74 65 73 0a | 2f 2f 20 44 61 6e 63 65 |ributes.|// Dance|
|00000040| 72 50 6f 70 20 61 74 74 | 72 69 62 75 74 65 73 0a |rPop att|ributes.|
|00000050| 73 70 65 65 64 20 35 30 | 0a 70 61 72 65 6e 74 73 |speed 50|.parents|
|00000060| 20 30 0a 6d 6f 64 65 6c | 5f 63 6f 6d 70 6c 65 78 | 0.model|_complex|
|00000070| 69 74 79 20 31 0a 72 65 | 6e 64 65 72 69 6e 67 20 |ity 1.re|ndering |
|00000080| 30 0a 6d 75 73 69 63 5f | 73 74 79 6c 65 20 30 0a |0.music_|style 0.|
|00000090| 66 72 61 6d 65 73 20 33 | 35 30 0a 6c 6f 6f 70 65 |frames 3|50.loope|
|000000a0| 64 20 74 72 75 65 0a 65 | 61 73 65 5f 74 77 65 65 |d true.e|ase_twee|
|000000b0| 6e 20 66 61 6c 73 65 0a | 6d 6f 72 70 68 20 74 72 |n false.|morph tr|
|000000c0| 75 65 0a 6d 6f 72 70 68 | 5f 73 70 65 65 64 20 31 |ue.morph|_speed 1|
|000000d0| 2e 35 0a 6d 6f 72 70 68 | 5f 61 63 63 20 30 2e 33 |.5.morph|_acc 0.3|
|000000e0| 0a 6d 6f 72 70 68 5f 6d | 75 73 69 63 20 31 32 0a |.morph_m|usic 12.|
|000000f0| 6d 6f 72 70 68 5f 73 65 | 6e 73 69 74 69 76 69 74 |morph_se|nsitivit|
|00000100| 79 20 32 30 0a 6d 6f 72 | 70 68 5f 74 68 72 65 73 |y 20.mor|ph_thres|
|00000110| 68 6f 6c 64 20 32 0a 7a | 6f 6f 6d 20 74 72 75 65 |hold 2.z|oom true|
|00000120| 0a 7a 6f 6f 6d 5f 66 61 | 63 74 6f 72 20 30 2e 38 |.zoom_fa|ctor 0.8|
|00000130| 0a 7a 6f 6f 6d 5f 6d 75 | 73 69 63 20 34 35 0a 7a |.zoom_mu|sic 45.z|
|00000140| 6f 6f 6d 5f 73 65 6e 73 | 69 74 69 76 69 74 79 20 |oom_sens|itivity |
|00000150| 31 30 30 0a 7a 6f 6f 6d | 5f 74 68 72 65 73 68 6f |100.zoom|_thresho|
|00000160| 6c 64 20 33 30 0a 72 6f | 74 61 74 65 20 74 72 75 |ld 30.ro|tate tru|
|00000170| 65 0a 73 70 69 6e 5f 6d | 69 6e 20 30 2e 30 34 0a |e.spin_m|in 0.04.|
|00000180| 73 70 69 6e 5f 6d 61 78 | 20 30 2e 33 0a 73 70 69 |spin_max| 0.3.spi|
|00000190| 6e 5f 6d 75 73 69 63 20 | 32 35 0a 73 70 69 6e 5f |n_music |25.spin_|
|000001a0| 73 65 6e 73 69 74 69 76 | 69 74 79 20 38 30 0a 73 |sensitiv|ity 80.s|
|000001b0| 70 69 6e 5f 74 68 72 65 | 73 68 6f 6c 64 20 35 0a |pin_thre|shold 5.|
|000001c0| 73 74 61 62 69 6c 69 74 | 79 20 30 2e 31 32 0a 73 |stabilit|y 0.12.s|
|000001d0| 74 61 62 69 6c 69 74 79 | 5f 6d 75 73 69 63 20 30 |tability|_music 0|
|000001e0| 0a 73 74 61 62 69 6c 69 | 74 79 5f 73 65 6e 73 69 |.stabili|ty_sensi|
|000001f0| 74 69 76 69 74 79 20 37 | 30 0a 73 74 61 62 69 6c |tivity 7|0.stabil|
|00000200| 69 74 79 5f 74 68 72 65 | 73 68 6f 6c 64 20 32 0a |ity_thre|shold 2.|
|00000210| 65 6e 64 20 2f 2f 20 44 | 61 6e 63 65 72 50 6f 70 |end // D|ancerPop|
|00000220| 20 61 74 74 72 69 62 75 | 74 65 73 0a 69 6e 64 69 | attribu|tes.indi|
|00000230| 20 64 61 6e 63 65 72 20 | 7b 0a 2f 2f 20 42 61 73 | dancer |{.// Bas|
|00000240| 65 49 6e 64 69 20 61 74 | 74 72 69 62 75 74 65 73 |eIndi at|tributes|
|00000250| 0a 2f 2f 20 44 61 6e 63 | 65 72 49 6e 64 69 41 74 |.// Danc|erIndiAt|
|00000260| 74 72 69 62 75 74 65 73 | 0a 67 65 6e 6f 6d 65 20 |tributes|.genome |
|00000270| 64 61 6e 63 65 72 20 7b | 0a 2f 2f 20 42 61 73 65 |dancer {|.// Base|
|00000280| 47 65 6e 6f 6d 65 20 61 | 74 74 72 69 62 75 74 65 |Genome a|ttribute|
|00000290| 73 0a 2f 2f 20 44 61 6e | 63 65 72 47 65 6e 6f 6d |s.// Dan|cerGenom|
|000002a0| 65 20 61 74 74 72 69 62 | 75 74 65 73 0a 70 72 6f |e attrib|utes.pro|
|000002b0| 67 0a 66 75 6e 63 20 76 | 6f 69 64 20 6d 61 69 6e |g.func v|oid main|
|000002c0| 28 29 3b 0a 66 75 6e 63 | 20 76 6f 69 64 20 77 6f |();.func| void wo|
|000002d0| 62 62 6c 65 28 29 3b 0a | 66 75 6e 63 20 76 6f 69 |bble();.|func voi|
|000002e0| 64 20 66 6c 6f 77 65 72 | 28 29 3b 0a 66 75 6e 63 |d flower|();.func|
|000002f0| 20 76 6f 69 64 20 62 75 | 69 6c 64 43 53 70 61 63 | void bu|ildCSpac|
|00000300| 65 41 28 20 69 6e 74 20 | 69 6e 64 65 78 20 29 3b |eA( int |index );|
|00000310| 0a 66 75 6e 63 20 76 6f | 69 64 20 62 75 69 6c 64 |.func vo|id build|
|00000320| 43 53 70 61 63 65 42 28 | 20 69 6e 74 20 69 6e 64 |CSpaceB(| int ind|
|00000330| 65 78 20 29 3b 0a 66 75 | 6e 63 20 76 6f 69 64 20 |ex );.fu|nc void |
|00000340| 6d 61 69 6e 28 29 20 7b | 0a 64 61 74 61 20 6e 75 |main() {|.data nu|
|00000350| 6d 20 77 61 6e 67 20 3d | 20 5b 30 2e 36 32 32 36 |m wang =| [0.6226|
|00000360| 34 36 5d 3a 5b 2d 32 5d | 3a 5b 32 5d 3b 20 0a 62 |46]:[-2]|:[2]; .b|
|00000370| 75 69 6c 64 43 53 70 61 | 63 65 41 28 5b 30 5d 29 |uildCSpa|ceA([0])|
|00000380| 3b 0a 62 75 69 6c 64 43 | 53 70 61 63 65 42 28 5b |;.buildC|SpaceB([|
|00000390| 31 5d 29 3b 0a 73 65 74 | 5f 73 68 69 6e 65 28 5b |1]);.set|_shine([|
|000003a0| 33 5d 29 3b 0a 73 65 74 | 5f 73 68 61 72 70 28 5b |3]);.set|_sharp([|
|000003b0| 31 30 30 5d 29 3b 0a 77 | 6f 62 62 6c 65 28 29 3b |100]);.w|obble();|
|000003c0| 0a 70 69 74 63 68 28 77 | 61 6e 67 29 3b 0a 66 6c |.pitch(w|ang);.fl|
|000003d0| 6f 77 65 72 28 29 3b 0a | 70 69 74 63 68 28 2d 77 |ower();.|pitch(-w|
|000003e0| 61 6e 67 29 3b 0a 79 61 | 77 28 5b 33 2e 31 34 31 |ang);.ya|w([3.141|
|000003f0| 35 39 5d 29 3b 0a 77 6f | 62 62 6c 65 28 29 3b 0a |59]);.wo|bble();.|
|00000400| 70 69 74 63 68 28 77 61 | 6e 67 29 3b 0a 66 6c 6f |pitch(wa|ng);.flo|
|00000410| 77 65 72 28 29 3b 0a 70 | 69 74 63 68 28 2d 77 61 |wer();.p|itch(-wa|
|00000420| 6e 67 29 3b 0a 79 61 77 | 28 5b 31 2e 35 37 5d 29 |ng);.yaw|([1.57])|
|00000430| 3b 0a 77 6f 62 62 6c 65 | 28 29 3b 0a 70 69 74 63 |;.wobble|();.pitc|
|00000440| 68 28 77 61 6e 67 29 3b | 0a 66 6c 6f 77 65 72 28 |h(wang);|.flower(|
|00000450| 29 3b 0a 70 69 74 63 68 | 28 2d 77 61 6e 67 29 3b |);.pitch|(-wang);|
|00000460| 0a 79 61 77 28 5b 33 2e | 31 34 31 35 39 5d 29 3b |.yaw([3.|14159]);|
|00000470| 0a 77 6f 62 62 6c 65 28 | 29 3b 0a 70 69 74 63 68 |.wobble(|);.pitch|
|00000480| 28 77 61 6e 67 29 3b 0a | 66 6c 6f 77 65 72 28 29 |(wang);.|flower()|
|00000490| 3b 0a 70 69 74 63 68 28 | 2d 77 61 6e 67 29 3b 0a |;.pitch(|-wang);.|
|000004a0| 7d 0a 66 75 6e 63 20 76 | 6f 69 64 20 77 6f 62 62 |}.func v|oid wobb|
|000004b0| 6c 65 28 29 20 7b 0a 70 | 75 73 68 28 29 3b 0a 64 |le() {.p|ush();.d|
|000004c0| 61 74 61 20 6e 75 6d 20 | 73 65 67 73 20 3d 20 5b |ata num |segs = [|
|000004d0| 33 30 5d 3b 20 0a 64 61 | 74 61 20 6e 75 6d 20 73 |30]; .da|ta num s|
|000004e0| 74 65 70 20 3d 20 5b 30 | 2e 35 31 31 31 38 37 5d |tep = [0|.511187]|
|000004f0| 3a 5b 2d 31 2e 35 5d 3a | 5b 32 5d 3b 20 0a 64 61 |:[-1.5]:|[2]; .da|
|00000500| 74 61 20 6e 75 6d 20 66 | 61 63 74 3b 20 0a 64 61 |ta num f|act; .da|
|00000510| 74 61 20 6e 75 6d 20 6c | 6f 63 75 73 31 3b 20 0a |ta num l|ocus1; .|
|00000520| 64 61 74 61 20 6e 75 6d | 20 74 68 69 6b 20 3d 20 |data num| thik = |
|00000530| 5b 31 2e 30 35 5d 3b 20 | 0a 64 61 74 61 20 6e 75 |[1.05]; |.data nu|
|00000540| 6d 20 62 65 6e 64 20 3d | 20 5b 2d 30 2e 30 33 30 |m bend =| [-0.030|
|00000550| 30 38 33 36 5d 3a 5b 2d | 30 2e 31 5d 3a 5b 30 2e |0836]:[-|0.1]:[0.|
|00000560| 31 5d 3b 20 0a 64 61 74 | 61 20 76 65 63 33 20 62 |1]; .dat|a vec3 b|
|00000570| 6c 6f 77 3b 20 0a 64 61 | 74 61 20 6e 75 6d 20 73 |low; .da|ta num s|
|00000580| 65 70 20 3d 20 5b 2d 31 | 2e 39 36 31 5d 3a 5b 2d |ep = [-1|.961]:[-|
|00000590| 31 35 5d 3a 5b 31 35 5d | 3b 20 0a 64 61 74 61 20 |15]:[15]|; .data |
|000005a0| 6e 75 6d 20 66 72 65 71 | 20 3d 20 5b 32 33 2e 38 |num freq| = [23.8|
|000005b0| 30 34 36 5d 3a 5b 31 35 | 5d 3a 5b 32 35 5d 3b 20 |046]:[15|]:[25]; |
|000005c0| 0a 64 61 74 61 20 6e 75 | 6d 20 66 72 65 71 32 20 |.data nu|m freq2 |
|000005d0| 3d 20 5b 39 2e 39 33 30 | 31 36 5d 3a 5b 36 5d 3a |= [9.930|16]:[6]:|
|000005e0| 5b 31 32 5d 3b 20 0a 64 | 61 74 61 20 6e 75 6d 20 |[12]; .d|ata num |
|000005f0| 77 61 76 65 3b 20 0a 64 | 61 74 61 20 6e 75 6d 20 |wave; .d|ata num |
|00000600| 64 74 20 3d 20 5b 30 2e | 31 33 38 37 38 33 5d 3a |dt = [0.|138783]:|
|00000610| 5b 2d 33 2e 31 34 31 5d | 3a 5b 33 2e 31 34 31 5d |[-3.141]|:[3.141]|
|00000620| 3b 20 0a 66 6f 72 77 61 | 72 64 28 73 65 70 29 3b |; .forwa|rd(sep);|
|00000630| 0a 65 67 67 5f 73 63 61 | 6c 65 28 5b 3c 31 2c 31 |.egg_sca|le([<1,1|
|00000640| 2c 33 2e 36 33 32 37 32 | 3e 5d 3a 5b 3c 31 2c 31 |,3.63272|>]:[<1,1|
|00000650| 2c 32 3e 5d 3a 5b 3c 31 | 2c 31 2c 35 3e 5d 29 3b |,2>]:[<1|,1,5>]);|
|00000660| 0a 66 6f 72 28 20 6e 75 | 6d 20 69 20 3d 20 5b 30 |.for( nu|m i = [0|
|00000670| 5d 3b 20 6c 65 73 73 28 | 69 2c 73 65 67 73 29 3b |]; less(|i,segs);|
|00000680| 20 28 69 2b 5b 31 5d 29 | 20 29 20 7b 0a 6c 6f 63 | (i+[1])| ) {.loc|
|00000690| 75 73 31 20 3d 20 28 69 | 2f 28 73 65 67 73 2d 5b |us1 = (i|/(segs-[|
|000006a0| 31 5d 29 29 3b 0a 77 61 | 76 65 20 3d 20 28 73 69 |1]));.wa|ve = (si|
|000006b0| 6e 28 28 28 6c 6f 63 75 | 73 31 2a 66 72 65 71 32 |n(((locu|s1*freq2|
|000006c0| 29 2b 64 74 29 29 2f 5b | 31 34 5d 29 3b 0a 66 61 |)+dt))/[|14]);.fa|
|000006d0| 63 74 20 3d 20 28 5b 31 | 5d 2b 28 73 69 6e 28 28 |ct = ([1|]+(sin((|
|000006e0| 6c 6f 63 75 73 31 2a 66 | 72 65 71 29 29 2f 5b 32 |locus1*f|req))/[2|
|000006f0| 5d 29 29 3b 0a 62 6c 6f | 77 20 3d 20 76 33 6d 61 |]));.blo|w = v3ma|
|00000700| 6b 65 28 66 61 63 74 2c | 66 61 63 74 2c 74 68 69 |ke(fact,|fact,thi|
|00000710| 6b 29 3b 0a 73 65 74 5f | 70 72 69 6d 28 5b 34 5d |k);.set_|prim([4]|
|00000720| 29 3b 0a 73 65 74 5f 63 | 6f 6c 6f 75 72 28 63 73 |);.set_c|olour(cs|
|00000730| 70 61 63 65 28 5b 30 5d | 2c 6c 6f 63 75 73 31 29 |pace([0]|,locus1)|
|00000740| 29 3b 0a 66 6f 72 77 61 | 72 64 28 73 74 65 70 29 |);.forwa|rd(step)|
|00000750| 3b 0a 65 67 67 5f 73 63 | 61 6c 65 28 62 6c 6f 77 |;.egg_sc|ale(blow|
|00000760| 29 3b 0a 79 61 77 28 62 | 65 6e 64 29 3b 0a 70 69 |);.yaw(b|end);.pi|
|00000770| 74 63 68 28 77 61 76 65 | 29 3b 0a 6c 61 79 28 29 |tch(wave|);.lay()|
|00000780| 3b 0a 7d 20 0a 70 6f 70 | 28 29 3b 0a 7d 0a 66 75 |;.} .pop|();.}.fu|
|00000790| 6e 63 20 76 6f 69 64 20 | 66 6c 6f 77 65 72 28 29 |nc void |flower()|
|000007a0| 20 7b 0a 70 75 73 68 28 | 29 3b 0a 73 65 74 5f 70 | {.push(|);.set_p|
|000007b0| 72 69 6d 28 5b 33 5d 29 | 3b 0a 64 61 74 61 20 6e |rim([3])|;.data n|
|000007c0| 75 6d 20 70 65 74 73 20 | 3d 20 5b 31 31 2e 31 37 |um pets |= [11.17|
|000007d0| 37 36 5d 3a 5b 34 5d 3a | 5b 31 35 5d 3b 20 0a 64 |76]:[4]:|[15]; .d|
|000007e0| 61 74 61 20 6e 75 6d 20 | 64 41 20 3d 20 5b 30 2e |ata num |dA = [0.|
|000007f0| 30 33 33 39 32 32 37 5d | 3a 5b 2d 30 2e 31 5d 3a |0339227]|:[-0.1]:|
|00000800| 5b 30 2e 33 5d 3b 20 0a | 64 61 74 61 20 6e 75 6d |[0.3]; .|data num|
|00000810| 20 64 42 20 3d 20 5b 30 | 2e 31 37 34 32 33 5d 3a | dB = [0|.17423]:|
|00000820| 5b 2d 30 2e 31 5d 3a 5b | 31 2e 35 5d 3b 20 0a 64 |[-0.1]:[|1.5]; .d|
|00000830| 61 74 61 20 6e 75 6d 20 | 70 65 74 61 6c 65 6e 20 |ata num |petalen |
|00000840| 3d 20 5b 38 2e 35 31 30 | 38 38 5d 3a 5b 34 5d 3a |= [8.510|88]:[4]:|
|00000850| 5b 31 32 5d 3b 20 0a 64 | 61 74 61 20 6e 75 6d 20 |[12]; .d|ata num |
|00000860| 69 6e 70 65 74 61 6c 65 | 6e 20 3d 20 28 5b 31 5d |inpetale|n = ([1]|
|00000870| 2f 70 65 74 61 6c 65 6e | 29 3b 20 0a 64 61 74 61 |/petalen|); .data|
|00000880| 20 6e 75 6d 20 6c 6f 63 | 75 73 32 3b 20 0a 64 61 | num loc|us2; .da|
|00000890| 74 61 20 6e 75 6d 20 6c | 65 6e 20 3d 20 5b 31 36 |ta num l|en = [16|
|000008a0| 2e 33 37 34 35 5d 3a 5b | 31 35 5d 3a 5b 33 35 5d |.3745]:[|15]:[35]|
|000008b0| 3b 20 0a 64 61 74 61 20 | 6e 75 6d 20 62 75 64 20 |; .data |num bud |
|000008c0| 3d 20 5b 37 2e 30 34 31 | 33 31 5d 3a 5b 34 5d 3a |= [7.041|31]:[4]:|
|000008d0| 5b 39 5d 3b 20 0a 64 61 | 74 61 20 6e 75 6d 20 66 |[9]; .da|ta num f|
|000008e0| 61 6e 67 20 3d 20 5b 30 | 2e 32 32 33 37 36 35 5d |ang = [0|.223765]|
|000008f0| 3a 5b 2d 31 5d 3a 5b 31 | 2e 35 5d 3b 20 0a 64 61 |:[-1]:[1|.5]; .da|
|00000900| 74 61 20 76 65 63 33 20 | 73 74 72 65 74 63 68 3b |ta vec3 |stretch;|
|00000910| 20 0a 64 61 74 61 20 76 | 65 63 33 20 69 6e 73 74 | .data v|ec3 inst|
|00000920| 72 65 74 63 68 3b 20 0a | 73 74 72 65 74 63 68 20 |retch; .|stretch |
|00000930| 3d 20 76 33 6d 61 6b 65 | 28 5b 31 5d 2c 5b 31 5d |= v3make|([1],[1]|
|00000940| 2c 70 65 74 61 6c 65 6e | 29 3b 0a 69 6e 73 74 72 |,petalen|);.instr|
|00000950| 65 74 63 68 20 3d 20 76 | 33 6d 61 6b 65 28 5b 31 |etch = v|3make([1|
|00000960| 5d 2c 5b 31 5d 2c 69 6e | 70 65 74 61 6c 65 6e 29 |],[1],in|petalen)|
|00000970| 3b 0a 66 6f 72 77 61 72 | 64 28 6c 65 6e 29 3b 0a |;.forwar|d(len);.|
|00000980| 75 73 63 61 6c 65 28 5b | 31 2e 32 5d 29 3b 0a 79 |uscale([|1.2]);.y|
|00000990| 61 77 28 66 61 6e 67 29 | 3b 0a 65 67 67 5f 73 63 |aw(fang)|;.egg_sc|
|000009a0| 61 6c 65 28 73 74 72 65 | 74 63 68 29 3b 0a 66 6f |ale(stre|tch);.fo|
|000009b0| 72 28 20 6e 75 6d 20 69 | 20 3d 20 5b 30 5d 3b 20 |r( num i| = [0]; |
|000009c0| 6c 65 73 73 28 69 2c 70 | 65 74 73 29 3b 20 28 69 |less(i,p|ets); (i|
|000009d0| 2b 5b 31 5d 29 20 29 20 | 7b 0a 6c 6f 63 75 73 32 |+[1]) ) |{.locus2|
|000009e0| 20 3d 20 28 69 2f 28 70 | 65 74 73 2d 5b 31 5d 29 | = (i/(p|ets-[1])|
|000009f0| 29 3b 0a 75 73 63 61 6c | 65 28 5b 31 2e 30 35 5d |);.uscal|e([1.05]|
|00000a00| 29 3b 0a 70 69 74 63 68 | 28 64 41 29 3b 0a 79 61 |);.pitch|(dA);.ya|
|00000a10| 77 28 64 42 29 3b 0a 73 | 65 74 5f 63 6f 6c 6f 75 |w(dB);.s|et_colou|
|00000a20| 72 28 63 73 70 61 63 65 | 28 5b 31 5d 2c 6c 6f 63 |r(cspace|([1],loc|
|00000a30| 75 73 32 29 29 3b 0a 6c | 61 79 28 29 3b 0a 70 75 |us2));.l|ay();.pu|
|00000a40| 73 68 28 29 3b 0a 65 67 | 67 5f 73 63 61 6c 65 28 |sh();.eg|g_scale(|
|00000a50| 69 6e 73 74 72 65 74 63 | 68 29 3b 0a 66 6f 72 77 |instretc|h);.forw|
|00000a60| 61 72 64 28 62 75 64 29 | 3b 0a 6c 61 79 28 29 3b |ard(bud)|;.lay();|
|00000a70| 0a 70 6f 70 28 29 3b 0a | 7d 20 0a 70 6f 70 28 29 |.pop();.|} .pop()|
|00000a80| 3b 0a 7d 0a 66 75 6e 63 | 20 76 6f 69 64 20 62 75 |;.}.func| void bu|
|00000a90| 69 6c 64 43 53 70 61 63 | 65 41 28 20 69 6e 74 20 |ildCSpac|eA( int |
|00000aa0| 69 6e 64 65 78 20 29 20 | 7b 0a 64 61 74 61 20 63 |index ) |{.data c|
|00000ab0| 6f 6c 6f 75 72 20 63 31 | 20 3d 20 5b 3c 30 2e 32 |olour c1| = [<0.2|
|00000ac0| 35 37 36 37 32 2c 30 2e | 36 36 32 36 37 34 2c 30 |57672,0.|662674,0|
|00000ad0| 2e 39 37 30 31 35 39 2c | 30 2e 38 37 31 34 39 38 |.970159,|0.871498|
|00000ae0| 3e 5d 3a 5b 3c 30 2c 30 | 2c 30 2e 37 2c 30 3e 5d |>]:[<0,0|,0.7,0>]|
|00000af0| 3a 5b 3c 31 2c 31 2c 31 | 2c 31 3e 5d 3b 20 0a 64 |:[<1,1,1|,1>]; .d|
|00000b00| 61 74 61 20 63 6f 6c 6f | 75 72 20 63 32 20 3d 20 |ata colo|ur c2 = |
|00000b10| 5b 3c 30 2e 36 36 34 38 | 33 36 2c 30 2e 33 39 35 |[<0.6648|36,0.395|
|00000b20| 37 34 36 2c 30 2e 33 37 | 36 39 2c 30 2e 36 31 31 |746,0.37|69,0.611|
|00000b30| 35 35 37 3e 5d 3a 5b 3c | 30 2c 30 2c 30 2c 30 3e |557>]:[<|0,0,0,0>|
|00000b40| 5d 3a 5b 3c 31 2c 31 2c | 31 2c 31 3e 5d 3b 20 0a |]:[<1,1,|1,1>]; .|
|00000b50| 64 61 74 61 20 63 6f 6c | 6f 75 72 20 63 33 20 3d |data col|our c3 =|
|00000b60| 20 5b 3c 30 2e 35 32 38 | 36 37 34 2c 30 2e 37 30 | [<0.528|674,0.70|
|00000b70| 39 30 34 37 2c 30 2e 39 | 30 39 38 39 35 2c 30 2e |9047,0.9|09895,0.|
|00000b80| 34 31 33 39 32 35 3e 5d | 3a 5b 3c 30 2c 30 2c 30 |413925>]|:[<0,0,0|
|00000b90| 2e 37 2c 30 3e 5d 3a 5b | 3c 31 2c 31 2c 31 2c 31 |.7,0>]:[|<1,1,1,1|
|00000ba0| 3e 5d 3b 20 0a 69 6e 69 | 74 5f 63 73 70 61 63 65 |>]; .ini|t_cspace|
|00000bb0| 28 69 6e 64 65 78 2c 63 | 31 29 3b 0a 65 78 74 65 |(index,c|1);.exte|
|00000bc0| 6e 64 5f 63 73 70 61 63 | 65 28 69 6e 64 65 78 2c |nd_cspac|e(index,|
|00000bd0| 5b 30 2e 35 5d 2c 63 32 | 29 3b 0a 65 78 74 65 6e |[0.5],c2|);.exten|
|00000be0| 64 5f 63 73 70 61 63 65 | 28 69 6e 64 65 78 2c 5b |d_cspace|(index,[|
|00000bf0| 30 2e 35 5d 2c 63 33 29 | 3b 0a 7d 0a 66 75 6e 63 |0.5],c3)|;.}.func|
|00000c00| 20 76 6f 69 64 20 62 75 | 69 6c 64 43 53 70 61 63 | void bu|ildCSpac|
|00000c10| 65 42 28 20 69 6e 74 20 | 69 6e 64 65 78 20 29 20 |eB( int |index ) |
|00000c20| 7b 0a 64 61 74 61 20 63 | 6f 6c 6f 75 72 20 63 30 |{.data c|olour c0|
|00000c30| 20 3d 20 5b 3c 30 2e 37 | 38 36 30 39 33 2c 30 2e | = [<0.7|86093,0.|
|00000c40| 39 32 37 34 37 36 2c 30 | 2e 38 36 39 36 32 31 2c |927476,0|.869621,|
|00000c50| 30 3e 5d 3a 5b 3c 30 2c | 30 2c 30 2c 30 3e 5d 3a |0>]:[<0,|0,0,0>]:|
|00000c60| 5b 3c 31 2c 31 2c 31 2c | 30 3e 5d 3b 20 0a 64 61 |[<1,1,1,|0>]; .da|
|00000c70| 74 61 20 63 6f 6c 6f 75 | 72 20 63 31 20 3d 20 5b |ta colou|r c1 = [|
|00000c80| 3c 30 2e 36 37 39 36 31 | 38 2c 30 2e 37 34 36 35 |<0.67961|8,0.7465|
|00000c90| 34 39 2c 30 2e 39 39 39 | 39 39 2c 30 2e 39 39 39 |49,0.999|99,0.999|
|00000ca0| 39 39 3e 5d 3a 5b 3c 30 | 2c 30 2e 34 2c 30 2e 39 |99>]:[<0|,0.4,0.9|
|00000cb0| 39 39 39 39 2c 30 2e 39 | 39 39 39 39 3e 5d 3a 5b |9999,0.9|9999>]:[|
|00000cc0| 3c 30 2e 39 39 39 39 39 | 2c 30 2e 39 39 39 39 39 |<0.99999|,0.99999|
|00000cd0| 2c 30 2e 39 39 39 39 39 | 2c 30 2e 39 39 39 39 39 |,0.99999|,0.99999|
|00000ce0| 3e 5d 3b 20 0a 64 61 74 | 61 20 63 6f 6c 6f 75 72 |>]; .dat|a colour|
|00000cf0| 20 63 32 20 3d 20 5b 3c | 30 2e 35 30 38 33 39 31 | c2 = [<|0.508391|
|00000d00| 2c 30 2e 33 31 32 34 32 | 33 2c 30 2e 32 34 30 32 |,0.31242|3,0.2402|
|00000d10| 31 37 2c 30 3e 5d 3a 5b | 3c 30 2c 30 2c 30 2c 30 |17,0>]:[|<0,0,0,0|
|00000d20| 3e 5d 3a 5b 3c 31 2c 31 | 2c 31 2c 30 3e 5d 3b 20 |>]:[<1,1|,1,0>]; |
|00000d30| 0a 64 61 74 61 20 63 6f | 6c 6f 75 72 20 63 33 20 |.data co|lour c3 |
|00000d40| 3d 20 5b 3c 30 2e 35 33 | 38 31 35 31 2c 30 2e 37 |= [<0.53|8151,0.7|
|00000d50| 35 35 36 33 33 2c 30 2e | 39 39 39 39 39 2c 30 2e |55633,0.|99999,0.|
|00000d60| 39 39 39 39 39 3e 5d 3a | 5b 3c 30 2c 30 2e 34 2c |99999>]:|[<0,0.4,|
|00000d70| 30 2e 39 39 39 39 39 2c | 30 2e 39 39 39 39 39 3e |0.99999,|0.99999>|
|00000d80| 5d 3a 5b 3c 30 2e 39 39 | 39 39 39 2c 30 2e 39 39 |]:[<0.99|999,0.99|
|00000d90| 39 39 39 2c 30 2e 39 39 | 39 39 39 2c 30 2e 39 39 |999,0.99|999,0.99|
|00000da0| 39 39 39 3e 5d 3b 20 0a | 64 61 74 61 20 6e 75 6d |999>]; .|data num|
|00000db0| 20 64 65 6c 74 61 31 20 | 3d 20 5b 30 2e 34 31 39 | delta1 |= [0.419|
|00000dc0| 33 33 38 5d 3a 5b 30 2e | 32 35 5d 3a 5b 31 5d 3b |338]:[0.|25]:[1];|
|00000dd0| 20 0a 64 61 74 61 20 6e | 75 6d 20 64 65 6c 74 61 | .data n|um delta|
|00000de0| 32 20 3d 20 5b 30 2e 38 | 33 32 36 39 32 5d 3a 5b |2 = [0.8|32692]:[|
|00000df0| 30 2e 32 35 5d 3a 5b 31 | 5d 3b 20 0a 64 61 74 61 |0.25]:[1|]; .data|
|00000e00| 20 6e 75 6d 20 64 65 6c | 74 61 33 20 3d 20 5b 30 | num del|ta3 = [0|
|00000e10| 2e 36 32 36 38 34 31 5d | 3a 5b 30 2e 32 35 5d 3a |.626841]|:[0.25]:|
|00000e20| 5b 31 5d 3b 20 0a 69 6e | 69 74 5f 63 73 70 61 63 |[1]; .in|it_cspac|
|00000e30| 65 28 69 6e 64 65 78 2c | 63 30 29 3b 0a 65 78 74 |e(index,|c0);.ext|
|00000e40| 65 6e 64 5f 63 73 70 61 | 63 65 28 69 6e 64 65 78 |end_cspa|ce(index|
|00000e50| 2c 64 65 6c 74 61 31 2c | 63 31 29 3b 0a 65 78 74 |,delta1,|c1);.ext|
|00000e60| 65 6e 64 5f 63 73 70 61 | 63 65 28 69 6e 64 65 78 |end_cspa|ce(index|
|00000e70| 2c 64 65 6c 74 61 32 2c | 63 32 29 3b 0a 65 78 74 |,delta2,|c2);.ext|
|00000e80| 65 6e 64 5f 63 73 70 61 | 63 65 28 69 6e 64 65 78 |end_cspa|ce(index|
|00000e90| 2c 64 65 6c 74 61 33 2c | 63 33 29 3b 0a 7d 0a 7d |,delta3,|c3);.}.}|
|00000ea0| 20 0a 7d 20 69 6e 64 69 | 20 64 61 6e 63 65 72 20 | .} indi| dancer |
|00000eb0| 7b 0a 2f 2f 20 42 61 73 | 65 49 6e 64 69 20 61 74 |{.// Bas|eIndi at|
|00000ec0| 74 72 69 62 75 74 65 73 | 0a 2f 2f 20 44 61 6e 63 |tributes|.// Danc|
|00000ed0| 65 72 49 6e 64 69 41 74 | 74 72 69 62 75 74 65 73 |erIndiAt|tributes|
|00000ee0| 0a 67 65 6e 6f 6d 65 20 | 64 61 6e 63 65 72 20 7b |.genome |dancer {|
|00000ef0| 0a 2f 2f 20 42 61 73 65 | 47 65 6e 6f 6d 65 20 61 |.// Base|Genome a|
|00000f00| 74 74 72 69 62 75 74 65 | 73 0a 2f 2f 20 44 61 6e |ttribute|s.// Dan|
|00000f10| 63 65 72 47 65 6e 6f 6d | 65 20 61 74 74 72 69 62 |cerGenom|e attrib|
|00000f20| 75 74 65 73 0a 70 72 6f | 67 0a 66 75 6e 63 20 76 |utes.pro|g.func v|
|00000f30| 6f 69 64 20 6d 61 69 6e | 28 29 3b 0a 66 75 6e 63 |oid main|();.func|
|00000f40| 20 76 6f 69 64 20 77 6f | 62 62 6c 65 28 29 3b 0a | void wo|bble();.|
|00000f50| 66 75 6e 63 20 76 6f 69 | 64 20 66 6c 6f 77 65 72 |func voi|d flower|
|00000f60| 28 29 3b 0a 66 75 6e 63 | 20 76 6f 69 64 20 62 75 |();.func| void bu|
|00000f70| 69 6c 64 43 53 70 61 63 | 65 41 28 20 69 6e 74 20 |ildCSpac|eA( int |
|00000f80| 69 6e 64 65 78 20 29 3b | 0a 66 75 6e 63 20 76 6f |index );|.func vo|
|00000f90| 69 64 20 62 75 69 6c 64 | 43 53 70 61 63 65 42 28 |id build|CSpaceB(|
|00000fa0| 20 69 6e 74 20 69 6e 64 | 65 78 20 29 3b 0a 66 75 | int ind|ex );.fu|
|00000fb0| 6e 63 20 76 6f 69 64 20 | 6d 61 69 6e 28 29 20 7b |nc void |main() {|
|00000fc0| 0a 64 61 74 61 20 6e 75 | 6d 20 77 61 6e 67 20 3d |.data nu|m wang =|
|00000fd0| 20 5b 30 2e 30 37 32 31 | 39 30 32 5d 3a 5b 2d 32 | [0.0721|902]:[-2|
|00000fe0| 5d 3a 5b 32 5d 3b 20 0a | 62 75 69 6c 64 43 53 70 |]:[2]; .|buildCSp|
|00000ff0| 61 63 65 41 28 5b 30 5d | 29 3b 0a 62 75 69 6c 64 |aceA([0]|);.build|
|00001000| 43 53 70 61 63 65 42 28 | 5b 31 5d 29 3b 0a 73 65 |CSpaceB(|[1]);.se|
|00001010| 74 5f 73 68 69 6e 65 28 | 5b 33 5d 29 3b 0a 73 65 |t_shine(|[3]);.se|
|00001020| 74 5f 73 68 61 72 70 28 | 5b 31 30 30 5d 29 3b 0a |t_sharp(|[100]);.|
|00001030| 77 6f 62 62 6c 65 28 29 | 3b 0a 70 69 74 63 68 28 |wobble()|;.pitch(|
|00001040| 77 61 6e 67 29 3b 0a 66 | 6c 6f 77 65 72 28 29 3b |wang);.f|lower();|
|00001050| 0a 70 69 74 63 68 28 2d | 77 61 6e 67 29 3b 0a 79 |.pitch(-|wang);.y|
|00001060| 61 77 28 5b 33 2e 31 34 | 31 35 39 5d 29 3b 0a 77 |aw([3.14|159]);.w|
|00001070| 6f 62 62 6c 65 28 29 3b | 0a 70 69 74 63 68 28 77 |obble();|.pitch(w|
|00001080| 61 6e 67 29 3b 0a 66 6c | 6f 77 65 72 28 29 3b 0a |ang);.fl|ower();.|
|00001090| 70 69 74 63 68 28 2d 77 | 61 6e 67 29 3b 0a 79 61 |pitch(-w|ang);.ya|
|000010a0| 77 28 5b 31 2e 35 37 5d | 29 3b 0a 77 6f 62 62 6c |w([1.57]|);.wobbl|
|000010b0| 65 28 29 3b 0a 70 69 74 | 63 68 28 77 61 6e 67 29 |e();.pit|ch(wang)|
|000010c0| 3b 0a 66 6c 6f 77 65 72 | 28 29 3b 0a 70 69 74 63 |;.flower|();.pitc|
|000010d0| 68 28 2d 77 61 6e 67 29 | 3b 0a 79 61 77 28 5b 33 |h(-wang)|;.yaw([3|
|000010e0| 2e 31 34 31 35 39 5d 29 | 3b 0a 77 6f 62 62 6c 65 |.14159])|;.wobble|
|000010f0| 28 29 3b 0a 70 69 74 63 | 68 28 77 61 6e 67 29 3b |();.pitc|h(wang);|
|00001100| 0a 66 6c 6f 77 65 72 28 | 29 3b 0a 70 69 74 63 68 |.flower(|);.pitch|
|00001110| 28 2d 77 61 6e 67 29 3b | 0a 7d 0a 66 75 6e 63 20 |(-wang);|.}.func |
|00001120| 76 6f 69 64 20 77 6f 62 | 62 6c 65 28 29 20 7b 0a |void wob|ble() {.|
|00001130| 70 75 73 68 28 29 3b 0a | 64 61 74 61 20 6e 75 6d |push();.|data num|
|00001140| 20 73 65 67 73 20 3d 20 | 5b 33 30 5d 3b 20 0a 64 | segs = |[30]; .d|
|00001150| 61 74 61 20 6e 75 6d 20 | 73 74 65 70 20 3d 20 5b |ata num |step = [|
|00001160| 30 2e 38 34 38 36 35 32 | 5d 3a 5b 2d 31 2e 35 5d |0.848652|]:[-1.5]|
|00001170| 3a 5b 32 5d 3b 20 0a 64 | 61 74 61 20 6e 75 6d 20 |:[2]; .d|ata num |
|00001180| 66 61 63 74 3b 20 0a 64 | 61 74 61 20 6e 75 6d 20 |fact; .d|ata num |
|00001190| 6c 6f 63 75 73 31 3b 20 | 0a 64 61 74 61 20 6e 75 |locus1; |.data nu|
|000011a0| 6d 20 74 68 69 6b 20 3d | 20 5b 31 2e 30 35 5d 3b |m thik =| [1.05];|
|000011b0| 20 0a 64 61 74 61 20 6e | 75 6d 20 62 65 6e 64 20 | .data n|um bend |
|000011c0| 3d 20 5b 2d 30 2e 30 34 | 32 31 33 32 5d 3a 5b 2d |= [-0.04|2132]:[-|
|000011d0| 30 2e 31 5d 3a 5b 30 2e | 31 5d 3b 20 0a 64 61 74 |0.1]:[0.|1]; .dat|
|000011e0| 61 20 76 65 63 33 20 62 | 6c 6f 77 3b 20 0a 64 61 |a vec3 b|low; .da|
|000011f0| 74 61 20 6e 75 6d 20 73 | 65 70 20 3d 20 5b 2d 33 |ta num s|ep = [-3|
|00001200| 2e 38 36 32 39 31 5d 3a | 5b 2d 31 35 5d 3a 5b 31 |.86291]:|[-15]:[1|
|00001210| 35 5d 3b 20 0a 64 61 74 | 61 20 6e 75 6d 20 66 72 |5]; .dat|a num fr|
|00001220| 65 71 20 3d 20 5b 32 33 | 2e 39 39 39 33 5d 3a 5b |eq = [23|.9993]:[|
|00001230| 31 35 5d 3a 5b 32 35 5d | 3b 20 0a 64 61 74 61 20 |15]:[25]|; .data |
|00001240| 6e 75 6d 20 66 72 65 71 | 32 20 3d 20 5b 39 2e 33 |num freq|2 = [9.3|
|00001250| 38 32 39 34 5d 3a 5b 36 | 5d 3a 5b 31 32 5d 3b 20 |8294]:[6|]:[12]; |
|00001260| 0a 64 61 74 61 20 6e 75 | 6d 20 77 61 76 65 3b 20 |.data nu|m wave; |
|00001270| 0a 64 61 74 61 20 6e 75 | 6d 20 64 74 20 3d 20 5b |.data nu|m dt = [|
|00001280| 2d 31 2e 30 32 39 36 5d | 3a 5b 2d 33 2e 31 34 31 |-1.0296]|:[-3.141|
|00001290| 5d 3a 5b 33 2e 31 34 31 | 5d 3b 20 0a 66 6f 72 77 |]:[3.141|]; .forw|
|000012a0| 61 72 64 28 73 65 70 29 | 3b 0a 65 67 67 5f 73 63 |ard(sep)|;.egg_sc|
|000012b0| 61 6c 65 28 5b 3c 31 2c | 31 2c 33 2e 36 36 38 35 |ale([<1,|1,3.6685|
|000012c0| 36 3e 5d 3a 5b 3c 31 2c | 31 2c 32 3e 5d 3a 5b 3c |6>]:[<1,|1,2>]:[<|
|000012d0| 31 2c 31 2c 35 3e 5d 29 | 3b 0a 66 6f 72 28 20 6e |1,1,5>])|;.for( n|
|000012e0| 75 6d 20 69 20 3d 20 5b | 30 5d 3b 20 6c 65 73 73 |um i = [|0]; less|
|000012f0| 28 69 2c 73 65 67 73 29 | 3b 20 28 69 2b 5b 31 5d |(i,segs)|; (i+[1]|
|00001300| 29 20 29 20 7b 0a 6c 6f | 63 75 73 31 20 3d 20 28 |) ) {.lo|cus1 = (|
|00001310| 69 2f 28 73 65 67 73 2d | 5b 31 5d 29 29 3b 0a 77 |i/(segs-|[1]));.w|
|00001320| 61 76 65 20 3d 20 28 73 | 69 6e 28 28 28 6c 6f 63 |ave = (s|in(((loc|
|00001330| 75 73 31 2a 66 72 65 71 | 32 29 2b 64 74 29 29 2f |us1*freq|2)+dt))/|
|00001340| 5b 31 34 5d 29 3b 0a 66 | 61 63 74 20 3d 20 28 5b |[14]);.f|act = ([|
|00001350| 31 5d 2b 28 73 69 6e 28 | 28 6c 6f 63 75 73 31 2a |1]+(sin(|(locus1*|
|00001360| 66 72 65 71 29 29 2f 5b | 32 5d 29 29 3b 0a 62 6c |freq))/[|2]));.bl|
|00001370| 6f 77 20 3d 20 76 33 6d | 61 6b 65 28 66 61 63 74 |ow = v3m|ake(fact|
|00001380| 2c 66 61 63 74 2c 74 68 | 69 6b 29 3b 0a 73 65 74 |,fact,th|ik);.set|
|00001390| 5f 70 72 69 6d 28 5b 34 | 5d 29 3b 0a 73 65 74 5f |_prim([4|]);.set_|
|000013a0| 63 6f 6c 6f 75 72 28 63 | 73 70 61 63 65 28 5b 30 |colour(c|space([0|
|000013b0| 5d 2c 6c 6f 63 75 73 31 | 29 29 3b 0a 66 6f 72 77 |],locus1|));.forw|
|000013c0| 61 72 64 28 73 74 65 70 | 29 3b 0a 65 67 67 5f 73 |ard(step|);.egg_s|
|000013d0| 63 61 6c 65 28 62 6c 6f | 77 29 3b 0a 79 61 77 28 |cale(blo|w);.yaw(|
|000013e0| 62 65 6e 64 29 3b 0a 70 | 69 74 63 68 28 77 61 76 |bend);.p|itch(wav|
|000013f0| 65 29 3b 0a 6c 61 79 28 | 29 3b 0a 7d 20 0a 70 6f |e);.lay(|);.} .po|
|00001400| 70 28 29 3b 0a 7d 0a 66 | 75 6e 63 20 76 6f 69 64 |p();.}.f|unc void|
|00001410| 20 66 6c 6f 77 65 72 28 | 29 20 7b 0a 70 75 73 68 | flower(|) {.push|
|00001420| 28 29 3b 0a 73 65 74 5f | 70 72 69 6d 28 5b 33 5d |();.set_|prim([3]|
|00001430| 29 3b 0a 64 61 74 61 20 | 6e 75 6d 20 70 65 74 73 |);.data |num pets|
|00001440| 20 3d 20 5b 39 2e 36 32 | 32 35 38 5d 3a 5b 34 5d | = [9.62|258]:[4]|
|00001450| 3a 5b 31 35 5d 3b 20 0a | 64 61 74 61 20 6e 75 6d |:[15]; .|data num|
|00001460| 20 64 41 20 3d 20 5b 30 | 2e 30 30 34 31 39 37 35 | dA = [0|.0041975|
|00001470| 37 5d 3a 5b 2d 30 2e 31 | 5d 3a 5b 30 2e 33 5d 3b |7]:[-0.1|]:[0.3];|
|00001480| 20 0a 64 61 74 61 20 6e | 75 6d 20 64 42 20 3d 20 | .data n|um dB = |
|00001490| 5b 30 2e 32 39 39 30 34 | 39 5d 3a 5b 2d 30 2e 31 |[0.29904|9]:[-0.1|
|000014a0| 5d 3a 5b 31 2e 35 5d 3b | 20 0a 64 61 74 61 20 6e |]:[1.5];| .data n|
|000014b0| 75 6d 20 70 65 74 61 6c | 65 6e 20 3d 20 5b 38 2e |um petal|en = [8.|
|000014c0| 37 37 31 35 31 5d 3a 5b | 34 5d 3a 5b 31 32 5d 3b |77151]:[|4]:[12];|
|000014d0| 20 0a 64 61 74 61 20 6e | 75 6d 20 69 6e 70 65 74 | .data n|um inpet|
|000014e0| 61 6c 65 6e 20 3d 20 28 | 5b 31 5d 2f 70 65 74 61 |alen = (|[1]/peta|
|000014f0| 6c 65 6e 29 3b 20 0a 64 | 61 74 61 20 6e 75 6d 20 |len); .d|ata num |
|00001500| 6c 6f 63 75 73 32 3b 20 | 0a 64 61 74 61 20 6e 75 |locus2; |.data nu|
|00001510| 6d 20 6c 65 6e 20 3d 20 | 5b 31 35 2e 30 39 37 35 |m len = |[15.0975|
|00001520| 5d 3a 5b 31 35 5d 3a 5b | 33 35 5d 3b 20 0a 64 61 |]:[15]:[|35]; .da|
|00001530| 74 61 20 6e 75 6d 20 62 | 75 64 20 3d 20 5b 36 2e |ta num b|ud = [6.|
|00001540| 37 36 34 33 5d 3a 5b 34 | 5d 3a 5b 39 5d 3b 20 0a |7643]:[4|]:[9]; .|
|00001550| 64 61 74 61 20 6e 75 6d | 20 66 61 6e 67 20 3d 20 |data num| fang = |
|00001560| 5b 30 2e 37 31 32 30 30 | 32 5d 3a 5b 2d 31 5d 3a |[0.71200|2]:[-1]:|
|00001570| 5b 31 2e 35 5d 3b 20 0a | 64 61 74 61 20 76 65 63 |[1.5]; .|data vec|
|00001580| 33 20 73 74 72 65 74 63 | 68 3b 20 0a 64 61 74 61 |3 stretc|h; .data|
|00001590| 20 76 65 63 33 20 69 6e | 73 74 72 65 74 63 68 3b | vec3 in|stretch;|
|000015a0| 20 0a 73 74 72 65 74 63 | 68 20 3d 20 76 33 6d 61 | .stretc|h = v3ma|
|000015b0| 6b 65 28 5b 31 5d 2c 5b | 31 5d 2c 70 65 74 61 6c |ke([1],[|1],petal|
|000015c0| 65 6e 29 3b 0a 69 6e 73 | 74 72 65 74 63 68 20 3d |en);.ins|tretch =|
|000015d0| 20 76 33 6d 61 6b 65 28 | 5b 31 5d 2c 5b 31 5d 2c | v3make(|[1],[1],|
|000015e0| 69 6e 70 65 74 61 6c 65 | 6e 29 3b 0a 66 6f 72 77 |inpetale|n);.forw|
|000015f0| 61 72 64 28 6c 65 6e 29 | 3b 0a 75 73 63 61 6c 65 |ard(len)|;.uscale|
|00001600| 28 5b 31 2e 32 5d 29 3b | 0a 79 61 77 28 66 61 6e |([1.2]);|.yaw(fan|
|00001610| 67 29 3b 0a 65 67 67 5f | 73 63 61 6c 65 28 73 74 |g);.egg_|scale(st|
|00001620| 72 65 74 63 68 29 3b 0a | 66 6f 72 28 20 6e 75 6d |retch);.|for( num|
|00001630| 20 69 20 3d 20 5b 30 5d | 3b 20 6c 65 73 73 28 69 | i = [0]|; less(i|
|00001640| 2c 70 65 74 73 29 3b 20 | 28 69 2b 5b 31 5d 29 20 |,pets); |(i+[1]) |
|00001650| 29 20 7b 0a 6c 6f 63 75 | 73 32 20 3d 20 28 69 2f |) {.locu|s2 = (i/|
|00001660| 28 70 65 74 73 2d 5b 31 | 5d 29 29 3b 0a 75 73 63 |(pets-[1|]));.usc|
|00001670| 61 6c 65 28 5b 31 2e 30 | 35 5d 29 3b 0a 70 69 74 |ale([1.0|5]);.pit|
|00001680| 63 68 28 64 41 29 3b 0a | 79 61 77 28 64 42 29 3b |ch(dA);.|yaw(dB);|
|00001690| 0a 73 65 74 5f 63 6f 6c | 6f 75 72 28 63 73 70 61 |.set_col|our(cspa|
|000016a0| 63 65 28 5b 31 5d 2c 6c | 6f 63 75 73 32 29 29 3b |ce([1],l|ocus2));|
|000016b0| 0a 6c 61 79 28 29 3b 0a | 70 75 73 68 28 29 3b 0a |.lay();.|push();.|
|000016c0| 65 67 67 5f 73 63 61 6c | 65 28 69 6e 73 74 72 65 |egg_scal|e(instre|
|000016d0| 74 63 68 29 3b 0a 66 6f | 72 77 61 72 64 28 62 75 |tch);.fo|rward(bu|
|000016e0| 64 29 3b 0a 6c 61 79 28 | 29 3b 0a 70 6f 70 28 29 |d);.lay(|);.pop()|
|000016f0| 3b 0a 7d 20 0a 70 6f 70 | 28 29 3b 0a 7d 0a 66 75 |;.} .pop|();.}.fu|
|00001700| 6e 63 20 76 6f 69 64 20 | 62 75 69 6c 64 43 53 70 |nc void |buildCSp|
|00001710| 61 63 65 41 28 20 69 6e | 74 20 69 6e 64 65 78 20 |aceA( in|t index |
|00001720| 29 20 7b 0a 64 61 74 61 | 20 63 6f 6c 6f 75 72 20 |) {.data| colour |
|00001730| 63 31 20 3d 20 5b 3c 30 | 2e 33 35 38 30 31 2c 30 |c1 = [<0|.35801,0|
|00001740| 2e 38 30 33 39 35 31 2c | 30 2e 39 37 31 36 31 35 |.803951,|0.971615|
|00001750| 2c 30 2e 39 30 32 33 32 | 35 3e 5d 3a 5b 3c 30 2c |,0.90232|5>]:[<0,|
|00001760| 30 2c 30 2e 37 2c 30 3e | 5d 3a 5b 3c 31 2c 31 2c |0,0.7,0>|]:[<1,1,|
|00001770| 31 2c 31 3e 5d 3b 20 0a | 64 61 74 61 20 63 6f 6c |1,1>]; .|data col|
|00001780| 6f 75 72 20 63 32 20 3d | 20 5b 3c 30 2e 36 34 30 |our c2 =| [<0.640|
|00001790| 32 32 39 2c 30 2e 33 31 | 32 36 35 35 2c 30 2e 31 |229,0.31|2655,0.1|
|000017a0| 33 38 32 30 38 2c 30 2e | 37 34 35 32 31 35 3e 5d |38208,0.|745215>]|
|000017b0| 3a 5b 3c 30 2c 30 2c 30 | 2c 30 3e 5d 3a 5b 3c 31 |:[<0,0,0|,0>]:[<1|
|000017c0| 2c 31 2c 31 2c 31 3e 5d | 3b 20 0a 64 61 74 61 20 |,1,1,1>]|; .data |
|000017d0| 63 6f 6c 6f 75 72 20 63 | 33 20 3d 20 5b 3c 30 2e |colour c|3 = [<0.|
|000017e0| 34 38 31 36 37 35 2c 30 | 2e 36 30 34 39 31 34 2c |481675,0|.604914,|
|000017f0| 30 2e 39 37 36 30 34 38 | 2c 30 2e 35 30 35 30 39 |0.976048|,0.50509|
|00001800| 33 3e 5d 3a 5b 3c 30 2c | 30 2c 30 2e 37 2c 30 3e |3>]:[<0,|0,0.7,0>|
|00001810| 5d 3a 5b 3c 31 2c 31 2c | 31 2c 31 3e 5d 3b 20 0a |]:[<1,1,|1,1>]; .|
|00001820| 69 6e 69 74 5f 63 73 70 | 61 63 65 28 69 6e 64 65 |init_csp|ace(inde|
|00001830| 78 2c 63 31 29 3b 0a 65 | 78 74 65 6e 64 5f 63 73 |x,c1);.e|xtend_cs|
|00001840| 70 61 63 65 28 69 6e 64 | 65 78 2c 5b 30 2e 35 5d |pace(ind|ex,[0.5]|
|00001850| 2c 63 32 29 3b 0a 65 78 | 74 65 6e 64 5f 63 73 70 |,c2);.ex|tend_csp|
|00001860| 61 63 65 28 69 6e 64 65 | 78 2c 5b 30 2e 35 5d 2c |ace(inde|x,[0.5],|
|00001870| 63 33 29 3b 0a 7d 0a 66 | 75 6e 63 20 76 6f 69 64 |c3);.}.f|unc void|
|00001880| 20 62 75 69 6c 64 43 53 | 70 61 63 65 42 28 20 69 | buildCS|paceB( i|
|00001890| 6e 74 20 69 6e 64 65 78 | 20 29 20 7b 0a 64 61 74 |nt index| ) {.dat|
|000018a0| 61 20 63 6f 6c 6f 75 72 | 20 63 30 20 3d 20 5b 3c |a colour| c0 = [<|
|000018b0| 30 2e 37 34 36 33 30 37 | 2c 30 2e 39 38 34 30 38 |0.746307|,0.98408|
|000018c0| 34 2c 30 2e 39 34 38 37 | 32 32 2c 30 3e 5d 3a 5b |4,0.9487|22,0>]:[|
|000018d0| 3c 30 2c 30 2c 30 2c 30 | 3e 5d 3a 5b 3c 31 2c 31 |<0,0,0,0|>]:[<1,1|
|000018e0| 2c 31 2c 30 3e 5d 3b 20 | 0a 64 61 74 61 20 63 6f |,1,0>]; |.data co|
|000018f0| 6c 6f 75 72 20 63 31 20 | 3d 20 5b 3c 30 2e 39 35 |lour c1 |= [<0.95|
|00001900| 31 32 38 2c 30 2e 36 32 | 38 32 36 36 2c 30 2e 39 |128,0.62|8266,0.9|
|00001910| 39 39 39 39 2c 30 2e 39 | 39 39 39 39 3e 5d 3a 5b |9999,0.9|9999>]:[|
|00001920| 3c 30 2c 30 2e 34 2c 30 | 2e 39 39 39 39 39 2c 30 |<0,0.4,0|.99999,0|
|00001930| 2e 39 39 39 39 39 3e 5d | 3a 5b 3c 30 2e 39 39 39 |.99999>]|:[<0.999|
|00001940| 39 39 2c 30 2e 39 39 39 | 39 39 2c 30 2e 39 39 39 |99,0.999|99,0.999|
|00001950| 39 39 2c 30 2e 39 39 39 | 39 39 3e 5d 3b 20 0a 64 |99,0.999|99>]; .d|
|00001960| 61 74 61 20 63 6f 6c 6f | 75 72 20 63 32 20 3d 20 |ata colo|ur c2 = |
|00001970| 5b 3c 30 2e 34 37 37 36 | 39 33 2c 30 2e 33 37 39 |[<0.4776|93,0.379|
|00001980| 30 33 2c 30 2e 33 32 31 | 35 32 37 2c 30 3e 5d 3a |03,0.321|527,0>]:|
|00001990| 5b 3c 30 2c 30 2c 30 2c | 30 3e 5d 3a 5b 3c 31 2c |[<0,0,0,|0>]:[<1,|
|000019a0| 31 2c 31 2c 30 3e 5d 3b | 20 0a 64 61 74 61 20 63 |1,1,0>];| .data c|
|000019b0| 6f 6c 6f 75 72 20 63 33 | 20 3d 20 5b 3c 30 2e 37 |olour c3| = [<0.7|
|000019c0| 32 31 37 34 31 2c 30 2e | 36 34 34 31 39 36 2c 30 |21741,0.|644196,0|
|000019d0| 2e 39 39 39 39 39 2c 30 | 2e 39 39 39 39 39 3e 5d |.99999,0|.99999>]|
|000019e0| 3a 5b 3c 30 2c 30 2e 34 | 2c 30 2e 39 39 39 39 39 |:[<0,0.4|,0.99999|
|000019f0| 2c 30 2e 39 39 39 39 39 | 3e 5d 3a 5b 3c 30 2e 39 |,0.99999|>]:[<0.9|
|00001a00| 39 39 39 39 2c 30 2e 39 | 39 39 39 39 2c 30 2e 39 |9999,0.9|9999,0.9|
|00001a10| 39 39 39 39 2c 30 2e 39 | 39 39 39 39 3e 5d 3b 20 |9999,0.9|9999>]; |
|00001a20| 0a 64 61 74 61 20 6e 75 | 6d 20 64 65 6c 74 61 31 |.data nu|m delta1|
|00001a30| 20 3d 20 5b 30 2e 34 36 | 31 34 30 36 5d 3a 5b 30 | = [0.46|1406]:[0|
|00001a40| 2e 32 35 5d 3a 5b 31 5d | 3b 20 0a 64 61 74 61 20 |.25]:[1]|; .data |
|00001a50| 6e 75 6d 20 64 65 6c 74 | 61 32 20 3d 20 5b 30 2e |num delt|a2 = [0.|
|00001a60| 39 38 32 32 39 33 5d 3a | 5b 30 2e 32 35 5d 3a 5b |982293]:|[0.25]:[|
|00001a70| 31 5d 3b 20 0a 64 61 74 | 61 20 6e 75 6d 20 64 65 |1]; .dat|a num de|
|00001a80| 6c 74 61 33 20 3d 20 5b | 30 2e 35 34 34 35 31 32 |lta3 = [|0.544512|
|00001a90| 5d 3a 5b 30 2e 32 35 5d | 3a 5b 31 5d 3b 20 0a 69 |]:[0.25]|:[1]; .i|
|00001aa0| 6e 69 74 5f 63 73 70 61 | 63 65 28 69 6e 64 65 78 |nit_cspa|ce(index|
|00001ab0| 2c 63 30 29 3b 0a 65 78 | 74 65 6e 64 5f 63 73 70 |,c0);.ex|tend_csp|
|00001ac0| 61 63 65 28 69 6e 64 65 | 78 2c 64 65 6c 74 61 31 |ace(inde|x,delta1|
|00001ad0| 2c 63 31 29 3b 0a 65 78 | 74 65 6e 64 5f 63 73 70 |,c1);.ex|tend_csp|
|00001ae0| 61 63 65 28 69 6e 64 65 | 78 2c 64 65 6c 74 61 32 |ace(inde|x,delta2|
|00001af0| 2c 63 32 29 3b 0a 65 78 | 74 65 6e 64 5f 63 73 70 |,c2);.ex|tend_csp|
|00001b00| 61 63 65 28 69 6e 64 65 | 78 2c 64 65 6c 74 61 33 |ace(inde|x,delta3|
|00001b10| 2c 63 33 29 3b 0a 7d 0a | 7d 20 0a 7d 20 69 6e 64 |,c3);.}.|} .} ind|
|00001b20| 69 20 64 61 6e 63 65 72 | 20 7b 0a 2f 2f 20 42 61 |i dancer| {.// Ba|
|00001b30| 73 65 49 6e 64 69 20 61 | 74 74 72 69 62 75 74 65 |seIndi a|ttribute|
|00001b40| 73 0a 2f 2f 20 44 61 6e | 63 65 72 49 6e 64 69 41 |s.// Dan|cerIndiA|
|00001b50| 74 74 72 69 62 75 74 65 | 73 0a 67 65 6e 6f 6d 65 |ttribute|s.genome|
|00001b60| 20 64 61 6e 63 65 72 20 | 7b 0a 2f 2f 20 42 61 73 | dancer |{.// Bas|
|00001b70| 65 47 65 6e 6f 6d 65 20 | 61 74 74 72 69 62 75 74 |eGenome |attribut|
|00001b80| 65 73 0a 2f 2f 20 44 61 | 6e 63 65 72 47 65 6e 6f |es.// Da|ncerGeno|
|00001b90| 6d 65 20 61 74 74 72 69 | 62 75 74 65 73 0a 70 72 |me attri|butes.pr|
|00001ba0| 6f 67 0a 66 75 6e 63 20 | 76 6f 69 64 20 6d 61 69 |og.func |void mai|
|00001bb0| 6e 28 29 3b 0a 66 75 6e | 63 20 76 6f 69 64 20 77 |n();.fun|c void w|
|00001bc0| 6f 62 62 6c 65 28 29 3b | 0a 66 75 6e 63 20 76 6f |obble();|.func vo|
|00001bd0| 69 64 20 66 6c 6f 77 65 | 72 28 29 3b 0a 66 75 6e |id flowe|r();.fun|
|00001be0| 63 20 76 6f 69 64 20 62 | 75 69 6c 64 43 53 70 61 |c void b|uildCSpa|
|00001bf0| 63 65 41 28 20 69 6e 74 | 20 69 6e 64 65 78 20 29 |ceA( int| index )|
|00001c00| 3b 0a 66 75 6e 63 20 76 | 6f 69 64 20 62 75 69 6c |;.func v|oid buil|
|00001c10| 64 43 53 70 61 63 65 42 | 28 20 69 6e 74 20 69 6e |dCSpaceB|( int in|
|00001c20| 64 65 78 20 29 3b 0a 66 | 75 6e 63 20 76 6f 69 64 |dex );.f|unc void|
|00001c30| 20 6d 61 69 6e 28 29 20 | 7b 0a 64 61 74 61 20 6e | main() |{.data n|
|00001c40| 75 6d 20 77 61 6e 67 20 | 3d 20 5b 2d 31 2e 34 30 |um wang |= [-1.40|
|00001c50| 35 38 34 5d 3a 5b 2d 32 | 5d 3a 5b 32 5d 3b 20 0a |584]:[-2|]:[2]; .|
|00001c60| 62 75 69 6c 64 43 53 70 | 61 63 65 41 28 5b 30 5d |buildCSp|aceA([0]|
|00001c70| 29 3b 0a 62 75 69 6c 64 | 43 53 70 61 63 65 42 28 |);.build|CSpaceB(|
|00001c80| 5b 31 5d 29 3b 0a 73 65 | 74 5f 73 68 69 6e 65 28 |[1]);.se|t_shine(|
|00001c90| 5b 33 5d 29 3b 0a 73 65 | 74 5f 73 68 61 72 70 28 |[3]);.se|t_sharp(|
|00001ca0| 5b 31 30 30 5d 29 3b 0a | 77 6f 62 62 6c 65 28 29 |[100]);.|wobble()|
|00001cb0| 3b 0a 70 69 74 63 68 28 | 77 61 6e 67 29 3b 0a 66 |;.pitch(|wang);.f|
|00001cc0| 6c 6f 77 65 72 28 29 3b | 0a 70 69 74 63 68 28 2d |lower();|.pitch(-|
|00001cd0| 77 61 6e 67 29 3b 0a 79 | 61 77 28 5b 33 2e 31 34 |wang);.y|aw([3.14|
|00001ce0| 31 35 39 5d 29 3b 0a 77 | 6f 62 62 6c 65 28 29 3b |159]);.w|obble();|
|00001cf0| 0a 70 69 74 63 68 28 77 | 61 6e 67 29 3b 0a 66 6c |.pitch(w|ang);.fl|
|00001d00| 6f 77 65 72 28 29 3b 0a | 70 69 74 63 68 28 2d 77 |ower();.|pitch(-w|
|00001d10| 61 6e 67 29 3b 0a 79 61 | 77 28 5b 31 2e 35 37 5d |ang);.ya|w([1.57]|
|00001d20| 29 3b 0a 77 6f 62 62 6c | 65 28 29 3b 0a 70 69 74 |);.wobbl|e();.pit|
|00001d30| 63 68 28 77 61 6e 67 29 | 3b 0a 66 6c 6f 77 65 72 |ch(wang)|;.flower|
|00001d40| 28 29 3b 0a 70 69 74 63 | 68 28 2d 77 61 6e 67 29 |();.pitc|h(-wang)|
|00001d50| 3b 0a 79 61 77 28 5b 33 | 2e 31 34 31 35 39 5d 29 |;.yaw([3|.14159])|
|00001d60| 3b 0a 77 6f 62 62 6c 65 | 28 29 3b 0a 70 69 74 63 |;.wobble|();.pitc|
|00001d70| 68 28 77 61 6e 67 29 3b | 0a 66 6c 6f 77 65 72 28 |h(wang);|.flower(|
|00001d80| 29 3b 0a 70 69 74 63 68 | 28 2d 77 61 6e 67 29 3b |);.pitch|(-wang);|
|00001d90| 0a 7d 0a 66 75 6e 63 20 | 76 6f 69 64 20 77 6f 62 |.}.func |void wob|
|00001da0| 62 6c 65 28 29 20 7b 0a | 70 75 73 68 28 29 3b 0a |ble() {.|push();.|
|00001db0| 64 61 74 61 20 6e 75 6d | 20 73 65 67 73 20 3d 20 |data num| segs = |
|00001dc0| 5b 33 30 5d 3b 20 0a 64 | 61 74 61 20 6e 75 6d 20 |[30]; .d|ata num |
|00001dd0| 73 74 65 70 20 3d 20 5b | 2d 31 2e 31 30 37 34 37 |step = [|-1.10747|
|00001de0| 5d 3a 5b 2d 31 2e 35 5d | 3a 5b 32 5d 3b 20 0a 64 |]:[-1.5]|:[2]; .d|
|00001df0| 61 74 61 20 6e 75 6d 20 | 66 61 63 74 3b 20 0a 64 |ata num |fact; .d|
|00001e00| 61 74 61 20 6e 75 6d 20 | 6c 6f 63 75 73 31 3b 20 |ata num |locus1; |
|00001e10| 0a 64 61 74 61 20 6e 75 | 6d 20 74 68 69 6b 20 3d |.data nu|m thik =|
|00001e20| 20 5b 31 2e 30 35 5d 3b | 20 0a 64 61 74 61 20 6e | [1.05];| .data n|
|00001e30| 75 6d 20 62 65 6e 64 20 | 3d 20 5b 30 2e 30 36 31 |um bend |= [0.061|
|00001e40| 38 33 39 34 5d 3a 5b 2d | 30 2e 31 5d 3a 5b 30 2e |8394]:[-|0.1]:[0.|
|00001e50| 31 5d 3b 20 0a 64 61 74 | 61 20 76 65 63 33 20 62 |1]; .dat|a vec3 b|
|00001e60| 6c 6f 77 3b 20 0a 64 61 | 74 61 20 6e 75 6d 20 73 |low; .da|ta num s|
|00001e70| 65 70 20 3d 20 5b 31 34 | 2e 32 34 36 33 5d 3a 5b |ep = [14|.2463]:[|
|00001e80| 2d 31 35 5d 3a 5b 31 35 | 5d 3b 20 0a 64 61 74 61 |-15]:[15|]; .data|
|00001e90| 20 6e 75 6d 20 66 72 65 | 71 20 3d 20 5b 31 37 2e | num fre|q = [17.|
|00001ea0| 36 33 36 32 5d 3a 5b 31 | 35 5d 3a 5b 32 35 5d 3b |6362]:[1|5]:[25];|
|00001eb0| 20 0a 64 61 74 61 20 6e | 75 6d 20 66 72 65 71 32 | .data n|um freq2|
|00001ec0| 20 3d 20 5b 31 30 2e 37 | 30 34 36 5d 3a 5b 36 5d | = [10.7|046]:[6]|
|00001ed0| 3a 5b 31 32 5d 3b 20 0a | 64 61 74 61 20 6e 75 6d |:[12]; .|data num|
|00001ee0| 20 77 61 76 65 3b 20 0a | 64 61 74 61 20 6e 75 6d | wave; .|data num|
|00001ef0| 20 64 74 20 3d 20 5b 2d | 32 2e 35 32 39 38 32 5d | dt = [-|2.52982]|
|00001f00| 3a 5b 2d 33 2e 31 34 31 | 5d 3a 5b 33 2e 31 34 31 |:[-3.141|]:[3.141|
|00001f10| 5d 3b 20 0a 66 6f 72 77 | 61 72 64 28 73 65 70 29 |]; .forw|ard(sep)|
|00001f20| 3b 0a 65 67 67 5f 73 63 | 61 6c 65 28 5b 3c 31 2c |;.egg_sc|ale([<1,|
|00001f30| 31 2c 32 2e 32 39 35 32 | 32 3e 5d 3a 5b 3c 31 2c |1,2.2952|2>]:[<1,|
|00001f40| 31 2c 32 3e 5d 3a 5b 3c | 31 2c 31 2c 35 3e 5d 29 |1,2>]:[<|1,1,5>])|
|00001f50| 3b 0a 66 6f 72 28 20 6e | 75 6d 20 69 20 3d 20 5b |;.for( n|um i = [|
|00001f60| 30 5d 3b 20 6c 65 73 73 | 28 69 2c 73 65 67 73 29 |0]; less|(i,segs)|
|00001f70| 3b 20 28 69 2b 5b 31 5d | 29 20 29 20 7b 0a 6c 6f |; (i+[1]|) ) {.lo|
|00001f80| 63 75 73 31 20 3d 20 28 | 69 2f 28 73 65 67 73 2d |cus1 = (|i/(segs-|
|00001f90| 5b 31 5d 29 29 3b 0a 77 | 61 76 65 20 3d 20 28 73 |[1]));.w|ave = (s|
|00001fa0| 69 6e 28 28 28 6c 6f 63 | 75 73 31 2a 66 72 65 71 |in(((loc|us1*freq|
|00001fb0| 32 29 2b 64 74 29 29 2f | 5b 31 34 5d 29 3b 0a 66 |2)+dt))/|[14]);.f|
|00001fc0| 61 63 74 20 3d 20 28 5b | 31 5d 2b 28 73 69 6e 28 |act = ([|1]+(sin(|
|00001fd0| 28 6c 6f 63 75 73 31 2a | 66 72 65 71 29 29 2f 5b |(locus1*|freq))/[|
|00001fe0| 32 5d 29 29 3b 0a 62 6c | 6f 77 20 3d 20 76 33 6d |2]));.bl|ow = v3m|
|00001ff0| 61 6b 65 28 66 61 63 74 | 2c 66 61 63 74 2c 74 68 |ake(fact|,fact,th|
|00002000| 69 6b 29 3b 0a 73 65 74 | 5f 70 72 69 6d 28 5b 34 |ik);.set|_prim([4|
|00002010| 5d 29 3b 0a 73 65 74 5f | 63 6f 6c 6f 75 72 28 63 |]);.set_|colour(c|
|00002020| 73 70 61 63 65 28 5b 30 | 5d 2c 6c 6f 63 75 73 31 |space([0|],locus1|
|00002030| 29 29 3b 0a 66 6f 72 77 | 61 72 64 28 73 74 65 70 |));.forw|ard(step|
|00002040| 29 3b 0a 65 67 67 5f 73 | 63 61 6c 65 28 62 6c 6f |);.egg_s|cale(blo|
|00002050| 77 29 3b 0a 79 61 77 28 | 62 65 6e 64 29 3b 0a 70 |w);.yaw(|bend);.p|
|00002060| 69 74 63 68 28 77 61 76 | 65 29 3b 0a 6c 61 79 28 |itch(wav|e);.lay(|
|00002070| 29 3b 0a 7d 20 0a 70 6f | 70 28 29 3b 0a 7d 0a 66 |);.} .po|p();.}.f|
|00002080| 75 6e 63 20 76 6f 69 64 | 20 66 6c 6f 77 65 72 28 |unc void| flower(|
|00002090| 29 20 7b 0a 70 75 73 68 | 28 29 3b 0a 73 65 74 5f |) {.push|();.set_|
|000020a0| 70 72 69 6d 28 5b 33 5d | 29 3b 0a 64 61 74 61 20 |prim([3]|);.data |
|000020b0| 6e 75 6d 20 70 65 74 73 | 20 3d 20 5b 31 30 2e 31 |num pets| = [10.1|
|000020c0| 31 35 35 5d 3a 5b 34 5d | 3a 5b 31 35 5d 3b 20 0a |155]:[4]|:[15]; .|
|000020d0| 64 61 74 61 20 6e 75 6d | 20 64 41 20 3d 20 5b 2d |data num| dA = [-|
|000020e0| 30 2e 30 31 34 39 31 31 | 37 5d 3a 5b 2d 30 2e 31 |0.014911|7]:[-0.1|
|000020f0| 5d 3a 5b 30 2e 33 5d 3b | 20 0a 64 61 74 61 20 6e |]:[0.3];| .data n|
|00002100| 75 6d 20 64 42 20 3d 20 | 5b 30 2e 38 38 37 33 35 |um dB = |[0.88735|
|00002110| 31 5d 3a 5b 2d 30 2e 31 | 5d 3a 5b 31 2e 35 5d 3b |1]:[-0.1|]:[1.5];|
|00002120| 20 0a 64 61 74 61 20 6e | 75 6d 20 70 65 74 61 6c | .data n|um petal|
|00002130| 65 6e 20 3d 20 5b 36 2e | 39 38 31 39 38 5d 3a 5b |en = [6.|98198]:[|
|00002140| 34 5d 3a 5b 31 32 5d 3b | 20 0a 64 61 74 61 20 6e |4]:[12];| .data n|
|00002150| 75 6d 20 69 6e 70 65 74 | 61 6c 65 6e 20 3d 20 28 |um inpet|alen = (|
|00002160| 5b 31 5d 2f 70 65 74 61 | 6c 65 6e 29 3b 20 0a 64 |[1]/peta|len); .d|
|00002170| 61 74 61 20 6e 75 6d 20 | 6c 6f 63 75 73 32 3b 20 |ata num |locus2; |
|00002180| 0a 64 61 74 61 20 6e 75 | 6d 20 6c 65 6e 20 3d 20 |.data nu|m len = |
|00002190| 5b 31 35 2e 38 31 33 39 | 5d 3a 5b 31 35 5d 3a 5b |[15.8139|]:[15]:[|
|000021a0| 33 35 5d 3b 20 0a 64 61 | 74 61 20 6e 75 6d 20 62 |35]; .da|ta num b|
|000021b0| 75 64 20 3d 20 5b 36 2e | 37 36 37 34 34 5d 3a 5b |ud = [6.|76744]:[|
|000021c0| 34 5d 3a 5b 39 5d 3b 20 | 0a 64 61 74 61 20 6e 75 |4]:[9]; |.data nu|
|000021d0| 6d 20 66 61 6e 67 20 3d | 20 5b 2d 30 2e 32 34 35 |m fang =| [-0.245|
|000021e0| 38 31 38 5d 3a 5b 2d 31 | 5d 3a 5b 31 2e 35 5d 3b |818]:[-1|]:[1.5];|
|000021f0| 20 0a 64 61 74 61 20 76 | 65 63 33 20 73 74 72 65 | .data v|ec3 stre|
|00002200| 74 63 68 3b 20 0a 64 61 | 74 61 20 76 65 63 33 20 |tch; .da|ta vec3 |
|00002210| 69 6e 73 74 72 65 74 63 | 68 3b 20 0a 73 74 72 65 |instretc|h; .stre|
|00002220| 74 63 68 20 3d 20 76 33 | 6d 61 6b 65 28 5b 31 5d |tch = v3|make([1]|
|00002230| 2c 5b 31 5d 2c 70 65 74 | 61 6c 65 6e 29 3b 0a 69 |,[1],pet|alen);.i|
|00002240| 6e 73 74 72 65 74 63 68 | 20 3d 20 76 33 6d 61 6b |nstretch| = v3mak|
|00002250| 65 28 5b 31 5d 2c 5b 31 | 5d 2c 69 6e 70 65 74 61 |e([1],[1|],inpeta|
|00002260| 6c 65 6e 29 3b 0a 66 6f | 72 77 61 72 64 28 6c 65 |len);.fo|rward(le|
|00002270| 6e 29 3b 0a 75 73 63 61 | 6c 65 28 5b 31 2e 32 5d |n);.usca|le([1.2]|
|00002280| 29 3b 0a 79 61 77 28 66 | 61 6e 67 29 3b 0a 65 67 |);.yaw(f|ang);.eg|
|00002290| 67 5f 73 63 61 6c 65 28 | 73 74 72 65 74 63 68 29 |g_scale(|stretch)|
|000022a0| 3b 0a 66 6f 72 28 20 6e | 75 6d 20 69 20 3d 20 5b |;.for( n|um i = [|
|000022b0| 30 5d 3b 20 6c 65 73 73 | 28 69 2c 70 65 74 73 29 |0]; less|(i,pets)|
|000022c0| 3b 20 28 69 2b 5b 31 5d | 29 20 29 20 7b 0a 6c 6f |; (i+[1]|) ) {.lo|
|000022d0| 63 75 73 32 20 3d 20 28 | 69 2f 28 70 65 74 73 2d |cus2 = (|i/(pets-|
|000022e0| 5b 31 5d 29 29 3b 0a 75 | 73 63 61 6c 65 28 5b 31 |[1]));.u|scale([1|
|000022f0| 2e 30 35 5d 29 3b 0a 70 | 69 74 63 68 28 64 41 29 |.05]);.p|itch(dA)|
|00002300| 3b 0a 79 61 77 28 64 42 | 29 3b 0a 73 65 74 5f 63 |;.yaw(dB|);.set_c|
|00002310| 6f 6c 6f 75 72 28 63 73 | 70 61 63 65 28 5b 31 5d |olour(cs|pace([1]|
|00002320| 2c 6c 6f 63 75 73 32 29 | 29 3b 0a 6c 61 79 28 29 |,locus2)|);.lay()|
|00002330| 3b 0a 70 75 73 68 28 29 | 3b 0a 65 67 67 5f 73 63 |;.push()|;.egg_sc|
|00002340| 61 6c 65 28 69 6e 73 74 | 72 65 74 63 68 29 3b 0a |ale(inst|retch);.|
|00002350| 66 6f 72 77 61 72 64 28 | 62 75 64 29 3b 0a 6c 61 |forward(|bud);.la|
|00002360| 79 28 29 3b 0a 70 6f 70 | 28 29 3b 0a 7d 20 0a 70 |y();.pop|();.} .p|
|00002370| 6f 70 28 29 3b 0a 7d 0a | 66 75 6e 63 20 76 6f 69 |op();.}.|func voi|
|00002380| 64 20 62 75 69 6c 64 43 | 53 70 61 63 65 41 28 20 |d buildC|SpaceA( |
|00002390| 69 6e 74 20 69 6e 64 65 | 78 20 29 20 7b 0a 64 61 |int inde|x ) {.da|
|000023a0| 74 61 20 63 6f 6c 6f 75 | 72 20 63 31 20 3d 20 5b |ta colou|r c1 = [|
|000023b0| 3c 30 2e 31 30 39 34 32 | 36 2c 30 2e 35 36 30 33 |<0.10942|6,0.5603|
|000023c0| 34 36 2c 30 2e 38 39 34 | 30 34 2c 30 2e 33 34 35 |46,0.894|04,0.345|
|000023d0| 33 31 38 3e 5d 3a 5b 3c | 30 2c 30 2c 30 2e 37 2c |318>]:[<|0,0,0.7,|
|000023e0| 30 3e 5d 3a 5b 3c 31 2c | 31 2c 31 2c 31 3e 5d 3b |0>]:[<1,|1,1,1>];|
|000023f0| 20 0a 64 61 74 61 20 63 | 6f 6c 6f 75 72 20 63 32 | .data c|olour c2|
|00002400| 20 3d 20 5b 3c 30 2e 30 | 35 39 31 34 38 38 2c 30 | = [<0.0|591488,0|
|00002410| 2e 39 31 32 34 37 31 2c | 30 2e 39 34 38 35 34 31 |.912471,|0.948541|
|00002420| 2c 30 2e 38 32 31 38 34 | 37 3e 5d 3a 5b 3c 30 2c |,0.82184|7>]:[<0,|
|00002430| 30 2c 30 2c 30 3e 5d 3a | 5b 3c 31 2c 31 2c 31 2c |0,0,0>]:|[<1,1,1,|
|00002440| 31 3e 5d 3b 20 0a 64 61 | 74 61 20 63 6f 6c 6f 75 |1>]; .da|ta colou|
|00002450| 72 20 63 33 20 3d 20 5b | 3c 30 2e 37 35 39 35 36 |r c3 = [|<0.75956|
|00002460| 34 2c 30 2e 33 32 39 32 | 38 39 2c 30 2e 38 36 35 |4,0.3292|89,0.865|
|00002470| 36 37 39 2c 30 2e 34 34 | 36 34 38 38 3e 5d 3a 5b |679,0.44|6488>]:[|
|00002480| 3c 30 2c 30 2c 30 2e 37 | 2c 30 3e 5d 3a 5b 3c 31 |<0,0,0.7|,0>]:[<1|
|00002490| 2c 31 2c 31 2c 31 3e 5d | 3b 20 0a 69 6e 69 74 5f |,1,1,1>]|; .init_|
|000024a0| 63 73 70 61 63 65 28 69 | 6e 64 65 78 2c 63 31 29 |cspace(i|ndex,c1)|
|000024b0| 3b 0a 65 78 74 65 6e 64 | 5f 63 73 70 61 63 65 28 |;.extend|_cspace(|
|000024c0| 69 6e 64 65 78 2c 5b 30 | 2e 35 5d 2c 63 32 29 3b |index,[0|.5],c2);|
|000024d0| 0a 65 78 74 65 6e 64 5f | 63 73 70 61 63 65 28 69 |.extend_|cspace(i|
|000024e0| 6e 64 65 78 2c 5b 30 2e | 35 5d 2c 63 33 29 3b 0a |ndex,[0.|5],c3);.|
|000024f0| 7d 0a 66 75 6e 63 20 76 | 6f 69 64 20 62 75 69 6c |}.func v|oid buil|
|00002500| 64 43 53 70 61 63 65 42 | 28 20 69 6e 74 20 69 6e |dCSpaceB|( int in|
|00002510| 64 65 78 20 29 20 7b 0a | 64 61 74 61 20 63 6f 6c |dex ) {.|data col|
|00002520| 6f 75 72 20 63 30 20 3d | 20 5b 3c 30 2e 36 31 32 |our c0 =| [<0.612|
|00002530| 30 39 34 2c 30 2e 37 33 | 31 38 32 2c 30 2e 38 32 |094,0.73|182,0.82|
|00002540| 37 34 34 36 2c 30 3e 5d | 3a 5b 3c 30 2c 30 2c 30 |7446,0>]|:[<0,0,0|
|00002550| 2c 30 3e 5d 3a 5b 3c 31 | 2c 31 2c 31 2c 30 3e 5d |,0>]:[<1|,1,1,0>]|
|00002560| 3b 20 0a 64 61 74 61 20 | 63 6f 6c 6f 75 72 20 63 |; .data |colour c|
|00002570| 31 20 3d 20 5b 3c 30 2e | 36 31 35 35 37 33 2c 30 |1 = [<0.|615573,0|
|00002580| 2e 34 39 30 34 33 37 2c | 30 2e 39 39 39 39 39 2c |.490437,|0.99999,|
|00002590| 30 2e 39 39 39 39 39 3e | 5d 3a 5b 3c 30 2c 30 2e |0.99999>|]:[<0,0.|
|000025a0| 34 2c 30 2e 39 39 39 39 | 39 2c 30 2e 39 39 39 39 |4,0.9999|9,0.9999|
|000025b0| 39 3e 5d 3a 5b 3c 30 2e | 39 39 39 39 39 2c 30 2e |9>]:[<0.|99999,0.|
|000025c0| 39 39 39 39 39 2c 30 2e | 39 39 39 39 39 2c 30 2e |99999,0.|99999,0.|
|000025d0| 39 39 39 39 39 3e 5d 3b | 20 0a 64 61 74 61 20 63 |99999>];| .data c|
|000025e0| 6f 6c 6f 75 72 20 63 32 | 20 3d 20 5b 3c 30 2e 37 |olour c2| = [<0.7|
|000025f0| 36 34 34 36 2c 30 2e 32 | 30 33 38 39 2c 30 2e 35 |6446,0.2|0389,0.5|
|00002600| 35 36 37 33 33 2c 30 3e | 5d 3a 5b 3c 30 2c 30 2c |56733,0>|]:[<0,0,|
|00002610| 30 2c 30 3e 5d 3a 5b 3c | 31 2c 31 2c 31 2c 30 3e |0,0>]:[<|1,1,1,0>|
|00002620| 5d 3b 20 0a 64 61 74 61 | 20 63 6f 6c 6f 75 72 20 |]; .data| colour |
|00002630| 63 33 20 3d 20 5b 3c 30 | 2e 38 38 37 30 31 34 2c |c3 = [<0|.887014,|
|00002640| 30 2e 35 33 35 36 35 35 | 2c 30 2e 39 39 39 39 39 |0.535655|,0.99999|
|00002650| 2c 30 2e 39 39 39 39 39 | 3e 5d 3a 5b 3c 30 2c 30 |,0.99999|>]:[<0,0|
|00002660| 2e 34 2c 30 2e 39 39 39 | 39 39 2c 30 2e 39 39 39 |.4,0.999|99,0.999|
|00002670| 39 39 3e 5d 3a 5b 3c 30 | 2e 39 39 39 39 39 2c 30 |99>]:[<0|.99999,0|
|00002680| 2e 39 39 39 39 39 2c 30 | 2e 39 39 39 39 39 2c 30 |.99999,0|.99999,0|
|00002690| 2e 39 39 39 39 39 3e 5d | 3b 20 0a 64 61 74 61 20 |.99999>]|; .data |
|000026a0| 6e 75 6d 20 64 65 6c 74 | 61 31 20 3d 20 5b 30 2e |num delt|a1 = [0.|
|000026b0| 36 37 34 39 35 39 5d 3a | 5b 30 2e 32 35 5d 3a 5b |674959]:|[0.25]:[|
|000026c0| 31 5d 3b 20 0a 64 61 74 | 61 20 6e 75 6d 20 64 65 |1]; .dat|a num de|
|000026d0| 6c 74 61 32 20 3d 20 5b | 30 2e 33 31 32 39 30 32 |lta2 = [|0.312902|
|000026e0| 5d 3a 5b 30 2e 32 35 5d | 3a 5b 31 5d 3b 20 0a 64 |]:[0.25]|:[1]; .d|
|000026f0| 61 74 61 20 6e 75 6d 20 | 64 65 6c 74 61 33 20 3d |ata num |delta3 =|
|00002700| 20 5b 30 2e 33 30 30 39 | 33 31 5d 3a 5b 30 2e 32 | [0.3009|31]:[0.2|
|00002710| 35 5d 3a 5b 31 5d 3b 20 | 0a 69 6e 69 74 5f 63 73 |5]:[1]; |.init_cs|
|00002720| 70 61 63 65 28 69 6e 64 | 65 78 2c 63 30 29 3b 0a |pace(ind|ex,c0);.|
|00002730| 65 78 74 65 6e 64 5f 63 | 73 70 61 63 65 28 69 6e |extend_c|space(in|
|00002740| 64 65 78 2c 64 65 6c 74 | 61 31 2c 63 31 29 3b 0a |dex,delt|a1,c1);.|
|00002750| 65 78 74 65 6e 64 5f 63 | 73 70 61 63 65 28 69 6e |extend_c|space(in|
|00002760| 64 65 78 2c 64 65 6c 74 | 61 32 2c 63 32 29 3b 0a |dex,delt|a2,c2);.|
|00002770| 65 78 74 65 6e 64 5f 63 | 73 70 61 63 65 28 69 6e |extend_c|space(in|
|00002780| 64 65 78 2c 64 65 6c 74 | 61 33 2c 63 33 29 3b 0a |dex,delt|a3,c3);.|
|00002790| 7d 0a 7d 20 0a 7d 20 69 | 6e 64 69 20 64 61 6e 63 |}.} .} i|ndi danc|
|000027a0| 65 72 20 7b 0a 2f 2f 20 | 42 61 73 65 49 6e 64 69 |er {.// |BaseIndi|
|000027b0| 20 61 74 74 72 69 62 75 | 74 65 73 0a 2f 2f 20 44 | attribu|tes.// D|
|000027c0| 61 6e 63 65 72 49 6e 64 | 69 41 74 74 72 69 62 75 |ancerInd|iAttribu|
|000027d0| 74 65 73 0a 67 65 6e 6f | 6d 65 20 64 61 6e 63 65 |tes.geno|me dance|
|000027e0| 72 20 7b 0a 2f 2f 20 42 | 61 73 65 47 65 6e 6f 6d |r {.// B|aseGenom|
|000027f0| 65 20 61 74 74 72 69 62 | 75 74 65 73 0a 2f 2f 20 |e attrib|utes.// |
|00002800| 44 61 6e 63 65 72 47 65 | 6e 6f 6d 65 20 61 74 74 |DancerGe|nome att|
|00002810| 72 69 62 75 74 65 73 0a | 70 72 6f 67 0a 66 75 6e |ributes.|prog.fun|
|00002820| 63 20 76 6f 69 64 20 6d | 61 69 6e 28 29 3b 0a 66 |c void m|ain();.f|
|00002830| 75 6e 63 20 76 6f 69 64 | 20 77 6f 62 62 6c 65 28 |unc void| wobble(|
|00002840| 29 3b 0a 66 75 6e 63 20 | 76 6f 69 64 20 66 6c 6f |);.func |void flo|
|00002850| 77 65 72 28 29 3b 0a 66 | 75 6e 63 20 76 6f 69 64 |wer();.f|unc void|
|00002860| 20 62 75 69 6c 64 43 53 | 70 61 63 65 41 28 20 69 | buildCS|paceA( i|
|00002870| 6e 74 20 69 6e 64 65 78 | 20 29 3b 0a 66 75 6e 63 |nt index| );.func|
|00002880| 20 76 6f 69 64 20 62 75 | 69 6c 64 43 53 70 61 63 | void bu|ildCSpac|
|00002890| 65 42 28 20 69 6e 74 20 | 69 6e 64 65 78 20 29 3b |eB( int |index );|
|000028a0| 0a 66 75 6e 63 20 76 6f | 69 64 20 6d 61 69 6e 28 |.func vo|id main(|
|000028b0| 29 20 7b 0a 64 61 74 61 | 20 6e 75 6d 20 77 61 6e |) {.data| num wan|
|000028c0| 67 20 3d 20 5b 30 2e 36 | 30 38 34 33 37 5d 3a 5b |g = [0.6|08437]:[|
|000028d0| 2d 32 5d 3a 5b 32 5d 3b | 20 0a 62 75 69 6c 64 43 |-2]:[2];| .buildC|
|000028e0| 53 70 61 63 65 41 28 5b | 30 5d 29 3b 0a 62 75 69 |SpaceA([|0]);.bui|
|000028f0| 6c 64 43 53 70 61 63 65 | 42 28 5b 31 5d 29 3b 0a |ldCSpace|B([1]);.|
|00002900| 73 65 74 5f 73 68 69 6e | 65 28 5b 33 5d 29 3b 0a |set_shin|e([3]);.|
|00002910| 73 65 74 5f 73 68 61 72 | 70 28 5b 31 30 30 5d 29 |set_shar|p([100])|
|00002920| 3b 0a 77 6f 62 62 6c 65 | 28 29 3b 0a 70 69 74 63 |;.wobble|();.pitc|
|00002930| 68 28 77 61 6e 67 29 3b | 0a 66 6c 6f 77 65 72 28 |h(wang);|.flower(|
|00002940| 29 3b 0a 70 69 74 63 68 | 28 2d 77 61 6e 67 29 3b |);.pitch|(-wang);|
|00002950| 0a 79 61 77 28 5b 33 2e | 31 34 31 35 39 5d 29 3b |.yaw([3.|14159]);|
|00002960| 0a 77 6f 62 62 6c 65 28 | 29 3b 0a 70 69 74 63 68 |.wobble(|);.pitch|
|00002970| 28 77 61 6e 67 29 3b 0a | 66 6c 6f 77 65 72 28 29 |(wang);.|flower()|
|00002980| 3b 0a 70 69 74 63 68 28 | 2d 77 61 6e 67 29 3b 0a |;.pitch(|-wang);.|
|00002990| 79 61 77 28 5b 31 2e 35 | 37 5d 29 3b 0a 77 6f 62 |yaw([1.5|7]);.wob|
|000029a0| 62 6c 65 28 29 3b 0a 70 | 69 74 63 68 28 77 61 6e |ble();.p|itch(wan|
|000029b0| 67 29 3b 0a 66 6c 6f 77 | 65 72 28 29 3b 0a 70 69 |g);.flow|er();.pi|
|000029c0| 74 63 68 28 2d 77 61 6e | 67 29 3b 0a 79 61 77 28 |tch(-wan|g);.yaw(|
|000029d0| 5b 33 2e 31 34 31 35 39 | 5d 29 3b 0a 77 6f 62 62 |[3.14159|]);.wobb|
|000029e0| 6c 65 28 29 3b 0a 70 69 | 74 63 68 28 77 61 6e 67 |le();.pi|tch(wang|
|000029f0| 29 3b 0a 66 6c 6f 77 65 | 72 28 29 3b 0a 70 69 74 |);.flowe|r();.pit|
|00002a00| 63 68 28 2d 77 61 6e 67 | 29 3b 0a 7d 0a 66 75 6e |ch(-wang|);.}.fun|
|00002a10| 63 20 76 6f 69 64 20 77 | 6f 62 62 6c 65 28 29 20 |c void w|obble() |
|00002a20| 7b 0a 70 75 73 68 28 29 | 3b 0a 64 61 74 61 20 6e |{.push()|;.data n|
|00002a30| 75 6d 20 73 65 67 73 20 | 3d 20 5b 33 30 5d 3b 20 |um segs |= [30]; |
|00002a40| 0a 64 61 74 61 20 6e 75 | 6d 20 73 74 65 70 20 3d |.data nu|m step =|
|00002a50| 20 5b 31 2e 31 31 39 30 | 35 5d 3a 5b 2d 31 2e 35 | [1.1190|5]:[-1.5|
|00002a60| 5d 3a 5b 32 5d 3b 20 0a | 64 61 74 61 20 6e 75 6d |]:[2]; .|data num|
|00002a70| 20 66 61 63 74 3b 20 0a | 64 61 74 61 20 6e 75 6d | fact; .|data num|
|00002a80| 20 6c 6f 63 75 73 31 3b | 20 0a 64 61 74 61 20 6e | locus1;| .data n|
|00002a90| 75 6d 20 74 68 69 6b 20 | 3d 20 5b 31 2e 30 35 5d |um thik |= [1.05]|
|00002aa0| 3b 20 0a 64 61 74 61 20 | 6e 75 6d 20 62 65 6e 64 |; .data |num bend|
|00002ab0| 20 3d 20 5b 30 2e 30 35 | 35 37 39 31 35 5d 3a 5b | = [0.05|57915]:[|
|00002ac0| 2d 30 2e 31 5d 3a 5b 30 | 2e 31 5d 3b 20 0a 64 61 |-0.1]:[0|.1]; .da|
|00002ad0| 74 61 20 76 65 63 33 20 | 62 6c 6f 77 3b 20 0a 64 |ta vec3 |blow; .d|
|00002ae0| 61 74 61 20 6e 75 6d 20 | 73 65 70 20 3d 20 5b 32 |ata num |sep = [2|
|00002af0| 2e 37 34 39 31 36 5d 3a | 5b 2d 31 35 5d 3a 5b 31 |.74916]:|[-15]:[1|
|00002b00| 35 5d 3b 20 0a 64 61 74 | 61 20 6e 75 6d 20 66 72 |5]; .dat|a num fr|
|00002b10| 65 71 20 3d 20 5b 31 39 | 2e 32 34 39 32 5d 3a 5b |eq = [19|.2492]:[|
|00002b20| 31 35 5d 3a 5b 32 35 5d | 3b 20 0a 64 61 74 61 20 |15]:[25]|; .data |
|00002b30| 6e 75 6d 20 66 72 65 71 | 32 20 3d 20 5b 37 2e 30 |num freq|2 = [7.0|
|00002b40| 31 33 30 35 5d 3a 5b 36 | 5d 3a 5b 31 32 5d 3b 20 |1305]:[6|]:[12]; |
|00002b50| 0a 64 61 74 61 20 6e 75 | 6d 20 77 61 76 65 3b 20 |.data nu|m wave; |
|00002b60| 0a 64 61 74 61 20 6e 75 | 6d 20 64 74 20 3d 20 5b |.data nu|m dt = [|
|00002b70| 33 2e 30 34 31 38 39 5d | 3a 5b 2d 33 2e 31 34 31 |3.04189]|:[-3.141|
|00002b80| 5d 3a 5b 33 2e 31 34 31 | 5d 3b 20 0a 66 6f 72 77 |]:[3.141|]; .forw|
|00002b90| 61 72 64 28 73 65 70 29 | 3b 0a 65 67 67 5f 73 63 |ard(sep)|;.egg_sc|
|00002ba0| 61 6c 65 28 5b 3c 31 2c | 31 2c 33 2e 36 39 32 30 |ale([<1,|1,3.6920|
|00002bb0| 36 3e 5d 3a 5b 3c 31 2c | 31 2c 32 3e 5d 3a 5b 3c |6>]:[<1,|1,2>]:[<|
|00002bc0| 31 2c 31 2c 35 3e 5d 29 | 3b 0a 66 6f 72 28 20 6e |1,1,5>])|;.for( n|
|00002bd0| 75 6d 20 69 20 3d 20 5b | 30 5d 3b 20 6c 65 73 73 |um i = [|0]; less|
|00002be0| 28 69 2c 73 65 67 73 29 | 3b 20 28 69 2b 5b 31 5d |(i,segs)|; (i+[1]|
|00002bf0| 29 20 29 20 7b 0a 6c 6f | 63 75 73 31 20 3d 20 28 |) ) {.lo|cus1 = (|
|00002c00| 69 2f 28 73 65 67 73 2d | 5b 31 5d 29 29 3b 0a 77 |i/(segs-|[1]));.w|
|00002c10| 61 76 65 20 3d 20 28 73 | 69 6e 28 28 28 6c 6f 63 |ave = (s|in(((loc|
|00002c20| 75 73 31 2a 66 72 65 71 | 32 29 2b 64 74 29 29 2f |us1*freq|2)+dt))/|
|00002c30| 5b 31 34 5d 29 3b 0a 66 | 61 63 74 20 3d 20 28 5b |[14]);.f|act = ([|
|00002c40| 31 5d 2b 28 73 69 6e 28 | 28 6c 6f 63 75 73 31 2a |1]+(sin(|(locus1*|
|00002c50| 66 72 65 71 29 29 2f 5b | 32 5d 29 29 3b 0a 62 6c |freq))/[|2]));.bl|
|00002c60| 6f 77 20 3d 20 76 33 6d | 61 6b 65 28 66 61 63 74 |ow = v3m|ake(fact|
|00002c70| 2c 66 61 63 74 2c 74 68 | 69 6b 29 3b 0a 73 65 74 |,fact,th|ik);.set|
|00002c80| 5f 70 72 69 6d 28 5b 34 | 5d 29 3b 0a 73 65 74 5f |_prim([4|]);.set_|
|00002c90| 63 6f 6c 6f 75 72 28 63 | 73 70 61 63 65 28 5b 30 |colour(c|space([0|
|00002ca0| 5d 2c 6c 6f 63 75 73 31 | 29 29 3b 0a 66 6f 72 77 |],locus1|));.forw|
|00002cb0| 61 72 64 28 73 74 65 70 | 29 3b 0a 65 67 67 5f 73 |ard(step|);.egg_s|
|00002cc0| 63 61 6c 65 28 62 6c 6f | 77 29 3b 0a 79 61 77 28 |cale(blo|w);.yaw(|
|00002cd0| 62 65 6e 64 29 3b 0a 70 | 69 74 63 68 28 77 61 76 |bend);.p|itch(wav|
|00002ce0| 65 29 3b 0a 6c 61 79 28 | 29 3b 0a 7d 20 0a 70 6f |e);.lay(|);.} .po|
|00002cf0| 70 28 29 3b 0a 7d 0a 66 | 75 6e 63 20 76 6f 69 64 |p();.}.f|unc void|
|00002d00| 20 66 6c 6f 77 65 72 28 | 29 20 7b 0a 70 75 73 68 | flower(|) {.push|
|00002d10| 28 29 3b 0a 73 65 74 5f | 70 72 69 6d 28 5b 33 5d |();.set_|prim([3]|
|00002d20| 29 3b 0a 64 61 74 61 20 | 6e 75 6d 20 70 65 74 73 |);.data |num pets|
|00002d30| 20 3d 20 5b 31 31 2e 33 | 37 35 39 5d 3a 5b 34 5d | = [11.3|759]:[4]|
|00002d40| 3a 5b 31 35 5d 3b 20 0a | 64 61 74 61 20 6e 75 6d |:[15]; .|data num|
|00002d50| 20 64 41 20 3d 20 5b 30 | 2e 30 31 36 38 38 38 5d | dA = [0|.016888]|
|00002d60| 3a 5b 2d 30 2e 31 5d 3a | 5b 30 2e 33 5d 3b 20 0a |:[-0.1]:|[0.3]; .|
|00002d70| 64 61 74 61 20 6e 75 6d | 20 64 42 20 3d 20 5b 30 |data num| dB = [0|
|00002d80| 2e 31 30 37 35 30 34 5d | 3a 5b 2d 30 2e 31 5d 3a |.107504]|:[-0.1]:|
|00002d90| 5b 31 2e 35 5d 3b 20 0a | 64 61 74 61 20 6e 75 6d |[1.5]; .|data num|
|00002da0| 20 70 65 74 61 6c 65 6e | 20 3d 20 5b 35 2e 32 34 | petalen| = [5.24|
|00002db0| 35 36 35 5d 3a 5b 34 5d | 3a 5b 31 32 5d 3b 20 0a |565]:[4]|:[12]; .|
|00002dc0| 64 61 74 61 20 6e 75 6d | 20 69 6e 70 65 74 61 6c |data num| inpetal|
|00002dd0| 65 6e 20 3d 20 28 5b 31 | 5d 2f 70 65 74 61 6c 65 |en = ([1|]/petale|
|00002de0| 6e 29 3b 20 0a 64 61 74 | 61 20 6e 75 6d 20 6c 6f |n); .dat|a num lo|
|00002df0| 63 75 73 32 3b 20 0a 64 | 61 74 61 20 6e 75 6d 20 |cus2; .d|ata num |
|00002e00| 6c 65 6e 20 3d 20 5b 32 | 31 2e 31 34 34 35 5d 3a |len = [2|1.1445]:|
|00002e10| 5b 31 35 5d 3a 5b 33 35 | 5d 3b 20 0a 64 61 74 61 |[15]:[35|]; .data|
|00002e20| 20 6e 75 6d 20 62 75 64 | 20 3d 20 5b 37 2e 38 36 | num bud| = [7.86|
|00002e30| 30 35 34 5d 3a 5b 34 5d | 3a 5b 39 5d 3b 20 0a 64 |054]:[4]|:[9]; .d|
|00002e40| 61 74 61 20 6e 75 6d 20 | 66 61 6e 67 20 3d 20 5b |ata num |fang = [|
|00002e50| 30 2e 38 38 38 31 34 37 | 5d 3a 5b 2d 31 5d 3a 5b |0.888147|]:[-1]:[|
|00002e60| 31 2e 35 5d 3b 20 0a 64 | 61 74 61 20 76 65 63 33 |1.5]; .d|ata vec3|
|00002e70| 20 73 74 72 65 74 63 68 | 3b 20 0a 64 61 74 61 20 | stretch|; .data |
|00002e80| 76 65 63 33 20 69 6e 73 | 74 72 65 74 63 68 3b 20 |vec3 ins|tretch; |
|00002e90| 0a 73 74 72 65 74 63 68 | 20 3d 20 76 33 6d 61 6b |.stretch| = v3mak|
|00002ea0| 65 28 5b 31 5d 2c 5b 31 | 5d 2c 70 65 74 61 6c 65 |e([1],[1|],petale|
|00002eb0| 6e 29 3b 0a 69 6e 73 74 | 72 65 74 63 68 20 3d 20 |n);.inst|retch = |
|00002ec0| 76 33 6d 61 6b 65 28 5b | 31 5d 2c 5b 31 5d 2c 69 |v3make([|1],[1],i|
|00002ed0| 6e 70 65 74 61 6c 65 6e | 29 3b 0a 66 6f 72 77 61 |npetalen|);.forwa|
|00002ee0| 72 64 28 6c 65 6e 29 3b | 0a 75 73 63 61 6c 65 28 |rd(len);|.uscale(|
|00002ef0| 5b 31 2e 32 5d 29 3b 0a | 79 61 77 28 66 61 6e 67 |[1.2]);.|yaw(fang|
|00002f00| 29 3b 0a 65 67 67 5f 73 | 63 61 6c 65 28 73 74 72 |);.egg_s|cale(str|
|00002f10| 65 74 63 68 29 3b 0a 66 | 6f 72 28 20 6e 75 6d 20 |etch);.f|or( num |
|00002f20| 69 20 3d 20 5b 30 5d 3b | 20 6c 65 73 73 28 69 2c |i = [0];| less(i,|
|00002f30| 70 65 74 73 29 3b 20 28 | 69 2b 5b 31 5d 29 20 29 |pets); (|i+[1]) )|
|00002f40| 20 7b 0a 6c 6f 63 75 73 | 32 20 3d 20 28 69 2f 28 | {.locus|2 = (i/(|
|00002f50| 70 65 74 73 2d 5b 31 5d | 29 29 3b 0a 75 73 63 61 |pets-[1]|));.usca|
|00002f60| 6c 65 28 5b 31 2e 30 35 | 5d 29 3b 0a 70 69 74 63 |le([1.05|]);.pitc|
|00002f70| 68 28 64 41 29 3b 0a 79 | 61 77 28 64 42 29 3b 0a |h(dA);.y|aw(dB);.|
|00002f80| 73 65 74 5f 63 6f 6c 6f | 75 72 28 63 73 70 61 63 |set_colo|ur(cspac|
|00002f90| 65 28 5b 31 5d 2c 6c 6f | 63 75 73 32 29 29 3b 0a |e([1],lo|cus2));.|
|00002fa0| 6c 61 79 28 29 3b 0a 70 | 75 73 68 28 29 3b 0a 65 |lay();.p|ush();.e|
|00002fb0| 67 67 5f 73 63 61 6c 65 | 28 69 6e 73 74 72 65 74 |gg_scale|(instret|
|00002fc0| 63 68 29 3b 0a 66 6f 72 | 77 61 72 64 28 62 75 64 |ch);.for|ward(bud|
|00002fd0| 29 3b 0a 6c 61 79 28 29 | 3b 0a 70 6f 70 28 29 3b |);.lay()|;.pop();|
|00002fe0| 0a 7d 20 0a 70 6f 70 28 | 29 3b 0a 7d 0a 66 75 6e |.} .pop(|);.}.fun|
|00002ff0| 63 20 76 6f 69 64 20 62 | 75 69 6c 64 43 53 70 61 |c void b|uildCSpa|
|00003000| 63 65 41 28 20 69 6e 74 | 20 69 6e 64 65 78 20 29 |ceA( int| index )|
|00003010| 20 7b 0a 64 61 74 61 20 | 63 6f 6c 6f 75 72 20 63 | {.data |colour c|
|00003020| 31 20 3d 20 5b 3c 30 2e | 39 33 34 33 31 31 2c 30 |1 = [<0.|934311,0|
|00003030| 2e 38 35 38 34 34 33 2c | 30 2e 38 35 31 33 34 38 |.858443,|0.851348|
|00003040| 2c 30 2e 39 31 32 30 39 | 36 3e 5d 3a 5b 3c 30 2c |,0.91209|6>]:[<0,|
|00003050| 30 2c 30 2e 37 2c 30 3e | 5d 3a 5b 3c 31 2c 31 2c |0,0.7,0>|]:[<1,1,|
|00003060| 31 2c 31 3e 5d 3b 20 0a | 64 61 74 61 20 63 6f 6c |1,1>]; .|data col|
|00003070| 6f 75 72 20 63 32 20 3d | 20 5b 3c 30 2e 34 31 32 |our c2 =| [<0.412|
|00003080| 33 34 38 2c 30 2e 33 30 | 32 31 31 35 2c 30 2e 30 |348,0.30|2115,0.0|
|00003090| 36 39 30 33 33 38 2c 30 | 2e 36 38 35 32 30 34 3e |690338,0|.685204>|
|000030a0| 5d 3a 5b 3c 30 2c 30 2c | 30 2c 30 3e 5d 3a 5b 3c |]:[<0,0,|0,0>]:[<|
|000030b0| 31 2c 31 2c 31 2c 31 3e | 5d 3b 20 0a 64 61 74 61 |1,1,1,1>|]; .data|
|000030c0| 20 63 6f 6c 6f 75 72 20 | 63 33 20 3d 20 5b 3c 30 | colour |c3 = [<0|
|000030d0| 2e 31 39 35 38 31 38 2c | 30 2e 35 35 35 33 36 39 |.195818,|0.555369|
|000030e0| 2c 30 2e 39 39 33 36 31 | 31 2c 30 2e 32 38 30 33 |,0.99361|1,0.2803|
|000030f0| 34 33 3e 5d 3a 5b 3c 30 | 2c 30 2c 30 2e 37 2c 30 |43>]:[<0|,0,0.7,0|
|00003100| 3e 5d 3a 5b 3c 31 2c 31 | 2c 31 2c 31 3e 5d 3b 20 |>]:[<1,1|,1,1>]; |
|00003110| 0a 69 6e 69 74 5f 63 73 | 70 61 63 65 28 69 6e 64 |.init_cs|pace(ind|
|00003120| 65 78 2c 63 31 29 3b 0a | 65 78 74 65 6e 64 5f 63 |ex,c1);.|extend_c|
|00003130| 73 70 61 63 65 28 69 6e | 64 65 78 2c 5b 30 2e 35 |space(in|dex,[0.5|
|00003140| 5d 2c 63 32 29 3b 0a 65 | 78 74 65 6e 64 5f 63 73 |],c2);.e|xtend_cs|
|00003150| 70 61 63 65 28 69 6e 64 | 65 78 2c 5b 30 2e 35 5d |pace(ind|ex,[0.5]|
|00003160| 2c 63 33 29 3b 0a 7d 0a | 66 75 6e 63 20 76 6f 69 |,c3);.}.|func voi|
|00003170| 64 20 62 75 69 6c 64 43 | 53 70 61 63 65 42 28 20 |d buildC|SpaceB( |
|00003180| 69 6e 74 20 69 6e 64 65 | 78 20 29 20 7b 0a 64 61 |int inde|x ) {.da|
|00003190| 74 61 20 63 6f 6c 6f 75 | 72 20 63 30 20 3d 20 5b |ta colou|r c0 = [|
|000031a0| 3c 30 2e 33 34 36 35 36 | 32 2c 30 2e 37 39 38 34 |<0.34656|2,0.7984|
|000031b0| 34 34 2c 30 2e 39 30 39 | 37 36 31 2c 30 3e 5d 3a |44,0.909|761,0>]:|
|000031c0| 5b 3c 30 2c 30 2c 30 2c | 30 3e 5d 3a 5b 3c 31 2c |[<0,0,0,|0>]:[<1,|
|000031d0| 31 2c 31 2c 30 3e 5d 3b | 20 0a 64 61 74 61 20 63 |1,1,0>];| .data c|
|000031e0| 6f 6c 6f 75 72 20 63 31 | 20 3d 20 5b 3c 30 2e 35 |olour c1| = [<0.5|
|000031f0| 39 39 30 33 35 2c 30 2e | 36 36 37 34 31 35 2c 30 |99035,0.|667415,0|
|00003200| 2e 39 39 39 39 39 2c 30 | 2e 39 39 39 39 39 3e 5d |.99999,0|.99999>]|
|00003210| 3a 5b 3c 30 2c 30 2e 34 | 2c 30 2e 39 39 39 39 39 |:[<0,0.4|,0.99999|
|00003220| 2c 30 2e 39 39 39 39 39 | 3e 5d 3a 5b 3c 30 2e 39 |,0.99999|>]:[<0.9|
|00003230| 39 39 39 39 2c 30 2e 39 | 39 39 39 39 2c 30 2e 39 |9999,0.9|9999,0.9|
|00003240| 39 39 39 39 2c 30 2e 39 | 39 39 39 39 3e 5d 3b 20 |9999,0.9|9999>]; |
|00003250| 0a 64 61 74 61 20 63 6f | 6c 6f 75 72 20 63 32 20 |.data co|lour c2 |
|00003260| 3d 20 5b 3c 30 2e 38 38 | 33 39 32 31 2c 30 2e 36 |= [<0.88|3921,0.6|
|00003270| 31 36 32 35 34 2c 30 2e | 38 38 34 38 31 36 2c 30 |16254,0.|884816,0|
|00003280| 3e 5d 3a 5b 3c 30 2c 30 | 2c 30 2c 30 3e 5d 3a 5b |>]:[<0,0|,0,0>]:[|
|00003290| 3c 31 2c 31 2c 31 2c 30 | 3e 5d 3b 20 0a 64 61 74 |<1,1,1,0|>]; .dat|
|000032a0| 61 20 63 6f 6c 6f 75 72 | 20 63 33 20 3d 20 5b 3c |a colour| c3 = [<|
|000032b0| 30 2e 37 32 31 37 34 31 | 2c 30 2e 36 34 34 31 39 |0.721741|,0.64419|
|000032c0| 36 2c 30 2e 39 39 39 39 | 39 2c 30 2e 39 39 39 39 |6,0.9999|9,0.9999|
|000032d0| 39 3e 5d 3a 5b 3c 30 2c | 30 2e 34 2c 30 2e 39 39 |9>]:[<0,|0.4,0.99|
|000032e0| 39 39 39 2c 30 2e 39 39 | 39 39 39 3e 5d 3a 5b 3c |999,0.99|999>]:[<|
|000032f0| 30 2e 39 39 39 39 39 2c | 30 2e 39 39 39 39 39 2c |0.99999,|0.99999,|
|00003300| 30 2e 39 39 39 39 39 2c | 30 2e 39 39 39 39 39 3e |0.99999,|0.99999>|
|00003310| 5d 3b 20 0a 64 61 74 61 | 20 6e 75 6d 20 64 65 6c |]; .data| num del|
|00003320| 74 61 31 20 3d 20 5b 30 | 2e 38 36 32 38 32 31 5d |ta1 = [0|.862821]|
|00003330| 3a 5b 30 2e 32 35 5d 3a | 5b 31 5d 3b 20 0a 64 61 |:[0.25]:|[1]; .da|
|00003340| 74 61 20 6e 75 6d 20 64 | 65 6c 74 61 32 20 3d 20 |ta num d|elta2 = |
|00003350| 5b 30 2e 39 33 30 31 35 | 32 5d 3a 5b 30 2e 32 35 |[0.93015|2]:[0.25|
|00003360| 5d 3a 5b 31 5d 3b 20 0a | 64 61 74 61 20 6e 75 6d |]:[1]; .|data num|
|00003370| 20 64 65 6c 74 61 33 20 | 3d 20 5b 30 2e 37 30 30 | delta3 |= [0.700|
|00003380| 31 31 5d 3a 5b 30 2e 32 | 35 5d 3a 5b 31 5d 3b 20 |11]:[0.2|5]:[1]; |
|00003390| 0a 69 6e 69 74 5f 63 73 | 70 61 63 65 28 69 6e 64 |.init_cs|pace(ind|
|000033a0| 65 78 2c 63 30 29 3b 0a | 65 78 74 65 6e 64 5f 63 |ex,c0);.|extend_c|
|000033b0| 73 70 61 63 65 28 69 6e | 64 65 78 2c 64 65 6c 74 |space(in|dex,delt|
|000033c0| 61 31 2c 63 31 29 3b 0a | 65 78 74 65 6e 64 5f 63 |a1,c1);.|extend_c|
|000033d0| 73 70 61 63 65 28 69 6e | 64 65 78 2c 64 65 6c 74 |space(in|dex,delt|
|000033e0| 61 32 2c 63 32 29 3b 0a | 65 78 74 65 6e 64 5f 63 |a2,c2);.|extend_c|
|000033f0| 73 70 61 63 65 28 69 6e | 64 65 78 2c 64 65 6c 74 |space(in|dex,delt|
|00003400| 61 33 2c 63 33 29 3b 0a | 7d 0a 7d 20 0a 7d 20 69 |a3,c3);.|}.} .} i|
|00003410| 6e 64 69 20 64 61 6e 63 | 65 72 20 7b 0a 2f 2f 20 |ndi danc|er {.// |
|00003420| 42 61 73 65 49 6e 64 69 | 20 61 74 74 72 69 62 75 |BaseIndi| attribu|
|00003430| 74 65 73 0a 2f 2f 20 44 | 61 6e 63 65 72 49 6e 64 |tes.// D|ancerInd|
|00003440| 69 41 74 74 72 69 62 75 | 74 65 73 0a 67 65 6e 6f |iAttribu|tes.geno|
|00003450| 6d 65 20 64 61 6e 63 65 | 72 20 7b 0a 2f 2f 20 42 |me dance|r {.// B|
|00003460| 61 73 65 47 65 6e 6f 6d | 65 20 61 74 74 72 69 62 |aseGenom|e attrib|
|00003470| 75 74 65 73 0a 2f 2f 20 | 44 61 6e 63 65 72 47 65 |utes.// |DancerGe|
|00003480| 6e 6f 6d 65 20 61 74 74 | 72 69 62 75 74 65 73 0a |nome att|ributes.|
|00003490| 70 72 6f 67 0a 66 75 6e | 63 20 76 6f 69 64 20 6d |prog.fun|c void m|
|000034a0| 61 69 6e 28 29 3b 0a 66 | 75 6e 63 20 76 6f 69 64 |ain();.f|unc void|
|000034b0| 20 77 6f 62 62 6c 65 28 | 29 3b 0a 66 75 6e 63 20 | wobble(|);.func |
|000034c0| 76 6f 69 64 20 66 6c 6f | 77 65 72 28 29 3b 0a 66 |void flo|wer();.f|
|000034d0| 75 6e 63 20 76 6f 69 64 | 20 62 75 69 6c 64 43 53 |unc void| buildCS|
|000034e0| 70 61 63 65 41 28 20 69 | 6e 74 20 69 6e 64 65 78 |paceA( i|nt index|
|000034f0| 20 29 3b 0a 66 75 6e 63 | 20 76 6f 69 64 20 62 75 | );.func| void bu|
|00003500| 69 6c 64 43 53 70 61 63 | 65 42 28 20 69 6e 74 20 |ildCSpac|eB( int |
|00003510| 69 6e 64 65 78 20 29 3b | 0a 66 75 6e 63 20 76 6f |index );|.func vo|
|00003520| 69 64 20 6d 61 69 6e 28 | 29 20 7b 0a 64 61 74 61 |id main(|) {.data|
|00003530| 20 6e 75 6d 20 77 61 6e | 67 20 3d 20 5b 30 2e 30 | num wan|g = [0.0|
|00003540| 33 31 36 39 30 35 5d 3a | 5b 2d 32 5d 3a 5b 32 5d |316905]:|[-2]:[2]|
|00003550| 3b 20 0a 62 75 69 6c 64 | 43 53 70 61 63 65 41 28 |; .build|CSpaceA(|
|00003560| 5b 30 5d 29 3b 0a 62 75 | 69 6c 64 43 53 70 61 63 |[0]);.bu|ildCSpac|
|00003570| 65 42 28 5b 31 5d 29 3b | 0a 73 65 74 5f 73 68 69 |eB([1]);|.set_shi|
|00003580| 6e 65 28 5b 33 5d 29 3b | 0a 73 65 74 5f 73 68 61 |ne([3]);|.set_sha|
|00003590| 72 70 28 5b 31 30 30 5d | 29 3b 0a 77 6f 62 62 6c |rp([100]|);.wobbl|
|000035a0| 65 28 29 3b 0a 70 69 74 | 63 68 28 77 61 6e 67 29 |e();.pit|ch(wang)|
|000035b0| 3b 0a 66 6c 6f 77 65 72 | 28 29 3b 0a 70 69 74 63 |;.flower|();.pitc|
|000035c0| 68 28 2d 77 61 6e 67 29 | 3b 0a 79 61 77 28 5b 33 |h(-wang)|;.yaw([3|
|000035d0| 2e 31 34 31 35 39 5d 29 | 3b 0a 77 6f 62 62 6c 65 |.14159])|;.wobble|
|000035e0| 28 29 3b 0a 70 69 74 63 | 68 28 77 61 6e 67 29 3b |();.pitc|h(wang);|
|000035f0| 0a 66 6c 6f 77 65 72 28 | 29 3b 0a 70 69 74 63 68 |.flower(|);.pitch|
|00003600| 28 2d 77 61 6e 67 29 3b | 0a 79 61 77 28 5b 31 2e |(-wang);|.yaw([1.|
|00003610| 35 37 5d 29 3b 0a 77 6f | 62 62 6c 65 28 29 3b 0a |57]);.wo|bble();.|
|00003620| 70 69 74 63 68 28 77 61 | 6e 67 29 3b 0a 66 6c 6f |pitch(wa|ng);.flo|
|00003630| 77 65 72 28 29 3b 0a 70 | 69 74 63 68 28 2d 77 61 |wer();.p|itch(-wa|
|00003640| 6e 67 29 3b 0a 79 61 77 | 28 5b 33 2e 31 34 31 35 |ng);.yaw|([3.1415|
|00003650| 39 5d 29 3b 0a 77 6f 62 | 62 6c 65 28 29 3b 0a 70 |9]);.wob|ble();.p|
|00003660| 69 74 63 68 28 77 61 6e | 67 29 3b 0a 66 6c 6f 77 |itch(wan|g);.flow|
|00003670| 65 72 28 29 3b 0a 70 69 | 74 63 68 28 2d 77 61 6e |er();.pi|tch(-wan|
|00003680| 67 29 3b 0a 7d 0a 66 75 | 6e 63 20 76 6f 69 64 20 |g);.}.fu|nc void |
|00003690| 77 6f 62 62 6c 65 28 29 | 20 7b 0a 70 75 73 68 28 |wobble()| {.push(|
|000036a0| 29 3b 0a 64 61 74 61 20 | 6e 75 6d 20 73 65 67 73 |);.data |num segs|
|000036b0| 20 3d 20 5b 33 30 5d 3b | 20 0a 64 61 74 61 20 6e | = [30];| .data n|
|000036c0| 75 6d 20 73 74 65 70 20 | 3d 20 5b 31 2e 31 31 39 |um step |= [1.119|
|000036d0| 30 35 5d 3a 5b 2d 31 2e | 35 5d 3a 5b 32 5d 3b 20 |05]:[-1.|5]:[2]; |
|000036e0| 0a 64 61 74 61 20 6e 75 | 6d 20 66 61 63 74 3b 20 |.data nu|m fact; |
|000036f0| 0a 64 61 74 61 20 6e 75 | 6d 20 6c 6f 63 75 73 31 |.data nu|m locus1|
|00003700| 3b 20 0a 64 61 74 61 20 | 6e 75 6d 20 74 68 69 6b |; .data |num thik|
|00003710| 20 3d 20 5b 31 2e 30 35 | 5d 3b 20 0a 64 61 74 61 | = [1.05|]; .data|
|00003720| 20 6e 75 6d 20 62 65 6e | 64 20 3d 20 5b 30 2e 30 | num ben|d = [0.0|
|00003730| 35 35 37 39 31 35 5d 3a | 5b 2d 30 2e 31 5d 3a 5b |557915]:|[-0.1]:[|
|00003740| 30 2e 31 5d 3b 20 0a 64 | 61 74 61 20 76 65 63 33 |0.1]; .d|ata vec3|
|00003750| 20 62 6c 6f 77 3b 20 0a | 64 61 74 61 20 6e 75 6d | blow; .|data num|
|00003760| 20 73 65 70 20 3d 20 5b | 32 2e 37 34 39 31 36 5d | sep = [|2.74916]|
|00003770| 3a 5b 2d 31 35 5d 3a 5b | 31 35 5d 3b 20 0a 64 61 |:[-15]:[|15]; .da|
|00003780| 74 61 20 6e 75 6d 20 66 | 72 65 71 20 3d 20 5b 31 |ta num f|req = [1|
|00003790| 39 2e 32 34 39 32 5d 3a | 5b 31 35 5d 3a 5b 32 35 |9.2492]:|[15]:[25|
|000037a0| 5d 3b 20 0a 64 61 74 61 | 20 6e 75 6d 20 66 72 65 |]; .data| num fre|
|000037b0| 71 32 20 3d 20 5b 37 2e | 30 31 33 30 35 5d 3a 5b |q2 = [7.|01305]:[|
|000037c0| 36 5d 3a 5b 31 32 5d 3b | 20 0a 64 61 74 61 20 6e |6]:[12];| .data n|
|000037d0| 75 6d 20 77 61 76 65 3b | 20 0a 64 61 74 61 20 6e |um wave;| .data n|
|000037e0| 75 6d 20 64 74 20 3d 20 | 5b 2d 30 2e 31 39 39 38 |um dt = |[-0.1998|
|000037f0| 32 39 5d 3a 5b 2d 33 2e | 31 34 31 5d 3a 5b 33 2e |29]:[-3.|141]:[3.|
|00003800| 31 34 31 5d 3b 20 0a 66 | 6f 72 77 61 72 64 28 73 |141]; .f|orward(s|
|00003810| 65 70 29 3b 0a 65 67 67 | 5f 73 63 61 6c 65 28 5b |ep);.egg|_scale([|
|00003820| 3c 31 2c 31 2c 33 2e 33 | 34 38 36 33 3e 5d 3a 5b |<1,1,3.3|4863>]:[|
|00003830| 3c 31 2c 31 2c 32 3e 5d | 3a 5b 3c 31 2c 31 2c 35 |<1,1,2>]|:[<1,1,5|
|00003840| 3e 5d 29 3b 0a 66 6f 72 | 28 20 6e 75 6d 20 69 20 |>]);.for|( num i |
|00003850| 3d 20 5b 30 5d 3b 20 6c | 65 73 73 28 69 2c 73 65 |= [0]; l|ess(i,se|
|00003860| 67 73 29 3b 20 28 69 2b | 5b 31 5d 29 20 29 20 7b |gs); (i+|[1]) ) {|
|00003870| 0a 6c 6f 63 75 73 31 20 | 3d 20 28 69 2f 28 73 65 |.locus1 |= (i/(se|
|00003880| 67 73 2d 5b 31 5d 29 29 | 3b 0a 77 61 76 65 20 3d |gs-[1]))|;.wave =|
|00003890| 20 28 73 69 6e 28 28 28 | 6c 6f 63 75 73 31 2a 66 | (sin(((|locus1*f|
|000038a0| 72 65 71 32 29 2b 64 74 | 29 29 2f 5b 31 34 5d 29 |req2)+dt|))/[14])|
|000038b0| 3b 0a 66 61 63 74 20 3d | 20 28 5b 31 5d 2b 28 73 |;.fact =| ([1]+(s|
|000038c0| 69 6e 28 28 6c 6f 63 75 | 73 31 2a 66 72 65 71 29 |in((locu|s1*freq)|
|000038d0| 29 2f 5b 32 5d 29 29 3b | 0a 62 6c 6f 77 20 3d 20 |)/[2]));|.blow = |
|000038e0| 76 33 6d 61 6b 65 28 66 | 61 63 74 2c 66 61 63 74 |v3make(f|act,fact|
|000038f0| 2c 74 68 69 6b 29 3b 0a | 73 65 74 5f 70 72 69 6d |,thik);.|set_prim|
|00003900| 28 5b 34 5d 29 3b 0a 73 | 65 74 5f 63 6f 6c 6f 75 |([4]);.s|et_colou|
|00003910| 72 28 63 73 70 61 63 65 | 28 5b 30 5d 2c 6c 6f 63 |r(cspace|([0],loc|
|00003920| 75 73 31 29 29 3b 0a 66 | 6f 72 77 61 72 64 28 73 |us1));.f|orward(s|
|00003930| 74 65 70 29 3b 0a 65 67 | 67 5f 73 63 61 6c 65 28 |tep);.eg|g_scale(|
|00003940| 62 6c 6f 77 29 3b 0a 79 | 61 77 28 62 65 6e 64 29 |blow);.y|aw(bend)|
|00003950| 3b 0a 70 69 74 63 68 28 | 77 61 76 65 29 3b 0a 6c |;.pitch(|wave);.l|
|00003960| 61 79 28 29 3b 0a 7d 20 | 0a 70 6f 70 28 29 3b 0a |ay();.} |.pop();.|
|00003970| 7d 0a 66 75 6e 63 20 76 | 6f 69 64 20 66 6c 6f 77 |}.func v|oid flow|
|00003980| 65 72 28 29 20 7b 0a 70 | 75 73 68 28 29 3b 0a 73 |er() {.p|ush();.s|
|00003990| 65 74 5f 70 72 69 6d 28 | 5b 33 5d 29 3b 0a 64 61 |et_prim(|[3]);.da|
|000039a0| 74 61 20 6e 75 6d 20 70 | 65 74 73 20 3d 20 5b 31 |ta num p|ets = [1|
|000039b0| 31 2e 33 37 35 39 5d 3a | 5b 34 5d 3a 5b 31 35 5d |1.3759]:|[4]:[15]|
|000039c0| 3b 20 0a 64 61 74 61 20 | 6e 75 6d 20 64 41 20 3d |; .data |num dA =|
|000039d0| 20 5b 2d 30 2e 30 39 37 | 35 30 33 31 5d 3a 5b 2d | [-0.097|5031]:[-|
|000039e0| 30 2e 31 5d 3a 5b 30 2e | 33 5d 3b 20 0a 64 61 74 |0.1]:[0.|3]; .dat|
|000039f0| 61 20 6e 75 6d 20 64 42 | 20 3d 20 5b 30 2e 31 30 |a num dB| = [0.10|
|00003a00| 37 35 30 34 5d 3a 5b 2d | 30 2e 31 5d 3a 5b 31 2e |7504]:[-|0.1]:[1.|
|00003a10| 35 5d 3b 20 0a 64 61 74 | 61 20 6e 75 6d 20 70 65 |5]; .dat|a num pe|
|00003a20| 74 61 6c 65 6e 20 3d 20 | 5b 31 31 2e 37 30 37 37 |talen = |[11.7077|
|00003a30| 5d 3a 5b 34 5d 3a 5b 31 | 32 5d 3b 20 0a 64 61 74 |]:[4]:[1|2]; .dat|
|00003a40| 61 20 6e 75 6d 20 69 6e | 70 65 74 61 6c 65 6e 20 |a num in|petalen |
|00003a50| 3d 20 28 5b 31 5d 2f 70 | 65 74 61 6c 65 6e 29 3b |= ([1]/p|etalen);|
|00003a60| 20 0a 64 61 74 61 20 6e | 75 6d 20 6c 6f 63 75 73 | .data n|um locus|
|00003a70| 32 3b 20 0a 64 61 74 61 | 20 6e 75 6d 20 6c 65 6e |2; .data| num len|
|00003a80| 20 3d 20 5b 31 39 2e 34 | 33 34 34 5d 3a 5b 31 35 | = [19.4|344]:[15|
|00003a90| 5d 3a 5b 33 35 5d 3b 20 | 0a 64 61 74 61 20 6e 75 |]:[35]; |.data nu|
|00003aa0| 6d 20 62 75 64 20 3d 20 | 5b 37 2e 38 36 30 35 34 |m bud = |[7.86054|
|00003ab0| 5d 3a 5b 34 5d 3a 5b 39 | 5d 3b 20 0a 64 61 74 61 |]:[4]:[9|]; .data|
|00003ac0| 20 6e 75 6d 20 66 61 6e | 67 20 3d 20 5b 30 2e 38 | num fan|g = [0.8|
|00003ad0| 38 38 31 34 37 5d 3a 5b | 2d 31 5d 3a 5b 31 2e 35 |88147]:[|-1]:[1.5|
|00003ae0| 5d 3b 20 0a 64 61 74 61 | 20 76 65 63 33 20 73 74 |]; .data| vec3 st|
|00003af0| 72 65 74 63 68 3b 20 0a | 64 61 74 61 20 76 65 63 |retch; .|data vec|
|00003b00| 33 20 69 6e 73 74 72 65 | 74 63 68 3b 20 0a 73 74 |3 instre|tch; .st|
|00003b10| 72 65 74 63 68 20 3d 20 | 76 33 6d 61 6b 65 28 5b |retch = |v3make([|
|00003b20| 31 5d 2c 5b 31 5d 2c 70 | 65 74 61 6c 65 6e 29 3b |1],[1],p|etalen);|
|00003b30| 0a 69 6e 73 74 72 65 74 | 63 68 20 3d 20 76 33 6d |.instret|ch = v3m|
|00003b40| 61 6b 65 28 5b 31 5d 2c | 5b 31 5d 2c 69 6e 70 65 |ake([1],|[1],inpe|
|00003b50| 74 61 6c 65 6e 29 3b 0a | 66 6f 72 77 61 72 64 28 |talen);.|forward(|
|00003b60| 6c 65 6e 29 3b 0a 75 73 | 63 61 6c 65 28 5b 31 2e |len);.us|cale([1.|
|00003b70| 32 5d 29 3b 0a 79 61 77 | 28 66 61 6e 67 29 3b 0a |2]);.yaw|(fang);.|
|00003b80| 65 67 67 5f 73 63 61 6c | 65 28 73 74 72 65 74 63 |egg_scal|e(stretc|
|00003b90| 68 29 3b 0a 66 6f 72 28 | 20 6e 75 6d 20 69 20 3d |h);.for(| num i =|
|00003ba0| 20 5b 30 5d 3b 20 6c 65 | 73 73 28 69 2c 70 65 74 | [0]; le|ss(i,pet|
|00003bb0| 73 29 3b 20 28 69 2b 5b | 31 5d 29 20 29 20 7b 0a |s); (i+[|1]) ) {.|
|00003bc0| 6c 6f 63 75 73 32 20 3d | 20 28 69 2f 28 70 65 74 |locus2 =| (i/(pet|
|00003bd0| 73 2d 5b 31 5d 29 29 3b | 0a 75 73 63 61 6c 65 28 |s-[1]));|.uscale(|
|00003be0| 5b 31 2e 30 35 5d 29 3b | 0a 70 69 74 63 68 28 64 |[1.05]);|.pitch(d|
|00003bf0| 41 29 3b 0a 79 61 77 28 | 64 42 29 3b 0a 73 65 74 |A);.yaw(|dB);.set|
|00003c00| 5f 63 6f 6c 6f 75 72 28 | 63 73 70 61 63 65 28 5b |_colour(|cspace([|
|00003c10| 31 5d 2c 6c 6f 63 75 73 | 32 29 29 3b 0a 6c 61 79 |1],locus|2));.lay|
|00003c20| 28 29 3b 0a 70 75 73 68 | 28 29 3b 0a 65 67 67 5f |();.push|();.egg_|
|00003c30| 73 63 61 6c 65 28 69 6e | 73 74 72 65 74 63 68 29 |scale(in|stretch)|
|00003c40| 3b 0a 66 6f 72 77 61 72 | 64 28 62 75 64 29 3b 0a |;.forwar|d(bud);.|
|00003c50| 6c 61 79 28 29 3b 0a 70 | 6f 70 28 29 3b 0a 7d 20 |lay();.p|op();.} |
|00003c60| 0a 70 6f 70 28 29 3b 0a | 7d 0a 66 75 6e 63 20 76 |.pop();.|}.func v|
|00003c70| 6f 69 64 20 62 75 69 6c | 64 43 53 70 61 63 65 41 |oid buil|dCSpaceA|
|00003c80| 28 20 69 6e 74 20 69 6e | 64 65 78 20 29 20 7b 0a |( int in|dex ) {.|
|00003c90| 64 61 74 61 20 63 6f 6c | 6f 75 72 20 63 31 20 3d |data col|our c1 =|
|00003ca0| 20 5b 3c 30 2e 39 33 34 | 33 31 31 2c 30 2e 38 35 | [<0.934|311,0.85|
|00003cb0| 38 34 34 33 2c 30 2e 38 | 35 31 33 34 38 2c 30 2e |8443,0.8|51348,0.|
|00003cc0| 39 31 32 30 39 36 3e 5d | 3a 5b 3c 30 2c 30 2c 30 |912096>]|:[<0,0,0|
|00003cd0| 2e 37 2c 30 3e 5d 3a 5b | 3c 31 2c 31 2c 31 2c 31 |.7,0>]:[|<1,1,1,1|
|00003ce0| 3e 5d 3b 20 0a 64 61 74 | 61 20 63 6f 6c 6f 75 72 |>]; .dat|a colour|
|00003cf0| 20 63 32 20 3d 20 5b 3c | 30 2e 34 31 32 33 34 38 | c2 = [<|0.412348|
|00003d00| 2c 30 2e 33 30 32 31 31 | 35 2c 30 2e 30 36 39 30 |,0.30211|5,0.0690|
|00003d10| 33 33 38 2c 30 2e 36 38 | 35 32 30 34 3e 5d 3a 5b |338,0.68|5204>]:[|
|00003d20| 3c 30 2c 30 2c 30 2c 30 | 3e 5d 3a 5b 3c 31 2c 31 |<0,0,0,0|>]:[<1,1|
|00003d30| 2c 31 2c 31 3e 5d 3b 20 | 0a 64 61 74 61 20 63 6f |,1,1>]; |.data co|
|00003d40| 6c 6f 75 72 20 63 33 20 | 3d 20 5b 3c 30 2e 31 39 |lour c3 |= [<0.19|
|00003d50| 35 38 31 38 2c 30 2e 35 | 35 35 33 36 39 2c 30 2e |5818,0.5|55369,0.|
|00003d60| 39 39 33 36 31 31 2c 30 | 2e 32 38 30 33 34 33 3e |993611,0|.280343>|
|00003d70| 5d 3a 5b 3c 30 2c 30 2c | 30 2e 37 2c 30 3e 5d 3a |]:[<0,0,|0.7,0>]:|
|00003d80| 5b 3c 31 2c 31 2c 31 2c | 31 3e 5d 3b 20 0a 69 6e |[<1,1,1,|1>]; .in|
|00003d90| 69 74 5f 63 73 70 61 63 | 65 28 69 6e 64 65 78 2c |it_cspac|e(index,|
|00003da0| 63 31 29 3b 0a 65 78 74 | 65 6e 64 5f 63 73 70 61 |c1);.ext|end_cspa|
|00003db0| 63 65 28 69 6e 64 65 78 | 2c 5b 30 2e 35 5d 2c 63 |ce(index|,[0.5],c|
|00003dc0| 32 29 3b 0a 65 78 74 65 | 6e 64 5f 63 73 70 61 63 |2);.exte|nd_cspac|
|00003dd0| 65 28 69 6e 64 65 78 2c | 5b 30 2e 35 5d 2c 63 33 |e(index,|[0.5],c3|
|00003de0| 29 3b 0a 7d 0a 66 75 6e | 63 20 76 6f 69 64 20 62 |);.}.fun|c void b|
|00003df0| 75 69 6c 64 43 53 70 61 | 63 65 42 28 20 69 6e 74 |uildCSpa|ceB( int|
|00003e00| 20 69 6e 64 65 78 20 29 | 20 7b 0a 64 61 74 61 20 | index )| {.data |
|00003e10| 63 6f 6c 6f 75 72 20 63 | 30 20 3d 20 5b 3c 30 2e |colour c|0 = [<0.|
|00003e20| 33 34 36 35 36 32 2c 30 | 2e 37 39 38 34 34 34 2c |346562,0|.798444,|
|00003e30| 30 2e 39 30 39 37 36 31 | 2c 30 3e 5d 3a 5b 3c 30 |0.909761|,0>]:[<0|
|00003e40| 2c 30 2c 30 2c 30 3e 5d | 3a 5b 3c 31 2c 31 2c 31 |,0,0,0>]|:[<1,1,1|
|00003e50| 2c 30 3e 5d 3b 20 0a 64 | 61 74 61 20 63 6f 6c 6f |,0>]; .d|ata colo|
|00003e60| 75 72 20 63 31 20 3d 20 | 5b 3c 30 2e 36 32 32 39 |ur c1 = |[<0.6229|
|00003e70| 35 32 2c 30 2e 36 35 30 | 36 38 39 2c 30 2e 39 39 |52,0.650|689,0.99|
|00003e80| 39 39 39 2c 30 2e 39 39 | 39 39 39 3e 5d 3a 5b 3c |999,0.99|999>]:[<|
|00003e90| 30 2c 30 2e 34 2c 30 2e | 39 39 39 39 39 2c 30 2e |0,0.4,0.|99999,0.|
|00003ea0| 39 39 39 39 39 3e 5d 3a | 5b 3c 30 2e 39 39 39 39 |99999>]:|[<0.9999|
|00003eb0| 39 2c 30 2e 39 39 39 39 | 39 2c 30 2e 39 39 39 39 |9,0.9999|9,0.9999|
|00003ec0| 39 2c 30 2e 39 39 39 39 | 39 3e 5d 3b 20 0a 64 61 |9,0.9999|9>]; .da|
|00003ed0| 74 61 20 63 6f 6c 6f 75 | 72 20 63 32 20 3d 20 5b |ta colou|r c2 = [|
|00003ee0| 3c 30 2e 36 32 37 31 32 | 38 2c 30 2e 35 38 35 36 |<0.62712|8,0.5856|
|00003ef0| 39 37 2c 30 2e 31 31 31 | 39 34 34 2c 30 3e 5d 3a |97,0.111|944,0>]:|
|00003f00| 5b 3c 30 2c 30 2c 30 2c | 30 3e 5d 3a 5b 3c 31 2c |[<0,0,0,|0>]:[<1,|
|00003f10| 31 2c 31 2c 30 3e 5d 3b | 20 0a 64 61 74 61 20 63 |1,1,0>];| .data c|
|00003f20| 6f 6c 6f 75 72 20 63 33 | 20 3d 20 5b 3c 30 2e 37 |olour c3| = [<0.7|
|00003f30| 32 31 37 34 31 2c 30 2e | 36 34 34 31 39 36 2c 30 |21741,0.|644196,0|
|00003f40| 2e 39 39 39 39 39 2c 30 | 2e 39 39 39 39 39 3e 5d |.99999,0|.99999>]|
|00003f50| 3a 5b 3c 30 2c 30 2e 34 | 2c 30 2e 39 39 39 39 39 |:[<0,0.4|,0.99999|
|00003f60| 2c 30 2e 39 39 39 39 39 | 3e 5d 3a 5b 3c 30 2e 39 |,0.99999|>]:[<0.9|
|00003f70| 39 39 39 39 2c 30 2e 39 | 39 39 39 39 2c 30 2e 39 |9999,0.9|9999,0.9|
|00003f80| 39 39 39 39 2c 30 2e 39 | 39 39 39 39 3e 5d 3b 20 |9999,0.9|9999>]; |
|00003f90| 0a 64 61 74 61 20 6e 75 | 6d 20 64 65 6c 74 61 31 |.data nu|m delta1|
|00003fa0| 20 3d 20 5b 30 2e 37 33 | 38 35 37 34 5d 3a 5b 30 | = [0.73|8574]:[0|
|00003fb0| 2e 32 35 5d 3a 5b 31 5d | 3b 20 0a 64 61 74 61 20 |.25]:[1]|; .data |
|00003fc0| 6e 75 6d 20 64 65 6c 74 | 61 32 20 3d 20 5b 30 2e |num delt|a2 = [0.|
|00003fd0| 33 35 36 38 34 35 5d 3a | 5b 30 2e 32 35 5d 3a 5b |356845]:|[0.25]:[|
|00003fe0| 31 5d 3b 20 0a 64 61 74 | 61 20 6e 75 6d 20 64 65 |1]; .dat|a num de|
|00003ff0| 6c 74 61 33 20 3d 20 5b | 30 2e 37 30 30 31 31 5d |lta3 = [|0.70011]|
|00004000| 3a 5b 30 2e 32 35 5d 3a | 5b 31 5d 3b 20 0a 69 6e |:[0.25]:|[1]; .in|
|00004010| 69 74 5f 63 73 70 61 63 | 65 28 69 6e 64 65 78 2c |it_cspac|e(index,|
|00004020| 63 30 29 3b 0a 65 78 74 | 65 6e 64 5f 63 73 70 61 |c0);.ext|end_cspa|
|00004030| 63 65 28 69 6e 64 65 78 | 2c 64 65 6c 74 61 31 2c |ce(index|,delta1,|
|00004040| 63 31 29 3b 0a 65 78 74 | 65 6e 64 5f 63 73 70 61 |c1);.ext|end_cspa|
|00004050| 63 65 28 69 6e 64 65 78 | 2c 64 65 6c 74 61 32 2c |ce(index|,delta2,|
|00004060| 63 32 29 3b 0a 65 78 74 | 65 6e 64 5f 63 73 70 61 |c2);.ext|end_cspa|
|00004070| 63 65 28 69 6e 64 65 78 | 2c 64 65 6c 74 61 33 2c |ce(index|,delta3,|
|00004080| 63 33 29 3b 0a 7d 0a 7d | 20 0a 7d 20 69 6e 64 69 |c3);.}.}| .} indi|
|00004090| 20 64 61 6e 63 65 72 20 | 7b 0a 2f 2f 20 42 61 73 | dancer |{.// Bas|
|000040a0| 65 49 6e 64 69 20 61 74 | 74 72 69 62 75 74 65 73 |eIndi at|tributes|
|000040b0| 0a 2f 2f 20 44 61 6e 63 | 65 72 49 6e 64 69 41 74 |.// Danc|erIndiAt|
|000040c0| 74 72 69 62 75 74 65 73 | 0a 67 65 6e 6f 6d 65 20 |tributes|.genome |
|000040d0| 64 61 6e 63 65 72 20 7b | 0a 2f 2f 20 42 61 73 65 |dancer {|.// Base|
|000040e0| 47 65 6e 6f 6d 65 20 61 | 74 74 72 69 62 75 74 65 |Genome a|ttribute|
|000040f0| 73 0a 2f 2f 20 44 61 6e | 63 65 72 47 65 6e 6f 6d |s.// Dan|cerGenom|
|00004100| 65 20 61 74 74 72 69 62 | 75 74 65 73 0a 70 72 6f |e attrib|utes.pro|
|00004110| 67 0a 66 75 6e 63 20 76 | 6f 69 64 20 6d 61 69 6e |g.func v|oid main|
|00004120| 28 29 3b 0a 66 75 6e 63 | 20 76 6f 69 64 20 77 6f |();.func| void wo|
|00004130| 62 62 6c 65 28 29 3b 0a | 66 75 6e 63 20 76 6f 69 |bble();.|func voi|
|00004140| 64 20 66 6c 6f 77 65 72 | 28 29 3b 0a 66 75 6e 63 |d flower|();.func|
|00004150| 20 76 6f 69 64 20 62 75 | 69 6c 64 43 53 70 61 63 | void bu|ildCSpac|
|00004160| 65 41 28 20 69 6e 74 20 | 69 6e 64 65 78 20 29 3b |eA( int |index );|
|00004170| 0a 66 75 6e 63 20 76 6f | 69 64 20 62 75 69 6c 64 |.func vo|id build|
|00004180| 43 53 70 61 63 65 42 28 | 20 69 6e 74 20 69 6e 64 |CSpaceB(| int ind|
|00004190| 65 78 20 29 3b 0a 66 75 | 6e 63 20 76 6f 69 64 20 |ex );.fu|nc void |
|000041a0| 6d 61 69 6e 28 29 20 7b | 0a 64 61 74 61 20 6e 75 |main() {|.data nu|
|000041b0| 6d 20 77 61 6e 67 20 3d | 20 5b 30 2e 36 30 38 34 |m wang =| [0.6084|
|000041c0| 33 37 5d 3a 5b 2d 32 5d | 3a 5b 32 5d 3b 20 0a 62 |37]:[-2]|:[2]; .b|
|000041d0| 75 69 6c 64 43 53 70 61 | 63 65 41 28 5b 30 5d 29 |uildCSpa|ceA([0])|
|000041e0| 3b 0a 62 75 69 6c 64 43 | 53 70 61 63 65 42 28 5b |;.buildC|SpaceB([|
|000041f0| 31 5d 29 3b 0a 73 65 74 | 5f 73 68 69 6e 65 28 5b |1]);.set|_shine([|
|00004200| 33 5d 29 3b 0a 73 65 74 | 5f 73 68 61 72 70 28 5b |3]);.set|_sharp([|
|00004210| 31 30 30 5d 29 3b 0a 77 | 6f 62 62 6c 65 28 29 3b |100]);.w|obble();|
|00004220| 0a 70 69 74 63 68 28 77 | 61 6e 67 29 3b 0a 66 6c |.pitch(w|ang);.fl|
|00004230| 6f 77 65 72 28 29 3b 0a | 70 69 74 63 68 28 2d 77 |ower();.|pitch(-w|
|00004240| 61 6e 67 29 3b 0a 79 61 | 77 28 5b 33 2e 31 34 31 |ang);.ya|w([3.141|
|00004250| 35 39 5d 29 3b 0a 77 6f | 62 62 6c 65 28 29 3b 0a |59]);.wo|bble();.|
|00004260| 70 69 74 63 68 28 77 61 | 6e 67 29 3b 0a 66 6c 6f |pitch(wa|ng);.flo|
|00004270| 77 65 72 28 29 3b 0a 70 | 69 74 63 68 28 2d 77 61 |wer();.p|itch(-wa|
|00004280| 6e 67 29 3b 0a 79 61 77 | 28 5b 31 2e 35 37 5d 29 |ng);.yaw|([1.57])|
|00004290| 3b 0a 77 6f 62 62 6c 65 | 28 29 3b 0a 70 69 74 63 |;.wobble|();.pitc|
|000042a0| 68 28 77 61 6e 67 29 3b | 0a 66 6c 6f 77 65 72 28 |h(wang);|.flower(|
|000042b0| 29 3b 0a 70 69 74 63 68 | 28 2d 77 61 6e 67 29 3b |);.pitch|(-wang);|
|000042c0| 0a 79 61 77 28 5b 33 2e | 31 34 31 35 39 5d 29 3b |.yaw([3.|14159]);|
|000042d0| 0a 77 6f 62 62 6c 65 28 | 29 3b 0a 70 69 74 63 68 |.wobble(|);.pitch|
|000042e0| 28 77 61 6e 67 29 3b 0a | 66 6c 6f 77 65 72 28 29 |(wang);.|flower()|
|000042f0| 3b 0a 70 69 74 63 68 28 | 2d 77 61 6e 67 29 3b 0a |;.pitch(|-wang);.|
|00004300| 7d 0a 66 75 6e 63 20 76 | 6f 69 64 20 77 6f 62 62 |}.func v|oid wobb|
|00004310| 6c 65 28 29 20 7b 0a 70 | 75 73 68 28 29 3b 0a 64 |le() {.p|ush();.d|
|00004320| 61 74 61 20 6e 75 6d 20 | 73 65 67 73 20 3d 20 5b |ata num |segs = [|
|00004330| 33 30 5d 3b 20 0a 64 61 | 74 61 20 6e 75 6d 20 73 |30]; .da|ta num s|
|00004340| 74 65 70 20 3d 20 5b 2d | 30 2e 36 31 31 38 34 36 |tep = [-|0.611846|
|00004350| 5d 3a 5b 2d 31 2e 35 5d | 3a 5b 32 5d 3b 20 0a 64 |]:[-1.5]|:[2]; .d|
|00004360| 61 74 61 20 6e 75 6d 20 | 66 61 63 74 3b 20 0a 64 |ata num |fact; .d|
|00004370| 61 74 61 20 6e 75 6d 20 | 6c 6f 63 75 73 31 3b 20 |ata num |locus1; |
|00004380| 0a 64 61 74 61 20 6e 75 | 6d 20 74 68 69 6b 20 3d |.data nu|m thik =|
|00004390| 20 5b 31 2e 30 35 5d 3b | 20 0a 64 61 74 61 20 6e | [1.05];| .data n|
|000043a0| 75 6d 20 62 65 6e 64 20 | 3d 20 5b 2d 30 2e 30 30 |um bend |= [-0.00|
|000043b0| 33 33 35 30 31 36 5d 3a | 5b 2d 30 2e 31 5d 3a 5b |335016]:|[-0.1]:[|
|000043c0| 30 2e 31 5d 3b 20 0a 64 | 61 74 61 20 76 65 63 33 |0.1]; .d|ata vec3|
|000043d0| 20 62 6c 6f 77 3b 20 0a | 64 61 74 61 20 6e 75 6d | blow; .|data num|
|000043e0| 20 73 65 70 20 3d 20 5b | 32 2e 37 34 39 31 36 5d | sep = [|2.74916]|
|000043f0| 3a 5b 2d 31 35 5d 3a 5b | 31 35 5d 3b 20 0a 64 61 |:[-15]:[|15]; .da|
|00004400| 74 61 20 6e 75 6d 20 66 | 72 65 71 20 3d 20 5b 31 |ta num f|req = [1|
|00004410| 39 2e 32 34 39 32 5d 3a | 5b 31 35 5d 3a 5b 32 35 |9.2492]:|[15]:[25|
|00004420| 5d 3b 20 0a 64 61 74 61 | 20 6e 75 6d 20 66 72 65 |]; .data| num fre|
|00004430| 71 32 20 3d 20 5b 37 2e | 30 31 33 30 35 5d 3a 5b |q2 = [7.|01305]:[|
|00004440| 36 5d 3a 5b 31 32 5d 3b | 20 0a 64 61 74 61 20 6e |6]:[12];| .data n|
|00004450| 75 6d 20 77 61 76 65 3b | 20 0a 64 61 74 61 20 6e |um wave;| .data n|
|00004460| 75 6d 20 64 74 20 3d 20 | 5b 33 2e 30 34 31 38 39 |um dt = |[3.04189|
|00004470| 5d 3a 5b 2d 33 2e 31 34 | 31 5d 3a 5b 33 2e 31 34 |]:[-3.14|1]:[3.14|
|00004480| 31 5d 3b 20 0a 66 6f 72 | 77 61 72 64 28 73 65 70 |1]; .for|ward(sep|
|00004490| 29 3b 0a 65 67 67 5f 73 | 63 61 6c 65 28 5b 3c 31 |);.egg_s|cale([<1|
|000044a0| 2c 31 2c 34 2e 37 38 37 | 32 32 3e 5d 3a 5b 3c 31 |,1,4.787|22>]:[<1|
|000044b0| 2c 31 2c 32 3e 5d 3a 5b | 3c 31 2c 31 2c 35 3e 5d |,1,2>]:[|<1,1,5>]|
|000044c0| 29 3b 0a 66 6f 72 28 20 | 6e 75 6d 20 69 20 3d 20 |);.for( |num i = |
|000044d0| 5b 30 5d 3b 20 6c 65 73 | 73 28 69 2c 73 65 67 73 |[0]; les|s(i,segs|
|000044e0| 29 3b 20 28 69 2b 5b 31 | 5d 29 20 29 20 7b 0a 6c |); (i+[1|]) ) {.l|
|000044f0| 6f 63 75 73 31 20 3d 20 | 28 69 2f 28 73 65 67 73 |ocus1 = |(i/(segs|
|00004500| 2d 5b 31 5d 29 29 3b 0a | 77 61 76 65 20 3d 20 28 |-[1]));.|wave = (|
|00004510| 73 69 6e 28 28 28 6c 6f | 63 75 73 31 2a 66 72 65 |sin(((lo|cus1*fre|
|00004520| 71 32 29 2b 64 74 29 29 | 2f 5b 31 34 5d 29 3b 0a |q2)+dt))|/[14]);.|
|00004530| 66 61 63 74 20 3d 20 28 | 5b 31 5d 2b 28 73 69 6e |fact = (|[1]+(sin|
|00004540| 28 28 6c 6f 63 75 73 31 | 2a 66 72 65 71 29 29 2f |((locus1|*freq))/|
|00004550| 5b 32 5d 29 29 3b 0a 62 | 6c 6f 77 20 3d 20 76 33 |[2]));.b|low = v3|
|00004560| 6d 61 6b 65 28 66 61 63 | 74 2c 66 61 63 74 2c 74 |make(fac|t,fact,t|
|00004570| 68 69 6b 29 3b 0a 73 65 | 74 5f 70 72 69 6d 28 5b |hik);.se|t_prim([|
|00004580| 34 5d 29 3b 0a 73 65 74 | 5f 63 6f 6c 6f 75 72 28 |4]);.set|_colour(|
|00004590| 63 73 70 61 63 65 28 5b | 30 5d 2c 6c 6f 63 75 73 |cspace([|0],locus|
|000045a0| 31 29 29 3b 0a 66 6f 72 | 77 61 72 64 28 73 74 65 |1));.for|ward(ste|
|000045b0| 70 29 3b 0a 65 67 67 5f | 73 63 61 6c 65 28 62 6c |p);.egg_|scale(bl|
|000045c0| 6f 77 29 3b 0a 79 61 77 | 28 62 65 6e 64 29 3b 0a |ow);.yaw|(bend);.|
|000045d0| 70 69 74 63 68 28 77 61 | 76 65 29 3b 0a 6c 61 79 |pitch(wa|ve);.lay|
|000045e0| 28 29 3b 0a 7d 20 0a 70 | 6f 70 28 29 3b 0a 7d 0a |();.} .p|op();.}.|
|000045f0| 66 75 6e 63 20 76 6f 69 | 64 20 66 6c 6f 77 65 72 |func voi|d flower|
|00004600| 28 29 20 7b 0a 70 75 73 | 68 28 29 3b 0a 73 65 74 |() {.pus|h();.set|
|00004610| 5f 70 72 69 6d 28 5b 33 | 5d 29 3b 0a 64 61 74 61 |_prim([3|]);.data|
|00004620| 20 6e 75 6d 20 70 65 74 | 73 20 3d 20 5b 31 31 2e | num pet|s = [11.|
|00004630| 33 37 35 39 5d 3a 5b 34 | 5d 3a 5b 31 35 5d 3b 20 |3759]:[4|]:[15]; |
|00004640| 0a 64 61 74 61 20 6e 75 | 6d 20 64 41 20 3d 20 5b |.data nu|m dA = [|
|00004650| 30 2e 32 32 37 30 37 37 | 5d 3a 5b 2d 30 2e 31 5d |0.227077|]:[-0.1]|
|00004660| 3a 5b 30 2e 33 5d 3b 20 | 0a 64 61 74 61 20 6e 75 |:[0.3]; |.data nu|
|00004670| 6d 20 64 42 20 3d 20 5b | 30 2e 31 30 37 35 30 34 |m dB = [|0.107504|
|00004680| 5d 3a 5b 2d 30 2e 31 5d | 3a 5b 31 2e 35 5d 3b 20 |]:[-0.1]|:[1.5]; |
|00004690| 0a 64 61 74 61 20 6e 75 | 6d 20 70 65 74 61 6c 65 |.data nu|m petale|
|000046a0| 6e 20 3d 20 5b 35 2e 37 | 34 38 39 35 5d 3a 5b 34 |n = [5.7|4895]:[4|
|000046b0| 5d 3a 5b 31 32 5d 3b 20 | 0a 64 61 74 61 20 6e 75 |]:[12]; |.data nu|
|000046c0| 6d 20 69 6e 70 65 74 61 | 6c 65 6e 20 3d 20 28 5b |m inpeta|len = ([|
|000046d0| 31 5d 2f 70 65 74 61 6c | 65 6e 29 3b 20 0a 64 61 |1]/petal|en); .da|
|000046e0| 74 61 20 6e 75 6d 20 6c | 6f 63 75 73 32 3b 20 0a |ta num l|ocus2; .|
|000046f0| 64 61 74 61 20 6e 75 6d | 20 6c 65 6e 20 3d 20 5b |data num| len = [|
|00004700| 32 39 2e 33 33 33 31 5d | 3a 5b 31 35 5d 3a 5b 33 |29.3331]|:[15]:[3|
|00004710| 35 5d 3b 20 0a 64 61 74 | 61 20 6e 75 6d 20 62 75 |5]; .dat|a num bu|
|00004720| 64 20 3d 20 5b 37 2e 33 | 37 32 36 33 5d 3a 5b 34 |d = [7.3|7263]:[4|
|00004730| 5d 3a 5b 39 5d 3b 20 0a | 64 61 74 61 20 6e 75 6d |]:[9]; .|data num|
|00004740| 20 66 61 6e 67 20 3d 20 | 5b 30 2e 30 33 38 38 31 | fang = |[0.03881|
|00004750| 5d 3a 5b 2d 31 5d 3a 5b | 31 2e 35 5d 3b 20 0a 64 |]:[-1]:[|1.5]; .d|
|00004760| 61 74 61 20 76 65 63 33 | 20 73 74 72 65 74 63 68 |ata vec3| stretch|
|00004770| 3b 20 0a 64 61 74 61 20 | 76 65 63 33 20 69 6e 73 |; .data |vec3 ins|
|00004780| 74 72 65 74 63 68 3b 20 | 0a 73 74 72 65 74 63 68 |tretch; |.stretch|
|00004790| 20 3d 20 76 33 6d 61 6b | 65 28 5b 31 5d 2c 5b 31 | = v3mak|e([1],[1|
|000047a0| 5d 2c 70 65 74 61 6c 65 | 6e 29 3b 0a 69 6e 73 74 |],petale|n);.inst|
|000047b0| 72 65 74 63 68 20 3d 20 | 76 33 6d 61 6b 65 28 5b |retch = |v3make([|
|000047c0| 31 5d 2c 5b 31 5d 2c 69 | 6e 70 65 74 61 6c 65 6e |1],[1],i|npetalen|
|000047d0| 29 3b 0a 66 6f 72 77 61 | 72 64 28 6c 65 6e 29 3b |);.forwa|rd(len);|
|000047e0| 0a 75 73 63 61 6c 65 28 | 5b 31 2e 32 5d 29 3b 0a |.uscale(|[1.2]);.|
|000047f0| 79 61 77 28 66 61 6e 67 | 29 3b 0a 65 67 67 5f 73 |yaw(fang|);.egg_s|
|00004800| 63 61 6c 65 28 73 74 72 | 65 74 63 68 29 3b 0a 66 |cale(str|etch);.f|
|00004810| 6f 72 28 20 6e 75 6d 20 | 69 20 3d 20 5b 30 5d 3b |or( num |i = [0];|
|00004820| 20 6c 65 73 73 28 69 2c | 70 65 74 73 29 3b 20 28 | less(i,|pets); (|
|00004830| 69 2b 5b 31 5d 29 20 29 | 20 7b 0a 6c 6f 63 75 73 |i+[1]) )| {.locus|
|00004840| 32 20 3d 20 28 69 2f 28 | 70 65 74 73 2d 5b 31 5d |2 = (i/(|pets-[1]|
|00004850| 29 29 3b 0a 75 73 63 61 | 6c 65 28 5b 31 2e 30 35 |));.usca|le([1.05|
|00004860| 5d 29 3b 0a 70 69 74 63 | 68 28 64 41 29 3b 0a 79 |]);.pitc|h(dA);.y|
|00004870| 61 77 28 64 42 29 3b 0a | 73 65 74 5f 63 6f 6c 6f |aw(dB);.|set_colo|
|00004880| 75 72 28 63 73 70 61 63 | 65 28 5b 31 5d 2c 6c 6f |ur(cspac|e([1],lo|
|00004890| 63 75 73 32 29 29 3b 0a | 6c 61 79 28 29 3b 0a 70 |cus2));.|lay();.p|
|000048a0| 75 73 68 28 29 3b 0a 65 | 67 67 5f 73 63 61 6c 65 |ush();.e|gg_scale|
|000048b0| 28 69 6e 73 74 72 65 74 | 63 68 29 3b 0a 66 6f 72 |(instret|ch);.for|
|000048c0| 77 61 72 64 28 62 75 64 | 29 3b 0a 6c 61 79 28 29 |ward(bud|);.lay()|
|000048d0| 3b 0a 70 6f 70 28 29 3b | 0a 7d 20 0a 70 6f 70 28 |;.pop();|.} .pop(|
|000048e0| 29 3b 0a 7d 0a 66 75 6e | 63 20 76 6f 69 64 20 62 |);.}.fun|c void b|
|000048f0| 75 69 6c 64 43 53 70 61 | 63 65 41 28 20 69 6e 74 |uildCSpa|ceA( int|
|00004900| 20 69 6e 64 65 78 20 29 | 20 7b 0a 64 61 74 61 20 | index )| {.data |
|00004910| 63 6f 6c 6f 75 72 20 63 | 31 20 3d 20 5b 3c 30 2e |colour c|1 = [<0.|
|00004920| 39 33 34 33 31 31 2c 30 | 2e 38 35 38 34 34 33 2c |934311,0|.858443,|
|00004930| 30 2e 38 35 31 33 34 38 | 2c 30 2e 39 31 32 30 39 |0.851348|,0.91209|
|00004940| 36 3e 5d 3a 5b 3c 30 2c | 30 2c 30 2e 37 2c 30 3e |6>]:[<0,|0,0.7,0>|
|00004950| 5d 3a 5b 3c 31 2c 31 2c | 31 2c 31 3e 5d 3b 20 0a |]:[<1,1,|1,1>]; .|
|00004960| 64 61 74 61 20 63 6f 6c | 6f 75 72 20 63 32 20 3d |data col|our c2 =|
|00004970| 20 5b 3c 30 2e 33 39 34 | 39 33 39 2c 30 2e 35 34 | [<0.394|939,0.54|
|00004980| 36 31 37 34 2c 30 2e 33 | 39 32 31 32 35 2c 30 2e |6174,0.3|92125,0.|
|00004990| 31 35 34 35 31 36 3e 5d | 3a 5b 3c 30 2c 30 2c 30 |154516>]|:[<0,0,0|
|000049a0| 2c 30 3e 5d 3a 5b 3c 31 | 2c 31 2c 31 2c 31 3e 5d |,0>]:[<1|,1,1,1>]|
|000049b0| 3b 20 0a 64 61 74 61 20 | 63 6f 6c 6f 75 72 20 63 |; .data |colour c|
|000049c0| 33 20 3d 20 5b 3c 30 2e | 31 39 35 38 31 38 2c 30 |3 = [<0.|195818,0|
|000049d0| 2e 35 35 35 33 36 39 2c | 30 2e 39 39 33 36 31 31 |.555369,|0.993611|
|000049e0| 2c 30 2e 32 38 30 33 34 | 33 3e 5d 3a 5b 3c 30 2c |,0.28034|3>]:[<0,|
|000049f0| 30 2c 30 2e 37 2c 30 3e | 5d 3a 5b 3c 31 2c 31 2c |0,0.7,0>|]:[<1,1,|
|00004a00| 31 2c 31 3e 5d 3b 20 0a | 69 6e 69 74 5f 63 73 70 |1,1>]; .|init_csp|
|00004a10| 61 63 65 28 69 6e 64 65 | 78 2c 63 31 29 3b 0a 65 |ace(inde|x,c1);.e|
|00004a20| 78 74 65 6e 64 5f 63 73 | 70 61 63 65 28 69 6e 64 |xtend_cs|pace(ind|
|00004a30| 65 78 2c 5b 30 2e 35 5d | 2c 63 32 29 3b 0a 65 78 |ex,[0.5]|,c2);.ex|
|00004a40| 74 65 6e 64 5f 63 73 70 | 61 63 65 28 69 6e 64 65 |tend_csp|ace(inde|
|00004a50| 78 2c 5b 30 2e 35 5d 2c | 63 33 29 3b 0a 7d 0a 66 |x,[0.5],|c3);.}.f|
|00004a60| 75 6e 63 20 76 6f 69 64 | 20 62 75 69 6c 64 43 53 |unc void| buildCS|
|00004a70| 70 61 63 65 42 28 20 69 | 6e 74 20 69 6e 64 65 78 |paceB( i|nt index|
|00004a80| 20 29 20 7b 0a 64 61 74 | 61 20 63 6f 6c 6f 75 72 | ) {.dat|a colour|
|00004a90| 20 63 30 20 3d 20 5b 3c | 30 2e 33 34 36 35 36 32 | c0 = [<|0.346562|
|00004aa0| 2c 30 2e 37 39 38 34 34 | 34 2c 30 2e 39 30 39 37 |,0.79844|4,0.9097|
|00004ab0| 36 31 2c 30 3e 5d 3a 5b | 3c 30 2c 30 2c 30 2c 30 |61,0>]:[|<0,0,0,0|
|00004ac0| 3e 5d 3a 5b 3c 31 2c 31 | 2c 31 2c 30 3e 5d 3b 20 |>]:[<1,1|,1,0>]; |
|00004ad0| 0a 64 61 74 61 20 63 6f | 6c 6f 75 72 20 63 31 20 |.data co|lour c1 |
|00004ae0| 3d 20 5b 3c 30 2e 30 35 | 31 33 39 33 36 2c 30 2e |= [<0.05|13936,0.|
|00004af0| 37 32 30 37 38 31 2c 30 | 2e 39 39 39 39 39 2c 30 |720781,0|.99999,0|
|00004b00| 2e 39 39 39 39 39 3e 5d | 3a 5b 3c 30 2c 30 2e 34 |.99999>]|:[<0,0.4|
|00004b10| 2c 30 2e 39 39 39 39 39 | 2c 30 2e 39 39 39 39 39 |,0.99999|,0.99999|
|00004b20| 3e 5d 3a 5b 3c 30 2e 39 | 39 39 39 39 2c 30 2e 39 |>]:[<0.9|9999,0.9|
|00004b30| 39 39 39 39 2c 30 2e 39 | 39 39 39 39 2c 30 2e 39 |9999,0.9|9999,0.9|
|00004b40| 39 39 39 39 3e 5d 3b 20 | 0a 64 61 74 61 20 63 6f |9999>]; |.data co|
|00004b50| 6c 6f 75 72 20 63 32 20 | 3d 20 5b 3c 30 2e 38 38 |lour c2 |= [<0.88|
|00004b60| 33 39 32 31 2c 30 2e 36 | 31 36 32 35 34 2c 30 2e |3921,0.6|16254,0.|
|00004b70| 38 38 34 38 31 36 2c 30 | 3e 5d 3a 5b 3c 30 2c 30 |884816,0|>]:[<0,0|
|00004b80| 2c 30 2c 30 3e 5d 3a 5b | 3c 31 2c 31 2c 31 2c 30 |,0,0>]:[|<1,1,1,0|
|00004b90| 3e 5d 3b 20 0a 64 61 74 | 61 20 63 6f 6c 6f 75 72 |>]; .dat|a colour|
|00004ba0| 20 63 33 20 3d 20 5b 3c | 30 2e 37 32 31 37 34 31 | c3 = [<|0.721741|
|00004bb0| 2c 30 2e 36 34 34 31 39 | 36 2c 30 2e 39 39 39 39 |,0.64419|6,0.9999|
|00004bc0| 39 2c 30 2e 39 39 39 39 | 39 3e 5d 3a 5b 3c 30 2c |9,0.9999|9>]:[<0,|
|00004bd0| 30 2e 34 2c 30 2e 39 39 | 39 39 39 2c 30 2e 39 39 |0.4,0.99|999,0.99|
|00004be0| 39 39 39 3e 5d 3a 5b 3c | 30 2e 39 39 39 39 39 2c |999>]:[<|0.99999,|
|00004bf0| 30 2e 39 39 39 39 39 2c | 30 2e 39 39 39 39 39 2c |0.99999,|0.99999,|
|00004c00| 30 2e 39 39 39 39 39 3e | 5d 3b 20 0a 64 61 74 61 |0.99999>|]; .data|
|00004c10| 20 6e 75 6d 20 64 65 6c | 74 61 31 20 3d 20 5b 30 | num del|ta1 = [0|
|00004c20| 2e 38 36 32 38 32 31 5d | 3a 5b 30 2e 32 35 5d 3a |.862821]|:[0.25]:|
|00004c30| 5b 31 5d 3b 20 0a 64 61 | 74 61 20 6e 75 6d 20 64 |[1]; .da|ta num d|
|00004c40| 65 6c 74 61 32 20 3d 20 | 5b 30 2e 39 33 30 31 35 |elta2 = |[0.93015|
|00004c50| 32 5d 3a 5b 30 2e 32 35 | 5d 3a 5b 31 5d 3b 20 0a |2]:[0.25|]:[1]; .|
|00004c60| 64 61 74 61 20 6e 75 6d | 20 64 65 6c 74 61 33 20 |data num| delta3 |
|00004c70| 3d 20 5b 30 2e 36 37 5d | 3a 5b 30 2e 32 35 5d 3a |= [0.67]|:[0.25]:|
|00004c80| 5b 31 5d 3b 20 0a 69 6e | 69 74 5f 63 73 70 61 63 |[1]; .in|it_cspac|
|00004c90| 65 28 69 6e 64 65 78 2c | 63 30 29 3b 0a 65 78 74 |e(index,|c0);.ext|
|00004ca0| 65 6e 64 5f 63 73 70 61 | 63 65 28 69 6e 64 65 78 |end_cspa|ce(index|
|00004cb0| 2c 64 65 6c 74 61 31 2c | 63 31 29 3b 0a 65 78 74 |,delta1,|c1);.ext|
|00004cc0| 65 6e 64 5f 63 73 70 61 | 63 65 28 69 6e 64 65 78 |end_cspa|ce(index|
|00004cd0| 2c 64 65 6c 74 61 32 2c | 63 32 29 3b 0a 65 78 74 |,delta2,|c2);.ext|
|00004ce0| 65 6e 64 5f 63 73 70 61 | 63 65 28 69 6e 64 65 78 |end_cspa|ce(index|
|00004cf0| 2c 64 65 6c 74 61 33 2c | 63 33 29 3b 0a 7d 0a 7d |,delta3,|c3);.}.}|
|00004d00| 20 0a 7d 20 69 6e 64 69 | 20 64 61 6e 63 65 72 20 | .} indi| dancer |
|00004d10| 7b 0a 2f 2f 20 42 61 73 | 65 49 6e 64 69 20 61 74 |{.// Bas|eIndi at|
|00004d20| 74 72 69 62 75 74 65 73 | 0a 2f 2f 20 44 61 6e 63 |tributes|.// Danc|
|00004d30| 65 72 49 6e 64 69 41 74 | 74 72 69 62 75 74 65 73 |erIndiAt|tributes|
|00004d40| 0a 67 65 6e 6f 6d 65 20 | 64 61 6e 63 65 72 20 7b |.genome |dancer {|
|00004d50| 0a 2f 2f 20 42 61 73 65 | 47 65 6e 6f 6d 65 20 61 |.// Base|Genome a|
|00004d60| 74 74 72 69 62 75 74 65 | 73 0a 2f 2f 20 44 61 6e |ttribute|s.// Dan|
|00004d70| 63 65 72 47 65 6e 6f 6d | 65 20 61 74 74 72 69 62 |cerGenom|e attrib|
|00004d80| 75 74 65 73 0a 70 72 6f | 67 0a 66 75 6e 63 20 76 |utes.pro|g.func v|
|00004d90| 6f 69 64 20 6d 61 69 6e | 28 29 3b 0a 66 75 6e 63 |oid main|();.func|
|00004da0| 20 76 6f 69 64 20 77 6f | 62 62 6c 65 28 29 3b 0a | void wo|bble();.|
|00004db0| 66 75 6e 63 20 76 6f 69 | 64 20 66 6c 6f 77 65 72 |func voi|d flower|
|00004dc0| 28 29 3b 0a 66 75 6e 63 | 20 76 6f 69 64 20 62 75 |();.func| void bu|
|00004dd0| 69 6c 64 43 53 70 61 63 | 65 41 28 20 69 6e 74 20 |ildCSpac|eA( int |
|00004de0| 69 6e 64 65 78 20 29 3b | 0a 66 75 6e 63 20 76 6f |index );|.func vo|
|00004df0| 69 64 20 62 75 69 6c 64 | 43 53 70 61 63 65 42 28 |id build|CSpaceB(|
|00004e00| 20 69 6e 74 20 69 6e 64 | 65 78 20 29 3b 0a 66 75 | int ind|ex );.fu|
|00004e10| 6e 63 20 76 6f 69 64 20 | 6d 61 69 6e 28 29 20 7b |nc void |main() {|
|00004e20| 0a 64 61 74 61 20 6e 75 | 6d 20 77 61 6e 67 20 3d |.data nu|m wang =|
|00004e30| 20 5b 2d 30 2e 32 39 38 | 39 36 36 5d 3a 5b 2d 32 | [-0.298|966]:[-2|
|00004e40| 5d 3a 5b 32 5d 3b 20 0a | 62 75 69 6c 64 43 53 70 |]:[2]; .|buildCSp|
|00004e50| 61 63 65 41 28 5b 30 5d | 29 3b 0a 62 75 69 6c 64 |aceA([0]|);.build|
|00004e60| 43 53 70 61 63 65 42 28 | 5b 31 5d 29 3b 0a 73 65 |CSpaceB(|[1]);.se|
|00004e70| 74 5f 73 68 69 6e 65 28 | 5b 33 5d 29 3b 0a 73 65 |t_shine(|[3]);.se|
|00004e80| 74 5f 73 68 61 72 70 28 | 5b 31 30 30 5d 29 3b 0a |t_sharp(|[100]);.|
|00004e90| 77 6f 62 62 6c 65 28 29 | 3b 0a 70 69 74 63 68 28 |wobble()|;.pitch(|
|00004ea0| 77 61 6e 67 29 3b 0a 66 | 6c 6f 77 65 72 28 29 3b |wang);.f|lower();|
|00004eb0| 0a 70 69 74 63 68 28 2d | 77 61 6e 67 29 3b 0a 79 |.pitch(-|wang);.y|
|00004ec0| 61 77 28 5b 33 2e 31 34 | 31 35 39 5d 29 3b 0a 77 |aw([3.14|159]);.w|
|00004ed0| 6f 62 62 6c 65 28 29 3b | 0a 70 69 74 63 68 28 77 |obble();|.pitch(w|
|00004ee0| 61 6e 67 29 3b 0a 66 6c | 6f 77 65 72 28 29 3b 0a |ang);.fl|ower();.|
|00004ef0| 70 69 74 63 68 28 2d 77 | 61 6e 67 29 3b 0a 79 61 |pitch(-w|ang);.ya|
|00004f00| 77 28 5b 31 2e 35 37 5d | 29 3b 0a 77 6f 62 62 6c |w([1.57]|);.wobbl|
|00004f10| 65 28 29 3b 0a 70 69 74 | 63 68 28 77 61 6e 67 29 |e();.pit|ch(wang)|
|00004f20| 3b 0a 66 6c 6f 77 65 72 | 28 29 3b 0a 70 69 74 63 |;.flower|();.pitc|
|00004f30| 68 28 2d 77 61 6e 67 29 | 3b 0a 79 61 77 28 5b 33 |h(-wang)|;.yaw([3|
|00004f40| 2e 31 34 31 35 39 5d 29 | 3b 0a 77 6f 62 62 6c 65 |.14159])|;.wobble|
|00004f50| 28 29 3b 0a 70 69 74 63 | 68 28 77 61 6e 67 29 3b |();.pitc|h(wang);|
|00004f60| 0a 66 6c 6f 77 65 72 28 | 29 3b 0a 70 69 74 63 68 |.flower(|);.pitch|
|00004f70| 28 2d 77 61 6e 67 29 3b | 0a 7d 0a 66 75 6e 63 20 |(-wang);|.}.func |
|00004f80| 76 6f 69 64 20 77 6f 62 | 62 6c 65 28 29 20 7b 0a |void wob|ble() {.|
|00004f90| 70 75 73 68 28 29 3b 0a | 64 61 74 61 20 6e 75 6d |push();.|data num|
|00004fa0| 20 73 65 67 73 20 3d 20 | 5b 33 30 5d 3b 20 0a 64 | segs = |[30]; .d|
|00004fb0| 61 74 61 20 6e 75 6d 20 | 73 74 65 70 20 3d 20 5b |ata num |step = [|
|00004fc0| 2d 31 2e 30 37 35 39 34 | 5d 3a 5b 2d 31 2e 35 5d |-1.07594|]:[-1.5]|
|00004fd0| 3a 5b 32 5d 3b 20 0a 64 | 61 74 61 20 6e 75 6d 20 |:[2]; .d|ata num |
|00004fe0| 66 61 63 74 3b 20 0a 64 | 61 74 61 20 6e 75 6d 20 |fact; .d|ata num |
|00004ff0| 6c 6f 63 75 73 31 3b 20 | 0a 64 61 74 61 20 6e 75 |locus1; |.data nu|
|00005000| 6d 20 74 68 69 6b 20 3d | 20 5b 31 2e 30 35 5d 3b |m thik =| [1.05];|
|00005010| 20 0a 64 61 74 61 20 6e | 75 6d 20 62 65 6e 64 20 | .data n|um bend |
|00005020| 3d 20 5b 30 2e 30 39 33 | 36 30 35 38 5d 3a 5b 2d |= [0.093|6058]:[-|
|00005030| 30 2e 31 5d 3a 5b 30 2e | 31 5d 3b 20 0a 64 61 74 |0.1]:[0.|1]; .dat|
|00005040| 61 20 76 65 63 33 20 62 | 6c 6f 77 3b 20 0a 64 61 |a vec3 b|low; .da|
|00005050| 74 61 20 6e 75 6d 20 73 | 65 70 20 3d 20 5b 31 34 |ta num s|ep = [14|
|00005060| 2e 32 34 36 33 5d 3a 5b | 2d 31 35 5d 3a 5b 31 35 |.2463]:[|-15]:[15|
|00005070| 5d 3b 20 0a 64 61 74 61 | 20 6e 75 6d 20 66 72 65 |]; .data| num fre|
|00005080| 71 20 3d 20 5b 31 35 2e | 39 31 33 35 5d 3a 5b 31 |q = [15.|9135]:[1|
|00005090| 35 5d 3a 5b 32 35 5d 3b | 20 0a 64 61 74 61 20 6e |5]:[25];| .data n|
|000050a0| 75 6d 20 66 72 65 71 32 | 20 3d 20 5b 31 30 2e 37 |um freq2| = [10.7|
|000050b0| 35 39 38 5d 3a 5b 36 5d | 3a 5b 31 32 5d 3b 20 0a |598]:[6]|:[12]; .|
|000050c0| 64 61 74 61 20 6e 75 6d | 20 77 61 76 65 3b 20 0a |data num| wave; .|
|000050d0| 64 61 74 61 20 6e 75 6d | 20 64 74 20 3d 20 5b 2d |data num| dt = [-|
|000050e0| 31 2e 33 31 39 36 34 5d | 3a 5b 2d 33 2e 31 34 31 |1.31964]|:[-3.141|
|000050f0| 5d 3a 5b 33 2e 31 34 31 | 5d 3b 20 0a 66 6f 72 77 |]:[3.141|]; .forw|
|00005100| 61 72 64 28 73 65 70 29 | 3b 0a 65 67 67 5f 73 63 |ard(sep)|;.egg_sc|
|00005110| 61 6c 65 28 5b 3c 31 2c | 31 2c 32 2e 39 31 34 30 |ale([<1,|1,2.9140|
|00005120| 33 3e 5d 3a 5b 3c 31 2c | 31 2c 32 3e 5d 3a 5b 3c |3>]:[<1,|1,2>]:[<|
|00005130| 31 2c 31 2c 35 3e 5d 29 | 3b 0a 66 6f 72 28 20 6e |1,1,5>])|;.for( n|
|00005140| 75 6d 20 69 20 3d 20 5b | 30 5d 3b 20 6c 65 73 73 |um i = [|0]; less|
|00005150| 28 69 2c 73 65 67 73 29 | 3b 20 28 69 2b 5b 31 5d |(i,segs)|; (i+[1]|
|00005160| 29 20 29 20 7b 0a 6c 6f | 63 75 73 31 20 3d 20 28 |) ) {.lo|cus1 = (|
|00005170| 69 2f 28 73 65 67 73 2d | 5b 31 5d 29 29 3b 0a 77 |i/(segs-|[1]));.w|
|00005180| 61 76 65 20 3d 20 28 73 | 69 6e 28 28 28 6c 6f 63 |ave = (s|in(((loc|
|00005190| 75 73 31 2a 66 72 65 71 | 32 29 2b 64 74 29 29 2f |us1*freq|2)+dt))/|
|000051a0| 5b 31 34 5d 29 3b 0a 66 | 61 63 74 20 3d 20 28 5b |[14]);.f|act = ([|
|000051b0| 31 5d 2b 28 73 69 6e 28 | 28 6c 6f 63 75 73 31 2a |1]+(sin(|(locus1*|
|000051c0| 66 72 65 71 29 29 2f 5b | 32 5d 29 29 3b 0a 62 6c |freq))/[|2]));.bl|
|000051d0| 6f 77 20 3d 20 76 33 6d | 61 6b 65 28 66 61 63 74 |ow = v3m|ake(fact|
|000051e0| 2c 66 61 63 74 2c 74 68 | 69 6b 29 3b 0a 73 65 74 |,fact,th|ik);.set|
|000051f0| 5f 70 72 69 6d 28 5b 34 | 5d 29 3b 0a 73 65 74 5f |_prim([4|]);.set_|
|00005200| 63 6f 6c 6f 75 72 28 63 | 73 70 61 63 65 28 5b 30 |colour(c|space([0|
|00005210| 5d 2c 6c 6f 63 75 73 31 | 29 29 3b 0a 66 6f 72 77 |],locus1|));.forw|
|00005220| 61 72 64 28 73 74 65 70 | 29 3b 0a 65 67 67 5f 73 |ard(step|);.egg_s|
|00005230| 63 61 6c 65 28 62 6c 6f | 77 29 3b 0a 79 61 77 28 |cale(blo|w);.yaw(|
|00005240| 62 65 6e 64 29 3b 0a 70 | 69 74 63 68 28 77 61 76 |bend);.p|itch(wav|
|00005250| 65 29 3b 0a 6c 61 79 28 | 29 3b 0a 7d 20 0a 70 6f |e);.lay(|);.} .po|
|00005260| 70 28 29 3b 0a 7d 0a 66 | 75 6e 63 20 76 6f 69 64 |p();.}.f|unc void|
|00005270| 20 66 6c 6f 77 65 72 28 | 29 20 7b 0a 70 75 73 68 | flower(|) {.push|
|00005280| 28 29 3b 0a 73 65 74 5f | 70 72 69 6d 28 5b 33 5d |();.set_|prim([3]|
|00005290| 29 3b 0a 64 61 74 61 20 | 6e 75 6d 20 70 65 74 73 |);.data |num pets|
|000052a0| 20 3d 20 5b 31 30 2e 31 | 31 35 35 5d 3a 5b 34 5d | = [10.1|155]:[4]|
|000052b0| 3a 5b 31 35 5d 3b 20 0a | 64 61 74 61 20 6e 75 6d |:[15]; .|data num|
|000052c0| 20 64 41 20 3d 20 5b 2d | 30 2e 30 31 37 31 36 34 | dA = [-|0.017164|
|000052d0| 38 5d 3a 5b 2d 30 2e 31 | 5d 3a 5b 30 2e 33 5d 3b |8]:[-0.1|]:[0.3];|
|000052e0| 20 0a 64 61 74 61 20 6e | 75 6d 20 64 42 20 3d 20 | .data n|um dB = |
|000052f0| 5b 30 2e 35 35 38 39 36 | 31 5d 3a 5b 2d 30 2e 31 |[0.55896|1]:[-0.1|
|00005300| 5d 3a 5b 31 2e 35 5d 3b | 20 0a 64 61 74 61 20 6e |]:[1.5];| .data n|
|00005310| 75 6d 20 70 65 74 61 6c | 65 6e 20 3d 20 5b 37 2e |um petal|en = [7.|
|00005320| 39 30 30 37 33 5d 3a 5b | 34 5d 3a 5b 31 32 5d 3b |90073]:[|4]:[12];|
|00005330| 20 0a 64 61 74 61 20 6e | 75 6d 20 69 6e 70 65 74 | .data n|um inpet|
|00005340| 61 6c 65 6e 20 3d 20 28 | 5b 31 5d 2f 70 65 74 61 |alen = (|[1]/peta|
|00005350| 6c 65 6e 29 3b 20 0a 64 | 61 74 61 20 6e 75 6d 20 |len); .d|ata num |
|00005360| 6c 6f 63 75 73 32 3b 20 | 0a 64 61 74 61 20 6e 75 |locus2; |.data nu|
|00005370| 6d 20 6c 65 6e 20 3d 20 | 5b 31 35 2e 37 32 38 36 |m len = |[15.7286|
|00005380| 5d 3a 5b 31 35 5d 3a 5b | 33 35 5d 3b 20 0a 64 61 |]:[15]:[|35]; .da|
|00005390| 74 61 20 6e 75 6d 20 62 | 75 64 20 3d 20 5b 37 2e |ta num b|ud = [7.|
|000053a0| 38 36 35 34 34 5d 3a 5b | 34 5d 3a 5b 39 5d 3b 20 |86544]:[|4]:[9]; |
|000053b0| 0a 64 61 74 61 20 6e 75 | 6d 20 66 61 6e 67 20 3d |.data nu|m fang =|
|000053c0| 20 5b 2d 30 2e 36 34 39 | 32 39 5d 3a 5b 2d 31 5d | [-0.649|29]:[-1]|
|000053d0| 3a 5b 31 2e 35 5d 3b 20 | 0a 64 61 74 61 20 76 65 |:[1.5]; |.data ve|
|000053e0| 63 33 20 73 74 72 65 74 | 63 68 3b 20 0a 64 61 74 |c3 stret|ch; .dat|
|000053f0| 61 20 76 65 63 33 20 69 | 6e 73 74 72 65 74 63 68 |a vec3 i|nstretch|
|00005400| 3b 20 0a 73 74 72 65 74 | 63 68 20 3d 20 76 33 6d |; .stret|ch = v3m|
|00005410| 61 6b 65 28 5b 31 5d 2c | 5b 31 5d 2c 70 65 74 61 |ake([1],|[1],peta|
|00005420| 6c 65 6e 29 3b 0a 69 6e | 73 74 72 65 74 63 68 20 |len);.in|stretch |
|00005430| 3d 20 76 33 6d 61 6b 65 | 28 5b 31 5d 2c 5b 31 5d |= v3make|([1],[1]|
|00005440| 2c 69 6e 70 65 74 61 6c | 65 6e 29 3b 0a 66 6f 72 |,inpetal|en);.for|
|00005450| 77 61 72 64 28 6c 65 6e | 29 3b 0a 75 73 63 61 6c |ward(len|);.uscal|
|00005460| 65 28 5b 31 2e 32 5d 29 | 3b 0a 79 61 77 28 66 61 |e([1.2])|;.yaw(fa|
|00005470| 6e 67 29 3b 0a 65 67 67 | 5f 73 63 61 6c 65 28 73 |ng);.egg|_scale(s|
|00005480| 74 72 65 74 63 68 29 3b | 0a 66 6f 72 28 20 6e 75 |tretch);|.for( nu|
|00005490| 6d 20 69 20 3d 20 5b 30 | 5d 3b 20 6c 65 73 73 28 |m i = [0|]; less(|
|000054a0| 69 2c 70 65 74 73 29 3b | 20 28 69 2b 5b 31 5d 29 |i,pets);| (i+[1])|
|000054b0| 20 29 20 7b 0a 6c 6f 63 | 75 73 32 20 3d 20 28 69 | ) {.loc|us2 = (i|
|000054c0| 2f 28 70 65 74 73 2d 5b | 31 5d 29 29 3b 0a 75 73 |/(pets-[|1]));.us|
|000054d0| 63 61 6c 65 28 5b 31 2e | 30 35 5d 29 3b 0a 70 69 |cale([1.|05]);.pi|
|000054e0| 74 63 68 28 64 41 29 3b | 0a 79 61 77 28 64 42 29 |tch(dA);|.yaw(dB)|
|000054f0| 3b 0a 73 65 74 5f 63 6f | 6c 6f 75 72 28 63 73 70 |;.set_co|lour(csp|
|00005500| 61 63 65 28 5b 31 5d 2c | 6c 6f 63 75 73 32 29 29 |ace([1],|locus2))|
|00005510| 3b 0a 6c 61 79 28 29 3b | 0a 70 75 73 68 28 29 3b |;.lay();|.push();|
|00005520| 0a 65 67 67 5f 73 63 61 | 6c 65 28 69 6e 73 74 72 |.egg_sca|le(instr|
|00005530| 65 74 63 68 29 3b 0a 66 | 6f 72 77 61 72 64 28 62 |etch);.f|orward(b|
|00005540| 75 64 29 3b 0a 6c 61 79 | 28 29 3b 0a 70 6f 70 28 |ud);.lay|();.pop(|
|00005550| 29 3b 0a 7d 20 0a 70 6f | 70 28 29 3b 0a 7d 0a 66 |);.} .po|p();.}.f|
|00005560| 75 6e 63 20 76 6f 69 64 | 20 62 75 69 6c 64 43 53 |unc void| buildCS|
|00005570| 70 61 63 65 41 28 20 69 | 6e 74 20 69 6e 64 65 78 |paceA( i|nt index|
|00005580| 20 29 20 7b 0a 64 61 74 | 61 20 63 6f 6c 6f 75 72 | ) {.dat|a colour|
|00005590| 20 63 31 20 3d 20 5b 3c | 30 2e 31 37 31 39 33 2c | c1 = [<|0.17193,|
|000055a0| 30 2e 33 33 33 39 35 35 | 2c 30 2e 39 35 31 39 33 |0.333955|,0.95193|
|000055b0| 31 2c 30 2e 31 35 35 35 | 37 32 3e 5d 3a 5b 3c 30 |1,0.1555|72>]:[<0|
|000055c0| 2c 30 2c 30 2e 37 2c 30 | 3e 5d 3a 5b 3c 31 2c 31 |,0,0.7,0|>]:[<1,1|
|000055d0| 2c 31 2c 31 3e 5d 3b 20 | 0a 64 61 74 61 20 63 6f |,1,1>]; |.data co|
|000055e0| 6c 6f 75 72 20 63 32 20 | 3d 20 5b 3c 30 2e 30 35 |lour c2 |= [<0.05|
|000055f0| 39 31 34 38 38 2c 30 2e | 39 31 32 34 37 31 2c 30 |91488,0.|912471,0|
|00005600| 2e 39 34 38 35 34 31 2c | 30 2e 38 32 31 38 34 37 |.948541,|0.821847|
|00005610| 3e 5d 3a 5b 3c 30 2c 30 | 2c 30 2c 30 3e 5d 3a 5b |>]:[<0,0|,0,0>]:[|
|00005620| 3c 31 2c 31 2c 31 2c 31 | 3e 5d 3b 20 0a 64 61 74 |<1,1,1,1|>]; .dat|
|00005630| 61 20 63 6f 6c 6f 75 72 | 20 63 33 20 3d 20 5b 3c |a colour| c3 = [<|
|00005640| 30 2e 37 35 39 35 36 34 | 2c 30 2e 33 32 39 32 38 |0.759564|,0.32928|
|00005650| 39 2c 30 2e 38 36 35 36 | 37 39 2c 30 2e 34 34 36 |9,0.8656|79,0.446|
|00005660| 34 38 38 3e 5d 3a 5b 3c | 30 2c 30 2c 30 2e 37 2c |488>]:[<|0,0,0.7,|
|00005670| 30 3e 5d 3a 5b 3c 31 2c | 31 2c 31 2c 31 3e 5d 3b |0>]:[<1,|1,1,1>];|
|00005680| 20 0a 69 6e 69 74 5f 63 | 73 70 61 63 65 28 69 6e | .init_c|space(in|
|00005690| 64 65 78 2c 63 31 29 3b | 0a 65 78 74 65 6e 64 5f |dex,c1);|.extend_|
|000056a0| 63 73 70 61 63 65 28 69 | 6e 64 65 78 2c 5b 30 2e |cspace(i|ndex,[0.|
|000056b0| 35 5d 2c 63 32 29 3b 0a | 65 78 74 65 6e 64 5f 63 |5],c2);.|extend_c|
|000056c0| 73 70 61 63 65 28 69 6e | 64 65 78 2c 5b 30 2e 35 |space(in|dex,[0.5|
|000056d0| 5d 2c 63 33 29 3b 0a 7d | 0a 66 75 6e 63 20 76 6f |],c3);.}|.func vo|
|000056e0| 69 64 20 62 75 69 6c 64 | 43 53 70 61 63 65 42 28 |id build|CSpaceB(|
|000056f0| 20 69 6e 74 20 69 6e 64 | 65 78 20 29 20 7b 0a 64 | int ind|ex ) {.d|
|00005700| 61 74 61 20 63 6f 6c 6f | 75 72 20 63 30 20 3d 20 |ata colo|ur c0 = |
|00005710| 5b 3c 30 2e 36 36 30 36 | 37 33 2c 30 2e 36 33 35 |[<0.6606|73,0.635|
|00005720| 39 36 2c 30 2e 38 33 37 | 31 31 39 2c 30 3e 5d 3a |96,0.837|119,0>]:|
|00005730| 5b 3c 30 2c 30 2c 30 2c | 30 3e 5d 3a 5b 3c 31 2c |[<0,0,0,|0>]:[<1,|
|00005740| 31 2c 31 2c 30 3e 5d 3b | 20 0a 64 61 74 61 20 63 |1,1,0>];| .data c|
|00005750| 6f 6c 6f 75 72 20 63 31 | 20 3d 20 5b 3c 30 2e 35 |olour c1| = [<0.5|
|00005760| 39 34 38 35 36 2c 30 2e | 36 34 35 30 33 36 2c 30 |94856,0.|645036,0|
|00005770| 2e 39 39 39 39 39 2c 30 | 2e 39 39 39 39 39 3e 5d |.99999,0|.99999>]|
|00005780| 3a 5b 3c 30 2c 30 2e 34 | 2c 30 2e 39 39 39 39 39 |:[<0,0.4|,0.99999|
|00005790| 2c 30 2e 39 39 39 39 39 | 3e 5d 3a 5b 3c 30 2e 39 |,0.99999|>]:[<0.9|
|000057a0| 39 39 39 39 2c 30 2e 39 | 39 39 39 39 2c 30 2e 39 |9999,0.9|9999,0.9|
|000057b0| 39 39 39 39 2c 30 2e 39 | 39 39 39 39 3e 5d 3b 20 |9999,0.9|9999>]; |
|000057c0| 0a 64 61 74 61 20 63 6f | 6c 6f 75 72 20 63 32 20 |.data co|lour c2 |
|000057d0| 3d 20 5b 3c 30 2e 37 38 | 39 36 35 37 2c 30 2e 36 |= [<0.78|9657,0.6|
|000057e0| 33 36 31 32 36 2c 30 2e | 39 33 35 34 38 35 2c 30 |36126,0.|935485,0|
|000057f0| 3e 5d 3a 5b 3c 30 2c 30 | 2c 30 2c 30 3e 5d 3a 5b |>]:[<0,0|,0,0>]:[|
|00005800| 3c 31 2c 31 2c 31 2c 30 | 3e 5d 3b 20 0a 64 61 74 |<1,1,1,0|>]; .dat|
|00005810| 61 20 63 6f 6c 6f 75 72 | 20 63 33 20 3d 20 5b 3c |a colour| c3 = [<|
|00005820| 30 2e 37 30 31 39 33 2c | 30 2e 36 35 39 39 36 36 |0.70193,|0.659966|
|00005830| 2c 30 2e 39 39 39 39 39 | 2c 30 2e 39 39 39 39 39 |,0.99999|,0.99999|
|00005840| 3e 5d 3a 5b 3c 30 2c 30 | 2e 34 2c 30 2e 39 39 39 |>]:[<0,0|.4,0.999|
|00005850| 39 39 2c 30 2e 39 39 39 | 39 39 3e 5d 3a 5b 3c 30 |99,0.999|99>]:[<0|
|00005860| 2e 39 39 39 39 39 2c 30 | 2e 39 39 39 39 39 2c 30 |.99999,0|.99999,0|
|00005870| 2e 39 39 39 39 39 2c 30 | 2e 39 39 39 39 39 3e 5d |.99999,0|.99999>]|
|00005880| 3b 20 0a 64 61 74 61 20 | 6e 75 6d 20 64 65 6c 74 |; .data |num delt|
|00005890| 61 31 20 3d 20 5b 30 2e | 37 37 39 33 34 5d 3a 5b |a1 = [0.|77934]:[|
|000058a0| 30 2e 32 35 5d 3a 5b 31 | 5d 3b 20 0a 64 61 74 61 |0.25]:[1|]; .data|
|000058b0| 20 6e 75 6d 20 64 65 6c | 74 61 32 20 3d 20 5b 30 | num del|ta2 = [0|
|000058c0| 2e 33 31 32 39 30 32 5d | 3a 5b 30 2e 32 35 5d 3a |.312902]|:[0.25]:|
|000058d0| 5b 31 5d 3b 20 0a 64 61 | 74 61 20 6e 75 6d 20 64 |[1]; .da|ta num d|
|000058e0| 65 6c 74 61 33 20 3d 20 | 5b 30 2e 33 30 30 39 33 |elta3 = |[0.30093|
|000058f0| 31 5d 3a 5b 30 2e 32 35 | 5d 3a 5b 31 5d 3b 20 0a |1]:[0.25|]:[1]; .|
|00005900| 69 6e 69 74 5f 63 73 70 | 61 63 65 28 69 6e 64 65 |init_csp|ace(inde|
|00005910| 78 2c 63 30 29 3b 0a 65 | 78 74 65 6e 64 5f 63 73 |x,c0);.e|xtend_cs|
|00005920| 70 61 63 65 28 69 6e 64 | 65 78 2c 64 65 6c 74 61 |pace(ind|ex,delta|
|00005930| 31 2c 63 31 29 3b 0a 65 | 78 74 65 6e 64 5f 63 73 |1,c1);.e|xtend_cs|
|00005940| 70 61 63 65 28 69 6e 64 | 65 78 2c 64 65 6c 74 61 |pace(ind|ex,delta|
|00005950| 32 2c 63 32 29 3b 0a 65 | 78 74 65 6e 64 5f 63 73 |2,c2);.e|xtend_cs|
|00005960| 70 61 63 65 28 69 6e 64 | 65 78 2c 64 65 6c 74 61 |pace(ind|ex,delta|
|00005970| 33 2c 63 33 29 3b 0a 7d | 0a 7d 20 0a 7d 20 69 6e |3,c3);.}|.} .} in|
|00005980| 64 69 20 64 61 6e 63 65 | 72 20 7b 0a 2f 2f 20 42 |di dance|r {.// B|
|00005990| 61 73 65 49 6e 64 69 20 | 61 74 74 72 69 62 75 74 |aseIndi |attribut|
|000059a0| 65 73 0a 2f 2f 20 44 61 | 6e 63 65 72 49 6e 64 69 |es.// Da|ncerIndi|
|000059b0| 41 74 74 72 69 62 75 74 | 65 73 0a 67 65 6e 6f 6d |Attribut|es.genom|
|000059c0| 65 20 64 61 6e 63 65 72 | 20 7b 0a 2f 2f 20 42 61 |e dancer| {.// Ba|
|000059d0| 73 65 47 65 6e 6f 6d 65 | 20 61 74 74 72 69 62 75 |seGenome| attribu|
|000059e0| 74 65 73 0a 2f 2f 20 44 | 61 6e 63 65 72 47 65 6e |tes.// D|ancerGen|
|000059f0| 6f 6d 65 20 61 74 74 72 | 69 62 75 74 65 73 0a 70 |ome attr|ibutes.p|
|00005a00| 72 6f 67 0a 66 75 6e 63 | 20 76 6f 69 64 20 6d 61 |rog.func| void ma|
|00005a10| 69 6e 28 29 3b 0a 66 75 | 6e 63 20 76 6f 69 64 20 |in();.fu|nc void |
|00005a20| 77 6f 62 62 6c 65 28 29 | 3b 0a 66 75 6e 63 20 76 |wobble()|;.func v|
|00005a30| 6f 69 64 20 66 6c 6f 77 | 65 72 28 29 3b 0a 66 75 |oid flow|er();.fu|
|00005a40| 6e 63 20 76 6f 69 64 20 | 62 75 69 6c 64 43 53 70 |nc void |buildCSp|
|00005a50| 61 63 65 41 28 20 69 6e | 74 20 69 6e 64 65 78 20 |aceA( in|t index |
|00005a60| 29 3b 0a 66 75 6e 63 20 | 76 6f 69 64 20 62 75 69 |);.func |void bui|
|00005a70| 6c 64 43 53 70 61 63 65 | 42 28 20 69 6e 74 20 69 |ldCSpace|B( int i|
|00005a80| 6e 64 65 78 20 29 3b 0a | 66 75 6e 63 20 76 6f 69 |ndex );.|func voi|
|00005a90| 64 20 6d 61 69 6e 28 29 | 20 7b 0a 64 61 74 61 20 |d main()| {.data |
|00005aa0| 6e 75 6d 20 77 61 6e 67 | 20 3d 20 5b 30 2e 30 33 |num wang| = [0.03|
|00005ab0| 31 36 39 30 35 5d 3a 5b | 2d 32 5d 3a 5b 32 5d 3b |16905]:[|-2]:[2];|
|00005ac0| 20 0a 62 75 69 6c 64 43 | 53 70 61 63 65 41 28 5b | .buildC|SpaceA([|
|00005ad0| 30 5d 29 3b 0a 62 75 69 | 6c 64 43 53 70 61 63 65 |0]);.bui|ldCSpace|
|00005ae0| 42 28 5b 31 5d 29 3b 0a | 73 65 74 5f 73 68 69 6e |B([1]);.|set_shin|
|00005af0| 65 28 5b 33 5d 29 3b 0a | 73 65 74 5f 73 68 61 72 |e([3]);.|set_shar|
|00005b00| 70 28 5b 31 30 30 5d 29 | 3b 0a 77 6f 62 62 6c 65 |p([100])|;.wobble|
|00005b10| 28 29 3b 0a 70 69 74 63 | 68 28 77 61 6e 67 29 3b |();.pitc|h(wang);|
|00005b20| 0a 66 6c 6f 77 65 72 28 | 29 3b 0a 70 69 74 63 68 |.flower(|);.pitch|
|00005b30| 28 2d 77 61 6e 67 29 3b | 0a 79 61 77 28 5b 33 2e |(-wang);|.yaw([3.|
|00005b40| 31 34 31 35 39 5d 29 3b | 0a 77 6f 62 62 6c 65 28 |14159]);|.wobble(|
|00005b50| 29 3b 0a 70 69 74 63 68 | 28 77 61 6e 67 29 3b 0a |);.pitch|(wang);.|
|00005b60| 66 6c 6f 77 65 72 28 29 | 3b 0a 70 69 74 63 68 28 |flower()|;.pitch(|
|00005b70| 2d 77 61 6e 67 29 3b 0a | 79 61 77 28 5b 31 2e 35 |-wang);.|yaw([1.5|
|00005b80| 37 5d 29 3b 0a 77 6f 62 | 62 6c 65 28 29 3b 0a 70 |7]);.wob|ble();.p|
|00005b90| 69 74 63 68 28 77 61 6e | 67 29 3b 0a 66 6c 6f 77 |itch(wan|g);.flow|
|00005ba0| 65 72 28 29 3b 0a 70 69 | 74 63 68 28 2d 77 61 6e |er();.pi|tch(-wan|
|00005bb0| 67 29 3b 0a 79 61 77 28 | 5b 33 2e 31 34 31 35 39 |g);.yaw(|[3.14159|
|00005bc0| 5d 29 3b 0a 77 6f 62 62 | 6c 65 28 29 3b 0a 70 69 |]);.wobb|le();.pi|
|00005bd0| 74 63 68 28 77 61 6e 67 | 29 3b 0a 66 6c 6f 77 65 |tch(wang|);.flowe|
|00005be0| 72 28 29 3b 0a 70 69 74 | 63 68 28 2d 77 61 6e 67 |r();.pit|ch(-wang|
|00005bf0| 29 3b 0a 7d 0a 66 75 6e | 63 20 76 6f 69 64 20 77 |);.}.fun|c void w|
|00005c00| 6f 62 62 6c 65 28 29 20 | 7b 0a 70 75 73 68 28 29 |obble() |{.push()|
|00005c10| 3b 0a 64 61 74 61 20 6e | 75 6d 20 73 65 67 73 20 |;.data n|um segs |
|00005c20| 3d 20 5b 33 30 5d 3b 20 | 0a 64 61 74 61 20 6e 75 |= [30]; |.data nu|
|00005c30| 6d 20 73 74 65 70 20 3d | 20 5b 31 2e 31 31 39 30 |m step =| [1.1190|
|00005c40| 35 5d 3a 5b 2d 31 2e 35 | 5d 3a 5b 32 5d 3b 20 0a |5]:[-1.5|]:[2]; .|
|00005c50| 64 61 74 61 20 6e 75 6d | 20 66 61 63 74 3b 20 0a |data num| fact; .|
|00005c60| 64 61 74 61 20 6e 75 6d | 20 6c 6f 63 75 73 31 3b |data num| locus1;|
|00005c70| 20 0a 64 61 74 61 20 6e | 75 6d 20 74 68 69 6b 20 | .data n|um thik |
|00005c80| 3d 20 5b 31 2e 30 35 5d | 3b 20 0a 64 61 74 61 20 |= [1.05]|; .data |
|00005c90| 6e 75 6d 20 62 65 6e 64 | 20 3d 20 5b 30 2e 30 30 |num bend| = [0.00|
|00005ca0| 39 38 36 35 35 5d 3a 5b | 2d 30 2e 31 5d 3a 5b 30 |98655]:[|-0.1]:[0|
|00005cb0| 2e 31 5d 3b 20 0a 64 61 | 74 61 20 76 65 63 33 20 |.1]; .da|ta vec3 |
|00005cc0| 62 6c 6f 77 3b 20 0a 64 | 61 74 61 20 6e 75 6d 20 |blow; .d|ata num |
|00005cd0| 73 65 70 20 3d 20 5b 32 | 2e 37 34 39 31 36 5d 3a |sep = [2|.74916]:|
|00005ce0| 5b 2d 31 35 5d 3a 5b 31 | 35 5d 3b 20 0a 64 61 74 |[-15]:[1|5]; .dat|
|00005cf0| 61 20 6e 75 6d 20 66 72 | 65 71 20 3d 20 5b 31 38 |a num fr|eq = [18|
|00005d00| 2e 35 31 36 33 5d 3a 5b | 31 35 5d 3a 5b 32 35 5d |.5163]:[|15]:[25]|
|00005d10| 3b 20 0a 64 61 74 61 20 | 6e 75 6d 20 66 72 65 71 |; .data |num freq|
|00005d20| 32 20 3d 20 5b 37 2e 30 | 31 33 30 35 5d 3a 5b 36 |2 = [7.0|1305]:[6|
|00005d30| 5d 3a 5b 31 32 5d 3b 20 | 0a 64 61 74 61 20 6e 75 |]:[12]; |.data nu|
|00005d40| 6d 20 77 61 76 65 3b 20 | 0a 64 61 74 61 20 6e 75 |m wave; |.data nu|
|00005d50| 6d 20 64 74 20 3d 20 5b | 30 2e 37 33 34 37 37 38 |m dt = [|0.734778|
|00005d60| 5d 3a 5b 2d 33 2e 31 34 | 31 5d 3a 5b 33 2e 31 34 |]:[-3.14|1]:[3.14|
|00005d70| 31 5d 3b 20 0a 66 6f 72 | 77 61 72 64 28 73 65 70 |1]; .for|ward(sep|
|00005d80| 29 3b 0a 65 67 67 5f 73 | 63 61 6c 65 28 5b 3c 31 |);.egg_s|cale([<1|
|00005d90| 2c 31 2c 33 2e 33 34 38 | 36 33 3e 5d 3a 5b 3c 31 |,1,3.348|63>]:[<1|
|00005da0| 2c 31 2c 32 3e 5d 3a 5b | 3c 31 2c 31 2c 35 3e 5d |,1,2>]:[|<1,1,5>]|
|00005db0| 29 3b 0a 66 6f 72 28 20 | 6e 75 6d 20 69 20 3d 20 |);.for( |num i = |
|00005dc0| 5b 30 5d 3b 20 6c 65 73 | 73 28 69 2c 73 65 67 73 |[0]; les|s(i,segs|
|00005dd0| 29 3b 20 28 69 2b 5b 31 | 5d 29 20 29 20 7b 0a 6c |); (i+[1|]) ) {.l|
|00005de0| 6f 63 75 73 31 20 3d 20 | 28 69 2f 28 73 65 67 73 |ocus1 = |(i/(segs|
|00005df0| 2d 5b 31 5d 29 29 3b 0a | 77 61 76 65 20 3d 20 28 |-[1]));.|wave = (|
|00005e00| 73 69 6e 28 28 28 6c 6f | 63 75 73 31 2a 66 72 65 |sin(((lo|cus1*fre|
|00005e10| 71 32 29 2b 64 74 29 29 | 2f 5b 31 34 5d 29 3b 0a |q2)+dt))|/[14]);.|
|00005e20| 66 61 63 74 20 3d 20 28 | 5b 31 5d 2b 28 73 69 6e |fact = (|[1]+(sin|
|00005e30| 28 28 6c 6f 63 75 73 31 | 2a 66 72 65 71 29 29 2f |((locus1|*freq))/|
|00005e40| 5b 32 5d 29 29 3b 0a 62 | 6c 6f 77 20 3d 20 76 33 |[2]));.b|low = v3|
|00005e50| 6d 61 6b 65 28 66 61 63 | 74 2c 66 61 63 74 2c 74 |make(fac|t,fact,t|
|00005e60| 68 69 6b 29 3b 0a 73 65 | 74 5f 70 72 69 6d 28 5b |hik);.se|t_prim([|
|00005e70| 34 5d 29 3b 0a 73 65 74 | 5f 63 6f 6c 6f 75 72 28 |4]);.set|_colour(|
|00005e80| 63 73 70 61 63 65 28 5b | 30 5d 2c 6c 6f 63 75 73 |cspace([|0],locus|
|00005e90| 31 29 29 3b 0a 66 6f 72 | 77 61 72 64 28 73 74 65 |1));.for|ward(ste|
|00005ea0| 70 29 3b 0a 65 67 67 5f | 73 63 61 6c 65 28 62 6c |p);.egg_|scale(bl|
|00005eb0| 6f 77 29 3b 0a 79 61 77 | 28 62 65 6e 64 29 3b 0a |ow);.yaw|(bend);.|
|00005ec0| 70 69 74 63 68 28 77 61 | 76 65 29 3b 0a 6c 61 79 |pitch(wa|ve);.lay|
|00005ed0| 28 29 3b 0a 7d 20 0a 70 | 6f 70 28 29 3b 0a 7d 0a |();.} .p|op();.}.|
|00005ee0| 66 75 6e 63 20 76 6f 69 | 64 20 66 6c 6f 77 65 72 |func voi|d flower|
|00005ef0| 28 29 20 7b 0a 70 75 73 | 68 28 29 3b 0a 73 65 74 |() {.pus|h();.set|
|00005f00| 5f 70 72 69 6d 28 5b 33 | 5d 29 3b 0a 64 61 74 61 |_prim([3|]);.data|
|00005f10| 20 6e 75 6d 20 70 65 74 | 73 20 3d 20 5b 31 31 2e | num pet|s = [11.|
|00005f20| 31 33 32 32 5d 3a 5b 34 | 5d 3a 5b 31 35 5d 3b 20 |1322]:[4|]:[15]; |
|00005f30| 0a 64 61 74 61 20 6e 75 | 6d 20 64 41 20 3d 20 5b |.data nu|m dA = [|
|00005f40| 2d 30 2e 30 38 32 35 31 | 35 31 5d 3a 5b 2d 30 2e |-0.08251|51]:[-0.|
|00005f50| 31 5d 3a 5b 30 2e 33 5d | 3b 20 0a 64 61 74 61 20 |1]:[0.3]|; .data |
|00005f60| 6e 75 6d 20 64 42 20 3d | 20 5b 30 2e 32 30 34 31 |num dB =| [0.2041|
|00005f70| 39 35 5d 3a 5b 2d 30 2e | 31 5d 3a 5b 31 2e 35 5d |95]:[-0.|1]:[1.5]|
|00005f80| 3b 20 0a 64 61 74 61 20 | 6e 75 6d 20 70 65 74 61 |; .data |num peta|
|00005f90| 6c 65 6e 20 3d 20 5b 31 | 31 2e 37 30 37 37 5d 3a |len = [1|1.7077]:|
|00005fa0| 5b 34 5d 3a 5b 31 32 5d | 3b 20 0a 64 61 74 61 20 |[4]:[12]|; .data |
|00005fb0| 6e 75 6d 20 69 6e 70 65 | 74 61 6c 65 6e 20 3d 20 |num inpe|talen = |
|00005fc0| 28 5b 31 5d 2f 70 65 74 | 61 6c 65 6e 29 3b 20 0a |([1]/pet|alen); .|
|00005fd0| 64 61 74 61 20 6e 75 6d | 20 6c 6f 63 75 73 32 3b |data num| locus2;|
|00005fe0| 20 0a 64 61 74 61 20 6e | 75 6d 20 6c 65 6e 20 3d | .data n|um len =|
|00005ff0| 20 5b 32 34 2e 36 34 37 | 38 5d 3a 5b 31 35 5d 3a | [24.647|8]:[15]:|
|00006000| 5b 33 35 5d 3b 20 0a 64 | 61 74 61 20 6e 75 6d 20 |[35]; .d|ata num |
|00006010| 62 75 64 20 3d 20 5b 37 | 2e 35 31 32 32 31 5d 3a |bud = [7|.51221]:|
|00006020| 5b 34 5d 3a 5b 39 5d 3b | 20 0a 64 61 74 61 20 6e |[4]:[9];| .data n|
|00006030| 75 6d 20 66 61 6e 67 20 | 3d 20 5b 2d 30 2e 38 38 |um fang |= [-0.88|
|00006040| 35 35 37 31 5d 3a 5b 2d | 31 5d 3a 5b 31 2e 35 5d |5571]:[-|1]:[1.5]|
|00006050| 3b 20 0a 64 61 74 61 20 | 76 65 63 33 20 73 74 72 |; .data |vec3 str|
|00006060| 65 74 63 68 3b 20 0a 64 | 61 74 61 20 76 65 63 33 |etch; .d|ata vec3|
|00006070| 20 69 6e 73 74 72 65 74 | 63 68 3b 20 0a 73 74 72 | instret|ch; .str|
|00006080| 65 74 63 68 20 3d 20 76 | 33 6d 61 6b 65 28 5b 31 |etch = v|3make([1|
|00006090| 5d 2c 5b 31 5d 2c 70 65 | 74 61 6c 65 6e 29 3b 0a |],[1],pe|talen);.|
|000060a0| 69 6e 73 74 72 65 74 63 | 68 20 3d 20 76 33 6d 61 |instretc|h = v3ma|
|000060b0| 6b 65 28 5b 31 5d 2c 5b | 31 5d 2c 69 6e 70 65 74 |ke([1],[|1],inpet|
|000060c0| 61 6c 65 6e 29 3b 0a 66 | 6f 72 77 61 72 64 28 6c |alen);.f|orward(l|
|000060d0| 65 6e 29 3b 0a 75 73 63 | 61 6c 65 28 5b 31 2e 32 |en);.usc|ale([1.2|
|000060e0| 5d 29 3b 0a 79 61 77 28 | 66 61 6e 67 29 3b 0a 65 |]);.yaw(|fang);.e|
|000060f0| 67 67 5f 73 63 61 6c 65 | 28 73 74 72 65 74 63 68 |gg_scale|(stretch|
|00006100| 29 3b 0a 66 6f 72 28 20 | 6e 75 6d 20 69 20 3d 20 |);.for( |num i = |
|00006110| 5b 30 5d 3b 20 6c 65 73 | 73 28 69 2c 70 65 74 73 |[0]; les|s(i,pets|
|00006120| 29 3b 20 28 69 2b 5b 31 | 5d 29 20 29 20 7b 0a 6c |); (i+[1|]) ) {.l|
|00006130| 6f 63 75 73 32 20 3d 20 | 28 69 2f 28 70 65 74 73 |ocus2 = |(i/(pets|
|00006140| 2d 5b 31 5d 29 29 3b 0a | 75 73 63 61 6c 65 28 5b |-[1]));.|uscale([|
|00006150| 31 2e 30 35 5d 29 3b 0a | 70 69 74 63 68 28 64 41 |1.05]);.|pitch(dA|
|00006160| 29 3b 0a 79 61 77 28 64 | 42 29 3b 0a 73 65 74 5f |);.yaw(d|B);.set_|
|00006170| 63 6f 6c 6f 75 72 28 63 | 73 70 61 63 65 28 5b 31 |colour(c|space([1|
|00006180| 5d 2c 6c 6f 63 75 73 32 | 29 29 3b 0a 6c 61 79 28 |],locus2|));.lay(|
|00006190| 29 3b 0a 70 75 73 68 28 | 29 3b 0a 65 67 67 5f 73 |);.push(|);.egg_s|
|000061a0| 63 61 6c 65 28 69 6e 73 | 74 72 65 74 63 68 29 3b |cale(ins|tretch);|
|000061b0| 0a 66 6f 72 77 61 72 64 | 28 62 75 64 29 3b 0a 6c |.forward|(bud);.l|
|000061c0| 61 79 28 29 3b 0a 70 6f | 70 28 29 3b 0a 7d 20 0a |ay();.po|p();.} .|
|000061d0| 70 6f 70 28 29 3b 0a 7d | 0a 66 75 6e 63 20 76 6f |pop();.}|.func vo|
|000061e0| 69 64 20 62 75 69 6c 64 | 43 53 70 61 63 65 41 28 |id build|CSpaceA(|
|000061f0| 20 69 6e 74 20 69 6e 64 | 65 78 20 29 20 7b 0a 64 | int ind|ex ) {.d|
|00006200| 61 74 61 20 63 6f 6c 6f | 75 72 20 63 31 20 3d 20 |ata colo|ur c1 = |
|00006210| 5b 3c 30 2e 39 33 34 33 | 31 31 2c 30 2e 38 35 38 |[<0.9343|11,0.858|
|00006220| 34 34 33 2c 30 2e 38 35 | 31 33 34 38 2c 30 2e 39 |443,0.85|1348,0.9|
|00006230| 31 32 30 39 36 3e 5d 3a | 5b 3c 30 2c 30 2c 30 2e |12096>]:|[<0,0,0.|
|00006240| 37 2c 30 3e 5d 3a 5b 3c | 31 2c 31 2c 31 2c 31 3e |7,0>]:[<|1,1,1,1>|
|00006250| 5d 3b 20 0a 64 61 74 61 | 20 63 6f 6c 6f 75 72 20 |]; .data| colour |
|00006260| 63 32 20 3d 20 5b 3c 30 | 2e 36 34 35 33 39 36 2c |c2 = [<0|.645396,|
|00006270| 30 2e 33 37 39 35 39 34 | 2c 30 2e 38 39 31 38 39 |0.379594|,0.89189|
|00006280| 34 2c 30 2e 31 30 38 39 | 36 38 3e 5d 3a 5b 3c 30 |4,0.1089|68>]:[<0|
|00006290| 2c 30 2c 30 2c 30 3e 5d | 3a 5b 3c 31 2c 31 2c 31 |,0,0,0>]|:[<1,1,1|
|000062a0| 2c 31 3e 5d 3b 20 0a 64 | 61 74 61 20 63 6f 6c 6f |,1>]; .d|ata colo|
|000062b0| 75 72 20 63 33 20 3d 20 | 5b 3c 30 2e 33 32 34 36 |ur c3 = |[<0.3246|
|000062c0| 36 39 2c 30 2e 34 37 38 | 38 33 34 2c 30 2e 39 30 |69,0.478|834,0.90|
|000062d0| 37 39 30 35 2c 30 2e 30 | 36 39 31 36 30 33 3e 5d |7905,0.0|691603>]|
|000062e0| 3a 5b 3c 30 2c 30 2c 30 | 2e 37 2c 30 3e 5d 3a 5b |:[<0,0,0|.7,0>]:[|
|000062f0| 3c 31 2c 31 2c 31 2c 31 | 3e 5d 3b 20 0a 69 6e 69 |<1,1,1,1|>]; .ini|
|00006300| 74 5f 63 73 70 61 63 65 | 28 69 6e 64 65 78 2c 63 |t_cspace|(index,c|
|00006310| 31 29 3b 0a 65 78 74 65 | 6e 64 5f 63 73 70 61 63 |1);.exte|nd_cspac|
|00006320| 65 28 69 6e 64 65 78 2c | 5b 30 2e 35 5d 2c 63 32 |e(index,|[0.5],c2|
|00006330| 29 3b 0a 65 78 74 65 6e | 64 5f 63 73 70 61 63 65 |);.exten|d_cspace|
|00006340| 28 69 6e 64 65 78 2c 5b | 30 2e 35 5d 2c 63 33 29 |(index,[|0.5],c3)|
|00006350| 3b 0a 7d 0a 66 75 6e 63 | 20 76 6f 69 64 20 62 75 |;.}.func| void bu|
|00006360| 69 6c 64 43 53 70 61 63 | 65 42 28 20 69 6e 74 20 |ildCSpac|eB( int |
|00006370| 69 6e 64 65 78 20 29 20 | 7b 0a 64 61 74 61 20 63 |index ) |{.data c|
|00006380| 6f 6c 6f 75 72 20 63 30 | 20 3d 20 5b 3c 30 2e 30 |olour c0| = [<0.0|
|00006390| 36 37 30 32 33 33 2c 30 | 2e 37 32 36 35 31 36 2c |670233,0|.726516,|
|000063a0| 30 2e 38 34 35 38 36 35 | 2c 30 3e 5d 3a 5b 3c 30 |0.845865|,0>]:[<0|
|000063b0| 2c 30 2c 30 2c 30 3e 5d | 3a 5b 3c 31 2c 31 2c 31 |,0,0,0>]|:[<1,1,1|
|000063c0| 2c 30 3e 5d 3b 20 0a 64 | 61 74 61 20 63 6f 6c 6f |,0>]; .d|ata colo|
|000063d0| 75 72 20 63 31 20 3d 20 | 5b 3c 30 2e 33 38 34 36 |ur c1 = |[<0.3846|
|000063e0| 34 39 2c 30 2e 39 31 34 | 31 32 36 2c 30 2e 39 39 |49,0.914|126,0.99|
|000063f0| 39 39 39 2c 30 2e 39 39 | 39 39 39 3e 5d 3a 5b 3c |999,0.99|999>]:[<|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.