Added ResetLetterBits() to clear data before using SetLetterBits(). git-svn-id: https://espeak.svn.sourceforge.net/svnroot/espeak/trunk@19 d46cf337-b52f-0410-862d-fd96e6ae7743master
@@ -307,3 +307,16 @@ oi ong ou u ui yu | |||
b c d f g h j k | |||
l m n N p r s t | |||
tS v w z | |||
Dictionary is_dict | |||
& @- a aI aU e E eI | |||
i I o O oU u W y | |||
Yy | |||
* : ; b c C d D | |||
f g h j J k l L | |||
l# m m# n N n# N# n^ | |||
n^# p Q r r# s S t | |||
T tl# v x z |
@@ -6,7 +6,8 @@ | |||
// Α α, Β β, Γ γ, Δ δ, Ε ε, Ζ ζ, Η η, Θ θ, Ι ι, Κ κ, Λ λ, Μ μ, Ν ν, Ξ ξ, | |||
// Ο ο, Π π, Ρ ρ, Σ σ ς (word-final form), Τ τ, Υ υ, Φ φ, Χ χ, Ψ ψ, Ω ω. | |||
// Y: ε η ι υ (+tonos variants, front vowels). | |||
// Letter group B: θ κ ξ π ς σ τ φ χ (voiceless consonants) | |||
// Letter group Y: ε η ι υ έ ή ί ύ (front vowels). | |||
.group α | |||
@@ -43,6 +44,7 @@ | |||
δ D | |||
δ (δ | |||
.group ε | |||
ε e | |||
ει i |
@@ -30,7 +30,7 @@ | |||
el 8 112 | |||
sv 25 114 | |||
no 29 118 | |||
is 27 113 | |||
is 32 117 | |||
vi 41 129 | |||
zh_yue 32 120 | |||
sw 14 101 | |||
@@ -143,6 +143,7 @@ | |||
1 n^/_n^ base | |||
1 n^/n^_ base | |||
1 n^/n^@ base | |||
1 n^/n^#_ is | |||
6 n/_n base ro | |||
3 n/n_ base ro | |||
1 n/n@ base | |||
@@ -233,13 +234,14 @@ | |||
1 ufric/sx_sv sv | |||
1 ufric/th base | |||
1 ufric/th_ base | |||
1 ufric/tl# is | |||
2 ufric/x base vi | |||
4 ufric/x2 af nl pt | |||
1 ufric/x_hr hr | |||
1 ustop/c base | |||
5 ustop/k base en fr hi sw | |||
9 ustop/k_ base en fi fr hi hu it el sw | |||
11 ustop/ki base en af fi fr hi hu it sw | |||
12 ustop/ki base en af fi fr hi hu it is sw | |||
10 ustop/kl base en fi fr hi hu it el sw | |||
11 ustop/kr base en fi fr hi hu it el sw | |||
9 ustop/k_unasp base fi hi hu it el | |||
@@ -339,7 +341,7 @@ | |||
2 vdiph/ooi_3 en_wm hr | |||
2 vdiph/ou fi zh_yue | |||
2 vdiph/ou_2 sk ro | |||
1 vdiph/ou_3 is | |||
2 vdiph/ou_3 is | |||
1 vdiph/@u en_wm | |||
1 vdiph/@u_2 en_rp | |||
1 vdiph/@u_3 ro | |||
@@ -386,8 +388,8 @@ | |||
2 voc/Q base | |||
4 voc/Q_ base nl pt | |||
2 voc/Q_less nl pt | |||
5 voc/v base fi hi nl ro | |||
6 voc/v_ base fi hi nl ro | |||
6 voc/v base fi hi nl ro is | |||
7 voc/v_ base fi hi nl ro is | |||
4 vocw/dh base es | |||
2 vocw/Q base | |||
3 vocw/Q_ base nl | |||
@@ -606,8 +608,8 @@ | |||
20 x/b base hi ro is | |||
2 x/b_ base is | |||
9 x/d base hi hr el is | |||
15 x/d_ base fi fr hi hu pl hr ru it ro el is ++ | |||
22 x/d_dnt base fi fr hi hu pl ru it ro sw | |||
14 x/d_ base fi fr hi pl hr ru it ro el is sw | |||
23 x/d_dnt base fi fr hi hu pl ru it ro sw | |||
6 x/d_pzd pl ru | |||
3 x/dzh base hi | |||
5 x/dzh_ base hi ru |
@@ -135,7 +135,7 @@ phoneme d // dental variant of /d/ | |||
vowelin f1=2 f2=1500 -300 300 f3=-150 80 | |||
vowelout f1=2 f2=1500 -300 300 f3=-150 80 | |||
formants d/d+x/d_dnt%110 | |||
before _ d/d_+x/d_ | |||
before _ d/d_+x/d_dnt%80 | |||
before r d/dr+x/d_dnt%110 | |||
after _ NULL | |||
after @ d/xd |
@@ -629,6 +629,21 @@ void SetLetterVowel(Translator *tr, int c) | |||
tr->letter_bits[c] = 0x81; // group 0 only | |||
} | |||
void ResetLetterBits(Translator *tr, int groups) | |||
{//============================================= | |||
// Clear all the specified groups | |||
unsigned int ix; | |||
unsigned int mask; | |||
mask = ~groups; | |||
for(ix=0; ix<sizeof(tr->letter_bits); ix++) | |||
{ | |||
tr->letter_bits[ix] &= mask; | |||
} | |||
} | |||
void SetLetterBits(Translator *tr, int group, const char *string) | |||
{//============================================================== | |||
int bits; |
@@ -916,6 +916,7 @@ void TestTest(int control) | |||
unsigned int ix=0; | |||
char textbuf[2000]; | |||
espeak_VOICE voice; | |||
espeak_VOICE *voice2; | |||
//FindPhonemesUsed(); | |||
//return; | |||
@@ -956,7 +957,10 @@ if(control==2) | |||
voice.gender = 0; | |||
voice.age = 0; | |||
voice.variant = 0; | |||
espeak_SetVoiceByName("en"); | |||
ix = espeak_SetVoiceByName("pt-xx"); | |||
voice2 = espeak_GetCurrentVoice(); | |||
// espeak_SetVoiceByProperties(&voice); | |||
espeak_SetParameter(espeakRANGE,0,0); | |||
espeak_Synth(textbuf,ix+1,0,POS_CHARACTER,0,espeakCHARS_8BIT+espeakSSML,NULL,NULL); |
@@ -35,7 +35,7 @@ | |||
#include "translate.h" | |||
#include "wave.h" | |||
const char *version_string = "1.25.02 21.May.07"; | |||
const char *version_string = "1.25.03 22.May.07"; | |||
const int version_phdata = 0x012501; | |||
int option_device_number = -1; |
@@ -653,7 +653,7 @@ static void SmoothSpect(void) | |||
modified = 0; | |||
if(frame->frflags & FRFLAG_FORMANT_RATE) | |||
len = (len * 13)/10; // allow slightly greater rate of change for this frame (was 12/10) | |||
len = (len * 12)/10; // allow slightly greater rate of change for this frame (was 12/10) | |||
for(pk=0; pk<6; pk++) | |||
{ |
@@ -122,8 +122,8 @@ Translator *SelectTranslator(const char *name) | |||
// character codes offset by 0x380 | |||
static const char el_vowels[] = {0x10,0x2c,0x2d,0x2e,0x2f,0x30,0x31,0x35,0x37,0x39,0x3f,0x45,0x49,0x4a,0x4b,0x4c,0x4d,0x4e,0x4f,0}; | |||
static const char el_fvowels[] = {0x2d,0x2e,0x2f,0x35,0x37,0x39,0x45,0x4d,0}; | |||
static const char el_voiceless[]= {0x38,0x3a,0x3f,0x40,0x42,0x43,0x44,0x46,0x47,0}; | |||
static const char el_fvowels[] = {0x2d,0x2e,0x2f,0x35,0x37,0x39,0x45,0x4d,0}; // ε η ι υ έ ή ί ύ | |||
static const char el_voiceless[]= {0x38,0x3a,0x3e,0x40,0x42,0x43,0x44,0x46,0x47,0}; // θ κ ξ π ς σ τ φ χ | |||
static const char el_consonants[]={0x32,0x33,0x34,0x36,0x38,0x3a,0x3b,0x3c,0x3d,0x3e,0x40,0x41,0x42,0x43,0x44,0x46,0x47,0x48,0}; | |||
static const wchar_t el_char_apostrophe[] = {0x3c3,0}; // σ | |||
@@ -259,6 +259,8 @@ Translator *SelectTranslator(const char *name) | |||
tr->letter_bits_offset = OFFSET_DEVANAGARI; | |||
tr->langopts.replace_chars = replace_chars_hi; | |||
tr->langopts.replacement_chars = replacement_chars_hi; | |||
memset(tr->letter_bits,0,sizeof(tr->letter_bits)); | |||
SetLetterBitsRange(tr,LETTERGP_A,0x06,0x14); // vowel letters | |||
SetLetterBitsRange(tr,LETTERGP_B,0x3e,0x4d); // vowel signs + virama | |||
SetLetterBitsRange(tr,LETTERGP_C,0x15,0x39); // the main consonant range | |||
@@ -311,7 +313,7 @@ Translator *SelectTranslator(const char *name) | |||
case L('h','u'): // Hungarian | |||
{ | |||
static int stress_amps_hu[8] = {16,16, 20,20, 20,24, 24,22 }; | |||
static int stress_lengths_hu[8] = {180,150, 200,180, 0,0, 230,270}; | |||
static int stress_lengths_hu[8] = {180,160, 200,180, 0,0, 230,270}; | |||
static const wchar_t replace_chars_hu[] = {0xd4,0xf4,0xdb,0xfb,0}; | |||
static const unsigned int replacement_chars_hu[] = {0x150,0x151,0x170,0x171,0}; // allow o,u-circumflex for o,u-double-acute | |||
@@ -322,7 +324,7 @@ Translator *SelectTranslator(const char *name) | |||
tr->langopts.replacement_chars = replacement_chars_hu; | |||
tr->langopts.stress_rule = 0; | |||
tr->langopts.stress_flags = 0x56; // move secondary stress from light to a following heavy syllable | |||
tr->langopts.stress_flags = 0x16; // move secondary stress from light to a following heavy syllable | |||
tr->langopts.param[LOPT_REGRESSIVE_VOICING] = 0x1; | |||
tr->langopts.param[LOPT_IT_DOUBLING] = 1; | |||
tr->langopts.long_stop = 130; | |||
@@ -336,14 +338,15 @@ Translator *SelectTranslator(const char *name) | |||
case L('i','s'): // Icelandic | |||
{ | |||
static int stress_amps_is[] = {16,16, 20,20, 20,24, 24,22 }; | |||
static int stress_lengths_is[8] = {180,140, 200,200, 0,0, 240,260}; | |||
static const wchar_t is_L08[] = {'c','f','h','k','p','s','t','x',0xfe,0}; // voiceless conants, including 'þ' | |||
static int stress_lengths_is[8] = {180,160, 200,200, 0,0, 240,260}; | |||
static const wchar_t is_L08[] = {'c','f','h','k','p','t','x',0xfe,0}; // voiceless conants, including 'þ' ?? 's' | |||
tr = new Translator(); | |||
SetupTranslator(tr,stress_lengths_is,stress_amps_is); | |||
tr->langopts.stress_rule = 1; | |||
tr->langopts.param[LOPT_IT_LENGTHEN] = 0x11; // remove lengthen indicator from unstressed vowels | |||
ResetLetterBits(tr,0x18); | |||
SetLetterBits(tr,4,"kpst"); // Letter group F | |||
SetLetterBits(tr,3,"jvr"); // Letter group H | |||
tr->letter_groups[8] = is_L08; | |||
@@ -502,6 +505,7 @@ Translator *SelectTranslator(const char *name) | |||
SetLetterVowel(tr,'y'); | |||
SetLetterVowel(tr,'r'); | |||
ResetLetterBits(tr,0x2); | |||
SetLetterBits(tr,5,sk_voiced); | |||
} | |||
break; |
@@ -504,6 +504,7 @@ int lookupwchar(const unsigned short *list,int c); | |||
int Eof(void); | |||
char *strchr_w(const char *s, int c); | |||
int IsBracket(int c); | |||
void ResetLetterBits(Translator *tr, int groups); | |||
void SetLetterBits(Translator *tr, int group, const char *string); | |||
void SetLetterBitsRange(Translator *tr, int group, int first, int last); | |||
void SetLetterVowel(Translator *tr, int c); |
@@ -1341,7 +1341,7 @@ espeak_ERROR SetVoiceByName(const char *name) | |||
} | |||
// first check for a voice with this filename | |||
if(LoadVoice(buf,1) != NULL) | |||
if((first_voice == NULL) && (LoadVoice(buf,1) != NULL)) | |||
{ | |||
voice_selected = first_voice; | |||