Synthesizing Voice From the Command Line
I don't do a lot of audio/video stuff with my system, but the other day I had the urge to see if there was some voice synthesis software available on Linux and it turned out that I already had it installed: it's called Festival. Turns out there are a number of voice synthesis and analysis packages available.
Festival is, according to the website:
Festival offers a general framework for building speech synthesis systems as well as including examples of various modules. As a whole it offers full text to speech through a number APIs: from shell level, though [sic] a Scheme command interpreter, as a C++ library, from Java, and an Emacs interface. Festival is multi-lingual (currently English (British and American), and Spanish) though English is the most advanced.
As far as simple commands, Festival comes with two: saytime and text2wave. Saytime does what you would expect, it speaks the time (as well as outputting the spoken text to stdout). Note though, the time that is output tends to be less than specific:
$ saytime
The time is now, just after half past 10, in the morning.
A wave file of the output is attached (time.wav).
The second command that comes with Festival is text2wave which converts text read from stdin to a .wav file output:
$ echo Your job has completed | text2wave >job.wav
$ aplay job.wav
# OR
$ echo Your job has completed | text2wave | aplay
The wave file is attached (job.wav).
If these commands do not exist on your system you will need to install the festival package. For other voice related packages search the web or check the list here on linux-sound.org
| Attachment | Size |
|---|---|
| job.wav | 58.8 KB |
| time.wav | 140.98 KB |
Mitch Frazier is an Associate Editor for Linux Journal and the Web Editor for linuxjournal.com.










This week 5 lucky Members will receive a copy of The Official Ubuntu Server Book by Benjamin Mako Hill and Linux Journal's very own Kyle Rankin. No entry necessary. Check back here early next week to find out who the lucky Online Members are.




Comments
Festival voice synthesis software
Hey,
I've been using Festival for 2 years. I use it mainly to get other people's attention. It's easy, it's fun and it's no hassle to install on Mandriva 2008.
Commercial text to speech for Linux
Cepstral is very good and has Linux versions that work well. However, it is not free. I found the voices to be much better quality than festival.
http://cepstral.com/
espeak
espeak is another great program for Synthesizing Voice From the Command Line.
To read a string:
$ espeak "Hello World"
or to read a text file:
$ espeak -f text.txt
To save the output it a WAV file:
$ espeak "Hello World" -w my.wav
It has other options to (Voice, speed, pitch)
Not that one way is better then the other. I just wanted to show that there is another way to do it.
http://www.bashscripts.info/
Learn to Take Control of Your Computer, NOW!!!
eSpeak
Ubuntu comes with eSpeak by default. I find that it sounds much better than Festival and I can listen to it for much longer. Orca, which is the screen reader I use on Ubuntu speaks through either speech-dispatcher or gnome-speech, both of which have an eSpeak driver. The comment to which I am replying gives good instructions for how to create a .wav file with eSpeak from the command line.
Post new comment