Linux下Festival离线语音合成

最近研究了下Linux下的语音合成,一般用的就是
espeak
festival
ekho
科大讯飞
其中espeak最古老,但是我的Ubuntu简单安装又没安装上,所以没研究,ekho我听了一下发音,感觉是断断续续的,也有可能是因为我听的是中文的原因,所以也放弃了,科大讯飞的倒是很好用,可惜要收费,而且2000台起步。最后就选择了festival,然后鼓捣了几天。
可能是资料比较老了,所以其中遇到换声音的问题解决了很久,后面终于找到另外一个方式去解决了,在听到女声的时候简直是泪流满面。

现在介绍一下简单的安装使用方法:

安装

$sudo apt-get install festival 

使用

$festival
festival 〉 (SayText "Hello World") //直接读字
festival 〉 (tts myfile) //如果是读文件里的

然后你就可以听到一个美国的男声发音了。
接下来,如果你想听女声发音,怎么办?

换发音人

新建一个文件夹

mkdir us1  
cd us1

下载资源文件

wget http://www.speech.cs.cmu.edu/cmu_arctic/packed/cmu_us_slt_arctic-0.95-release.tar.bz2

当然如果你想换其他发音人,http://www.speech.cs.cmu.edu/cmu_arctic/packed/去这里找

解压,并放置资源文件

tar xf cmu_us_slt_arctic-0.95-release.tar.bz2
sudo mv cmu_us_slt_arctic /usr/share/festival/voices/english/cmu_us_slt_arctic_clunits

修改默认发音人

sudo vi /etc/festival.scm

然后在最下面添加

(set! voice_default 'voice_cmu_us_slt_arctic_clunits)

注意这里不是

'voice_cmu_us_slt_arctic_clunits’

不要想太多。

现在试试

$festival
festival 〉 (SayText "Hello World")

是不是变成女声了?

简单的试了一下跑C程序

#include
main(){
    system("festival --tts 'text'");//读当前目录下text文件夹
}

新建一个叫text的文件,里面写上Hello World。

编译运行,OK!

你可能感兴趣的:(Linux)