(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-04-22
(45)【発行日】2024-05-01
(54)【発明の名称】画像拡張ニューラルネットワーク
(51)【国際特許分類】
G06T 1/40 20060101AFI20240423BHJP
G06N 3/094 20230101ALI20240423BHJP
【FI】
G06T1/40
G06N3/094
【外国語出願】
(21)【出願番号】P 2023068765
(22)【出願日】2023-04-19
(62)【分割の表示】P 2021558609の分割
【原出願日】2019-07-19
【審査請求日】2023-05-08
(32)【優先日】2019-05-24
(33)【優先権主張国・地域又は機関】US
(32)【優先日】2019-05-30
(33)【優先権主張国・地域又は機関】US
(73)【特許権者】
【識別番号】502208397
【氏名又は名称】グーグル エルエルシー
【氏名又は名称原語表記】Google LLC
【住所又は居所原語表記】1600 Amphitheatre Parkway 94043 Mountain View, CA U.S.A.
(74)【代理人】
【識別番号】100108453
【氏名又は名称】村山 靖彦
(74)【代理人】
【識別番号】100110364
【氏名又は名称】実広 信哉
(74)【代理人】
【識別番号】100133400
【氏名又は名称】阿部 達彦
(72)【発明者】
【氏名】ミカエル・ピエール・ボネヴィエ
(72)【発明者】
【氏名】アーロン・マシノ
(72)【発明者】
【氏名】アーロン・サルナ
(72)【発明者】
【氏名】シュチャオ・ビ
(72)【発明者】
【氏名】ジンビン・ワン
(72)【発明者】
【氏名】マイケル・スペンサー・クライニン
(72)【発明者】
【氏名】ウェンチャオ・トン
(72)【発明者】
【氏名】ディリップ・クリシュナン
(72)【発明者】
【氏名】ハイフェン・ゴン
(72)【発明者】
【氏名】ツァ・リュウ
(72)【発明者】
【氏名】ホセイン・ターレビー
(72)【発明者】
【氏名】ラーナン・サヤグ
(72)【発明者】
【氏名】ピョートル・テテルヴァク
【審査官】三沢 岳志
(56)【参考文献】
【文献】米国特許出願公開第2019/0147333(US,A1)
【文献】米国特許出願公開第2019/0122072(US,A1)
【文献】特開2019-079114(JP,A)
(58)【調査した分野】(Int.Cl.,DB名)
G06T 1/40
G06N 3/094
(57)【特許請求の範囲】
【請求項1】
1つまたは複数のコンピュータによって実行される方法であって、
(i)生成ニューラルネットワークを使用して生成した合成画像と、(ii)関連付けられたターゲット画像とを受信するステップと、
前記ターゲット画像の意味的特徴表現を生成するステップであって、
画像処理ニューラルネットワークを使用して前記ターゲット画像を処理するステップであって、前記画像処理ニューラルネットワークが、画像処理タスクを実行して、前記画像処理ニューラルネットワークの中間出力を生成するように訓練されている、ステップと、
前記画像処理ニューラルネットワークの前記中間出力に基づいて前記ターゲット画像の前記意味的特徴表現を決定するステップとを含む、ステップと、
弁別ニューラルネットワークを使用して前記合成画像を含む入力を処理し、前記生成ニューラルネットワークを使用して前記合成画像が生成された可能性を定義する弁別出力を生成するステップとを備え、
前記弁別ニューラルネットワークが、前記ターゲット画像の前記意味的特徴表現に条件付けされている、方法。
【請求項2】
前記合成画像は、動作によって生成されており、該動作は、
前記ターゲット画像の一部をマスクすることによってマスクされた画像を生成することと、
前記生成ニューラルネットワークを使用して前記マスクされた画像を含むネットワーク入力を処理し、前記合成画像を生成することと
を含む、請求項1に記載の方法。
【請求項3】
前記弁別ニューラルネットワークへの前記入力は、前記ターゲット画像のマスクされた部分を識別するマスク画像をさらに含む、請求項2に記載の方法。
【請求項4】
前記画像処理ニューラルネットワークの前記中間出力に基づいて前記ターゲット画像の前記意味的特徴表現を決定するステップは、
前記画像処理ニューラルネットワークの前記中間出力を正規化するステップを含む、請求項1に記載の方法。
【請求項5】
前記画像処理ニューラルネットワークの前記中間出力が、前記画像処理ニューラルネットワークの1つまたは複数の隠れ層によって生成された出力を含む、請求項1に記載の方法。
【請求項6】
前記画像処理ニューラルネットワークは、画像分類タスクを実行するように訓練されている、請求項1に記載の方法。
【請求項7】
前記弁別ニューラルネットワークへの前記入力は、前記合成画像と前記ターゲット画像の前記意味的特徴表現との両方を含む、請求項1に記載の方法。
【請求項8】
前記弁別ニューラルネットワークを使用して前記合成画像を含む入力を処理し、前記弁別出力を生成するステップは、
前記弁別ニューラルネットワークを使用して前記合成画像を含む前記入力を処理し、前記弁別ニューラルネットワークの最終層によって第1の弁別出力を生成するステップと、
(i)前記弁別ニューラルネットワークの中間出力と、(ii)前記ターゲット画像の前記意味的特徴表現とを処理し、第2の弁別出力を生成するステップと、
前記第1の弁別出力と前記第2の弁別出力を組み合わせることによって前記弁別出力を生成するステップと
を含む、請求項1に記載の方法。
【請求項9】
前記第1の弁別出力と前記第2の弁別出力を組み合わせることは、
前記第1の弁別出力と前記第2の弁別出力を合計することを含む、請求項8に記載の方法。
【請求項10】
1つまたは複数のコンピュータと、
前記1つまたは複数のコンピュータに通信可能に結合された1つまたは複数の記憶デバイスとを備えたシステムであって、
前記1つまたは複数の記憶デバイスは、前記1つまたは複数のコンピュータによって実行されると、前記1つまたは複数のコンピュータに動作を実行させる命令を記憶し、前記動作は、
(i)生成ニューラルネットワークを使用して生成した合成画像と、(ii)関連付けられたターゲット画像とを受信する動作と、
前記ターゲット画像の意味的特徴表現を生成する動作であって、
画像処理ニューラルネットワークを使用して前記ターゲット画像を処理する動作であって、前記画像処理ニューラルネットワークが、画像処理タスクを実行して、前記画像処理ニューラルネットワークの中間出力を生成するように訓練されている、動作と、
前記画像処理ニューラルネットワークの前記中間出力に基づいて前記ターゲット画像の前記意味的特徴表現を決定する動作とを含む、動作と、
弁別ニューラルネットワークを使用して前記合成画像を含む入力を処理し、前記生成ニューラルネットワークを使用して前記合成画像が生成された可能性を定義する弁別出力を生成する動作とを備え、
前記弁別ニューラルネットワークが、前記ターゲット画像の前記意味的特徴表現に条件付けされている、システム。
【請求項11】
前記合成画像は、動作によって生成されており、該動作は、
前記ターゲット画像の一部をマスクすることによってマスクされた画像を生成することと、
前記生成ニューラルネットワークを使用して前記マスクされた画像を含むネットワーク入力を処理し、前記合成画像を生成することと
を含む、請求項10に記載のシステム。
【請求項12】
前記弁別ニューラルネットワークへの前記入力は、前記ターゲット画像のマスクされた部分を識別するマスク画像をさらに含む、請求項11に記載のシステム。
【請求項13】
前記画像処理ニューラルネットワークの前記中間出力に基づいて前記ターゲット画像の前記意味的特徴表現を決定する動作は、
前記画像処理ニューラルネットワークの前記中間出力を正規化する動作を含む、請求項10に記載のシステム。
【請求項14】
前記画像処理ニューラルネットワークの前記中間出力が、前記画像処理ニューラルネットワークの1つまたは複数の隠れ層によって生成された出力を含む、請求項10に記載のシステム。
【請求項15】
前記画像処理ニューラルネットワークは、画像分類タスクを実行するように訓練されている、請求項10に記載のシステム。
【請求項16】
前記弁別ニューラルネットワークへの前記入力は、前記合成画像と前記ターゲット画像の前記意味的特徴表現との両方を含む、請求項10に記載のシステム。
【請求項17】
前記弁別ニューラルネットワークを使用して前記合成画像を含む入力を処理し、前記弁別出力を生成する動作は、
前記弁別ニューラルネットワークを使用して前記合成画像を含む前記入力を処理し、前記弁別ニューラルネットワークの最終層によって第1の弁別出力を生成する動作と、
(i)前記弁別ニューラルネットワークの中間出力と、(ii)前記ターゲット画像の前記意味的特徴表現とを処理し、第2の弁別出力を生成する動作と、
前記第1の弁別出力と前記第2の弁別出力を組み合わせることによって前記弁別出力を生成する動作と
を含む、請求項10に記載のシステム。
【請求項18】
前記第1の弁別出力と前記第2の弁別出力を組み合わせることは、
前記第1の弁別出力と前記第2の弁別出力を合計することを含む、請求項17に記載のシステム。
【請求項19】
1つまたは複数のコンピュータによって実行されると、前記1つまたは複数のコンピュータに動作を実行させる命令を記憶した1つまたは複数の非一時的コンピュータ記憶媒体であって、前記動作は、
(i)生成ニューラルネットワークを使用して生成した合成画像と、(ii)関連付けられたターゲット画像とを受信する動作と、
前記ターゲット画像の意味的特徴表現を生成する動作であって、
画像処理ニューラルネットワークを使用して前記ターゲット画像を処理する動作であって、前記画像処理ニューラルネットワークが、画像処理タスクを実行して、前記画像処理ニューラルネットワークの中間出力を生成するように訓練されている、動作と、
前記画像処理ニューラルネットワークの前記中間出力に基づいて前記ターゲット画像の前記意味的特徴表現を決定する動作とを含む、動作と、
弁別ニューラルネットワークを使用して前記合成画像を含む入力を処理し、前記生成ニューラルネットワークを使用して前記合成画像が生成された可能性を定義する弁別出力を生成する動作とを備え、
前記弁別ニューラルネットワークが、前記ターゲット画像の前記意味的特徴表現に条件付けされている、非一時的コンピュータ記憶媒体。
【請求項20】
前記合成画像は、動作によって生成されており、該動作は、
前記ターゲット画像の一部をマスクすることによってマスクされた画像を生成することと、
前記生成ニューラルネットワークを使用して前記マスクされた画像を含むネットワーク入力を処理し、前記合成画像を生成することと
を含む、請求項19に記載の非一時的コンピュータ記憶媒体。
【発明の詳細な説明】
【技術分野】
【0001】
本明細書は、機械学習モデルを使用して画像を処理することに関する。
【背景技術】
【0002】
機械学習モデルは、入力を受信し、受信された入力に基づいて、出力、たとえば予測出力を生成する。いくつかの機械学習モデルは、パラメトリックモデルであり、受信した入力およびモデルのパラメータの値に基づいて出力を生成する。
【0003】
いくつかの機械学習モデルは、受信された入力のための出力を生成するためにモデルの複数の層を使用するディープモデルである。たとえば、ディープニューラルネットワークは、出力層と、出力を生成するために受信された入力に変換を各々適用する1つまたは複数の隠れ層とを含むディープ機械学習モデルである。
【発明の概要】
【課題を解決するための手段】
【0004】
本明細書は、画像拡張を実行する1つまたは複数の位置にある1つまたは複数のコンピュータ上のコンピュータプログラムとして実装されるシステムについて説明する。
【0005】
第1の態様によれば、1つまたは複数のデータ処理装置によって実行される方法が提供され、この方法は、複数の生成ニューラルネットワークパラメータを有する生成ニューラルネットワーク(generative neural network)に、提供された画像を含む入力を提供するステップを含み、生成ニューラルネットワークは、拡張画像を生成するために、複数の生成ニューラルネットワークパラメータの訓練された値に従って入力を処理し、拡張画像は、(i)提供された画像よりも多くの行、多くの列、または両方を有し、(ii)提供された画像の現実的な拡張であると予測され、生成ニューラルネットワークは、敵対的損失目的関数を使用して訓練されている。
【0006】
このようにして、追加の行および/または列は、提供された画像の元の境界のうちの1つまたは複数を越える拡張を提供し、たとえば、提供された画像の高レベルの意味的特性ならびに低レベルの構造およびテクスチャを維持するなど、提供された画像の予測された現実的な拡張を提供する。
【0007】
この方法は、ブロック内に提示される画像の要求を受信するステップと、提供された画像が要求に応答していると決定するステップと、拡張画像を生成した後、要求に応答して拡張画像を提供するステップとを含み得る。
【0008】
この方法は、ブロックのサイズが、提供された画像のサイズとは異なることに基づいて、提供された画像が画像拡張に適格であると決定し、それに応答して、提供された画像を含む入力を生成ニューラルネットワークに提供するステップを含み得る。
【0009】
ブロックのサイズは、ブロックのアスペクト比を指定し得る。
【0010】
要求は、ブロック内の画像とともに提示される追加要素を指定してもよく、要求に応答して拡張画像を提供するステップは、拡張画像の拡張部分上に追加要素をオーバーレイするステップを含み得る。
【0011】
ブロックは、検索結果と一緒に、またはサードパーティウェブページ上に提示されてもよい。
【0012】
生成ニューラルネットワークは、複数の畳み込みニューラルネットワーク層を含み得る。
【0013】
生成ニューラルネットワークは、複数のスキップ接続を含み得る。
【0014】
生成ニューラルネットワークは、複数のインスタンス正規化層を含み得る。
【0015】
生成ニューラルネットワークへの入力は、拡張画像と同じ数の行および列を有するベースライン画像であり、(i)提供された画像に対応する第1の部分、および(ii)デフォルトの画素値を有する第2の部分を含む、ベースライン画像と、拡張画像と同じ数の行および列を有するマスク画像であり、ベースライン画像の第1の部分および第2の部分を識別する、マスク画像とを含み得る。
【0016】
ベースライン画像の第1の部分に対応するマスク画像内の画素は各々、第1の画素値を有し、ベースライン画像の第2の部分に対応するマスク画像内の画素は各々、第1の画素値とは異なる第2の画素値を有し得る。
【0017】
生成ニューラルネットワークは、生成ニューラルネットワークを使用して所与の画像が生成された可能性を特徴付ける弁別出力を生成するために、所与の画像を処理するように構成された複数の弁別ニューラルネットワークパラメータを有する弁別ニューラルネットワーク(discriminative neural network)と共同で訓練され得る。
【0018】
敵対的損失目的関数を使用して生成ニューラルネットワークを訓練するステップは、訓練画像を拡張する訓練拡張画像を生成するために、生成ニューラルネットワークを使用し、生成ニューラルネットワークパラメータの現在の値に従って、訓練画像を含む訓練入力を処理するステップと、訓練拡張画像に基づいて弁別ニューラルネットワーク入力を生成するステップと、生成ニューラルネットワークを使用して弁別ニューラルネットワーク入力が生成された可能性を特徴付ける弁別出力を生成するために、弁別ニューラルネットワークを使用し、弁別ニューラルネットワークパラメータの現在の値に従って、弁別ニューラルネットワーク入力を処理するステップと、敵対的損失目的関数に基づいて生成ニューラルネットワークパラメータの現在値を調整するステップであり、敵対的損失目的関数は、生成ニューラルネットワークを使用して弁別ニューラルネットワーク入力が生成された可能性を特徴付ける弁別出力に依存する、調整するステップと含み得る。
【0019】
訓練拡張画像に基づいて弁別ニューラルネットワーク入力を生成するステップは、訓練画像に対応する訓練拡張画像の一部を訓練画像で上書きするステップを含み得る。
【0020】
この方法は、訓練拡張画像とターゲット画像との類似性を特徴付ける再構成損失目的関数に基づいて、生成ニューラルネットワークパラメータの現在値を調整するステップであり、訓練画像は、ターゲット画像のクロッピングされた表現である、調整するステップを含み得る。
【0021】
弁別ニューラルネットワークは、ターゲット画像の意味的特徴表現を条件とし、訓練画像は、ターゲット画像のクロッピングされた表現である。
【0022】
ターゲット画像の意味的特徴表現は、ターゲット画像を処理することによって、分類ニューラルネットワークの中間出力を使用して決定され得る。
【0023】
弁別出力は、(i)弁別ニューラルネットワークの最終層の出力、および(ii)弁別ニューラルネットワークの中間出力とターゲット画像の意味的特徴表現との間の類似性尺度に基づき得る。
【0024】
別の態様によれば、1つまたは複数のコンピュータと、1つまたは複数のコンピュータによって実行されると、1つまたは複数のコンピュータに、第1の態様のそれぞれの方法の動作を実行させる命令を記憶する1つまたは複数の記憶デバイスとを備えるシステムが提供される。
【0025】
別の態様によれば、1つまたは複数のコンピュータによって実行されると、1つまたは複数のコンピュータに、第1の態様のそれぞれの方法の動作を実行させる命令を記憶する1つまたは複数のコンピュータ記憶媒体が提供される。
【0026】
一態様の随意の特徴を、必要に応じて別のものと組み合わせてもよい。本明細書に記載される主題の特定の実施形態は、以下の利点のうちの1つまたは複数を実現するように実施することができる。
【0027】
本明細書に記載される画像拡張システムは、生成ニューラルネットワークを使用して、(たとえば、元の境界を越えて入力画像を拡張する)拡張画像を生成し得る。生成ニューラルネットワークは、入力画像が(i)「実」画像であるか、(ii)生成ニューラルネットワークによって生成された拡張画像であるかの予測を定義する出力を生成するために、入力画像を処理するように構成された「弁別」ニューラルネットワークと共同で訓練される。生成ニューラルネットワークと弁別ニューラルネットワークとの共同訓練を容易にするために、システムは、弁別ニューラルネットワークによって処理される入力画像に対応する意味的特徴について弁別ニューラルネットワークを条件付けることができる。このように弁別ニューラルネットワークを条件付けることにより、より少ない訓練反復にわたって許容可能なパフォーマンスレベルを達成するようにシステムを訓練することが可能になり、それによって、システムは、訓練中に、いくつかの従来のシステムよりも少ない計算リソース(たとえば、メモリおよび計算能力)を消費することが可能になる。
【0028】
いくつかの従来のインペインティングシステムは、元の画像データによってすべての方向において囲まれた画像の一部を「埋める」。対照的に、本明細書に記載される画像拡張システムは、その元の境界を越えて画像を拡張して、画像の高レベルの意味的特性ならびに低レベルの画像構造およびテクスチャを拡張する拡張画像を生成する。画像拡張タスクを実行するために従来のインペインティングシステムを直接適用することは、いくつかの場合には、本明細書に記載される画像拡張システムによって生成されるものよりも低品質の拡張画像をもたらす可能性がある。たとえば、従来のインペインティングシステムは、ぼやけたまたは反復的な画素および一貫性のないセマンティクスを有する拡張画像を生成することができるが、現在説明されている画像拡張システムによって生成される拡張画像は、同じぼやけた、反復的な画素、または一貫性のない意味的特性を有さない。
【0029】
本明細書に記載される画像拡張システムは、様々な用途、たとえば、仮想現実の用途、計算写真の用途、およびデジタルコンポーネント配信の用途のいずれかに使用することができる拡張画像を生成する。デジタルコンポーネント配信の用途では、デジタルコンポーネント配信システムは、たとえば、検索結果と一緒に、またはサードパーティウェブページ上に、ブロックで提示するためにデジタルコンポーネントを送信する。いくつかの場合には、デジタルコンポーネントに含まれる画像は、たとえば、画像とブロックのアスペクト比が異なるために、画像が定義されたブロックを満たすことを妨げるサイズを有することがある。この状況では、本明細書に記載される画像拡張システムは、画像がブロックを満たすことができるように、画像をサイズ変更するために使用することができ、それによって、リソースのより効率的な使用(特に、ブロック内で利用可能なスペースのより効率的な使用)を可能にし、ユーザインターフェース内のブランクスポットおよび/または歪んだ画像の提示を防止することができる。言い換えれば、本出願で説明されるシステムは、画像の「フィルイン」だけでなく、その境界を越えた画像の拡張も可能にし、これにより、単一の画像サイズのみが利用可能であるときでも、複数の異なるサイズのブロックに適合するように画像を修正することが可能になる。これは、元の画像の特徴を保持しながら、単一の画像を様々なサイズのブロックに適合するように修正することができるので、記憶する必要がある画像の数を低減する。画像拡張システムは、画像がブロックを満たすように画像のアスペクト比を変更するために、ある寸法に沿って画像を伸張または圧縮することによって、画像を歪める必要性をなくすことができる。さらに、デジタルコンポーネント配信の用途では、いくつかのデジタルコンポーネントプロバイダは、デジタルコンポーネントに含まれる画像が歪むことなく(たとえば、ある寸法に沿って伸張または圧縮されることによって)提示されることを必要とする場合がある。
【0030】
本明細書の主題の1つまたは複数の実施形態の詳細は、添付の図面および以下の説明に記載される。主題の他の特徴、態様、および利点は、説明、図面、および特許請求の範囲から明らかになるであろう。
【図面の簡単な説明】
【0031】
【
図2】敵対的損失目的関数を使用して、弁別ニューラルネットワークと共同で生成ニューラルネットワークを訓練するための例示的なデータフローを示す図である。
【
図3】画像拡張システムによって生成される拡張画像の一例を示す図である。
【
図4】デジタルコンポーネント配信システムが画像拡張システムを使用する例示的な環境のブロック図である。
【
図5】画像拡張システムを使用してデジタルコンポーネントに含まれる画像が拡張された、ユーザデバイスの画面上に表示されているデジタルコンポーネントを示す図である。
【
図6】画像拡張システムを使用してデジタルコンポーネントに含まれる画像が拡張された、「バナー」ブロックに表示されているデジタルコンポーネントを示す図である。
【
図7】デジタルコンポーネント配信システムによる送信のためにデジタルコンポーネントを提供するエンティティに提示することができる例示的なユーザインターフェースの図である。
【
図8】要求に応答して拡張画像を提供するための例示的なプロセスのフロー図である。
【
図9】例示的なコンピュータシステムのブロック図である。
【発明を実施するための形態】
【0032】
様々な図面における同様の参照番号および名称は、同様の要素を示す。
【0033】
本明細書は、その元の境界を越えて画像を現実的に拡張する、たとえば、画像の高レベルの意味的特性ならびに低レベルの構造およびテクスチャを維持しながら、その元の境界を越えて画像を拡張する「拡張」画像を生成するために画像を処理する技術について説明する。そのような処理は、画像強調に使用することができる。たとえば、画像が配置されるブロックに一致しない寸法を画像が有する場合、画像寸法は、元の画像内のコンテンツの特性を維持しながら、ブロックに一致するように拡大されてもよい。別の例では、画像の一部が欠落しているなど、画像が損傷している場合、本開示の態様を使用して、欠落部分を自動的に生成し得る。たとえば、不適切にキャプチャされた、または不完全な損傷画像のキャプチャされたバージョンは、本明細書で説明する技法により再生成することができる。
【0034】
画像を拡張するために、本明細書に記載される画像拡張システムは、対応する拡張画像を生成するために敵対的損失目的関数を使用して訓練される生成ニューラルネットワークを使用して画像を処理する。敵対的損失目的関数は、拡張画像を処理することによって、弁別ニューラルネットワークによって生成された出力に基づいて、生成ニューラルネットワークを使用して生成された拡張画像を評価する。弁別ニューラルネットワークは、入力画像が(i)「実」(すなわち、自然)画像であるか、(ii)生成ニューラルネットワークを使用して生成された拡張画像であるかを予測するように訓練される。生成ニューラルネットワークおよび弁別ニューラルネットワークを共同で訓練することにより、実画像と区別することが困難な拡張画像を生成することを、画像拡張システムに促す。
【0035】
画像拡張システムは、たとえば、画像が歪むことなくブロックを満たすことを可能にするために、様々な寸法の定義されたブロックで提示されるデジタルコンポーネントに含まれる画像をサイズ変更するなど、様々な用途のいずれにも使用することができる。
【0036】
本明細書全体にわたって使用されるように、デジタルコンポーネントという語句は、たとえば、画像、ビデオクリップ、オーディオクリップ、マルチメディアクリップ、テキストセグメント、またはユニフォームリソースロケータ(URL)のうちの1つまたは複数を含むことができるデジタルコンテンツまたはデジタル情報の個別ユニットを指す。デジタルコンポーネントは、単一のファイルとして、またはファイルの集合として物理メモリデバイスに電子的に記憶することができ、デジタルコンポーネントは、ビデオファイル、オーディオファイル、マルチメディアファイル、画像ファイル、またはテキストファイルの形態をとり、ストリーミングビデオ、ストリーミングオーディオ、ソーシャルネットワークポスト、ブログポスト、および/または広告情報を含むことができ、したがって、広告は、デジタルコンポーネントの一種である。一般に、デジタルコンポーネントは、単一のプロバイダまたはソース(たとえば、広告主、発行者、または他のコンテンツプロバイダ)によって定義される(または提供される)が、1つのソースから提供されるデジタルコンポーネントは、別のソースからのデータ(たとえば、気象情報、リアルタイムイベント情報、または別のソースから取得される他の情報)により強化され得る。
【0037】
これらの特徴および他の特徴について、以下でより詳細に説明する。
【0038】
図1は、例示的な画像拡張システム100を示す。画像拡張システム100は、以下で説明するシステム、コンポーネント、および技法が実装される1つまたは複数の位置にある1つまたは複数のコンピュータ上のコンピュータプログラムとして実装されるシステムの一例である。
【0039】
画像拡張システム100は、その元の境界を越えて画像102を現実的に拡張する拡張画像104を生成するために、画像102を処理するように構成される。より具体的には、拡張画像104を表す画素の2次元(2D)アレイは、一般に、画像102よりも多くの行、多くの列、または両方を有する。
図1に示す例では、拡張画像104は、元の画像102と比較してその右側に1つまたは複数の追加の列106を有する。特定の例では、画像102は、100×100次元であってもよく、拡張画像104は、100×120次元であってもよい。別の特定の例では、画像102は、80×120次元であってもよく、拡張画像は、90×125次元であってもよい。次元の単位は、画素の数など、任意の適切な単位であってもよい。システム100を使用して生成された拡張画像の一例を
図3に示す。
【0040】
いくつかの場合には、拡張画像104を生成する前に、画像拡張システム100は、元の画像102を均一に縮小または拡大し得る(すなわち、そのアスペクト比を維持し、それによって歪みを回避しながら)。特定の例では、次元100×200を有する入力画像から次元50×120を有する出力画像を生成するために、画像拡張システムは、まず、入力画像を次元50×100に一様に縮小し、次いで、次元50×100の縮小された画像から次元50×120を有する拡張画像を生成し得る。
【0041】
画像102(および拡張画像104)は、任意の適切なフォーマットで、たとえば、各々が対応するグレースケール強度または適切な色空間内の画素の色を表す色ベクトルに関連付けられた画素の2Dアレイとして表すことができる。色空間は、たとえば、赤緑青(RGB)色空間またはCIELAB色空間であってもよい。
【0042】
拡張画像104を生成するために、システム100は、画像102から生成ネットワーク入力108を決定し、生成ニューラルネットワーク110を使用して生成ネットワーク入力108を処理する。生成ネットワーク入力のいくつかの例を以下に示す。
【0043】
一例では、生成ネットワーク入力108は、両方とも生成ニューラルネットワーク110によって生成される拡張画像と同じ次元(すなわち、行および列の数)を有するベースライン画像112およびマスク画像114を含む。ベースライン画像112は、(i)画像102に対応する第1の部分112-A、および(ii)デフォルトの画素値(たとえば、黒または白の画素値)を有する第2の部分112-Bを含む。すなわち、ベースライン画像112は、画像102を含み、デフォルトの画素値の1つまたは複数の行または列だけ画像102を拡張すると理解することができる。マスク画像114は、ベースライン画像のどの部分が、(i)画像102、および(ii)デフォルトの画素値に対応するかを識別する。たとえば、画像102に一致するベースライン画像112の適切なサブセットに対応するマスク画像114内の画素は、第1の値(たとえば、値0)を有してもよく、マスク画像114内の残りの画素は、第2の値(たとえば、値1)を有してもよい。この例では、ベースライン画像112およびマスク画像114は、生成ネットワーク入力108を形成するために、チャネルごとに空間的に連結されてもよい。
【0044】
別の例では、生成ネットワーク入力108は、すなわち、マスク画像114を含まず、ベースライン画像112のみを含み得る。
【0045】
別の例では、生成ネットワーク入力108は、すなわち、ベースライン画像112またはマスク画像114のいずれも含まず、画像102に直接対応し得る。
【0046】
生成ニューラルネットワーク110は、拡張画像104を生成するために、生成ニューラルネットワークパラメータのセットの訓練された値に従って生成ネットワーク入力108を処理するように構成される。生成ニューラルネットワーク110は、一般に、畳み込みニューラルネットワークアーキテクチャ、すなわち、1つまたは複数の畳み込みニューラルネットワーク層(および随意に、他の適切な種類のニューラルネットワーク層)を含むニューラルネットワークアーキテクチャを有する。
【0047】
敵対的訓練システム116は、生成ニューラルネットワーク110が現実的な拡張画像104を生成することを可能にする生成ニューラルネットワークパラメータの訓練された値を決定するように構成される。敵対的訓練システム116は、
図2を参照してより詳細に説明するように、敵対的損失目的関数を使用して、弁別ニューラルネットワークとともに生成的ニューラルネットワーク110を共同で訓練する。
【0048】
いくつかの場合には、システム100は、元の画像を繰り返し拡張することによって「パノラマ」拡張画像を作成することができる。たとえば、システム100は、元の画像を拡張して第1の拡張画像を生成し、次いで、第1の拡張画像のクロッピングされた部分を拡張して第2の拡張画像を生成することなどが可能である。最後に、システムは、拡張画像を連結して、たとえば、2×、3×、5×、または任意の他の適切な係数だけ、元の画像を実質的に拡張するパノラマ画像を生成することができる。
【0049】
システム100によって生成された拡張画像104は、様々な用途のいずれかで使用することができる。いくつかの例を以下に示す。
【0050】
一例では、バーチャルリアリティの用途では、元の画像をキャプチャするために実際に使用されたのとは異なるカメラの向きからキャプチャされた画像をシミュレートする必要がある場合がある。画像拡張システム100は、元の画像の境界の外側のコンテンツを埋めることによって、このように画像をシミュレートするために使用することができる。
【0051】
別の例では、パノラマステッチングの用途(たとえば、複数の画像が、単一の合成された画像を生成するために一緒に「スティッチ」される)では、いくつかの従来の技法は、長方形のパノラマを達成するために、スティッチされた投影のギザギザのエッジをクロッピングすることを必要とする。画像拡張システム100は、代わりに、ギザギザのエッジ間のギャップを埋める拡張画像を生成することによって、ギザギザのエッジをクロップする必要をなくすことができ、それによって、より効果的なパノラマステッチングを可能にする。
【0052】
別の例では、画像拡張システム100を使用して、あるアスペクト比でキャプチャされ撮られたビデオを、伸張またはクロッピングに頼ることなく、異なるアスペクト比で画面上に表示することができる。特に、画像拡張システム100を使用して、ビデオ内の各ビデオフレームを処理して、たとえば、ビデオが表示される画面と同じアスペクト比を有する、対応する拡張ビデオフレームを生成することができる。
【0053】
別の例では、画像拡張システム100は、デジタルコンポーネント配信システムによって、検索結果と一緒に、またはサードパーティウェブサイト上に、定義されたブロックで表示される画像を拡張して、伸張またはクロッピングに頼ることなく、画像がブロックを満たすことを可能にするために使用することができる。デジタルコンポーネント配信システムの一部として画像拡張システム100を使用することについて、
図4を参照してより詳細に説明する。
【0054】
図2は、敵対的損失目的関数204を使用して、生成ニューラルネットワーク110を弁別ニューラルネットワーク202と共同で訓練するために敵対的訓練システム116によって実行され得る動作を示す例示的なデータフロー200である。一般に、生成ニューラルネットワーク110は、入力画像を現実的に拡張する拡張画像を生成するように訓練され、弁別ニューラルネットワーク202は、(すなわち、自然画像とは対照的に)生成ニューラルネットワーク110を使用して入力画像が生成された可能性を特徴付ける弁別出力を生成するように訓練される。次に、生成ニューラルネットワーク110の訓練について詳細に説明し、その後、弁別ニューラルネットワーク202の訓練について説明する。
【0055】
生成ニューラルネットワーク110は、複数の訓練反復にわたって訓練され、各訓練反復において、生成ニューラルネットワークパラメータの現在のパラメータ値は、訓練例の現在のバッチ(すなわち、セット)に基づいて調整される。各訓練例は、(i)訓練生成ネットワーク入力、および(ii)対応する訓練生成ネットワーク入力を処理することによって生成ニューラルネットワーク110によって生成されるべきターゲット拡張画像を含む。
【0056】
訓練例に含まれるターゲット拡張画像206は、一般に、実(すなわち、自然)画像である。ターゲット拡張画像206に対応する訓練生成ネットワーク入力は、
図1を参照して説明したように、様々な方法のいずれかで表すことができる。一例では、ターゲット拡張画像206に対応する訓練生成ネットワーク入力は、ベースライン画像208およびマスク画像210を含む。ベースライン画像208は、ターゲット拡張画像206の一部を「マスキング」することによって、たとえば、ターゲット拡張画像206の一部の画素値をデフォルト値(たとえば、値0)に設定することによって生成される。マスク画像210は、ベースライン画像においてマスクされたターゲット拡張画像206の部分を識別する。訓練生成ネットワーク入力に含まれるターゲット拡張画像の部分は、本明細書では「訓練画像」と呼ばれることがある。
【0057】
一般に、訓練例の現在のバッチは、複数の訓練例を含むことができる。しかしながら、便宜上、以下の説明は、現在のバッチにおける特定の訓練例を参照する。
【0058】
生成ニューラルネットワーク110は、訓練例に含まれる訓練生成ネットワーク入力を処理して、対応する訓練拡張画像212を生成する。訓練拡張画像212を生成した後、敵対的訓練システム116は、生成ニューラルネットワーク110によって訓練拡張画像が生成された可能性を特徴付ける弁別出力を生成するために、弁別ニューラルネットワーク202を使用して訓練拡張画像212を処理する。したがって、弁別出力は、生成ニューラルネットワーク110によって生成された訓練拡張画像212が、訓練画像をもっともらしく拡張する現実的な画像であるかどうかを特徴付ける。以下でより詳細に説明するように、敵対的損失目的関数204は、弁別ニューラルネットワーク202によって生成される弁別出力に依存する。
【0059】
いくつかの場合には、訓練拡張画像212を直接処理するのではなく、敵対的訓練システム116は、まず、訓練拡張画像212の対応する部分に訓練画像を上書きする。すなわち、敵対的訓練システム116は、訓練画像の境界を越えて延在する訓練拡張画像212の部分を修正することなく、訓練画像と一致すべき訓練拡張画像212の部分に訓練画像を上書きする。このように訓練拡張画像212を修正することは、訓練拡張画像が本質的に現実的な画像であるかどうかだけでなく、訓練拡張画像が元の訓練画像の現実的な拡張であるかどうかを特徴付けるために、弁別出力を促す。
【0060】
訓練拡張画像212が弁別ニューラルネットワーク202に提供される前に、マスク画像210は、訓練拡張画像212にチャネルごとに空間的に連結されてもよい。
【0061】
訓練拡張画像212(または訓練拡張画像212に基づく入力)を処理することに加えて、弁別ニューラルネットワーク202は、訓練例のターゲット拡張画像206の意味的特徴表現に「条件付け」され得る。すなわち、訓練拡張画像212のために弁別ニューラルネットワーク202によって生成される弁別出力は、ターゲット拡張画像206の意味的特徴表現に依存し得る。
【0062】
ターゲット拡張画像206の意味的特徴表現は、ターゲット拡張画像206の内容を暗黙的または明示的に特徴付ける、たとえば、数値のベクトルまたは行列など、数値の順序付けられた集合を指す。敵対的訓練システム116は、ターゲット拡張画像206を処理することによって、ターゲット拡張画像206の意味的特徴表現を、事前訓練された画像処理ニューラルネットワークによって生成された中間出力であると決定する。ニューラルネットワークの中間出力は、ニューラルネットワークの1つまたは複数の中間層、すなわち、入力層に続くが出力層に先行する層によって生成される出力を指す。
【0063】
画像処理ニューラルネットワークは、任意の適切なニューラルネットワークアーキテクチャ(たとえば、InceptionV3アーキテクチャ)を有し得、たとえば、分類タスクまたは回帰タスクなど、様々な画像処理タスクのいずれかを実行するように事前訓練され得る。特定の例では、画像処理ニューラルネットワークは、入力画像が所定数のオブジェクトクラス(たとえば、人、車両、自転車など)の各々からのオブジェクトを描写するそれぞれの可能性を特徴付ける出力を生成することによって、分類タスクを実行するように事前訓練されてもよい。別の特定の例では、画像処理ニューラルネットワークは、入力画像に描かれたオブジェクトを囲むと予測されるバウンディングボックスの位置を特徴付ける出力を生成することによって、回帰タスクを実行するように事前訓練されてもよい。「事前訓練された」画像処理ニューラルネットワークは、画像処理タスクを実行するように事前に訓練されたネットワークを指す。
【0064】
いくつかの場合には、敵対的訓練システム116は、正規化エンジン214を使用して、弁別ニューラルネットワーク202を条件付けるためにそれを使用する前に、ターゲット拡張画像の意味表現を正規化する。たとえば、正規化エンジン214は、正規化された意味表現Cnormを以下のように決定し得る。
【0065】
【0066】
式中、Cは正規化されていない意味表現であり、
【0067】
【0068】
は、(たとえば、訓練画像のセットからの)画像の意味表現の期待値であり、|・|2は、L2ノルムを指す。さらに、敵対的訓練システム116は、弁別ニューラルネットワークを条件付けるために意味表現を使用する前に、生成および弁別ニューラルネットワークと共同で訓練される1つまたは複数のニューラルネットワーク層216(たとえば、全結合層)を使用して、正規化された意味表現を処理し得る。
【0069】
弁別ニューラルネットワーク202は、様々な方法のうちの任意の方法で、ターゲット拡張画像の意味表現を条件とすることができる。一例では、敵対的訓練システム116は、ターゲット拡張画像の意味表現を、たとえば、弁別ニューラルネットワークの入力層または中間層など、弁別ニューラルネットワークへの追加入力として提供し得る。別の例では、敵対的訓練システム116は、(i)ターゲット拡張画像の意味表現と、(ii)弁別ニューラルネットワークの中間出力との間の類似性尺度に少なくとも部分的に基づいて弁別出力を決定してもよく、たとえば、弁別出力Dは、以下によって与えられ得、
D=DO+<DN,S> (2)
式中、DOは、弁別ニューラルネットワークの最終ニューラルネットワーク層のスカラー出力であり、DNは、弁別ニューラルネットワークの中間出力(たとえば、中間層218によって生成される)であり、Sは、ターゲット拡張画像の意味表現であり、<・, ・>は、ドット積演算を指す。
【0070】
弁別ニューラルネットワーク202を意味表現で条件付けることは、生成ニューラルネットワーク110および弁別ニューラルネットワーク202の共同訓練を安定化させ、訓練された生成ニューラルネットワーク110によって生成される拡張画像の品質も向上させ得る。特に、弁別ニューラルネットワーク202を意味表現で条件付けることは、弁別ニューラルネットワーク202が、ターゲット拡張画像のマスクされた部分からを含む、ターゲット拡張画像の意味的内容全体に依存する弁別出力を生成することを可能にし得る。意味表現は、ターゲット拡張画像の「グローバル」コンテキストを特徴付ける結果として、効果的な条件付け情報(conditioning information)(すなわち、弁別ニューラルネットワークがより正確な弁別出力を生成することを可能にする)を提供し得る。対照的に、たとえば、画素値は本質的に「局所的」であり、潜在的にノイズが多いので、弁別ネットワークをターゲット拡張画像の画素値で直接条件付けることは、あまり効果的ではない可能性がある。また、弁別ニューラルネットワークを意味表現で条件付けることは、その最終層の出力における意味内容を直接考慮するために、弁別ニューラルネットワーク上の負担を低減することによって、弁別ニューラルネットワークをより効果的に(たとえば、より少ない訓練反復で)訓練することを可能にし得る。たとえば、式(2)を参照すると、弁別出力は、弁別ニューラルネットワークの中間出力と意味表現との間の内積によって意味内容を考慮に入れることができる。
【0071】
弁別出力を生成した後、敵対的訓練システム116は、たとえば、以下のように、敵対的損失目的関数Ladv 204および再構成目的関数Lrec 220を含む目的関数LGの勾配を使用して、生成ニューラルネットワークパラメータの現在の値を調整することができ、
【0072】
【0073】
式中、λは、スカラーハイパーパラメータであり、xは、ターゲット拡張画像であり、
【0074】
【0075】
は、生成ニューラルネットワークによって生成された訓練拡張画像であり、|・|1は、L1ノルムであり、
【0076】
【0077】
は、訓練拡張画像(または訓練拡張画像に基づく入力)を処理することによって弁別ニューラルネットワークによって生成される弁別出力である。
【0078】
式(3)~(5)によって特徴付けられる目的関数は、目的関数の例示的な例として提供されるが、他の目的関数も可能である。一般に、再構成目的関数Lrecは、ターゲット拡張画像xと訓練拡張画像
【0079】
【0080】
との間の類似性を様々な方法で特徴付けることができ、敵対的損失目的関数Ladvは、様々な方法で、弁別出力
【0081】
【0082】
に依存する。
【0083】
敵対的訓練システム116は、たとえば、所定数の訓練反復の間、弁別ニューラルネットワーク202と生成ニューラルネットワーク110とを交互に訓練することによって、弁別ニューラルネットワーク202と生成ニューラルネットワーク110とを共同で訓練する。
【0084】
弁別ニューラルネットワークの訓練中の各訓練反復において、弁別ニューラルネットワークの現在のパラメータ値は、訓練例の現在のバッチに基づいて調整される。前述のように、訓練例の現在のバッチは、複数の訓練例を含むことができるが、便宜上、以下の説明は、特定の訓練例を参照する。
【0085】
弁別ニューラルネットワーク202を訓練するために、敵対的訓練システム116は、対応する訓練拡張画像を生成するために、生成ニューラルネットワーク110を使用して、訓練例の訓練生成ネットワーク入力を処理する。敵対的訓練システム116は、対応する弁別出力を生成するために、弁別ニューラルネットワークを使用して、訓練拡張画像(または訓練拡張画像に基づく入力)と対応するターゲット拡張画像の両方を処理する。次いで、敵対的訓練システム116は、訓練拡張画像およびターゲット拡張画像に対して生成された弁別出力に依存する弁別目的関数に基づいて、弁別ニューラルネットワーク202の現在のパラメータ値を調整する。たとえば、弁別目的関数Ldiscは、以下によって与えられ得、
【0086】
【0087】
式中、ReLU(・)は、整流された線形単位関数であり、D(x)は、ターゲット拡張画像のために弁別ニューラルネットワークによって生成された弁別出力であり、
【0088】
【0089】
は、生成ニューラルネットワークによって生成された訓練拡張画像のために弁別ニューラルネットワークによって生成された弁別出力である。式(6)によって特徴付けられる弁別目的関数は、例示の目的のためだけに提供され、他の弁別目的関数が可能である。
【0090】
弁別ニューラルネットワーク202は、任意の適切なニューラルネットワークアーキテクチャを有することができる。一例では、弁別ニューラルネットワーク202は、全結合層が後に続くリーキーなReLU活性化機能を有する6つのストライド畳み込み層を有する。
【0091】
生成ニューラルネットワークおよび弁別ニューラルネットワークの訓練中に、敵対的訓練システム116は、たとえば、逆伝搬技法を使用して目的関数の勾配を決定することができる。敵対的訓練システム116は、目的関数の勾配を使用して、任意の適切な勾配降下最適化手順、たとえば、AdamまたはRMSpropを使用して、生成ニューラルネットワークおよび弁別ニューラルネットワークの現在のパラメータ値を調整することができる。
【0092】
敵対的訓練システム116は、訓練終了基準が満たされるまで、たとえば、各ニューラルネットワークに対して所定数の訓練反復が実行されるまで、または性能基準が満たされるまで、生成ニューラルネットワーク110および弁別ニューラルネットワーク202を共同で訓練し続けることができる。
【0093】
図3は、元の画像302を処理することによって、
図1を参照して説明した画像拡張システム100によって生成された拡張画像300の一例の図である。拡張画像300は、元の画像302の高レベルの意味的特性ならびに低レベルの構造およびテクスチャを維持する元の画像302の現実的な拡張であることを諒解することができる。
【0094】
図4は、デジタルコンポーネント配信システム410が画像拡張システム100を使用し、電子ドキュメントとともに提示するためにデジタルコンポーネントデータベース416からデジタルコンポーネントを送信する例示的な環境400のブロック図である。以下でより詳細に説明するように、デジタルコンポーネント配信システムは、デジタルコンポーネントが、ユーザデバイスにおいて、たとえば、検索結果と一緒に、またはサードパーティウェブサイト上に、ブロックで、電子ドキュメントとともに提示される旨の要求に応答して、デジタルコンポーネントを送信することができる。
【0095】
要求に応答して送信されるデジタルコンポーネントを識別した後、配信システムは、デジタルコンポーネントに含まれる画像が画像拡張に適格であることを識別し得る。一例では、配信システムは、画像のサイズ(たとえば、アスペクト比)が、画像が提示されるブロックのサイズと(たとえば、少なくともしきい値量だけ)異なることに基づいて、画像が画像拡張に適格であることを識別し得る。この例では、デジタルコンポーネント要求は、デジタルコンポーネントが提示されるブロックのサイズを特徴付けるデータを含むことができる。別の例では、配信システムは、デジタルコンポーネントの他の視覚要素(たとえば、テキスト、ロゴ、および対話型要素)をデジタルコンポーネントの画像上にオーバーレイすべきではないことを指定したデジタルコンポーネントのプロバイダに基づいて、画像が画像拡張に適格であることを識別し得る。
【0096】
デジタルコンポーネントに含まれる画像が拡張に適格であることを識別したことに応答して、配信システムは、拡張画像を生成するために画像拡張システム100を使用して画像を処理することができる。一例では、配信システムは、拡張画像が表示されるブロックのアスペクト比に一致するアスペクト比を有する拡張画像を生成し得る。別の例では、配信システムは、拡張画像を生成し、次いで、デジタルコンポーネントの追加の視覚要素(たとえば、テキスト、ロゴ、および対話型要素)を、画像の拡張部分上にのみ(すなわち、元の画像を修正することなく)オーバーレイしてもよい。
【0097】
デジタルコンポーネントに含まれる画像を拡張した後、配信システムは、コンポーネント要求を生成したユーザデバイスにおけるブロックでの提示のために、拡張画像とともにデジタルコンポーネントを送信し得る。
【0098】
次に、例示的な環境400および配信システムによって実行される動作について、より詳細に説明する。
【0099】
例示的な環境400は、ローカルエリアネットワーク(LAN)、ワイドエリアネットワーク(WAN)、インターネット、またはそれらの組合せなどのネットワーク402を含む。ネットワーク402は、電子ドキュメントサーバ404、クライアントデバイス406、デジタルコンポーネントサーバ408、およびデジタルコンポーネント配信システム410(「配信システム」410とも呼ばれる)を接続する。例示的な環境400は、多くの異なる電子ドキュメントサーバ404、クライアントデバイス406、およびデジタルコンポーネントサーバ408を含み得る。
【0100】
クライアントデバイス406は、ネットワーク402を介してリソースを要求し、受信することが可能な電子デバイスである。例示的なクライアントデバイス406は、パーソナルコンピュータ、モバイル通信デバイス(たとえば、携帯電話)、およびネットワーク402を介してデータを送受信することができる他のデバイスを含む。クライアントデバイス406は、典型的には、ネットワーク402を介したデータの送受信を容易にするために、ウェブブラウザなどのユーザアプリケーションを含むが、クライアントデバイス406によって実行されるネイティブアプリケーションは、ネットワーク402を介したデータの送受信を容易にすることもできる。
【0101】
電子ドキュメントは、クライアントデバイス406においてコンテンツのセットを提示するデータである。電子ドキュメントの例には、ウェブページ、ワードプロセシングドキュメント、ポータブルドキュメントフォーマット(PDF)ドキュメント、画像、ビデオ、検索結果ページ、およびフィードソースがある。モバイルコンピューティングデバイス、タブレットコンピューティングデバイス、またはデスクトップコンピューティングデバイスにインストールされたアプリケーションなどのネイティブアプリケーション(たとえば、「アプリ」)も、電子ドキュメントの例である。電子ドキュメントは、電子ドキュメントサーバ404(「電子ドキュメントサーバ」)によってクライアントデバイス406に提供することができる。たとえば、電子ドキュメントサーバ404は、発行者ウェブサイトをホストするサーバを含むことができる。この例では、クライアントデバイス406は、所与の発行者ウェブページに対する要求を開始することができ、所与の発行者ウェブページをホストする電子サーバ404は、クライアントデバイス406で所与のウェブページの提示を開始するマシン実行可能命令を送信することによって、要求に応答することができる。
【0102】
別の例では、電子ドキュメントサーバ404は、クライアントデバイス406がアプリをダウンロードすることができるアプリサーバを含むことができる。この例では、クライアントデバイス406は、クライアントデバイス406においてアプリをインストールするために必要なファイルをダウンロードし、次いで、ダウンロードされたアプリをローカルに実行することができる。
【0103】
電子ドキュメントは、様々なコンテンツを含むことができる。たとえば、電子ドキュメントは、電子ドキュメント自体の中にあり、および/または時間とともに変化しない静的コンテンツ(たとえば、テキストまたは他の指定されたコンテンツ)を含むことができる。また、電子ドキュメントは、時間の経過とともに、または要求ごとに変化する可能性がある動的コンテンツを含むこともできる。たとえば、所与の電子ドキュメントの発行者は、電子ドキュメントの一部をポピュレートするために使用されるデータソースを維持することができる。この例では、所与の電子ドキュメントは、所与の電子ドキュメントがクライアントデバイス406によって処理(たとえば、レンダリングまたは実行)されると、クライアントデバイス406に、データソースからコンテンツを要求させる1つまたは複数のタグまたはスクリプトを含むことができる。クライアントデバイス406は、データソースから取得されたコンテンツを所与の電子ドキュメントに統合して、データソースから取得されたコンテンツを含む合成電子ドキュメントを作成する。
【0104】
いくつかの状況では、所与の電子ドキュメントは、デジタルコンポーネント配信システム410を参照する1つまたは複数のデジタルコンポーネントタグまたはデジタルコンポーネントスクリプトを含むことができる。これらの状況では、デジタルコンポーネントタグまたはデジタルコンポーネントスクリプトは、所与の電子ドキュメントがクライアントデバイス406によって処理されると、クライアントデバイス406によって実行される。デジタルコンポーネントタグまたはデジタルコンポーネントスクリプトの実行は、ネットワーク402を介してデジタルコンポーネント配信システム410に送信される1つまたは複数のデジタルコンポーネント412に対する要求(「コンポーネント要求」と呼ばれる)を生成するようにクライアントデバイス406を構成する。たとえば、デジタルコンポーネントタグまたはデジタルコンポーネントスクリプトは、クライアントデバイス406が、ヘッダおよびペイロードデータを含むパケット化されたデータ要求を生成することを可能にすることができる。コンポーネント要求412は、デジタルコンポーネントが要求されているサーバの名前(またはネットワークロケーション)、要求側デバイス(たとえば、クライアントデバイス406)の名前(またはネットワークロケーション)、および/またはデジタルコンポーネント配信システム410が、要求に応答して提供される1つまたは複数のデジタルコンポーネントを選択するために使用することができる情報などの特徴を指定するイベントデータを含むことができる。コンポーネント要求412は、クライアントデバイス406によって、ネットワーク402(たとえば、電気通信ネットワーク)を介して、デジタルコンポーネント配信システム410のサーバに送信される。
【0105】
コンポーネント要求412は、要求されている電子ドキュメント、およびデジタルコンポーネントを提示することができる電子ドキュメントのロケーションの特性など、他のイベント特徴を指定するイベントデータを含むことができる。たとえば、デジタルコンポーネントが提示される電子ドキュメント(たとえば、ウェブページ)への参照(たとえば、URL)を指定するイベントデータ、デジタルコンポーネントを提示するために利用可能な電子ドキュメントの利用可能なロケーション、利用可能なロケーションのサイズ、および/またはロケーションでの提示に適格なメディアタイプを、デジタルコンポーネント配信システム410に提供することができる。同様に、電子ドキュメントによって参照される電子ドキュメント(「ドキュメントキーワード」)またはエンティティ(たとえば、人、場所、または物)に関連付けられたキーワードを指定するイベントデータも、コンポーネント要求412に(たとえば、ペイロードデータとして)含め、電子ドキュメントとの提示に適格なデジタルコンポーネントの識別を容易にするためにデジタルコンポーネント配信システム410に提供することができる。イベントデータはまた、検索結果ページを取得するためにクライアントデバイス406からサブミットされた検索クエリ、ならびに/あるいは検索結果および/または検索結果に含まれるテキスト、可聴、または他の視覚コンテンツを指定するデータを含むことができる。
【0106】
コンポーネント要求412はまた、クライアントデバイスのユーザが提供した情報、コンポーネント要求がサブミットされた状態または領域を示す地理的情報、またはデジタルコンポーネントが表示される環境のコンテキストを提供する他の情報(たとえば、コンポーネント要求の時刻、コンポーネント要求の曜日、モバイルデバイスまたはタブレットデバイスなど、デジタルコンポーネントが表示されるデバイスのタイプ)など、他の情報に関連するイベントデータを含むこともできる。コンポーネント要求412は、たとえば、パケット化ネットワークを介して送信することができ、コンポーネント要求412自体は、ヘッダおよびペイロードデータを有するパケット化データとしてフォーマットすることができる。ヘッダは、パケットの宛先を指定することができ、ペイロードデータは、上述の情報のいずれかを含むことができる。
【0107】
コンポーネント配信システム410は、コンポーネント要求412の受信に応答して、および/またはコンポーネント要求412に含まれる情報を使用して、所与の電子ドキュメントとともに提示されるデジタルコンポーネントを選択する。いくつかの実装形態では、デジタルコンポーネントの遅延選択によって引き起こされる可能性があるエラーを回避するために、(本明細書で説明される技法を使用して)1秒未満でデジタルコンポーネントが選択される。たとえば、コンポーネント要求412に応答してデジタルコンポーネントを提供する際の遅延は、クライアントデバイス406においてページロードエラーをもたらすか、または電子ドキュメントの他の部分がクライアントデバイス406において提示された後であっても、電子ドキュメントの一部がポピュレートされないままであることを引き起こす可能性がある。また、デジタルコンポーネントをクライアントデバイス406に提供する際の遅延が増大するにつれて、デジタルコンポーネントがクライアントデバイス406に配信されると、電子ドキュメントがもはやクライアントデバイス406に提示されなくなる可能性が高くなり、それによって、電子ドキュメントに関するユーザの経験に悪影響を及ぼす。さらに、デジタルコンポーネントを提供する際の遅延は、たとえば、デジタルコンポーネントが提供されるときに電子ドキュメントがもはやクライアントデバイス406に提示されない場合、デジタルコンポーネントの配信の失敗をもたらす可能性がある。
【0108】
いくつかの実装形態では、デジタルコンポーネント配信システム410は、たとえば、相互接続され、要求412に応答してデジタルコンポーネントを識別し、配信する、サーバおよび複数のコンピューティングデバイスのセット414を含む分散コンピューティングシステムに実装される。複数のコンピューティングデバイスのセット414は、一緒に動作して、何百万もの利用可能なデジタルコンポーネント(DC1~x)のコーパスから、電子ドキュメントに提示されるのに適格であるデジタルコンポーネントのセットを識別する。何百万もの利用可能なデジタルコンポーネントは、たとえば、デジタルコンポーネントデータベース416においてインデックス付けすることができる。各デジタルコンポーネントインデックスエントリは、対応するデジタルコンポーネントを参照することができ、および/または、対応するデジタルコンポーネントの配信/送信に寄与する(たとえば、条件付けまたは制限する)配信パラメータ(DP1~DPx)を含むことができる。たとえば、配信パラメータは、コンポーネント要求が、デジタルコンポーネントの配信パラメータのうちの1つに一致する(たとえば、正確に、または何らかの事前に指定された類似性レベルで)少なくとも1つの基準を含むことを要求することによって、デジタルコンポーネントの送信に寄与することができる。
【0109】
いくつかの実装形態では、特定のデジタルコンポーネントの配信パラメータは、デジタルコンポーネントが提示に適格であるために、(たとえば、電子ドキュメント、ドキュメントキーワード、またはコンポーネント要求412で指定された用語によって)一致しなければならない配信キーワードを含むことができる。言い換えれば、配信パラメータは、ネットワーク402を介したデジタルコンポーネントの配信(たとえば、送信)をトリガするために使用される。配信パラメータはまた、コンポーネント要求412が、特定の地理的領域(たとえば、国または州)を指定する情報、および/または、デジタルコンポーネントが提示に適格であるために、コンポーネント要求412が特定のタイプのクライアントデバイス(たとえば、モバイルデバイスまたはタブレットデバイス)で発信されたことを指定する情報を含むことを要求することもできる。
【0110】
配信パラメータはまた、たとえば、コンポーネント評価プロセスによって、(たとえば、他の利用可能なデジタルコンポーネントの中で)配信/送信のためのデジタルコンポーネントの適格性を評価するために使用される適格性値(たとえば、ランキングスコア、入札、または何らかの他の指定された値)を指定することもできる。いくつかの状況では、適格性値は、デジタルコンポーネントのプロバイダが、(たとえば、デジタルコンポーネントとのユーザ対話など、デジタルコンポーネントの提示に起因する特定のイベントの各インスタンスについて)デジタルコンポーネントの送信に応答してサブミットする意思がある補償の最大量を指定することができる。
【0111】
適格なデジタルコンポーネントの識別は、複数のタスク417a~417cにセグメント化することができ、これらのタスクは、次いで、複数のコンピューティングデバイスのセット414内のコンピューティングデバイスの間で割り当てられる。たとえば、セット414内の異なるコンピューティングデバイスは各々、デジタルコンポーネントデータベース416の異なる部分を分析して、コンポーネント要求412に含まれる情報に一致する配信パラメータを有する様々なデジタルコンポーネントを識別することができる。いくつかの実装形態では、セット414内の各所与のコンピューティングデバイスは、異なるデータ次元(または次元のセット)を分析し、分析の結果(結果1~結果3)418a~418cをデジタルコンポーネント配信システム410に渡す(たとえば、送信する)ことができる。たとえば、セット414内のコンピューティングデバイスの各々によって提供される結果418a~418cは、コンポーネント要求および/または特定の配信パラメータを有するデジタルコンポーネントのサブセットに応答して、配信に適格なデジタルコンポーネントのサブセットを識別し得る。デジタルコンポーネントのサブセットの識別は、たとえば、イベントデータを配信パラメータと比較することと、イベントデータの少なくともいくつかの特徴に一致する配信パラメータを有するデジタルコンポーネントのサブセットを識別することとを含むことができる。
【0112】
デジタルコンポーネント配信システム410は、複数のコンピューティングデバイスのセット414から受信された結果418a~418cを集約し、集約された結果に関連付けられた情報を使用して、(i)要求412に応答して提供される1つまたは複数のデジタルコンポーネントを選択し、(ii)1つまたは複数のデジタルコンポーネントの送信要件を決定する。たとえば、デジタルコンポーネント配信システム410は、1つまたは複数のコンポーネント評価プロセスの結果に基づいて、ウィニングデジタルコンポーネント(1つまたは複数のデジタルコンポーネント)のセットを選択することができる。次に、デジタルコンポーネント配信システム410は、ネットワーク402を介して、クライアントデバイス406がウィニングデジタルコンポーネントのセットを所与の電子ドキュメントに統合することを可能にする応答データ420(たとえば、応答を表すデジタルデータ)を生成し、送信することができ、その結果、ウィニングデジタルコンポーネントのセットおよび電子ドキュメントのコンテンツが、クライアントデバイス406のディスプレイに一緒に提示される。
【0113】
いくつかの実装形態では、クライアントデバイス406は、応答データ420に含まれる命令を実行し、クライアントデバイス406が1つまたは複数のデジタルコンポーネントサーバからウィニングデジタルコンポーネントのセットを取得するように構成し、それを可能にする。たとえば、応答データ420内の命令は、ネットワークロケーション(たとえば、ユニフォームリソースロケータ(URL))、およびクライアントデバイス406に、サーバ要求(SR)421をデジタルコンポーネントサーバ408に送信させて、デジタルコンポーネントサーバ408から所与のウィニングデジタルコンポーネントを取得させるスクリプトを含むことができる。要求に応答して、デジタルコンポーネントサーバ408は、サーバ要求421(たとえば、複数のデジタルコンポーネントを記憶するデータベース内)で指定された所与のウィニングデジタルコンポーネントを識別し、クライアントデバイス406で電子ドキュメント内の所与のウィニングデジタルコンポーネントを提示するデジタルコンポーネントデータ(DCデータ)422をクライアントデバイス406に送信する。
【0114】
電子ドキュメントの検索を容易にするために、環境400は、電子ドキュメントをクロールし、インデックス付けすることによって(たとえば、電子ドキュメントのクロールされたコンテンツに基づいてインデックス付けされた)、電子ドキュメントを識別する検索システム450を含むことができる。電子ドキュメントに関するデータは、データが関連付けられている電子ドキュメントに基づいてインデックス付けすることができる。インデックス付けされ、随意に、キャッシュされた電子ドキュメントのコピーは、検索インデックス452(たとえば、ハードウェアメモリデバイス)に記憶される。電子ドキュメントに関連付けられるデータは、電子ドキュメントに含まれるコンテンツおよび/または電子ドキュメントのメタデータを表すデータである。
【0115】
クライアントデバイス406は、ネットワーク402を介して検索システム450に検索クエリをサブミットすることができる。これに応答して、検索システム450は、検索インデックス452にアクセスして、検索クエリに関連する電子ドキュメントを識別する。検索システム450は、検索結果の形式で電子ドキュメントを識別し、検索結果を検索結果ページでクライアントデバイス406に返す。検索結果は、特定の検索クエリに応答する(たとえば、関連する)電子ドキュメントを識別する検索システム450によって生成されたデータであり、検索結果とのユーザ対話に応答して、クライアントデバイスに、指定されたネットワークロケーション(たとえば、URL)からのデータを要求させるアクティブリンク(たとえば、ハイパーテキストリンク)を含む。例示的な検索結果は、ウェブページタイトル、ウェブページから抽出されたテキストの断片または画像の一部、およびウェブページのURLを含むことができる。別の例示的な検索結果は、ダウンロード可能なアプリケーションのタイトル、ダウンロード可能なアプリケーションを記述するテキストの断片、ダウンロード可能なアプリケーションのユーザインターフェースを描写する画像、および/またはアプリケーションをクライアントデバイス406にダウンロードすることができる位置へのURLを含むことができる。いくつかの状況では、検索システム450は、サブミットされた検索クエリに関連するダウンロード可能なアプリケーションに関する情報を提示するために、クライアントデバイス406にインストールするためにアプリケーションをダウンロードすることができるアプリケーションストア(またはオンラインポータル)の一部とすることができ、またはそれと対話することができる。他の電子ドキュメントと同様に、検索結果ページは、デジタルコンポーネント(たとえば、広告、ビデオクリップ、オーディオクリップ、画像、または他のデジタルコンポーネント)を提示することができる1つまたは複数のスロットを含むことができる。
【0116】
コンポーネント要求に応答して送信されるデジタルコンポーネントを選択するために、配信システム410は、コンポーネント要求に応答して送信されるのに適格であるデジタルコンポーネントのセットを識別し得る。次いで、配信システム410は、たとえば、オークション手順を介して送信される適格なデジタルコンポーネントのうちの1つまたは複数を選択し得る。いくつかの実装形態では、配信システム410は、それぞれの適格性値に従って適格なデジタルコンポーネントをランク付けし、コンポーネント要求に応答して送信される1つまたは複数の最高ランクのデジタルコンポーネントを選択することによって、オークション手順を実行する。
【0117】
たとえば、配信システム410は、デジタルコンポーネントA、B、およびCを、コンポーネント要求に応答して送信されるのに適格であるものとして識別し得る。この例では、デジタルコンポーネントAは$5の適格性値を有し、デジタルコンポーネントBは$1の適格性値を有し、デジタルコンポーネントCは$5.5の適格性値を有し、デジタルコンポーネントの適格性値は、デジタルコンポーネントに関連付けられた入札を表す。配信システム410は、それぞれの適格性値に従って、C、A、Bのように、デジタルコンポーネントを(たとえば、降順に)ランク付けし得る。最後に、配信システム410は、コンポーネント要求に応答して、送信のために最高ランクのデジタルコンポーネントCを選択してもよい。
【0118】
デジタルコンポーネント要求に応答して送信されるデジタルコンポーネントを選択した後、配信システム410は、選択されたデジタルコンポーネントの送信要件を決定する。送信要件は、デジタルコンポーネントの送信に応答してデジタルコンポーネントのプロバイダによって実行されるアクションを指定する。たとえば、送信要件は、デジタルコンポーネントのプロバイダが、デジタルコンポーネントの送信に応答して補償額をサブミットすることを指定し得る。いくつかの場合には、補償額は、デジタルコンポーネントの提示(たとえば、デジタルコンポーネントとのユーザ対話)に起因する特定のイベントの各インスタンスについてサブミットされる額を指定する。
【0119】
配信システム410は、選択されたデジタルコンポーネントの適格性値、および/またはコンポーネント要求に応答して送信されるのに適格であると決定された他のデジタルコンポーネントの適格性値に基づいて、選択されたデジタルコンポーネントの送信要件を決定し得る。たとえば、配信システム410は、デジタルコンポーネント要求に応答して、デジタルコンポーネントA、B、およびCを送信に適格であると識別することができ、A、B、およびCは、$5、$1、および$5.5のそれぞれの適格値を有する。配信システム410は、(最高の適格性値を有するので)送信のためにデジタルコンポーネントCを選択してもよく、適格なデジタルコンポーネントの適格性値の中から次に高い適格性値であるデジタルコンポーネントCの送信要件を決定してもよい。この例では、次に高い適格性値は、$5(すなわち、デジタルコンポーネントAの適格性値)であり、したがって、配信システム410は、デジタルコンポーネントCの送信要件を$5と決定し得る。
【0120】
図5は、たとえばスマートフォンなど、ユーザデバイスの画面上に表示されているデジタルコンポーネントを示す。デジタルコンポーネントは、デバイスの画面を満たす画像と、画像をオーバーレイするロゴ502、テキストのセグメント504、および対話型要素506を含む追加の視覚要素とを含む。この例では、画像は、デジタルコンポーネント配信システムに提供された第1の部分508と、画像拡張システム100を使用して生成された第2の部分510とを含む。デジタルコンポーネント配信システムは、ユーザデバイスに提供されるデジタルコンポーネントの要求を受信した後、デバイスの画面を満たす拡張画像を生成し、画像の拡張部分510上に追加要素502、504、および506をオーバーレイする。この例では、デジタルコンポーネントが表示される「ブロック」は、ユーザデバイスの画面全体に対応するが、ブロックは、画面のすべてを占めるわけではない。
【0121】
図6は、たとえば、検索結果とともに、またはサードパーティウェブサイト上に、「バナー」ブロック内に表示されているデジタルコンポーネントを示す。
図6と同様に、デジタルコンポーネントは、ブロックを満たす画像と、追加の要素602とを含む。この例では、画像は、デジタルコンポーネント配信システムに提供された第1の部分604と、画像拡張システム100を使用して生成された第2の部分606とを含む。デジタルコンポーネント配信システムは、ユーザデバイス上のバナーブロックに提示されるデジタルコンポーネントの要求を受信した後、ブロックを満たす拡張画像を生成し、画像の拡張部分606上に追加要素602をオーバーレイする。
【0122】
図7は、(たとえば、
図4を参照して説明したように)デジタルコンポーネント配信システムによる送信のためにデジタルコンポーネントを提供するエンティティ(たとえば、広告主、発行者、または他のコンテンツプロバイダ)に提示することができる例示的なユーザインターフェース700の図である。ユーザインターフェース700は、提供されたデジタルコンポーネントに含まれる画像702と、画像702を拡張する複数の拡張画像704-A~Cとを提示する。一般に、異なる画像拡張手順を使用して生成される結果、拡張画像704-A~Cの各々は異なる。たとえば、拡張画像のうちの1つは、
図1を参照して説明した画像拡張システムを使用して生成されていてもよく、拡張画像のうちの別のものは、以下でより詳細に説明する偏微分方程式(PDE)に基づく画像拡張手順を使用して生成されていてもよい。
【0123】
ユーザインターフェース700は、デジタルコンポーネントのプロバイダに、(たとえば、デジタルコンポーネントプロバイダにとって最も視覚的に魅力的である)拡張画像のうちの好ましい1つを選択するように促す。デジタルコンポーネントプロバイダは、たとえば、マウス706を使用して(または様々な他の方法のいずれかで)特定の拡張画像をクリックすることによって、特定の拡張画像を選択することができる。配信システムが、提供されたデジタルコンポーネントに含まれる画像が拡張に適格であると後で決定した場合、配信は、ユーザによって選択された特定の拡張画像に対応する画像拡張手順を使用して、画像の拡張を生成する。
【0124】
画像は、様々な方法で、たとえば、
図1を参照して説明した画像拡張システムを使用して、またはPDEに基づく画像拡張手順を使用して、拡張することができる。PDE拡張方法では、画像の拡張部分の画素値は、元の画像の境界の一部の画素値によって指定されるPDE対象境界条件に対する(近似または正確な)解として識別される。PDEは、たとえば、拡散PDE、または任意の他の適切なPDEであってもよい。境界条件に従うPDEに対する解は、任意の適切な数値技法、たとえば、有限要素技法を使用して取得され得る。
【0125】
図8は、要求に応答して拡張画像を提供するための例示的なプロセス800のフロー図である。便宜上、プロセス800は、1つまたは複数の位置に配置された1つまたは複数のコンピュータのシステムによって実行されるものとして説明する。たとえば、この仕様に従って適切にプログラムされた配信システム、たとえば、
図1の配信システム100は、プロセス800を実行することができる。
【0126】
システムは、提供された画像が画像拡張に適格であると決定する(802)。一例では、システムは、たとえば、検索結果と一緒に、またはサードパーティウェブページ上に、ブロックに提示されるデジタルコンポーネントの要求を受信し、その後、提供された画像を含むデジタルコンポーネントが要求に応答していると決定し得る。この例では、システムは、たとえば、画像とブロックとが異なるアスペクト比を有する場合、画像のサイズがブロックのサイズとは異なることに基づいて、提供された画像が拡張に適格であると決定し得る。
【0127】
システムは、拡張画像を生成するために生成ニューラルネットワークパラメータの訓練された値に従って入力を処理する生成ニューラルネットワークに画像を含む入力を提供する(804)。拡張画像は、(i)提供された画像よりも多くの行、多くの列、または両方を有し、(ii)提供された画像の現実的な拡張であると予測される。
【0128】
生成ニューラルネットワークによって処理される入力は、ベースライン画像およびマスク画像を含むことができ、両方とも拡張画像と同じ数の行および列を有する。ベースライン画像は、(i)提供された画像に対応する第1の部分、および(ii)デフォルトの画素値を有する第2の部分を含む。マスク画像は、ベースライン画像の第1の部分および第2の部分を識別する。一例では、ベースライン画像の第1の部分に対応するマスク画像内の画素は各々、第1の画素値を有し、ベースライン画像の第2の部分に対応するマスク画像内の画素は各々、異なる第2の画素値を有する。
【0129】
生成ニューラルネットワークは、複数の畳み込みニューラルネットワーク層を含み、任意の適切なニューラルネットワークアーキテクチャを有することができる。たとえば、生成ニューラルネットワークは、1つもしくは複数のスキップ接続、1つもしくは複数のインスタンス正規化層、またはその両方を含み得る。
【0130】
生成ニューラルネットワークは、敵対的損失目的関数を使用して、弁別ニューラルネットワークと共同で訓練されている。弁別ニューラルネットワークは、生成ニューラルネットワークを使用して所与の画像が生成された可能性を特徴付ける弁別出力を生成するために、所与の画像を処理するように構成される。
【0131】
このシステムは、複数の訓練反復にわたって敵対的損失目的関数を使用して生成ニューラルネットワークを訓練する。各訓練反復において、システムは、生成ニューラルネットワークを使用して訓練画像を含む訓練入力を処理して、訓練画像を拡張する訓練拡張画像を生成し、次いで、訓練拡張画像に基づいて弁別ニューラルネットワーク入力を生成する。一例では、システムは、訓練画像を使用して、訓練画像に対応する訓練拡張画像の部分を上書きすることによって、弁別ニューラルネットワーク入力を生成する。システムは、生成ニューラルネットワークを使用して弁別ニューラルネットワーク入力が生成された可能性を特徴付ける弁別出力を生成するために、弁別ニューラルネットワークを使用して弁別ニューラルネットワーク入力を処理する。その後、システムは、敵対的損失目的関数に基づいて生成ニューラルネットワークパラメータの現在値を調整し、敵対的損失目的関数は、弁別ニューラルネットワークによって生成された弁別出力に依存する。
【0132】
いくつかの場合には、訓練画像は、ターゲット画像のクロッピングされた表現であり、弁別ニューラルネットワークは、ターゲット画像の意味的特徴表現を条件とする。システムは、ターゲット画像を処理することによって、ターゲット画像の意味表現を、分類ニューラルネットワークによって生成された中間出力であると決定し得る。弁別ニューラルネットワークをターゲット画像の意味的特徴表現で条件付けることは、たとえば、弁別ニューラルネットワークの中間出力とターゲット画像の意味的特徴表現との間の類似性尺度に基づいて弁別出力を決定することを含み得る。弁別出力は、弁別ニューラルネットワークの最終層の出力に基づいてさらに決定されてもよい。
【0133】
敵対的損失目的関数を使用して生成ニューラルネットワークを訓練することに加えて、システムは、再構成損失目的関数を使用して生成ニューラルネットワークをさらに訓練してもよい。より具体的には、システムは、訓練拡張画像とターゲット画像との類似性を特徴付ける再構成損失目的関数に基づいて、生成ニューラルネットワークパラメータの現在値を調整し得る。
【0134】
システムは、要求に応答して拡張画像を提供する(806)。いくつかの場合には、要求は、ブロック内の画像とともに提示される追加要素を指定し、システムは、拡張画像の拡張部分に追加要素をオーバーレイする。システムが、要求に応答して拡張画像を提供した後、拡張画像は、たとえば、検索結果と一緒に、またはサードパーティウェブページ上に提示されてもよい。
【0135】
図9は、上述の動作を実行するために使用することができる例示的なコンピュータシステム900のブロック図である。システム900は、プロセッサ910、メモリ920、記憶デバイス930、および入出力デバイス940を含む。コンポーネント910、920、930、および940の各々は、たとえば、システムバス950を使用して相互接続することができる。プロセッサ910は、システム900内で実行するための命令を処理することが可能である。一実装形態では、プロセッサ910は、シングルスレッドプロセッサである。別の実装形態では、プロセッサ910は、マルチスレッドプロセッサである。プロセッサ910は、メモリ920または記憶デバイス930に記憶された命令を処理することが可能である。
【0136】
メモリ920は、システム900内に情報を記憶する。一実装形態では、メモリ920は、コンピュータ可読媒体である。一実装形態では、メモリ920は、揮発性メモリユニットである。別の実装形態では、メモリ920は、不揮発性メモリユニットである。
【0137】
記憶デバイス930は、システム900のための大容量ストレージを提供することが可能である。一実装形態では、記憶デバイス930は、コンピュータ可読媒体である。様々な異なる実装形態では、記憶デバイス930は、たとえば、ハードディスクデバイス、光ディスクデバイス、複数のコンピューティングデバイス(たとえば、クラウド記憶デバイス)によってネットワーク上で共有される記憶デバイス、または他の何らかの大容量記憶デバイスを含むことができる。
【0138】
入出力デバイス940は、システム900のための入出力動作を提供する。一実装形態では、入出力デバイス940は、1つまたは複数のネットワークインターフェースデバイス、たとえば、Ethernetカード、シリアル通信デバイス、たとえば、RS-232ポート、および/またはワイヤレスインターフェースデバイス、たとえば、802.11カードを含むことができる。別の実装形態では、入出力デバイスは、入力データを受信し、出力データを他の入出力デバイス、たとえば、キーボード、プリンタ、および表示デバイス960に送信するように構成されたドライバデバイスを含むことができる。しかしながら、モバイルコンピューティングデバイス、モバイル通信デバイス、セットトップボックステレビクライアントデバイスなど、他の実装形態も使用することができる。
【0139】
図9には例示的な処理システムが記載されているが、本明細書に記載される主題および機能的動作の実装は、他のタイプのデジタル電子回路、または本明細書に開示された構造およびそれらの構造的均等物を含むコンピュータソフトウェア、ファームウェア、もしくはハードウェア、またはそれらの1つもしくは複数の組合せに実装することができる。
【0140】
本明細書では、システムおよびコンピュータプログラムコンポーネントに関連して「構成された」という用語を使用する。1つまたは複数のコンピュータのシステムが特定の動作またはアクションを実行するように構成されるとは、システムが、動作中、システムに動作またはアクションを実行させるソフトウェア、ファームウェア、ハードウェア、またはそれらの組合せをインストールしていることを意味する。1つまたは複数のコンピュータプログラムが特定の動作またはアクションを実行するように構成されるとは、1つまたは複数のプログラムが、データ処理装置によって実行されると、装置に動作またはアクションを実行させる命令を含むことを意味する。
【0141】
本明細書に記載される主題および機能的動作の実施形態は、デジタル電子回路、有形に実施されたコンピュータソフトウェアまたはファームウェア、本明細書に開示される構造およびそれらの構造的均等物を含むコンピュータハードウェア、またはそれらの1つもしくは複数の組合せに実装することができる。本明細書に記載される主題の実施形態は、1つまたは複数のコンピュータプログラム、すなわち、データ処理装置によって実行される、またはデータ処理装置の動作を制御するための有形の非一時的記憶媒体上に符号化されたコンピュータプログラム命令の1つまたは複数のモジュールとして実装することができる。コンピュータ記憶媒体は、機械可読記憶デバイス、機械可読記憶基板、ランダムまたはシリアルアクセスメモリデバイス、またはそれらの1つもしくは複数の組合せとすることができる。代替的に、または追加として、プログラム命令は、データ処理装置によって実行するための適切な受信機装置への送信のために情報を符号化するために生成された、人工的に生成された伝搬信号、たとえば、機械生成電気、光学、または電磁信号上で符号化することができる。
【0142】
「データ処理装置」という用語は、データ処理ハードウェアを指し、例として、プログラマブルプロセッサ、コンピュータ、または複数のプロセッサもしくはコンピュータを含む、データを処理するためのあらゆる種類の装置、デバイスおよび機械を包含する。装置は、たとえば、FPGA(フィールドプログラマブルゲートアレイ)もしくはASIC(特定用途向け集積回路)などの専用論理回路でもよく、またはそれをさらに含むこともできる。装置は、随意に、ハードウェアに加えて、コンピュータプログラムの実行環境を作成するコード、たとえば、プロセッサファームウェア、プロトコルスタック、データベース管理システム、オペレーティングシステム、またはそれらの1つもしくは複数の組合せを構成するコードを含むことができる。
【0143】
プログラム、ソフトウェア、ソフトウェアアプリケーション、アプリ、モジュール、ソフトウェアモジュール、スクリプト、またはコードとも呼ばれるまたは記述されることもあるコンピュータプログラムは、コンパイルもしくはインタープリタ型言語、宣言型言語もしくは手続き型言語を含む、任意の形式のプログラミング言語で記述することができ、それは、スタンドアロンプログラムとして、またはモジュール、コンポーネント、サブルーチン、もしくはコンピューティング環境での使用に適した他のユニットとしてなど、あらゆる形式で展開することができる。プログラムは、必ずしも必要はないが、ファイルシステム内のファイルに対応し得る。プログラムは、当該のプログラム専用の単一のファイル、または、たとえば、1つもしくは複数のモジュール、サブプログラム、もしくはコードの一部を記憶するファイルなど、複数のコーディネートされたファイルに、たとえば、マークアップ言語文書に記憶された1つもしくは複数のスクリプトなど、他のプログラムもしくはデータを保持するファイルの一部に記憶することができる。コンピュータプログラムは、1つのコンピュータ上で、または1つのサイトに位置するか、もしくは複数のサイトに分散され、データ通信ネットワークによって相互接続された複数のコンピュータ上で実行されるように配備することができる。
【0144】
本明細書では、「エンジン」という用語は、1つもしくは複数の特定の機能を実行するようにプログラムされているソフトウェアベースのシステム、サブシステム、またはプロセスを指すために広く使用されている。一般に、エンジンは、1つまたは複数の位置にある1つまたは複数のコンピュータにインストールされた1つまたは複数のソフトウェアモジュールまたは構成要素として実装される。いくつかの場合には、1つまたは複数のコンピュータが特定のエンジンに専用であり、他の場合には、複数のエンジンを、同じ1つまたは複数のコンピュータにインストールし、そこにおいて実行することができる。
【0145】
本明細書に記載されるプロセスおよび論理フローは、入力データ上で動作し、出力を生成することによって機能を実行するために、1つまたは複数のコンピュータプログラムを実行する1つまたは複数のプログラム可能コンピュータによって実行することができる。プロセスおよび論理フローは、たとえばFPGAもしくはASICなどの専用論理回路によって、または専用論理回路と1つもしくは複数のプログラムされたコンピュータとの組合せによっても実行することができる。
【0146】
コンピュータプログラムの実行に適したコンピュータは、汎用マイクロプロセッサもしくは専用マイクロプロセッサ、もしくはその両方、または他の種類の中央処理ユニットに基づくことができる。一般に、中央処理ユニットは、読取り専用メモリまたはランダムアクセスメモリまたはその両方から命令およびデータを受信する。コンピュータの必須要素は、命令を実施または実行するための中央処理ユニット、ならびに命令およびデータを記憶するための1つまたは複数のメモリデバイスである。中央処理ユニットおよびメモリは、専用論理回路によって補うまたはそこに組み込むことができる。一般に、コンピュータは、たとえば磁気、光磁気ディスク、または光ディスクなど、データを記憶するための1つまたは複数の大容量記憶デバイスも含み、あるいは、1つまたは複数の大容量記憶デバイスからデータを受信する、それにデータを転送する、またはその両方のために動作可能に結合される。しかしながら、コンピュータはそのようなデバイスを有する必要はない。さらに、コンピュータは、別のデバイス、たとえば、ほんのいくつかの例を挙げれば、携帯電話、携帯情報端末(PDA)、モバイルオーディオもしくはビデオプレーヤ、ゲームコンソール、全地球測位システム(GPS)受信機、またはユニバーサルシリアルバス(USB)フラッシュドライブなどのポータブル記憶デバイス中に組み込むことができる。
【0147】
コンピュータプログラム命令およびデータを記憶するのに適したコンピュータ可読媒体は、例として、たとえば、EPROM、EEPROM、およびフラッシュメモリデバイスなどの半導体メモリデバイス、たとえば内部ハードディスクまたはリムーバブルディスクなどの磁気ディスク、光磁気ディスク、ならびにCD-ROMおよびDVD-ROMディスクを含むすべての形態の不揮発性メモリ、媒体、およびメモリデバイスを含む。
【0148】
ユーザとの対話を提供するために、本明細書に記載される主題の実施形態は、ユーザに情報を表示するための、CRT(陰極線管)またはLCD(液晶ディスプレイ)モニタなどのディスプレイデバイス、ならびにキーボードおよび、ユーザがコンピュータに入力を提供することができる、たとえば、マウスまたはトラックボールなどのポインティングデバイスを有するコンピュータ上に実装することができる。他の種類のデバイスを使用して、ユーザとの対話を提供することもでき、たとえば、ユーザに提供されるフィードバックは、たとえば、視覚フィードバック、聴覚フィードバック、または触覚フィードバックなど、任意の形態の感覚フィードバックとすることができ、ユーザからの入力は、音響、音声、または触覚入力を含む任意の形態で受信することができる。さらに、コンピュータは、たとえば、ウェブブラウザから受信された要求に応答して、ユーザのデバイス上のウェブブラウザにウェブページを送信することによってなど、ユーザによって使用されるデバイスとの間でドキュメントを送受信することによって、ユーザと対話することができる。また、コンピュータは、テキストメッセージまたは他の形態のメッセージをパーソナルデバイス、たとえば、メッセージングアプリケーションを実行しているスマートフォンに送信し、代わりに、ユーザから応答メッセージを受信することによって、ユーザと対話することができる。
【0149】
機械学習モデルを実装するためのデータ処理装置はまた、たとえば、機械学習のトレーニングまたは製作、すなわち推論、作業負荷の共通部分および計算集約的部分を処理するための専用ハードウェアアクセラレータユニットを含むこともできる。
【0150】
機械学習モデルは、機械学習フレームワーク、たとえば、TensorFlowフレームワーク、Microsoft Cognitive Toolkitフレームワーク、Apache Singaフレームワーク、またはApache MXNetフレームワークを使用して実装および展開することができる。
【0151】
本明細書に記載される主題の実施形態は、たとえばデータサーバとしてのバックエンド構成要素を含む、またはアプリケーションサーバなどのミドルウェア構成要素を含む、またはたとえば、ユーザが本明細書に記載される主題の実装と対話することができる、グラフィカルユーザインターフェース、ウェブブラウザ、またはアプリを有するクライアントコンピュータなどのフロントエンド構成要素を含む、または1つもしくは複数のそのようなバックエンド、ミドルウェア、またはフロントエンド構成要素の任意の組合せを含むコンピューティングシステムにおいて実装することができる。システムの構成要素は、たとえば、通信ネットワークなど、任意の形式または媒体のデジタルデータ通信によって相互接続することができる。通信ネットワークの例には、ローカルエリアネットワーク(LAN)およびワイドエリアネットワーク(WAN)、たとえばインターネットがある。
【0152】
コンピューティングシステムは、クライアントおよびサーバを含むことができる。クライアントとサーバとは、一般に、互いに遠隔であり、典型的には、通信ネットワークを介して対話する。クライアントとサーバとの関係は、それぞれのコンピュータ上で実行され、互いにクライアントサーバ関係を有するコンピュータプログラムによって生じる。いくつかの実施形態では、サーバは、たとえば、クライアントとして動作するデバイスと対話しているユーザにデータを表示し、ユーザからユーザ入力を受信するために、データ、たとえば、HTMLページをユーザデバイスに送信する。たとえば、ユーザ対話の結果など、ユーザデバイスにおいて生成されたデータは、デバイスからサーバにおいて受信することができる。
【0153】
本明細書は、多くの具体的な実施の詳細を含むが、これらは、いかなる発明の範囲または特許請求される可能性のある範囲に対する限定ではなく、むしろ特定の発明の特定の実施形態に固有であり得る特徴の説明として解釈されるものとする。別個の実施形態の文脈において本明細書に記載されるいくつかの特徴は、単一の実施形態において組み合わせて実装することもできる。逆に、単一の実施形態の文脈で記載されている様々な特徴は、複数の実施形態で別々にまたは任意の適切な部分組合せで実装することもできる。さらに、特徴は、いくつかの組合せで作用するものとして上述されており、当初はそのように請求されているが、いくつかの場合、請求された組合せからの1つまたは複数の特徴を、組合せから削除することができ、請求された組合せは、部分組合せ、または部分組合せの変形を対象とし得る。
【0154】
同様に、動作が図面に示され、特許請求の範囲に特定の順序で記載されているが、これは、そのような動作が、示された特定の順序で、または逐次的な順序で実行されること、あるいは望ましい結果を達成するために、図示されたすべての動作が実行されることを必要とするものとして理解されないものとする。いくつかの状況では、マルチタスキングおよび並列処理が有利であり得る。さらに、上述した実施形態における様々なシステムモジュールおよび構成要素の分離は、すべての実施形態においてそのような分離を必要とするものと理解されないものとし、記述されたプログラム構成要素およびシステムを、一般に、単一のソフトウェア製品に一緒に組み入れることができ、または複数のソフトウェア製品にパッケージ化することができることを理解されたい。
【0155】
主題の特定の実施形態が記載されている。他の実施形態は、以下の特許請求の範囲内にある。たとえば、特許請求の範囲に列挙されたアクションは、異なる順序で実行され、依然として望ましい結果を達成することができる。一例として、添付の図面に示されるプロセスは、望ましい結果を達成するために、示された特定の順序または逐次的な順序を必ずしも必要としない。いくつかの場合には、マルチタスキングおよび並列処理が有利であり得る。
【符号の説明】
【0156】
100 画像拡張システム
102 画像
104 拡張画像
106 列
108 生成ネットワーク入力
110 生成ニューラルネットワーク
112 ベースライン画像
114 マスク画像
116 敵対的訓練システム
200 データフロー
202 弁別ニューラルネットワーク
204 敵対的損失目的関数
206 ターゲット拡張画像
208 ベースライン画像
210 マスク画像
212 訓練拡張画像
214 正規化エンジン
216 ニューラルネットワーク層
218 中間層
220 再構成目的関数
300 拡張画像
302 元の画像
400 環境
402 ネットワーク
404 電子ドキュメントサーバ
406 クライアントデバイス
408 デジタルコンポーネントサーバ
410 デジタルコンポーネント配信システム
412 コンポーネント要求
414 複数のコンピューティングデバイスのセット
416 デジタルコンポーネントデータベース
417a~417c タスク
418a~418c 結果
420 応答データ
421 サーバ要求(SR)
422 デジタルコンポーネントデータ(DCデータ)
450 検索システム
452 検索インデックス
502 ロゴ
504 テキストのセグメント
506 対話型要素
508 第1の部分
510 第2の部分
602 追加の要素
604 第1の部分
606 第2の部分
700 ユーザインターフェース
702 画像
704-A~C 拡張画像
706 マウス
900 コンピュータシステム
910 プロセッサ
920 メモリ
930 記憶デバイス
940 入出力デバイス
950 システムバス
960 表示デバイス