libcm is a C development framework with an emphasis on audio signal processing applications.
Du kannst nicht mehr als 25 Themen auswählen Themen müssen mit entweder einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

cmDspPgm.c 145KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399
  1. //( { file_desc:"'snap' programs." kw:[snap] }
  2. #include "cmPrefix.h"
  3. #include "cmGlobal.h"
  4. #include "cmFloatTypes.h"
  5. #include "cmRpt.h"
  6. #include "cmErr.h"
  7. #include "cmCtx.h"
  8. #include "cmMem.h"
  9. #include "cmMallocDebug.h"
  10. #include "cmLinkedHeap.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 "cmSerialPort.h"
  21. #include "cmTime.h"
  22. #include "cmAudioSys.h"
  23. #include "cmProcObj.h"
  24. #include "cmPP_NARG.h"
  25. #include "cmDspCtx.h"
  26. #include "cmDspClass.h"
  27. #include "cmDspSys.h"
  28. #include "cmDspPgm.h"
  29. #include "cmDspPgmPP.h"
  30. #include "cmDspPgmKr.h"
  31. //)
  32. //( { label:cmDspPgm_ReflecCalc file_desc:"Acoustic time-of-flight measurement program." kw:[spgm] }
  33. cmDspRC_t _cmDspSysPgm_ReflectCalc( cmDspSysH_t h, void** userPtrPtr )
  34. {
  35. // audio inputs
  36. cmDspInst_t* ai0 = cmDspSysAllocInst(h,"AudioIn", NULL, 1, 0 );
  37. cmDspInst_t* ai1 = cmDspSysAllocInst(h,"AudioIn", NULL, 1, 1 );
  38. cmDspInst_t* rc0 = cmDspSysAllocInst(h,"ReflectCalc", NULL, 0 );
  39. //cmDspInst_t* rc1 = cmDspSysAllocInst(h,"ReflectCalc", NULL, 0 );
  40. // audio outputs
  41. cmDspInst_t* ao0 = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 0 );
  42. cmDspInst_t* ao1 = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 1 );
  43. // input meters
  44. cmDspInst_t* im0 = cmDspSysAllocInst(h,"AMeter","In 0", 0);
  45. cmDspInst_t* im1 = cmDspSysAllocInst(h,"AMeter","In 1", 0);
  46. // output meters
  47. //cmDspInst_t* om0 = cmDspSysAllocInst(h,"AMeter","Out 0", 0);
  48. //cmDspInst_t* om1 = cmDspSysAllocInst(h,"AMeter","Out 1",0);
  49. // gain controls
  50. cmDspInst_t* igain = cmDspSysAllocInst( h,"Scalar", "In Gain", 5, kNumberDuiId, 0.0, 4.0, 0.01, 1.0);
  51. cmDspInst_t* ogain = cmDspSysAllocInst( h,"Scalar", "Out Gain", 5, kNumberDuiId, 0.0, 4.0, 0.01, 3.0);
  52. cmDspSysConnectAudio(h, ai0, "out", im0, "in"); // ain0 -> imtr0
  53. cmDspSysConnectAudio(h, ai1, "out", im1, "in"); // ain1 -> imtr1
  54. cmDspSysInstallCb( h, igain,"val", ai0, "gain", NULL); // igain -> ain0
  55. cmDspSysInstallCb( h, igain,"val", ai1, "gain", NULL); // igain -> ain0
  56. cmDspSysInstallCb( h, ogain,"val", ao0, "gain", NULL); // igain -> ain0
  57. cmDspSysInstallCb( h, ogain,"val", ao1, "gain", NULL); // igain -> ain0
  58. cmDspSysConnectAudio(h, ai0,"out", rc0, "in" );
  59. cmDspSysConnectAudio(h, rc0,"out", ao0, "in" );
  60. cmDspSysConnectAudio(h, ai1,"out", ao1, "in" );
  61. return kOkDspRC;
  62. }
  63. //------------------------------------------------------------------------------
  64. //)
  65. //( { label:cmDspPgm_SyncRecd file_desc:"Generate MIDI / Audio synchronization data with cmDspSyncRecd." kw:[spgm] }
  66. cmDspRC_t _cmDspSysPgm_SyncRecd( cmDspSysH_t h, void** userPtrPtr )
  67. {
  68. cmDspRC_t rc = kOkDspRC;
  69. unsigned audioFileBits = 24;
  70. cmDspInst_t* ai0p = cmDspSysAllocInst(h,"AudioIn", NULL, 1, 0 );
  71. cmDspInst_t* ai1p = cmDspSysAllocInst(h,"AudioIn", NULL, 1, 1 );
  72. cmDspInst_t* mip = cmDspSysAllocInst(h,"MidiIn", NULL, 0 );
  73. cmDspInst_t* srp = cmDspSysAllocInst(h,"SyncRecd",NULL, 3, "/home/kevin/temp/kr/sr","sr","audio",audioFileBits);
  74. cmDspInst_t* am0p = cmDspSysAllocInst(h,"AMeter", "Left", 0);
  75. cmDspInst_t* am1p = cmDspSysAllocInst(h,"AMeter", "Right",0);
  76. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut", NULL, 1, 0 );
  77. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut", NULL, 1, 1 );
  78. cmDspInst_t* chk = cmDspSysAllocInst(h,"Checkbox","recd", 5, "Recd","open","close", 1.0, 0.0);
  79. cmDspInst_t* gain0 = cmDspSysAllocInst(h,"Scalar", "In Gain-0", 5, kNumberDuiId, 0.0, 10.0,0.01, 1.0 );
  80. cmDspInst_t* gain1 = cmDspSysAllocInst(h,"Scalar", "In Gain-1", 5, kNumberDuiId, 0.0, 10.0,0.01, 1.0 );
  81. // check for allocation errors
  82. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  83. goto errLabel;
  84. cmDspSysInstallCb(h, mip, "status", srp, "status", NULL);
  85. cmDspSysInstallCb(h, mip, "d0", srp, "d0", NULL);
  86. cmDspSysInstallCb(h, mip, "d1", srp, "d1", NULL);
  87. cmDspSysInstallCb(h, mip, "sec", srp, "sec", NULL);
  88. cmDspSysInstallCb(h, mip, "nsec", srp, "nsec", NULL);
  89. cmDspSysInstallCb(h, chk, "sym", srp, "cmd", NULL);
  90. cmDspSysInstallCb(h, gain0, "val", ai0p, "gain", NULL);
  91. cmDspSysInstallCb(h, gain1, "val", ai1p, "gain", NULL);
  92. cmDspSysConnectAudio(h, ai0p, "out", srp, "ain-0");
  93. cmDspSysConnectAudio(h, ai1p, "out", srp, "ain-1");
  94. cmDspSysConnectAudio(h, ai0p, "out", am0p, "in");
  95. cmDspSysConnectAudio(h, ai1p, "out", am1p, "in");
  96. cmDspSysConnectAudio(h, ai0p, "out", ao0p, "in");
  97. cmDspSysConnectAudio(h, ai1p, "out", ao1p, "in");
  98. errLabel:
  99. return rc;
  100. }
  101. //------------------------------------------------------------------------------
  102. //)
  103. //( { label:cmDspPgm_MidiFilePlay file_desc:"MIDI file player example program." kw:[spgm] }
  104. cmDspRC_t _cmDspSysPgm_MidiFilePlay( cmDspSysH_t h, void** userPtrPtr )
  105. {
  106. cmDspRC_t rc = kOkDspRC;
  107. const cmChar_t* deviceName = "Scarlett 18i20 USB";
  108. const cmChar_t* portName = "Scarlett 18i20 USB MIDI 1";
  109. //const cmChar_t* deviceName = "Fastlane";
  110. //const cmChar_t* portName = "Fastlane MIDI A";
  111. //const cmChar_t* deviceName = "DKV-M4";
  112. //const cmChar_t* portName = "DKV-M4 MIDI 1";
  113. const char* fn0 = "media/audio/midi/988-v25.mid";
  114. const cmChar_t* fn = cmFsMakeFn(cmFsUserDir(),fn0,NULL,NULL );
  115. cmDspInst_t* fnp = cmDspSysAllocInst(h,"Fname", NULL, 3, false,"MIDI Files (*.mid)\tMIDI Files (*.{mid})",fn);
  116. cmDspInst_t* ignp = cmDspSysAllocInst( h,"Scalar", "In Gain", 5, kNumberDuiId, 0.0, 4.0, 0.01, 1.0);
  117. cmDspInst_t* ai0p = cmDspSysAllocInst(h,"AudioIn", NULL, 1, 2 );
  118. cmDspInst_t* ai1p = cmDspSysAllocInst(h,"AudioIn", NULL, 1, 3 );
  119. cmDspInst_t* mfp = cmDspSysAllocInst(h,"MidiFilePlay",NULL, 0 );
  120. cmDspInst_t* pic = cmDspSysAllocInst(h,"Picadae", NULL, 0 );
  121. cmDspInst_t* mop = cmDspSysAllocInst( h,"MidiOut", NULL, 2, deviceName, portName);
  122. cmDspInst_t* start = cmDspSysAllocInst( h,"Button", "start", 2, kButtonDuiId, 0.0 );
  123. cmDspInst_t* stop = cmDspSysAllocInst( h,"Button", "stop", 2, kButtonDuiId, 0.0 );
  124. cmDspInst_t* cont = cmDspSysAllocInst( h,"Button", "continue", 2, kButtonDuiId, 0.0 );
  125. cmDspInst_t* beg = cmDspSysAllocInst(h,"Scalar", "Beg Samp", 5, kNumberDuiId, 0.0, 1000000000.0, 1.0, 0.0 );
  126. cmDspInst_t* end = cmDspSysAllocInst(h,"Scalar", "End Samp", 5, kNumberDuiId, 0.0, 1000000000.0, 1.0, 1000000000.0 );
  127. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 2 );
  128. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 3 );
  129. cmDspInst_t* ao2p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 4 );
  130. cmDspInst_t* ao3p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 5 );
  131. cmDspInst_t* im0p = cmDspSysAllocInst(h,"AMeter","In 0", 0);
  132. cmDspInst_t* im1p = cmDspSysAllocInst(h,"AMeter","In 1", 0);
  133. cmDspInst_t* om0p = cmDspSysAllocInst(h,"AMeter","Out 0", 0);
  134. cmDspInst_t* om1p = cmDspSysAllocInst(h,"AMeter","Out 1",0);
  135. cmDspInst_t* om2p = cmDspSysAllocInst(h,"AMeter","Out 2", 0);
  136. cmDspInst_t* om3p = cmDspSysAllocInst(h,"AMeter","Out 3",0);
  137. // check for allocation errors
  138. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  139. goto errLabel;
  140. cmDspSysInstallCb( h, fnp, "out", mfp, "fn", NULL);
  141. cmDspSysInstallCb( h, start, "sym", beg, "send", NULL);
  142. cmDspSysInstallCb( h, beg, "val", mfp, "bsi", NULL);
  143. cmDspSysInstallCb( h, start, "sym", end, "send", NULL);
  144. cmDspSysInstallCb( h, end, "val", mfp, "esi", NULL);
  145. cmDspSysInstallCb( h, start, "sym", mfp, "sel", NULL);
  146. cmDspSysInstallCb( h, stop, "sym", mfp, "sel", NULL);
  147. cmDspSysInstallCb( h, cont, "sym", mfp, "sel", NULL);
  148. bool usePicadaeFl = false;
  149. if( usePicadaeFl )
  150. {
  151. cmDspSysInstallCb( h, mfp, "d1", pic, "d1", NULL);
  152. cmDspSysInstallCb( h, mfp, "d0", pic, "d0", NULL);
  153. cmDspSysInstallCb( h, mfp, "status", pic, "status", NULL);
  154. cmDspSysInstallCb( h, pic, "d1", mop, "d1", NULL);
  155. cmDspSysInstallCb( h, pic, "d0", mop, "d0", NULL);
  156. cmDspSysInstallCb( h, pic, "status", mop, "status", NULL);
  157. }
  158. else
  159. {
  160. cmDspSysInstallCb( h, mfp, "d1", mop, "d1", NULL);
  161. cmDspSysInstallCb( h, mfp, "d0", mop, "d0", NULL);
  162. cmDspSysInstallCb( h, mfp, "status", mop, "status", NULL);
  163. }
  164. //cmDspSysConnectAudio(h, ai0p, "out", ao0p, "in");
  165. //cmDspSysConnectAudio(h, ai1p, "out", ao1p, "in");
  166. cmDspSysConnectAudio(h, ai0p, "out", im0p, "in"); //ain0 -> imtr0
  167. cmDspSysConnectAudio(h, ai1p, "out", im1p, "in"); //ain1 -> imtr1
  168. cmDspSysInstallCb( h, ignp,"val", ai0p, "gain", NULL); // igain -> ain0
  169. cmDspSysConnectAudio(h, ai0p,"out", ao0p, "in" ); // ain0 -> aout0
  170. cmDspSysConnectAudio(h, ai0p,"out", om0p, "in" ); // ain0 -> omtr0
  171. cmDspSysInstallCb( h, ignp,"val", ai1p, "gain", NULL); // igain -> ain1
  172. cmDspSysConnectAudio(h, ai1p,"out", ao1p, "in" ); // ain1 -> aout1
  173. cmDspSysConnectAudio(h, ai1p,"out", om1p, "in" ); // ain1 -> omtr1
  174. cmDspSysConnectAudio(h, ai0p,"out", ao2p, "in" ); // ain0 -> aout2
  175. cmDspSysConnectAudio(h, ai0p,"out", om2p, "in" ); // ain0 -> omtr0
  176. cmDspSysConnectAudio(h, ai1p,"out", ao3p, "in" ); // ain1 -> aout3
  177. cmDspSysConnectAudio(h, ai1p,"out", om3p, "in" ); // ain0 -> omtr0
  178. errLabel:
  179. cmFsFreeFn(fn);
  180. return rc;
  181. }
  182. //------------------------------------------------------------------------------
  183. //)
  184. //( { label:cmDspPgm_Test_Midi file_desc:"MIDI input/output example program." kw:[spgm] }
  185. cmDspRC_t _cmDspSysPgm_Test_Midi( cmDspSysH_t h, void** userPtrPtr )
  186. {
  187. cmDspRC_t rc = kOkDspRC;
  188. const cmChar_t* deviceName = "Fastlane";
  189. const cmChar_t* portName = "Fastlane MIDI A";
  190. #ifdef OS_OSX
  191. deviceName = "MOTU - FastLane USB";
  192. portName = "Port A";
  193. //deviceName = "RME - Fireface UFX (23148636)";
  194. //portName = "Port 2";
  195. #endif
  196. cmDspInst_t* sendBtn = cmDspSysAllocInst( h,"Button", "Send", 2, kButtonDuiId, 0.0 );
  197. cmDspInst_t* status = cmDspSysAllocInst( h,"Scalar", "Status", 5, kNumberDuiId, 0.0, 127.0, 1.0, 144.0);
  198. cmDspInst_t* d0 = cmDspSysAllocInst( h,"Scalar", "D0", 5, kNumberDuiId, 0.0, 127.0, 1.0, 64.0);
  199. cmDspInst_t* d1 = cmDspSysAllocInst( h,"Scalar", "D1", 5, kNumberDuiId, 0.0, 127.0, 1.0, 64.0);
  200. cmDspInst_t* midiOut = cmDspSysAllocInst( h,"MidiOut", NULL, 2, deviceName, portName);
  201. cmDspInst_t* midiIn = cmDspSysAllocInst( h,"MidiIn", NULL, 0 );
  202. //cmDspInst_t* printer = cmDspSysAllocInst( h,"Printer", NULL, 1, ">" );
  203. cmDspInst_t* prst = cmDspSysAllocInst( h,"Printer", NULL, 1, "st>" );
  204. cmDspInst_t* prd0 = cmDspSysAllocInst( h,"Printer", NULL, 1, "d0>" );
  205. cmDspInst_t* prd1 = cmDspSysAllocInst( h,"Printer", NULL, 1, "d1>" );
  206. // check for allocation errors
  207. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  208. goto errLabel;
  209. cmDspSysInstallCb( h, sendBtn, "out", d1, "send", NULL);
  210. cmDspSysInstallCb( h, sendBtn, "out", d0, "send", NULL);
  211. cmDspSysInstallCb( h, sendBtn, "out", status, "send", NULL);
  212. cmDspSysInstallCb( h, status, "val", midiOut, "status",NULL);
  213. cmDspSysInstallCb( h, d0, "val", midiOut, "d0", NULL);
  214. cmDspSysInstallCb( h, d1, "val", midiOut, "d1", NULL);
  215. cmDspSysInstallCb( h, midiIn, "status", prst, "in", NULL);
  216. cmDspSysInstallCb( h, midiIn, "d0", prd0, "in", NULL);
  217. cmDspSysInstallCb( h, midiIn, "d1", prd1, "in", NULL);
  218. //cmDspSysInstallCb( h, midiIn, "smpidx", printer, "in", NULL);
  219. errLabel:
  220. return rc;
  221. }
  222. //------------------------------------------------------------------------------
  223. //)
  224. //( { label:cmDspPgm_Test_Pedals file_desc:"MIDI input/output example program." kw:[spgm] }
  225. cmDspRC_t _cmDspSysPgm_Test_Pedals( cmDspSysH_t h, void** userPtrPtr )
  226. {
  227. cmDspRC_t rc = kOkDspRC;
  228. //const cmChar_t* deviceName = "Fastlane";
  229. //const cmChar_t* portName = "Fastlane MIDI A";
  230. const cmChar_t* deviceName = "Apple Inc. - IAC Driver";
  231. const cmChar_t* portName = "Bus 1";
  232. //deviceName = "MOTU - FastLane USB";
  233. //portName = "Port A";
  234. //deviceName = "RME - Fireface UFX (23148636)";
  235. //portName = "Port 2";
  236. cmDspInst_t* ai0 = cmDspSysAllocInst(h,"AudioIn", NULL, 1, 0 );
  237. cmDspInst_t* ai1 = cmDspSysAllocInst(h,"AudioIn", NULL, 1, 1 );
  238. cmDspInst_t* on0 = cmDspSysAllocButton( h, "Note On 1", 1.0 );
  239. cmDspInst_t* of0 = cmDspSysAllocButton( h, "Off 1 ", 2.0 );
  240. cmDspInst_t* on1 = cmDspSysAllocButton( h, "Note On 2", 3.0 );
  241. cmDspInst_t* of1 = cmDspSysAllocButton( h, "Off 2 ", 4.0 );
  242. cmDspInst_t* dm1 = cmDspSysAllocButton( h, "Damp On ", 5.0 );
  243. cmDspInst_t* dm0 = cmDspSysAllocButton( h, "Damp Off ", 6.0 );
  244. cmDspInst_t* sf1 = cmDspSysAllocButton( h, "Soft On ", 5.0 );
  245. cmDspInst_t* sf0 = cmDspSysAllocButton( h, "Soft Off ", 6.0 );
  246. cmDspInst_t* so1 = cmDspSysAllocButton( h, "Sost On ", 5.0 );
  247. cmDspInst_t* so0 = cmDspSysAllocButton( h, "Sost Off ", 6.0 );
  248. cmDspInst_t* lst = cmDspSysAllocInst( h, "MsgList","Seq", 1, "note_list");
  249. cmDspInst_t* mop = cmDspSysAllocInst( h, "MidiOut", NULL, 2, deviceName, portName);
  250. cmDspInst_t* ao0 = cmDspSysAllocInst(h,"AudioOut", NULL, 1, 2 );
  251. cmDspInst_t* ao1 = cmDspSysAllocInst(h,"AudioOut", NULL, 1, 3 );
  252. //cmDspInst_t* prt = cmDspSysAllocInst( h,"Printer", NULL, 1, "" );
  253. // check for allocation errors
  254. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  255. goto errLabel;
  256. cmDspSysConnectAudio( h, ai0, "out", ao0, "in" );
  257. cmDspSysConnectAudio( h, ai1, "out", ao1, "in" );
  258. cmDspSysInstallCb( h, on0, "out", lst, "sel", NULL );
  259. cmDspSysInstallCb( h, of0, "out", lst, "sel", NULL );
  260. cmDspSysInstallCb( h, on1, "out", lst, "sel", NULL );
  261. cmDspSysInstallCb( h, of1, "out", lst, "sel", NULL );
  262. cmDspSysInstallCb( h, dm1, "out", lst, "sel", NULL );
  263. cmDspSysInstallCb( h, dm0, "out", lst, "sel", NULL );
  264. cmDspSysInstallCb( h, sf1, "out", lst, "sel", NULL );
  265. cmDspSysInstallCb( h, sf0, "out", lst, "sel", NULL );
  266. cmDspSysInstallCb( h, so1, "out", lst, "sel", NULL );
  267. cmDspSysInstallCb( h, so0, "out", lst, "sel", NULL );
  268. //cmDspSysInstallCb( h, lst, "d1", prt, "in", NULL );
  269. //cmDspSysInstallCb( h, lst, "d0", prt, "in", NULL );
  270. //cmDspSysInstallCb( h, lst, "status", prt, "in", NULL );
  271. cmDspSysInstallCb( h, lst, "d1", mop, "d1", NULL);
  272. cmDspSysInstallCb( h, lst, "d0", mop, "d0", NULL);
  273. cmDspSysInstallCb( h, lst, "status", mop, "status", NULL);
  274. errLabel:
  275. return rc;
  276. }
  277. //------------------------------------------------------------------------------
  278. //)
  279. //( { label:cmDspPgm_Stereo_Through file_desc:"Stereo audio through example program." kw:[spgm] }
  280. cmDspRC_t _cmDspSysPgm_Stereo_Through( cmDspSysH_t h, void** userPtrPtr )
  281. {
  282. cmDspInst_t* ignp = cmDspSysAllocInst( h,"Scalar", "In Gain", 5, kNumberDuiId, 0.0, 4.0, 0.01, 0.0);
  283. //cmDspInst_t* ognp = cmDspSysAllocInst( h,"Scalar", "Out Gain", 5, kNumberDuiId, 0.0, 4.0, 0.01, 1.0);
  284. cmDspInst_t* hzp = cmDspSysAllocInst(h,"Scalar", "Hz", 5, kNumberDuiId, 0.0, 10.0, 0.001, 1.0);
  285. cmDspInst_t* php = cmDspSysAllocInst(h,"Phasor", NULL, 0 );
  286. cmDspInst_t* wtp = cmDspSysAllocInst(h,"WaveTable",NULL, 2, cmDspSysSampleRate(h), 2 );
  287. cmDspInst_t* ai0p = cmDspSysAllocInst(h,"AudioIn", NULL, 1, 2 );
  288. cmDspInst_t* ai1p = cmDspSysAllocInst(h,"AudioIn", NULL, 1, 3 );
  289. // MOTU Traveler: Use channels 2&3 (out plugs:3&4) because 0&1 do not show up on plugs 1&2.
  290. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 2 );
  291. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 3 );
  292. cmDspInst_t* im0p = cmDspSysAllocInst(h,"AMeter","In 0", 0);
  293. cmDspInst_t* im1p = cmDspSysAllocInst(h,"AMeter","In 1", 0);
  294. cmDspInst_t* om0p = cmDspSysAllocInst(h,"AMeter","Out 0", 0);
  295. cmDspInst_t* om1p = cmDspSysAllocInst(h,"AMeter","Out 1",0);
  296. //cmDspSysConnectAudio(h, ai0p, "out", ao0p, "in");
  297. //cmDspSysConnectAudio(h, ai1p, "out", ao1p, "in");
  298. cmDspSysConnectAudio(h, ai0p, "out", im0p, "in"); //ain0 -> imtr0
  299. cmDspSysConnectAudio(h, ai1p, "out", im1p, "in"); //ain1 -> imtr1
  300. if(0)
  301. {
  302. cmDspSysInstallCb( h, hzp, "val", php, "mult", NULL); // hz -> phs
  303. cmDspSysConnectAudio(h, php, "out", wtp, "phs" ); // phs -> wt
  304. cmDspSysConnectAudio(h, wtp, "out", ao0p, "in" ); // wt -> aout0
  305. cmDspSysConnectAudio(h, wtp, "out", om0p, "in" ); // wt -> omtr0
  306. }
  307. else
  308. {
  309. cmDspSysInstallCb( h, ignp,"val", ai0p, "gain", NULL); // igain -> ain0
  310. cmDspSysConnectAudio(h, ai0p,"out", ao0p, "in" ); // ain0 -> aout0
  311. cmDspSysConnectAudio(h, ai0p,"out", om0p, "in" ); // ain0 -> omtr0
  312. }
  313. cmDspSysInstallCb( h, ignp,"val", ai1p, "gain", NULL); // igain -> ain1
  314. cmDspSysConnectAudio(h, ai1p,"out", ao1p, "in" ); // ain1 -> aout1
  315. cmDspSysConnectAudio(h, ai1p,"out", om1p, "in" ); // ain1 -> omtr1
  316. return kOkDspRC;
  317. }
  318. //------------------------------------------------------------------------------
  319. //)
  320. //( { label:cmDspSysPgm_All_In_And_Out file_desc:"Meter all the input channels and pass two channels to the output." kw:[spgm] }
  321. cmDspRC_t _cmDspSysPgm_All_In_And_Out( cmDspSysH_t h, void** userPtrPtr )
  322. {
  323. cmDspInst_t* ignp = cmDspSysAllocInst( h,"Scalar", "In Gain", 5, kNumberDuiId, 0.0, 4.0, 0.01, 1.0);
  324. const unsigned inN = 18;
  325. cmDspInst_t* ainA[inN];
  326. cmDspInst_t* aoutA[inN];
  327. cmDspInst_t* imtrA[inN];
  328. int i;
  329. for(i=0;i<inN; ++i)
  330. {
  331. char label[32];
  332. snprintf(label,32,"in %i",i);
  333. ainA[i] = cmDspSysAllocInst(h,"AudioIn", NULL, 1, i );
  334. imtrA[i] = cmDspSysAllocInst(h,"AMeter",label, 0);
  335. aoutA[i] = cmDspSysAllocInst(h,"AudioOut", NULL, 1, i );
  336. }
  337. for(i=0; i<inN; ++i)
  338. {
  339. cmDspSysInstallCb( h, ignp, "val", ainA[i], "gain", NULL); // igain -> ain
  340. cmDspSysConnectAudio(h, ainA[i],"out", imtrA[i], "in" ); // ain -> imtr
  341. cmDspSysConnectAudio(h, ainA[i],"out", aoutA[i], "in" ); // ain -> aout
  342. }
  343. return kOkDspRC;
  344. }
  345. //------------------------------------------------------------------------------
  346. //)
  347. //( { label:cmDspPgm_Stereo_Fx file_desc:"Stereo audio effects example program." kw:[spgm] }
  348. cmDspRC_t _cmDspSysPgm_Stereo_Fx( cmDspSysH_t h, void** userPtrPtr )
  349. {
  350. bool useBuiltInFl = true;
  351. cmDspInst_t* ignp = cmDspSysAllocInst( h,"Scalar", "In Gain", 5, kNumberDuiId, 0.0, 4.0, 0.01, 1.0);
  352. cmDspInst_t* ognp = cmDspSysAllocInst( h,"Scalar", "Out Gain", 5, kNumberDuiId, 0.0, 4.0, 0.01, 1.0);
  353. //cmDspInst_t* fb0p = cmDspSysAllocInst( h,"Scalar", "Feeback 0", 5, kNumberDuiId, 0.0, 1.0, 0.001, 0.0);
  354. //cmDspInst_t* fb1p = cmDspSysAllocInst( h,"Scalar", "Feedback 1", 5, kNumberDuiId, 0.0, 1.0, 0.001, 0.0);
  355. //cmDspInst_t* tm0p = cmDspSysAllocInst( h,"Scalar", "Time 0", 5, kNumberDuiId, 0.0, 1000.0, 0.0001, 10.0);
  356. //cmDspInst_t* tm1p = cmDspSysAllocInst( h,"Scalar", "Time 1", 5, kNumberDuiId, 0.0, 1000.0, 0.0001, 10.0);
  357. cmDspInst_t* rt0p = cmDspSysAllocInst( h,"Scalar", "Ratio 0", 5, kNumberDuiId, 0.01, 10.0, 0.01, 1.0);
  358. cmDspInst_t* rt1p = cmDspSysAllocInst( h,"Scalar", "Ratio 1", 5, kNumberDuiId, 0.01, 10.0, 0.01, 1.0);
  359. cmDspInst_t* ai0p = cmDspSysAllocInst(h,"AudioIn", NULL, 1, useBuiltInFl ? 0 : 2 );
  360. cmDspInst_t* ai1p = cmDspSysAllocInst(h,"AudioIn", NULL, 1, useBuiltInFl ? 1 : 3 );
  361. cmDspInst_t* om0p = cmDspSysAllocInst(h,"AMeter","Out Left", 0);
  362. cmDspInst_t* om1p = cmDspSysAllocInst(h,"AMeter","Out Right",0);
  363. //cmDspInst_t* dy0p = cmDspSysAllocInst(h,"Delay", NULL, 2, 1000.0, 0.5 );
  364. //cmDspInst_t* dy1p = cmDspSysAllocInst(h,"Delay", NULL, 2, 2000.0, 0.7 );
  365. cmDspInst_t* ps0p = cmDspSysAllocInst(h,"PShift", NULL, 0 );
  366. cmDspInst_t* ps1p = cmDspSysAllocInst(h,"PShift", NULL, 0 );
  367. // MOTU Traveler: Use channels 2&3 (out plugs:3&4) because 0&1 do not show up on plugs 1&2.
  368. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, useBuiltInFl ? 0 : 2 );
  369. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, useBuiltInFl ? 1 : 3 );
  370. cmDspSysConnectAudio(h, ai0p,"out", om0p, "in" ); // input meter connection
  371. cmDspSysConnectAudio(h, ai1p,"out", om1p, "in" );
  372. //cmDspSysConnectAudio(h, ai0p,"out", dy0p, "in" ); // input -> delay
  373. //cmDspSysConnectAudio(h, ai1p,"out", dy1p, "in" );
  374. cmDspSysConnectAudio(h, ai0p,"out", ps0p, "in" ); // delay -> pshift
  375. cmDspSysConnectAudio(h, ai1p,"out", ps1p, "in" );
  376. cmDspSysConnectAudio(h, ps0p,"out", ao0p, "in" ); // pshift -> output
  377. cmDspSysConnectAudio(h, ps1p,"out", ao1p, "in" );
  378. //cmDspSysConnectAudio(h, dy0p,"out", ao0p, "in" ); // delay -> output
  379. //cmDspSysConnectAudio(h, dy1p,"out", ao1p, "in" );
  380. cmDspSysInstallCb( h, ignp,"val", ai0p, "gain", NULL); // input gain
  381. cmDspSysInstallCb( h, ignp,"val", ai1p, "gain", NULL);
  382. cmDspSysInstallCb( h, ognp, "val", ao0p, "gain", NULL); // output gain
  383. cmDspSysInstallCb( h, ognp, "val", ao1p, "gain", NULL);
  384. //cmDspSysInstallCb( h, fb0p, "val", dy0p, "fb", NULL); // feedback
  385. //cmDspSysInstallCb( h, fb1p, "val", dy1p, "fb", NULL);
  386. //cmDspSysInstallCb( h, tm0p, "val", dy0p, "time", NULL); // delay time
  387. //cmDspSysInstallCb( h, tm1p, "val", dy1p, "time", NULL);
  388. cmDspSysInstallCb( h, rt0p, "val", ps0p, "ratio", NULL); // pitch ratio
  389. cmDspSysInstallCb( h, rt1p, "val", ps1p, "ratio", NULL);
  390. return kOkDspRC;
  391. }
  392. //------------------------------------------------------------------------------
  393. //)
  394. //( { label:cmDspPgm_PlaySine file_desc:"Play a sine signal." kw:[spgm] }
  395. cmDspRC_t _cmDspSysPgm_PlaySine( cmDspSysH_t h, void** userPtrPtr )
  396. {
  397. bool useBuiltInFl = true;
  398. double frqHz = 440.0;
  399. cmDspInst_t* chp = cmDspSysAllocInst( h,"Scalar", "Channel", 5, kNumberDuiId, 0.0, 100.0, 1.0, 0.0);
  400. cmDspInst_t* php = cmDspSysAllocInst(h,"Phasor", NULL, 2, cmDspSysSampleRate(h), frqHz );
  401. cmDspInst_t* wtp = cmDspSysAllocInst(h,"WaveTable", NULL, 2, ((int)cmDspSysSampleRate(h)), 4);
  402. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut", NULL, 1, useBuiltInFl ? 0 : 2 );
  403. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut", NULL, 1, useBuiltInFl ? 1 : 3 );
  404. cmDspInst_t* om0p = cmDspSysAllocInst(h,"AMeter","Out", 0);
  405. cmDspInst_t* gain= cmDspSysAllocInst( h,"Scalar", "Gain", 5, kNumberDuiId, 0.0, 10.0, 0.01, 0.0);
  406. cmDspSysConnectAudio(h, php, "out", wtp, "phs" ); // phasor -> wave table
  407. cmDspSysConnectAudio(h, wtp, "out", ao0p, "in" ); // wave table -> audio out
  408. cmDspSysConnectAudio(h, wtp, "out", ao1p, "in" ); //
  409. cmDspSysConnectAudio(h, wtp, "out", om0p, "in" );
  410. cmDspSysInstallCb( h, chp, "val", ao0p, "ch", NULL);
  411. cmDspSysInstallCb( h, gain, "val", ao0p, "gain", NULL);
  412. cmDspSysInstallCb( h, gain, "val", ao1p, "gain", NULL);
  413. return kOkDspRC;
  414. }
  415. cmDspRC_t _cmDspSysPgm_PlayFile( cmDspSysH_t h, void** userPtrPtr )
  416. {
  417. bool useBuiltInFl = true;
  418. //const char* fn0 = "media/audio/20110723-Kriesberg/Audio Files/Piano 3_01.wav";
  419. const char* fn0 = "media/audio/sourcetone/Ella & Louis - Under A Blanket Of Blue";
  420. //int beg = 6900826;
  421. //int end = 13512262;
  422. const cmChar_t* fn = cmFsMakeFn(cmFsUserDir(),fn0,NULL,NULL );
  423. cmDspInst_t* ofp = cmDspSysAllocInst(h,"Scalar", "Offset", 5, kNumberDuiId, 0.0, cmDspSysSampleRate(h)*600.0, 1.0, 0.0);
  424. cmDspInst_t* fnp = cmDspSysAllocInst(h,"Fname", NULL, 3, false,"Audio Files (*.wav,*.aiff,*.aif)\tAudio Files (*.{wav,aiff,aif})",fn);
  425. cmDspInst_t* php = cmDspSysAllocInst(h,"Phasor", NULL, 0 );
  426. cmDspInst_t* wtp = cmDspSysAllocInst(h,"WaveTable",NULL, 2, ((int)cmDspSysSampleRate(h)), 1 );
  427. //cmDspInst_t* afp = cmDspSysAllocInst(h,"AudioFileOut",NULL,2,"/home/kevin/temp/record0.aif",1);
  428. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, useBuiltInFl ? 0 : 2 );
  429. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, useBuiltInFl ? 1 : 3 );
  430. cmDspSysConnectAudio(h, php, "out", wtp, "phs" ); // phasor -> wave table
  431. cmDspSysConnectAudio(h, wtp, "out", ao0p, "in" ); // wave table -> audio out
  432. cmDspSysConnectAudio(h, wtp, "out", ao1p, "in" ); //
  433. //cmDspSysConnectAudio(h, wtp, "out", afp, "in0");
  434. cmDspSysInstallCb(h, ofp, "val", wtp, "beg", NULL );
  435. cmDspSysInstallCb(h, fnp, "out", wtp, "fn", NULL);
  436. return kOkDspRC;
  437. }
  438. //------------------------------------------------------------------------------
  439. //)
  440. //( { label:cmDspPgm_MultiOut file_desc:"Play to multiple output channels example program." kw:[spgm] }
  441. cmDspRC_t _cmDspSysPgm_MultiOut( cmDspSysH_t h, void** userPtrPtr )
  442. {
  443. cmDspRC_t rc = kOkDspRC;
  444. double frqHz = 440.0;
  445. unsigned chCnt = 8;
  446. unsigned oneOfN_chCnt = 2;
  447. double offs = 34612504;
  448. cmDspInst_t* aout[chCnt];
  449. unsigned i;
  450. const char* fn0 = "media/audio/20110723-Kriesberg/Audio Files/Piano 3_23.wav";
  451. const cmChar_t* fn = cmFsMakeFn(cmFsUserDir(),fn0,NULL,NULL );
  452. cmDspInst_t* f_phs = cmDspSysAllocInst(h,"Phasor", NULL, 0 );
  453. cmDspInst_t* f_wt = cmDspSysAllocInst(h,"WaveTable",NULL, 2, ((int)cmDspSysSampleRate(h)), 1 );
  454. cmDspInst_t* f_mtr = cmDspSysAllocInst(h,"AMeter", "File Out", 0);
  455. cmDspInst_t* f_rew = cmDspSysAllocInst(h,"Button", "Rewind", 2, kButtonDuiId, 1.0 );
  456. cmDspInst_t* f_pts = cmDspSysAllocInst(h,"PortToSym", NULL, 1, "on" );
  457. cmDspInst_t* f_beg = cmDspSysAllocInst(h,"Scalar", "File Begin", 5, kNumberDuiId, 0.0, cmDspSysSampleRate(h)*6000.0, 1.0, offs);
  458. cmDspInst_t* f_nam = cmDspSysAllocInst(h,"Fname", NULL, 3, false,"Audio Files (*.wav,*.aiff,*.aif)\tAudio Files (*.{wav,aiff,aif})",fn);
  459. cmDspInst_t* s_phs = cmDspSysAllocInst(h,"Phasor", NULL, 2, cmDspSysSampleRate(h), frqHz );
  460. cmDspInst_t* s_wt = cmDspSysAllocInst(h,"WaveTable", NULL, 2, ((int)cmDspSysSampleRate(h)), 4);
  461. cmDspInst_t* s_mtr = cmDspSysAllocInst(h,"AMeter", "Tone Out", 0);
  462. cmDspInst_t* swtch = cmDspSysAllocInst(h,"1ofN", NULL, 2, oneOfN_chCnt, 0 );
  463. for(i=0; i<chCnt; ++i)
  464. aout[i] = cmDspSysAllocInst(h,"AudioOut",NULL, 1, i );
  465. cmDspInst_t* chck = cmDspSysAllocInst(h,"Checkbox", "Source", 5, "Tone","file","tone", 0.0, 1.0);
  466. cmDspInst_t** vol = cmDspSysAllocInstArray(h,chCnt,"Scalar", "Gain", NULL, 5, kNumberDuiId, 0.0, 10.0, 0.01, 0.0 );
  467. // check for allocation errors
  468. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  469. goto errLabel;
  470. cmDspSysConnectAudio( h, s_phs, "out", s_wt, "phs" ); // sine phasor -> wave table
  471. cmDspSysConnectAudio( h, s_wt, "out", s_mtr, "in" ); // sine wave table -> meter
  472. cmDspSysConnectAudio( h, s_wt, "out", swtch, "a-in-1");
  473. cmDspSysConnectAudio( h, f_phs, "out", f_wt, "phs" ); // file phasor -> wave table
  474. cmDspSysConnectAudio( h, f_wt, "out", f_mtr, "in" ); // file wave table -> meter
  475. cmDspSysConnectAudio( h, f_wt, "out", swtch, "a-in-0");
  476. cmDspSysConnectAudio11N1( h, swtch, "a-out", aout, "in", chCnt );
  477. cmDspSysInstallCbN1N1( h, vol, "val", aout, "gain", chCnt );
  478. cmDspSysInstallCb( h, chck, "out", swtch, "chidx", NULL );
  479. cmDspSysInstallCb( h, f_nam, "out", f_wt, "fn", NULL );
  480. cmDspSysInstallCb( h, f_beg, "val", f_wt, "beg", NULL );
  481. cmDspSysInstallCb( h, f_rew, "out", f_pts, "on", NULL );
  482. cmDspSysInstallCb( h, f_pts, "on", f_beg, "send", NULL );
  483. cmDspSysInstallCb( h, f_pts, "on", f_nam, "send", NULL );
  484. cmDspSysInstallCb( h, f_pts, "on", f_wt, "cmd", NULL );
  485. errLabel:
  486. return rc;
  487. }
  488. //------------------------------------------------------------------------------
  489. //)
  490. //( { label:cmDspPgm_MultiIn file_desc:"Multiple audio inputs example program." kw:[spgm] }
  491. cmDspRC_t _cmDspSysPgm_MultiIn(cmDspSysH_t h, void** userPtrPtr)
  492. {
  493. int chCnt = 8;
  494. cmDspInst_t* a[chCnt];
  495. int i;
  496. for(i=0; i<chCnt; ++i)
  497. a[i] = cmDspSysAllocInst( h, "AudioIn", NULL, 1, i );
  498. cmDspInst_t* mxp = cmDspSysAllocInst( h, "AMix", NULL, chCnt+1, chCnt, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0 );
  499. cmDspInst_t* afp = cmDspSysAllocInst( h, "AudioFileOut", NULL, 2,"/home/kevin/temp/at/test_in.aif",1);
  500. cmDspInst_t* aop = cmDspSysAllocInst( h, "AudioOut", NULL, 1, 0 );
  501. // AudioFileOut needs an open message to create the output file
  502. cmDspInst_t* btn = cmDspSysAllocInst( h, "Button", "open", 2, kButtonDuiId, 1.0 );
  503. cmDspSysAssignInstAttrSymbolStr(h, btn, "_reset" );
  504. cmDspInst_t* pts = cmDspSysAllocInst(h,"PortToSym", NULL, 1, "open" );
  505. cmDspSysConnectAudioN11N(h, a, "out", mxp, "in", chCnt );
  506. cmDspSysConnectAudio( h, mxp, "out", afp, "in0" );
  507. cmDspSysConnectAudio( h, mxp, "out", aop, "in" );
  508. cmDspSysInstallCb( h, btn, "sym", pts, "open", NULL );
  509. cmDspSysInstallCb( h, pts, "open", afp, "sel", NULL );
  510. return kOkDspRC;
  511. }
  512. //------------------------------------------------------------------------------
  513. //)
  514. //( { label:cmDspPgm_GateDetect file_desc:"Gate detector example program." kw:[spgm] }
  515. cmDspRC_t _cmDspSysPgm_GateDetect( cmDspSysH_t h, void** userPtrPtr )
  516. {
  517. bool useBuiltInFl = true;
  518. //const char* fn0 = "media/audio/20110723-Kriesberg/Audio Files/Piano 3_01.wav";
  519. //int beg = 6900826;
  520. //int end = 13512262;
  521. //const char* fn0 = "media/audio/McGill-3/1 Audio Track.aiff";
  522. const char* fn0 = "temp/gate_detect0.aif";
  523. int beg = 0;
  524. int end = -1;
  525. const cmChar_t* fn = cmFsMakeFn(cmFsUserDir(),fn0,NULL,NULL );
  526. const cmChar_t* tfn = "/home/kevin/temp/test0.txt";
  527. cmDspInst_t* ofp = cmDspSysAllocInst(h,"Scalar", "Offset", 5, kNumberDuiId, 0.0, cmDspSysSampleRate(h)*600.0, 1.0, 0.0);
  528. //cmDspInst_t* fnp = cmDspSysAllocInst(h,"Fname", NULL, 3, false,"Audio Files (*.wav,*.aiff,*.aif)\tAudio Files (*.{wav,aiff,aif})",fn);
  529. cmDspInst_t* php = cmDspSysAllocInst(h,"Phasor", NULL, 0 );
  530. cmDspInst_t* wtp = cmDspSysAllocInst(h,"WaveTable", NULL, 6, ((int)cmDspSysSampleRate(h)), 1, fn, -1, beg, end );
  531. cmDspInst_t* gdp = cmDspSysAllocInst(h,"GateDetect",NULL, 1, 20.0);
  532. cmDspInst_t* gmp = cmDspSysAllocInst(h,"Meter", NULL, 3, 0.0, 0.0, 1.0);
  533. cmDspInst_t* rmp = cmDspSysAllocInst(h,"Meter", NULL, 3, -100.0, -100.0, 0.0);
  534. cmDspInst_t* txp = cmDspSysAllocInst(h,"TextFile", NULL, 2, 3, tfn);
  535. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, useBuiltInFl ? 0 : 2 );
  536. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, useBuiltInFl ? 1 : 3 );
  537. cmDspSysConnectAudio(h, php, "out", wtp, "phs" ); // phasor -> wave table
  538. cmDspSysConnectAudio(h, wtp, "out", ao0p, "in" ); // wave table -> audio out
  539. cmDspSysConnectAudio(h, wtp, "out", ao1p, "in" ); //
  540. cmDspSysConnectAudio(h, wtp, "out", gdp, "in" );
  541. cmDspSysInstallCb(h, ofp, "val", wtp, "beg", NULL );
  542. cmDspSysInstallCb(h, gdp, "gate", gmp, "in", NULL );
  543. cmDspSysInstallCb(h, gdp, "rms", rmp, "in", NULL );
  544. cmDspSysInstallCb(h, gdp, "gate", txp, "in-0", NULL);
  545. cmDspSysInstallCb(h, gdp, "rms", txp, "in-1", NULL);
  546. cmDspSysInstallCb(h, gdp, "mean", txp, "in-2", NULL);
  547. return kOkDspRC;
  548. }
  549. //------------------------------------------------------------------------------
  550. //)
  551. //( { label:cmDspPgm_Record file_desc:"Record audio to an audio file." kw:[spgm] }
  552. cmDspRC_t _cmDspSysPgm_Record(cmDspSysH_t h, void** userPtrPtr)
  553. {
  554. int chCnt = 8;
  555. cmDspInst_t* a[chCnt];
  556. int i;
  557. for(i=0; i<chCnt; ++i)
  558. a[i] = cmDspSysAllocInst( h, "AudioIn", NULL, 1, i );
  559. cmDspInst_t* mxp = cmDspSysAllocInst( h, "AMix", NULL, chCnt+1, chCnt, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0 );
  560. cmDspInst_t* afp = cmDspSysAllocInst( h, "AudioFileOut", NULL, 2,"/home/kevin/temp/gate_detect.aif",1);
  561. cmDspInst_t* aop = cmDspSysAllocInst( h, "AudioOut", NULL, 1, 0 );
  562. cmDspInst_t* txp = cmDspSysAllocInst( h, "TextFile", NULL, 2, 1, "/home/kevin/temp/gate_detect.txt");
  563. cmDspInst_t* chp = cmDspSysAllocInst( h, "Scalar", "Channel", 5, kNumberDuiId, 0.0, 7.0, 1.0, 0.0);
  564. // AudioFileOut needs an open message to create the output file
  565. cmDspInst_t* btn = cmDspSysAllocInst( h, "Button", "open", 2, kButtonDuiId, 1.0 );
  566. cmDspSysAssignInstAttrSymbolStr(h, btn, "_reset" );
  567. cmDspInst_t* pts = cmDspSysAllocInst(h,"PortToSym", NULL, 1, "open" );
  568. for(i=0; i<chCnt; ++i)
  569. {
  570. cmChar_t lbl[15];
  571. snprintf(lbl,15,"in-%i",i);
  572. cmDspSysConnectAudio(h,a[i], "out", mxp, lbl);
  573. }
  574. cmDspSysConnectAudio(h, mxp, "out", afp, "in0" );
  575. cmDspSysConnectAudio(h, mxp, "out", aop, "in" );
  576. cmDspSysInstallCb(h, chp, "out", txp, "in-0", NULL);
  577. cmDspSysInstallCb( h, btn, "sym", pts, "open", NULL );
  578. cmDspSysInstallCb( h, pts, "open", afp, "sel", NULL );
  579. return kOkDspRC;
  580. }
  581. //------------------------------------------------------------------------------
  582. //)
  583. //( { label:cmDspPgm_FtRecord file_desc:"Record streaming audio input to an audio file." kw:[spgm] }
  584. cmDspRC_t _cmDspSysPgm_RtRecord(cmDspSysH_t h, void** userPtrPtr)
  585. {
  586. cmDspInst_t* ai0 = cmDspSysAllocInst( h, "AudioIn", NULL, 1, 0 );
  587. cmDspInst_t* ai1 = cmDspSysAllocInst( h, "AudioIn", NULL, 1, 1 );
  588. cmDspInst_t* afp = cmDspSysAllocInst( h, "AudioFileOut", NULL, 2,"/Users/kevin/temp/test.aif",2);
  589. cmDspInst_t* ao0 = cmDspSysAllocInst( h, "AudioOut", NULL, 1, 2 );
  590. cmDspInst_t* ao1 = cmDspSysAllocInst( h, "AudioOut", NULL, 1, 3 );
  591. // AudioFileOut needs an open message to create the output file
  592. cmDspInst_t* btn = cmDspSysAllocInst( h, "Button", "open", 2, kButtonDuiId, 1.0 );
  593. cmDspSysAssignInstAttrSymbolStr(h, btn, "_reset" );
  594. cmDspInst_t* pts = cmDspSysAllocInst(h,"PortToSym", NULL, 1, "open" );
  595. cmDspSysConnectAudio(h,ai0, "out", afp, "in0");
  596. cmDspSysConnectAudio(h,ai1, "out", afp, "in1");
  597. cmDspSysConnectAudio(h,ai0, "out", ao0, "in");
  598. cmDspSysConnectAudio(h,ai1, "out", ao1, "in");
  599. cmDspSysInstallCb( h, btn, "sym", pts, "open", NULL );
  600. cmDspSysInstallCb( h, pts, "open", afp, "sel", NULL );
  601. return kOkDspRC;
  602. }
  603. //------------------------------------------------------------------------------
  604. //)
  605. //( { label:cmDspPgm_PitchShift file_desc:"Pitch-shifter example program." kw:[spgm] }
  606. cmDspRC_t _cmDspSysPgm_PitchShiftFile( cmDspSysH_t h, void** userPtrPtr )
  607. {
  608. bool useBuiltInFl = true;
  609. const cmChar_t* fn0 = "media/audio/20110723-Kriesberg/Audio Files/Piano 3_01.wav";
  610. const cmChar_t* fn1 = "temp/record0.aif";
  611. int beg = 6900826;
  612. int end = 13512262;
  613. const cmChar_t* fn = cmFsMakeFn(cmFsUserDir(),fn0,NULL,NULL );
  614. const cmChar_t* ofn = cmFsMakeFn(cmFsUserDir(),fn1,NULL,NULL );
  615. cmDspInst_t* rt0p = cmDspSysAllocInst(h,"Scalar", "Ratio 0", 5, kNumberDuiId, 0.01, 10.0, 0.01, 1.0);
  616. cmDspInst_t* rt1p = cmDspSysAllocInst(h,"Scalar", "Ratio 1", 5, kNumberDuiId, 0.01, 10.0, 0.01, 1.0);
  617. cmDspInst_t* ofp = cmDspSysAllocInst(h,"Scalar", "Offset", 5, kNumberDuiId, 0.0, cmDspSysSampleRate(h)*600.0, 1.0, 0.0);
  618. //cmDspInst_t* fnp = cmDspSysAllocInst(h,"Fname", NULL, 3, false,"Audio Files (*.wav,*.aiff,*.aif)\tAudio Files (*.{wav,aiff,aif})",fn);
  619. cmDspInst_t* php = cmDspSysAllocInst(h,"Phasor", NULL, 0 );
  620. cmDspInst_t* wtp = cmDspSysAllocInst(h,"WaveTable",NULL, 6, ((int)cmDspSysSampleRate(h)), 1, fn, -1, beg, end );
  621. cmDspInst_t* afp = cmDspSysAllocInst(h,"AudioFileOut",NULL,2,ofn,1);
  622. cmDspInst_t* ps0p = cmDspSysAllocInst(h,"PShift", NULL, 0 );
  623. cmDspInst_t* ps1p = cmDspSysAllocInst(h,"PShift", NULL, 0 );
  624. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, useBuiltInFl ? 0 : 2 );
  625. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, useBuiltInFl ? 1 : 3 );
  626. cmDspSysConnectAudio(h, php, "out", wtp, "phs" ); // phasor -> wave table
  627. cmDspSysConnectAudio(h, wtp, "out", ps0p, "in" ); // wave table -> shift
  628. cmDspSysConnectAudio(h, wtp, "out", ps1p, "in" ); //
  629. cmDspSysConnectAudio(h, ps0p, "out", ao0p, "in" ); // shift -> audio out
  630. cmDspSysConnectAudio(h, ps1p, "out", ao1p, "in" ); //
  631. cmDspSysConnectAudio(h, ps0p, "out", afp, "in0"); //
  632. cmDspSysInstallCb(h, ofp, "val", wtp, "beg", NULL );
  633. //cmDspSysInstallCb(h, fnp, "out", wtp, "fn", NULL);
  634. cmDspSysInstallCb(h, rt0p, "val", ps0p, "ratio", NULL);
  635. cmDspSysInstallCb(h, rt1p, "val", ps1p, "ratio", NULL);
  636. return kOkDspRC;
  637. }
  638. //------------------------------------------------------------------------------
  639. //)
  640. //( { label:cmDspPgm_LoopRecd file_desc:"Loop-recorder example program." kw:[spgm] }
  641. cmDspRC_t _cmDspSysPgm_LoopRecd( cmDspSysH_t h, void** userPtrPtr )
  642. {
  643. bool useBuiltInFl = true;
  644. const cmChar_t* fn0 = "media/audio/20110723-Kriesberg/Audio Files/Piano 3_01.wav";
  645. const cmChar_t* fn = cmFsMakeFn(cmFsUserDir(),fn0,NULL,NULL );
  646. int beg = 6900826;
  647. int end = 13512262;
  648. cmDspInst_t* rfl = cmDspSysAllocInst(h,"Button", "Recd", 2, kCheckDuiId, 0.0 );
  649. cmDspInst_t* pfl = cmDspSysAllocInst(h,"Button", "Play", 2, kButtonDuiId, 1.0 );
  650. cmDspInst_t* rtp = cmDspSysAllocInst(h,"Scalar", "Ratio", 5, kNumberDuiId, 0.0, 10.0, 0.01, 1.0 );
  651. cmDspInst_t* ofp = cmDspSysAllocInst(h,"Scalar", "Offset", 5, kNumberDuiId, 0.0, cmDspSysSampleRate(h)*600.0, 1.0, 0.0);
  652. //cmDspInst_t* fnp = cmDspSysAllocInst(h,"Fname", NULL, 3, false,"Audio Files (*.wav,*.aiff,*.aif)\tAudio Files (*.{wav,aiff,aif})",fn);
  653. cmDspInst_t* php = cmDspSysAllocInst(h,"Phasor", NULL, 0 );
  654. cmDspInst_t* wtp = cmDspSysAllocInst(h,"WaveTable",NULL, 6, ((int)cmDspSysSampleRate(h)), 1, fn, -1, beg, end );
  655. //cmDspInst_t* afp = cmDspSysAllocInst(h,"AudioFileOut",NULL,2,"/home/kevin/temp/record0.aif",1);
  656. cmDspInst_t* lrp = cmDspSysAllocInst(h,"LoopRecd", NULL, 0 );
  657. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, useBuiltInFl ? 0 : 2 );
  658. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, useBuiltInFl ? 1 : 3 );
  659. cmDspSysConnectAudio(h, php, "out", wtp, "phs" ); // phasor -> wave table
  660. cmDspSysConnectAudio(h, wtp, "out", lrp, "in" ); // wave table -> shift
  661. cmDspSysConnectAudio(h, lrp, "out", ao0p, "in" ); // shift -> audio out
  662. cmDspSysConnectAudio(h, wtp, "out", ao1p, "in" );
  663. cmDspSysInstallCb(h, ofp, "val", wtp, "beg", NULL );
  664. //cmDspSysInstallCb(h, fnp, "out", wtp, "fn", NULL);
  665. cmDspSysInstallCb(h, rfl, "out", lrp, "recd", NULL);
  666. cmDspSysInstallCb(h, pfl, "out", lrp, "play", NULL);
  667. cmDspSysInstallCb(h, rtp, "val", lrp, "ratio",NULL);
  668. return kOkDspRC;
  669. }
  670. //------------------------------------------------------------------------------
  671. //)
  672. //( { label:cmDspPgm_UiTest file_desc:"User Interface example program." kw:[spgm] }
  673. cmDspRC_t _cmDspSysPgm_UiTest(cmDspSysH_t h, void** userPtrPtr )
  674. {
  675. cmDspRC_t rc = kOkDspRC;
  676. cmDspInst_t* mdp = cmDspSysAllocInst(h,"Scalar", "Mode", 5, kNumberDuiId, 0.0, 4.0, 1.0, 1.0);
  677. cmDspInst_t* wsp = cmDspSysAllocInst(h,"MsgList","wndSmpCnt", 3, "wndSmpCnt", NULL, 2);
  678. cmDspInst_t* hfp = cmDspSysAllocInst(h,"MsgList","hopFact", 3, "hopFact", NULL, 2);
  679. cmDspInst_t* thp = cmDspSysAllocInst(h,"Scalar", "threshold", 5, kNumberDuiId, 0.0, 1.0, 0.01, 0.5 );
  680. cmDspInst_t* trp = cmDspSysAllocInst(h,"Scalar", "target", 5, kNumberDuiId, 0.0, 1.0, 0.01, 0.5 );
  681. cmDspInst_t* btn = cmDspSysAllocInst(h,"Button", "btn", 2, kButtonDuiId, 12.3 );
  682. cmDspInst_t* chk = cmDspSysAllocInst(h,"Button", "check", 2, kCheckDuiId, 0 );
  683. cmDspInst_t* chb = cmDspSysAllocInst(h,"Checkbox","checkbox", 5, "Checker","up","down", 2.0, 1.0);
  684. cmDspInst_t* txt = cmDspSysAllocInst(h,"Text", "text", 1, "Hello" );
  685. cmDspInst_t* prp = cmDspSysAllocInst(h,"Printer", NULL, 1, ">" );
  686. cmDspInst_t* mtp = cmDspSysAllocInst(h,"Meter", "meter", 3, 0.0, 0.0, 4.0);
  687. cmDspInst_t* ctp = cmDspSysAllocInst(h,"Counter", NULL, 3, 0.0, 10.0, 1.0 );
  688. cmDspInst_t* lbl = cmDspSysAllocInst(h,"Label", "label1", 1, "label2");
  689. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  690. return rc;
  691. cmDspSysInstallCb(h, mdp, "val", thp, "val", NULL );
  692. cmDspSysInstallCb(h, mdp, "val", prp, "in", NULL );
  693. cmDspSysInstallCb(h, wsp, "out", prp, "in", NULL );
  694. cmDspSysInstallCb(h, hfp, "out", prp, "in", NULL );
  695. cmDspSysInstallCb(h, trp, "val", prp, "in", NULL );
  696. cmDspSysInstallCb(h, btn, "out", prp, "in", NULL );
  697. cmDspSysInstallCb(h, chk, "out", prp, "in", NULL );
  698. cmDspSysInstallCb(h, ctp, "out", prp, "in", NULL );
  699. cmDspSysInstallCb(h, mdp, "val", btn, "in", NULL );
  700. cmDspSysInstallCb(h, thp, "val", mtp, "in", NULL );
  701. cmDspSysInstallCb(h, thp, "val", trp, "val", NULL );
  702. cmDspSysInstallCb(h, btn, "sym", prp, "in", NULL );
  703. cmDspSysInstallCb(h, btn, "out", ctp, "next", NULL );
  704. cmDspSysInstallCb(h, txt, "val", prp, "in", NULL );
  705. cmDspSysInstallCb(h, chb, "out", prp, "in", NULL );
  706. cmDspSysInstallCb(h, chb, "sym", prp, "in", NULL );
  707. cmDspSysInstallCb(h, mdp, "val", lbl, "in", NULL );
  708. return rc;
  709. }
  710. //------------------------------------------------------------------------------
  711. //)
  712. //( { label:cmDspPgm_Xfade file_desc:"Cross fader example program." kw:[spgm] }
  713. cmDspRC_t _cmDspSysPgm_Xfade( cmDspSysH_t h, void** userPtrPtr )
  714. {
  715. cmDspRC_t rc = kOkDspRC;
  716. unsigned leftChIdx = 2;
  717. unsigned rightChIdx = 3;
  718. unsigned chCnt = 2;
  719. double xfadeMs = 1000; // cross fade time
  720. double sgHz = 500;
  721. unsigned sgShapeId = 1;
  722. double sgGain = 0.5;
  723. cmDspInst_t* sg = cmDspSysAllocInst( h, "SigGen", NULL, 3, sgHz, sgShapeId, sgGain );
  724. cmDspInst_t* xfp = cmDspSysAllocInst(h,"Xfader", NULL, 2, chCnt, xfadeMs );
  725. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, leftChIdx );
  726. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, rightChIdx );
  727. cmDspInst_t* im0p = cmDspSysAllocInst(h,"AMeter","In 0", 0);
  728. cmDspInst_t* im1p = cmDspSysAllocInst(h,"AMeter","In 1", 0);
  729. cmDspInst_t* om0p = cmDspSysAllocInst(h,"AMeter","Out 0", 0);
  730. cmDspInst_t* om1p = cmDspSysAllocInst(h,"AMeter","Out 1", 0);
  731. cmDspInst_t* mstr = cmDspSysAllocInst(h,"Button", "Mstr", 2, kCheckDuiId, 0.0 );
  732. cmDspInst_t* btn0 = cmDspSysAllocInst(h,"Button", "Fade 0", 2, kCheckDuiId, 0.0 );
  733. cmDspInst_t* btn1 = cmDspSysAllocInst(h,"Button", "Fade 1", 2, kCheckDuiId, 1.0 );
  734. cmDspInst_t* gm0p = cmDspSysAllocInst(h,"Meter","Gain 0", 3, 0.0, 0.0, 1.0);
  735. cmDspInst_t* gm1p = cmDspSysAllocInst(h,"Meter","Gain 1", 3, 0.0, 0.0, 1.0);
  736. cmDspInst_t* pon = cmDspSysAllocInst(h,"Printer", NULL, 1, "on:" );
  737. cmDspInst_t* pof = cmDspSysAllocInst(h,"Printer", NULL, 1, "off:" );
  738. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  739. return rc;
  740. cmDspSysConnectAudio(h, sg, "out", im0p, "in"); // ain -> meter
  741. cmDspSysConnectAudio(h, sg, "out", im1p, "in"); //
  742. cmDspSysConnectAudio(h, sg, "out", xfp, "in-0"); // ain -> xfader
  743. cmDspSysConnectAudio(h, sg, "out", xfp, "in-1");
  744. cmDspSysConnectAudio(h, xfp, "out-0", om0p, "in" ); // xfade -> meter
  745. cmDspSysConnectAudio(h, xfp, "out-1", om1p, "in" ); //
  746. cmDspSysConnectAudio(h, xfp, "out-0", ao0p, "in" ); // xfade -> aout
  747. cmDspSysConnectAudio(h, xfp, "out-1", ao1p, "in" ); //
  748. cmDspSysInstallCb(h, btn0, "out", xfp, "gate-0", NULL ); // check -> xfade gate
  749. cmDspSysInstallCb(h, btn1, "out", xfp, "gate-1", NULL );
  750. cmDspSysInstallCb(h, mstr, "out", xfp, "mgate", NULL );
  751. cmDspSysInstallCb(h, xfp, "gain-0", gm0p, "in", NULL );
  752. cmDspSysInstallCb(h, xfp, "gain-1", gm1p, "in", NULL );
  753. cmDspSysInstallCb(h, xfp, "on", pon, "in", NULL );
  754. cmDspSysInstallCb(h, xfp, "off", pof, "in", NULL );
  755. return cmDspSysLastRC(h);
  756. }
  757. //------------------------------------------------------------------------------
  758. //)
  759. //( { label:cmDspPgm_Pgm6 file_desc:"Stereo strectral non-linear distortion example." kw:[spgm] }
  760. cmDspRC_t _cmDspSysPgm6( cmDspSysH_t h, void* audioDir )
  761. {
  762. cmDspRC_t rc = kOkDspRC;
  763. int wndSmpCnt = 2048;
  764. int hopFact = 4;
  765. //const char* afDir = "/Volumes/LaTetra0/media/audio/20110723-Kriesberg/Audio Files";
  766. //const char* afDir = "/Users/administrator/Documents/kc";
  767. const char* afDir = "/home/kevin/media/audio/20110723-Kriesberg/Audio Files";
  768. cmDspInst_t* ph0p = cmDspSysAllocInst(h,"Phasor", NULL, 0 );
  769. cmDspInst_t* wt0p = cmDspSysAllocInst(h,"WaveTable",NULL, 0 );
  770. cmDspInst_t* ro0p = cmDspSysAllocInst(h,"Reorder", NULL, 5, 3, 2, 0, 1, 2 );
  771. cmDspInst_t* kr0p = cmDspSysAllocInst(h,"Kr", NULL, 2, wndSmpCnt, hopFact );
  772. cmDspInst_t* kr1p = cmDspSysAllocInst(h,"Kr", NULL, 2, wndSmpCnt, hopFact );
  773. cmDspInst_t* prp = cmDspSysAllocInst(h,"Printer", NULL, 0 );
  774. bool useBuiltInFl = true;
  775. // MOTU Traveler: Use channels 2&3 (out plugs:3&4) because 0&1 do not show up on plugs 1&2.
  776. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, useBuiltInFl ? 0 : 2 );
  777. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, useBuiltInFl ? 1 : 3 );
  778. // BUG: If audio inputs are not connected a 'not an audio buffer' msg is generated.
  779. // This is a problem with type determination in the cmDspClass related code : see cmDspClass.c 833
  780. // for a place that this error would be thrown in the following audio outputs were not connected
  781. // to audio sources.
  782. cmDspInst_t* ao2p = NULL;
  783. cmDspInst_t* ao3p = NULL;
  784. if( !useBuiltInFl )
  785. {
  786. ao2p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 4 );
  787. ao3p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 5 );
  788. }
  789. cmDspInst_t* al0p = cmDspSysAllocInst(h,"MsgList","audFiles", 2, "audFiles",NULL);
  790. cmDspInst_t* fl0p = cmDspSysAllocInst(h,"MsgList","audFragsA", 2, "audFrags",NULL);
  791. cmDspInst_t* fn0p = cmDspSysAllocInst(h,"Sprintf","filename", 1, "%s/%s_%02i.wav");
  792. cmDspInst_t* md0p = cmDspSysAllocInst(h,"Scalar", "Mode", 5, kNumberDuiId, 0.0, 4.0, 1.0, 1.0);
  793. cmDspInst_t* ws0p = cmDspSysAllocInst(h,"MsgList","wndSmpCnt", 3, "wndSmpCnt", NULL, 2);
  794. cmDspInst_t* hf0p = cmDspSysAllocInst(h,"MsgList","hopFact", 3, "hopFact", NULL, 2);
  795. cmDspInst_t* th0p = cmDspSysAllocInst(h,"Scalar", "threshold", 5, kNumberDuiId, 0.0, 100.0, 1.0, 60.0 );
  796. cmDspInst_t* us0p = cmDspSysAllocInst(h,"Scalar", "upr slope", 5, kNumberDuiId, 0.0, 10.0, 0.01, 0.0 );
  797. cmDspInst_t* ls0p = cmDspSysAllocInst(h,"Scalar", "lwr slope", 5, kNumberDuiId, 0.3, 10.0, 0.01, 2.0 );
  798. cmDspInst_t* of0p = cmDspSysAllocInst(h,"Scalar", "offset", 5, kNumberDuiId, 0.0, 100.0, 0.01, 30.0 );
  799. cmDspInst_t* iv0p = cmDspSysAllocInst(h,"Scalar", "invert", 5, kNumberDuiId, 0.0, 1.0, 1.0, 0.0 );
  800. cmDspSysNewColumn(h,0);
  801. //cmDspInst_t* al1p = cmDspSysAllocInst(h,"MsgList","audFiles", 2, "audFiles",NULL);
  802. //cmDspInst_t* fl1p = cmDspSysAllocInst(h,"MsgList","audFrags1", 2, "audFrags",NULL);
  803. //cmDspInst_t* fn1p = cmDspSysAllocInst(h,"Sprintf","filename", 1, "%s/%s_%02i.wav");
  804. cmDspInst_t* md1p = cmDspSysAllocInst(h,"Scalar", "Mode", 5, kNumberDuiId, 0.0, 4.0, 1.0, 1.0);
  805. cmDspInst_t* ws1p = cmDspSysAllocInst(h,"MsgList","wndSmpCnt", 3, "wndSmpCnt", NULL, 2);
  806. cmDspInst_t* hf1p = cmDspSysAllocInst(h,"MsgList","hopFact", 3, "hopFact", NULL, 2);
  807. cmDspInst_t* th1p = cmDspSysAllocInst(h,"Scalar", "threshold", 5, kNumberDuiId, 0.0, 100.0, 1.0, 60.0 );
  808. cmDspInst_t* us1p = cmDspSysAllocInst(h,"Scalar", "upr slope", 5, kNumberDuiId, 0.0, 10.0, 0.01, 0.0 );
  809. cmDspInst_t* ls1p = cmDspSysAllocInst(h,"Scalar", "lwr slope", 5, kNumberDuiId, 0.3, 10.0, 0.01, 2.0 );
  810. cmDspInst_t* of1p = cmDspSysAllocInst(h,"Scalar", "offset", 5, kNumberDuiId, 0.0, 100.0, 0.01, 30.0 );
  811. cmDspInst_t* iv1p = cmDspSysAllocInst(h,"Scalar", "invert", 5, kNumberDuiId, 0.0, 1.0, 1.0, 0.0 );
  812. cmDspSysNewColumn(h,0);
  813. cmDspInst_t* dnp = cmDspSysAllocInst(h,"Fname", "audDir", 3, true,NULL,afDir);
  814. cmDspInst_t* mtp = cmDspSysAllocInst(h,"Meter","MyMeter", 3, 50.0, 0.0, 100.0);
  815. cmDspInst_t* atp = cmDspSysAllocInst(h,"AMeter","Audio Meter",0);
  816. if( (rc = cmDspSysLastRC(h)) != kOkDspRC )
  817. return rc;
  818. cmDspSysConnectAudio(h, ph0p, "out", wt0p, "phs"); // phasor->wt:phs
  819. cmDspSysConnectAudio(h, wt0p, "out", kr0p, "in"); // wt->kr
  820. cmDspSysConnectAudio(h, kr0p, "out", ao0p, "in"); // kr->aout- 0
  821. cmDspSysConnectAudio(h, wt0p, "out", kr1p, "in"); // wt->kr
  822. cmDspSysConnectAudio(h, kr1p, "out", ao1p, "in"); // kr->aout - 1
  823. if( ao2p != NULL )
  824. cmDspSysConnectAudio(h, wt0p,"out", ao2p, "in"); // wt->aout - 2
  825. if( ao3p != NULL )
  826. cmDspSysConnectAudio(h, wt0p,"out", ao3p, "in"); // wt->aout - 3
  827. cmDspSysConnectAudio(h, wt0p,"out", atp, "in"); // wt->meter
  828. cmDspSysInstallCb(h, ws0p, "out", kr0p, "wndn", NULL ); // wndSmpCnt->kr
  829. cmDspSysInstallCb(h, hf0p, "out", kr0p, "hopf", NULL ); // hopFact->kr
  830. cmDspSysInstallCb(h, md0p, "val", kr0p, "mode", NULL ); // mode->kr
  831. cmDspSysInstallCb(h, th0p, "val", kr0p, "thrh", NULL ); // thresh->kr
  832. cmDspSysInstallCb(h, ls0p, "val", kr0p, "lwrs", NULL ); // lwrSlope->kr
  833. cmDspSysInstallCb(h, us0p, "val", kr0p, "uprs", NULL ); // uprSlope->kr
  834. cmDspSysInstallCb(h, of0p, "val", kr0p, "offs", NULL ); // offset->kr
  835. cmDspSysInstallCb(h, iv0p, "val", kr0p, "invt", NULL ); // invert->kr
  836. cmDspSysInstallCb(h, th0p, "val", mtp, "in", NULL );
  837. cmDspSysInstallCb(h, ws1p, "out", kr1p, "wndn", NULL ); // wndSmpCnt->kr
  838. cmDspSysInstallCb(h, hf1p, "out", kr1p, "hopf", NULL ); // hopFact->kr
  839. cmDspSysInstallCb(h, md1p, "val", kr1p, "mode", NULL ); // mode->kr
  840. cmDspSysInstallCb(h, th1p, "val", kr1p, "thrh", NULL ); // thresh->kr
  841. cmDspSysInstallCb(h, ls1p, "val", kr1p, "lwrs", NULL ); // lwrSlope->kr
  842. cmDspSysInstallCb(h, us1p, "val", kr1p, "uprs", NULL ); // uprSlope->kr
  843. cmDspSysInstallCb(h, of1p, "val", kr1p, "offs", NULL ); // offset->kr
  844. cmDspSysInstallCb(h, iv1p, "val", kr1p, "invt", NULL ); // invert->kr
  845. cmDspSysInstallCb(h, dnp, "out", fn0p, "in-0", NULL); // dir->fn:0
  846. cmDspSysInstallCb(h, al0p, "out", fn0p, "in-1", NULL ); // fn->fn:1
  847. cmDspSysInstallCb(h, fl0p, "take", fn0p, "in-2", NULL ); // take->fn:2
  848. cmDspSysInstallCb(h, fn0p, "out", ro0p, "in-0", NULL); // fn->print
  849. cmDspSysInstallCb(h, fl0p, "beg", ro0p, "in-1", NULL); //
  850. cmDspSysInstallCb(h, fl0p, "end", ro0p, "in-2", NULL); //
  851. cmDspSysInstallCb(h, ro0p, "out-0", wt0p, "fn", NULL ); // fn->wt:fn
  852. cmDspSysInstallCb(h, ro0p, "out-1", wt0p, "beg", NULL ); // beg->wt:beg
  853. cmDspSysInstallCb(h, ro0p, "out-2", wt0p, "end", NULL ); // end->wt:end
  854. cmDspSysInstallCb(h, ro0p, "out-1", prp, "in", NULL ); //
  855. //cmDspSysInstallCb(h, dnp, "out", fn1p, "in-0", NULL); // dir->fn:0
  856. //cmDspSysInstallCb(h, al1p, "out", fn1p, "in-1", NULL ); // fn->fn:1
  857. //cmDspSysInstallCb(h, fl1p, "take", fn1p, "in-2", NULL ); // take->fn:2
  858. //cmDspSysInstallCb(h, fn1p, "out", ro1p, "in-0", NULL); // fn->print
  859. //cmDspSysInstallCb(h, fl1p, "beg", ro1p, "in-1", NULL); //
  860. //cmDspSysInstallCb(h, fl1p, "end", ro1p, "in-2", NULL); //
  861. //cmDspSysInstallCb(h, ro1p, "out-0", wt1p, "fn", NULL ); // fn->wt:fn
  862. //cmDspSysInstallCb(h, ro1p, "out-1", wt1p, "beg", NULL ); // beg->wt:beg
  863. //cmDspSysInstallCb(h, ro1p, "out-2", wt1p, "end", NULL ); // end->wt:end
  864. return cmDspSysLastRC(h);
  865. }
  866. //------------------------------------------------------------------------------
  867. //)
  868. //( { label:cmDspPgm_Guitar file_desc:"Similiar to Pgm6." kw:[spgm] }
  869. cmDspRC_t _cmDspSysPgmGuitar( cmDspSysH_t h, void** userPtrPtr )
  870. {
  871. cmDspRC_t rc = kOkDspRC;
  872. int wndSmpCnt = 2048;
  873. int hopFact = 4;
  874. const char* afDir = "/Volumes/LaTetra0/media/audio/20110723-Kriesberg/Audio Files";
  875. //const char* afDir = "/Users/administrator/Documents/kc";
  876. cmDspInst_t* ph0p = cmDspSysAllocInst(h,"Phasor", NULL, 0 );
  877. cmDspInst_t* wt0p = cmDspSysAllocInst(h,"WaveTable",NULL, 0 );
  878. cmDspInst_t* ro0p = cmDspSysAllocInst(h,"Reorder", NULL, 5, 3, 2, 0, 1, 2 );
  879. cmDspInst_t* kr0p = cmDspSysAllocInst(h,"Kr", NULL, 2, wndSmpCnt, hopFact );
  880. cmDspInst_t* kr1p = cmDspSysAllocInst(h,"Kr", NULL, 2, wndSmpCnt, hopFact );
  881. cmDspInst_t* prp = cmDspSysAllocInst(h,"Printer", NULL, 0 );
  882. bool useBuiltInFl = true;
  883. // MOTU Traveler: Use channels 2&3 (out plugs:3&4) because 0&1 do not show up on plugs 1&2.
  884. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, useBuiltInFl ? 0 : 2 );
  885. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, useBuiltInFl ? 1 : 3 );
  886. // BUG: If audio inputs are not connected a 'not an audio buffer' msg is generated.
  887. // This is a problem with type determination in the cmDspClass related code : see cmDspClass.c 833
  888. // for a place that this error would be thrown in the following audio outputs were not connected
  889. // to audio sources.
  890. cmDspInst_t* ao2p = NULL;
  891. cmDspInst_t* ao3p = NULL;
  892. if( !useBuiltInFl )
  893. {
  894. ao2p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 4 );
  895. ao3p = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 5 );
  896. }
  897. cmDspInst_t* al0p = cmDspSysAllocInst(h,"MsgList","audFiles", 2, "audFiles",NULL);
  898. cmDspInst_t* fl0p = cmDspSysAllocInst(h,"MsgList","audFragsA", 2, "audFrags",NULL);
  899. cmDspInst_t* fn0p = cmDspSysAllocInst(h,"Sprintf","filename", 1, "%s/%s_%02i.wav");
  900. cmDspInst_t* md0p = cmDspSysAllocInst(h,"Scalar", "Mode", 5, kNumberDuiId, 0.0, 4.0, 1.0, 1.0);
  901. cmDspInst_t* ws0p = cmDspSysAllocInst(h,"MsgList","wndSmpCnt", 3, "wndSmpCnt", NULL, 2);
  902. cmDspInst_t* hf0p = cmDspSysAllocInst(h,"MsgList","hopFact", 3, "hopFact", NULL, 2);
  903. cmDspInst_t* th0p = cmDspSysAllocInst(h,"Scalar", "threshold", 5, kNumberDuiId, 0.0, 100.0, 1.0, 60.0 );
  904. cmDspInst_t* us0p = cmDspSysAllocInst(h,"Scalar", "upr slope", 5, kNumberDuiId, 0.0, 10.0, 0.01, 0.0 );
  905. cmDspInst_t* ls0p = cmDspSysAllocInst(h,"Scalar", "lwr slope", 5, kNumberDuiId, 0.3, 10.0, 0.01, 2.0 );
  906. cmDspInst_t* of0p = cmDspSysAllocInst(h,"Scalar", "offset", 5, kNumberDuiId, 0.0, 100.0, 0.01, 30.0 );
  907. cmDspInst_t* iv0p = cmDspSysAllocInst(h,"Scalar", "invert", 5, kNumberDuiId, 0.0, 1.0, 1.0, 0.0 );
  908. cmDspSysNewColumn(h,0);
  909. //cmDspInst_t* al1p = cmDspSysAllocInst(h,"MsgList","audFiles", 2, "audFiles",NULL);
  910. //cmDspInst_t* fl1p = cmDspSysAllocInst(h,"MsgList","audFrags1", 2, "audFrags",NULL);
  911. //cmDspInst_t* fn1p = cmDspSysAllocInst(h,"Sprintf","filename", 1, "%s/%s_%02i.wav");
  912. cmDspInst_t* md1p = cmDspSysAllocInst(h,"Scalar", "Mode", 5, kNumberDuiId, 0.0, 4.0, 1.0, 1.0);
  913. cmDspInst_t* ws1p = cmDspSysAllocInst(h,"MsgList","wndSmpCnt", 3, "wndSmpCnt", NULL, 2);
  914. cmDspInst_t* hf1p = cmDspSysAllocInst(h,"MsgList","hopFact", 3, "hopFact", NULL, 2);
  915. cmDspInst_t* th1p = cmDspSysAllocInst(h,"Scalar", "threshold", 5, kNumberDuiId, 0.0, 100.0, 1.0, 60.0 );
  916. cmDspInst_t* us1p = cmDspSysAllocInst(h,"Scalar", "upr slope", 5, kNumberDuiId, 0.0, 10.0, 0.01, 0.0 );
  917. cmDspInst_t* ls1p = cmDspSysAllocInst(h,"Scalar", "lwr slope", 5, kNumberDuiId, 0.3, 10.0, 0.01, 2.0 );
  918. cmDspInst_t* of1p = cmDspSysAllocInst(h,"Scalar", "offset", 5, kNumberDuiId, 0.0, 100.0, 0.01, 30.0 );
  919. cmDspInst_t* iv1p = cmDspSysAllocInst(h,"Scalar", "invert", 5, kNumberDuiId, 0.0, 1.0, 1.0, 0.0 );
  920. cmDspSysNewColumn(h,0);
  921. cmDspInst_t* dnp = cmDspSysAllocInst(h,"Fname", "audDir", 3, true,NULL,afDir);
  922. cmDspInst_t* mtp = cmDspSysAllocInst(h,"Meter","MyMeter", 3, 50.0, 0.0, 100.0);
  923. cmDspInst_t* atp = cmDspSysAllocInst(h,"AMeter","Audio Meter",0);
  924. if( (rc = cmDspSysLastRC(h)) != kOkDspRC )
  925. return rc;
  926. cmDspSysConnectAudio(h, ph0p, "out", wt0p, "phs"); // phasor->wt:phs
  927. cmDspSysConnectAudio(h, wt0p, "out", kr0p, "in"); // wt->kr
  928. cmDspSysConnectAudio(h, kr0p, "out", ao0p, "in"); // kr->aout- 0
  929. cmDspSysConnectAudio(h, wt0p, "out", kr1p, "in"); // wt->kr
  930. cmDspSysConnectAudio(h, kr1p, "out", ao1p, "in"); // kr->aout - 1
  931. if( ao2p != NULL )
  932. cmDspSysConnectAudio(h, wt0p,"out", ao2p, "in"); // wt->aout - 2
  933. if( ao3p != NULL )
  934. cmDspSysConnectAudio(h, wt0p,"out", ao3p, "in"); // wt->aout - 3
  935. cmDspSysConnectAudio(h, wt0p,"out", atp, "in"); // wt->meter
  936. cmDspSysInstallCb(h, ws0p, "out", kr0p, "wndn", NULL ); // wndSmpCnt->kr
  937. cmDspSysInstallCb(h, hf0p, "out", kr0p, "hopf", NULL ); // hopFact->kr
  938. cmDspSysInstallCb(h, md0p, "val", kr0p, "mode", NULL ); // mode->kr
  939. cmDspSysInstallCb(h, th0p, "val", kr0p, "thrh", NULL ); // thresh->kr
  940. cmDspSysInstallCb(h, ls0p, "val", kr0p, "lwrs", NULL ); // lwrSlope->kr
  941. cmDspSysInstallCb(h, us0p, "val", kr0p, "uprs", NULL ); // uprSlope->kr
  942. cmDspSysInstallCb(h, of0p, "val", kr0p, "offs", NULL ); // offset->kr
  943. cmDspSysInstallCb(h, iv0p, "val", kr0p, "invt", NULL ); // invert->kr
  944. cmDspSysInstallCb(h, th0p, "val", mtp, "in", NULL );
  945. cmDspSysInstallCb(h, ws1p, "out", kr1p, "wndn", NULL ); // wndSmpCnt->kr
  946. cmDspSysInstallCb(h, hf1p, "out", kr1p, "hopf", NULL ); // hopFact->kr
  947. cmDspSysInstallCb(h, md1p, "val", kr1p, "mode", NULL ); // mode->kr
  948. cmDspSysInstallCb(h, th1p, "val", kr1p, "thrh", NULL ); // thresh->kr
  949. cmDspSysInstallCb(h, ls1p, "val", kr1p, "lwrs", NULL ); // lwrSlope->kr
  950. cmDspSysInstallCb(h, us1p, "val", kr1p, "uprs", NULL ); // uprSlope->kr
  951. cmDspSysInstallCb(h, of1p, "val", kr1p, "offs", NULL ); // offset->kr
  952. cmDspSysInstallCb(h, iv1p, "val", kr1p, "invt", NULL ); // invert->kr
  953. cmDspSysInstallCb(h, dnp, "out", fn0p, "in-0", NULL); // dir->fn:0
  954. cmDspSysInstallCb(h, al0p, "out", fn0p, "in-1", NULL ); // fn->fn:1
  955. cmDspSysInstallCb(h, fl0p, "take", fn0p, "in-2", NULL ); // take->fn:2
  956. cmDspSysInstallCb(h, fn0p, "out", ro0p, "in-0", NULL); // fn->print
  957. cmDspSysInstallCb(h, fl0p, "beg", ro0p, "in-1", NULL); //
  958. cmDspSysInstallCb(h, fl0p, "end", ro0p, "in-2", NULL); //
  959. cmDspSysInstallCb(h, ro0p, "out-0", wt0p, "fn", NULL ); // fn->wt:fn
  960. cmDspSysInstallCb(h, ro0p, "out-1", wt0p, "beg", NULL ); // beg->wt:beg
  961. cmDspSysInstallCb(h, ro0p, "out-2", wt0p, "end", NULL ); // end->wt:end
  962. cmDspSysInstallCb(h, ro0p, "out-1", prp, "in", NULL ); //
  963. //cmDspSysInstallCb(h, dnp, "out", fn1p, "in-0", NULL); // dir->fn:0
  964. //cmDspSysInstallCb(h, al1p, "out", fn1p, "in-1", NULL ); // fn->fn:1
  965. //cmDspSysInstallCb(h, fl1p, "take", fn1p, "in-2", NULL ); // take->fn:2
  966. //cmDspSysInstallCb(h, fn1p, "out", ro1p, "in-0", NULL); // fn->print
  967. //cmDspSysInstallCb(h, fl1p, "beg", ro1p, "in-1", NULL); //
  968. //cmDspSysInstallCb(h, fl1p, "end", ro1p, "in-2", NULL); //
  969. //cmDspSysInstallCb(h, ro1p, "out-0", wt1p, "fn", NULL ); // fn->wt:fn
  970. //cmDspSysInstallCb(h, ro1p, "out-1", wt1p, "beg", NULL ); // beg->wt:beg
  971. //cmDspSysInstallCb(h, ro1p, "out-2", wt1p, "end", NULL ); // end->wt:end
  972. return cmDspSysLastRC(h);
  973. }
  974. //------------------------------------------------------------------------------
  975. //)
  976. //( { label:cmDspPgm_Pickups0 file_desc:"'fluxo' with loop-record, echo, rectify, and pitch-shift." kw:[spgm fluxo] }
  977. cmDspRC_t _cmDspSysPgm_Pickups0( cmDspSysH_t h, void** userPtrPtr )
  978. {
  979. unsigned i;
  980. unsigned chCnt = 8;
  981. double delayFb = 0.0;
  982. double delayMaxMs = 1000.0;
  983. cmDspInst_t* chArray[chCnt];
  984. cmDspInst_t* m_mxWet = cmDspSysAllocInst(h,"Scalar", "Mstr Wet", 5, kNumberDuiId, 0.0, 2.0, 0.01, 1.0 );
  985. cmDspInst_t* m_mxDry = cmDspSysAllocInst(h,"Scalar", "Mstr Dry", 5, kNumberDuiId, 0.0, 2.0, 0.01, 1.0 );
  986. cmDspSysNewColumn(h,0);
  987. cmDspInst_t* m_lpByp = cmDspSysAllocInst(h,"Button", "Mstr Lp Byps", 2, kCheckDuiId, 0.0 );
  988. cmDspInst_t* m_lpRcd = cmDspSysAllocInst(h,"Button", "Mstr Lp Recd", 2, kCheckDuiId, 0.0 );
  989. cmDspInst_t* m_lpRat = cmDspSysAllocInst(h,"Scalar", "Mstr Lp Ratio", 5, kNumberDuiId, 0.0, 10.0, 0.01, 1.0 );
  990. cmDspSysNewColumn(h,0);
  991. cmDspInst_t* m_dlyByp = cmDspSysAllocInst(h,"Button", "Mstr Dly Byps", 2, kCheckDuiId, 0.0 );
  992. cmDspInst_t* m_dlyMs = cmDspSysAllocInst(h,"Scalar", "Mstr Dly Time", 5, kNumberDuiId, 0.0, delayMaxMs, 1.0, 0.0 );
  993. cmDspInst_t* m_dlyFb = cmDspSysAllocInst(h,"Scalar", "Mstr Dly Fb", 5, kNumberDuiId, 0.0, 0.999, 0.01, 0.0 );
  994. cmDspSysNewColumn(h,0);
  995. cmDspInst_t* m_psByp = cmDspSysAllocInst(h,"Button", "Mstr PS Byps", 2, kCheckDuiId, 0.0 );
  996. cmDspInst_t* m_psRat = cmDspSysAllocInst(h,"Scalar", "Mstr PS Ratio", 5, kNumberDuiId, 0.0, 10.0, 0.01, 1.0 );
  997. cmDspSysNewColumn(h,0);
  998. cmDspInst_t* m_rcByp = cmDspSysAllocInst(h,"Button", "Mstr Rect Byps", 2, kCheckDuiId, 0.0 );
  999. cmDspSysInsertHorzBorder(h);
  1000. for(i=0; i<chCnt; ++i)
  1001. {
  1002. int chIdx = i;
  1003. cmDspInst_t* mxWet = cmDspSysAllocInst(h,"Scalar", "Wet", 5, kNumberDuiId, 0.0, 2.0, 0.01, 1.0 );
  1004. cmDspInst_t* mxDry = cmDspSysAllocInst(h,"Scalar", "Dry", 5, kNumberDuiId, 0.0, 2.0, 0.01, 1.0 );
  1005. cmDspInst_t* lpByp = cmDspSysAllocInst(h,"Button", "Lp Byps", 2, kCheckDuiId, 0.0 );
  1006. cmDspInst_t* lpRcd = cmDspSysAllocInst(h,"Button", "Lp Recd", 2, kCheckDuiId, 0.0 );
  1007. cmDspInst_t* lpRat = cmDspSysAllocInst(h,"Scalar", "Lp Ratio", 5, kNumberDuiId, 0.0, 10.0, 0.01, 1.0 );
  1008. cmDspInst_t* dlyByp = cmDspSysAllocInst(h,"Button", "Delay Byps", 2, kCheckDuiId, 0.0 );
  1009. cmDspInst_t* dlyMs = cmDspSysAllocInst(h,"Scalar", "Delay Time", 5, kNumberDuiId, 0.0, delayMaxMs, 1.0, 0.0 );
  1010. cmDspInst_t* dlyFb = cmDspSysAllocInst(h,"Scalar", "Delay Fb", 5, kNumberDuiId, 0.0, 0.999, 0.01, 0.0 );
  1011. cmDspInst_t* psByp = cmDspSysAllocInst(h,"Button", "PS Byps", 2, kCheckDuiId, 0.0 );
  1012. cmDspInst_t* psRat = cmDspSysAllocInst(h,"Scalar", "PS Ratio", 5, kNumberDuiId, 0.0, 10.0, 0.01, 1.0 );
  1013. cmDspInst_t* rcByp = cmDspSysAllocInst(h,"Button", "Rect Byps", 2, kCheckDuiId, 0.0 );
  1014. cmDspInst_t* ain = cmDspSysAllocInst(h, "AudioIn", NULL, 1, chIdx );
  1015. cmDspInst_t* loop = cmDspSysAllocInst(h, "LoopRecd", NULL, 0 );
  1016. cmDspInst_t* dely = cmDspSysAllocInst(h, "Delay", NULL, 2, delayMaxMs, delayFb );
  1017. cmDspInst_t* pshf = cmDspSysAllocInst(h, "PShift", NULL, 0 );
  1018. cmDspInst_t* rect = cmDspSysAllocInst(h, "Rectify", NULL, 0 );
  1019. cmDspInst_t* amix = cmDspSysAllocInst(h, "AMix", NULL, 1, 2 );
  1020. //cmDspInst_t* aout = cmDspSysAllocInst(h, "AudioOut", NULL, 1, chIdx );
  1021. chArray[i] = amix;
  1022. cmDspSysNewColumn(h,0);
  1023. cmDspSysConnectAudio(h, ain, "out", loop, "in"); // ain -> loop
  1024. cmDspSysConnectAudio(h, loop, "out", dely, "in"); // loop -> delay
  1025. cmDspSysConnectAudio(h, dely, "out", pshf, "in"); // delay -> pshf
  1026. cmDspSysConnectAudio(h, pshf, "out", rect, "in"); // pshf -> rect
  1027. cmDspSysConnectAudio(h, rect, "out", amix, "in-0"); // rect -> mix_wet
  1028. cmDspSysConnectAudio(h, ain, "out", amix, "in-1"); // ain -> mix_dry
  1029. //cmDspSysConnectAudio(h, amix, "out", aout, "in"); // mix -> out
  1030. cmDspSysInstallCb(h, mxWet, "val", amix, "gain-0", NULL );
  1031. cmDspSysInstallCb(h, mxDry, "val", amix, "gain-1", NULL );
  1032. cmDspSysInstallCb(h, lpByp, "out", loop, "bypass", NULL );
  1033. cmDspSysInstallCb(h, lpRcd, "out", loop, "recd", NULL );
  1034. cmDspSysInstallCb(h, lpRat, "val", loop, "ratio", NULL );
  1035. cmDspSysInstallCb(h, dlyByp,"val", dely, "bypass", NULL );
  1036. cmDspSysInstallCb(h, dlyMs, "val", dely, "time", NULL );
  1037. cmDspSysInstallCb(h, dlyFb, "out", dely, "fb", NULL );
  1038. cmDspSysInstallCb(h, psByp, "out", pshf, "bypass", NULL );
  1039. cmDspSysInstallCb(h, psRat, "val", pshf, "ratio", NULL );
  1040. cmDspSysInstallCb(h, rcByp, "out", rect, "bypass", NULL );
  1041. cmDspSysInstallCb(h, m_mxWet, "val", mxWet, "in", NULL );
  1042. cmDspSysInstallCb(h, m_mxDry, "val", mxDry, "in", NULL );
  1043. cmDspSysInstallCb(h, m_lpByp, "out", lpByp, "in", NULL );
  1044. cmDspSysInstallCb(h, m_lpRcd, "out", lpRcd, "in", NULL );
  1045. cmDspSysInstallCb(h, m_lpRat, "val", lpRat, "in", NULL );
  1046. cmDspSysInstallCb(h, m_dlyByp,"out", dlyByp,"in", NULL );
  1047. cmDspSysInstallCb(h, m_dlyMs, "val", dlyMs, "in", NULL );
  1048. cmDspSysInstallCb(h, m_dlyFb, "val", dlyFb, "in", NULL );
  1049. cmDspSysInstallCb(h, m_psByp, "out", psByp, "in", NULL );
  1050. cmDspSysInstallCb(h, m_psRat, "val", psRat, "in", NULL );
  1051. cmDspSysInstallCb(h, m_rcByp, "out", rcByp, "in", NULL );
  1052. }
  1053. double dfltGain = 0.5;
  1054. cmDspInst_t* omix = cmDspSysAllocInst(h, "AMix", NULL, 9, 8, dfltGain, dfltGain, dfltGain, dfltGain, dfltGain, dfltGain, dfltGain, dfltGain );
  1055. cmDspInst_t* aout0 = cmDspSysAllocInst(h, "AudioOut", NULL, 1, 0 );
  1056. cmDspInst_t* aout1 = cmDspSysAllocInst(h, "AudioOut", NULL, 1, 1 );
  1057. cmDspInst_t* aout2 = cmDspSysAllocInst(h, "AudioOut", NULL, 1, 2 );
  1058. cmDspInst_t* aout3 = cmDspSysAllocInst(h, "AudioOut", NULL, 1, 3 );
  1059. for(i=0; i<chCnt; ++i)
  1060. {
  1061. char label[32];
  1062. snprintf(label,32,"in-%i",i);
  1063. cmDspSysConnectAudio(h, chArray[i], "out", omix, label);
  1064. }
  1065. cmDspSysConnectAudio(h, omix, "out", aout0, "in");
  1066. cmDspSysConnectAudio(h, omix, "out", aout1, "in");
  1067. cmDspSysConnectAudio(h, omix, "out", aout2, "in");
  1068. cmDspSysConnectAudio(h, omix, "out", aout3, "in");
  1069. return kOkDspRC;
  1070. }
  1071. //------------------------------------------------------------------------------
  1072. //)
  1073. //( { label:cmDspPgm_AutoGain file_desc:"'fluxo' channel calibration program." kw:[spgm fluxo] }
  1074. #include "cmAudioFile.h"
  1075. #include "cmProcObj.h"
  1076. #include "cmProc.h"
  1077. #include "cmProc3.h"
  1078. // Usage:
  1079. // 1) Push 'start'.
  1080. // 2) Select the first element in the Ch Cfg List UI.
  1081. // 3) Play several examples of the note.
  1082. // 4) Select the next element in the Ch Cfg List UI.
  1083. // 5) Go to 3) until all ch's have been played.
  1084. // 6) Push 'proc'. A new set of gains will be calc'd and sent to the audio input channels.
  1085. // Note that if a mistake is made while playing a set of notes in 3) then
  1086. // push select the same element from the list again and replay.
  1087. // The order the notes are played in does not make any difference.
  1088. cmDspRC_t _cmDspSysPgm_AutoGain( cmDspSysH_t h, void** userPtrPtr )
  1089. {
  1090. cmDspRC_t rc = kOkDspRC;
  1091. unsigned i;
  1092. //unsigned j;
  1093. cmErr_t err;
  1094. const cmChar_t* errLabelPtr = NULL;
  1095. cmCtx_t* cmCtx = cmDspSysPgmCtx(h);
  1096. unsigned chCnt = 0;
  1097. unsigned nsChCnt = 0;
  1098. const cmChar_t* chCfgFn = NULL;
  1099. const cmChar_t* chCfgPath = NULL;
  1100. unsigned agMedCnt = 5;
  1101. unsigned agAvgCnt = 9;
  1102. unsigned agSuprCnt = 3;
  1103. unsigned agOffCnt = 3;
  1104. cmReal_t agSuprCoeff = 1.4;
  1105. cmReal_t agOnThreshDb = -53.0;
  1106. cmReal_t agOffThreshDb = -80.0;
  1107. cmReal_t agHopMs = 25;
  1108. //cmReal_t cdMaxTimeSpanMs = 50;
  1109. //cmReal_t cdMinNoteCnt = 3;
  1110. unsigned labelCharCnt = 31;
  1111. char label0[ labelCharCnt + 1];
  1112. cmErrSetup(&err,&cmCtx->rpt,"Auto-gain");
  1113. // get the name of channel cfg file
  1114. if( cmJsonPathValues( cmDspSysPgmRsrcHandle(h),"cfg/",NULL,&errLabelPtr,
  1115. "chCfgFn", kStringTId, &chCfgFn,
  1116. "agParms/hopMs", kRealTId, &agHopMs,
  1117. "agParms/medCnt", kIntTId, &agMedCnt,
  1118. "agParms/avgCnt", kIntTId, &agAvgCnt,
  1119. "agParms/suprCnt", kIntTId, &agSuprCnt,
  1120. "agParms/offCnt", kIntTId, &agOffCnt,
  1121. "agParms/suprCoeff", kRealTId, &agSuprCoeff,
  1122. "agParms/onThreshDb", kRealTId, &agOnThreshDb,
  1123. "agParms/offThreshDb", kRealTId, &agOffThreshDb,
  1124. NULL) != kOkJsRC )
  1125. {
  1126. rc = cmErrMsg(&err,kPgmCfgFailDspRC,"An error occurred while reading the required auto-tune JSON parameters.");
  1127. goto errLabel;
  1128. }
  1129. // get the count of channels from the ch. cfg. array
  1130. if(( chCnt = cmChCfgChannelCount(cmCtx,chCfgFn,&nsChCnt)) == 0 )
  1131. {
  1132. rc = cmErrMsg(&err,kPgmCfgFailDspRC,"Unable to obtain the channel count from '%s'.",cmStringNullGuard(chCfgFn));
  1133. goto errLabel;
  1134. }
  1135. // prepend the prefs directory to the ch. cfg filename
  1136. chCfgPath = cmFsMakeFn(cmFsPrefsDir(),chCfgFn,NULL,NULL);
  1137. if( rc == kOkDspRC )
  1138. {
  1139. //mDspInst_t* ain[chCnt];
  1140. cmDspInst_t* ef[chCnt];
  1141. cmDspInst_t* mtr[chCnt];
  1142. cmDspInst_t* amtr[chCnt];
  1143. cmDspInst_t* on[chCnt];
  1144. cmDspInst_t* off[chCnt];
  1145. cmDspInst_t* rms[chCnt];
  1146. ///cmDspInst_t* fdr0[chCnt];
  1147. ///cmDspInst_t* fdr1[chCnt];
  1148. ///cmDspInst_t* fdr2[chCnt];
  1149. // allocate the audio inputs
  1150. //for(i=0; i<chCnt; ++i)
  1151. // ain[i] = cmDspSysAllocAudioIn(h,i,1.0);
  1152. unsigned inChCnt;
  1153. cmDspInst_t** ain = cmDspSysAllocAudioInAR( h, "audioInMap", 1.0, &inChCnt );
  1154. // allocate the auto-gain calibration object
  1155. cmDspInst_t* ag = cmDspSysAllocInst( h, "AutoGain", NULL, 9, chCnt, agHopMs,agMedCnt,agAvgCnt,agSuprCnt,agOffCnt,agSuprCoeff,agOnThreshDb,agOffThreshDb );
  1156. // allocate the command buttons
  1157. cmDspInst_t* start = cmDspSysAllocButton(h, "start", 0);
  1158. cmDspInst_t* proc = cmDspSysAllocButton(h, "proc", 0);
  1159. cmDspInst_t* cancel = cmDspSysAllocButton(h, "cancel", 0);
  1160. cmDspInst_t* write = cmDspSysAllocButton(h, "write", 0);
  1161. cmDspInst_t* print = cmDspSysAllocButton(h, "print", 0);
  1162. cmDspInst_t* chMenu = cmDspSysAllocMsgList(h, chCfgPath, "ch_array", 0 );
  1163. cmDspInst_t* onThr = cmDspSysAllocScalar(h,"On Thresh",-100.0,0.0,0.1,-45.0);
  1164. cmDspInst_t* offThr = cmDspSysAllocScalar(h,"Off Thresh",-100.0,0.0,0.1,-80.0);
  1165. //cmDspInst_t* prt = cmDspSysAllocInst(h,"Printer",NULL,1,"ag>");
  1166. cmDspInst_t* sub = cmDspSysAllocInst(h,"ScalarOp",NULL,6,2,"+","in-0",0.0,"in-1",-1.0);
  1167. cmDspSysNewColumn(h,200);
  1168. cmDspSysAllocLabel(h,"EF Gate",kLeftAlignDuiId);
  1169. // allocate the envelope followers and meters
  1170. for(i=0; i<chCnt; ++i )
  1171. {
  1172. snprintf(label0,labelCharCnt,"%2i",i);
  1173. ef[i] = cmDspSysAllocInst( h, "EnvFollow", NULL, 0 );
  1174. mtr[i] = cmDspSysAllocInst( h, "Meter",label0, 3, 0.0, 0.0, 1.0 );
  1175. }
  1176. cmDspSysNewColumn(h,200);
  1177. cmDspSysAllocLabel(h,"Audio",kLeftAlignDuiId);
  1178. // allocate the envelope followers and meters
  1179. for(i=0; i<chCnt; ++i )
  1180. {
  1181. amtr[i] = cmDspSysAllocInst( h, "AMeter", NULL, 0 );
  1182. }
  1183. // chord detector, note selector, mix0, mix1, mix2
  1184. ///cmDspInst_t* cdp = cmDspSysAllocInst(h, "ChordDetect", NULL, 1, "cdSel" );
  1185. ///cmDspInst_t* nsp = cmDspSysAllocInst(h, "NoteSelect", NULL, 1, chCnt );
  1186. // onset count display
  1187. cmDspSysNewColumn(h,150);
  1188. cmDspSysAllocLabel(h,"Onsets",kLeftAlignDuiId);
  1189. for(i=0; i<chCnt; ++i)
  1190. on[i] = cmDspSysAllocScalar(h,NULL,0,1,0,0);
  1191. // offset count display
  1192. cmDspSysNewColumn(h,150);
  1193. cmDspSysAllocLabel(h,"Offsets",kLeftAlignDuiId);
  1194. for(i=0; i<chCnt; ++i)
  1195. off[i] = cmDspSysAllocScalar(h,NULL,0,1,0,0);
  1196. // offset count display
  1197. cmDspSysNewColumn(h,150);
  1198. cmDspSysAllocLabel(h,"RMS",kLeftAlignDuiId);
  1199. for(i=0; i<chCnt; ++i)
  1200. rms[i] = cmDspSysAllocScalar(h,NULL,0,1,0,0);
  1201. /*
  1202. // note select gate meters
  1203. for(j=0; j<3; ++j)
  1204. {
  1205. snprintf(label0,labelCharCnt,"Set %i",j);
  1206. cmDspSysNewColumn(h,50);
  1207. cmDspSysAllocLabel(h,label0,kLeftAlignDuiId );
  1208. for(i=0; i<chCnt; ++i)
  1209. {
  1210. cmDspInst_t* m = cmDspSysAllocInst(h, "Meter", NULL, 3, 0.0, 0.0, 1.0 );
  1211. switch(j)
  1212. {
  1213. case 0: fdr0[i] = m; break;
  1214. case 1: fdr1[i] = m; break;
  1215. case 2: fdr2[i] = m; break;
  1216. }
  1217. }
  1218. }
  1219. // chord detector parameters
  1220. cmDspSysNewColumn(h,150);
  1221. cmDspSysAllocLabel(h,"Chord Detector",kLeftAlignDuiId);
  1222. cmDspInst_t* cdSpanMs = cmDspSysAllocScalar(h,"Span Ms", 10.0,1000.0,1.0,cdMaxTimeSpanMs);
  1223. cmDspInst_t* cdNoteCnt = cmDspSysAllocScalar(h,"Note Cnt", 1.0, 100.0,1.0,cdMinNoteCnt );
  1224. cmDspInst_t* cdCount = cmDspSysAllocScalar(h,"Ch. Count", 0,1,0,0);
  1225. */
  1226. // allocate an audio mixer and two audio output channels
  1227. cmDspInst_t* amix = cmDspSysAllocInst( h, "AMix", NULL, 1, chCnt);
  1228. cmDspInst_t* ao0 = cmDspSysAllocAudioOut(h,0,1.0);
  1229. cmDspInst_t* ao1 = cmDspSysAllocAudioOut(h,1,1.0);
  1230. // alloc chCfg last so that it's default outputs are applied to connected objects
  1231. cmDspInst_t* chCfg = cmDspSysAllocInst( h, "ChCfg", NULL, 1, chCfgFn );
  1232. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  1233. goto errLabel;
  1234. cmDspSysConnectAudioN11N(h,ain, "out", ag, "in", chCnt); // ain -> auto gain
  1235. cmDspSysConnectAudioN11N(h,ain, "out", amix, "in", chCnt); // ain -> amix
  1236. cmDspSysConnectAudioN1N1(h,ain, "out", ef, "in", chCnt); // ain -> EF
  1237. cmDspSysConnectAudioN1N1(h, ain, "out", amtr, "in",chCnt);
  1238. cmDspSysInstallCb1N1N(h, ag, "gain", chCfg, "gain", chCnt ); // ag -> chCfg (gain)
  1239. cmDspSysInstallCb1NN1(h, chCfg, "gain", ain, "gain", chCnt ); // cgCfg -> ain (gain)
  1240. cmDspSysInstallCb1NN1(h, chCfg, "ch", ain, "ch", chCnt ); // cgCfg -> ain (ch)
  1241. cmDspSysInstallCbN1N1(h, ef, "gate", mtr, "in", chCnt ); // EF gate -> meter
  1242. cmDspSysInstallCb11N1(h, onThr, "val", ef, "ondb", chCnt ); //
  1243. cmDspSysInstallCb11N1(h, offThr, "val", ef, "offdb", chCnt ); //
  1244. cmDspSysInstallCbN1N1(h, ef, "ons", on, "val", chCnt ); // EF -> onset count
  1245. cmDspSysInstallCbN1N1(h, ef, "offs", off, "val", chCnt ); // EF -> offset count
  1246. cmDspSysInstallCbN1N1(h, ef, "rms", rms, "val", chCnt );
  1247. ///cmDspSysInstallCbN11N(h, ef, "gate", cdp, "gate", chCnt ); // EF -> CD gate
  1248. ///cmDspSysInstallCbN11N(h, ef, "rms", cdp, "rms", chCnt ); // EF -> CD rms
  1249. ///cmDspSysInstallCb1N1N(h, cdp, "gate", nsp, "gate", chCnt ); // CD -> NS gate
  1250. ///cmDspSysInstallCb1N1N(h, cdp, "rms", nsp, "rms", chCnt ); // CD -> NS rms
  1251. ///cmDspSysInstallCb1NN1(h, nsp, "gate-0",fdr0, "in", chCnt ); // NS -> Fader 0 gate
  1252. ///cmDspSysInstallCb1NN1(h, nsp, "gate-1",fdr1, "in", chCnt ); // NS -> Fader 1 gate
  1253. ///cmDspSysInstallCb1NN1(h, nsp, "gate-2",fdr2, "in", chCnt ); // NS -> Fader 2 gate
  1254. cmDspSysConnectAudio(h, amix, "out", ao0, "in"); // amix -> aout 0
  1255. cmDspSysConnectAudio(h, amix, "out", ao1, "in"); // amix -> aout 1
  1256. //cmDspSysInstallCb(h, chMenu, "ch", ag, "id", NULL );
  1257. cmDspSysInstallCb(h, chMenu, "sel", sub, "in-0", NULL );
  1258. cmDspSysInstallCb(h, sub, "out", ag, "id", NULL );
  1259. cmDspSysInstallCb(h, start, "sym", ag, "sel", NULL );
  1260. cmDspSysInstallCb(h, proc, "sym", ag, "sel", NULL );
  1261. cmDspSysInstallCb(h, cancel, "sym", ag, "sel", NULL );
  1262. cmDspSysInstallCb(h, print, "sym", ag, "sel", NULL );
  1263. cmDspSysInstallCb(h, print, "sym", chCfg, "sel", NULL );
  1264. cmDspSysInstallCb(h, write, "sym", chCfg, "sel", NULL );
  1265. /*
  1266. cmDspSysInstallCb(h, cdSpanMs, "val", cdp, "span", NULL );
  1267. cmDspSysInstallCb(h, cdNoteCnt, "val", cdp, "notes", NULL );
  1268. cmDspSysInstallCb(h, cdp, "count", cdCount, "val", NULL );
  1269. cmDspSysInstallCb(h, cdp, "detect", nsp, "trig", NULL );
  1270. */
  1271. }
  1272. errLabel:
  1273. cmFsFreeFn(chCfgPath);
  1274. return rc;
  1275. }
  1276. //------------------------------------------------------------------------------
  1277. //)
  1278. //( { label:cmDspPgm_PickupFxFile file_desc:"'fluxo' noise shapers." kw:[spgm fluxo] }
  1279. cmDspRC_t _cmDspSysPgm_PickupFxFile( cmDspSysH_t h, void** userPtrPtr )
  1280. {
  1281. cmDspRC_t rc = kOkDspRC;
  1282. cmErr_t err;
  1283. cmCtx_t* cmCtx = cmDspSysPgmCtx(h);
  1284. unsigned chCnt = 0;
  1285. unsigned nsChCnt = 0;
  1286. const cmChar_t* chCfgPath = NULL;
  1287. const cmChar_t* chCfgFn = "pick_chs8.js";
  1288. double cfMinHz = 20.0;
  1289. double cfAlpha = 0.9;
  1290. bool cfFbFl = true;
  1291. unsigned sgShapeId = 2;
  1292. const cmChar_t* afn = "/home/kevin/media/audio/gate_detect/gate_detect0.aif";
  1293. double abeg[] = { 9.842046, 18.838291, 27.007957, 35.562079, 45.461793, 52.920218, 60.436312, 68.913543};
  1294. double aend[] = {11.399088, 20.645229, 28.891786, 37.311349, 47.287954, 54.131251, 62.473923, 72.142964};
  1295. bool cfBypassFl = false;
  1296. unsigned i;
  1297. cmErrSetup(&err,&cmCtx->rpt,"Pickup Effects");
  1298. // prepend the prefs directory to the ch. cfg filename
  1299. chCfgPath = cmFsMakeFn(cmFsPrefsDir(),chCfgFn,NULL,NULL);
  1300. // get the count of channels from the ch. cfg. array
  1301. if(( chCnt = cmChCfgChannelCount(cmCtx,chCfgFn,&nsChCnt)) == 0 )
  1302. {
  1303. rc = cmErrMsg(&err,kPgmCfgFailDspRC,"Unable to obtain the channel count from '%s'.",cmStringNullGuard(chCfgFn));
  1304. goto errLabel;
  1305. }
  1306. if( rc == kOkDspRC )
  1307. {
  1308. cmDspInst_t* af[chCnt];
  1309. //cmDspInst_t* aout[chCnt];
  1310. cmDspInst_t* ef[chCnt];
  1311. cmDspInst_t* cf[chCnt];
  1312. cmDspInst_t* sg[chCnt];
  1313. cmDspInst_t* mtr[chCnt];
  1314. cmDspInst_t* mute[chCnt];
  1315. cmDspInst_t* phs = cmDspSysAllocInst(h,"Phasor", NULL, 0 );
  1316. // allocate the audio inputs
  1317. for(i=0; i<chCnt; ++i)
  1318. {
  1319. unsigned labelCharCnt = 31;
  1320. cmChar_t label[labelCharCnt+1];
  1321. snprintf(label,labelCharCnt,"%i",i);
  1322. int sbeg = floor(abeg[i] * cmDspSysSampleRate(h));
  1323. int send = floor(aend[i] * cmDspSysSampleRate(h));
  1324. //ain[i] = cmDspSysAllocAudioIn( h,i,1.0);
  1325. af[i] = cmDspSysAllocInst(h,"WaveTable",NULL, 6, ((int)cmDspSysSampleRate(h)), 1, afn, -1, sbeg, send );
  1326. //aout[i] = cmDspSysAllocAudioOut(h,i,1.0);
  1327. ef[i] = cmDspSysAllocInst(h, "EnvFollow", NULL, 0 );
  1328. sg[i] = cmDspSysAllocInst(h, "SigGen", NULL, 2, 1000.0, sgShapeId );
  1329. cf[i] = cmDspSysAllocInst(h, "CombFilt", NULL, 5, cfBypassFl, cfMinHz, cfFbFl, cfMinHz, cfAlpha );
  1330. mtr[i] = cmDspSysAllocInst( h, "Meter",label, 3, 0.0, 0.0, 1.0 );
  1331. }
  1332. // allocate the ch cfg last so that it's default outputs initialize connected objects
  1333. cmDspInst_t* chCfg = cmDspSysAllocInst( h, "ChCfg", NULL, 1, chCfgFn );
  1334. cmDspInst_t* mix = cmDspSysAllocInst( h, "AMix", NULL, 1, chCnt );
  1335. cmDspSysNewColumn(h,50);
  1336. for(i=0; i<chCnt; ++i)
  1337. mute[i] = cmDspSysAllocCheck(h,"",0);
  1338. // checkk for allocation errors
  1339. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  1340. goto errLabel;
  1341. //
  1342. //cmDspSysConnectAudioN1N1(h, ain, "out", aout, "in", chCnt );
  1343. cmDspSysConnectAudio11N1(h, phs, "out", af, "phs", chCnt );
  1344. cmDspSysConnectAudioN1N1(h, af, "out", ef, "in", chCnt ); // af -> EF
  1345. cmDspSysConnectAudioN1N1(h, sg, "out", cf, "in", chCnt ); // sg -> CF
  1346. cmDspSysConnectAudioN11N(h, cf, "out", mix, "in", chCnt ); // CF -> mix
  1347. //cmDspSysInstallCb1NN1( h, chCfg, "gain", ain, "gain", chCnt ); // chCfg -> ain gain
  1348. cmDspSysInstallCb1NN1( h, chCfg, "hz", cf, "hz", chCnt ); // chCfg -> CF Hz
  1349. //cmDspSysInstallCbN1N1( h, ef, "rms", aout, "gain", chCnt ); // EF -> aout gain
  1350. cmDspSysInstallCbN1N1( h, ef, "rms", mtr, "in", chCnt ); // EF -> meter RMS
  1351. cmDspSysInstallCbN11N( h, ef, "rms", mix, "gain", chCnt );
  1352. cmDspSysInstallCbN11N( h, mute, "out", mix, "mute", chCnt ); // mute -> mix
  1353. }
  1354. errLabel:
  1355. cmFsFreeFn(chCfgPath);
  1356. return rc;
  1357. }
  1358. //------------------------------------------------------------------------------
  1359. //)
  1360. //( { label:cmDspPgm_NoiseTails file_desc:"'fluxo' noise shapers." kw:[spgm fluxo] }
  1361. cmDspRC_t _cmDspSysPgm_NoiseTails( cmDspSysH_t h, void** userPtrPtr )
  1362. {
  1363. cmDspRC_t rc = kOkDspRC;
  1364. cmErr_t err;
  1365. cmCtx_t* cmCtx = cmDspSysPgmCtx(h);
  1366. unsigned chCnt = 0;
  1367. unsigned nsChCnt = 0;
  1368. const cmChar_t* chCfgPath = NULL;
  1369. const cmChar_t* chCfgFn = "pick_chs8.js";
  1370. double cfMinHz = 20.0;
  1371. double cfHz = 500;
  1372. double cfAlpha = 0.9;
  1373. bool cfFbFl = true;
  1374. bool cfBypassFl= false;
  1375. unsigned sgShapeId = 3;
  1376. double dfltDelayMs = 100;
  1377. unsigned i;
  1378. cmErrSetup(&err,&cmCtx->rpt,"Noise Tails");
  1379. // prepend the prefs directory to the ch. cfg filename
  1380. chCfgPath = cmFsMakeFn(cmFsPrefsDir(),chCfgFn,NULL,NULL);
  1381. // get the count of channels from the ch. cfg. array
  1382. if(( chCnt = cmChCfgChannelCount(cmCtx,chCfgFn,&nsChCnt)) == 0 )
  1383. {
  1384. rc = cmErrMsg(&err,kPgmCfgFailDspRC,"Unable to obtain the channel count from '%s'.",cmStringNullGuard(chCfgFn));
  1385. goto errLabel;
  1386. }
  1387. if( rc == kOkDspRC )
  1388. {
  1389. cmDspInst_t* ain[chCnt];
  1390. cmDspInst_t* ef[chCnt];
  1391. cmDspInst_t* cf[chCnt];
  1392. cmDspInst_t* sg[chCnt];
  1393. cmDspInst_t* mtr[chCnt];
  1394. cmDspInst_t* add[chCnt];
  1395. cmDspInst_t* mul[chCnt];
  1396. cmDspInst_t* dly[chCnt];
  1397. // allocate the audio inputs
  1398. for(i=0; i<chCnt; ++i)
  1399. {
  1400. unsigned labelCharCnt = 31;
  1401. cmChar_t label[labelCharCnt+1];
  1402. snprintf(label,labelCharCnt,"%i",i);
  1403. ain[i] = cmDspSysAllocAudioIn( h, i, 1.0);
  1404. ef[i] = cmDspSysAllocInst( h, "EnvFollow", NULL, 0 );
  1405. sg[i] = cmDspSysAllocInst( h, "SigGen", NULL, 2, 1000.0, sgShapeId );
  1406. cf[i] = cmDspSysAllocInst( h, "CombFilt", NULL, 5, cfBypassFl, cfMinHz, cfFbFl, cfHz, cfAlpha );
  1407. mtr[i] = cmDspSysAllocInst( h, "Meter",label, 3, 0.0, 0.0, 1.0 );
  1408. add[i] = cmDspSysAllocInst( h, "ScalarOp", NULL, 6, 2, "+", "in-0", 0.0, "in-1", 0.0);
  1409. mul[i] = cmDspSysAllocInst( h, "ScalarOp", NULL, 6, 2, "*", "in-0", 0.0, "in-1", 0.99);
  1410. dly[i] = cmDspSysAllocInst( h, "MsgDelay", NULL, 2, 1000, dfltDelayMs );
  1411. }
  1412. // allocate the ch cfg last so that it's default outputs initialize connected objects
  1413. cmDspInst_t* chCfg = cmDspSysAllocInst( h, "ChCfg", NULL, 1, chCfgFn );
  1414. cmDspInst_t* mix = cmDspSysAllocInst( h, "AMix", NULL, 1, chCnt );
  1415. cmDspInst_t* ao0 = cmDspSysAllocAudioOut( h, 0, 1.0 );
  1416. cmDspInst_t* ao1 = cmDspSysAllocAudioOut( h, 1, 1.0 );
  1417. cmDspInst_t* alpha = cmDspSysAllocScalar( h, "alpha", -1.0, 1.0, 0.001, cfAlpha );
  1418. cmDspInst_t* decay = cmDspSysAllocScalar( h, "decay", -1.0, 1.0, 0.001, 0.5);
  1419. cmDspInst_t* delay = cmDspSysAllocScalar( h, "delay", 0.0, 1000.0, 1.0, dfltDelayMs );
  1420. cmDspInst_t* zero = cmDspSysAllocScalar( h, "zero", 0.0, 0.0, 0.0, 0.0);
  1421. // check for allocation errors
  1422. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  1423. goto errLabel;
  1424. cmDspSysConnectAudioN1N1( h, ain, "out", ef, "in", chCnt ); // ain -> EF
  1425. cmDspSysConnectAudioN1N1( h, sg, "out", cf, "in", chCnt ); // sg -> CF
  1426. cmDspSysConnectAudioN11N( h, cf, "out", mix, "in", chCnt ); // cf -> mix
  1427. cmDspSysConnectAudio( h, mix, "out", ao0, "in"); // mix -> aout L
  1428. cmDspSysConnectAudio( h, mix, "out", ao1, "in"); // mix -> aout R
  1429. cmDspSysInstallCb1NN1( h, chCfg, "gain", ain, "gain", chCnt ); // chCfg -> ain gain
  1430. cmDspSysInstallCb1NN1( h, chCfg, "hz", cf, "hz", chCnt ); // chCfg -> CF Hz
  1431. cmDspSysInstallCbN1N1( h, ef, "rms", add, "in-0", chCnt ); // EF -> mul 0
  1432. cmDspSysInstallCbN1N1( h, mul, "out", add, "in-1", chCnt ); // mul -> add
  1433. cmDspSysInstallCbN1N1( h, add, "out", dly, "in", chCnt ); // add -> delay
  1434. cmDspSysInstallCbN11N( h, dly, "out", mix, "gain", chCnt ); // delay -> mix gain
  1435. cmDspSysInstallCbN1N1( h, add, "out", mul, "in-0", chCnt); // add -> mul (feedback)
  1436. cmDspSysInstallCb11N1( h, decay, "val", mul, "in-1", chCnt ); // decay ctl
  1437. cmDspSysInstallCbN1N1( h, ef, "gate", mtr, "in", chCnt ); // EF -> meter RMS
  1438. cmDspSysInstallCb11N1( h, alpha, "val", cf, "alpha",chCnt ); // CF alpha
  1439. cmDspSysInstallCb11N1( h, delay, "val", dly, "delay",chCnt ); // Delay ctl
  1440. cmDspSysInstallCb111N( h, zero, "val", mix, "in", chCnt ); //
  1441. }
  1442. errLabel:
  1443. cmFsFreeFn(chCfgPath);
  1444. return rc;
  1445. }
  1446. //------------------------------------------------------------------------------
  1447. //)
  1448. //( { label:cmDspPgm_NoiseTails2 file_desc:"'fluxo' noise shapers." kw:[spgm fluxo] }
  1449. cmDspRC_t _cmDspSysPgm_NoiseTails2( cmDspSysH_t h, void** userPtrPtr )
  1450. {
  1451. cmDspRC_t rc = kOkDspRC;
  1452. cmErr_t err;
  1453. cmCtx_t* cmCtx = cmDspSysPgmCtx(h);
  1454. unsigned chCnt = 0;
  1455. unsigned nsChCnt = 0;
  1456. const cmChar_t* chCfgPath = NULL;
  1457. const cmChar_t* chCfgFn = "pick_chs8.js";
  1458. double cfMinHz = 20.0;
  1459. double cfHz = 500;
  1460. double cfAlpha = 0.9;
  1461. bool cfFbFl = true;
  1462. bool cfBypassFl = false;
  1463. unsigned sgShapeId = 3;
  1464. double adsrMaxMs = 10000;
  1465. double adsrMinMs = 0;
  1466. double adsrIncMs = 1;
  1467. double adsrMaxLevel = 100.0;
  1468. double adsrSusLevel = 100.0;
  1469. double adsrMinLevel = 0.0;
  1470. double adsrIncLevel = 0.001;
  1471. bool eqBypassFl = false;
  1472. unsigned eqModeSymId = cmSymTblRegisterStaticSymbol(cmDspSysSymbolTable(h),"LP");
  1473. double eqF0hz = 250;
  1474. double eqQ = 1.0;
  1475. double eqFgain = 1.0;
  1476. bool mtBypassFl = false;
  1477. double mtTimeScale= 1.0;
  1478. double mtFeedback = 0.0;
  1479. unsigned i;
  1480. cmErrSetup(&err,&cmCtx->rpt,"Noise Tails");
  1481. // prepend the prefs directory to the ch. cfg filename
  1482. chCfgPath = cmFsMakeFn(cmFsPrefsDir(),chCfgFn,NULL,NULL);
  1483. // get the count of channels from the ch. cfg. array
  1484. if(( chCnt = cmChCfgChannelCount(cmCtx,chCfgFn,&nsChCnt)) == 0 )
  1485. {
  1486. rc = cmErrMsg(&err,kPgmCfgFailDspRC,"Unable to obtain the channel count from '%s'.",cmStringNullGuard(chCfgFn));
  1487. goto errLabel;
  1488. }
  1489. if( rc == kOkDspRC )
  1490. {
  1491. cmDspInst_t* ain[chCnt];
  1492. cmDspInst_t* ef[chCnt];
  1493. cmDspInst_t* cf[chCnt];
  1494. cmDspInst_t* sg[chCnt];
  1495. cmDspInst_t* mtr[chCnt];
  1496. cmDspInst_t* add[chCnt];
  1497. cmDspInst_t* mul[chCnt];
  1498. cmDspInst_t* env[chCnt];
  1499. cmDspInst_t* d2l[chCnt];
  1500. cmDspInst_t* eq[chCnt];
  1501. cmDspInst_t* mt[chCnt];
  1502. // allocate the audio inputs
  1503. for(i=0; i<chCnt; ++i)
  1504. {
  1505. unsigned labelCharCnt = 31;
  1506. cmChar_t label[labelCharCnt+1];
  1507. snprintf(label,labelCharCnt,"%i",i);
  1508. ain[i] = cmDspSysAllocAudioIn( h, i, 1.0);
  1509. ef[i] = cmDspSysAllocInst( h, "EnvFollow", NULL, 0 );
  1510. sg[i] = cmDspSysAllocInst( h, "SigGen", NULL, 2, 1000.0, sgShapeId );
  1511. cf[i] = cmDspSysAllocInst( h, "CombFilt", NULL, 5, cfBypassFl, cfMinHz, cfFbFl, cfHz, cfAlpha );
  1512. mtr[i] = cmDspSysAllocInst( h, "Meter",label, 3, 0.0, 0.0, 1.0 );
  1513. env[i] = cmDspSysAllocInst( h, "Adsr", NULL, 2, true, adsrMinLevel );
  1514. d2l[i] = cmDspSysAllocInst( h, "DbToLin", NULL, 0 );
  1515. add[i] = cmDspSysAllocInst( h, "ScalarOp", NULL, 6, 2, "+", "in-0", 0.0, "in-1", 0.0);
  1516. mul[i] = cmDspSysAllocInst( h, "ScalarOp", NULL, 6, 2, "*", "in-0", 0.0, "in-1", 0.99);
  1517. eq[i] = cmDspSysAllocInst( h, "BiQuadEq", NULL, 5, eqBypassFl, eqModeSymId, eqF0hz, eqQ, eqFgain );
  1518. mt[i] = cmDspSysAllocInst( h, "MtDelay", NULL, 9, mtBypassFl, mtTimeScale, mtFeedback, 20.0, 0.8, 15.0, 0.9, 12.0, 0.9 );
  1519. }
  1520. // allocate the ch cfg last so that it's default outputs initialize connected objects
  1521. cmDspInst_t* chCfg = cmDspSysAllocInst( h, "ChCfg", NULL, 1, chCfgFn );
  1522. cmDspInst_t* mix = cmDspSysAllocInst( h, "AMix", NULL, 1, chCnt );
  1523. cmDspInst_t* ao0 = cmDspSysAllocAudioOut( h, 0, 1.0 );
  1524. cmDspInst_t* ao1 = cmDspSysAllocAudioOut( h, 1, 1.0 );
  1525. cmDspInst_t* alpha = cmDspSysAllocScalar( h, "alpha", -1.0, 1.0, 0.001, cfAlpha );
  1526. cmDspInst_t* decay = cmDspSysAllocScalar( h, "decay", -1.0, 1.0, 0.001, 0.5);
  1527. cmDspInst_t* zero = cmDspSysAllocScalar( h, "zero", 0.0, 0.0, 0.0, 0.0);
  1528. // cmDspInst_t* print = cmDspSysAllocButton( h, "print", 0 );
  1529. cmDspSysNewColumn(h,200);
  1530. cmDspInst_t* dly = cmDspSysAllocScalar( h, "Dly Ms", adsrMinMs, adsrMaxMs, adsrIncMs, 0.0);
  1531. cmDspInst_t* atk = cmDspSysAllocScalar( h, "Atk Ms", adsrMinMs, adsrMaxMs, adsrIncMs, 2000.0);
  1532. cmDspInst_t* dcy = cmDspSysAllocScalar( h, "Dcy Ms", adsrMinMs, adsrMaxMs, adsrIncMs, 100.0);
  1533. cmDspInst_t* hold = cmDspSysAllocScalar( h, "Hold Ms", adsrMinMs, adsrMaxMs, adsrIncMs, 100.0);
  1534. cmDspInst_t* rls = cmDspSysAllocScalar( h, "Rls Ms", adsrMinMs, adsrMaxMs, adsrIncMs, 4000.0);
  1535. cmDspInst_t* alvl = cmDspSysAllocScalar( h, "AdsrMax", adsrMinLevel,adsrMaxLevel,adsrIncLevel, adsrMaxLevel);
  1536. cmDspInst_t* sus = cmDspSysAllocScalar( h, "Sustain", adsrMinLevel,adsrMaxLevel,adsrIncLevel, adsrSusLevel );
  1537. cmDspSysNewColumn(h,200);
  1538. cmDspInst_t* onThr = cmDspSysAllocScalar(h,"On Thresh",-100.0,0.0,0.1,-55.0);
  1539. cmDspInst_t* offThr = cmDspSysAllocScalar(h,"Off Thresh",-100.0,0.0,0.1,-80.0);
  1540. cmDspInst_t* eqbyp = cmDspSysAllocCheck( h, "Eq Byp", 0 );
  1541. cmDspInst_t* eqmode = cmDspSysAllocInst( h, "MsgList","Mode", 1, "biQuadEqMode");
  1542. cmDspInst_t* eqq = cmDspSysAllocScalar( h, "Q", -100.0, 100.0, 0.1, eqQ);
  1543. cmDspInst_t* eqfgn = cmDspSysAllocScalar( h, "Filt Gain", 0.0, 1.0, 0.1, eqFgain);
  1544. cmDspInst_t* mtfb = cmDspSysAllocScalar( h, "Mt Feedback", 0.0, 1.0, 0.01, mtFeedback);
  1545. cmDspInst_t* mtscale= cmDspSysAllocScalar( h, "Mt Time Scale", 0.01, 10.0, 0.01, mtTimeScale);
  1546. // check for allocation errors
  1547. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  1548. goto errLabel;
  1549. cmDspSysConnectAudioN1N1( h, ain, "out", ef, "in", chCnt ); // ain -> EF
  1550. cmDspSysConnectAudioN1N1( h, sg, "out", cf, "in", chCnt ); // sg -> CF
  1551. cmDspSysConnectAudioN1N1( h, cf, "out", eq, "in", chCnt );
  1552. cmDspSysConnectAudioN1N1( h, eq, "out", mt, "in", chCnt );
  1553. cmDspSysConnectAudioN11N( h, mt, "out", mix, "in", chCnt ); // cf -> mix
  1554. cmDspSysConnectAudio( h, mix, "out", ao0, "in"); // mix -> aout L
  1555. cmDspSysConnectAudio( h, mix, "out", ao1, "in"); // mix -> aout R
  1556. cmDspSysInstallCb1NN1( h, chCfg, "gain", ain, "gain", chCnt ); // chCfg -> ain gain
  1557. cmDspSysInstallCb1NN1( h, chCfg, "hz", cf, "hz", chCnt ); // chCfg -> CF Hz
  1558. cmDspSysInstallCb1NN1( h, chCfg, "hz", eq, "f0", chCnt ); // chCfg -> Eq Hz
  1559. cmDspSysInstallCbN1N1( h, mul, "out", add, "in-1", chCnt ); // mul -> add
  1560. cmDspSysInstallCbN1N1( h, ef, "gate", env, "gate", chCnt ); // EF -> adsr (gate)
  1561. cmDspSysInstallCbN1N1( h, ef, "rms", env, "rms", chCnt ); // EF ->adsr (rms)
  1562. //cmDspSysInstallCb11N1( h, print, "out", env, "cmd", chCnt );
  1563. cmDspSysInstallCbN1N1( h, env, "out", d2l, "in", chCnt );
  1564. cmDspSysInstallCbN11N( h, d2l, "out", mix, "gain", chCnt );
  1565. cmDspSysInstallCbN1N1( h, add, "out", mul, "in-0", chCnt ); // add -> mul (feedback)
  1566. cmDspSysInstallCb11N1( h, decay, "val", mul, "in-1", chCnt ); // decay ctl
  1567. cmDspSysInstallCbN1N1( h, ef, "gate", mtr, "in", chCnt ); // EF -> meter RMS
  1568. cmDspSysInstallCb11N1( h, alpha, "val", cf, "alpha",chCnt ); // CF alpha
  1569. cmDspSysInstallCb111N( h, zero, "val", mix, "in", chCnt ); //
  1570. cmDspSysInstallCb11N1( h, dly, "val", env, "dly", chCnt );
  1571. cmDspSysInstallCb11N1( h, atk, "val", env, "atk", chCnt );
  1572. cmDspSysInstallCb11N1( h, dcy, "val", env, "dcy", chCnt );
  1573. cmDspSysInstallCb11N1( h, hold, "val", env, "hold", chCnt );
  1574. cmDspSysInstallCb11N1( h, rls, "val", env, "rls", chCnt );
  1575. cmDspSysInstallCb11N1( h, alvl, "val", env, "alvl", chCnt );
  1576. cmDspSysInstallCb11N1( h, sus, "val", env, "sus", chCnt );
  1577. cmDspSysInstallCb11N1( h, onThr, "val", ef, "ondb", chCnt ); //
  1578. cmDspSysInstallCb11N1( h, offThr, "val", ef, "offdb", chCnt ); //
  1579. cmDspSysInstallCb11N1( h, eqbyp, "out", eq, "bypass", chCnt );
  1580. cmDspSysInstallCb11N1( h, eqmode, "mode", eq, "mode", chCnt );
  1581. cmDspSysInstallCb11N1( h, eqq, "val", eq, "Q", chCnt );
  1582. cmDspSysInstallCb11N1( h, eqfgn, "val", eq, "gain", chCnt );
  1583. cmDspSysInstallCb11N1( h, mtfb, "val", mt, "fb", chCnt );
  1584. cmDspSysInstallCb11N1( h, mtscale, "val", mt, "scale", chCnt );
  1585. }
  1586. errLabel:
  1587. cmFsFreeFn(chCfgPath);
  1588. return rc;
  1589. }
  1590. //------------------------------------------------------------------------------
  1591. //)
  1592. //( { label:cmDspPgm_CombFilt file_desc:"Comb filter example program." kw:[spgm] }
  1593. cmDspRC_t _cmDspSysPgm_CombFilt( cmDspSysH_t h, void** userPtrPtr )
  1594. {
  1595. cmDspRC_t rc = kOkDspRC;
  1596. double cfMinHz = 20.0;
  1597. double cfAlpha = 0.9;
  1598. bool cfFbFl = true;
  1599. bool cfBypassFl= false;
  1600. unsigned sgShapeId = 2;
  1601. cmDspInst_t* ao = cmDspSysAllocAudioOut( h, 0, 1.0 );
  1602. cmDspInst_t* sg = cmDspSysAllocInst( h, "SigGen", NULL, 2, 1000.0, sgShapeId );
  1603. cmDspInst_t* cf = cmDspSysAllocInst( h, "CombFilt", NULL, 5, cfBypassFl, cfMinHz, cfFbFl, cfMinHz, cfAlpha );
  1604. cmDspInst_t* hz = cmDspSysAllocScalar( h, "Hz", 25, 10000, 1, 1000 );
  1605. cmDspInst_t* a = cmDspSysAllocScalar( h, "Alpha", 0.0, 2.0, 0.001, cfAlpha);
  1606. // check for allocation errors
  1607. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  1608. goto errLabel;
  1609. cmDspSysConnectAudio(h, sg, "out", cf, "in");
  1610. cmDspSysConnectAudio(h, cf, "out", ao, "in");
  1611. cmDspSysInstallCb( h, hz, "val", cf, "hz", NULL);
  1612. cmDspSysInstallCb( h, a, "val", cf, "alpha", NULL);
  1613. errLabel:
  1614. return rc;
  1615. }
  1616. //------------------------------------------------------------------------------
  1617. //)
  1618. //( { label:cmDspPgm_ScalarOp file_desc:"Scalar operations example program." kw:[spgm] }
  1619. cmDspRC_t _cmDspSysPgm_ScalarOp( cmDspSysH_t h, void** userPtrPtr )
  1620. {
  1621. cmDspRC_t rc;
  1622. cmDspInst_t* add = cmDspSysAllocInst( h, "ScalarOp", NULL, 6, 2, "+", "in-0", 0.0, "in-1", 0.0 );
  1623. cmDspInst_t* mul0 = cmDspSysAllocInst( h, "ScalarOp", NULL, 6, 2, "*$", "in-0", 0.0, "in-1", 0.0 );
  1624. cmDspInst_t* mul1 = cmDspSysAllocInst( h, "ScalarOp", NULL, 6, 2, "*", "in-0", 0.0, "in-1", 0.0 );
  1625. cmDspInst_t* in = cmDspSysAllocScalar( h, "Input", 0.0, 10.0, 0.001, 0.0);
  1626. cmDspInst_t* in_m = cmDspSysAllocScalar( h, "Input_M", 0.0, 10.0, 0.001, 0.0);
  1627. cmDspInst_t* fb = cmDspSysAllocScalar( h, "Feedback", 0.0, 10.0, 0.001, 0.0);
  1628. cmDspInst_t* fb_m = cmDspSysAllocScalar( h, "Feedback_M", 0.0, 10.0, 0.001, 0.0);
  1629. cmDspInst_t* out = cmDspSysAllocScalar( h, "Out", 0.0, 10.0, 0.001, 0.0);
  1630. // check for allocation errors
  1631. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  1632. goto errLabel;
  1633. // Notice that changing 'in' or 'in_m' causes 'out' to be recomputed, but other
  1634. // changes are cached prior to 'add'. This prevents the program from going into
  1635. // an infinite loop.
  1636. //
  1637. // in -> mult0
  1638. // in_m -> mult0--+
  1639. // +-->fb -> mult1 +----> add
  1640. // | fb_m -> mult1-------> add --------+------> out
  1641. // | |
  1642. // +-------------------------------------+
  1643. //
  1644. cmDspSysInstallCb( h, in, "val", mul0, "in-0", NULL );
  1645. cmDspSysInstallCb( h, in_m, "val", mul0, "in-1", NULL );
  1646. cmDspSysInstallCb( h, fb, "val", mul1, "in-0", NULL );
  1647. cmDspSysInstallCb( h, fb_m, "val", mul1, "in-1", NULL );
  1648. cmDspSysInstallCb( h, mul0, "out", add, "in-0", NULL );
  1649. cmDspSysInstallCb( h, mul1, "out", add, "in-1", NULL );
  1650. cmDspSysInstallCb( h, add, "out", fb, "val", NULL );
  1651. cmDspSysInstallCb( h, add, "out", out, "val", NULL );
  1652. errLabel:
  1653. return rc;
  1654. }
  1655. //------------------------------------------------------------------------------
  1656. //)
  1657. //( { label:cmDspPgm_RingMod file_desc:"Ring modulation example program." kw:[spgm] }
  1658. cmDspRC_t _cmDspSysPgm_RingMod( cmDspSysH_t h, void** userPtrPtr )
  1659. {
  1660. cmDspRC_t rc = kOkDspRC;
  1661. cmErr_t err;
  1662. cmCtx_t* cmCtx = cmDspSysPgmCtx(h);
  1663. unsigned chCnt = 0;
  1664. unsigned nsChCnt = 0;
  1665. const cmChar_t* chCfgPath = NULL;
  1666. const cmChar_t* chCfgFn = "pick_chs8.js";
  1667. unsigned groupCnt = 3;
  1668. unsigned chsPerGroup = 2;
  1669. cmReal_t fadeTimeMs = 25;
  1670. unsigned i,j,k;
  1671. cmErrSetup(&err,&cmCtx->rpt,"Pickup Effects");
  1672. // prepend the prefs directory to the ch. cfg filename
  1673. chCfgPath = cmFsMakeFn(cmFsPrefsDir(),chCfgFn,NULL,NULL);
  1674. // get the count of channels from the ch. cfg. array
  1675. if(( chCnt = cmChCfgChannelCount(cmCtx,chCfgFn,&nsChCnt)) == 0 )
  1676. {
  1677. rc = cmErrMsg(&err,kPgmCfgFailDspRC,"Unable to obtain the channel count from '%s'.",cmStringNullGuard(chCfgFn));
  1678. goto errLabel;
  1679. }
  1680. if( rc == kOkDspRC )
  1681. {
  1682. cmDspInst_t* ain[chCnt];
  1683. cmDspInst_t* ef[chCnt];
  1684. cmDspInst_t* mtr[chCnt];
  1685. cmDspInst_t* nom[groupCnt];
  1686. cmDspInst_t* rm[groupCnt];
  1687. cmDspInst_t* nm_mtr[groupCnt*chsPerGroup];
  1688. unsigned labelCharCnt = 31;
  1689. cmChar_t label[labelCharCnt+1];
  1690. // allocate the audio inputs and envelope followers
  1691. for(i=0; i<chCnt; ++i)
  1692. {
  1693. snprintf(label,labelCharCnt,"%i",i);
  1694. ain[i] = cmDspSysAllocAudioIn( h, i, 1.0);
  1695. ef[i] = cmDspSysAllocInst( h, "EnvFollow", NULL, 0 );
  1696. mtr[i] = cmDspSysAllocInst( h, "Meter", label, 3, 0.0, 0.0, 1.0 );
  1697. }
  1698. cmDspInst_t* gs = cmDspSysAllocInst( h, "GroupSel", NULL, 3, chCnt, groupCnt, chsPerGroup );
  1699. for(i=0; i<groupCnt; ++i)
  1700. {
  1701. nom[i] = cmDspSysAllocInst(h, "AudioNofM", NULL, 3, chCnt, chsPerGroup, fadeTimeMs );
  1702. rm[i] = cmDspSysAllocInst(h, "RingMod", NULL, 1, chsPerGroup );
  1703. }
  1704. for(i=0,k=0; i<groupCnt; ++i)
  1705. {
  1706. cmDspSysNewColumn(h,50);
  1707. snprintf(label,labelCharCnt,"%i",i);
  1708. cmDspSysAllocLabel(h,label,kLeftAlignDuiId );
  1709. for(j=0; j<chsPerGroup; ++j,++k)
  1710. {
  1711. snprintf(label,labelCharCnt,"%i",j);
  1712. nm_mtr[k] = cmDspSysAllocInst(h, "Meter", label, 3, 0.0, 0.0, 1.0 );
  1713. }
  1714. }
  1715. assert(k==groupCnt*chsPerGroup);
  1716. // allocate the ch cfg last so that it's default outputs initialize connected objects
  1717. //cmDspInst_t* chCfg = cmDspSysAllocInst( h, "ChCfg", NULL, 1, chCfgFn );
  1718. cmDspInst_t* mix = cmDspSysAllocInst( h, "AMix", NULL, 1, groupCnt );
  1719. cmDspInst_t* ao0 = cmDspSysAllocAudioOut( h, 0, 1.0 );
  1720. cmDspInst_t* ao1 = cmDspSysAllocAudioOut( h, 1, 1.0 );
  1721. // check for allocation errors
  1722. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  1723. goto errLabel;
  1724. cmDspSysConnectAudioN1N1( h, ain, "out", ef, "in", chCnt ); // ain -> EF
  1725. for(i=0; i<groupCnt; ++i)
  1726. {
  1727. cmDspSysConnectAudioN11N( h, ain, "out", nom[i], "in", chCnt );
  1728. cmDspSysConnectAudio1N1N( h, nom[i], "out", rm[i], "in", chsPerGroup);
  1729. snprintf(label,labelCharCnt,"gate-%i",i);
  1730. cmDspSysInstallCb1N1N( h, gs, label, nom[i], "gate", chCnt );
  1731. cmDspSysInstallCb1NN1( h, nom[i], "gain", nm_mtr + i * chsPerGroup, "in", chsPerGroup);
  1732. }
  1733. cmDspSysConnectAudioN11N( h, rm, "out", mix, "in", groupCnt );
  1734. cmDspSysConnectAudio( h, mix, "out", ao0, "in"); // mix -> aout L
  1735. cmDspSysConnectAudio( h, mix, "out", ao1, "in"); // mix -> aout R
  1736. cmDspSysInstallCbN11N( h, ef, "gate", gs, "gate", chCnt ); // EF -> grp_sel gate
  1737. cmDspSysInstallCbN11N( h, ef, "rms", gs, "rms", chCnt ); // EF -> grp_sel RMS
  1738. cmDspSysInstallCbN1N1( h, ef, "gate", mtr, "in", chCnt );
  1739. }
  1740. errLabel:
  1741. cmFsFreeFn(chCfgPath);
  1742. return rc;
  1743. }
  1744. //------------------------------------------------------------------------------
  1745. //)
  1746. //( { label:cmDspPgm_RingMod2 file_desc:"Ring modulation example program." kw:[spgm] }
  1747. cmDspRC_t _cmDspSysPgm_RingMod2( cmDspSysH_t h, void** userPtrPtr )
  1748. {
  1749. cmDspRC_t rc = kOkDspRC;
  1750. cmErr_t err;
  1751. cmCtx_t* cmCtx = cmDspSysPgmCtx(h);
  1752. unsigned iChCnt = 0;
  1753. unsigned oChCnt = 0;
  1754. unsigned nsChCnt = 0;
  1755. const cmChar_t* chCfgPath = NULL;
  1756. const cmChar_t* chCfgFn = "pick_chs8.js";
  1757. unsigned i;
  1758. cmErrSetup(&err,&cmCtx->rpt,"Pickup Effects");
  1759. // prepend the prefs directory to the ch. cfg filename
  1760. chCfgPath = cmFsMakeFn(cmFsPrefsDir(),chCfgFn,NULL,NULL);
  1761. // get the count of channels from the ch. cfg. array
  1762. if(( iChCnt = cmChCfgChannelCount(cmCtx,chCfgFn,&nsChCnt)) == 0 )
  1763. {
  1764. rc = cmErrMsg(&err,kPgmCfgFailDspRC,"Unable to obtain the channel count from '%s'.",cmStringNullGuard(chCfgFn));
  1765. goto errLabel;
  1766. }
  1767. if( rc == kOkDspRC && iChCnt > 0 )
  1768. {
  1769. if( iChCnt % 2 )
  1770. iChCnt -= 1;
  1771. oChCnt = iChCnt/2;
  1772. cmDspInst_t* ain[iChCnt];
  1773. cmDspInst_t* ef[iChCnt];
  1774. cmDspInst_t* mtr[iChCnt];
  1775. cmDspInst_t* rm[oChCnt];
  1776. unsigned labelCharCnt = 31;
  1777. cmChar_t label[labelCharCnt+1];
  1778. // allocate the audio inputs and envelope followers
  1779. for(i=0; i<iChCnt; ++i)
  1780. {
  1781. snprintf(label,labelCharCnt,"%i",i);
  1782. ain[i] = cmDspSysAllocAudioIn( h, i, 1.0);
  1783. ef[i] = cmDspSysAllocInst( h, "EnvFollow", NULL, 0 );
  1784. mtr[i] = cmDspSysAllocInst( h, "Meter", label, 3, 0.0, 0.0, 1.0 );
  1785. }
  1786. for(i=0; i<oChCnt; ++i)
  1787. {
  1788. rm[i] = cmDspSysAllocInst( h, "RingMod", NULL, 1, 2 );
  1789. }
  1790. cmDspInst_t* gain = cmDspSysAllocScalar( h, "RM Gain", 0.0, 10.0, 0.001, 1.0);
  1791. cmDspInst_t* mix = cmDspSysAllocInst( h, "AMix", NULL, 1, oChCnt );
  1792. cmDspInst_t* ao0 = cmDspSysAllocAudioOut( h, 0, 1.0 );
  1793. cmDspInst_t* ao1 = cmDspSysAllocAudioOut( h, 1, 1.0 );
  1794. // check for allocation errors
  1795. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  1796. goto errLabel;
  1797. cmDspSysConnectAudioN1N1( h, ain, "out", ef, "in", iChCnt ); // ain -> EF
  1798. cmDspSysInstallCbN1N1( h, ef, "gate", mtr, "in", iChCnt ); // EF -> mtr (gate)
  1799. for(i=0; i<oChCnt; ++i)
  1800. {
  1801. cmDspSysConnectAudio( h, ain[i*2+0], "out", rm[i], "in-0"); // ain -> rm 0
  1802. cmDspSysConnectAudio( h, ain[i*2+1], "out", rm[i], "in-1"); // ain -> rm 1
  1803. snprintf(label,labelCharCnt,"in-%i",i);
  1804. cmDspSysConnectAudio( h, rm[i], "out", mix, label); // rm -> mix
  1805. cmDspSysInstallCb(h, gain, "val", rm[i], "gain", NULL ); // gain -> rm gain
  1806. }
  1807. cmDspSysConnectAudio( h, mix, "out", ao0, "in"); // mix -> aout L
  1808. cmDspSysConnectAudio( h, mix, "out", ao1, "in"); // mix -> aout R
  1809. }
  1810. errLabel:
  1811. cmFsFreeFn(chCfgPath);
  1812. return rc;
  1813. }
  1814. //------------------------------------------------------------------------------
  1815. //)
  1816. //( { label:cmDspPgm_MsgDelay file_desc:"Message delay example program." kw:[spgm] }
  1817. cmDspRC_t _cmDspSysPgm_MsgDelay( cmDspSysH_t h, void** userPtrPtr )
  1818. {
  1819. cmDspRC_t rc = kOkDspRC;
  1820. double dfltDelayTimeMs = 100.0;
  1821. double maxDelayTimeMs = 10000.0;
  1822. cmDspInst_t* ctl = cmDspSysAllocScalar( h, "Delay", 0.0, maxDelayTimeMs, 1.0, dfltDelayTimeMs );
  1823. cmDspInst_t* dly = cmDspSysAllocInst( h, "MsgDelay", NULL, 2, 1000, dfltDelayTimeMs );
  1824. cmDspInst_t* print = cmDspSysAllocInst( h, "Printer", NULL, 1, ">");
  1825. if( (rc = cmDspSysLastRC(h)) != kOkDspRC )
  1826. return rc;
  1827. cmDspSysInstallCb( h, ctl, "val", dly, "delay", NULL );
  1828. cmDspSysInstallCb( h, ctl, "val", dly, "in", NULL );
  1829. cmDspSysInstallCb( h, dly, "out", print, "in", NULL );
  1830. return rc;
  1831. }
  1832. //------------------------------------------------------------------------------
  1833. //)
  1834. //( { label:cmDspPgm_Adsr file_desc:"ADSR envelope generator example program." kw:[spgm] }
  1835. cmDspRC_t _cmDspSysPgm_Adsr( cmDspSysH_t h, void** userPtrPtr )
  1836. {
  1837. cmDspRC_t rc;
  1838. bool trigModeFl = true;
  1839. double adsrMaxMs = 5000;
  1840. double adsrMinMs = 0;
  1841. double adsrIncMs = 1;
  1842. double adsrMaxLevel = 100.0; //1.0;
  1843. double adsrSusLevel = 80.0; //0.8;
  1844. double adsrMinLevel = 0.0; //0.0;
  1845. double adsrIncLevel = 0.001;
  1846. const cmChar_t* fn = "/home/kevin/temp/adsr1.bin";
  1847. cmDspInst_t* adsr = cmDspSysAllocInst(h, "Adsr", NULL, 2, trigModeFl, adsrMinLevel );
  1848. cmDspInst_t* chck = cmDspSysAllocCheck(h,"Gate",0);
  1849. cmDspInst_t* mtr = cmDspSysAllocInst(h,"Meter","Out", 3, adsrMinLevel, adsrMinLevel, adsrMaxLevel );
  1850. cmDspInst_t* bmf = cmDspSysAllocInst(h,"BinMtxFile", NULL, 2, 1, fn );
  1851. cmDspInst_t* dly = cmDspSysAllocScalar( h, "Dly Ms", adsrMinMs, adsrMaxMs, adsrIncMs, 0.0);
  1852. cmDspInst_t* atk = cmDspSysAllocScalar( h, "Atk Ms", adsrMinMs, adsrMaxMs, adsrIncMs, 1000.0);
  1853. cmDspInst_t* dcy = cmDspSysAllocScalar( h, "Dcy Ms", adsrMinMs, adsrMaxMs, adsrIncMs, 300.0);
  1854. cmDspInst_t* hold = cmDspSysAllocScalar( h, "Hold Ms", adsrMinMs, adsrMaxMs, adsrIncMs, 500.0);
  1855. cmDspInst_t* rls = cmDspSysAllocScalar( h, "Rls Ms", adsrMinMs, adsrMaxMs, adsrIncMs, 1000.0);
  1856. cmDspInst_t* alvl = cmDspSysAllocScalar( h, "AdsrMax", adsrMinLevel,adsrMaxLevel,adsrIncLevel, adsrMaxLevel);
  1857. cmDspInst_t* sus = cmDspSysAllocScalar( h, "Sustain", adsrMinLevel,adsrMaxLevel,adsrIncLevel, adsrSusLevel);
  1858. // check for allocation errors
  1859. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  1860. goto errLabel;
  1861. cmDspSysInstallCb( h, dly, "val", adsr, "dly", NULL );
  1862. cmDspSysInstallCb( h, atk, "val", adsr, "atk", NULL );
  1863. cmDspSysInstallCb( h, dcy, "val", adsr, "dcy", NULL );
  1864. cmDspSysInstallCb( h, hold, "val", adsr, "hold", NULL );
  1865. cmDspSysInstallCb( h, rls, "val", adsr, "rls", NULL );
  1866. cmDspSysInstallCb( h, alvl, "val", adsr, "alvl", NULL );
  1867. cmDspSysInstallCb( h, sus, "val", adsr, "sus", NULL );
  1868. cmDspSysInstallCb( h, chck, "out", adsr, "gate", NULL );
  1869. cmDspSysInstallCb( h, adsr, "out", mtr, "in", NULL );
  1870. cmDspSysInstallCb( h, adsr, "out", bmf, "in", NULL );
  1871. errLabel:
  1872. return rc;
  1873. }
  1874. //------------------------------------------------------------------------------
  1875. //)
  1876. //( { label:cmDspPgm_Adsr file_desc:"Dynamics compressor example program." kw:[spgm] }
  1877. cmDspRC_t _cmDspSysPgm_Compressor( cmDspSysH_t h, void** userPtrPtr )
  1878. {
  1879. cmDspRC_t rc;
  1880. const cmChar_t* ofn = "/home/kevin/temp/adsr0.bin";
  1881. const char* afn0 = "media/audio/20110723-Kriesberg/Audio Files/Piano 3_01.wav";
  1882. int beg = 6900826;
  1883. int end = 13512262;
  1884. const cmChar_t* afn = cmFsMakeFn(cmFsUserDir(),afn0,NULL,NULL );
  1885. bool bypassFl = false;
  1886. double inGain = 1.0;
  1887. double threshDb = -40.0;
  1888. double ratio_num = 4.0;
  1889. double atkMs = 100.0;
  1890. double rlsMs = 100.0;
  1891. double makeup = 1.0;
  1892. double wndMaxMs = 1000.0;
  1893. double wndMs = 200.0;
  1894. cmDspInst_t* off = cmDspSysAllocInst(h,"Scalar", "Offset", 5, kNumberDuiId, 0.0, cmDspSysSampleRate(h)*600.0, 1.0, 0.0);
  1895. cmDspInst_t* phs = cmDspSysAllocInst(h,"Phasor", NULL, 0 );
  1896. cmDspInst_t* wt = cmDspSysAllocInst(h,"WaveTable",NULL, 6, ((int)cmDspSysSampleRate(h)), 1, afn, -1, beg, end );
  1897. cmDspInst_t* cmp = cmDspSysAllocInst(h,"Compressor",NULL, 8, bypassFl, threshDb, ratio_num, atkMs, rlsMs, makeup, wndMs, wndMaxMs );
  1898. cmDspInst_t* ao0 = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 0 );
  1899. cmDspInst_t* ao1 = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 1 );
  1900. cmDspInst_t* bmf = cmDspSysAllocInst(h,"BinMtxFile", NULL, 2, 1, ofn );
  1901. cmDspInst_t* mtr = cmDspSysAllocInst(h,"Meter","Env", 3, 0.0, 0.0, 1.0);
  1902. cmDspInst_t* igain = cmDspSysAllocScalar( h, "In Gain", 0.0, 10.0, 0.1, inGain);
  1903. cmDspInst_t* thr = cmDspSysAllocScalar( h, "ThreshDb", -100.0, 0.0, 0.1, threshDb);
  1904. cmDspInst_t* rat = cmDspSysAllocScalar( h, "Ratio", 0.1, 100, 0.1, ratio_num);
  1905. cmDspInst_t* atk = cmDspSysAllocScalar( h, "Atk Ms", 0.0, 1000.0, 0.1, atkMs);
  1906. cmDspInst_t* rls = cmDspSysAllocScalar( h, "Rls Ms", 0.0, 1000.0, 0.1, rlsMs);
  1907. cmDspInst_t* mkup = cmDspSysAllocScalar( h, "Makeup", 0.0, 10.0, 0.01, makeup);
  1908. cmDspInst_t* wnd = cmDspSysAllocScalar( h, "Wnd Ms", 1.0, wndMaxMs, 1.0, wndMs );
  1909. // check for allocation errors
  1910. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  1911. goto errLabel;
  1912. cmDspSysConnectAudio(h, phs, "out", wt, "phs" ); // phasor -> wave table
  1913. cmDspSysConnectAudio(h, wt, "out", cmp, "in" ); // wave table -> cmp in
  1914. cmDspSysConnectAudio(h, cmp, "out", ao0, "in" ); // comp -> aout
  1915. cmDspSysConnectAudio(h, cmp, "out", ao1, "in" ); //
  1916. cmDspSysInstallCb(h, off, "val", wt, "beg", NULL );
  1917. cmDspSysInstallCb(h, igain,"val", cmp, "igain", NULL );
  1918. cmDspSysInstallCb(h, thr, "val", cmp, "thr", NULL );
  1919. cmDspSysInstallCb(h, rat, "val", cmp, "ratio", NULL );
  1920. cmDspSysInstallCb(h, atk, "val", cmp, "atk", NULL );
  1921. cmDspSysInstallCb(h, rls, "val", cmp, "rls", NULL );
  1922. cmDspSysInstallCb(h, mkup, "val", cmp, "ogain", NULL );
  1923. cmDspSysInstallCb(h, wnd, "val", cmp, "wnd", NULL );
  1924. cmDspSysInstallCb(h, cmp, "env", bmf, "in", NULL );
  1925. cmDspSysInstallCb(h, cmp, "env", mtr, "in", NULL );
  1926. errLabel:
  1927. return rc;
  1928. }
  1929. //------------------------------------------------------------------------------
  1930. //)
  1931. //( { label:cmDspPgm_BiQuadEq file_desc:"Biquad EQ example program." kw:[spgm] }
  1932. cmDspRC_t _cmDspSysPgm_BiQuadEq( cmDspSysH_t h, void** userPtrPtr )
  1933. {
  1934. cmDspRC_t rc = kOkDspRC;
  1935. const char* afn0 = "media/audio/20110723-Kriesberg/Audio Files/Piano 3_01.wav";
  1936. int beg = 6900826;
  1937. int end = 13512262;
  1938. const cmChar_t* afn = cmFsMakeFn(cmFsUserDir(),afn0,NULL,NULL );
  1939. bool bypassFl = false;
  1940. unsigned modeSymId = cmSymTblRegisterStaticSymbol(cmDspSysSymbolTable(h),"LP");
  1941. double f0hz = 264.0;
  1942. double Q = 1.0;
  1943. double fgain = 1.0;
  1944. cmDspInst_t* off = cmDspSysAllocInst(h,"Scalar", "Offset", 5, kNumberDuiId, 0.0, cmDspSysSampleRate(h)*600.0, 1.0, 0.0);
  1945. cmDspInst_t* phs = cmDspSysAllocInst(h,"Phasor", NULL, 0 );
  1946. cmDspInst_t* wt = cmDspSysAllocInst(h,"WaveTable",NULL, 6, ((int)cmDspSysSampleRate(h)), 1, afn, -1, beg, end );
  1947. cmDspInst_t* flt = cmDspSysAllocInst(h,"BiQuadEq",NULL, 5, bypassFl, modeSymId,f0hz, Q, fgain );
  1948. cmDspInst_t* ao0 = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 0 );
  1949. cmDspInst_t* ao1 = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 1 );
  1950. cmDspInst_t* mode = cmDspSysAllocInst( h, "MsgList","Mode", 1, "biQuadEqMode");
  1951. cmDspInst_t* fhz = cmDspSysAllocScalar( h, "Fc Hz", 0.0, 15000.0, 0.1, f0hz);
  1952. cmDspInst_t* q = cmDspSysAllocScalar( h, "Q", -100.0, 100, 0.1, Q);
  1953. cmDspInst_t* fgn = cmDspSysAllocScalar( h, "Filt Gain", 0.0, 1.0, 0.1, fgain);
  1954. // check for allocation errors
  1955. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  1956. goto errLabel;
  1957. cmDspSysConnectAudio(h, phs, "out", wt, "phs" ); // phasor -> wave table
  1958. cmDspSysConnectAudio(h, wt, "out", flt, "in" ); // wave table -> cmp in
  1959. cmDspSysConnectAudio(h, flt, "out", ao0, "in" ); // filter -> aout
  1960. cmDspSysConnectAudio(h, flt, "out", ao1, "in" ); //
  1961. cmDspSysInstallCb(h, off, "val", wt, "beg", NULL );
  1962. cmDspSysInstallCb(h, mode,"mode",flt, "mode", NULL );
  1963. cmDspSysInstallCb(h, fhz, "val", flt, "f0", NULL );
  1964. cmDspSysInstallCb(h, q, "val", flt, "Q", NULL );
  1965. cmDspSysInstallCb(h, fgn, "val", flt, "gain", NULL );
  1966. errLabel:
  1967. return rc;
  1968. }
  1969. //------------------------------------------------------------------------------
  1970. //)
  1971. //( { label:cmDspPgm_DistDs file_desc:"Guitar distortion example program." kw:[spgm] }
  1972. cmDspRC_t _cmDspSysPgm_DistDs( cmDspSysH_t h, void** userPtrPtr )
  1973. {
  1974. cmDspRC_t rc = kOkDspRC;
  1975. const char* afn0 = "media/audio/20110723-Kriesberg/Audio Files/Piano 3_01.wav";
  1976. int beg = 6900826;
  1977. int end = 13512262;
  1978. const cmChar_t* afn = cmFsMakeFn(cmFsUserDir(),afn0,NULL,NULL );
  1979. bool bypassFl = false;
  1980. double inGain = 1.0;
  1981. double dsrate = 44100.0;
  1982. double bits = 24.0;
  1983. bool rectifyFl = false;
  1984. bool fullRectFl = false;
  1985. double clipDb = -10.0;
  1986. cmDspInst_t* off = cmDspSysAllocInst(h,"Scalar", "Offset", 5, kNumberDuiId, 0.0, cmDspSysSampleRate(h)*600.0, 1.0, 0.0);
  1987. cmDspInst_t* phs = cmDspSysAllocInst(h,"Phasor", NULL, 0 );
  1988. cmDspInst_t* wt = cmDspSysAllocInst(h,"WaveTable",NULL, 6, ((int)cmDspSysSampleRate(h)), 1, afn, -1, beg, end );
  1989. cmDspInst_t* dst = cmDspSysAllocInst(h,"DistDs",NULL, 3, bypassFl, inGain, dsrate, bits );
  1990. cmDspInst_t* ao0 = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 0 );
  1991. cmDspInst_t* ao1 = cmDspSysAllocInst(h,"AudioOut",NULL, 1, 1 );
  1992. cmDspInst_t* ign = cmDspSysAllocScalar( h, "In Gain", 0.0, 10.0, 0.01, 1.0);
  1993. cmDspInst_t* rct = cmDspSysAllocCheck( h, "Rectify", rectifyFl);
  1994. cmDspInst_t* ful = cmDspSysAllocCheck( h, "Full/Half", fullRectFl);
  1995. cmDspInst_t* dsr = cmDspSysAllocScalar( h, "Srate", 0.0, 96000, 1.0, dsrate);
  1996. cmDspInst_t* dbt = cmDspSysAllocScalar( h, "bits", 2.0, 32.0, 1.0, bits);
  1997. cmDspInst_t* clip = cmDspSysAllocScalar( h, "Clip dB", -100.0, 0.0, 0.1, clipDb);
  1998. cmDspInst_t* ogn = cmDspSysAllocScalar( h, "Out Gain", 0.0, 10.0, 0.01, 1.0);
  1999. // check for allocation errors
  2000. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2001. goto errLabel;
  2002. cmDspSysConnectAudio(h, phs, "out", wt, "phs" ); // phasor -> wave table
  2003. cmDspSysConnectAudio(h, wt, "out", dst, "in" ); // wave table -> cmp in
  2004. cmDspSysConnectAudio(h, dst, "out", ao0, "in" ); // filter -> aout
  2005. cmDspSysConnectAudio(h, dst, "out", ao1, "in" ); //
  2006. cmDspSysInstallCb(h, off, "val", wt, "beg", NULL );
  2007. cmDspSysInstallCb(h, ign, "val", dst, "igain", NULL );
  2008. cmDspSysInstallCb(h, dsr, "val", dst, "srate", NULL );
  2009. cmDspSysInstallCb(h, dbt, "val", dst, "bits", NULL );
  2010. cmDspSysInstallCb(h, rct, "out", dst, "rect", NULL );
  2011. cmDspSysInstallCb(h, ful, "out", dst, "full", NULL );
  2012. cmDspSysInstallCb(h, clip, "val", dst, "clip", NULL );
  2013. cmDspSysInstallCb(h, ogn, "val", dst, "ogain", NULL );
  2014. errLabel:
  2015. return rc;
  2016. }
  2017. //------------------------------------------------------------------------------
  2018. //)
  2019. //( { label:cmDspPgm_Seq file_desc:"Message list 'seq' mode example program." kw:[spgm] }
  2020. cmDspRC_t _cmDspSysPgm_Seq( cmDspSysH_t h, void** userPtrPtr )
  2021. {
  2022. cmDspRC_t rc;
  2023. double min = 1.0;
  2024. double max = 10.0;
  2025. double incr = 1.0;
  2026. cmDspInst_t* btn = cmDspSysAllocButton( h, "smack", 0);
  2027. cmDspInst_t* cnt = cmDspSysAllocInst( h, "Counter", NULL, 3, min, max, incr );
  2028. cmDspInst_t* lst = cmDspSysAllocInst( h, "MsgList","Seq", 1, "seqTest");
  2029. cmDspInst_t* prt = cmDspSysAllocInst( h, "Printer", NULL, 1, ">");
  2030. cmDspSysInstallCb(h, lst, "cnt", cnt, "max", NULL );
  2031. cmDspSysInstallCb(h, btn, "out", cnt, "next", NULL );
  2032. cmDspSysInstallCb(h, cnt, "out", lst, "sel", NULL );
  2033. cmDspSysInstallCb(h, lst, "midi", prt, "in", NULL );
  2034. // check for allocation errors
  2035. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2036. goto errLabel;
  2037. errLabel:
  2038. return rc;
  2039. }
  2040. //------------------------------------------------------------------------------
  2041. //)
  2042. //( { label:cmDspPgm_ThunkNet file_desc:"UDP network receiver example program." kw:[spgm] }
  2043. cmDspRC_t _cmDspSysPgm_ThunkNet( cmDspSysH_t h, void** userPtrPtr )
  2044. {
  2045. cmDspRC_t rc;
  2046. cmDspInst_t* add = cmDspSysAllocInst( h, "ScalarOp", "adder-0", 6, 2, "+", "in-0", 0.0, "in-1", 0.0 );
  2047. cmDspInst_t* in = cmDspSysAllocScalar( h, "Input", 0.0, 10.0, 0.001, 0.0);
  2048. cmDspInst_t* out = cmDspSysAllocScalar( h, "Out", 0.0, 10.0, 0.001, 0.0);
  2049. // check for allocation errors
  2050. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2051. goto errLabel;
  2052. cmDspSysInstallCb( h, in, "val", add, "in-1", NULL );
  2053. cmDspSysInstallCb( h, add, "out", out, "val", NULL );
  2054. errLabel:
  2055. return rc;
  2056. }
  2057. //------------------------------------------------------------------------------
  2058. //)
  2059. //( { label:cmDspPgm_WhirlNet file_desc:"UDP network sender example program." kw:[spgm] }
  2060. cmDspRC_t _cmDspSysPgm_WhirlNet( cmDspSysH_t h, void** userPtrPtr )
  2061. {
  2062. cmDspRC_t rc;
  2063. cmDspInst_t* in = cmDspSysAllocScalar( h, "Input", 0.0, 10.0, 0.001, 0.0);
  2064. // check for allocation errors
  2065. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2066. goto errLabel;
  2067. cmDspSysInstallNetCb( h, in, "val", "thunk", "adder-0", "in-0" );
  2068. errLabel:
  2069. return rc;
  2070. }
  2071. //------------------------------------------------------------------------------
  2072. //)
  2073. //( { label:cmDspPgm_NofM file_desc:"Select NofM example program." kw:[spgm] }
  2074. cmDspRC_t _cmDspSysPgm_NofM( cmDspSysH_t h, void** userPtrPtr )
  2075. {
  2076. cmDspRC_t rc;
  2077. unsigned iChCnt = 3;
  2078. unsigned oChCnt = 2;
  2079. unsigned sgShapeId = 0;
  2080. double sgGain = 0.4;
  2081. double xfadeMs = 1000;
  2082. cmDspInst_t* onBtn = cmDspSysAllocButton( h, "on", 0 );
  2083. cmDspInst_t* offBtn = cmDspSysAllocButton(h, "off", 0 );
  2084. cmDspInst_t* sg0 = cmDspSysAllocInst( h, "SigGen", NULL, 3, 500.0, sgShapeId, sgGain );
  2085. cmDspInst_t* sg1 = cmDspSysAllocInst( h, "SigGen", NULL, 3, 1000.0, sgShapeId, sgGain );
  2086. cmDspInst_t* sg2 = cmDspSysAllocInst( h, "SigGen", NULL, 3, 2000.0, sgShapeId, sgGain );
  2087. cmDspInst_t* nom = cmDspSysAllocInst( h,"NofM", NULL, 3, iChCnt, oChCnt, xfadeMs );
  2088. cmDspInst_t* mix = cmDspSysAllocInst( h, "AMix", NULL, 1, oChCnt );
  2089. cmDspInst_t* ao = cmDspSysAllocAudioOut(h, 0, 1.0 );
  2090. cmDspInst_t* btn = cmDspSysAllocButton( h, "cfg", 0);
  2091. cmDspInst_t* sel0 = cmDspSysAllocCheck(h,"Sel-0",0);
  2092. cmDspInst_t* sel1 = cmDspSysAllocCheck(h,"Sel-1",0);
  2093. cmDspInst_t* sel2 = cmDspSysAllocCheck(h,"Sel-2",0);
  2094. cmDspInst_t* in0 = cmDspSysAllocScalar( h, "In-0", 0.0, 10.0, 0.001, 0.0);
  2095. cmDspInst_t* in1 = cmDspSysAllocScalar( h, "In-1", 0.0, 10.0, 0.001, 0.0);
  2096. cmDspInst_t* in2 = cmDspSysAllocScalar( h, "In-2", 0.0, 10.0, 0.001, 0.0);
  2097. cmDspInst_t* out0 = cmDspSysAllocScalar( h, "Out-0", 0.0, 10.0, 0.001, 0.0);
  2098. cmDspInst_t* out1 = cmDspSysAllocScalar( h, "Out-1", 0.0, 10.0, 0.001, 0.0);
  2099. // check for allocation errors
  2100. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2101. goto errLabel;
  2102. cmDspSysConnectAudio( h, sg0, "out", nom, "a-in-0" );
  2103. cmDspSysConnectAudio( h, sg1, "out", nom, "a-in-1" );
  2104. cmDspSysConnectAudio( h, sg2, "out", nom, "a-in-2" );
  2105. cmDspSysConnectAudio( h, nom, "a-out-0", mix, "in-0" );
  2106. cmDspSysConnectAudio( h, nom, "a-out-1", mix, "in-1" );
  2107. cmDspSysConnectAudio( h, mix, "out", ao, "in" );
  2108. cmDspSysInstallCb( h, btn, "sym", nom, "cmd", NULL );
  2109. cmDspSysInstallCb( h, sel0, "out", nom, "sel-0", NULL );
  2110. cmDspSysInstallCb( h, sel1, "out", nom, "sel-1", NULL );
  2111. cmDspSysInstallCb( h, sel2, "out", nom, "sel-2", NULL );
  2112. cmDspSysInstallCb( h, in0, "val", nom, "f-in-0", NULL );
  2113. cmDspSysInstallCb( h, in1, "val", nom, "f-in-1", NULL );
  2114. cmDspSysInstallCb( h, in2, "val", nom, "f-in-2", NULL );
  2115. cmDspSysInstallCb( h, nom, "f-out-0", out0, "val", NULL );
  2116. cmDspSysInstallCb( h, nom, "f-out-1", out1, "val", NULL );
  2117. cmDspSysInstallCb( h, onBtn, "sym", nom, "cmd", NULL );
  2118. cmDspSysInstallCb( h, offBtn, "sym", nom, "cmd", NULL );
  2119. errLabel:
  2120. return rc;
  2121. }
  2122. //------------------------------------------------------------------------------
  2123. //)
  2124. //( { label:cmDspPgm_1ofM file_desc:"Select 1 of N example program." kw:[spgm] }
  2125. cmDspRC_t _cmDspSysPgm_1ofN( cmDspSysH_t h, void** userPtrPtr )
  2126. {
  2127. cmDspRC_t rc;
  2128. unsigned inCnt = 3;
  2129. unsigned initSel = 0;
  2130. cmDspInst_t* oom = cmDspSysAllocInst(h,"1ofN", NULL, 2, inCnt, initSel );
  2131. cmDspInst_t* sel = cmDspSysAllocScalar( h, "Sel", 0, inCnt-1, 0.001, 0.0);
  2132. cmDspInst_t* in0 = cmDspSysAllocScalar( h, "In-0", 0.0, 10.0, 0.001, 0.0);
  2133. cmDspInst_t* in1 = cmDspSysAllocScalar( h, "In-1", 0.0, 10.0, 0.001, 0.0);
  2134. cmDspInst_t* in2 = cmDspSysAllocScalar( h, "In-2", 0.0, 10.0, 0.001, 0.0);
  2135. cmDspInst_t* out = cmDspSysAllocScalar( h, "Out", 0.0, 10.0, 0.001, 0.0);
  2136. // check for allocation errors
  2137. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2138. goto errLabel;
  2139. cmDspSysInstallCb( h, sel, "val", oom, "chidx", NULL );
  2140. cmDspSysInstallCb( h, in0, "val", oom, "f-in-0", NULL );
  2141. cmDspSysInstallCb( h, in1, "val", oom, "f-in-1", NULL );
  2142. cmDspSysInstallCb( h, in2, "val", oom, "f-in-2", NULL );
  2143. cmDspSysInstallCb( h, oom, "f-out", out, "val", NULL );
  2144. errLabel:
  2145. return rc;
  2146. }
  2147. //------------------------------------------------------------------------------
  2148. //)
  2149. //( { label:cmDspPgm_Router file_desc:"Router example program." kw:[spgm] }
  2150. cmDspRC_t _cmDspSysPgm_Router( cmDspSysH_t h, void** userPtrPtr )
  2151. {
  2152. cmDspRC_t rc;
  2153. unsigned inCnt = 3;
  2154. unsigned initSel = 0;
  2155. cmDspInst_t* rtr = cmDspSysAllocInst(h,"Router", NULL, 2, inCnt, initSel );
  2156. cmDspInst_t* sel = cmDspSysAllocScalar( h, "Sel", 0, inCnt-1, 1.0, 0.0);
  2157. cmDspInst_t* in = cmDspSysAllocScalar( h, "In", 0.0, 10.0, 0.001, 0.0);
  2158. cmDspInst_t* out0 = cmDspSysAllocScalar( h, "Out-0", 0.0, 10.0, 0.001, 0.0);
  2159. cmDspInst_t* out1 = cmDspSysAllocScalar( h, "Out-1", 0.0, 10.0, 0.001, 0.0);
  2160. cmDspInst_t* out2 = cmDspSysAllocScalar( h, "Out-2", 0.0, 10.0, 0.001, 0.0);
  2161. // check for allocation errors
  2162. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2163. goto errLabel;
  2164. cmDspSysInstallCb( h, sel, "val", rtr, "sel", NULL );
  2165. cmDspSysInstallCb( h, in, "val", rtr, "f-in", NULL );
  2166. cmDspSysInstallCb( h, rtr, "f-out-0", out0, "val", NULL );
  2167. cmDspSysInstallCb( h, rtr, "f-out-1", out1, "val", NULL );
  2168. cmDspSysInstallCb( h, rtr, "f-out-2", out2, "val", NULL );
  2169. errLabel:
  2170. return rc;
  2171. }
  2172. //------------------------------------------------------------------------------
  2173. //)
  2174. //( { label:cmDspPgm_Preset file_desc:"Preset save/restore example program." kw:[spgm] }
  2175. cmDspRC_t _cmDspSysPgm_Preset( cmDspSysH_t h, void** userPtrPtr )
  2176. {
  2177. cmDspRC_t rc;
  2178. unsigned sgShapeId = 0;
  2179. double sgHz = 500;
  2180. double sgGain = 0.02;
  2181. unsigned grpSymId = cmDspSysPresetRegisterGroup(h,"test");
  2182. const cmChar_t* prefixLabel = NULL;
  2183. cmDspInst_t* sg = cmDspSysAllocInst( h, "SigGen", NULL, 3, sgHz, sgShapeId, sgGain );
  2184. cmDspInst_t* ao = cmDspSysAllocAudioOut( h, 0, 1.0 );
  2185. cmDspInst_t* shapes = cmDspSysAllocMsgListP(h, grpSymId, prefixLabel, "Shape", NULL, "shapeList", 0 );
  2186. cmDspInst_t* gains = cmDspSysAllocMsgListP(h, grpSymId, prefixLabel, "Gains", NULL, "gainMenu", 0 );
  2187. cmDspInst_t* hz = cmDspSysAllocScalarP( h, grpSymId, prefixLabel, "Hz", 0.0, 10000.0, 0.01, sgHz);
  2188. cmDspInst_t* gain = cmDspSysAllocScalarP( h, grpSymId, prefixLabel, "Gain", 0.0, 1.0, 0.01, sgGain);
  2189. cmDspInst_t* preset = cmDspSysAllocInst( h, "Preset", NULL, 1, grpSymId );
  2190. cmDspInst_t* presetLbl = cmDspSysAllocInst( h, "Text", "Preset", 1, "" );
  2191. cmDspInst_t* storeBtn = cmDspSysAllocButton( h, "store", 0);
  2192. cmDspInst_t* recallBtn = cmDspSysAllocButton( h, "recall", 0);
  2193. // check for allocation errors
  2194. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2195. goto errLabel;
  2196. cmDspSysConnectAudio(h, sg, "out", ao, "in" );
  2197. cmDspSysInstallCb( h, shapes,"out", sg, "shape", NULL );
  2198. cmDspSysInstallCb( h, hz, "val", sg, "hz", NULL );
  2199. cmDspSysInstallCb( h, gain, "val", sg, "gain", NULL );
  2200. cmDspSysInstallCb( h, gains, "out", gain, "val", NULL );
  2201. cmDspSysInstallCb( h, presetLbl, "val", preset, "label",NULL);
  2202. cmDspSysInstallCb( h, storeBtn, "sym", preset, "cmd", NULL );
  2203. cmDspSysInstallCb( h, recallBtn, "sym", preset, "cmd", NULL );
  2204. errLabel:
  2205. return rc;
  2206. }
  2207. //------------------------------------------------------------------------------
  2208. //)
  2209. //( { label:cmDspPgm_RsrcWr file_desc:"Set a resource value example program." kw:[spgm] }
  2210. cmDspRC_t _cmDspSysPgm_RsrcWr( cmDspSysH_t h, void** userPtrPtr )
  2211. {
  2212. cmDspRC_t rc = kOkDspRC;
  2213. const cmChar_t* lbl1 = "rsrc1";
  2214. const cmChar_t* lbl2 = "rsrc2";
  2215. const cmChar_t* str1 = NULL;
  2216. const cmChar_t* str2 = NULL;
  2217. if( cmDspRsrcString(h,&str1, lbl1, NULL ) != kOkDspRC )
  2218. str1 = "1";
  2219. if( cmDspRsrcString(h,&str2, lbl2, NULL ) != kOkDspRC )
  2220. str2 = "2";
  2221. cmDspInst_t* rsrcWr = cmDspSysAllocInst( h, "RsrcWr", NULL, 2, lbl1, lbl2 );
  2222. cmDspInst_t* textUi0 = cmDspSysAllocInst( h, "Text", "Value1", 1, str1 );
  2223. cmDspInst_t* textUi1 = cmDspSysAllocInst( h, "Text", "Value2", 1, str2 );
  2224. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2225. goto errLabel;
  2226. cmDspSysInstallCb( h, textUi0, "val", rsrcWr, "rsrc1", NULL );
  2227. cmDspSysInstallCb( h, textUi1, "val", rsrcWr, "rsrc2", NULL );
  2228. errLabel:
  2229. return rc;
  2230. }
  2231. //------------------------------------------------------------------------------
  2232. //)
  2233. //( { label:cmDspPgm_1Up file_desc:"1Up example program." kw:[spgm] }
  2234. cmDspRC_t _cmDspSysPgm_1Up( cmDspSysH_t h, void** userPtrPtr )
  2235. {
  2236. cmDspRC_t rc;
  2237. unsigned chCnt = 3;
  2238. double maxIdx = chCnt - 1;
  2239. unsigned initIdx = 2;
  2240. cmDspInst_t* sel = cmDspSysAllocScalar( h, "Chan", 0.0, maxIdx, 1.0, 0.0 );
  2241. cmDspInst_t* up = cmDspSysAllocInst( h, "1Up", NULL, 2, chCnt, initIdx );
  2242. cmDspInst_t* pr0 = cmDspSysAllocInst( h, "Printer", NULL, 1, "0:" );
  2243. cmDspInst_t* pr1 = cmDspSysAllocInst( h, "Printer", NULL, 1, "1:" );
  2244. cmDspInst_t* pr2 = cmDspSysAllocInst( h, "Printer", NULL, 1, "2:" );
  2245. // check for allocation errors
  2246. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2247. goto errLabel;
  2248. cmDspSysInstallCb( h, sel, "val", up, "sel",NULL);
  2249. cmDspSysInstallCb( h, up, "out-0", pr0, "in", NULL );
  2250. cmDspSysInstallCb( h, up, "out-1", pr1, "in", NULL );
  2251. cmDspSysInstallCb( h, up, "out-2", pr2, "in", NULL );
  2252. errLabel:
  2253. return rc;
  2254. }
  2255. //------------------------------------------------------------------------------
  2256. //)
  2257. //( { label:cmDspPgm_PortToSym file_desc:"PortToSym example program." kw:[spgm] }
  2258. cmDspRC_t _cmDspSysPgm_PortToSym( cmDspSysH_t h, void** userPtrPtr )
  2259. {
  2260. cmDspRC_t rc = kOkDspRC;
  2261. inst_t* btn0 = button( "Btn0", 0.0 );
  2262. inst_t* btn1 = button( "Btn1", 0.0 );
  2263. inst_t* btn2 = button( "Btn2", 0.0 );
  2264. inst_t* pts = inst( "PortToSym", NULL, "one", "two", "three");
  2265. inst_t* pr0 = inst( "Printer", NULL, "sym:" );
  2266. inst_t* pr1 = inst( "Printer", NULL, "btn:" );
  2267. inst_t* pr2 = inst( "Printer", NULL, "out:" );
  2268. // check for allocation errors
  2269. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2270. goto errLabel;
  2271. event( btn0, out, pts, one );
  2272. event( btn1, out, pts, two );
  2273. event( btn2, out, pts, three );
  2274. event( btn0, out, pr1, in );
  2275. event( btn1, out, pr1, in );
  2276. event( btn2, out, pr1, in );
  2277. event( pts, one, pr0, in );
  2278. event( pts, two, pr0, in );
  2279. event( pts, three, pr0, in );
  2280. event( pts, out, pr2, in );
  2281. errLabel:
  2282. return rc;
  2283. }
  2284. //------------------------------------------------------------------------------
  2285. //)
  2286. //( { label:cmDspPgm_IntToSym file_desc:"IntToSym example program." kw:[spgm] }
  2287. cmDspRC_t _cmDspSysPgm_IntToSym( cmDspSysH_t h, void** userPtrPtr )
  2288. {
  2289. cmDspRC_t rc = kOkDspRC;
  2290. inst_t* sel0 = scalar( "Sel0", 0.0, 10.0, 1.0, 1.0 );
  2291. inst_t* sel1 = scalar( "Sel1", 0.0, 10.0, 1.0, 1.0 );
  2292. inst_t* sel2 = scalar( "Sel2", 0.0, 10.0, 1.0, 1.0 );
  2293. inst_t* val = scalar( "Val", 0.0, 10.0, 1.0, 1.0 );
  2294. inst_t* pts = inst( "IntToSym", NULL, 0, "one", 0, "two", 0, "three");
  2295. inst_t* pr0 = inst( "Printer", NULL, "val:" );
  2296. inst_t* pr1 = inst( "Printer", NULL, "sym:" );
  2297. inst_t* pr2 = inst( "Printer", NULL, "out:" );
  2298. // check for allocation errors
  2299. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2300. goto errLabel;
  2301. event( sel0, val, pts, one-int );
  2302. event( sel1, val, pts, two-int );
  2303. event( sel2, val, pts, three-int );
  2304. event( val, val, pts, in );
  2305. event( val, val, pr0, in );
  2306. event( pts, one, pr1, in );
  2307. event( pts, two, pr1, in );
  2308. event( pts, three, pr1, in );
  2309. event( pts, out, pr2, in );
  2310. errLabel:
  2311. return rc;
  2312. }
  2313. //------------------------------------------------------------------------------
  2314. //)
  2315. //( { label:cmDspPgm_Line file_desc:"Line generator example program." kw:[spgm] }
  2316. cmDspRC_t _cmDspSysPgm_Line( cmDspSysH_t h, void** userPtrPtr )
  2317. {
  2318. cmDspRC_t rc = kOkDspRC;
  2319. cmDspInst_t* beg = cmDspSysAllocScalar( h, "beg", -10.0, 10.0, 1.0, 0.0 );
  2320. cmDspInst_t* end = cmDspSysAllocScalar( h, "end", -10.0, 10.0, 1.0, 1.0 );
  2321. cmDspInst_t* dur = cmDspSysAllocScalar( h, "dur", 0.0, 10000.0, 1.0, 0.0 );
  2322. cmDspInst_t* reset = cmDspSysAllocButton( h, "reset", 0.0 );
  2323. cmDspInst_t* line = cmDspSysAllocInst( h, "Line", NULL, 3, 0.0, 10.0, 1000.0 );
  2324. cmDspInst_t* mtr = cmDspSysAllocInst( h, "Meter", NULL, 3, -10.0, 10.0, 0.0 );
  2325. cmDspInst_t* pr1 = cmDspSysAllocInst( h, "Printer", NULL, 1, ">" );
  2326. // check for allocation errors
  2327. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2328. goto errLabel;
  2329. cmDspSysInstallCb( h, beg, "val", line, "beg", NULL);
  2330. cmDspSysInstallCb( h, end, "val", line, "end", NULL);
  2331. cmDspSysInstallCb( h, dur, "val", line, "dur", NULL);
  2332. cmDspSysInstallCb( h, line, "out", mtr, "in", NULL );
  2333. cmDspSysInstallCb( h, reset, "sym", line, "cmd", NULL );
  2334. cmDspSysInstallCb( h, line, "out", pr1, "in", NULL );
  2335. errLabel:
  2336. return rc;
  2337. }
  2338. //------------------------------------------------------------------------------
  2339. //)
  2340. //( { label:cmDspPgm_Array file_desc:"Array and pitch converter example program." kw:[spgm] }
  2341. cmDspRC_t _cmDspSysPgm_Array( cmDspSysH_t h, void** userPtrPtr )
  2342. {
  2343. cmDspRC_t rc = kOkDspRC;
  2344. unsigned cnt = 0;
  2345. const cmChar_t* rsrcLabelStr = "test";
  2346. if( cmDspRsrcArrayCount( h, &cnt, rsrcLabelStr, NULL ) != kOkDspRC )
  2347. return cmErrMsg(&cmDspSysPgmCtx(h)->err,kPgmCfgFailDspRC,"The resource '%s' could not be read.",rsrcLabelStr);
  2348. cmDspInst_t* printBtn = cmDspSysAllocButton( h, "print", 0.0 );
  2349. cmDspInst_t* sendBtn = cmDspSysAllocButton( h, "send", 0.0 );
  2350. cmDspInst_t* cntBtn = cmDspSysAllocButton( h, "count", 0.0 );
  2351. cmDspInst_t* offsCtl = cmDspSysAllocScalar( h, "offset",0.0, 128.0, 1.0, 60.0 );
  2352. cmDspInst_t* array = cmDspSysAllocInst( h, "Array", NULL, 1, rsrcLabelStr );
  2353. cmDspInst_t** pcvt = cmDspSysAllocInstArray( h, cnt, "PitchCvt", NULL, NULL, 0 );
  2354. cmDspInst_t* printer = cmDspSysAllocInst( h, "Printer", NULL, 1, ">" );
  2355. cmDspSysInstallCb( h, printBtn, "sym", array, "cmd", NULL );
  2356. cmDspSysInstallCb( h, sendBtn, "sym", array, "cmd", NULL );
  2357. cmDspSysInstallCb( h, cntBtn, "sym", array, "cmd", NULL );
  2358. cmDspSysInstallCb11N1( h, offsCtl, "val", pcvt, "offs", cnt );
  2359. cmDspSysInstallCb1NN1( h, array, "out", pcvt, "midi", cnt );
  2360. cmDspSysInstallCbN111( h, pcvt, "midi", printer, "in", cnt );
  2361. cmDspSysInstallCb( h, array, "cnt", printer, "in", NULL );
  2362. return rc;
  2363. }
  2364. cmDspRC_t _cmDspSysPgm_SegLine( cmDspSysH_t h, void** userPtrPtr )
  2365. {
  2366. cmDspRC_t rc = kOkDspRC;
  2367. cmDspInst_t* btn = cmDspSysAllocButton( h, "Trig", 0.0 );
  2368. cmDspInst_t* sline = cmDspSysAllocInst( h, "SegLine", NULL, 1, "array" );
  2369. cmDspInst_t* printer = cmDspSysAllocInst( h, "Printer", NULL, 1, ">" );
  2370. // check for allocation errors
  2371. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2372. goto errLabel;
  2373. cmDspSysInstallCb( h, btn, "sym", sline, "trig", NULL );
  2374. cmDspSysInstallCb( h, sline, "out", printer, "in", NULL );
  2375. errLabel:
  2376. return rc;
  2377. }
  2378. //------------------------------------------------------------------------------
  2379. //)
  2380. //( { label:cmDspPgm_AvailCh file_desc:"AvailCh and XFader example program." kw:[spgm] }
  2381. cmDspRC_t _cmDspSysPgm_AvailCh( cmDspSysH_t h, void** userPtrPtr )
  2382. {
  2383. double frqHz = 440.0;
  2384. unsigned xfadeChCnt = 2;
  2385. double xfadeMs = 250.0;
  2386. bool xfadeInitFl = false;
  2387. const char* fn = "/Users/kevin/media/audio/20110723-Kriesberg/Audio Files/Piano 3_01.wav";
  2388. cmDspInst_t* chk0 = cmDspSysAllocInst(h,"Button", "0", 2, kButtonDuiId, 0.0 );
  2389. cmDspInst_t* hz = cmDspSysAllocScalar( h, "hz",0.0, 10000.0, 0.01, 1.0 );
  2390. //cmDspInst_t* chk1 = cmDspSysAllocInst(h,"Button", "1", 2, kCheckDuiId, 0.0 );
  2391. cmDspInst_t* achp = cmDspSysAllocInst( h, "AvailCh", NULL, 1, xfadeChCnt );
  2392. cmDspInst_t* sphp = cmDspSysAllocInst( h, "Phasor", NULL, 2, cmDspSysSampleRate(h), frqHz );
  2393. cmDspInst_t* swtp = cmDspSysAllocInst( h, "WaveTable", NULL, 2, ((int)cmDspSysSampleRate(h)), 4);
  2394. cmDspInst_t* fphp = cmDspSysAllocInst( h, "Phasor", NULL, 1, cmDspSysSampleRate(h) );
  2395. cmDspInst_t* fwtp = cmDspSysAllocInst( h, "WaveTable", NULL, 5, ((int)cmDspSysSampleRate(h)), 1, fn, -1, 7000000 );
  2396. cmDspInst_t* fad0 = cmDspSysAllocInst( h, "Xfader", NULL, 3, xfadeChCnt, xfadeMs, xfadeInitFl );
  2397. cmDspInst_t* prp = cmDspSysAllocInst( h, "Printer", NULL, 1, "ch:" );
  2398. cmDspInst_t* prg0 = cmDspSysAllocInst( h, "Printer", NULL, 1, "g0:" );
  2399. cmDspInst_t* prg1 = cmDspSysAllocInst( h, "Printer", NULL, 1, "g1:" );
  2400. cmDspInst_t* ao0p = cmDspSysAllocInst(h,"AudioOut", NULL, 1, 0 );
  2401. cmDspInst_t* ao1p = cmDspSysAllocInst(h,"AudioOut", NULL, 1, 1 );
  2402. // phasor->sine->fad-0->aout
  2403. cmDspSysConnectAudio(h, sphp, "out", swtp, "phs" );
  2404. cmDspSysConnectAudio(h, swtp, "out", fad0, "in-0" );
  2405. cmDspSysConnectAudio(h, fad0, "out-0", ao0p, "in" );
  2406. // phasor->file->fad-1->aout
  2407. cmDspSysConnectAudio(h, fphp, "out", fwtp, "phs" );
  2408. cmDspSysConnectAudio(h, fwtp, "out", fad0, "in-1" );
  2409. cmDspSysConnectAudio(h, fad0, "out-1", ao1p, "in" );
  2410. //cmDspSysInstallCb(h, chk0, "out", fad0, "gate-0", NULL);
  2411. //cmDspSysInstallCb(h, chk1, "out", fad0, "gate-1", NULL);
  2412. cmDspSysInstallCb(h, chk0, "sym", achp, "trig", NULL); // btn->availCh.trig
  2413. cmDspSysInstallCb(h, achp, "ch", prp, "in", NULL); // availCh.ch -> printer
  2414. cmDspSysInstallCb(h, achp, "gate-0", fad0, "gate-0", NULL ); // availCh.gate->xfad.gate
  2415. cmDspSysInstallCb(h, fad0, "state-0", achp, "dis-0", NULL ); // xfad->state ->availCh.dis
  2416. cmDspSysInstallCb(h, achp, "gate-1", fad0, "gate-1", NULL );
  2417. cmDspSysInstallCb(h, fad0, "state-1", achp, "dis-1", NULL );
  2418. cmDspSysInstallCb(h, hz, "val", sphp, "mult", NULL );
  2419. cmDspSysInstallCb(h, achp, "gate-0", prg0, "in", NULL );
  2420. cmDspSysInstallCb(h, achp, "gate-1", prg1, "in", NULL );
  2421. return kOkDspRC;
  2422. }
  2423. //------------------------------------------------------------------------------
  2424. //)
  2425. //( { label:cmDspPgm_Goertzel file_desc:"Goertzel detector example program." kw:[spgm] }
  2426. cmDspRC_t _cmDspSysPgm_Goertzel( cmDspSysH_t h, void** userPtrPtr )
  2427. {
  2428. cmDspRC_t rc;
  2429. const unsigned chCnt = 8;
  2430. unsigned hopFact = 2;
  2431. double dfltHz = 18000.0;
  2432. unsigned sigGenMode = 2; // sine
  2433. double sigGenGain = 0.9;
  2434. double dfltMixGain = 1.0/chCnt;
  2435. double fcHzV[chCnt];
  2436. unsigned i;
  2437. for(i=0; i<chCnt; ++i)
  2438. fcHzV[i] = 18000.0 + (20000.0-18000.0) * i /chCnt;
  2439. cmDspInst_t* ain = cmDspSysAllocAudioIn( h, 0, 1.0);
  2440. cmDspInst_t* amtr = cmDspSysAllocInst( h, "AMeter", "In", 0 );
  2441. cmDspInst_t* goer = cmDspSysAllocInst( h, "Goertzel", NULL, 3, hopFact, chCnt, fcHzV );
  2442. cmDspSysNewColumn(h,0);
  2443. cmDspInst_t** mtrV = cmDspSysAllocInstArray(h, chCnt, "Meter", "Mtr", NULL, 3, 0.0, 0.0, 1.0 );
  2444. cmDspInst_t** sgV = cmDspSysAllocInstArray(h, chCnt, "SigGen", "SG", NULL, 2, dfltHz, sigGenMode, sigGenGain, 0 );
  2445. cmDspInst_t* mix = cmDspSysAllocInst( h, "AMix", NULL,1, chCnt );
  2446. cmDspInst_t* ao0 = cmDspSysAllocAudioOut( h, 0, 1.0);
  2447. cmDspInst_t* ao1 = cmDspSysAllocAudioOut( h, 0, 1.0);
  2448. cmDspSysNewColumn(h,0);
  2449. cmDspInst_t** hzV = cmDspSysAllocInstArray( h, chCnt, "Scalar", "Hz", NULL, 5, kNumberDuiId, 0.0, 22000.0, 100.0, dfltHz );
  2450. cmDspSysNewColumn(h,0);
  2451. cmDspInst_t** gnV = cmDspSysAllocInstArray( h, chCnt, "Scalar", "Gain", NULL, 5, kNumberDuiId, 0.0, 1.0, 0.01, dfltMixGain );
  2452. cmDspInst_t* igain = cmDspSysAllocScalar( h, "igain", 0.0, 3.0, 0.01, 1.0 );
  2453. cmDspInst_t* hop = cmDspSysAllocScalar( h, "hop", 0.0, 16.0, 1.0, 4.0 );
  2454. //cmDspInst_t* prnt = cmDspSysAllocInst( h,"Printer", NULL, 1, ">" );
  2455. // check for allocation errors
  2456. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2457. goto errLabel;
  2458. cmDspSysConnectAudio(h,ain,"out", goer, "in" );
  2459. cmDspSysConnectAudio(h,ain,"out", amtr, "in" );
  2460. cmDspSysConnectAudioN11N(h,sgV, "out", mix, "in", chCnt );
  2461. cmDspSysConnectAudio(h,mix,"out", ao0, "in" );
  2462. cmDspSysConnectAudio(h,mix,"out", ao1, "in" );
  2463. cmDspSysInstallCb( h, igain, "val", ain, "gain", NULL);
  2464. cmDspSysInstallCbN1N1( h, hzV, "val", sgV, "hz", chCnt);
  2465. cmDspSysInstallCbN11N( h, hzV, "val", goer, "hz", chCnt );
  2466. cmDspSysInstallCbN11N( h, gnV, "val", mix, "gain", chCnt);
  2467. cmDspSysInstallCb1NN1( h, goer, "out", mtrV, "in", chCnt );
  2468. cmDspSysInstallCb( h, hop, "val", goer, "hop", NULL );
  2469. errLabel:
  2470. return rc;
  2471. }
  2472. //------------------------------------------------------------------------------
  2473. //)
  2474. //( { label:cmDspPgm_TakeSeqBldr file_desc:"Take sequence builder example program." kw:[spgm] }
  2475. cmDspRC_t _cmDspSysPgm_TakeSeqBldr( cmDspSysH_t h, void** userPtrPtr )
  2476. {
  2477. cmDspRC_t rc = kOkDspRC;
  2478. //const cmChar_t* tksbFn = "/User/kevin/src/cmkc/src/kc/data/takeSeqBldr0.js";
  2479. const cmChar_t* tksbFn = "/Users/kevin/src/cmkc/src/kc/data/takeSeqBldr_osx.js";
  2480. const cmChar_t* deviceName = "MOTU - Traveler mk3"; //"Fastlane";
  2481. const cmChar_t* portName = "MIDI Port"; // "Fastlane MIDI A";
  2482. //const cmChar_t* deviceName = "DKV-M4";
  2483. //const cmChar_t* portName = "DKV-M4 MIDI 1";
  2484. const cmChar_t* fn = cmFsMakeFn(cmFsUserDir(),tksbFn,NULL,NULL );
  2485. cmDspInst_t* tsb = cmDspSysAllocInst( h,"TakeSeqBldr", NULL, 1, tksbFn );
  2486. cmDspInst_t* tsr = cmDspSysAllocInst( h,"TakeSeqRend", NULL, 0 );
  2487. cmDspInst_t* nano = cmDspSysAllocInst( h,"NanoMap", NULL, 0 );
  2488. cmDspInst_t* mop = cmDspSysAllocInst( h,"MidiOut", NULL, 2, deviceName, portName);
  2489. cmDspSysNewPage(h,"Controls");
  2490. //cmDspInst_t* fnp = cmDspSysAllocInst(h,"Fname", NULL, 3, false,"JS Files (*.js)\tJS Files (*.{js})",fn);
  2491. cmDspInst_t* start = cmDspSysAllocInst( h,"Button", "start", 2, kButtonDuiId, 0.0 );
  2492. cmDspInst_t* stop = cmDspSysAllocInst( h,"Button", "stop", 2, kButtonDuiId, 0.0 );
  2493. cmDspInst_t* cont = cmDspSysAllocInst( h,"Button", "continue", 2, kButtonDuiId, 0.0 );
  2494. cmDspInst_t* prt = cmDspSysAllocInst( h, "Printer", NULL, 1, ">" );
  2495. // check for allocation errors
  2496. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2497. goto errLabel;
  2498. cmDspSysInstallCb( h, tsb, "bldr", tsr, "bldr", NULL);
  2499. cmDspSysInstallCb( h, tsb, "refresh", tsr, "refresh", NULL );
  2500. cmDspSysInstallCb( h, tsb, "sel", tsr, "sel", NULL );
  2501. cmDspSysInstallCb( h, start, "sym", tsr, "cmd", NULL);
  2502. cmDspSysInstallCb( h, stop, "sym", tsr, "cmd", NULL);
  2503. cmDspSysInstallCb( h, cont, "sym", tsr, "cmd", NULL);
  2504. cmDspSysInstallCb( h, tsr, "d1", nano, "d1", NULL);
  2505. cmDspSysInstallCb( h, tsr, "d0", nano, "d0", NULL);
  2506. cmDspSysInstallCb( h, tsr, "status", nano, "status", NULL);
  2507. cmDspSysInstallCb( h, nano, "d1", mop, "d1", NULL);
  2508. cmDspSysInstallCb( h, nano, "d0", mop, "d0", NULL);
  2509. cmDspSysInstallCb( h, nano, "status", mop, "status", NULL);
  2510. //cmDspSysInstallCb( h, tsb, "sel", prt, "in", NULL );
  2511. cmDspSysInstallCb( h, tsb, "refresh", prt, "in", NULL);
  2512. errLabel:
  2513. cmFsFreeFn(fn);
  2514. return rc;
  2515. }
  2516. //------------------------------------------------------------------------------
  2517. //)
  2518. //( { label:cmDspPgm_TwoD file_desc:"Two dimensional controller example program." kw:[spgm] }
  2519. cmDspRC_t _cmDspSysPgm_TwoD( cmDspSysH_t h, void** userPtrPtr )
  2520. {
  2521. cmDspRC_t rc = kOkDspRC;
  2522. cmDspInst_t* twod = cmDspSysAllocInst(h,"twod", NULL, 0);
  2523. cmDspInst_t* aprt = cmDspSysAllocInst(h,"Printer",NULL, 1, "a: ");
  2524. cmDspInst_t* rprt = cmDspSysAllocInst(h,"Printer",NULL, 1, "r: ");
  2525. // check for allocation errors
  2526. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2527. goto errLabel;
  2528. cmDspSysInstallCb(h, twod, "angle", aprt, "in", NULL );
  2529. cmDspSysInstallCb(h, twod, "radius", rprt, "in", NULL );
  2530. errLabel:
  2531. return rc;
  2532. }
  2533. //------------------------------------------------------------------------------
  2534. //)
  2535. //( { label:cmDspPgm_BinEnc file_desc:"HRTF binaural encoder example program." kw:[spgm] }
  2536. cmDspRC_t _cmDspSysPgm_BinEnc( cmDspSysH_t h, void** userPtrPtr )
  2537. {
  2538. cmDspRC_t rc = kOkDspRC;
  2539. double durMs = 10000.0;
  2540. double lineHz = 0.2;
  2541. double maxDurMs = 60000.0;
  2542. double azimBeg = 0.0;
  2543. double azimEnd = 360.0;
  2544. //const char* fn1 = "media/audio/sourcetone/Jazz/Ella & Louis - Under A Blanket Of Blue";
  2545. const char* fn0 = "temp/comhear/drw/monty.wav";
  2546. cmDspInst_t* twod = cmDspSysAllocInst( h, "twod", NULL, 0);
  2547. cmDspInst_t* php = cmDspSysAllocInst( h, "Phasor", NULL, 0 );
  2548. cmDspInst_t* wtp = cmDspSysAllocInst( h, "WaveTable", NULL, 2, ((int)cmDspSysSampleRate(h)), 1 );
  2549. cmDspInst_t* bep = cmDspSysAllocInst( h, "BinauralEnc",NULL, 1, 0);
  2550. cmDspInst_t* ao0p = cmDspSysAllocInst( h, "AudioOut", NULL, 1, 0 );
  2551. cmDspInst_t* ao1p = cmDspSysAllocInst( h, "AudioOut", NULL, 1, 1 );
  2552. cmDspSysNewPage(h,"Controls");
  2553. const cmChar_t* fn = cmFsMakeFn(cmFsUserDir(),fn0,NULL,NULL );
  2554. cmDspInst_t* fnp = cmDspSysAllocInst( h,"Fname", NULL, 3, false,"Audio Files (*.wav,*.aiff,*.aif)\tAudio Files (*.{wav,aiff,aif})",fn);
  2555. cmDspInst_t* beg = cmDspSysAllocScalar( h, "beg", 0.0, azimEnd, 1.0, azimBeg );
  2556. cmDspInst_t* end = cmDspSysAllocScalar( h, "end", 0.0, azimEnd, 1.0, azimEnd );
  2557. cmDspInst_t* dur = cmDspSysAllocScalar( h, "dur", 0.0, maxDurMs, 1.0, durMs );
  2558. cmDspInst_t* reset = cmDspSysAllocButton( h, "reset", 0.0 );
  2559. cmDspInst_t* azm = cmDspSysAllocScalar( h, "azimuth", azimBeg, azimEnd, 1.0, 0.0 );
  2560. cmDspInst_t* angle = cmDspSysAllocScalar( h, "angle", azimBeg, azimEnd, 1.0, 0.0 );
  2561. cmDspInst_t* mode = cmDspSysAllocScalar( h, "mode", 0.0, 1.0, 1.0, 0.0 );
  2562. cmDspInst_t* gain = cmDspSysAllocScalar( h, "gain", 0.0,10.0, 0.01, 1.0 );
  2563. cmDspInst_t* line = cmDspSysAllocInst( h, "Line", NULL, 3, azimBeg, azimEnd, durMs, lineHz );
  2564. cmDspInst_t* prt = cmDspSysAllocInst( h, "Printer", NULL, 1, ">" );
  2565. // check for allocation errors
  2566. if((rc = cmDspSysLastRC(h)) != kOkDspRC )
  2567. goto errLabel;
  2568. cmDspSysConnectAudio(h, php, "out", wtp, "phs" ); // phasor -> wave table
  2569. cmDspSysConnectAudio(h, wtp, "out", bep, "in" );
  2570. cmDspSysConnectAudio(h, bep, "out0", ao0p, "in" ); // wave table -> audio out
  2571. cmDspSysConnectAudio(h, bep, "out1", ao1p, "in" ); //
  2572. cmDspSysInstallCb( h, fnp, "out", wtp, "fn", NULL);
  2573. cmDspSysInstallCb( h, beg, "val", line, "beg", NULL);
  2574. cmDspSysInstallCb( h, end, "val", line, "end", NULL);
  2575. cmDspSysInstallCb( h, dur, "val", line, "dur", NULL);
  2576. cmDspSysInstallCb( h, reset,"sym", line, "cmd", NULL );
  2577. cmDspSysInstallCb( h, line, "out", azm, "val", NULL );
  2578. cmDspSysInstallCb( h, azm, "val", bep, "azim", NULL );
  2579. cmDspSysInstallCb( h, twod, "angle", angle,"val", NULL );
  2580. cmDspSysInstallCb( h, angle,"val", bep, "azim", NULL );
  2581. cmDspSysInstallCb( h, mode, "val", bep, "mode", NULL );
  2582. cmDspSysInstallCb( h, twod, "angle", prt, "in", NULL );
  2583. cmDspSysInstallCb( h, gain, "val", ao0p, "gain", NULL );
  2584. cmDspSysInstallCb( h, gain, "val", ao1p, "gain", NULL );
  2585. return kOkDspRC;
  2586. errLabel:
  2587. return rc;
  2588. }
  2589. //)
  2590. //(
  2591. _cmDspSysPgm_t _cmDspSysPgmArray[] =
  2592. {
  2593. { "reflect", _cmDspSysPgm_ReflectCalc, NULL, NULL },
  2594. { "tksblite", _cmDspSysPgm_TksbLite, NULL, NULL },
  2595. { "tksb", _cmDspSysPgm_Tksb, NULL, NULL },
  2596. { "time_line", _cmDspSysPgm_TimeLine, NULL, NULL },
  2597. { "time_line_lite", _cmDspSysPgm_TimeLineLite, NULL, NULL },
  2598. { "time_line_lite_af", _cmDspSysPgm_TimeLineLiteAf, NULL, NULL },
  2599. { "seq-bldr", _cmDspSysPgm_TakeSeqBldr, NULL, NULL },
  2600. { "multi-out", _cmDspSysPgm_MultiOut, NULL, NULL },
  2601. { "multi-in", _cmDspSysPgm_MultiIn, NULL, NULL },
  2602. { "goertzel", _cmDspSysPgm_Goertzel, NULL, NULL },
  2603. { "main", _cmDspSysPgm_Main, NULL, NULL },
  2604. { "array", _cmDspSysPgm_Array, NULL, NULL },
  2605. { "line", _cmDspSysPgm_Line, NULL, NULL },
  2606. { "1Up", _cmDspSysPgm_1Up, NULL, NULL },
  2607. { "PortToSym", _cmDspSysPgm_PortToSym, NULL, NULL },
  2608. { "IntToSym", _cmDspSysPgm_IntToSym, NULL, NULL },
  2609. { "preset", _cmDspSysPgm_Preset, NULL, NULL },
  2610. { "rsrcWr", _cmDspSysPgm_RsrcWr, NULL, NULL },
  2611. { "router", _cmDspSysPgm_Router, NULL, NULL },
  2612. { "1ofN", _cmDspSysPgm_1ofN, NULL, NULL },
  2613. { "NofM", _cmDspSysPgm_NofM, NULL, NULL },
  2614. { "whirl_net", _cmDspSysPgm_WhirlNet, NULL, NULL },
  2615. { "thunk_net", _cmDspSysPgm_ThunkNet, NULL, NULL },
  2616. { "seq", _cmDspSysPgm_Seq, NULL, NULL },
  2617. { "dist_ds", _cmDspSysPgm_DistDs, NULL, NULL },
  2618. { "bi_quad_eq", _cmDspSysPgm_BiQuadEq, NULL, NULL },
  2619. { "compressor", _cmDspSysPgm_Compressor, NULL, NULL },
  2620. { "adsr", _cmDspSysPgm_Adsr, NULL, NULL },
  2621. { "msg delay", _cmDspSysPgm_MsgDelay, NULL, NULL },
  2622. { "pickup rmod2", _cmDspSysPgm_RingMod2, NULL, NULL },
  2623. { "pickup rmod", _cmDspSysPgm_RingMod, NULL, NULL },
  2624. { "pickup tails", _cmDspSysPgm_NoiseTails, NULL, NULL },
  2625. { "tails_2", _cmDspSysPgm_NoiseTails2, NULL, NULL },
  2626. { "pickups", _cmDspSysPgm_Pickups0, NULL, NULL },
  2627. { "sync_recd", _cmDspSysPgm_SyncRecd, NULL, NULL },
  2628. { "midi_test", _cmDspSysPgm_Test_Midi, NULL, NULL },
  2629. { "pedal_test", _cmDspSysPgm_Test_Pedals, NULL, NULL },
  2630. { "midi_file", _cmDspSysPgm_MidiFilePlay, NULL, NULL },
  2631. { "2_thru", _cmDspSysPgm_Stereo_Through, NULL, NULL },
  2632. { "all_in_out", _cmDspSysPgm_All_In_And_Out, NULL, NULL },
  2633. { "guitar", _cmDspSysPgmGuitar, NULL, NULL },
  2634. { "2_fx", _cmDspSysPgm_Stereo_Fx, NULL, NULL },
  2635. { "sine", _cmDspSysPgm_PlaySine, NULL, NULL },
  2636. { "file", _cmDspSysPgm_PlayFile, NULL, NULL },
  2637. { "gate_detect", _cmDspSysPgm_GateDetect, NULL, NULL },
  2638. { "rt_record", _cmDspSysPgm_RtRecord, NULL, NULL },
  2639. { "record", _cmDspSysPgm_Record, NULL, NULL },
  2640. { "pitch_shift", _cmDspSysPgm_PitchShiftFile, NULL, NULL },
  2641. { "loop_recd", _cmDspSysPgm_LoopRecd, NULL, NULL },
  2642. { "ui_test", _cmDspSysPgm_UiTest, NULL, NULL },
  2643. { "xfade_test", _cmDspSysPgm_Xfade, NULL, NULL },
  2644. { "auto_gain", _cmDspSysPgm_AutoGain, NULL, NULL },
  2645. { "comb filt", _cmDspSysPgm_CombFilt, NULL, NULL },
  2646. { "scalar op", _cmDspSysPgm_ScalarOp, NULL, NULL },
  2647. { "seg_line", _cmDspSysPgm_SegLine, NULL, NULL },
  2648. { "avail_ch", _cmDspSysPgm_AvailCh, NULL, NULL },
  2649. { "two-d", _cmDspSysPgm_TwoD, NULL, NULL },
  2650. { "bin-enc", _cmDspSysPgm_BinEnc, NULL, NULL },
  2651. { NULL , NULL, NULL, NULL }
  2652. };
  2653. _cmDspSysPgm_t* _cmDspSysPgmArrayBase()
  2654. {
  2655. return _cmDspSysPgmArray;
  2656. }
  2657. //)