💾 Archived View for tilde.pink › ~ssb22 › lexconvert.gmi captured on 2022-06-03 at 23:34:32. Gemini links have been rewritten to link to archived content

View Raw

More Information

⬅️ Previous capture (2022-01-08)

➡️ Next capture (2023-01-29)

🚧 View Differences

-=-=-=-=-=-=-

lexconvert: a converter for phoneme codes and lexicon formats

As a person with limited vision, I often use speech synthesis software to read things.  Some uncommon words (such as names and places in literature) are pronounced wrongly by speech synthesizers, but if the synthesizer has a user-controlled pronunciation dictionary (lexicon) then this can be used to correct its pronunciation where necessary.  However, if you move to a different speech synthesizer, you may find the lexicon format is different. 

To help, here is a Python program that converts between different codes for English phonemes and between lexicon files.  It supports quite a few, and there is information in the Python file about how to add your own. It works in both Python 2 and Python 3.

Download lexconvert.py; usage information is below.

lexconvert.py

lexconvert v0.35

convert phonemes between different speech synthesizers etc

(c) 2007-22 Silas S. Brown. License: Apache 2

Available pronunciation formats:

acapela-uk - Acapela-optimised X-SAMPA for UK English voices (e.g. “Peter”), contributed by Jan Weiss

amiga - AmigaOS speech synthesizer (American English)

android-pico - X-SAMPA phonemes for the default “Pico” voice in Android (1.6+, American), wrapped in Java code

apollo - Dolphin Apollo 2 serial-port and parallel-port hardware synthesizers (in case anybody still uses those)

audapter - Audapter Speech System, an old hardware serial/parallel-port synthesizer (American English)

bbcmicro - BBC Micro Speech program from 1985 (see comments in lexconvert.py for more details)

bbcmicro-cc - Computer Concepts Speech ROM which provided phonemes for the BBC Micro’s TMS5220 “speech chip” add-on (less widely sold than the software-only product)

braille-ipa - IPA symbols in Braille (2008 BANA standard). By default Braille ASCII is output; if you prefer to see the Braille dots via Unicode, set the BRAILLE_UNICODE environment variable.

cepstral - Cepstral’s British English SSML phoneset

cheetah - Allophone codes for the 1983 “Cheetah Sweet Talker” SP0256-based hardware add-on for ZX Spectrum and BBC Micro home computers. The conversion from phonemes to allophones might need tweaking.

cmu - format of the US-English Carnegie Mellon University Pronouncing Dictionary, contributed by Jan Weiss

dectalk - DECtalk hardware synthesizers (American English)

deva-approx - Rough approximation using Devanagari (for getting Indian computer voices to speak some English words; works with some words better than others); can also be used to approximate Devanagari words in English phonemes

doubletalk - DoubleTalk PC/LT serial-port hardware synthesizers (American English; assumes DOS driver by default, otherwise set DTALK_COMMAND_CODE to your current command-code binary value, e.g. export DTALK_COMMAND_CODE=1)

espeak - eSpeak’s default British voice

example - A small built-in example lexicon for testing when you don’t have your full custom lexicon to hand. Use --convert to write it in one of the other formats and see if a synth can import it.

festival - Festival’s British voice

festival-cmu - American CMU version of Festival

kana-approx - Rough approximation using kana (for getting Japanese computer voices to speak some English words; works with some words better than others). Set KANA_TYPE environment variable to hiragana or katakana (which can affect the sounds of some voices); default is hiragana

keynote - Phoneme-read and lexicon-add codes for Keynote Gold hardware synthesizers (American English)

latex-ipa - IPA symbols for typesetting in LaTeX using the “tipa” package

mac - approximation in American English using the [[inpt PHON]] notation of Apple’s US voices

mac-uk - Scansoft/Nuance British voices in Mac OS 10.7+ (system lexicon editing required, see --mac-uk option)

names - Lexconvert internal phoneme names (sometimes useful with the --phones option while developing new formats)

pinyin-approx - Rough approximation using roughly the spelling rules of Chinese Pinyin (for getting Chinese-only voices to speak some English words; works with some words better than others)

rsynth - rsynth text-to-speech C library (American English)

sam - Software Automatic Mouth (1982 American English synth that ran on C64, Atari 400/800/etc and Apple II/etc)

sapi - Microsoft Speech API (American English)

