ap_pitch.c 40 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143
  1. /*
  2. * Copyright (c) 1983-2013 Trevor Wishart and Composers Desktop Project Ltd
  3. * http://www.trevorwishart.co.uk
  4. * http://www.composersdesktop.com
  5. *
  6. This file is part of the CDP System.
  7. The CDP System is free software; you can redistribute it
  8. and/or modify it under the terms of the GNU Lesser General Public
  9. License as published by the Free Software Foundation; either
  10. version 2.1 of the License, or (at your option) any later version.
  11. The CDP System is distributed in the hope that it will be useful,
  12. but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. GNU Lesser General Public License for more details.
  15. You should have received a copy of the GNU Lesser General Public
  16. License along with the CDP System; if not, write to the Free Software
  17. Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
  18. 02111-1307 USA
  19. *
  20. */
  21. #include <stdio.h>
  22. #include <stdlib.h>
  23. #include <structures.h>
  24. #include <cdpmain.h>
  25. #include <tkglobals.h>
  26. #include <pnames.h>
  27. #include <pitch.h>
  28. #include <processno.h>
  29. #include <modeno.h>
  30. #include <globcon.h>
  31. #include <logic.h>
  32. #include <filetype.h>
  33. #include <mixxcon.h>
  34. #include <flags.h>
  35. #include <speccon.h>
  36. #include <arrays.h>
  37. #include <special.h>
  38. #include <formants.h>
  39. #include <sfsys.h>
  40. #include <osbind.h>
  41. #include <string.h>
  42. #include <math.h>
  43. #include <srates.h>
  44. #ifndef HUGE
  45. #define HUGE 3.40282347e+38F
  46. #endif
  47. /********************************************************************************************/
  48. /********************************** FORMERLY IN pconsistency.c ******************************/
  49. /********************************************************************************************/
  50. static int check_viability_and_compatibility_of_shiftp_params(dataptr dz);
  51. static int sub_check_shiftp(dataptr dz);
  52. /********************************************************************************************/
  53. /********************************** FORMERLY IN preprocess.c ********************************/
  54. /********************************************************************************************/
  55. #define SCALEFUDGE (3.0)
  56. static int tune_preprocess(dataptr dz);
  57. static int convert_params_for_tune(dataptr dz);
  58. static int pick_preprocess(dataptr dz);
  59. static int adjust_parameters_for_specpick(dataptr dz);
  60. static int mark_chosen_channels_in_bitflags(dataptr dz);
  61. static int chan_containing_partial(int *botpchan,double *lastchtop,int *chan,double partial,dataptr dz);
  62. /********************************************************************************************/
  63. /********************************** FORMERLY IN specialin.c *********************************/
  64. /********************************************************************************************/
  65. static int generate_template_frqs(char *str,int datatype,dataptr dz);
  66. static int get_input_frqs(char *str,int datatype,double **fundamentals, double **harmonics,int *infrqcnt,dataptr dz);
  67. static int generate_template(double *fundamentals, double *harmonics, int infrqcnt, dataptr dz);
  68. static int getnextfrq(double *minfrq,double *fundamentals,double *harmonics,int infrqcnt);
  69. static int chordget(char *str,dataptr dz);
  70. /***************************************************************************************/
  71. /****************************** FORMERLY IN aplinit.c **********************************/
  72. /***************************************************************************************/
  73. /***************************** ESTABLISH_BUFPTRS_AND_EXTRA_BUFFERS **************************/
  74. int establish_bufptrs_and_extra_buffers(dataptr dz)
  75. {
  76. int exit_status;
  77. int is_spec = FALSE;
  78. dz->extra_bufcnt = -1; /* ENSURE EVERY CASE HAS A PAIR OF ENTRIES !! */
  79. dz->bptrcnt = 0;
  80. dz->bufcnt = 0;
  81. switch(dz->process) {
  82. case(ALT): dz->extra_bufcnt = 0; dz->bptrcnt = 1; is_spec = TRUE; break;
  83. case(OCT): dz->extra_bufcnt = 0; dz->bptrcnt = 1; is_spec = TRUE; break;
  84. case(SHIFTP): dz->extra_bufcnt = 0; dz->bptrcnt = 1; is_spec = TRUE; break;
  85. case(TUNE): dz->extra_bufcnt = 0; dz->bptrcnt = 1; is_spec = TRUE; break;
  86. case(PICK): dz->extra_bufcnt = 0; dz->bptrcnt = 1; is_spec = TRUE; break;
  87. case(MULTRANS): dz->extra_bufcnt = 1; dz->bptrcnt = 1; is_spec = TRUE; break;
  88. case(CHORD): dz->extra_bufcnt = 1; dz->bptrcnt = 1; is_spec = TRUE; break;
  89. default:
  90. sprintf(errstr,"Unknown program type [%d] in establish_bufptrs_and_extra_buffers()\n",dz->process);
  91. return(PROGRAM_ERROR);
  92. }
  93. if(dz->extra_bufcnt < 0) {
  94. sprintf(errstr,"bufcnts have not been set: establish_bufptrs_and_extra_buffers()\n");
  95. return(PROGRAM_ERROR);
  96. }
  97. if(is_spec)
  98. return establish_spec_bufptrs_and_extra_buffers(dz);
  99. else if((dz->process==HOUSE_SPEC && dz->mode==HOUSE_CONVERT) || dz->process==INFO_DIFF) {
  100. if((exit_status = establish_spec_bufptrs_and_extra_buffers(dz))<0)
  101. return(exit_status);
  102. }
  103. return establish_groucho_bufptrs_and_extra_buffers(dz);
  104. }
  105. /***************************** SETUP_INTERNAL_ARRAYS_AND_ARRAY_POINTERS **************************/
  106. int setup_internal_arrays_and_array_pointers(dataptr dz)
  107. {
  108. int n;
  109. dz->ptr_cnt = -1; /* base constructor...process */
  110. dz->array_cnt = -1;
  111. dz->iarray_cnt = -1;
  112. dz->larray_cnt = -1;
  113. switch(dz->process) {
  114. case(ALT): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  115. case(OCT): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  116. case(SHIFTP): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  117. case(TUNE): dz->array_cnt = 0; dz->iarray_cnt =1; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  118. case(PICK): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt =1; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  119. case(MULTRANS): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  120. case(CHORD): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  121. }
  122. /*** WARNING ***
  123. ANY APPLICATION DEALING WITH A NUMLIST INPUT: MUST establish AT LEAST 1 double array: i.e. dz->array_cnt = at least 1
  124. **** WARNING ***/
  125. if(dz->array_cnt < 0 || dz->iarray_cnt < 0 || dz->larray_cnt < 0 || dz->ptr_cnt < 0 || dz->fptr_cnt < 0) {
  126. sprintf(errstr,"array_cnt not set in setup_internal_arrays_and_array_pointers()\n");
  127. return(PROGRAM_ERROR);
  128. }
  129. if(dz->array_cnt > 0) {
  130. if((dz->parray = (double **)malloc(dz->array_cnt * sizeof(double *)))==NULL) {
  131. sprintf(errstr,"INSUFFICIENT MEMORY for internal double arrays.\n");
  132. return(MEMORY_ERROR);
  133. }
  134. for(n=0;n<dz->array_cnt;n++)
  135. dz->parray[n] = NULL;
  136. }
  137. if(dz->iarray_cnt > 0) {
  138. if((dz->iparray = (int **)malloc(dz->iarray_cnt * sizeof(int *)))==NULL) {
  139. sprintf(errstr,"INSUFFICIENT MEMORY for internal int arrays.\n");
  140. return(MEMORY_ERROR);
  141. }
  142. for(n=0;n<dz->iarray_cnt;n++)
  143. dz->iparray[n] = NULL;
  144. }
  145. if(dz->larray_cnt > 0) {
  146. if((dz->lparray = (int **)malloc(dz->larray_cnt * sizeof(int *)))==NULL) {
  147. sprintf(errstr,"INSUFFICIENT MEMORY for internal long arrays.\n");
  148. return(MEMORY_ERROR);
  149. }
  150. for(n=0;n<dz->larray_cnt;n++)
  151. dz->lparray[n] = NULL;
  152. }
  153. if(dz->ptr_cnt > 0) {
  154. if((dz->ptr = (double **)malloc(dz->ptr_cnt * sizeof(double *)))==NULL) {
  155. sprintf(errstr,"INSUFFICIENT MEMORY for internal pointer arrays.\n");
  156. return(MEMORY_ERROR);
  157. }
  158. for(n=0;n<dz->ptr_cnt;n++)
  159. dz->ptr[n] = NULL;
  160. }
  161. if(dz->fptr_cnt > 0) {
  162. if((dz->fptr = (float **)malloc(dz->fptr_cnt * sizeof(float *)))==NULL) {
  163. sprintf(errstr,"INSUFFICIENT MEMORY for internal float-pointer arrays.\n");
  164. return(MEMORY_ERROR);
  165. }
  166. for(n=0;n<dz->fptr_cnt;n++)
  167. dz->fptr[n] = NULL;
  168. }
  169. return(FINISHED);
  170. }
  171. /****************************** ASSIGN_PROCESS_LOGIC *********************************/
  172. int assign_process_logic(dataptr dz)
  173. {
  174. switch(dz->process) {
  175. case(ALT): setup_process_logic(ANAL_WITH_PITCHDATA, EQUAL_ANALFILE, ANALFILE_OUT, dz); break;
  176. case(OCT): setup_process_logic(ANAL_WITH_PITCHDATA, EQUAL_ANALFILE, ANALFILE_OUT, dz); break;
  177. case(SHIFTP): setup_process_logic(ANALFILE_ONLY, EQUAL_ANALFILE, ANALFILE_OUT, dz); break;
  178. case(TUNE): setup_process_logic(ANALFILE_ONLY, EQUAL_ANALFILE, ANALFILE_OUT, dz); break;
  179. case(PICK): setup_process_logic(ANALFILE_ONLY, EQUAL_ANALFILE, ANALFILE_OUT, dz); break;
  180. case(MULTRANS): setup_process_logic(ANALFILE_ONLY, EQUAL_ANALFILE, ANALFILE_OUT, dz); break;
  181. case(CHORD): setup_process_logic(ANALFILE_ONLY, EQUAL_ANALFILE, ANALFILE_OUT, dz); break;
  182. default:
  183. sprintf(errstr,"Unknown process: assign_process_logic()\n");
  184. return(PROGRAM_ERROR);
  185. break;
  186. }
  187. if(dz->has_otherfile) {
  188. switch(dz->input_data_type) {
  189. case(ALL_FILES):
  190. case(TWO_SNDFILES):
  191. case(SNDFILE_AND_ENVFILE):
  192. case(SNDFILE_AND_BRKFILE):
  193. case(SNDFILE_AND_UNRANGED_BRKFILE):
  194. case(SNDFILE_AND_DB_BRKFILE):
  195. break;
  196. case(MANY_SNDFILES):
  197. if(dz->process==INFO_TIMELIST)
  198. break;
  199. /* fall thro */
  200. default:
  201. sprintf(errstr,"Most processes accepting files with different properties\n"
  202. "can only take 2 sound infiles.\n");
  203. return(PROGRAM_ERROR);
  204. }
  205. }
  206. return(FINISHED);
  207. }
  208. /***************************** SET_LEGAL_INFILE_STRUCTURE **************************
  209. *
  210. * Allows 2nd infile to have different props to first infile.
  211. */
  212. void set_legal_infile_structure(dataptr dz)
  213. {
  214. switch(dz->process) {
  215. default:
  216. dz->has_otherfile = FALSE;
  217. break;
  218. }
  219. }
  220. /***************************************************************************************/
  221. /****************************** FORMERLY IN internal.c *********************************/
  222. /***************************************************************************************/
  223. /****************************** SET_LEGAL_INTERNALPARAM_STRUCTURE *********************************/
  224. int set_legal_internalparam_structure(int process,int mode,aplptr ap)
  225. {
  226. int exit_status = FINISHED;
  227. switch(process) {
  228. case(ALT): return(FINISHED);
  229. case(OCT): return(FINISHED);
  230. case(SHIFTP): exit_status = set_internalparam_data("idddddd",ap); break;
  231. case(TUNE): return(FINISHED);
  232. case(PICK): exit_status = set_internalparam_data("ii",ap); break;
  233. case(MULTRANS): return(FINISHED);
  234. case(CHORD): return(FINISHED);
  235. default:
  236. sprintf(errstr,"Unknown process in set_legal_internalparam_structure()\n");
  237. return(PROGRAM_ERROR);
  238. }
  239. return(exit_status);
  240. }
  241. /********************************************************************************************/
  242. /********************************** FORMERLY IN specialin.c *********************************/
  243. /********************************************************************************************/
  244. /********************** READ_SPECIAL_DATA ************************/
  245. int read_special_data(char *str,dataptr dz)
  246. {
  247. aplptr ap = dz->application;
  248. switch(ap->special_data) {
  249. case(FRQ_OR_FRQSET):
  250. case(PITCH_OR_PITCHSET): return generate_template_frqs(str,(int)ap->special_data,dz);
  251. case(SEMIT_TRANSPOS_SET): return chordget(str,dz);
  252. default:
  253. sprintf(errstr,"Unknown special_data type: read_special_data()\n");
  254. return(PROGRAM_ERROR);
  255. }
  256. return(FINISHED); /* NOTREACHED */
  257. }
  258. /**************************** GENERATE_TEMPLATE_FRQS ****************************/
  259. int generate_template_frqs(char *str,int datatype,dataptr dz) /* 'datatype' has to be PITCH_OR_PITCHSET or FRQ_OR_FRQSET */
  260. {
  261. double *fundamentals, *harmonics;
  262. int infrqcnt;
  263. int exit_status;
  264. if((exit_status = get_input_frqs(str,datatype,&fundamentals,&harmonics,&infrqcnt,dz))<0)
  265. return(exit_status);
  266. if((exit_status = generate_template(fundamentals,harmonics,infrqcnt,dz))<0)
  267. return(exit_status);
  268. free(fundamentals);
  269. free(harmonics);
  270. return(FINISHED);
  271. }
  272. /**************************** GET_INPUT_FRQS ****************************/
  273. int get_input_frqs(char *str,int datatype,double **fundamentals, double **harmonics,int *infrqcnt,dataptr dz)
  274. {
  275. double dummy = 0.0, mididummy = 0.0;
  276. FILE *fp;
  277. int n, is_numeric = 0;
  278. int arraysize = BIGARRAY;
  279. char temp[200], *p;
  280. *infrqcnt = 0;
  281. if(!sloom) {
  282. //TW NEW CONVENTION ON numeric filenames
  283. if(!value_is_numeric(str) && file_has_invalid_startchar(str)) {
  284. sprintf(errstr,"Filename has invalid start-character [%s]\n",str);
  285. return(USER_ERROR);
  286. }
  287. if(value_is_numeric(str)) {
  288. if(sscanf(str,"%lf",&dummy)!=1) {
  289. sprintf(errstr,"Invalid frq or pitch data: get_input_frqs()\n");
  290. return(DATA_ERROR);
  291. }
  292. is_numeric = 1;
  293. }
  294. } else {
  295. if(str[0]==NUMERICVAL_MARKER) {
  296. str++;
  297. if(strlen(str)<=0 || sscanf(str,"%lf",&dummy)!=1) {
  298. sprintf(errstr,"Invalid frq or pitch data: get_input_frqs()\n");
  299. return(DATA_ERROR);
  300. }
  301. is_numeric = 1;
  302. }
  303. }
  304. if(is_numeric) {
  305. if(datatype == PITCH_OR_PITCHSET) {
  306. mididummy = dummy;
  307. dummy = miditohz(dummy);
  308. }
  309. if(dummy <= 0.0 || dummy >= dz->nyquist) {
  310. if(datatype == PITCH_OR_PITCHSET) {
  311. sprintf(errstr,"Input midi value %lf in file %s is outside frq range (>0 - %.0lf[nyquist])\n",
  312. mididummy,str,dz->nyquist);
  313. } else {
  314. sprintf(errstr,"Input frq value %lf in file %s is outside frq range (>0 - %.0lf[nyquist])\n",
  315. dummy,str,dz->nyquist);
  316. }
  317. return(USER_ERROR);
  318. }
  319. if((*fundamentals = (double *)malloc(sizeof(double)))==NULL) {
  320. sprintf(errstr,"INSUFFICIENT MEMORY to store fundamentals.\n");
  321. return(MEMORY_ERROR);
  322. }
  323. (*fundamentals)[(*infrqcnt)++] = (float)dummy;
  324. } else {
  325. if((fp = fopen(str,"r"))==NULL) {
  326. sprintf(errstr,"Cannot open file %s to read template.\n",str);
  327. return(DATA_ERROR);
  328. }
  329. if((*fundamentals = (double *)malloc(arraysize * sizeof(double)))==NULL) {
  330. sprintf(errstr,"INSUFFICIENT MEMORY to store fundamentals.\n");
  331. return(MEMORY_ERROR);
  332. }
  333. while(fgets(temp,200,fp)!=NULL) {
  334. p = temp;
  335. while(get_float_from_within_string(&p,&dummy)) {
  336. switch(datatype) {
  337. case(PITCH_OR_PITCHSET):
  338. mididummy = dummy;
  339. dummy = miditohz(dummy);
  340. /* fall thro */
  341. case(FRQ_OR_FRQSET):
  342. if(dummy <= 0.0 || dummy >= dz->nyquist) {
  343. if(datatype == PITCH_OR_PITCHSET) {
  344. sprintf(errstr,"Input midi value %lf in file %s is outside frq range (>0 - %.0lf[nyquist])\n",
  345. mididummy,str,dz->nyquist);
  346. } else {
  347. sprintf(errstr,"Input frq value %lf in file %s is outside frq range (>0 - %.0lf[nyquist])\n",
  348. dummy,str,dz->nyquist);
  349. }
  350. return(USER_ERROR);
  351. }
  352. break;
  353. }
  354. (*fundamentals)[*infrqcnt] = (float)dummy;
  355. if(++(*infrqcnt)>=arraysize) {
  356. arraysize += BIGARRAY;
  357. if((*fundamentals = (double *)realloc((char *)(*fundamentals),arraysize*sizeof(double)))==NULL) {
  358. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate fundamentals store.\n");
  359. return(MEMORY_ERROR);
  360. }
  361. }
  362. }
  363. }
  364. if(*infrqcnt==0) {
  365. sprintf(errstr,"No data found in frq template file %s\n",str);
  366. return(DATA_ERROR);
  367. }
  368. if((*fundamentals = (double *)realloc((char *)(*fundamentals),(*infrqcnt) * sizeof(double)))==NULL) {
  369. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate fundamentals store.\n");
  370. return(MEMORY_ERROR);
  371. }
  372. if(fclose(fp)<0) {
  373. fprintf(stdout,"WARNING: Failed to close input textfile %s.\n",str);
  374. fflush(stdout);
  375. }
  376. }
  377. if((*harmonics = (double *)malloc((*infrqcnt) * sizeof(double)))==NULL) {
  378. sprintf(errstr,"INSUFFICIENT MEMORY to store harmonics.\n");
  379. return(MEMORY_ERROR);
  380. }
  381. for(n=0;n<(*infrqcnt);n++)
  382. (*harmonics)[n] = (*fundamentals)[n];
  383. return(FINISHED);
  384. }
  385. /**************************** GENERATE_TEMPLATE *************************/
  386. int generate_template(double *fundamentals, double *harmonics, int infrqcnt, dataptr dz)
  387. {
  388. int exit_status;
  389. int n;
  390. double lastchtop, thischtop, thisfrq;
  391. for(n=0;n<infrqcnt;n++) {
  392. if(fundamentals[n]>=dz->nyquist) {
  393. sprintf(errstr,"Input frq %d = %lf >= nyquist[%.0lf].\n",n+1,fundamentals[n],dz->nyquist);
  394. return(DATA_ERROR);
  395. }
  396. }
  397. lastchtop = 0.0;
  398. thischtop = dz->chwidth/2.0;
  399. if((exit_status = getnextfrq(&thisfrq,fundamentals,harmonics,infrqcnt))<0)
  400. return(exit_status);
  401. if((exit_status = float_array(&(dz->frq_template),dz->clength))<0)
  402. return(exit_status);
  403. for(n=0;n<dz->clength;n++) {
  404. while(thisfrq < lastchtop) {
  405. if((exit_status = getnextfrq(&thisfrq,fundamentals,harmonics,infrqcnt))<0)
  406. return(exit_status);
  407. }
  408. if(thisfrq > thischtop)
  409. dz->frq_template[n] = (float)(-1.0);
  410. else
  411. dz->frq_template[n] = (float)thisfrq;
  412. lastchtop = thischtop;
  413. if((thischtop += dz->chwidth) > dz->nyquist)
  414. thischtop = dz->nyquist;
  415. }
  416. return(FINISHED);
  417. }
  418. /***************************** GETNEXTFRQ *****************************/
  419. int getnextfrq(double *minfrq,double *fundamentals,double *harmonics,int infrqcnt)
  420. {
  421. int minptr = 0, n;
  422. *minfrq = HUGE;
  423. for(n=0;n<infrqcnt;n++) {
  424. if(harmonics[n] < *minfrq) { /* FIND CURRENT MIN FRQ IN ARRAY harmonics[] */
  425. *minfrq = harmonics[n];
  426. minptr = n;
  427. }
  428. }
  429. harmonics[minptr] += fundamentals[minptr]; /* INCREMENT MIN VALUE TO NEXT APPROPRIATE HARMONIC */
  430. return(FINISHED);
  431. }
  432. /*************************** CHORDGET ******************************/
  433. int chordget(char *str,dataptr dz)
  434. {
  435. FILE *fp;
  436. double val;
  437. int arraysize = BIGARRAY;
  438. char temp[200], *q;
  439. if((dz->transpos = (float *)malloc(arraysize * sizeof(float)))==NULL) {
  440. sprintf(errstr,"INSUFFICIENT MEMORY for transposition array.\n");
  441. return(MEMORY_ERROR);
  442. }
  443. if(!sloom) {
  444. //TW NEW CONVENTION on numeric filenames
  445. if(!value_is_numeric(str) && file_has_invalid_startchar(str)) {
  446. sprintf(errstr,"Cannot read parameter value [%s]\n",str);
  447. return(USER_ERROR);
  448. }
  449. //TW REVISED Dec 2002
  450. if(value_is_numeric(str)) {
  451. sprintf(errstr,"This process takes chord-data in a FILE only.\n");
  452. return(DATA_ERROR);
  453. }
  454. if((fp = fopen(str,"r"))==NULL) {
  455. sprintf(errstr,"Can't open text file %s to read.\n",str);
  456. return(DATA_ERROR);
  457. }
  458. } else {
  459. if(str[0] == NUMERICVAL_MARKER) {
  460. //TW THis Check should be redundant: trapped by Sound Loom
  461. sprintf(errstr,"This process takes chord-data in a FILE only.\n");
  462. return(DATA_ERROR);
  463. } else if((fp = fopen(str,"r"))==NULL) {
  464. sprintf(errstr,"Can't open text file %s to read.\n",str);
  465. return(DATA_ERROR);
  466. }
  467. }
  468. while(fgets(temp,200,fp)==temp) {
  469. q = temp;
  470. while(get_float_from_within_string(&q,&val)) {
  471. val *= OCTAVES_PER_SEMITONE; /* CONVERT SEMITONES TO OCTAVES */
  472. val = pow(2.0,val); /* CONVERT OCTAVES TO FRQ RATIO */
  473. if(val <= MIN_TRANSPOS || val > MAX_TRANSPOS) {
  474. sprintf(errstr,"transposition out of range (frq ratio %lf to %lf)\n",
  475. LOG2(MIN_TRANSPOS) * SEMITONES_PER_OCTAVE,LOG2(MAX_TRANSPOS) * SEMITONES_PER_OCTAVE);
  476. return(DATA_ERROR);
  477. }
  478. dz->transpos[dz->itemcnt] = (float)val;
  479. if(++dz->itemcnt >= arraysize) {
  480. arraysize += BIGARRAY;
  481. if((dz->transpos = (float *)realloc((char *)dz->transpos,arraysize * sizeof(float)))==NULL) {
  482. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate transposition array.\n");
  483. return(MEMORY_ERROR);
  484. }
  485. }
  486. }
  487. }
  488. if(dz->itemcnt == 0) {
  489. sprintf(errstr,"No data in file %s\n",str);
  490. return(DATA_ERROR);
  491. }
  492. if((dz->transpos = (float *)realloc((char *)dz->transpos,dz->itemcnt * sizeof(float)))==NULL) {
  493. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate transposition array.\n");
  494. return(MEMORY_ERROR);
  495. }
  496. if(fclose(fp)<0) {
  497. fprintf(stdout,"WARNING: Failed to close input textfile %s.\n",str);
  498. fflush(stdout);
  499. }
  500. return(FINISHED);
  501. }
  502. /********************************************************************************************/
  503. /********************************** FORMERLY IN preprocess.c ********************************/
  504. /********************************************************************************************/
  505. /****************************** PARAM_PREPROCESS *********************************/
  506. int param_preprocess(dataptr dz)
  507. {
  508. int check;
  509. switch(dz->process) {
  510. case(OCT): return initialise_specenv(&check,dz);
  511. case(SHIFTP): return adjust_params_and_setup_internal_params_for_shiftp(dz);
  512. case(TUNE): return tune_preprocess(dz);
  513. case(PICK): return pick_preprocess(dz);
  514. case(ALT): case(MULTRANS): case(CHORD):
  515. return(FINISHED);
  516. default:
  517. sprintf(errstr,"PROGRAMMING PROBLEM: Unknown process in param_preprocess()\n");
  518. return(PROGRAM_ERROR);
  519. }
  520. return(FINISHED); /* NOTREACHED */
  521. }
  522. /************ ADJUST_PARAMS_AND_SETUP_INTERNAL_PARAMS_FOR_SHIFTP *************/
  523. int adjust_params_and_setup_internal_params_for_shiftp(dataptr dz)
  524. {
  525. int exit_status;
  526. double frq;
  527. frq = dz->param[SHIFTP_FFRQ] + dz->chwidth/2.0;
  528. dz->iparam[SHIFTP_FDCNO] = (int)floor(frq/dz->chwidth);
  529. dz->param[SHIFTP_S1L1] = dz->param[SHIFTP_SHF1] - 1.0;
  530. dz->param[SHIFTP_1LS1] = 1.0 - dz->param[SHIFTP_SHF1];
  531. if(dz->mode == P_SHFT_UP_AND_DN) {
  532. dz->param[SHIFTP_S2L1] = dz->param[SHIFTP_SHF2] - 1.0;
  533. dz->param[SHIFTP_1LS2] = 1.0 - dz->param[SHIFTP_SHF2];
  534. }
  535. else {
  536. dz->param[SHIFTP_S2L1] = 0.0;
  537. dz->param[SHIFTP_1LS2] = 0.0;
  538. }
  539. dz->param[SHIFTP_NS1] = dz->param[SHIFTP_SHF1];
  540. if(dz->mode == P_SHFT_UP_AND_DN)
  541. dz->param[SHIFTP_NS2] = dz->param[SHIFTP_SHF2];
  542. else
  543. dz->param[SHIFTP_NS2] = 0.0;
  544. if(dz->vflag[SHP_IS_DEPTH] && dz->brksize[SHIFTP_DEPTH]==0) {
  545. if((exit_status = reset_shiftps_according_to_depth_value(dz))<0)
  546. return(exit_status);
  547. }
  548. return(FINISHED);
  549. }
  550. /************************ RESET_SHIFTPS_ACCORDING_TO_DEPTH_VALUE ****************************/
  551. int reset_shiftps_according_to_depth_value(dataptr dz)
  552. {
  553. switch(dz->mode) {
  554. case(6):
  555. if(dz->param[SHIFTP_SHF2] > 1.0)
  556. dz->param[SHIFTP_NS2] = (dz->param[SHIFTP_S2L1] * dz->param[SHIFTP_DEPTH]) + 1.0;
  557. else
  558. dz->param[SHIFTP_NS2] = 1.0 - (dz->param[SHIFTP_1LS2] * dz->param[SHIFTP_DEPTH]);
  559. default:
  560. if(dz->param[SHIFTP_SHF1] > 1.0)
  561. dz->param[SHIFTP_NS1] = (dz->param[SHIFTP_S1L1] * dz->param[SHIFTP_DEPTH]) + 1.0;
  562. else
  563. dz->param[SHIFTP_NS1] = 1.0 - (dz->param[SHIFTP_1LS1] * dz->param[SHIFTP_DEPTH]);
  564. }
  565. return(FINISHED);
  566. }
  567. /************************** TUNE_PREPROCESS ******************************/
  568. int tune_preprocess(dataptr dz)
  569. {
  570. int exit_status;
  571. if((exit_status = convert_params_for_tune(dz))<0)
  572. return(exit_status);
  573. if((dz->iparray[TUNE_LOUD] = (int *)malloc(dz->wanted * sizeof(int)))==NULL) {
  574. sprintf(errstr,"INSUFFICIENT MEMORY for loudness array.\n");
  575. return(MEMORY_ERROR);
  576. }
  577. return setup_ring(dz);
  578. }
  579. /************ CONVERT_PARAMS_FOR_TUNE *************/
  580. int convert_params_for_tune(dataptr dz)
  581. {
  582. double *p;
  583. int n;
  584. if(dz->brksize[TUNE_CLAR]==0)
  585. dz->param[TUNE_CLAR] = 1.0 - dz->param[TUNE_CLAR];
  586. else {
  587. p = dz->brk[TUNE_CLAR] + 1;
  588. for(n = 0;n<dz->brksize[TUNE_CLAR];n++) {
  589. *p = 1.0 - *p;
  590. p += 2;
  591. }
  592. }
  593. return(FINISHED);
  594. }
  595. /************************** PICK_PREPROCESS ******************************/
  596. int pick_preprocess(dataptr dz)
  597. {
  598. int exit_status;
  599. if((exit_status = adjust_parameters_for_specpick(dz))<0)
  600. return(exit_status);
  601. if((exit_status = setup_internal_bitflags(PICK_BFLG,PICK_LONGPOW2,PICK_DIVMASK,dz))<0)
  602. return(exit_status);
  603. return mark_chosen_channels_in_bitflags(dz);
  604. }
  605. /************ ADJUST_PARAMETERS_FOR_SPECPICK *************/
  606. int adjust_parameters_for_specpick(dataptr dz)
  607. {
  608. /* Make perceived clarity grow linearly with entered val: PICK */
  609. double *p;
  610. int n;
  611. if(dz->brksize[PICK_CLAR] == 0) {
  612. dz->param[PICK_CLAR] = 1.0 - dz->param[PICK_CLAR];
  613. dz->param[PICK_CLAR] = pow(dz->param[PICK_CLAR],SCALEFUDGE);
  614. } else {
  615. p = dz->brk[PICK_CLAR] + 1;
  616. for(n=0; n < dz->brksize[PICK_CLAR]; n++) {
  617. *p = 1.0 - *p;
  618. *p = pow(*p,SCALEFUDGE);
  619. p += 2;
  620. }
  621. }
  622. return(FINISHED);
  623. }
  624. /***************************** MARK_CHOSEN_CHANNELS_IN_BITFLAGS *************/
  625. int mark_chosen_channels_in_bitflags(dataptr dz)
  626. {
  627. int exit_status;
  628. int n=1, chan;
  629. int mask;
  630. int botpchan = 0;
  631. double lastchtop = dz->chwidth/2.0;
  632. double partial = dz->param[PICK_FUND];
  633. do {
  634. if((exit_status = chan_containing_partial(&botpchan,&lastchtop,&chan,partial,dz))<0) {
  635. sprintf(errstr,"Problem with partial->channel calculation: mark_chosen_channels_in_bitflags()\n");
  636. return(PROGRAM_ERROR);
  637. }
  638. mask = 1; /* set bitflag */
  639. dz->lparray[PICK_BFLG][(chan>>dz->iparam[PICK_LONGPOW2])]
  640. |= (mask <<= (chan & dz->iparam[PICK_DIVMASK]));
  641. switch(dz->mode) {
  642. case(PIK_HARMS): n++; partial = dz->param[PICK_FUND] * (double)n; break;
  643. case(PIK_OCTS): partial = partial * 2.0; break;
  644. case(PIK_ODD_HARMS): n+=2; partial = dz->param[PICK_FUND] * (double)n; break;
  645. case(PIK_LINEAR): partial += dz->param[PICK_LIN]; break;
  646. case(PIK_DISPLACED_HARMS): n++; partial = (dz->param[PICK_FUND]
  647. * (double)n) + dz->param[PICK_LIN];
  648. break;
  649. default:
  650. sprintf(errstr,"Programing Problem: Unknown mode in mark_chosen_channels_in_bitflags()\n");
  651. return(PROGRAM_ERROR);
  652. }
  653. } while(partial < dz->nyquist);
  654. return(FINISHED);
  655. }
  656. /************************** CHAN_CONTAINING_PARTIAL *************************/
  657. int chan_containing_partial(int *botpchan,double *lastchtop,int *chan,double partial,dataptr dz)
  658. {
  659. int n;
  660. double chtop;
  661. chtop = *lastchtop;
  662. for(n=*botpchan; n<=dz->clength ;n++) {
  663. if(partial < chtop) {
  664. *botpchan = n;
  665. *lastchtop = chtop;
  666. *chan = n;
  667. return(FINISHED);
  668. }
  669. chtop += dz->chwidth;
  670. }
  671. return(GOAL_FAILED);
  672. }
  673. /********************************************************************************************/
  674. /********************************** FORMERLY IN procspec.c **********************************/
  675. /********************************************************************************************/
  676. /**************************** SPEC_PROCESS_FILE ****************************/
  677. int spec_process_file(dataptr dz)
  678. {
  679. dz->total_windows = 0;
  680. display_virtual_time(0L,dz);
  681. switch(dz->process) {
  682. case(ALT): return outer_loop(dz);
  683. case(OCT): return outer_loop(dz);
  684. case(SHIFTP): return outer_loop(dz);
  685. case(TUNE): return outer_loop(dz);
  686. case(PICK): return outer_loop(dz);
  687. case(MULTRANS): return outer_loop(dz);
  688. case(CHORD): return outer_loop(dz);
  689. default:
  690. sprintf(errstr,"Unknown process in procspec()\n");
  691. return(PROGRAM_ERROR);
  692. }
  693. return(FINISHED); /* NOTREACHED */
  694. }
  695. /**************************** INNER_LOOP ****************************/
  696. int inner_loop
  697. (int *peakscore,int *descnt,int *in_start_portion,int *least,int *pitchcnt,int windows_in_buf,dataptr dz)
  698. {
  699. int exit_status;
  700. int local_zero_set = FALSE;
  701. int wc;
  702. for(wc=0; wc<windows_in_buf; wc++) {
  703. if(dz->total_windows==0) {
  704. if((exit_status = skip_or_special_operation_on_window_zero(dz))<0)
  705. return(exit_status);
  706. if(exit_status==TRUE) {
  707. dz->flbufptr[0] += dz->wanted;
  708. dz->total_windows++;
  709. dz->time = (float)(dz->time + dz->frametime);
  710. continue;
  711. }
  712. }
  713. if((exit_status = read_values_from_all_existing_brktables((double)dz->time,dz))<0)
  714. return(exit_status);
  715. switch(dz->process) {
  716. case(ALT): exit_status = specalt(pitchcnt,dz); break;
  717. case(OCT): exit_status = specoct(dz); break;
  718. case(CHORD): exit_status = specchord(dz); break;
  719. case(MULTRANS): exit_status = specchord2(dz); break;
  720. case(PICK): exit_status = specpick(dz); break;
  721. case(SHIFTP): exit_status = specshiftp(dz); break;
  722. case(TUNE): exit_status = spectune(dz); break;
  723. default:
  724. sprintf(errstr,"unknown process in inner_loop()\n");
  725. return(PROGRAM_ERROR);
  726. }
  727. if(exit_status<0)
  728. return(exit_status);
  729. dz->flbufptr[0] += dz->wanted;
  730. dz->total_windows++;
  731. dz->time = (float)(dz->time + dz->frametime);
  732. }
  733. if(!dz->zeroset && local_zero_set==TRUE) {
  734. fprintf(stdout,"WARNING: Zero-amp spectral window(s) encountered: orig window(s) substituted.\n");
  735. fflush(stdout);
  736. dz->zeroset = TRUE;
  737. }
  738. return(FINISHED);
  739. }
  740. /***************** SKIP_OR_SPECIAL_OPERATION_ON_WINDOW_ZERO ************/
  741. int skip_or_special_operation_on_window_zero(dataptr dz)
  742. {
  743. int vc;
  744. switch(dz->process) {
  745. case(CHORD): case(OCT): case(MULTRANS):
  746. switch(dz->process) {
  747. case(CHORD):
  748. case(MULTRANS):
  749. for(vc = 0; vc < dz->wanted; vc += 2)
  750. dz->windowbuf[0][FREQ] = dz->flbufptr[0][FREQ];
  751. break;
  752. }
  753. return(TRUE);
  754. }
  755. return(FALSE);
  756. }
  757. /********************************************************************************************/
  758. /********************************** FORMERLY IN pconsistency.c ******************************/
  759. /********************************************************************************************/
  760. /****************************** CHECK_PARAM_VALIDITY_AND_CONSISTENCY *********************************/
  761. int check_param_validity_and_consistency(dataptr dz)
  762. {
  763. handle_pitch_zeros(dz);
  764. switch(dz->process) {
  765. case(SHIFTP): return check_viability_and_compatibility_of_shiftp_params(dz);
  766. }
  767. return(FINISHED);
  768. }
  769. /***************** CHECK_VIABILITY_AND_COMPATIBILITY_OF_SHIFTP_PARAMS ******************/
  770. int check_viability_and_compatibility_of_shiftp_params(dataptr dz)
  771. {
  772. int exit_status;
  773. double thistime = 0.0;
  774. if(dz->vflag[SHP_IS_DEPTH]) {
  775. if((exit_status = check_depth_vals(SHIFTP_DEPTH,dz))<0)
  776. return(exit_status);
  777. }
  778. if(dz->brksize[SHIFTP_FFRQ] || dz->brksize[SHIFTP_SHF1] || dz->brksize[SHIFTP_SHF2]) {
  779. while(thistime < dz->duration + dz->frametime) {
  780. if((exit_status = read_values_from_all_existing_brktables(thistime,dz))<0)
  781. return(exit_status);
  782. if((exit_status = sub_check_shiftp(dz))<0)
  783. return(exit_status);
  784. thistime += dz->frametime;
  785. }
  786. return(FINISHED);
  787. }
  788. return sub_check_shiftp(dz);
  789. }
  790. /*********************** SUB_CHECK_SHIFTP ***********************/
  791. int sub_check_shiftp(dataptr dz)
  792. {
  793. double frq = dz->param[SHIFTP_FFRQ] + dz->chwidth/2.0;
  794. int fdcno = (int)floor(frq/dz->chwidth);
  795. switch(dz->mode) {
  796. case(P_SHFT_UP_AND_DN):
  797. dz->param[SHIFTP_SHF1] *= OCTAVES_PER_SEMITONE;
  798. dz->param[SHIFTP_SHF1] = pow(2.0,dz->param[SHIFTP_SHF1]);
  799. dz->param[SHIFTP_SHF2] *= OCTAVES_PER_SEMITONE;
  800. dz->param[SHIFTP_SHF2] = pow(2.0,dz->param[SHIFTP_SHF2]);
  801. if(dz->param[SHIFTP_SHF1] > 1.0
  802. && round((double)(dz->clength-1)/dz->param[SHIFTP_SHF1]) < fdcno) {
  803. sprintf(errstr,"Shift above frq split is too great to work.\n");
  804. return(DATA_ERROR);
  805. }
  806. if(dz->param[SHIFTP_SHF1] <= 1.0
  807. && round((double)(dz->clength-1)*dz->param[SHIFTP_SHF1]) <= fdcno) {
  808. sprintf(errstr,"Shift above frq split is too great to work.\n");
  809. return(DATA_ERROR);
  810. }
  811. if(dz->param[SHIFTP_SHF2] > dz->param[SHIFTP_FFRQ]/SPEC_MINFRQ) {
  812. sprintf(errstr,"Shift below frq split is too great to work.\n");
  813. return(DATA_ERROR);
  814. }
  815. if(dz->param[SHIFTP_SHF2] <= 1.0
  816. && (1.0/dz->param[SHIFTP_SHF2]) >= dz->param[SHIFTP_FFRQ]/SPEC_MINFRQ) {
  817. sprintf(errstr,"Shift below frq split is too great to work.\n");
  818. return(DATA_ERROR);
  819. }
  820. break;
  821. case(P_SHFT_DN):
  822. dz->param[SHIFTP_SHF1] *= OCTAVES_PER_SEMITONE;
  823. dz->param[SHIFTP_SHF1] = pow(2.0,dz->param[SHIFTP_SHF1]);
  824. if(dz->param[SHIFTP_SHF1] > 1.0
  825. && round((double)(dz->clength-1)/dz->param[SHIFTP_SHF1]) < fdcno) {
  826. sprintf(errstr,"Shift incompatible with frqsplit.\n");
  827. return(DATA_ERROR);
  828. }
  829. if(dz->param[SHIFTP_SHF1] <= 1.0
  830. && round((double)(dz->clength-1)*dz->param[SHIFTP_SHF1]) < fdcno) {
  831. sprintf(errstr,"Shift incompatible with frqsplit.\n");
  832. return(DATA_ERROR);
  833. }
  834. break;
  835. case(P_SHFT_UP):
  836. dz->param[SHIFTP_SHF1] *= OCTAVES_PER_SEMITONE;
  837. dz->param[SHIFTP_SHF1] = pow(2.0,dz->param[SHIFTP_SHF1]);
  838. if(dz->param[SHIFTP_SHF1] > 1.0
  839. && round((double)(dz->clength-1)/dz->param[SHIFTP_SHF1]) < fdcno) {
  840. sprintf(errstr,"Shift incompatible with frqsplit.\n");
  841. return(DATA_ERROR);
  842. }
  843. if(dz->param[SHIFTP_SHF1] <= 1.0
  844. && round((double)(dz->clength-1)*dz->param[SHIFTP_SHF1]) <= fdcno) {
  845. sprintf(errstr,"Shift incompatible with frqsplit.\n");
  846. return(DATA_ERROR);
  847. }
  848. break;
  849. }
  850. return(FINISHED);
  851. }
  852. /********************************************************************************************/
  853. /********************************** FORMERLY IN buffers.c ***********************************/
  854. /********************************************************************************************/
  855. /**************************** ALLOCATE_LARGE_BUFFERS ******************************/
  856. int allocate_large_buffers(dataptr dz)
  857. {
  858. switch(dz->process) {
  859. case(ALT): case(OCT): case(SHIFTP):
  860. case(TUNE): case(PICK): case(MULTRANS):
  861. case(CHORD):
  862. return allocate_single_buffer(dz);
  863. }
  864. sprintf(errstr,"Unknown program no. in allocate_large_buffers()\n");
  865. return(PROGRAM_ERROR);
  866. }
  867. /********************************************************************************************/
  868. /********************************** FORMERLY IN cmdline.c ***********************************/
  869. /********************************************************************************************/
  870. int get_process_no(char *prog_identifier_from_cmdline,dataptr dz)
  871. {
  872. if (!strcmp(prog_identifier_from_cmdline,"altharms")) dz->process = ALT;
  873. else if(!strcmp(prog_identifier_from_cmdline,"octmove")) dz->process = OCT;
  874. else if(!strcmp(prog_identifier_from_cmdline,"transp")) dz->process = SHIFTP;
  875. else if(!strcmp(prog_identifier_from_cmdline,"tune")) dz->process = TUNE;
  876. else if(!strcmp(prog_identifier_from_cmdline,"pick")) dz->process = PICK;
  877. else if(!strcmp(prog_identifier_from_cmdline,"chord")) dz->process = MULTRANS;
  878. else if(!strcmp(prog_identifier_from_cmdline,"chordf")) dz->process = CHORD;
  879. else {
  880. sprintf(errstr,"Unknown program identification string '%s'\n",prog_identifier_from_cmdline);
  881. return(USAGE_ONLY);
  882. }
  883. //TW UPDATE
  884. return(FINISHED);
  885. }
  886. /********************************************************************************************/
  887. /********************************** FORMERLY IN usage.c *************************************/
  888. /********************************************************************************************/
  889. /******************************** USAGE1 ********************************/
  890. int usage1(void)
  891. {
  892. sprintf(errstr,
  893. "\nPITCH OPERATIONS ON A SPECTRAL FILE\n\n"
  894. "USAGE: pitch NAME (mode) infile outfile parameters: \n"
  895. "\n"
  896. "where NAME can be any one of\n"
  897. "\n"
  898. "altharms octmove transp tune pick chordf chord\n\n"
  899. "Type 'pitch altharms' for more info on pitch altharms..ETC.\n");
  900. return(USAGE_ONLY);
  901. }
  902. /******************************** USAGE2 ********************************/
  903. int usage2(char *str)
  904. {
  905. if(!strcmp(str,"altharms")) {
  906. fprintf(stdout,
  907. "pitch altharms mode infile pitchfile outfile [-x]\n"
  908. "\n"
  909. "DELETE ALTERNATE HARMONICS\n"
  910. "\n"
  911. "MODES :-\n"
  912. "1 delete odd harmonics.\n"
  913. " Usually produces octave up transposition with no formant change.\n"
  914. "2 delete even harmonics.\n"
  915. "-x alternative spectral reconstruction.\n\n"
  916. "PITCHFILE must be derived from infile\n");
  917. } else if(!strcmp(str,"octmove")) {
  918. fprintf(stdout,
  919. "pitch octmove 1-2 infile pitchfile outfile [-i] transposition\n"
  920. "pitch octmove 3 infile pitchfile outfile [-i] transposition bassboost\n"
  921. "\n"
  922. "OCTAVE TRANSPOSE WITHOUT FORMANT SHIFT\n"
  923. "\n"
  924. "MODES :-\n"
  925. "1 transpose up.\n"
  926. "2 transpose down.\n"
  927. "3 transpose down, with bass-reinforcement.\n"
  928. "\n"
  929. "PITCHFILE must be derived from infile.\n"
  930. "transposition an integer transposition-ratio: 2 is 8va, 3 is 12th etc.\n"
  931. " as in harmonic series.\n"
  932. "bassboost bass reinforcement: values >=0.0\n"
  933. "-i quicksearch for formants (less accurate).\n"
  934. "\n"
  935. "bassboost may vary over time.\n");
  936. } else if(!strcmp(str,"transp")) { /* SHIFTP */
  937. fprintf(stdout,
  938. "pitch transp 1-3 infile outfile frq_split [-ddepth]\n"
  939. "pitch transp 4-5 infile outfile frq_split transpos [-ddepth]\n"
  940. "pitch transp 6 infile outfile frq_split transpos1 transpos2 [-ddepth]\n"
  941. "\n"
  942. "SHIFT PITCH OF (PART OF) SPECTRUM\n"
  943. "\n"
  944. "MODES :-\n"
  945. "1 Octave transpose up, above freq_split.\n"
  946. "2 Octave transpose down, below freq_split.\n"
  947. "3 Octave transpose up and down.\n"
  948. "4 Pitch transpose up, above freq_split.\n"
  949. "5 Pitch transpose down, below freq_split.\n"
  950. "6 Pitch transpose up and down.\n"
  951. "\n"
  952. "frq_split is frequency above or below which transposition takes place.\n"
  953. "transpos is transposition above or below freq_split.\n"
  954. "transpos1 is transposition above freq_split. (semitones)\n"
  955. "transpos2 is transposition below freq_split. (semitones)\n"
  956. "depth transposition effect on source (from 0(no effect) to 1(full effect))\n"
  957. "\n"
  958. "depth,frq_split,transpos1 & transpos2 can vary over time.\n");
  959. } else if(!strcmp(str,"tune")) {
  960. fprintf(stdout,
  961. "pitch tune mode infile outfile pitch_template\n"
  962. " [-ffocus] [-cclarity] [-ttrace] [-bbcut] \n"
  963. "\n"
  964. "REPLACE SPECTRAL FRQS BY HARMONICS OF SPECIFIED PITCH(ES)\n"
  965. "\n"
  966. "MODES :-\n"
  967. "1 enter pitch_template data as frq (in Hz).\n"
  968. "2 enter pitch_template data as (possibly fractional) MIDI values.\n"
  969. "\n"
  970. "pitch_template a value, or a textfile containing values (as hz or midi).\n"
  971. "\n"
  972. "-f FOCUS determines degree of focusing of partial pitches onto template.\n"
  973. " (range 0-1: val or brkpnt file: default 1).\n"
  974. "-c CLARITY determines degree to which non-template partials are suppressed.\n"
  975. " (range 0-1: val or brkpnt file: default 0).\n"
  976. "-t TRACE specifies no. of (window_by_window) most prominent channels\n"
  977. " to be replaced by template frqs.\n"
  978. "-b Ignore frqs below BCUT, Bass cutoff frq.\n"
  979. "\n"
  980. "All parameters may vary over time.\n");
  981. } else if(!strcmp(str,"pick")) {
  982. fprintf(stdout,
  983. "pitch pick 1-3 infile outfile fundamental [-cclarity]\n"
  984. "pitch pick 4-5 infile outfile fundamental frqstep [-cclarity]\n"
  985. "\n"
  986. "ONLY RETAIN CHANNELS WHICH MIGHT HOLD SPECIFIED PARTIALS\n"
  987. "\n"
  988. "MODES :-\n"
  989. "1 Harmonic Series.\n"
  990. "2 Octaves.\n"
  991. "3 Odd partials of harmonic series only.\n"
  992. "4 Partials are successive linear steps (each of frqstep) from 'fundamental'.\n"
  993. "5 Add linear displacement (frqstep) to harmonic partials over fundamental.\n"
  994. "\n"
  995. "fundamental Fundamental frequency of harmonic series, (or of calculation).\n"
  996. "frqstep Frequency step to be added to another frequency.\n"
  997. "clarity extent to which data in other channels is suppressed.\n"
  998. " Range 0-1: Default 1.\n"
  999. "\n"
  1000. "clarity may vary over time.\n");
  1001. } else if(!strcmp(str,"chordf")) {
  1002. fprintf(stdout,
  1003. "pitch chordf infile outfile -fN|-pN [-i] transpose_file [-bbot] [-ttop] [-x]\n"
  1004. "\n"
  1005. "TRANSPOSED VERSIONS OF SPECTRUM SUPERIMPOSED WITHIN EXISTING SPECTRAL ENVELOPE\n"
  1006. "\n"
  1007. "-f extract spectral envelope linear-freqwise, using N chans per point.\n"
  1008. "-p extract spectral envelope linear-pitchwise, using N bands per octave.\n"
  1009. " (recommeded value 1.0)\n"
  1010. "-i quicksearch for formants (less accurate).\n"
  1011. "\n"
  1012. "transpose_file is file of (possibly fractional) semitone transposition values.\n"
  1013. "\n"
  1014. "-b BOT = bottom frq, below which data is filtered out.\n"
  1015. "-t TOP = top frq, above which data is filtered out.\n"
  1016. "-x Fuller spectrum.\n"
  1017. "\n"
  1018. "top frq and bottom frq may vary over time.\n"
  1019. "\n");
  1020. } else if(!strcmp(str,"chord")) {
  1021. fprintf(stdout,
  1022. "pitch chord infile outfile transpose_file [-bbot] [-ttop] [-x]\n"
  1023. "\n"
  1024. "TRANSPOSED VERSIONS OF SOUND SUPERIMPOSED ON ORIGINAL\n"
  1025. "\n"
  1026. "transpose_file is file of (possibly fractional) semitone transposition values.\n"
  1027. "\n"
  1028. "-t TOP = top frq, above which data is filtered out.\n"
  1029. "-b BOT = bottom frq, below which data is filtered out.\n"
  1030. "-x Fuller spectrum.\n"
  1031. "\n"
  1032. "top frq and bottom frq may vary over time.\n"
  1033. "\n");
  1034. } else
  1035. fprintf(stdout,"Unknown option '%s'\n",str);
  1036. return(USAGE_ONLY);
  1037. }
  1038. /******************************** USAGE3 ********************************/
  1039. int usage3(char *str1,char *str2)
  1040. {
  1041. sprintf(errstr,"Insufficient parameters on command line.\n");
  1042. return(USAGE_ONLY);
  1043. }