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.

cmDspPgmKrChain.c 36KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609
  1. //| Copyright: (C) 2009-2020 Kevin Larke <contact AT larke DOT org>
  2. //| License: GNU GPL version 3.0 or above. See the accompanying LICENSE file.
  3. #include "cmPrefix.h"
  4. #include "cmGlobal.h"
  5. #include "cmFloatTypes.h"
  6. #include "cmRpt.h"
  7. #include "cmErr.h"
  8. #include "cmCtx.h"
  9. #include "cmMem.h"
  10. #include "cmMallocDebug.h"
  11. #include "cmLinkedHeap.h"
  12. #include "cmText.h"
  13. #include "cmFileSys.h"
  14. #include "cmSymTbl.h"
  15. #include "cmJson.h"
  16. #include "cmPrefs.h"
  17. #include "cmDspValue.h"
  18. #include "cmMsgProtocol.h"
  19. #include "cmThread.h"
  20. #include "cmUdpPort.h"
  21. #include "cmUdpNet.h"
  22. #include "cmTime.h"
  23. #include "cmSerialPort.h"
  24. #include "cmAudioSys.h"
  25. #include "cmProcObj.h"
  26. #include "cmDspCtx.h"
  27. #include "cmDspClass.h"
  28. #include "cmDspSys.h"
  29. #include "cmDspPgm.h"
  30. #include "cmAudioFile.h"
  31. #include "cmProcObj.h"
  32. #include "cmProc.h"
  33. #include "cmProc3.h"
  34. #include "cmVectOpsTemplateMain.h"
  35. #include "cmVectOps.h"
  36. #include "cmDspPgmKrChain.h"
  37. #undef KR2
  38. cmDspRC_t krLoadRsrc(cmDspSysH_t h, cmErr_t* err, krRsrc_t* r)
  39. {
  40. cmDspRC_t rc;
  41. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  42. return rc;
  43. cmDspRsrcString(h,&r->tlFn, "timeLineFn", NULL);
  44. cmDspRsrcString(h,&r->tlPrefixPath,"tlPrefixPath", NULL);
  45. cmDspRsrcString(h,&r->scFn, "scoreFn", NULL);
  46. cmDspRsrcString(h,&r->tksbFn, "tksbFn", NULL);
  47. cmDspRsrcString(h,&r->modFn, "modFn", NULL);
  48. cmDspRsrcString(h,&r->measFn, "measFn", NULL);
  49. cmDspRsrcString(h,&r->recordDir, "recordDir", NULL);
  50. cmDspRsrcString(h,&r->midiDevice, "midiDevice", NULL);
  51. cmDspRsrcString(h,&r->midiOutPort, "midiOutPort", NULL);
  52. cmDspRsrcString(h,&r->midiOutPort2,"midiOutPort2", NULL);
  53. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  54. cmErrMsg(err,rc,"A KR DSP resource load failed.");
  55. return rc;
  56. }
  57. const cmChar_t* _mlbl(const cmChar_t* prefix, unsigned ch )
  58. {
  59. static char s[128];
  60. s[127]=0;
  61. snprintf(s,127,"%s%i",prefix,ch);
  62. return s;
  63. }
  64. #define mlbl(a) _mlbl(a,mch)
  65. #define lbl(a) cmDspSysPrintLabel(a,ach)
  66. #ifndef KR2
  67. void _cmDspSys_TlXformChain( cmDspSysH_t h, cmDspTlXform_t* c, unsigned preGrpSymId, unsigned cmpPreGrpSymId, cmDspInst_t* modp, unsigned ach, unsigned mch )
  68. {
  69. unsigned measRtrChCnt = 9; // note: router channel 8 is not connected
  70. unsigned scaleRangeDfltSelId = 8;
  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. bool cmpBypassFl = false;
  78. double cmpInGain = 3.0;
  79. double cmpThreshDb = -40.0;
  80. double cmpRatio_num = 5.0;
  81. double cmpAtkMs = 20.0;
  82. double cmpRlsMs = 100.0;
  83. double cmpMakeup = 1.0;
  84. double cmpWndMaxMs = 1000.0;
  85. double cmpWndMs = 200.0;
  86. cmDspInst_t* p_wet = cmDspSysAllocInst(h,"Printer", NULL, 1, "WET:");
  87. cmDspInst_t* achan = cmDspSysAllocInst(h, "AvailCh", NULL, 1, xfadeChCnt );
  88. // Measurement scale/range
  89. cmDspInst_t* even_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.8, 1.1, 0.0, 1.0 );
  90. cmDspInst_t* dynm_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 4.0, 0.01, 1.0 );
  91. cmDspInst_t* tmpo_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 80.0, 120.0, 0.01, 1.0 );
  92. cmDspInst_t* cost_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, 0.001, 1.0 );
  93. // Measurement -> parameter mappers
  94. cmDspInst_t* even_rt = cmDspSysAllocInst(h, "Router", NULL, 2, measRtrChCnt, measRtrChCnt-1 );
  95. cmDspInst_t* dynm_rt = cmDspSysAllocInst(h, "Router", NULL, 2, measRtrChCnt, measRtrChCnt-1 );
  96. cmDspInst_t* tmpo_rt = cmDspSysAllocInst(h, "Router", NULL, 2, measRtrChCnt, measRtrChCnt-1 );
  97. cmDspInst_t* cost_rt = cmDspSysAllocInst(h, "Router", NULL, 2, measRtrChCnt, measRtrChCnt-1 );
  98. // Scale/ranges applied to incoming measurements.
  99. cmDspInst_t* cel_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, 0.0, 100.0 );
  100. cmDspInst_t* exp_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0,-10.0, 10.0 );
  101. cmDspInst_t* mix_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, 0.01, 1.0 );
  102. cmDspInst_t* thr_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, 0.01, 100.0 );
  103. cmDspInst_t* upr_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, -1.0, 5.0 );
  104. cmDspInst_t* lwr_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, -5.0, 5.0 );
  105. //cmDspInst_t* off_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, 0.0, 100.0 );
  106. cmDspInst_t* wet_sr = cmDspSysAllocInst(h, "ScaleRange", NULL, 4, 0.0, 1.0, 0.0, 1.0 );
  107. // Parameter-> kr routers (routers used to cross-fade between the two kr units)
  108. unsigned paramRtChCnt = 2;
  109. cmDspInst_t* wnd_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  110. cmDspInst_t* hop_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  111. cmDspInst_t* cel_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  112. cmDspInst_t* exp_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  113. cmDspInst_t* mix_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  114. cmDspInst_t* thr_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  115. cmDspInst_t* upr_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  116. cmDspInst_t* lwr_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  117. cmDspInst_t* wet_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  118. // Audio processors
  119. cmDspInst_t* kr0 = cmDspSysAllocInst(h, "Kr2", NULL, 2, krWndSmpCnt, krHopFact );
  120. cmDspInst_t* kr1 = cmDspSysAllocInst(h, "Kr2", NULL, 2, krWndSmpCnt, krHopFact );
  121. cmDspInst_t* xfad = cmDspSysAllocInst(h, "Xfader", NULL, 3, xfadeChCnt, xfadeMs, xfadeInitFl );
  122. cmDspInst_t* mix = cmDspSysAllocInst(h, "AMix", NULL, 3, xfadeChCnt, mixGain, mixGain );
  123. cmDspInst_t* cmp = cmDspSysAllocInst(h, "Compressor", NULL, 8, cmpBypassFl, cmpThreshDb, cmpRatio_num, cmpAtkMs, cmpRlsMs, cmpMakeup, cmpWndMs, cmpWndMaxMs );
  124. // Internal audio connections
  125. cmDspSysConnectAudio(h, kr0, "out", xfad, "in-0");
  126. cmDspSysConnectAudio(h, kr1, "out", xfad, "in-1");
  127. cmDspSysConnectAudio(h, xfad, "out-0", mix, "in-0");
  128. cmDspSysConnectAudio(h, xfad, "out-1", mix, "in-1");
  129. cmDspSysConnectAudio(h, mix, "out", cmp, "in" );
  130. // active channel <-> cross-fade connections
  131. cmDspSysInstallCb(h, achan, "reset", xfad, "reset", NULL);
  132. cmDspSysInstallCb(h, achan, "gate-0", xfad, "gate-0", NULL );
  133. cmDspSysInstallCb(h, achan, "gate-1", xfad, "gate-1", NULL );
  134. cmDspSysInstallCb(h, xfad, "state-0", achan, "dis-0", NULL );
  135. cmDspSysInstallCb(h, xfad, "state-1", achan, "dis-1", NULL );
  136. // Measurement Number Controls
  137. cmDspInst_t* val_dynm_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Dynm Meas"), 0.0, 10.0, 1.0, 1.0);
  138. cmDspInst_t* min_dynm_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min In Dyn"), 0.0, 10.0, 1.0, 0.0);
  139. cmDspInst_t* max_dynm_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max In Dyn"), 0.0, 10.0, 1.0, 4.0);
  140. cmDspInst_t* dynm_map_menu = cmDspSysAllocMsgListP(h,preGrpSymId, NULL, lbl("DynSel 0"), NULL, "measMenu", scaleRangeDfltSelId);
  141. cmDspInst_t* val_even_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Even Meas"), 0.0, 3.0, 0.001, 0.5);
  142. cmDspInst_t* min_even_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min In Even"), 0.0, 1.0, 0.001, 0.0);
  143. cmDspInst_t* max_even_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max In Even"), 0.0, 3.0, 0.001, 1.0);
  144. cmDspInst_t* even_map_menu = cmDspSysAllocMsgListP( h,preGrpSymId, NULL, lbl("EvenSel"), NULL, "measMenu", 4);
  145. cmDspSysNewColumn(h,0);
  146. cmDspInst_t* val_tmpo_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Tempo Meas"), 0.0, 200.0, 1.0, 100.0);
  147. cmDspInst_t* min_tmpo_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min In Tempo"), 0.0, 200.0, 1.0, 80.0);
  148. cmDspInst_t* max_tmpo_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max In Tempo"), 0.0, 200.0, 1.0, 120.0);
  149. cmDspInst_t* tmpo_map_menu = cmDspSysAllocMsgListP( h,preGrpSymId, NULL, lbl("TempoSel"), NULL, "measMenu", scaleRangeDfltSelId);
  150. cmDspInst_t* val_cost_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Cost Meas"), 0.0, 1.0, 0.01, 0.5);
  151. cmDspInst_t* min_cost_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min In Cost"), 0.0, 1.0, 0.01, 0.0);
  152. cmDspInst_t* max_cost_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max In Cost"), 0.0, 1.0, 0.01, 1.0);
  153. cmDspInst_t* cost_map_menu = cmDspSysAllocMsgListP( h,preGrpSymId, NULL, lbl("CostSel"), NULL, "measMenu", scaleRangeDfltSelId);
  154. cmDspSysInstallCb(h, val_dynm_ctl, "val", dynm_sr, "val_in", NULL );
  155. cmDspSysInstallCb(h, min_dynm_ctl, "val", dynm_sr, "min_in", NULL );
  156. cmDspSysInstallCb(h, max_dynm_ctl, "val", dynm_sr, "max_in", NULL );
  157. cmDspSysInstallCb(h, dynm_map_menu,"out", dynm_rt, "sel", NULL );
  158. cmDspSysInstallCb(h, dynm_sr, "val_out", dynm_rt, "f-in", NULL );
  159. cmDspSysInstallCb(h, val_even_ctl, "val", even_sr, "val_in", NULL );
  160. cmDspSysInstallCb(h, min_even_ctl, "val", even_sr, "min_in", NULL );
  161. cmDspSysInstallCb(h, max_even_ctl, "val", even_sr, "max_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, val_tmpo_ctl, "val", tmpo_sr, "val_in", NULL );
  165. cmDspSysInstallCb(h, min_tmpo_ctl, "val", tmpo_sr, "min_in", NULL );
  166. cmDspSysInstallCb(h, max_tmpo_ctl, "val", tmpo_sr, "max_in", NULL );
  167. cmDspSysInstallCb(h, tmpo_map_menu,"out", tmpo_rt, "sel", NULL );
  168. cmDspSysInstallCb(h, tmpo_sr, "val_out", tmpo_rt, "f-in", NULL );
  169. cmDspSysInstallCb(h, val_cost_ctl, "val", cost_sr, "val_in", NULL );
  170. cmDspSysInstallCb(h, min_cost_ctl, "val", cost_sr, "min_in", NULL );
  171. cmDspSysInstallCb(h, max_cost_ctl, "val", cost_sr, "max_in", NULL );
  172. cmDspSysInstallCb(h, cost_map_menu,"out", cost_rt, "sel", NULL );
  173. cmDspSysInstallCb(h, cost_sr, "val_out", cost_rt, "f-in", NULL );
  174. cmDspSysNewColumn(h,0);
  175. cmDspInst_t* min_cel_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min Ceil"), 0.0,100.0, 0.1, 10.0);
  176. cmDspInst_t* max_cel_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max Ceil"), 0.0,100.0, 0.1, 50.0);
  177. cmDspInst_t* min_exp_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min Exp"), -10.0, 10.0, 0.01, 1.0);
  178. cmDspInst_t* max_exp_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max Exp"), -10.0, 10.0, 0.01, 4.0);
  179. cmDspInst_t* min_mix_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min Mix"), 0.0, 1.0, 0.01, 0.0);
  180. cmDspInst_t* max_mix_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max Mix"), 0.0, 1.0, 0.01, 1.0);
  181. cmDspInst_t* min_thr_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min Thresh"), 0.0,100.0, 1.0, 30.0);
  182. cmDspInst_t* max_thr_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max Thresh"), 0.0,100.0, 1.0, 80.0);
  183. cmDspInst_t* min_upr_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min Upr"), -1.0, 1.0, 0.001, -0.5);
  184. cmDspInst_t* max_upr_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max Upr"), -1.0, 1.0, 0.001, 0.5);
  185. cmDspInst_t* min_lwr_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min Lwr"), 0.0, -1.0, 5.0, 1.0);
  186. cmDspInst_t* max_lwr_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max Lwr"), 0.0, -1.0, 5.0, 3.0);
  187. cmDspInst_t* min_off_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min Off"), 0.0, 50.0, 0.1, 30.0);
  188. cmDspInst_t* max_off_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max Off"), 0.0, 50.0, 0.1, 30.0);
  189. cmDspInst_t* min_wet_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Min Wet"), 0.0, 1.0, 0.01, 0.0);
  190. cmDspInst_t* max_wet_ctl = cmDspSysAllocScalarP( h,preGrpSymId, NULL, lbl("Max Wet"), 0.0, 1.0, 0.01, 1.0);
  191. // Parameter number controls
  192. cmDspSysNewColumn(h,0);
  193. cmDspInst_t* wnd_ctl = cmDspSysAllocMsgListP(h,preGrpSymId,NULL, lbl("WndSmpCnt"), NULL, "wndSmpCnt", 2);
  194. cmDspInst_t* hop_ctl = cmDspSysAllocMsgListP(h,preGrpSymId,NULL, lbl("HopFact"), NULL, "hopFact", 2);
  195. cmDspInst_t* cel_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Ceiling"), 0.0, 100.0, 0.1, 30.0 );
  196. cmDspInst_t* exp_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Expo"), -10.0, 10.0, 0.01, 2.0 );
  197. cmDspInst_t* mix_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Mix"), 0.0, 1.0, 0.01, 0.0 );
  198. cmDspInst_t* thr_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Threshold"), 0.0, 100.0, 1.0, 60.0 );
  199. cmDspInst_t* upr_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Upr slope"), 0.0, 10.0, 0.01, 0.0 );
  200. cmDspInst_t* lwr_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Lwr slope"), 0.3, 10.0, 0.01, 2.0 );
  201. cmDspInst_t* wet_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Wet Dry"), 0.0, 1.0, 0.001, 1.0 );
  202. cmDspSysInstallCb(h, wnd_ctl, "out", wnd_rt, "f-in", NULL );
  203. cmDspSysInstallCb(h, achan, "ch", wnd_rt, "sel", NULL ); // ach->rt sel
  204. cmDspSysInstallCb(h, wnd_rt, "f-out-0", kr0, "wndn", NULL ); // wndn->kr
  205. cmDspSysInstallCb(h, wnd_rt, "f-out-1", kr1, "wndn", NULL ); // wndn->kr
  206. cmDspSysInstallCb(h, hop_ctl, "out", hop_rt, "f-in", NULL );
  207. cmDspSysInstallCb(h, achan, "ch", hop_rt, "sel", NULL ); // ach->rt sel
  208. cmDspSysInstallCb(h, hop_rt, "f-out-0", kr0, "hopf", NULL ); // hopf->kr
  209. cmDspSysInstallCb(h, hop_rt, "f-out-1", kr1, "hopf", NULL ); // hopf->kr
  210. cmDspSysInstallCb(h, min_thr_ctl, "val", thr_sr, "min_out", NULL );
  211. cmDspSysInstallCb(h, max_thr_ctl, "val", thr_sr, "max_out", NULL );
  212. cmDspSysInstallCb(h, even_rt, "f-out-0", thr_sr, "val_in", NULL );
  213. cmDspSysInstallCb(h, dynm_rt, "f-out-0", thr_sr, "val_in", NULL );
  214. cmDspSysInstallCb(h, tmpo_rt, "f-out-0", thr_sr, "val_in", NULL );
  215. cmDspSysInstallCb(h, cost_rt, "f-out-0", thr_sr, "val_in", NULL );
  216. cmDspSysInstallCb(h, thr_sr, "val_out", thr_ctl,"val", NULL );
  217. cmDspSysInstallCb(h, thr_ctl, "val", thr_rt, "f-in", NULL );
  218. cmDspSysInstallCb(h, achan, "ch", thr_rt, "sel", NULL ); // ach->rt sel
  219. cmDspSysInstallCb(h, thr_rt, "f-out-0", kr0, "thrh", NULL ); // thr->kr
  220. cmDspSysInstallCb(h, thr_rt, "f-out-1", kr1, "thrh", NULL ); // thr->kr
  221. cmDspSysInstallCb(h, min_upr_ctl, "val", upr_sr, "min_out", NULL );
  222. cmDspSysInstallCb(h, max_upr_ctl, "val", upr_sr, "max_out", NULL );
  223. cmDspSysInstallCb(h, even_rt, "f-out-1", upr_sr, "val_in", NULL );
  224. cmDspSysInstallCb(h, dynm_rt, "f-out-1", upr_sr, "val_in", NULL );
  225. cmDspSysInstallCb(h, tmpo_rt, "f-out-1", upr_sr, "val_in", NULL );
  226. cmDspSysInstallCb(h, cost_rt, "f-out-1", upr_sr, "val_in", NULL );
  227. cmDspSysInstallCb(h, upr_sr, "val_out", upr_ctl,"val", NULL );
  228. cmDspSysInstallCb(h, upr_ctl, "val", upr_rt, "f-in", NULL );
  229. cmDspSysInstallCb(h, achan, "ch", upr_rt, "sel", NULL ); // ach->rt sel
  230. cmDspSysInstallCb(h, upr_rt, "f-out-0", kr0, "uprs", NULL ); // upr->kr
  231. cmDspSysInstallCb(h, upr_rt, "f-out-1", kr1, "uprs", NULL ); // upr->kr
  232. cmDspSysInstallCb(h, min_lwr_ctl, "val", lwr_sr, "min_out", NULL );
  233. cmDspSysInstallCb(h, max_lwr_ctl, "val", lwr_sr, "max_out", NULL );
  234. cmDspSysInstallCb(h, even_rt, "f-out-2", lwr_sr, "val_in", NULL );
  235. cmDspSysInstallCb(h, dynm_rt, "f-out-2", lwr_sr, "val_in", NULL );
  236. cmDspSysInstallCb(h, tmpo_rt, "f-out-2", lwr_sr, "val_in", NULL );
  237. cmDspSysInstallCb(h, cost_rt, "f-out-2", lwr_sr, "val_in", NULL );
  238. cmDspSysInstallCb(h, lwr_sr, "val_out", lwr_ctl,"val", NULL );
  239. cmDspSysInstallCb(h, lwr_ctl, "val", lwr_rt, "f-in", NULL );
  240. cmDspSysInstallCb(h, achan, "ch", lwr_rt, "sel", NULL ); // ach->rt sel
  241. cmDspSysInstallCb(h, lwr_rt, "f-out-0", kr0, "lwrs", NULL ); // lwr->kr
  242. cmDspSysInstallCb(h, lwr_rt, "f-out-1", kr1, "lwrs", NULL ); // lwr->kr
  243. cmDspSysInstallCb(h, min_wet_ctl, "val", wet_sr, "min_out", NULL );
  244. cmDspSysInstallCb(h, max_wet_ctl, "val", wet_sr, "max_out", NULL );
  245. cmDspSysInstallCb(h, even_rt, "f-out-3", wet_sr, "val_in", NULL );
  246. cmDspSysInstallCb(h, dynm_rt, "f-out-3", wet_sr, "val_in", NULL );
  247. cmDspSysInstallCb(h, tmpo_rt, "f-out-3", wet_sr, "val_in", NULL );
  248. cmDspSysInstallCb(h, cost_rt, "f-out-3", wet_sr, "val_in", NULL );
  249. cmDspSysInstallCb(h, wet_sr, "val_out", wet_ctl,"val", NULL );
  250. cmDspSysInstallCb(h, wet_ctl, "val", wet_rt, "f-in", NULL );
  251. cmDspSysInstallCb(h, achan, "ch", wet_rt, "sel", NULL ); // ach->rt sel
  252. cmDspSysInstallCb(h, wet_rt, "f-out-0", kr0, "wet", NULL ); // wet->kr
  253. cmDspSysInstallCb(h, wet_rt, "f-out-1", kr1, "wet", NULL ); // wet->kr
  254. cmDspSysInstallCb(h, wet_rt, "f-out-0", p_wet, "in", NULL );
  255. cmDspSysInstallCb(h, wet_rt, "f-out-1", p_wet, "in", NULL );
  256. cmDspSysInstallCb(h, min_cel_ctl, "val", cel_sr, "min_out", NULL );
  257. cmDspSysInstallCb(h, max_cel_ctl, "val", cel_sr, "max_out", NULL );
  258. cmDspSysInstallCb(h, even_rt, "f-out-4", cel_sr, "val_in", NULL );
  259. cmDspSysInstallCb(h, dynm_rt, "f-out-4", cel_sr, "val_in", NULL );
  260. cmDspSysInstallCb(h, tmpo_rt, "f-out-4", cel_sr, "val_in", NULL );
  261. cmDspSysInstallCb(h, cost_rt, "f-out-4", cel_sr, "val_in", NULL );
  262. cmDspSysInstallCb(h, cel_sr, "val_out", cel_ctl,"val", NULL );
  263. cmDspSysInstallCb(h, cel_ctl, "val", cel_rt, "f-in", NULL );
  264. cmDspSysInstallCb(h, achan, "ch", cel_rt, "sel", NULL ); // ach->rt sel
  265. cmDspSysInstallCb(h, cel_rt, "f-out-0", kr0, "ceil", NULL ); // cel->kr
  266. cmDspSysInstallCb(h, cel_rt, "f-out-1", kr1, "ceil", NULL ); // cel->kr
  267. cmDspSysInstallCb(h, min_exp_ctl, "val", exp_sr, "min_out", NULL );
  268. cmDspSysInstallCb(h, max_exp_ctl, "val", exp_sr, "max_out", NULL );
  269. cmDspSysInstallCb(h, even_rt, "f-out-5", exp_sr, "val_in", NULL );
  270. cmDspSysInstallCb(h, dynm_rt, "f-out-5", exp_sr, "val_in", NULL );
  271. cmDspSysInstallCb(h, tmpo_rt, "f-out-5", exp_sr, "val_in", NULL );
  272. cmDspSysInstallCb(h, cost_rt, "f-out-5", exp_sr, "val_in", NULL );
  273. cmDspSysInstallCb(h, exp_sr, "val_out", exp_ctl,"val", NULL );
  274. cmDspSysInstallCb(h, exp_ctl, "val", exp_rt, "f-in", NULL );
  275. cmDspSysInstallCb(h, achan, "ch", exp_rt, "sel", NULL ); // ach->rt sel
  276. cmDspSysInstallCb(h, exp_rt, "f-out-0", kr0, "expo", NULL ); // exp->kr
  277. cmDspSysInstallCb(h, exp_rt, "f-out-1", kr1, "expo", NULL ); // exp->kr
  278. cmDspSysInstallCb(h, min_mix_ctl, "val", mix_sr, "min_out", NULL );
  279. cmDspSysInstallCb(h, max_mix_ctl, "val", mix_sr, "max_out", NULL );
  280. cmDspSysInstallCb(h, even_rt, "f-out-6", mix_sr, "val_in", NULL );
  281. cmDspSysInstallCb(h, dynm_rt, "f-out-6", mix_sr, "val_in", NULL );
  282. cmDspSysInstallCb(h, tmpo_rt, "f-out-6", mix_sr, "val_in", NULL );
  283. cmDspSysInstallCb(h, cost_rt, "f-out-6", mix_sr, "val_in", NULL );
  284. cmDspSysInstallCb(h, mix_sr, "val_out", mix_ctl,"val", NULL );
  285. cmDspSysInstallCb(h, mix_ctl, "val", mix_rt, "f-in", NULL );
  286. cmDspSysInstallCb(h, achan, "ch", mix_rt, "sel", NULL ); // ach->rt sel
  287. cmDspSysInstallCb(h, mix_rt, "f-out-0", kr0, "mix", NULL ); // mix->kr
  288. cmDspSysInstallCb(h, mix_rt, "f-out-1", kr1, "mix", NULL ); // mix->kr
  289. cmDspSysNewColumn(h,0);
  290. cmDspInst_t* cmp_byp = cmDspSysAllocCheckP( h, cmpPreGrpSymId, NULL, lbl("Bypass"), 1.0 );
  291. cmDspInst_t* cmp_igain = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("In Gain"), 0.0, 10.0, 0.1, cmpInGain);
  292. cmDspInst_t* cmp_thr = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("ThreshDb"), -100.0, 0.0, 0.1, cmpThreshDb);
  293. cmDspInst_t* cmp_rat = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("Ratio"), 0.1, 100, 0.1, cmpRatio_num);
  294. cmDspInst_t* cmp_atk = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("Atk Ms"), 0.0, 1000.0, 0.1, cmpAtkMs);
  295. cmDspInst_t* cmp_rls = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("Rls Ms"), 0.0, 1000.0, 0.1, cmpRlsMs);
  296. cmDspInst_t* cmp_mkup = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("Makeup"), 0.0, 10.0, 0.01, cmpMakeup);
  297. cmDspInst_t* cmp_wnd = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("Wnd Ms"), 1.0, cmpWndMaxMs, 1.0, cmpWndMs );
  298. cmDspInst_t* cmp_mtr = cmDspSysAllocInst(h,"Meter",lbl("Env"), 3, 0.0, 0.0, 1.0);
  299. cmDspSysInstallCb(h, cmp_byp, "out", cmp, "bypass", NULL );
  300. cmDspSysInstallCb(h, cmp_igain,"val", cmp, "igain", NULL );
  301. cmDspSysInstallCb(h, cmp_thr, "val", cmp, "thr", NULL );
  302. cmDspSysInstallCb(h, cmp_rat, "val", cmp, "ratio", NULL );
  303. cmDspSysInstallCb(h, cmp_atk, "val", cmp, "atk", NULL );
  304. cmDspSysInstallCb(h, cmp_rls, "val", cmp, "rls", NULL );
  305. cmDspSysInstallCb(h, cmp_mkup, "val", cmp, "ogain", NULL );
  306. cmDspSysInstallCb(h, cmp_wnd, "val", cmp, "wnd", NULL );
  307. cmDspSysInstallCb(h, cmp, "env", cmp_mtr, "in", NULL );
  308. cmDspSysInstallCb(h, modp, mlbl("cbyp"), cmp_byp, "in", NULL );
  309. cmDspSysInstallCb(h, modp, mlbl("cigain"), cmp_igain,"val", NULL );
  310. cmDspSysInstallCb(h, modp, mlbl("cthrsh"), cmp_thr, "val", NULL );
  311. cmDspSysInstallCb(h, modp, mlbl("cratio"), cmp_rat, "val", NULL );
  312. cmDspSysInstallCb(h, modp, mlbl("catkms"), cmp_atk, "val", NULL );
  313. cmDspSysInstallCb(h, modp, mlbl("crlsms"), cmp_rls, "val", NULL );
  314. cmDspSysInstallCb(h, modp, mlbl("cmakeup"), cmp_mkup, "val", NULL );
  315. cmDspSysInstallCb(h, modp, mlbl("cwndms"), cmp_wnd, "val", NULL );
  316. //
  317. cmDspInst_t* xfadMs = cmDspSysAllocInst(h,"Scalar", lbl("Xfade Ms"), 5, kNumberDuiId, 0.0, 1000.0,0.01, 50.0 );
  318. cmDspSysInstallCb(h, xfadMs, "val", xfad, "ms", NULL );
  319. cmDspSysInstallCb(h, modp, mlbl("xfad"), xfadMs, "val", NULL);
  320. cmDspInst_t* sw_btn = cmDspSysAllocButton( h, lbl("switch"), 0);
  321. cmDspSysInstallCb( h, sw_btn, "sym", achan, "trig", NULL );
  322. // TODO: FIX THIS: can't send window length (e.g. 1024,2048, ... ) to a 'MsgList' with 4 elements
  323. // since it expects an index betweeen 0 and 3. CRASH!
  324. //cmDspSysInstallCb(h, modp, mlbl("win"), wnd_ctl, "sel", NULL );
  325. cmDspSysInstallCb(h, modp, mlbl("hop"), hop_ctl, "sel", NULL );
  326. cmDspSysInstallCb(h, modp, mlbl("ceil"), cel_ctl, "val", NULL );
  327. cmDspSysInstallCb(h, modp, mlbl("expo"), exp_ctl, "val", NULL );
  328. cmDspSysInstallCb(h, modp, mlbl("mix"), mix_ctl, "val", NULL );
  329. cmDspSysInstallCb(h, modp, mlbl("thr"), thr_ctl, "val", NULL );
  330. cmDspSysInstallCb(h, modp, mlbl("upr"), upr_ctl, "val", NULL );
  331. cmDspSysInstallCb(h, modp, mlbl("lwr"), lwr_ctl, "val", NULL );
  332. //cmDspSysInstallCb(h, modp, mlbl("wet"), wet_ctl, "val", NULL );
  333. cmDspSysInstallCb(h, modp, mlbl("minc"), min_cel_ctl, "val", NULL );
  334. cmDspSysInstallCb(h, modp, mlbl("maxc"), max_cel_ctl, "val", NULL );
  335. cmDspSysInstallCb(h, modp, mlbl("mine"), min_exp_ctl, "val", NULL );
  336. cmDspSysInstallCb(h, modp, mlbl("maxe"), max_exp_ctl, "val", NULL );
  337. cmDspSysInstallCb(h, modp, mlbl("minm"), min_mix_ctl, "val", NULL );
  338. cmDspSysInstallCb(h, modp, mlbl("maxm"), max_mix_ctl, "val", NULL );
  339. cmDspSysInstallCb(h, modp, mlbl("mint"), min_thr_ctl, "val", NULL );
  340. cmDspSysInstallCb(h, modp, mlbl("maxt"), max_thr_ctl, "val", NULL );
  341. cmDspSysInstallCb(h, modp, mlbl("minu"), min_upr_ctl, "val", NULL );
  342. cmDspSysInstallCb(h, modp, mlbl("maxu"), max_upr_ctl, "val", NULL );
  343. cmDspSysInstallCb(h, modp, mlbl("minl"), min_lwr_ctl, "val", NULL );
  344. cmDspSysInstallCb(h, modp, mlbl("maxl"), max_lwr_ctl, "val", NULL );
  345. cmDspSysInstallCb(h, modp, mlbl("mino"), min_off_ctl, "val", NULL );
  346. cmDspSysInstallCb(h, modp, mlbl("maxo"), max_off_ctl, "val", NULL );
  347. //cmDspSysInstallCb(h, modp, mlbl("sw"), achan, "trig", NULL ); // See also: amp.sfloc->achan.trig
  348. c->achan = achan;
  349. c->kr0 = kr0;
  350. c->kr1 = kr1;
  351. c->cmp = cmp;
  352. c->even_ctl = val_even_ctl;
  353. }
  354. #endif
  355. //=======================================================================================================================
  356. //=======================================================================================================================
  357. // KR2 Modeless Transform based on cmDspKr2 and cmSpecDist2
  358. //=======================================================================================================================
  359. //=======================================================================================================================
  360. /*
  361. #ifdef KR2
  362. void _cmDspSys_TlXformChain( cmDspSysH_t h, cmDspTlXform_t* c, unsigned preGrpSymId, unsigned cmpPreGrpSymId, cmDspInst_t* modp, unsigned ach, unsigned mch )
  363. {
  364. unsigned measRtrChCnt = 6; // note: router channel 6 is not connected
  365. int krWndSmpCnt = 2048;
  366. int krHopFact = 4;
  367. unsigned xfadeChCnt = 2;
  368. double xfadeMs = 50;
  369. bool xfadeInitFl = true;
  370. double mixGain = 1.0;
  371. bool cmpBypassFl = false;
  372. double cmpInGain = 3.0;
  373. double cmpThreshDb = -40.0;
  374. double cmpRatio_num = 5.0;
  375. double cmpAtkMs = 20.0;
  376. double cmpRlsMs = 100.0;
  377. double cmpMakeup = 1.0;
  378. double cmpWndMaxMs = 1000.0;
  379. double cmpWndMs = 200.0;
  380. cmDspInst_t* achan = cmDspSysAllocInst(h, "AvailCh", NULL, 1, xfadeChCnt );
  381. // Parameter-> kr routers (routers used to cross-fade between the two kr units)
  382. unsigned paramRtChCnt = 2;
  383. cmDspInst_t* wnd_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  384. cmDspInst_t* hop_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  385. cmDspInst_t* ceil_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  386. cmDspInst_t* expo_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  387. cmDspInst_t* mix_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  388. cmDspInst_t* thr_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  389. cmDspInst_t* upr_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  390. cmDspInst_t* lwr_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  391. cmDspInst_t* wet_rt = cmDspSysAllocInst(h, "Router", NULL, 2, paramRtChCnt, paramRtChCnt-1 );
  392. // Audio processors
  393. cmDspInst_t* kr0 = cmDspSysAllocInst(h, "Kr2", NULL, 2, krWndSmpCnt, krHopFact );
  394. cmDspInst_t* kr1 = cmDspSysAllocInst(h, "Kr2", NULL, 2, krWndSmpCnt, krHopFact );
  395. cmDspInst_t* xfad = cmDspSysAllocInst(h, "Xfader", NULL, 3, xfadeChCnt, xfadeMs, xfadeInitFl );
  396. cmDspInst_t* mix = cmDspSysAllocInst(h, "AMix", NULL, 3, xfadeChCnt, mixGain, mixGain );
  397. cmDspInst_t* cmp = cmDspSysAllocInst(h, "Compressor", NULL, 8, cmpBypassFl, cmpThreshDb, cmpRatio_num, cmpAtkMs, cmpRlsMs, cmpMakeup, cmpWndMs, cmpWndMaxMs );
  398. // Internal audio connections
  399. cmDspSysConnectAudio(h, kr0, "out", xfad, "in-0");
  400. cmDspSysConnectAudio(h, kr1, "out", xfad, "in-1");
  401. cmDspSysConnectAudio(h, xfad, "out-0", mix, "in-0");
  402. cmDspSysConnectAudio(h, xfad, "out-1", mix, "in-1");
  403. cmDspSysConnectAudio(h, mix, "out", cmp, "in" );
  404. // active channel <-> cross-fade connections
  405. cmDspSysInstallCb(h, achan, "reset", xfad, "reset", NULL);
  406. cmDspSysInstallCb(h, achan, "gate-0", xfad, "gate-0", NULL );
  407. cmDspSysInstallCb(h, achan, "gate-1", xfad, "gate-1", NULL );
  408. cmDspSysInstallCb(h, xfad, "state-0", achan, "dis-0", NULL );
  409. cmDspSysInstallCb(h, xfad, "state-1", achan, "dis-1", NULL );
  410. // Parameter number controls
  411. cmDspInst_t* wnd_ctl = cmDspSysAllocMsgListP(h,preGrpSymId,NULL, lbl("WndSmpCnt"), NULL, "wndSmpCnt", 2);
  412. cmDspInst_t* hop_ctl = cmDspSysAllocMsgListP(h,preGrpSymId,NULL, lbl("HopFact"), NULL, "hopFact", 2);
  413. cmDspInst_t* ceil_ctl= cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Ceiling"), 0.0, 100.0, 0.1, 30.0 );
  414. cmDspInst_t* expo_ctl= cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Expo"), -10.0, 10.0, 0.01, 2.0 );
  415. cmDspInst_t* mix_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Mix"), 0.0, 1.0, 0.01, 0.0 );
  416. cmDspInst_t* thr_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Threshold"), 0.0, 100.0, 0.1, 60.0 );
  417. cmDspInst_t* upr_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Upr slope"), -10.0, 10.0, 0.01, 0.0 );
  418. cmDspInst_t* lwr_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Lwr slope"), -10.0, 10.0, 0.01, 2.0 );
  419. cmDspInst_t* wet_ctl = cmDspSysAllocScalarP( h,preGrpSymId,NULL, lbl("Wet Dry"), 0.0, 1.0, 0.001, 1.0 );
  420. cmDspSysInstallCb(h, wnd_ctl, "out", wnd_rt, "f-in", NULL );
  421. cmDspSysInstallCb(h, achan, "ch", wnd_rt, "sel", NULL ); // ach->rt sel
  422. cmDspSysInstallCb(h, wnd_rt, "f-out-0", kr0, "wndn", NULL ); // wndn->kr
  423. cmDspSysInstallCb(h, wnd_rt, "f-out-1", kr1, "wndn", NULL ); // wndn->kr
  424. cmDspSysInstallCb(h, hop_ctl, "out", hop_rt, "f-in", NULL );
  425. cmDspSysInstallCb(h, achan, "ch", hop_rt, "sel", NULL ); // ach->rt sel
  426. cmDspSysInstallCb(h, hop_rt, "f-out-0", kr0, "hopf", NULL ); // hopf->kr
  427. cmDspSysInstallCb(h, hop_rt, "f-out-1", kr1, "hopf", NULL ); // hopf->kr
  428. cmDspSysInstallCb(h, ceil_ctl, "val", ceil_rt, "f-in", NULL );
  429. cmDspSysInstallCb(h, achan, "ch", ceil_rt, "sel", NULL ); // ach->rt sel
  430. cmDspSysInstallCb(h, ceil_rt, "f-out-0", kr0, "ceil", NULL ); // ceil->kr
  431. cmDspSysInstallCb(h, ceil_rt, "f-out-1", kr1, "ceil", NULL ); // ceil->kr
  432. cmDspSysInstallCb(h, expo_ctl, "val", expo_rt, "f-in", NULL );
  433. cmDspSysInstallCb(h, achan, "ch", expo_rt, "sel", NULL ); // ach->rt sel
  434. cmDspSysInstallCb(h, expo_rt, "f-out-0", kr0, "expo", NULL ); // expo->kr
  435. cmDspSysInstallCb(h, expo_rt, "f-out-1", kr1, "expo", NULL ); // expo->kr
  436. cmDspSysInstallCb(h, mix_ctl, "val", mix_rt, "f-in", NULL );
  437. cmDspSysInstallCb(h, achan, "ch", mix_rt, "sel", NULL ); // ach->rt sel
  438. cmDspSysInstallCb(h, mix_rt, "f-out-0", kr0, "mix", NULL ); // mix->kr
  439. cmDspSysInstallCb(h, mix_rt, "f-out-1", kr1, "mix", NULL ); // mix->kr
  440. cmDspSysInstallCb(h, thr_ctl, "val", thr_rt, "f-in", NULL );
  441. cmDspSysInstallCb(h, achan, "ch", thr_rt, "sel", NULL ); // ach->rt sel
  442. cmDspSysInstallCb(h, thr_rt, "f-out-0", kr0, "thrh", NULL ); // thr->kr
  443. cmDspSysInstallCb(h, thr_rt, "f-out-1", kr1, "thrh", NULL ); // thr->kr
  444. cmDspSysInstallCb(h, upr_ctl, "val", upr_rt, "f-in", NULL );
  445. cmDspSysInstallCb(h, achan, "ch", upr_rt, "sel", NULL ); // ach->rt sel
  446. cmDspSysInstallCb(h, upr_rt, "f-out-0", kr0, "uprs", NULL ); // upr->kr
  447. cmDspSysInstallCb(h, upr_rt, "f-out-1", kr1, "uprs", NULL ); // upr->kr
  448. cmDspSysInstallCb(h, lwr_ctl, "val", lwr_rt, "f-in", NULL );
  449. cmDspSysInstallCb(h, achan, "ch", lwr_rt, "sel", NULL ); // ach->rt sel
  450. cmDspSysInstallCb(h, lwr_rt, "f-out-0", kr0, "lwrs", NULL ); // lwr->kr
  451. cmDspSysInstallCb(h, lwr_rt, "f-out-1", kr1, "lwrs", NULL ); // lwr->kr
  452. cmDspSysInstallCb(h, wet_ctl, "val", wet_rt, "f-in", NULL );
  453. cmDspSysInstallCb(h, achan, "ch", wet_rt, "sel", NULL ); // ach->rt sel
  454. cmDspSysInstallCb(h, wet_rt, "f-out-0", kr0, "wet", NULL ); // wet->kr
  455. cmDspSysInstallCb(h, wet_rt, "f-out-1", kr1, "wet", NULL ); // wet->kr
  456. cmDspSysNewColumn(h,0);
  457. cmDspInst_t* cmp_byp = cmDspSysAllocCheckP( h, cmpPreGrpSymId, NULL, lbl("Bypass"), 1.0 );
  458. cmDspInst_t* cmp_igain = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("In Gain"), 0.0, 10.0, 0.1, cmpInGain);
  459. cmDspInst_t* cmp_thr = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("ThreshDb"), -100.0, 0.0, 0.1, cmpThreshDb);
  460. cmDspInst_t* cmp_rat = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("Ratio"), 0.1, 100, 0.1, cmpRatio_num);
  461. cmDspInst_t* cmp_atk = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("Atk Ms"), 0.0, 1000.0, 0.1, cmpAtkMs);
  462. cmDspInst_t* cmp_rls = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("Rls Ms"), 0.0, 1000.0, 0.1, cmpRlsMs);
  463. cmDspInst_t* cmp_mkup = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("Makeup"), 0.0, 10.0, 0.01, cmpMakeup);
  464. cmDspInst_t* cmp_wnd = cmDspSysAllocScalarP( h, cmpPreGrpSymId, NULL, lbl("Wnd Ms"), 1.0, cmpWndMaxMs, 1.0, cmpWndMs );
  465. cmDspInst_t* cmp_mtr = cmDspSysAllocInst(h,"Meter",lbl("Env"), 3, 0.0, 0.0, 1.0);
  466. cmDspSysInstallCb(h, cmp_byp, "out", cmp, "bypass", NULL );
  467. cmDspSysInstallCb(h, cmp_igain,"val", cmp, "igain", NULL );
  468. cmDspSysInstallCb(h, cmp_thr, "val", cmp, "thr", NULL );
  469. cmDspSysInstallCb(h, cmp_rat, "val", cmp, "ratio", NULL );
  470. cmDspSysInstallCb(h, cmp_atk, "val", cmp, "atk", NULL );
  471. cmDspSysInstallCb(h, cmp_rls, "val", cmp, "rls", NULL );
  472. cmDspSysInstallCb(h, cmp_mkup, "val", cmp, "ogain", NULL );
  473. cmDspSysInstallCb(h, cmp_wnd, "val", cmp, "wnd", NULL );
  474. cmDspSysInstallCb(h, cmp, "env", cmp_mtr, "in", NULL );
  475. cmDspSysInstallCb(h, modp, mlbl("cbyp"), cmp_byp, "in", NULL );
  476. cmDspSysInstallCb(h, modp, mlbl("cigain"), cmp_igain,"val", NULL );
  477. cmDspSysInstallCb(h, modp, mlbl("cthrsh"), cmp_thr, "val", NULL );
  478. cmDspSysInstallCb(h, modp, mlbl("cratio"), cmp_rat, "val", NULL );
  479. cmDspSysInstallCb(h, modp, mlbl("catkms"), cmp_atk, "val", NULL );
  480. cmDspSysInstallCb(h, modp, mlbl("crlsms"), cmp_rls, "val", NULL );
  481. cmDspSysInstallCb(h, modp, mlbl("cmakeup"), cmp_mkup, "val", NULL );
  482. cmDspSysInstallCb(h, modp, mlbl("cwndms"), cmp_wnd, "val", NULL );
  483. //
  484. cmDspInst_t* xfadMs = cmDspSysAllocInst(h,"Scalar", lbl("Xfade Ms"), 5, kNumberDuiId, 0.0, 1000.0,0.01, 50.0 );
  485. cmDspSysInstallCb(h, xfadMs, "val", xfad, "ms", NULL );
  486. cmDspSysInstallCb(h, modp, mlbl("xfad"), xfadMs, "val", NULL);
  487. cmDspInst_t* sw_btn = cmDspSysAllocButton( h, lbl("switch"), 0);
  488. cmDspSysInstallCb( h, sw_btn, "sym", achan, "trig", NULL );
  489. cmDspSysInstallCb(h, modp, mlbl("win"), wnd_ctl, "sel", NULL );
  490. cmDspSysInstallCb(h, modp, mlbl("hop"), hop_ctl, "sel", NULL );
  491. cmDspSysInstallCb(h, modp, mlbl("ceil"), ceil_ctl, "val", NULL );
  492. cmDspSysInstallCb(h, modp, mlbl("expo"), expo_ctl, "val", NULL );
  493. cmDspSysInstallCb(h, modp, mlbl("mix"), mix_ctl, "val", NULL );
  494. cmDspSysInstallCb(h, modp, mlbl("thr"), thr_ctl, "val", NULL );
  495. cmDspSysInstallCb(h, modp, mlbl("upr"), upr_ctl, "val", NULL );
  496. cmDspSysInstallCb(h, modp, mlbl("lwr"), lwr_ctl, "val", NULL );
  497. cmDspSysInstallCb(h, modp, mlbl("wet"), wet_ctl, "val", NULL );
  498. cmDspSysInstallCb(h, modp, mlbl("sw"), achan, "trig", NULL ); // See also: amp.sfloc->achan.trig
  499. c->achan = achan;
  500. c->kr0 = kr0;
  501. c->kr1 = kr1;
  502. c->cmp = cmp;
  503. }
  504. #endif
  505. */