libcm is a C development framework with an emphasis on audio signal processing applications.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791
  1. #include "cmPrefix.h"
  2. #include "cmGlobal.h"
  3. #include "cmFloatTypes.h"
  4. #include "cmRpt.h"
  5. #include "cmErr.h"
  6. #include "cmCtx.h"
  7. #include "cmMem.h"
  8. #include "cmMallocDebug.h"
  9. #include "cmLinkedHeap.h"
  10. #include "cmText.h"
  11. #include "cmFileSys.h"
  12. #include "cmSymTbl.h"
  13. #include "cmJson.h"
  14. #include "cmPrefs.h"
  15. #include "cmDspValue.h"
  16. #include "cmMsgProtocol.h"
  17. #include "cmThread.h"
  18. #include "cmUdpPort.h"
  19. #include "cmUdpNet.h"
  20. #include "cmTime.h"
  21. #include "cmAudioSys.h"
  22. #include "cmProcObj.h"
  23. #include "cmDspCtx.h"
  24. #include "cmDspClass.h"
  25. #include "cmDspSys.h"
  26. #include "cmDspPgm.h"
  27. #include "cmAudioFile.h"
  28. #include "cmProcObj.h"
  29. #include "cmProc.h"
  30. #include "cmProc3.h"
  31. #include "cmVectOpsTemplateMain.h"
  32. #include "cmVectOps.h"
  33. typedef struct
  34. {
  35. const cmChar_t* tlFn;
  36. const cmChar_t* tlPrefixPath;
  37. const cmChar_t* scFn;
  38. const cmChar_t* modFn;
  39. const cmChar_t* measFn;
  40. const cmChar_t* recordDir;
  41. const cmChar_t* midiDevice;
  42. const cmChar_t* midiOutPort;
  43. } krRsrc_t;
  44. cmDspRC_t krLoadRsrc(cmDspSysH_t h, cmErr_t* err, krRsrc_t* r)
  45. {
  46. cmDspRC_t rc;
  47. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  48. return rc;
  49. cmDspRsrcString(h,&r->tlFn, "timeLineFn", NULL);
  50. cmDspRsrcString(h,&r->tlPrefixPath,"tlPrefixPath", NULL);
  51. cmDspRsrcString(h,&r->scFn, "scoreFn", NULL);
  52. cmDspRsrcString(h,&r->modFn, "modFn", NULL);
  53. cmDspRsrcString(h,&r->measFn, "measFn", NULL);
  54. cmDspRsrcString(h,&r->recordDir, "recordDir", NULL);
  55. cmDspRsrcString(h,&r->midiDevice, "midiDevice", NULL);
  56. cmDspRsrcString(h,&r->midiOutPort, "midiOutPort", NULL);
  57. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  58. cmErrMsg(err,rc,"A KR DSP resource load failed.");
  59. return rc;
  60. }
  61. // connection information for 1 transform channel
  62. typedef struct
  63. {
  64. cmDspInst_t* achan;
  65. cmDspInst_t* kr0; // audio input
  66. cmDspInst_t* kr1;
  67. cmDspInst_t* cmp; // audio output
  68. } cmDspTlXform_t;
  69. const cmChar_t* _mlbl(const cmChar_t* prefix, unsigned ch )
  70. {
  71. static char s[128];
  72. s[127]=0;
  73. snprintf(s,127,"%s%i",prefix,ch);
  74. return s;
  75. }
  76. #define mlbl(a) _mlbl(a,mch)
  77. #define lbl(a) cmDspSysPrintLabel(a,ch)
  78. void _cmDspSys_TlXformChain( cmDspSysH_t h, cmDspTlXform_t* c, unsigned preGrpSymId, unsigned cmpPreGrpSymId, cmDspInst_t* modp, unsigned ch, unsigned mch )
  79. {
  80. unsigned measRtrChCnt = 6; // note: router channel 6 is not connected
  81. int krWndSmpCnt = 2048;
  82. int krHopFact = 4;
  83. unsigned xfadeChCnt = 2;
  84. double xfadeMs = 50;
  85. bool xfadeInitFl = true;
  86. double mixGain = 1.0;
  87. bool cmpBypassFl = false;
  88. double cmpInGain = 3.0;
  89. double cmpThreshDb = -40.0;
  90. double cmpRatio_num = 5.0;
  91. double cmpAtkMs = 20.0;
  92. double cmpRlsMs = 100.0;
  93. double cmpMakeup = 1.0;
  94. double cmpWndMaxMs = 1000.0;
  95. double cmpWndMs = 200.0;
  96. cmDspInst_t* achan = cmDspSysAllocInst(h, "AvailCh", NULL, 1, xfadeChCnt );
  97. // Measurement scale/range
  98. cmDspInst_t* even_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.8, 1.1, 0.0, 1.0 );
  99. cmDspInst_t* dynm_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 4.0, 0.01, 1.0 );
  100. cmDspInst_t* tmpo_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 80.0, 120.0, 0.01, 1.0 );
  101. cmDspInst_t* cost_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, 0.001, 1.0 );
  102. // Measurement -> parameter mappers
  103. cmDspInst_t* even_rt = cmDspSysAllocInst(h, "Router", NULL, 2, measRtrChCnt, measRtrChCnt-1 );
  104. cmDspInst_t* dynm_rt = cmDspSysAllocInst(h, "Router", NULL, 2, measRtrChCnt, measRtrChCnt-1 );
  105. cmDspInst_t* tmpo_rt = cmDspSysAllocInst(h, "Router", NULL, 2, measRtrChCnt, measRtrChCnt-1 );
  106. cmDspInst_t* cost_rt = cmDspSysAllocInst(h, "Router", NULL, 2, measRtrChCnt, measRtrChCnt-1 );
  107. // Scale/ranges applied to incoming measurements.
  108. cmDspInst_t* thr_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, 0.01, 100.0 );
  109. cmDspInst_t* upr_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, -1.0, 5.0 );
  110. cmDspInst_t* lwr_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, -5.0, 5.0 );
  111. cmDspInst_t* off_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, 0.0, 100.0 );
  112. cmDspInst_t* wet_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, 0.0, 1.0 );
  113. // Parameter-> kr routers (routers used to cross-fade between the two kr units)
  114. unsigned paramRtChCnt = 2;
  115. cmDspInst_t* mod_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  116. cmDspInst_t* wnd_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  117. cmDspInst_t* hop_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  118. cmDspInst_t* thr_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  119. cmDspInst_t* upr_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  120. cmDspInst_t* lwr_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  121. cmDspInst_t* inv_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  122. cmDspInst_t* off_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  123. cmDspInst_t* wet_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  124. // Audio processors
  125. cmDspInst_t* kr0 = cmDspSysAllocInst(h, "Kr", NULL, 2, krWndSmpCnt, krHopFact );
  126. cmDspInst_t* kr1 = cmDspSysAllocInst(h, "Kr", NULL, 2, krWndSmpCnt, krHopFact );
  127. cmDspInst_t* xfad = cmDspSysAllocInst(h, "Xfader", NULL, 3, xfadeChCnt, xfadeMs, xfadeInitFl );
  128. cmDspInst_t* mix = cmDspSysAllocInst(h, "AMix", NULL, 3, xfadeChCnt, mixGain, mixGain );
  129. cmDspInst_t* cmp = cmDspSysAllocInst(h, "Compressor", NULL, 8, cmpBypassFl, cmpThreshDb, cmpRatio_num, cmpAtkMs, cmpRlsMs, cmpMakeup, cmpWndMs, cmpWndMaxMs );
  130. // Internal audio connections
  131. cmDspSysConnectAudio(h, kr0, "out", xfad, "in-0");
  132. cmDspSysConnectAudio(h, kr1, "out", xfad, "in-1");
  133. cmDspSysConnectAudio(h, xfad, "out-0", mix, "in-0");
  134. cmDspSysConnectAudio(h, xfad, "out-1", mix, "in-1");
  135. cmDspSysConnectAudio(h, mix, "out", cmp, "in" );
  136. // active channel <-> cross-fade connections
  137. cmDspSysInstallCb(h, achan, "reset", xfad, "reset", NULL);
  138. cmDspSysInstallCb(h, achan, "gate-0", xfad, "gate-0", NULL );
  139. cmDspSysInstallCb(h, achan, "gate-1", xfad, "gate-1", NULL );
  140. cmDspSysInstallCb(h, xfad, "state-0", achan, "dis-0", NULL );
  141. cmDspSysInstallCb(h, xfad, "state-1", achan, "dis-1", NULL );
  142. // Measurement Number Controls
  143. cmDspInst_t* min_dynm_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min In Dyn"), 0.0, 10.0, 1.0, 0.0);
  144. cmDspInst_t* max_dynm_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max In Dyn"), 0.0, 10.0, 1.0, 4.0);
  145. cmDspInst_t* dynm_map_menu = cmDspSysAllocMsgListP(h,preGrpSymId, NULL, lbl("DynSel 0"), NULL, "measMenu", measRtrChCnt-1);
  146. cmDspInst_t* min_even_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min In Even"), 0.0, 1.0, 0.001, 0.75);
  147. cmDspInst_t* max_even_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max In Even"), 0.0, 3.0, 0.001, 1.0);
  148. cmDspInst_t* even_map_menu = cmDspSysAllocMsgListP( h,preGrpSymId, NULL, lbl("EvenSel"), NULL, "measMenu", measRtrChCnt-1);
  149. cmDspSysNewColumn(h,0);
  150. cmDspInst_t* min_tmpo_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min In Tempo"), 0.0, 200.0, 1.0, 80.0);
  151. cmDspInst_t* max_tmpo_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max In Tempo"), 0.0, 200.0, 1.0, 120.0);
  152. cmDspInst_t* tmpo_map_menu = cmDspSysAllocMsgListP( h,preGrpSymId, NULL, lbl("TempoSel"), NULL, "measMenu", measRtrChCnt-1);
  153. cmDspInst_t* min_cost_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min In Cost"), 0.0, 1.0, 0.01, 0.0);
  154. cmDspInst_t* max_cost_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max In Cost"), 0.0, 1.0, 0.01, 1.0);
  155. cmDspInst_t* cost_map_menu = cmDspSysAllocMsgListP( h,preGrpSymId, NULL, lbl("CostSel"), NULL, "measMenu", measRtrChCnt-1);
  156. cmDspSysInstallCb(h, min_dynm_ctl, "val", dynm_sr, "min_in", NULL );
  157. cmDspSysInstallCb(h, max_dynm_ctl, "val", dynm_sr, "min_in", NULL );
  158. cmDspSysInstallCb(h, dynm_map_menu,"out", dynm_rt, "sel", NULL );
  159. cmDspSysInstallCb(h, dynm_sr, "val_out", dynm_rt, "f-in", NULL );
  160. cmDspSysInstallCb(h, min_even_ctl, "val", even_sr, "min_in", NULL );
  161. cmDspSysInstallCb(h, max_even_ctl, "val", even_sr, "min_in", NULL );
  162. cmDspSysInstallCb(h, even_map_menu,"out", even_rt, "sel", NULL );
  163. cmDspSysInstallCb(h, even_sr, "val_out", even_rt, "f-in", NULL );
  164. cmDspSysInstallCb(h, min_tmpo_ctl, "val", tmpo_sr, "min_in", NULL );
  165. cmDspSysInstallCb(h, max_tmpo_ctl, "val", tmpo_sr, "min_in", NULL );
  166. cmDspSysInstallCb(h, tmpo_map_menu,"out", tmpo_rt, "sel", NULL );
  167. cmDspSysInstallCb(h, tmpo_sr, "val_out", tmpo_rt, "f-in", NULL );
  168. cmDspSysInstallCb(h, min_cost_ctl, "val", cost_sr, "min_in", NULL );
  169. cmDspSysInstallCb(h, max_cost_ctl, "val", cost_sr, "min_in", NULL );
  170. cmDspSysInstallCb(h, cost_map_menu,"out", cost_rt, "sel", NULL );
  171. cmDspSysInstallCb(h, cost_sr, "val_out", cost_rt, "f-in", NULL );
  172. cmDspSysNewColumn(h,0);
  173. cmDspInst_t* min_thr_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min Thresh"), 0.0,100.0, 1.0, 30.0);
  174. cmDspInst_t* max_thr_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max Thresh"), 0.0,100.0, 1.0, 80.0);
  175. cmDspInst_t* min_upr_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min Upr"), -1.0, 1.0, 0.001, -0.5);
  176. cmDspInst_t* max_upr_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max Upr"), -1.0, 1.0, 0.001, 0.5);
  177. cmDspInst_t* min_lwr_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min Lwr"), 0.0, -1.0, 5.0, 1.0);
  178. cmDspInst_t* max_lwr_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max Lwr"), 0.0, -1.0, 5.0, 3.0);
  179. cmDspInst_t* min_off_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min Off"), 0.0, 50.0, 0.1, 30.0);
  180. cmDspInst_t* max_off_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max Off"), 0.0, 50.0, 0.1, 30.0);
  181. cmDspInst_t* min_wet_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min Wet"), 0.0, 1.0, 0.01, 1.0);
  182. cmDspInst_t* max_wet_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max Wet"), 0.0, 1.0, 0.01, 1.0);
  183. // Parameter number controls
  184. cmDspSysNewColumn(h,0);
  185. cmDspInst_t* mod_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Mode"), 0.0, 4.0, 1.0, 1.0);
  186. cmDspInst_t* wnd_ctl = cmDspSysAllocMsgListP(h,preGrpSymId,NULL, lbl("WndSmpCnt"), NULL, "wndSmpCnt", 2);
  187. cmDspInst_t* hop_ctl = cmDspSysAllocMsgListP(h,preGrpSymId,NULL, lbl("HopFact"), NULL, "hopFact", 2);
  188. cmDspInst_t* thr_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Threshold"), 0.0, 100.0, 1.0, 60.0 );
  189. cmDspInst_t* upr_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Upr slope"), 0.0, 10.0, 0.01, 0.0 );
  190. cmDspInst_t* lwr_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Lwr slope"), 0.3, 10.0, 0.01, 2.0 );
  191. cmDspInst_t* off_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Offset"), 0.0, 100.0, 0.01, 20.0 );
  192. cmDspInst_t* inv_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Invert"), 0.0, 1.0, 1.0, 0.0 );
  193. cmDspInst_t* wet_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Wet Dry"), 0.0, 1.0, 0.001, 1.0 );
  194. cmDspSysInstallCb(h, mod_ctl, "val", mod_rt, "f-in", NULL );
  195. cmDspSysInstallCb(h, achan, "ch", mod_rt, "sel", NULL ); // ach->rt sel
  196. cmDspSysInstallCb(h, mod_rt, "f-out-0", kr0, "mode", NULL ); // mode->kr
  197. cmDspSysInstallCb(h, mod_rt, "f-out-1", kr1, "mode", NULL ); // mode->kr
  198. cmDspSysInstallCb(h, wnd_ctl, "out", wnd_rt, "f-in", NULL );
  199. cmDspSysInstallCb(h, achan, "ch", wnd_rt, "sel", NULL ); // ach->rt sel
  200. cmDspSysInstallCb(h, wnd_rt, "f-out-0", kr0, "wndn", NULL ); // wndn->kr
  201. cmDspSysInstallCb(h, wnd_rt, "f-out-1", kr1, "wndn", NULL ); // wndn->kr
  202. cmDspSysInstallCb(h, hop_ctl, "out", hop_rt, "f-in", NULL );
  203. cmDspSysInstallCb(h, achan, "ch", hop_rt, "sel", NULL ); // ach->rt sel
  204. cmDspSysInstallCb(h, hop_rt, "f-out-0", kr0, "hopf", NULL ); // hopf->kr
  205. cmDspSysInstallCb(h, hop_rt, "f-out-1", kr1, "hopf", NULL ); // hopf->kr
  206. cmDspSysInstallCb(h, min_thr_ctl, "val", thr_sr, "min_out", NULL );
  207. cmDspSysInstallCb(h, max_thr_ctl, "val", thr_sr, "max_out", NULL );
  208. cmDspSysInstallCb(h, even_rt, "f-out-0", thr_sr, "val_in", NULL );
  209. cmDspSysInstallCb(h, dynm_rt, "f-out-0", thr_sr, "val_in", NULL );
  210. cmDspSysInstallCb(h, tmpo_rt, "f-out-0", thr_sr, "val_in", NULL );
  211. cmDspSysInstallCb(h, cost_rt, "f-out-0", thr_sr, "val_in", NULL );
  212. cmDspSysInstallCb(h, thr_sr, "val_out", thr_ctl,"val", NULL );
  213. cmDspSysInstallCb(h, thr_ctl, "val", thr_rt, "f-in", NULL );
  214. cmDspSysInstallCb(h, achan, "ch", thr_rt, "sel", NULL ); // ach->rt sel
  215. cmDspSysInstallCb(h, thr_rt, "f-out-0", kr0, "thrh", NULL ); // thr->kr
  216. cmDspSysInstallCb(h, thr_rt, "f-out-1", kr1, "thrh", NULL ); // thr->kr
  217. cmDspSysInstallCb(h, min_upr_ctl, "val", upr_sr, "min_out", NULL );
  218. cmDspSysInstallCb(h, max_upr_ctl, "val", upr_sr, "max_out", NULL );
  219. cmDspSysInstallCb(h, even_rt, "f-out-1", upr_sr, "val_in", NULL );
  220. cmDspSysInstallCb(h, dynm_rt, "f-out-1", upr_sr, "val_in", NULL );
  221. cmDspSysInstallCb(h, tmpo_rt, "f-out-1", upr_sr, "val_in", NULL );
  222. cmDspSysInstallCb(h, cost_rt, "f-out-1", upr_sr, "val_in", NULL );
  223. cmDspSysInstallCb(h, upr_sr, "val_out", upr_ctl,"val", NULL );
  224. cmDspSysInstallCb(h, upr_ctl, "val", upr_rt, "f-in", NULL );
  225. cmDspSysInstallCb(h, achan, "ch", upr_rt, "sel", NULL ); // ach->rt sel
  226. cmDspSysInstallCb(h, upr_rt, "f-out-0", kr0, "uprs", NULL ); // upr->kr
  227. cmDspSysInstallCb(h, upr_rt, "f-out-1", kr1, "uprs", NULL ); // upr->kr
  228. cmDspSysInstallCb(h, min_lwr_ctl, "val", lwr_sr, "min_out", NULL );
  229. cmDspSysInstallCb(h, max_lwr_ctl, "val", lwr_sr, "max_out", NULL );
  230. cmDspSysInstallCb(h, even_rt, "f-out-2", lwr_sr, "val_in", NULL );
  231. cmDspSysInstallCb(h, dynm_rt, "f-out-2", lwr_sr, "val_in", NULL );
  232. cmDspSysInstallCb(h, tmpo_rt, "f-out-2", lwr_sr, "val_in", NULL );
  233. cmDspSysInstallCb(h, cost_rt, "f-out-2", lwr_sr, "val_in", NULL );
  234. cmDspSysInstallCb(h, lwr_sr, "val_out", lwr_ctl,"val", NULL );
  235. cmDspSysInstallCb(h, lwr_ctl, "val", lwr_rt, "f-in", NULL );
  236. cmDspSysInstallCb(h, achan, "ch", lwr_rt, "sel", NULL ); // ach->rt sel
  237. cmDspSysInstallCb(h, lwr_rt, "f-out-0", kr0, "lwrs", NULL ); // lwr->kr
  238. cmDspSysInstallCb(h, lwr_rt, "f-out-1", kr1, "lwrs", NULL ); // lwr->kr
  239. cmDspSysInstallCb(h, min_off_ctl, "val", off_sr, "min_out", NULL );
  240. cmDspSysInstallCb(h, max_off_ctl, "val", off_sr, "max_out", NULL );
  241. cmDspSysInstallCb(h, even_rt, "f-out-3", off_sr, "val_in", NULL );
  242. cmDspSysInstallCb(h, dynm_rt, "f-out-3", off_sr, "val_in", NULL );
  243. cmDspSysInstallCb(h, tmpo_rt, "f-out-3", off_sr, "val_in", NULL );
  244. cmDspSysInstallCb(h, cost_rt, "f-out-3", off_sr, "val_in", NULL );
  245. cmDspSysInstallCb(h, off_sr, "val_out", off_ctl,"val", NULL );
  246. cmDspSysInstallCb(h, off_ctl, "val", off_rt, "f-in", NULL );
  247. cmDspSysInstallCb(h, achan, "ch", off_rt, "sel", NULL ); // ach->rt sel
  248. cmDspSysInstallCb(h, off_rt, "f-out-0", kr0, "offs", NULL ); // off->kr
  249. cmDspSysInstallCb(h, off_rt, "f-out-1", kr1, "offs", NULL ); // off->kr
  250. cmDspSysInstallCb(h, inv_ctl, "val", inv_rt, "f-in", NULL );
  251. cmDspSysInstallCb(h, achan, "ch", inv_rt, "sel", NULL ); // ach->rt sel
  252. cmDspSysInstallCb(h, inv_rt, "f-out-0", kr0, "invt", NULL ); // inv->kr
  253. cmDspSysInstallCb(h, inv_rt, "f-out-1", kr1, "invt", NULL ); // inv->kr
  254. cmDspSysInstallCb(h, min_wet_ctl, "val", wet_sr, "min_out", NULL );
  255. cmDspSysInstallCb(h, max_wet_ctl, "val", wet_sr, "max_out", NULL );
  256. cmDspSysInstallCb(h, even_rt, "f-out-4", wet_sr, "val_in", NULL );
  257. cmDspSysInstallCb(h, dynm_rt, "f-out-4", wet_sr, "val_in", NULL );
  258. cmDspSysInstallCb(h, tmpo_rt, "f-out-4", wet_sr, "val_in", NULL );
  259. cmDspSysInstallCb(h, cost_rt, "f-out-4", wet_sr, "val_in", NULL );
  260. cmDspSysInstallCb(h, wet_sr, "val_out", wet_ctl,"val", NULL );
  261. cmDspSysInstallCb(h, wet_ctl, "val", wet_rt, "f-in", NULL );
  262. cmDspSysInstallCb(h, achan, "ch", wet_rt, "sel", NULL ); // ach->rt sel
  263. cmDspSysInstallCb(h, wet_rt, "f-out-0", kr0, "wet", NULL ); // wet->kr
  264. cmDspSysInstallCb(h, wet_rt, "f-out-1", kr1, "wet", NULL ); // wet->kr
  265. cmDspSysNewColumn(h,0);
  266. cmDspInst_t* cmp_byp = cmDspSysAllocCheckP( h, cmpPreGrpSymId, NULL, lbl("Bypass"), 1.0 );
  267. cmDspInst_t* cmp_igain = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("In Gain"), 0.0, 10.0, 0.1, cmpInGain);
  268. cmDspInst_t* cmp_thr = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("ThreshDb"), -100.0, 0.0, 0.1, cmpThreshDb);
  269. cmDspInst_t* cmp_rat = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("Ratio"), 0.1, 100, 0.1, cmpRatio_num);
  270. cmDspInst_t* cmp_atk = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("Atk Ms"), 0.0, 1000.0, 0.1, cmpAtkMs);
  271. cmDspInst_t* cmp_rls = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("Rls Ms"), 0.0, 1000.0, 0.1, cmpRlsMs);
  272. cmDspInst_t* cmp_mkup = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("Makeup"), 0.0, 10.0, 0.01, cmpMakeup);
  273. cmDspInst_t* cmp_wnd = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("Wnd Ms"), 1.0, cmpWndMaxMs, 1.0, cmpWndMs );
  274. cmDspInst_t* cmp_mtr = cmDspSysAllocInst(h,"Meter",lbl("Env"), 3, 0.0, 0.0, 1.0);
  275. cmDspSysInstallCb(h, cmp_byp, "out", cmp, "bypass", NULL );
  276. cmDspSysInstallCb(h, cmp_igain,"val", cmp, "igain", NULL );
  277. cmDspSysInstallCb(h, cmp_thr, "val", cmp, "thr", NULL );
  278. cmDspSysInstallCb(h, cmp_rat, "val", cmp, "ratio", NULL );
  279. cmDspSysInstallCb(h, cmp_atk, "val", cmp, "atk", NULL );
  280. cmDspSysInstallCb(h, cmp_rls, "val", cmp, "rls", NULL );
  281. cmDspSysInstallCb(h, cmp_mkup, "val", cmp, "ogain", NULL );
  282. cmDspSysInstallCb(h, cmp_wnd, "val", cmp, "wnd", NULL );
  283. cmDspSysInstallCb(h, cmp, "env", cmp_mtr, "in", NULL );
  284. cmDspSysInstallCb(h, modp, mlbl("cbyp"), cmp_byp, "in", NULL );
  285. cmDspSysInstallCb(h, modp, mlbl("cigain"), cmp_igain,"val", NULL );
  286. cmDspSysInstallCb(h, modp, mlbl("cthrsh"), cmp_thr, "val", NULL );
  287. cmDspSysInstallCb(h, modp, mlbl("cratio"), cmp_rat, "val", NULL );
  288. cmDspSysInstallCb(h, modp, mlbl("catkms"), cmp_atk, "val", NULL );
  289. cmDspSysInstallCb(h, modp, mlbl("crlsms"), cmp_rls, "val", NULL );
  290. cmDspSysInstallCb(h, modp, mlbl("cmakeup"), cmp_mkup, "val", NULL );
  291. cmDspSysInstallCb(h, modp, mlbl("cwndms"), cmp_wnd, "val", NULL );
  292. //
  293. cmDspInst_t* xfadMs = cmDspSysAllocInst(h,"Scalar", lbl("Xfade Ms"), 5, kNumberDuiId, 0.0, 1000.0,0.01, 50.0 );
  294. cmDspSysInstallCb(h, xfadMs, "val", xfad, "ms", NULL );
  295. cmDspSysInstallCb(h, modp, mlbl("xfad"), xfadMs, "val", NULL);
  296. cmDspSysInstallCb(h, modp, mlbl("win"), wnd_ctl, "sel", NULL );
  297. cmDspSysInstallCb(h, modp, mlbl("hop"), hop_ctl, "sel", NULL );
  298. cmDspSysInstallCb(h, modp, mlbl("mod"), mod_ctl, "val", NULL );
  299. cmDspSysInstallCb(h, modp, mlbl("thr"), thr_ctl, "val", NULL );
  300. cmDspSysInstallCb(h, modp, mlbl("upr"), upr_ctl, "val", NULL );
  301. cmDspSysInstallCb(h, modp, mlbl("lwr"), lwr_ctl, "val", NULL );
  302. cmDspSysInstallCb(h, modp, mlbl("mint"), min_thr_ctl, "val", NULL );
  303. cmDspSysInstallCb(h, modp, mlbl("maxt"), max_thr_ctl, "val", NULL );
  304. cmDspSysInstallCb(h, modp, mlbl("minu"), min_upr_ctl, "val", NULL );
  305. cmDspSysInstallCb(h, modp, mlbl("maxu"), max_upr_ctl, "val", NULL );
  306. cmDspSysInstallCb(h, modp, mlbl("minl"), min_lwr_ctl, "val", NULL );
  307. cmDspSysInstallCb(h, modp, mlbl("maxl"), max_lwr_ctl, "val", NULL );
  308. cmDspSysInstallCb(h, modp, mlbl("sw"), achan, "trig", NULL ); // See also: amp.sfloc->achan.trig
  309. c->achan = achan;
  310. c->kr0 = kr0;
  311. c->kr1 = kr1;
  312. c->cmp = cmp;
  313. }
  314. cmDspRC_t _cmDspSysPgm_TimeLine(cmDspSysH_t h, void** userPtrPtr )
  315. {
  316. cmDspRC_t rc = kOkDspRC;
  317. cmCtx_t* cmCtx = cmDspSysPgmCtx(h);
  318. cmErr_t err;
  319. krRsrc_t r;
  320. bool fragFl = true;
  321. bool useWtFl = true;
  322. unsigned wtLoopCnt = 1; // 1=play once (-1=loop forever)
  323. unsigned wtInitMode = 0; // initial wt mode is 'silence'
  324. unsigned wtSmpCnt = floor(cmDspSysSampleRate(h)); // wt length == srate
  325. unsigned sfBufCnt = 7; // length of the MIDI event buffer
  326. unsigned sfMaxWndCnt = 10; // length of the score event buffer
  327. unsigned sfMinVel = 5; // ignore MIDI events below this velocity
  328. bool sfEnaMeasFl = false;
  329. double recdPlayInitAllocSecs = 10.0;
  330. double recdPlayMaxLaSecs = 2.0;
  331. double recdPlayCurLaSecs = 0.1;
  332. double recdPlayFadeRateDbPerSec = 4.0;
  333. memset(&r,0,sizeof(r));
  334. cmErrSetup(&err,&cmCtx->rpt,"Kr Timeline");
  335. if( krLoadRsrc(h,&err,&r) != kOkDspRC )
  336. return rc;
  337. cmDspInst_t* ai0p = cmDspSysAllocInst(h,"AudioIn", NULL, 1, 0);
  338. cmDspInst_t* ai1p = cmDspSysAllocInst(h,"AudioIn", NULL, 1, 1);
  339. cmDspInst_t* tlp = cmDspSysAllocInst(h,"TimeLine", "tl", 2, r.tlFn, r.tlPrefixPath );
  340. cmDspInst_t* scp = cmDspSysAllocInst(h,"Score", "sc", 1, r.scFn );
  341. cmDspInst_t* php = cmDspSysAllocInst(h,"Phasor", NULL, 1, cmDspSysSampleRate(h) );
  342. cmDspInst_t* wtp = cmDspSysAllocInst(h,"WaveTable", NULL, 4, wtSmpCnt, wtInitMode, NULL, wtLoopCnt );
  343. cmDspInst_t* pts = cmDspSysAllocInst(h,"PortToSym", NULL, 2, "on", "off" );
  344. cmDspInst_t* mip = cmDspSysAllocInst(h,"MidiIn", NULL, 0 );
  345. cmDspInst_t* mfp = cmDspSysAllocInst(h,"MidiFilePlay",NULL, 0 );
  346. cmDspInst_t* nmp = cmDspSysAllocInst(h,"NanoMap", NULL, 0 );
  347. cmDspInst_t* mop = cmDspSysAllocInst(h,"MidiOut", NULL, 2, r.midiDevice,r.midiOutPort);
  348. cmDspInst_t* sfp = cmDspSysAllocInst(h,"ScFol", NULL, 1, r.scFn, sfBufCnt, sfMaxWndCnt, sfMinVel, sfEnaMeasFl );
  349. cmDspInst_t* amp = cmDspSysAllocInst(h,"ActiveMeas", NULL, 1, 100 );
  350. cmDspInst_t* rpp = cmDspSysAllocInst(h,"RecdPlay", NULL, 6, 2, r.scFn, recdPlayInitAllocSecs, recdPlayMaxLaSecs, recdPlayCurLaSecs, recdPlayFadeRateDbPerSec);
  351. cmDspInst_t* modp = cmDspSysAllocInst(h,"ScMod", NULL, 2, r.modFn, "m1" );
  352. cmDspInst_t* modr = cmDspSysAllocInst(h,"ScMod", NULL, 2, r.modFn, "m1" );
  353. unsigned preGrpSymId = cmDspSysPresetRegisterGroup(h,"tl");
  354. unsigned cmpPreGrpSymId = cmDspSysPresetRegisterGroup(h,"tl_cmp");
  355. cmDspTlXform_t c0,c1,c2,c3;
  356. cmDspSysNewPage(h,"Controls-0");
  357. _cmDspSys_TlXformChain(h, &c0, preGrpSymId, cmpPreGrpSymId, modp, 0, 0 );
  358. cmDspSysNewPage(h,"Controls-1");
  359. _cmDspSys_TlXformChain(h, &c1, preGrpSymId, cmpPreGrpSymId, modp, 1, 1 );
  360. cmDspInst_t* mix0 = NULL;
  361. cmDspInst_t* mix1 = NULL;
  362. if( fragFl )
  363. {
  364. cmDspSysNewPage(h,"Ctl-R/P-0");
  365. _cmDspSys_TlXformChain(h, &c2, preGrpSymId, cmpPreGrpSymId, modr, 2, 0 );
  366. cmDspSysNewPage(h,"Ctl-R/P-1");
  367. _cmDspSys_TlXformChain(h, &c3, preGrpSymId, cmpPreGrpSymId, modr, 3, 1 );
  368. mix0 = cmDspSysAllocInst(h,"AMix", NULL, 3, 2, 1.0, 1.0 );
  369. mix1 = cmDspSysAllocInst(h,"AMix", NULL, 3, 2, 1.0, 1.0 );
  370. }
  371. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut", NULL, 1, 0 );
  372. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut", NULL, 1, 1 );
  373. cmDspInst_t* ao2p = cmDspSysAllocInst(h,"AudioOut", NULL, 1, 2 );
  374. cmDspInst_t* ao3p = cmDspSysAllocInst(h,"AudioOut", NULL, 1, 3 );
  375. cmDspSysNewPage(h,"Main");
  376. cmDspInst_t* liveb= cmDspSysAllocInst(h,"Button", "live", 2, kCheckDuiId, 0.0 );
  377. cmDspInst_t* simb = cmDspSysAllocInst(h,"Button", "simulate",2, kCheckDuiId, 0.0 );
  378. cmDspInst_t* ainb = cmDspSysAllocInst(h,"Button", "audio in",2, kCheckDuiId, 0.0 );
  379. cmDspInst_t* measb= cmDspSysAllocInst(h,"Button", "meas", 2, kCheckDuiId, 0.0 );
  380. cmDspInst_t* onb = cmDspSysAllocInst(h,"Button", "start", 2, kButtonDuiId, 1.0 );
  381. cmDspInst_t* offb = cmDspSysAllocInst(h,"Button", "stop", 2, kButtonDuiId, 1.0 );
  382. cmDspInst_t* prtb = cmDspSysAllocInst(h,"Button", "print", 2, kButtonDuiId, 1.0 );
  383. cmDspInst_t* qtb = cmDspSysAllocInst(h,"Button", "quiet", 2, kButtonDuiId, 1.0 );
  384. cmDspInst_t* mutm = cmDspSysAllocInst(h,"Checkbox","main", 1, "main","on","off",1.0,0.0,1.0 );
  385. cmDspInst_t* mutr = cmDspSysAllocInst(h,"Checkbox","frag", 1, "frag","on","off",1.0,0.0,1.0 );
  386. cmDspInst_t* prp = cmDspSysAllocInst(h,"Printer", NULL, 1, ">" );
  387. cmDspInst_t* prd = cmDspSysAllocInst(h,"Printer", NULL, 1, "DYN:" );
  388. cmDspInst_t* pre = cmDspSysAllocInst(h,"Printer", NULL, 1, "EVEN:" );
  389. cmDspInst_t* prt = cmDspSysAllocInst(h,"Printer", NULL, 1, "TEMPO:");
  390. cmDspInst_t* prc = cmDspSysAllocInst(h,"Printer", NULL, 1, "COST:");
  391. //cmDspInst_t* prv = cmDspSysAllocInst(h,"Printer", NULL, 1, "Value:");
  392. // Record <-> Live switches
  393. cmDspInst_t* tlRt = cmDspSysAllocInst(h,"Router", NULL, 2, 2, 0); // time line swich
  394. cmDspInst_t* wtRt = cmDspSysAllocInst(h,"Router", NULL, 2, 2, 0);
  395. cmDspInst_t* mfpRt = cmDspSysAllocInst(h,"Router", NULL, 2, 2, 0);
  396. cmDspInst_t* amRt = cmDspSysAllocInst(h,"Router", NULL, 2, 2, 0);
  397. cmDspInst_t* au0Sw = cmDspSysAllocInst(h,"1ofN", NULL, 2, 2, 0);
  398. cmDspInst_t* au1Sw = cmDspSysAllocInst(h,"1ofN", NULL, 2, 2, 0);
  399. cmDspInst_t* siRt = cmDspSysAllocInst(h,"Router", NULL, 2, 2, 0);
  400. cmDspInst_t* d0Rt = cmDspSysAllocInst(h,"Router", NULL, 2, 2, 0);
  401. cmDspInst_t* d1Rt = cmDspSysAllocInst(h,"Router", NULL, 2, 2, 0);
  402. cmDspInst_t* stRt = cmDspSysAllocInst(h,"Router", NULL, 2, 2, 0);
  403. cmDspSysNewColumn(h,0);
  404. cmDspInst_t* igain0 = cmDspSysAllocInst(h,"Scalar", "In Gain-0", 5, kNumberDuiId, 0.0, 10.0,0.01, 1.0 );
  405. cmDspInst_t* igain1 = cmDspSysAllocInst(h,"Scalar", "In Gain-1", 5, kNumberDuiId, 0.0, 10.0,0.01, 1.0 );
  406. cmDspInst_t* lasecs = cmDspSysAllocInst(h,"Scalar", "LA Secs", 5, kNumberDuiId, 0.0, recdPlayMaxLaSecs,0.01, recdPlayCurLaSecs );
  407. cmDspInst_t* dbpsec = cmDspSysAllocInst(h,"Scalar", "Fade dBpSec", 5, kNumberDuiId, 0.0, 24.0, 0.01, recdPlayFadeRateDbPerSec);
  408. cmDspInst_t* ogain0 = cmDspSysAllocInst(h,"Scalar", "Out Gain-0", 5, kNumberDuiId, 0.0, 10.0,0.01, 3.0 );
  409. cmDspInst_t* ogain1 = cmDspSysAllocInst(h,"Scalar", "Out Gain-1", 5, kNumberDuiId, 0.0, 10.0,0.01, 3.0 );
  410. cmDspInst_t* ogain2 = cmDspSysAllocInst(h,"Scalar", "Out Gain-2", 5, kNumberDuiId, 0.0, 10.0,0.01, 3.0 );
  411. cmDspInst_t* ogain3 = cmDspSysAllocInst(h,"Scalar", "Out Gain-3", 5, kNumberDuiId, 0.0, 10.0,0.01, 3.0 );
  412. cmDspInst_t* scLoc = cmDspSysAllocInst(h,"Scalar", "Sc Loc", 5, kNumberDuiId, 0.0, 3000.0, 1.0, 0.0 );
  413. // Audio file recording
  414. cmDspInst_t* recdGain= cmDspSysAllocInst(h,"Scalar", "Recd Gain", 5, kNumberDuiId, 0.0, 100.0,0.01, 1.5 );
  415. cmDspInst_t* recdChk = cmDspSysAllocInst(h,"Button", "Record", 2, kCheckDuiId, 0.0 );
  416. cmDspInst_t* recdPtS = cmDspSysAllocInst(h,"GateToSym", NULL, 2, cmSymTblRegisterStaticSymbol(cmDspSysSymbolTable(h),"open"),cmSymTblRegisterStaticSymbol(cmDspSysSymbolTable(h),"close"));
  417. cmDspInst_t* afop = cmDspSysAllocInst(h,"AudioFileOut",NULL, 2, r.recordDir,2);
  418. cmDspInst_t* mi0p = cmDspSysAllocInst(h,"AMeter","In 0", 0);
  419. cmDspInst_t* mi1p = cmDspSysAllocInst(h,"AMeter","In 1", 0);
  420. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  421. return rc;
  422. // Output Audio file recording.
  423. cmDspSysInstallCb(h, recdGain,"val", afop, "gain0", NULL );
  424. cmDspSysInstallCb(h, recdGain,"val", afop, "gain1", NULL );
  425. cmDspSysInstallCb(h, recdChk, "out", recdPtS, "on", NULL );
  426. cmDspSysInstallCb(h, recdChk, "out", recdPtS, "off", NULL );
  427. cmDspSysInstallCb(h, recdPtS, "out", afop, "sel", NULL );
  428. // Audio connections
  429. cmDspSysConnectAudio(h, php, "out", wtp, "phs" ); // phs -> wt
  430. if( useWtFl )
  431. {
  432. cmDspSysConnectAudio(h, wtp, "out", au0Sw, "a-in-0" ); // wt -> sw
  433. cmDspSysConnectAudio(h, ai0p, "out", au0Sw, "a-in-1" ); // ain -> sw
  434. cmDspSysConnectAudio(h, ai0p, "out", mi0p, "in" );
  435. cmDspSysConnectAudio(h, au0Sw, "a-out", rpp, "in-0"); // sw -> rcdply
  436. cmDspSysConnectAudio(h, au0Sw, "a-out", c0.kr0,"in" ); // sw -> kr
  437. cmDspSysConnectAudio(h, au0Sw, "a-out", c0.kr1,"in" ); // sw -> kr
  438. }
  439. else
  440. {
  441. cmDspSysConnectAudio(h, ai0p, "out", rpp, "in-0"); // sw -> rcdply
  442. cmDspSysConnectAudio(h, ai0p, "out", c0.kr0, "in" ); // ain -> sw
  443. cmDspSysConnectAudio(h, ai0p, "out", c0.kr1, "in" ); // ain -> sw
  444. cmDspSysConnectAudio(h, ai0p, "out", mi0p, "in" );
  445. }
  446. if( fragFl )
  447. {
  448. cmDspSysConnectAudio(h, c0.cmp, "out", mix0, "in-0" ); // cmp -> mix 0
  449. cmDspSysConnectAudio(h, rpp, "out-0", c2.kr0,"in" );
  450. cmDspSysConnectAudio(h, rpp, "out-0", c2.kr1,"in" );
  451. cmDspSysConnectAudio(h, c2.cmp, "out", mix0, "in-1"); // rpp -> mix 1
  452. cmDspSysConnectAudio(h, mix0, "out", ao0p, "in" ); // mix -> aout
  453. }
  454. else
  455. {
  456. cmDspSysConnectAudio(h, c0.cmp, "out", ao0p, "in" );
  457. //cmDspSysConnectAudio(h, wtp, "out", ao0p, "in" );
  458. }
  459. if( useWtFl )
  460. {
  461. cmDspSysConnectAudio(h, wtp, "out", au1Sw, "a-in-0" ); // wt -> sw
  462. cmDspSysConnectAudio(h, ai1p, "out", au1Sw, "a-in-1" ); // ain -> sw
  463. cmDspSysConnectAudio(h, ai1p, "out", mi1p, "in" );
  464. cmDspSysConnectAudio(h, au1Sw, "a-out", rpp, "in-1"); // sw -> rcdply
  465. cmDspSysConnectAudio(h, au1Sw, "a-out", c1.kr0,"in" ); // sw -> kr
  466. cmDspSysConnectAudio(h, au1Sw, "a-out", c1.kr1,"in" ); // sw -> kr
  467. }
  468. else
  469. {
  470. cmDspSysConnectAudio(h, ai1p, "out", rpp, "in-1"); // sw -> rcdply
  471. cmDspSysConnectAudio(h, ai1p, "out", c1.kr0, "in" ); // ain -> sw
  472. cmDspSysConnectAudio(h, ai1p, "out", c1.kr1, "in" ); // ain -> sw
  473. cmDspSysConnectAudio(h, ai1p, "out", mi1p, "in" );
  474. }
  475. if( fragFl )
  476. {
  477. cmDspSysConnectAudio(h, c1.cmp, "out", mix1, "in-0" ); // cmp -> mix 0
  478. cmDspSysConnectAudio(h, rpp, "out-1", c3.kr0, "in" );
  479. cmDspSysConnectAudio(h, rpp, "out-1", c3.kr1, "in" );
  480. cmDspSysConnectAudio(h, c3.cmp, "out", mix1, "in-1"); // rpp -> mix 1
  481. cmDspSysConnectAudio(h, mix1, "out", ao1p, "in" ); // mix -> aout
  482. }
  483. else
  484. {
  485. cmDspSysConnectAudio(h, c1.cmp, "out", ao1p, "in" ); // cmp -> mix 0
  486. //cmDspSysConnectAudio(h, wtp, "out", ao1p, "in" );
  487. }
  488. cmDspSysConnectAudio(h, c0.cmp, "out", afop, "in0" ); // comp -> audio_file_out
  489. cmDspSysConnectAudio(h, c1.cmp, "out", afop, "in1" );
  490. cmDspSysConnectAudio(h, ai0p, "out", ao2p, "in" );
  491. cmDspSysConnectAudio(h, ai1p, "out", ao3p, "in" );
  492. //--------------- Preset controls
  493. cmDspSysNewColumn(h,0);
  494. cmDspInst_t* preset = cmDspSysAllocInst( h, "Preset", NULL, 1, preGrpSymId );
  495. cmDspInst_t* presetLbl = cmDspSysAllocInst( h, "Text", "Preset", 1, "" );
  496. cmDspInst_t* storeBtn = cmDspSysAllocButton( h, "store", 0);
  497. cmDspInst_t* recallBtn = cmDspSysAllocButton( h, "recall", 0);
  498. cmDspSysInstallCb( h, presetLbl, "val", preset, "label",NULL);
  499. cmDspSysInstallCb( h, storeBtn, "sym", preset, "cmd", NULL );
  500. cmDspSysInstallCb( h, recallBtn, "sym", preset, "cmd", NULL );
  501. cmDspInst_t* prePath = cmDspSysAllocInst( h, "Fname", "prePath", 3, true,NULL,r.tlPrefixPath);
  502. cmDspSysNewColumn(h,0);
  503. //--------------- Recorded performance evaluation and Active Measurement related controls
  504. cmDspInst_t* clrBtn = cmDspSysAllocButton( h, "clear", 0);
  505. cmDspInst_t* prtBtn = cmDspSysAllocButton( h, "dump", 0);
  506. cmDspInst_t* mlst = cmDspSysAllocInst( h, "MsgList", NULL, 3, "meas", r.measFn, 2);
  507. cmDspInst_t* amCmd = cmDspSysAllocInst( h, "PortToSym", NULL, 2, "add", "rewind" );
  508. cmDspSysInstallCb( h, clrBtn, "sym", amp, "cmd", NULL ); // clear active meas.
  509. cmDspSysInstallCb( h, prtBtn, "sym", amp, "cmd", NULL ); // print active meas
  510. cmDspSysInstallCb( h, prtBtn, "sym", scp, "cmd", NULL );
  511. cmDspSysInstallCb( h, amCmd, "add", amp, "cmd", NULL ); // add active meas
  512. cmDspSysInstallCb( h, amCmd, "rewind", amp, "cmd", NULL ); // rewind active meas
  513. cmDspSysInstallCb( h, mlst, "loc", amp, "loc", NULL ); // recorded meas's list to active meas unit
  514. cmDspSysInstallCb( h, mlst, "typeId", amp, "type", NULL ); //
  515. cmDspSysInstallCb( h, mlst, "val", amp, "val", NULL ); //
  516. cmDspSysInstallCb( h, mlst, "cost", amp, "cst", NULL ); //
  517. cmDspSysInstallCb( h, mlst, "typeId", amCmd, "add", NULL ); //
  518. cmDspSysInstallCb( h, sfp, "out", amRt, "f-in", NULL ); // sfp-active meas router (rtr is switched by live btn)
  519. cmDspSysInstallCb( h, amRt, "f-out-0",amp, "sfloc", NULL );
  520. cmDspSysInstallCb( h, sfp, "vloc", amp, "loc", NULL ); // live meas's to active meas unit
  521. cmDspSysInstallCb( h, sfp, "vval", amp, "val", NULL ); //
  522. cmDspSysInstallCb( h, sfp, "vcost",amp, "cst", NULL ); //
  523. cmDspSysInstallCb( h, sfp, "vtyp", amp, "type", NULL ); //
  524. cmDspSysInstallCb( h, sfp, "vtyp", amCmd, "add", NULL); //
  525. // ***** delete this to prevent the score follower from driving the active-measure unit in 'live' mode
  526. cmDspSysInstallCb( h, amRt, "f-out-1",amp, "sfloc", NULL );
  527. // *****
  528. // active measure loc to xfad channel trigger
  529. cmDspSysInstallCb( h, amp, "scloc", c0.achan, "trig", NULL ); // See Also: modp.sw ->achan.trig
  530. cmDspSysInstallCb( h, amp, "scloc", c1.achan, "trig", NULL );
  531. if( fragFl )
  532. {
  533. cmDspSysInstallCb( h, amp, "scloc", c2.achan, "trig", NULL );
  534. cmDspSysInstallCb( h, amp, "scloc", c3.achan, "trig", NULL );
  535. }
  536. cmDspSysInstallCb( h, amp, "even", pre, "in", NULL ); // active meas output to printers
  537. cmDspSysInstallCb( h, amp, "dyn", prd, "in", NULL );
  538. cmDspSysInstallCb( h, amp, "tempo", prt, "in", NULL );
  539. cmDspSysInstallCb( h, amp, "cost", prc, "in", NULL );
  540. // wave-table to time-line cursor
  541. cmDspSysInstallCb( h, wtp, "fidx",tlp, "curs", NULL);
  542. cmDspSysInstallCb(h, prePath, "out", tlp, "path", NULL );
  543. // 'live' button -> live router selector switch
  544. cmDspSysInstallCb(h, liveb, "out", wtRt, "sel", NULL );
  545. cmDspSysInstallCb(h, liveb, "out", tlRt, "sel", NULL );
  546. cmDspSysInstallCb(h, liveb, "out", mfpRt,"sel", NULL );
  547. cmDspSysInstallCb(h, liveb, "out", amRt, "sel", NULL );
  548. cmDspSysInstallCb(h, liveb, "out", au0Sw, "chidx", NULL );
  549. cmDspSysInstallCb(h, liveb, "out", au1Sw, "chidx", NULL );
  550. cmDspSysInstallCb(h, liveb, "out", measb, "in", NULL );
  551. cmDspSysInstallCb(h, measb, "out", sfp, "measfl", NULL );
  552. // 'simulate' button -> simulate router selector switch
  553. cmDspSysInstallCb(h, simb, "out", ainb, "in", NULL );
  554. cmDspSysInstallCb(h, ainb, "out", au0Sw, "chidx", NULL );
  555. cmDspSysInstallCb(h, ainb, "out", au1Sw, "chidx", NULL );
  556. cmDspSysInstallCb(h, simb, "out", siRt, "sel", NULL );
  557. cmDspSysInstallCb(h, simb, "out", d1Rt, "sel", NULL );
  558. cmDspSysInstallCb(h, simb, "out", d0Rt, "sel", NULL );
  559. cmDspSysInstallCb(h, simb, "out", stRt, "sel", NULL );
  560. // start connections
  561. cmDspSysInstallCb(h, onb, "sym", tlRt, "s-in", NULL );
  562. cmDspSysInstallCb(h, tlRt, "s-out-0",tlp, "reset", NULL );
  563. cmDspSysInstallCb(h, onb, "sym", scp, "send", NULL );
  564. cmDspSysInstallCb(h, onb, "sym", mfpRt,"s-in", NULL );
  565. cmDspSysInstallCb(h, mfpRt,"s-out-0",mfp, "sel", NULL );
  566. cmDspSysInstallCb(h, onb, "sym", pts, "on", NULL );
  567. cmDspSysInstallCb(h, pts, "on", wtRt, "s-in", NULL );
  568. cmDspSysInstallCb(h, wtRt,"s-out-0", wtp, "cmd", NULL );
  569. cmDspSysInstallCb(h, pts, "on", modp, "cmd", NULL );
  570. cmDspSysInstallCb(h, pts, "on", modr, "cmd", NULL );
  571. cmDspSysInstallCb(h, pts, "on", rpp, "cmd", NULL );
  572. cmDspSysInstallCb(h, onb, "sym", amCmd, "rewind",NULL );
  573. cmDspSysInstallCb(h, onb, "out", c0.achan,"reset", NULL );
  574. cmDspSysInstallCb(h, onb, "out", c1.achan,"reset", NULL );
  575. // stop connections
  576. cmDspSysInstallCb(h, wtp, "done",offb,"in", NULL ); // 'done' from WT simulates pressing Stop btn.
  577. cmDspSysInstallCb(h, tlp, "mfn", pts, "off", NULL ); // Prevents WT start on new audio file from TL.
  578. cmDspSysInstallCb(h, offb, "sym", mfp, "sel", NULL );
  579. cmDspSysInstallCb(h, offb, "sym", pts, "off", NULL );
  580. cmDspSysInstallCb(h, pts, "off", wtp, "cmd", NULL );
  581. cmDspSysInstallCb(h, pts, "off", modp,"cmd", NULL );
  582. cmDspSysInstallCb(h, pts, "off", modr,"cmd", NULL );
  583. cmDspSysInstallCb(h, offb, "sym", mop, "reset", NULL );
  584. // time-line to wave-table selection
  585. cmDspSysInstallCb(h, tlp, "absi", wtp, "beg", NULL );
  586. cmDspSysInstallCb(h, tlp, "aesi", wtp, "end", NULL );
  587. cmDspSysInstallCb(h, tlp, "afn", wtp, "fn", NULL );
  588. // time-line to MIDI file player selection
  589. cmDspSysInstallCb(h, tlp, "mbsi", mfp, "bsi", NULL );
  590. cmDspSysInstallCb(h, tlp, "mesi", mfp, "esi", NULL );
  591. cmDspSysInstallCb(h, tlp, "mfn", mfp, "fn", NULL );
  592. // score to score follower - to set initial search location
  593. cmDspSysInstallCb(h, scp, "sel", sfp, "index", NULL );
  594. cmDspSysInstallCb(h, scp, "sel", modp,"reset", NULL );
  595. cmDspSysInstallCb(h, scp, "sel", modr,"reset", NULL );
  596. cmDspSysInstallCb(h, scp, "sel", rpp, "initIdx", NULL );
  597. cmDspSysInstallCb(h, scp, "sel", prp, "in", NULL );
  598. // NOTE: THIS IS A DUPLICATE OF THE scp.sel CONNECTIONS
  599. cmDspSysInstallCb(h, scLoc, "val", sfp, "index", NULL );
  600. cmDspSysInstallCb(h, scLoc, "val", modp,"reset", NULL );
  601. cmDspSysInstallCb(h, scLoc, "val", modr,"reset", NULL );
  602. cmDspSysInstallCb(h, scLoc, "val", rpp, "initIdx", NULL );
  603. cmDspSysInstallCb(h, scLoc, "val", prp, "in", NULL );
  604. //cmDspSysInstallCb(h, reload,"out", modp, "reload", NULL );
  605. // MIDI file player to score follower
  606. cmDspSysInstallCb(h, mfp, "smpidx", siRt, "f-in",NULL );
  607. cmDspSysInstallCb(h, siRt, "f-out-0", sfp, "smpidx",NULL );
  608. // leave siRt.f-out-1 unconnected because it should be ignored in 'simulate mode'
  609. cmDspSysInstallCb(h, mfp, "d1", d1Rt, "f-in", NULL );
  610. cmDspSysInstallCb(h, d1Rt, "f-out-0", sfp, "d1", NULL );
  611. cmDspSysInstallCb(h, d1Rt, "f-out-1", nmp, "d1", NULL );
  612. cmDspSysInstallCb(h, nmp, "d1", mop, "d1", NULL );
  613. cmDspSysInstallCb(h, mfp, "d0", d0Rt, "f-in", NULL );
  614. cmDspSysInstallCb(h, d0Rt, "f-out-0", sfp, "d0", NULL );
  615. cmDspSysInstallCb(h, d0Rt, "f-out-1", nmp, "d0", NULL );
  616. cmDspSysInstallCb(h, nmp, "d0", mop, "d0", NULL );
  617. cmDspSysInstallCb(h, mfp, "status", stRt, "f-in", NULL );
  618. cmDspSysInstallCb(h, stRt, "f-out-0", sfp, "status",NULL );
  619. cmDspSysInstallCb(h, stRt, "f-out-1", nmp, "status",NULL );
  620. cmDspSysInstallCb(h, nmp, "status", mop, "status",NULL );
  621. // MIDI input port
  622. cmDspSysInstallCb(h, mip, "smpidx", sfp, "smpidx", NULL );
  623. cmDspSysInstallCb(h, mip, "d1", sfp, "d1", NULL );
  624. cmDspSysInstallCb(h, mip, "d0", sfp, "d0", NULL );
  625. cmDspSysInstallCb(h, mip, "status", sfp, "status", NULL );
  626. // score follower to recd_play,modulator and printers
  627. cmDspSysInstallCb(h, sfp, "out", rpp, "index", NULL );
  628. cmDspSysInstallCb(h, sfp, "out", modp, "index", NULL );
  629. cmDspSysInstallCb(h, sfp, "out", modr, "index", NULL );
  630. cmDspSysInstallCb(h, sfp, "recent", prp, "in", NULL ); // report 'recent' but only act on 'max' loc index
  631. cmDspSysInstallCb(h, prtb, "sym", sfp, "cmd", NULL );
  632. cmDspSysInstallCb(h, qtb, "sym", sfp, "cmd", NULL );
  633. cmDspSysInstallCb( h, lasecs, "val", rpp, "curla", NULL ); // recd/play control
  634. cmDspSysInstallCb( h, dbpsec, "val", rpp, "frate", NULL );
  635. cmDspSysInstallCb(h, igain0, "val", ai0p, "gain", NULL ); // input gain control
  636. cmDspSysInstallCb(h, igain1, "val", ai1p, "gain", NULL );
  637. if( fragFl )
  638. {
  639. cmDspSysInstallCb(h, mutm, "out", mix0, "gain-0", NULL );
  640. cmDspSysInstallCb(h, mutm, "out", mix1, "gain-0", NULL );
  641. cmDspSysInstallCb(h, mutr, "out", mix0, "gain-1", NULL );
  642. cmDspSysInstallCb(h, mutr, "out", mix1, "gain-1", NULL );
  643. }
  644. cmDspSysInstallCb(h, ogain0, "val", ao0p, "gain", NULL ); // output gain control
  645. cmDspSysInstallCb(h, ogain1, "val", ao1p, "gain", NULL );
  646. cmDspSysInstallCb(h, ogain2, "val", ao2p, "gain", NULL );
  647. cmDspSysInstallCb(h, ogain3, "val", ao3p, "gain", NULL );
  648. return rc;
  649. }
  650. cmDspRC_t _cmDspSysPgm_KrLive(cmDspSysH_t h, void** userPtrPtr )
  651. {
  652. cmDspRC_t rc = kOkDspRC;
  653. return rc;
  654. }