【CentOS 7】 Open JTalkをインストールしてみた
概要
Slackに書き込んだメッセージをOpen JTalkでBotにしゃべらせたい!!
この記事を読んで完全に影響を受けましたね。
調べてみると多くの先人方がRaspberry Piで実装してますが、残念ながら持っていないので手元にあったCentOSにOpen JTalkをインストールしてみます。
入力された日本語テキストに基づいて自由な音声を生成するHMMテキスト音声合成システム
http://open-jtalk.sp.nitech.ac.jp
こちらのサイトを参考にさせていただき、バージョンを変えるだけで簡単にできました!*1
パッケージ管理にporg
porgというパッケージ管理ツールがあると良さそうなので、まずはこちらを参考にインストールしてみます。
ダウンロード
以下からporg-0.10.tar.gzをダウンロード。ちなみに以降のファイルのダウンロードはすべて/home/{user}/ダウンロードへ行い、ここを起点とします。
https://sourceforge.net/projects/porg/files/
インストール
/usr/local/src/へ解凍し、管理者権限でインストール。
# tar zxf ./porg-0.10.tar.gz -C /usr/local/src/ # cd /usr/local/src/porg-0.10/ # ./configure --prefix=/usr/local --disable-grop # make # make install
hts-engine api
次にOpen JTalkの実行環境としてhts_engine APIというものが必要らしいので用意。
ダウンロード
以下からhts_engine_API-1.10.tar.gzをダウンロード。
https://sourceforge.net/projects/hts-engine/files/hts_engine%20API/
インストール
解凍して、ビルド。
$ tar zxvf hts_engine_API-1.10.tar.gz -C ~/src/open_jtalk/ $ cd /home/{user}/src/open_jtalk/hts_engine_API-1.10 $ ./configure $ make
先ほど入れたパッケージ管理ツール『porg』でインストール。progと何度かタイプミスして実行しちゃったのでここ注意ね!
$ sudo /usr/local/bin/porg -lp hts_engine_api-1.10 "make install" $ sudo /usr/local/bin/porg -f hts_engine_api-1.10 hts_engine_api-1.10: /usr/local/bin/hts_engine /usr/local/include/HTS_engine.h /usr/local/lib/libHTSEngine.a
Open JTalk
ようやく本命です。ここまで時間はそれなりにかかってますがあと一息!
ダウンロード
以下からopen_jtalk-1.09.tar.gzをダウンロード。
https://sourceforge.net/projects/open-jtalk/files/Open%20JTalk/
インストール
解凍してビルド。
$ tar zxvf open_jtalk-1.09.tar.gz -C /home/{user}/src/open_jtalk/ $ cd /home/{user}/src/open_jtalk/open_jtalk-1.09 $ ./configure --with-charset=UTF-8 $ make
porgでインストール。
$ sudo /usr/local/bin/porg -lp open_jtalk-1.09 "make install" $ sudo /usr/local/bin/porg -f open_jtalk-1.09 open_jtalk-1.09: /usr/local/bin/open_jtalk /usr/local/dic/char.bin /usr/local/dic/matrix.bin /usr/local/dic/sys.dic /usr/local/dic/unk.dic
必要なファイル
あとは終わったも同然。辞書と音声ファイルが必要ということでそれぞれのディレクトリを用意。
# mkdir /usr/local/share/open_jtalk # mkdir /usr/local/share/hts_voice
辞書
以下よりopen_jtalk_dic_utf_8-1.09.tar.gzをダウンロード。
https://sourceforge.net/projects/open-jtalk/files/Dictionary/open_jtalk_dic-1.09/
用意した辞書用ディレクトリに解凍。
# tar zxvf open_jtalk_dic_utf_8-1.09.tar.gz -C /usr/local/share/open_jtalk/
音声ファイル
以下よりhts_voice_nitech_jp_atr503_m001-1.05.tar.gzをダウンロード。
https://sourceforge.net/projects/open-jtalk/files/HTS%20voice/hts_voice_nitech_jp_atr503_m001-1.05/
用意した音声ファイル用ディレクトリに解凍。
# tar zxvf hts_voice_nitech_jp_atr503_m001-1.05.tar.gz -C /usr/local/share/hts_voice/
しゃべらせる
すべての準備が整いました。
text.txtを作成しUTF-8で保存。
ワタシ日本語チョットデキル
open_jtalkに辞書、音声ファイルを指定して、テキストファイルをwav形式に変換します。カレントディレクトリにoutput.wavができてればOK♪
$ open_jtalk -m /usr/local/share/hts_voice/hts_voice_nitech_jp_atr503_m001-1.05/nitech_jp_atr503_m001.htsvoice -ow output.wav -x /usr/local/share/open_jtalk/open_jtalk_dic_utf_8-1.09/ text.txt
再生
$ aplay output.wav
できたーヾ(*´∀`*)ノ
次はSlackと連携させてみるぞい!
*1:詳細は参考サイト様をご覧ください!