libcm is a C development framework with an emphasis on audio signal processing applications.
您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

cmDspPgmKr.c 20KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412
  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* audPath;
  36. const cmChar_t* scFn;
  37. const cmChar_t* modFn;
  38. } krRsrc_t;
  39. cmDspRC_t krLoadRsrc(cmDspSysH_t h, cmErr_t* err, krRsrc_t* r)
  40. {
  41. cmDspRC_t rc;
  42. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  43. return rc;
  44. cmDspRsrcString(h,&r->tlFn, "timeLineFn", NULL);
  45. cmDspRsrcString(h,&r->audPath,"tlAudioFilePath", NULL);
  46. cmDspRsrcString(h,&r->scFn, "scoreFn", NULL);
  47. cmDspRsrcString(h,&r->modFn, "modFn", NULL);
  48. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  49. cmErrMsg(err,rc,"A KR DSP resource load failed.");
  50. return rc;
  51. }
  52. cmDspRC_t _cmDspSysPgm_TimeLine(cmDspSysH_t h, void** userPtrPtr )
  53. {
  54. cmDspRC_t rc = kOkDspRC;
  55. cmCtx_t* cmCtx = cmDspSysPgmCtx(h);
  56. cmErr_t err;
  57. krRsrc_t r;
  58. unsigned wtLoopCnt = 1; // 1=play once (-1=loop forever)
  59. unsigned wtInitMode = 0; // initial wt mode is 'silence'
  60. unsigned wtSmpCnt = floor(cmDspSysSampleRate(h)); // wt length == srate
  61. int krWndSmpCnt = 2048;
  62. int krHopFact = 4;
  63. unsigned xfadOutChCnt = 2;
  64. double xfadMs = 200;
  65. bool xfadAllOnFl = true;
  66. memset(&r,0,sizeof(r));
  67. cmErrSetup(&err,&cmCtx->rpt,"Kr Timeline");
  68. if( krLoadRsrc(h,&err,&r) != kOkDspRC )
  69. return rc;
  70. cmDspInst_t* tlp = cmDspSysAllocInst(h,"TimeLine", "tl", 2, r.tlFn, r.audPath );
  71. cmDspInst_t* scp = cmDspSysAllocInst(h,"Score", "sc", 1, r.scFn );
  72. cmDspInst_t* php = cmDspSysAllocInst(h,"Phasor", NULL, 1, cmDspSysSampleRate(h) );
  73. cmDspInst_t* wtp = cmDspSysAllocInst(h,"WaveTable", NULL, 4, wtSmpCnt, wtInitMode, NULL, wtLoopCnt );
  74. cmDspInst_t* pts = cmDspSysAllocInst(h,"PortToSym", NULL, 2, "on", "off" );
  75. cmDspInst_t* mfp = cmDspSysAllocInst(h,"MidiFilePlay",NULL, 0 );
  76. cmDspInst_t* sfp = cmDspSysAllocInst(h,"ScFol", NULL, 1, r.scFn );
  77. cmDspInst_t* srp = cmDspSysAllocInst(h,"ScaleRange", NULL, 0 );
  78. cmDspInst_t* modp = cmDspSysAllocInst(h,"ScMod", NULL, 2, r.modFn, "m1" );
  79. cmDspInst_t* kr0p = cmDspSysAllocInst(h,"Kr", NULL, 2, krWndSmpCnt, krHopFact );
  80. cmDspInst_t* kr1p = cmDspSysAllocInst(h,"Kr", NULL, 2, krWndSmpCnt, krHopFact );
  81. cmDspInst_t* xfad = cmDspSysAllocInst(h,"Xfader", NULL, 3, xfadOutChCnt, xfadMs, xfadAllOnFl );
  82. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut", NULL, 1, 0 );
  83. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut", NULL, 1, 1 );
  84. //cmDspInst_t* af0p = cmDspSysAllocInst(h,"AudioFileOut",NULL, 2, "/home/kevin/temp/debug0.wav",1);
  85. cmDspSysNewPage(h,"Controls");
  86. cmDspInst_t* onb = cmDspSysAllocInst(h,"Button", "start", 2, kButtonDuiId, 1.0 );
  87. cmDspInst_t* offb = cmDspSysAllocInst(h,"Button", "stop", 2, kButtonDuiId, 1.0 );
  88. cmDspInst_t* prtb = cmDspSysAllocInst(h,"Button", "print", 2, kButtonDuiId, 1.0 );
  89. cmDspInst_t* qtb = cmDspSysAllocInst(h,"Button", "quiet", 2, kButtonDuiId, 1.0 );
  90. cmDspInst_t* prp = cmDspSysAllocInst(h,"Printer", NULL, 1, ">" );
  91. cmDspInst_t* prd = cmDspSysAllocInst(h,"Printer", NULL, 1, "DYN:" );
  92. cmDspInst_t* pre = cmDspSysAllocInst(h,"Printer", NULL, 1, "EVEN:" );
  93. cmDspInst_t* prt = cmDspSysAllocInst(h,"Printer", NULL, 1, "TEMPO:");
  94. //cmDspInst_t* prc = cmDspSysAllocInst(h,"Printer", NULL, 1, "COST:");
  95. //cmDspInst_t* prv = cmDspSysAllocInst(h,"Printer", NULL, 1, "Value:");
  96. cmDspSysNewColumn(h,0);
  97. cmDspInst_t* md0p = cmDspSysAllocInst(h,"Scalar", "Mode", 5, kNumberDuiId, 0.0, 4.0, 1.0, 1.0);
  98. cmDspInst_t* ws0p = cmDspSysAllocInst(h,"MsgList","wndSmpCnt", 3, "wndSmpCnt", NULL, 2);
  99. cmDspInst_t* hf0p = cmDspSysAllocInst(h,"MsgList","hopFact", 3, "hopFact", NULL, 2);
  100. cmDspInst_t* th0p = cmDspSysAllocInst(h,"Scalar", "threshold", 5, kNumberDuiId, 0.0, 100.0, 1.0, 60.0 );
  101. cmDspInst_t* us0p = cmDspSysAllocInst(h,"Scalar", "upr slope", 5, kNumberDuiId, 0.0, 10.0, 0.01, 0.0 );
  102. cmDspInst_t* ls0p = cmDspSysAllocInst(h,"Scalar", "lwr slope", 5, kNumberDuiId, 0.3, 10.0, 0.01, 2.0 );
  103. cmDspInst_t* of0p = cmDspSysAllocInst(h,"Scalar", "offset", 5, kNumberDuiId, 0.0, 100.0, 0.01, 30.0 );
  104. cmDspInst_t* iv0p = cmDspSysAllocInst(h,"Scalar", "invert", 5, kNumberDuiId, 0.0, 1.0, 1.0, 0.0 );
  105. cmDspInst_t* wet0 = cmDspSysAllocInst(h,"Scalar", "wet", 5, kNumberDuiId, 0.0, 1.0,0.001, 1.0 );
  106. cmDspSysNewColumn(h,0);
  107. //cmDspInst_t* al1p = cmDspSysAllocInst(h,"MsgList","audFiles", 2, "audFiles",NULL);
  108. //cmDspInst_t* fl1p = cmDspSysAllocInst(h,"MsgList","audFrags1", 2, "audFrags",NULL);
  109. //cmDspInst_t* fn1p = cmDspSysAllocInst(h,"Sprintf","filename", 1, "%s/%s_%02i.wav");
  110. cmDspInst_t* md1p = cmDspSysAllocInst(h,"Scalar", "Mode1", 5, kNumberDuiId, 0.0, 4.0, 1.0, 1.0);
  111. cmDspInst_t* ws1p = cmDspSysAllocInst(h,"MsgList","wndSmpCnt1", 3, "wndSmpCnt", NULL, 2);
  112. cmDspInst_t* hf1p = cmDspSysAllocInst(h,"MsgList","hopFact1", 3, "hopFact", NULL, 2);
  113. cmDspInst_t* th1p = cmDspSysAllocInst(h,"Scalar", "threshold1", 5, kNumberDuiId, 0.0, 100.0, 1.0, 60.0 );
  114. cmDspInst_t* us1p = cmDspSysAllocInst(h,"Scalar", "upr slope1", 5, kNumberDuiId, 0.0, 10.0, 0.01, 0.0 );
  115. cmDspInst_t* ls1p = cmDspSysAllocInst(h,"Scalar", "lwr slope1", 5, kNumberDuiId, 0.3, 10.0, 0.01, 2.0 );
  116. cmDspInst_t* of1p = cmDspSysAllocInst(h,"Scalar", "offset1", 5, kNumberDuiId, 0.0, 100.0, 0.01, 30.0 );
  117. cmDspInst_t* iv1p = cmDspSysAllocInst(h,"Scalar", "invert1", 5, kNumberDuiId, 0.0, 1.0, 1.0, 0.0 );
  118. cmDspInst_t* wet1 = cmDspSysAllocInst(h,"Scalar", "wet1", 5, kNumberDuiId, 0.0, 1.0,0.001, 1.0 );
  119. cmDspSysNewColumn(h,0);
  120. cmDspInst_t* ogain = cmDspSysAllocInst(h,"Scalar", "Out Gain", 5, kNumberDuiId, 0.0, 10.0,0.01, 3.0 );
  121. //cmDspInst_t* reload = cmDspSysAllocInst(h,"Button", "Reload", 2, kButtonDuiId, 0.0 );
  122. cmDspInst_t* imin_dyn = cmDspSysAllocScalar( h, "Min In Dyn", 0.0, 10.0, 1.0, 0.0);
  123. cmDspInst_t* imax_dyn = cmDspSysAllocScalar( h, "Max In Dyn", 0.0, 10.0, 1.0, 4.0);
  124. cmDspInst_t* omin_dyn = cmDspSysAllocScalar( h, "Min Out Dyn", 0.0, 100.0, 0.5, 0.0);
  125. cmDspInst_t* omax_dyn = cmDspSysAllocScalar( h, "Max Out Dyn", 0.0, 100.0, 0.5, 100.0);
  126. cmDspInst_t* imin_even = cmDspSysAllocScalar( h, "Min In Even", 0.0, 10.0, 0.01, 0.0);
  127. cmDspInst_t* imax_even = cmDspSysAllocScalar( h, "Max In Even", 0.0, 10.0, 0.01, 1.0);
  128. cmDspInst_t* omin_even = cmDspSysAllocScalar( h, "Min Out Even", 0.0, 100.0, 0.5, 0.0);
  129. cmDspInst_t* omax_even = cmDspSysAllocScalar( h, "Max Out Even", 0.0, 100.0, 0.5, 100.0);
  130. cmDspInst_t* imin_tempo = cmDspSysAllocScalar( h, "Min In Tempo", 0.0, 200.0, 1.0, 80.0);
  131. cmDspInst_t* imax_tempo = cmDspSysAllocScalar( h, "Max In Tempo", 0.0, 200.0, 1.0, 120.0);
  132. cmDspInst_t* omin_tempo = cmDspSysAllocScalar( h, "Min Out Tempo", 0.0, 100.0, 0.5, 0.0);
  133. cmDspInst_t* omax_tempo = cmDspSysAllocScalar( h, "Max Out Tempo", 0.0, 100.0, 0.5, 100.0);
  134. cmDspInst_t* imin_cost = cmDspSysAllocScalar( h, "Min In Cost", 0.0, 200.0, 1.0, 80.0);
  135. cmDspInst_t* imax_cost = cmDspSysAllocScalar( h, "Max In Cost", 0.0, 200.0, 1.0, 120.0);
  136. cmDspInst_t* omin_cost = cmDspSysAllocScalar( h, "Min Out Cost", 0.0, 100.0, 0.5, 0.0);
  137. cmDspInst_t* omax_cost = cmDspSysAllocScalar( h, "Max Out Cost", 0.0, 100.0, 0.5, 100.0);
  138. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  139. return rc;
  140. // phasor->wt->aout
  141. cmDspSysConnectAudio(h, php, "out", wtp, "phs" ); // phs -> wt
  142. if(1)
  143. {
  144. cmDspSysConnectAudio(h, wtp, "out", kr0p, "in" ); // wt->kr
  145. cmDspSysConnectAudio(h, wtp, "out", kr1p, "in" );
  146. cmDspSysConnectAudio(h, kr0p, "out", xfad, "in-0"); // kr->aout
  147. cmDspSysConnectAudio(h, kr1p, "out", xfad, "in-1");
  148. cmDspSysConnectAudio(h, xfad, "out-0", ao0p, "in"); // kr->aout
  149. cmDspSysConnectAudio(h, xfad, "out-1", ao1p, "in");
  150. }
  151. else
  152. {
  153. cmDspSysConnectAudio(h, wtp, "out", ao0p, "in" ); // wt -> aout0
  154. cmDspSysConnectAudio(h, wtp, "out", ao1p, "in" ); // wt -> aout1
  155. //cmDspSysConnectAudio(h, wtp, "out", af0p, "in0" ); // wt -> audio file
  156. }
  157. // wave-table to time-line cursor
  158. cmDspSysInstallCb( h, wtp, "fidx",tlp, "curs", NULL);
  159. // start connections
  160. cmDspSysInstallCb(h, onb, "sym", tlp, "reset", NULL );
  161. cmDspSysInstallCb(h, onb, "sym", scp, "send", NULL );
  162. cmDspSysInstallCb(h, onb, "sym", mfp, "sel", NULL );
  163. cmDspSysInstallCb(h, onb, "sym", pts, "on", NULL );
  164. cmDspSysInstallCb(h, pts, "on", wtp, "cmd", NULL );
  165. cmDspSysInstallCb(h, pts, "on", modp,"cmd", NULL );
  166. // stop connections
  167. cmDspSysInstallCb(h, wtp, "done",offb,"in", NULL ); // 'done' from WT simulates pressing Stop btn.
  168. cmDspSysInstallCb(h, tlp, "mfn", pts, "off", NULL ); // Prevents WT start on new audio file from TL.
  169. cmDspSysInstallCb(h, offb, "sym", mfp, "sel", NULL );
  170. cmDspSysInstallCb(h, offb, "sym", pts, "off", NULL );
  171. cmDspSysInstallCb(h, pts, "off", wtp, "cmd", NULL );
  172. cmDspSysInstallCb(h, pts, "off", modp,"cmd", NULL );
  173. // time-line to wave-table selection
  174. cmDspSysInstallCb(h, tlp, "absi", wtp, "beg", NULL );
  175. cmDspSysInstallCb(h, tlp, "aesi", wtp, "end", NULL );
  176. cmDspSysInstallCb(h, tlp, "afn", wtp, "fn", NULL );
  177. // time-line to MIDI file player selection
  178. cmDspSysInstallCb(h, tlp, "mbsi", mfp, "bsi", NULL );
  179. cmDspSysInstallCb(h, tlp, "mesi", mfp, "esi", NULL );
  180. cmDspSysInstallCb(h, tlp, "mfn", mfp, "fn", NULL );
  181. // score to score follower - to set initial search location
  182. cmDspSysInstallCb(h, scp, "sel", sfp, "index", NULL );
  183. //cmDspSysInstallCb(h, scp, "sel", prv, "in", NULL );
  184. cmDspSysInstallCb(h, scp, "sel", modp,"reset", NULL );
  185. //cmDspSysInstallCb(h, reload,"out", modp, "reload", NULL );
  186. // MIDI file play er to score follower
  187. if(1)
  188. {
  189. cmDspSysInstallCb(h, mfp, "smpidx", sfp, "smpidx", NULL );
  190. cmDspSysInstallCb(h, mfp, "d1", sfp, "d1", NULL );
  191. cmDspSysInstallCb(h, mfp, "d0", sfp, "d0", NULL );
  192. cmDspSysInstallCb(h, mfp, "status", sfp, "status", NULL );
  193. }
  194. // score follower to modulator and printers
  195. cmDspSysInstallCb(h, sfp, "out", modp, "index", NULL );
  196. cmDspSysInstallCb(h, sfp, "out", prp, "in", NULL );
  197. cmDspSysInstallCb(h, sfp, "even", pre, "in", NULL );
  198. cmDspSysInstallCb(h, sfp, "dyn", prd, "in", NULL );
  199. cmDspSysInstallCb(h, sfp, "tempo",prt, "in", NULL );
  200. cmDspSysInstallCb(h, prtb, "sym", sfp, "cmd", NULL );
  201. cmDspSysInstallCb(h, qtb, "sym", sfp, "cmd", NULL );
  202. cmDspSysInstallCb(h, ws0p, "out", kr0p, "wndn", NULL ); // wndSmpCnt->kr
  203. cmDspSysInstallCb(h, hf0p, "out", kr0p, "hopf", NULL ); // hopFact->kr
  204. cmDspSysInstallCb(h, md0p, "val", kr0p, "mode", NULL ); // mode->kr
  205. cmDspSysInstallCb(h, th0p, "val", kr0p, "thrh", NULL ); // thresh->kr
  206. cmDspSysInstallCb(h, ls0p, "val", kr0p, "lwrs", NULL ); // lwrSlope->kr
  207. cmDspSysInstallCb(h, us0p, "val", kr0p, "uprs", NULL ); // uprSlope->kr
  208. cmDspSysInstallCb(h, of0p, "val", kr0p, "offs", NULL ); // offset->kr
  209. cmDspSysInstallCb(h, iv0p, "val", kr0p, "invt", NULL ); // invert->kr
  210. cmDspSysInstallCb(h, wet0, "val", kr0p, "wet", NULL ); // wet->kr
  211. cmDspSysInstallCb(h, ws1p, "out", kr1p, "wndn", NULL ); // wndSmpCnt->kr
  212. cmDspSysInstallCb(h, hf1p, "out", kr1p, "hopf", NULL ); // hopFact->kr
  213. cmDspSysInstallCb(h, md1p, "val", kr1p, "mode", NULL ); // mode->kr
  214. cmDspSysInstallCb(h, th1p, "val", kr1p, "thrh", NULL ); // thresh->kr
  215. cmDspSysInstallCb(h, ls1p, "val", kr1p, "lwrs", NULL ); // lwrSlope->kr
  216. cmDspSysInstallCb(h, us1p, "val", kr1p, "uprs", NULL ); // uprSlope->kr
  217. cmDspSysInstallCb(h, of1p, "val", kr1p, "offs", NULL ); // offset->kr
  218. cmDspSysInstallCb(h, iv1p, "val", kr1p, "invt", NULL ); // invert->kr
  219. cmDspSysInstallCb(h, wet1, "val", kr1p, "wet", NULL ); // wet->kr
  220. cmDspSysInstallCb(h, ogain, "val", ao0p, "gain", NULL ); // output gain control
  221. cmDspSysInstallCb(h, ogain, "val", ao1p, "gain", NULL );
  222. // Printer connections
  223. cmDspSysInstallCb(h, tlp, "afn", prp, "in", NULL );
  224. cmDspSysInstallCb(h, tlp, "mfn", prp, "in", NULL );
  225. cmDspSysInstallCb(h, tlp, "sel", prp, "in", NULL );
  226. cmDspSysInstallCb(h, modp, "mod0", md0p, "val", NULL );
  227. cmDspSysInstallCb(h, modp, "win0", kr0p, "wndn",NULL );
  228. cmDspSysInstallCb(h, modp, "thr0", th0p, "val", NULL );
  229. cmDspSysInstallCb(h, modp, "upr0", us0p, "val", NULL );
  230. cmDspSysInstallCb(h, modp, "lwr0", ls0p, "val", NULL );
  231. cmDspSysInstallCb(h, modp, "off0", of0p, "val", NULL );
  232. cmDspSysInstallCb(h, modp, "inv0", iv0p, "val", NULL );
  233. cmDspSysInstallCb(h, modp, "wet0", wet0, "val", NULL );
  234. cmDspSysInstallCb(h, modp, "xf0", xfad, "gate-0", NULL );
  235. cmDspSysInstallCb(h, modp, "mod1", md1p, "val", NULL );
  236. cmDspSysInstallCb(h, modp, "win1", kr1p, "wndn",NULL );
  237. cmDspSysInstallCb(h, modp, "thr1", th1p, "val", NULL );
  238. cmDspSysInstallCb(h, modp, "upr1", us1p, "val", NULL );
  239. cmDspSysInstallCb(h, modp, "lwr1", ls1p, "val", NULL );
  240. cmDspSysInstallCb(h, modp, "off1", of1p, "val", NULL );
  241. cmDspSysInstallCb(h, modp, "inv1", iv1p, "val", NULL );
  242. cmDspSysInstallCb(h, modp, "wet1", wet1, "val", NULL );
  243. cmDspSysInstallCb(h, modp, "xf1", xfad, "gate-1", NULL );
  244. cmDspSysInstallCb(h, sfp, "dyn", srp, "val_in", NULL );
  245. cmDspSysInstallCb(h, imin_dyn, "val", srp, "min_in", NULL );
  246. cmDspSysInstallCb(h, imax_dyn, "val", srp, "max_in", NULL );
  247. cmDspSysInstallCb(h, omin_dyn, "val", srp, "min_out", NULL );
  248. cmDspSysInstallCb(h, omax_dyn, "val", srp, "max_out", NULL );
  249. //cmDspSysInstallCb(h, srp, "val_out", th0p, "val", NULL );
  250. //cmDspSysInstallCb(h, srp, "val_out", th1p, "val", NULL );
  251. cmDspSysInstallCb(h, sfp, "even", srp, "val_in", NULL );
  252. cmDspSysInstallCb(h, imin_even, "val", srp, "min_in", NULL );
  253. cmDspSysInstallCb(h, imax_even, "val", srp, "max_in", NULL );
  254. cmDspSysInstallCb(h, omin_even, "val", srp, "min_out", NULL );
  255. cmDspSysInstallCb(h, omax_even, "val", srp, "max_out", NULL );
  256. //cmDspSysInstallCb(h, srp, "val_out", th0p, "val", NULL );
  257. //cmDspSysInstallCb(h, srp, "val_out", th1p, "val", NULL );
  258. cmDspSysInstallCb(h, sfp, "tempo", srp, "val_in", NULL );
  259. cmDspSysInstallCb(h, imin_tempo, "val", srp, "min_in", NULL );
  260. cmDspSysInstallCb(h, imax_tempo, "val", srp, "max_in", NULL );
  261. cmDspSysInstallCb(h, omin_tempo, "val", srp, "min_out", NULL );
  262. cmDspSysInstallCb(h, omax_tempo, "val", srp, "max_out", NULL );
  263. //cmDspSysInstallCb(h, srp, "val_out", th0p, "val", NULL );
  264. //cmDspSysInstallCb(h, srp, "val_out", th1p, "val", NULL );
  265. cmDspSysInstallCb(h, sfp, "cost", srp, "val_in", NULL );
  266. cmDspSysInstallCb(h, imin_cost, "val", srp, "min_in", NULL );
  267. cmDspSysInstallCb(h, imax_cost, "val", srp, "max_in", NULL );
  268. cmDspSysInstallCb(h, omin_cost, "val", srp, "min_out", NULL );
  269. cmDspSysInstallCb(h, omax_cost, "val", srp, "max_out", NULL );
  270. //cmDspSysInstallCb(h, srp, "val_out", th0p, "val", NULL );
  271. //cmDspSysInstallCb(h, srp, "val_out", th1p, "val", NULL );
  272. return rc;
  273. }
  274. cmDspRC_t _cmDspSysPgm_Switcher( cmDspSysH_t h, void** userPtrPtr )
  275. {
  276. bool useBuiltInFl = true;
  277. const char* fn0 = "media/audio/20110723-Kriesberg/Audio Files/Piano 3_01.wav";
  278. const cmChar_t* fn = cmFsMakeFn(cmFsUserDir(),fn0,NULL,NULL );
  279. bool dsBypassFl = false;
  280. double dsInGain = 1.0;
  281. double dsSrate = 96000.0;
  282. double dsBits = 24.0;
  283. bool dsRectifyFl = false;
  284. bool dsFullRectFl = false;
  285. double dsClipDb = -10.0;
  286. double cfMinHz = 20.0;
  287. double cfHz = 1000.0;
  288. double cfAlpha = 0.9;
  289. bool cfFbFl = true;
  290. bool cfBypassFl = false;
  291. unsigned xfChCnt = 2;
  292. double xfMs = 250;
  293. cmDspInst_t* ofp = cmDspSysAllocInst(h,"Scalar", "Offset", 5, kNumberDuiId, 0.0, cmDspSysSampleRate(h)*600.0, 1.0, 0.0);
  294. cmDspInst_t* fnp = cmDspSysAllocInst(h,"Fname", NULL, 3, false,"Audio Files (*.wav,*.aiff,*.aif)\tAudio Files (*.{wav,aiff,aif})",fn);
  295. cmDspInst_t* php = cmDspSysAllocInst(h,"Phasor", NULL, 0 );
  296. cmDspInst_t* wtp = cmDspSysAllocInst(h,"WaveTable",NULL, 2, ((int)cmDspSysSampleRate(h)), 1 );
  297. cmDspInst_t* ds = cmDspSysAllocInst(h,"DistDs", NULL, 3, dsBypassFl, dsInGain, dsSrate, dsBits );
  298. cmDspInst_t* cf = cmDspSysAllocInst( h,"CombFilt", NULL, 5, cfBypassFl, cfMinHz, cfFbFl, cfMinHz, cfAlpha );
  299. cmDspInst_t* xfad = cmDspSysAllocInst(h,"Xfader", NULL, 2, xfChCnt, xfMs );
  300. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, useBuiltInFl ? 0 : 2 );
  301. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, useBuiltInFl ? 1 : 3 );
  302. cmDspInst_t* ign = cmDspSysAllocScalar( h, "In Gain", 0.0, 10.0, 0.01, 1.0);
  303. cmDspInst_t* rct = cmDspSysAllocCheck( h, "Rectify", dsRectifyFl);
  304. cmDspInst_t* ful = cmDspSysAllocCheck( h, "Full/Half", dsFullRectFl);
  305. cmDspInst_t* dsr = cmDspSysAllocScalar( h, "Srate", 0.0, 96000, 1.0, dsSrate);
  306. cmDspInst_t* dbt = cmDspSysAllocScalar( h, "bits", 2.0, 32.0, 1.0, dsBits);
  307. cmDspInst_t* clip = cmDspSysAllocScalar( h, "Clip dB", -100.0, 0.0, 0.1, dsClipDb);
  308. cmDspInst_t* ogn = cmDspSysAllocScalar( h, "Out Gain", 0.0, 10.0, 0.01, 1.0);
  309. cmDspInst_t* cfhz = cmDspSysAllocScalar( h, "CF Hz", 25, 10000, 1, cfHz );
  310. cmDspInst_t* cfalpha = cmDspSysAllocScalar( h, "CF Alpha", 0.0, 2.0, 0.001, cfAlpha);
  311. cmDspInst_t* cfgain = cmDspSysAllocScalar( h, "CF Gain", 0.0, 20.0, 0.001, 1.0);
  312. cmDspInst_t* cffb = cmDspSysAllocInst( h,"Button", "CF Fb", 2, kCheckDuiId, 0.0 );
  313. cmDspInst_t* dfdb = cmDspSysAllocInst( h,"Button", "Dist Fader", 2, kCheckDuiId, 0.0 );
  314. cmDspInst_t* cfdb = cmDspSysAllocInst( h,"Button", "CF Fade", 2, kCheckDuiId, 0.0 );
  315. cmDspSysConnectAudio(h, php, "out", wtp, "phs" ); // phasor -> wave table
  316. cmDspSysConnectAudio(h, wtp, "out", cf, "in" );
  317. cmDspSysConnectAudio(h, cf, "out", xfad, "in-0" );
  318. cmDspSysConnectAudio(h, xfad,"out-0", ao0p, "in");
  319. cmDspSysConnectAudio(h, wtp, "out", ds, "in" );
  320. cmDspSysConnectAudio(h, ds, "out", xfad, "in-1" ); //
  321. cmDspSysConnectAudio(h, xfad,"out-1", ao1p, "in");
  322. cmDspSysInstallCb(h, ofp, "val", wtp, "beg", NULL );
  323. cmDspSysInstallCb(h, fnp, "out", wtp, "fn", NULL);
  324. // Distortion control connections
  325. cmDspSysInstallCb(h, ign, "val", ds, "igain", NULL );
  326. cmDspSysInstallCb(h, dsr, "val", ds, "srate", NULL );
  327. cmDspSysInstallCb(h, dbt, "val", ds, "bits", NULL );
  328. cmDspSysInstallCb(h, rct, "out", ds, "rect", NULL );
  329. cmDspSysInstallCb(h, ful, "out", ds, "full", NULL );
  330. cmDspSysInstallCb(h, clip, "val", ds, "clip", NULL );
  331. cmDspSysInstallCb(h, ogn, "val", ds, "ogain", NULL );
  332. cmDspSysInstallCb(h, cfhz, "val", cf, "hz", NULL );
  333. cmDspSysInstallCb(h, cfalpha, "val", cf, "alpha", NULL );
  334. cmDspSysInstallCb(h, cffb, "out", cf, "fb", NULL );
  335. cmDspSysInstallCb(h, cfgain, "val", ao1p, "gain", NULL );
  336. cmDspSysInstallCb(h, cfdb, "out", xfad, "gate-0", NULL);
  337. cmDspSysInstallCb(h, dfdb, "out", xfad, "gate-1", NULL);
  338. return kOkDspRC;
  339. }