(19)【発行国】日本国特許庁(JP)
(12)【公報種別】公表特許公報(A)
(11)【公表番号】
(43)【公表日】2024-02-08
(54)【発明の名称】別個のアプリケーションにおいて検索フィルタパラメータを導入または制御するための自動アシスタント
(51)【国際特許分類】
G06F 16/9032 20190101AFI20240201BHJP
【FI】
G06F16/9032
【審査請求】有
【予備審査請求】未請求
(21)【出願番号】P 2023537160
(86)(22)【出願日】2021-12-15
(85)【翻訳文提出日】2023-08-10
(86)【国際出願番号】 US2021063635
(87)【国際公開番号】W WO2022225568
(87)【国際公開日】2022-10-27
(32)【優先日】2021-04-20
(33)【優先権主張国・地域又は機関】US
(81)【指定国・地域】
(71)【出願人】
【識別番号】502208397
【氏名又は名称】グーグル エルエルシー
【氏名又は名称原語表記】Google LLC
【住所又は居所原語表記】1600 Amphitheatre Parkway 94043 Mountain View, CA U.S.A.
(74)【代理人】
【識別番号】100108453
【氏名又は名称】村山 靖彦
(74)【代理人】
【識別番号】100110364
【氏名又は名称】実広 信哉
(74)【代理人】
【識別番号】100133400
【氏名又は名称】阿部 達彦
(72)【発明者】
【氏名】ジョセフ・ラング
(72)【発明者】
【氏名】マーシン・ノヴァク-プシゴツキ
【テーマコード(参考)】
5B175
【Fターム(参考)】
5B175GA04
5B175GC03
5B175HA05
(57)【要約】
本明細書において記載される実装形態は、ユーザと別個のアプリケーションとの間のインターフェースとして別個のアプリケーションのアプリケーションコンテンツを検索するように動作することのできる自動アシスタントに関する。自動アシスタントは、別個のアプリケーションの既存の検索フィルタ特徴とインタラクションすることができ、特定のフィルタパラメータがアプリケーションの検索インターフェースにおいて直接的に制御可能ではない状況に適応することもできる。例として、検索動作が特定の語を使用して実施されるようにユーザが要求するとき、それらの語が、アプリケーションの検索インターフェースにおいて利用可能でないことのあるコンテンツフィルタを指すことがある。しかし、自動アシスタントは、確実に、結果として得られるどんな検索結果も適宜フィルタリングされるようにするために、それらのコンテンツフィルタに基づいてアシスタント入力を生成することができる。次いで、このアシスタント入力が、アプリケーションの検索フィールドにサブミットされることが可能であり、検索動作が実行されることが可能である。
【特許請求の範囲】
【請求項1】
1つまたは複数のプロセッサによって実装される方法であって、
コンピューティングデバイスにおいて、ユーザから、前記コンピューティングデバイスを介してアクセス可能な自動アシスタントに向けられた口頭発話を受け取るステップであって、
前記コンピューティングデバイスが、前記口頭発話が受け取られたときにアプリケーションの検索結果インターフェースをレンダリングしているディスプレイインターフェースを含む、ステップと、
前記口頭発話に基づいて、前記検索結果インターフェースの1つまたは複数のフィルタ設定のうちに含まれない特定のフィルタ設定を前記ユーザが特定したかどうかを判定するステップと、
前記1つまたは複数のフィルタ設定のうちに含まれない前記特定のフィルタ設定を前記ユーザが特定したと前記自動アシスタントが判定したとき、
前記検索結果インターフェースのアプリケーションコンテンツおよび前記口頭発話に基づくアプリケーション入力を生成するステップと、
前記アプリケーションに前記アプリケーション入力に基づいて検索動作の実施を初期化させるステップと
を含む、方法。
【請求項2】
前記アプリケーション入力が、前記特定のフィルタ設定、および前記検索結果インターフェースにおいてレンダリングされている前記アプリケーションコンテンツに対応する1つまたは複数の検索語を特定する、請求項1に記載の方法。
【請求項3】
前記アプリケーション入力が、前記口頭発話内に含まれる1つまたは複数の語、および前記アプリケーションコンテンツを前記検索結果インターフェースにおいてレンダリングさせるために前記アプリケーションに以前にサブミットされた1つまたは複数の検索語を含む、請求項1または請求項2に記載の方法。
【請求項4】
前記1つまたは複数のフィルタ設定のうちに含まれる前記特定のフィルタ設定を前記ユーザが特定したと前記自動アシスタントが判定したとき、
前記ユーザからの前記口頭発話に従って、前記アプリケーションの前記特定のフィルタ設定を変更させるステップであって、
前記特定のフィルタ設定を変更させることにより、別のアプリケーションコンテンツを前記検索結果インターフェースにおいてレンダリングさせる、ステップをさらに含む、請求項1から3のいずれか一項に記載の方法。
【請求項5】
前記アプリケーションに前記アプリケーション入力に基づいて前記検索動作の実施を初期化させるステップが、
前記アプリケーション入力を前記検索結果インターフェースの検索フィールドに組み込むステップを含む、請求項1から4のいずれか一項に記載の方法。
【請求項6】
前記検索結果インターフェースの前記1つまたは複数のフィルタ設定のうちに含まれない前記特定のフィルタ設定を前記ユーザが特定したかどうかを判定するステップが、
前記アプリケーションまたは別のアプリケーションによって以前にレンダリングされた1つまたは複数の検索インターフェースに基づくアシスタントデータを処理するステップを含む、請求項1から5のいずれか一項に記載の方法。
【請求項7】
前記1つまたは複数のフィルタ設定のうちに含まれない前記特定のフィルタ設定を前記ユーザが特定したと前記自動アシスタントが判定したとき、
前記検索結果インターフェースの前記1つまたは複数のフィルタ設定の各フィルタ設定のそれぞれの状態を決定するステップであって、
前記アプリケーション入力が、前記検索結果インターフェースの前記1つまたは複数のフィルタ設定の各フィルタ設定のそれぞれの状態にさらに基づく、ステップをさらに含む、請求項1から6のいずれか一項に記載の方法。
【請求項8】
前記アプリケーションに前記アプリケーション入力に基づいて前記検索動作の実施を初期化させるステップが、
前記アプリケーションに、アプリケーションコンテンツの、前記1つまたは複数のフィルタ設定の各フィルタ設定のそれぞれの状態に従ってフィルタリングされたサブセットを、レンダリングさせるステップを含む、請求項7に記載の方法。
【請求項9】
1つまたは複数のプロセッサによって実装される方法であって、
コンピューティングデバイスにおいて、ユーザから、自動アシスタントに前記自動アシスタントとは別個のものであるアプリケーションを使用した検索動作を初期化させることを促進するための口頭発話を受け取るステップであって、
前記口頭発話が1つまたは複数の語を特定する、ステップと、
前記口頭発話に基づいて、前記口頭発話の前記1つまたは複数の語が、前記アプリケーションのインターフェースにおいてレンダリングされた1つまたは複数の選択可能なグラフィカルユーザインターフェース(GUI)要素に関連するかどうかを判定するステップであって、
前記1つまたは複数の選択可能なGUI要素が、前記アプリケーションの検索特徴の1つまたは複数のフィルタパラメータを制御する、ステップと、
前記口頭発話の前記1つまたは複数の語が、前記アプリケーションの前記インターフェースにおいてレンダリングされた前記1つまたは複数の選択可能なGUI要素に対応するとき、
前記1つまたは複数の選択可能なGUI要素のうちの1つまたは複数の特定の選択可能なGUI要素に、1つまたは複数の特定のフィルタパラメータを制御させるステップと、
前記アプリケーションに前記1つまたは複数の特定のフィルタパラメータに従って前記検索動作を初期化させるステップと
を含む、方法。
【請求項10】
前記アプリケーションに前記検索動作を初期化させるステップが、
前記アプリケーションの検索フィールドに、前記1つまたは複数の特定のフィルタパラメータを前記検索フィールドが含むことなく、前記口頭発話内で特定された前記1つまたは複数の語を含めさせるステップを含む、請求項9に記載の方法。
【請求項11】
前記口頭発話の前記1つまたは複数の語が、前記アプリケーションの前記インターフェースにおいてレンダリングされた前記1つまたは複数の選択可能なGUI要素に対応しないとき、
前記1つまたは複数の特定のフィルタパラメータを特徴付けるアプリケーション入力を生成するステップと、
前記アプリケーションに、前記アプリケーション入力を使用して前記検索動作を初期化させるステップと
をさらに含む、請求項9または請求項10に記載の方法。
【請求項12】
前記アプリケーションに、前記アプリケーション入力を使用して前記検索動作を初期化させるステップが、
前記アプリケーションの検索フィールドに前記アプリケーション入力を含めさせるステップであって、
前記アプリケーション入力が前記1つまたは複数の特定のフィルタパラメータを特定する、ステップを含む、請求項11に記載の方法。
【請求項13】
前記アプリケーション入力が、前記1つまたは複数の特定のフィルタパラメータに基づいて選択される非英数文字を含む、請求項12に記載の方法。
【請求項14】
前記口頭発話が、前記アプリケーションを使用して特定のコンテンツを検索し、その後、前記特定のコンテンツを前記ユーザのためにレンダリングすることの前記自動アシスタントに対する要求を含む、請求項9から13のいずれか一項に記載の方法。
【請求項15】
前記口頭発話の前記1つまたは複数の語が、前記アプリケーションの前記インターフェースにおいてレンダリングされた前記1つまたは複数の選択可能なGUI要素に対応しないとき、
前記1つまたは複数の特定のフィルタパラメータを満足させる特定のアプリケーションコンテンツにアクセスするステップと、
前記特定のアプリケーションコンテンツにアクセスした後で、前記自動アシスタントに前記特定のアプリケーションコンテンツに基づく可聴コンテンツをレンダリングさせるステップと
をさらに含む、請求項14に記載の方法。
【請求項16】
前記口頭発話の前記1つまたは複数の語が、前記アプリケーションの前記インターフェースにおいてレンダリングされた前記1つまたは複数の選択可能なGUI要素に対応するとき、
前記検索動作に基づいて、複数の異なる検索結果を前記アプリケーションの別のインターフェースにおいてレンダリングさせるステップと、
前記複数の異なる検索結果をレンダリングした後で、前記ユーザから追加の口頭発話を受け取るステップであって、
前記追加の口頭発話が、前記複数の異なる検索結果のサブセットを識別するための1つまたは複数の追加の語を特定する、ステップと、
前記追加の口頭発話を受け取ったことに応答して、前記複数の異なる検索結果を前記1つまたは複数の追加の語に従ってフィルタリングさせるステップと
をさらに含む、請求項9から15のいずれか一項に記載の方法。
【請求項17】
前記複数の異なる検索結果を前記1つまたは複数の追加の語に従ってフィルタリングさせるステップが、
前記別のインターフェースにおいてレンダリングされた1つまたは複数の他の選択可能なGUI要素が、前記1つまたは複数の追加の語に対応すると判定するステップと、
前記1つまたは複数の他の選択可能なGUI要素を前記1つまたは複数の追加の語に従って選択するステップと
を含む、請求項16に記載の方法。
【請求項18】
1つまたは複数のプロセッサによって実装される方法であって、
コンピューティングデバイスにおいて、アプリケーションのインターフェースを介してアクセス可能なアプリケーションコンテンツの検索を実施することの自動アシスタントに対する要求を含む口頭発話を受け取るステップであって、
前記口頭発話が、検索される前記アプリケーションコンテンツに関連する1つまたは複数の語を特定する、ステップと、
前記口頭発話に基づいて、前記アプリケーションコンテンツを前記口頭発話内で特定された前記1つまたは複数の語に従ってフィルタリングするための1つまたは複数のフィルタリング特徴を前記アプリケーションが提供するかどうかを判定するステップと、
前記アプリケーションが前記1つまたは複数のフィルタリング特徴を提供しないと判定されたとき、
前記1つまたは複数の語に基づいて、前記アプリケーションコンテンツの前記検索の実施を促進すべく前記アプリケーションにサブミットするための1つまたは複数のフィルタパラメータを識別するステップと、
前記自動アシスタントに、前記アプリケーションへのアプリケーション入力を提供させるステップであって、前記アプリケーション入力が前記1つまたは複数のフィルタパラメータを特定する、ステップと、
前記アプリケーション入力に基づいて、前記アプリケーションに検索結果をレンダリングさせるステップであって、前記検索結果が、前記アプリケーションコンテンツの、前記1つまたは複数のフィルタパラメータを満足させるサブセットを含む、ステップと
を含む、方法。
【請求項19】
前記1つまたは複数のフィルタリング特徴が、前記アプリケーションの1つまたは複数のフィルタリング動作を制御する1つまたは複数の選択可能なグラフィカルユーザインターフェース(GUI)要素を含む、請求項18に記載の方法。
【請求項20】
前記アプリケーションが前記1つまたは複数のフィルタリング特徴を提供しないと判定されたとき、
前記1つまたは複数のフィルタパラメータに基づいて、前記1つまたは複数のフィルタパラメータに基づいて選択される1つまたは複数の非英数文字を識別するステップであって、前記アプリケーション入力が前記1つまたは複数の非英数文字を特定する、ステップをさらに含む、請求項18または請求項19に記載の方法。
【請求項21】
コンピューティングシステムの1つまたは複数のプロセッサによって実行されると、前記コンピューティングシステムに請求項1から20のいずれか一項に記載の方法を実施させる命令を含む、コンピュータプログラム。
【請求項22】
請求項1から20のいずれか一項に記載の方法を実施するように構成された1つまたは複数のコンピューティングデバイス。
【発明の詳細な説明】
【背景技術】
【0001】
人間は、本明細書では「自動アシスタント」と呼ばれる(「デジタルエージェント」、「チャットボット」、「インタラクティブパーソナルアシスタント」、「インテリジェントパーソナルアシスタント」、「アシスタントアプリケーション」、「会話型エージェント」などとも呼ばれる)インタラクティブソフトウェアアプリケーションを用いて、人間対コンピュータの対話に関与することができる。例えば、(自動アシスタントとインタラクションするときは「ユーザ」と呼ばれることのある)人間は、場合によってはテキストに変換され、次いで処理されることのある、口頭による自然言語入力(すなわち発話)を使用して、かつ/またはテキストの(例えばタイプした)自然言語入力を提供することによって、自動アシスタントにコマンドおよび/または要求を与えることができる。
【0002】
例えば、自身の自動アシスタントを呼び出して、特定のアプリケーションを介して検索動作を実施させるユーザは、その特定のアプリケーションが、自動アシスタントとインターフェースするための特徴をイネーブルにしていたかどうかによって、制限されることがある。自動アシスタントがアプリケーションの特定の特徴を制御できるかどうかに応じて、自動アシスタントは、ユーザからの要求を限られた数しか履行しないことがある。そのような場合、ユーザは必然的に、履行された要求と履行されていない要求を個別に識別し、次いでその後、履行されていない要求があればそれを手動により完了させるためにタッチインターフェースとインタラクションすることを課せられることがある。インターフェース間をこのように切り替えることにより、コンピューティングデバイスの多くの点にわたってリソースが消費されることがあり、またアプリケーションおよび/または自動アシスタントによって不正確な検索結果が提供される可能性が高まることがある。
【発明の概要】
【課題を解決するための手段】
【0003】
本明細書において記載される実装形態は、ユーザがアプリケーション(例えばウェブサイト、クライアントアプリケーション、サーバアプリケーション、ブラウザなど)のアプリケーションコンテンツを、自動アシスタントに口頭発話を提供することによって、かつユーザがアプリケーションに直接的な入力を提供することなく、検索および/またはフィルタリングすることを可能にする、自動アシスタントに関する。ユーザが自動アシスタントに、アプリケーションにアクセスし、アプリケーションコンテンツを検索するように要求したときに、検索動作が初期化されることが可能である。ユーザからのそのような要求に応答して、自動アシスタントは、ユーザによって特定されたアプリケーションが、検索フィールドは別にして、検索結果をフィルタリングするための任意の特徴を提供するかどうかを判定することができる。自動アシスタントは、アプリケーションの検索インターフェースが、検索結果内に含まれるコンテンツのタイプを限定するための1つまたは複数の選択可能なグラフィカルユーザインターフェース(GUI)要素を含むかどうかを判定することができる。自動アシスタントは、ユーザからのアシスタント入力内の1つまたは複数の語に対応する1つまたは複数の選択可能なフィルタ要素をこのアプリケーションインターフェースが含むと判定したとき、この1つまたは複数のフィルタ要素をその1つまたは複数の語に従って調整することができる。次いで、自動アシスタントは、アプリケーションインターフェースの検索フィールドに、アシスタント入力内で特定された1つまたは複数の他の語を埋め、検索動作を初期化することができる。
【0004】
検索動作が初期化されたとき、アプリケーションは、検索フィールド内の1つまたは複数の語に関係するアプリケーションコンテンツを検索することができる。結果として、ユーザは、アプリケーションコンテンツを検索するためにアプリケーションと直接的にインタラクションしていなくても、アプリケーションから検索結果を受け取ることになる。アプリケーションと直接的にインタラクションしているのではなく、ユーザは、自動アシスタントが、ユーザからの要求に従ってアプリケーションとインタラクションするために、自然言語理解(NLU)および/または音声テキスト化処理を実施することを利用している。このようにして、ユーザは、アプリケーションインターフェースにおいて特定のフィルタ要素を識別しようと試みて、かつ/またはアプリケーションインターフェースの検索フィールド内に検索語を手動によりタイプして費やす、時間の量を低減させることができる。
【0005】
いくつかの実装形態では、アプリケーションによって提供される検索結果は、ユーザから自動アシスタントへの別の要求に応答して自動アシスタントによってさらにフィルタリングされることが可能である。例えば、ユーザは、自動アシスタントにアプリケーションとインタラクションして検索結果を提供させた後で、追加の口頭発話を自動アシスタントに提供することができる。この口頭発話は、1つまたは複数の追加の検索語を特定することができ、それが自動アシスタントによって使用されて、検索結果がフィルタリングされ、かつ/またはその他の方法で検索結果のサブセットが選択されることが可能である。例えば、追加の口頭発話を受け取ったことに応答して、自動アシスタントは、追加の口頭発話内に具体的に表現された任意の追加の検索語が、アプリケーションの検索結果インターフェースにおいてレンダリングされた1つまたは複数の選択可能なフィルタ要素に対応するかどうかを判定することができる。自動アシスタントは、追加の検索語がアプリケーションの1つまたは複数の選択可能なフィルタ要素に対応しないと判定したとき、アプリケーションによって実行すべき検索コマンドを生成することができる。この検索コマンドは、検索結果を生じさせるために使用された、確立された任意の検索パラメータをリセットするのではなく、かつ/またはヌル状態から新たな検索を開始するのではなく、確実にアプリケーションが検索結果のサブセットを提供するようにするために生成されることが可能である。
【0006】
いくつかの実装形態では、ユーザは自動アシスタントに、任意の検索結果コンテンツをユーザにいつ提供すべきかに関するパラメータを含む検索要求を与えることができる。例えば、ユーザは、アプリケーション(例えばニュースアプリケーション)のコンテンツを検索することを求める検索要求を与えるとともに、それに続く、ユーザが検索結果を自身に提供してもらいたい時間を指定することができる(例えば「アシスタント、昨日からのブロックチェーンの記事があるかどうか私のニュースアプリケーションを検索して、それを10:00AMに私に読み上げて」)。このようにして、自動アシスタントは、デバイスのエコシステム上で動作しているとき、いかなる関連の検索結果も、ユーザが指定の時間にアクセスしている可能性のあるデバイスにおいて検索しかつ/またはダウンロードすることができる。これによりまた、自動アシスタントが、結果として得られるコンテンツを受け取るようにユーザが要求している時点で利用可能などんなネットワークからでもコンテンツを即座にダウンロードするのではなく、検索結果を取り出すために信頼できるネットワークを選択することが可能になり得る。
【0007】
上記の説明は、本開示のいくつかの実装形態の概要として提供されたものである。それらの実装形態および他の実装形態についてのさらなる説明を、下でより詳細に記載する。
【0008】
他の実装形態は、1つまたは複数のプロセッサ(例えば中央処理装置(CPU)、グラフィック処理装置(GPU)、および/またはテンソルプロセッシングユニット(TPU)によって実行可能な、上述した方法および/または本明細書の別の場所で説明する方法のうちの1つまたは複数などの方法を実施するための命令を記憶する、非一時的コンピュータ可読記憶媒体を含むことができる。さらに他の実装形態は、上述した方法および/または本明細書の別の場所で説明する方法のうちの1つまたは複数などの方法を実施するための記憶された命令を実行するように動作可能な1つまたは複数のプロセッサを含む、1つまたは複数のコンピュータのシステムを含むことができる。
【0009】
前述の概念および本明細書においてより詳細に説明するさらなる概念のあらゆる組合せが、本明細書において開示する本主題の一部であるとして企図されていることを理解されたい。例えば、本開示の末尾に出現する、特許請求される主題のあらゆる組合せが、本明細書において開示する本主題の一部であるとして企図されている。
【図面の簡単な説明】
【0010】
【
図1A】ユーザが、アプリケーションの検索動作を制御するために自動アシスタントとインタラクションする、ビューを示す図である。
【
図1B】ユーザが、アプリケーションの検索動作を制御するために自動アシスタントとインタラクションする、ビューを示す図である。
【
図1C】ユーザが、アプリケーションの検索動作を制御するために自動アシスタントとインタラクションする、ビューを示す図である。
【
図1D】ユーザが、アプリケーションの検索動作を制御するために自動アシスタントとインタラクションする、ビューを示す図である。
【
図2】別個のアプリケーションの検索動作を、検索フィルタについての明確な制御をその別個のアプリケーションが提供するかどうかにかかわらず検索フィルタが実施されることを可能にするように制御するための、自動アシスタントを提供するシステムを示す図である。
【
図3】特定のアプリケーションコンテンツを検索および/またはフィルタリングするために自動アシスタントを別個のアプリケーションとインターフェースするように動作させるための方法を示す図である。
【
図4】例示的なコンピュータシステムのブロック図である。
【発明を実施するための形態】
【0011】
図1A、
図1B、
図1C、および
図1Dは、ユーザ102が、アプリケーション132の検索動作を制御するために自動アシスタントとインタラクションする、ビュー100、ビュー120、ビュー140、およびビュー160を示す。アプリケーション132は、自動アシスタントとは別個のものとすることができるが、自動アシスタントがアプリケーション132の特定の動作を制御することを可能にすることができる。例えば、アプリケーション132は、ユーザ102がコンピュータ部品を購入するために用いることのできるハードウェアショッピングアプリケーションとすることができる。自動アシスタントを呼び出してアプリケーション132を制御するために、ユーザ102は口頭発話106をコンピューティングデバイス104のオーディオインターフェースに提供することができる。口頭発話106は、例えば、
図1Aのビュー100に示すように、「アシスタント、RAMがあるかどうかハードウェアショッピングアプリケーションを検索して」とすることができる。
【0012】
口頭発話に応答して、自動アシスタントは、アプリケーション132を初期化し、アプリケーション132に口頭発話の自然言語コンテンツに基づく検索動作を実行させることができる。例えば、「RAM」という語が、自動アシスタントによってアプリケーション132の検索フィールド122に組み込まれ、アプリケーション132に「RAM」という語に基づく検索を実行させることができる。結果として、自動アシスタントは、口頭発話106に応答して、検索結果インターフェース138をコンピューティングデバイス104のディスプレイインターフェースにおいてレンダリングさせることができる。アプリケーション132における検索結果インターフェース138は、検索結果126のリスト、1つもしくは複数のフィルタを制御するための1つもしくは複数の選択可能なGUI要素124、1つもしくは複数の選択可能なチェックボックス130、1つもしくは複数の画像結果、および/またはアプリケーション132を制御するための1つもしくは複数の他の選択可能な要素136を含むことができる。
【0013】
ユーザ102は、コンピューティングデバイス104においてディスプレイインターフェースと手動によりインタラクションして、検索結果126をさらに絞り込むことができるが、その代わりに、自動アシスタントと引き続きインタラクションして、検索結果126を絞り込むこともできる。例えば、ユーザ102からの事前の許可を受けて、自動アシスタントは、ユーザ102がアプリケーション132を制御するための任意の入力を提供したかどうかを引き続き検出することができる。例として、ユーザ102は、別の口頭発話134を、検索結果126をこの別の口頭発話134のコンテンツに従ってフィルタリングするために、提供することができる。この別の口頭発話134は、例えば、検索結果126内にリストされた項目のサブセットの分類を指すことのできる「SODIMM」とすることができる。この別の口頭発話134に応答して、自動アシスタントは、この別の口頭発話134が1つもしくは複数の追加の検索語および/または1つもしくは複数のフィルタパラメータを含むかどうかを判定することができる。
【0014】
自動アシスタントは、例えば、検索結果インターフェース138において利用可能な1つまたは複数のフィルタのフィルタパラメータをユーザが特定したと判定することができる。いくつかの実装形態では、自動アシスタントは、口頭発話のコンテンツとアプリケーションのフィルタパラメータとの間の相互関係を、利用可能なアシスタントデータに基づいて識別することができる。アシスタントデータは、アプリケーション132および/または別のアプリケーションに関連するさまざまなアプリケーションインターフェースおよび/またはアプリケーションメタデータ(例えばHTML、XML、PHPなど)に基づく、1つもしくは複数の発見的プロセスおよび/または1つもしくは複数のトレーニングされた機械学習モデルを特徴付けることができる。したがって、特定のフィルタパラメータがユーザによって特定されたとき、その特定のフィルタパラメータに従って1つまたは複数の選択可能なGUI要素を変更するための1つまたは複数のコマンドを生成する目的で、アシスタントデータが使用されることが可能である。
【0015】
この別の口頭発話134に応答して、自動アシスタントは、口頭発話134のコンテンツに基づいてフィルタをイネーブルにするために、1つまたは複数の選択可能なGUI要素124とインタラクションすることができる。例えば、自動アシスタントは、「タイプ」ドロップダウンメニューを選択させ、かつ
図1Cのビュー140に示すようにRAMタイプ「SODIMM」を選択させる、コマンドを生成することができる。RAMのタイプを制御する選択可能なGUI要素124を変更したことに応答して、アプリケーション132はその後、検索結果142の別のリストをレンダリングすることができ、また自動アシスタントを介して活動状態にされたフィルタ146の標識(例えばSODIMM)を含めることもできる。
【0016】
いくつかの実装形態では、ユーザ102がインタラクションしているアプリケーション132が、検索結果をフィルタリングする1つまたは複数のフィルタリング動作を制御するための特定のフィルタを含まないことがある。それにもかかわらず、検索結果をアプリケーション132によって提供されるどんな選択可能なGUI要素にも対応しないことのある1つまたは複数の検索パラメータに従ってさらに絞り込むために、自動アシスタントがユーザ102によって呼び出されることが可能である。例えば、ユーザ102は、メモリチップの別の分類を指すことのできる「非ECC」など、追加の口頭発話144を提供することができる。追加の口頭発話144を受け取ったことに応答して、自動アシスタントは、追加の口頭発話144のコンテンツが、検索結果インターフェース138において利用可能な任意の選択要素に関連する1つまたは複数の語を含むかどうかを判定することができる。
【0017】
例えば、自動アシスタントは、検索結果インターフェース138の任意のコンテンツおよび/またはアプリケーション132に関連するメタデータが、検索結果142を「非ECC」という語に従ってフィルタリングすることのできる選択可能なフィルタに対応するかどうかを判定することができる。自動アシスタントは、追加の口頭発話144内の1つまたは複数の語が、アプリケーション132の、利用可能などんな選択可能なフィルタにも関連しないと判定したとき、ユーザにより選択可能な適切なフィルタを提供しないアプリケーション132の代わりに、検索語148を生成することができる。いくつかの実装形態では、自動アシスタントは、口頭発話内の1つまたは複数の語が、利用可能などんなコンテンツフィルタにも関連しないと判定したとき、検索コマンドに組み込むための1つまたは複数の英数文字および/または非英数文字を識別することができる。
【0018】
追加の口頭発話144に応答して、自動アシスタントは、1つまたは複数の検索語148を検索フィールド122に組み込み、アプリケーション132を介して検索動作を初期化することができる。検索語148は、ユーザ102によって要求された事前の検索からの1つまたは複数の検索語(例えば「RAM」)、およびユーザ102によって要求された一番最近の検索からの1つまたは複数の追加の検索語(例えば「非ECC」)を含むことができる。結果として、アプリケーション132は、フィルタリングされた検索結果162を検索結果インターフェース138においてレンダリングすることができる。いくつかの実装形態では、
図1Dのビュー160に提示されているように、自動アシスタントによって用いられた任意のアシスタントフィルタについてユーザ102に知らせるために、検索語148が検索フィールド122内に留まることができる。
【0019】
いくつかの実装形態では、(例えば
図1Cに示す)現在利用可能な検索結果をさらに絞り込むための別の入力をユーザ102が発行したとき、自動アシスタントは、アプリケーション132において利用可能な1つまたは複数のフィルタの各フィルタのそれぞれの状態を識別することができる。例えば、ユーザ102が口頭発話144を提供したことに応答して、自動アシスタントは、「タイプ」フィルタの設定を識別し、後続の検索が実施されるときに確実に「タイプ」フィルタが同じ状態を有するようにするための、アシスタント入力を用いてアプリケーション132にサブミットされることの可能なコマンドデータを生成することができる。例として、自動アシスタントは、口頭発話144に基づいて、検索フィールド148内に提供するための検索コマンドを生成することができ、この検索コマンド(例えば「非ECC RAM」)が実行されるとき、自動アシスタントは、「タイプ」フィルタが「SODIMM」に限定されているかどうかを判定するためのチェックをすることができる。自動アシスタントは、「タイプ」フィルタが変化しないままになっていると判定したとき、別のコマンドをサブミットしないことがある。しかし、口頭発話144に基づく検索コマンドの実行後に「タイプ」フィルタがリセットされているとき、自動アシスタントは、「タイプ」フィルタを「SODIMM」に限定されるように変更することができる。いくつかの実装形態では、自動アシスタントは、ユーザ102が、検索結果の現在のセットをさらに絞り込むように要求しているか、それとも(例えば全てのフィルタがリセットされた)ヌル状態からの新たな検索を開始するように要求しているかを判定することができる。いくつかの実装形態では、この判定は、アシスタント入力のコンテンツ(例えば口頭発話が「検索」という語を含むか、それとも省略しているか)および/または新たな検索もしくは検索の絞り込みに関連することのできる任意のコンテキストに基づくことができる。
【0020】
いくつかの実装形態では、ユーザ102は、検索結果を明示的に特定することなく、かつ/または一番最近の検索結果162に課すための別のフィルタパラメータを示すことによって、特定の検索結果を選択することができる。例えば、特定の検索結果は、特定の検索結果の、他の検索結果と比較した特徴に基づいて識別されることが可能である。いくつかの実装形態では、ユーザ102は、検索結果のリストについて検索結果を選択するために、特定の検索結果の視覚的特徴および/または自然言語コンテンツ特徴を指定することができる。視覚的特徴は、例えば、アプリケーション132によっていくつかの検索結果に関連してレンダリングされている1つまたは複数の画像128に対応することができる。その代わりにまたはそれに加えて、特定の検索結果とユーザ102によって提供されたアシスタント入力のコンテンツとの間の任意の相互関係を識別するために、特定の検索結果の英数文字および/または非英数文字が自動アシスタントによって解釈されることが可能である。
【0021】
例えば、ユーザ102は、一番最近の検索結果162のうちの最大のメモリ容量(例えば16GB)を有する検索結果を指すことのできる「最大のもの」など、口頭発話を提供することができる。いくつかの実装形態では、各検索結果が、自動アシスタントによって、潜在空間内にマッピングされることの可能なそれぞれの埋め込みを生成するように処理されることが可能である。その後、後続のアシスタント入力に応答して、自動アシスタントは、そのアシスタント入力についての埋め込みを、潜在空間にマッピングされたそれぞれの埋め込みと比較することができる。その代わりにまたはそれに加えて、ユーザが指している可能性のある特定の検索結果を識別するために、発見的プロセスが実行されることが可能である。例えば、口頭発話164があると、自動アシスタントは、各検索結果についてのサイズを示すことのできる語を識別するために、それぞれの検索結果内の1つまたは複数の語を相互に比較することができる。自動アシスタントが、ユーザ102が指している検索結果を(例えば16GB RAMについてのチェックボックス130を選択することによって)選択したとき、ユーザ102は、ユーザ102とアプリケーション132との間のインターフェースとしての働きをする自動アシスタントを用い続けるために、後続の口頭発話166(例えば「チェックアウト」)を提供することができる。
【0022】
図2は、別個のアプリケーションの検索動作を、検索フィルタについての明確な制御をその別個のアプリケーションが提供するかどうかにかかわらず検索フィルタが実施されることを可能にするように制御するための、自動アシスタントを提供するシステム200を示す。自動アシスタント204は、コンピューティングデバイス202および/またはサーバデバイスなど、1つまたは複数のコンピューティングデバイスにおいて設けられる、アシスタントアプリケーションの一部として動作することができる。ユーザは自動アシスタント204と、アシスタントインターフェース220を介してインタラクションすることができ、アシスタントインターフェース220は、マイクロホン、カメラ、タッチスクリーンディスプレイ、ユーザインターフェース、および/またはユーザとアプリケーションとの間のインターフェースを提供することの可能な他の任意の装置とすることができる。例として、ユーザは、アシスタントインターフェース220に口頭入力、テキスト入力、および/またはグラフィカル入力を提供して、自動アシスタント204に1つまたは複数のアクションを初期化させる(例えばデータを提供させる、周辺デバイスを制御させる、エージェントにアクセスさせる、入力および/または出力を生成させるなど)ことによって、自動アシスタント204を初期化することができる。
【0023】
あるいは、自動アシスタント204は、1つまたは複数のトレーニングされた機械学習モデルを使用してコンテキストデータ236を処理することに基づいて、初期化されてもよい。コンテキストデータ236は、自動アシスタント204にアクセス可能な環境の1つもしくは複数の特徴、および/または自動アシスタント204とインタラクションしようとしていることが予測されるユーザの1つもしくは複数の特徴を、特徴付けることができる。コンピューティングデバイス202は、ディスプレイデバイスを含むことができ、ディスプレイデバイスは、タッチインターフェースを含むディスプレイパネルとすることができ、タッチインターフェースは、タッチインターフェースを介してユーザがコンピューティングデバイス202のアプリケーション234を制御することを可能にするタッチ入力および/またはジェスチャを受け取るためのものである。いくつかの実装形態では、コンピューティングデバイス202はディスプレイデバイスを欠いていることがあり、したがって、グラフィカルユーザインターフェース出力を提供せずに、可聴ユーザインターフェース出力を提供する。さらに、コンピューティングデバイス202は、ユーザから口頭による自然言語入力を受け取るためのマイクロホンなどのユーザインターフェースを提供することができる。いくつかの実装形態では、コンピューティングデバイス202はタッチインターフェースを含むことができ、コンピューティングデバイス202にはカメラがないことがあるが、コンピューティングデバイス202は、オプションで、1つまたは複数の他のセンサを含むことができる。
【0024】
コンピューティングデバイス202および/または他のサードパーティクライアントデバイスは、インターネットなどのネットワーク経由でサーバデバイスと通信状態にあることができる。加えて、コンピューティングデバイス202および他の任意のコンピューティングデバイスは、Wi-Fiネットワークなどのローカルエリアネットワーク(LAN)経由で相互に通信状態にあることができる。コンピューティングデバイス202は、コンピューティングデバイス202における計算リソースを節約するために、計算タスクをサーバデバイスにオフロードすることができる。例として、サーバデバイスが自動アシスタント204をホストすることができ、かつ/またはコンピューティングデバイス202が、1つもしくは複数のアシスタントインターフェース220において受信した入力をサーバデバイスに送信することができる。しかし、いくつかの実装形態では、自動アシスタント204は、コンピューティングデバイス202においてホストされることが可能であり、自動アシスタントの動作に関連付けられることの可能なさまざまなプロセスが、コンピューティングデバイス202において実施されることが可能である。
【0025】
さまざまな実装形態では、自動アシスタント204の全てまたは一部の態様が、コンピューティングデバイス202上に実装されることが可能である。それらの実装形態のいくつかでは、自動アシスタント204の態様が、コンピューティングデバイス202によって実装され、自動アシスタント204の他の態様を実装することのできるサーバデバイスとインターフェースすることができる。サーバデバイスは、オプションで、複数のユーザおよびそれらの関連するアシスタントアプリケーションに、複数のスレッドを介してサービスすることができる。自動アシスタント204の全てまたは一部の態様がコンピューティングデバイス202によって実装される実装形態では、自動アシスタント204は、コンピューティングデバイス202のオペレーティングシステムとは別個の(例えばオペレーティングシステムの「上に」インストールされる)アプリケーションとすることもでき、あるいは別法として、コンピューティングデバイス202のオペレーティングシステムによって直接実装される(例えばオペレーティングシステムと一体であるがオペレーティングシステムのアプリケーションと見なされる)ことも可能である。
【0026】
いくつかの実装形態では、自動アシスタント204は、入力処理エンジン206を含むことができ、入力処理エンジン206は、複数の異なるモジュールを用いて、コンピューティングデバイス202および/またはサーバデバイスの入力および/または出力を処理することができる。例として、入力処理エンジン206は、アシスタントインターフェース220において受け取ったオーディオデータをそのオーディオデータ内に具体的に表現されたテキストを識別するために処理することのできる、音声処理エンジン208を含むことができる。コンピューティングデバイス202における計算リソースを維持するために、オーディオデータは、例えばコンピューティングデバイス202からサーバデバイスに送信されることが可能である。それに加えてまたはその代わりに、オーディオデータは、コンピューティングデバイス202において一手に処理されることも可能である。
【0027】
オーディオデータをテキストに変換するためのプロセスは、音声認識アルゴリズムを含むことができ、音声認識アルゴリズムは、ニューラルネットワークおよび/または統計モデルを用いて、単語またはフレーズに対応するオーディオデータのグループを識別することができる。オーディオデータから変換されたテキストは、データパーシングエンジン210によってパースされることが可能であり、コマンドフレーズ、意図(intent)、アクション、スロット値、および/またはユーザによって指定された他の任意のコンテンツを生成および/または識別するために使用することのできるテキストデータとして、自動アシスタント204にとって利用可能にされることが可能である。いくつかの実装形態では、自動アシスタント204および/または自動アシスタント204を介してアクセスされることの可能なアプリケーションもしくはエージェントによって実施されることの可能な特定の意図、アクション、および/またはルーチンに対応する入力をユーザが提供したかどうかを判定するために、データパーシングエンジン210によって提供された出力データがパラメータエンジン212に提供されることが可能である。例えば、アシスタントデータ238が、サーバデバイスおよび/またはコンピューティングデバイス202において記憶されることが可能であり、アシスタントデータ238は、自動アシスタント204によって実施されることの可能な1つまたは複数のアクションを定義するデータ、ならびにそのアクションを実施するために必要なパラメータを含むことができる。パラメータエンジン212は、意図、アクション、および/またはスロット値に関する1つまたは複数のパラメータを生成し、この1つまたは複数のパラメータを出力生成エンジン214に提供することができる。出力生成エンジン214は、この1つまたは複数のパラメータを使用して、ユーザに出力を提供するためにアシスタントインターフェース220と通信し、かつ/または1つもしくは複数のアプリケーション234に出力を提供するために1つもしくは複数のアプリケーション234と通信することができる。
【0028】
いくつかの実装形態では、自動アシスタント204は、コンピューティングデバイス202のオペレーティングシステム「の上に」インストールされることの可能なアプリケーションとすることができ、かつ/またはそれ自体が、コンピューティングデバイス202のオペレーティングシステムの一部(もしくは全体)を形成することができる。自動アシスタントアプリケーションは、オンデバイス音声認識、オンデバイス自然言語理解、およびオンデバイス履行を含み、かつ/またはそれらにアクセスすることができる。例えば、オンデバイス音声認識は、(マイクロホンによって検出された)オーディオデータをコンピューティングデバイス202においてローカルに記憶されたエンドツーエンド音声認識機械学習モデルを使用して処理する、オンデバイス音声認識モジュールを使用して実施されることが可能である。オンデバイス音声認識は、オーディオデータ内に存在する口頭発話(があればそれ)について、認識されたテキストを生成する。また、例えば、オンデバイス自然言語理解(NLU)は、オンデバイス音声認識を使用して生成された、認識されたテキストと、オプションでコンテキストデータとを処理してNLUデータを生成する、オンデバイスNLUモジュールを使用して実施されることが可能である。
【0029】
NLUデータは、口頭発話に対応する意図と、オプションで、意図に関するパラメータ(例えばスロット値)とを含むことができる。オンデバイス履行は、(オンデバイスNLUからの)NLUデータと、オプションで他のローカルデータとを利用して、口頭発話の意図(およびオプションで意図に関するパラメータ)を解決するためにとるべきアクションを決定する、オンデバイス履行モジュールを使用して実施されることが可能である。これには、口頭発話に対するローカルおよび/もしくはリモートの応答(例えば回答)、口頭発話に基づいて実施すべき、ローカルにインストールされたアプリケーションとのインタラクション、口頭発話に基づいてモノのインターネット(IoT)デバイスに(直接的にもしくは対応するリモートシステムを介して)送信すべきコマンド、ならびに/または口頭発話に基づいて実施すべき他の解決アクションを決定することを含むことができる。次いで、オンデバイス履行は、口頭発話を解決するために、決定されたアクションのローカルおよび/またはリモートの実施/実行を開始することができる。
【0030】
さまざまな実装形態では、リモート音声処理、リモートNLU、および/またはリモート履行が、少なくとも選択的に利用されることが可能である。例えば、認識されたテキストは、リモートNLUおよび/またはリモート履行のために、リモート自動アシスタントコンポーネントに少なくとも選択的に送信されることが可能である。例として、認識されたテキストは、オプションで、オンデバイス実施と並行して、またはオンデバイスNLUおよび/もしくはオンデバイス履行の失敗に応答して、リモート実施のために送信されることが可能である。しかし、オンデバイス音声処理、オンデバイスNLU、オンデバイス履行、および/またはオンデバイス実行は、少なくとも、口頭発話を解決するときにそれらがもたらすレイテンシ低減のため(口頭発話を解決するのにクライアント-サーバラウンドトリップが必要とされないため)、優先されることが可能である。さらに、オンデバイス機能は、ネットワーク接続性のない、またはネットワーク接続性が限られた状況下で利用可能な、唯一の機能であり得る。
【0031】
いくつかの実装形態では、コンピューティングデバイス202は、コンピューティングデバイス202および/または自動アシスタント204を提供したエンティティとは異なるサードパーティエンティティによって提供されることの可能な1つまたは複数のアプリケーション234を含むことができる。自動アシスタント204および/またはコンピューティングデバイス202のアプリケーション状態エンジンが、1つまたは複数のアプリケーション234によって実施されることの可能な1つまたは複数のアクション、ならびに1つもしくは複数のアプリケーション234の各アプリケーションの状態および/またはコンピューティングデバイス202に関連するそれぞれのデバイスの状態を決定するために、アプリケーションデータ230にアクセスすることができる。自動アシスタント204および/またはコンピューティングデバイス202のデバイス状態エンジンが、コンピューティングデバイス202および/またはコンピューティングデバイス202に関連する1つもしくは複数のデバイスによって実施されることの可能な1つまたは複数のアクションを決定するために、デバイスデータ232にアクセスすることができる。さらに、アプリケーションデータ230および/または他の任意のデータ(例えばデバイスデータ232)は、コンテキストデータ236を生成するために自動アシスタント204によってアクセスされることが可能であり、コンテキストデータ236は、特定のアプリケーション234および/またはデバイスが実行されているコンテキスト、ならびに/あるいは特定のユーザがコンピューティングデバイス202にアクセスしている、アプリケーション234、および/または他の任意のデバイスもしくはモジュールにアクセスしているコンテキストを特徴付けることができる。
【0032】
1つまたは複数のアプリケーション234がコンピューティングデバイス202において実行されている間、デバイスデータ232は、コンピューティングデバイス202において実行されている各アプリケーション234の現在の動作状態を特徴付けることができる。さらに、アプリケーションデータ230は、1つまたは複数のアプリケーション234の指示でレンダリングされている1つまたは複数のグラフィカルユーザインターフェースのコンテンツなど、実行されているアプリケーション234の1つまたは複数の特徴を特徴付けることができる。その代わりにまたはそれに加えて、アプリケーションデータ230は、それぞれのアプリケーションの現在の動作状態に基づいて、それぞれのアプリケーションによってかつ/または自動アシスタント204によって更新されることの可能な、アクションスキーマを特徴付けることができる。その代わりにまたはそれに加えて、1つまたは複数のアプリケーション234に関する1つまたは複数のアクションスキーマは、固定のままであり得るが、自動アシスタント204を介して初期化すべき適切なアクションを決定するためにアプリケーション状態エンジンによってアクセスされることが可能である。
【0033】
コンピューティングデバイス202は、アシスタント呼出しエンジン222をさらに含むことができ、アシスタント呼出しエンジン222は、1つまたは複数のトレーニングされた機械学習モデルを使用して、アプリケーションデータ230、デバイスデータ232、コンテキストデータ236、および/またはコンピューティングデバイス202にとってアクセス可能な他の任意のデータを処理することができる。アシスタント呼出しエンジン222はこのデータを、自動アシスタント204を呼び出すための呼出しフレーズをユーザが明示的に話すのを待つか、または呼出しフレーズを明示的に話すようにユーザに要求する代わりに、データが、自動アシスタントを呼び出そうとするユーザの意図を示すものであると見なすべきか否かを判定するために、処理することができる。例えば、1つまたは複数のトレーニングされた機械学習モデルは、複数のデバイスおよび/またはアプリケーションがさまざまな動作状態を呈している環境内にユーザが存在するというシナリオに基づくトレーニングデータインスタンスを使用してトレーニングされることが可能である。トレーニングデータインスタンスは、ユーザが自動アシスタントを呼び出すコンテキストおよびユーザが自動アシスタントを呼び出さない他のコンテキストを特徴付けるトレーニングデータを取り込むために、生成されることが可能である。
【0034】
1つまたは複数のトレーニングされた機械学習モデルが、これらのトレーニングデータインスタンスに従ってトレーニングされたとき、アシスタント呼出しエンジン222は自動アシスタント204に、コンテキストおよび/または環境の特徴に基づいて、ユーザからの口頭による呼出しフレーズを検出させるかまたはその検出を制限させることができる。それに加えてまたはその代わりに、アシスタント呼出しエンジン222は自動アシスタント204に、コンテキストおよび/または環境の特徴に基づいて、ユーザからの1つまたは複数のアシスタントコマンドを検出させるかまたはその検出を制限させることもできる。いくつかの実装形態では、アシスタント呼出しエンジン222は、コンピューティングデバイス202が別のコンピューティングデバイスからのアシスタント抑制出力を検出したことに基づいて、ディスエーブルまたは制限されることが可能である。このようにして、コンピューティングデバイス202がアシスタント抑制出力を検出しているとき、自動アシスタント204は、普通ならアシスタント抑制出力が検出されていなければ自動アシスタント204が呼び出されるようにするはずであるコンテキストデータ236に基づいて呼び出されないことになる。
【0035】
いくつかの実装形態では、システム200はフィルタ識別エンジン216を含むことができ、フィルタ識別エンジン216は、1つもしくは複数のフィルタ特徴へのアクセスをアプリケーションが与えるかどうかを判定するために、かつ/または1つもしくは複数のフィルタ特徴をどのように制御するかを決定するために、アプリケーションデータ230、デバイスデータ232、コンテキストデータ236、および/または他の任意のデータを含むことのできるアシスタントデータ238を処理する。フィルタ識別エンジン216は、コンピューティングデバイス202において実行されているアプリケーション234が1つまたは複数のフィルタ特徴を制御するための1つまたは複数の選択可能なGUI要素をレンダリングしているかどうかを判定するために、アシスタントデータ238を処理することができる。いくつかの実装形態では、アシスタントデータ238は、1つもしくは複数の発見的プロセスに従って、かつ/または1つもしくは複数のトレーニングされた機械学習モデルを使用して、処理されることが可能である。特定のアプリケーションについて1つまたは複数のフィルタ特徴が識別されたとき、フィルタ識別エンジン216は、ユーザからの入力がその1つまたは複数のフィルタ特徴に関連するかどうかを判定するために、システム200の入力語エンジン218と通信することができる。
【0036】
例えば、フィルタ識別エンジン216は、ユーザによってアクセスされているアプリケーションの1つまたは複数のフィルタ特徴を特徴付けるデータを生成することができ、自動アシスタント204は、そのデータをユーザからの入力と比較することができる。ユーザは、1つもしくは複数の語および/または特定のアプリケーションコンテンツの検索をアプリケーションに実施させるための自動アシスタントに対する要求を含む、口頭発話などの入力を提供することができる。自動アシスタント204は、その入力のコンテンツが1つまたは複数のフィルタ特徴のいずれかに関連するかどうかを判定するために、その入力の自然言語コンテンツをフィルタ識別エンジン216からのデータと比較することができる。フィルタ特徴のうちの1つまたは複数を特定する検索要求をユーザが提供したと自動アシスタント204が判定したとき、自動アシスタントは、アプリケーションに通信すべきコマンドデータを生成することができる。アプリケーションによって受け取られたコマンドデータは、1つまたは複数のフィルタ特徴の1つまたは複数のフィルタパラメータをユーザからの入力に従って変更し、アプリケーションに検索動作を実行させることができる。
【0037】
いくつかの実装形態では、ユーザからの入力が、アプリケーションのどんなフィルタ特徴にも関連しないことがあるがそれでもなお検索結果をフィルタリングするためのものであることがユーザによって意図されていることのある語を含むことができる。結果として、自動アシスタント204は、検索入力エンジン226を用いて、ユーザ入力内の任意の語が、アプリケーションの検索フィールドに組み込まれることの可能な検索コマンド(すなわちアプリケーション入力)を生成するためのベースとして使用されることが可能であるかどうかを判定することができる。例えば、検索結果をフィルタリングするための語(例えば「今年製造されたRAMを検索して」)をユーザが含めたが、対応するフィルタリング特徴がアプリケーションにない(例えば製造年を限定するためのスライドバーがない)とき、検索入力エンジン226は、検索動作の実行の際にアプリケーションの検索フィールドに組み込むべき検索コマンドの一部分(例えば「MFR>=2021」)を生成することができる。その代わりにまたはそれに加えて、入力のいくつかの語が検索語(例えば「RAM」、「ラップトップメモリ」など)として検索コマンドに組み込まれることが可能であると入力語エンジン218が決定したとき、検索入力エンジン226は、そのような検索語を、他の任意の識別されたフィルタパラメータと組み合わせて、検索コマンドに組み込むことができる(例えばSearch Field: "RAMラップトップメモリMFR>=2021")。
【0038】
検索動作が自動アシスタントを介してアプリケーションにおいて実行されるとき、アプリケーションは、検索結果としての特定のコンテンツをレンダリングすることができる。検索結果は、アプリケーションの検索結果インターフェースにおいてレンダリングされることが可能であり、また検索結果は、システム200の検索結果エンジン224によって処理されることが可能である。検索結果エンジン224は、後続の任意の入力(例えば検索結果がコンピューティングデバイス202のフォアグラウンドにおいてレンダリングされている間に提供されたユーザ入力)が検索結果に関連するかどうかを判定するために、検索結果に基づいてさらなるデータを生成することができる。検索結果エンジン224は、限定はしないが、検索結果インターフェースに関連することのできるスクリーンショット、メタデータ、ソースコード、および/または他の任意のデータを含む、データを処理することができる。いくつかの実装形態では、検索結果エンジン224は、検索動作を実行することのユーザからの要求に応答してより正確な検索結果をレンダリングさせるために、1つまたは複数のトレーニングされた機械学習モデルをさらにトレーニングするためのトレーニングデータを生成することができる。例えば、特定のトレーニングされた機械学習モデルを、ユーザによって指定された検索語および/またはフィルタパラメータを処理するために用いられたときにより高信頼になるように改変するために、語および/または埋め込みの重み付けが変更されることが可能である。例として、第1のアプリケーションの場合の語の重み付けは、第2のアプリケーションの場合のそれらの語の別の重み付けとは、少なくとも、ユーザからの検索要求に関連する結果をいかに高信頼にそれぞれの語が生じさせるかに基づいて異なってよい。
【0039】
図3は、特定のアプリケーションコンテンツを検索および/またはフィルタリングするために自動アシスタントを別個のアプリケーションとインターフェースするように動作させるための方法300を示す。方法300は、自動アシスタントとインタラクションすることの可能な、1つまたは複数のアプリケーション、デバイス、および/または他の任意の装置もしくはモジュールによって実施されることが可能である。方法300は、口頭発話が自動アシスタントによって受け取られたかどうかを判定する動作302を含むことができる。例えば、口頭発話は、特定の記事を識別するために百科事典アプリケーションにアクセスすることを自動アシスタントに求める要求(例えば「アシスタント、今年書かれた暗号化技術の記事があるかどうか私の百科事典アプリケーションを検索して」)とすることができる。口頭発話を受け取ったことに応答して、自動アシスタントは、口頭発話内に具体的に表現された1つまたは複数の要求を識別するために、オーディオデータを処理することができる。
【0040】
方法300は、動作302から動作304に移ることができ、動作304は、検索動作が別のアプリケーションにおいて初期化されることをユーザが要求しているかどうかを判定することを含むことができる。そうではなく、口頭発話が受け取られないとき、自動アシスタントはアシスタント入力を引き続き検出することができる。検索動作が初期化されることを求める要求は、特定のアプリケーションコンテンツを検索するために、ユーザの用いたいアプリケーションを、自動アシスタントと組み合わせて指定することができる。その代わりにまたはそれに加えて、検索動作を求める要求は、特定のアプリケーションコンテンツを識別するために使用すべき1つまたは複数の語を特定することができる。ユーザが、検索動作が別のアプリケーションにおいて初期化されるように要求したと判定されたとき、方法300は、動作304からオプションの動作306に移ることができる。そうでない場合、方法300は、1人または複数のユーザからのアシスタント入力を検出するために動作302に戻ることができる。
【0041】
オプションの動作306は、1つまたは複数のアプリケーションの1つまたは複数の検索インターフェースに基づく自動アシスタントデータを処理することを含むことができる。例えば、アシスタントデータは、アプリケーションの検索インターフェースに基づくデータを処理するために使用されることの可能な、1つもしくは複数の発見的プロセスおよび/または1つもしくは複数の機械学習モデルを特徴付けることができる。口頭発話に応答して、自動アシスタントは、アプリケーションの検索インターフェースがコンピューティングデバイスのディスプレイインターフェースにおいてレンダリングされるようにするために、アプリケーションを初期化することができる。アシスタントデータは、検索インターフェースの特定の特徴が自動アシスタントによって制御されることが可能であるかどうかを判定するために処理されることが可能である。例えば、検索インターフェースは、アプリケーションによって実行すべき検索動作を定めるための検索語および/または他の文字の入力用の検索フィールドを含むことができる。その代わりにまたはそれに加えて、検索インターフェースは、検索動作についてのフィルタ設定を確立させるための1つまたは複数の選択可能なGUI要素を含むことができる。
【0042】
方法300は、オプションの動作306から、口頭発話がアプリケーションに関連する1つまたは複数のフィルタパラメータを特定するかどうかを判定するための動作308に移ることができる。例えば、口頭発話の自然言語コンテンツとアプリケーションに関連する1つまたは複数のフィルタパラメータとの間に任意の相互関係があるかどうかを判定するために、アシスタントデータが入力のオーディオデータとともに処理されることが可能である。先の例によれば、自動アシスタントは、アプリケーションの検索インターフェースが、特定の日付より前に掲載された百科事典の記事をフィルタリングするためのフィルタパラメータを含むと決定することができる。口頭発話が1つまたは複数のフィルタパラメータを特定すると自動アシスタントが判定したとき、方法300は、動作308から動作310に移ることができる。そうでない場合、方法300は、動作308から動作314に移ることができる。
【0043】
動作310は、1つまたは複数のフィルタ設定を口頭発話に基づいて変更することを含むことができる。例えば、口頭発話は、自動アシスタントがアプリケーションの1つまたは複数のフィルタを適宜変更できるようにするためにユーザによって指定された、1つまたは複数のフィルタパラメータを具体的に表現することができる。いくつかの場合には、ユーザは、1つもしくは複数のチェックボックスおよび/または1つもしくは複数のダイヤルなど、1つまたは複数の選択可能なGUI要素に対応する1つまたは複数のフィルタパラメータを特定することができる。自動アシスタントは、ユーザからの要求に従って検索動作を実行するために1つまたは複数の選択可能なGUI要素をどのように変更するかを、ユーザによって特定された1つまたは複数のフィルタパラメータに基づいて決定することができる。例えば、自動アシスタントに特定の年より後に掲載された記事があるかどうか百科事典アプリケーションを検索するようにユーザが要求したとき、自動アシスタントは、掲載日付フィルタを制御するダイヤル式の選択可能なGUI要素を調整することができる。次いで、方法300は、動作310から動作312に移ることができ、動作312は、アプリケーションに口頭発話に基づいて検索動作を初期化させることを含むことができる。結果として、実行される検索動作は、ユーザが特定のフィルタを活動状態にするためにディスプレイインターフェースと手動によりインタラクションしなくても、ユーザによって指定されたフィルタパラメータを使用して初期化され、自動アシスタントによって実施されることが可能である。その代わりにまたはそれに加えて、検索動作は、口頭発話内で特定され、アプリケーションの検索インターフェースの検索フィールドに組み込まれた、1つまたは複数の検索語を用いて初期化されることが可能である。
【0044】
いくつかの実装形態では、口頭発話が、アプリケーションに関連しないかまたはその他の形でアプリケーションの検索インターフェースにおいて利用可能でないことのある1つまたは複数のフィルタパラメータを特定するとき、方法300は、動作308から動作314に移ることができる。動作314は、この1つまたは複数のフィルタパラメータに基づいてアプリケーション入力を生成することを含むことができる。アプリケーション入力は、例えば、検索動作を実行するためにアプリケーションの検索フィールド内に提供されることの可能な英数文字および/または非英数文字を含む検索コマンドとすることができる。いくつかの実装形態では、フィルタパラメータがユーザによって特定されたものの検索インターフェースにおいて利用可能でないとき、自動アシスタントは、1つまたは複数の特殊文字(例えば非英数文字)を識別することができる。例えば、検索インターフェースが、特定の時間に関して検索結果を限定するための選択可能なGUI要素を含まないとき、自動アシスタントは、1つまたは複数の特殊文字および/または式(例えば>、<、>=、<=など)を識別することができ、これらは、特定の時間範囲に関連しないことのあるいくつかの検索結果をフィルタリング除去するために使用されることが可能である(例えば「暗号化技術<=1年」)。このようにして、ユーザはそのような検索を、検索結果が表示されるのを待ち、その後、検索結果インターフェースにおいて利用可能であることもあればないこともある任意のフィルタを調整して実施するのではなく、自動アシスタントへの単一の入力として実施することができる。
【0045】
図4は、例示的なコンピュータシステム410のブロック
図400である。コンピュータシステム410は、典型的には、いくつかの周辺デバイスとバスサブシステム412を介して通信する少なくとも1つのプロセッサ414を含む。これらの周辺デバイスは、例えばメモリ425およびファイルストレージサブシステム426を含むストレージサブシステム424、ユーザインターフェース出力デバイス420、ユーザインターフェース入力デバイス422、ならびにネットワークインターフェースサブシステム416を含むことができる。入力デバイスおよび出力デバイスは、コンピュータシステム410とのユーザインタラクションを可能にする。ネットワークインターフェスサブシステム416は、外部ネットワークへのインターフェースを提供し、他のコンピュータシステム内の対応するインターフェースデバイスに結合される。
【0046】
ユーザインターフェース入力デバイス422は、キーボード、マウス、トラックボール、タッチパッド、もしくはグラフィックタブレットなどのポインティングデバイス、スキャナ、ディスプレイに組み込まれたタッチスクリーン、ボイス認識システム、マイクロホンなどのオーディオ入力デバイス、および/または他のタイプの入力デバイスを含むことができる。一般に、「入力デバイス」という用語の使用は、コンピュータシステム410内または通信ネットワーク上に情報を入力するための、可能なあらゆるタイプのデバイスおよび方途を含むことが意図されている。
【0047】
ユーザインターフェース出力デバイス420は、ディスプレイサブシステム、プリンタ、ファックス装置、またはオーディオ出力デバイスなどの非視覚的ディスプレイを含むことができる。ディスプレイサブシステムは、陰極線管(CRT)、液晶ディスプレイ(LCD)などのフラットパネルデバイス、投影デバイス、または可視画像を生み出すための他の何らかの機構を含むことができる。ディスプレイサブシステムは、オーディオ出力デバイスを介するなどして、非視覚的ディスプレイを提供することもできる。一般に、「出力デバイス」という用語の使用は、コンピュータシステム410からユーザに、または別のマシンもしくはコンピュータシステムに情報を出力するための、可能なあらゆるタイプのデバイスおよび方途を含むことが意図されている。
【0048】
ストレージサブシステム424は、本明細書において説明したモジュールの一部または全てのモジュールの機能を提供するプログラミング構造およびデータ構造を記憶する。例えば、ストレージサブシステム424は、方法300の選択された態様を実施するための、かつ/あるいはシステム200、コンピューティングデバイス104、ならびに/または本明細書において論じた他の任意のアプリケーション、デバイス、装置、および/もしくはモジュールのうちの1つまたは複数を実装するための、ロジックを含むことができる。
【0049】
これらのソフトウェアモジュールは一般に、プロセッサ414単独で、または他のプロセッサとの組合せによって実行される。ストレージサブシステム424内で使用されるメモリ425は、プログラム実行中の命令およびデータを記憶するためのメインランダムアクセスメモリ(RAM)430と、固定の命令が記憶される読出し専用メモリ(ROM)432とを含む、いくつかのメモリを含むことができる。ファイルストレージサブシステム426は、プログラムファイルおよびデータファイルのための永続ストレージを提供することができ、ハードディスクドライブ、フロッピーディスクドライブおよび関連するリムーバブルメディア、CD-ROMドライブ、光学式ドライブ、またはリムーバブルメディアカートリッジを含むことができる。特定の実装形態の機能を実装したモジュールは、ファイルストレージサブシステム426によって、ストレージサブシステム424内またはプロセッサ414によってアクセス可能な他のマシン内に記憶されることが可能である。
【0050】
バスサブシステム412は、コンピュータシステム410のさまざまなコンポーネントおよびサブシステムを意図したとおりに相互に通信させるための機構を提供する。バスサブシステム412は、単一のバスとして概略的に示されているが、バスサブシステムの代替実装形態では、複数のバスを使用することができる。
【0051】
コンピュータシステム410は、ワークステーション、サーバ、コンピューティングクラスタ、ブレードサーバ、サーバファーム、または他の任意のデータ処理システムもしくはコンピューティングデバイスを含む、さまざまなタイプのものとすることができる。コンピュータおよびネットワークの絶えず変化する性質のため、
図4に描いたコンピュータシステム410についての説明は、いくつかの実装形態を例示することを目的とした特定の一例として意図されているにすぎない。
図4に描いたコンピュータシステムよりも多くのまたは少ないコンポーネントを有する、コンピュータシステム410の他の多くの構成が可能である。
【0052】
本明細書において説明したシステムが、ユーザ(もしくは本明細書においてしばしば言及されるように、「参加者」)についての個人情報を収集するか、または個人情報を使用できる状況下では、ユーザは、プログラムまたは機能がユーザ情報(例えばユーザのソーシャルネットワーク、社会的行為もしくは社会的活動、職業、ユーザの嗜好、またはユーザの現在の地理的位置についての情報)を収集するかどうかを制御する機会、あるいはコンテンツサーバからユーザにとってより関連のあり得るコンテンツを受け取るかどうか、かつ/またはどのように受け取るかを制御する機会を与えられてよい。また、特定のデータが、それが記憶または使用される前に、個人を識別可能な情報が取り除かれるように、1つまたは複数の方途で取り扱われてよい。例えば、ユーザの識別情報が、そのユーザにとって個人を識別可能な情報を特定することができないように取り扱われてよく、または地理的位置情報が取得される場合、ユーザの具体的な地理的位置を特定することができないように、ユーザの地理的位置が(市レベル、郵便番号レベル、もしくは州レベルなどに)一般化されてよい。したがって、ユーザは、ユーザについてどのように情報が収集されかつ/または使用されるかに対して制御することができてよい。
【0053】
以上、いくつかの実装形態について、本明細書において説明し、図示してきたが、機能を実施するための、かつ/または結果および/もしくは本明細書において説明した利点のうちの1つもしくは複数を得るための、多様な他の手段および/または構造を利用することができ、そのような変形形態および/または修正形態はそれぞれ、本明細書において説明した実装形態の範囲内にあるものと見なされる。より一般には、本明細書において説明したあらゆるパラメータ、寸法、材料、および構成は、例示的であることが意図されており、実際のパラメータ、寸法、材料、および/または構成は、本教示が使用される1つまたは複数の特定の適用例に応じて決まる。当業者なら、本明細書において説明した特定の実装形態の多くの等価物を認識し、または通常の実験だけを使用してそれを確認することができるであろう。したがって、前述の実装形態は、ほんの一例として提示されたものであること、また添付の特許請求の範囲およびその等価物の範囲内で、具体的に説明し特許請求した以外の方法でも実装形態を実施できることを理解されたい。本開示の実装形態は、本明細書において説明した各個別の特徴、システム、物品、材料、用具一式、および/または方法を対象とする。加えて、2つ以上のそのような特徴、システム、物品、材料、用具一式、および/または方法のどんな組合せも、そのような特徴、システム、物品、材料、用具一式、および/または方法が相互に矛盾しない場合、本開示の範囲内に含まれる。
【0054】
いくつかの実装形態では、1つまたは複数のプロセッサによって実装される方法が、コンピューティングデバイスにおいて、ユーザから、コンピューティングデバイスを介してアクセス可能な自動アシスタントに向けられた口頭発話を受け取ることであって、コンピューティングデバイスが、口頭発話が受け取られたときにアプリケーションの検索結果インターフェースをレンダリングしているディスプレイインターフェースを含む、受け取ることなどの動作を含むものとして記載される。方法は、口頭発話に基づいて、検索結果インターフェースの1つまたは複数のフィルタ設定のうちに含まれない特定のフィルタ設定をユーザが特定したかどうかを判定することという動作をさらに含むことができる。方法は、1つまたは複数のフィルタ設定のうちに含まれない特定のフィルタ設定をユーザが特定したと自動アシスタントが判定したとき、検索結果インターフェースのアプリケーションコンテンツおよび口頭発話に基づくアプリケーション入力を生成すること、ならびにアプリケーションにアプリケーション入力に基づいて検索動作の実施を初期化させることという動作をさらに含むことができる。
【0055】
いくつかの実装形態では、アプリケーション入力が、特定のフィルタ設定、および検索結果インターフェースにおいてレンダリングされているアプリケーションコンテンツに対応する1つまたは複数の検索語を特定する。いくつかの実装形態では、アプリケーション入力が、口頭発話内に含まれる1つまたは複数の語、およびアプリケーションコンテンツを検索結果インターフェースにおいてレンダリングさせるためにアプリケーションに以前にサブミットされた1つまたは複数の検索語を含む。いくつかの実装形態では、方法は、1つまたは複数のフィルタ設定のうちに含まれる特定のフィルタ設定をユーザが特定したと自動アシスタントが判定したとき、アプリケーションの特定のフィルタ設定をユーザからの口頭発話に従って変更させることであって、特定のフィルタ設定を変更することにより、別のアプリケーションコンテンツが検索結果インターフェースにおいてレンダリングされる、変更させることという動作をさらに含むことができる。いくつかの実装形態では、アプリケーションにアプリケーション入力に基づいて検索動作の実施を初期化させることが、アプリケーション入力を検索結果インターフェースの検索フィールドに組み込むことを含む。
【0056】
いくつかの実装形態では、検索結果インターフェースの1つまたは複数のフィルタ設定のうちに含まれない特定のフィルタ設定をユーザが特定したかどうかを判定することが、上記アプリケーションまたは別のアプリケーションによって以前にレンダリングされた1つまたは複数の検索インターフェースに基づくアシスタントデータを処理することを含む。いくつかの実装形態では、方法は、1つまたは複数のフィルタ設定のうちに含まれない特定のフィルタ設定をユーザが特定したと自動アシスタントが判定したとき、検索結果インターフェースの1つまたは複数のフィルタ設定の各フィルタ設定のそれぞれの状態を決定することであって、アプリケーション入力が、検索結果インターフェースの1つまたは複数のフィルタ設定の各フィルタ設定のそれぞれの状態にさらに基づく、決定することという動作をさらに含むことができる。いくつかの実装形態では、アプリケーションにアプリケーション入力に基づいて検索動作の実施を初期化させることが、アプリケーションに、アプリケーションコンテンツの、1つまたは複数のフィルタ設定の各フィルタ設定のそれぞれの状態に従ってフィルタリングされたサブセットを、レンダリングさせることを含む。
【0057】
他の実装形態では、1つまたは複数のプロセッサによって実装される方法が、コンピューティングデバイスにおいて、ユーザから、自動アシスタントに自動アシスタントとは別個のものであるアプリケーションを使用した検索動作を初期化させることを促進するための口頭発話を受け取ることであって、口頭発話が1つまたは複数の語を特定する、受け取ることなどの動作を含むものとして記載される。方法は、口頭発話に基づいて、口頭発話の1つまたは複数の語が、アプリケーションのインターフェースにおいてレンダリングされた1つまたは複数の選択可能なグラフィカルユーザインターフェース(GUI)要素に関連するかどうかを判定することであって、1つまたは複数の選択可能なGUI要素がアプリケーションの検索特徴の1つまたは複数のフィルタパラメータを制御する、判定することという動作をさらに含むことができる。方法は、口頭発話の1つまたは複数の語が、アプリケーションのインターフェースにおいてレンダリングされた1つまたは複数の選択可能なGUI要素に対応するとき、1つまたは複数の選択可能なGUI要素のうちの1つまたは複数の特定の選択可能なGUI要素に、1つまたは複数の特定のフィルタパラメータを制御させること、およびアプリケーションに1つまたは複数の特定のフィルタパラメータに従って検索動作を初期化させることという動作をさらに含むことができる。
【0058】
いくつかの実装形態では、アプリケーションに検索動作を初期化させることが、アプリケーションの検索フィールドに、1つまたは複数の特定のフィルタパラメータを検索フィールドが含むことなく、口頭発話内で特定された1つまたは複数の語を含めさせることを含む。いくつかの実装形態では、方法は、口頭発話の1つまたは複数の語が、アプリケーションのインターフェースにおいてレンダリングされた1つまたは複数の選択可能なGUI要素に対応しないとき、1つまたは複数の特定のフィルタパラメータを特徴付けるアプリケーション入力を生成すること、およびアプリケーションに、アプリケーション入力を使用して検索動作を初期化させることという動作をさらに含むことができる。いくつかの実装形態では、アプリケーションに、アプリケーション入力を使用して検索動作を初期化させることが、アプリケーションの検索フィールドにアプリケーション入力を含めさせることであって、アプリケーション入力が1つまたは複数の特定のフィルタパラメータを特定する、含めさせることを含む。
【0059】
いくつかの実装形態では、アプリケーション入力が、1つまたは複数の特定のフィルタパラメータに基づいて選択される非英数文字を含む。いくつかの実装形態では、口頭発話が、アプリケーションを使用して特定のコンテンツを検索し、その後、その特定のコンテンツをユーザのためにレンダリングすることの自動アシスタントに対する要求を含む。いくつかの実装形態では、方法は、口頭発話の1つまたは複数の語が、アプリケーションのインターフェースにおいてレンダリングされた1つまたは複数の選択可能なGUI要素に対応しないとき、1つまたは複数の特定のフィルタパラメータを満足させる特定のアプリケーションコンテンツにアクセスすること、および特定のアプリケーションコンテンツにアクセスした後で、自動アシスタントに特定のアプリケーションコンテンツに基づく可聴コンテンツをレンダリングさせることという動作をさらに含むことができる。
【0060】
いくつかの実装形態では、方法は、口頭発話の1つまたは複数の語が、アプリケーションのインターフェースにおいてレンダリングされた1つまたは複数の選択可能なGUI要素に対応するとき、検索動作に基づいて、複数の異なる検索結果をアプリケーションの別のインターフェースにおいてレンダリングさせること、複数の異なる検索結果をレンダリングした後で、ユーザから追加の口頭発話を受け取ることであって、追加の口頭発話が、複数の異なる検索結果のサブセットを識別するための1つまたは複数の追加の語を特定する、受け取ること、および追加の口頭発話を受け取ったことに応答して、複数の異なる検索結果を1つまたは複数の追加の語に従ってフィルタリングさせることという動作をさらに含むことができる。いくつかの実装形態では、複数の異なる検索結果を1つまたは複数の追加の語に従ってフィルタリングさせることが、この別のインターフェースにおいてレンダリングされた1つまたは複数の他の選択可能なGUI要素が、1つまたは複数の追加の語に対応すると判定することと、1つまたは複数の他の選択可能なGUI要素を1つまたは複数の追加の語に従って選択することとを含む。
【0061】
いくつかの実装形態では、1つまたは複数のプロセッサによって実装される方法が、コンピューティングデバイスにおいて、アプリケーションのインターフェースを介してアクセス可能なアプリケーションコンテンツの検索を実施することの自動アシスタントに対する要求を含む口頭発話を受け取ることであって、口頭発話が、検索されるアプリケーションコンテンツに関連する1つまたは複数の語を特定する、受け取ることなどの動作を含むものとして記載される。方法は、口頭発話に基づいて、アプリケーションコンテンツを口頭発話内で特定された1つまたは複数の語に従ってフィルタリングするための1つまたは複数のフィルタリング特徴をアプリケーションが提供するかどうかを判定することという動作をさらに含むことができる。方法は、アプリケーションが1つまたは複数のフィルタリング特徴を提供しないと判定されたとき、1つまたは複数の語に基づいて、アプリケーションコンテンツの検索の実施を促進すべくアプリケーションにサブミットするための1つまたは複数のフィルタパラメータを識別すること、自動アシスタントに、アプリケーションへのアプリケーション入力を提供させることであって、アプリケーション入力が1つまたは複数のフィルタパラメータを特定する、提供させること、およびアプリケーション入力に基づいて、アプリケーションに検索結果をレンダリングさせることであって、検索結果が、アプリケーションコンテンツの、1つまたは複数のフィルタパラメータを満足させるサブセットを含む、レンダリングさせることという動作をさらに含むことができる。
【0062】
いくつかの実装形態では、1つまたは複数のフィルタリング特徴が、アプリケーションの1つまたは複数のフィルタリング動作を制御する1つまたは複数の選択可能なグラフィカルユーザインターフェース(GUI)要素を含む。いくつかの実装形態では、方法は、アプリケーションが1つまたは複数のフィルタリング特徴を提供しないと判定されたとき、1つまたは複数のフィルタパラメータに基づいて、1つまたは複数のフィルタパラメータに基づいて選択される1つまたは複数の非英数文字を識別することであって、アプリケーション入力が1つまたは複数の非英数文字を特定する、識別することという動作をさらに含むことができる。
【符号の説明】
【0063】
100 ビュー
102 ユーザ
104 コンピューティングデバイス
106 口頭発話
120 ビュー
122 検索フィールド
124 選択可能なGUI要素
126 検索結果
128 画像
130 選択可能なチェックボックス
132 アプリケーション
134 別の口頭発話
136 他の選択可能な要素
138 検索結果インターフェース
140 ビュー
142 検索結果
144 追加の口頭発話
146 フィルタ
148 検索語、検索フィールド
160 ビュー
162 フィルタリングされた検索結果、一番最近の検索結果
164 口頭発話
166 後続の口頭発話
200 システム
202 コンピューティングデバイス
204 自動アシスタント
206 入力処理エンジン
208 音声処理エンジン
210 データパーシングエンジン
212 パラメータエンジン
214 出力生成エンジン
216 フィルタ識別エンジン
218 入力語エンジン
220 アシスタントインターフェース
222 アシスタント呼出しエンジン
224 検索結果エンジン
226 検索入力エンジン
230 アプリケーションデータ
232 デバイスデータ
234 アプリケーション
236 コンテキストデータ
238 アシスタントデータ
300 方法
400 ブロック図
410 コンピュータシステム
412 バスサブシステム
414 プロセッサ
416 ネットワークインターフェースサブシステム
420 ユーザインターフェース出力デバイス
422 ユーザインターフェース入力デバイス
424 ストレージサブシステム
425 メモリ
426 ファイルストレージサブシステム
430 メインランダムアクセスメモリ(RAM)
432 読出し専用メモリ(ROM)
【国際調査報告】