strans_multi.c 80 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129
  1. #include <stdio.h>
  2. /*
  3. * Copyright (c) 1983-2023 Trevor Wishart and Composers Desktop Project Ltd
  4. * http://www.trevorwishart.co.uk
  5. * http://www.composersdesktop.com
  6. *
  7. This file is part of the CDP System.
  8. The CDP System is free software; you can redistribute it
  9. and/or modify it under the terms of the GNU Lesser General Public
  10. License as published by the Free Software Foundation; either
  11. version 2.1 of the License, or (at your option) any later version.
  12. The CDP System is distributed in the hope that it will be useful,
  13. but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. GNU Lesser General Public License for more details.
  16. You should have received a copy of the GNU Lesser General Public
  17. License along with the CDP System; if not, write to the Free Software
  18. Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
  19. 02111-1307 USA
  20. *
  21. */
  22. #include <stdlib.h>
  23. #include <structures.h>
  24. #include <tkglobals.h>
  25. #include <pnames.h>
  26. #include <filetype.h>
  27. #include <processno.h>
  28. #include <modeno.h>
  29. #include <logic.h>
  30. #include <flags.h>
  31. #include <globcon.h>
  32. #include <speccon.h>
  33. #include <txtucon.h>
  34. #include <cdpmain.h>
  35. #include <math.h>
  36. #include <mixxcon.h>
  37. #include <osbind.h>
  38. #include <standalone.h>
  39. #include <ctype.h>
  40. #include <sfsys.h>
  41. #include <string.h>
  42. #include <srates.h>
  43. #include <modicon.h>
  44. #include <arrays.h>
  45. //#ifdef unix
  46. #define round(x) lround((x))
  47. //#endif
  48. char errstr[2400];
  49. int anal_infiles = 1;
  50. int sloom = 0;
  51. int sloombatch = 0;
  52. const char* cdp_version = "7.1.0";
  53. #define MININC (0.002) /* rwd - black hole avoidance */
  54. //CDP LIB REPLACEMENTS
  55. //static int check_gate_param_validity_and_consistency(dataptr dz);
  56. static int setup_strans_application(dataptr dz);
  57. static int parse_sloom_data(int argc,char *argv[],char ***cmdline,int *cmdlinecnt,dataptr dz);
  58. static int parse_infile_and_check_type(char **cmdline,dataptr dz);
  59. static int setup_strans_param_ranges_and_defaults(dataptr dz);
  60. static int handle_the_outfile(int *cmdlinecnt,char ***cmdline,dataptr dz);
  61. static int setup_and_init_input_param_activity(dataptr dz,int tipc);
  62. static int setup_input_param_defaultval_stores(int tipc,aplptr ap);
  63. static int establish_application(dataptr dz);
  64. static int initialise_vflags(dataptr dz);
  65. static int setup_parameter_storage_and_constants(int storage_cnt,dataptr dz);
  66. static int initialise_is_int_and_no_brk_constants(int storage_cnt,dataptr dz);
  67. static int mark_parameter_types(dataptr dz,aplptr ap);
  68. static int assign_file_data_storage(int infilecnt,dataptr dz);
  69. static int get_tk_cmdline_word(int *cmdlinecnt,char ***cmdline,char *q);
  70. static int get_the_process_no(char *prog_identifier_from_cmdline,dataptr dz);
  71. static int setup_and_init_input_brktable_constants(dataptr dz,int brkcnt);
  72. static int strans_preprocess(dataptr dz);
  73. static int process_varispeed(dataptr dz);
  74. static int convert_brkpnts(dataptr dz);
  75. static int change_frame(dataptr dz);
  76. static long inv_cntevents(long dur,double s0,double s1);
  77. static int force_value_at_end_time(int paramno,dataptr dz);
  78. static int read_samps_for_strans(dataptr dz);
  79. static int samesize(long *obufcnt,long intime0,double insize0,double insize1,long duration,dataptr dz);
  80. static int getetime(long *obufcnt,long t0,long t1,double s0,double s1,long number,dataptr dz);
  81. static double cntevents(long dur,double s0,double s1);
  82. static int timevents(long *obufcnt,long intime0,long intime1,double insize0,double insize1,dataptr dz);
  83. static int write_samps_with_intime_display(float *buf,int samps_to_write,dataptr dz);
  84. static void splice_end(long obufcnt,dataptr dz); /* A kludge to avoid clicks at end */
  85. static int sizeq(double f1,double f2);
  86. static int putval(long *obufcnt,double pos,dataptr dz);
  87. static void dz2props(dataptr dz, SFPROPS* props);
  88. static int create_stransbufs(dataptr dz);
  89. static double refinesize(double hibound,double lobound,double fnumber,long duration,double error,double insize0);
  90. static int integral_times(long *obufcnt,long intime0,long isize,long number,dataptr dz);
  91. static int unvarying_times(long *obufcnt,long intime0,double size,long number,dataptr dz);
  92. static int putintval(long *obufcnt,long i,dataptr dz);
  93. static int do_acceleration(dataptr dz);
  94. static int do_vibrato(dataptr dz);
  95. static double interp_read_sintable(double *sintab,double sfindex);
  96. static int get_the_mode_from_cmdline(char *str,dataptr dz);
  97. /**************************************** MAIN *********************************************/
  98. int main(int argc,char *argv[])
  99. {
  100. int exit_status;
  101. dataptr dz = NULL;
  102. char **cmdline;
  103. int cmdlinecnt;
  104. long n;
  105. //aplptr ap;
  106. int is_launched = FALSE;
  107. if(argc==2 && (strcmp(argv[1],"--version") == 0)) {
  108. fprintf(stdout,"%s\n",cdp_version);
  109. fflush(stdout);
  110. return 0;
  111. }
  112. /* CHECK FOR SOUNDLOOM */
  113. if((sloom = sound_loom_in_use(&argc,&argv)) > 1) {
  114. sloom = 0;
  115. sloombatch = 1;
  116. }
  117. if(sflinit("cdp")){
  118. sfperror("cdp: initialisation\n");
  119. return(FAILED);
  120. }
  121. /* SET UP THE PRINCIPLE DATASTRUCTURE */
  122. if((exit_status = establish_datastructure(&dz))<0) { // CDP LIB
  123. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  124. return(FAILED);
  125. }
  126. if(!sloom) {
  127. if(argc == 1) {
  128. usage1();
  129. return(FAILED);
  130. } else if(argc == 2) {
  131. usage2(argv[1]);
  132. return(FAILED);
  133. }
  134. }
  135. dz->maxmode = 4;
  136. if(!sloom) {
  137. if((exit_status = make_initial_cmdline_check(&argc,&argv))<0) { // CDP LIB
  138. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  139. return(FAILED);
  140. }
  141. cmdline = argv;
  142. cmdlinecnt = argc;
  143. if((get_the_process_no(argv[0],dz))<0)
  144. return(FAILED);
  145. cmdline++;
  146. cmdlinecnt--;
  147. if((exit_status = get_the_mode_from_cmdline(cmdline[0],dz))<0) {
  148. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  149. return(exit_status);
  150. }
  151. cmdline++;
  152. cmdlinecnt--;
  153. // setup_particular_application =
  154. if((exit_status = setup_strans_application(dz))<0) {
  155. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  156. return(FAILED);
  157. }
  158. if((exit_status = count_and_allocate_for_infiles(cmdlinecnt,cmdline,dz))<0) { // CDP LIB
  159. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  160. return(FAILED);
  161. }
  162. } else {
  163. //parse_TK_data() =
  164. if((exit_status = parse_sloom_data(argc,argv,&cmdline,&cmdlinecnt,dz))<0) {
  165. exit_status = print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  166. return(exit_status);
  167. }
  168. }
  169. //ap = dz->application;
  170. // parse_infile_and_hone_type() =
  171. if((exit_status = parse_infile_and_check_type(cmdline,dz))<0) {
  172. exit_status = print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  173. return(FAILED);
  174. }
  175. // setup_param_ranges_and_defaults() =
  176. if((exit_status = setup_strans_param_ranges_and_defaults(dz))<0) {
  177. exit_status = print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  178. return(FAILED);
  179. }
  180. // open_first_infile CDP LIB
  181. if((exit_status = open_first_infile(cmdline[0],dz))<0) {
  182. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  183. return(FAILED);
  184. }
  185. cmdlinecnt--;
  186. cmdline++;
  187. // handle_extra_infiles() : redundant
  188. // handle_outfile() =
  189. if((exit_status = handle_the_outfile(&cmdlinecnt,&cmdline,dz))<0) {
  190. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  191. return(FAILED);
  192. }
  193. // handle_formants() redundant
  194. // handle_formant_quiksearch() redundant
  195. // handle_special_data() redundant
  196. if((exit_status = read_parameters_and_flags(&cmdline,&cmdlinecnt,dz))<0) { // CDP LIB
  197. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  198. return(FAILED);
  199. }
  200. // check_param_validity_and_consistency() redundant
  201. is_launched = TRUE;
  202. dz->bufcnt = 2;
  203. if((dz->sampbuf = (float **)malloc(sizeof(float *) * (dz->bufcnt+1)))==NULL) {
  204. sprintf(errstr,"INSUFFICIENT MEMORY establishing sample buffers.\n");
  205. return(MEMORY_ERROR);
  206. }
  207. if((dz->sbufptr = (float **)malloc(sizeof(float *) * dz->bufcnt))==NULL) {
  208. sprintf(errstr,"INSUFFICIENT MEMORY establishing sample buffer pointers.\n");
  209. return(MEMORY_ERROR);
  210. }
  211. for(n = 0;n <dz->bufcnt; n++)
  212. dz->sampbuf[n] = dz->sbufptr[n] = (float *)0;
  213. dz->sampbuf[n] = (float *)0;
  214. if((exit_status = create_stransbufs(dz))<0) { // CDP LIB
  215. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  216. return(FAILED);
  217. }
  218. if((exit_status = strans_preprocess(dz))<0) {
  219. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  220. return(FAILED);
  221. }
  222. switch(dz->mode) {
  223. case(0):
  224. case(1): exit_status = process_varispeed(dz); break;
  225. case(2): exit_status = do_acceleration(dz); break;
  226. case(3): exit_status = do_vibrato(dz); break;
  227. }
  228. if(exit_status<0) {
  229. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  230. return(FAILED);
  231. }
  232. if((exit_status = complete_output(dz))<0) { // CDP LIB
  233. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  234. return(FAILED);
  235. }
  236. exit_status = print_messages_and_close_sndfiles(FINISHED,is_launched,dz); // CDP LIB
  237. free(dz);
  238. return(SUCCEEDED);
  239. }
  240. /**********************************************
  241. REPLACED CDP LIB FUNCTIONS
  242. **********************************************/
  243. /****************************** SET_PARAM_DATA *********************************/
  244. int set_param_data(aplptr ap, int special_data,int maxparamcnt,int paramcnt,char *paramlist)
  245. {
  246. ap->special_data = (char)special_data;
  247. ap->param_cnt = (char)paramcnt;
  248. ap->max_param_cnt = (char)maxparamcnt;
  249. if(ap->max_param_cnt>0) {
  250. if((ap->param_list = (char *)malloc((size_t)(ap->max_param_cnt+1)))==NULL) {
  251. sprintf(errstr,"INSUFFICIENT MEMORY: for param_list\n");
  252. return(MEMORY_ERROR);
  253. }
  254. strcpy(ap->param_list,paramlist);
  255. }
  256. return(FINISHED);
  257. }
  258. /****************************** SET_VFLGS *********************************/
  259. int set_vflgs
  260. (aplptr ap,char *optflags,int optcnt,char *optlist,char *varflags,int vflagcnt, int vparamcnt,char *varlist)
  261. {
  262. ap->option_cnt = (char) optcnt; /*RWD added cast */
  263. if(optcnt) {
  264. if((ap->option_list = (char *)malloc((size_t)(optcnt+1)))==NULL) {
  265. sprintf(errstr,"INSUFFICIENT MEMORY: for option_list\n");
  266. return(MEMORY_ERROR);
  267. }
  268. strcpy(ap->option_list,optlist);
  269. if((ap->option_flags = (char *)malloc((size_t)(optcnt+1)))==NULL) {
  270. sprintf(errstr,"INSUFFICIENT MEMORY: for option_flags\n");
  271. return(MEMORY_ERROR);
  272. }
  273. strcpy(ap->option_flags,optflags);
  274. }
  275. ap->vflag_cnt = (char) vflagcnt;
  276. ap->variant_param_cnt = (char) vparamcnt;
  277. if(vflagcnt) {
  278. if((ap->variant_list = (char *)malloc((size_t)(vflagcnt+1)))==NULL) {
  279. sprintf(errstr,"INSUFFICIENT MEMORY: for variant_list\n");
  280. return(MEMORY_ERROR);
  281. }
  282. strcpy(ap->variant_list,varlist);
  283. if((ap->variant_flags = (char *)malloc((size_t)(vflagcnt+1)))==NULL) {
  284. sprintf(errstr,"INSUFFICIENT MEMORY: for variant_flags\n");
  285. return(MEMORY_ERROR);
  286. }
  287. strcpy(ap->variant_flags,varflags);
  288. }
  289. return(FINISHED);
  290. }
  291. /***************************** APPLICATION_INIT **************************/
  292. int application_init(dataptr dz)
  293. {
  294. int exit_status;
  295. int storage_cnt;
  296. int tipc, brkcnt;
  297. aplptr ap = dz->application;
  298. if(ap->vflag_cnt>0)
  299. initialise_vflags(dz);
  300. tipc = ap->max_param_cnt + ap->option_cnt + ap->variant_param_cnt;
  301. ap->total_input_param_cnt = (char)tipc;
  302. if(tipc>0) {
  303. if((exit_status = setup_input_param_range_stores(tipc,ap))<0)
  304. return(exit_status);
  305. if((exit_status = setup_input_param_defaultval_stores(tipc,ap))<0)
  306. return(exit_status);
  307. if((exit_status = setup_and_init_input_param_activity(dz,tipc))<0)
  308. return(exit_status);
  309. }
  310. brkcnt = tipc;
  311. //THERE ARE NO INPUTFILE brktables USED IN THIS PROCESS
  312. if(brkcnt>0) {
  313. if((exit_status = setup_and_init_input_brktable_constants(dz,brkcnt))<0)
  314. return(exit_status);
  315. }
  316. if((storage_cnt = tipc + ap->internal_param_cnt)>0) {
  317. if((exit_status = setup_parameter_storage_and_constants(storage_cnt,dz))<0)
  318. return(exit_status);
  319. if((exit_status = initialise_is_int_and_no_brk_constants(storage_cnt,dz))<0)
  320. return(exit_status);
  321. }
  322. if((exit_status = mark_parameter_types(dz,ap))<0)
  323. return(exit_status);
  324. // establish_infile_constants() replaced by
  325. dz->infilecnt = 1;
  326. //establish_bufptrs_and_extra_buffers():
  327. if((exit_status = setup_internal_arrays_and_array_pointers(dz))<0)
  328. return(exit_status);
  329. return(FINISHED);
  330. }
  331. /********************** SETUP_PARAMETER_STORAGE_AND_CONSTANTS ********************/
  332. /* RWD mallo changed to calloc; helps debug verison run as release! */
  333. int setup_parameter_storage_and_constants(int storage_cnt,dataptr dz)
  334. {
  335. if((dz->param = (double *)calloc(storage_cnt, sizeof(double)))==NULL) {
  336. sprintf(errstr,"setup_parameter_storage_and_constants(): 1\n");
  337. return(MEMORY_ERROR);
  338. }
  339. if((dz->iparam = (int *)calloc(storage_cnt, sizeof(int) ))==NULL) {
  340. sprintf(errstr,"setup_parameter_storage_and_constants(): 2\n");
  341. return(MEMORY_ERROR);
  342. }
  343. if((dz->is_int = (char *)calloc(storage_cnt, sizeof(char)))==NULL) {
  344. sprintf(errstr,"setup_parameter_storage_and_constants(): 3\n");
  345. return(MEMORY_ERROR);
  346. }
  347. if((dz->no_brk = (char *)calloc(storage_cnt, sizeof(char)))==NULL) {
  348. sprintf(errstr,"setup_parameter_storage_and_constants(): 5\n");
  349. return(MEMORY_ERROR);
  350. }
  351. return(FINISHED);
  352. }
  353. /************** INITIALISE_IS_INT_AND_NO_BRK_CONSTANTS *****************/
  354. int initialise_is_int_and_no_brk_constants(int storage_cnt,dataptr dz)
  355. {
  356. int n;
  357. for(n=0;n<storage_cnt;n++) {
  358. dz->is_int[n] = (char)0;
  359. dz->no_brk[n] = (char)0;
  360. }
  361. return(FINISHED);
  362. }
  363. /***************************** MARK_PARAMETER_TYPES **************************/
  364. int mark_parameter_types(dataptr dz,aplptr ap)
  365. {
  366. int n, m; /* PARAMS */
  367. for(n=0;n<ap->max_param_cnt;n++) {
  368. switch(ap->param_list[n]) {
  369. case('0'): break; /* dz->is_active[n] = 0 is default */
  370. case('i'): dz->is_active[n] = (char)1; dz->is_int[n] = (char)1;dz->no_brk[n] = (char)1; break;
  371. case('I'): dz->is_active[n] = (char)1; dz->is_int[n] = (char)1; break;
  372. case('d'): dz->is_active[n] = (char)1; dz->no_brk[n] = (char)1; break;
  373. case('D'): dz->is_active[n] = (char)1; /* normal case: double val or brkpnt file */ break;
  374. default:
  375. sprintf(errstr,"Programming error: invalid parameter type in mark_parameter_types()\n");
  376. return(PROGRAM_ERROR);
  377. }
  378. } /* OPTIONS */
  379. for(n=0,m=ap->max_param_cnt;n<ap->option_cnt;n++,m++) {
  380. switch(ap->option_list[n]) {
  381. case('i'): dz->is_active[m] = (char)1; dz->is_int[m] = (char)1; dz->no_brk[m] = (char)1; break;
  382. case('I'): dz->is_active[m] = (char)1; dz->is_int[m] = (char)1; break;
  383. case('d'): dz->is_active[m] = (char)1; dz->no_brk[m] = (char)1; break;
  384. case('D'): dz->is_active[m] = (char)1; /* normal case: double val or brkpnt file */ break;
  385. default:
  386. sprintf(errstr,"Programming error: invalid option type in mark_parameter_types()\n");
  387. return(PROGRAM_ERROR);
  388. }
  389. } /* VARIANTS */
  390. for(n=0,m=ap->max_param_cnt + ap->option_cnt;n < ap->variant_param_cnt; n++, m++) {
  391. switch(ap->variant_list[n]) {
  392. case('0'): break;
  393. case('i'): dz->is_active[m] = (char)1; dz->is_int[m] = (char)1; dz->no_brk[m] = (char)1; break;
  394. case('I'): dz->is_active[m] = (char)1; dz->is_int[m] = (char)1; break;
  395. case('d'): dz->is_active[m] = (char)1; dz->no_brk[m] = (char)1; break;
  396. case('D'): dz->is_active[m] = (char)1; /* normal case: double val or brkpnt file */ break;
  397. default:
  398. sprintf(errstr,"Programming error: invalid variant type in mark_parameter_types()\n");
  399. return(PROGRAM_ERROR);
  400. }
  401. } /* INTERNAL */
  402. for(n=0,
  403. m=ap->max_param_cnt + ap->option_cnt + ap->variant_param_cnt; n<ap->internal_param_cnt; n++,m++) {
  404. switch(ap->internal_param_list[n]) {
  405. case('0'): break; /* dummy variables: variables not used: but important for internal paream numbering!! */
  406. case('i'): dz->is_int[m] = (char)1; dz->no_brk[m] = (char)1; break;
  407. case('d'): dz->no_brk[m] = (char)1; break;
  408. default:
  409. sprintf(errstr,"Programming error: invalid internal param type in mark_parameter_types()\n");
  410. return(PROGRAM_ERROR);
  411. }
  412. }
  413. return(FINISHED);
  414. }
  415. /************************ HANDLE_THE_OUTFILE *********************/
  416. int handle_the_outfile(int *cmdlinecnt,char ***cmdline,dataptr dz)
  417. {
  418. int stype, n;
  419. char *filename = (*cmdline)[0];
  420. if(filename[0]=='-' && filename[1]=='f') {
  421. dz->floatsam_output = 1;
  422. dz->true_outfile_stype = SAMP_FLOAT;
  423. filename+= 2;
  424. }
  425. if(!sloom) {
  426. if(file_has_invalid_startchar(filename) || value_is_numeric(filename)) {
  427. sprintf(errstr,"Outfile name %s has invalid start character(s) or looks too much like a number.\n",filename);
  428. return(DATA_ERROR);
  429. }
  430. }
  431. strcpy(dz->outfilename,filename);
  432. if(dz->floatsam_output!=1)
  433. stype = SAMP_SHORT;
  434. else
  435. stype = dz->infile->stype;
  436. dz->true_outfile_stype = stype;
  437. dz->outfilesize = -1;
  438. if(dz->infile->channels > 2 || stype > SAMP_FLOAT) {
  439. SFPROPS props, inprops;
  440. dz2props(dz,&props);
  441. props.chans = dz->infile->channels;
  442. props.srate = dz->infile->srate;
  443. if(dz->ifd && dz->ifd[0] >=0) {
  444. if(snd_headread(dz->ifd[0], &inprops)) /* snd_getchanformat not working ...*/
  445. props.chformat = inprops.chformat;
  446. }
  447. dz->ofd = sndcreat_ex(filename,dz->outfilesize,&props,SFILE_CDP,CDP_CREATE_NORMAL);
  448. if(dz->ofd < 0){
  449. sprintf(errstr,"Cannot open output file %s\n", filename);
  450. return(DATA_ERROR);
  451. }
  452. } else {
  453. if((dz->ofd = sndcreat_formatted(filename,dz->outfilesize,stype,
  454. dz->infile->channels,dz->infile->srate,CDP_CREATE_NORMAL)) < 0) {
  455. sprintf(errstr,"Cannot open output file %s\n", filename);
  456. return(DATA_ERROR);
  457. }
  458. }
  459. dz->outchans = dz->infile->channels;
  460. dz->needpeaks = 1;
  461. dz->outpeaks = (CHPEAK *) malloc(sizeof(CHPEAK) * dz->outchans);
  462. if(dz->outpeaks==NULL)
  463. return MEMORY_ERROR;
  464. dz->outpeakpos = (unsigned int *) malloc(sizeof(unsigned int) * dz->outchans);
  465. if(dz->outpeakpos==NULL)
  466. return MEMORY_ERROR;
  467. for(n=0;n < dz->outchans;n++){
  468. dz->outpeaks[n].value = 0.0f;
  469. dz->outpeaks[n].position = 0;
  470. dz->outpeakpos[n] = 0;
  471. }
  472. dz->outfilesize = sndsizeEx(dz->ofd);
  473. (*cmdline)++;
  474. (*cmdlinecnt)--;
  475. return(FINISHED);
  476. }
  477. /***************************** ESTABLISH_APPLICATION **************************/
  478. int establish_application(dataptr dz)
  479. {
  480. aplptr ap;
  481. if((dz->application = (aplptr)malloc(sizeof (struct applic)))==NULL) {
  482. sprintf(errstr,"establish_application()\n");
  483. return(MEMORY_ERROR);
  484. }
  485. ap = dz->application;
  486. memset((char *)ap,0,sizeof(struct applic));
  487. return(FINISHED);
  488. }
  489. /************************* INITIALISE_VFLAGS *************************/
  490. int initialise_vflags(dataptr dz)
  491. {
  492. int n;
  493. if((dz->vflag = (char *)malloc(dz->application->vflag_cnt * sizeof(char)))==NULL) {
  494. sprintf(errstr,"INSUFFICIENT MEMORY: vflag store,\n");
  495. return(MEMORY_ERROR);
  496. }
  497. for(n=0;n<dz->application->vflag_cnt;n++)
  498. dz->vflag[n] = FALSE;
  499. return FINISHED;
  500. }
  501. /************************* SETUP_INPUT_PARAM_DEFAULTVALS *************************/
  502. int setup_input_param_defaultval_stores(int tipc,aplptr ap)
  503. {
  504. int n;
  505. if((ap->default_val = (double *)malloc(tipc * sizeof(double)))==NULL) {
  506. sprintf(errstr,"INSUFFICIENT MEMORY for application default values store\n");
  507. return(MEMORY_ERROR);
  508. }
  509. for(n=0;n<tipc;n++)
  510. ap->default_val[n] = 0.0;
  511. return(FINISHED);
  512. }
  513. /***************************** SETUP_AND_INIT_INPUT_PARAM_ACTIVITY **************************/
  514. int setup_and_init_input_param_activity(dataptr dz,int tipc)
  515. {
  516. int n;
  517. if((dz->is_active = (char *)malloc((size_t)tipc))==NULL) {
  518. sprintf(errstr,"setup_and_init_input_param_activity()\n");
  519. return(MEMORY_ERROR);
  520. }
  521. for(n=0;n<tipc;n++)
  522. dz->is_active[n] = (char)0;
  523. return(FINISHED);
  524. }
  525. /************************* SETUP_STRANS_APPLICATION *******************/
  526. int setup_strans_application(dataptr dz)
  527. {
  528. int exit_status;
  529. aplptr ap;
  530. if((exit_status = establish_application(dz))<0) // GLOBAL
  531. return(FAILED);
  532. ap = dz->application;
  533. // SEE parstruct FOR EXPLANATION of next 2 functions
  534. switch(dz->mode) {
  535. case(0):
  536. case(1):
  537. if((exit_status = set_param_data(ap,0 ,1,1,"D"))<0)
  538. return(FAILED);
  539. if((exit_status = set_vflgs(ap,"",0,"","o",1,0,"0"))<0)
  540. return(FAILED);
  541. break;
  542. case(2):
  543. if((exit_status = set_param_data(ap,0 ,2,2, "dd"))<0)
  544. return(FAILED);
  545. if((exit_status = set_vflgs(ap,"s",1,"d","",0,0,""))<0)
  546. return(FAILED);
  547. break;
  548. case(3):
  549. if((exit_status = set_param_data(ap,0 ,2,2, "DD"))<0)
  550. return(FAILED);
  551. if((exit_status = set_vflgs(ap,"",0,"","",0,0,""))<0)
  552. return(FAILED);
  553. break;
  554. }
  555. // TW April 2015 -->
  556. if((exit_status = set_legal_internalparam_structure(dz->process,dz->mode,ap))<0)
  557. return(exit_status); /* LIBRARY */
  558. // <-- TW April 2015
  559. // set_legal_infile_structure -->
  560. dz->has_otherfile = FALSE;
  561. // assign_process_logic -->
  562. dz->input_data_type = SNDFILES_ONLY;
  563. dz->process_type = UNEQUAL_SNDFILE;
  564. dz->outfiletype = SNDFILE_OUT;
  565. return application_init(dz); //GLOBAL
  566. }
  567. /************************* PARSE_INFILE_AND_CHECK_TYPE *******************/
  568. int parse_infile_and_check_type(char **cmdline,dataptr dz)
  569. {
  570. int exit_status;
  571. infileptr infile_info;
  572. if(!sloom) {
  573. if((infile_info = (infileptr)malloc(sizeof(struct filedata)))==NULL) {
  574. sprintf(errstr,"INSUFFICIENT MEMORY for infile structure to test file data.");
  575. return(MEMORY_ERROR);
  576. } else if((exit_status = cdparse(cmdline[0],infile_info))<0) {
  577. sprintf(errstr,"Failed to parse input file %s\n",cmdline[0]);
  578. return(PROGRAM_ERROR);
  579. } else if(infile_info->filetype != SNDFILE) {
  580. sprintf(errstr,"File %s is not of correct type\n",cmdline[0]);
  581. return(DATA_ERROR);
  582. } else if((exit_status = copy_parse_info_to_main_structure(infile_info,dz))<0) {
  583. sprintf(errstr,"Failed to copy file parsing information\n");
  584. return(PROGRAM_ERROR);
  585. }
  586. free(infile_info);
  587. }
  588. return(FINISHED);
  589. }
  590. /************************* SETUP_STRANS_PARAM_RANGES_AND_DEFAULTS *******************/
  591. int setup_strans_param_ranges_and_defaults(dataptr dz)
  592. {
  593. int exit_status;
  594. double duration;
  595. aplptr ap = dz->application;
  596. // set_param_ranges()
  597. ap->total_input_param_cnt = (char)(ap->max_param_cnt + ap->option_cnt + ap->variant_param_cnt);
  598. // NB total_input_param_cnt is > 0 !!!
  599. if((exit_status = setup_input_param_range_stores(ap->total_input_param_cnt,ap))<0)
  600. return(FAILED);
  601. // get_param_ranges()
  602. duration = (double)(dz->insams[0]/dz->infile->channels)/(double)dz->infile->srate;
  603. switch(dz->mode) {
  604. case(MOD_TRANSPOS):
  605. ap->lo[VTRANS_TRANS] = MIN_TRANSPOS;
  606. ap->hi[VTRANS_TRANS] = MAX_TRANSPOS;
  607. ap->default_val[VTRANS_TRANS] = 1.0;
  608. break;
  609. case(MOD_TRANSPOS_SEMIT):
  610. ap->lo[VTRANS_TRANS] = EIGHT_8VA_DOWN;
  611. ap->hi[VTRANS_TRANS] = EIGHT_8VA_UP;
  612. ap->default_val[VTRANS_TRANS] = 0.0;
  613. break;
  614. case(2):
  615. ap->lo[ACCEL_ACCEL] = MIN_ACCEL;
  616. ap->hi[ACCEL_ACCEL] = MAX_ACCEL;
  617. ap->default_val[ACCEL_ACCEL] = 1.0;
  618. ap->lo[ACCEL_GOALTIME] = MINTIME_ACCEL;
  619. ap->hi[ACCEL_GOALTIME] = duration;
  620. ap->default_val[ACCEL_GOALTIME] = min(1.0,duration);
  621. ap->lo[ACCEL_STARTTIME] = 0.0;
  622. ap->hi[ACCEL_STARTTIME] = duration - MINTIME_ACCEL;
  623. ap->default_val[ACCEL_STARTTIME]= 0.0;
  624. break;
  625. case(3):
  626. ap->lo[VIB_FRQ] = 0.0;
  627. ap->hi[VIB_FRQ] = MAX_VIB_FRQ;
  628. ap->default_val[VIB_FRQ] = DEFAULT_VIB_FRQ;
  629. ap->lo[VIB_DEPTH] = 0.0;
  630. ap->hi[VIB_DEPTH] = EIGHT_8VA_UP;
  631. ap->default_val[VIB_DEPTH] = DEFAULT_VIB_DEPTH;
  632. break;
  633. }
  634. if(!sloom)
  635. put_default_vals_in_all_params(dz);
  636. return(FINISHED);
  637. }
  638. /********************************* PARSE_SLOOM_DATA *********************************/
  639. int parse_sloom_data(int argc,char *argv[],char ***cmdline,int *cmdlinecnt,dataptr dz)
  640. {
  641. int exit_status;
  642. int cnt = 1, infilecnt;
  643. int filesize, insams, inbrksize;
  644. double dummy;
  645. int true_cnt = 0;
  646. //aplptr ap;
  647. while(cnt<=PRE_CMDLINE_DATACNT) {
  648. if(cnt > argc) {
  649. sprintf(errstr,"Insufficient data sent from TK\n");
  650. return(DATA_ERROR);
  651. }
  652. switch(cnt) {
  653. case(1):
  654. if(sscanf(argv[cnt],"%d",&dz->process)!=1) {
  655. sprintf(errstr,"Cannot read process no. sent from TK\n");
  656. return(DATA_ERROR);
  657. }
  658. break;
  659. case(2):
  660. if(sscanf(argv[cnt],"%d",&dz->mode)!=1) {
  661. sprintf(errstr,"Cannot read mode no. sent from TK\n");
  662. return(DATA_ERROR);
  663. }
  664. if(dz->mode > 0)
  665. dz->mode--;
  666. //setup_particular_application() =
  667. if((exit_status = setup_strans_application(dz))<0)
  668. return(exit_status);
  669. //ap = dz->application;
  670. break;
  671. case(3):
  672. if(sscanf(argv[cnt],"%d",&infilecnt)!=1) {
  673. sprintf(errstr,"Cannot read infilecnt sent from TK\n");
  674. return(DATA_ERROR);
  675. }
  676. if(infilecnt < 1) {
  677. true_cnt = cnt + 1;
  678. cnt = PRE_CMDLINE_DATACNT; /* force exit from loop after assign_file_data_storage */
  679. }
  680. if((exit_status = assign_file_data_storage(infilecnt,dz))<0)
  681. return(exit_status);
  682. break;
  683. case(INPUT_FILETYPE+4):
  684. if(sscanf(argv[cnt],"%d",&dz->infile->filetype)!=1) {
  685. sprintf(errstr,"Cannot read filetype sent from TK (%s)\n",argv[cnt]);
  686. return(DATA_ERROR);
  687. }
  688. break;
  689. case(INPUT_FILESIZE+4):
  690. if(sscanf(argv[cnt],"%d",&filesize)!=1) {
  691. sprintf(errstr,"Cannot read infilesize sent from TK\n");
  692. return(DATA_ERROR);
  693. }
  694. dz->insams[0] = filesize;
  695. break;
  696. case(INPUT_INSAMS+4):
  697. if(sscanf(argv[cnt],"%d",&insams)!=1) {
  698. sprintf(errstr,"Cannot read insams sent from TK\n");
  699. return(DATA_ERROR);
  700. }
  701. dz->insams[0] = insams;
  702. break;
  703. case(INPUT_SRATE+4):
  704. if(sscanf(argv[cnt],"%d",&dz->infile->srate)!=1) {
  705. sprintf(errstr,"Cannot read srate sent from TK\n");
  706. return(DATA_ERROR);
  707. }
  708. break;
  709. case(INPUT_CHANNELS+4):
  710. if(sscanf(argv[cnt],"%d",&dz->infile->channels)!=1) {
  711. sprintf(errstr,"Cannot read channels sent from TK\n");
  712. return(DATA_ERROR);
  713. }
  714. break;
  715. case(INPUT_STYPE+4):
  716. if(sscanf(argv[cnt],"%d",&dz->infile->stype)!=1) {
  717. sprintf(errstr,"Cannot read stype sent from TK\n");
  718. return(DATA_ERROR);
  719. }
  720. break;
  721. case(INPUT_ORIGSTYPE+4):
  722. if(sscanf(argv[cnt],"%d",&dz->infile->origstype)!=1) {
  723. sprintf(errstr,"Cannot read origstype sent from TK\n");
  724. return(DATA_ERROR);
  725. }
  726. break;
  727. case(INPUT_ORIGRATE+4):
  728. if(sscanf(argv[cnt],"%d",&dz->infile->origrate)!=1) {
  729. sprintf(errstr,"Cannot read origrate sent from TK\n");
  730. return(DATA_ERROR);
  731. }
  732. break;
  733. case(INPUT_MLEN+4):
  734. if(sscanf(argv[cnt],"%d",&dz->infile->Mlen)!=1) {
  735. sprintf(errstr,"Cannot read Mlen sent from TK\n");
  736. return(DATA_ERROR);
  737. }
  738. break;
  739. case(INPUT_DFAC+4):
  740. if(sscanf(argv[cnt],"%d",&dz->infile->Dfac)!=1) {
  741. sprintf(errstr,"Cannot read Dfac sent from TK\n");
  742. return(DATA_ERROR);
  743. }
  744. break;
  745. case(INPUT_ORIGCHANS+4):
  746. if(sscanf(argv[cnt],"%d",&dz->infile->origchans)!=1) {
  747. sprintf(errstr,"Cannot read origchans sent from TK\n");
  748. return(DATA_ERROR);
  749. }
  750. break;
  751. case(INPUT_SPECENVCNT+4):
  752. if(sscanf(argv[cnt],"%d",&dz->infile->specenvcnt)!=1) {
  753. sprintf(errstr,"Cannot read specenvcnt sent from TK\n");
  754. return(DATA_ERROR);
  755. }
  756. dz->specenvcnt = dz->infile->specenvcnt;
  757. break;
  758. case(INPUT_WANTED+4):
  759. if(sscanf(argv[cnt],"%d",&dz->wanted)!=1) {
  760. sprintf(errstr,"Cannot read wanted sent from TK\n");
  761. return(DATA_ERROR);
  762. }
  763. break;
  764. case(INPUT_WLENGTH+4):
  765. if(sscanf(argv[cnt],"%d",&dz->wlength)!=1) {
  766. sprintf(errstr,"Cannot read wlength sent from TK\n");
  767. return(DATA_ERROR);
  768. }
  769. break;
  770. case(INPUT_OUT_CHANS+4):
  771. if(sscanf(argv[cnt],"%d",&dz->out_chans)!=1) {
  772. sprintf(errstr,"Cannot read out_chans sent from TK\n");
  773. return(DATA_ERROR);
  774. }
  775. break;
  776. /* RWD these chanegs to samps - tk will have to deal with that! */
  777. case(INPUT_DESCRIPTOR_BYTES+4):
  778. if(sscanf(argv[cnt],"%d",&dz->descriptor_samps)!=1) {
  779. sprintf(errstr,"Cannot read descriptor_samps sent from TK\n");
  780. return(DATA_ERROR);
  781. }
  782. break;
  783. case(INPUT_IS_TRANSPOS+4):
  784. if(sscanf(argv[cnt],"%d",&dz->is_transpos)!=1) {
  785. sprintf(errstr,"Cannot read is_transpos sent from TK\n");
  786. return(DATA_ERROR);
  787. }
  788. break;
  789. case(INPUT_COULD_BE_TRANSPOS+4):
  790. if(sscanf(argv[cnt],"%d",&dz->could_be_transpos)!=1) {
  791. sprintf(errstr,"Cannot read could_be_transpos sent from TK\n");
  792. return(DATA_ERROR);
  793. }
  794. break;
  795. case(INPUT_COULD_BE_PITCH+4):
  796. if(sscanf(argv[cnt],"%d",&dz->could_be_pitch)!=1) {
  797. sprintf(errstr,"Cannot read could_be_pitch sent from TK\n");
  798. return(DATA_ERROR);
  799. }
  800. break;
  801. case(INPUT_DIFFERENT_SRATES+4):
  802. if(sscanf(argv[cnt],"%d",&dz->different_srates)!=1) {
  803. sprintf(errstr,"Cannot read different_srates sent from TK\n");
  804. return(DATA_ERROR);
  805. }
  806. break;
  807. case(INPUT_DUPLICATE_SNDS+4):
  808. if(sscanf(argv[cnt],"%d",&dz->duplicate_snds)!=1) {
  809. sprintf(errstr,"Cannot read duplicate_snds sent from TK\n");
  810. return(DATA_ERROR);
  811. }
  812. break;
  813. case(INPUT_BRKSIZE+4):
  814. if(sscanf(argv[cnt],"%d",&inbrksize)!=1) {
  815. sprintf(errstr,"Cannot read brksize sent from TK\n");
  816. return(DATA_ERROR);
  817. }
  818. if(inbrksize > 0) {
  819. switch(dz->input_data_type) {
  820. case(WORDLIST_ONLY):
  821. break;
  822. case(PITCH_AND_PITCH):
  823. case(PITCH_AND_TRANSPOS):
  824. case(TRANSPOS_AND_TRANSPOS):
  825. dz->tempsize = inbrksize;
  826. break;
  827. case(BRKFILES_ONLY):
  828. case(UNRANGED_BRKFILE_ONLY):
  829. case(DB_BRKFILES_ONLY):
  830. case(ALL_FILES):
  831. case(ANY_NUMBER_OF_ANY_FILES):
  832. if(dz->extrabrkno < 0) {
  833. sprintf(errstr,"Storage location number for brktable not established by CDP.\n");
  834. return(DATA_ERROR);
  835. }
  836. if(dz->brksize == NULL) {
  837. sprintf(errstr,"CDP has not established storage space for input brktable.\n");
  838. return(PROGRAM_ERROR);
  839. }
  840. dz->brksize[dz->extrabrkno] = inbrksize;
  841. break;
  842. default:
  843. sprintf(errstr,"TK sent brktablesize > 0 for input_data_type [%d] not using brktables.\n",
  844. dz->input_data_type);
  845. return(PROGRAM_ERROR);
  846. }
  847. break;
  848. }
  849. break;
  850. case(INPUT_NUMSIZE+4):
  851. if(sscanf(argv[cnt],"%d",&dz->numsize)!=1) {
  852. sprintf(errstr,"Cannot read numsize sent from TK\n");
  853. return(DATA_ERROR);
  854. }
  855. break;
  856. case(INPUT_LINECNT+4):
  857. if(sscanf(argv[cnt],"%d",&dz->linecnt)!=1) {
  858. sprintf(errstr,"Cannot read linecnt sent from TK\n");
  859. return(DATA_ERROR);
  860. }
  861. break;
  862. case(INPUT_ALL_WORDS+4):
  863. if(sscanf(argv[cnt],"%d",&dz->all_words)!=1) {
  864. sprintf(errstr,"Cannot read all_words sent from TK\n");
  865. return(DATA_ERROR);
  866. }
  867. break;
  868. case(INPUT_ARATE+4):
  869. if(sscanf(argv[cnt],"%f",&dz->infile->arate)!=1) {
  870. sprintf(errstr,"Cannot read arate sent from TK\n");
  871. return(DATA_ERROR);
  872. }
  873. break;
  874. case(INPUT_FRAMETIME+4):
  875. if(sscanf(argv[cnt],"%lf",&dummy)!=1) {
  876. sprintf(errstr,"Cannot read frametime sent from TK\n");
  877. return(DATA_ERROR);
  878. }
  879. dz->frametime = (float)dummy;
  880. break;
  881. case(INPUT_WINDOW_SIZE+4):
  882. if(sscanf(argv[cnt],"%f",&dz->infile->window_size)!=1) {
  883. sprintf(errstr,"Cannot read window_size sent from TK\n");
  884. return(DATA_ERROR);
  885. }
  886. break;
  887. case(INPUT_NYQUIST+4):
  888. if(sscanf(argv[cnt],"%lf",&dz->nyquist)!=1) {
  889. sprintf(errstr,"Cannot read nyquist sent from TK\n");
  890. return(DATA_ERROR);
  891. }
  892. break;
  893. case(INPUT_DURATION+4):
  894. if(sscanf(argv[cnt],"%lf",&dz->duration)!=1) {
  895. sprintf(errstr,"Cannot read duration sent from TK\n");
  896. return(DATA_ERROR);
  897. }
  898. break;
  899. case(INPUT_MINBRK+4):
  900. if(sscanf(argv[cnt],"%lf",&dz->minbrk)!=1) {
  901. sprintf(errstr,"Cannot read minbrk sent from TK\n");
  902. return(DATA_ERROR);
  903. }
  904. break;
  905. case(INPUT_MAXBRK+4):
  906. if(sscanf(argv[cnt],"%lf",&dz->maxbrk)!=1) {
  907. sprintf(errstr,"Cannot read maxbrk sent from TK\n");
  908. return(DATA_ERROR);
  909. }
  910. break;
  911. case(INPUT_MINNUM+4):
  912. if(sscanf(argv[cnt],"%lf",&dz->minnum)!=1) {
  913. sprintf(errstr,"Cannot read minnum sent from TK\n");
  914. return(DATA_ERROR);
  915. }
  916. break;
  917. case(INPUT_MAXNUM+4):
  918. if(sscanf(argv[cnt],"%lf",&dz->maxnum)!=1) {
  919. sprintf(errstr,"Cannot read maxnum sent from TK\n");
  920. return(DATA_ERROR);
  921. }
  922. break;
  923. default:
  924. sprintf(errstr,"case switch item missing: parse_sloom_data()\n");
  925. return(PROGRAM_ERROR);
  926. }
  927. cnt++;
  928. }
  929. if(cnt!=PRE_CMDLINE_DATACNT+1) {
  930. sprintf(errstr,"Insufficient pre-cmdline params sent from TK\n");
  931. return(DATA_ERROR);
  932. }
  933. if(true_cnt)
  934. cnt = true_cnt;
  935. *cmdlinecnt = 0;
  936. while(cnt < argc) {
  937. if((exit_status = get_tk_cmdline_word(cmdlinecnt,cmdline,argv[cnt]))<0)
  938. return(exit_status);
  939. cnt++;
  940. }
  941. return(FINISHED);
  942. }
  943. /********************************* GET_TK_CMDLINE_WORD *********************************/
  944. int get_tk_cmdline_word(int *cmdlinecnt,char ***cmdline,char *q)
  945. {
  946. if(*cmdlinecnt==0) {
  947. if((*cmdline = (char **)malloc(sizeof(char *)))==NULL) {
  948. sprintf(errstr,"INSUFFICIENT MEMORY for TK cmdline array.\n");
  949. return(MEMORY_ERROR);
  950. }
  951. } else {
  952. if((*cmdline = (char **)realloc(*cmdline,((*cmdlinecnt)+1) * sizeof(char *)))==NULL) {
  953. sprintf(errstr,"INSUFFICIENT MEMORY for TK cmdline array.\n");
  954. return(MEMORY_ERROR);
  955. }
  956. }
  957. if(((*cmdline)[*cmdlinecnt] = (char *)malloc((strlen(q) + 1) * sizeof(char)))==NULL) {
  958. sprintf(errstr,"INSUFFICIENT MEMORY for TK cmdline item %d.\n",(*cmdlinecnt)+1);
  959. return(MEMORY_ERROR);
  960. }
  961. strcpy((*cmdline)[*cmdlinecnt],q);
  962. (*cmdlinecnt)++;
  963. return(FINISHED);
  964. }
  965. /****************************** ASSIGN_FILE_DATA_STORAGE *********************************/
  966. int assign_file_data_storage(int infilecnt,dataptr dz)
  967. {
  968. int exit_status;
  969. int no_sndfile_system_files = FALSE;
  970. dz->infilecnt = infilecnt;
  971. if((exit_status = allocate_filespace(dz))<0)
  972. return(exit_status);
  973. if(no_sndfile_system_files)
  974. dz->infilecnt = 0;
  975. return(FINISHED);
  976. }
  977. /************************* SETUP_INTERNAL_ARRAYS_AND_ARRAY_POINTERS *******************/
  978. int setup_internal_arrays_and_array_pointers(dataptr dz)
  979. {
  980. dz->array_cnt = 1;
  981. if(dz->mode == 3) {
  982. if((dz->parray = (double **)malloc(sizeof(double *)))==NULL) {
  983. sprintf(errstr,"INSUFFICIENT MEMORY for internal double arrays.\n");
  984. return(MEMORY_ERROR);
  985. }
  986. dz->parray[0] = NULL;
  987. }
  988. return(FINISHED);
  989. }
  990. /************************* redundant functions: to ensure libs compile OK *******************/
  991. int assign_process_logic(dataptr dz)
  992. {
  993. return(FINISHED);
  994. }
  995. void set_legal_infile_structure(dataptr dz)
  996. {}
  997. int establish_bufptrs_and_extra_buffers(dataptr dz)
  998. {
  999. return(FINISHED);
  1000. }
  1001. int read_special_data(char *str,dataptr dz)
  1002. {
  1003. return(FINISHED);
  1004. }
  1005. int inner_loop
  1006. (int *peakscore,int *descnt,int *in_start_portion,int *least,int *pitchcnt,int windows_in_buf,dataptr dz)
  1007. {
  1008. return(FINISHED);
  1009. }
  1010. int get_process_no(char *prog_identifier_from_cmdline,dataptr dz)
  1011. {
  1012. return(FINISHED);
  1013. }
  1014. /******************************** USAGE1 ********************************/
  1015. int usage1(void)
  1016. {
  1017. usage2("multi");
  1018. return(USAGE_ONLY);
  1019. }
  1020. /********************************************************************************************/
  1021. int get_the_process_no(char *prog_identifier_from_cmdline,dataptr dz)
  1022. {
  1023. if(!strcmp(prog_identifier_from_cmdline,"multi")) dz->process = STRANS;
  1024. else {
  1025. sprintf(errstr,"Unknown program identification string '%s'\n",prog_identifier_from_cmdline);
  1026. return(USAGE_ONLY);
  1027. }
  1028. return(FINISHED);
  1029. }
  1030. /******************************** SETUP_AND_INIT_INPUT_BRKTABLE_CONSTANTS ********************************/
  1031. int setup_and_init_input_brktable_constants(dataptr dz,int brkcnt)
  1032. {
  1033. int n;
  1034. if((dz->brk = (double **)malloc(brkcnt * sizeof(double *)))==NULL) {
  1035. sprintf(errstr,"setup_and_init_input_brktable_constants(): 1\n");
  1036. return(MEMORY_ERROR);
  1037. }
  1038. if((dz->brkptr = (double **)malloc(brkcnt * sizeof(double *)))==NULL) {
  1039. sprintf(errstr,"setup_and_init_input_brktable_constants(): 6\n");
  1040. return(MEMORY_ERROR);
  1041. }
  1042. if((dz->brksize = (int *)malloc(brkcnt * sizeof(int)))==NULL) {
  1043. sprintf(errstr,"setup_and_init_input_brktable_constants(): 2\n");
  1044. return(MEMORY_ERROR);
  1045. }
  1046. if((dz->firstval = (double *)malloc(brkcnt * sizeof(double)))==NULL) {
  1047. sprintf(errstr,"setup_and_init_input_brktable_constants(): 3\n");
  1048. return(MEMORY_ERROR);
  1049. }
  1050. if((dz->lastind = (double *)malloc(brkcnt * sizeof(double)))==NULL) {
  1051. sprintf(errstr,"setup_and_init_input_brktable_constants(): 4\n");
  1052. return(MEMORY_ERROR);
  1053. }
  1054. if((dz->lastval = (double *)malloc(brkcnt * sizeof(double)))==NULL) {
  1055. sprintf(errstr,"setup_and_init_input_brktable_constants(): 5\n");
  1056. return(MEMORY_ERROR);
  1057. }
  1058. if((dz->brkinit = (int *)malloc(brkcnt * sizeof(int)))==NULL) {
  1059. sprintf(errstr,"setup_and_init_input_brktable_constants(): 7\n");
  1060. return(MEMORY_ERROR);
  1061. }
  1062. for(n=0;n<brkcnt;n++) {
  1063. dz->brk[n] = NULL;
  1064. dz->brkptr[n] = NULL;
  1065. dz->brkinit[n] = 0;
  1066. dz->brksize[n] = 0;
  1067. }
  1068. return(FINISHED);
  1069. }
  1070. /******************************** USAGE2 ********************************/
  1071. int usage2(char *str)
  1072. {
  1073. if(!strcmp(str,"multi")) {
  1074. fprintf(stderr,
  1075. "CHANGE SPEED & PITCH OF (MULTICHANNEL) SRC SOUND, OR ADD VIBRATO.\n\n"
  1076. "USAGE: strans multi 1 infile outfile speed [-o]\n"
  1077. "OR: strans multi 2 infile outfile semitone-transpos [-o]\n"
  1078. "OR: strans multi 3 infile outfile accel goaltime [-sstarttime]\n"
  1079. "OR: strans multi 4 infile outfile vibfrq vibdepth\n"
  1080. "\n"
  1081. "SPEED is a speed-multiplier\n"
  1082. "SEMITONE-TRANSPOS is transposition in semitones\n"
  1083. " -o brkpnt times read as outfile times (default: as infile times).\n"
  1084. "\n"
  1085. "ACCEL (a speed multiplier) is the speed reached at the goaltime.\n"
  1086. "GOALTIME is the time at which the full acceleration is achieved.\n"
  1087. "STARTTIME is the time at which acceleration begins (default 0.0).\n"
  1088. "\n"
  1089. "VIBFRQ is the vibrato frequency in Hz (can vary over time).\n"
  1090. "VIBDEPTH is pitch-depth of vibrato (in semitones) (can vary over time).\n");
  1091. } else
  1092. fprintf(stdout,"Unknown option '%s'\n",str);
  1093. return(USAGE_ONLY);
  1094. }
  1095. int usage3(char *str1,char *str2)
  1096. {
  1097. fprintf(stderr,"Insufficient parameters on command line.\n");
  1098. return(USAGE_ONLY);
  1099. }
  1100. /****************************** STRANS_PREPROCESS *********************************/
  1101. int strans_preprocess(dataptr dz)
  1102. {
  1103. double acceltime, tabratio, *p, *pend;
  1104. long n;
  1105. switch(dz->mode) {
  1106. case(0):
  1107. case(1):
  1108. dz->iparam[UNITSIZE] = dz->insams[0]/dz->infile->channels;
  1109. dz->param[VTRANS_SR] = (double)dz->infile->srate;
  1110. dz->iparam[TOTAL_UNITS_READ] = 0;
  1111. break;
  1112. case(2):
  1113. acceltime = dz->param[ACCEL_GOALTIME] - dz->param[ACCEL_STARTTIME];
  1114. if(acceltime < MINTIME_ACCEL) {
  1115. sprintf(errstr,"time for acceleration (%lf) must be greater than %.3fsecs\n",acceltime,MINTIME_ACCEL);
  1116. return(DATA_ERROR);
  1117. }
  1118. dz->param[ACCEL_ACCEL] = pow(dz->param[ACCEL_ACCEL],(1.0/(acceltime *(double)dz->infile->srate)));
  1119. dz->iparam[ACCEL_STARTTIME] = /* convert to time-in-samples */
  1120. round(dz->param[ACCEL_STARTTIME] * (double)dz->infile->srate) * dz->infile->channels;
  1121. break;
  1122. case(3):
  1123. // TW : Mar 2015 NB (integer) iparam[1 = UNITSIZE] but (in mode 3) (float) param[1 = VIB_DEPTH] : NO CONFLICT
  1124. dz->iparam[UNITSIZE] = dz->insams[0]/dz->infile->channels;
  1125. dz->param[VTRANS_SR] = (double)dz->infile->srate;
  1126. // <-- TW : Mar 2015
  1127. tabratio = (double)VIB_TABSIZE/(double)dz->infile->srate; /* converts frq to sintable step */
  1128. if(dz->brksize[VIB_FRQ]) {
  1129. p = dz->brk[VIB_FRQ] + 1;
  1130. pend = dz->brk[VIB_FRQ] + (dz->brksize[VIB_FRQ] * 2);
  1131. while(p < pend) {
  1132. *p *= tabratio;
  1133. p += 2;
  1134. }
  1135. } else
  1136. dz->param[VIB_FRQ] *= tabratio;
  1137. if(dz->brksize[VIB_DEPTH]) { /* converts semitones to 8vas */
  1138. p = dz->brk[VIB_DEPTH] + 1;
  1139. pend = dz->brk[VIB_DEPTH] + (dz->brksize[VIB_DEPTH] * 2);
  1140. while(p < pend) {
  1141. *p *= OCTAVES_PER_SEMITONE;
  1142. p += 2;
  1143. }
  1144. } else
  1145. dz->param[VIB_DEPTH] *= OCTAVES_PER_SEMITONE;
  1146. if((dz->parray[VIB_SINTAB] = (double *)malloc((VIB_TABSIZE + 1) * sizeof(double)))==NULL) {
  1147. sprintf(errstr,"INSUFFICIENT MEMORY for vibrato sintable.\n");
  1148. return(MEMORY_ERROR);
  1149. }
  1150. tabratio = TWOPI/(double)VIB_TABSIZE; /* converts table-step to fraction of 2PI */
  1151. for(n=0;n<VIB_TABSIZE;n++)
  1152. dz->parray[VIB_SINTAB][n] = sin((double)n * tabratio);
  1153. dz->parray[VIB_SINTAB][n] = 0.0;
  1154. break;
  1155. }
  1156. return FINISHED;
  1157. }
  1158. /****************************** SET_LEGAL_INTERNALPARAM_STRUCTURE *********************************/
  1159. int set_legal_internalparam_structure(int process,int mode,aplptr ap)
  1160. {
  1161. int exit_status = FINISHED;
  1162. switch(mode) {
  1163. case(2): exit_status = set_internalparam_data( "iiid",ap); break;
  1164. case(3): exit_status = set_internalparam_data( "iiiid",ap); break;
  1165. default:
  1166. exit_status = set_internalparam_data("iiiiid",ap);
  1167. break;
  1168. }
  1169. return exit_status;
  1170. }
  1171. /****************************** VTRANS_PROCESS *************************/
  1172. int process_varispeed(dataptr dz)
  1173. {
  1174. int exit_status, chans = dz->infile->channels;
  1175. long n, m, chunksread, place, thispos;
  1176. double *dbrk, flplace = 0.0, fracsamp, step, interp;
  1177. float *ibuf = dz->sampbuf[0], *obuf = dz->sampbuf[1], *obufend = dz->sampbuf[2], *obufptr;
  1178. long obufcnt = 0;
  1179. if(dz->brksize[VTRANS_TRANS]) {
  1180. if((exit_status = convert_brkpnts(dz))<0)
  1181. return(exit_status);
  1182. if(dz->vflag[VTRANS_OUTTIMES]) { /* convert to intimes */
  1183. if((exit_status = change_frame(dz))<0)
  1184. return(exit_status);
  1185. }
  1186. } else if(dz->mode == MOD_TRANSPOS_SEMIT)
  1187. dz->param[VTRANS_TRANS] = pow(2.0,(dz->param[VTRANS_TRANS] * OCTAVES_PER_SEMITONE));
  1188. display_virtual_time(0L,dz);
  1189. if((exit_status = read_samps_for_strans(dz))<0)
  1190. return(exit_status);
  1191. if(dz->brksize[VTRANS_TRANS]) {
  1192. dbrk = dz->brk[VTRANS_TRANS];
  1193. for(n=1,m=2;n<dz->brksize[VTRANS_TRANS];n++,m+=2) {
  1194. if((exit_status =
  1195. timevents(&obufcnt,(long)round(dbrk[m-2]),(long)round(dbrk[m]),dbrk[m-1],dbrk[m+1],dz))!=CONTINUE)
  1196. break;
  1197. }
  1198. if(exit_status < 0)
  1199. return(exit_status);
  1200. return write_samps_with_intime_display(dz->sampbuf[1],obufcnt,dz);
  1201. } else {
  1202. obufptr = obuf;
  1203. while(dz->ssampsread > 0) {
  1204. chunksread = dz->ssampsread/chans;
  1205. while(flplace < (double)chunksread) {
  1206. place = (int)flplace;
  1207. fracsamp = flplace - (double)place;
  1208. thispos = place * chans;
  1209. for(n=0;n<chans;n++) {
  1210. step = ibuf[thispos + chans] - ibuf[thispos];
  1211. interp = fracsamp * step;
  1212. *obufptr = (float)(ibuf[thispos] + interp);
  1213. obufptr++;
  1214. thispos++;
  1215. }
  1216. if(obufptr >= obufend) {
  1217. if((exit_status = write_samps_with_intime_display(obuf,dz->buflen,dz))<0)
  1218. return(exit_status);
  1219. obufptr = obuf;
  1220. }
  1221. flplace += dz->param[VTRANS_TRANS];
  1222. }
  1223. if((exit_status = read_samps_for_strans(dz))<0)
  1224. return(exit_status);
  1225. chunksread = dz->ssampsread/chans;
  1226. flplace -= (double)(dz->buflen/chans);
  1227. }
  1228. if(obufptr!=obuf) /* 12 */
  1229. return write_samps_with_intime_display(obuf,obufptr - obuf,dz);
  1230. }
  1231. return FINISHED;
  1232. }
  1233. /*************************** READ_SAMPS_FOR_STRANS **************************/
  1234. int read_samps_for_strans(dataptr dz)
  1235. {
  1236. //TW MUST READ EXTRA SAMPLE FOR EACH CHANNEL to get wrap-around value
  1237. float *buffer = dz->sampbuf[0];
  1238. long samps_read, samps_to_read = dz->buflen + dz->infile->channels;
  1239. dz->iparam[UNITS_RD_PRE_THISBUF] = dz->iparam[TOTAL_UNITS_READ];
  1240. if((samps_read = fgetfbufEx(buffer, samps_to_read,dz->ifd[0],0)) < 0) {
  1241. sprintf(errstr, "Can't read from input soundfile.\n");
  1242. return(SYSTEM_ERROR);
  1243. }
  1244. dz->samps_left -= samps_read;
  1245. if(samps_read == samps_to_read) {
  1246. if((sndseekEx(dz->ifd[0],-(long)dz->infile->channels,1))<0) { /* WE'VE READ EXTRA SECTOR,for wrap-around */
  1247. sprintf(errstr,"sndseekEx() failed.\n");
  1248. return(SYSTEM_ERROR);
  1249. }
  1250. samps_read -= dz->infile->channels;
  1251. dz->samps_left += dz->infile->channels;
  1252. }
  1253. dz->ssampsread = samps_read;
  1254. dz->total_samps_read += samps_read;
  1255. dz->iparam[UNITS_READ] = samps_read/dz->infile->channels;
  1256. dz->iparam[TOTAL_UNITS_READ] += dz->iparam[UNITS_READ];
  1257. return(FINISHED);
  1258. }
  1259. /************************ CONVERT_BRKPNTS ************************/
  1260. int convert_brkpnts(dataptr dz)
  1261. {
  1262. int exit_status;
  1263. double *p, *pend;
  1264. if((exit_status= force_value_at_zero_time(VTRANS_TRANS,dz))<0)
  1265. return(exit_status);
  1266. if((exit_status= force_value_at_end_time(VTRANS_TRANS,dz))<0)
  1267. return(exit_status);
  1268. p = dz->brk[VTRANS_TRANS];
  1269. pend = p + (dz->brksize[VTRANS_TRANS] * 2);
  1270. while(p < pend) {
  1271. *p = (double)round((*p) * dz->param[VTRANS_SR]); /* convert to (mono) sample frame */
  1272. p += 2;
  1273. }
  1274. if(dz->mode==MOD_TRANSPOS_SEMIT) {
  1275. p = dz->brk[VTRANS_TRANS] + 1;
  1276. while(p < pend) {
  1277. *p = pow(2.0,(*p) * OCTAVES_PER_SEMITONE); /* convert to ratios */
  1278. p += 2;
  1279. }
  1280. }
  1281. return(FINISHED);
  1282. }
  1283. /************************ CHANGE_FRAME ************************/
  1284. int change_frame(dataptr dz)
  1285. {
  1286. long n, m;
  1287. long *newtime;
  1288. double *dbrk, lasttime, lastval, thistime, thisval;
  1289. dbrk = dz->brk[VTRANS_TRANS];
  1290. if((newtime = (long *)malloc(dz->brksize[VTRANS_TRANS] * 2 * sizeof(double)))==NULL) {
  1291. sprintf(errstr,"INSUFFICIENT MEMORY to create transformed brktable.\n");
  1292. return(MEMORY_ERROR);
  1293. }
  1294. newtime[0] = 0;
  1295. lasttime = dbrk[0];
  1296. lastval = dbrk[1];
  1297. for(n=1,m=2;n<dz->brksize[VTRANS_TRANS];n++,m+=2) {
  1298. thistime = dbrk[m];
  1299. thisval = dbrk[m+1];
  1300. newtime[n] = newtime[n-1] +
  1301. inv_cntevents((long)round(thistime - lasttime),lastval,thisval);
  1302. lasttime = thistime;
  1303. lastval = thisval;
  1304. }
  1305. for(n=1,m=2;n<dz->brksize[VTRANS_TRANS];n++,m+=2)
  1306. dbrk[m] = (double)newtime[n];
  1307. free(newtime);
  1308. return(FINISHED);
  1309. }
  1310. /*************************** INV_CNTEVENTS *****************************
  1311. *
  1312. * no. of event in input (N) corresponding to output (T1-T0) given by :-
  1313. *
  1314. * N = (T1-T0) log S1
  1315. * ------- e__
  1316. * (S1-S0) S0
  1317. *
  1318. * Hence,
  1319. * no. of event in output (T1-T0) corresponding to input (N) given by :-
  1320. *
  1321. * (S1-S0)N = (T1-T0)
  1322. * --------
  1323. * log S1
  1324. * e__
  1325. * S0
  1326. *
  1327. * Except where S1==S0, when (T1-T0) = S * N
  1328. */
  1329. long inv_cntevents(long dur,double s0,double s1)
  1330. {
  1331. double ftime;
  1332. long time;
  1333. if(sizeq(s1,s0))
  1334. ftime = (double)dur * s0;
  1335. else
  1336. ftime = ((double)dur * (s1-s0))/log(s1/s0);
  1337. time = round(ftime);
  1338. if(time==0)
  1339. time = 1;
  1340. return(time);
  1341. }
  1342. /*************************** FORCE_VALUE_AT_END_TIME *****************************/
  1343. int force_value_at_end_time(int paramno,dataptr dz)
  1344. {
  1345. double duration = (double)dz->iparam[UNITSIZE]/dz->param[VTRANS_SR];
  1346. double *p = dz->brk[paramno] + ((dz->brksize[paramno]-1) * 2);
  1347. double timegap, newgap, step, newstep, timeratio;
  1348. if(dz->brksize[paramno] < 2) {
  1349. sprintf(errstr,"Brktable too small (< 2 pairs).\n");
  1350. return(DATA_ERROR);
  1351. }
  1352. if(flteq(*p,duration)) {
  1353. *p = duration;
  1354. return(FINISHED);
  1355. } else if(*p < duration) {
  1356. dz->brksize[paramno]++;
  1357. if((dz->brk[paramno] = realloc((char *)dz->brk[paramno],dz->brksize[paramno] * 2 * sizeof(double)))==NULL) {
  1358. sprintf(errstr,"INSUFFICIENT MEMORY TO GROW BRKTABLE.\n");
  1359. return(MEMORY_ERROR);
  1360. }
  1361. p = dz->brk[paramno] + ((dz->brksize[paramno]-1) * 2);
  1362. *p = duration;
  1363. *(p+1) = *(p-1);
  1364. return(FINISHED);
  1365. } else { /* *p > duration) */
  1366. while(p > dz->brk[paramno]) {
  1367. p -= 2;
  1368. if(flteq(*p,duration)) {
  1369. *p = duration;
  1370. dz->brksize[paramno] = (p - dz->brk[paramno] + 2)/2;
  1371. return(FINISHED);
  1372. } else if(*p < duration) {
  1373. timegap = *(p+2) - *p;
  1374. newgap = duration - *p;
  1375. timeratio = newgap/timegap;
  1376. switch(dz->mode) {
  1377. case(MOD_TRANSPOS_SEMIT):
  1378. step = *(p+3) - *(p+1);
  1379. newstep = step * timeratio;
  1380. *(p+3) = *(p+1) + newstep;
  1381. break;
  1382. case(MOD_TRANSPOS):
  1383. step = LOG2(*(p+3)) - LOG2(*(p+1));
  1384. newstep = pow(2.0,step * timeratio);
  1385. *(p+3) = *(p+1) * newstep;
  1386. break;
  1387. }
  1388. *(p+2) = duration;
  1389. dz->brksize[paramno] = (p - dz->brk[paramno] + 4)/2;
  1390. return(FINISHED);
  1391. }
  1392. }
  1393. }
  1394. sprintf(errstr,"Failed to place brkpnt at snd endtime.\n");
  1395. return(PROGRAM_ERROR);
  1396. }
  1397. /****************************** PUTVAL ******************************/
  1398. int putval(long *obufcnt,double pos,dataptr dz)
  1399. {
  1400. int exit_status;
  1401. long i = (long)pos; /* TRUNCATE */
  1402. double frac = pos - (double)i, diff;
  1403. float val1, val2;
  1404. float *buffer = dz->sampbuf[0];
  1405. float *obuf = dz->sampbuf[1];
  1406. int chans = dz->infile->channels;
  1407. int n;
  1408. i *= chans;
  1409. for(n=0;n<chans;n++) {
  1410. val1 = buffer[i];
  1411. val2 = buffer[i+chans];
  1412. diff = (double)(val2-val1);
  1413. //TW obuf[(*obufcnt)++] = val1 + (float)/*round*/(frac * diff);
  1414. obuf[(*obufcnt)++] = (float)(val1 + (frac * diff));
  1415. if(*obufcnt >= dz->buflen) {
  1416. if((exit_status = write_samps_with_intime_display(obuf,dz->buflen,dz))<0)
  1417. return(exit_status);
  1418. *obufcnt = 0;
  1419. }
  1420. i++;
  1421. }
  1422. return(CONTINUE);
  1423. }
  1424. /**************************** SIZEQ *******************************/
  1425. #define CALCLIM 0.02
  1426. int sizeq(double f1,double f2)
  1427. {
  1428. double upperbnd, lowerbnd;
  1429. upperbnd = f2 + CALCLIM;
  1430. lowerbnd = f2 - CALCLIM;
  1431. if((f1>upperbnd) || (f1<lowerbnd))
  1432. return(FALSE);
  1433. return(TRUE);
  1434. }
  1435. /*************************** SPLICE_END *****************************/
  1436. void splice_end(long obufcnt,dataptr dz) /* A kludge to avoid clicks at end */
  1437. {
  1438. #define VTRANS_SPLICELEN (5.0)
  1439. float *buf = dz->sampbuf[1];
  1440. int chans = dz->infile->channels;
  1441. int splicelen = round(VTRANS_SPLICELEN * MS_TO_SECS * dz->infile->srate) * dz->infile->channels;
  1442. int n, m, k = min(obufcnt,splicelen);
  1443. long startsamp = obufcnt - k;
  1444. double inv_k;
  1445. k /= chans;
  1446. inv_k = 1.0/(double)k;
  1447. for(n = k-1;n >= 0;n--) {
  1448. for(m=0;m<chans;m++) {
  1449. buf[startsamp] = (float)(buf[startsamp] * n * inv_k);
  1450. startsamp++;
  1451. }
  1452. }
  1453. }
  1454. /*************************** WRITE_SAMPS_WITH_INTIME_DISPLAY ***********************/
  1455. int write_samps_with_intime_display(float *buf,int samps_to_write,dataptr dz)
  1456. {
  1457. int exit_status;
  1458. int samps_written;
  1459. if(samps_to_write > 0) {
  1460. if((exit_status = write_samps_no_report(buf,samps_to_write,&samps_written,dz))<0) {
  1461. sprintf(errstr, "Can't write to output soundfile.\n");
  1462. return(SYSTEM_ERROR);
  1463. }
  1464. display_virtual_time(dz->total_samps_read,dz);
  1465. }
  1466. return(FINISHED);
  1467. }
  1468. /************************** TIMEVENTS *******************************
  1469. *
  1470. * Generates event positions from startsize and end size
  1471. *
  1472. * Let start-time be T0 and end time be T1
  1473. * Let start size be S0 and end size be S1
  1474. *
  1475. * number of event is given by :-
  1476. *
  1477. * N = (T1-T0) log S1
  1478. * ------- e__
  1479. * (S1-S0) S0
  1480. *
  1481. * In general this will be non-integral, and we should
  1482. * round N to an integer, and recalculate S1 by successive
  1483. * approximation.
  1484. *
  1485. * Then positions of events are given by
  1486. *
  1487. * for X = 0 to N (S1-S0)
  1488. * ----- X
  1489. * T = (S1T0 - S0T1) S0(T1 - T0) (T1-T0)
  1490. * s ----------- + ---------- e
  1491. * (S1 - S0) (S1 - S0)
  1492. *
  1493. * If difference in eventsizes input to the main program is very small
  1494. *
  1495. * This function calculates the number of events within the time-interval,
  1496. * and generates the times of these events.
  1497. */
  1498. int timevents(long *obufcnt,long intime0,long intime1,double insize0,double insize1,dataptr dz)
  1499. {
  1500. int exit_status;
  1501. long number;
  1502. double fnum, fnumber, error, pos;
  1503. double lobound, hibound;
  1504. long duration;
  1505. if(flteq(insize0,0.0) || flteq(insize1,0.0)) {
  1506. sprintf(errstr,"Event size of zero encountered in pair %lf %lf at time %lf\n",
  1507. insize0,insize1,(double)intime0/dz->param[VTRANS_SR]);
  1508. return(DATA_ERROR);
  1509. }
  1510. duration = intime1-intime0;
  1511. if(duration<=0) {
  1512. sprintf(errstr,"Inconsistent input times [ %lf : %lf ] to timevents()\n",
  1513. (double)intime0/dz->param[VTRANS_SR],(double)intime1/dz->param[VTRANS_SR]);
  1514. return(DATA_ERROR);
  1515. }
  1516. if(sizeq(insize1,insize0)) /* 1 */
  1517. return(samesize(obufcnt,intime0,insize0,insize1,duration,dz));
  1518. fnum =cntevents(duration,insize0,insize1); /* 2 */
  1519. number = round(fnum);
  1520. if(number<2) { /* 3 */
  1521. pos = (double)(intime0 - dz->iparam[UNITS_RD_PRE_THISBUF]);
  1522. if(pos >= (double)dz->iparam[UNITS_READ]) {
  1523. if(dz->samps_left <= 0)
  1524. return(FINISHED);
  1525. if((exit_status = read_samps_for_strans(dz))<0)
  1526. return(exit_status);
  1527. pos -= (double)dz->iparam[UNIT_BUFLEN];
  1528. }
  1529. if((exit_status = putval(obufcnt,pos,dz))<0)
  1530. return(exit_status);
  1531. } else {
  1532. fnumber = (double)number; /* 4 */
  1533. error = fabs(fnum - fnumber);
  1534. /* HIBOUND is a SMALLER value of SIZE to give BIGGER value of NUM-OF-SEGS */
  1535. /* LOBOUND is a LARGER value of SIZE to give SMALLER value of NUM-OF-SEGS */
  1536. lobound = max(insize1,insize0); /* 5 */
  1537. hibound = min(insize1,insize0);
  1538. if(error > FLTERR) /* 6 */
  1539. insize1 = refinesize(hibound,lobound,fnumber,duration,error,insize0);
  1540. else
  1541. insize1 = (hibound+lobound)/2;
  1542. return(getetime(obufcnt,intime0,intime1,insize0,insize1,number,dz));
  1543. } /* 7 */
  1544. return(CONTINUE);
  1545. }
  1546. /*************************** CNTEVENTS *****************************/
  1547. double cntevents(long dur,double s0,double s1)
  1548. {
  1549. double f1 = (double)dur,f2;
  1550. if(sizeq(s1,s0))
  1551. return((f1*2.0)/(s1+s0));
  1552. f2 = s1-s0;
  1553. f1 /= f2;
  1554. f2 = s1/s0;
  1555. f2 = log(f2);
  1556. f1 *= f2;
  1557. return(fabs(f1));
  1558. }
  1559. /******************************* SAMESIZE(): *******************************
  1560. *
  1561. * get event positions, if eventsize approx same throughout segment.
  1562. *
  1563. *(1) Get average size, find number of events and round to nearest int.
  1564. *(2) If too many or zero events, do exception.
  1565. *(3) Recalculate size, and thence event times.
  1566. */
  1567. int samesize(long *obufcnt,long intime0,double insize0,double insize1,long duration,dataptr dz)
  1568. {
  1569. int exit_status;
  1570. long number, isize;
  1571. double size, pos; /* 1 */
  1572. size = (insize0+insize1)/2;
  1573. number = round((double)duration/size);
  1574. if(number==0) { /* 2 */
  1575. pos = (double)(intime0 - dz->iparam[UNITS_RD_PRE_THISBUF]);
  1576. if(pos >= (double)dz->iparam[UNITS_READ]) {
  1577. if(dz->samps_left <= 0)
  1578. return(FINISHED);
  1579. if((exit_status = read_samps_for_strans(dz))<0)
  1580. return(exit_status);
  1581. pos -= (double)dz->iparam[UNIT_BUFLEN];
  1582. }
  1583. if((exit_status = putval(obufcnt,pos,dz))<0)
  1584. return(exit_status);
  1585. return(CONTINUE);
  1586. }
  1587. size = (double)duration/(double)number;
  1588. if(flteq((double)(isize = (long)round(size)),size))
  1589. return integral_times(obufcnt,intime0,isize,number,dz);
  1590. return unvarying_times(obufcnt,intime0,size,number,dz);
  1591. }
  1592. /******************************* GETETIME ********************************
  1593. *
  1594. * Calculate time-positions of events that vary in size between s0 and s1.
  1595. * NB We need to invert the time order, if s1 < s0.
  1596. */
  1597. int getetime(long *obufcnt,long t0,long t1,double s0,double s1,long number,dataptr dz)
  1598. {
  1599. int exit_status;
  1600. long n;
  1601. double sdiff = s1-s0, tdiff = (double)(t1-t0), d1, d2, d3, pos;
  1602. /***** TW n=0 NOT 1 ********/
  1603. for(n=1;n<number;n++) {
  1604. /***** TW ********/
  1605. d1 = sdiff/tdiff;
  1606. d1 *= (double)n;
  1607. d1 = exp(d1);
  1608. d2 = s0*tdiff;
  1609. d2 /= sdiff;
  1610. d1 *= d2;
  1611. d2 = s1*t0;
  1612. d3 = s0*t1;
  1613. d2 -= d3;
  1614. d2 /= sdiff;
  1615. pos = d1 + d2;
  1616. pos -= (double)dz->iparam[UNITS_RD_PRE_THISBUF];
  1617. if(pos >= (double)dz->iparam[UNITS_READ]) {
  1618. if(dz->samps_left <= 0)
  1619. return(FINISHED);
  1620. if((exit_status = read_samps_for_strans(dz))<0)
  1621. return(exit_status);
  1622. pos -= (double)dz->iparam[UNIT_BUFLEN];
  1623. }
  1624. if((exit_status = putval(obufcnt,pos,dz))<0)
  1625. return(exit_status);
  1626. }
  1627. return(CONTINUE);
  1628. }
  1629. /******************************* DZ2PROPS ********************************/
  1630. void dz2props(dataptr dz, SFPROPS* props)
  1631. {
  1632. if(dz->outfiletype == SNDFILE_OUT){
  1633. switch(dz->true_outfile_stype){
  1634. case SAMP_SHORT:
  1635. props->samptype = SHORT16;
  1636. break;
  1637. case SAMP_FLOAT:
  1638. props->samptype = FLOAT32;
  1639. break;
  1640. case SAMP_BYTE:
  1641. props->samptype = SHORT8;
  1642. break;
  1643. case SAMP_LONG:
  1644. props->samptype = INT_32;
  1645. break;
  1646. case SAMP_2424:
  1647. props->samptype = INT2424;
  1648. break;
  1649. case SAMP_2432:
  1650. props->samptype = INT2432;
  1651. break;
  1652. case SAMP_2024:
  1653. props->samptype = INT2024;
  1654. break;
  1655. default:
  1656. props->samptype = INT_MASKED;
  1657. break;
  1658. }
  1659. props->srate = dz->outfile->srate;
  1660. props->chans = dz->outchans; //or outfile->channels?
  1661. props->type = wt_wave;
  1662. props->format = WAVE_EX;
  1663. props->chformat = MC_STD;
  1664. }
  1665. }
  1666. /*************************** CREATE_STRANSBUFS **************************/
  1667. int create_stransbufs(dataptr dz)
  1668. {
  1669. long bigbufsize, xs;
  1670. if(dz->sbufptr == 0 || dz->sampbuf==0) {
  1671. sprintf(errstr,"buffer pointers not allocated: create_sndbufs()\n");
  1672. return(PROGRAM_ERROR);
  1673. }
  1674. bigbufsize = (long)Malloc(-1);
  1675. bigbufsize /= dz->bufcnt;
  1676. if(bigbufsize <=0) {
  1677. bigbufsize = F_SECSIZE * sizeof(float); /* RWD keep ths for now */
  1678. }
  1679. dz->buflen = bigbufsize / sizeof(float);
  1680. /*RWD also cover n-channels usage */
  1681. dz->buflen = (dz->buflen / dz->infile->channels) * dz->infile->channels;
  1682. bigbufsize = dz->buflen * sizeof(float);
  1683. xs = dz->infile->channels * sizeof(float); /* wraparound points */
  1684. if((dz->bigbuf = (float *)malloc((bigbufsize * dz->bufcnt) + xs)) == NULL) {
  1685. sprintf(errstr,"INSUFFICIENT MEMORY to create sound buffers.\n");
  1686. return(PROGRAM_ERROR);
  1687. }
  1688. dz->sampbuf[0] = dz->sbufptr[0] = dz->bigbuf;
  1689. dz->sampbuf[1] = dz->sbufptr[1] = dz->bigbuf + dz->buflen + dz->infile->channels;
  1690. dz->sampbuf[2] = dz->sampbuf[1] + dz->buflen;
  1691. // TW : Mar 2015: iparam[2 = UNIT_BUFLEN] SET BELOW, but in Mode 2, iparam[2 = ACCEL_STARTTIME in samples] : CONFLICT
  1692. // TW : Mar 2015: BUT: UNIT_BUFLEN not used in Mode 2 SO THIS RESOLVES CONFLICT
  1693. if(dz->mode != 2)
  1694. dz->iparam[UNIT_BUFLEN] = dz->buflen/dz->infile->channels;
  1695. return(FINISHED);
  1696. }
  1697. /***************************** REFINESIZE(): ******************************
  1698. *
  1699. * refine size of final event to reduce error within bounds.
  1700. */
  1701. double refinesize(double hibound,double lobound,double fnumber,long duration,double error,double insize0)
  1702. {
  1703. double size, fnum, lasterror;
  1704. double flterr_squared = FLTERR * FLTERR;
  1705. do {
  1706. lasterror = error;
  1707. size = (hibound+lobound)/2.0;
  1708. fnum = cntevents(duration,insize0,size);
  1709. error = fabs(fnumber-fnum);
  1710. if(error>FLTERR) {
  1711. if(fnum<fnumber)
  1712. lobound = size;
  1713. else
  1714. hibound = size;
  1715. }
  1716. if(fabs(lasterror - error) < flterr_squared)
  1717. break; /* In case error cannot be reduced */
  1718. } while(error > FLTERR);
  1719. return(size);
  1720. }
  1721. /************************ INTEGRAL_TIMES ***************************
  1722. *
  1723. * GENERATE vals for equally spaced events, spaced by whole nos. of samps.
  1724. */
  1725. int integral_times(long *obufcnt,long intime0,long isize,long number,dataptr dz)
  1726. {
  1727. int exit_status;
  1728. long k, pos = intime0 - dz->iparam[UNITS_RD_PRE_THISBUF];
  1729. for(k=0;k<number;k++) {
  1730. if(pos >= dz->iparam[UNITS_READ]) {
  1731. if(dz->samps_left <= 0)
  1732. return(FINISHED);
  1733. if((exit_status = read_samps_for_strans(dz))<0)
  1734. return(exit_status);
  1735. pos -= dz->iparam[UNIT_BUFLEN];
  1736. }
  1737. if((exit_status = putintval(obufcnt,pos,dz))<0)
  1738. return(exit_status);
  1739. pos += isize;
  1740. }
  1741. return(CONTINUE);
  1742. }
  1743. /****************************** PUTINTVAL ******************************/
  1744. int putintval(long *obufcnt,long i,dataptr dz)
  1745. {
  1746. int exit_status;
  1747. int n;
  1748. float *buffer = dz->sampbuf[0];
  1749. float *obuf = dz->sampbuf[1];
  1750. i *= dz->infile->channels;
  1751. for(n=0;n<dz->infile->channels;n++) {
  1752. obuf[(*obufcnt)++] = buffer[i];
  1753. if(*obufcnt >= dz->buflen) {
  1754. if((exit_status = write_samps_with_intime_display(obuf,dz->buflen,dz))<0)
  1755. return(exit_status);
  1756. *obufcnt = 0;
  1757. }
  1758. i++;
  1759. }
  1760. return(FINISHED);
  1761. }
  1762. /************************ UNVARYING_TIMES ***************************
  1763. *
  1764. * GENERATE vals for equally spaced events.
  1765. */
  1766. int unvarying_times(long *obufcnt,long intime0,double size,long number,dataptr dz)
  1767. {
  1768. int exit_status;
  1769. long k;
  1770. double pos = (double)(intime0 - dz->iparam[UNITS_RD_PRE_THISBUF]);
  1771. for(k=0;k<number;k++) {
  1772. if(pos >= (double)dz->iparam[UNITS_READ]) {
  1773. if(dz->samps_left <= 0)
  1774. return(FINISHED);
  1775. if((exit_status = read_samps_for_strans(dz))<0)
  1776. return(exit_status);
  1777. pos -= (double)dz->iparam[UNIT_BUFLEN];
  1778. }
  1779. if((exit_status = putval(obufcnt,pos,dz))<0)
  1780. return(exit_status);
  1781. pos += size;
  1782. }
  1783. return(CONTINUE);
  1784. }
  1785. /******************************* DO_ACCELERATION ***************************/
  1786. int do_acceleration(dataptr dz)
  1787. {
  1788. int exit_status;
  1789. long place, chunksread, n, thisplace, nextplace;
  1790. double flplace, fracsamp, step;
  1791. int OK = 1, chans = dz->infile->channels;
  1792. double interp;
  1793. float *ibuf = dz->sampbuf[0];
  1794. float *obuf = dz->sampbuf[1], *obufptr, *obufend = obuf + dz->buflen;
  1795. double place_inc = 1.0;
  1796. long startsamp = dz->iparam[ACCEL_STARTTIME];
  1797. long previous_total_ssampsread = 0;
  1798. double accel = dz->param[ACCEL_ACCEL];
  1799. dz->total_samps_read = 0;
  1800. display_virtual_time(0L,dz);
  1801. if((exit_status = read_samps_for_strans(dz))<0)
  1802. return(exit_status);
  1803. while(dz->total_samps_read <= startsamp) {
  1804. if((exit_status = write_samps_with_intime_display(ibuf,dz->ssampsread,dz))<0)
  1805. return(exit_status);
  1806. previous_total_ssampsread = dz->total_samps_read;
  1807. if((exit_status = read_samps_for_strans(dz))<0)
  1808. return(exit_status);
  1809. }
  1810. startsamp -= previous_total_ssampsread;
  1811. if(startsamp > 0)
  1812. memcpy((char *)obuf,(char *)ibuf,startsamp * sizeof(float));
  1813. obufptr = obuf + startsamp;
  1814. chunksread = dz->ssampsread/chans;
  1815. place = startsamp/chans;
  1816. flplace = place;
  1817. for(;;) {
  1818. while(chunksread > place) {
  1819. while(place < chunksread) {
  1820. fracsamp = flplace - (double)place;
  1821. for(n=0;n < chans; n++) {
  1822. thisplace = (place * chans) + n;
  1823. nextplace = ((place+1) * chans) + n;
  1824. step = ibuf[nextplace] - ibuf[thisplace];
  1825. interp = fracsamp * step;
  1826. *obufptr++ = (float)(ibuf[thisplace] + interp);
  1827. }
  1828. if(obufptr >= obufend) {
  1829. if((exit_status = write_samps_with_intime_display(obuf,dz->buflen,dz))<0)
  1830. return(exit_status);
  1831. obufptr = obuf;
  1832. }
  1833. flplace += place_inc;
  1834. place_inc *= accel;
  1835. if(place_inc <= MININC) {
  1836. fprintf(stdout, "INFO: Acceleration reached black hole! - finishing\n");
  1837. fflush(stdout);
  1838. OK = 0;
  1839. break;
  1840. }
  1841. place = (int)flplace;
  1842. }
  1843. if(!OK)
  1844. break;
  1845. }
  1846. if(dz->samps_left > 0) {
  1847. flplace -= (double)chunksread;
  1848. place -= chunksread;
  1849. if((exit_status = read_samps_for_strans(dz))<0)
  1850. return(exit_status);
  1851. if((chunksread = dz->ssampsread/chans) <= 0)
  1852. break;
  1853. } else
  1854. break;
  1855. }
  1856. splice_end(obufptr - obuf,dz);
  1857. return write_samps_with_intime_display(obuf,obufptr - obuf ,dz);
  1858. }
  1859. /******************************* DO_VIBRATO ********************************/
  1860. int do_vibrato(dataptr dz)
  1861. {
  1862. int exit_status;
  1863. float *ibuf = dz->sampbuf[0];
  1864. float *obuf = dz->sampbuf[1];
  1865. float *obufend = dz->sampbuf[1] + dz->buflen;
  1866. double *sintab = dz->parray[VIB_SINTAB];
  1867. int chans = dz->infile->channels;
  1868. double sr = (double)dz->infile->srate;
  1869. double tabsize = (double)VIB_TABSIZE;
  1870. double bloksize = (double)VIB_BLOKSIZE;
  1871. double inv_bloksize = 1.0/bloksize;
  1872. double thistime = 0.0;
  1873. double time_incr = bloksize/sr; /* timestep between param reads */
  1874. int effective_buflen = dz->buflen/chans;
  1875. long place = 0; /* integer position in sndfile */
  1876. double flplace = 0.0; /* float position in sndfile */
  1877. double incr; /* incr of position in sndfile */
  1878. double sfindex = 0.0; /* float position in sintable */
  1879. double sinval; /* current sintable value */
  1880. double current_depth, lastdepth, depth_incr;
  1881. double current_frq, lastfrq, frq_incr;
  1882. double fracsamp; /* fraction of samptime to interp*/
  1883. double step; /* step between snd samples */
  1884. double interp; /* part of sampstep to use */
  1885. int blokcnt = 0; /* distance through blokd params */
  1886. float *obufptr = obuf;
  1887. long chunksread, thisplace, nextplace, n;
  1888. if(dz->brksize[VIB_FRQ]) {
  1889. if((exit_status = read_value_from_brktable(thistime,VIB_FRQ,dz))<0)
  1890. return(exit_status);
  1891. } else
  1892. frq_incr = 0.0;
  1893. if(dz->brksize[VIB_DEPTH]) {
  1894. if((exit_status = read_value_from_brktable(thistime,VIB_DEPTH,dz))<0)
  1895. return(exit_status);
  1896. } else
  1897. depth_incr = 0.0;
  1898. current_frq = lastfrq = dz->param[VIB_FRQ];
  1899. current_depth = lastdepth = dz->param[VIB_DEPTH];
  1900. thistime += time_incr; /* now time is 1 bloklength ahead */
  1901. if((exit_status = read_samps_for_strans(dz))<0)
  1902. return(exit_status);
  1903. if((exit_status = read_values_from_all_existing_brktables(thistime,dz))<0)
  1904. return(exit_status); /* read value 1 bloklength ahead */
  1905. frq_incr = (dz->param[VIB_FRQ] - lastfrq) * inv_bloksize;
  1906. depth_incr = (dz->param[VIB_DEPTH] - lastdepth) * inv_bloksize;
  1907. lastfrq = dz->param[VIB_FRQ];
  1908. lastdepth = dz->param[VIB_DEPTH];
  1909. blokcnt = VIB_BLOKSIZE - 1; /* -1 as we've read 1 (chancnt) sample already. */
  1910. thistime += time_incr; /* Now time is 2 bloklengths ahead */
  1911. /* but we won't read till another 1 blok has passed. */
  1912. chunksread = dz->ssampsread / chans;
  1913. memset((char *)obuf,0,dz->buflen * sizeof(float));
  1914. for(;;) {
  1915. if(--blokcnt <= 0) { /* look at params only every BLOKCNT(*chans)samples */
  1916. if((exit_status = read_values_from_all_existing_brktables(thistime,dz))<0)
  1917. return(exit_status); /* & read vals 1 bloklen ahead,to calc par incr */
  1918. frq_incr = (dz->param[VIB_FRQ] - lastfrq) * inv_bloksize;
  1919. depth_incr = (dz->param[VIB_DEPTH] - lastdepth) * inv_bloksize;
  1920. lastfrq = dz->param[VIB_FRQ];
  1921. lastdepth = dz->param[VIB_DEPTH];
  1922. blokcnt = VIB_BLOKSIZE;
  1923. thistime += time_incr;
  1924. }
  1925. current_depth += depth_incr; /* increment params sample by (stereo) sample */
  1926. current_frq += frq_incr;
  1927. if((sfindex += current_frq) >= tabsize)
  1928. sfindex -= tabsize; /* advance in sintable,wrapping around if ness */
  1929. sinval = interp_read_sintable(sintab,sfindex); /* read sintab by interpolation */
  1930. incr = pow(2.0,sinval * current_depth); /* convert speed & depth from 8vas to ratio */
  1931. if((flplace += incr) >= (double)chunksread) { /* advance through src sound */
  1932. if(dz->samps_left <=0) /* if at end of src, finish */
  1933. break; /* else if at end of buffer, get more sound in */
  1934. if((exit_status = read_samps_for_strans(dz))<0)
  1935. return(exit_status);
  1936. flplace -= effective_buflen;
  1937. }
  1938. place = (long)flplace; /* TRUNCATE */ /* read sndfile by interpolation */
  1939. fracsamp = flplace - (double)place;
  1940. for(n=0;n<chans;n++) {
  1941. thisplace = (place * chans) + n;
  1942. nextplace = ((place+1) * chans) + n;
  1943. step = ibuf[nextplace] - ibuf[thisplace];
  1944. interp = fracsamp * step;
  1945. *obufptr++ = (float)(ibuf[thisplace] + interp);
  1946. }
  1947. if(obufptr >= obufend) { /* if at end of outbuf, write a buffer */
  1948. if((exit_status = write_samps_with_intime_display(obuf,dz->buflen,dz))<0)
  1949. return(exit_status);
  1950. memset((char *)obuf,0,dz->buflen * sizeof(float));
  1951. obufptr = obuf;
  1952. }
  1953. }
  1954. if(obufptr > obuf) /* if samples remain in outbuf, write them */
  1955. return write_samps_with_intime_display(obuf,obufptr - obuf,dz);
  1956. return(FINISHED);
  1957. }
  1958. /******************************* INTERP_READ_SINTABLE ********************************/
  1959. double interp_read_sintable(double *sintab,double sfindex)
  1960. {
  1961. int sindex0 = (int)sfindex; /* TRUNCATE */
  1962. int sindex1 = sindex0 + 1;
  1963. double frac = sfindex - (double)sindex0;
  1964. double val0 = sintab[sindex0];
  1965. double val1 = sintab[sindex1];
  1966. double valdiff = val1 - val0;
  1967. double valfrac = valdiff * frac;
  1968. return(val0 + valfrac);
  1969. }
  1970. /****************************** GET_MODE *********************************/
  1971. int get_the_mode_from_cmdline(char *str,dataptr dz)
  1972. {
  1973. if(sscanf(str,"%d",&dz->mode)!=1) {
  1974. sprintf(errstr,"Cannot read mode of program.\n");
  1975. return(USAGE_ONLY);
  1976. }
  1977. if(dz->mode <= 0 || dz->mode > dz->maxmode) {
  1978. sprintf(errstr,"Program mode value [%d] is out of range [1 - %d].\n",dz->mode,dz->maxmode);
  1979. return(USAGE_ONLY);
  1980. }
  1981. dz->mode--; /* CHANGE TO INTERNAL REPRESENTATION OF MODE NO */
  1982. return(FINISHED);
  1983. }