wavmedian.c 36 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157
  1. // _cdprogs\scramble scramble 5 alan_bellydancefc.wav test.wav cuts.txt
  2. #include <stdio.h>
  3. #include <stdlib.h>
  4. #include <structures.h>
  5. #include <tkglobals.h>
  6. #include <pnames.h>
  7. #include <filetype.h>
  8. #include <processno.h>
  9. #include <modeno.h>
  10. #include <logic.h>
  11. #include <globcon.h>
  12. #include <cdpmain.h>
  13. #include <math.h>
  14. #include <mixxcon.h>
  15. #include <osbind.h>
  16. #include <standalone.h>
  17. #include <science.h>
  18. #include <ctype.h>
  19. #include <sfsys.h>
  20. #include <string.h>
  21. #include <srates.h>
  22. #ifdef unix
  23. #define round(x) lround((x))
  24. #endif
  25. char errstr[2400];
  26. int anal_infiles = 1;
  27. int sloom = 0;
  28. int sloombatch = 0;
  29. const char* cdp_version = "6.1.0";
  30. //CDP LIB REPLACEMENTS
  31. static int setup_wavmedian_application(dataptr dz);
  32. static int parse_sloom_data(int argc,char *argv[],char ***cmdline,int *cmdlinecnt,dataptr dz);
  33. static int parse_infile_and_check_type(char **cmdline,dataptr dz);
  34. static int setup_wavmedian_param_ranges_and_defaults(dataptr dz);
  35. static int handle_the_outfile(int *cmdlinecnt,char ***cmdline,dataptr dz);
  36. static int setup_and_init_input_param_activity(dataptr dz,int tipc);
  37. static int setup_input_param_defaultval_stores(int tipc,aplptr ap);
  38. static int establish_application(dataptr dz);
  39. static int initialise_vflags(dataptr dz);
  40. static int setup_parameter_storage_and_constants(int storage_cnt,dataptr dz);
  41. static int initialise_is_int_and_no_brk_constants(int storage_cnt,dataptr dz);
  42. static int mark_parameter_types(dataptr dz,aplptr ap);
  43. static int assign_file_data_storage(int infilecnt,dataptr dz);
  44. static int get_tk_cmdline_word(int *cmdlinecnt,char ***cmdline,char *q);
  45. static int get_the_process_no(char *prog_identifier_from_cmdline,dataptr dz);
  46. static int setup_and_init_input_brktable_constants(dataptr dz,int brkcnt);
  47. static int waveset_group_find(int *buffer_overrun,int *current_buf,int initial_phase,int *current_pos,int *cnt,int *last_total_samps_read,int group_cyclecnt,dataptr dz);
  48. static int change_buf(int *current_buf,int *buffer_overrun,float **buf,int *last_total_samps_read,dataptr dz);
  49. static int get_initial_phase(int *initial_phase,dataptr dz);
  50. static int find_waveset_median(dataptr dz);
  51. /**************************************** MAIN *********************************************/
  52. int main(int argc,char *argv[])
  53. {
  54. int exit_status;
  55. dataptr dz = NULL;
  56. char **cmdline;
  57. int cmdlinecnt;
  58. int n;
  59. aplptr ap;
  60. int is_launched = FALSE;
  61. if(argc==2 && (strcmp(argv[1],"--version") == 0)) {
  62. fprintf(stdout,"%s\n",cdp_version);
  63. fflush(stdout);
  64. return 0;
  65. }
  66. /* CHECK FOR SOUNDLOOM */
  67. if((sloom = sound_loom_in_use(&argc,&argv)) > 1) {
  68. sloom = 0;
  69. sloombatch = 1;
  70. }
  71. if(sflinit("cdp")){
  72. sfperror("cdp: initialisation\n");
  73. return(FAILED);
  74. }
  75. /* SET UP THE PRINCIPLE DATASTRUCTURE */
  76. if((exit_status = establish_datastructure(&dz))<0) { // CDP LIB
  77. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  78. return(FAILED);
  79. }
  80. if(!sloom) {
  81. if(argc == 1) {
  82. usage1();
  83. return(FAILED);
  84. } else if(argc == 2) {
  85. usage2(argv[1]);
  86. return(FAILED);
  87. }
  88. }
  89. if(!sloom) {
  90. if((exit_status = make_initial_cmdline_check(&argc,&argv))<0) { // CDP LIB
  91. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  92. return(FAILED);
  93. }
  94. cmdline = argv;
  95. cmdlinecnt = argc;
  96. if((get_the_process_no(argv[0],dz))<0)
  97. return(FAILED);
  98. cmdline++;
  99. cmdlinecnt--;
  100. dz->maxmode = 0;
  101. // setup_particular_application =
  102. if((exit_status = setup_wavmedian_application(dz))<0) {
  103. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  104. return(FAILED);
  105. }
  106. if((exit_status = count_and_allocate_for_infiles(cmdlinecnt,cmdline,dz))<0) { // CDP LIB
  107. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  108. return(FAILED);
  109. }
  110. } else {
  111. //parse_TK_data() =
  112. if((exit_status = parse_sloom_data(argc,argv,&cmdline,&cmdlinecnt,dz))<0) {
  113. exit_status = print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  114. return(exit_status);
  115. }
  116. }
  117. ap = dz->application;
  118. // parse_infile_and_hone_type() =
  119. if((exit_status = parse_infile_and_check_type(cmdline,dz))<0) {
  120. exit_status = print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  121. return(FAILED);
  122. }
  123. // setup_param_ranges_and_defaults() =
  124. if((exit_status = setup_wavmedian_param_ranges_and_defaults(dz))<0) {
  125. exit_status = print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  126. return(FAILED);
  127. }
  128. // open_first_infile CDP LIB
  129. if((exit_status = open_first_infile(cmdline[0],dz))<0) {
  130. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  131. return(FAILED);
  132. }
  133. cmdlinecnt--;
  134. cmdline++;
  135. if((exit_status = read_parameters_and_flags(&cmdline,&cmdlinecnt,dz))<0) { // CDP LIB
  136. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  137. return(FAILED);
  138. }
  139. is_launched = TRUE;
  140. dz->bufcnt = 2;
  141. if((dz->sampbuf = (float **)malloc(sizeof(float *) * (dz->bufcnt+1)))==NULL) {
  142. sprintf(errstr,"INSUFFICIENT MEMORY establishing sample buffers.\n");
  143. return(MEMORY_ERROR);
  144. }
  145. if((dz->sbufptr = (float **)malloc(sizeof(float *) * dz->bufcnt))==NULL) {
  146. sprintf(errstr,"INSUFFICIENT MEMORY establishing sample buffer pointers.\n");
  147. return(MEMORY_ERROR);
  148. }
  149. for(n = 0;n <dz->bufcnt; n++)
  150. dz->sampbuf[n] = dz->sbufptr[n] = (float *)0;
  151. dz->sampbuf[n] = (float *)0;
  152. if((exit_status = create_sndbufs(dz))<0) { // CDP LIB
  153. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  154. return(FAILED);
  155. }
  156. //param_preprocess() redundant
  157. //spec_process_file =
  158. if((exit_status = find_waveset_median(dz))<0) {
  159. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  160. return(FAILED);
  161. }
  162. sffinish();
  163. // if(sloom)
  164. // fprintf(stdout,"END:");
  165. fflush(stdout);
  166. free(dz);
  167. return(SUCCEEDED);
  168. }
  169. /**********************************************
  170. REPLACED CDP LIB FUNCTIONS
  171. **********************************************/
  172. /****************************** SET_PARAM_DATA *********************************/
  173. int set_param_data(aplptr ap, int special_data,int maxparamcnt,int paramcnt,char *paramlist)
  174. {
  175. ap->special_data = (char)special_data;
  176. ap->param_cnt = (char)paramcnt;
  177. ap->max_param_cnt = (char)maxparamcnt;
  178. if(ap->max_param_cnt>0) {
  179. if((ap->param_list = (char *)malloc((size_t)(ap->max_param_cnt+1)))==NULL) {
  180. sprintf(errstr,"INSUFFICIENT MEMORY: for param_list\n");
  181. return(MEMORY_ERROR);
  182. }
  183. strcpy(ap->param_list,paramlist);
  184. }
  185. return(FINISHED);
  186. }
  187. /****************************** SET_VFLGS *********************************/
  188. int set_vflgs
  189. (aplptr ap,char *optflags,int optcnt,char *optlist,char *varflags,int vflagcnt, int vparamcnt,char *varlist)
  190. {
  191. ap->option_cnt = (char) optcnt; /*RWD added cast */
  192. if(optcnt) {
  193. if((ap->option_list = (char *)malloc((size_t)(optcnt+1)))==NULL) {
  194. sprintf(errstr,"INSUFFICIENT MEMORY: for option_list\n");
  195. return(MEMORY_ERROR);
  196. }
  197. strcpy(ap->option_list,optlist);
  198. if((ap->option_flags = (char *)malloc((size_t)(optcnt+1)))==NULL) {
  199. sprintf(errstr,"INSUFFICIENT MEMORY: for option_flags\n");
  200. return(MEMORY_ERROR);
  201. }
  202. strcpy(ap->option_flags,optflags);
  203. }
  204. ap->vflag_cnt = (char) vflagcnt;
  205. ap->variant_param_cnt = (char) vparamcnt;
  206. if(vflagcnt) {
  207. if((ap->variant_list = (char *)malloc((size_t)(vflagcnt+1)))==NULL) {
  208. sprintf(errstr,"INSUFFICIENT MEMORY: for variant_list\n");
  209. return(MEMORY_ERROR);
  210. }
  211. strcpy(ap->variant_list,varlist);
  212. if((ap->variant_flags = (char *)malloc((size_t)(vflagcnt+1)))==NULL) {
  213. sprintf(errstr,"INSUFFICIENT MEMORY: for variant_flags\n");
  214. return(MEMORY_ERROR);
  215. }
  216. strcpy(ap->variant_flags,varflags);
  217. }
  218. return(FINISHED);
  219. }
  220. /***************************** APPLICATION_INIT **************************/
  221. int application_init(dataptr dz)
  222. {
  223. int exit_status;
  224. int storage_cnt;
  225. int tipc, brkcnt;
  226. aplptr ap = dz->application;
  227. if(ap->vflag_cnt>0)
  228. initialise_vflags(dz);
  229. tipc = ap->max_param_cnt + ap->option_cnt + ap->variant_param_cnt;
  230. ap->total_input_param_cnt = (char)tipc;
  231. if(tipc>0) {
  232. if((exit_status = setup_input_param_range_stores(tipc,ap))<0)
  233. return(exit_status);
  234. if((exit_status = setup_input_param_defaultval_stores(tipc,ap))<0)
  235. return(exit_status);
  236. if((exit_status = setup_and_init_input_param_activity(dz,tipc))<0)
  237. return(exit_status);
  238. }
  239. brkcnt = tipc;
  240. //THERE ARE NO INPUTFILE brktables USED IN THIS PROCESS
  241. if(brkcnt>0) {
  242. if((exit_status = setup_and_init_input_brktable_constants(dz,brkcnt))<0)
  243. return(exit_status);
  244. }
  245. if((storage_cnt = tipc + ap->internal_param_cnt)>0) {
  246. if((exit_status = setup_parameter_storage_and_constants(storage_cnt,dz))<0)
  247. return(exit_status);
  248. if((exit_status = initialise_is_int_and_no_brk_constants(storage_cnt,dz))<0)
  249. return(exit_status);
  250. }
  251. if((exit_status = mark_parameter_types(dz,ap))<0)
  252. return(exit_status);
  253. // establish_infile_constants() replaced by
  254. dz->infilecnt = 1;
  255. //establish_bufptrs_and_extra_buffers():
  256. return(FINISHED);
  257. }
  258. /********************** SETUP_PARAMETER_STORAGE_AND_CONSTANTS ********************/
  259. /* RWD mallo changed to calloc; helps debug verison run as release! */
  260. int setup_parameter_storage_and_constants(int storage_cnt,dataptr dz)
  261. {
  262. if((dz->param = (double *)calloc(storage_cnt, sizeof(double)))==NULL) {
  263. sprintf(errstr,"setup_parameter_storage_and_constants(): 1\n");
  264. return(MEMORY_ERROR);
  265. }
  266. if((dz->iparam = (int *)calloc(storage_cnt, sizeof(int) ))==NULL) {
  267. sprintf(errstr,"setup_parameter_storage_and_constants(): 2\n");
  268. return(MEMORY_ERROR);
  269. }
  270. if((dz->is_int = (char *)calloc(storage_cnt, sizeof(char)))==NULL) {
  271. sprintf(errstr,"setup_parameter_storage_and_constants(): 3\n");
  272. return(MEMORY_ERROR);
  273. }
  274. if((dz->no_brk = (char *)calloc(storage_cnt, sizeof(char)))==NULL) {
  275. sprintf(errstr,"setup_parameter_storage_and_constants(): 5\n");
  276. return(MEMORY_ERROR);
  277. }
  278. return(FINISHED);
  279. }
  280. /************** INITIALISE_IS_INT_AND_NO_BRK_CONSTANTS *****************/
  281. int initialise_is_int_and_no_brk_constants(int storage_cnt,dataptr dz)
  282. {
  283. int n;
  284. for(n=0;n<storage_cnt;n++) {
  285. dz->is_int[n] = (char)0;
  286. dz->no_brk[n] = (char)0;
  287. }
  288. return(FINISHED);
  289. }
  290. /***************************** MARK_PARAMETER_TYPES **************************/
  291. int mark_parameter_types(dataptr dz,aplptr ap)
  292. {
  293. int n, m; /* PARAMS */
  294. for(n=0;n<ap->max_param_cnt;n++) {
  295. switch(ap->param_list[n]) {
  296. case('0'): break; /* dz->is_active[n] = 0 is default */
  297. case('i'): dz->is_active[n] = (char)1; dz->is_int[n] = (char)1;dz->no_brk[n] = (char)1; break;
  298. case('I'): dz->is_active[n] = (char)1; dz->is_int[n] = (char)1; break;
  299. case('d'): dz->is_active[n] = (char)1; dz->no_brk[n] = (char)1; break;
  300. case('D'): dz->is_active[n] = (char)1; /* normal case: double val or brkpnt file */ break;
  301. default:
  302. sprintf(errstr,"Programming error: invalid parameter type in mark_parameter_types()\n");
  303. return(PROGRAM_ERROR);
  304. }
  305. } /* OPTIONS */
  306. for(n=0,m=ap->max_param_cnt;n<ap->option_cnt;n++,m++) {
  307. switch(ap->option_list[n]) {
  308. case('i'): dz->is_active[m] = (char)1; dz->is_int[m] = (char)1; dz->no_brk[m] = (char)1; break;
  309. case('I'): dz->is_active[m] = (char)1; dz->is_int[m] = (char)1; break;
  310. case('d'): dz->is_active[m] = (char)1; dz->no_brk[m] = (char)1; break;
  311. case('D'): dz->is_active[m] = (char)1; /* normal case: double val or brkpnt file */ break;
  312. default:
  313. sprintf(errstr,"Programming error: invalid option type in mark_parameter_types()\n");
  314. return(PROGRAM_ERROR);
  315. }
  316. } /* VARIANTS */
  317. for(n=0,m=ap->max_param_cnt + ap->option_cnt;n < ap->variant_param_cnt; n++, m++) {
  318. switch(ap->variant_list[n]) {
  319. case('0'): break;
  320. case('i'): dz->is_active[m] = (char)1; dz->is_int[m] = (char)1; dz->no_brk[m] = (char)1; break;
  321. case('I'): dz->is_active[m] = (char)1; dz->is_int[m] = (char)1; break;
  322. case('d'): dz->is_active[m] = (char)1; dz->no_brk[m] = (char)1; break;
  323. case('D'): dz->is_active[m] = (char)1; /* normal case: double val or brkpnt file */ break;
  324. default:
  325. sprintf(errstr,"Programming error: invalid variant type in mark_parameter_types()\n");
  326. return(PROGRAM_ERROR);
  327. }
  328. } /* INTERNAL */
  329. for(n=0,
  330. m=ap->max_param_cnt + ap->option_cnt + ap->variant_param_cnt; n<ap->internal_param_cnt; n++,m++) {
  331. switch(ap->internal_param_list[n]) {
  332. case('0'): break; /* dummy variables: variables not used: but important for internal paream numbering!! */
  333. case('i'): dz->is_int[m] = (char)1; dz->no_brk[m] = (char)1; break;
  334. case('d'): dz->no_brk[m] = (char)1; break;
  335. default:
  336. sprintf(errstr,"Programming error: invalid internal param type in mark_parameter_types()\n");
  337. return(PROGRAM_ERROR);
  338. }
  339. }
  340. return(FINISHED);
  341. }
  342. /***************************** ESTABLISH_APPLICATION **************************/
  343. int establish_application(dataptr dz)
  344. {
  345. aplptr ap;
  346. if((dz->application = (aplptr)malloc(sizeof (struct applic)))==NULL) {
  347. sprintf(errstr,"establish_application()\n");
  348. return(MEMORY_ERROR);
  349. }
  350. ap = dz->application;
  351. memset((char *)ap,0,sizeof(struct applic));
  352. return(FINISHED);
  353. }
  354. /************************* INITIALISE_VFLAGS *************************/
  355. int initialise_vflags(dataptr dz)
  356. {
  357. int n;
  358. if((dz->vflag = (char *)malloc(dz->application->vflag_cnt * sizeof(char)))==NULL) {
  359. sprintf(errstr,"INSUFFICIENT MEMORY: vflag store,\n");
  360. return(MEMORY_ERROR);
  361. }
  362. for(n=0;n<dz->application->vflag_cnt;n++)
  363. dz->vflag[n] = FALSE;
  364. return FINISHED;
  365. }
  366. /************************* SETUP_INPUT_PARAM_DEFAULTVALS *************************/
  367. int setup_input_param_defaultval_stores(int tipc,aplptr ap)
  368. {
  369. int n;
  370. if((ap->default_val = (double *)malloc(tipc * sizeof(double)))==NULL) {
  371. sprintf(errstr,"INSUFFICIENT MEMORY for application default values store\n");
  372. return(MEMORY_ERROR);
  373. }
  374. for(n=0;n<tipc;n++)
  375. ap->default_val[n] = 0.0;
  376. return(FINISHED);
  377. }
  378. /***************************** SETUP_AND_INIT_INPUT_PARAM_ACTIVITY **************************/
  379. int setup_and_init_input_param_activity(dataptr dz,int tipc)
  380. {
  381. int n;
  382. if((dz->is_active = (char *)malloc((size_t)tipc))==NULL) {
  383. sprintf(errstr,"setup_and_init_input_param_activity()\n");
  384. return(MEMORY_ERROR);
  385. }
  386. for(n=0;n<tipc;n++)
  387. dz->is_active[n] = (char)0;
  388. return(FINISHED);
  389. }
  390. /************************* SETUP_WAVMEDIAN_APPLICATION *******************/
  391. int setup_wavmedian_application(dataptr dz)
  392. {
  393. int exit_status;
  394. aplptr ap;
  395. if((exit_status = establish_application(dz))<0) // GLOBAL
  396. return(FAILED);
  397. ap = dz->application;
  398. // SEE parstruct FOR EXPLANATION of next 2 functions
  399. if((exit_status = set_param_data(ap,0,1,1,"d"))<0)
  400. return(FAILED);
  401. if((exit_status = set_vflgs(ap,"",0,"","",0,0,""))<0)
  402. return(FAILED);
  403. // set_legal_infile_structure -->
  404. dz->has_otherfile = FALSE;
  405. // assign_process_logic -->
  406. dz->input_data_type = SNDFILES_ONLY;
  407. dz->process_type = OTHER_PROCESS;
  408. dz->outfiletype = NO_OUTPUTFILE;
  409. return application_init(dz); //GLOBAL
  410. }
  411. /************************* PARSE_INFILE_AND_CHECK_TYPE *******************/
  412. int parse_infile_and_check_type(char **cmdline,dataptr dz)
  413. {
  414. int exit_status;
  415. infileptr infile_info;
  416. if(!sloom) {
  417. if((infile_info = (infileptr)malloc(sizeof(struct filedata)))==NULL) {
  418. sprintf(errstr,"INSUFFICIENT MEMORY for infile structure to test file data.");
  419. return(MEMORY_ERROR);
  420. } else if((exit_status = cdparse(cmdline[0],infile_info))<0) {
  421. sprintf(errstr,"Failed to parse input file %s\n",cmdline[0]);
  422. return(PROGRAM_ERROR);
  423. } else if(infile_info->filetype != SNDFILE) {
  424. sprintf(errstr,"File %s is not of correct type\n",cmdline[0]);
  425. return(DATA_ERROR);
  426. } else if(infile_info->channels != 1) {
  427. sprintf(errstr,"File %s is not of correct type (must be mono)\n",cmdline[0]);
  428. return(DATA_ERROR);
  429. } else if((exit_status = copy_parse_info_to_main_structure(infile_info,dz))<0) {
  430. sprintf(errstr,"Failed to copy file parsing information\n");
  431. return(PROGRAM_ERROR);
  432. }
  433. free(infile_info);
  434. }
  435. return(FINISHED);
  436. }
  437. /************************* SETUP_WAVMEDIAN_PARAM_RANGES_AND_DEFAULTS *******************/
  438. int setup_wavmedian_param_ranges_and_defaults(dataptr dz)
  439. {
  440. int exit_status;
  441. aplptr ap = dz->application;
  442. // set_param_ranges()
  443. ap->total_input_param_cnt = (char)(ap->max_param_cnt + ap->option_cnt + ap->variant_param_cnt);
  444. // NB total_input_param_cnt is > 0 !!!
  445. if((exit_status = setup_input_param_range_stores(ap->total_input_param_cnt,ap))<0)
  446. return(FAILED);
  447. // get_param_ranges()
  448. ap->lo[0] = 0.0001;
  449. ap->hi[0] = 10;
  450. ap->default_val[SCR_SEED] = .02;
  451. if(!sloom)
  452. put_default_vals_in_all_params(dz);
  453. return(FINISHED);
  454. }
  455. /********************************* PARSE_SLOOM_DATA *********************************/
  456. int parse_sloom_data(int argc,char *argv[],char ***cmdline,int *cmdlinecnt,dataptr dz)
  457. {
  458. int exit_status;
  459. int cnt = 1, infilecnt;
  460. int filesize, insams, inbrksize;
  461. double dummy;
  462. int true_cnt = 0;
  463. aplptr ap;
  464. while(cnt<=PRE_CMDLINE_DATACNT) {
  465. if(cnt > argc) {
  466. sprintf(errstr,"Insufficient data sent from TK\n");
  467. return(DATA_ERROR);
  468. }
  469. switch(cnt) {
  470. case(1):
  471. if(sscanf(argv[cnt],"%d",&dz->process)!=1) {
  472. sprintf(errstr,"Cannot read process no. sent from TK\n");
  473. return(DATA_ERROR);
  474. }
  475. break;
  476. case(2):
  477. if(sscanf(argv[cnt],"%d",&dz->mode)!=1) {
  478. sprintf(errstr,"Cannot read mode no. sent from TK\n");
  479. return(DATA_ERROR);
  480. }
  481. if(dz->mode > 0)
  482. dz->mode--;
  483. //setup_particular_application() =
  484. if((exit_status = setup_wavmedian_application(dz))<0)
  485. return(exit_status);
  486. ap = dz->application;
  487. break;
  488. case(3):
  489. if(sscanf(argv[cnt],"%d",&infilecnt)!=1) {
  490. sprintf(errstr,"Cannot read infilecnt sent from TK\n");
  491. return(DATA_ERROR);
  492. }
  493. if(infilecnt < 1) {
  494. true_cnt = cnt + 1;
  495. cnt = PRE_CMDLINE_DATACNT; /* force exit from loop after assign_file_data_storage */
  496. }
  497. if((exit_status = assign_file_data_storage(infilecnt,dz))<0)
  498. return(exit_status);
  499. break;
  500. case(INPUT_FILETYPE+4):
  501. if(sscanf(argv[cnt],"%d",&dz->infile->filetype)!=1) {
  502. sprintf(errstr,"Cannot read filetype sent from TK (%s)\n",argv[cnt]);
  503. return(DATA_ERROR);
  504. }
  505. break;
  506. case(INPUT_FILESIZE+4):
  507. if(sscanf(argv[cnt],"%d",&filesize)!=1) {
  508. sprintf(errstr,"Cannot read infilesize sent from TK\n");
  509. return(DATA_ERROR);
  510. }
  511. dz->insams[0] = filesize;
  512. break;
  513. case(INPUT_INSAMS+4):
  514. if(sscanf(argv[cnt],"%d",&insams)!=1) {
  515. sprintf(errstr,"Cannot read insams sent from TK\n");
  516. return(DATA_ERROR);
  517. }
  518. dz->insams[0] = insams;
  519. break;
  520. case(INPUT_SRATE+4):
  521. if(sscanf(argv[cnt],"%d",&dz->infile->srate)!=1) {
  522. sprintf(errstr,"Cannot read srate sent from TK\n");
  523. return(DATA_ERROR);
  524. }
  525. break;
  526. case(INPUT_CHANNELS+4):
  527. if(sscanf(argv[cnt],"%d",&dz->infile->channels)!=1) {
  528. sprintf(errstr,"Cannot read channels sent from TK\n");
  529. return(DATA_ERROR);
  530. }
  531. break;
  532. case(INPUT_STYPE+4):
  533. if(sscanf(argv[cnt],"%d",&dz->infile->stype)!=1) {
  534. sprintf(errstr,"Cannot read stype sent from TK\n");
  535. return(DATA_ERROR);
  536. }
  537. break;
  538. case(INPUT_ORIGSTYPE+4):
  539. if(sscanf(argv[cnt],"%d",&dz->infile->origstype)!=1) {
  540. sprintf(errstr,"Cannot read origstype sent from TK\n");
  541. return(DATA_ERROR);
  542. }
  543. break;
  544. case(INPUT_ORIGRATE+4):
  545. if(sscanf(argv[cnt],"%d",&dz->infile->origrate)!=1) {
  546. sprintf(errstr,"Cannot read origrate sent from TK\n");
  547. return(DATA_ERROR);
  548. }
  549. break;
  550. case(INPUT_MLEN+4):
  551. if(sscanf(argv[cnt],"%d",&dz->infile->Mlen)!=1) {
  552. sprintf(errstr,"Cannot read Mlen sent from TK\n");
  553. return(DATA_ERROR);
  554. }
  555. break;
  556. case(INPUT_DFAC+4):
  557. if(sscanf(argv[cnt],"%d",&dz->infile->Dfac)!=1) {
  558. sprintf(errstr,"Cannot read Dfac sent from TK\n");
  559. return(DATA_ERROR);
  560. }
  561. break;
  562. case(INPUT_ORIGCHANS+4):
  563. if(sscanf(argv[cnt],"%d",&dz->infile->origchans)!=1) {
  564. sprintf(errstr,"Cannot read origchans sent from TK\n");
  565. return(DATA_ERROR);
  566. }
  567. break;
  568. case(INPUT_SPECENVCNT+4):
  569. if(sscanf(argv[cnt],"%d",&dz->infile->specenvcnt)!=1) {
  570. sprintf(errstr,"Cannot read specenvcnt sent from TK\n");
  571. return(DATA_ERROR);
  572. }
  573. dz->specenvcnt = dz->infile->specenvcnt;
  574. break;
  575. case(INPUT_WANTED+4):
  576. if(sscanf(argv[cnt],"%d",&dz->wanted)!=1) {
  577. sprintf(errstr,"Cannot read wanted sent from TK\n");
  578. return(DATA_ERROR);
  579. }
  580. break;
  581. case(INPUT_WLENGTH+4):
  582. if(sscanf(argv[cnt],"%d",&dz->wlength)!=1) {
  583. sprintf(errstr,"Cannot read wlength sent from TK\n");
  584. return(DATA_ERROR);
  585. }
  586. break;
  587. case(INPUT_OUT_CHANS+4):
  588. if(sscanf(argv[cnt],"%d",&dz->out_chans)!=1) {
  589. sprintf(errstr,"Cannot read out_chans sent from TK\n");
  590. return(DATA_ERROR);
  591. }
  592. break;
  593. /* RWD these chanegs to samps - tk will have to deal with that! */
  594. case(INPUT_DESCRIPTOR_BYTES+4):
  595. if(sscanf(argv[cnt],"%d",&dz->descriptor_samps)!=1) {
  596. sprintf(errstr,"Cannot read descriptor_samps sent from TK\n");
  597. return(DATA_ERROR);
  598. }
  599. break;
  600. case(INPUT_IS_TRANSPOS+4):
  601. if(sscanf(argv[cnt],"%d",&dz->is_transpos)!=1) {
  602. sprintf(errstr,"Cannot read is_transpos sent from TK\n");
  603. return(DATA_ERROR);
  604. }
  605. break;
  606. case(INPUT_COULD_BE_TRANSPOS+4):
  607. if(sscanf(argv[cnt],"%d",&dz->could_be_transpos)!=1) {
  608. sprintf(errstr,"Cannot read could_be_transpos sent from TK\n");
  609. return(DATA_ERROR);
  610. }
  611. break;
  612. case(INPUT_COULD_BE_PITCH+4):
  613. if(sscanf(argv[cnt],"%d",&dz->could_be_pitch)!=1) {
  614. sprintf(errstr,"Cannot read could_be_pitch sent from TK\n");
  615. return(DATA_ERROR);
  616. }
  617. break;
  618. case(INPUT_DIFFERENT_SRATES+4):
  619. if(sscanf(argv[cnt],"%d",&dz->different_srates)!=1) {
  620. sprintf(errstr,"Cannot read different_srates sent from TK\n");
  621. return(DATA_ERROR);
  622. }
  623. break;
  624. case(INPUT_DUPLICATE_SNDS+4):
  625. if(sscanf(argv[cnt],"%d",&dz->duplicate_snds)!=1) {
  626. sprintf(errstr,"Cannot read duplicate_snds sent from TK\n");
  627. return(DATA_ERROR);
  628. }
  629. break;
  630. case(INPUT_BRKSIZE+4):
  631. if(sscanf(argv[cnt],"%d",&inbrksize)!=1) {
  632. sprintf(errstr,"Cannot read brksize sent from TK\n");
  633. return(DATA_ERROR);
  634. }
  635. if(inbrksize > 0) {
  636. switch(dz->input_data_type) {
  637. case(WORDLIST_ONLY):
  638. break;
  639. case(PITCH_AND_PITCH):
  640. case(PITCH_AND_TRANSPOS):
  641. case(TRANSPOS_AND_TRANSPOS):
  642. dz->tempsize = inbrksize;
  643. break;
  644. case(BRKFILES_ONLY):
  645. case(UNRANGED_BRKFILE_ONLY):
  646. case(DB_BRKFILES_ONLY):
  647. case(ALL_FILES):
  648. case(ANY_NUMBER_OF_ANY_FILES):
  649. if(dz->extrabrkno < 0) {
  650. sprintf(errstr,"Storage location number for brktable not established by CDP.\n");
  651. return(DATA_ERROR);
  652. }
  653. if(dz->brksize == NULL) {
  654. sprintf(errstr,"CDP has not established storage space for input brktable.\n");
  655. return(PROGRAM_ERROR);
  656. }
  657. dz->brksize[dz->extrabrkno] = inbrksize;
  658. break;
  659. default:
  660. sprintf(errstr,"TK sent brktablesize > 0 for input_data_type [%d] not using brktables.\n",
  661. dz->input_data_type);
  662. return(PROGRAM_ERROR);
  663. }
  664. break;
  665. }
  666. break;
  667. case(INPUT_NUMSIZE+4):
  668. if(sscanf(argv[cnt],"%d",&dz->numsize)!=1) {
  669. sprintf(errstr,"Cannot read numsize sent from TK\n");
  670. return(DATA_ERROR);
  671. }
  672. break;
  673. case(INPUT_LINECNT+4):
  674. if(sscanf(argv[cnt],"%d",&dz->linecnt)!=1) {
  675. sprintf(errstr,"Cannot read linecnt sent from TK\n");
  676. return(DATA_ERROR);
  677. }
  678. break;
  679. case(INPUT_ALL_WORDS+4):
  680. if(sscanf(argv[cnt],"%d",&dz->all_words)!=1) {
  681. sprintf(errstr,"Cannot read all_words sent from TK\n");
  682. return(DATA_ERROR);
  683. }
  684. break;
  685. case(INPUT_ARATE+4):
  686. if(sscanf(argv[cnt],"%f",&dz->infile->arate)!=1) {
  687. sprintf(errstr,"Cannot read arate sent from TK\n");
  688. return(DATA_ERROR);
  689. }
  690. break;
  691. case(INPUT_FRAMETIME+4):
  692. if(sscanf(argv[cnt],"%lf",&dummy)!=1) {
  693. sprintf(errstr,"Cannot read frametime sent from TK\n");
  694. return(DATA_ERROR);
  695. }
  696. dz->frametime = (float)dummy;
  697. break;
  698. case(INPUT_WINDOW_SIZE+4):
  699. if(sscanf(argv[cnt],"%f",&dz->infile->window_size)!=1) {
  700. sprintf(errstr,"Cannot read window_size sent from TK\n");
  701. return(DATA_ERROR);
  702. }
  703. break;
  704. case(INPUT_NYQUIST+4):
  705. if(sscanf(argv[cnt],"%lf",&dz->nyquist)!=1) {
  706. sprintf(errstr,"Cannot read nyquist sent from TK\n");
  707. return(DATA_ERROR);
  708. }
  709. break;
  710. case(INPUT_DURATION+4):
  711. if(sscanf(argv[cnt],"%lf",&dz->duration)!=1) {
  712. sprintf(errstr,"Cannot read duration sent from TK\n");
  713. return(DATA_ERROR);
  714. }
  715. break;
  716. case(INPUT_MINBRK+4):
  717. if(sscanf(argv[cnt],"%lf",&dz->minbrk)!=1) {
  718. sprintf(errstr,"Cannot read minbrk sent from TK\n");
  719. return(DATA_ERROR);
  720. }
  721. break;
  722. case(INPUT_MAXBRK+4):
  723. if(sscanf(argv[cnt],"%lf",&dz->maxbrk)!=1) {
  724. sprintf(errstr,"Cannot read maxbrk sent from TK\n");
  725. return(DATA_ERROR);
  726. }
  727. break;
  728. case(INPUT_MINNUM+4):
  729. if(sscanf(argv[cnt],"%lf",&dz->minnum)!=1) {
  730. sprintf(errstr,"Cannot read minnum sent from TK\n");
  731. return(DATA_ERROR);
  732. }
  733. break;
  734. case(INPUT_MAXNUM+4):
  735. if(sscanf(argv[cnt],"%lf",&dz->maxnum)!=1) {
  736. sprintf(errstr,"Cannot read maxnum sent from TK\n");
  737. return(DATA_ERROR);
  738. }
  739. break;
  740. default:
  741. sprintf(errstr,"case switch item missing: parse_sloom_data()\n");
  742. return(PROGRAM_ERROR);
  743. }
  744. cnt++;
  745. }
  746. if(cnt!=PRE_CMDLINE_DATACNT+1) {
  747. sprintf(errstr,"Insufficient pre-cmdline params sent from TK\n");
  748. return(DATA_ERROR);
  749. }
  750. if(true_cnt)
  751. cnt = true_cnt;
  752. *cmdlinecnt = 0;
  753. while(cnt < argc) {
  754. if((exit_status = get_tk_cmdline_word(cmdlinecnt,cmdline,argv[cnt]))<0)
  755. return(exit_status);
  756. cnt++;
  757. }
  758. return(FINISHED);
  759. }
  760. /********************************* GET_TK_CMDLINE_WORD *********************************/
  761. int get_tk_cmdline_word(int *cmdlinecnt,char ***cmdline,char *q)
  762. {
  763. if(*cmdlinecnt==0) {
  764. if((*cmdline = (char **)malloc(sizeof(char *)))==NULL) {
  765. sprintf(errstr,"INSUFFICIENT MEMORY for TK cmdline array.\n");
  766. return(MEMORY_ERROR);
  767. }
  768. } else {
  769. if((*cmdline = (char **)realloc(*cmdline,((*cmdlinecnt)+1) * sizeof(char *)))==NULL) {
  770. sprintf(errstr,"INSUFFICIENT MEMORY for TK cmdline array.\n");
  771. return(MEMORY_ERROR);
  772. }
  773. }
  774. if(((*cmdline)[*cmdlinecnt] = (char *)malloc((strlen(q) + 1) * sizeof(char)))==NULL) {
  775. sprintf(errstr,"INSUFFICIENT MEMORY for TK cmdline item %d.\n",(*cmdlinecnt)+1);
  776. return(MEMORY_ERROR);
  777. }
  778. strcpy((*cmdline)[*cmdlinecnt],q);
  779. (*cmdlinecnt)++;
  780. return(FINISHED);
  781. }
  782. /****************************** ASSIGN_FILE_DATA_STORAGE *********************************/
  783. int assign_file_data_storage(int infilecnt,dataptr dz)
  784. {
  785. int exit_status;
  786. int no_sndfile_system_files = FALSE;
  787. dz->infilecnt = infilecnt;
  788. if((exit_status = allocate_filespace(dz))<0)
  789. return(exit_status);
  790. if(no_sndfile_system_files)
  791. dz->infilecnt = 0;
  792. return(FINISHED);
  793. }
  794. /************************* redundant functions: to ensure libs compile OK *******************/
  795. int assign_process_logic(dataptr dz)
  796. {
  797. return(FINISHED);
  798. }
  799. void set_legal_infile_structure(dataptr dz)
  800. {}
  801. int set_legal_internalparam_structure(int process,int mode,aplptr ap)
  802. {
  803. return(FINISHED);
  804. }
  805. int setup_internal_arrays_and_array_pointers(dataptr dz)
  806. {
  807. return(FINISHED);
  808. }
  809. int establish_bufptrs_and_extra_buffers(dataptr dz)
  810. {
  811. return(FINISHED);
  812. }
  813. int read_special_data(char *str,dataptr dz)
  814. {
  815. return(FINISHED);
  816. }
  817. int inner_loop
  818. (int *peakscore,int *descnt,int *in_start_portion,int *least,int *pitchcnt,int windows_in_buf,dataptr dz)
  819. {
  820. return(FINISHED);
  821. }
  822. int get_process_no(char *prog_identifier_from_cmdline,dataptr dz)
  823. {
  824. return(FINISHED);
  825. }
  826. /******************************** USAGE1 ********************************/
  827. int usage1(void)
  828. {
  829. usage2("wavmedian");
  830. return(USAGE_ONLY);
  831. }
  832. /**************************** GET_THE_PROCESS_NO **********************************/
  833. int get_the_process_no(char *prog_identifier_from_cmdline,dataptr dz)
  834. {
  835. if(!strcmp(prog_identifier_from_cmdline,"wavmedian")) dz->process = WAVMEDIAN;
  836. else {
  837. sprintf(errstr,"Unknown program identification string '%s'\n",prog_identifier_from_cmdline);
  838. return(USAGE_ONLY);
  839. }
  840. return(FINISHED);
  841. }
  842. /******************************** SETUP_AND_INIT_INPUT_BRKTABLE_CONSTANTS ********************************/
  843. int setup_and_init_input_brktable_constants(dataptr dz,int brkcnt)
  844. {
  845. int n;
  846. if((dz->brk = (double **)malloc(brkcnt * sizeof(double *)))==NULL) {
  847. sprintf(errstr,"setup_and_init_input_brktable_constants(): 1\n");
  848. return(MEMORY_ERROR);
  849. }
  850. if((dz->brkptr = (double **)malloc(brkcnt * sizeof(double *)))==NULL) {
  851. sprintf(errstr,"setup_and_init_input_brktable_constants(): 6\n");
  852. return(MEMORY_ERROR);
  853. }
  854. if((dz->brksize = (int *)malloc(brkcnt * sizeof(int)))==NULL) {
  855. sprintf(errstr,"setup_and_init_input_brktable_constants(): 2\n");
  856. return(MEMORY_ERROR);
  857. }
  858. if((dz->firstval = (double *)malloc(brkcnt * sizeof(double)))==NULL) {
  859. sprintf(errstr,"setup_and_init_input_brktable_constants(): 3\n");
  860. return(MEMORY_ERROR);
  861. }
  862. if((dz->lastind = (double *)malloc(brkcnt * sizeof(double)))==NULL) {
  863. sprintf(errstr,"setup_and_init_input_brktable_constants(): 4\n");
  864. return(MEMORY_ERROR);
  865. }
  866. if((dz->lastval = (double *)malloc(brkcnt * sizeof(double)))==NULL) {
  867. sprintf(errstr,"setup_and_init_input_brktable_constants(): 5\n");
  868. return(MEMORY_ERROR);
  869. }
  870. if((dz->brkinit = (int *)malloc(brkcnt * sizeof(int)))==NULL) {
  871. sprintf(errstr,"setup_and_init_input_brktable_constants(): 7\n");
  872. return(MEMORY_ERROR);
  873. }
  874. for(n=0;n<brkcnt;n++) {
  875. dz->brk[n] = NULL;
  876. dz->brkptr[n] = NULL;
  877. dz->brkinit[n] = 0;
  878. dz->brksize[n] = 0;
  879. }
  880. return(FINISHED);
  881. }
  882. /******************************** USAGE2 ********************************/
  883. int usage2(char *str)
  884. {
  885. if(!strcmp(str,"wavmedian")) {
  886. fprintf(stderr,
  887. "USAGE:\n"
  888. "wavmedian wavmedian infile duration\n"
  889. "\n"
  890. "Find best waveset count to produce desired events duration.\n"
  891. "\n");
  892. } else
  893. fprintf(stdout,"Unknown option '%s'\n",str);
  894. return(USAGE_ONLY);
  895. }
  896. int usage3(char *str1,char *str2)
  897. {
  898. fprintf(stderr,"Insufficient parameters on command line.\n");
  899. return(USAGE_ONLY);
  900. }
  901. /*************************** FIND_WAVESET_MEDIAN ************************/
  902. int find_waveset_median(dataptr dz)
  903. {
  904. int exit_status, started_scoring, finished_scoring, bestcnt = 0, highest_score, n;
  905. int current_pos_in_buf, cnt, last_total_samps_read;
  906. int *score;
  907. int buffer_overrun, initial_phase = 0, current_buf;
  908. int group_cyclecnt = 0, lolim, hilim, start, end, len;
  909. if((dz->lparray = (int **)malloc(sizeof(int *)))==NULL) {
  910. sprintf(errstr,"INSUFFICIENT MEMORY for internal integer arrays.\n");
  911. return(MEMORY_ERROR);
  912. }
  913. if((dz->lparray[0] = (int *)malloc(1001 * sizeof(int)))==NULL) { // wavecycle cnt can go from 1 to 1000
  914. sprintf(errstr,"INSUFFICIENT MEMORY for sine table.\n");
  915. return(MEMORY_ERROR);
  916. }
  917. score = dz->lparray[0];
  918. memset((char *)dz->lparray[0],0,1000 * sizeof(int));
  919. lolim = (int)round(dz->param[0] * 0.6666 * dz->infile->srate); // Limits of band of durations "close" to desired duration
  920. hilim = (int)round(dz->param[0] * 1.5 * dz->infile->srate);
  921. started_scoring = 0;
  922. finished_scoring = 0;
  923. do {
  924. group_cyclecnt++;
  925. if(group_cyclecnt > 1000) { // Ran out of waveset-groupings to test
  926. finished_scoring = group_cyclecnt;
  927. break;
  928. }
  929. sndseekEx(dz->ifd[0],0,0);
  930. dz->total_samps_read = 0;
  931. cnt = 0;
  932. current_buf = 0;
  933. last_total_samps_read = 0;
  934. if((exit_status = read_samps(dz->sampbuf[current_buf],dz))<0)
  935. return(exit_status);
  936. if(initial_phase == 0) {
  937. if((exit_status = get_initial_phase(&initial_phase,dz))<0)
  938. return(exit_status);
  939. }
  940. current_pos_in_buf = 0; // current_pos_in_buffer
  941. do {
  942. buffer_overrun = FALSE;
  943. start = last_total_samps_read + current_pos_in_buf;
  944. exit_status = waveset_group_find(&buffer_overrun,&current_buf,initial_phase,&current_pos_in_buf,&cnt,&last_total_samps_read,group_cyclecnt,dz);
  945. end = last_total_samps_read + current_pos_in_buf;
  946. len = end - start;
  947. if(len > lolim && len < hilim) // Count number of waveset-gps of this size which lie within duration limits
  948. score[group_cyclecnt]++;
  949. } while(exit_status == CONTINUE);
  950. if(exit_status<0)
  951. return(exit_status);
  952. if(cnt==0) { // source sound too short to use wavesets of this size
  953. finished_scoring = group_cyclecnt;
  954. break;
  955. }
  956. if(started_scoring && score[group_cyclecnt] == 0) { // All wavesets now too large: abandon search here
  957. finished_scoring = group_cyclecnt;
  958. }
  959. if(score[group_cyclecnt] > 0) // Once we reach some gropuing size which works, switch on "soring_started"
  960. started_scoring = 1;
  961. } while(!finished_scoring);
  962. highest_score = 0;
  963. for(n=1;n < finished_scoring;n++) {
  964. if(score[n] > highest_score) {
  965. highest_score = score[n];
  966. bestcnt = n;
  967. }
  968. }
  969. fprintf(stdout,"KEEP: %d\n",bestcnt);
  970. fflush(stdout);
  971. return(FINISHED);
  972. }
  973. /***************************** WAVESET_GROUP_FIND *******************************/
  974. int waveset_group_find(int *buffer_overrun,int *current_buf,int initial_phase,int *current_pos,int *cnt,int *last_total_samps_read,int group_cyclecnt,dataptr dz)
  975. {
  976. int exit_status;
  977. float *b = dz->sampbuf[*current_buf];
  978. register int i = *current_pos;
  979. register int n;
  980. switch(initial_phase) {
  981. case(1):
  982. for(n=0;n<group_cyclecnt;n++) {
  983. while(b[i]>=0.0) {
  984. if(++i >= dz->ssampsread) {
  985. if((exit_status = change_buf(current_buf,buffer_overrun,&b,last_total_samps_read,dz))!=CONTINUE) {
  986. *current_pos = i;
  987. (*cnt)++;
  988. return(exit_status);
  989. }
  990. i = 0;
  991. }
  992. }
  993. while(b[i]<=0.0) {
  994. if(++i >= dz->ssampsread) {
  995. if((exit_status = change_buf(current_buf,buffer_overrun,&b,last_total_samps_read,dz))!=CONTINUE) {
  996. *current_pos = i;
  997. (*cnt)++;
  998. return(exit_status);
  999. }
  1000. i = 0;
  1001. }
  1002. }
  1003. }
  1004. break;
  1005. case(-1):
  1006. for(n=0;n<group_cyclecnt;n++) {
  1007. while(b[i]<=0.0) {
  1008. if(++i >= dz->ssampsread) {
  1009. if((exit_status = change_buf(current_buf,buffer_overrun,&b,last_total_samps_read,dz))!=CONTINUE) {
  1010. *current_pos = i;
  1011. (*cnt)++;
  1012. return(exit_status);
  1013. }
  1014. i = 0;
  1015. }
  1016. }
  1017. while(b[i]>=0.0) {
  1018. if(++i >= dz->ssampsread) {
  1019. if((exit_status = change_buf(current_buf,buffer_overrun,&b,last_total_samps_read,dz))!=CONTINUE) {
  1020. *current_pos = i;
  1021. (*cnt)++;
  1022. return(exit_status);
  1023. }
  1024. i = 0;
  1025. }
  1026. }
  1027. }
  1028. break;
  1029. }
  1030. *current_pos = i;
  1031. (*cnt)++;
  1032. return(CONTINUE);
  1033. }
  1034. /***************************** CHANGE_BUF *******************************/
  1035. int change_buf(int *current_buf,int *buffer_overrun,float **buf,int *last_total_samps_read,dataptr dz)
  1036. {
  1037. int exit_status;
  1038. if(dz->samps_left<=0)
  1039. return(FINISHED);
  1040. if(*buffer_overrun==TRUE) {
  1041. sprintf(errstr,"Buffer overflow: cycle(set) too long at %lf secs.\n",
  1042. (double)dz->total_samps_read/(double)dz->infile->srate);
  1043. return(GOAL_FAILED);
  1044. }
  1045. *buffer_overrun = TRUE;
  1046. *current_buf = !(*current_buf);
  1047. *buf = dz->sampbuf[*current_buf];
  1048. *last_total_samps_read = dz->total_samps_read;
  1049. if((exit_status = read_samps(*buf,dz))<0)
  1050. return(exit_status);
  1051. return(CONTINUE);
  1052. }
  1053. /*************************** GET_INITIAL_PHASE **********************/
  1054. int get_initial_phase(int *initial_phase,dataptr dz)
  1055. {
  1056. float *b = dz->sampbuf[0];
  1057. int current_pos_in_buf = 0;
  1058. while(b[current_pos_in_buf]==0 && current_pos_in_buf < dz->ssampsread)
  1059. current_pos_in_buf++;
  1060. if(current_pos_in_buf >= dz->ssampsread) {
  1061. sprintf(errstr,"1st buffer is ALL ZEROES: Cannot proceed.\n");
  1062. return(GOAL_FAILED);
  1063. }
  1064. if(b[current_pos_in_buf] > 0)
  1065. *initial_phase = 1;
  1066. else
  1067. *initial_phase = -1;
  1068. return(FINISHED);
  1069. }