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.

cmDspPgmKr.c 43KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816
  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 "cmAudioSys.h"
  21. #include "cmProcObj.h"
  22. #include "cmDspCtx.h"
  23. #include "cmDspClass.h"
  24. #include "cmDspSys.h"
  25. #include "cmDspPgm.h"
  26. #include "cmAudioFile.h"
  27. #include "cmProcObj.h"
  28. #include "cmProc.h"
  29. #include "cmProc3.h"
  30. #include "cmVectOpsTemplateMain.h"
  31. #include "cmVectOps.h"
  32. typedef struct
  33. {
  34. const cmChar_t* tlFn;
  35. const cmChar_t* tlPrefixPath;
  36. const cmChar_t* scFn;
  37. const cmChar_t* modFn;
  38. const cmChar_t* measFn;
  39. const cmChar_t* recordDir;
  40. const cmChar_t* midiDevice;
  41. const cmChar_t* midiInPort;
  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->midiInPort, "midiOutPort", NULL);
  57. cmDspRsrcString(h,&r->midiOutPort, "midiInPort", NULL);
  58. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  59. cmErrMsg(err,rc,"A KR DSP resource load failed.");
  60. return rc;
  61. }
  62. cmDspRC_t _cmDspSysPgm_TimeLine(cmDspSysH_t h, void** userPtrPtr )
  63. {
  64. cmDspRC_t rc = kOkDspRC;
  65. cmCtx_t* cmCtx = cmDspSysPgmCtx(h);
  66. cmErr_t err;
  67. krRsrc_t r;
  68. unsigned wtLoopCnt = 1; // 1=play once (-1=loop forever)
  69. unsigned wtInitMode = 0; // initial wt mode is 'silence'
  70. unsigned wtSmpCnt = floor(cmDspSysSampleRate(h)); // wt length == srate
  71. int krWndSmpCnt = 2048;
  72. int krHopFact = 4;
  73. unsigned xfadeChCnt = 2;
  74. double xfadeMs = 50;
  75. bool xfadeInitFl = true;
  76. double mixGain = 1.0;
  77. unsigned measRtChCnt = 4; // note: router channel 4 is not connected
  78. bool cmpBypassFl = false;
  79. double cmpInGain = 3.0;
  80. double cmpThreshDb = -40.0;
  81. double cmpRatio_num = 5.0;
  82. double cmpAtkMs = 20.0;
  83. double cmpRlsMs = 100.0;
  84. double cmpMakeup = 1.0;
  85. double cmpWndMaxMs = 1000.0;
  86. double cmpWndMs = 200.0;
  87. memset(&r,0,sizeof(r));
  88. cmErrSetup(&err,&cmCtx->rpt,"Kr Timeline");
  89. if( krLoadRsrc(h,&err,&r) != kOkDspRC )
  90. return rc;
  91. unsigned preGrpSymId = cmDspSysPresetRegisterGroup(h,"tl");
  92. unsigned compPreGrpSymId = cmDspSysPresetRegisterGroup(h,"tl_cmp");
  93. cmDspInst_t* tlp = cmDspSysAllocInst(h,"TimeLine", "tl", 2, r.tlFn, r.tlPrefixPath );
  94. cmDspInst_t* scp = cmDspSysAllocInst(h,"Score", "sc", 1, r.scFn );
  95. cmDspInst_t* php = cmDspSysAllocInst(h,"Phasor", NULL, 1, cmDspSysSampleRate(h) );
  96. cmDspInst_t* wtp = cmDspSysAllocInst(h,"WaveTable", NULL, 4, wtSmpCnt, wtInitMode, NULL, wtLoopCnt );
  97. cmDspInst_t* pts = cmDspSysAllocInst(h,"PortToSym", NULL, 2, "on", "off" );
  98. cmDspInst_t* mfp = cmDspSysAllocInst(h,"MidiFilePlay",NULL, 0 );
  99. cmDspInst_t* sfp = cmDspSysAllocInst(h,"ScFol", NULL, 1, r.scFn );
  100. cmDspInst_t* amp = cmDspSysAllocInst(h,"ActiveMeas", NULL, 1, 100 );
  101. cmDspInst_t* modp = cmDspSysAllocInst(h,"ScMod", NULL, 2, r.modFn, "m1" );
  102. cmDspInst_t* asp = cmDspSysAllocInst(h,"AmSync", NULL, 0 );
  103. cmDspInst_t* mop = NULL;
  104. if( cmTextIsNotEmpty(r.midiDevice) && cmTextIsNotEmpty(r.midiOutPort) )
  105. {
  106. /*
  107. #ifdef OS_OSX
  108. deviceName = "RME - Fireface UFX (23148636)";
  109. portName = "Port 2";
  110. #endif
  111. */
  112. mop = cmDspSysAllocInst( h,"MidiOut", NULL, 2, r.midiDevice, r.midiOutPort);
  113. }
  114. cmDspInst_t* achan0 = cmDspSysAllocInst(h, "AvailCh", NULL, 1, xfadeChCnt );
  115. cmDspInst_t* achan1 = cmDspSysAllocInst(h, "AvailCh", NULL, 1, xfadeChCnt );
  116. cmDspInst_t* even_sr_00 = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.8, 1.1, 0.0, 1.0 );
  117. cmDspInst_t* even_rt_00 = cmDspSysAllocInst(h, "Router", NULL, 2, measRtChCnt, measRtChCnt-1 );
  118. cmDspInst_t* dyn_sr_00 = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 4.0, 0.01, 1.0 );
  119. cmDspInst_t* dyn_rt_00 = cmDspSysAllocInst(h, "Router", NULL, 2, measRtChCnt, measRtChCnt-1 );
  120. cmDspInst_t* tempo_sr_00 = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 80.0, 120.0, 0.01, 1.0 );
  121. cmDspInst_t* tempo_rt_00 = cmDspSysAllocInst(h, "Router", NULL, 2, measRtChCnt, measRtChCnt-1 );
  122. cmDspInst_t* cost_sr_00 = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, 0.001, 1.0 );
  123. cmDspInst_t* cost_rt_00 = cmDspSysAllocInst(h, "Router", NULL, 2, measRtChCnt, measRtChCnt-1 );
  124. cmDspInst_t* thrh_sr_00 = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, 0.01, 100.0 );
  125. cmDspInst_t* upr_sr_00 = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, -1.0, 5.0 );
  126. cmDspInst_t* lwr_sr_00 = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, -5.0, 5.0 );
  127. cmDspInst_t* even_sr_10 = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.8, 1.1, 0.0, 1.0 );
  128. cmDspInst_t* even_rt_10 = cmDspSysAllocInst(h, "Router", NULL, 2, measRtChCnt, measRtChCnt-1 );
  129. cmDspInst_t* dyn_sr_10 = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 4.0, 0.01, 1.0 );
  130. cmDspInst_t* dyn_rt_10 = cmDspSysAllocInst(h, "Router", NULL, 2, measRtChCnt, measRtChCnt-1 );
  131. cmDspInst_t* tempo_sr_10 = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 80.0, 120.0, 0.01, 1.0 );
  132. cmDspInst_t* tempo_rt_10 = cmDspSysAllocInst(h, "Router", NULL, 2, measRtChCnt, measRtChCnt-1 );
  133. cmDspInst_t* cost_sr_10 = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, 0.001, 1.0 );
  134. cmDspInst_t* cost_rt_10 = cmDspSysAllocInst(h, "Router", NULL, 2, measRtChCnt, measRtChCnt-1 );
  135. cmDspInst_t* thrh_sr_10 = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, 0.01, 100.0 );
  136. cmDspInst_t* upr_sr_10 = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, -1.0, 5.0 );
  137. cmDspInst_t* lwr_sr_10 = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, -5.0, 5.0 );
  138. unsigned paramRtChCnt = 2;
  139. cmDspInst_t* mod_rt_00 = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  140. cmDspInst_t* thr_rt_00 = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  141. cmDspInst_t* upr_rt_00 = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  142. cmDspInst_t* lwr_rt_00 = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  143. cmDspInst_t* mod_rt_10 = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  144. cmDspInst_t* thr_rt_10 = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  145. cmDspInst_t* upr_rt_10 = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  146. cmDspInst_t* lwr_rt_10 = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  147. cmDspInst_t* kr00 = cmDspSysAllocInst(h, "Kr", NULL, 2, krWndSmpCnt, krHopFact );
  148. cmDspInst_t* kr01 = cmDspSysAllocInst(h, "Kr", NULL, 2, krWndSmpCnt, krHopFact );
  149. cmDspInst_t* fad0 = cmDspSysAllocInst(h, "Xfader", NULL, 3, xfadeChCnt, xfadeMs, xfadeInitFl );
  150. cmDspInst_t* mix0 = cmDspSysAllocInst(h, "AMix", NULL, 3, xfadeChCnt, mixGain, mixGain );
  151. cmDspInst_t* cmp0 = cmDspSysAllocInst(h,"Compressor", NULL, 8, cmpBypassFl, cmpThreshDb, cmpRatio_num, cmpAtkMs, cmpRlsMs, cmpMakeup, cmpWndMs, cmpWndMaxMs );
  152. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut", NULL, 1, 0 );
  153. cmDspInst_t* kr10 = cmDspSysAllocInst(h, "Kr", NULL, 2, krWndSmpCnt, krHopFact );
  154. cmDspInst_t* kr11 = cmDspSysAllocInst(h, "Kr", NULL, 2, krWndSmpCnt, krHopFact );
  155. cmDspInst_t* fad1 = cmDspSysAllocInst(h, "Xfader", NULL, 3, xfadeChCnt, xfadeMs, xfadeInitFl );
  156. cmDspInst_t* mix1 = cmDspSysAllocInst(h, "AMix", NULL, 3, xfadeChCnt, mixGain, mixGain );
  157. cmDspInst_t* cmp1 = cmDspSysAllocInst(h,"Compressor", NULL, 8, cmpBypassFl, cmpThreshDb, cmpRatio_num, cmpAtkMs, cmpRlsMs, cmpMakeup, cmpWndMs, cmpWndMaxMs );
  158. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut", NULL, 1, 1 );
  159. cmDspSysNewPage(h,"Controls");
  160. cmDspInst_t* onb = cmDspSysAllocInst(h,"Button", "start", 2, kButtonDuiId, 1.0 );
  161. cmDspInst_t* offb = cmDspSysAllocInst(h,"Button", "stop", 2, kButtonDuiId, 1.0 );
  162. cmDspInst_t* prtb = cmDspSysAllocInst(h,"Button", "print", 2, kButtonDuiId, 1.0 );
  163. cmDspInst_t* qtb = cmDspSysAllocInst(h,"Button", "quiet", 2, kButtonDuiId, 1.0 );
  164. cmDspInst_t* prp = cmDspSysAllocInst(h,"Printer", NULL, 1, ">" );
  165. cmDspInst_t* prd = cmDspSysAllocInst(h,"Printer", NULL, 1, "DYN:" );
  166. cmDspInst_t* pre = cmDspSysAllocInst(h,"Printer", NULL, 1, "EVEN:" );
  167. cmDspInst_t* prt = cmDspSysAllocInst(h,"Printer", NULL, 1, "TEMPO:");
  168. cmDspInst_t* prc = cmDspSysAllocInst(h,"Printer", NULL, 1, "COST:");
  169. //cmDspInst_t* prv = cmDspSysAllocInst(h,"Printer", NULL, 1, "Value:");
  170. //--------------- Preset controls
  171. cmDspInst_t* preset = cmDspSysAllocInst( h, "Preset", NULL, 1, preGrpSymId );
  172. cmDspInst_t* presetLbl = cmDspSysAllocInst( h, "Text", "Preset", 1, "" );
  173. cmDspInst_t* storeBtn = cmDspSysAllocButton( h, "store", 0);
  174. cmDspInst_t* recallBtn = cmDspSysAllocButton( h, "recall", 0);
  175. cmDspSysInstallCb( h, presetLbl, "val", preset, "label",NULL);
  176. cmDspSysInstallCb( h, storeBtn, "sym", preset, "cmd", NULL );
  177. cmDspSysInstallCb( h, recallBtn, "sym", preset, "cmd", NULL );
  178. cmDspInst_t* prePath = cmDspSysAllocInst( h, "Fname", "prePath", 3, true,NULL,r.tlPrefixPath);
  179. //--------------- Recorded performance evaluation and Active Measurement related controls
  180. cmDspInst_t* clrBtn = cmDspSysAllocButton( h, "clear", 0);
  181. cmDspInst_t* prtBtn = cmDspSysAllocButton( h, "dump", 0);
  182. cmDspInst_t* mlst = cmDspSysAllocInst( h, "MsgList", NULL, 3, "meas", r.measFn, 2);
  183. cmDspInst_t* amCmd = cmDspSysAllocInst( h, "PortToSym", NULL, 2, "add", "rewind" );
  184. cmDspSysInstallCb( h, clrBtn, "sym", amp, "cmd", NULL );
  185. cmDspSysInstallCb( h, prtBtn, "sym", amp, "cmd", NULL );
  186. cmDspSysInstallCb( h, amCmd, "add", amp, "cmd", NULL );
  187. cmDspSysInstallCb( h, amCmd, "rewind", amp, "cmd", NULL );
  188. cmDspSysInstallCb( h, mlst, "loc", amp, "loc", NULL );
  189. cmDspSysInstallCb( h, mlst, "typeId", amp, "type",NULL );
  190. cmDspSysInstallCb( h, mlst, "val", amp, "val", NULL );
  191. cmDspSysInstallCb( h, mlst, "cost", amp, "cst", NULL );
  192. cmDspSysInstallCb( h, mlst, "typeId", amCmd, "add", NULL );
  193. cmDspSysInstallCb( h, sfp, "out", amp, "sfloc", NULL );
  194. cmDspSysInstallCb( h, amp, "even", pre, "in", NULL );
  195. cmDspSysInstallCb( h, amp, "dyn", prd, "in", NULL );
  196. cmDspSysInstallCb( h, amp, "tempo", prt, "in", NULL );
  197. cmDspSysInstallCb( h, amp, "cost", prc, "in", NULL );
  198. cmDspSysNewColumn(h,0);
  199. double dfltOffset = 2.0; // 30.0;
  200. // ------ Spectral distortion controls 0
  201. cmDspInst_t* md00p = cmDspSysAllocScalarP( h,preGrpSymId,NULL, "Mode-00", 0.0, 4.0, 1.0, 1.0);
  202. cmDspInst_t* ws00p = cmDspSysAllocMsgListP(h,preGrpSymId,NULL, "wndSmpCnt-00", NULL, "wndSmpCnt", 2);
  203. cmDspInst_t* hf00p = cmDspSysAllocMsgListP(h,preGrpSymId,NULL, "hopFact-00", NULL, "hopFact", 2);
  204. cmDspInst_t* th00p = cmDspSysAllocScalarP( h,preGrpSymId,NULL, "threshold-00", 0.0, 100.0, 1.0, 60.0 );
  205. cmDspInst_t* us00p = cmDspSysAllocScalarP( h,preGrpSymId,NULL, "upr slope-00", 0.0, 10.0, 0.01, 0.0 );
  206. cmDspInst_t* ls00p = cmDspSysAllocScalarP( h,preGrpSymId,NULL, "lwr slope-00", 0.3, 10.0, 0.01, 2.0 );
  207. cmDspInst_t* of00p = cmDspSysAllocScalarP( h,preGrpSymId,NULL, "offset-00", 0.0, 100.0, 0.01, dfltOffset );
  208. cmDspInst_t* iv00p = cmDspSysAllocScalarP( h,preGrpSymId,NULL, "invert-00", 0.0, 1.0, 1.0, 0.0 );
  209. cmDspInst_t* wet00p = cmDspSysAllocScalarP(h,preGrpSymId,NULL, "wet-00", 0.0, 1.0,0.001, 1.0 );
  210. cmDspSysNewColumn(h,0);
  211. // ------ Spectral distortion controls 1
  212. cmDspInst_t* md10p = cmDspSysAllocScalarP( h,preGrpSymId,NULL, "Mode-10", 0.0, 4.0, 1.0, 1.0);
  213. cmDspInst_t* ws10p = cmDspSysAllocMsgListP(h,preGrpSymId,NULL, "wndSmpCnt-10", NULL, "wndSmpCnt", 2);
  214. cmDspInst_t* hf10p = cmDspSysAllocMsgListP(h,preGrpSymId,NULL, "hopFact-10", NULL, "hopFact", 2);
  215. cmDspInst_t* th10p = cmDspSysAllocScalarP( h,preGrpSymId,NULL, "threshold-10", 0.0, 100.0, 1.0, 60.0 );
  216. cmDspInst_t* us10p = cmDspSysAllocScalarP( h,preGrpSymId,NULL, "upr slope-10", 0.0, 10.0, 0.01, 0.0 );
  217. cmDspInst_t* ls10p = cmDspSysAllocScalarP( h,preGrpSymId,NULL, "lwr slope-10", 0.3, 10.0, 0.01, 2.0 );
  218. cmDspInst_t* of10p = cmDspSysAllocScalarP( h,preGrpSymId,NULL, "offset-10", 0.0, 100.0, 0.01, dfltOffset );
  219. cmDspInst_t* iv10p = cmDspSysAllocScalarP( h,preGrpSymId,NULL, "invert-10", 0.0, 1.0, 1.0, 0.0 );
  220. cmDspInst_t* wet10p = cmDspSysAllocScalarP( h,preGrpSymId,NULL, "wet-10", 0.0, 1.0,0.001, 1.0 );
  221. cmDspSysNewColumn(h,0);
  222. cmDspInst_t* ogain0 = cmDspSysAllocInst(h,"Scalar", "Out Gain-0", 5, kNumberDuiId, 0.0, 10.0,0.01, 3.0 );
  223. cmDspInst_t* ogain1 = cmDspSysAllocInst(h,"Scalar", "Out Gain-1", 5, kNumberDuiId, 0.0, 10.0,0.01, 3.0 );
  224. cmDspInst_t* xfadMs = cmDspSysAllocInst(h,"Scalar", "Xfade Ms", 5, kNumberDuiId, 0.0, 1000.0,0.01, 50.0 );
  225. // Audio file recording
  226. cmDspInst_t* recdGain= cmDspSysAllocInst(h,"Scalar", "Recd Gain", 5, kNumberDuiId, 0.0, 100.0,0.01, 1.5 );
  227. cmDspInst_t* recdChk = cmDspSysAllocInst(h,"Button", "Record", 2, kCheckDuiId, 0.0 );
  228. cmDspInst_t* recdPtS = cmDspSysAllocInst(h,"GateToSym", NULL, 2, cmSymTblRegisterStaticSymbol(cmDspSysSymbolTable(h),"open"),cmSymTblRegisterStaticSymbol(cmDspSysSymbolTable(h),"close"));
  229. cmDspInst_t* afop = cmDspSysAllocInst(h,"AudioFileOut",NULL, 2, r.recordDir,2);
  230. cmDspSysInstallCb(h, recdGain,"val", afop, "gain0", NULL );
  231. cmDspSysInstallCb(h, recdGain,"val", afop, "gain1", NULL );
  232. cmDspSysInstallCb(h, recdChk, "out", recdPtS, "on", NULL );
  233. cmDspSysInstallCb(h, recdChk, "out", recdPtS, "off", NULL );
  234. cmDspSysInstallCb(h, recdPtS, "out", afop, "sel", NULL );
  235. cmDspSysNewPage(h,"Sc/Rgn");
  236. // -------- Measurement Scale/Ranges controls 0
  237. cmDspInst_t* min_dyn_0 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Min In Dyn 0", 0.0, 10.0, 1.0, 0.0);
  238. cmDspInst_t* max_dyn_0 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Max In Dyn 0", 0.0, 10.0, 1.0, 4.0);
  239. cmDspInst_t* menu_dyn_0 = cmDspSysAllocMsgListP(h,preGrpSymId, NULL, "DynSel 0", NULL, "measMenu", measRtChCnt-1);
  240. cmDspInst_t* min_even_0 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Min In Even 0", 0.0, 1.0, 0.001, 0.75);
  241. cmDspInst_t* max_even_0 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Max In Even 0", 0.0, 3.0, 0.001, 1.0);
  242. cmDspInst_t* menu_even_0 = cmDspSysAllocMsgListP(h,preGrpSymId, NULL, "EvenSel 0", NULL, "measMenu", measRtChCnt-1);
  243. cmDspSysNewColumn(h,0);
  244. cmDspInst_t* min_tempo_0 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Min In Tempo 0", 0.0, 200.0, 1.0, 80.0);
  245. cmDspInst_t* max_tempo_0 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Max In Tempo 0", 0.0, 200.0, 1.0, 120.0);
  246. cmDspInst_t* menu_tempo_0 = cmDspSysAllocMsgListP(h,preGrpSymId, NULL, "TempoSel 0", NULL, "measMenu", measRtChCnt-1);
  247. cmDspInst_t* min_cost_0 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Min In Cost 0", 0.0, 1.0, 0.01, 0.0);
  248. cmDspInst_t* max_cost_0 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Max In Cost 0", 0.0, 1.0, 0.01, 1.0);
  249. cmDspInst_t* menu_cost_0 = cmDspSysAllocMsgListP(h,preGrpSymId, NULL, "CostSel 0", NULL, "measMenu", measRtChCnt-1);
  250. // -------- Parameter Scale/Ranges controls 0
  251. cmDspSysNewColumn(h,0);
  252. cmDspInst_t* min_thrh_0 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Min Thresh 0", 0.0, 100.0, 1.0, 30.0);
  253. cmDspInst_t* max_thrh_0 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Max Thresh 0", 0.0, 100.0, 1.0, 80.0);
  254. cmDspInst_t* min_upr_0 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Min Upr 0", -1.0, 1.0, 0.001, -0.5);
  255. cmDspInst_t* max_upr_0 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Max Upr 0", -1.0, 1.0, 0.001, 0.5);
  256. cmDspInst_t* min_lwr_0 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Min Lwr 0", 0.0, -1.0, 5.0, 1.0);
  257. cmDspInst_t* max_lwr_0 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Max Lwr 0", 0.0, -1.0, 5.0, 3.0);
  258. // -------- Measurement Scale/Ranges controls 0
  259. cmDspSysNewColumn(h,0);
  260. cmDspInst_t* min_dyn_1 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Min In Dyn 1", 0.0, 10.0, 1.0, 0.0);
  261. cmDspInst_t* max_dyn_1 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Max In Dyn 1", 0.0, 10.0, 1.0, 4.0);
  262. cmDspInst_t* menu_dyn_1 = cmDspSysAllocMsgListP(h,preGrpSymId, NULL, "DynSel 1", NULL, "measMenu", measRtChCnt-1);
  263. cmDspInst_t* min_even_1 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Min In Even 1", 0.0, 1.0, 0.001, 0.75);
  264. cmDspInst_t* max_even_1 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Max In Even 1", 0.0, 3.0, 0.001, 1.0);
  265. cmDspInst_t* menu_even_1 = cmDspSysAllocMsgListP(h,preGrpSymId, NULL, "EvenSel 1", NULL, "measMenu", measRtChCnt-1);
  266. cmDspSysNewColumn(h,0);
  267. cmDspInst_t* min_tempo_1 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Min In Tempo 1", 0.0, 200.0, 1.0, 80.0);
  268. cmDspInst_t* max_tempo_1 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Max In Tempo 1", 0.0, 200.0, 1.0, 120.0);
  269. cmDspInst_t* menu_tempo_1 = cmDspSysAllocMsgListP(h,preGrpSymId, NULL, "TempoSel 1", NULL, "measMenu", measRtChCnt-1);
  270. cmDspInst_t* min_cost_1 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Min In Cost 1", 0.0, 1.0, 0.01, 0.0);
  271. cmDspInst_t* max_cost_1 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Max In Cost 1", 0.0, 1.0, 0.01, 1.0);
  272. cmDspInst_t* menu_cost_1 = cmDspSysAllocMsgListP(h,preGrpSymId, NULL, "CostSel 1", NULL, "measMenu", measRtChCnt-1);
  273. // -------- Parameter Scale/Ranges controls 0
  274. cmDspSysNewColumn(h,0);
  275. cmDspInst_t* min_thrh_1 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Min Thresh 1", 0.0, 100.0, 1.0, 30.0);
  276. cmDspInst_t* max_thrh_1 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Max Thresh 1", 0.0, 100.0, 1.0, 80.0);
  277. cmDspInst_t* min_upr_1 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Min Upr 1", -1.0, 1.0, 0.001, -0.5);
  278. cmDspInst_t* max_upr_1 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Max Upr 1", -1.0, 1.0, 0.001, 0.5);
  279. cmDspInst_t* min_lwr_1 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Min Lwr 1", 0.0, -1.0, 5.0, 1.0);
  280. cmDspInst_t* max_lwr_1 = cmDspSysAllocScalarP( h,preGrpSymId, NULL, "Max Lwr 1", 0.0, -1.0, 5.0, 3.0);
  281. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  282. return rc;
  283. // phasor->wt->aout
  284. cmDspSysConnectAudio(h, php, "out", wtp, "phs" ); // phs -> wt
  285. cmDspSysConnectAudio(h, wtp, "out", kr00, "in" ); // wt -> kr
  286. cmDspSysConnectAudio(h, kr00, "out", fad0, "in-0");
  287. cmDspSysConnectAudio(h, fad0, "out-0", mix0, "in-0");
  288. cmDspSysConnectAudio(h, wtp, "out", kr01, "in" ); // wt -> kr
  289. cmDspSysConnectAudio(h, kr01, "out", fad0, "in-1");
  290. cmDspSysConnectAudio(h, fad0, "out-1", mix0, "in-1");
  291. cmDspSysConnectAudio(h, mix0, "out", cmp0, "in");
  292. cmDspSysConnectAudio(h, cmp0, "out", ao0p, "in" ); // comp -> aout
  293. cmDspSysConnectAudio(h, wtp, "out", kr10, "in" ); // wt -> kr
  294. cmDspSysConnectAudio(h, kr10, "out", fad1, "in-0");
  295. cmDspSysConnectAudio(h, fad1, "out-0", mix1, "in-0");
  296. cmDspSysConnectAudio(h, wtp, "out", kr11, "in" ); // wt -> kr
  297. cmDspSysConnectAudio(h, kr11, "out", fad1, "in-1");
  298. cmDspSysConnectAudio(h, fad1, "out-1", mix1, "in-1");
  299. cmDspSysConnectAudio(h, mix1, "out", cmp1, "in");
  300. cmDspSysConnectAudio(h, cmp1, "out", ao1p, "in" ); // comp -> aout
  301. cmDspSysConnectAudio(h, cmp0, "out", afop, "in0" ); // comp -> audio_file_out
  302. cmDspSysConnectAudio(h, cmp1, "out", afop, "in1" );
  303. // wave-table to time-line cursor
  304. cmDspSysInstallCb( h, wtp, "fidx",tlp, "curs", NULL);
  305. cmDspSysInstallCb(h, prePath, "out", tlp, "path", NULL );
  306. // start connections
  307. cmDspSysInstallCb(h, onb, "sym", tlp, "reset", NULL );
  308. cmDspSysInstallCb(h, onb, "sym", scp, "send", NULL );
  309. cmDspSysInstallCb(h, onb, "sym", mfp, "sel", NULL );
  310. cmDspSysInstallCb(h, onb, "sym", pts, "on", NULL );
  311. cmDspSysInstallCb(h, pts, "on", wtp, "cmd", NULL );
  312. cmDspSysInstallCb(h, pts, "on", modp,"cmd", NULL );
  313. cmDspSysInstallCb(h, onb, "sym", amCmd, "rewind", NULL );
  314. cmDspSysInstallCb(h, onb, "sym", achan0, "trig", NULL );
  315. cmDspSysInstallCb(h, onb, "sym", achan1, "trig", NULL );
  316. // stop connections
  317. cmDspSysInstallCb(h, wtp, "done",offb,"in", NULL ); // 'done' from WT simulates pressing Stop btn.
  318. cmDspSysInstallCb(h, tlp, "mfn", pts, "off", NULL ); // Prevents WT start on new audio file from TL.
  319. cmDspSysInstallCb(h, offb, "sym", mfp, "sel", NULL );
  320. cmDspSysInstallCb(h, offb, "sym", pts, "off", NULL );
  321. cmDspSysInstallCb(h, pts, "off", wtp, "cmd", NULL );
  322. cmDspSysInstallCb(h, pts, "off", modp,"cmd", NULL );
  323. // time-line to wave-table selection
  324. cmDspSysInstallCb(h, tlp, "absi", wtp, "beg", NULL );
  325. cmDspSysInstallCb(h, tlp, "aesi", wtp, "end", NULL );
  326. cmDspSysInstallCb(h, tlp, "afn", wtp, "fn", NULL );
  327. // time-line to MIDI file player selection
  328. cmDspSysInstallCb(h, tlp, "mbsi", mfp, "bsi", NULL );
  329. cmDspSysInstallCb(h, tlp, "mesi", mfp, "esi", NULL );
  330. cmDspSysInstallCb(h, tlp, "mfn", mfp, "fn", NULL );
  331. cmDspSysInstallCb(h, scp, "sel", sfp, "index", NULL ); // score to score follower - to set initial search location
  332. cmDspSysInstallCb(h, scp, "sel", modp,"reset", NULL );
  333. //cmDspSysInstallCb(h, reload,"out", modp, "reload", NULL );
  334. // MIDI file player to score follower
  335. cmDspSysInstallCb(h, mfp, "smpidx", sfp, "smpidx", NULL );
  336. cmDspSysInstallCb(h, mfp, "d1", sfp, "d1", NULL );
  337. cmDspSysInstallCb(h, mfp, "d0", sfp, "d0", NULL );
  338. cmDspSysInstallCb(h, mfp, "status", sfp, "status", NULL );
  339. if( mop != NULL )
  340. {
  341. cmDspSysInstallCb(h, mfp, "d1", mop, "d1", NULL );
  342. cmDspSysInstallCb(h, mfp, "d0", mop, "d0", NULL );
  343. cmDspSysInstallCb(h, mfp, "status", mop, "status", NULL );
  344. }
  345. // score follower to modulator and printers
  346. cmDspSysInstallCb(h, sfp, "out", modp, "index", NULL );
  347. cmDspSysInstallCb(h, sfp, "out", prp, "in", NULL );
  348. cmDspSysInstallCb(h, prtb, "sym", sfp, "cmd", NULL );
  349. cmDspSysInstallCb(h, qtb, "sym", sfp, "cmd", NULL );
  350. // audio-midi sync connections
  351. cmDspSysInstallCb(h, tlp, "albl", asp, "afn", NULL );
  352. cmDspSysInstallCb(h, tlp, "mlbl", asp, "mfn", NULL );
  353. cmDspSysInstallCb(h, wtp, "fidx", asp, "asmp",NULL );
  354. cmDspSysInstallCb(h, mfp, "id", asp, "mid", NULL );
  355. cmDspSysInstallCb(h, offb,"sym", asp, "sel", NULL );
  356. //cmDspSysInstallCb(h, tlp, "absi", prp, "in", NULL );
  357. cmDspSysInstallCb(h, ws00p, "out", kr00, "wndn", NULL ); // wndSmpCnt->kr
  358. cmDspSysInstallCb(h, hf00p, "out", kr00, "hopf", NULL ); // hopFact->kr
  359. cmDspSysInstallCb(h, of00p, "val", kr00, "offs", NULL ); // offset->kr
  360. cmDspSysInstallCb(h, iv00p, "val", kr00, "invt", NULL ); // invert->kr
  361. cmDspSysInstallCb(h, wet00p, "val", kr00, "wet", NULL ); // wet->kr
  362. cmDspSysInstallCb(h, ws00p, "out", kr01, "wndn", NULL ); // wndSmpCnt->kr
  363. cmDspSysInstallCb(h, hf00p, "out", kr01, "hopf", NULL ); // hopFact->kr
  364. cmDspSysInstallCb(h, of00p, "val", kr01, "offs", NULL ); // offset->kr
  365. cmDspSysInstallCb(h, iv00p, "val", kr01, "invt", NULL ); // invert->kr
  366. cmDspSysInstallCb(h, wet00p, "val", kr01, "wet", NULL ); // wet->kr
  367. cmDspSysInstallCb(h, ws10p, "out", kr10, "wndn", NULL ); // wndSmpCnt->kr
  368. cmDspSysInstallCb(h, hf10p, "out", kr10, "hopf", NULL ); // hopFact->kr
  369. cmDspSysInstallCb(h, of10p, "val", kr10, "offs", NULL ); // offset->kr
  370. cmDspSysInstallCb(h, iv10p, "val", kr10, "invt", NULL ); // invert->kr
  371. cmDspSysInstallCb(h, wet10p, "val", kr10, "wet", NULL ); // wet->kr
  372. cmDspSysInstallCb(h, ws10p, "out", kr11, "wndn", NULL ); // wndSmpCnt->kr
  373. cmDspSysInstallCb(h, hf10p, "out", kr11, "hopf", NULL ); // hopFact->kr
  374. cmDspSysInstallCb(h, of10p, "val", kr11, "offs", NULL ); // offset->kr
  375. cmDspSysInstallCb(h, iv10p, "val", kr11, "invt", NULL ); // invert->kr
  376. cmDspSysInstallCb(h, wet10p, "val", kr11, "wet", NULL ); // wet->kr
  377. cmDspSysInstallCb(h, ogain0, "val", ao0p, "gain", NULL ); // output gain control
  378. cmDspSysInstallCb(h, ogain1, "val", ao1p, "gain", NULL );
  379. cmDspSysInstallCb(h, xfadMs, "val", fad0, "ms", NULL );
  380. cmDspSysInstallCb(h, xfadMs, "val", fad1, "ms", NULL );
  381. // Printer connections
  382. cmDspSysInstallCb(h, tlp, "afn", prp, "in", NULL );
  383. cmDspSysInstallCb(h, tlp, "mfn", prp, "in", NULL );
  384. cmDspSysInstallCb(h, tlp, "sel", prp, "in", NULL );
  385. cmDspSysInstallCb(h, modp, "mod0", md00p, "val", NULL );
  386. cmDspSysInstallCb(h, modp, "thr0", th00p, "val", NULL );
  387. cmDspSysInstallCb(h, modp, "upr0", us00p, "val", NULL );
  388. cmDspSysInstallCb(h, modp, "lwr0", ls00p, "val", NULL );
  389. cmDspSysInstallCb(h, modp, "mint0", min_thrh_0, "val", NULL );
  390. cmDspSysInstallCb(h, modp, "maxt0", max_thrh_0, "val", NULL );
  391. cmDspSysInstallCb(h, modp, "minu0", min_upr_0, "val", NULL );
  392. cmDspSysInstallCb(h, modp, "maxu0", max_upr_0, "val", NULL );
  393. cmDspSysInstallCb(h, modp, "minl0", min_lwr_0, "val", NULL );
  394. cmDspSysInstallCb(h, modp, "maxl0", max_lwr_0, "val", NULL );
  395. cmDspSysInstallCb(h, modp, "mod1", md10p, "val", NULL );
  396. cmDspSysInstallCb(h, modp, "thr1", th10p, "val", NULL );
  397. cmDspSysInstallCb(h, modp, "upr1", us10p, "val", NULL );
  398. cmDspSysInstallCb(h, modp, "lwr1", ls10p, "val", NULL );
  399. cmDspSysInstallCb(h, modp, "mint1", min_thrh_1, "val", NULL );
  400. cmDspSysInstallCb(h, modp, "maxt1", max_thrh_1, "val", NULL );
  401. cmDspSysInstallCb(h, modp, "minu1", min_upr_1, "val", NULL );
  402. cmDspSysInstallCb(h, modp, "maxu1", max_upr_1, "val", NULL );
  403. cmDspSysInstallCb(h, modp, "minl1", min_lwr_1, "val", NULL );
  404. cmDspSysInstallCb(h, modp, "maxl1", max_lwr_1, "val", NULL );
  405. cmDspSysInstallCb(h, modp, "xfad", xfadMs, "val", NULL );
  406. // =========================================================================
  407. // Cross fade connections for measurments
  408. //
  409. // active measure loc to xfad channel trigger
  410. cmDspSysInstallCb( h, amp, "scloc", achan0, "trig", NULL );
  411. cmDspSysInstallCb( h, amp, "scloc", achan1, "trig", NULL );
  412. //cmDspSysInstallCb( h, modp, "post", achan0, "trig", NULL );
  413. //cmDspSysInstallCb( h, modp, "post", achan1, "trig", NULL );
  414. // xfade router channel selection
  415. cmDspSysInstallCb( h, achan0, "ch", mod_rt_00, "sel", NULL );
  416. cmDspSysInstallCb( h, achan0, "ch", thr_rt_00, "sel", NULL );
  417. cmDspSysInstallCb( h, achan0, "ch", upr_rt_00, "sel", NULL );
  418. cmDspSysInstallCb( h, achan0, "ch", lwr_rt_00, "sel", NULL );
  419. cmDspSysInstallCb( h, achan1, "ch", mod_rt_10, "sel", NULL );
  420. cmDspSysInstallCb( h, achan1, "ch", thr_rt_10, "sel", NULL );
  421. cmDspSysInstallCb( h, achan1, "ch", upr_rt_10, "sel", NULL );
  422. cmDspSysInstallCb( h, achan1, "ch", lwr_rt_10, "sel", NULL );
  423. // active measure to meas->param mapping routers
  424. cmDspSysInstallCb(h, amp, "even", even_sr_00, "val_in", NULL );
  425. cmDspSysInstallCb(h, amp, "even", even_sr_10, "val_in", NULL );
  426. cmDspSysInstallCb(h, amp, "dyn", dyn_sr_00, "val_in", NULL );
  427. cmDspSysInstallCb(h, amp, "dyn", dyn_sr_10, "val_in", NULL );
  428. cmDspSysInstallCb(h, amp, "tempo", tempo_sr_00,"val_in", NULL );
  429. cmDspSysInstallCb(h, amp, "tempo", tempo_sr_10,"val_in", NULL );
  430. cmDspSysInstallCb(h, amp, "cost", cost_sr_00, "val_in", NULL );
  431. cmDspSysInstallCb(h, amp, "cost", cost_sr_10, "val_in", NULL );
  432. // active-channel to cross-fade connections
  433. cmDspSysInstallCb(h, achan0, "gate-0", fad0, "gate-0", NULL );
  434. cmDspSysInstallCb(h, achan0, "gate-1", fad0, "gate-1", NULL );
  435. cmDspSysInstallCb(h, fad0, "state-0", achan0, "dis-0", NULL );
  436. cmDspSysInstallCb(h, fad0, "state-1", achan0, "dis-1", NULL );
  437. cmDspSysInstallCb(h, achan1, "gate-0", fad1, "gate-0", NULL );
  438. cmDspSysInstallCb(h, achan1, "gate-1", fad1, "gate-1", NULL );
  439. cmDspSysInstallCb(h, fad1, "state-0", achan1, "dis-0", NULL );
  440. cmDspSysInstallCb(h, fad1, "state-1", achan1, "dis-1", NULL );
  441. // =========================================================================
  442. // Scale Range Connections 00
  443. //
  444. // DYN -> scaleRange -> Router -> var scaleRange
  445. cmDspSysInstallCb(h, min_dyn_0, "val", dyn_sr_00, "min_in", NULL );
  446. cmDspSysInstallCb(h, max_dyn_0, "val", dyn_sr_00, "max_in", NULL );
  447. cmDspSysInstallCb(h, dyn_sr_00, "val_out", dyn_rt_00, "f-in", NULL );
  448. cmDspSysInstallCb(h, menu_dyn_0, "out", dyn_rt_00, "sel", NULL );
  449. cmDspSysInstallCb(h, dyn_rt_00, "f-out-0", thrh_sr_00, "val_in", NULL );
  450. cmDspSysInstallCb(h, dyn_rt_00, "f-out-1", upr_sr_00, "val_in", NULL );
  451. cmDspSysInstallCb(h, dyn_rt_00, "f-out-2", lwr_sr_00, "val_in", NULL );
  452. // EVEN -> scaleRange -> Router -> var scaleRange
  453. cmDspSysInstallCb(h, min_even_0, "val", even_sr_00, "min_in", NULL );
  454. cmDspSysInstallCb(h, max_even_0, "val", even_sr_00, "max_in", NULL );
  455. cmDspSysInstallCb(h, even_sr_00, "val_out", even_rt_00, "f-in", NULL );
  456. cmDspSysInstallCb(h, menu_even_0, "out", even_rt_00, "sel", NULL );
  457. cmDspSysInstallCb(h, even_rt_00, "f-out-0", thrh_sr_00, "val_in", NULL );
  458. cmDspSysInstallCb(h, even_rt_00, "f-out-1", upr_sr_00, "val_in", NULL );
  459. cmDspSysInstallCb(h, even_rt_00, "f-out-2", lwr_sr_00, "val_in", NULL );
  460. // TEMPO -> scaleRange -> Router -> var scaleRange
  461. cmDspSysInstallCb(h, min_tempo_0, "val", tempo_sr_00, "min_in", NULL );
  462. cmDspSysInstallCb(h, max_tempo_0, "val", tempo_sr_00, "max_in", NULL );
  463. cmDspSysInstallCb(h, tempo_sr_00, "val_out", tempo_rt_00, "f-in", NULL );
  464. cmDspSysInstallCb(h, menu_tempo_0, "out", tempo_rt_00, "sel", NULL );
  465. cmDspSysInstallCb(h, tempo_rt_00, "f-out-0", thrh_sr_00, "val_in", NULL );
  466. cmDspSysInstallCb(h, tempo_rt_00, "f-out-1", upr_sr_00, "val_in", NULL );
  467. cmDspSysInstallCb(h, tempo_rt_00, "f-out-2", lwr_sr_00, "val_in", NULL );
  468. // COST -> scaleRange -> Router -> var scaleRange
  469. cmDspSysInstallCb(h, min_cost_0, "val", cost_sr_00, "min_in", NULL );
  470. cmDspSysInstallCb(h, max_cost_0, "val", cost_sr_00, "max_in", NULL );
  471. cmDspSysInstallCb(h, cost_sr_00, "val_out", cost_rt_00, "f-in", NULL );
  472. cmDspSysInstallCb(h, menu_cost_0, "out", cost_rt_00, "sel", NULL );
  473. cmDspSysInstallCb(h, cost_rt_00, "f-out-0", thrh_sr_00, "val_in", NULL );
  474. cmDspSysInstallCb(h, cost_rt_00, "f-out-1", upr_sr_00, "val_in", NULL );
  475. cmDspSysInstallCb(h, cost_rt_00, "f-out-2", lwr_sr_00, "val_in", NULL );
  476. // MODE -> FX
  477. cmDspSysInstallCb(h, md00p, "val", mod_rt_00, "f-in", NULL );
  478. cmDspSysInstallCb(h, mod_rt_00, "f-out-0", kr00, "mode", NULL ); // mode->kr
  479. cmDspSysInstallCb(h, mod_rt_00, "f-out-1", kr01, "mode", NULL ); // mode->kr
  480. // THRESH scaleRange -> FX
  481. cmDspSysInstallCb(h, min_thrh_0, "val", thrh_sr_00, "min_out", NULL );
  482. cmDspSysInstallCb(h, max_thrh_0, "val", thrh_sr_00, "max_out", NULL );
  483. cmDspSysInstallCb(h, thrh_sr_00, "val_out", th00p, "val", NULL );
  484. cmDspSysInstallCb(h, th00p, "val", thr_rt_00, "f-in", NULL );
  485. cmDspSysInstallCb(h, thr_rt_00, "f-out-0", kr00, "thrh", NULL ); // thresh->kr
  486. cmDspSysInstallCb(h, thr_rt_00, "f-out-1", kr01, "thrh", NULL ); // thresh->kr
  487. // UPR scaleRange -> FX
  488. cmDspSysInstallCb(h, min_upr_0, "val", upr_sr_00, "min_out", NULL );
  489. cmDspSysInstallCb(h, max_upr_0, "val", upr_sr_00, "max_out", NULL );
  490. cmDspSysInstallCb(h, upr_sr_00, "val_out", us00p, "val", NULL );
  491. cmDspSysInstallCb(h, us00p, "val", upr_rt_00, "f-in", NULL );
  492. cmDspSysInstallCb(h, upr_rt_00, "f-out-0", kr00, "uprs", NULL ); // uprSlope->kr
  493. cmDspSysInstallCb(h, upr_rt_00, "f-out-1", kr01, "uprs", NULL ); // uprSlope->kr
  494. // LWR scaleRange -> FX
  495. cmDspSysInstallCb(h, min_lwr_0, "val", lwr_sr_00, "min_out", NULL );
  496. cmDspSysInstallCb(h, max_lwr_0, "val", lwr_sr_00, "max_out", NULL );
  497. cmDspSysInstallCb(h, lwr_sr_00, "val_out", ls00p, "val", NULL );
  498. cmDspSysInstallCb(h, ls00p, "val", lwr_rt_00, "f-in", NULL );
  499. cmDspSysInstallCb(h, lwr_rt_00, "f-out-0", kr00, "lwrs", NULL ); // lwrSlope->kr
  500. cmDspSysInstallCb(h, lwr_rt_00, "f-out-1", kr01, "lwrs", NULL ); // lwrSlope->kr
  501. // =========================================================================
  502. // Scale Range Connections 10
  503. //
  504. // DYN -> scaleRange -> Router -> var scaleRange
  505. cmDspSysInstallCb(h, min_dyn_1, "val", dyn_sr_10, "min_in", NULL );
  506. cmDspSysInstallCb(h, max_dyn_1, "val", dyn_sr_10, "max_in", NULL );
  507. cmDspSysInstallCb(h, dyn_sr_10, "val_out", dyn_rt_10, "f-in", NULL );
  508. cmDspSysInstallCb(h, menu_dyn_1, "out", dyn_rt_10, "sel", NULL );
  509. cmDspSysInstallCb(h, dyn_rt_10, "f-out-0", thrh_sr_10, "val_in", NULL );
  510. cmDspSysInstallCb(h, dyn_rt_10, "f-out-1", upr_sr_10, "val_in", NULL );
  511. cmDspSysInstallCb(h, dyn_rt_10, "f-out-2", lwr_sr_10, "val_in", NULL );
  512. // EVEN -> scaleRange -> Router -> var scaleRange
  513. cmDspSysInstallCb(h, min_even_1, "val", even_sr_10, "min_in", NULL );
  514. cmDspSysInstallCb(h, max_even_1, "val", even_sr_10, "max_in", NULL );
  515. cmDspSysInstallCb(h, even_sr_10, "val_out", even_rt_10, "f-in", NULL );
  516. cmDspSysInstallCb(h, menu_even_1, "out", even_rt_10, "sel", NULL );
  517. cmDspSysInstallCb(h, even_rt_10, "f-out-0", thrh_sr_10, "val_in", NULL );
  518. cmDspSysInstallCb(h, even_rt_10, "f-out-1", upr_sr_10, "val_in", NULL );
  519. cmDspSysInstallCb(h, even_rt_10, "f-out-2", lwr_sr_10, "val_in", NULL );
  520. // TEMPO -> scaleRange -> Router -> var scaleRange
  521. cmDspSysInstallCb(h, min_tempo_1, "val", tempo_sr_10, "min_in", NULL );
  522. cmDspSysInstallCb(h, max_tempo_1, "val", tempo_sr_10, "max_in", NULL );
  523. cmDspSysInstallCb(h, tempo_sr_10, "val_out", tempo_rt_10, "f-in", NULL );
  524. cmDspSysInstallCb(h, menu_tempo_1, "out", tempo_rt_10, "sel", NULL );
  525. cmDspSysInstallCb(h, tempo_rt_10, "f-out-0", thrh_sr_10, "val_in", NULL );
  526. cmDspSysInstallCb(h, tempo_rt_10, "f-out-1", upr_sr_10, "val_in", NULL );
  527. cmDspSysInstallCb(h, tempo_rt_10, "f-out-2", lwr_sr_10, "val_in", NULL );
  528. // COST -> scaleRange -> Router -> var scaleRange
  529. cmDspSysInstallCb(h, min_cost_1, "val", cost_sr_10, "min_in", NULL );
  530. cmDspSysInstallCb(h, max_cost_1, "val", cost_sr_10, "max_in", NULL );
  531. cmDspSysInstallCb(h, cost_sr_10, "val_out", cost_rt_10, "f-in", NULL );
  532. cmDspSysInstallCb(h, menu_cost_1, "out", cost_rt_10, "sel", NULL );
  533. cmDspSysInstallCb(h, cost_rt_10, "f-out-0", thrh_sr_10, "val_in", NULL );
  534. cmDspSysInstallCb(h, cost_rt_10, "f-out-1", upr_sr_10, "val_in", NULL );
  535. cmDspSysInstallCb(h, cost_rt_10, "f-out-2", lwr_sr_10, "val_in", NULL );
  536. // MODE -> FX
  537. cmDspSysInstallCb(h, md10p, "val", mod_rt_10, "f-in", NULL );
  538. cmDspSysInstallCb(h, mod_rt_10, "f-out-0", kr10, "mode", NULL ); // mode->kr
  539. cmDspSysInstallCb(h, mod_rt_10, "f-out-1", kr11, "mode", NULL ); // mode->kr
  540. // THRESH scaleRange -> FX
  541. cmDspSysInstallCb(h, min_thrh_1, "val", thrh_sr_10, "min_out", NULL );
  542. cmDspSysInstallCb(h, max_thrh_1, "val", thrh_sr_10, "max_out", NULL );
  543. cmDspSysInstallCb(h, thrh_sr_10, "val_out", th10p, "val", NULL );
  544. cmDspSysInstallCb(h, th10p, "val", thr_rt_10, "f-in", NULL );
  545. cmDspSysInstallCb(h, thr_rt_10, "f-out-0", kr10, "thrh", NULL ); // thresh->kr
  546. cmDspSysInstallCb(h, thr_rt_10, "f-out-1", kr11, "thrh", NULL ); // thresh->kr
  547. // UPR scaleRange -> FX
  548. cmDspSysInstallCb(h, min_upr_1, "val", upr_sr_10, "min_out", NULL );
  549. cmDspSysInstallCb(h, max_upr_1, "val", upr_sr_10, "max_out", NULL );
  550. cmDspSysInstallCb(h, upr_sr_10, "val_out", us10p, "val", NULL );
  551. cmDspSysInstallCb(h, us10p, "val", upr_rt_10, "f-in", NULL );
  552. cmDspSysInstallCb(h, upr_rt_10, "f-out-0", kr10, "uprs", NULL ); // uprSlope->kr
  553. cmDspSysInstallCb(h, upr_rt_10, "f-out-1", kr11, "uprs", NULL ); // uprSlope->kr
  554. // LWR scaleRange -> FX
  555. cmDspSysInstallCb(h, min_lwr_1, "val", lwr_sr_10, "min_out", NULL );
  556. cmDspSysInstallCb(h, max_lwr_1, "val", lwr_sr_10, "max_out", NULL );
  557. cmDspSysInstallCb(h, lwr_sr_10, "val_out", ls10p, "val", NULL );
  558. cmDspSysInstallCb(h, ls10p, "val", lwr_rt_10, "f-in", NULL );
  559. cmDspSysInstallCb(h, lwr_rt_10, "f-out-0", kr10, "lwrs", NULL ); // lwrSlope->kr
  560. cmDspSysInstallCb(h, lwr_rt_10, "f-out-1", kr11, "lwrs", NULL ); // lwrSlope->kr
  561. cmDspSysNewPage(h,"Compressor");
  562. cmDspInst_t* cmp0_byp = cmDspSysAllocCheckP( h, compPreGrpSymId, NULL, "Bypass0", 1.0 );
  563. cmDspInst_t* cmp0_igain = cmDspSysAllocScalarP( h, compPreGrpSymId, NULL, "In Gain0", 0.0, 10.0, 0.1, cmpInGain );
  564. cmDspInst_t* cmp0_thr = cmDspSysAllocScalarP( h, compPreGrpSymId, NULL, "ThreshDb0", -100.0, 0.0, 0.1, cmpThreshDb);
  565. cmDspInst_t* cmp0_rat = cmDspSysAllocScalarP( h, compPreGrpSymId, NULL, "Ratio0", 0.1, 100, 0.1, cmpRatio_num);
  566. cmDspInst_t* cmp0_atk = cmDspSysAllocScalarP( h, compPreGrpSymId, NULL, "Atk Ms0", 0.0, 1000.0, 0.1, cmpAtkMs);
  567. cmDspInst_t* cmp0_rls = cmDspSysAllocScalarP( h, compPreGrpSymId, NULL, "Rls Ms0", 0.0, 1000.0, 0.1, cmpRlsMs);
  568. cmDspInst_t* cmp0_mkup = cmDspSysAllocScalarP( h, compPreGrpSymId, NULL, "Makeup0", 0.0, 10.0, 0.01, cmpMakeup);
  569. cmDspInst_t* cmp0_wnd = cmDspSysAllocScalarP( h, compPreGrpSymId, NULL, "Wnd Ms0", 1.0, cmpWndMaxMs, 1.0, cmpWndMs );
  570. cmDspInst_t* cmp0_mtr = cmDspSysAllocInst(h,"Meter","Env0", 3, 0.0, 0.0, 1.0);
  571. cmDspSysInstallCb(h, cmp0_byp, "out", cmp0, "bypass", NULL );
  572. cmDspSysInstallCb(h, cmp0_igain,"val", cmp0, "igain", NULL );
  573. cmDspSysInstallCb(h, cmp0_thr, "val", cmp0, "thr", NULL );
  574. cmDspSysInstallCb(h, cmp0_rat, "val", cmp0, "ratio", NULL );
  575. cmDspSysInstallCb(h, cmp0_atk, "val", cmp0, "atk", NULL );
  576. cmDspSysInstallCb(h, cmp0_rls, "val", cmp0, "rls", NULL );
  577. cmDspSysInstallCb(h, cmp0_mkup, "val", cmp0, "ogain", NULL );
  578. cmDspSysInstallCb(h, cmp0_wnd, "val", cmp0, "wnd", NULL );
  579. cmDspSysInstallCb(h, cmp0, "env", cmp0_mtr, "in", NULL );
  580. cmDspSysNewColumn(h,0);
  581. cmDspInst_t* cmp1_byp = cmDspSysAllocCheckP( h, compPreGrpSymId, NULL, "Bypass1", 1.0 );
  582. cmDspInst_t* cmp1_igain = cmDspSysAllocScalarP( h, compPreGrpSymId, NULL, "In Gain1", 0.0, 10.0, 0.1, cmpInGain);
  583. cmDspInst_t* cmp1_thr = cmDspSysAllocScalarP( h, compPreGrpSymId, NULL, "ThreshDb1", -100.0, 0.0, 0.1, cmpThreshDb);
  584. cmDspInst_t* cmp1_rat = cmDspSysAllocScalarP( h, compPreGrpSymId, NULL, "Ratio1", 0.1, 100, 0.1, cmpRatio_num);
  585. cmDspInst_t* cmp1_atk = cmDspSysAllocScalarP( h, compPreGrpSymId, NULL, "Atk Ms1", 0.0, 1000.0, 0.1, cmpAtkMs);
  586. cmDspInst_t* cmp1_rls = cmDspSysAllocScalarP( h, compPreGrpSymId, NULL, "Rls Ms1", 0.0, 1000.0, 0.1, cmpRlsMs);
  587. cmDspInst_t* cmp1_mkup = cmDspSysAllocScalarP( h, compPreGrpSymId, NULL, "Makeup1", 0.0, 10.0, 0.01, cmpMakeup);
  588. cmDspInst_t* cmp1_wnd = cmDspSysAllocScalarP( h, compPreGrpSymId, NULL, "Wnd Ms1", 1.0, cmpWndMaxMs, 1.0, cmpWndMs );
  589. cmDspInst_t* cmp1_mtr = cmDspSysAllocInst(h,"Meter","Env1", 3, 0.0, 0.0, 1.0);
  590. cmDspSysInstallCb(h, cmp1_byp, "out", cmp1, "bypass", NULL );
  591. cmDspSysInstallCb(h, cmp1_igain,"val", cmp1, "igain", NULL );
  592. cmDspSysInstallCb(h, cmp1_thr, "val", cmp1, "thr", NULL );
  593. cmDspSysInstallCb(h, cmp1_rat, "val", cmp1, "ratio", NULL );
  594. cmDspSysInstallCb(h, cmp1_atk, "val", cmp1, "atk", NULL );
  595. cmDspSysInstallCb(h, cmp1_rls, "val", cmp1, "rls", NULL );
  596. cmDspSysInstallCb(h, cmp1_mkup, "val", cmp1, "ogain", NULL );
  597. cmDspSysInstallCb(h, cmp1_wnd, "val", cmp1, "wnd", NULL );
  598. cmDspSysInstallCb(h, cmp1, "env", cmp1_mtr, "in", NULL );
  599. //--------------- Compressor Preset controls
  600. cmDspSysNewColumn(h,0);
  601. cmDspInst_t* comp_preset = cmDspSysAllocInst( h, "Preset", NULL, 1, compPreGrpSymId );
  602. cmDspInst_t* comp_presetLbl = cmDspSysAllocInst( h, "Text", "Comp_Preset", 1, "" );
  603. cmDspInst_t* comp_storeBtn = cmDspSysAllocButton( h, "comp_store", 0);
  604. cmDspInst_t* comp_recallBtn = cmDspSysAllocButton( h, "comp_recall", 0);
  605. cmDspInst_t* comp_pts = cmDspSysAllocInst( h, "PortToSym", NULL, 2, "store", "recall");
  606. cmDspSysInstallCb( h, comp_presetLbl, "val", comp_preset, "label",NULL);
  607. cmDspSysInstallCb( h, comp_storeBtn, "out", comp_pts, "store", NULL );
  608. cmDspSysInstallCb( h, comp_recallBtn, "out", comp_pts, "recall", NULL );
  609. cmDspSysInstallCb( h, comp_pts, "store", comp_preset, "cmd", NULL );
  610. cmDspSysInstallCb( h, comp_pts, "recall", comp_preset, "cmd", NULL );
  611. return rc;
  612. }
  613. cmDspRC_t _cmDspSysPgm_KrLive(cmDspSysH_t h, void** userPtrPtr )
  614. {
  615. cmDspRC_t rc = kOkDspRC;
  616. cmCtx_t* cmCtx = cmDspSysPgmCtx(h);
  617. cmErr_t err;
  618. krRsrc_t r;
  619. /*
  620. int krWndSmpCnt = 2048;
  621. int krHopFact = 4;
  622. unsigned xfadeChCnt = 2;
  623. double xfadeMs = 50;
  624. bool xfadeInitFl = true;
  625. double mixGain = 1.0;
  626. unsigned measRtChCnt = 4; // note: router channel 4 is not connected
  627. bool cmpBypassFl = false;
  628. double cmpInGain = 3.0;
  629. double cmpThreshDb = -40.0;
  630. double cmpRatio_num = 5.0;
  631. double cmpAtkMs = 20.0;
  632. double cmpRlsMs = 100.0;
  633. double cmpMakeup = 1.0;
  634. double cmpWndMaxMs = 1000.0;
  635. double cmpWndMs = 200.0;
  636. */
  637. memset(&r,0,sizeof(r));
  638. cmErrSetup(&err,&cmCtx->rpt,"Kr Live");
  639. if( krLoadRsrc(h,&err,&r) != kOkDspRC )
  640. return rc;
  641. //unsigned preGrpSymId = cmDspSysPresetRegisterGroup(h,"tl");
  642. //unsigned compPreGrpSymId = cmDspSysPresetRegisterGroup(h,"tl_cmp");
  643. cmDspInst_t* mip = cmDspSysAllocInst(h, "MidiIn", NULL, 2, r.midiDevice, r.midiInPort);
  644. cmDspInst_t* mop = cmDspSysAllocInst(h, "MidiOut", NULL, 2, r.midiDevice, r.midiOutPort);
  645. cmDspInst_t* ai0p = cmDspSysAllocInst(h,"AudioIn", NULL, 1, 0 );
  646. cmDspInst_t* ai1p = cmDspSysAllocInst(h,"AudioIn", NULL, 1, 0 );
  647. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut", NULL, 1, 0 );
  648. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut", NULL, 1, 0 );
  649. cmDspSysConnectAudio(h, ai0p, "out", ao0p, "in" );
  650. cmDspSysConnectAudio(h, ai1p, "out", ao1p, "in" );
  651. cmDspSysInstallCb(h, mip, "status", mop, "status", NULL);
  652. cmDspSysInstallCb(h, mip, "d0", mop, "d0", NULL);
  653. cmDspSysInstallCb(h, mip, "d1", mop, "d1", NULL);
  654. return rc;
  655. }