stutter.c 56 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640
  1. // HEREH
  2. // _cdprogs\stutter stutter alan_bellydancefc.wav test.wav datafile 20 1 0 0 0 1
  3. // _cdprogs\stutter stutter alan_bellydancefc.wav test.wav datafile dur segjoins silprop silmin silmax seed [-ttrans] [-aatten] [-bbias] [-mmindur] [-p]
  4. #include <stdio.h>
  5. #include <stdlib.h>
  6. #include <structures.h>
  7. #include <tkglobals.h>
  8. #include <pnames.h>
  9. #include <filetype.h>
  10. #include <processno.h>
  11. #include <modeno.h>
  12. #include <logic.h>
  13. #include <globcon.h>
  14. #include <cdpmain.h>
  15. #include <math.h>
  16. #include <mixxcon.h>
  17. #include <osbind.h>
  18. #include <standalone.h>
  19. #include <science.h>
  20. #include <ctype.h>
  21. #include <sfsys.h>
  22. #include <string.h>
  23. #include <srates.h>
  24. #ifdef unix
  25. #define round(x) lround((x))
  26. #endif
  27. #define minseglen is_flat
  28. #define maxseglen is_sharp
  29. #define segcnt ringsize
  30. #define silcnt zeroset
  31. #define silence activebuf
  32. #define smpsdur total_windows
  33. char errstr[2400];
  34. int anal_infiles = 1;
  35. int sloom = 0;
  36. int sloombatch = 0;
  37. const char* cdp_version = "6.1.0";
  38. //CDP LIB REPLACEMENTS
  39. static int check_stutter_param_validity_and_consistency(dataptr dz);
  40. static int setup_stutter_application(dataptr dz);
  41. static int parse_sloom_data(int argc,char *argv[],char ***cmdline,int *cmdlinecnt,dataptr dz);
  42. static int parse_infile_and_check_type(char **cmdline,dataptr dz);
  43. static int setup_stutter_param_ranges_and_defaults(dataptr dz);
  44. static int handle_the_outfile(int *cmdlinecnt,char ***cmdline,dataptr dz);
  45. static int setup_and_init_input_param_activity(dataptr dz,int tipc);
  46. static int setup_input_param_defaultval_stores(int tipc,aplptr ap);
  47. static int establish_application(dataptr dz);
  48. static int initialise_vflags(dataptr dz);
  49. static int setup_parameter_storage_and_constants(int storage_cnt,dataptr dz);
  50. static int initialise_is_int_and_no_brk_constants(int storage_cnt,dataptr dz);
  51. static int mark_parameter_types(dataptr dz,aplptr ap);
  52. static int assign_file_data_storage(int infilecnt,dataptr dz);
  53. static int get_tk_cmdline_word(int *cmdlinecnt,char ***cmdline,char *q);
  54. static int get_the_process_no(char *prog_identifier_from_cmdline,dataptr dz);
  55. static int setup_and_init_input_brktable_constants(dataptr dz,int brkcnt);
  56. static int stutter(dataptr dz);
  57. static int handle_the_special_data(char *str,dataptr dz);
  58. static int stutter_param_preprocess(dataptr dz);
  59. static int create_stutter_sndbufs(dataptr dz);
  60. static void rndpermm(int permlen,int *permm);
  61. static void insert(int m,int t,int permlen,int *permm);
  62. static void prefix(int m,int permlen,int *permm);
  63. static void shuflup(int k,int permlen, int *permm);
  64. static void select_silence_inserts(int *silpermm,dataptr dz);
  65. static int get_segno(int *segs_outcnt,int *permm,dataptr dz);
  66. static int insert_silence(float *obuf,double *time,int *obufpos,dataptr dz);
  67. /**************************************** MAIN *********************************************/
  68. int main(int argc,char *argv[])
  69. {
  70. int exit_status;
  71. dataptr dz = NULL;
  72. char **cmdline;
  73. int cmdlinecnt;
  74. int n;
  75. aplptr ap;
  76. int is_launched = FALSE;
  77. if(argc==2 && (strcmp(argv[1],"--version") == 0)) {
  78. fprintf(stdout,"%s\n",cdp_version);
  79. fflush(stdout);
  80. return 0;
  81. }
  82. /* CHECK FOR SOUNDLOOM */
  83. if((sloom = sound_loom_in_use(&argc,&argv)) > 1) {
  84. sloom = 0;
  85. sloombatch = 1;
  86. }
  87. if(sflinit("cdp")){
  88. sfperror("cdp: initialisation\n");
  89. return(FAILED);
  90. }
  91. /* SET UP THE PRINCIPLE DATASTRUCTURE */
  92. if((exit_status = establish_datastructure(&dz))<0) { // CDP LIB
  93. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  94. return(FAILED);
  95. }
  96. if(!sloom) {
  97. if(argc == 1) {
  98. usage1();
  99. return(FAILED);
  100. } else if(argc == 2) {
  101. usage2(argv[1]);
  102. return(FAILED);
  103. }
  104. }
  105. if(!sloom) {
  106. if((exit_status = make_initial_cmdline_check(&argc,&argv))<0) { // CDP LIB
  107. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  108. return(FAILED);
  109. }
  110. cmdline = argv;
  111. cmdlinecnt = argc;
  112. if((get_the_process_no(argv[0],dz))<0)
  113. return(FAILED);
  114. cmdline++;
  115. cmdlinecnt--;
  116. dz->maxmode = 0;
  117. // setup_particular_application =
  118. if((exit_status = setup_stutter_application(dz))<0) {
  119. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  120. return(FAILED);
  121. }
  122. if((exit_status = count_and_allocate_for_infiles(cmdlinecnt,cmdline,dz))<0) { // CDP LIB
  123. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  124. return(FAILED);
  125. }
  126. } else {
  127. //parse_TK_data() =
  128. if((exit_status = parse_sloom_data(argc,argv,&cmdline,&cmdlinecnt,dz))<0) {
  129. exit_status = print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  130. return(exit_status);
  131. }
  132. }
  133. ap = dz->application;
  134. // parse_infile_and_hone_type() =
  135. if((exit_status = parse_infile_and_check_type(cmdline,dz))<0) {
  136. exit_status = print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  137. return(FAILED);
  138. }
  139. // setup_param_ranges_and_defaults() =
  140. if((exit_status = setup_stutter_param_ranges_and_defaults(dz))<0) {
  141. exit_status = print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  142. return(FAILED);
  143. }
  144. // open_first_infile CDP LIB
  145. if((exit_status = open_first_infile(cmdline[0],dz))<0) {
  146. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  147. return(FAILED);
  148. }
  149. cmdlinecnt--;
  150. cmdline++;
  151. // handle_extra_infiles() : redundant
  152. // handle_outfile() =
  153. if((exit_status = handle_the_outfile(&cmdlinecnt,&cmdline,dz))<0) {
  154. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  155. return(FAILED);
  156. }
  157. // handle_formants() redundant
  158. // handle_formant_quiksearch() redundant
  159. // handle_special_data ....
  160. if((exit_status = handle_the_special_data(cmdline[0],dz))<0) {
  161. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  162. return(FAILED);
  163. }
  164. cmdlinecnt--;
  165. cmdline++;
  166. if((exit_status = read_parameters_and_flags(&cmdline,&cmdlinecnt,dz))<0) { // CDP LIB
  167. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  168. return(FAILED);
  169. }
  170. // check_param_validity_and_consistency....
  171. if((exit_status = check_stutter_param_validity_and_consistency(dz))<0) {
  172. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  173. return(FAILED);
  174. }
  175. //param_preprocess =
  176. if((exit_status = stutter_param_preprocess(dz))<0) {
  177. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  178. return(FAILED);
  179. }
  180. is_launched = TRUE;
  181. dz->bufcnt = dz->segcnt + 2;
  182. if((dz->sampbuf = (float **)malloc(sizeof(float *) * (dz->bufcnt+1)))==NULL) {
  183. sprintf(errstr,"INSUFFICIENT MEMORY establishing sample buffers.\n");
  184. return(MEMORY_ERROR);
  185. }
  186. if((dz->sbufptr = (float **)malloc(sizeof(float *) * dz->bufcnt))==NULL) {
  187. sprintf(errstr,"INSUFFICIENT MEMORY establishing sample buffer pointers.\n");
  188. return(MEMORY_ERROR);
  189. }
  190. for(n = 0;n <dz->bufcnt; n++)
  191. dz->sampbuf[n] = dz->sbufptr[n] = (float *)0;
  192. dz->sampbuf[n] = (float *)0;
  193. if((exit_status = create_stutter_sndbufs(dz))<0) {
  194. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  195. return(FAILED);
  196. }
  197. //spec_process_file =
  198. if((exit_status = stutter(dz))<0) {
  199. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  200. return(FAILED);
  201. }
  202. if((exit_status = complete_output(dz))<0) { // CDP LIB
  203. print_messages_and_close_sndfiles(exit_status,is_launched,dz);
  204. return(FAILED);
  205. }
  206. exit_status = print_messages_and_close_sndfiles(FINISHED,is_launched,dz); // CDP LIB
  207. free(dz);
  208. return(SUCCEEDED);
  209. }
  210. /**********************************************
  211. REPLACED CDP LIB FUNCTIONS
  212. **********************************************/
  213. /****************************** SET_PARAM_DATA *********************************/
  214. int set_param_data(aplptr ap, int special_data,int maxparamcnt,int paramcnt,char *paramlist)
  215. {
  216. ap->special_data = (char)special_data;
  217. ap->param_cnt = (char)paramcnt;
  218. ap->max_param_cnt = (char)maxparamcnt;
  219. if(ap->max_param_cnt>0) {
  220. if((ap->param_list = (char *)malloc((size_t)(ap->max_param_cnt+1)))==NULL) {
  221. sprintf(errstr,"INSUFFICIENT MEMORY: for param_list\n");
  222. return(MEMORY_ERROR);
  223. }
  224. strcpy(ap->param_list,paramlist);
  225. }
  226. return(FINISHED);
  227. }
  228. /****************************** SET_VFLGS *********************************/
  229. int set_vflgs
  230. (aplptr ap,char *optflags,int optcnt,char *optlist,char *varflags,int vflagcnt, int vparamcnt,char *varlist)
  231. {
  232. ap->option_cnt = (char) optcnt; /*RWD added cast */
  233. if(optcnt) {
  234. if((ap->option_list = (char *)malloc((size_t)(optcnt+1)))==NULL) {
  235. sprintf(errstr,"INSUFFICIENT MEMORY: for option_list\n");
  236. return(MEMORY_ERROR);
  237. }
  238. strcpy(ap->option_list,optlist);
  239. if((ap->option_flags = (char *)malloc((size_t)(optcnt+1)))==NULL) {
  240. sprintf(errstr,"INSUFFICIENT MEMORY: for option_flags\n");
  241. return(MEMORY_ERROR);
  242. }
  243. strcpy(ap->option_flags,optflags);
  244. }
  245. ap->vflag_cnt = (char) vflagcnt;
  246. ap->variant_param_cnt = (char) vparamcnt;
  247. if(vflagcnt) {
  248. if((ap->variant_list = (char *)malloc((size_t)(vflagcnt+1)))==NULL) {
  249. sprintf(errstr,"INSUFFICIENT MEMORY: for variant_list\n");
  250. return(MEMORY_ERROR);
  251. }
  252. strcpy(ap->variant_list,varlist);
  253. if((ap->variant_flags = (char *)malloc((size_t)(vflagcnt+1)))==NULL) {
  254. sprintf(errstr,"INSUFFICIENT MEMORY: for variant_flags\n");
  255. return(MEMORY_ERROR);
  256. }
  257. strcpy(ap->variant_flags,varflags);
  258. }
  259. return(FINISHED);
  260. }
  261. /***************************** APPLICATION_INIT **************************/
  262. int application_init(dataptr dz)
  263. {
  264. int exit_status;
  265. int storage_cnt;
  266. int tipc, brkcnt;
  267. aplptr ap = dz->application;
  268. if(ap->vflag_cnt>0)
  269. initialise_vflags(dz);
  270. tipc = ap->max_param_cnt + ap->option_cnt + ap->variant_param_cnt;
  271. ap->total_input_param_cnt = (char)tipc;
  272. if(tipc>0) {
  273. if((exit_status = setup_input_param_range_stores(tipc,ap))<0)
  274. return(exit_status);
  275. if((exit_status = setup_input_param_defaultval_stores(tipc,ap))<0)
  276. return(exit_status);
  277. if((exit_status = setup_and_init_input_param_activity(dz,tipc))<0)
  278. return(exit_status);
  279. }
  280. brkcnt = tipc;
  281. //THERE ARE NO INPUTFILE brktables USED IN THIS PROCESS
  282. if(brkcnt>0) {
  283. if((exit_status = setup_and_init_input_brktable_constants(dz,brkcnt))<0)
  284. return(exit_status);
  285. }
  286. if((storage_cnt = tipc + ap->internal_param_cnt)>0) {
  287. if((exit_status = setup_parameter_storage_and_constants(storage_cnt,dz))<0)
  288. return(exit_status);
  289. if((exit_status = initialise_is_int_and_no_brk_constants(storage_cnt,dz))<0)
  290. return(exit_status);
  291. }
  292. if((exit_status = mark_parameter_types(dz,ap))<0)
  293. return(exit_status);
  294. // establish_infile_constants() replaced by
  295. dz->infilecnt = 1;
  296. //establish_bufptrs_and_extra_buffers():
  297. return(FINISHED);
  298. }
  299. /********************** SETUP_PARAMETER_STORAGE_AND_CONSTANTS ********************/
  300. /* RWD mallo changed to calloc; helps debug verison run as release! */
  301. int setup_parameter_storage_and_constants(int storage_cnt,dataptr dz)
  302. {
  303. if((dz->param = (double *)calloc(storage_cnt, sizeof(double)))==NULL) {
  304. sprintf(errstr,"setup_parameter_storage_and_constants(): 1\n");
  305. return(MEMORY_ERROR);
  306. }
  307. if((dz->iparam = (int *)calloc(storage_cnt, sizeof(int) ))==NULL) {
  308. sprintf(errstr,"setup_parameter_storage_and_constants(): 2\n");
  309. return(MEMORY_ERROR);
  310. }
  311. if((dz->is_int = (char *)calloc(storage_cnt, sizeof(char)))==NULL) {
  312. sprintf(errstr,"setup_parameter_storage_and_constants(): 3\n");
  313. return(MEMORY_ERROR);
  314. }
  315. if((dz->no_brk = (char *)calloc(storage_cnt, sizeof(char)))==NULL) {
  316. sprintf(errstr,"setup_parameter_storage_and_constants(): 5\n");
  317. return(MEMORY_ERROR);
  318. }
  319. return(FINISHED);
  320. }
  321. /************** INITIALISE_IS_INT_AND_NO_BRK_CONSTANTS *****************/
  322. int initialise_is_int_and_no_brk_constants(int storage_cnt,dataptr dz)
  323. {
  324. int n;
  325. for(n=0;n<storage_cnt;n++) {
  326. dz->is_int[n] = (char)0;
  327. dz->no_brk[n] = (char)0;
  328. }
  329. return(FINISHED);
  330. }
  331. /***************************** MARK_PARAMETER_TYPES **************************/
  332. int mark_parameter_types(dataptr dz,aplptr ap)
  333. {
  334. int n, m; /* PARAMS */
  335. for(n=0;n<ap->max_param_cnt;n++) {
  336. switch(ap->param_list[n]) {
  337. case('0'): break; /* dz->is_active[n] = 0 is default */
  338. case('i'): dz->is_active[n] = (char)1; dz->is_int[n] = (char)1;dz->no_brk[n] = (char)1; break;
  339. case('I'): dz->is_active[n] = (char)1; dz->is_int[n] = (char)1; break;
  340. case('d'): dz->is_active[n] = (char)1; dz->no_brk[n] = (char)1; break;
  341. case('D'): dz->is_active[n] = (char)1; /* normal case: double val or brkpnt file */ break;
  342. default:
  343. sprintf(errstr,"Programming error: invalid parameter type in mark_parameter_types()\n");
  344. return(PROGRAM_ERROR);
  345. }
  346. } /* OPTIONS */
  347. for(n=0,m=ap->max_param_cnt;n<ap->option_cnt;n++,m++) {
  348. switch(ap->option_list[n]) {
  349. case('i'): dz->is_active[m] = (char)1; dz->is_int[m] = (char)1; dz->no_brk[m] = (char)1; break;
  350. case('I'): dz->is_active[m] = (char)1; dz->is_int[m] = (char)1; break;
  351. case('d'): dz->is_active[m] = (char)1; dz->no_brk[m] = (char)1; break;
  352. case('D'): dz->is_active[m] = (char)1; /* normal case: double val or brkpnt file */ break;
  353. default:
  354. sprintf(errstr,"Programming error: invalid option type in mark_parameter_types()\n");
  355. return(PROGRAM_ERROR);
  356. }
  357. } /* VARIANTS */
  358. for(n=0,m=ap->max_param_cnt + ap->option_cnt;n < ap->variant_param_cnt; n++, m++) {
  359. switch(ap->variant_list[n]) {
  360. case('0'): break;
  361. case('i'): dz->is_active[m] = (char)1; dz->is_int[m] = (char)1; dz->no_brk[m] = (char)1; break;
  362. case('I'): dz->is_active[m] = (char)1; dz->is_int[m] = (char)1; break;
  363. case('d'): dz->is_active[m] = (char)1; dz->no_brk[m] = (char)1; break;
  364. case('D'): dz->is_active[m] = (char)1; /* normal case: double val or brkpnt file */ break;
  365. default:
  366. sprintf(errstr,"Programming error: invalid variant type in mark_parameter_types()\n");
  367. return(PROGRAM_ERROR);
  368. }
  369. } /* INTERNAL */
  370. for(n=0,
  371. m=ap->max_param_cnt + ap->option_cnt + ap->variant_param_cnt; n<ap->internal_param_cnt; n++,m++) {
  372. switch(ap->internal_param_list[n]) {
  373. case('0'): break; /* dummy variables: variables not used: but important for internal paream numbering!! */
  374. case('i'): dz->is_int[m] = (char)1; dz->no_brk[m] = (char)1; break;
  375. case('d'): dz->no_brk[m] = (char)1; break;
  376. default:
  377. sprintf(errstr,"Programming error: invalid internal param type in mark_parameter_types()\n");
  378. return(PROGRAM_ERROR);
  379. }
  380. }
  381. return(FINISHED);
  382. }
  383. /************************ HANDLE_THE_OUTFILE *********************/
  384. int handle_the_outfile(int *cmdlinecnt,char ***cmdline,dataptr dz)
  385. {
  386. int exit_status;
  387. char *filename = (*cmdline)[0];
  388. if(filename[0]=='-' && filename[1]=='f') {
  389. dz->floatsam_output = 1;
  390. dz->true_outfile_stype = SAMP_FLOAT;
  391. filename+= 2;
  392. }
  393. if(!sloom) {
  394. if(file_has_invalid_startchar(filename) || value_is_numeric(filename)) {
  395. sprintf(errstr,"Outfile name %s has invalid start character(s) or looks too much like a number.\n",filename);
  396. return(DATA_ERROR);
  397. }
  398. }
  399. strcpy(dz->outfilename,filename);
  400. if((exit_status = create_sized_outfile(filename,dz))<0)
  401. return(exit_status);
  402. (*cmdline)++;
  403. (*cmdlinecnt)--;
  404. return(FINISHED);
  405. }
  406. /***************************** ESTABLISH_APPLICATION **************************/
  407. int establish_application(dataptr dz)
  408. {
  409. aplptr ap;
  410. if((dz->application = (aplptr)malloc(sizeof (struct applic)))==NULL) {
  411. sprintf(errstr,"establish_application()\n");
  412. return(MEMORY_ERROR);
  413. }
  414. ap = dz->application;
  415. memset((char *)ap,0,sizeof(struct applic));
  416. return(FINISHED);
  417. }
  418. /************************* INITIALISE_VFLAGS *************************/
  419. int initialise_vflags(dataptr dz)
  420. {
  421. int n;
  422. if((dz->vflag = (char *)malloc(dz->application->vflag_cnt * sizeof(char)))==NULL) {
  423. sprintf(errstr,"INSUFFICIENT MEMORY: vflag store,\n");
  424. return(MEMORY_ERROR);
  425. }
  426. for(n=0;n<dz->application->vflag_cnt;n++)
  427. dz->vflag[n] = FALSE;
  428. return FINISHED;
  429. }
  430. /************************* SETUP_INPUT_PARAM_DEFAULTVALS *************************/
  431. int setup_input_param_defaultval_stores(int tipc,aplptr ap)
  432. {
  433. int n;
  434. if((ap->default_val = (double *)malloc(tipc * sizeof(double)))==NULL) {
  435. sprintf(errstr,"INSUFFICIENT MEMORY for application default values store\n");
  436. return(MEMORY_ERROR);
  437. }
  438. for(n=0;n<tipc;n++)
  439. ap->default_val[n] = 0.0;
  440. return(FINISHED);
  441. }
  442. /***************************** SETUP_AND_INIT_INPUT_PARAM_ACTIVITY **************************/
  443. int setup_and_init_input_param_activity(dataptr dz,int tipc)
  444. {
  445. int n;
  446. if((dz->is_active = (char *)malloc((size_t)tipc))==NULL) {
  447. sprintf(errstr,"setup_and_init_input_param_activity()\n");
  448. return(MEMORY_ERROR);
  449. }
  450. for(n=0;n<tipc;n++)
  451. dz->is_active[n] = (char)0;
  452. return(FINISHED);
  453. }
  454. /************************* SETUP_STUTTER_APPLICATION *******************/
  455. int setup_stutter_application(dataptr dz)
  456. {
  457. int exit_status;
  458. aplptr ap;
  459. if((exit_status = establish_application(dz))<0) // GLOBAL
  460. return(FAILED);
  461. ap = dz->application;
  462. // SEE parstruct FOR EXPLANATION of next 2 functions
  463. if((exit_status = set_param_data(ap,MOTORDATA,6,6,"didddi"))<0)
  464. return(FAILED);
  465. if((exit_status = set_vflgs(ap,"tabm",4,"DDDd","p",1,0,"0"))<0)
  466. return(FAILED);
  467. // set_legal_infile_structure -->
  468. dz->has_otherfile = FALSE;
  469. // assign_process_logic -->
  470. dz->input_data_type = SNDFILES_ONLY;
  471. dz->process_type = UNEQUAL_SNDFILE;
  472. dz->outfiletype = SNDFILE_OUT;
  473. return application_init(dz); //GLOBAL
  474. }
  475. /************************* PARSE_INFILE_AND_CHECK_TYPE *******************/
  476. int parse_infile_and_check_type(char **cmdline,dataptr dz)
  477. {
  478. int exit_status;
  479. infileptr infile_info;
  480. if(!sloom) {
  481. if((infile_info = (infileptr)malloc(sizeof(struct filedata)))==NULL) {
  482. sprintf(errstr,"INSUFFICIENT MEMORY for infile structure to test file data.");
  483. return(MEMORY_ERROR);
  484. } else if((exit_status = cdparse(cmdline[0],infile_info))<0) {
  485. sprintf(errstr,"Failed to parse input file %s\n",cmdline[0]);
  486. return(PROGRAM_ERROR);
  487. } else if(infile_info->filetype != SNDFILE) {
  488. sprintf(errstr,"File %s is not of correct type\n",cmdline[0]);
  489. return(DATA_ERROR);
  490. } else if((exit_status = copy_parse_info_to_main_structure(infile_info,dz))<0) {
  491. sprintf(errstr,"Failed to copy file parsing information\n");
  492. return(PROGRAM_ERROR);
  493. }
  494. free(infile_info);
  495. }
  496. return(FINISHED);
  497. }
  498. /************************* SETUP_STUTTER_PARAM_RANGES_AND_DEFAULTS *******************/
  499. int setup_stutter_param_ranges_and_defaults(dataptr dz)
  500. {
  501. int exit_status;
  502. aplptr ap = dz->application;
  503. // set_param_ranges()
  504. ap->total_input_param_cnt = (char)(ap->max_param_cnt + ap->option_cnt + ap->variant_param_cnt);
  505. // NB total_input_param_cnt is > 0 !!!
  506. if((exit_status = setup_input_param_range_stores(ap->total_input_param_cnt,ap))<0)
  507. return(FAILED);
  508. // get_param_ranges()
  509. ap->lo[STUT_DUR] = 1;
  510. ap->hi[STUT_DUR] = 7200;
  511. ap->default_val[STUT_DUR] = 20;
  512. ap->lo[STUT_JOIN] = 1;
  513. ap->hi[STUT_JOIN] = STUT_MAX_JOIN;
  514. ap->default_val[STUT_JOIN] = 1;
  515. ap->lo[STUT_SIL] = 0;
  516. ap->hi[STUT_SIL] = 1;
  517. ap->default_val[STUT_SIL] = 0;
  518. ap->lo[STUT_SILMIN] = 0;
  519. ap->hi[STUT_SILMIN] = 10;
  520. ap->default_val[STUT_SILMIN] = 0.1;
  521. ap->lo[STUT_SILMAX] = 0;
  522. ap->hi[STUT_SILMAX] = 10;
  523. ap->default_val[STUT_SILMAX] = .5;
  524. ap->lo[STUT_SEED] = 0;
  525. ap->hi[STUT_SEED] = 256;
  526. ap->default_val[STUT_SEED] = 1;
  527. ap->lo[STUT_TRANS] = 0;
  528. ap->hi[STUT_TRANS] = 3;
  529. ap->default_val[STUT_TRANS] = 0;
  530. ap->lo[STUT_ATTEN] = 0;
  531. ap->hi[STUT_ATTEN] = 1;
  532. ap->default_val[STUT_ATTEN] = 0;
  533. ap->lo[STUT_BIAS] = -1.0;
  534. ap->hi[STUT_BIAS] = 1.0;
  535. ap->default_val[STUT_BIAS] = 0.0;
  536. ap->lo[STUT_MINDUR] = STUT_SPLICE + STUT_DOVE;
  537. ap->hi[STUT_MINDUR] = 250;
  538. ap->default_val[STUT_MINDUR] = STUT_MIN;
  539. dz->maxmode = 0;
  540. if(!sloom)
  541. put_default_vals_in_all_params(dz);
  542. return(FINISHED);
  543. }
  544. /********************************* PARSE_SLOOM_DATA *********************************/
  545. int parse_sloom_data(int argc,char *argv[],char ***cmdline,int *cmdlinecnt,dataptr dz)
  546. {
  547. int exit_status;
  548. int cnt = 1, infilecnt;
  549. int filesize, insams, inbrksize;
  550. double dummy;
  551. int true_cnt = 0;
  552. aplptr ap;
  553. while(cnt<=PRE_CMDLINE_DATACNT) {
  554. if(cnt > argc) {
  555. sprintf(errstr,"Insufficient data sent from TK\n");
  556. return(DATA_ERROR);
  557. }
  558. switch(cnt) {
  559. case(1):
  560. if(sscanf(argv[cnt],"%d",&dz->process)!=1) {
  561. sprintf(errstr,"Cannot read process no. sent from TK\n");
  562. return(DATA_ERROR);
  563. }
  564. break;
  565. case(2):
  566. if(sscanf(argv[cnt],"%d",&dz->mode)!=1) {
  567. sprintf(errstr,"Cannot read mode no. sent from TK\n");
  568. return(DATA_ERROR);
  569. }
  570. if(dz->mode > 0)
  571. dz->mode--;
  572. //setup_particular_application() =
  573. if((exit_status = setup_stutter_application(dz))<0)
  574. return(exit_status);
  575. ap = dz->application;
  576. break;
  577. case(3):
  578. if(sscanf(argv[cnt],"%d",&infilecnt)!=1) {
  579. sprintf(errstr,"Cannot read infilecnt sent from TK\n");
  580. return(DATA_ERROR);
  581. }
  582. if(infilecnt < 1) {
  583. true_cnt = cnt + 1;
  584. cnt = PRE_CMDLINE_DATACNT; /* force exit from loop after assign_file_data_storage */
  585. }
  586. if((exit_status = assign_file_data_storage(infilecnt,dz))<0)
  587. return(exit_status);
  588. break;
  589. case(INPUT_FILETYPE+4):
  590. if(sscanf(argv[cnt],"%d",&dz->infile->filetype)!=1) {
  591. sprintf(errstr,"Cannot read filetype sent from TK (%s)\n",argv[cnt]);
  592. return(DATA_ERROR);
  593. }
  594. break;
  595. case(INPUT_FILESIZE+4):
  596. if(sscanf(argv[cnt],"%d",&filesize)!=1) {
  597. sprintf(errstr,"Cannot read infilesize sent from TK\n");
  598. return(DATA_ERROR);
  599. }
  600. dz->insams[0] = filesize;
  601. break;
  602. case(INPUT_INSAMS+4):
  603. if(sscanf(argv[cnt],"%d",&insams)!=1) {
  604. sprintf(errstr,"Cannot read insams sent from TK\n");
  605. return(DATA_ERROR);
  606. }
  607. dz->insams[0] = insams;
  608. break;
  609. case(INPUT_SRATE+4):
  610. if(sscanf(argv[cnt],"%d",&dz->infile->srate)!=1) {
  611. sprintf(errstr,"Cannot read srate sent from TK\n");
  612. return(DATA_ERROR);
  613. }
  614. break;
  615. case(INPUT_CHANNELS+4):
  616. if(sscanf(argv[cnt],"%d",&dz->infile->channels)!=1) {
  617. sprintf(errstr,"Cannot read channels sent from TK\n");
  618. return(DATA_ERROR);
  619. }
  620. break;
  621. case(INPUT_STYPE+4):
  622. if(sscanf(argv[cnt],"%d",&dz->infile->stype)!=1) {
  623. sprintf(errstr,"Cannot read stype sent from TK\n");
  624. return(DATA_ERROR);
  625. }
  626. break;
  627. case(INPUT_ORIGSTYPE+4):
  628. if(sscanf(argv[cnt],"%d",&dz->infile->origstype)!=1) {
  629. sprintf(errstr,"Cannot read origstype sent from TK\n");
  630. return(DATA_ERROR);
  631. }
  632. break;
  633. case(INPUT_ORIGRATE+4):
  634. if(sscanf(argv[cnt],"%d",&dz->infile->origrate)!=1) {
  635. sprintf(errstr,"Cannot read origrate sent from TK\n");
  636. return(DATA_ERROR);
  637. }
  638. break;
  639. case(INPUT_MLEN+4):
  640. if(sscanf(argv[cnt],"%d",&dz->infile->Mlen)!=1) {
  641. sprintf(errstr,"Cannot read Mlen sent from TK\n");
  642. return(DATA_ERROR);
  643. }
  644. break;
  645. case(INPUT_DFAC+4):
  646. if(sscanf(argv[cnt],"%d",&dz->infile->Dfac)!=1) {
  647. sprintf(errstr,"Cannot read Dfac sent from TK\n");
  648. return(DATA_ERROR);
  649. }
  650. break;
  651. case(INPUT_ORIGCHANS+4):
  652. if(sscanf(argv[cnt],"%d",&dz->infile->origchans)!=1) {
  653. sprintf(errstr,"Cannot read origchans sent from TK\n");
  654. return(DATA_ERROR);
  655. }
  656. break;
  657. case(INPUT_SPECENVCNT+4):
  658. if(sscanf(argv[cnt],"%d",&dz->infile->specenvcnt)!=1) {
  659. sprintf(errstr,"Cannot read specenvcnt sent from TK\n");
  660. return(DATA_ERROR);
  661. }
  662. dz->specenvcnt = dz->infile->specenvcnt;
  663. break;
  664. case(INPUT_WANTED+4):
  665. if(sscanf(argv[cnt],"%d",&dz->wanted)!=1) {
  666. sprintf(errstr,"Cannot read wanted sent from TK\n");
  667. return(DATA_ERROR);
  668. }
  669. break;
  670. case(INPUT_WLENGTH+4):
  671. if(sscanf(argv[cnt],"%d",&dz->wlength)!=1) {
  672. sprintf(errstr,"Cannot read wlength sent from TK\n");
  673. return(DATA_ERROR);
  674. }
  675. break;
  676. case(INPUT_OUT_CHANS+4):
  677. if(sscanf(argv[cnt],"%d",&dz->out_chans)!=1) {
  678. sprintf(errstr,"Cannot read out_chans sent from TK\n");
  679. return(DATA_ERROR);
  680. }
  681. break;
  682. /* RWD these chanegs to samps - tk will have to deal with that! */
  683. case(INPUT_DESCRIPTOR_BYTES+4):
  684. if(sscanf(argv[cnt],"%d",&dz->descriptor_samps)!=1) {
  685. sprintf(errstr,"Cannot read descriptor_samps sent from TK\n");
  686. return(DATA_ERROR);
  687. }
  688. break;
  689. case(INPUT_IS_TRANSPOS+4):
  690. if(sscanf(argv[cnt],"%d",&dz->is_transpos)!=1) {
  691. sprintf(errstr,"Cannot read is_transpos sent from TK\n");
  692. return(DATA_ERROR);
  693. }
  694. break;
  695. case(INPUT_COULD_BE_TRANSPOS+4):
  696. if(sscanf(argv[cnt],"%d",&dz->could_be_transpos)!=1) {
  697. sprintf(errstr,"Cannot read could_be_transpos sent from TK\n");
  698. return(DATA_ERROR);
  699. }
  700. break;
  701. case(INPUT_COULD_BE_PITCH+4):
  702. if(sscanf(argv[cnt],"%d",&dz->could_be_pitch)!=1) {
  703. sprintf(errstr,"Cannot read could_be_pitch sent from TK\n");
  704. return(DATA_ERROR);
  705. }
  706. break;
  707. case(INPUT_DIFFERENT_SRATES+4):
  708. if(sscanf(argv[cnt],"%d",&dz->different_srates)!=1) {
  709. sprintf(errstr,"Cannot read different_srates sent from TK\n");
  710. return(DATA_ERROR);
  711. }
  712. break;
  713. case(INPUT_DUPLICATE_SNDS+4):
  714. if(sscanf(argv[cnt],"%d",&dz->duplicate_snds)!=1) {
  715. sprintf(errstr,"Cannot read duplicate_snds sent from TK\n");
  716. return(DATA_ERROR);
  717. }
  718. break;
  719. case(INPUT_BRKSIZE+4):
  720. if(sscanf(argv[cnt],"%d",&inbrksize)!=1) {
  721. sprintf(errstr,"Cannot read brksize sent from TK\n");
  722. return(DATA_ERROR);
  723. }
  724. if(inbrksize > 0) {
  725. switch(dz->input_data_type) {
  726. case(WORDLIST_ONLY):
  727. break;
  728. case(PITCH_AND_PITCH):
  729. case(PITCH_AND_TRANSPOS):
  730. case(TRANSPOS_AND_TRANSPOS):
  731. dz->tempsize = inbrksize;
  732. break;
  733. case(BRKFILES_ONLY):
  734. case(UNRANGED_BRKFILE_ONLY):
  735. case(DB_BRKFILES_ONLY):
  736. case(ALL_FILES):
  737. case(ANY_NUMBER_OF_ANY_FILES):
  738. if(dz->extrabrkno < 0) {
  739. sprintf(errstr,"Storage location number for brktable not established by CDP.\n");
  740. return(DATA_ERROR);
  741. }
  742. if(dz->brksize == NULL) {
  743. sprintf(errstr,"CDP has not established storage space for input brktable.\n");
  744. return(PROGRAM_ERROR);
  745. }
  746. dz->brksize[dz->extrabrkno] = inbrksize;
  747. break;
  748. default:
  749. sprintf(errstr,"TK sent brktablesize > 0 for input_data_type [%d] not using brktables.\n",
  750. dz->input_data_type);
  751. return(PROGRAM_ERROR);
  752. }
  753. break;
  754. }
  755. break;
  756. case(INPUT_NUMSIZE+4):
  757. if(sscanf(argv[cnt],"%d",&dz->numsize)!=1) {
  758. sprintf(errstr,"Cannot read numsize sent from TK\n");
  759. return(DATA_ERROR);
  760. }
  761. break;
  762. case(INPUT_LINECNT+4):
  763. if(sscanf(argv[cnt],"%d",&dz->linecnt)!=1) {
  764. sprintf(errstr,"Cannot read linecnt sent from TK\n");
  765. return(DATA_ERROR);
  766. }
  767. break;
  768. case(INPUT_ALL_WORDS+4):
  769. if(sscanf(argv[cnt],"%d",&dz->all_words)!=1) {
  770. sprintf(errstr,"Cannot read all_words sent from TK\n");
  771. return(DATA_ERROR);
  772. }
  773. break;
  774. case(INPUT_ARATE+4):
  775. if(sscanf(argv[cnt],"%f",&dz->infile->arate)!=1) {
  776. sprintf(errstr,"Cannot read arate sent from TK\n");
  777. return(DATA_ERROR);
  778. }
  779. break;
  780. case(INPUT_FRAMETIME+4):
  781. if(sscanf(argv[cnt],"%lf",&dummy)!=1) {
  782. sprintf(errstr,"Cannot read frametime sent from TK\n");
  783. return(DATA_ERROR);
  784. }
  785. dz->frametime = (float)dummy;
  786. break;
  787. case(INPUT_WINDOW_SIZE+4):
  788. if(sscanf(argv[cnt],"%f",&dz->infile->window_size)!=1) {
  789. sprintf(errstr,"Cannot read window_size sent from TK\n");
  790. return(DATA_ERROR);
  791. }
  792. break;
  793. case(INPUT_NYQUIST+4):
  794. if(sscanf(argv[cnt],"%lf",&dz->nyquist)!=1) {
  795. sprintf(errstr,"Cannot read nyquist sent from TK\n");
  796. return(DATA_ERROR);
  797. }
  798. break;
  799. case(INPUT_DURATION+4):
  800. if(sscanf(argv[cnt],"%lf",&dz->duration)!=1) {
  801. sprintf(errstr,"Cannot read duration sent from TK\n");
  802. return(DATA_ERROR);
  803. }
  804. break;
  805. case(INPUT_MINBRK+4):
  806. if(sscanf(argv[cnt],"%lf",&dz->minbrk)!=1) {
  807. sprintf(errstr,"Cannot read minbrk sent from TK\n");
  808. return(DATA_ERROR);
  809. }
  810. break;
  811. case(INPUT_MAXBRK+4):
  812. if(sscanf(argv[cnt],"%lf",&dz->maxbrk)!=1) {
  813. sprintf(errstr,"Cannot read maxbrk sent from TK\n");
  814. return(DATA_ERROR);
  815. }
  816. break;
  817. case(INPUT_MINNUM+4):
  818. if(sscanf(argv[cnt],"%lf",&dz->minnum)!=1) {
  819. sprintf(errstr,"Cannot read minnum sent from TK\n");
  820. return(DATA_ERROR);
  821. }
  822. break;
  823. case(INPUT_MAXNUM+4):
  824. if(sscanf(argv[cnt],"%lf",&dz->maxnum)!=1) {
  825. sprintf(errstr,"Cannot read maxnum sent from TK\n");
  826. return(DATA_ERROR);
  827. }
  828. break;
  829. default:
  830. sprintf(errstr,"case switch item missing: parse_sloom_data()\n");
  831. return(PROGRAM_ERROR);
  832. }
  833. cnt++;
  834. }
  835. if(cnt!=PRE_CMDLINE_DATACNT+1) {
  836. sprintf(errstr,"Insufficient pre-cmdline params sent from TK\n");
  837. return(DATA_ERROR);
  838. }
  839. if(true_cnt)
  840. cnt = true_cnt;
  841. *cmdlinecnt = 0;
  842. while(cnt < argc) {
  843. if((exit_status = get_tk_cmdline_word(cmdlinecnt,cmdline,argv[cnt]))<0)
  844. return(exit_status);
  845. cnt++;
  846. }
  847. return(FINISHED);
  848. }
  849. /********************************* GET_TK_CMDLINE_WORD *********************************/
  850. int get_tk_cmdline_word(int *cmdlinecnt,char ***cmdline,char *q)
  851. {
  852. if(*cmdlinecnt==0) {
  853. if((*cmdline = (char **)malloc(sizeof(char *)))==NULL) {
  854. sprintf(errstr,"INSUFFICIENT MEMORY for TK cmdline array.\n");
  855. return(MEMORY_ERROR);
  856. }
  857. } else {
  858. if((*cmdline = (char **)realloc(*cmdline,((*cmdlinecnt)+1) * sizeof(char *)))==NULL) {
  859. sprintf(errstr,"INSUFFICIENT MEMORY for TK cmdline array.\n");
  860. return(MEMORY_ERROR);
  861. }
  862. }
  863. if(((*cmdline)[*cmdlinecnt] = (char *)malloc((strlen(q) + 1) * sizeof(char)))==NULL) {
  864. sprintf(errstr,"INSUFFICIENT MEMORY for TK cmdline item %d.\n",(*cmdlinecnt)+1);
  865. return(MEMORY_ERROR);
  866. }
  867. strcpy((*cmdline)[*cmdlinecnt],q);
  868. (*cmdlinecnt)++;
  869. return(FINISHED);
  870. }
  871. /****************************** ASSIGN_FILE_DATA_STORAGE *********************************/
  872. int assign_file_data_storage(int infilecnt,dataptr dz)
  873. {
  874. int exit_status;
  875. int no_sndfile_system_files = FALSE;
  876. dz->infilecnt = infilecnt;
  877. if((exit_status = allocate_filespace(dz))<0)
  878. return(exit_status);
  879. if(no_sndfile_system_files)
  880. dz->infilecnt = 0;
  881. return(FINISHED);
  882. }
  883. /************************* redundant functions: to ensure libs compile OK *******************/
  884. int assign_process_logic(dataptr dz)
  885. {
  886. return(FINISHED);
  887. }
  888. void set_legal_infile_structure(dataptr dz)
  889. {}
  890. int set_legal_internalparam_structure(int process,int mode,aplptr ap)
  891. {
  892. return(FINISHED);
  893. }
  894. int setup_internal_arrays_and_array_pointers(dataptr dz)
  895. {
  896. return(FINISHED);
  897. }
  898. int establish_bufptrs_and_extra_buffers(dataptr dz)
  899. {
  900. return(FINISHED);
  901. }
  902. int read_special_data(char *str,dataptr dz)
  903. {
  904. return(FINISHED);
  905. }
  906. int inner_loop
  907. (int *peakscore,int *descnt,int *in_start_portion,int *least,int *pitchcnt,int windows_in_buf,dataptr dz)
  908. {
  909. return(FINISHED);
  910. }
  911. int get_process_no(char *prog_identifier_from_cmdline,dataptr dz)
  912. {
  913. return(FINISHED);
  914. }
  915. /******************************** USAGE1 ********************************/
  916. int usage1(void)
  917. {
  918. usage2("stutter");
  919. return(USAGE_ONLY);
  920. }
  921. /**************************** CHECK_STUTTER_PARAM_VALIDITY_AND_CONSISTENCY *****************************/
  922. int check_stutter_param_validity_and_consistency(dataptr dz)
  923. {
  924. double temp;
  925. if(dz->param[STUT_SIL] == 0.0) {
  926. if (dz->param[STUT_SILMIN] > 0.0 || dz->param[STUT_SILMAX] > 0.0) {
  927. sprintf(errstr,"ERROR: You have selected NO silence inserts.\n");
  928. return DATA_ERROR;
  929. }
  930. } else if(dz->param[STUT_SILMIN] > dz->param[STUT_SILMAX]) {
  931. fprintf(stdout,"WARNING: Min silence duration (%lf) is greater than max silence duration (%lf).\n",dz->param[STUT_SILMIN],dz->param[STUT_SILMAX]);
  932. fprintf(stdout,"WARNING: Reversing these values.\n");
  933. fflush(stdout);
  934. temp = dz->param[STUT_SILMIN];
  935. dz->param[STUT_SILMIN] = dz->param[STUT_SILMAX];
  936. dz->param[STUT_SILMAX] = temp;
  937. }
  938. return FINISHED;
  939. }
  940. /********************************************************************************************/
  941. int get_the_process_no(char *prog_identifier_from_cmdline,dataptr dz)
  942. {
  943. if(!strcmp(prog_identifier_from_cmdline,"stutter")) dz->process = STUTTER;
  944. else {
  945. sprintf(errstr,"Unknown program identification string '%s'\n",prog_identifier_from_cmdline);
  946. return(USAGE_ONLY);
  947. }
  948. return(FINISHED);
  949. }
  950. /******************************** SETUP_AND_INIT_INPUT_BRKTABLE_CONSTANTS ********************************/
  951. int setup_and_init_input_brktable_constants(dataptr dz,int brkcnt)
  952. {
  953. int n;
  954. if((dz->brk = (double **)malloc(brkcnt * sizeof(double *)))==NULL) {
  955. sprintf(errstr,"setup_and_init_input_brktable_constants(): 1\n");
  956. return(MEMORY_ERROR);
  957. }
  958. if((dz->brkptr = (double **)malloc(brkcnt * sizeof(double *)))==NULL) {
  959. sprintf(errstr,"setup_and_init_input_brktable_constants(): 6\n");
  960. return(MEMORY_ERROR);
  961. }
  962. if((dz->brksize = (int *)malloc(brkcnt * sizeof(int)))==NULL) {
  963. sprintf(errstr,"setup_and_init_input_brktable_constants(): 2\n");
  964. return(MEMORY_ERROR);
  965. }
  966. if((dz->firstval = (double *)malloc(brkcnt * sizeof(double)))==NULL) {
  967. sprintf(errstr,"setup_and_init_input_brktable_constants(): 3\n");
  968. return(MEMORY_ERROR);
  969. }
  970. if((dz->lastind = (double *)malloc(brkcnt * sizeof(double)))==NULL) {
  971. sprintf(errstr,"setup_and_init_input_brktable_constants(): 4\n");
  972. return(MEMORY_ERROR);
  973. }
  974. if((dz->lastval = (double *)malloc(brkcnt * sizeof(double)))==NULL) {
  975. sprintf(errstr,"setup_and_init_input_brktable_constants(): 5\n");
  976. return(MEMORY_ERROR);
  977. }
  978. if((dz->brkinit = (int *)malloc(brkcnt * sizeof(int)))==NULL) {
  979. sprintf(errstr,"setup_and_init_input_brktable_constants(): 7\n");
  980. return(MEMORY_ERROR);
  981. }
  982. for(n=0;n<brkcnt;n++) {
  983. dz->brk[n] = NULL;
  984. dz->brkptr[n] = NULL;
  985. dz->brkinit[n] = 0;
  986. dz->brksize[n] = 0;
  987. }
  988. return(FINISHED);
  989. }
  990. /******************************** USAGE2 ********************************/
  991. int usage2(char *str)
  992. {
  993. if(!strcmp(str,"stutter")) {
  994. fprintf(stderr,
  995. "USAGE:\n"
  996. "stutter stutter infile outfile datafile dur segjoins silprop\n"
  997. "silmin silmax seed [-ttrans] [-aatten] [-bbias] [-mmindur] [-p]\n"
  998. "\n"
  999. "Slice src (e.g. speech) into elements (e.g. words or syllables).\n"
  1000. "Cut segments from elements, always cutting from element start.\n"
  1001. "Play these in a random order (with possible intervening silence).\n"
  1002. "\n"
  1003. "DATAFILE List of times at which to slice src into elements.\n"
  1004. " Minimum timestep between times (MT) = 0.016 secs.\n"
  1005. " Times range: MT secs to (duration - MT).\n"
  1006. "DUR Duration of output.\n"
  1007. "SEGJOINS Value 1: uses the specified elements as srcs to cut.\n"
  1008. " Value 2: also use pairs-of-segments as srcs.\n"
  1009. " Value N: also use 2,3,....N joined-segments as srcs.\n"
  1010. " Where joined segs used, cuts end in the last seg joined.\n"
  1011. " Range 1 to %d.\n"
  1012. "SILPROP Silence may be inserted at joins between cut-segments.\n"
  1013. " \"silprop\" is proportion of joins to have inserted silence.\n"
  1014. " (Range 0 - 1). (Apart from none, minimum is 1 in %d)\n"
  1015. "SILMIN Minimum duration of any silences at joins.\n"
  1016. "SILMAX Maximum duration of any silences at joins.\n"
  1017. "SEED Same seed value (with all other params same)\n"
  1018. " produces identical output from any random-varying processes.\n"
  1019. "TRANS Range (semitones) of any random transposition of segments.\n"
  1020. "ATTEN Range of any random attenuation of segment level (Range 0-1).\n"
  1021. "BIAS Bias size of segments cut (Range -1 to 1). 0 = no bias.\n"
  1022. " -ve vals bias towards smaller segs: +ve vals towards larger segs.\n"
  1023. "MINDUR Minimum duration of cut segments, in mS ( >8 mS ).\n"
  1024. "-p Permute elements (all elements used before any used again).\n"
  1025. " i.e.randomly order elements, cut segs from each and play.\n"
  1026. " Then permute order, cut new segs and play, etc.\n"
  1027. " (Default: segs cut from elements taken entirely at random).\n",STUT_MAX_JOIN,STUT_SILDIV);
  1028. } else
  1029. fprintf(stdout,"Unknown option '%s'\n",str);
  1030. return(USAGE_ONLY);
  1031. }
  1032. int usage3(char *str1,char *str2)
  1033. {
  1034. fprintf(stderr,"Insufficient parameters on command line.\n");
  1035. return(USAGE_ONLY);
  1036. }
  1037. /******************************** STUTTER ********************************/
  1038. int stutter(dataptr dz)
  1039. {
  1040. int exit_status, segs_outcnt, segno, silence_cnt = 0, chans = dz->infile->channels;
  1041. float **ibuf, *sbuf, *obuf;
  1042. int *gp_startcut = dz->lparray[0], *gp_sampsread = dz->lparray[1];
  1043. double time, segdur, dsbufpos, splic, rnd, amp, trns, frac, diff, val, srate = (double)dz->infile->srate;
  1044. double *inseg = dz->parray[0];
  1045. int m, n, j, k, ch, gp_mindur, gp_splicelen, gp_cutlen, gp_cutpos, start_read, samps_to_read, gp_start, ibufpos, sbufpos, gp_sbufpos, obufpos;
  1046. int seg_groupings_cnt, next_groupings_end;
  1047. int *permm, *silpermm = NULL;
  1048. gp_splicelen = (int)round(STUT_SPLICE * MS_TO_SECS * srate);
  1049. gp_mindur = (int)round(dz->param[STUT_MINDUR] * MS_TO_SECS * srate);
  1050. if((ibuf = (float **)malloc(dz->segcnt * sizeof(float *)))==NULL) {
  1051. sprintf(errstr,"Insufficient memory to create input sound buffers.\n");
  1052. return(MEMORY_ERROR);
  1053. }
  1054. for(n=0;n<dz->segcnt;n++) { // Establish all sound buffers
  1055. ibuf[n] = dz->sampbuf[n];
  1056. memset((char *)ibuf[n],0,dz->buflen * sizeof(float));
  1057. }
  1058. sbuf = dz->sampbuf[n++];
  1059. memset((char *)sbuf,0,dz->buflen * sizeof(float));
  1060. obuf = dz->sampbuf[n];
  1061. memset((char *)obuf,0,dz->buflen * sizeof(float));
  1062. seg_groupings_cnt = dz->itemcnt + 1;
  1063. next_groupings_end = seg_groupings_cnt;
  1064. for(n=0,m=0;n < dz->segcnt;n++,m+=2) { // Cut all segments, noting their (grouped) length
  1065. start_read = (int)round(inseg[m] * srate) * chans;
  1066. if(n == dz->segcnt - 1 || (int)round(inseg[m+2] * srate) * chans == 0) {
  1067. samps_to_read = dz->insams[0] - start_read;
  1068. seg_groupings_cnt--;
  1069. next_groupings_end += seg_groupings_cnt;
  1070. }
  1071. else {
  1072. segdur = inseg[m+1] - inseg[m];
  1073. samps_to_read = (int)round(segdur * srate) * chans;
  1074. }
  1075. sndseekEx(dz->ifd[0],start_read,0);
  1076. memset((char *)ibuf[n],0,dz->buflen);
  1077. if((dz->ssampsread = fgetfbufEx(ibuf[n],samps_to_read,dz->ifd[0],0)) < 0) {
  1078. sprintf(errstr,"Can't read sample-set %d from input soundfile.\n",n+1);
  1079. return(SYSTEM_ERROR);
  1080. }
  1081. if(dz->ssampsread != samps_to_read) {
  1082. fprintf(stdout,"WARNING: Samps read (%d) not exactly as asked for (%d) for input seg %d\n",dz->ssampsread,samps_to_read,n+1);
  1083. fflush(stdout);
  1084. }
  1085. gp_sampsread[n] = dz->ssampsread/chans; // Remember gp_length of segment read
  1086. gp_start = (int)round(inseg[m] * srate); // Find gp_sample start of this segment within input file
  1087. gp_startcut[n] -= gp_start; // Find start-cut-place WITHIN cut-segment
  1088. if(n>0) { // Splice start and end of segments (except at start and end of source snd)
  1089. ibufpos = 0;
  1090. for(k=0;k<gp_splicelen;k++) {
  1091. splic = (double)k/(double)gp_splicelen;
  1092. for(ch=0;ch<chans;ch++) {
  1093. ibuf[n][ibufpos] = (float)(ibuf[n][ibufpos] * splic);
  1094. ibufpos++;
  1095. }
  1096. }
  1097. }
  1098. if(n<dz->segcnt-1) {
  1099. for(k=0,j=gp_sampsread[n] - 1;k<gp_splicelen;k++,j--) {
  1100. ibufpos = j * chans;
  1101. splic = (double)k/(double)gp_splicelen;
  1102. for(ch=0;ch<chans;ch++) {
  1103. ibuf[n][ibufpos] = (float)(ibuf[n][ibufpos] * splic);
  1104. ibufpos++;
  1105. }
  1106. }
  1107. memset((char *)(ibuf[n] + dz->ssampsread),0,(dz->buflen - dz->ssampsread) * sizeof(float));
  1108. }
  1109. } // Establish array for permuting order of segments, and possibly, occurence of silences
  1110. if((permm = (int *)malloc(dz->segcnt * sizeof(int)))==NULL) {
  1111. sprintf(errstr,"Insufficient memory to create segment-order permutation store.\n");
  1112. return(MEMORY_ERROR);
  1113. }
  1114. if(dz->param[STUT_SIL] > 0.0) { // If there are silence insertions, set up a permutation array for yes-no
  1115. if((silpermm = (int *)malloc(STUT_SILDIV * sizeof(int)))==NULL) {
  1116. sprintf(errstr,"Insufficient memory to create segment-order permutation store.\n");
  1117. return(MEMORY_ERROR);
  1118. }
  1119. }
  1120. srand(dz->iparam[STUT_SEED]); // Initialise randomisation
  1121. if(dz->vflag[STUT_PERM]) // If order of segments is to be permuted, set up first rand permutation
  1122. rndpermm(dz->segcnt,permm); // Permute order of segments
  1123. time = 0.0;
  1124. segs_outcnt = 0;
  1125. obufpos = 0;
  1126. silence_cnt = 0;
  1127. while(time < dz->param[STUT_DUR]) {
  1128. if((exit_status = read_values_from_all_existing_brktables(time,dz))<0)
  1129. return exit_status;
  1130. sbufpos = 0;
  1131. ibufpos = 0;
  1132. segno = get_segno(&segs_outcnt,permm,dz); // Select a segment
  1133. gp_cutlen = gp_sampsread[segno] - gp_startcut[segno]; // Find the cutable length (from zero or, end of prior joined segment, to end of seg)
  1134. rnd = drand48();
  1135. if(dz->param[STUT_BIAS] != 1.0) // Generate (possibly biased) random value
  1136. rnd = pow(rnd,dz->param[STUT_BIAS]);
  1137. // Make a random cut of the CUTABLE LENGTH, which is at least gp_mindur in length
  1138. gp_cutpos = (int)round((double)(gp_cutlen - gp_mindur) * rnd);
  1139. gp_cutpos += gp_mindur;
  1140. gp_cutpos += gp_startcut[segno]; // Include any prior joined-segs
  1141. amp = 1.0;
  1142. if(dz->param[STUT_ATTEN]) {
  1143. rnd = drand48() * dz->param[STUT_ATTEN];
  1144. amp -= rnd;
  1145. }
  1146. memset((char *)sbuf,0,dz->buflen * sizeof(float));
  1147. for(n=0;n < gp_cutpos ;n++) { // Copy segment to the segment buffer
  1148. for(ch=0;ch < chans;ch++) {
  1149. sbuf[sbufpos] = (float)(ibuf[segno][ibufpos] * amp);
  1150. sbufpos++;
  1151. ibufpos++;
  1152. }
  1153. }
  1154. for(n = 0,m = gp_cutpos - 1;n < gp_splicelen;n++,m--) {// Spice end of cut segment
  1155. splic = (double)n/(double)gp_splicelen;
  1156. sbufpos = m * chans;
  1157. for(ch=0;ch < chans;ch++) {
  1158. sbuf[sbufpos] = (float)(sbuf[sbufpos] * splic);
  1159. sbufpos++;
  1160. }
  1161. }
  1162. if(dz->param[STUT_TRANS]) { // If segment is to be transposed
  1163. trns = (drand48() * 2.0) - 1.0; // Range -1 t0 1
  1164. trns *= dz->param[STUT_TRANS]; // Range -TRANS to +TRANS semitones
  1165. trns = pow(2.0,trns/SEMITONES_PER_OCTAVE); // and convert to frq ratio
  1166. } else
  1167. trns = 1.0;
  1168. dsbufpos = 0.0;
  1169. while(dsbufpos<gp_cutpos) { // copy segment to output, with possible transposition
  1170. gp_sbufpos = (int)floor(dsbufpos);
  1171. frac = dsbufpos - (double)gp_sbufpos;
  1172. sbufpos = gp_sbufpos * chans;
  1173. for(ch = 0;ch<chans;ch++) {
  1174. val = sbuf[sbufpos];
  1175. diff = sbuf[sbufpos + chans] - val;
  1176. val += frac * diff;
  1177. obuf[obufpos++] = (float)val;
  1178. sbufpos++;
  1179. }
  1180. if(obufpos >= dz->buflen) { // If outbuffer fills
  1181. if((exit_status = write_samps(obuf,dz->buflen,dz))<0)
  1182. return exit_status; // Write buffer-full of sound
  1183. memset((char *)obuf,0,dz->buflen * sizeof(float));
  1184. obufpos = 0; // and reset obuffer pointer
  1185. }
  1186. dsbufpos += trns;
  1187. }
  1188. time = (double)((dz->total_samps_written + obufpos)/chans)/srate;
  1189. if(time >= dz->param[STUT_DUR]) // Check time after segment written, and if reached required duration, break
  1190. break;
  1191. if(dz->param[STUT_SIL] > 0.0) { // If there are silence insertions
  1192. if(silence_cnt >= dz->silcnt) { // If reached end of silence yes-no array
  1193. select_silence_inserts(silpermm,dz); // re-permute
  1194. silence_cnt = 0;
  1195. }
  1196. if(dz->silence[silence_cnt]) { // If this join is flagged for a silent-insert
  1197. if((exit_status = insert_silence(obuf,&time,&obufpos,dz))<0)
  1198. return exit_status; // do silent insert
  1199. }
  1200. silence_cnt++; // Advance yes-no flags array pointer
  1201. }
  1202. }
  1203. if(obufpos > 0) {
  1204. if((exit_status = write_samps(obuf,obufpos,dz))<0)
  1205. return(exit_status);
  1206. }
  1207. return FINISHED;
  1208. }
  1209. /**************************** HANDLE_THE_SPECIAL_DATA ****************************/
  1210. int handle_the_special_data(char *str,dataptr dz)
  1211. {
  1212. int done = 0;
  1213. double dummy = 0.0, lasttime;
  1214. double splicedur = MOT_SPLICE * MS_TO_SECS;
  1215. double dblsplicedur = splicedur * 2;
  1216. FILE *fp;
  1217. int cnt = 0, linecnt;
  1218. char temp[800], *p;
  1219. if((fp = fopen(str,"r"))==NULL) {
  1220. sprintf(errstr,"Cannot open file %s to read times.\n",str);
  1221. return(DATA_ERROR);
  1222. }
  1223. linecnt = 0;
  1224. lasttime = -1.0;
  1225. while(fgets(temp,200,fp)!=NULL) {
  1226. p = temp;
  1227. while(isspace(*p))
  1228. p++;
  1229. if(*p == ';' || *p == ENDOFSTR) // Allow comments in file
  1230. continue;
  1231. while(get_float_from_within_string(&p,&dummy)) {
  1232. if(cnt == 0) {
  1233. if(dummy <= dblsplicedur) {
  1234. sprintf(errstr,"Invalid time (%lf) (closer to start than 2 splicedurs = %.3lf) at line %d in file %s.\n",dummy,dblsplicedur,linecnt+1,str);
  1235. return(DATA_ERROR);
  1236. }
  1237. } else if(dummy <= lasttime + dblsplicedur) {
  1238. sprintf(errstr,"Times (%lf & %lf) not increasing by 2 splicedurs (%.3lf) line %d in file %s.\n",lasttime, dummy,dblsplicedur,linecnt,str);
  1239. return(DATA_ERROR);
  1240. } else if(dummy >= dz->duration - dblsplicedur) {
  1241. fprintf(stdout,"WARNING: Time (%lf) too near or beyond end of source-file, at line %d in file %s.\n",dummy,linecnt+1,str);
  1242. fprintf(stdout,"WARNING: Ignoring data at and after this time.\n");
  1243. fflush(stdout);
  1244. done = 1;
  1245. break;
  1246. }
  1247. lasttime = dummy;
  1248. cnt++;
  1249. }
  1250. if(done)
  1251. break;
  1252. linecnt++;
  1253. }
  1254. if(cnt == 0) {
  1255. sprintf(errstr,"No valid data found in file %s.\n",str);
  1256. return(DATA_ERROR);
  1257. }
  1258. dz->itemcnt = cnt;
  1259. if((dz->parray = (double **)malloc(2 * sizeof(double *)))==NULL) {
  1260. sprintf(errstr,"INSUFFICIENT MEMORY to create slice-time-data storage. (1)\n");
  1261. return(MEMORY_ERROR);
  1262. }
  1263. if((dz->parray[1] = (double *)malloc(dz->itemcnt * sizeof(double)))==NULL) {
  1264. sprintf(errstr,"INSUFFICIENT MEMORY to create slice-time-data storage. (2)\n");
  1265. return(MEMORY_ERROR);
  1266. }
  1267. fseek(fp,0,0);
  1268. cnt = 0;
  1269. done = 0;
  1270. while(fgets(temp,200,fp)!=NULL) {
  1271. p = temp;
  1272. while(isspace(*p))
  1273. p++;
  1274. if(*p == ';' || *p == ENDOFSTR) // Allow comments in file
  1275. continue;
  1276. while(get_float_from_within_string(&p,&dummy)) {
  1277. dz->parray[1][cnt] = dummy;
  1278. if(++cnt >= dz->itemcnt) {
  1279. done = 1;
  1280. break;
  1281. }
  1282. }
  1283. if(done)
  1284. break;
  1285. }
  1286. fclose(fp);
  1287. return FINISHED;
  1288. }
  1289. /**************************** STUTTER_PARAM_PREPROCESS *****************************/
  1290. int stutter_param_preprocess(dataptr dz)
  1291. {
  1292. double srate = (double)dz->infile->srate, segdur;
  1293. int chans = dz->infile->channels;
  1294. double *inslice = dz->parray[1], *outcuts;
  1295. int n, m, k, kk, tot, outcnt, *gp_startcut;
  1296. double overlap = (STUT_DOVE + STUT_SPLICE) * MS_TO_SECS;
  1297. int datacnt = 0;
  1298. dz->maxseglen = 0.0;
  1299. dz->minseglen = HUGE;
  1300. outcnt = (dz->itemcnt + 1) * 2; // N slices (dz->itemcnt) converted to N+1 pairs of cut-times
  1301. for(k = 0; k < dz->iparam[STUT_JOIN]; k++) { // Supplemented by others pairs, if segs are to be joined (datacnt)
  1302. datacnt += outcnt;
  1303. outcnt -= 2;
  1304. }
  1305. dz->segcnt = datacnt/2;
  1306. if(dz->iparam[STUT_JOIN] > dz->segcnt) {
  1307. sprintf(errstr,"Maximum joining of segments (%d) greater than actual number of segments (%d).\n",dz->iparam[STUT_JOIN],dz->segcnt);
  1308. return DATA_ERROR;
  1309. }
  1310. if((dz->parray[0] = (double *)malloc(datacnt * sizeof(double)))==NULL) {
  1311. sprintf(errstr,"INSUFFICIENT MEMORY to create segment-times storage.\n");
  1312. return(MEMORY_ERROR);
  1313. }
  1314. if((dz->lparray = (int **)malloc(2 * sizeof(int *)))==NULL) {
  1315. sprintf(errstr,"INSUFFICIENT MEMORY to create cut-data storage. (1)\n");
  1316. return(MEMORY_ERROR);
  1317. }
  1318. if((dz->lparray[0] = (int *)malloc(dz->segcnt * sizeof(int)))==NULL) {
  1319. sprintf(errstr,"INSUFFICIENT MEMORY to create cut-segs start and end storage.\n");
  1320. return(MEMORY_ERROR);
  1321. }
  1322. if((dz->lparray[1] = (int *)malloc(dz->segcnt * sizeof(int)))==NULL) {
  1323. sprintf(errstr,"INSUFFICIENT MEMORY to create cut-segs length storage.\n");
  1324. return(MEMORY_ERROR);
  1325. }
  1326. gp_startcut = dz->lparray[0];
  1327. outcuts = dz->parray[0]; // e.g. itemcnt = 4
  1328. outcnt = (dz->itemcnt + 1) * 2; // e.g. outcnt = (4+1)*2 = 10
  1329. tot = 0;
  1330. for(k = 0; k < dz->iparam[STUT_JOIN]; k++) {
  1331. outcuts[tot+outcnt-1] = dz->duration; // End cut is always at end of file
  1332. m = dz->itemcnt - 1;
  1333. if(m-k >= 0) {
  1334. for(n=tot+outcnt-2; m >= k; n-=2,m--) {
  1335. outcuts[n] = max(inslice[m-k] - overlap,0.0); // Ensure startcut of each segment-group is NOT before file-start
  1336. outcuts[n-1] = inslice[m] + overlap;
  1337. segdur = outcuts[n+1] - outcuts[n];
  1338. dz->maxseglen = max(dz->maxseglen,segdur);
  1339. dz->minseglen = max(dz->minseglen,segdur);
  1340. }
  1341. }
  1342. outcuts[tot] = 0.0; // Start cut is always at start of file
  1343. segdur = outcuts[tot+1] - outcuts[tot];
  1344. dz->maxseglen = max(dz->maxseglen,segdur);
  1345. dz->minseglen = max(dz->minseglen,segdur);
  1346. tot += outcnt; // Advance to end of previous perm-set written
  1347. outcnt -= 2; // Reduce the number of items to write by 1-pair
  1348. } // (pairs go from A B C D (4) -> AB BC CD (3) -> ABC BCD (2) -> ABCD (1))
  1349. // e.g.
  1350. // orig storage m= 0 1 2 3 dz->itemcnt = 4
  1351. // prog vals A B C D k = 0 (single-segs) initially
  1352. // outcnt = (4+1)*2 = 10 m-k = m-0 = 3, so 7&8 both get D
  1353. // final storage 0 1 2 3 4 5 6 7 8 9
  1354. // final vals 0 A+ -A B+ B- C+ C- D+ D- dur
  1355. // k = 1 (double-segs) initially
  1356. // outcnt = (3+1)*2 = 8 m-k = m-1 = 2 so 6getsC and 5getsD
  1357. // final storage 0 1 2 3 4 5 6 7
  1358. // final vals 0 B+ A- C+ B- D+ C- dur
  1359. // k = 2 (triple-segs) initially
  1360. // outcnt = (2+1)*2 = 6 m-k = m-2 = 1 so 4getsB and 3getsD
  1361. // final storage 0 1 2 3 4 5
  1362. // final vals 0 C+ A- D+ B- dur
  1363. // k = 3 (quad-segs) initially
  1364. // outcnt = (1+1)*2 = 4 m-k = m-3 = 0 so 2getsA and 1getsD
  1365. // final storage 0 1 2 3
  1366. // final vals 0 D+ A- dur
  1367. // k = 4 (5seg = allfile) initially
  1368. // outcnt = (0+1)*2 = 2 m-k = m-4 = -1 so loop is not triggered
  1369. // final storage 0 1
  1370. // final vals 0 dur
  1371. if(dz->minseglen < dz->param[STUT_MINDUR] * MS_TO_SECS) {
  1372. sprintf(errstr,"Smalleset cut segment (%lf mS) is shorter than min duration set (%lf mS)\n",dz->minseglen * SECS_TO_MS,dz->param[STUT_MINDUR]);
  1373. return DATA_ERROR;
  1374. }
  1375. kk = 0;
  1376. for(k = 0; k < dz->iparam[STUT_JOIN]; k++) { // when k = 0, n runs frm -1 to 3 all cuts start at seg-starts + initial cut at 0 i.e. 0 A B C D
  1377. for(n = k-1; n < dz->itemcnt; n++) { // when k = 1, n runs from 0 to 3 all cuts start 1 seg after double-seg-start i.e. A B C D
  1378. if(kk >= datacnt) { // when k = 2, n runs from 1 to 3 all cuts start 2 segs after triple-seg-start i.e. B C D
  1379. sprintf(errstr,"Unexpected array overrun, storing segment-startcut data.\n");
  1380. return PROGRAM_ERROR; // when k = 3, n runs from 2 to 3 all cuts start 3 segs after quad-seg-start i.e. C D
  1381. } // when k = 4, n runs from 3 to 3 only cut start 4 segs after quin-seg-start i.e. D
  1382. if(n < 0) // i.e. with 4 slices there are 5 segments, and this is the entire input file!!
  1383. gp_startcut[kk++] = 0;
  1384. else // This is gp_sample at which cutting can begin in this segment, in absolute gp_samples
  1385. gp_startcut[kk++] = (int)round((inslice[n] - overlap) * srate);
  1386. }
  1387. }
  1388. if(dz->param[STUT_SIL] > 0) { // If silences are to be inserted
  1389. dz->param[STUT_SIL] *= (double)STUT_SILDIV; // establish proportion of silences
  1390. dz->silcnt = (int)round(dz->param[STUT_SIL]); // and set up silence yes-no store
  1391. if((dz->silence = (int *)malloc(STUT_SILDIV * sizeof(int)))==NULL) {
  1392. sprintf(errstr,"Insufficient memory to create silence choice store.\n");
  1393. return(MEMORY_ERROR);
  1394. }
  1395. } else
  1396. dz->silcnt = 0;
  1397. if(dz->brksize[STUT_BIAS]) { // Invert the bias vals entered.
  1398. for(n=0,m=1;n<dz->brksize[STUT_BIAS];n++,m+=2) { // bias (range -1 to 1) becomes pow(10,0,bias) (range .1 to 10)
  1399. dz->brk[STUT_BIAS][m] = -dz->brk[STUT_BIAS][m]; // Biasing done by raising a linear function between 0 and 1 to a power.
  1400. dz->brk[STUT_BIAS][m] = pow(10.0,dz->brk[STUT_BIAS][m]);// So vals <0 (= < 1) produce weighting to LONGER cuts, as curve becomes fast-slow rise
  1401. } // But entered values < 0 are intend to make bias towards SHORTER cuts.
  1402. } else { // Hence we invert the values.
  1403. dz->param[STUT_BIAS] = -dz->param[STUT_BIAS];
  1404. dz->param[STUT_BIAS] = pow(10.0,dz->param[STUT_BIAS]);
  1405. }
  1406. dz->smpsdur = (int)round(dz->param[STUT_DUR] * srate) * chans;// Get total required duration in samples
  1407. return FINISHED;
  1408. }
  1409. /******************************** CREATE_STUTTER_SNDBUFS ********************************/
  1410. int create_stutter_sndbufs(dataptr dz)
  1411. {
  1412. int n, chans = dz->infile->channels;
  1413. int bigbufsize, secsize, framesize = F_SECSIZE * chans;
  1414. double srate = (double)dz->infile->srate;
  1415. dz->buflen = (int)ceil(dz->maxseglen * srate) * chans;
  1416. secsize = dz->buflen/framesize;
  1417. if(secsize * framesize != dz->buflen)
  1418. secsize++;
  1419. dz->buflen = secsize * framesize;
  1420. dz->buflen += chans; // wrap-around point
  1421. bigbufsize = (dz->buflen * dz->bufcnt) * sizeof(float);
  1422. if((dz->bigbuf = (float *)malloc(bigbufsize)) == NULL) {
  1423. sprintf(errstr,"INSUFFICIENT MEMORY to create total sound buffers.\n");
  1424. return(PROGRAM_ERROR);
  1425. }
  1426. dz->sbufptr[0] = dz->sampbuf[0] = dz->bigbuf; // 1 Inbuf for each infile
  1427. for(n=1;n < dz->bufcnt;n++) // 1 untransposed segment buf
  1428. dz->sbufptr[n] = dz->sampbuf[n] = dz->sampbuf[n-1] + dz->buflen; // 1 output buf
  1429. dz->sampbuf[n] = dz->sampbuf[n-1] + dz->buflen;
  1430. return(FINISHED);
  1431. }
  1432. /*************************** RNDPERMM ********************************/
  1433. void rndpermm(int permlen,int *permm)
  1434. {
  1435. int n, t;
  1436. for(n=0;n<permlen;n++) { /* 1 */
  1437. t = (int)(drand48() * (double)(n+1)); /* 2 */
  1438. if(t==n)
  1439. prefix(n,permlen,permm);
  1440. else
  1441. insert(n,t,permlen,permm);
  1442. }
  1443. }
  1444. /***************************** INSERT **********************************
  1445. *
  1446. * Insert the value m AFTER the T-th element in permm[pindex].
  1447. */
  1448. void insert(int m,int t,int permlen,int *permm)
  1449. {
  1450. shuflup(t+1,permlen,permm);
  1451. permm[t+1] = m;
  1452. }
  1453. /***************************** PREFIX ************************************
  1454. *
  1455. * Insert the value m at start of the permutation permm[pindex].
  1456. */
  1457. void prefix(int m,int permlen,int *permm)
  1458. {
  1459. shuflup(0,permlen,permm);
  1460. permm[0] = m;
  1461. }
  1462. /****************************** SHUFLUP ***********************************
  1463. *
  1464. * move set members in permm[pindex] upwards, starting from element k.
  1465. */
  1466. void shuflup(int k,int permlen, int *permm)
  1467. {
  1468. int n, *i;
  1469. int z = permlen - 1;
  1470. i = permm + z;
  1471. for(n = z;n > k;n--) {
  1472. *i = *(i-1);
  1473. i--;
  1474. }
  1475. }
  1476. /****************************** SELECT_SILENCE_INSERTS ***********************************/
  1477. void select_silence_inserts(int *silpermm,dataptr dz)
  1478. {
  1479. int n;
  1480. memset((char *)dz->silence,0,STUT_SILDIV); // Preset all joins to have no silence (silence-off = 0)
  1481. rndpermm(STUT_SILDIV,silpermm); // Permute order of joins
  1482. for(n=0;n < dz->silcnt;n++) // Set 1st "silcnt" items of perm to silence-on (=1)
  1483. dz->silence[silpermm[n]] = 1;
  1484. }
  1485. /****************************** GET_SEGNO ***********************************/
  1486. int get_segno(int *segs_outcnt,int *permm,dataptr dz)
  1487. {
  1488. int segno;
  1489. if(dz->vflag[STUT_PERM]) {
  1490. if(*segs_outcnt >= dz->segcnt) {
  1491. rndpermm(dz->segcnt,permm); // Permute order of segments
  1492. *segs_outcnt = 0;
  1493. }
  1494. segno = permm[*segs_outcnt];
  1495. } else // segno entirely random
  1496. segno = (int)floor(drand48() * dz->segcnt);
  1497. (*segs_outcnt)++;
  1498. return segno;
  1499. }
  1500. /****************************** INSERT_SILENCE ***********************************/
  1501. int insert_silence(float *obuf,double *time,int *obufpos,dataptr dz)
  1502. {
  1503. int exit_status, chans = dz->infile->channels;
  1504. int silsmps, endsmp, overrun;
  1505. double srate = (double)dz->infile->srate;
  1506. double silrange = dz->param[STUT_SILMAX] - dz->param[STUT_SILMIN];
  1507. silsmps = (int)round(drand48() * silrange * srate) * chans; // Generate random duration silence within specified ranges
  1508. *obufpos += silsmps;
  1509. endsmp = dz->total_samps_written + *obufpos; // Calc where this will write to, in absolute samples
  1510. if((overrun = endsmp - dz->smpsdur) > 0) // Check if this overruns required duration
  1511. *obufpos -= overrun; // and if it does, reduce the quantity of silence to write
  1512. while(*obufpos >= dz->buflen) {
  1513. if((exit_status = write_samps(obuf,dz->buflen,dz))<0) // If obuf overflows
  1514. return exit_status; // Write buffer-full of sound+silence or silence
  1515. memset((char *)obuf,0,dz->buflen * sizeof(float));
  1516. *obufpos -= dz->buflen; // and reset obuf pointer
  1517. } // Then recalc endtime
  1518. *time = (double)((dz->total_samps_written + *obufpos)/chans)/srate;
  1519. return FINISHED;
  1520. }