ap_repitch.c 82 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179
  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 <repitch.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. #include <pvoc.h>
  45. //TW UPDATES
  46. #include <vowels.h>
  47. #include <ctype.h>
  48. #define round(x) lround((x))
  49. /********************************************************************************************/
  50. /********************************** FORMERLY IN pconsistency.c ******************************/
  51. /********************************************************************************************/
  52. static int check_consistency_of_pitch_params(dataptr dz);
  53. static int check_consistency_of_track_params(dataptr dz);
  54. static void establish_datareduction(int k,dataptr dz);
  55. static int check_compatibility_pinvert_params(dataptr dz);
  56. static int check_validity_of_prandomise_params(dataptr dz);
  57. static int check_consistency_of_pcut_params(dataptr dz);
  58. static int check_compatibility_of_pfix_smoothing_flags(dataptr dz);
  59. static int check_for_valid_transposition_ratios(double,double,dataptr);
  60. /********************************************************************************************/
  61. /********************************** FORMERLY IN preprocess.c ********************************/
  62. /********************************************************************************************/
  63. static int specpitch_preprocess(dataptr dz);
  64. static int adjust_parameters_for_specpitch(dataptr dz);
  65. static int establish_internal_arrays_for_pitchwork(dataptr dz);
  66. static int establish_arrays_for_pitchwork(dataptr dz);
  67. static int track_preprocess(dataptr dz);
  68. static int convert_track_params(dataptr dz);
  69. static int setup_internal_params_and_arrays_for_track(dataptr dz);
  70. static int papprox_preprocess(dataptr dz);
  71. static int pexag_preprocess(dataptr dz);
  72. static int pinvert_preprocess(dataptr dz);
  73. static int pquantise_preprocess(dataptr dz);
  74. static int adjust_params_and_setup_internal_params_for_prandomise(dataptr dz);
  75. static int adjust_params_and_setup_internal_params_for_psmooth(dataptr dz);
  76. static int adjust_params_for_ptranspose(dataptr dz);
  77. static int pvibrato_preprocess(dataptr dz);
  78. static int pfix_preprocess(dataptr dz);
  79. static int repitchb_preprocess(dataptr dz);
  80. /********************************************************************************************/
  81. /********************************** FORMERLY IN specialin.c *********************************/
  82. /********************************************************************************************/
  83. static int get_transposition_value(double val,int datatype,dataptr dz);
  84. static int convert_constant_to_transposition_table(double val,dataptr dz);
  85. static int getsize_and_getdata_from_transpos_brkfile
  86. (char *filename,double minval, double maxval,int which_type, dataptr dz);
  87. static int read_pquantise_set(char *filename,dataptr dz);
  88. static int sort_quantising_set(dataptr dz);
  89. static int generate_octave_duplicates(dataptr dz);
  90. static int eliminate_duplicates_in_quantising_set(dataptr dz);
  91. static int read_interval_mapping(char *str,dataptr dz);
  92. static int get_mapping(char *filename,dataptr dz);
  93. static int sort_mapping(dataptr dz);
  94. static int get_and_count_data_from_textfile(char *filename,double **brktable,int *brksize);
  95. static int get_and_count_timedata_from_textfile(char *filename,int **brktable1,int **brktable2,int *brksize,dataptr dz);
  96. //TW UPDATES
  97. static int get_the_pitches(char *filename,double **times,double **pitch,int *pcnt);
  98. static int get_pitch(char *str,double *pitch);
  99. /***************************************************************************************/
  100. /****************************** FORMERLY IN aplinit.c **********************************/
  101. /***************************************************************************************/
  102. /***************************** ESTABLISH_BUFPTRS_AND_EXTRA_BUFFERS **************************/
  103. int establish_bufptrs_and_extra_buffers(dataptr dz)
  104. {
  105. dz->extra_bufcnt = -1; /* ENSURE EVERY CASE HAS A PAIR OF ENTRIES !! */
  106. dz->bptrcnt = 0;
  107. dz->bufcnt = 0;
  108. switch(dz->process) {
  109. case(PITCH): dz->extra_bufcnt = 3; dz->bptrcnt = 2; break;
  110. case(TRACK): dz->extra_bufcnt = 3; dz->bptrcnt = 2; break;
  111. case(P_APPROX): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  112. case(P_EXAG): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  113. case(P_INVERT): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  114. case(P_QUANTISE): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  115. case(P_RANDOMISE): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  116. case(P_SMOOTH): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  117. case(P_TRANSPOSE): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  118. case(P_VIBRATO): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  119. case(P_CUT): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  120. case(P_FIX): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  121. case(REPITCH): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  122. case(REPITCHB): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  123. case(TRNSP): dz->extra_bufcnt = 1; dz->bptrcnt = 1; break;
  124. case(TRNSF): dz->extra_bufcnt = 1; dz->bptrcnt = 1; break;
  125. //TW UPDATES
  126. case(P_SYNTH): dz->extra_bufcnt = 0; dz->bptrcnt = 2; break;
  127. case(P_VOWELS): dz->extra_bufcnt = 0; dz->bptrcnt = 2; break;
  128. case(P_GEN): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  129. case(P_INTERP): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  130. case(P_INSERT): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  131. case(P_SINSERT): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  132. case(P_PTOSIL): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  133. case(P_NTOSIL): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  134. case(ANALENV): dz->extra_bufcnt = 0; dz->bptrcnt = 4; break;
  135. case(P_BINTOBRK): dz->extra_bufcnt = 0; dz->bptrcnt = 0; break;
  136. default:
  137. sprintf(errstr,"Unknown program type [%d] in establish_bufptrs_and_extra_buffers()\n",dz->process);
  138. return(PROGRAM_ERROR);
  139. }
  140. if(dz->extra_bufcnt < 0) {
  141. sprintf(errstr,"bufcnts have not been set: establish_bufptrs_and_extra_buffers()\n");
  142. return(PROGRAM_ERROR);
  143. }
  144. return establish_spec_bufptrs_and_extra_buffers(dz);
  145. }
  146. /***************************** SETUP_INTERNAL_ARRAYS_AND_ARRAY_POINTERS **************************/
  147. int setup_internal_arrays_and_array_pointers(dataptr dz)
  148. {
  149. int n;
  150. dz->ptr_cnt = -1; /* base constructor...process */
  151. dz->array_cnt = -1;
  152. dz->iarray_cnt = -1;
  153. dz->larray_cnt = -1;
  154. switch(dz->process) {
  155. case(PITCH): dz->array_cnt =2; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  156. case(TRACK): dz->array_cnt =2; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  157. case(P_APPROX): dz->array_cnt =1; dz->iarray_cnt =1; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  158. case(P_EXAG): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  159. case(P_INVERT): dz->array_cnt =1; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  160. case(P_QUANTISE): dz->array_cnt =1; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  161. case(P_RANDOMISE):dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  162. case(P_SMOOTH): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  163. case(P_TRANSPOSE):dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  164. case(P_VIBRATO): dz->array_cnt =1; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  165. case(P_CUT): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  166. case(P_FIX): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  167. case(REPITCH): dz->array_cnt =1; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  168. case(REPITCHB): dz->array_cnt =1; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  169. case(TRNSP): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  170. case(TRNSF): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  171. //TW UPDATES
  172. case(P_SYNTH): dz->array_cnt = 1; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  173. case(P_VOWELS): dz->array_cnt = 1; dz->iarray_cnt = 1; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  174. case(P_GEN): dz->array_cnt = 2; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  175. case(P_INSERT): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 2; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  176. case(P_SINSERT): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 2; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  177. case(P_PTOSIL): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  178. case(P_NTOSIL): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  179. case(ANALENV): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  180. case(P_BINTOBRK): dz->array_cnt=1; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  181. case(P_INTERP): dz->array_cnt = 0; dz->iarray_cnt = 0; dz->larray_cnt = 0; dz->ptr_cnt = 0; dz->fptr_cnt = 0; break;
  182. }
  183. /*** WARNING ***
  184. ANY APPLICATION DEALING WITH A NUMLIST INPUT: MUST establish AT LEAST 1 double array: i.e. dz->array_cnt = at least 1
  185. **** WARNING ***/
  186. if(dz->array_cnt < 0 || dz->iarray_cnt < 0 || dz->larray_cnt < 0 || dz->ptr_cnt < 0 || dz->fptr_cnt < 0) {
  187. sprintf(errstr,"array_cnt not set in setup_internal_arrays_and_array_pointers()\n");
  188. return(PROGRAM_ERROR);
  189. }
  190. if(dz->array_cnt > 0) {
  191. if((dz->parray = (double **)malloc(dz->array_cnt * sizeof(double *)))==NULL) {
  192. sprintf(errstr,"INSUFFICIENT MEMORY for internal double arrays.\n");
  193. return(MEMORY_ERROR);
  194. }
  195. for(n=0;n<dz->array_cnt;n++)
  196. dz->parray[n] = NULL;
  197. }
  198. if(dz->iarray_cnt > 0) {
  199. if((dz->iparray = (int **)malloc(dz->iarray_cnt * sizeof(int *)))==NULL) {
  200. sprintf(errstr,"INSUFFICIENT MEMORY for internal int arrays.\n");
  201. return(MEMORY_ERROR);
  202. }
  203. for(n=0;n<dz->iarray_cnt;n++)
  204. dz->iparray[n] = NULL;
  205. }
  206. if(dz->larray_cnt > 0) {
  207. if((dz->lparray = (int **)malloc(dz->larray_cnt * sizeof(int *)))==NULL) {
  208. sprintf(errstr,"INSUFFICIENT MEMORY for internal long arrays.\n");
  209. return(MEMORY_ERROR);
  210. }
  211. for(n=0;n<dz->larray_cnt;n++)
  212. dz->lparray[n] = NULL;
  213. }
  214. if(dz->ptr_cnt > 0) {
  215. if((dz->ptr = (double **)malloc(dz->ptr_cnt * sizeof(double *)))==NULL) {
  216. sprintf(errstr,"INSUFFICIENT MEMORY for internal pointer arrays.\n");
  217. return(MEMORY_ERROR);
  218. }
  219. for(n=0;n<dz->ptr_cnt;n++)
  220. dz->ptr[n] = NULL;
  221. }
  222. if(dz->fptr_cnt > 0) {
  223. if((dz->fptr = (float **)malloc(dz->fptr_cnt * sizeof(float *)))==NULL) {
  224. sprintf(errstr,"INSUFFICIENT MEMORY for internal float-pointer arrays.\n");
  225. return(MEMORY_ERROR);
  226. }
  227. for(n=0;n<dz->fptr_cnt;n++)
  228. dz->fptr[n] = NULL;
  229. }
  230. return(FINISHED);
  231. }
  232. /****************************** ASSIGN_PROCESS_LOGIC *********************************/
  233. int assign_process_logic(dataptr dz)
  234. {
  235. switch(dz->process) {
  236. case(PITCH): setup_process_logic(ANALFILE_ONLY, EQUAL_ANALFILE, ANALFILE_OUT, dz); break;
  237. case(TRACK): setup_process_logic(ANALFILE_ONLY, EQUAL_ANALFILE, ANALFILE_OUT, dz); break;
  238. case(P_APPROX): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_BIGPITCH, PITCH_OUT, dz); break;
  239. case(P_EXAG): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_PITCH, PITCH_OUT, dz); break;
  240. case(P_INVERT): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_PITCH, PITCH_OUT, dz); break;
  241. case(P_QUANTISE): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_PITCH, PITCH_OUT, dz); break;
  242. case(P_RANDOMISE): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_PITCH, PITCH_OUT, dz); break;
  243. case(P_SMOOTH): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_PITCH, PITCH_OUT, dz); break;
  244. case(P_TRANSPOSE): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_PITCH, PITCH_OUT, dz); break;
  245. case(P_VIBRATO): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_PITCH, PITCH_OUT, dz); break;
  246. case(P_CUT): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_BIGPITCH, PITCH_OUT, dz); break;
  247. //TW UPDATES
  248. case(P_SYNTH): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_ANAL, ANALFILE_OUT, dz); break;
  249. case(P_VOWELS): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_ANAL, ANALFILE_OUT, dz); break;
  250. case(P_INTERP): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_PITCH, PITCH_OUT, dz); break;
  251. case(P_GEN): setup_process_logic(NO_FILE_AT_ALL, PITCH_TO_BIGPITCH, PITCH_OUT, dz); break;
  252. case(P_INSERT): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_PITCH, PITCH_OUT, dz); break;
  253. case(P_SINSERT): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_PITCH, PITCH_OUT, dz); break;
  254. case(P_PTOSIL): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_PITCH, PITCH_OUT, dz); break;
  255. case(P_NTOSIL): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_PITCH, PITCH_OUT, dz); break;
  256. case(ANALENV): setup_process_logic(ANALFILE_ONLY, UNEQUAL_ENVFILE, ENVFILE_OUT, dz); break;
  257. case(P_BINTOBRK): setup_process_logic(PITCHFILE_ONLY, TO_TEXTFILE, TEXTFILE_OUT, dz); break;
  258. case(P_FIX): setup_process_logic(PITCHFILE_ONLY, PITCH_TO_PITCH, PITCH_OUT, dz); break;
  259. case(REPITCH):
  260. switch(dz->mode) {
  261. case(PPT): setup_process_logic(PITCH_AND_PITCH, PITCH_TO_BIGPITCH, PITCH_OUT, dz); break;
  262. case(PTP): setup_process_logic(PITCH_AND_TRANSPOS, PITCH_TO_BIGPITCH, PITCH_OUT, dz); break;
  263. case(TTT): setup_process_logic(TRANSPOS_AND_TRANSPOS, PITCH_TO_BIGPITCH, PITCH_OUT, dz); break;
  264. }
  265. break;
  266. case(REPITCHB):
  267. switch(dz->mode) {
  268. case(PPT): setup_process_logic(PITCH_AND_PITCH, TO_TEXTFILE, TEXTFILE_OUT, dz); break;
  269. case(PTP): setup_process_logic(PITCH_AND_TRANSPOS, TO_TEXTFILE, TEXTFILE_OUT, dz); break;
  270. case(TTT): setup_process_logic(TRANSPOS_AND_TRANSPOS, TO_TEXTFILE, TEXTFILE_OUT, dz); break;
  271. }
  272. break;
  273. case(TRNSP):
  274. case(TRNSF):
  275. switch(dz->mode) {
  276. case(TRNS_BIN): setup_process_logic(ANAL_WITH_TRANSPOS, EQUAL_ANALFILE, ANALFILE_OUT, dz); break;
  277. default: setup_process_logic(ANALFILE_ONLY, EQUAL_ANALFILE, ANALFILE_OUT, dz); break;
  278. }
  279. break;
  280. default:
  281. sprintf(errstr,"Unknown process: assign_process_logic()\n");
  282. return(PROGRAM_ERROR);
  283. break;
  284. }
  285. if(dz->has_otherfile) {
  286. switch(dz->input_data_type) {
  287. case(ALL_FILES):
  288. case(TWO_SNDFILES):
  289. case(SNDFILE_AND_ENVFILE):
  290. case(SNDFILE_AND_BRKFILE):
  291. case(SNDFILE_AND_UNRANGED_BRKFILE):
  292. case(SNDFILE_AND_DB_BRKFILE):
  293. break;
  294. case(MANY_SNDFILES):
  295. if(dz->process==INFO_TIMELIST)
  296. break;
  297. /* fall thro */
  298. default:
  299. sprintf(errstr,"Most processes accepting files with different properties\n"
  300. "can only take 2 sound infiles.\n");
  301. return(PROGRAM_ERROR);
  302. }
  303. }
  304. return(FINISHED);
  305. }
  306. /***************************** SET_LEGAL_INFILE_STRUCTURE **************************
  307. *
  308. * Allows 2nd infile to have different props to first infile.
  309. */
  310. void set_legal_infile_structure(dataptr dz)
  311. {
  312. switch(dz->process) {
  313. default:
  314. dz->has_otherfile = FALSE;
  315. break;
  316. }
  317. }
  318. /***************************************************************************************/
  319. /****************************** FORMERLY IN internal.c *********************************/
  320. /***************************************************************************************/
  321. /****************************** SET_LEGAL_INTERNALPARAM_STRUCTURE *********************************/
  322. int set_legal_internalparam_structure(int process,int mode,aplptr ap)
  323. {
  324. int exit_status = FINISHED;
  325. switch(process) {
  326. case(PITCH):
  327. switch(mode) {
  328. case(PICH_TO_BIN): exit_status = set_internalparam_data("0d",ap); break;
  329. case(PICH_TO_BRK): exit_status = set_internalparam_data( "d",ap); break;
  330. }
  331. break;
  332. case(TRACK):
  333. switch(mode) {
  334. case(TRK_TO_BIN): exit_status = set_internalparam_data("0d",ap); break;
  335. case(TRK_TO_BRK): exit_status = set_internalparam_data( "d",ap); break;
  336. }
  337. break;
  338. case(P_APPROX): return(FINISHED);
  339. case(P_EXAG): return(FINISHED);
  340. case(P_INVERT): return(FINISHED);
  341. case(P_QUANTISE): return(FINISHED);
  342. case(P_RANDOMISE): exit_status = set_internalparam_data("i",ap); break;
  343. case(P_SMOOTH): return(FINISHED);
  344. case(P_TRANSPOSE): return(FINISHED);
  345. case(P_VIBRATO): return(FINISHED);
  346. case(P_CUT): return(FINISHED);
  347. case(P_FIX): exit_status = set_internalparam_data("iiii",ap); break;
  348. case(REPITCH): return(FINISHED);
  349. case(REPITCHB): return(FINISHED);
  350. case(TRNSP): return(FINISHED);
  351. case(TRNSF): return(FINISHED);
  352. //TW UPDATES
  353. case(P_SYNTH): return(FINISHED);
  354. case(P_VOWELS): return(FINISHED);
  355. case(P_GEN): return(FINISHED);
  356. case(P_INSERT): return(FINISHED);
  357. case(P_SINSERT): return(FINISHED);
  358. case(P_PTOSIL): return(FINISHED);
  359. case(P_NTOSIL): return(FINISHED);
  360. case(ANALENV): return(FINISHED);
  361. case(P_BINTOBRK): return(FINISHED);
  362. case(P_INTERP): return(FINISHED);
  363. default:
  364. sprintf(errstr,"Unknown process in set_legal_internalparam_structure()\n");
  365. return(PROGRAM_ERROR);
  366. }
  367. return(exit_status);
  368. }
  369. /********************************************************************************************/
  370. /********************************** FORMERLY IN specialin.c *********************************/
  371. /********************************************************************************************/
  372. /********************** READ_SPECIAL_DATA ************************/
  373. int read_special_data(char *str,dataptr dz)
  374. {
  375. int exit_status = FINISHED;
  376. //TW UPDATE
  377. int n;
  378. aplptr ap = dz->application;
  379. double dummy = 0.0, is_numeric = 0;
  380. switch(ap->special_data) {
  381. case(TRANSPOS_RATIO_OR_CONSTANT):
  382. case(TRANSPOS_OCTAVE_OR_CONSTANT):
  383. case(TRANSPOS_SEMIT_OR_CONSTANT):
  384. if(!sloom) {
  385. //TW NEW FILENAME CONVENTION
  386. if(!value_is_numeric(str) && file_has_invalid_startchar(str)) {
  387. sprintf(errstr,"Filename has an invalid start-character [%s]\n",str);
  388. return(USER_ERROR);
  389. }
  390. if(value_is_numeric(str)) {
  391. if(sscanf(str,"%lf",&dummy)!=1) {
  392. sprintf(errstr,"Invalid data: read_special_data()\n");
  393. return(DATA_ERROR);
  394. }
  395. is_numeric = 1;
  396. }
  397. } else {
  398. if(str[0]==NUMERICVAL_MARKER) { /* TK convention: values preceded by an extra '@' */
  399. str++;
  400. if(strlen(str)<=0 || sscanf(str,"%lf",&dummy)!=1) {
  401. sprintf(errstr,"Invalid transposition data: read_special_data()\n");
  402. return(DATA_ERROR);
  403. }
  404. is_numeric = 1;
  405. }
  406. }
  407. if(is_numeric)
  408. return get_transposition_value(dummy,(int)ap->special_data,dz);
  409. else
  410. return getsize_and_getdata_from_transpos_brkfile
  411. (str,(double)MIN_TRANSPOS,(double)MAX_TRANSPOS,(int)ap->special_data,dz);
  412. break;
  413. case(PITCHQUANTISE_SET): return read_pquantise_set(str,dz);
  414. case(INTERVAL_MAPPING): return read_interval_mapping(str,dz);
  415. case(OUT_PFILE):
  416. if(!sloom) {
  417. if((dz->other_file=sndcreat_formatted(str,(dz->insams[0]/dz->wanted),SAMP_FLOAT,
  418. 1,dz->infile->srate,CDP_CREATE_NORMAL)) < 0) {
  419. sprintf(errstr,"Cannot open output pitch file %s\n",str);
  420. return(DATA_ERROR);
  421. }
  422. dz->needpeaks = 0;
  423. }
  424. break;
  425. case(OUT_PBRKFILE):
  426. if(!sloom) {
  427. if((dz->fp = fopen(str,"w"))==NULL) {
  428. sprintf(errstr,"Cannot open file %s for output.\n",str);
  429. return(DATA_ERROR);
  430. }
  431. }
  432. break;
  433. //TW UPDATES
  434. case(PITCH_SPECTRUM):
  435. if((exit_status = get_and_count_data_from_textfile(str,&dz->parray[PICH_SPEC],&dz->itemcnt)) < 0)
  436. return(exit_status);
  437. for(n=0;n<dz->itemcnt;n++) {
  438. if(dz->parray[PICH_SPEC][n] < ap->min_special || dz->parray[PICH_SPEC][n] > ap->max_special) {
  439. sprintf(errstr,"Partial amplitude[%d] = %lf is out of range (%lf - %lf)\n",
  440. n+1,dz->parray[PICH_SPEC][n],ap->min_special,ap->max_special);
  441. return(DATA_ERROR);
  442. }
  443. }
  444. break;
  445. case(ZERO_INSERTTIMES):
  446. if((exit_status = get_and_count_timedata_from_textfile(str,&dz->lparray[0],&dz->lparray[1],&dz->itemcnt,dz)) < 0)
  447. return(exit_status);
  448. break;
  449. case(PITCH_VOWELS):
  450. if((exit_status = get_the_vowels(str,&dz->parray[0],&dz->iparray[0],&dz->itemcnt,dz)) < 0)
  451. return(exit_status);
  452. break;
  453. case(PITCH_CREATE):
  454. if((exit_status = get_the_pitches(str,&dz->parray[0],&dz->parray[1],&dz->itemcnt)) < 0)
  455. return(exit_status);
  456. break;
  457. default:
  458. sprintf(errstr,"Unknown special_data type: read_special_data()\n");
  459. return(PROGRAM_ERROR);
  460. }
  461. return(FINISHED);
  462. }
  463. /********************** GET_TRANSPOSITION_VALUE ************************/
  464. int get_transposition_value(double val,int datatype,dataptr dz)
  465. {
  466. switch(datatype) {
  467. case(TRANSPOS_SEMIT_OR_CONSTANT): val *= OCTAVES_PER_SEMITONE; /* semitones -> octaves */
  468. /* fall thro */
  469. case(TRANSPOS_OCTAVE_OR_CONSTANT): val = (float)pow(2.0,val); break; /* octaves -> frqratios */
  470. }
  471. if(val < MIN_TRANSPOS || val > MAX_TRANSPOS) { /* graphics - range could be preset */
  472. sprintf(errstr,"Transposition [%lf] out of range %lf - %lf semitones\n",val,MIN_TRANSPOS,MAX_TRANSPOS);
  473. return(DATA_ERROR);
  474. }
  475. return convert_constant_to_transposition_table(val,dz);
  476. }
  477. /****************************** CONVERT_CONSTANT_TO_TRANSPOSITION_TABLE *********************************
  478. *
  479. * convert constant to transposition table.
  480. */
  481. int convert_constant_to_transposition_table(double val,dataptr dz)
  482. { int n = 0, arraysize = BIGARRAY;
  483. double ttime = 0.0;
  484. double infiletime = (double)dz->wlength * dz->frametime;
  485. if((dz->transpos = (float *)malloc(arraysize * sizeof(float)))==NULL) {
  486. sprintf(errstr,"INSUFFICIENT MEMORY for transpostion array.\n");
  487. return(MEMORY_ERROR);
  488. }
  489. while(n < dz->wlength) {
  490. (dz->transpos)[n] = (float)val;
  491. if(++n >= arraysize) {
  492. arraysize += BIGARRAY;
  493. if((dz->transpos = (float *)realloc((char *)dz->transpos,arraysize*sizeof(float)))==NULL) {
  494. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate transpostion array.\n");
  495. return(MEMORY_ERROR);
  496. }
  497. }
  498. ttime += dz->frametime;
  499. }
  500. while(ttime < infiletime) {
  501. (dz->transpos)[n] = (float)val;
  502. if(++n >= arraysize) {
  503. arraysize += BIGARRAY;
  504. if((dz->transpos = (float *)realloc((char *)dz->transpos,arraysize*sizeof(float)))==NULL) {
  505. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate transpostion array.\n");
  506. return(MEMORY_ERROR);
  507. }
  508. }
  509. ttime += dz->frametime;
  510. }
  511. if((dz->transpos = (float *)realloc((char *)dz->transpos,n * sizeof(float)))==NULL) {
  512. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate transpostion array.\n");
  513. return(MEMORY_ERROR);
  514. }
  515. return(FINISHED);
  516. }
  517. /********************** GETSIZE_AND_GETDATA_FROM_TRANSPOS_BRKFILE *******************/
  518. int getsize_and_getdata_from_transpos_brkfile(char *filename,double minval, double maxval,int which_type, dataptr dz)
  519. {
  520. FILE *fp;
  521. int exit_status;
  522. int brksize;
  523. if((fp = fopen(filename,"r"))==NULL) {
  524. sprintf(errstr, "Can't open brkpntfile %s to read data.\n",filename);
  525. return(DATA_ERROR);
  526. }
  527. if((exit_status =
  528. read_and_test_pitch_or_transposition_brkvals(fp,filename,&(dz->temp),&brksize,which_type,minval,maxval))<0)
  529. return(exit_status);
  530. if(fclose(fp)<0) {
  531. fprintf(stdout,"WARNING: Failed to close output textfile %s.\n",filename);
  532. fflush(stdout);
  533. }
  534. if((exit_status =
  535. convert_brkpntdata_to_window_by_window_array(dz->temp,brksize,&(dz->transpos),dz->wlength,dz->frametime))<0)
  536. return(exit_status);
  537. return(FINISHED);
  538. }
  539. /********************************* READ_PQUANTISE_SET ********************************/
  540. int read_pquantise_set(char *filename,dataptr dz)
  541. {
  542. int exit_status;
  543. double *p;
  544. int n;
  545. if((exit_status = get_and_count_data_from_textfile(filename,&(dz->parray[PQ_QSET]),&(dz->itemcnt)))<0)
  546. return(exit_status);
  547. p = dz->parray[PQ_QSET];
  548. for(n=0;n<dz->itemcnt;n++) {
  549. if(*p < MIDIMIN || *p > MIDIMAX) {
  550. sprintf(errstr,"Pitch value out of range (%d.0 - %d.0) in quantisation set\n",MIDIMIN,MIDIMAX);
  551. return(DATA_ERROR);
  552. }
  553. p++;
  554. }
  555. return FINISHED;
  556. }
  557. /************************* SORT_QUANTISING_SET *****************************/
  558. int sort_quantising_set(dataptr dz)
  559. {
  560. int n, m;
  561. double thisval;
  562. for(n=1;n<dz->itemcnt;n++) {
  563. thisval = dz->parray[PQ_QSET][n];
  564. m = n-1;
  565. while(m >= 0 && dz->parray[PQ_QSET][m] > thisval) {
  566. dz->parray[PQ_QSET][m+1] = dz->parray[PQ_QSET][m];
  567. m--;
  568. }
  569. dz->parray[PQ_QSET][m+1] = thisval;
  570. }
  571. return(FINISHED);
  572. }
  573. /************************* GENERATE_OCTAVE_DUPLICATES *****************************/
  574. int generate_octave_duplicates(dataptr dz)
  575. {
  576. int n, m;
  577. double thisval, octval;
  578. int duplicated;
  579. int orig_itemcnt = dz->itemcnt;
  580. for(n=0;n<orig_itemcnt;n++) {
  581. thisval = dz->parray[PQ_QSET][n];
  582. octval = thisval;
  583. while((octval -= SEMITONES_PER_OCTAVE) >= MIDIMIN) {
  584. duplicated = FALSE;
  585. for(m=0;m<dz->itemcnt;m++) {
  586. if(flteq(dz->parray[PQ_QSET][m],octval)) {
  587. duplicated = TRUE;
  588. break;
  589. }
  590. }
  591. if(!duplicated) {
  592. dz->itemcnt++;
  593. if((dz->parray[PQ_QSET] = (double *)realloc((char *)dz->parray[PQ_QSET],dz->itemcnt * sizeof(double)))==NULL) {
  594. sprintf(errstr,"INSUFFICIENT MEMORY for quantisation set array.\n");
  595. return(MEMORY_ERROR);
  596. }
  597. dz->parray[PQ_QSET][dz->itemcnt - 1] = octval;
  598. }
  599. }
  600. octval = thisval;
  601. while((octval += SEMITONES_PER_OCTAVE) <= MIDIMAX) {
  602. duplicated = FALSE;
  603. for(m=0;m<dz->itemcnt;m++) {
  604. if(flteq(dz->parray[PQ_QSET][m],octval)) {
  605. duplicated = TRUE;
  606. break;
  607. }
  608. }
  609. if(!duplicated) {
  610. dz->itemcnt++;
  611. if((dz->parray[PQ_QSET] = (double *) realloc((char *)dz->parray[PQ_QSET],dz->itemcnt * sizeof(double)))==NULL) {
  612. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate quantisation set array.\n");
  613. return(MEMORY_ERROR);
  614. }
  615. dz->parray[PQ_QSET][dz->itemcnt - 1] = octval;
  616. }
  617. }
  618. }
  619. return(FINISHED);
  620. }
  621. /************************* ELIMINATE_DUPLICATES_IN_QUANTISING_SET *****************************/
  622. int eliminate_duplicates_in_quantising_set(dataptr dz)
  623. {
  624. int n, m, k;
  625. for(n=1,m=0;n<dz->itemcnt;n++,m++) { /* eliminate DUPLICATE vals */
  626. if(flteq(dz->parray[PQ_QSET][n],dz->parray[PQ_QSET][m])) {
  627. for(k=n;k<dz->itemcnt;k++)
  628. dz->parray[PQ_QSET][k-1] = dz->parray[PQ_QSET][k];
  629. n--;
  630. m--;
  631. dz->itemcnt--;
  632. }
  633. }
  634. return(FINISHED);
  635. }
  636. /************************** READ_INTERVAL_MAPPING ********************************/
  637. int read_interval_mapping(char *str,dataptr dz)
  638. {
  639. int exit_status;
  640. if(!strcmp(str,"0"))
  641. dz->is_mapping = FALSE;
  642. else {
  643. if((exit_status = get_mapping(str,dz))<0)
  644. return(exit_status);
  645. dz->is_mapping = TRUE;
  646. }
  647. return(FINISHED);
  648. }
  649. /********************************* GET_MAPPING ********************************/
  650. int get_mapping(char *filename,dataptr dz)
  651. {
  652. int exit_status;
  653. double *p;
  654. int n;
  655. if((exit_status = get_and_count_data_from_textfile(filename,&(dz->parray[PI_INTMAP]),&(dz->itemcnt)))<0)
  656. return(exit_status);
  657. p = dz->parray[PI_INTMAP];
  658. for(n=0;n<dz->itemcnt;n++) {
  659. if(*p < -MAXINTRANGE || *p > MAXINTRANGE) {
  660. sprintf(errstr,
  661. "Mapping val (%lf) out of range (%.0lf to -%.0lf semitones) (8 8vas up or down).\n",
  662. *p,MAXINTRANGE,MAXINTRANGE);
  663. return(DATA_ERROR);
  664. }
  665. p++;
  666. }
  667. if(ODD(dz->itemcnt)) {
  668. sprintf(errstr,"Data not paired correctly in mapping file\n");
  669. return(DATA_ERROR);
  670. }
  671. dz->itemcnt /= 2;
  672. return sort_mapping(dz);
  673. }
  674. /************************* SORT_MAPPING *****************************
  675. *
  676. * sort interval mapping into ascending size of src_interval.
  677. */
  678. int sort_mapping(dataptr dz)
  679. {
  680. int n, m, j, k;
  681. double src_interval, goal_interval;
  682. for(n=1;n<dz->itemcnt;n++) {
  683. k = n*2;
  684. src_interval = dz->parray[PI_INTMAP][k];
  685. goal_interval = dz->parray[PI_INTMAP][k+1];
  686. m = n-1;
  687. while(m >= 0 && dz->parray[PI_INTMAP][m*2] > src_interval) {
  688. k = (m+1)* 2;
  689. j = m * 2;
  690. dz->parray[PI_INTMAP][k] = dz->parray[PI_INTMAP][j];
  691. dz->parray[PI_INTMAP][k+1] = dz->parray[PI_INTMAP][j+1];
  692. m--;
  693. }
  694. k = (m+1)*2;
  695. dz->parray[PI_INTMAP][k] = src_interval;
  696. dz->parray[PI_INTMAP][k+1] = goal_interval;
  697. }
  698. return(FINISHED);
  699. }
  700. /*************************** GET_AND_COUNT_DATA_FROM_TEXTFILE ******************************
  701. *
  702. * (1) Gets double table data from a text file.
  703. * (2) counts ALL items (not pairing them).
  704. * (3) Does NOT check for in-range.
  705. */
  706. int get_and_count_data_from_textfile(char *filename,double **brktable,int *brksize)
  707. {
  708. FILE *fp;
  709. double *p;
  710. int arraysize = BIGARRAY;
  711. char temp[200], *q;
  712. int n = 0;
  713. if((fp = fopen(filename,"r"))==NULL) {
  714. sprintf(errstr, "Can't open textfile %s to read data.\n",filename);
  715. return(DATA_ERROR);
  716. }
  717. if((*brktable = (double *)malloc(arraysize * sizeof(double)))==NULL) {
  718. sprintf(errstr,"INSUFFICIENT MEMORY for data.\n");
  719. return(MEMORY_ERROR);
  720. }
  721. p = *brktable;
  722. while(fgets(temp,200,fp)==temp) {
  723. q = temp;
  724. while(get_float_from_within_string(&q,p)) {
  725. p++;
  726. if(++n >= arraysize) {
  727. arraysize += BIGARRAY;
  728. if((*brktable = (double *)realloc((char *)(*brktable),arraysize * sizeof(double)))==NULL) {
  729. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate data table.\n");
  730. return(MEMORY_ERROR);
  731. }
  732. p = *brktable + n;
  733. }
  734. }
  735. }
  736. if(n == 0) {
  737. sprintf(errstr,"No data in textdata file %s\n",filename);
  738. return(DATA_ERROR);
  739. }
  740. if((*brktable = (double *)realloc((char *)(*brktable),n * sizeof(double)))==NULL) {
  741. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate data table.\n");
  742. return(MEMORY_ERROR);
  743. }
  744. if(fclose(fp)<0) {
  745. fprintf(stdout,"WARNING: Failed to close input textfile %s.\n",filename);
  746. fflush(stdout);
  747. }
  748. *brksize = n;
  749. return(FINISHED);
  750. }
  751. /*************************** GET_AND_COUNT_TIMEDATA_FROM_TEXTFILE ******************************
  752. *
  753. * (1) Gets double table data from a text file.
  754. * (2) counts ALL items (not pairing them).
  755. * (3) Does NOT check for in-range.
  756. */
  757. int get_and_count_timedata_from_textfile(char *filename,int **brktable1,int **brktable2,int *brksize,dataptr dz)
  758. {
  759. FILE *fp;
  760. double dummy[2];
  761. int *p[2];
  762. int arraysize = BIGARRAY;
  763. char temp[200], *q;
  764. int n = 0;
  765. int thistable;
  766. aplptr ap = dz->application;
  767. if((fp = fopen(filename,"r"))==NULL) {
  768. sprintf(errstr, "Can't open textfile %s to read data.\n",filename);
  769. return(DATA_ERROR);
  770. }
  771. if((*brktable1 = (int *)malloc(arraysize * sizeof(int)))==NULL) {
  772. sprintf(errstr,"INSUFFICIENT MEMORY for data.\n");
  773. return(MEMORY_ERROR);
  774. }
  775. if((*brktable2 = (int *)malloc(arraysize * sizeof(int)))==NULL) {
  776. sprintf(errstr,"INSUFFICIENT MEMORY for data.\n");
  777. return(MEMORY_ERROR);
  778. }
  779. p[0] = *brktable1;
  780. p[1] = *brktable2;
  781. thistable = 0;
  782. while(fgets(temp,200,fp)==temp) {
  783. q = temp;
  784. while(get_float_from_within_string(&q,&(dummy[thistable]))) {
  785. if(thistable) {
  786. if(dummy[0] < ap->min_special || dummy[0] > ap->max_special) {
  787. sprintf(errstr,"Time (%lf) in datafile out of range (%lf %lf)\n",
  788. dummy[0],ap->min_special,ap->max_special);
  789. return(DATA_ERROR);
  790. }
  791. if(dummy[1] < ap->min_special || dummy[1] > ap->max_special) {
  792. sprintf(errstr,"Time (%lf) in datafile out of range (%lf %lf)\n",
  793. dummy[1],ap->min_special,ap->max_special);
  794. return(DATA_ERROR);
  795. }
  796. if(flteq(dummy[0],dummy[1])) {
  797. sprintf(errstr,"Times in datafile equivalent (%lf %lf)\n",dummy[0],dummy[1]);
  798. return(DATA_ERROR);
  799. }
  800. if(dummy[0] > dummy[1]) {
  801. sprintf(errstr,"Times in datafile reversed (%lf %lf)\n",dummy[0],dummy[1]);
  802. return(DATA_ERROR);
  803. }
  804. if(dz->mode == 1) { /* info as sample-cnt, convert to time */
  805. dummy[0] /= (double)dz->infile->origrate;
  806. dummy[1] /= (double)dz->infile->origrate;
  807. }
  808. *(p[0]) = (int)round(dummy[0] * dz->infile->arate); /* convert from time to window number */
  809. *(p[1]) = (int)round(dummy[1] * dz->infile->arate);
  810. p[0]++;
  811. p[1]++;
  812. if(++n >= arraysize) {
  813. arraysize += BIGARRAY;
  814. if((*brktable1 = (int *)realloc((char *)(*brktable1),arraysize * sizeof(int)))==NULL) {
  815. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate data table.\n");
  816. return(MEMORY_ERROR);
  817. }
  818. if((*brktable2 = (int *)realloc((char *)(*brktable2),arraysize * sizeof(int)))==NULL) {
  819. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate data table.\n");
  820. return(MEMORY_ERROR);
  821. }
  822. p[0] = *brktable1 + n;
  823. p[1] = *brktable2 + n;
  824. }
  825. }
  826. thistable = !thistable;
  827. }
  828. }
  829. if(n == 0) {
  830. sprintf(errstr,"No data in textdata file %s\n",filename);
  831. return(DATA_ERROR);
  832. }
  833. if(thistable) {
  834. sprintf(errstr,"data in textdata file %s not paired correctly\n",filename);
  835. return(DATA_ERROR);
  836. }
  837. if((*brktable1 = (int *)realloc((char *)(*brktable1),n * sizeof(int)))==NULL) {
  838. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate data table.\n");
  839. return(MEMORY_ERROR);
  840. }
  841. if((*brktable2 = (int *)realloc((char *)(*brktable2),n * sizeof(int)))==NULL) {
  842. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate data table.\n");
  843. return(MEMORY_ERROR);
  844. }
  845. if(fclose(fp)<0) {
  846. fprintf(stdout,"WARNING: Failed to close input textfile %s.\n",filename);
  847. fflush(stdout);
  848. }
  849. *brksize = n;
  850. return(FINISHED);
  851. }
  852. //TW UPDATE : NEW FUNCTION
  853. /******************************** GET_THE_PITCHES ********************************/
  854. int get_the_pitches(char *filename,double **times,double **pitch,int *pcnt)
  855. {
  856. FILE *fp;
  857. double *t, lasttime = 0.0;
  858. double *pitchval;
  859. int non_zero_start = 0;
  860. int arraysize = BIGARRAY, n = 0;
  861. char temp[200], *q, *p;
  862. int istime;
  863. if((fp = fopen(filename,"r"))==NULL) {
  864. sprintf(errstr, "Can't open textfile %s to read pitch data.\n",filename);
  865. return(DATA_ERROR);
  866. }
  867. if((*times = (double *)malloc(arraysize * sizeof(double)))==NULL) {
  868. sprintf(errstr,"INSUFFICIENT MEMORY for time data.\n");
  869. return(MEMORY_ERROR);
  870. }
  871. if((*pitch = (double *)malloc(arraysize * sizeof(double)))==NULL) {
  872. sprintf(errstr,"INSUFFICIENT MEMORY for vowels data.\n");
  873. return(MEMORY_ERROR);
  874. }
  875. t = *times;
  876. pitchval = *pitch;
  877. istime = 1;
  878. while(fgets(temp,200,fp)==temp) {
  879. q = temp;
  880. while(get_word_from_string(&q,&p)) {
  881. if(istime) {
  882. if(sscanf(p,"%lf",t)!=1) {
  883. sprintf(errstr,"No time for time-pitch pair %d\n",n+1);
  884. return(DATA_ERROR);
  885. }
  886. if(n==0) {
  887. if(*t < 0.0) {
  888. sprintf(errstr,"First time is less than zero in pitch data\n");
  889. return(DATA_ERROR);
  890. } else if(*t > 0.0) {
  891. print_outwarning_flush("FIRST TIME in pitch data IS NOT ZERO : assuming first pitch runs from time zero\n");
  892. non_zero_start = 1;
  893. t++;
  894. *t = *(t-1);
  895. *(t-1) = 0.0;
  896. }
  897. } else {
  898. if (*t <= lasttime) {
  899. sprintf(errstr,"Times do not advance (from %lf to %lf at pair %d) in pitch data\n",
  900. lasttime,*t,n+1);
  901. return(DATA_ERROR);
  902. }
  903. }
  904. lasttime = *t++;
  905. } else {
  906. if(get_pitch(p,pitchval)<0) {
  907. strcat(errstr,p);
  908. sprintf(temp,"' is a bad pitch value at item %d\n",n+1);
  909. strcat(errstr,temp);
  910. return(DATA_ERROR);
  911. }
  912. if((n==0) && non_zero_start) {
  913. pitchval++;
  914. *pitchval = *(pitchval-1);
  915. n++;
  916. }
  917. pitchval++;
  918. if(++n >= arraysize) {
  919. arraysize += BIGARRAY;
  920. if((*times = (double *)realloc((char *)(*times),arraysize * sizeof(double)))==NULL) {
  921. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate table of pitch-times.\n");
  922. return(MEMORY_ERROR);
  923. }
  924. if((*pitch = (double *)realloc((char *)(*pitch),arraysize * sizeof(double)))==NULL) {
  925. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate table of pitches.\n");
  926. return(MEMORY_ERROR);
  927. }
  928. t = *times + n;
  929. pitchval = *pitch + n;
  930. }
  931. }
  932. istime = !istime;
  933. }
  934. }
  935. if(n < 2) {
  936. sprintf(errstr,"Insufficient data in pitch datafile %s\n",filename);
  937. return(DATA_ERROR);
  938. }
  939. if(!istime) {
  940. sprintf(errstr,"data in pitch datafile %s not paired correctly\n",filename);
  941. return(DATA_ERROR);
  942. }
  943. if((*times = (double *)realloc((char *)(*times),n * sizeof(double)))==NULL) {
  944. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate vowel-time table.\n");
  945. return(MEMORY_ERROR);
  946. }
  947. if((*pitch = (double *)realloc((char *)(*pitch),n * sizeof(double)))==NULL) {
  948. sprintf(errstr,"INSUFFICIENT MEMORY to reallocate vowels table.\n");
  949. return(MEMORY_ERROR);
  950. }
  951. if(fclose(fp)<0) {
  952. fprintf(stdout,"WARNING: Failed to close input textfile %s.\n",filename);
  953. fflush(stdout);
  954. }
  955. *pcnt = n;
  956. return(FINISHED);
  957. }
  958. /********************************************************************************************/
  959. /********************************** FORMERLY IN preprocess.c ********************************/
  960. /********************************************************************************************/
  961. /****************************** PARAM_PREPROCESS *********************************/
  962. int param_preprocess(dataptr dz)
  963. {
  964. switch(dz->process) {
  965. case(PITCH): return specpitch_preprocess(dz);
  966. case(TRACK): return track_preprocess(dz);
  967. case(P_APPROX): return papprox_preprocess(dz);
  968. case(P_EXAG): return pexag_preprocess(dz);
  969. case(P_INVERT): return pinvert_preprocess(dz);
  970. case(P_QUANTISE): return pquantise_preprocess(dz);
  971. case(P_RANDOMISE): return adjust_params_and_setup_internal_params_for_prandomise(dz);
  972. case(P_SMOOTH): return adjust_params_and_setup_internal_params_for_psmooth(dz);
  973. case(P_TRANSPOSE): return adjust_params_for_ptranspose(dz);
  974. case(P_VIBRATO): return pvibrato_preprocess(dz);
  975. case(P_FIX): return pfix_preprocess(dz);
  976. case(REPITCHB): return repitchb_preprocess(dz);
  977. case(P_CUT): case(REPITCH): case(TRNSP): case(TRNSF):
  978. //TW UPDATES
  979. case(P_SYNTH):
  980. case(P_VOWELS):
  981. case(P_GEN):
  982. case(P_INSERT):
  983. case(P_SINSERT):
  984. case(P_PTOSIL):
  985. case(P_NTOSIL):
  986. case(ANALENV):
  987. case(P_BINTOBRK):
  988. case(P_INTERP):
  989. return(FINISHED);
  990. default:
  991. sprintf(errstr,"PROGRAMMING PROBLEM: Unknown process in param_preprocess()\n");
  992. return(PROGRAM_ERROR);
  993. }
  994. return(FINISHED); /* NOTREACHED */
  995. }
  996. /************************** SPECPITCH_PREPROCESS ******************************/
  997. int specpitch_preprocess(dataptr dz)
  998. {
  999. int exit_status;
  1000. if((exit_status = adjust_parameters_for_specpitch(dz))<0)
  1001. return(exit_status);
  1002. if(dz->mode == PICH_TO_BRK) {
  1003. if((dz->parray[PICH_PBRK] = (double *)malloc(dz->wlength * 2 * sizeof(double)))==NULL) {
  1004. sprintf(errstr,"INSUFFICIENT MEMORY for pitchbrk array.\n");
  1005. return(MEMORY_ERROR);
  1006. }
  1007. }
  1008. if((exit_status = establish_internal_arrays_for_pitchwork(dz))<0)
  1009. return(exit_status);
  1010. initrand48();
  1011. dz->param[PICH_PICH] = 0.0;
  1012. return setup_ring(dz);
  1013. }
  1014. /************ ADJUST_PARAMETERS_FOR_SPECPITCH *************/
  1015. int adjust_parameters_for_specpitch(dataptr dz)
  1016. {
  1017. /* convert semitone to ratio */
  1018. dz->param[PICH_RNGE] = pow(SEMITONE_INTERVAL,fabs(dz->param[PICH_RNGE]));
  1019. /* convert dB to gain */
  1020. dz->param[PICH_SRATIO] /= 20.0;
  1021. dz->param[PICH_SRATIO] = pow(10.0,dz->param[PICH_SRATIO]);
  1022. dz->param[PICH_SRATIO] = 1.0/dz->param[PICH_SRATIO];
  1023. return(FINISHED);
  1024. }
  1025. /************ ESTABLISH_INTERNAL_ARRAYS_FOR_PITCHWORK *************/
  1026. int establish_internal_arrays_for_pitchwork(dataptr dz)
  1027. {
  1028. int exit_status;
  1029. if((exit_status = establish_arrays_for_pitchwork(dz))<0)
  1030. return(exit_status);
  1031. if((exit_status = establish_bottom_frqs_of_channels(dz))<0)
  1032. return(exit_status);
  1033. return establish_testtone_amps(dz);
  1034. }
  1035. /***************************** ESTABLISH_ARRAYS_FOR_PITCHWORK *************************/
  1036. int establish_arrays_for_pitchwork(dataptr dz)
  1037. {
  1038. int i;
  1039. if((dz->parray[PICH_PRETOTAMP] = (double *)malloc(dz->wlength * sizeof(double)))==NULL) {
  1040. sprintf(errstr,"INSUFFICIENT MEMORY for amp totalling array.\n");
  1041. return(MEMORY_ERROR);
  1042. }
  1043. //RWD NOV97 quick solution to unassigned value somewhere in spec pitch!
  1044. for(i = 0; i < dz->wlength;i++)
  1045. dz->parray[PICH_PRETOTAMP][i] = 0.0;
  1046. if((dz->pitches = (float *)malloc(dz->wlength * sizeof(float)))==NULL) {
  1047. sprintf(errstr,"INSUFFICIENT MEMORY for pitches array.\n");
  1048. return(MEMORY_ERROR);
  1049. }
  1050. return(FINISHED);
  1051. }
  1052. /************************** TRACK_PREPROCESS ******************************/
  1053. int track_preprocess(dataptr dz)
  1054. {
  1055. int exit_status;
  1056. if((exit_status = convert_track_params(dz))<0)
  1057. return(exit_status);
  1058. if((exit_status = setup_internal_params_and_arrays_for_track(dz))<0)
  1059. return(exit_status);
  1060. initrand48();
  1061. return establish_internal_arrays_for_pitchwork(dz);
  1062. }
  1063. /************ CONVERT_TRACK_PARAMS *************/
  1064. int convert_track_params(dataptr dz)
  1065. { /* convert semitone to ratio */
  1066. dz->param[TRAK_RNGE] = pow(SEMITONE_INTERVAL,fabs(dz->param[TRAK_RNGE]));
  1067. /* convert dB to gain */
  1068. dz->param[TRAK_SRATIO] /= 20.0;
  1069. dz->param[TRAK_SRATIO] = pow(10.0,dz->param[TRAK_SRATIO]);
  1070. dz->param[TRAK_SRATIO] = 1.0/dz->param[TRAK_SRATIO];
  1071. return(FINISHED);
  1072. }
  1073. /************ SETUP_INTERNAL_PARAMS_AND_ARRAYS_FOR_TRACK *************/
  1074. int setup_internal_params_and_arrays_for_track(dataptr dz)
  1075. { /* setup internal arrays */
  1076. dz->param[TRAK_LOLM] = MINPITCH;
  1077. if(dz->mode == TRK_TO_BRK) {
  1078. if((dz->parray[PICH_PBRK] = (double *)malloc(dz->wlength * 2 * sizeof(double)))==NULL) {
  1079. sprintf(errstr,"INSUFFICIENT MEMORY for pitch brk array.\n");
  1080. return(MEMORY_ERROR);
  1081. }
  1082. }
  1083. return(FINISHED);
  1084. }
  1085. /************************** PAPPROX_PREPROCESS ******************************/
  1086. int papprox_preprocess(dataptr dz)
  1087. {
  1088. int exit_status;
  1089. if(dz->mode==TRANSP_OUT)
  1090. dz->is_transpos = TRUE;
  1091. if((exit_status = convert_msecs_to_secs(PA_TRANG,dz))<0)
  1092. return(exit_status);
  1093. return convert_msecs_to_secs(PA_SRANG,dz);
  1094. }
  1095. /************************** PEXAG_PREPROCESS ******************************/
  1096. int pexag_preprocess(dataptr dz)
  1097. {
  1098. if(dz->mode == RANGE_ONLY_TO_T
  1099. || dz->mode == CONTOUR_ONLY_TO_T
  1100. || dz->mode == R_AND_C_TO_T)
  1101. dz->is_transpos = TRUE;
  1102. return(FINISHED);
  1103. }
  1104. /************************** PINVERT_PREPROCESS ******************************/
  1105. int pinvert_preprocess(dataptr dz)
  1106. {
  1107. if(dz->mode==TRANSP_OUT)
  1108. dz->is_transpos = TRUE;
  1109. return(FINISHED);
  1110. }
  1111. /************************** PQUANTISE_PREPROCESS ******************************/
  1112. int pquantise_preprocess(dataptr dz)
  1113. {
  1114. if(dz->mode==TRANSP_OUT)
  1115. dz->is_transpos = TRUE;
  1116. if(dz->vflag[PQ_OCTDUPL])
  1117. generate_octave_duplicates(dz);
  1118. eliminate_duplicates_in_quantising_set(dz);
  1119. return sort_quantising_set(dz);
  1120. }
  1121. /************ ADJUST_PARAMS_AND_SETUP_INTERNAL_PARAMS_FOR_PRANDOMISE *************/
  1122. int adjust_params_and_setup_internal_params_for_prandomise(dataptr dz)
  1123. {
  1124. int exit_status;
  1125. if((exit_status = convert_msecs_to_secs(PR_TSTEP,dz))<0)
  1126. return(exit_status);
  1127. if(dz->mode==TRANSP_OUT)
  1128. dz->is_transpos = TRUE;
  1129. if(dz->vflag[PR_IS_SLEW]) {
  1130. if(dz->param[PR_SLEW] < 0.0)
  1131. dz->iparam[PR_NEGATIV_SLEW] = TRUE;
  1132. dz->param[PR_SLEW] = -1.0/dz->param[PR_SLEW];
  1133. }
  1134. return(FINISHED);
  1135. }
  1136. /************ ADJUST_PARAMS_AND_SETUP_INTERNAL_PARAMS_FOR_PSMOOTH *************/
  1137. int adjust_params_and_setup_internal_params_for_psmooth(dataptr dz)
  1138. {
  1139. int exit_status;
  1140. if((exit_status = convert_msecs_to_secs(PS_TFRAME,dz))<0)
  1141. return(exit_status);
  1142. if(dz->mode==TRANSP_OUT)
  1143. dz->is_transpos = TRUE;
  1144. return(FINISHED);
  1145. }
  1146. /************ ADJUST_PARAMS_FOR_PTRANSPOSE *************/
  1147. int adjust_params_for_ptranspose(dataptr dz)
  1148. {
  1149. dz->param[PT_TVAL] /= 12.0;
  1150. dz->param[PT_TVAL] = pow(2.0,dz->param[PT_TVAL]);
  1151. return(FINISHED);
  1152. }
  1153. /************************** PVIBRATO_PREPROCESS ******************************/
  1154. int pvibrato_preprocess(dataptr dz)
  1155. {
  1156. int n;
  1157. double scaling = (PI * 2.0)/P_TABSIZE;
  1158. if(dz->mode==TRANSP_OUT)
  1159. dz->is_transpos = TRUE;
  1160. if((dz->parray[PV_SIN] = (double *)malloc((P_TABSIZE + 1) * sizeof(double)))==NULL) {
  1161. sprintf(errstr,"INSUFFICIENT MEMORY for vibrato sine table.\n");
  1162. return(MEMORY_ERROR);
  1163. }
  1164. for(n=0;n<P_TABSIZE;n++)
  1165. dz->parray[PV_SIN][n] = sin((double)n * scaling);
  1166. dz->parray[PV_SIN][n] = 0.0;
  1167. return(FINISHED);
  1168. }
  1169. /************************** PFIX_PREPROCESS ******************************/
  1170. int pfix_preprocess(dataptr dz)
  1171. {
  1172. dz->iparam[PF_ISFILTER] = 0; /* establish pfix filtertype */
  1173. if(dz->vflag[PF_HIPASS])
  1174. dz->iparam[PF_ISFILTER] |= IS_HIPASS;
  1175. if(dz->vflag[PF_LOPASS])
  1176. dz->iparam[PF_ISFILTER] |= IS_LOPASS;
  1177. if(dz->vflag[PF_STARTCUT]) { /* establish_pfix_cutpoints */
  1178. if(!dz->vflag[PF_ENDCUT])
  1179. dz->iparam[PF_ECUTW] = dz->wlength;
  1180. else
  1181. dz->iparam[PF_ECUTW] = round(dz->param[PF_ECUT]/dz->frametime);
  1182. }
  1183. if(dz->vflag[PF_ENDCUT]) {
  1184. if(!dz->vflag[PF_STARTCUT])
  1185. dz->iparam[PF_SCUTW] = 0;
  1186. else
  1187. dz->iparam[PF_SCUTW] = round(dz->param[PF_SCUT]/dz->frametime);
  1188. }
  1189. if(dz->vflag[PF_ENDCUT] || dz->vflag[PF_STARTCUT]) {
  1190. dz->iparam[PF_ISCUT] = 1;
  1191. if(dz->iparam[PF_SCUTW] >= dz->iparam[PF_ECUTW]) {
  1192. sprintf(errstr,"Remove-pitch times incompatible.\n");
  1193. return(USER_ERROR);
  1194. }
  1195. }
  1196. return(FINISHED);
  1197. }
  1198. /************************** REPITCHB_PREPROCESS ******************************/
  1199. int repitchb_preprocess(dataptr dz)
  1200. {
  1201. dz->mode += 3; /* converts to higher (brkpnt) mode inside the option 'repitch' */
  1202. dz->param[RP_DRED] /= 12.0;
  1203. dz->param[RP_DRED] = pow(2.0,dz->param[RP_DRED]);
  1204. dz->is_sharp = dz->param[RP_DRED];
  1205. if(dz->is_sharp==0.0) {
  1206. sprintf(errstr,"parameter not set: repitchb_preprocess()\n");
  1207. return(PROGRAM_ERROR);
  1208. }
  1209. dz->is_flat = 1.0/dz->is_sharp;
  1210. return(FINISHED);
  1211. }
  1212. /********************************************************************************************/
  1213. /********************************** FORMERLY IN procspec.c **********************************/
  1214. /********************************************************************************************/
  1215. /**************************** SPEC_PROCESS_FILE ****************************/
  1216. int spec_process_file(dataptr dz)
  1217. {
  1218. dz->total_windows = 0;
  1219. display_virtual_time(0L,dz);
  1220. switch(dz->process) {
  1221. case(TRNSP): return outer_loop(dz);
  1222. case(TRNSF): return outer_loop(dz);
  1223. case(PITCH): return outer_pitch_loop(dz);
  1224. case(TRACK): return outer_pitch_loop(dz);
  1225. case(P_APPROX): return outer_pichpich_loop(dz);
  1226. case(P_EXAG): return outer_pichpich_loop(dz);
  1227. case(P_INVERT): return outer_pichpich_loop(dz);
  1228. case(P_QUANTISE): return outer_pichpich_loop(dz);
  1229. case(P_RANDOMISE): return outer_pichpich_loop(dz);
  1230. case(P_SMOOTH): return outer_pichpich_loop(dz);
  1231. case(P_TRANSPOSE): return outer_pichpich_loop(dz);
  1232. case(P_VIBRATO): return outer_pichpich_loop(dz);
  1233. case(P_CUT): return outer_pichpich_loop(dz);
  1234. //TW UPDATES
  1235. case(P_SYNTH): return outer_pichpich_loop(dz);
  1236. case(P_VOWELS): return outer_pichpich_loop(dz);
  1237. case(P_INSERT): return outer_pichpich_loop(dz);
  1238. case(P_SINSERT): return outer_pichpich_loop(dz);
  1239. case(P_PTOSIL): return outer_pichpich_loop(dz);
  1240. case(P_NTOSIL): return outer_pichpich_loop(dz);
  1241. case(P_INTERP): return outer_pichpich_loop(dz);
  1242. case(ANALENV): return get_anal_envelope(dz);
  1243. case(P_BINTOBRK): return convert_pitch_from_binary_to_text(dz);
  1244. case(P_GEN): return generate_pitch(dz);
  1245. case(P_FIX): return specpfix(dz);
  1246. case(REPITCH): return specrepitch(dz);
  1247. case(REPITCHB): return specrepitch(dz);
  1248. default:
  1249. sprintf(errstr,"Unknown process in procspec()\n");
  1250. return(PROGRAM_ERROR);
  1251. }
  1252. return(FINISHED); /* NOTREACHED */
  1253. }
  1254. /**************************** INNER_LOOP ****************************/
  1255. int inner_loop
  1256. (int *peakscore,int *descnt,int *in_start_portion,int *least,int *pitchcnt,int windows_in_buf,dataptr dz)
  1257. {
  1258. int exit_status;
  1259. int local_zero_set = FALSE;
  1260. int wc;
  1261. for(wc=0; wc<windows_in_buf; wc++) {
  1262. if(dz->total_windows==0) {
  1263. if((exit_status = skip_or_special_operation_on_window_zero(dz))<0)
  1264. return(exit_status);
  1265. if(exit_status==TRUE) {
  1266. dz->flbufptr[0] += dz->wanted;
  1267. dz->total_windows++;
  1268. dz->time = (float)(dz->time + dz->frametime);
  1269. continue;
  1270. }
  1271. }
  1272. if((exit_status = read_values_from_all_existing_brktables((double)dz->time,dz))<0)
  1273. return(exit_status);
  1274. switch(dz->process) {
  1275. case(TRNSF): exit_status = spectrnsf(dz); break;
  1276. case(TRNSP): exit_status = spectrnsp(dz); break;
  1277. default:
  1278. sprintf(errstr,"unknown process in inner_loop()\n");
  1279. return(PROGRAM_ERROR);
  1280. }
  1281. if(exit_status<0)
  1282. return(exit_status);
  1283. dz->flbufptr[0] += dz->wanted;
  1284. dz->total_windows++;
  1285. dz->time = (float)(dz->time + dz->frametime);
  1286. }
  1287. if(!dz->zeroset && local_zero_set==TRUE) {
  1288. fprintf(stdout,"WARNING: Zero-amp spectral window(s) encountered: orig window(s) substituted.\n");
  1289. fflush(stdout);
  1290. dz->zeroset = TRUE;
  1291. }
  1292. return(FINISHED);
  1293. }
  1294. /***************** SKIP_OR_SPECIAL_OPERATION_ON_WINDOW_ZERO ************/
  1295. int skip_or_special_operation_on_window_zero(dataptr dz)
  1296. {
  1297. int vc;
  1298. switch(dz->process) {
  1299. case(TRNSF):
  1300. case(TRNSP):
  1301. for(vc = 0; vc < dz->wanted; vc += 2)
  1302. dz->windowbuf[0][FREQ] = dz->flbufptr[0][FREQ];
  1303. break;
  1304. }
  1305. return(TRUE);
  1306. }
  1307. /********************************************************************************************/
  1308. /********************************** FORMERLY IN pconsistency.c ******************************/
  1309. /********************************************************************************************/
  1310. /****************************** CHECK_PARAM_VALIDITY_AND_CONSISTENCY *********************************/
  1311. int check_param_validity_and_consistency(dataptr dz)
  1312. {
  1313. int exit_status;
  1314. int chans;
  1315. int srate;
  1316. int win_overlap;
  1317. int chancnt;
  1318. handle_pitch_zeros(dz);
  1319. switch(dz->process) {
  1320. case(PITCH): return check_consistency_of_pitch_params(dz);
  1321. case(TRACK): return check_consistency_of_track_params(dz);
  1322. case(P_INVERT): return check_compatibility_pinvert_params(dz);
  1323. case(P_RANDOMISE): return check_validity_of_prandomise_params(dz);
  1324. case(P_CUT): return check_consistency_of_pcut_params(dz);
  1325. case(P_FIX): return check_compatibility_of_pfix_smoothing_flags(dz);
  1326. case(TRNSF): return check_for_valid_transposition_ratios(MINPITCH/dz->nyquist,dz->nyquist/MINPITCH,dz);
  1327. case(TRNSP): return check_for_valid_transposition_ratios(MINPITCH/dz->nyquist,dz->nyquist/MINPITCH,dz);
  1328. case(P_SYNTH):
  1329. case(P_VOWELS):
  1330. chans = dz->infile->channels;
  1331. dz->infile->channels = dz->infile->origchans;
  1332. if((exit_status = create_sized_outfile(dz->wordstor[0],dz))<0)
  1333. return(exit_status);
  1334. dz->infile->channels = chans;
  1335. break;
  1336. case(ANALENV):
  1337. chans = dz->infile->channels;
  1338. srate = dz->infile->srate;
  1339. // JULY 2005 OLD
  1340. dz->infile->srate = round(1.0/dz->frametime);
  1341. // NEW
  1342. dz->infile->srate = (int)(1.0/dz->frametime);
  1343. dz->infile->channels = 1;
  1344. if((exit_status = create_sized_outfile(dz->wordstor[0],dz))<0)
  1345. return(exit_status);
  1346. dz->infile->channels = chans;
  1347. dz->infile->srate = srate;
  1348. break;
  1349. case(P_GEN):
  1350. if(dz->floatsam_output)
  1351. dz->infile->origstype = SAMP_FLOAT;
  1352. else
  1353. dz->infile->origstype = SAMP_SHORT;
  1354. dz->infile->origrate = dz->iparam[PGEN_SRATE];
  1355. dz->infile->stype = SAMP_FLOAT;
  1356. win_overlap = dz->iparam[PGEN_WINOVLP_INPUT]-1;
  1357. chancnt = dz->iparam[PGEN_CHANS_INPUT];
  1358. chancnt = chancnt + (chancnt%2);
  1359. switch(win_overlap) {
  1360. case 0: dz->infile->Mlen = 4*chancnt; break;
  1361. case 1: dz->infile->Mlen = 2*chancnt; break;
  1362. case 2: dz->infile->Mlen = chancnt; break;
  1363. case 3: dz->infile->Mlen = chancnt / 2; break;
  1364. default:
  1365. sprintf(errstr,"pvoc: Invalid window overlap factor.\n");
  1366. return(PROGRAM_ERROR);
  1367. }
  1368. if((dz->infile->Dfac = (int)(dz->infile->Mlen/PVOC_CONSTANT_A)) == 0){
  1369. fprintf(stdout,"WARNING: Decimation too low: adjusted.\n");
  1370. fflush(stdout);
  1371. dz->infile->Dfac = 1;
  1372. }
  1373. dz->infile->origchans = dz->iparam[PGEN_CHANS_INPUT] + 2;
  1374. dz->wanted = dz->infile->origchans;
  1375. dz->clength = dz->wanted/2;
  1376. dz->nyquist = dz->infile->origrate / 2;
  1377. dz->infile->arate = (float) dz->infile->origrate / (float)dz->infile->Dfac;
  1378. dz->infile->srate = (int) dz->infile->arate;
  1379. dz->frametime = (float)(1.0/dz->infile->arate);
  1380. dz->wlength = (int)round(dz->param[SS_DUR] * dz->infile->arate);
  1381. dz->chwidth = dz->nyquist/(double)dz->clength;
  1382. dz->infile->channels = 1;
  1383. if((exit_status = create_sized_outfile(dz->outfilename,dz))<0)
  1384. return(exit_status);
  1385. break;
  1386. }
  1387. return(FINISHED);
  1388. }
  1389. /************ CHECK_CONSISTENCY_OF_PITCH_PARAMS *************/
  1390. int check_consistency_of_pitch_params(dataptr dz)
  1391. {
  1392. if(dz->param[PICH_HILM] <= dz->param[PICH_LOLM]) {
  1393. sprintf(errstr,"Impossible pitch range specified.\n");
  1394. return(USER_ERROR);
  1395. }
  1396. if(dz->mode==PICH_TO_BRK) {
  1397. if(dz->vflag==NULL) {
  1398. sprintf(errstr,"Problem in setting up redundant flag for PITCH.\n");
  1399. return(PROGRAM_ERROR);
  1400. }
  1401. if((dz->vflag = (char *)realloc((char *)dz->vflag,2 * sizeof(char)))==NULL) {
  1402. sprintf(errstr,"INSUFFICIENT MEMORY for extra internal flags.\n");
  1403. return(MEMORY_ERROR);
  1404. }
  1405. dz->vflag[KEEP_PITCH_ZEROS] = FALSE;
  1406. establish_datareduction(PICH_DATAREDUCE,dz);
  1407. }
  1408. return(FINISHED);
  1409. }
  1410. /************ CHECK_CONSISTENCY_OF_TRACK_PARAMS *************/
  1411. int check_consistency_of_track_params(dataptr dz)
  1412. {
  1413. if(dz->vflag!=NULL) {
  1414. sprintf(errstr,"Problem in setting up redundant flag for TRACK.\n");
  1415. return(PROGRAM_ERROR);
  1416. }
  1417. if((dz->vflag = (char *)malloc(2 * sizeof(char)))==NULL) {
  1418. sprintf(errstr,"INSUFFICIENT MEMORY for extra internal flags.\n");
  1419. return(MEMORY_ERROR);
  1420. }
  1421. dz->vflag[KEEP_PITCH_ZEROS] = FALSE;
  1422. establish_datareduction(TRAK_DATAREDUCE,dz);
  1423. //TW UPDATE
  1424. return(FINISHED);
  1425. }
  1426. /************************** ESTABLISH_DATAREDUCTION ********************************/
  1427. void establish_datareduction(int paramno,dataptr dz)
  1428. {
  1429. double datareduction = dz->param[paramno] * OCTAVES_PER_SEMITONE;
  1430. datareduction = pow(2.0,datareduction);
  1431. dz->is_sharp = datareduction;
  1432. dz->is_flat = 1.0/dz->is_sharp;
  1433. }
  1434. /************ CHECK_COMPATIBILITY_PINVERT_PARAMS *************/
  1435. int check_compatibility_pinvert_params(dataptr dz)
  1436. {
  1437. int exit_status;
  1438. int n;
  1439. double maxmean, minmean;
  1440. if((dz->vflag[PI_IS_TOP] || dz->vflag[PI_IS_BOT]) && dz->vflag[PI_IS_MEAN]) {
  1441. if(dz->brksize[PI_MEAN]) {
  1442. maxmean = MIDIMIN;
  1443. if((exit_status = hztomidi(&minmean,dz->nyquist))<0)
  1444. return(exit_status);
  1445. for(n=0;n<dz->itemcnt*2; n+=2) {
  1446. if(dz->brk[PI_MEAN][n] > maxmean)
  1447. maxmean = dz->brk[PI_MEAN][n];
  1448. if(dz->brk[PI_MEAN][n] < minmean)
  1449. minmean = dz->brk[PI_MEAN][n];
  1450. }
  1451. } else
  1452. maxmean = minmean = dz->param[PI_MEAN];
  1453. if(dz->vflag[PI_IS_TOP] && (dz->param[PI_TOP] < maxmean)) {
  1454. if(dz->brksize[PI_MEAN])
  1455. sprintf(errstr,
  1456. "top midipitch value must be ABOVE all mean values in brkpntfile.\n");
  1457. else
  1458. sprintf(errstr,"top midipitch value must be ABOVE mean value.\n");
  1459. return(USER_ERROR);
  1460. }
  1461. if(dz->vflag[PI_IS_BOT] && (dz->param[PI_BOT] > minmean)) {
  1462. if(dz->brksize[PI_MEAN])
  1463. sprintf(errstr,"bot midipitch value must be BELOW all mean values in brkpntfile.\n");
  1464. else
  1465. sprintf(errstr,"bot midipitch value must be BELOW mean value.\n");
  1466. return(USER_ERROR);
  1467. }
  1468. }
  1469. return(FINISHED);
  1470. }
  1471. /************ CHECK_VALIDITY_OF_PRANDOMISE_PARAMS *************/
  1472. int check_validity_of_prandomise_params(dataptr dz)
  1473. {
  1474. if(dz->vflag[PR_IS_SLEW] && fabs(dz->param[PR_SLEW])<=1.0) {
  1475. sprintf(errstr,"slew out of range: slew must be >1 or <-1\n");
  1476. return(USER_ERROR);
  1477. }
  1478. return(FINISHED);
  1479. }
  1480. /********************** CHECK_CONSISTENCY_OF_PCUT_PARAMS **********************/
  1481. int check_consistency_of_pcut_params(dataptr dz)
  1482. {
  1483. if(dz->mode==PCUT_BOTH && (dz->param[PC_STT] >= dz->param[PC_END])) {
  1484. sprintf(errstr,"Start and end cut-times incompatible.\n");
  1485. return(USER_ERROR);
  1486. }
  1487. return(FINISHED);
  1488. }
  1489. /***************************** CHECK_COMPATIBILITY_OF_PFIX_SMOOTHING_FLAGS ******/
  1490. int check_compatibility_of_pfix_smoothing_flags(dataptr dz)
  1491. {
  1492. if(dz->vflag[PF_TWOW] && !dz->vflag[PF_IS_SMOOTH]) {
  1493. sprintf(errstr,"-w flag cannot be used without -s flag.\n");
  1494. return(USER_ERROR);
  1495. }
  1496. return(FINISHED);
  1497. }
  1498. /********************* CHECK_FOR_VALID_TRANSPOSITION_RATIOS **********************/
  1499. int check_for_valid_transposition_ratios(double mintrans,double maxtrans,dataptr dz)
  1500. {
  1501. int n;
  1502. for(n=0;n<dz->wlength;n++) {
  1503. if(dz->transpos[n] < mintrans || dz->transpos[n] > maxtrans) {
  1504. sprintf(errstr,
  1505. "Invalid transposition ratio (%f) encountered.\n(MIN %lf MAX %lf)\n",
  1506. dz->transpos[n],mintrans,maxtrans);
  1507. return(DATA_ERROR);
  1508. }
  1509. }
  1510. return(FINISHED);
  1511. }
  1512. /********************************************************************************************/
  1513. /********************************** FORMERLY IN buffers.c ***********************************/
  1514. /********************************************************************************************/
  1515. /**************************** ALLOCATE_LARGE_BUFFERS ******************************/
  1516. int allocate_large_buffers(dataptr dz)
  1517. {
  1518. switch(dz->process) {
  1519. case(TRNSP): case(TRNSF):
  1520. return allocate_single_buffer(dz);
  1521. case(PITCH): case(TRACK):
  1522. //TW UPDATES
  1523. case(P_SYNTH):
  1524. case(P_VOWELS):
  1525. return allocate_single_buffer_plus_extra_pointer(dz);
  1526. case(P_APPROX): case(P_EXAG): case(P_INVERT):
  1527. case(P_QUANTISE): case(P_RANDOMISE):case(P_SMOOTH):
  1528. case(P_TRANSPOSE): case(P_VIBRATO): case(P_CUT):
  1529. case(P_FIX): case(REPITCH): case(REPITCHB):
  1530. return(FINISHED);
  1531. //TW UPDATES
  1532. case(P_INSERT):
  1533. case(P_SINSERT):
  1534. case(P_PTOSIL):
  1535. case(P_NTOSIL):
  1536. case(P_GEN):
  1537. case(P_INTERP):
  1538. case(P_BINTOBRK):
  1539. return(FINISHED);
  1540. case(ANALENV):
  1541. return allocate_double_buffer(dz);
  1542. default:
  1543. sprintf(errstr,"Unknown program no. in allocate_large_buffers()\n");
  1544. return(PROGRAM_ERROR);
  1545. }
  1546. return(FINISHED); /* NOTREACHED */
  1547. }
  1548. /********************************************************************************************/
  1549. /********************************** FORMERLY IN cmdline.c ***********************************/
  1550. /********************************************************************************************/
  1551. int get_process_no(char *prog_identifier_from_cmdline,dataptr dz)
  1552. {
  1553. if (!strcmp(prog_identifier_from_cmdline,"getpitch")) dz->process = PITCH;
  1554. else if(!strcmp(prog_identifier_from_cmdline,"track")) dz->process = TRACK;
  1555. else if(!strcmp(prog_identifier_from_cmdline,"approx")) dz->process = P_APPROX;
  1556. else if(!strcmp(prog_identifier_from_cmdline,"exag")) dz->process = P_EXAG;
  1557. else if(!strcmp(prog_identifier_from_cmdline,"invert")) dz->process = P_INVERT;
  1558. else if(!strcmp(prog_identifier_from_cmdline,"quantise")) dz->process = P_QUANTISE;
  1559. else if(!strcmp(prog_identifier_from_cmdline,"randomise")) dz->process = P_RANDOMISE;
  1560. else if(!strcmp(prog_identifier_from_cmdline,"smooth")) dz->process = P_SMOOTH;
  1561. else if(!strcmp(prog_identifier_from_cmdline,"pchshift")) dz->process = P_TRANSPOSE;
  1562. else if(!strcmp(prog_identifier_from_cmdline,"vibrato")) dz->process = P_VIBRATO;
  1563. else if(!strcmp(prog_identifier_from_cmdline,"cut")) dz->process = P_CUT;
  1564. else if(!strcmp(prog_identifier_from_cmdline,"fix")) dz->process = P_FIX;
  1565. else if(!strcmp(prog_identifier_from_cmdline,"combine")) dz->process = REPITCH;
  1566. else if(!strcmp(prog_identifier_from_cmdline,"combineb")) dz->process = REPITCHB;
  1567. else if(!strcmp(prog_identifier_from_cmdline,"transpose")) dz->process = TRNSP;
  1568. else if(!strcmp(prog_identifier_from_cmdline,"transposef")) dz->process = TRNSF;
  1569. //TW UPDATES (or definite instatements)
  1570. else if(!strcmp(prog_identifier_from_cmdline,"synth")) dz->process = P_SYNTH;
  1571. else if(!strcmp(prog_identifier_from_cmdline,"vowels")) dz->process = P_VOWELS;
  1572. else if(!strcmp(prog_identifier_from_cmdline,"insertzeros")) dz->process = P_INSERT;
  1573. else if(!strcmp(prog_identifier_from_cmdline,"insertsil")) dz->process = P_SINSERT;
  1574. else if(!strcmp(prog_identifier_from_cmdline,"pitchtosil")) dz->process = P_PTOSIL;
  1575. else if(!strcmp(prog_identifier_from_cmdline,"noisetosil")) dz->process = P_NTOSIL;
  1576. else if(!strcmp(prog_identifier_from_cmdline,"analenv")) dz->process = ANALENV;
  1577. else if(!strcmp(prog_identifier_from_cmdline,"generate")) dz->process = P_GEN;
  1578. else if(!strcmp(prog_identifier_from_cmdline,"interp")) dz->process = P_INTERP;
  1579. else if(!strcmp(prog_identifier_from_cmdline,"pchtotext")) dz->process = P_BINTOBRK;
  1580. else {
  1581. sprintf(errstr,"Unknown program identification string '%s'\n",prog_identifier_from_cmdline);
  1582. return(USAGE_ONLY);
  1583. }
  1584. //TW UPDATE
  1585. return(FINISHED);
  1586. }
  1587. /********************************************************************************************/
  1588. /********************************** FORMERLY IN usage.c *************************************/
  1589. /********************************************************************************************/
  1590. /******************************** USAGE1 ********************************/
  1591. int usage1(void)
  1592. {
  1593. fprintf(stdout,
  1594. "\nREPITCHING OPERATIONS ON SPECTRAL AND PITCH FILES\n\n"
  1595. "USAGE: repitch NAME (mode) infile (infile2) outfile parameters: \n"
  1596. "\n"
  1597. "where NAME can be any one of\n"
  1598. "\n"
  1599. "getpitch\n"
  1600. "approx exag invert quantise randomise smooth\n"
  1601. "vibrato cut fix combine combineb\n"
  1602. //TW UPDATES
  1603. "synth vowels insertzeros insertsil pitchtosil noisetosil analenv\n"
  1604. "generate interp pchtotext\n"
  1605. "pchshift transpose transposef\n\n"
  1606. "Type 'repitch getpitch' for more info on repitch getpitch..ETC.\n");
  1607. return(USAGE_ONLY);
  1608. }
  1609. /******************************** USAGE2 ********************************/
  1610. int usage2(char *str)
  1611. {
  1612. if(!strcmp(str,"getpitch")) {
  1613. fprintf(stdout,
  1614. "repitch getpitch 1 infile outfile pfil \n\t [-tR] [-gM] [-sS] [-nH] [-lL] [-hT] [-a] [-z]\n"
  1615. "repitch getpitch 2 infile outfile bfil \n\t [-tR] [-gM] [-sS] [-nH] [-lL] [-hT] [-di] [-a]\n\n"
  1616. "ATTEMPT TO EXTRACT PITCH FROM SPECTRAL DATA.\n\n"
  1617. "outfile If resynthesized, produces tone at detected (possibly varying) pitch.\n\n"
  1618. "pfil (MODE 1) Binary output file containing pitch information.\n"
  1619. "bfil (MODE 2) breakpoint (text) outfile of pitch info (as time/Hz pairs).\n"
  1620. " Either of these may be reused in other pitch-manipulating options.\n\n"
  1621. "-t R R = Tuning range(semitones) within which harmonics accepted as in tune\n"
  1622. " (Default 1)\n"
  1623. "-g M M = minimum number of adjacent windows that must be pitched,\n"
  1624. " for a pitch-value to be registered (Default %d).\n"
  1625. "-s S S = signal to noise ratio, in decibels. (Default %.0lfdB)\n"
  1626. " Windows which are more than SdB below maximum level in sound, are\n"
  1627. " assumed to be noise, & any detected pitchvalue is assumed spurious.\n"
  1628. "-n H H = how many of the %d loudest peaks in spectrum must be harmonics\n"
  1629. " to confirm sound is pitched: Default %d.\n"
  1630. "-l L L = frequency of LOWEST acceptable pitch (Default min: %.0lfHz).\n"
  1631. "-h T T = frequency of TOPMOST acceptable pitch (Default max: nyquist/%d).\n"
  1632. "-d i i = acceptable pitch-ratio error in data reduction. (semitones)\n"
  1633. " Default 1/8 tone = %lf\n"
  1634. "-a Alternative pitch-finding algorithm (avoid N<2).\n"
  1635. "-z Retain unpitched windows (set them to -1)\n"
  1636. " Default: Set pitch by interpolation between adjacent pitched windows.\n",
  1637. BLIPLEN,SILENCE_RATIO,MAXIMI,ACCEPTABLE_MATCH,MINPITCH,MAXIMI,LOG2(EIGHTH_TONE)*SEMITONES_PER_OCTAVE);
  1638. } else if(!strcmp(str,"approx")) {
  1639. fprintf(stdout,
  1640. "repitch approx mode pitchfile outfile [-pprange] [-ttrange] [-ssrange]\n\n"
  1641. "MAKE AN APPROXIMATE COPY OF A PITCHFILE.\n\n"
  1642. "PRANGE Interval (semitones) over which pitch +- randomly varies from orig.\n"
  1643. " Range > 0.0\n"
  1644. "TRANGE Time-interval (msecs) by which pitchval can stray from orig time.\n"
  1645. " Applied to turning-points in pitch-contour.\n"
  1646. " Range: from duration of 1 analysis window to duration of entire file.\n"
  1647. "SRANGE Time-interval (msecs) over which pitch contour scanned.\n"
  1648. " Pitchshift by a semitone within srange, indicates pitch rise or fall.\n"
  1649. " Range: from duration of %d analwindows to (approx) dur of infile.\n\n"
  1650. "MODES....\n"
  1651. "(1) Gives a pitchfile as ouput.\n"
  1652. "(2) Gives a transposition file as output.\n\n"
  1653. "Prange, trange and srange may vary over time.\n",2*BLOKCNT);
  1654. } else if(!strcmp(str,"exag")) {
  1655. fprintf(stdout,
  1656. "repitch exag 1-2 pitchfile outfile meanpch range\n"
  1657. "repitch exag 3-4 pitchfile outfile meanpch contour\n"
  1658. "repitch exag 5-6 pitchfile outfile meanpch range contour\n\n"
  1659. "EXAGGERATE PITCH CONTOUR.\n\n"
  1660. "MEANPITCH pitch (MIDI) around which intervals stretched.\n"
  1661. "RANGE exagg pitch-range (multiply semitone-intvl). >0.\n"
  1662. "CONTOUR exagg pitch-contour. Values (0-1).\n\n"
  1663. "MODES....\n"
  1664. "(1,3,5) Give a pitchfile as ouput.\n"
  1665. "(2,4,6) Give a transposition file as output.\n\n"
  1666. "Meanpitch, range and contour may all vary over time.\n");
  1667. } else if(!strcmp(str,"invert")) {
  1668. fprintf(stdout,
  1669. "repitch invert mode pitchfile outfile map [-mmeanpch] [-bbot] [-ttop]\n\n"
  1670. "INVERT PITCH CONTOUR OF A PITCH DATA FILE.\n\n"
  1671. "MAP Set map to ZERO if no mapping is required..OTHERWISE\n"
  1672. " map is a file of paired values showing how intervals\n"
  1673. " (in, possibly fractional, SEMITONES)\n"
  1674. " are to be mapped onto their inversions.\n"
  1675. " Range -%.0lf to %.0lf.\n"
  1676. "MEANPCH pitch (MIDI) around which pitchline inverted.\n"
  1677. " Range: MIDI equivalents of %.0lfHz to nyquist.\n"
  1678. "BOT bottom pitch (MIDI) permissible (default 0).\n"
  1679. " Range: MIDI equivalents of %.0lfHz to nyquist.\n"
  1680. "TOP top pitch (MIDI) permissible (default 127).\n"
  1681. " Range: MIDI equivalents of %.0lfHz to nyquist.\n"
  1682. "MODES.\n"
  1683. "(1) Gives a pitchfile as ouput.\n"
  1684. "(2) Gives a transposition file as output.\n\n"
  1685. "Meanpitch may vary over time.\n",MAXINTRANGE,MAXINTRANGE,MINPITCH,MINPITCH,MINPITCH);
  1686. } else if(!strcmp(str,"quantise")) {
  1687. fprintf(stdout,
  1688. "repitch quantise mode pitchfile outfile q-set [-o]\n\n"
  1689. "QUANTISE PITCHES IN A PITCH DATA FILE.\n\n"
  1690. "q_set a file of (possibly fractional) MIDI pitchvals\n"
  1691. " over which pitch to be quantised.\n"
  1692. "-o duplicates q_set in all octave transpositions\n\n"
  1693. "MODES....\n"
  1694. "(1) Gives a pitchfile as ouput.\n"
  1695. "(2) Gives a transposition file as output.\n\n");
  1696. } else if(!strcmp(str,"randomise")) {
  1697. fprintf(stdout,
  1698. "repitch randomise mode pitchfile outfile maxinterval timestep [-sslew]\n\n"
  1699. "RANDOMISE PITCH LINE.\n\n"
  1700. "MAXINTERVAL (semitones) over which pitches can +- randomvary.\n"
  1701. " Range 0 to %.0lf: Value or brkpnt file.\n"
  1702. "TIMESTEP maximum timestep between random pitch fluctuations (milliseconds).\n"
  1703. " Timesteps are random values less than this.\n"
  1704. " Range: duration of 1 anal window to dur of entire file.\n"
  1705. "SLEW e.g. 2: upward variation range twice that of downward.\n"
  1706. " e.g -3: downward variation range 3 times that of upward.\n"
  1707. " Range >1 || <-1.\n\n"
  1708. "MODES....\n"
  1709. "(1) Gives a pitchfile as ouput.\n"
  1710. "(2) Gives a transposition file as output.\n\n"
  1711. "Maxinterval and timestep may vary over time.\n",MAXINTRANGE);
  1712. } else if(!strcmp(str,"smooth")) {
  1713. fprintf(stdout,
  1714. "repitch smooth mode pitchfile outfile timeframe [-pmeanpch] [-h]\n\n"
  1715. "SMOOTH PITCH CONTOUR IN A PITCH DATA FILE.\n\n"
  1716. "TIMEFRAME (millisecs) over which to interpolate pitch values.\n"
  1717. " Range: duration of 1 anal window to dur of entire file.\n"
  1718. "-p interp between PEAK value in each timeframe block of pitch values.\n"
  1719. " MEANPITCH is pitch from which peaks measured\n"
  1720. " (and must be within pitch range, in every timeframe block).\n"
  1721. " Peak is maximum displacement from mean (up or down).\n"
  1722. "-h At end of file, hold last interpolated pitchvalue calculated.\n"
  1723. " Default: interpolate thence to last actual value in input.\n"
  1724. "MODES....\n"
  1725. "(1) Gives a pitchfile as ouput.\n"
  1726. "(2) Gives a transposition file as output.\n\n"
  1727. "Timeframe and meanpitch may vary over time.\n");
  1728. } else if(!strcmp(str,"pchshift")) {
  1729. fprintf(stdout,
  1730. "repitch pchshift pitchfile outpitchfile transposition\n\n"
  1731. "SHIFTS PITCHES IN PITCHDATA FILE BY CONSTANT NO OF SEMITONES.\n\n"
  1732. "(To transpose pitch of spectrum in time-varying way,'repitch transpose[f]')\n");
  1733. } else if(!strcmp(str,"vibrato")) {
  1734. fprintf(stdout,
  1735. "repitch vibrato mode pitchfile outfile vibfreq vibrange\n\n"
  1736. "ADD VIBRATO TO PITCH IN A PITCH DATA FILE.\n\n"
  1737. "VIBFREQ frequency of vibrato itself (Hz). Values >0.\n"
  1738. "VIBRANGE max interval vibrato moves away from central pitch (semitones).\n"
  1739. " Values >0.\n\n"
  1740. "MODES....\n"
  1741. "(1) Gives a pitchfile as ouput.\n"
  1742. "(2) Gives a transposition file as output.\n\n"
  1743. "Vibfreq and vibrange may vary over time.\n");
  1744. } else if(!strcmp(str,"cut")) {
  1745. fprintf(stdout,
  1746. "repitch cut 1 pitchfile outpitchfile starttime\n"
  1747. "repitch cut 2 pitchfile outpitchfile endtime\n"
  1748. "repitch cut 3 pitchfile outpitchfile starttime endtime\n\n"
  1749. "CUT OUT AND KEEP A SEGMENT OF A BINARY PITCH-DATAFILE.\n");
  1750. } else if(!strcmp(str,"fix")) {
  1751. fprintf(stdout,
  1752. "repitch fix pitchfile outpitchfile\n"
  1753. " [-rt1] [-xt2] [-lbf] [-htf] [-sN] [-bf1] [-ef2] [-w] [-i]\n\n"
  1754. "MASSAGE PITCH DATA IN A BINARY PITCHFILE.\n"
  1755. "Pitchdata may be viewed by running pitchinfo see, and viewing output in viewsf.\n\n"
  1756. "PITCHFILE & OUTPITCHFILE:binary pitchdata files generated by 'spec pitch' etc.\n\n"
  1757. "-r t1 Starttime: remove pitch from time 't1' (default 0.0).\n"
  1758. "-x t2 Endtime: end pitch removal at time 't2' (default, end of file).\n"
  1759. "-l bf Bottom_frq: remove pitch below frequency 'bf'.\n"
  1760. "-h tf Top_frq: remove pitch above frequency 'tf'.\n"
  1761. "-s N Smoothcnt: smooth onset errors & glitches in pitchdata, N times.\n"
  1762. "-b f1 Startfrq: force start frequency to be 'f1'.\n"
  1763. "-e f2 Endfrq: force end frequency to be 'f2'.\n"
  1764. "-w removes 2-window glitches (Default: 1-window) (Use ONLY with -s)\n"
  1765. "-i interpolate through ALL non-pitch windows in pitch_data,\n"
  1766. " producing pitch everywhere.\n"
  1767. "RULES.........\n"
  1768. "(1) AT LEAST ONE flag must be used.\n"
  1769. "(2) When pitches are removed they are replaced by a 'no-pitch' indicator.\n"
  1770. " These (and any already existing unpitched windows in the file) can be\n"
  1771. " converted to pitch-data (by interpolation between adjacent pitches)\n"
  1772. " using the -i flag.\n"
  1773. "(3) With multiple flags, ORDER of operations inside program is....\n"
  1774. " REMOVE-TIMEWISE(rx),REMOVE-FRQWISE(lh),SMOOTH(sw),SET-ENDVALS(be),INTERP(i)\n");
  1775. } else if(!strcmp(str,"combine")) {
  1776. fprintf(stdout,
  1777. "repitch combine 1 pitchfile pitchfile2 outtransposfile\n"
  1778. "repitch combine 2 pitchfile transposfile outpitchfile\n"
  1779. "repitch combine 3 transposfile transposfile2 outtransposfile\n\n"
  1780. " GENERATE TRANSPOSITION DATA FROM 2 SETS OF PITCH DATA,\n"
  1781. " OR TRANSPOSE PITCH DATA WITH TRANSPOSITION DATA,\n"
  1782. "OR COMBINE 2 SETS OF TRANSPOSITION DATA TO FORM NEW TRANSPOSITION DATA,\n"
  1783. " PRODUCING BINARY DATAFILE OUTPUT.\n\n"
  1784. "PITCHFILE binary pitchdatafile OR time/pitch(frq) brkpnt file\n"
  1785. "TRANSPOSFILE binary transposition file OR time/transpos(ratio) brkpnt file\n"
  1786. "OUTPITCHFILE binary pitchdatafile\n"
  1787. "OUTTRANSPOSFILE binary transpositionfile\n\n"
  1788. "NB: It's IMPOSSIBLE to generate binary outfile from exclusively brkpnt infiles.\n");
  1789. } else if(!strcmp(str,"combineb")) {
  1790. fprintf(stdout,
  1791. "repitch combineb 1 pitchfile pitchfile2 outtbrkfile [-dI]\n"
  1792. "repitch combineb 2 pitchfile transposfile outpbrkfile [-dI]\n"
  1793. "repitch combineb 3 transposfile transposfile2 outtbrkfile [-dI]\n\n"
  1794. " GENERATE TRANSPOSITION DATA FROM 2 SETS OF PITCH DATA,\n"
  1795. " OR TRANSPOSE PITCH DATA WITH TRANSPOSITION DATA,\n"
  1796. "OR COMBINE 2 SETS OF TRANSPOSITION DATA TO FORM NEW TRANSPOSITION DATA,\n"
  1797. " PRODUCING A TIME/VAL BRKPNT FILE OUTPUT.\n\n"
  1798. "PITCHFILE binary pitchdatafile OR time/pitch(frq) brkpnt file\n"
  1799. "TRANSPOSFILE binary transposition file OR time/transpos(ratio) brkpnt file\n"
  1800. "OUTPBRKFILE time/pitch(frq) brkpnt file\n"
  1801. "OUTTBRKFILE time/transposition(ratio) brkpnt file\n\n"
  1802. "-d I = acceptable pitch error in brkpntfile data-reduction.\n"
  1803. " Range > 1.0 : Default: eighth_tone = %lf\n",LOG2(EIGHTH_TONE)*SEMITONES_PER_OCTAVE);
  1804. } else if(!strcmp(str,"transposef")) {
  1805. fprintf(stdout,
  1806. "repitch transposef 1-3 infile outfile -fN|-pN [-i] transpos [-lminf][-hmaxf][-x]\n"
  1807. "repitch transposef 4 infile transpos outfile -fN|-pN [-i] [-lminf][-hmaxf][-x]\n"
  1808. "\n"
  1809. "TRANSPOSE SPECTRUM : BUT RETAIN ORIGINAL SPECTRAL ENVELOPE\n"
  1810. "\n"
  1811. "MODES\n"
  1812. "1 transposition as a frq ratio.\n"
  1813. "2 transposition in (fractions of) octaves.\n"
  1814. "3 transposition in (fractions of) semitones.\n"
  1815. "4 transposition as a binary data file.\n"
  1816. "\n"
  1817. "-f extract formant envelope linear frqwise,\n"
  1818. " using 1 point for every N equally-spaced frequency-channels.\n"
  1819. "-p extract formant envelope linear pitchwise,\n"
  1820. " using N equally-spaced pitch-bands per octave.\n"
  1821. "-i quicksearch for formants (less accurate).\n"
  1822. "\n"
  1823. "-l MINF = minimum frq, below which data is filtered out.\n"
  1824. "-h MAXF = maximum frq, above which data is filtered out.\n"
  1825. "-x Fuller spectrum.\n"
  1826. "\n"
  1827. "frq-ratio, octave or semitone transpositions may vary over time.\n"
  1828. "maxfrq and minfrq may vary over time.\n");
  1829. } else if(!strcmp(str,"transpose")) {
  1830. fprintf(stdout,
  1831. "repitch transpose 1-3 infile outfile transpos [-lminfrq][-hmaxfrq][-x]\n"
  1832. "repitch transpose 4 infile transpos outfile [-lminfrq][-hmaxfrq][-x]\n"
  1833. "\n"
  1834. "TRANSPOSE SPECTRUM (SPECTRAL ENVELOPE ALSO MOVES)\n"
  1835. "\n"
  1836. "MODES\n"
  1837. "1 transposition as a frq ratio.\n"
  1838. "2 transposition in (fractions of) octaves.\n"
  1839. "3 transposition in (fractions of) semitones.\n"
  1840. "4 transposition as a binary data file.\n"
  1841. "\n"
  1842. "-l MINFRQ = minimum frq, below which data is filtered out.\n"
  1843. "-h MAXFRQ = maximum frq, above which data is filtered out.\n"
  1844. "-x Fuller spectrum.\n"
  1845. "\n"
  1846. "frq-ratio, octave or semitone transpositions may vary over time.\n");
  1847. //TW UPDATES
  1848. } else if(!strcmp(str,"synth")) {
  1849. fprintf(stdout,
  1850. "repitch synth binarypitchfile outanalfile harmonics-data\n"
  1851. "\n"
  1852. "CREATE SPECTRUM OF A SOUND FOLLOWING THE PITCH CONTOUR IN THE PITCH FILE\n"
  1853. "\n"
  1854. "HARMONICS-DATA is a list of the amplitude of each harmonic in sequence, from 1 upwards\n"
  1855. "Amplitudes must lie in the range 0-1\n");
  1856. } else if(!strcmp(str,"generate")) {
  1857. fprintf(stdout,
  1858. "repitch generate outpitchdatafile midipitch-data srate [-cpoints] [-ooverlap]\n"
  1859. "\n"
  1860. "CREATE BINARY PITCHDATA FILE FROM A TEXTFILE OF TIME-MIDI VALUE PAIRS\n"
  1861. "\n"
  1862. "MIDIPITCH-DATA is a list of paired time and midi-note-values\n"
  1863. " where times must start at zero and increase,\n"
  1864. " and note values may be numeric MIDI values (possibly fractional)\n"
  1865. " OR note names (A,B,C,D,E,F or G)\n"
  1866. " possibly followed by '#'(sharp) or 'b'(flat)\n"
  1867. " followed by an octave number between -5 and 5\n"
  1868. " where 0 corresponds to the octave starting at middle C.\n\n"
  1869. "SRATE is the sample rate of the soundfile that might later be generated\n"
  1870. " from the binary pitch data.\n"
  1871. "POINTS No of analysis points (2-32768 (power of 2)): default 1024\n"
  1872. " More points give better freq resolution but worse time-resolution.\n"
  1873. "OVERLAP Filter overlap factor (1-4): default 3\n");
  1874. } else if(!strcmp(str,"vowels")) {
  1875. fprintf(stdout,
  1876. "repitch vowels infile outfile vowel-data halfwidth curve pk_range fweight foffset\n"
  1877. "\n"
  1878. "CREATE SPECTRUM OF VOWEL SOUND(S) FOLLOWING PITCH CONTOUR IN PITCH FILE\n"
  1879. "\n"
  1880. "VOWEL-DATA is a vowel, OR a file of paired time/vowel values\n"
  1881. "where vowel is one of the following strings\n"
  1882. " ee : as in 'heat'\n"
  1883. " i : as in 'hit'\n"
  1884. " ai : as in 'hate'\n"
  1885. " aii: as in scottish 'e'\n"
  1886. " e : as in 'pet'\n"
  1887. " a : as in 'pat'\n"
  1888. " ar : as in 'heart'\n"
  1889. " o : as in 'hot'\n"
  1890. " or : as in 'taught'\n"
  1891. " u : as in 'hood'\n"
  1892. " uu : as in scottish 'you'\n"
  1893. " ui : as in scottish 'could'\n"
  1894. " x : neutral vowel as in 'herb', or 'a'\n"
  1895. " xx : as in Southern English 'hub'\n"
  1896. " n : as in mean, can, done\n"
  1897. "\n"
  1898. "In brkpnt files, times must start at zero, and increase.\n"
  1899. "\n"
  1900. "HALFWIDTH is half-width of formant, in Hz, as fraction of formant centre-frq (range .01 - 10)\n"
  1901. "CURVE is the steepness of the formant peak (range 0.1 to 10.0)\n"
  1902. "PK_RANGE ratio of (max) amplitude range of formant peaks to (max) total range (range 0 to 1)\n"
  1903. "FWEIGHT is amplitude weighting of fundamental (range 0 to 1)\n"
  1904. "FOFFSET is amount of scattering of frqs of harmonics from their true value (range 0 to 1)\n"
  1905. "\n");
  1906. } else if(!strcmp(str,"insertzeros")) {
  1907. fprintf(stdout,
  1908. "repitch insertzeros mode infile outfile zeros-data\n"
  1909. "\n"
  1910. "MARK AREAS AS UNPITCHED IN A PITCHDATA FILE\n"
  1911. "\n"
  1912. "MODES\n"
  1913. "1 data as times.\n"
  1914. "2 data as (grouped) sample count: Count samples in mono, pairs in stereo etc\n"
  1915. "\n"
  1916. "ZEROS-DATA\n"
  1917. "is a list of pairs of times between which unpitched data to be indicated.\n");
  1918. } else if(!strcmp(str,"insertsil")) {
  1919. fprintf(stdout,
  1920. "repitch insertsil mode infile outfile silence-data\n"
  1921. "\n"
  1922. "MARK AREAS AS SILENT IN A PITCHDATA FILE\n"
  1923. "\n"
  1924. "MODES\n"
  1925. "1 data as times.\n"
  1926. "2 data as (grouped) sample count: Count samples in mono, pairs in stereo etc\n"
  1927. "\n"
  1928. "SILENCE-DATA\n"
  1929. "is a a list of pairs of times between which silence is to be indicated.\n");
  1930. } else if(!strcmp(str,"pitchtosil")) {
  1931. fprintf(stdout,
  1932. "repitch pitchtosil infile outfile\n"
  1933. "\n"
  1934. "REPLACE PITCHED WINDOWS BY SILENCE\n");
  1935. } else if(!strcmp(str,"noisetosil")) {
  1936. fprintf(stdout,
  1937. "repitch noisetosil infile outfile\n"
  1938. "\n"
  1939. "REPLACE UNPITCHED WINDOWS BY SILENCE\n");
  1940. } else if(!strcmp(str,"analenv")) {
  1941. fprintf(stdout,
  1942. "repitch analenv inanalfile outenvfile\n"
  1943. "\n"
  1944. "EXTRACT THE WINDOW-LOUDNESS ENVELOPE OF AN ANALYSIS FILE\n"
  1945. "\n"
  1946. "Extracts loudness of each window of analysis file.\n"
  1947. "Output data synchronous with pitch or formant data from same analfile\n");
  1948. } else if(!strcmp(str,"interp")) {
  1949. fprintf(stdout,
  1950. "repitch interp 1-2 infile outfile\n"
  1951. "\n"
  1952. "REPLACE NOISE OR SILENCE BY PITCH INTERPOLATED FROM EXISTING PITCHES\n"
  1953. "\n"
  1954. "Mode 1 glides from previous valid pitch to next vaild pitch.\n"
  1955. "Mode 2 sustains previous valid pitch until next vaild pitch appears.\n");
  1956. } else if(!strcmp(str,"pchtotext")) {
  1957. fprintf(stdout,
  1958. "repitch pchtotext infile outfile\n"
  1959. "\n"
  1960. "CONVERT BINARY PITCH DATA TO TEXTFILE\n");
  1961. } else
  1962. fprintf(stdout,"Unknown option '%s'\n",str);
  1963. return(USAGE_ONLY);
  1964. }
  1965. /******************************** USAGE3 ********************************/
  1966. int usage3(char *str1,char *str2)
  1967. {
  1968. sprintf(errstr,"Insufficient parameters on command line.\n");
  1969. return(USAGE_ONLY);
  1970. }
  1971. //TW UPDATE : NEW FUNCTION
  1972. /******************************** GET_PITCH ********************************/
  1973. int get_pitch(char *str,double *midi)
  1974. {
  1975. char *p = str;
  1976. int oct, intmidi = 0, is_noteval = 0;
  1977. switch(*p) {
  1978. case('c'): case('C'): intmidi = 0; is_noteval = 1; break;
  1979. case('d'): case('D'): intmidi = 2; is_noteval = 1; break;
  1980. case('e'): case('E'): intmidi = 4; is_noteval = 1; break;
  1981. case('f'): case('F'): intmidi = 5; is_noteval = 1; break;
  1982. case('g'): case('G'): intmidi = 7; is_noteval = 1; break;
  1983. case('a'): case('A'): intmidi = 9; is_noteval = 1; break;
  1984. case('b'): case('B'): intmidi = 11; is_noteval = 1; break;
  1985. }
  1986. if(is_noteval) {
  1987. p++;
  1988. switch(*p) {
  1989. case('#'): intmidi++; p++; break;
  1990. case('b'): intmidi--; p++; break;
  1991. }
  1992. if(sscanf(p,"%d",&oct)!=1) {
  1993. sprintf(errstr,"No (valid) octave value given : '");
  1994. return(-1);
  1995. }
  1996. if(oct < -5 || oct > 5) {
  1997. sprintf(errstr,"Octave value (%d) out of range : '",oct);
  1998. return(-1);
  1999. }
  2000. oct += 5;
  2001. oct *= 12;
  2002. intmidi += oct;
  2003. *midi = (double)intmidi;
  2004. } else if(sscanf(str,"%lf",midi)!=1) {
  2005. sprintf(errstr,"'");
  2006. return(-1);
  2007. }
  2008. if(*midi < 0.0 || *midi >= 132.0) {
  2009. sprintf(errstr,"Midi value (%lf) out of range : '",*midi);
  2010. return(-1);
  2011. }
  2012. return FINISHED;
  2013. }