speakjet - Allophone codes for the American English “SpeakJet” speech synthesis chip (the conversion from phonemes to allophones might need tweaking). Set the SPEAKJET_SYM environment variable to use mnemonics, otherwise numbers are used (set SPEAKJET_BINARY for binary output).

unicode-ipa - IPA symbols in Unicode, as used by an increasing number of dictionary programs, websites etc

unicode-ipa-syls - Like unicode-ipa but with syllable separators preserved

unicode-rough - A non-standard notation that’s reminiscent of unicode-ipa but changed so that more of the characters show in old browsers with incomplete fonts

vocaloid - X-SAMPA phonemes for Yamaha’s Vocaloid singing synthesizer. Contributed by Lorenzo Gatti, who tested in Vocaloid 4 using two American English voices.

x-sampa - General X-SAMPA notation, contributed by Jan Weiss

yinghan - As unicode-ipa but, when converting a user lexicon, generates Python code that reads Wenlin Yinghan dictionary entries and adds IPA bands to matching words

Program options:

E.g.: python lexconvert.py --convert festival cepstral

E.g.: python lexconvert.py --parens unicode-ipa This is a test sentence.

Beware, the considerations about eSpeak versions that apply to --ruby also apply here.

E.g.: python lexconvert.py --phones unicode-ipa This is a test sentence.

Set environment variable PHONES_PIPE_COMMAND to an additional command to which to write the phones as well as standard output. (If standard input is a terminal then this will be done separately after each line.)

(Some commercial speech synthesizers do not work well when driven entirely from phonemes, because their internal format is different and is optimised for normal text.)

Set format to ‘all’ if you want to see the phonemes in *all* supported formats.

E.g.: python lexconvert.py --ruby unicode-ipa This is a test sentence.

This option is made more complicated by the fact that different versions of eSpeak may space the phoneme output differently, for example when handling numbers; if your eSpeak version is not recognised then all numbers are unannotated. Anyway you are advised not to rely on this option working with the new development NG versions of eSpeak. If the version you have behaves unexpectedly, words and phonemes output might lose synchronisation. However this option is believed to be stable when used with simple text and the original eSpeak.

You can optionally set the RUBY_GRADINT_CGI environment variable to the URL of an instance of Gradint Web Edition to generate audio links for each word. If doing this in a Web Adjuster filter, see comments in the lexconvert source for setup details.

(Requires the ‘espeak’ command.)

E.g.: python lexconvert.py --try festival h @0 l ou1

or: python lexconvert.py --try unicode-ipa '\u02c8\u0279\u026adn\u0329' (for Unicode put '\uNNNN' or UTF-8)

You need to specify the location of the OALD file in <location>,

e.g. for Debian festlex-oald package: python lexconvert.py --festival-dictionary-to-espeak /usr/share/festival/dicts/oald/all.scm

or if you can’t install the Debian package, try downloading http://ftp.debian.org/debian/pool/non-free/f/festlex-oald/festlex-oald_1.4.0.orig.tar.gz, unpack it into /tmp, and do: python lexconvert.py --festival-dictionary-to-espeak /tmp/festival/lib/dicts/oald/oald-0.4.out

In all cases you need to cd to the eSpeak source directory before running this. en_extra will be overwritten. Converter will also read your ~/.festivalrc if it exists. (You can later incrementally update from ~/.festivalrc using the --convert option; the entries from the system dictionary will not be overwritten in this case.) Specify --without-check to bypass checking the existing eSpeak pronunciation for OALD entries (much faster, but makes a larger file and in some cases compromises the pronunciation quality).

Legal

All material © Silas S. Brown unless otherwise stated. Android is a trademark of Google LLC. Apache is a registered trademark of The Apache Software Foundation. Apple is a trademark of Apple Inc. Cepstral is a trademark and brand of Cepstral, LLC. Debian is a trademark owned by Software in the Public Interest, Inc. DECtalk is a trademark of Fonix Corporation. Java is a registered trademark of Oracle Corporation in the US and possibly other countries. Mac is a trademark of Apple Inc. Microsoft is a registered trademark of Microsoft Corp. Python is a trademark of the Python Software Foundation. ScanSoft and Nuance are trademarks of Nuance Communications, Inc. TeX is a trademark of the American Mathematical Society. Unicode is a registered trademark of Unicode, Inc. in the United States and other countries. Vocaloid is a trademark of Yamaha Corporation. Wenlin is a trademark of Wenlin Institute, Inc. SPC. Yamaha is a trademark of Yamaha Corporation. Any other trademarks I mentioned without realising are trademarks of their respective holders.