| common_FLAGS = -Isrc/include/espeak-ng | common_FLAGS = -Isrc/include/espeak-ng | ||||
| common_SOURCE = \ | common_SOURCE = \ | ||||
| src/libespeak-ng/compiledata.c \ | |||||
| src/libespeak-ng/compiledict.c \ | src/libespeak-ng/compiledict.c \ | ||||
| src/libespeak-ng/dictionary.c \ | src/libespeak-ng/dictionary.c \ | ||||
| src/libespeak-ng/intonation.c \ | src/libespeak-ng/intonation.c \ |
| ReadPhondataManifest(); | ReadPhondataManifest(); | ||||
| } // end of CompilePhonemeData | } // end of CompilePhonemeData | ||||
| #include <errno.h> | |||||
| void CompileMbrola(const wxChar *mbrola_file) | |||||
| {//================= | |||||
| char *p; | |||||
| FILE *f_in; | |||||
| FILE *f_out; | |||||
| int percent; | |||||
| int n; | |||||
| int *pw; | |||||
| int *pw_end; | |||||
| int count = 0; | |||||
| int control; | |||||
| char phoneme[40]; | |||||
| char phoneme2[40]; | |||||
| char name1[40]; | |||||
| char name2[40]; | |||||
| char mbrola_voice[40]; | |||||
| char buf[sizeof(path_home)+30]; | |||||
| int mbrola_ctrl = 20; // volume in 1/16 ths | |||||
| MBROLA_TAB data[N_PHONEME_TAB]; | |||||
| wxString filepath; | |||||
| if (mbrola_file == NULL) | |||||
| { | |||||
| filepath = wxFileSelector(_T("Read Mbrola phonemes file"),path_phsource+_T("/mbrola"),_T(""),_T(""),_T("*"),wxOPEN); | |||||
| } | |||||
| else | |||||
| { | |||||
| filepath = mbrola_file; | |||||
| } | |||||
| strcpy(buf,filepath.mb_str(wxConvLocal)); | |||||
| if((f_in = fopen(buf,"r")) == NULL) | |||||
| { | |||||
| wxLogError(_T("Can't read: ")+filepath); | |||||
| return; | |||||
| } | |||||
| while(fgets(buf,sizeof(phoneme),f_in) != NULL) | |||||
| { | |||||
| buf[sizeof(phoneme)-1] = 0; | |||||
| if((p = strstr(buf,"//")) != NULL) | |||||
| *p = 0; // truncate line at comment | |||||
| if(memcmp(buf,"volume",6)==0) | |||||
| { | |||||
| mbrola_ctrl = atoi(&buf[6]); | |||||
| continue; | |||||
| } | |||||
| n = sscanf(buf,"%d %s %s %d %s %s",&control,phoneme,phoneme2,&percent,name1,name2); | |||||
| if(n >= 5) | |||||
| { | |||||
| data[count].name = StringToWord(phoneme); | |||||
| if(strcmp(phoneme2,"NULL")==0) | |||||
| data[count].next_phoneme = 0; | |||||
| else | |||||
| if(strcmp(phoneme2,"VWL")==0) | |||||
| data[count].next_phoneme = 2; | |||||
| else | |||||
| data[count].next_phoneme = StringToWord(phoneme2); | |||||
| data[count].mbr_name = 0; | |||||
| data[count].mbr_name2 = 0; | |||||
| data[count].percent = percent; | |||||
| data[count].control = control; | |||||
| if(strcmp(name1,"NULL")!=0) | |||||
| data[count].mbr_name = StringToWord(name1); | |||||
| if(n == 6) | |||||
| data[count].mbr_name2 = StringToWord(name2); | |||||
| count++; | |||||
| } | |||||
| } | |||||
| fclose(f_in); | |||||
| wxFileName filename = wxFileName(filepath); | |||||
| strcpy(mbrola_voice,filename.GetName().mb_str(wxConvLocal)); | |||||
| sprintf(buf,"%s/mbrola_ph/%s_phtrans",path_home,mbrola_voice); | |||||
| if((f_out = fopen(buf,"wb")) == NULL) | |||||
| { | |||||
| wxLogError(_T("Can't write to: ")+wxString(buf,wxConvLocal)); | |||||
| return; | |||||
| } | |||||
| data[count].name = 0; // list terminator | |||||
| Write4Bytes(f_out, mbrola_ctrl); | |||||
| pw_end = (int *)(&data[count+1]); | |||||
| for(pw = (int *)data; pw < pw_end; pw++) | |||||
| { | |||||
| Write4Bytes(f_out, *pw); | |||||
| } | |||||
| fclose(f_out); | |||||
| wxLogStatus(_T("Mbrola translation file: %d phonemes"),count); | |||||
| } // end of CompileMbrola | |||||
| static const char *preset_tune_names[] = { | static const char *preset_tune_names[] = { | ||||
| "s1", "c1", "q1", "e1", NULL}; | "s1", "c1", "q1", "e1", NULL}; |
| extern void init_z(); | extern void init_z(); | ||||
| extern void CompilePhonemeData(void); | extern void CompilePhonemeData(void); | ||||
| extern void CompileSampleRate(void); | extern void CompileSampleRate(void); | ||||
| extern void CompileMbrola(const wxChar *mbrola_file = NULL); | |||||
| extern "C" void CompileMbrola(const char *mbrola_file); | |||||
| extern void CompileIntonation(); | extern void CompileIntonation(); | ||||
| extern void InitSpectrumDisplay(); | extern void InitSpectrumDisplay(); | ||||
| extern void InitProsodyDisplay(); | extern void InitProsodyDisplay(); | ||||
| break; | break; | ||||
| case MENU_COMPILE_MBROLA: | case MENU_COMPILE_MBROLA: | ||||
| CompileMbrola(); | |||||
| { | |||||
| wxString filepath = wxFileSelector(_T("Read Mbrola phonemes file"),path_phsource+_T("/mbrola"),_T(""),_T(""),_T("*"),wxOPEN); | |||||
| CompileMbrola(filepath.mb_str(wxConvLocal)); | |||||
| } | |||||
| break; | break; | ||||
| case MENU_COMPILE_INTONATION: | case MENU_COMPILE_INTONATION: |
| /*************************************************************************** | |||||
| * Copyright (C) 2005 to 2014 by Jonathan Duddington * | |||||
| * email: [email protected] * | |||||
| * Copyright (C) 2013-2015 Reece H. Dunn * | |||||
| * * | |||||
| * This program is free software; you can redistribute it and/or modify * | |||||
| * it under the terms of the GNU General Public License as published by * | |||||
| * the Free Software Foundation; either version 3 of the License, or * | |||||
| * (at your option) any later version. * | |||||
| * * | |||||
| * This program is distributed in the hope that it will be useful, * | |||||
| * but WITHOUT ANY WARRANTY; without even the implied warranty of * | |||||
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * | |||||
| * GNU General Public License for more details. * | |||||
| * * | |||||
| * You should have received a copy of the GNU General Public License * | |||||
| * along with this program; if not, see: * | |||||
| * <http://www.gnu.org/licenses/>. * | |||||
| ***************************************************************************/ | |||||
| #include <stdio.h> | |||||
| #include <unistd.h> | |||||
| #include "speak_lib.h" | |||||
| #include "phoneme.h" | |||||
| #include "speech.h" | |||||
| #include "synthesize.h" | |||||
| static unsigned int StringToWord(const char *string) | |||||
| { | |||||
| // Pack 4 characters into a word | |||||
| int ix; | |||||
| unsigned char c; | |||||
| unsigned int word; | |||||
| if(string==NULL) | |||||
| return(0); | |||||
| word = 0; | |||||
| for(ix=0; ix<4; ix++) | |||||
| { | |||||
| if(string[ix]==0) break; | |||||
| c = string[ix]; | |||||
| word |= (c << (ix*8)); | |||||
| } | |||||
| return(word); | |||||
| } | |||||
| void CompileMbrola(const char *filepath) | |||||
| { | |||||
| char *p; | |||||
| FILE *f_in; | |||||
| FILE *f_out; | |||||
| int percent; | |||||
| int n; | |||||
| int *pw; | |||||
| int *pw_end; | |||||
| int count = 0; | |||||
| int control; | |||||
| char phoneme[40]; | |||||
| char phoneme2[40]; | |||||
| char name1[40]; | |||||
| char name2[40]; | |||||
| char mbrola_voice[40]; | |||||
| char buf[sizeof(path_home)+30]; | |||||
| int mbrola_ctrl = 20; // volume in 1/16 ths | |||||
| MBROLA_TAB data[N_PHONEME_TAB]; | |||||
| strcpy(buf,filepath); | |||||
| if((f_in = fopen(buf,"r")) == NULL) | |||||
| { | |||||
| fprintf(stderr, "Can't read: %s\n", filepath); | |||||
| return; | |||||
| } | |||||
| while(fgets(buf,sizeof(phoneme),f_in) != NULL) | |||||
| { | |||||
| buf[sizeof(phoneme)-1] = 0; | |||||
| if((p = strstr(buf,"//")) != NULL) | |||||
| *p = 0; // truncate line at comment | |||||
| if(memcmp(buf,"volume",6)==0) | |||||
| { | |||||
| mbrola_ctrl = atoi(&buf[6]); | |||||
| continue; | |||||
| } | |||||
| n = sscanf(buf,"%d %s %s %d %s %s",&control,phoneme,phoneme2,&percent,name1,name2); | |||||
| if(n >= 5) | |||||
| { | |||||
| data[count].name = StringToWord(phoneme); | |||||
| if(strcmp(phoneme2,"NULL")==0) | |||||
| data[count].next_phoneme = 0; | |||||
| else | |||||
| if(strcmp(phoneme2,"VWL")==0) | |||||
| data[count].next_phoneme = 2; | |||||
| else | |||||
| data[count].next_phoneme = StringToWord(phoneme2); | |||||
| data[count].mbr_name = 0; | |||||
| data[count].mbr_name2 = 0; | |||||
| data[count].percent = percent; | |||||
| data[count].control = control; | |||||
| if(strcmp(name1,"NULL")!=0) | |||||
| data[count].mbr_name = StringToWord(name1); | |||||
| if(n == 6) | |||||
| data[count].mbr_name2 = StringToWord(name2); | |||||
| count++; | |||||
| } | |||||
| } | |||||
| fclose(f_in); | |||||
| strcpy(mbrola_voice,basename(filepath)); | |||||
| sprintf(buf,"%s/mbrola_ph/%s_phtrans",path_home,mbrola_voice); | |||||
| if((f_out = fopen(buf,"wb")) == NULL) | |||||
| { | |||||
| fprintf(stderr, "Can't write to: %s\n", buf); | |||||
| return; | |||||
| } | |||||
| data[count].name = 0; // list terminator | |||||
| Write4Bytes(f_out, mbrola_ctrl); | |||||
| pw_end = (int *)(&data[count+1]); | |||||
| for(pw = (int *)data; pw < pw_end; pw++) | |||||
| { | |||||
| Write4Bytes(f_out, *pw); | |||||
| } | |||||
| fclose(f_out); | |||||
| fprintf(stdout, "Mbrola translation file: %d phonemes", count); | |||||
| } |