JP2019194713A - 話者検証のためのニューラルネットワーク - Google Patents

話者検証のためのニューラルネットワーク Download PDF

Info

Publication number
JP2019194713A
JP2019194713A JP2019108765A JP2019108765A JP2019194713A JP 2019194713 A JP2019194713 A JP 2019194713A JP 2019108765 A JP2019108765 A JP 2019108765A JP 2019108765 A JP2019108765 A JP 2019108765A JP 2019194713 A JP2019194713 A JP 2019194713A
Authority
JP
Japan
Prior art keywords
speaker
utterance
neural network
utterances
training
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP2019108765A
Other languages
English (en)
Other versions
JP6766221B2 (ja
Inventor
ゲオルク・ハイゴルト
Heigold Georg
サミー・ベンジオ
Bengio Samy
イグナシオ・ロペス・モレーノ
lopez moreno Ignacio
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Google LLC
Original Assignee
Google LLC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Google LLC filed Critical Google LLC
Publication of JP2019194713A publication Critical patent/JP2019194713A/ja
Application granted granted Critical
Publication of JP6766221B2 publication Critical patent/JP6766221B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G07CHECKING-DEVICES
    • G07CTIME OR ATTENDANCE REGISTERS; REGISTERING OR INDICATING THE WORKING OF MACHINES; GENERATING RANDOM NUMBERS; VOTING OR LOTTERY APPARATUS; ARRANGEMENTS, SYSTEMS OR APPARATUS FOR CHECKING NOT PROVIDED FOR ELSEWHERE
    • G07C9/00Individual registration on entry or exit
    • G07C9/30Individual registration on entry or exit not involving the use of a pass
    • G07C9/32Individual registration on entry or exit not involving the use of a pass in combination with an identity check
    • G07C9/37Individual registration on entry or exit not involving the use of a pass in combination with an identity check using biometric data, e.g. fingerprints, iris scans or voice recognition
    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10LSPEECH ANALYSIS TECHNIQUES OR SPEECH SYNTHESIS; SPEECH RECOGNITION; SPEECH OR VOICE PROCESSING TECHNIQUES; SPEECH OR AUDIO CODING OR DECODING
    • G10L17/00Speaker identification or verification techniques
    • G10L17/18Artificial neural networks; Connectionist approaches
    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10LSPEECH ANALYSIS TECHNIQUES OR SPEECH SYNTHESIS; SPEECH RECOGNITION; SPEECH OR VOICE PROCESSING TECHNIQUES; SPEECH OR AUDIO CODING OR DECODING
    • G10L17/00Speaker identification or verification techniques
    • G10L17/02Preprocessing operations, e.g. segment selection; Pattern representation or modelling, e.g. based on linear discriminant analysis [LDA] or principal components; Feature selection or extraction
    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10LSPEECH ANALYSIS TECHNIQUES OR SPEECH SYNTHESIS; SPEECH RECOGNITION; SPEECH OR VOICE PROCESSING TECHNIQUES; SPEECH OR AUDIO CODING OR DECODING
    • G10L17/00Speaker identification or verification techniques
    • G10L17/04Training, enrolment or model building

Landscapes

  • Engineering & Computer Science (AREA)
  • Human Computer Interaction (AREA)
  • Physics & Mathematics (AREA)
  • Acoustics & Sound (AREA)
  • Audiology, Speech & Language Pathology (AREA)
  • Health & Medical Sciences (AREA)
  • Multimedia (AREA)
  • Artificial Intelligence (AREA)
  • Evolutionary Computation (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • General Physics & Mathematics (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)
  • Electrically Operated Instructional Devices (AREA)
  • Circuit For Audible Band Transducer (AREA)

Abstract

【課題】話者検証のためのニューラルネットワークを提供する。【解決手段】システム100において方法は、話者検証モデルに対するニューラルネットワークをトレーニングするステップと、クライアントデバイスでユーザを加入させるステップと、ユーザのアイデンティティを前記ユーザの音声の特性に基づいて検証するステップとを含む。方法は、コンピューティングデバイスで、ユーザの発声を特徴付けるデータを受信するステップを含み、話者表現を、コンピューティングデバイス上のニューラルネットワークを用いて発声に対して生成する。ニューラルネットワークは、それぞれが、第1の発声を特徴付けるデータおよび1つまたは複数の第2の発声を特徴付けるデータを含み、マッチング話者サンプルまたは非マッチング話者サンプルとしてラベル付けされる、複数のトレーニング・サンプルに基づいてトレーニングされる。【選択図】図1

Description

本明細書の主題は一般に、話者検証タスクで使用されるニューラルネットワークおよび他のモデルに関する。
話者検証は一般に人のアイデンティティを、当該人の音声の特性に基づいて検証することに関する。幾つかのコンピューティングデバイスは、ユーザに、ユーザにより話された会話の1つまたは複数のサンプルを当該デバイスに提供することで当該デバイスに「加入」させることができる。当該サンプルから、ユーザの音声を表す話者モデルが決定される。当該デバイスで受信された後続の会話サンプルをついで、当該話者モデルに関して処理し評価して、ユーザのアイデンティティを検証してもよい。
本明細書では一般に、話者検証のためのニューラルネットワーク、または他のタイプのモデルをトレーニングし使用するためのシステム、方法、デバイス、および他の技術を説明する。幾つかの実装では、ニューラルネットワークは、話者検証を実施するコンピューティングデバイスによりアクセス可能な話者検証モデルのコンポーネントであってもよい。一般に、ニューラルネットワークは、それぞれ話者の加入および発声の検証をシミュレートする反復でトレーニングされてもよい。例えば、各トレーニングの反復において、所与の発声に対してニューラルネットワークにより生成された話者表現を話者モデルに関して評価してもよい。シミュレートされた検証発声に対する話者表現の、1つまたは複数のシミュレートされた加入発声に対する話者表現の組合せ(例えば、平均)との比較に基づいて、ニューラルネットワークのパラメータを、所与の発声を同一の人または加入した人とは異なる人により話されているとして分類するように当該話者検証モデルの能力を最適化するように更新してもよい。これが、当該システムの信頼性を増大する点で利点を有することは理解される。ニューラルネットワークはさらに、当該発声のフレームを独立にまたは逐次的に処理するのではなく、単一のパスでニューラルネットワークを通じて、発声全体を特徴づけるデータを処理するように構成されてもよい。これらのおよび他の実装は下記でより完全に説明され、図面で示される。
本明細書で説明する主題の幾つかの実装はコンピュータ実行型の方法を含む。当該方法は、コンピューティングシステムで、ニューラルネットワークをトレーニングするためのトレーニングデータの複数の異なるサブセットを選択するステップを含むことができる。トレーニングデータの各サブセットは、第1の話者の各発声を分類する複数の第1のコンポーネントと、第1の話者または第2の話者の発声を特徴付ける第2のコンポーネントとを含むことができる。トレーニングデータの当該選択されたサブセットごとに、当該方法は、第1のコンポーネントの各々に対応する各第1の話者表現を生成するために、第1のコンポーネントの各々をニューラルネットワークに入力するステップと、第2のコンポーネントに対応する第2の話者表現を生成するために、第2のコンポーネントをニューラルネットワークに入力するステップと、当該複数の第1のコンポーネントに対する当該各第1の話者表現の平均に基づいて第1の話者に対するシミュレートされた話者モデルを決定するステップと、第2の話者表現を当該シミュレートされた話者モデルと比較して、第2のコンポーネントにより特徴付けられた発声を第1の話者の発声としてまたは第1の話者と異なる話者の発声として分類するステップと、第2のコンポーネントにより特徴付けられた発声が第1の話者の発声としてまたは第1の話者と異なる話者の発声として正しく分類されたかどうかに基づいて、ニューラルネットワークを調節するステップとを含むことができる。
これらのおよび他の実装は以下の特徴のうち1つまたは複数を含むことができる。
第2のコンポーネントをニューラルネットワークに入力するステップに応答して、第2の話者表現を、単一のパスでニューラルネットワークを通じて、第2のコンポーネントにより特徴付けられた当該発声の全体に対するデータを処理することで、ニューラルネットワークで生成することができる。
トレーニングデータの当該複数の異なるサブセットからトレーニングデータの第1のサブセットを選択するステップは、各発声グループが当該各発声グループに対する当該対応する話者の発声のみを特徴づけるデータから構成されるように、それぞれ異なる話者に対応する複数の発声グループからの第1の話者に対応する第1の発声グループを選択するステップと、第1の話者または第2の話者に対応する第2の発声グループを発声の当該複数のグループから選択するステップと、当該複数の第1のコンポーネントを第1の発声グループ内の発声を特徴付ける当該データから決定するステップと、第2のコンポーネントを第2の発声グループ内の発声を特徴付ける当該データから決定するステップとを含むことができる。
第1の発声グループおよび第2の発声グループの少なくとも1つを発声の当該複数のグループからランダムに選択することができる。
第1の話者は、互いにトレーニングデータの当該複数の異なるサブセットのうちの少なくとも幾つかと異なることができる。第2の話者は、互いにトレーニングデータの当該複数の異なるサブセットのうちの少なくとも幾つかと異なることができる。
トレーニングデータの当該複数の異なるサブセットのうちトレーニングデータの第1のサブセット内の第1のコンポーネントの総数は、トレーニングデータの当該複数の異なるサブセットのうちトレーニングデータの第2のサブセット内の第1のコンポーネントの総数と異なることができる。
第2の話者表現を当該シミュレートされた話者モデルと比較して、第2のコンポーネントにより特徴付けられた当該発声を第1の話者の発声としてまたは第1の話者と異なる話者の発声として分類するステップは、第2の話者表現からの値および当該シミュレートされた話者モデルからの値の間の距離を決定するステップと、ロジスティック回帰機能を当該距離に適用するステップとを含むことができる。
ニューラルネットワークは複数の隠蔽されたレイヤを含むことができる。ニューラルネットワークはソフトマックス出力レイヤを有さなくてもよい。
ニューラルネットワークは、ローカルに接続された隠蔽されたレイヤと、当該レイヤに続く複数の完全に接続された隠蔽されたレイヤを有するディープ・ニューラルネットワークを含むことができる。
当該複数の第1のコンポーネントにより特徴付けられた当該発声、および第2のコンポーネントにより特徴付けられた当該発声は全て、固定長を有することができる。
ニューラルネットワークは、可変長を有する発声を特徴付けるデータでトレーニングされるように構成される長短期メモリ再帰型ニューラルネットワークであることができる。
トレーニングデータの当該複数の異なるサブセットにわたって各複数の第1のコンポーネントにより特徴付けられた発声、およびトレーニングデータの当該複数の異なるサブセットにわたって各第2のコンポーネントにより特徴付けられた発声は全て、同一の単語またはフレーズの発声であることができる。
トレーニングデータの当該複数の異なるサブセットにわたって各複数の第1のコンポーネントにより特徴付けられた発声の少なくとも幾つか、およびトレーニングデータの当該複数の異なるサブセットにわたって各第2のコンポーネントにより特徴付けられた当該発声の少なくとも幾つかは異なる単語または異なるフレーズから成る発声であることができる。
当該トレーニングされたニューラルネットワークを、話者検証を当該1つまたは複数のコンピューティングデバイスで実施する際に使用するための当該コンピューティングシステムとは別の1つまたは複数のコンピューティングデバイスに提供することができる。
第1の話者表現の各々を、第1の話者表現に対応するニューラルネットワークに入力された当該各第1のコンポーネントに基づいてニューラルネットワーク生成することができる。第2の話者表現を、第2の話者表現に対応するニューラルネットワークに入力された第2のコンポーネントに基づいてニューラルネットワークにより生成することができる。
本明細書で説明する主題の幾つかの実装はコンピューティングデバイスを含むことができる。コンピューティングデバイスは、1つまたは複数のコンピュータプロセッサと、当該1つまたは複数のプロセッサにより実行されたとき、動作を実施させる命令を格納した1つまたは複数のコンピュータ可読媒体とを備えることができる。当該動作は、コンピューティングデバイスで、コンピューティングデバイスのユーザの発声を特徴付けるデータを受信するステップと、コンピューティングデバイスで、コンピューティングデバイス上のニューラルネットワークを用いて当該発声に対する話者表現を生成するステップであって、ニューラルネットワークが、それぞれ(i)第1の発声を特徴付けるデータおよび1つまたは複数の第2の発声を特徴付けるデータを含み、(ii)第1の発声の話者が当該1つまたは複数の第2の発声の話者と同一であるかどうかに従って、マッチングサンプルまたは非マッチングサンプルとしてラベル付けされる、複数のトレーニング・サンプルに基づいてトレーニングされている、ステップと、コンピューティングデバイスで、コンピューティングデバイスの認証されたユーザに対する話者モデルにアクセスするステップと、コンピューティングデバイスで、当該話者モデルに関する当該発声に対する話者表現を評価して、当該発声がコンピューティングデバイスの認証されたユーザにより話された可能性があったかどうかを判定するステップとを含むことができる。
各発声グループが当該各発声グループに対する対応する話者の発声のみから構成されるように、第1の発声および当該1つまたは複数の第2の発声を異なる話者に対応する発声グループから選択することによって、当該複数のトレーニング・サンプルの各々を生成することができる。
当該動作はさらに、コンピューティングデバイスの認証されたユーザの1組の発声を取得するステップと、当該発声に対する各話者表現を生成するために、各発声を当該1組の発声からニューラルネットワークに入力するステップと、当該認証されたユーザの当該1組の発声における当該発声に対する各話者表現の平均に基づいてコンピューティングデバイスの認証されたユーザに対する話者モデルを生成するステップとを含むことができる。
ニューラルネットワークがトレーニングされている当該複数のトレーニング・サンプルの何れも、コンピューティングデバイスのユーザの発声を特徴付けるデータを含まなくてもよい。
コンピューティングデバイスで、当該発声に対する話者表現を生成するステップは、当該発声の全体をニューラルネットワークで単一のパスでニューラルネットワークを通じて特徴付けるデータを処理するステップを含むことができる。
ニューラルネットワークは再帰型ニューラルネットワークであることができる。ユーザの発声は第1の時間長を有することができる。当該発声に対する話者表現は、当該発声の第1の時間長の全体に対して当該発声を特徴付けるデータを処理するステップを含むことができる。当該動作はさらに、コンピューティングデバイスのユーザの別の発声を受信するステップであって、当該他の発声は、第1の時間長と異なる第2の時間長を有する、ステップと、当該他の発声の第2の時間長の全体に対して当該他の発声を特徴付けるデータを処理することでユーザの当該他の発声に対する第2の話者表現を生成するステップとを含むことができる。
当該動作はさらに、ユーザの発声がコンピューティングデバイスの認証されたユーザにより話された可能性があったと判定したことに応答して、機能をコンピューティングデバイスで実施するステップを含むことができる。当該機能は、コンピューティングデバイスの状態をロックされた状態からロックされていない状態に変更するステップであって、コンピューティングデバイスは、当該ロックされた状態のコンピューティングデバイスの1つまたは複数の能力へのアクセスをブロックするように構成され、コンピューティングデバイスは当該ロックされていない状態のコンピューティングデバイスの当該1つまたは複数の能力へのアクセスを許可するように構成される、ステップを含むことができる。
当該話者表現は、決定された発声に基づいて決定されるユーザの音声の区別的な特徴を示すニューラルネットワークの出力を含むことができる。
本明細書で説明する主題の幾つかの実装はコンピュータ実行型の方法を含むことができる。当該方法は、コンピューティングデバイスで、コンピューティングデバイスのユーザの発声を特徴付けるデータを受信するステップを含むことができる。話者表現を、コンピューティングデバイスで、コンピューティングデバイス上のニューラルネットワークを用いて当該発声に対して生成することができる。ニューラルネットワークを、それぞれが(i)第1の発声を特徴付けるデータおよび1つまたは複数の第2の発声を特徴付けるデータを含み、(ii)第1の発声の話者が当該1つまたは複数の第2の発声の話者と同一であるかどうかに従って、マッチングサンプルまたは非マッチングサンプルとしてラベル付けされる、複数のトレーニング・サンプルに基づいてトレーニングすることができる。話者モデルに、コンピューティングデバイスで、コンピューティングデバイスの認証されたユーザに対してアクセスすることができる。当該発声に対する話者表現を、コンピューティングデバイスで、当該話者モデルに関して評価して、当該発声がコンピューティングデバイスの認証されたユーザにより話された可能性があったかどうかを判定することができる。
本明細書で説明する主題の幾つかの実装はコンピュータ実行型の方法を含むことができる。当該コンピュータ実行型の方法は、第1の1組の発声に対するニューラルネットワークの出力に基づいて特定の話者に対する話者モデルを決定するステップであって、第1のセットは複数の異なる特定の話者の発声を含む、ステップと、第1の1組の発声内にない特定の発声に対するニューラルネットワークの出力に基づいて話者表現を決定するステップと、当該話者表現を当該特定の話者に対する当該話者モデルと比較して、当該特定の発声を当該特定の話者の発声としてまたは当該特定の話者と異なる話者の発声として分類するステップと、当該発声の当該特定の話者の発声としてまたは当該特定の話者と異なる話者の発声としての当該分類が正しかったかどうかに基づいてニューラルネットワークを調節するステップとを含むことができる。
これらのおよび他の実装は以下の特徴のうち1つまたは複数を含むことができる。複数の異なる発声のセットを、ニューラルネットワークをトレーニングするためのトレーニングデータとして選択することができる。各1組の発声は、(i)当該各1組の発声に対する第1の第1の話者の複数の異なる発声、および(ii)当該各1組の発声に対する第1の話者、または、第1の話者と異なる当該各1組の発声に対する第2の話者の何れかの第2の発声を含むことができる。当該複数の異なる発声のセットを、ニューラルネットワークを繰り返しトレーニングするために使用することができる。当該複数の異なる発声のセットからの各1組の発声を、ニューラルネットワークをトレーニングするために異なるトレーニングの反復において使用することができる。第1の1組の発声を当該複数の異なる発声のセットから選択することができる。当該特定の話者は第1の1組の発声に対する第1の話者である。
本明細書で説明する主題のさらなる実装は、当該方法のアクションを実施するように構成され、コンピュータ記憶デバイスで符号化された対応するシステム、装置、およびコンピュータプログラムを含むことができる。1つまたは複数のコンピュータのシステムを、動作中に当該システムに当該アクションを実施させるソフトウェア、ファームウェア、ハードウェア、または当該システムにインストールされたそれらの組合せにより構成することができる。1つまたは複数のコンピュータプログラムを、1つまたは複数のデータ処理装置により実行されたとき、当該装置に当該アクションを実施させる命令を有することによりそのように構成することができる。
本明細書で説明する主題の幾つかの実装は以下の利点の1つまたは複数を実現しうる。ニューラルネットワークを、ユーザの音声の特性に基づいて話者のアイデンティティをより正確に検証できる話者検証モデルで使用するための話者表現を生成するために、トレーニングすることができる。ターゲット性能レベルを、有限のコンピューティングリソースを有するモバイルコンピューティングデバイスに格納しそこで使用しうるコンパクトなニューラルネットワークで実現することができる。さらに、ニューラルネットワークを、話者検証プロセスの検証および加入段階をシミュレートする方式でトレーニングしてもよい。したがって、ニューラルネットワークは、当該話者検証プロセスのトレーニング段階と検証および加入段階との間の対称性のため良好な性能を実現しうる。本明細書で説明するアプローチに従うニューラルネットワークをトレーニングする利益は、事前選択された数の話者の間の特定の話者に属するとして入力を分類するためにニューラルネットワークをトレーニングすることを含む他のアプローチと対照的に、より多くの数の様々な話者を、当該ネットワークをトレーニングするために使用しうるということである。さらに、高信頼のトレーニングを保証するためのトレーニング話者ごとに要求された最小数のトレーニング発声がなくてもよい。さらに、ニューラルネットワークは、独立なパス内のニューラルネットワークを通じて当該発声のフレームを処理する必要なく、発声全体を特徴づけるデータを単一のパスでニューラルネットワークを通じて処理するように構成されてもよい。上で参照した態様は、発声がコンピューティングデバイスの認証されたユーザにより話された可能性があったかどうかを評価することに寄与しうる。当該態様はかかる評価を特に高信頼としうる。これを、少なくとも、コンピューティングデバイスの認証されたユーザのような、発声が特定の人により話されたかどうかを評価する際のエラーを減らすことで、より有効な音声認識システムとすることができる。当該高信頼性は、上で参照した態様に関連付けられた広範囲のシステムのセキュリティを増大させうる。例えば、当該態様が認証されたユーザを認識するために使用され、応答して、コンピューティングデバイスの状態をロックされた状態からロックされていない状態に変更する場合、上で参照したエラーの減少は、コンピューティングデバイスのアンロックをより安全にする。実際、当該システムの高信頼性は、コンピューティングデバイスを、非認証されたユーザからの詐欺的なアンロック試行に対してあまり脆弱でなくしうる。当該エラーの減少はまた、エラー訂正の必要性を削減でき、これはコンピューティングリソースをエラー訂正に割り当てる必要性を削減できる。これは、コンピュータリソースがより制限されうるモバイルコンピューティングデバイスにおいて特に有利である。
(i)ニューラルネットワークをトレーニングし、(ii)ユーザをコンピューティングデバイスで加入させ、(iii)ユーザの音声の区別的な特徴に基づいてコンピューティングデバイスのユーザの発声を検証する動作を実行する、例示的なクライアントデバイスおよびコンピューティングシステムの略図である。 話者検証タスクで使用するための話者表現を決定するためにニューラルネットワークをトレーニングするためのブロック図である。 音声の区別的な特性を示す話者表現を決定するためにニューラルネットワークをトレーニングするための例示的なプロセスの流れ図である。 発声プール内の異なる話者に対する発声のグループからのトレーニング発声のサブセットの例示的な選択を示す概念図である。 ニューラルネットワークをトレーニングするための発声プールからのトレーニングデータのバッチの例示的な選択を示す概念図である。 発声の少なくとも一部を特徴づけるデータを処理し、当該発声の当該少なくとも一部を特徴づけるデータに基づいて話者表現を生成するように構成された例示的なディープ・ニューラルネットワークのブロック図である。 話者検証モデルで使用するために構成される長短期メモリレイヤを有する例示的な再帰型ニューラルネットワークのブロック図である。 コンピューティングデバイス上のニューラルネットワークを用いて、ユーザの発声から決定されたユーザの音声の特性に基づいてユーザのアイデンティティを検証するための例示的なプロセスの流れ図である。 本明細書で説明するコンピュータ実行型の方法および他の技術を実行する際に使用できるコンピューティングデバイスおよびモバイルコンピューティングデバイスの1例を示す図である。
図1は、話者検証モデルに対するニューラルネットワークをトレーニングし、当該モデルを用いて話者検証のプロセスを実行するための例示的なシステム100の略図である。一般に、話者検証とは、当該話者の1つまたは複数の発声から決定される当該話者の音声の特性に基づいて話者のアイデンティティ要求を受理または拒否するタスクである。図1に示すように、話者検証は一般に3つの段階、即ち(i)当該話者検証モデルに対するニューラルネットワークのトレーニング、(ii)新たな話者の加入、および(iii)当該加入した話者の検証を含むことができる。
システム100はクライアントデバイス110、コンピューティングシステム120、およびネットワーク130を含む。幾つかの実装では、コンピューティングシステム120は、トレーニングされたニューラルネットワーク140に基づいて話者検証モデル144をクライアントデバイス110に提供してもよい。幾つかの実装では、話者検証モデル144は、例えば、オペレーティング・システムまたはアプリケーションのコンポーネントとしてクライアントデバイス110に事前インストールされてもよい。他の実装では、話者検証モデル144がネットワーク130上で受信されてもよい。クライアントデバイス110は、話者検証モデル144を使用してユーザ102を当該話者検証プロセスに加入させてもよい。後の時点でユーザ102のアイデンティティを検証する必要があるとき、クライアントデバイス110は、話者検証モデル144を用いてユーザ102のアイデンティティを検証するためにユーザ102の会話発声を受信してもよい。話者検証モデル144をクライアントデバイス110にローカルに格納してもよいので、クライアントデバイス110はネットワーク130上の通信なしに話者検証判定を行うことができうる。
図1には示していないが、幾つかの実装では、コンピューティングシステム120は、クライアントデバイス110に格納されるニューラルネットワーク140ではなくまたはそれに加えて、当該トレーニングされたニューラルネットワーク140に基づいて話者検証モデル144を格納してもよい。これらの実装では、クライアントデバイス110は、ネットワーク130を介してコンピューティングシステム120と通信して話者検証モデル144にリモートにアクセスし、それをユーザ102の加入のために使用してもよい。後の時点でユーザ102のアイデンティティを検証する必要があるとき、クライアントデバイス110はユーザ102の会話発声を受信してもよく、ネットワーク130を介してコンピューティングシステム120と通信して、当該リモートに配置された話者検証モデル144を用いてユーザ102のアイデンティティを検証してもよい。コンピューティングシステム120およびコンピューティング・デバイス110は、互いと異なってもよく、物理的に別々であってもよい。
システム100では、クライアントデバイス110は、例えば、デスクトップコンピュータ、ラップトップコンピュータ、タブレットコンピュータ、時計、ウェラブルコンピュータ、セルラ電話、スマートフォン、音楽プレイヤ、eブックリーダ、ナビゲーションシステム、またはユーザが対話しうる任意の他の適切なコンピューティングデバイスであることができる。幾つかの実装では、クライアントデバイス110はモバイルコンピューティングデバイスであってもよい。コンピューティングシステム120は1つまたは複数のコンピュータを含むことができ、当該コンピュータのうち独立なものに対して機能を実施してもよく、または当該機能は、複数のコンピュータにわたって実施するために分散されてもよい。ネットワーク130は、有線またはワイヤレスまたはその両方の組合せであることができ、インターネットを含むことができる。
幾つかの実装では、ユーザの電話のようなクライアントデバイス110は、話者検証モデル144をクライアントデバイス110にローカルに格納して、クライアントデバイス110が、加入または検証処理のためにリモートサーバ(例えば、コンピューティングシステム120)でのモデルに頼ることなくユーザのアイデンティティを検証できるようにしてもよく、したがって通信帯域幅および時間を節約することができる。さらに、幾つかの実装では、1つまたは複数の新たなユーザが加入するとき、本明細書で説明した話者検証モデル144は当該新たなユーザを用いた話者検証モデル144の任意の再トレーニングを必要とせず、これはまた、計算的に効率的でありうる。他の実装では、ニューラルネットワーク(およびしたがって当該話者検証モデル)を新たに収集されたトレーニングデータの使用に基づいて定常的に更新できるように、加入、検証、またはその両方のために提供された所与のユーザの発声をコンピューティングシステム120に提供し、当該トレーニングデータに追加してもよい。
当該トレーニングされたニューラルネットワーク140を含む話者検証モデル144のサイズは、クライアントデバイス110の記憶空間およびメモリ空間が制限されうるので、コンパクトでありうるのが望ましい。後述のように、話者検証モデル144はトレーニングされたニューラルネットワーク140に基づく。話者検証モデル144は、発声を特徴付けるデータに基づいて、当該発声の話者の音声の区別的な特徴を示す話者表現を生成するためのニューラルネットワーク140を含んでもよい。話者検証モデル144は、当該発声の話者のアイデンティティ要求を検証できるように、当該話者表現を処理し、当該発声の話者の音声が加入したユーザの音声と十分に同様であるかかどうかを判定するためのさらなるコンポーネントを含んでもよい。
幾つかの実装では、ニューラルネットワークは大規模な1組のトレーニングデータを用いてトレーニングされてもよい。様々な技術を当該トレーニングデータの前処理の間に、トレーニング自体の間に、または後トレーニング段階の間に適用して、ニューラルネットワークのサイズを強制および/または削減し、コンパクトなモデルサイズを実現してもよい。例えば、話者検証モデル144を、ニューラルネットワーク140の特定のレイヤのみを選択することで構築してもよい。これは、クライアントデバイス110に格納するのに適したコンパクトな話者検証モデルをもたらしうる。当該話者モデルに対する話者表現を生成する際にソフトマックスまたは他の分類レイヤなしに、加入を実施してもよい。
図1はまた、段階(A)乃至(F)で示す、データの例示的なフローを示す。段階(A)乃至(F)を、当該示されたシーケンスで行ってもよく、または、当該示されたシーケンスと異なるシーケンスで行ってもよい。幾つかの実装では、段階(A)乃至(F)の1つまたは複数をオフラインで行ってもよい。コンピューティングシステム120は、クライアントデバイス110がネットワーク130に接続されないときに計算を実施してもよい。段階(A)および(B)は一般に上で参照した当該トレーニング段階の間に発生する。段階(D)は一般に加入段階の間に発生する。段階(E)乃至(G)は一般に検証段階の間に発生する。
段階(A)で、コンピューティングシステム120は、ニューラルネットワーク140の監視されたトレーニングをニューラルネットワーク140に提供するためのトレーニング発声のサンプルを選択する。幾つかの実装では、トレーニング・サンプル122における発声がそれぞれ、多数の異なるトレーニング話者により話された1つまたは複数の所定の単語から構成されてもよい。当該発声は以前に記録されておりコンピューティングシステム120により使用するためにアクセス可能とされている。各トレーニング話者は所定の発声をコンピューティングデバイスに話してもよく、コンピューティングデバイスは当該発声を含むオーディオ信号を記録してもよい。例えば、各トレーニング話者を、当該トレーニングフレーズ「Hello Phone」を話すように促してもよい。幾つかの実装では、各トレーニング話者を、同一のトレーニングフレーズ複数回を話すように促してもよい。各トレーニング話者の当該記録されたオーディオ信号がコンピューティングシステム120に送信されてもよく、コンピューティングシステム120は当該記録されたオーディオ信号を多数の異なるコンピューティングデバイスおよび多数の異なるトレーニング話者から収集してもよい。幾つかの実装では、ユーザのアイデンティティが当該予め定義されたトレーニングフレーズの発声から決定されたユーザの音声の特性に基づいて検証されてもよいという点で、ニューラルネットワーク140をテキスト依存の話者検証に対して最適化してもよい。かかる実装では、ニューラルネットワーク140は、全ての、または実質的に全ての、当該予め定義されたトレーニングフレーズを含む発声でトレーニングされてもよい。他の実装では、ニューラルネットワーク140は、ユーザのアイデンティティが多種多様な単語またはフレーズの発声から決定されたユーザの音声の特性に基づいて検証されてもよいという点で、テキスト独立な話者検証を可能とするためにトレーニングされてもよく、当該多種多様な単語またはフレーズの発声は予め定義されていなくてもよい。例えば、ユーザは、自分のアイデンティティを検証するために、どの単語またはフレーズを彼または彼女が話したいかを独立に判定でき、当該トレーニングされたニューラルネットワーク140に基づく話者検証モデルは次いで、当該話された単語またはフレーズが与えられた場合にユーザを認証することができる。テキスト独立な話者検証を可能とするために、ニューラルネットワーク140は、多数の異なるトレーニング話者により話された多種多様な単語またはフレーズの発声でトレーニングされてもよい。
段階(B)で、ニューラルネットワーク140は、クライアントデバイスでユーザの加入および検証と平行する方式でトレーニングされてもよい。したがって、コンピューティングシステム120は、各トレーニング・サンプル122において、1組のシミュレートされた加入発声122bおよびシミュレートされた検証発声122aを選択することができる。シミュレートされた加入発声122bは、シミュレートされた話者モデルをトレーニング・サンプル122ごとに決定できるように、同一のトレーニング話者の全ての発声であってもよい。シミュレートされた検証発声122aは、シミュレートされた加入発声122bの話者と同一の話者の発声であってもよく、または異なる話者の発声であってもよい。トレーニング・サンプル122を次いでニューラルネットワーク140に提供でき、シミュレートされた検証発声122aがシミュレートされた加入発声122bの話者と同一の話者により話されたか、またはシミュレートされた加入発声122bの話者と異なる話者により話されたかどうかに関して、ニューラルネットワーク140の出力に基づいて分類を行ってもよい。ニューラルネットワーク140は次いで、当該話者判定が正しかったかどうかに基づいて更新することができる。幾つかの実装では、各トレーニング・サンプル122を、2つのクラス、即ち、(当該シミュレートされた検証発声および加入発声の話者が同一であるサンプルに関する)マッチング話者クラス141aおよび(当該シミュレートされた検証発声および加入発声の話者が異なるサンプルに関する)非マッチング話者クラス141bのうち1つに属するとしてラベル付けしてもよい。これらのラベルは、同一の話者が発声122aおよび発声122bを話したかどうかのグランド・トルースを示す。トレーニング・サンプル122の分類の正確性を当該サンプルのラベルに基づいて決定することができる。幾つかの実装では、ニューラルネットワークに対する調節は、入力サンプルの分類の正確性に厳密に基づかなくてもよいが、一般にシミュレートされた検証発声122aおよびシミュレートされた加入発声122bに対するニューラルネットワークにより生成された話者表現の比較から決定された1つまたは複数のメトリックに基づいてもよい。幾つかの実装では、トレーニング・サンプル122をトレーニングデータのリポジトリから選択してもよい。当該トレーニングデータのリポジトリを、発声プール121に編成してもよい。発声プール121の各々は当該発声のトレーニング話者によりグループ化されたトレーニング発声を含んでもよい。
ニューラルネットワーク140は、トレーニング・サンプル122における発声に関する情報を入力するための入力レイヤ、およびサンプル122を処理するための幾つかの隠蔽されたレイヤを含んでもよい。当該トレーニングされたニューラルネットワーク140が、サンプル122のシミュレートされた検証発声および加入発声のうちマッチングまたは非マッチング話者の何れかを有するとのトレーニング・サンプル122の所望の分類を生成させる出力を話者検証モデル144が生成するように、1つまたは複数の隠蔽されたレイヤの重みまたは他のパラメータを調節してもよい。幾つかの実装では、ニューラルネットワーク140のパラメータをコンピューティングシステム120により自動的に調節してもよい。幾つかの他の実装では、ニューラルネットワーク140のパラメータをコンピューティングシステム120のオペレータにより手動で調節してもよい。ニューラルネットワークのトレーニング段階を、例えば図2、3、4A−B、および5A−Bの説明において以下でより詳細に説明する。
段階(C)で、ニューラルネットワーク140がトレーニングされると、当該トレーニングされたニューラルネットワーク140に基づく話者検証モデル144が、例えば、ネットワーク130を通じてコンピューティングシステム120からクライアントデバイス110に送信される。幾つかの実装では、当該トレーニングされたニューラルネットワーク140、またはその一部は、話者検証モデル144のコンポーネントであってもよい。話者検証モデル144を、1つまたは複数のユーザ102の発声から決定されたユーザの音声の特性に基づいてユーザ102のアイデンティティを検証するように構成することができる。モデル144を、ユーザの音声の区別的な特徴を示すユーザ102に対する話者表現を生成するために、ユーザ102の発声を特徴づけるデータを当該トレーニングされたニューラルネットワーク140への入力として提供するように構成してもよい。当該話者表現を次いで、以前に決定されたユーザの音声のモデルと比較することができる。当該話者表現がユーザの話者モデルと十分に同様である場合、話者検証モデル144は、ユーザ102のアイデンティティが正当であるという指示を出力することができる。対照的に、当該話者表現がユーザの話者モデルと十分に同様でない場合、話者検証モデル144は、ユーザ102のアイデンティティが無効である(検証されない)という指示を出力することができる。
段階(D)で、クライアントデバイス110で自分の音声を加入させたいと望むユーザ102が、加入段階で1つまたは複数の加入発声152をクライアントデバイス110に提供する。一般に、ユーザ102は、音声がニューラルネットワーク140のトレーニングで使用されなかったトレーニング話者の1つではない。幾つかの実装では、クライアントデバイス110は、トレーニング・サンプル122の発声において当該1組のトレーニング話者により話された同一のフレーズである加入フレーズを話すことをユーザ102に促してもよい。幾つかの実装では、クライアントデバイス110は、加入フレーズを何回か話すようにユーザに促してもよく、当該話された加入発声に対するオーディオ信号を加入発声152として記録してもよい。
クライアントデバイス110は、加入発声152を使用して、クライアントデバイス110の話者検証システムにおいてユーザ102を加入させる。一般に、ユーザ102の加入はニューラルネットワーク140の再トレーニングなしに行われる。同一の話者検証モデル144の夫々のインスタンスは、多数の異なる話者を加入させるために、ニューラルネットワーク140における重み値または他のパラメータを変更するのを必要とせずに、多数の異なるクライアントデバイスで使用されてもよい。話者検証モデル144を、再トレーニングニューラルネットワーク140なしに任意のユーザを加入させるために使用できるので、制限された処理要件でクライアントデバイス110で加入を実施してもよい。
幾つかの実装では、加入発声152に関する情報は話者検証モデル144へ入力され、話者検証モデル144は、ユーザ102に対応する基準ベクトルまたは他の1組の値を出力してもよい。当該基準ベクトルまたは他の1組の値は、ユーザの音声の区別的な特徴を特徴付ける話者モデルを構成してもよい。当該話者モデルをクライアントデバイス110に、またはクライアントデバイス110から離れたコンピューティングシステムに格納してもよく、その結果、後にクライアントデバイス110により受信された発声に基づいて生成された話者表現を当該話者モデルと比較して、後に受信された発声の各話者がユーザ102であるかまたは他の話者であるかどうかを検証してもよい。
段階(E)で、ユーザ102が、音声認証を用いてクライアントデバイス110へのアクセスを得ようと試みる。ユーザ102は、検証段階で検証発声154をクライアントデバイス110に提供する。幾つかの実装では、検証発声154は、加入発声152と同一の、話されたフレーズの発声である。検証発声154は話者検証モデル144への入力として使用される。
段階(F)で、クライアントデバイス110は、ユーザの音声が加入したユーザの当該音声にマッチするかどうかを判定する。幾つかの実装では、ニューラルネットワーク140は検証発声154を特徴付けるデータを処理してもよく、検証発声154に基づいてユーザ102に対する話者表現を出力してもよい。幾つかの実装では、クライアントデバイス110は、ユーザ102に対する話者表現を加入したユーザに対する当該話者モデルと比較して、検証発声154が加入したユーザにより話されたかどうかを判定してもよい。ニューラルネットワークの検証段階を、例えば図6に関して以下でより詳細に説明する。
段階(G)で、クライアントデバイス110が、検証結果156を表す指示をユーザ102に提供する。幾つかの実装では、クライアントデバイス110がユーザ102のアイデンティティを受理した場合、クライアントデバイス110は、検証が成功したという視覚的指示またはオーディオ指示をユーザ102に送信してもよい。幾つかの他の実装では、クライアントデバイス110がユーザ102のアイデンティティを受理した場合、クライアントデバイス110はユーザ102に次の入力を促してもよい。例えば、クライアントデバイス110は、メッセージ「Device enabled. Please enter your search」を当該ディスプレイに出力してもよい。幾つかの他の実装では、クライアントデバイス110がユーザ102のアイデンティティを受理した場合、クライアントデバイス110は、さらなる入力をユーザ102から待つことなく後続のアクションを実施してもよい。例えば、ユーザ102は検証段階の間に、クライアントデバイス110に対して「Hello Phone , search the nearest coffee shop」を話してもよい。クライアントデバイス110は、検証フレーズ「Hello Phone」を用いてユーザ102のアイデンティティを検証してもよい。ユーザ102のアイデンティティが受理された場合、クライアントデバイス110は、ユーザ102にさらなる入力を求めることなく、最も近いコーヒー店の検索を実施してもよい。一般に、幾つかの実装では、クライアントデバイス110がユーザ102のアイデンティティを受理した場合、クライアントデバイス110はロックされた状態からロックされていない状態に遷移することで応答してもよい。当該ロックされた状態において、クライアントデバイス110の1つまたは複数の能力は無効化またはブロックであり、当該ロックされていない状態では、当該能力は有効であり、または、ユーザ102がアクセスするのに利用可能とされる。同様に、クライアントデバイス110は、成功した検証に応答して、低電力状態からより完全に特徴付けられた状態に「活性化」または遷移してもよい。
幾つかの実装では、クライアントデバイス110がユーザ102のアイデンティティを拒絶した場合、クライアントデバイス110は、検証が拒絶されたという視覚的指示またはオーディオ指示をユーザ102に送信してもよい。幾つかの実装では、クライアントデバイス110がユーザ102のアイデンティティを拒絶した場合、クライアントデバイス110はユーザ102に別の発声試行を促してもよい。幾つかの実装では、試行の数が閾値を超過した場合、クライアントデバイス110は、ユーザ102が自分のアイデンティティをさらに検証するのを試みるのをブロックしてもよい。
図2を参照すると、ニューラルネットワーク206をトレーニングするための例示的なシステム200のブロック図が示されている。図2により示されたトレーニング段階が完了すると、当該トレーニングされたニューラルネットワーク206は、話者の発声を特徴付けるデータを処理し、当該話者の音声の区別的な特徴を示す当該話者に対する話者表現を生成することができる。当該話者表現はついで、加入段階の間に当該話者に対する話者モデルを生成するか、または検証段階の間に当該話者のアイデンティティを検証する際に話者検証モデルにより使用されてもよい。
一般に、図2は、ニューラルネットワーク206が、後に話者検証タスクを実施するクライアントデバイスで発生する加入および検証段階と平行する方式でトレーニングされてもよいことを示す。トレーニング発声を有限数の話者から当該話者の各々に対する対応するクラスに分類するためにニューラルネットワーク206をトレーニングする幾つかのアプローチとは異なり、図2のニューラルネットワーク206は、所与の発声の特定の話者を決定するためにトレーニングされない。その代わり、ニューラルネットワーク206は、当該発声の何れかを特定の話者イデンティティと必ずしもマッチすることなく、区別的かつ所与の発声の話者が別の1組の発声の話者と同一であるか否かを判定するために使用可能である話者表現を生成するためにトレーニングされる。このように、トレーニングの間に最適化された損失関数は、検証段階の間に当該話者検証モデルにより利用される同一の関数である。換言すれば、検証の間に、検証発声に基づく話者表現は加入したユーザに対する話者モデルと比較される。当該話者表現が当該話者モデルと十分に同様である場合、検証発声の話者のアイデンティティが検証される。図2に示す当該アプローチはトレーニングの間に同様な技術を使用する。即ち、シミュレートされた話者モデル214が1つまたは複数の加入発声に対する話者表現に基づいて生成され、話者表現208はまた、シミュレートされた検証発声202に対して生成される。ニューラルネットワーク206の重み値および他のパラメータは、シミュレートされた検証発声202をシミュレートされた加入発声204a乃至nと同一または異なる話者により話されているとして分類する際のエラーを最小化するために、トレーニングの間に調節される。
図2は、シミュレートされた検証発声202を特徴づけるデータおよび1つまたは複数のシミュレートされた加入発声204a乃至nを特徴づけるデータを含むトレーニングデータのサンプルに基づく単一のトレーニングの反復の前方パスを示す。実際に、ニューラルネットワーク206は、多数の反復およびトレーニングデータの多数の異なるサンプルにわたってトレーニングされる。各反復により、ニューラルネットワーク206を、当該各反復に対するトレーニングデータの対応するサンプルを処理した結果に基づいて調節してもよい。図4Aおよび4Bは、さらに以下で説明するように、シミュレートされた検証発声202およびシミュレートされた加入発声204a乃至nが選択されうる例示的な技術を示す。特定のサンプルに対するシミュレートされた加入発声204a乃至nは一般に、同一のトレーニング話者により話された全ての発声である。シミュレートされた加入発声204a乃至nの話者は異なるトレーニングの反復に対するトレーニングデータの異なるサンプルの間で異なってもよいが、所与のトレーニング反復に対する所与のトレーニング・サンプルにおいて、加入発声204a乃至nの全ては一般に同一のトレーニング話者により話される。シミュレートされた検証発声202はシミュレートされた加入発声204a乃至nの話者と同一のトレーニング話者により話されているかもしれず、または、シミュレートされた加入発声204a乃至nの話者と異なるトレーニング話者により話されているかもしれない。当該話者がシミュレートされた検証発声202とシミュレートされた加入発声204a乃至nの両方の間で同一であるトレーニングデータのサンプルに対して、当該サンプルを「マッチング」サンプルとしてラベル付けしてもよい。当該話者がシミュレートされた検証発声202およびシミュレートされた加入発声204a乃至nの間で異なるトレーニングデータのサンプルに対して、当該サンプルを「非マッチング」サンプルとしてラベル付けしてもよい。当該ラベルは当該トレーニング・サンプルの真の分類を表してもよく、トレーニングの前の前処理段階で決定してもよい。幾つかの実装では、ニューラルネットワーク206の出力に基づくトレーニング・サンプルの当該推定された分類は、当該トレーニング・サンプルに対するラベルにより示される真の分類と比較して、ニューラルネットワーク206を調節するかどうかを判定してもよい。
幾つかの実装では、当該トレーニング・サンプルにおけるデータは、当該シミュレートされた検証発声および加入発声202、204a乃至nに対する生のオーディオ信号はでなくてもよい。その代わり、発声202、204a乃至nが、ニューラルネットワーク206により処理するための適切なフォーマットに処理および変換されていてもよい。例えば、当該トレーニング・サンプルにおけるデータは、生のオーディオ信号自体ではなく、当該シミュレートされた検証発声および加入発声202、204a乃至nの各特徴を特徴付けてもよい。幾つかの実装では、当該トレーニング・サンプル内のシミュレートされた発声202、204a乃至nの各々を表すデータは各発声に対する1つまたは複数のログフィルタバンクを含んでもよい。幾つかの実装では、各発声を当該発声に対する複数のフレームに分割してもよく、別々のログフィルタバンクを当該発声のフレームごとに生成することができる。例えば、当該発声の各フレームは例えば40個のログフィルタバンクにより表されてもよい。
幾つかの実装では、シミュレートされた検証発声202を特徴づけるデータおよびシミュレートされた加入発声204a乃至nの各々を特徴づけるデータをニューラルネットワーク206を通じて一度(即ち、単一のパスで)処理することができる。したがって、所与の発声に対するトレーニングデータが各々各1組のログフィルタバンクにより表された複数のフレームに分割されているが、当該発声の全体に対するフレームの全てを特徴づけるデータを、ニューラルネットワークを通じて単一のパスで処理するために、ニューラルネットワーク206に(例えば、それぞれ40個のログフィルタバンクを有する80個のフレームに対する80x40個の特徴ベクトルとして)入力することができる。これは、当該フレームを別々に処理するために、当該発声のフレームごとにデータをニューラルネットワーク206に独立して入力するのとは対照的である。他の実装では、各発声202、204a乃至nの全体を特徴づけるデータを単一のパスでニューラルネットワーク206を通じて処理するためにニューラルネットワーク206をトレーニングするのではなく、発声202、204a乃至nの独立なフレームを特徴づけるデータを、ニューラルネットワーク206への入力として提供することができる。
幾つかの実装では、シミュレートされた検証発声および加入発声202、204a乃至nを1つまたは複数の追加の技術に従って事前に処理してもよい。例えば、ニューラルネットワーク206の構造は、トレーニング発声が全て固定された長さ(例えば、0.8秒のオーディオ)を有するのを要求してもよい。少なくとも幾つかの発声202、204a乃至nはしたがって、長い発声を均一な長さに刈り込み、かつ/または幾つかの短い発声をパディングして長いクリップを作成した結果であってもよい。他の実装では、しかし、ニューラルネットワーク206は可変長さ発声を処理できてもよく、この場合、トレーニングデータ内の発声202、204a乃至nを固定された長さに刈り込むかまたはパディングしてもよい。発声202、204a乃至nに対するオーディオはまた均一化されていてもよく、雑音の存在において堅牢に実施されるようにニューラルネットワークがトレーニングされることを保証するために、トレーニング発声202、204a乃至nに雑音が追加されているかまたはそこから雑音が除去されていてもよい。
点線ボックス215内のシステム200の部分は、複数のシミュレートされた加入発声204a乃至nを特徴づけるデータがシミュレートされた加入発声204a乃至nの特定のトレーニング話者に対するシミュレートされた話者モデル214を生成するために使用されるという点で、話者検証プロセスの加入段階をシミュレートする。シミュレートされた加入発声204a乃至nの各々を特徴づけるそれぞれのデータはニューラルネットワーク206ニューラルネットワーク206の入力レイヤに別々に入力される。ニューラルネットワーク206は1つまたは複数の隠蔽されたレイヤを通じて当該データを処理し、シミュレートされた加入発声204a乃至nの各々に対する各話者表現210a乃至nを生成する。例えば、図2に示すように、話者表現1(210a)はシミュレートされた加入発声1に基づいてニューラルネットワーク206により生成される(204a)。同様に、話者表現2(210b)はシミュレートされた加入発声2に基づいてニューラルネットワーク206により生成される(204b)。話者表現はしたがって、シミュレートされた加入発声204a乃至nの各々に対するニューラルネットワーク206により生成されてもよい。幾つかの実装では、話者表現210a乃至nを、ニューラルネットワーク206を通じてシミュレートされた加入発声204a乃至nの各々を逐次的に処理することで生成してもよい。幾つかの実装では、話者表現210a乃至nを、発声204a乃至nを特徴付けるデータを、シミュレートされた加入発声204a乃至nの各々に対するニューラルネットワーク206の各インスタンスと並列に処理することで並列に生成することができる。話者表現210a乃至nは一般にそれぞれ、シミュレートされた加入発声204a乃至nの対応する1つに基づいてニューラルネットワーク206により決定された、当該シミュレートされた加入トレーニング話者の音声の区別的な特性を表す値の集合を含む。幾つかの実装では、話者表現210a乃至nはニューラルネットワーク206の最後の隠蔽されたレイヤの重み値または他のパラメータを示してもよい。幾つかの実装では、話者表現210a乃至nは、ニューラルネットワーク206がソフトマックス出力レイヤなしに構成されたときの、ニューラルネットワーク206の最終的な出力であってもよい。
シミュレートされた話者モデル214を生成するために、話者表現210a乃至nを図2のボックス212に示すように平均化することができる。したがって、シミュレートされた話者モデル214は、シミュレートされた加入発声204a乃至nのトレーニング話者の音声の区別的な特性を表す値の集合を定義してもよい。シミュレートされた話者モデル214を決定するために複数の話者表現210a乃至nを平均化することで、当該異なるシミュレートされた加入発声204a乃至nの間の話者の音声の変形を平滑化することができる。シミュレートされた話者モデル214は、独立な話者表現210a乃至nの何れかよりも高信頼な話者の音声の表現であってもよい。これは、所与のシミュレートされた加入発声204a乃至nの特質を独立に反映してもよい。
幾つかの実装では、トレーニングデータの各サンプル内のシミュレートされた加入発声204a乃至nの総数はトレーニングの反復ごとに変化してもよい。例えば、第1のトレーニングの反復に対する第1のトレーニング・サンプルは9個のシミュレートされた加入発声204a乃至nを含んでもよい。第2のトレーニングの反復に対する第2のトレーニング・サンプルは、しかし、4個のシミュレートされた加入発声204a乃至nのみを含んでもよい。他の実装では、トレーニングデータの各サンプル内のシミュレートされた加入発声204a乃至nの総数はトレーニングの反復ごとに固定されていてもよい。例えば、ニューラルネットワーク206は、当該1組のトレーニングデータが反復ごとに全体で5個のシミュレートされた加入発声204a乃至nを含む一連の反復でトレーニングされてもよい。幾つかの実装では、当該トレーニングの反復の1つ、一部または全部を、単一のシミュレートされた加入発声204a乃至nのみを含むトレーニング・サンプルで実施してもよい。
話者表現210a乃至nが、シミュレートされた加入発声204a乃至nを特徴付けるデータから生成されたのと同一の方式で、話者表現208を、シミュレートされた検証発声202を特徴付けるデータから生成することができる。当該シミュレートされた検証発声202を特徴付けるデータ(例えば、検証発声202の特徴を特徴づけるログフィルタバンク値)をニューラルネットワーク206の入力レイヤに提供することができる。ニューラルネットワーク206次いで、当該ネットワークの1つまたは複数の隠蔽されたレイヤを通じて入力を処理する。ニューラルネットワーク206の出力は、シミュレートされた検証発声202を話した話者の音声の区別的な特性を示す値の集合を定義する話者表現208である。
ニューラルネットワーク206のトレーニングの間の検証段階とさらに並行するために、シミュレートされた検証発声202に基づく話者表現208は、例えば、検証段階の間に話者検証モデルによりクライアントデバイスで行われるのと同一の方式でシミュレートされた話者モデル214と比較されることができる。幾つかの実装では、当該比較を、(1)シミュレートされた話者表現208に対して値の集合を定義する第1のベクトルおよび(2)シミュレートされた話者モデル214に対する値の集合を定義する第2のベクトルの余弦距離を(ブロック216に示すように)取得することにより実施することができる。ロジスティック回帰218を次いで当該距離に適用して、シミュレートされた検証発声202を話したトレーニング話者が、シミュレートされた加入発声204a乃至nを話したトレーニング話者と同一であるかまたは異なるかどうかを推定することができる。これは、マッチング話者クラスに対する第1のブロック220a、および非マッチング話者クラスに対する第2のブロック220bにより図2で表されている。幾つかの実装では、ロジスティック回帰218と異なる分類技術を適用して、シミュレートされた検証発声202を話したトレーニング話者が、シミュレートされた加入発声204a乃至nを話したトレーニング話者と同一であるかまたは異なるかどうかに関する判定を行ってもよい。例えば、ヒンジレイヤまたはソフトマックスレイヤを幾つかの代替的な分類に対して使用してもよい。図2に示すような2つのクラスモデルでは、当該そフトマックスおよびロジスティック回帰技術は同一のまたは同様な最適化機能を使用してもよい。
ニューラルネットワーク206の重み値または他のパラメータを次いで、ブロック222により表されるように、シミュレートされた検証発声202に対する話者表現208のシミュレートされた話者モデル214との比較の結果に基づいて、調節することができる。例えば、当該トレーニング・サンプルが真に非マッチング話者を有するとしてラベル付けされ、不正確に分類されたトレーニング・サンプルがマッチング話者を有するとして分類された場合、ニューラルネットワーク206はエラーを補正するように自動的に調節されてもよい。より一般に、ニューラルネットワーク206を最適化して、話者サンプルをマッチングするための類似性スコアを最大化するか、または、ロジスティック回帰によるスコア出力を最適化してもよく、ニューラルネットワーク206をまた最適化して、非マッチング話者サンプルに対する類似性スコアを最小化するか、またはロジスティック回帰によるスコア出力を最適化してもよい。幾つかの実装では、ニューラルネットワーク206に対する調節を、トレーニングの反復ごとに各トレーニング・サンプルの結果に応答して行うことができ、またはニューラルネットワーク206をトレーニングの反復の幾つかのみの結果に基づいて調節してもよい。幾つかの実装では、ニューラルネットワーク206を、話者表現208および非マッチング話者に対するシミュレートされた話者モデル214の間の距離(即ち、差異の最大化)を最大化し、話者表現208およびマッチング話者に対するシミュレートされた話者モデル214の間の距離を最小化(即ち、差異を最小化)するように調節してもよく。幾つかの実装では、トレーニング・サンプルをマッチング話者クラス220aまたは非マッチング話者クラス220bの何れかに属するとして分類するための硬判定をトレーニング段階の間に行わなくてもよいことに留意されたい。寧ろ、ニューラルネットワーク206を、ロジスティック回帰レイヤ218により出力される当該スコアを最適化するか、または、1つまたは複数の他のメトリックを最適化する方式で調節してもよい。
次に図3を参照すると、話者検証モデルで使用されうるニューラルネットワークをトレーニングするための例示的なプロセス300の流れ図が示されている。幾つかの実装では、プロセス300を、図1からのコンピューティングシステム120および図2からのコンピューティングシステム200のような本明細書で説明するコンピューティングシステムにより実行してもよい。
プロセス300は段階302で開始し、第1の1組のトレーニングデータが選択される(即ち、第1のトレーニング・サンプル)。第1の1組のトレーニングデータは、シミュレートされた検証発声を特徴づけるデータおよび1つまたは複数のシミュレートされた加入発声を特徴づけるデータを含むことができる。当該トレーニングセットにおける発声は、それらがトレーニング段階の間に話者検証の加入段階および検証段階を並行させるかまたは「シミュレート」する方式でトレーニングプロセスで使用されるという点で、「シミュレートされる」。しかし、当該発声自体は一般に、トレーニング話者により話された記録された会話の実際のスニペットである。当該トレーニング話者は一般に、当該話者検証プロセスの実際の加入および検証段階の間に発声を提供した同一の話者ではない。下記でさらに説明する図4Aおよび4Bは、当該シミュレートされた検証発声および加入発声を選択するための例示的な技術を示す。
当該選択された1組のトレーニングデータ(即ち、選択されたサンプル)を、それがマッチング話者の会話または非マッチング話者に対するサンプルを表すかどうかに従ってラベル付けしてもよい。当該シミュレートされた検証発声の話者が当該シミュレートされた加入発声の話者と同じである場合、当該1組のトレーニングデータはマッチング話者サンプルとしてラベル付けされる。当該シミュレートされた検証発声の話者が当該シミュレートされた加入発声の話者と異なる場合、当該1組のトレーニングデータが非マッチング話者サンプルとしてラベル付けされる。幾つかの実装では、当該ラベルを、マッチングまたは非マッチングサンプルの何れかであるとして当該1組のトレーニングデータの推定された分類が正確であるか否かを判定するために、後にトレーニングプロセス300において使用することができる。
幾つかの実装では、選択された1組のトレーニングデータは、シミュレートされた検証発声および加入発声に対する生のオーディオ信号ではなく、その代わり当該発声の特徴を特徴付けるデータを含んでもよい。例えば、当該1組のトレーニングデータで表された各発声は、当該発声の固定長のフレームに対して決定された1組のログフィルタバンクにより特徴付けられることができる。当該発声のフレームごとの当該ログフィルタバンクをついで、ニューラルネットワークへの入力として提供され当該発声の全体を分類する単一の1組の入力値に連結してもよい。
プロセス300の段階304および306で、話者表現は、第1の1組のトレーニングデータで分類される発声の各々に対して決定される。当該話者表現はそれぞれ、当該各話者表現に対する対応する発声を話した当該トレーニング話者の音声の区別的な特徴を示す値の集合であることができる。例えば、第1の話者表現が当該シミュレートされた検証発声に基づいて生成されてもよく、各第2の話者表現が当該シミュレートされた加入発声の各々に基づいて生成されてもよい。当該話者表現を生成するために、発声を特徴づけるデータが、トレーニングされているニューラルネットワークの入力レイヤに提供される。ニューラルネットワークは次いで、当該ネットワークの1つまたは複数の隠蔽されたレイヤを通じて当該入力データを処理する。当該話者表現は次いでニューラルネットワークの出力である。幾つかの実装では、当該出力は、ソフトマックスレイヤではない出力レイヤで出力される。当該出力を提供する最終的なレイヤは完全に接続された線形レイヤであってもよい。幾つかの実装では、当該話者表現は、ソフマックス出力レイヤの出力ではなく、ニューラルネットワークの最後の隠蔽されたレイヤで生成された値またはその活性化を含んでもよい。幾つかの実装では、ニューラルネットワークをソフトマックス出力レイヤなしで構成してもよい。
段階308で、当該シミュレートされた加入発声に対応する話者表現が、シミュレートされた話者モデルを生成するために結合される。当該シミュレートされた話者モデルは、当該シミュレートされた加入発声に対する話者表現の平均であることができる。当該話者表現を平均化することで、当該トレーニング話者の音声を特徴づける高信頼のモデルを決定することができる。例えば、当該話者が当該シミュレートされた加入発声の各々を話した方式の変形を、当該シミュレートされた検証発声に対する話者表現が比較される堅牢なベースラインで当該話者モデルを使用できるように、平滑化してもよい。幾つかの実装では、プロセス300は、当該シミュレートされた加入発声に対する話者表現のサブセットのみを選択して、当該シミュレートされた話者モデルを生成する際に結合してもよい。例えば、当該シミュレートされた加入発声の各々または当該対応するシミュレートされた加入発声の品質の測定値を決定してもよい。プロセス300はついで、当該シミュレートされた話者モデルを生成するために使用される1組の表現に含めるために、閾値品質スコアを満たすこれらの話者表現のみ、または対応する発声が閾値品質スコアを満たすこれらの話者表現を選択してもよい。
段階310で、シミュレートされた検証発声に対する話者表現がシミュレートされた話者モデルと比較される。幾つかの実装では、二進クラシファイアが、マッチング話者を表すかまたは表さないとしてデータサンプルを分類するために使用される。幾つかの実装では、当該比較は、当該シミュレートされた検証発声に対する話者表現および当該シミュレートされた話者モデルの間の類似性の測定値を決定するステップを含むことができる。例えば、類似性の測定値は、当該話者表現に対する値のベクトルと当該シミュレートされた話者モデルに対する値のベクトルの間の余弦距離であってもよい。類似性の測定値はついで、マッチング話者サンプルまたは非マッチング話者サンプルの何れかとして第1の1組のトレーニングデータの分類を推定するために使用されてもよい。例えば、類似性の測定値が十分に高い(例えば、閾値類似性スコアを満たす)場合、ロジスティック回帰を、当該1組のトレーニングデータをマッチング話者のクラスにマップするために使用してもよい。他方、類似性の測定値が低すぎる(例えば、閾値類似性スコアを満たさない)場合、ロジスティック回帰を、当該1組のトレーニングデータを非マッチング話者のクラスにマップするために使用してもよい。
次に、段階312で、ニューラルネットワークの1つまたは複数のパラメータを、シミュレートされた検証発声に対する話者表現およびシミュレートされた話者モデルの間の段階310での比較の結果に基づいて調節してもよい。例えば、当該トレーニングデータが非マッチング話者サンプルとしてラベル付けされた場合に、隠蔽されたレイヤにおける様々なノードの重み、またはニューラルネットワークの他のパラメータを調節して、当該話者表現および当該シミュレートされた話者モデルの間の距離を増大(類似性スコアを減少)させてもよい。さらに、当該トレーニングデータがマッチング話者サンプルとしてラベル化された場合に、ニューラルネットワークの重みまたは他のパラメータを調節して、当該話者表現および当該シミュレートされた話者モデルの間の距離を削減(当該類似性スコアを増大)させてもよい。一般に、トレーニングプロセス300の各反復は各加入段階および各検証段階をシミュレートすることを意図しているので、ニューラルネットワークを調節して、話者検証の間に実際の加入および検証段階に適用されるたものと同一の損失関数を最適化してもよい。このアプローチの1つの利益は、ニューラルネットワークが、より正確な検証話者のアイデンティティのための話者検証モデルにおいて使用できる話者表現をより良く生成するためにトレーニングされるということである。例えば、幾つかの実装では、ニューラルネットワークをトレーニングするときに考慮されない発声の実際の検証の間に追加の後処理ステップが行われない。これらの技術を、ニューラルネットワークをトレーニングするための「エンド・ツー・エンド」のアプローチと考えてもよい。
最後に、段階314で、次に1組のトレーニングデータが、トレーニングニューラルネットワークの別の反復に対して選択される。再度、この段階で選択された当該1組のトレーニングデータはシミュレートされた検証発声を特徴付けるデータおよび1つまたは複数のシミュレートされた加入発声を特徴付けるデータを含んでもよい。プロセス300はついで、段階304乃至312を反復し、追加のトレーニングの反復に対するトレーニングデータの追加のセットを限界に達するまで選択し続けてもよい。幾つかの実装では、当該限界が、利用可能なトレーニングデータの全てが期限切れになることから生じてもよい。幾つかの実装では、プロセス300をターゲット性能レベルに到達するまで続けてもよい。例えば、何回かのトレーニングの反復の後、ニューラルネットワークを、トレーニングプロセス300の間に使用されなかった差し出された1組のデータに対してテストしてもよい。トレーニングを、当該差し出されたセット上の試験が、ニューラルネットワークが少なくともターゲット性能レベルを達成したことを示すまで、続けてもよい。
次に図4Aおよび4Bを参照すると、話者検証モデルに対するニューラルネットワークをトレーニングする際に使用するためのトレーニングデータのセットを選択するための例示的な技術を示す略図が示されている。幾つかの実装では、図4Aおよび4Bに関して説明された技術は、多数のトレーニングの反復にわたって選択されたトレーニング発声の多様性を保証することができる。これは、所与の数のトレーニング発声に対してニューラルネットワークをより良く実施することをもたらしうる。
幾つかの実装では、当該利用可能なトレーニング発声の全部のまたは一部を複数のグループ410a乃至nにクラスタ化してもよい。グループ410a乃至nを、トレーニング発声のグループの集合を含む発声プール408にさらに構成してもよい。当該トレーニング発声を幾つかの実装では話者によりグループ化してもよい。例えば、グループ410aは、全て第1の話者により話された複数の発声を含み、グループ410nは全て別の話者により話された複数の発声を含む。したがって、グループ410a乃至nの各々は異なる話者に対応してもよい。グループ410a乃至nは全て同一のトレーニング発声の数を含んでもよく、またはトレーニング発声の数はグループ410a乃至nの異なるものの間で変化してもよい。
トレーニングの反復ごとに、発声プール408にアクセスしてもよく、特定の発声を、各トレーニングの反復における入力として適用されるトレーニングデータのサンプルに対して選択してもよい。例えば、図4Aは、入力サンプル402としてトレーニングの反復のために発声プール408からランダムに選択された1つの1組のトレーニングデータを示す。第1の話者に対応する第1の発声グループは、当該シミュレートされた話者モデルを生成する際に使用するための発声プール408内のグループ410a乃至nから選択することができる。当該グループをランダムにまたは別の方式で選択してもよい。当該選択されたグループ、例えば、図4Aのグループ410aから、当該第1の話者の発声のサブセットが、入力サンプル402内のシミュレートされた加入発声406として選択される。このサブセットは一般に複数の発声を含み、或るトレーニングの反復から別の反復へと、同一数または異なる数の発声を含んでもよい。当該選択されたグループ、例えば、グループ410aからの発声をランダムに選択してもよく、その結果、当該発声の異なる組合せが、異なるトレーニングの反復において第1の話者に対する異なるシミュレートされた話者モデルを生成するために使用される。
発声404もシミュレートされた検証発声として選択される。発声404は、当該トレーニングの反復が加入発声406とのマッチまたは非マッチの1例であるかどうかに依存して、第1の話者または異なる話者の発声であってもよい。マッチングおよび非マッチングの例の両方がトレーニングで使用される。結果として、幾つかのトレーニングの反復に対して、発声404は、第1の話者の発声、例えば、グループ410aからの発声である。他のトレーニングの反復に対して、発声404は、図4Aに示すように、第1の話者と異なる第2の話者の発声であり、その結果入力サンプル402はシミュレートされた検証発声404とシミュレートされた加入発声406の間のマッチを表さない。
図4Aの例では、特定の発声が、シミュレートされた検証発声404として第2の発声グループ410nから選択される(例えば、ランダムに選択される)。幾つかの実装では、(発声404がそこから選択される)第2の発声グループを、発声プール408内のグループ410a乃至nからランダムに、または、グループ410a乃至nの変化する選択のパターンに従って選択してもよい。他の実装では、当該シミュレートされた加入発声の話者と同一の話者からの別の発声が当該シミュレートされた検証発声として適用されるべきかどうかに関してランダムな選択を行ってもよい。したがって、おそらく当該ランダムな選択がバイアスされ、その結果、シミュレートされた検証発声404がシミュレートされた加入発声の話者406と同一の話者の発声であるという50パーセントの可能性が存在する。当該ランダムな選択の結果が、入力サンプル402がマッチング話者サンプルであるというものである場合、シミュレートされた検証発声404を、シミュレートされた加入発声406が選択された発声のグループと同一の発声のグループ410から選択することができる。しかし、当該ランダムな選択の結果が、入力サンプル402が非マッチング話者サンプルであるというものである場合、シミュレートされた検証発声404を、シミュレートされた加入発声406がそこから選択された発声のグループと異なる話者に対応する発声410の異なるグループから選択することができる。
一般に、図4Aにより示される選択技術は、話者の異なる組合せからの発声を異なるトレーニングの反復で適用させることができる。例えば、第1のトレーニングの反復において、当該シミュレートされた加入発声は第1の話者により話されているかもしれず、当該シミュレートされた検証発声はまた第1の話者により話されているかもしれない。第2のトレーニングの反復において、当該シミュレートされた加入発声は第2の話者により話されているかもしれず、当該シミュレートされた検証発声は第3の話者により話されているかもしれない。次に第3のトレーニングの反復において、当該シミュレートされた加入発声は第1の話者により話されているかもしれず、当該シミュレートされた検証発声は第2の話者により話されているかもしれない。幾つかの実装では、異なる順列を生成するかまたは当該シミュレートされた検証発声と加入発声の話者の間の入力サンプル402における順列数を最大化する方式で発声410a乃至nのグループをランダムに選択せずその代わり決定的に発声410a乃至nのグループを選択する、選択アルゴリズムを使用してもよい。単純な例として、3つの異なるトレーニング話者からの発声の3つのグループA、B、およびCが発声プール408で利用可能であった場合、9個の異なる入力サンプル402が9個のトレーニングの反復、即ち、(A、A)、(A、B)、(A、C)、(B、A)、(B、B)、(B、C)、(C、A)、(C、B)、および(C、C)に関して生成されてもよい。トレーニングの反復はまた、これらの同一のグループのペアとともに生じうるが、当該グループ内では異なる発声が選択される。
本明細書で説明する当該トレーニングアプローチの1つの履歴は、事前に選択された数の話者のうち特定の話者に属するとして入力を分類するためにニューラルネットワークをトレーニングすることを含む他のアプローチと対照的に、より多くの様々な話者を当該ネットワークをトレーニングするために使用してもよい。さらに、高信頼のトレーニングを保証するためにトレーニング話者ごとに要求される(トレーニング話者ごとに実際に使用される当該1つまたは複数の発声以外の)最小数のトレーニング発声はない。なぜならば、当該ネットワークは特定の話者に対してトレーニングされず、その代わり所与の入力サンプル402が当該シミュレートされた検証発声および加入発声の中にマッチング話者または非マッチング話者があるかどうかに基づいてトレーニングされるからである。
図4Bは、ニューラルネットワークのトレーニングの間に入力サンプルに関する発声を選択するためのシャッフル技術の略図400bを示す。本図に示すように、トレーニング・サンプルのバッチにおけるサンプルは全て、当該バッチ内のトレーニング・サンプルの間の発声の良好なシャッフルおよび多様性を取得するために異なるプールから来ることができる。当該シャッフル技術は、より堅牢なおよび高信頼のニューラルネットワークのトレーニングをもたらしうる。
図5Aおよび5Bを参照すると、話者検証モデルで使用されうる例示的なニューラルネットワーク502、512のブロック図が示されている。幾つかの実装ではニューラルネットワーク502、512の何れかを、図1乃至4Bおよび6に関して説明した技術を実装するために使用してもよく、図2乃至4Bに関して説明したトレーニング技術を含む。
図5Aのディープ・ニューラルネットワーク502のアーキテクチャは、ローカルに接続されたレイヤ504を含み、それに続いて1つまたは複数の完全に接続された隠蔽されたレイヤ506a乃至nを含む。ローカルに接続されたレイヤ504および完全に接続されたレイヤ506a乃至nは整流線形ユニット(ReLU)を有してもよい。ネットワーク502の最後のレイヤは完全に接続された線形レイヤ508であり、これは、入力発声(または発声のフレーム)503aに基づいて話者表現510aを出力する。表現510aの前の最後のレイヤ502は、幾つかの実装では、非負の活性化を全空間にマップし、投影を決定するための線形レイヤである。当該全空間は、ReLu活性化がy=max(x、0)のような関数でありうるという概念を指す。したがって、当該話者表現を形成する活性化(y)は常に正のベクトルであってもよい。かかる活性化関数が線形活性化関数y=xにより変更される場合、当該話者表現を潜在的に正負の値を有するベクトルとして生成することができる。後者は、例えば、それに余弦距離比較関数が続くとき、当該話者のより適切な表現であることができる。
ニューラルネットワーク502の構成は一般に、固定された長さのトレーニング発声、または固定された数の発声のフレームを処理することができる。ニューラルネットワーク502がトレーニングされ、後に加入および検証段階における実行時の間に使用されるとき、発声を適切に刈り込みまたはパディングして、当該発声がニューラルネットワーク502により処理するために要求される固定長を有することを保証してもよい。結果として、ニューラルネットワーク502は、単一のパス、例えば、ディープ・ニューラルネットワーク502を通じた単一の前方伝播で話者表現を計算することができる。これにより、当該話者表現を、発声の異なる部分の逐次的処理を含む技術より低いレイテンシで生成することができる。
次に、図5Bに示すニューラルネットワーク512は、再帰型ニューラルネットワークである。ニューラルネットワーク502のアーキテクチャと異なり、ニューラルネットワーク512は可変長の入力発声を処理することができる。例えば、発声503bは、ニューラルネットワーク512が使用されているコンテキストに依存して、トレーニング発声、加入発声、または検証発声であってもよい。発声503bを複数のフレームに分割してもよく、当該複数のフレームは固定長を有してもよい。ニューラルネットワーク512に入力されたフレームの数は、発声503bの全体の長さの関数であってもよい。換言すれば、長い発声はより多くのフレームを有してもよく、短い発声はより少ないフレームを有してもよい。発声503bのフレームは長短期メモリ(LSTM)レイヤ516に入力される。1つまたは複数の追加の隠蔽されたレイヤがLSTMレイヤ516に続いてもよい。ネットワーク512の最後のレイヤは再度、完全に接続された線形レイヤ518である。幾つかのケースでは、完全に接続された線形レイヤ518は、非負の活性化を当該全空間にマッピングし、投影を決定することで話者表現510bを出力してもよい。ニューラルネットワーク512は可変長さ発声を扱うことができるので、これは発声の単語またはフレーズが予め定義されず異なる発声の間で変化しうるテキスト独立な話者検証に良く適しうる。
図5Aおよび5Bに示すニューラルネットワーク502および512は特定の構成を有するとして示されているが、本明細書で説明する当該技術で使用されうるニューラルネットワークはこれらの例により限定されない。例えば、ニューラルネットワークの隠蔽されたトポロジは異なる数および配置のレイヤを有してもよく、当該レイヤは、完全に接続されたレイヤ、ローカルに接続されたレイヤ、または長短期メモリレイヤのような任意の回帰レイヤを含んでも含まなくてもよい。幾つかの実装では、ニューラルネットワークは従来型のニューラルネットワークであってもよい。
図6は、本明細書で説明する技術に従ってトレーニングされている話者検証モデルおよびニューラルネットワークを用いて発声を検証するための例示的なプロセス600の流れ図である。プロセス600は一般に図1に示す検証段階(段階E乃至G)に対応する。図6で参照されるニューラルネットワークは、幾つかの実装では、図2乃至4Bに関して説明した技術に従ってトレーニングされてもよく、図5Aまたは5Bに示すような構造を有してもよい。
段階602で、発声はコンピューティングデバイスのユーザから受信されることができる。例えば、ユーザは、自分のスマートフォンをアンロックするか、または、幾つかの他の機能をコンピューティングデバイスで実施したいかもしれない。しかし、スマートフォンは、それがロックされない前に、または所望の機能が実施される前にユーザを認証するようにユーザに要求してもよい。幾つかの実装では、当該認証を、スマーフォンの話者検証モデルを用いてユーザの音声の特性に基づいて実施してもよい。スマーフォンは、検証発声を話すようにユーザに促してもよく、検証発声を段階602でスマーフォンにより受信し記録してもよい。
段階604で、スマーフォンは、当該受信された発声に基づいて話者表現を生成するためにニューラルネットワークにアクセスする。ニューラルネットワークは、ローカルにスマーフォンに格納されてもよく、または例えば、アプリケーションプログラミングインタフェース(API)を介してリモートコンピューティングシステム上でアクセスされてもよい。ニューラルネットワークは本明細書で説明する技術に従ってトレーニングされてもよく、それぞれシミュレートされた検証発声および複数のシミュレートされた加入発声を含むデータのサンプルに基づいてトレーニングされているかもしれない。ニューラルネットワークは、単一のパス内でニューラルネットワークを通じて、発声の全体を特徴付けるデータを処理するように構成されてもよい。段階606で、当該受信された発声を特徴付けるデータがニューラルネットワークへの入力として提供される。ニューラルネットワークは、当該入力を処理し、ユーザの音声の区別的な特性を示す話者表現を生成する。
段階608で、話者モデルがスマーフォンでアクセスされる。当該話者モデルは加入したユーザの音声の区別的な特徴を示してもよい。幾つかの実装では、当該話者モデルが、加入したユーザの各発声を特徴付けるデータからニューラルネットワークにより生成された複数の話者表現の平均に基づいてもよい。段階610で、検証発声に基づいて段階606で生成された話者表現が、当該話者モデルと比較され、または、そうでない場合は当該話者モデルに関して評価される。幾つかの実装では、当該比較または他の評価がユーザのスマーフォン上で話者検証モデルにより実施される。当該話者検証モデルは、検証発声に対する話者モデルと話者表現の間の類似性の距離または他の測定値を決定してもよい。類似性の距離または他の測定値に基づいて、当該話者検証モデルは、ユーザの音声が加入したユーザの音声と十分に同様である場合に、ユーザを認証してもよい。そうでない場合、ユーザの音声の類似性が加入したユーザの音声に関して少なくとも閾値類似性スコアを満たさない場合に、当該話者検証モデルはユーザが認証されないという指示を生成してもよい。
幾つかの実装では、当該話者検証モデルが、検証発声が加入した話者により話されたことを十分な確信度で判定した場合、加入したユーザに対する話者モデルをついで、検証発声に基づいて更新してもよい。例えば、当該デバイスが以下の3つの検証発声にどのように応答しうるかを考える。当該話者検証モデルが第1の検証発声を話したユーザのアイデンティティを拒否する(例えば、デバイスは第1の検証発声に応答してアンロックを拒否してもよい)ように、3つの検証発声のうち最初のものに対する類似性スコアは第1の閾値より小さい。当該3つの検証発声のうち2番目のものに対する類似性スコアは、第2の検証発声を話したユーザのアイデンティティが受理されるように、第1の閾値を満たしてもよい。しかし、第2の検証発声に対する類似性スコアは、加入したユーザの話者モデルを第2の検証発声に基づいて更新するために十分に高い。最後に、検証発声のうち第3のものに対する類似性スコアが、第3の検証発声を話したユーザのアイデンティティが受理される(例えば、デバイスのアンロックのような第1の1組のアクションを実施してもよい)ように、第1の閾値を満たし、また、加入したユーザに対する当該話者モデルが第3の検証発声に基づいて更新されうるように、より高い第2の閾値を満たす。当該話者モデルが、第3の検証発声に対してニューラルネットワークにより生成された話者表現を第1のインスタンス内の話者モデルを生成するために使用されたユーザの加入発声からの他の話者表現と結合(例えば、平均化)することで更新されてもよい。
段階612で、スマーフォンは次いで、ユーザが認証されたかどうかに基づいて動作を行うことができる。例えば、当該発声を提供したユーザが加入したユーザであるという判定に応答して、スマーフォンを起動またはアンロックしてもよい。しかし、当該発声を提供したユーザがが加入したユーザでないか、または、複数の加入したユーザの1つでないと判定された場合、スマーフォンはロックされたままであってもよく、または、そうでない場合はユーザが実施するために選択された1つまたは複数の機能の実施をブロックしてもよい。別のアプリケーションでは、本明細書で説明する話者検証技術をユーザデバイス(例えば、スマートフォン、ノートブックコンピュータ、ウェラブルデバイス)で使用して、当該デバイスにより非認証されたユーザ(例えば、音声当該デバイスで加入されていないユーザ)から検出された会話入力を拒否してもよい。例えば、当該デバイスがロックされていない状態であるとき、当該デバイスは、ユーザが当該デバイスに実施してほしいアクション(例えば「Navigate to the football game」または「Play my music collection」)を示すデバイスの認証されたユーザにより話された音声コマンドをリッスンしてもよい。幾つかの実装では、当該音声コマンドが当該認証されたユーザにより話されたと判定できる場合には、当該デバイスは当該音声コマンドにより示される当該要求されたアクションをのみを実施してもよい。このように、他の非認証されたユーザからの雑談を、例えば、拒絶してもよい。
図7は、本明細書で説明する技術を実装するために使用できるコンピューティングデバイス700およびモバイルコンピューティングデバイスの1例を示す。コンピューティングデバイス700は、ラップトップ、デスクトップ、ワークステーション、携帯情報端末、サーバ、ブレードサーバ、メインフレーム、および他の適切なコンピュータのような様々な形態のデジタルコンピュータを表すことを意図している。当該モバイルコンピューティングデバイスは、携帯情報端末、セルラスマーフォン、スマートフォン、および他の同様なコンピューティングデバイスのような様々な形態のモバイルデバイスを表すことを意図している。ここで示したコンポーネント、それらの接続および関係、およびそれらの機能は例示的なものにすぎず、本明細書で説明および/またはクレームした発明の実装を限定しようとするものではない。
コンピューティングデバイス700は、プロセッサ702、メモリ704、記憶デバイス706、メモリ704および複数の高速拡張ポート710に接続する高速インタフェース708、および低速拡張ポート714および記憶デバイス706に接続する低速インタフェース712を含む。プロセッサ702、メモリ704、記憶デバイス706、高速インタフェース708、高速拡張ポート710、および低速インタフェース712の各々は様々なバスを用いて相互接続され、必要に応じて共通のマザーボード上でまたは他の方式でマウントされてもよい。プロセッサ702は、高速インタフェース708に接続されるディスプレイ716のような外部入力/出力デバイスにGUIに関するグラフィカル情報を表示するためのメモリ704または記憶デバイス706に格納された命令を含む、コンピューティングデバイス700内で実行するための命令を処理することができる。他の実装では、複数のプロセッサおよび/または複数のバスは、必要に応じて、複数のメモリおよびメモリのタイプに沿って使用されてもよい。また、複数のコンピューティングデバイスは、(例えば、サーババンク、ブレードサーバのグループ、またはマルチプロセッサシステムとして)必要な動作の部分を提供する各デバイスと接続されてもよい。
メモリ704は情報をコンピューティングデバイス700内に格納する。幾つかの実装では、メモリ704は揮発性メモリユニットまたはユニットである。幾つかの実装では、メモリ704は非揮発性メモリユニットまたはユニットである。メモリ704はまた、磁気または光ディスクのような別の形態のコンピュータ可読媒体であってもよい。
記憶デバイス706は大容量記憶をコンピューティングデバイス700に提供することができる。幾つかの実装では、記憶デバイス706は、記憶領域ネットワークまたは他の構成でのデバイスを含む、フロッピーディスクデバイス、ハードディスクデバイス、光ディスクデバイス、またはテープデバイス、フラッシュ・メモリまたは他の同様な固体状態メモリデバイス、またはデバイスのアレイのようなコンピュータ可読媒体であってもよいかまたはそれを含んでもよい。当該コンピュータプログラム製品はまた、実行されたとき上述したような1つまたは複数の方法を実施する命令を含んでもよい。当該コンピュータプログラム製品をまた、プロセッサ702上のメモリ704、記憶デバイス706、またはメモリのようなコンピュータまたはマシン可読媒体で有形に具体化することができる。
高速インタフェース708はコンピューティングデバイス700に対する帯域幅集約的な動作を管理し、低速インタフェース712はより低い帯域幅集約的な動作を管理する。かかる機能の割当ては例示的なものにすぎない。幾つかの実装では、高速インタフェース708は、(例えば、グラフィックスプロセッサまたはアクセラレータを通じて)メモリ704、ディスプレイ716に接続され、高速拡張ポート710に接続される。高速拡張ポート710は様々な拡張カード(図示せず)を受けつけてもよい。当該実装では、低速インタフェース712は記憶デバイス706および低速拡張ポート714に接続される。低速拡張ポート714は、様々な通信ポート(例えば、USB、Bluetooth(登録商標)、イーサネット(登録商標)、ワイヤレスイーサネット)を含んでもよく、キーボード、ポインティングデバイス、スキャナのような1つまたは複数の入力/出力デバイス、またはスイッチまたはルータのようなネットワーキングデバイスに、例えば、ネットワークアダプタを通じて接続してもよい。
コンピューティングデバイス700を本図に示すように幾つかの異なる形態で実装してもよい。例えば、それを標準サーバ720として、またはかかるサーバのグループにおいて複数回、実装してもよい。さらに、ラップトップコンピュータ722のようなパーソナルコンピュータで実装してもよい。また、ラックサーバシステム724の一部として実装してもよい。代替的に、コンピューティングデバイス700からのコンポーネントは、モバイルコンピューティングデバイス750のようなモバイルデバイス(図示せず)内の他のコンポーネントと結合されてもよい。かかるデバイスの各々はコンピューティングデバイス700およびモバイルコンピューティングデバイス750の1つまたは複数を含んでもよく、システム全体は互いと通信する複数のコンピューティングデバイスで構成されてもよい。
モバイルコンピューティングデバイス750は、プロセッサ752、メモリ764、他のコンポーネントのうちディスプレイ754、通信インタフェース766、および送受信機768のような入力/出力デバイスを含む。モバイルコンピューティングデバイス750にまた、追加の記憶を提供するための、マイクロドライブまたは他のデバイスのような記憶デバイスが提供されてもよい。プロセッサ752、メモリ764、ディスプレイ754、通信インタフェース766、および送受信機768の各々は様々なバスを用いて相互接続され、当該コンポーネントの幾つかは必要に応じて共通のマザーボード上でまたは他の方式でマウントされてもよい。
プロセッサ752は、メモリ764に格納された命令を含む、モバイルコンピューティングデバイス750内の命令を実行することができる。プロセッサ752を、別々のおよび複数のアナログおよびデジタルプロセッサを含むチップから成るチップ・セットとして実装してもよい。プロセッサ752は、例えば、モバイルコンピューティングデバイス750により実行されるユーザインタフェース、アプリケーション、およびモバイルコンピューティングデバイス750によるワイヤレス通信の制御のような、モバイルコンピューティングデバイス750の他のコンポーネントの協調を提供してもよい。
プロセッサ752は、ディスプレイ754に接続される制御インタフェース758およびディスプレイインタフェース756を通じてユーザと通信してもよい。ディスプレイ754は、例えば、TFT(薄膜トランジスタ液晶ディスプレイ)ディスプレイまたはOLED(有機発光ダイオード)ディスプレイ、または他の適切なディスプレイ技術であってもよい。ディスプレイインタフェース756は、ディスプレイ754を駆動してグラフィカルおよび他の情報をユーザに提供するための適切な回路を備えてもよい。制御インタフェース758は、ユーザからコマンドを受信し、プロセッサ752に送信するために当該コマンドを変換してもよい。さらに、外部インタフェース762は、他のデバイスとのモバイルコンピューティングデバイス750の近領域通信を可能するために、プロセッサ752との通信を提供してもよい。外部インタフェース762は、例えば、幾つかの実装では有線通信を提供し、または他の実装ではワイヤレス通信を提供してもよく、複数のインタフェースをまた使用してもよい。
メモリ764はモバイルコンピューティングデバイス750内に格納する。メモリ764を、コンピュータ可読媒体または媒体、揮発性メモリユニットまたはユニット、または非揮発性メモリユニットまたはユニットの1つまたは複数として実装することができる。拡張メモリ774はまた、拡張インタフェース772を通じてモバイルコンピューティングデバイス750に提供され接続されてもよい。拡張インタフェース772は、例えば、SIMM(Single In Line Memory Module)カードインタフェースを含んでもよい。拡張メモリ774はモバイルコンピューティングデバイス750に対する追加の記憶空間を提供してもよく、または、モバイルコンピューティングデバイス750に対するアプリケーションまたは他の情報を格納してもよい。特に、拡張メモリ774は、上述したプロセスを実行または補完する命令を含んでもよく、セキュア情報を含んでもよい。したがって、例えば、拡張メモリ774を、モバイルコンピューティングデバイス750に対するセキュリティモジュールとして提供してもよく、モバイルコンピューティングデバイス750の安全な使用を許可する命令でプログラムされてもよい。さらに、セキュアアプリケーションを、ハック不能な方式でSIMMカードに識別情報を配置するといった、当該SIMMカードを介して追加の情報とともに提供してもよい。
当該メモリは、以下で説明するように、例えば、フラッシュ・メモリおよび/またはNVRAMメモリ(非揮発性ランダム・アクセスメモリ)を含んでもよい。当該コンピュータプログラム製品は、実行されたとき、上述したもののような1つまたは複数の方法を実施する命令を含む。当該コンピュータプログラム製品は、メモリ764、拡張メモリ774、またはプロセッサ752上のメモリのようなコンピュータまたはマシン可読媒体であることができる。幾つかの実装では、当該コンピュータプログラム製品を、伝播信号で、例えば、送受信機768または外部インタフェース762上で受信することができる。
モバイルコンピューティングデバイス750は通信インタフェース766を通じて無線で通信してもよい。通信インタフェース766は、必要な場合はデジタル信号処理回路を含んでもよい。通信インタフェース766は、とりわけGSM通話(Global System for Mobile communications)、SMS(Short Message Service)、EMS(Enhanced Messaging Service)、またはMMSメッセージング(Multimedia Messaging Service)、CDMA(code division multiple access)、TDMA(time division multiple access)、PDC(Personal Digital Cellular)、WCDMA(Wideband Code Division Multiple Access)(登録商標)、CDMA2000、またはGPRS(General Packet Radio Service)のような、様々なモードまたはプロトコルの下での通信を提供してもよい。かかる通信を、例えば、送受信機768を通じて無線周波数を用いて行ってもよい。さらに、短波通信を、例えばBluetooth(登録商標)、WiFi、または他のかかる送受信機(図示せず)を用いて行ってもよい。さらに、GPS(Global Positioning System)受信器モジュール770は追加のナビゲーション位置関連のワイヤレスデータをモバイルコンピューティングデバイス750に提供してもよい。モバイルコンピューティングデバイス750は、モバイルコンピューティングデバイス750で実行されているアプリケーションにより必要に応じて使用されてもよい。
モバイルコンピューティングデバイス750はまた、オーディオコーデック760を用いて可聴的に通信してもよく、オーディオコーデック760は話された情報をユーザから受信し、それを使用可能なデジタル情報に変換してもよい。オーディオコーデック760は、話者を通じて、例えば、モバイルコンピューティングデバイス750のハンドセットでユーザに対する可聴音を同様に生成してもよい。かかる音は音声通話からの音を含んでもよく、記録された音(例えば、音声メッセージ、音楽ファイル等)を含んでもよく、また、モバイルコンピューティングデバイス750で動作しているアプリケーションにより生成された音を含んでもよい。
モバイルコンピューティングデバイス750を、本図で示すように幾つかの異なる形態で実装してもよい。例えば、セルラスマーフォン780として実装してもよい。また、スマートフォン782、携帯情報端末、または他の同様なモバイルデバイスの一部として実装してもよい。
本明細書で説明したシステムおよび技術の様々な実装を、デジタル電子回路、集積回路、特別に設計されたASIC(特殊用途向け集積回路)、コンピュータハードウェア、ファームウェア、ソフトウェア、および/またはその組合せで実現することができる。これらの様々な実装は、少なくとも1つのプログラム可能プロセッサを含むプログラム可能システムで実行可能および/または解釈可能である1つまたは複数のコンピュータプログラムでの実装を含むことができる。当該少なくとも1つのプログラム可能プロセッサは、特殊目的または一般的な目的であってもよく、記憶システム、少なくとも1つの入力デバイス、および少なくとも1つの出力デバイスとデータおよび命令を送受信するために接続されてもよい。
これらのコンピュータプログラム(プログラム、ソフトウェア、ソフトウェアアプリケーションまたはコードとしても知られる)はプログラム可能プロセッサに対するマシン命令を含み、高レベル手続型および/またはオブジェクト指向プログラミング言語で、および/またはアセンブリ/マシン言語で実装することができる。本明細書で使用する際、当該用語マシン可読媒体およびコンピュータ可読媒体は、マシン命令をマシン可読信号として受信するマシン可読媒体を含む、マシン命令および/またはデータをプログラム可能プロセッサに提供するために使用される、任意のコンピュータプログラム製品、装置および/またはデバイス(例えば、磁気ディスク、光ディスク、メモリ、プログラム可能論理デバイス(PLD))を指す。マシン可読信号という用語は、マシン命令および/またはデータをプログラム可能プロセッサに提供するために使用される任意の信号を指す。
ユーザとの対話を提供するために、本明細書で説明したシステムおよび技術を、ユーザが当該コンピュータへの入力を提供できるユーザおよびキーボードおよびポインティングデバイス(例えば、マウスまたはトラックボール)に情報を表示するための、ディスプレイデバイス(例えば、CRT(カソード・レイ・チューブ)またはLCD(液晶ディスプレイ)モニタ)を有するコンピュータで実装することができる。他の種類のデバイスを、ユーザとの対話を提供するために使用することができる。例えば、ユーザに提供されるフィードバックは任意の形態のセンサフィードバック(例えば、視覚フィードバック、可聴フィードバック、または触覚フィードバック)であることができ、ユーザからの入力を音響、会話、または触覚入力を含む任意の形態で受信することができる。
本明細書で説明したシステムおよび技術を、(例えば、データサーバとして)バックエンドコンポーネントを含む、またはミドルウェアコンポーネント(例えば、アプリケーションサーバ)を含む、またはフロントエンドコンポーネント(例えば、ユーザがそれを通じて本明細書で説明したシステムおよび技術の実装と対話できるグラフィカルユーザインタフェースまたはウェブ・ブラウザを有するクライアントコンピュータ)を含む、またはかかるバックエンド、ミドルウェア、またはフロントエンドコンポーネント任意の組合せを含む、コンピューティングシステムで実装することができる。当該システムの当該コンポーネントは、デジタルデータ通信(例えば、通信ネットワーク)の任意の形態または媒体により相互接続されることができる。通信ネットワークの例はローカル・エリア・ネットワーク(LAN)、広帯域ネットワーク(WAN)、およびインターネットを含む。
当該コンピューティングシステムはクライアントおよびサーバを含むことができる。クライアントおよびサーバは一般に互いから離れており、一般に通信ネットワークを通じて対話する。クライアントおよびサーバの関係は、当該各コンピュータで実行され互いにクライアントサーバ関係を有するコンピュータプログラムにより生ずる。
様々な実装を上で詳細に説明したが、他の修正が可能である。さらに、本図で示した論理フローは、所望の結果を実現するために、示した特定の順序、または逐次的な順序を必要としない。さらに、他のステップを提供してもよく、またはステップを当該説明したフローから削除してもよく、他のコンポーネントを当該説明したシステムに追加し、または、そこから削除してもよい。したがって、他の実装は添付の特許請求の範囲内にある。
121 発声プール
122 トレーニング・サンプル
122a シミュレートされた検証発声
122b シミュレートされた加入発声
130 ネットワーク
140 トレーニングされたニューラル・ネットワーク
141a マッチングする話者
141b マッチングしない話者
144 話者検証モデル
152 加入発声(複数可)
154 検証発声
156 検証結果

Claims (21)

  1. コンピューティングデバイスで、前記コンピューティングデバイスのユーザの発声を特徴付けるデータを受信するステップと、
    前記コンピューティングデバイスで、前記コンピューティングデバイス上のニューラルネットワークを用いて前記発声に対する話者表現を生成するステップであって、前記ニューラルネットワークが、それぞれ、
    (i)第1の発声を特徴付けるデータおよび1つまたは複数の第2の発声を特徴付けるデータを含み、
    (ii)前記第1の発声の話者が前記1つまたは複数の第2の発声の話者と同一であるかどうかに従って、マッチングサンプルまたは非マッチングサンプルとしてラベル付けされる、
    複数のトレーニング・サンプルに基づいてトレーニングされている、ステップと、
    前記コンピューティングデバイスで、前記コンピューティングデバイスの認証されたユーザに対する話者モデルにアクセスするステップと、
    前記コンピューティングデバイスで、前記話者モデルに関する前記発声に対する前記話者表現を評価して、前記発声が前記コンピューティングデバイスの前記認証されたユーザにより話された可能性があったかどうかを判定するステップと、
    を含む、コンピュータ実行型の方法。
  2. 前記複数のトレーニング・サンプルの各々は、各発声グループが前記各発声グループに対する前記対応する話者の発声のみから構成されるように、前記第1の発声および前記1つまたは複数の第2の発声を異なる話者に対応する発声グループから選択することにより生成された、請求項1に記載のコンピュータ実行型の方法。
  3. 前記コンピューティングデバイスの前記認証されたユーザの1組の発声を取得するステップと、
    前記発声に対する各話者表現を生成するために、各発声を前記1組の発声から前記ニューラルネットワークに入力するステップと、
    前記認証されたユーザの前記1組の発声における前記発声に対する前記各話者表現の平均に基づいて前記コンピューティングデバイスの前記認証されたユーザに対する前記話者モデルを生成するステップと、
    をさらに含む、請求項1または2に記載のコンピュータ実行型の方法。
  4. 前記ニューラルネットワークがトレーニングされている前記複数のトレーニング・サンプルの何れも、前記コンピューティングデバイスの前記ユーザの前記発声を特徴付けるデータを含まない、請求項1乃至3の何れか1項に記載のコンピュータ実行型の方法。
  5. 前記コンピューティングデバイスで、前記発声に対する前記話者表現を生成するステップは、前記発声の全体を特徴付けるデータを前記ニューラルネットワークで単一のパスで前記ニューラルネットワークを通じて処理するステップを含む、請求項1乃至4の何れか1項に記載のコンピュータ実行型の方法。
  6. 前記ユーザの前記発声が前記コンピューティングデバイスの前記認証されたユーザにより話された可能性があったと判定したことに応答して、機能を前記コンピューティングデバイス上で実施するステップをさらに含む、請求項1乃至5の何れか1項に記載のコンピュータ実行型の方法。
  7. 第1の1組の発声に対するニューラルネットワークの出力に基づいて特定の話者に対する話者モデルを決定するステップであって、前記第1の1組の発声は前記特定の話者の複数の異なる発声を含む、ステップと、
    前記第1の1組の発声内にない特定の発声に対する前記ニューラルネットワークの出力に基づいて話者表現を決定するステップと、
    前記話者表現を前記特定の話者に対する前記話者モデルと比較して、前記特定の発声を前記特定の話者の発声としてまたは前記特定の話者と異なる話者の発声として分類するステップと、
    前記発声の前記特定の話者の発声としてまたは前記特定の話者と異なる話者の発声としての前記分類が正しかったかどうかに基づいて前記ニューラルネットワークを調節するステップと、
    を含む、コンピュータ実行型の方法。
  8. コンピューティングシステムで、複数の異なる発声のセットを、前記ニューラルネットワークをトレーニングするためのトレーニングデータとして選択するステップであって、各1組の発声は、
    (i)前記各1組の発声に対する第1の第1の話者の複数の異なる発声と、
    (ii)前記各1組の発声に対する前記第1の話者または前記第1の話者と異なる前記各1組の発声に対する第2の話者の何れかの第2の発声と、
    を含む、ステップと、
    前記複数の異なる発声のセットを用いて、前記ニューラルネットワークのトレーニングを反復するステップであって、前記複数の異なる発声のセットからの各1組の発声は前記ニューラルネットワークをトレーニングするために異なるトレーニングの反復で使用される、ステップと、
    を含み、
    前記第1の1組の発声は前記複数の異なる発声のセットから選択され、前記特定の話者は前記第1の1組の発声に対する前記第1の話者である、
    請求項7に記載のコンピュータ実行型の方法。
  9. コンピューティングシステムで、ニューラルネットワークをトレーニングするためのトレーニングデータの複数の異なるサブセットを選択するステップであって、トレーニングデータの各サブセットは、第1の話者の各発声を分類する複数の第1のコンポーネントおよび前記第1の話者または第2の話者の発声を特徴付ける第2のコンポーネントを含む、ステップと、
    トレーニングデータの前記選択されたサブセットの各々に対して、
    前記第1のコンポーネントの各々に対応する各第1の話者表現を生成するために、前記第1のコンポーネントの各々を前記ニューラルネットワークに入力するステップと、
    前記第2のコンポーネントに対応する第2の話者表現を生成するために、前記第2のコンポーネントを前記ニューラルネットワークに入力するステップと、
    前記複数の第1のコンポーネントに対する前記各第1の話者表現の平均に基づいて前記第1の話者に対するシミュレートされた話者モデルを決定するステップと、
    前記第2の話者表現を前記シミュレートされた話者モデルと比較して、前記第2のコンポーネントにより特徴付けられた前記発声を前記第1の話者の発声としてまたは前記第1の話者と異なる話者の発声として分類するステップと、
    前記第2のコンポーネントにより特徴付けられた前記発声が前記第1の話者の発声としてまたは前記第1の話者と異なる話者の発声として正しく分類されたかどうかに基づいて、前記ニューラルネットワークを調節するステップと、
    を含む、コンピュータ実行型の方法。
  10. 前記第2のコンポーネントを前記ニューラルネットワークに入力するステップに応答して、単一のパスで前記ニューラルネットワークを通じて、前記第2のコンポーネントにより特徴付けられた前記発声の全体に対するデータを処理することで、前記第2の話者表現を前記ニューラルネットワークで生成するステップをさらに含む、請求項9に記載のコンピュータ実行型の方法。
  11. トレーニングデータの前記複数の異なるサブセットからトレーニングデータの第1のサブセットを選択するステップは、
    各発声グループが前記各発声グループに対する前記対応する話者の発声のみを特徴づけるデータから構成されるように、それぞれ異なる話者に対応する複数の発声グループからの前記第1の話者に対応する第1の発声グループを選択するステップと、
    前記第1の話者または前記第2の話者に対応する第2の発声グループを前記複数の発声グループから選択するステップと、
    前記複数の第1のコンポーネントを前記第1の発声グループ内の発声を特徴付ける前記データから決定するステップと、
    前記第2のコンポーネントを前記第2の発声グループ内の発声を特徴付ける前記データから決定するステップと、
    を含む、請求項9または10に記載のコンピュータ実行型の方法。
  12. 前記第1の発声グループおよび前記第2の発声グループの少なくとも1つは前記複数の発声グループからランダムに選択される、請求項11に記載のコンピュータ実行型の方法。
  13. 前記第1の話者はトレーニングデータの前記複数の異なるサブセットの少なくとも幾つかの間で互いに異なり、
    前記第2の話者はトレーニングデータの前記複数の異なるサブセットの少なくとも幾つかの間で互いに異なる、
    請求項9乃至12の何れか1項に記載のコンピュータ実行型の方法。
  14. トレーニングデータの前記複数の異なるサブセットのうちトレーニングデータの第1のサブセット内の第1のコンポーネントの総数は、トレーニングデータの前記複数の異なるサブセットのうちトレーニングデータの第2のサブセット内の第1のコンポーネントの総数と異なる、請求項9乃至13の何れか1項に記載のコンピュータ実行型の方法。
  15. 記第2の話者表現を前記シミュレートされた話者モデルと比較して、前記第2のコンポーネントにより特徴付けられた前記発声を前記第1の話者の発声としてまたは前記第1の話者と異なる話者の発声として分類するステップは、前記第2の話者表現からの値および前記シミュレートされた話者モデルからの値の間の距離を決定するステップと、ロジスティック回帰機能を前記距離に適用するステップとを含む、請求項9乃至14の何れか1項に記載のコンピュータ実行型の方法。
  16. 前記ニューラルネットワークは複数の隠蔽されたレイヤを含み、前記ニューラルネットワークはソフトマックス出力レイヤを有さない、請求項9乃至15の何れか1項に記載のコンピュータ実行型の方法。
  17. 前記ニューラルネットワークは、ローカルに接続された隠蔽されたレイヤと、前記レイヤに続く複数の完全に接続された隠蔽されたレイヤを有するディープ・ニューラルネットワークを含む、請求項9乃至16の何れか1項に記載のコンピュータ実行型の方法。
  18. 前記複数の第1のコンポーネントにより特徴付けられた前記発声と前記第2のコンポーネントにより特徴付けられた前記発声とは全て固定長を有する、請求項17に記載のコンピュータ実行型の方法。
  19. 前記ニューラルネットワークは、可変長を有する発声を特徴付けるデータでトレーニングされるように構成された長短期メモリ再帰型ニューラルネットワークを含む、請求項9乃至18の何れか1項に記載のコンピュータ実行型の方法。
  20. トレーニングデータの前記複数の異なるサブセットにわたって前記各複数の第1のコンポーネントにより特徴付けられた前記発声と、トレーニングデータの前記複数の異なるサブセットにわたって前記各第2のコンポーネントにより特徴付けられた前記発声とは全て、同一の単語またはフレーズの発声である、請求項9乃至19の何れか1項に記載のコンピュータ実行型の方法。
  21. トレーニングデータの前記複数の異なるサブセットにわたって前記各複数の第1のコンポーネントにより特徴付けられた前記発声の少なくとも幾つかと、トレーニングデータの前記複数の異なるサブセットにわたって前記各第2のコンポーネントにより特徴付けられた前記発声の少なくとも幾つかとは、異なる単語または異なるフレーズの発声である、請求項9乃至19の何れか1項に記載のコンピュータ実行型の方法。
JP2019108765A 2015-09-04 2019-06-11 話者検証のためのニューラルネットワーク Active JP6766221B2 (ja)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US14/846,187 US9978374B2 (en) 2015-09-04 2015-09-04 Neural networks for speaker verification
US14/846,187 2015-09-04

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
JP2017556908A Division JP6542386B2 (ja) 2015-09-04 2016-07-27 話者検証のためのニューラルネットワーク

Related Child Applications (1)

Application Number Title Priority Date Filing Date
JP2020154566A Division JP7110292B2 (ja) 2015-09-04 2020-09-15 話者検証のためのニューラルネットワーク

Publications (2)

Publication Number Publication Date
JP2019194713A true JP2019194713A (ja) 2019-11-07
JP6766221B2 JP6766221B2 (ja) 2020-10-07

Family

ID=56853791

Family Applications (5)

Application Number Title Priority Date Filing Date
JP2017556908A Active JP6542386B2 (ja) 2015-09-04 2016-07-27 話者検証のためのニューラルネットワーク
JP2019108765A Active JP6766221B2 (ja) 2015-09-04 2019-06-11 話者検証のためのニューラルネットワーク
JP2020154566A Active JP7110292B2 (ja) 2015-09-04 2020-09-15 話者検証のためのニューラルネットワーク
JP2022115625A Active JP7362851B2 (ja) 2015-09-04 2022-07-20 話者検証のためのニューラルネットワーク
JP2023171420A Pending JP2024001111A (ja) 2015-09-04 2023-10-02 話者検証のためのニューラルネットワーク

Family Applications Before (1)

Application Number Title Priority Date Filing Date
JP2017556908A Active JP6542386B2 (ja) 2015-09-04 2016-07-27 話者検証のためのニューラルネットワーク

Family Applications After (3)

Application Number Title Priority Date Filing Date
JP2020154566A Active JP7110292B2 (ja) 2015-09-04 2020-09-15 話者検証のためのニューラルネットワーク
JP2022115625A Active JP7362851B2 (ja) 2015-09-04 2022-07-20 話者検証のためのニューラルネットワーク
JP2023171420A Pending JP2024001111A (ja) 2015-09-04 2023-10-02 話者検証のためのニューラルネットワーク

Country Status (8)

Country Link
US (5) US9978374B2 (ja)
EP (3) EP3621070B1 (ja)
JP (5) JP6542386B2 (ja)
KR (2) KR101995547B1 (ja)
CN (1) CN107924682A (ja)
DE (1) DE112016004008T5 (ja)
GB (1) GB2556459B (ja)
WO (1) WO2017039884A1 (ja)

Families Citing this family (74)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8977255B2 (en) 2007-04-03 2015-03-10 Apple Inc. Method and system for operating a multi-function portable electronic device using voice-activation
BR112015018905B1 (pt) 2013-02-07 2022-02-22 Apple Inc Método de operação de recurso de ativação por voz, mídia de armazenamento legível por computador e dispositivo eletrônico
US9338493B2 (en) 2014-06-30 2016-05-10 Apple Inc. Intelligent automated assistant for TV user interactions
US10747498B2 (en) 2015-09-08 2020-08-18 Apple Inc. Zero latency digital assistant
US10691473B2 (en) 2015-11-06 2020-06-23 Apple Inc. Intelligent automated assistant in a messaging environment
CA2954839A1 (en) * 2016-01-22 2017-07-22 Wal-Mart Stores, Inc. Systems and methods of enabling forecasting
US9978367B2 (en) * 2016-03-16 2018-05-22 Google Llc Determining dialog states for language models
US10373612B2 (en) * 2016-03-21 2019-08-06 Amazon Technologies, Inc. Anchored speech detection and speech recognition
CN105933323B (zh) * 2016-06-01 2019-05-31 百度在线网络技术(北京)有限公司 声纹注册、认证方法及装置
US10311219B2 (en) * 2016-06-07 2019-06-04 Vocalzoom Systems Ltd. Device, system, and method of user authentication utilizing an optical microphone
US20180018973A1 (en) * 2016-07-15 2018-01-18 Google Inc. Speaker verification
KR102596430B1 (ko) * 2016-08-31 2023-10-31 삼성전자주식회사 화자 인식에 기초한 음성 인식 방법 및 장치
US9824692B1 (en) 2016-09-12 2017-11-21 Pindrop Security, Inc. End-to-end speaker recognition using deep neural network
WO2018053537A1 (en) 2016-09-19 2018-03-22 Pindrop Security, Inc. Improvements of speaker recognition in the call center
CA3036561C (en) 2016-09-19 2021-06-29 Pindrop Security, Inc. Channel-compensated low-level features for speaker recognition
KR20180082033A (ko) * 2017-01-09 2018-07-18 삼성전자주식회사 음성을 인식하는 전자 장치
CN110603584A (zh) * 2017-04-20 2019-12-20 谷歌有限责任公司 设备上的多用户认证
KR102125549B1 (ko) * 2017-04-20 2020-06-22 한국전자통신연구원 심층신경망 기반 음성 인식 시스템을 위한 발화 검증 방법
US10592725B2 (en) * 2017-04-21 2020-03-17 General Electric Company Neural network systems
DK179496B1 (en) 2017-05-12 2019-01-15 Apple Inc. USER-SPECIFIC Acoustic Models
DK201770427A1 (en) 2017-05-12 2018-12-20 Apple Inc. LOW-LATENCY INTELLIGENT AUTOMATED ASSISTANT
US10325602B2 (en) * 2017-08-02 2019-06-18 Google Llc Neural networks for speaker verification
CN107301864B (zh) * 2017-08-16 2020-12-22 重庆邮电大学 一种基于Maxout神经元的深度双向LSTM声学模型
CN111630934B (zh) * 2018-01-22 2023-10-13 诺基亚技术有限公司 隐私保护的声纹认证装置和方法
CN108597523B (zh) * 2018-03-23 2019-05-17 平安科技(深圳)有限公司 说话人认证方法、服务器及计算机可读存储介质
US10937438B2 (en) 2018-03-29 2021-03-02 Ford Global Technologies, Llc Neural network generative modeling to transform speech utterances and augment training data
CN108495143A (zh) * 2018-03-30 2018-09-04 百度在线网络技术(北京)有限公司 视频推荐的方法和装置
US10853911B2 (en) * 2018-04-17 2020-12-01 Google Llc Dynamic adaptation of images for projection, and/or of projection parameters, based on user(s) in environment
US10928918B2 (en) 2018-05-07 2021-02-23 Apple Inc. Raise to speak
GB2573809B (en) * 2018-05-18 2020-11-04 Emotech Ltd Speaker Recognition
JP6980603B2 (ja) * 2018-06-21 2021-12-15 株式会社東芝 話者モデル作成システム、認識システム、プログラムおよび制御装置
KR102655791B1 (ko) 2018-08-27 2024-04-09 삼성전자주식회사 화자 인증 방법, 화자 인증을 위한 학습 방법 및 그 장치들
CN109344713B (zh) * 2018-08-31 2021-11-02 电子科技大学 一种姿态鲁棒的人脸识别方法
CN109284406B (zh) * 2018-09-03 2021-12-03 四川长虹电器股份有限公司 基于差异循环神经网络的意图识别方法
KR20200027331A (ko) * 2018-09-04 2020-03-12 엘지전자 주식회사 음성 합성 장치
US10978059B2 (en) * 2018-09-25 2021-04-13 Google Llc Speaker diarization using speaker embedding(s) and trained generative model
US11462215B2 (en) 2018-09-28 2022-10-04 Apple Inc. Multi-modal inputs for voice commands
CN110289003B (zh) * 2018-10-10 2021-10-29 腾讯科技(深圳)有限公司 一种声纹识别的方法、模型训练的方法以及服务器
KR102608470B1 (ko) 2018-10-23 2023-12-01 삼성전자주식회사 데이터 인식 장치 및 방법과 트레이닝 장치 및 방법
KR102172925B1 (ko) * 2018-10-25 2020-11-02 광주과학기술원 딥러닝 기반 기후 변화 예측 시스템의 동작 방법
US10810993B2 (en) * 2018-10-26 2020-10-20 Deepmind Technologies Limited Sample-efficient adaptive text-to-speech
CN111902865A (zh) * 2018-12-03 2020-11-06 谷歌有限责任公司 文本无关的说话者识别
KR102570070B1 (ko) 2018-12-27 2023-08-23 삼성전자주식회사 일반화된 사용자 모델을 이용한 사용자 인증 방법 및 장치
US11031017B2 (en) * 2019-01-08 2021-06-08 Google Llc Fully supervised speaker diarization
DE102019201456B3 (de) * 2019-02-05 2020-07-23 Sivantos Pte. Ltd. Verfahren für eine individualisierte Signalverarbeitung eines Audiosignals eines Hörgerätes
US11019201B2 (en) 2019-02-06 2021-05-25 Pindrop Security, Inc. Systems and methods of gateway detection in a telephone network
US11468886B2 (en) 2019-03-12 2022-10-11 Lg Electronics Inc. Artificial intelligence apparatus for performing voice control using voice extraction filter and method for the same
US10923111B1 (en) 2019-03-28 2021-02-16 Amazon Technologies, Inc. Speech detection and speech recognition
US20200322377A1 (en) * 2019-04-08 2020-10-08 Pindrop Security, Inc. Systems and methods for end-to-end architectures for voice spoofing detection
US11960843B2 (en) * 2019-05-02 2024-04-16 Adobe Inc. Multi-module and multi-task machine learning system based on an ensemble of datasets
US11468890B2 (en) 2019-06-01 2022-10-11 Apple Inc. Methods and user interfaces for voice-based control of electronic devices
US11848023B2 (en) * 2019-06-10 2023-12-19 Google Llc Audio noise reduction
KR102316537B1 (ko) 2019-06-21 2021-10-22 한양대학교 산학협력단 잡음 환경에 강인한 화자 인식을 위한 심화신경망 기반의 특징 강화 및 변형된 손실 함수를 이용한 결합 학습 방법 및 장치
CN110610708B (zh) * 2019-08-31 2021-10-15 浙江工业大学 一种基于布谷鸟搜索算法的声纹识别攻击防御方法
US11900246B2 (en) 2019-09-02 2024-02-13 Samsung Electronics Co., Ltd. Method and apparatus for recognizing user based on on-device training
US11341988B1 (en) * 2019-09-23 2022-05-24 Apple Inc. Hybrid learning-based and statistical processing techniques for voice activity detection
US11361761B2 (en) * 2019-10-16 2022-06-14 International Business Machines Corporation Pattern-based statement attribution
WO2020035085A2 (en) * 2019-10-31 2020-02-20 Alipay (Hangzhou) Information Technology Co., Ltd. System and method for determining voice characteristics
CN110782901B (zh) * 2019-11-05 2021-12-24 深圳大学 一种识别网络电话语音的方法、存储介质及装置
US11741986B2 (en) 2019-11-05 2023-08-29 Samsung Electronics Co., Ltd. System and method for passive subject specific monitoring
US11238847B2 (en) * 2019-12-04 2022-02-01 Google Llc Speaker awareness using speaker dependent speech model(s)
CA3166263A1 (en) * 2020-02-03 2021-08-12 Pindrop Security, Inc. Cross-channel enrollment and authentication of voice biometrics
US11061543B1 (en) 2020-05-11 2021-07-13 Apple Inc. Providing relevant data items based on context
US11508380B2 (en) * 2020-05-26 2022-11-22 Apple Inc. Personalized voices for text messaging
US11688412B2 (en) * 2020-06-15 2023-06-27 Tencent America LLC Multi-modal framework for multi-channel target speech separation
CN111739521B (zh) * 2020-06-19 2021-06-22 腾讯科技(深圳)有限公司 电子设备唤醒方法、装置、电子设备及存储介质
US11490204B2 (en) 2020-07-20 2022-11-01 Apple Inc. Multi-device audio adjustment coordination
US11438683B2 (en) 2020-07-21 2022-09-06 Apple Inc. User identification using headphones
KR20220040875A (ko) * 2020-09-24 2022-03-31 삼성전자주식회사 음성 인식 서비스를 위한 등록 사용자에 대한 화자 인증 학습 장치 및 그 동작 방법
CN111933152B (zh) * 2020-10-12 2021-01-08 北京捷通华声科技股份有限公司 注册音频的有效性的检测方法、检测装置和电子设备
US11315575B1 (en) * 2020-10-13 2022-04-26 Google Llc Automatic generation and/or use of text-dependent speaker verification features
WO2022086045A1 (ko) * 2020-10-22 2022-04-28 삼성전자주식회사 전자 장치 및 이의 제어 방법
KR102590540B1 (ko) * 2020-11-30 2023-10-18 주식회사 마음에이아이 인공 신경망 학습 방법과 이를 이용한 발음 평가 방법
US20220254331A1 (en) * 2021-02-05 2022-08-11 Cambium Assessment, Inc. Neural network and method for machine learning assisted speech recognition

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH064097A (ja) * 1992-06-18 1994-01-14 Seiko Epson Corp 話者認識方法
JPH1173196A (ja) * 1997-07-18 1999-03-16 Lucent Technol Inc 話者の申し出識別を認証する方法
JPH1173195A (ja) * 1997-07-18 1999-03-16 Lucent Technol Inc 話者の申し出識別を認証する方法
US20150127336A1 (en) * 2013-11-04 2015-05-07 Google Inc. Speaker verification using neural networks

Family Cites Families (27)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5167004A (en) * 1991-02-28 1992-11-24 Texas Instruments Incorporated Temporal decorrelation method for robust speaker verification
JPH07210197A (ja) * 1994-01-14 1995-08-11 Nippondenso Co Ltd 話者識別方法
JPH08171398A (ja) * 1994-12-16 1996-07-02 Matsushita Electric Ind Co Ltd データ認識装置、辞書作成装置及び学習装置
JPH08227408A (ja) * 1995-02-22 1996-09-03 Meidensha Corp ニューラルネットワーク
FR2795848B1 (fr) * 1999-07-01 2001-08-17 Commissariat Energie Atomique Systeme d'intelligence artificielle pour la classification d'evenements, d'objets ou de situations a partir de signaux et de parametres discriminants issus de modeles
FR2842643B1 (fr) * 2002-07-22 2004-09-03 France Telecom Normalisation de score de verification dans un dispositif de reconnaissance vocale de locuteur
US7509257B2 (en) * 2002-12-24 2009-03-24 Marvell International Ltd. Method and apparatus for adapting reference templates
WO2006033044A2 (en) * 2004-09-23 2006-03-30 Koninklijke Philips Electronics N.V. Method of training a robust speaker-dependent speech recognition system with speaker-dependent expressions and robust speaker-dependent speech recognition system
JP2009510509A (ja) * 2005-09-29 2009-03-12 コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ セグメント別特徴比較によりプレイリストを自動生成する方法及び装置
EP2182512A1 (en) * 2008-10-29 2010-05-05 BRITISH TELECOMMUNICATIONS public limited company Speaker verification
CN102810311B (zh) * 2011-06-01 2014-12-03 株式会社理光 说话人估计方法和说话人估计设备
GB2493956A (en) * 2011-08-24 2013-02-27 Inview Technology Ltd Recommending audio-visual content based on user's personal preerences and the profiles of others
US8498864B1 (en) * 2012-09-27 2013-07-30 Google Inc. Methods and systems for predicting a text
US9230550B2 (en) * 2013-01-10 2016-01-05 Sensory, Incorporated Speaker verification and identification using artificial neural network-based sub-phonetic unit discrimination
CN103971690A (zh) * 2013-01-28 2014-08-06 腾讯科技(深圳)有限公司 一种声纹识别方法和装置
US9502038B2 (en) * 2013-01-28 2016-11-22 Tencent Technology (Shenzhen) Company Limited Method and device for voiceprint recognition
US9343068B2 (en) * 2013-09-16 2016-05-17 Qualcomm Incorporated Method and apparatus for controlling access to applications having different security levels
US20150095017A1 (en) * 2013-09-27 2015-04-02 Google Inc. System and method for learning word embeddings using neural language models
WO2015060867A1 (en) * 2013-10-25 2015-04-30 Intel Corporation Techniques for preventing voice replay attacks
CN104751842B (zh) * 2013-12-31 2019-11-15 科大讯飞股份有限公司 深度神经网络的优化方法及系统
US8812320B1 (en) * 2014-04-01 2014-08-19 Google Inc. Segment-based speaker verification using dynamically generated phrases
US10540979B2 (en) * 2014-04-17 2020-01-21 Qualcomm Incorporated User interface for secure access to a device using speaker verification
CN104167208B (zh) * 2014-08-08 2017-09-15 中国科学院深圳先进技术研究院 一种说话人识别方法和装置
CN104732977B (zh) * 2015-03-09 2018-05-11 广东外语外贸大学 一种在线口语发音质量评价方法和系统
CN105518708B (zh) * 2015-04-29 2018-06-12 北京旷视科技有限公司 用于验证活体人脸的方法、设备和计算机程序产品
US10115055B2 (en) * 2015-05-26 2018-10-30 Booking.Com B.V. Systems methods circuits and associated computer executable code for deep learning based natural language understanding
JP6671020B2 (ja) * 2016-06-23 2020-03-25 パナソニックIpマネジメント株式会社 対話行為推定方法、対話行為推定装置及びプログラム

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH064097A (ja) * 1992-06-18 1994-01-14 Seiko Epson Corp 話者認識方法
JPH1173196A (ja) * 1997-07-18 1999-03-16 Lucent Technol Inc 話者の申し出識別を認証する方法
JPH1173195A (ja) * 1997-07-18 1999-03-16 Lucent Technol Inc 話者の申し出識別を認証する方法
US20150127336A1 (en) * 2013-11-04 2015-05-07 Google Inc. Speaker verification using neural networks

Also Published As

Publication number Publication date
JP7362851B2 (ja) 2023-10-17
GB201717774D0 (en) 2017-12-13
DE112016004008T5 (de) 2018-05-17
US9978374B2 (en) 2018-05-22
EP3278331B1 (en) 2019-12-25
US20170069327A1 (en) 2017-03-09
JP2018517927A (ja) 2018-07-05
JP2021006913A (ja) 2021-01-21
US11107478B2 (en) 2021-08-31
EP4084000A3 (en) 2022-11-09
US20240038245A1 (en) 2024-02-01
CN107924682A (zh) 2018-04-17
JP2022163057A (ja) 2022-10-25
JP7110292B2 (ja) 2022-08-01
JP6542386B2 (ja) 2019-07-10
EP3621070A1 (en) 2020-03-11
JP6766221B2 (ja) 2020-10-07
GB2556459B (en) 2021-09-15
GB2556459A (en) 2018-05-30
US20180315430A1 (en) 2018-11-01
KR102026396B1 (ko) 2019-09-27
US20200160869A1 (en) 2020-05-21
JP2024001111A (ja) 2024-01-09
EP3621070B1 (en) 2022-09-07
US10586542B2 (en) 2020-03-10
US11961525B2 (en) 2024-04-16
KR101995547B1 (ko) 2019-07-02
KR20170131585A (ko) 2017-11-29
EP3278331A1 (en) 2018-02-07
US20210366491A1 (en) 2021-11-25
EP4084000A2 (en) 2022-11-02
WO2017039884A1 (en) 2017-03-09
KR20190079692A (ko) 2019-07-05

Similar Documents

Publication Publication Date Title
JP7362851B2 (ja) 話者検証のためのニューラルネットワーク
US10325602B2 (en) Neural networks for speaker verification
JP7384877B2 (ja) コロケーション情報を使用した話者照合
US11545155B2 (en) System and method for speaker recognition on mobile devices
KR101824157B1 (ko) 화자 검증을 위한 동적 임계치
US20160293167A1 (en) Speaker recognition using neural networks
US20170236520A1 (en) Generating Models for Text-Dependent Speaker Verification
WO2017162053A1 (zh) 一种身份认证的方法和装置
US20230015169A1 (en) Speaker Identification Accuracy
CN111344783A (zh) 说话人识别系统中的注册
Duraibi et al. Suitability of Voice Recognition Within the IoT Environment
Khemiri et al. Automatic speaker verification using nearest neighbor normalization (3N) on an iPad tablet

Legal Events

Date Code Title Description
A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20190613

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20190613

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20200817

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20200916

R150 Certificate of patent or registration of utility model

Ref document number: 6766221

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250