ども。こんばんは。
続いては、GCP周りです。
これもガイドには載っていますが、ガイドの画面キャプチャがちっちゃいのでこちらでも紹介したいと思います。
今回はGoogle Assitant APIを使うためにGoogle Cloud Platformにサインアップして、新しいプロジェクトの作成やAPIキーを取得します。
取得したAPIキーをAIY Voice Kitにコピーしてサンプルを動作するところまでをやります。
まずはGCPのコンソール(https://console.cloud.google.com/)にアクセスします。
私は初利用だったので、規約の同意とかが出てきました。
※Googleのアカウントはすでに持っていたモノを使っています。
新しいプロジェクトを作成します。
任意ですが「AIY Voice Kit」とかにしてみました。
できました。
作成されたプロジェクトが選ばれていることを確認して「API & Services」のダッシュボードに移動します。
Google Assistant APIを検索します。
APIを有効します。
有効化できたらこんな感じになります。
※「認証情報の作成」っていうボタンを押したくなるのですが一旦我慢します。
こんな感じで、左側の「認証情報」を選択して「OAuth同意画面」を設定します。
ユーザに表示するサービ名は最後に出てきます。
※それ以外はメールアドレスのみ入力しましたが多分大丈夫。。
で、次左のタブに移動してOAuthのクライアントIDとクライアントシークレットを作成します。
クライアントの種別とかを設定します。
今回はその他にして手打ちで入力しました。
作成を押した後ポップアップでIDとシークレットが表示されますが後でダウンロードできます。
出来上がったものをダウンロード(JSON形式)します。
ここまででGCP上での操作は一旦終了!
次にGoogle Assistant関連のアクティビティの設定をします。
これ結構重要みたいです。
実際にAssistantを使いたいGoogleアカウントでアクティビティの管理(https://myaccount.google.com/activitycontrols)にアクセスします。
以下のアクティビティを有効にします。(私は全部有効になっていました。)
- ウェブとアプリのアクティビティ
- Chrome の閲覧履歴と Google サービスを使用するウェブサイトやアプリでのアクティビティを含める
※↑これにチェック入ってないと一辺倒な応答しか返さない?らしい。
- Chrome の閲覧履歴と Google サービスを使用するウェブサイトやアプリでのアクティビティを含める
- 端末情報
- 音声アクティビティ
- イメージはこんなかんじ。
では、いよいよAIY Voice Kitを使います!
ダウンロードしてたJSONファイルを転送します。
ダウンロードしたJSONファイルをAIY Voice Kitにアップロードします。
※ダウンロードした状態だと「client_secret_****」という名前のはず。
アップロード後以下のファイル名にリネームします。
/home/pi/assistant.json
ここまでで準備完了。
いよいよサンプルプログラムを実行するのですが、私はSSH環境でやっています。
HDMIでディスプレイに繋いでいれば、AIY用のターミナルがあるようですが、SSH経由だと環境変数などを一旦読み込む必要があります。
こんな感じ。(piユーザでログイン後に実行)
pi@hoge~ $ cd AIY-voice-kit-python/
pi@hoge:~/AIY-voice-kit-python $ source env/bin/activate
(env) pi@hoge:~/AIY-voice-kit-python $
じゃぁOK Googleなやつ言ってみますか!
(env) pi@hoge:~/AIY-voice-kit-python $ src/assistant_library_demo.py
※初回は以下のようにアカウントの同意?を求めるURLが出る模様です。ディスプレイとか繋いでるとブラウザが立ち上がってたのかも?
とりあえず普通にURLをコピーして(別の端末でもいいので)アクセスします。
アカウントの選択が出てきます。
アクセスを許可します。
コードが出てくるのでこれをSSHに戻って貼り付けます。
これで喋るはずです。
OK google!
(ボタンが光ります!おおお!)
今日の天気は♪
You are welcome!
・・・You are welcome?
!?
・・・あれ?
あ、こいつ英語しかしゃべれないんだった・・・
ということでこうなりました。
※こっ恥ずかしいので、私の声はカット済み。ハウアーユーとネイティブジャパニーズで喋りかけました。
あと、音でかい・・・。
音量(ボリューム)の調節はこちらが参考になりました。
Voice Kitで自作GoogleHomeを作る際に付け足したこと
$ sudo amixer -M #←ミキサーの名前を確認
$ sudo amixer set Master 70% #←音をちっちゃく。
Simple mixer control ‘Master’,0
Capabilities: volume
Playback channels: Front Left – Front Right
Capture channels: Front Left – Front Right
Limits: 0 – 255
Front Left: 179 [70%]
Front Right: 179 [70%]
起動時に小さくする用にしたほうがいいですね。
日本語の件は、一応つい最近Assistant SDKが多言語対応したみたい?ですね。
Google、「Google Assistant SDK」を日本語対応などの新機能でアップデート
あと、先駆者の方がいらっしゃいましたが、いわゆるGoogle Homeのようにはなかなかいかない模様ですね。。。
AIYスピーカーを、ほぼ日本語版Google Homeに【Google Assistant SDアップデート】
と、とりあえず動いた!!!
次回は・・・。。。うーん。どうしましょ。日本語対応ですかね。。。
あと、Cloud Speech(音声の認識してくれるサービス)は有料?らしいですが、日本語もちゃんと聞き取れる見たいでです。
また、登録していませんが、2017年12月30時点では、
料金はざっくりまとめると、月間60分までは無料。(15秒単位。一秒しか喋らなくても15秒分としてカウントされる)
それ以上(61~100 万分)は、$0.006 / 15 秒*らしいです。
えと、単純計算で
60分/15秒=240回
240回/31日=7.741…
一日7回までは無料で使える感じですかね。単純計算ですが。
で、まぁ追加になっても15秒1円もかからない($0.006=0.67643743 円 2017/12/30時点)し、いいかなぁ。
これも無料トライアルに含まれるんかな?(←まだトライアル登録してないけど。)
バックナンバー
ではでは。またの機会に・