(19)【発行国】日本国特許庁(JP)
(12)【公報種別】公開特許公報(A)
(11)【公開番号】P2022183045
(43)【公開日】2022-12-08
(54)【発明の名称】ニューラル・ネットワークを訓練するためのパラメータ推定の最適化
(51)【国際特許分類】
G06T 7/00 20170101AFI20221201BHJP
【FI】
G06T7/00 350C
【審査請求】未請求
【請求項の数】31
【出願形態】OL
【外国語出願】
(21)【出願番号】P 2022082067
(22)【出願日】2022-05-19
(31)【優先権主張番号】17/334,501
(32)【優先日】2021-05-28
(33)【優先権主張国・地域又は機関】US
【公序良俗違反の表示】
(特許庁注:以下のものは登録商標)
1.BLUETOOTH
2.ZIGBEE
3.LoRaWAN
4.SIGFOX
(71)【出願人】
【識別番号】501450960
【氏名又は名称】エヌビディア コーポレーション
(74)【代理人】
【識別番号】110000855
【氏名又は名称】弁理士法人浅村特許事務所
(72)【発明者】
【氏名】ダグアン シュ
(72)【発明者】
【氏名】ホルガー ラインハルト ロス
(72)【発明者】
【氏名】ドン ヤン
(72)【発明者】
【氏名】アンドリ― マイロネンコ
(72)【発明者】
【氏名】アリ ハタミザデー
(72)【発明者】
【氏名】ヴィシュウェシュ ナス
(72)【発明者】
【氏名】アナス ザイヌル アビディン
【テーマコード(参考)】
5L096
【Fターム(参考)】
5L096AA06
5L096AA09
5L096BA04
5L096BA06
5L096BA13
5L096EA11
5L096EA39
5L096FA34
5L096GA30
5L096HA11
5L096JA03
5L096JA22
5L096KA04
5L096MA07
(57)【要約】
【課題】訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのパラメータを推定する装置、システム、及び技法を提供すること。
【解決手段】少なくとも一実施例では、たとえば、訓練データの一意性に基づいて、1つ又は複数のニューラル・ネットワークを訓練するためのパラメータを推定するために、訓練データのサブセットが選択され、使用される。
【選択図】
図1
【特許請求の範囲】
【請求項1】
プロセッサであって、
1つ又は複数のニューラル・ネットワークを訓練するために使用されるデータの一意性に少なくとも部分的に基づいて前記1つ又は複数のニューラル・ネットワークを訓練するための1つ又は複数の回路を備える、プロセッサ。
【請求項2】
前記1つ又は複数の回路が、さらに、前記データの前記一意性に少なくとも部分的に基づいて前記1つ又は複数のニューラル・ネットワークを訓練するためのパラメータを推定するためのものである、請求項1に記載のプロセッサ。
【請求項3】
前記1つ又は複数の回路が、さらに、前記データの間の類似性を算出することによって前記データの一意性を示すための1つ又は複数の動作を実行するためのものである、請求項1に記載のプロセッサ。
【請求項4】
前記1つ又は複数の回路が、さらに、前記データの一意性を、少なくとも、
訓練画像内の関心領域を、前記データの他の訓練画像内の対応する関心領域と比較すること
によって算出するためのものである、請求項1に記載のプロセッサ。
【請求項5】
前記データが画像を含み、前記1つ又は複数の回路が、さらに、
画像を前記データの他の画像と比較することによって前記画像の一意性を示すスコアを算出することと、
複数のスコアを含むリストに前記スコアを記憶することと
を行うためのものである、請求項1に記載のプロセッサ。
【請求項6】
前記1つ又は複数の回路が、さらに、
前記リストに少なくとも部分的に基づいて前記データのサブセットを選択することと、
前記データの選択されている前記サブセットに基づいて前記1つ又は複数のニューラル・ネットワークを訓練するためのパラメータを推定するために、プロキシ・ニューラル・ネットワークを使用することであって、前記プロキシ・ニューラル・ネットワークが、前記1つ又は複数のニューラル・ネットワークのより小さい表現である、使用することと
を行うためのものである、請求項5に記載のプロセッサ。
【請求項7】
システムであって、
1つ又は複数のニューラル・ネットワークを訓練するために使用されるデータの一意性に少なくとも部分的に基づいて前記1つ又は複数のニューラル・ネットワークを訓練するための1つ又は複数のプロセッサを備える、システム。
【請求項8】
前記1つ又は複数のプロセッサが、さらに、
前記データの前記一意性に基づいて前記データのサブセットを識別することと、
前記データのサブセットに少なくとも部分的に基づいて前記1つ又は複数のニューラル・ネットワークを訓練するために使用される1つ又は複数の値を推定することと
を行うためのものである、請求項7に記載のシステム。
【請求項9】
1つ又は複数の値が、学習率、前記1つ又は複数のニューラル・ネットワークのサイズ、及び、前記1つ又は複数のニューラル・ネットワークのトポロジのうちの少なくとも1つを含む、請求項8に記載のシステム。
【請求項10】
前記1つ又は複数のプロセッサが、さらに、
前記データの1つ又は複数の画像から物体を識別することと、
前記物体を前記1つ又は複数の画像からの対応する物体と比較することと、
前記物体と前記対応する物体との間の類似性を表すインジケータを生成することと、
前記インジケータをリストに記憶することであって、前記リストが、ランク付けされた順序で配列されている複数のインジケータを含む、記憶することと
を行うためのものである、請求項7に記載のシステム。
【請求項11】
前記1つ又は複数のプロセッサが、さらに、
前記リストに基づいて前記データのサブセットを識別することと、
前記データの前記サブセットに基づいて前記1つ又は複数のニューラル・ネットワークを訓練するために使用される1つ又は複数の値を推論するために異なるニューラル・ネットワークを使用することであって、前記異なるニューラル・ネットワークが、前記1つ又は複数のニューラル・ネットワークの一部分である、使用することと
を行うためのものである、請求項10に記載のシステム。
【請求項12】
前記1つ又は複数のニューラル・ネットワークが、U-Netを含み、
前記異なるニューラル・ネットワークが、前記U-Netの一部分を含み、残差ブロック、チャネル、及びレベルのうちの少なくとも1つが、前記U-Netと比較して低減されている、請求項11に記載のシステム。
【請求項13】
方法であって、
1つ又は複数のニューラル・ネットワークを訓練するために使用されるデータの一意性に少なくとも部分的に基づいて前記1つ又は複数のニューラル・ネットワークを訓練するステップ
を含む、方法。
【請求項14】
物体を含む画像内の領域を識別するために前記データを使用するステップと、
前記物体を含む複数の他の画像内の他の領域を識別するために前記データを使用するステップと、
類似性スコアを生成するために前記領域と前記他の領域とを比較するステップと、
前記類似性スコアをインデックスに追加するステップであって、前記インデックスは、前記類似性スコアに基づくランク付けされた順序を含む、追加するステップと
をさらに含む、請求項13に記載の方法。
【請求項15】
類似性スコアが、前記領域内の前記物体と前記他の領域内の前記物体との間の非類似性に基づいて、より高い前記インデックスにランク付けされる、請求項14に記載の方法。
【請求項16】
前記インデックスに基づいて前記データのサブセットを識別するステップと、
前記データの前記サブセットに基づいて前記1つ又は複数のニューラル・ネットワークを訓練するためのパラメータを推定するために使用される1つ又は複数の値を生成するために異なるニューラル・ネットワークを使用するステップと
をさらに含む、請求項14に記載の方法。
【請求項17】
前記データの1つ又は複数の医療画像の間の相互情報に基づいて前記データの一意性を示すための動作を実行するステップをさらに含む、請求項13に記載の方法。
【請求項18】
前記1つ又は複数のニューラル・ネットワークが、畳み込みニューラル・ネットワークを含む、請求項13に記載の方法。
【請求項19】
命令セットを記憶されている機械可読媒体であって、前記命令セットが、1つ又は複数のプロセッサによって実行されると、前記1つ又は複数のプロセッサに、少なくとも、
1つ又は複数のニューラル・ネットワークを訓練するために使用されるデータの一意性に少なくとも部分的に基づいて前記1つ又は複数のニューラル・ネットワークが訓練されるようにすること
を行わせる、機械可読媒体。
【請求項20】
前記さらなる命令セットが、前記1つ又は複数のプロセッサによって実行されると、前記1つ又は複数のプロセッサに、
前記データの画像から物体を識別することと、
前記データの他の画像から前記物体を識別することと、
前記画像からの前記物体と前記他の画像からの前記物体との間の非類似性に基づいてスコアを生成することと、
前記スコアをテーブルに追加することであって、前記テーブルが、複数のスコアをソートされた順序において含む、追加することと
を行わせる命令をさらに含む、請求項19に記載の機械可読媒体。
【請求項21】
前記さらなる命令セットが、前記1つ又は複数のプロセッサによって実行されると、前記1つ又は複数のプロセッサに、
前記データのサブセットを選択するために前記テーブルを使用することと、
前記サブセットに基づいて前記1つ又は複数のニューラル・ネットワークを訓練するために使用される1つ又は複数のハイパー・パラメータを推定するために、前記1つ又は複数のニューラル・ネットワークとは異なる代替的なニューラル・ネットワークを使用することと
を行わせる命令をさらに含む、請求項20に記載の機械可読媒体。
【請求項22】
前記さらなる命令セットが、前記1つ又は複数のプロセッサによって実行されると、前記1つ又は複数のプロセッサに、前記データの間の非類似性を算出することによって前記データの一意性を示すための動作を実行させる命令をさらに含む、請求項19に記載の機械可読媒体。
【請求項23】
前記データが、オーディオ・データを含む、請求項19に記載の機械可読媒体。
【請求項24】
前記1つ又は複数のニューラル・ネットワークが、U-Netを含む、請求項19に記載の機械可読媒体。
【請求項25】
システムであって、
1つ又は複数のニューラル・ネットワークを訓練するために使用されるデータの一意性に少なくとも部分的に基づいて前記1つ又は複数のニューラル・ネットワークを訓練するための1つ又は複数のプロセッサを有する1つ又は複数のコンピュータを備える、システム。
【請求項26】
前記1つ又は複数のプロセッサが、さらに、
前記データの前記一意性に基づいて前記1つ又は複数のニューラル・ネットワークを訓練するためのハイパー・パラメータを算出するためのものである、請求項25に記載のシステム。
【請求項27】
前記ハイパー・パラメータが、前記1つ又は複数のニューラル・ネットワークの構造、及び、前記1つ又はニューラル・ネットワークがどのように訓練されるべきかを示す1つ又は複数の変数を含む、請求項26に記載のシステム。
【請求項28】
前記1つ又は複数のプロセッサが、さらに、
前記データから得られる画像のセットの間で1つ又は複数の物体を比較することによってスコアを生成することであって、前記スコアが、第1の画像内の物体と、他の画像内の対応する物体との間の類似性を示す情報を含む、生成することと、
複数のスコアを含むリストに前記スコアを記憶することと
を行うためのものである、請求項25に記載のシステム。
【請求項29】
前記1つ又は複数のプロセッサが、さらに、前記複数のスコアに基づいて前記1つ又は複数のニューラル・ネットワークを訓練するために使用されるパラメータを推定するための前記データの一部分を選択するために、前記リストを使用するためのものである、請求項28に記載のシステム。
【請求項30】
前記1つ又は複数のニューラル・ネットワークが、再帰ニューラル・ネットワーク(RNN)を含む、請求項25に記載のシステム。
【請求項31】
前記データが、医療画像を含む、請求項25に記載のシステム。
【発明の詳細な説明】
【技術分野】
【0001】
少なくとも一実施例は、1つ又は複数のニューラル・ネットワークを訓練するために使用されるデータの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためにリソースを処理することに関する。たとえば、少なくとも一実施例は、本明細書に記載されている様々な新規の技法に従って、1つ又は複数のニューラル・ネットワークを訓練するために使用されるパラメータを推定するための、訓練データのサブセットを、訓練データの一意性に基づいて選択するために使用されるプロセッサ又はコンピューティング・システムに関する。
【発明の概要】
【0002】
様々な文脈において、ニューラル・ネットワーク・モデルを訓練するためのパラメータを推定するために利用される訓練データを決定することは、困難であり得る。多くの場合、訓練データは、高次元であり、したがって、パラメータを推定するために多大な計算コストを必要とする医療画像を含む。訓練データが、サイズが大きい画像を含む場合、ニューラル・ネットワークを訓練するためのパラメータを推定するために使用されるメモリ容量、時間、又は計算リソースが重要になる。訓練データからニューラル・ネットワークを訓練するためのパラメータを推定するために使用されるメモリ容量、時間、又は計算リソースには、改善の余地がある。
【図面の簡単な説明】
【0003】
【
図1】少なくとも一実施例による、1つ又は複数のニューラル・ネットワークが訓練データの一意性に基づいて訓練される例示的なフレームワークを示す図である。
【
図2】少なくとも一実施例による、訓練データの一意性に基づいてニューラル・ネットワークを訓練するための訓練データのサブセットを選択するための例示的なフレームワークを示す図である。
【
図3】少なくとも一実施例による、訓練データの一意性に基づいてニューラル・ネットワークを訓練するためのフレームワークを使用したときの結果の例示的な視覚化を示す図である。
【
図4】少なくとも一実施例による、訓練データの一意性に基づいてニューラル・ネットワークを訓練するためのフレームワークを使用したときの検証スコアの例示的視覚化を示す図である。
【
図5】少なくとも一実施例による、訓練データの一意性に基づいてニューラル・ネットワークを訓練するためのフレームワークを使用したときの結果の例示的な視覚化を示す図である。
【
図6】少なくとも一実施例による、訓練データの一意性に基づいてニューラル・ネットワークを訓練するためのプロセスの実例を示す図である。
【
図7】少なくとも一実施例による、訓練データの一意性に基づいてニューラル・ネットワークを訓練するために使用されるパラメータを推定するプロセスの実例を示す図である。
【
図8A】少なくとも一実施例による、推論及び/又は訓練論理を示す図である。
【
図8B】少なくとも一実施例による、推論及び/又は訓練論理を示す図である。
【
図9】少なくとも一実施例による、ニューラル・ネットワークの訓練及び展開を示す図である。
【
図10】少なくとも一実施例による、例示的データ・センタ・システムを示す図である。
【
図11A】少なくとも一実施例による、自律車両の実例を示す図である。
【
図11B】少なくとも一実施例による、
図11Aの自律車両のカメラのロケーション及び視野の実例を示す図である。
【
図11C】少なくとも一実施例による、
図11Aの自律車両の例示的システム・アーキテクチャを示すブロック図である。
【
図11D】少なくとも一実施例による、クラウド・ベースのサーバと
図11Aの自律車両との通信のためのシステムを示す図である。
【
図12】少なくとも一実施例による、コンピュータ・システムを示すブロック図である。
【
図13】少なくとも一実施例による、コンピュータ・システムを示すブロック図である。
【
図14】少なくとも一実施例による、コンピュータ・システムを示す図である。
【
図15】少なくとも一実施例による、コンピュータ・システムを示す図である。
【
図16A】少なくとも一実施例による、コンピュータ・システムを示す図である。
【
図16B】少なくとも一実施例による、コンピュータ・システムを示す図である。
【
図16C】少なくとも一実施例による、コンピュータ・システムを示す図である。
【
図16D】少なくとも一実施例による、コンピュータ・システムを示す図である。
【
図16E】少なくとも一実施例による、共有プログラミング・モデルを示す図である。
【
図16F】少なくとも一実施例による、共有プログラミング・モデルを示す図である。
【
図17】少なくとも一実施例による、例示的な集積回路及び関連するグラフィックス・プロセッサを示す図である。
【
図18A】少なくとも一実施例による、例示的な集積回路及び関連グラフィックス・プロセッサを示す図である。
【
図18B】少なくとも一実施例による、例示的な集積回路及び関連グラフィックス・プロセッサを示す図である。
【
図19A】少なくとも一実施例による、追加の例示的グラフィックス・プロセッサ論理を示す図である。
【
図19B】少なくとも一実施例による、追加の例示的グラフィックス・プロセッサ論理を示す図である。
【
図20】少なくとも一実施例による、コンピュータ・システムを示す図である。
【
図21A】少なくとも一実施例による、並列プロセッサを示す図である。
【
図21B】少なくとも一実施例による、パーティション・ユニットを示す図である。
【
図21C】少なくとも一実施例による、処理クラスタを示す図である。
【
図21D】少なくとも一実施例による、グラフィックス・マルチプロセッサを示す図である。
【
図22】少なくとも一実施例による、マルチ・グラフィックス・プロセッシング・ユニット(GPU)システムを示す図である。
【
図23】少なくとも一実施例による、グラフィックス・プロセッサを示す図である。
【
図24】少なくとも一実施例による、プロセッサ用のプロセッサ・マイクロ・アーキテクチャを示すブロック図である。
【
図25】少なくとも一実施例による、深層学習アプリケーション・プロセッサを示す図である。
【
図26】少なくとも一実施例による、例示的ニューロモーフィック・プロセッサを示すブロック図である。
【
図27】1つ又は複数の実施例による、グラフィックス・プロセッサの少なくとも一部分を示す図である。
【
図28】1つ又は複数の実施例による、グラフィックス・プロセッサの少なくとも一部分を示す図である。
【
図29】1つ又は複数の実施例による、グラフィックス・プロセッサの少なくとも一部分を示す図である。
【
図30】少なくとも一実施例によるグラフィックス・プロセッサのグラフィックス処理エンジンのブロック図である。
【
図31】少なくとも一実施例による、グラフィックス・プロセッサ・コアの少なくとも一部分のブロック図である。
【
図32A】少なくとも一実施例による、グラフィックス・プロセッサ・コアの処理要素のアレイを含むスレッド実行論理を示す図である。
【
図32B】少なくとも一実施例による、グラフィックス・プロセッサ・コアの処理要素のアレイを含むスレッド実行論理を示す図である。
【
図33】少なくとも一実施例による、並列処理ユニット(「PPU」)を示す図である。
【
図34】少なくとも一実施例による、汎用処理クラスタ(「GPC」)を示す図である。
【
図35】少なくとも一実施による、並列処理ユニット(「PPU」)のメモリ・パーティション・ユニットを示す図である。
【
図36】少なくとも一実施例による、ストリーミング・マルチプロセッサを示す図である。
【
図37】少なくとも一実施例による、先進コンピューティング・パイプラインの例示的なデータ・フロー図である。
【
図38】少なくとも一実施例による、先進コンピューティング・パイプラインにおいて機械学習モデルを訓練、適合、インスタンス化及び展開するための例示的なシステムのシステム図である。
【
図39】少なくとも一実施例による、イメージング・データを処理するための先進コンピューティング・パイプライン3810Aの例示的な図解を含む図である。
【
図40A】少なくとも一実施例による、超音波デバイスをサポートする仮想機器の例示的なデータ・フロー図である。
【
図40B】少なくとも一実施例による、CTスキャナをサポートする仮想機器の例示的なデータ・フロー図である。
【
図41A】少なくとも一実施例による、機械学習モデルを訓練するプロセスのデータ・フロー図である。
【
図41B】少なくとも一実施例による、事前に訓練されたアノテーション・モデルによってアノテーション・ツールを強化するためのクライアント・サーバ・アーキテクチャの例示的な図である。
【発明を実施するための形態】
【0004】
少なくとも一実施例では、医療画像セグメント化のための深層学習モデルは、主にデータ駆動型である。少なくとも一実施例では、より多くのデータを用いて訓練されたモデルは、性能及び一般化可能性の改善をもたらす。少なくとも一実施例では、ニューラル・ネットワークは、様々な医学的事象(たとえば、疾患、傷害など)に対応する様々なパターンを学習するように訓練される。少なくとも一実施例では、医療画像が、訓練のためにニューラル・ネットワークに供給される。少なくとも一実施例では、パラメータ(たとえば、学習率、ニューラル・ネットワークのサイズ、ニューラル・ネットワークのトポロジ)が推定され、1つ又は複数のニューラル・ネットワークを訓練するときに使用される。少なくとも一実施例では、ニューラル・ネットワークの訓練に使用するのに最良に適するパラメータを決定することができる。
【0005】
ニューラル・ネットワークは、多くの場合、医療画像から情報を推論するように訓練される。多くの事例において、医療画像は、高次元であり、訓練を支援する大量の情報(たとえば、ラベル)とともに得られる。データ駆動型方法が、コンピュータ断層撮影(CT)及び磁気共鳴イメージング(MRI)などのほとんどのイメージング・モダリティの医療画像セグメント化ベースのタスクのための主な手法になってきている。しかしながら、深層学習方法の性能は、モデルを訓練するときに利用される、本明細書においてはハイパー・パラメータ又は値としても参照されるパラメータ(たとえば、学習率、オプティマイザ、水増し確率など)に大いに依存する。ハイパー・パラメータ最適化(HPO)は、自動機械学習(AutoML)又は別のシステムを使用することによって実行することができるが、データが高次元である、すなわち、三次元(3D)ボリュームであることが多い医療イメージング・タスクによって計算コストが深刻になるため、AutoML及び他のシステムを使用することは、一般的に、極めて計算コストがかかるプロセスである。
【0006】
少なくとも一実施例では、ニューラル・ネットワークを訓練するために使用されるパラメータは、訓練データセット全体を表すにもかかわらず、サイズが相対的にはるかに小さいプロキシ・データセットを最初に構築することによって、効率的に決定することができる。プロキシ・データセットはまた、本明細書においては、プロキシ・データ、訓練データの一部分、又は訓練データのサブセットとして参照される場合もある。少なくとも一実施例では、ニューラル・ネットワークを訓練するために使用されるパラメータは、プロキシ・データセット、及び、本質的により小さいネットワークであるにもかかわらず、より大きい/完全なネットワーク構造を表す1つ又は複数のプロキシ・モデルを使用して推定することができる。少なくとも一実施例では、プロキシ・データセットとプロキシ・ネットワークの両方を利用して、AutoMLの計算負担を大幅に低減することができ(たとえば、数日から数時間へ)、それにもかかわらず、性能の改善をもたらすことができるパラメータを推定することが可能であり得る。少なくとも一実施例では、プロキシ・データセット及びプロキシ・モデルを使用することによって、パラメータをより効率的且つ正確に計算するようにすることができる。少なくとも一実施例では、本明細書に記載の技法は、相互情報及び正規化相互相関の従来の計量基準を介してプロキシ・データセットを構築する。少なくとも一実施例では、プロキシ・ネットワーク(たとえば、プロキシ・ニューラル・ネットワーク)は、畳み込みニューラル・ネットワーク(たとえば、U-net)の残差ブロック、チャネル及び/又はレベル数の低減によって体系的に再構築することができる。少なくとも一実施例では、本明細書に記載の技法は、複数の異なるイメージング・モダリティにわたって一般化することができる。
【0007】
少なくとも一実施例では、プロセッサは、訓練データの一意性(たとえば、訓練データの間の類似性)に基づいてニューラル・ネットワークを訓練するためにパラメータ推定を実行するための1つ又は複数の回路を備える。少なくとも一実施例では、上記プロセッサは、コンピュータ可読記憶媒体に記憶されている命令を実行することによって、パラメータ推定を実行し、上記プロセッサは、下記に記載のように、システムの一部であってもよい。少なくとも一実施例では、データの一意性は、訓練データ内の様々なデータの間の類似性に少なくとも部分的に基づいて決定される。少なくとも一実施例では、類似性は、最初に、訓練データからの訓練画像内の関心領域を識別することによって決定される。少なくとも一実施例では、上記関心領域は、訓練データからの他の訓練画像内の対応する関心領域と比較される。少なくとも一実施例では、一意性を示すスコア(たとえば、重要性スコア、類似性スコア、インジケータ)が、上記比較に基づいて生成される。少なくとも一実施例では、上記スコアは、スコアのリスト(たとえば、インデックス、テーブル)に追加される。少なくとも一実施例では、上記リストは、ランク順に配列されたスコアを含む。少なくとも一実施例では、他の画像の関心領域に対する関心領域の類似性がより低いほど、類似性の低い画像は他の画像に対して冗長でないため、上記関心領域はより高いスコアを有することになる。少なくとも一実施例では、訓練データからのすべての訓練画像が分析され、他の訓練画像内の関心領域に対する上記訓練画像内の関心領域の類似性がどれだけ高い又は低いかに基づいて、スコアを割り当てられる。少なくとも一実施例では、1つ又は複数の回路を備えるプロセッサは、上記リスト内のスコアに基づいて訓練画像のサブセットを使用することによってニューラル・ネットワークを訓練するためにパラメータ推定を実行する。少なくとも一実施例では、訓練画像のサブセットは、各訓練画像と関連付けられる上記スコアに基づいて選択される。少なくとも一実施例では、1つ又は複数の回路を備えるプロセッサは、プロキシ・モデル(たとえば、訓練されるべき上記ニューラル・ネットワークとは異なる機械学習モデル)を生成し、訓練画像の選択されたサブセットを使用して上記ニューラル・ネットワークを訓練するためのパラメータを推定(たとえば、算出、決定)する。少なくとも一実施例では、各画像にスコアを与えることによって、パラメータを推定するために使用されるデータは、データ・セット全体をより代表するものであり、したがって、結果として、ニューラル・ネットワークを訓練するときにパラメータをより効率的且つ正確に算出することができるようになる。
【0008】
図1は、少なくとも一実施例による、1つ又は複数のニューラル・ネットワーク116が訓練データ102の一意性に基づいて訓練される例示的なフレームワーク100を示す。少なくとも一実施例では、フレームワーク100は、ネットワーク104を通じて得られる訓練データ102を通じてモデル116を訓練するように構成されている1つ又は複数のグラフィックス・プロセッシング・ユニット(GPU)を含む。少なくとも一実施例では、GPU106は、訓練データ102の一意性に基づいてモデル116を訓練するために使用することができるパラメータ114を推定するための、訓練データ102の部分(たとえば、プロキシ・データ)110を選択する。
【0009】
少なくとも一実施例では、GPU106は、1つ又は複数のグラフィックス処理システムを含む。少なくとも一実施例では、GPU106は並列処理ユニット(PPU)である。少なくとも一実施例では、GPU106は、モデル112、116などの様々なモデル及び/又はニューラル・ネットワークを実施し、訓練する1つ又は複数の回路を備える1つ又は複数のプロセッサである。少なくとも一実施例では、モデル112、116は、入力データの1つ又は複数の特徴が属する1つ又は複数のカテゴリを識別する分類モデルである。少なくとも一実施例では、モデル112、116は、マルチ・ラベル分類モデルである。少なくとも一実施例では、モデル112、116は、1つ又は複数のニューラル・モデルを含む。少なくとも一実施例では、モデル112、116は、1つ又は複数の畳み込みニューラル・ネットワーク(CNN)アーキテクチャを含む。少なくとも一実施例では、モデル112、116は、U-netである。少なくとも一実施例では、モデル112、116は、入力データに基づいて入力データの1つ又は複数の態様を分類する1つ又は複数のニューラル・ネットワークを含む。少なくとも一実施例では、モデル112、116は、医療イメージング・データの1つ又は複数の特徴を分類する1つ又は複数のニューラル・ネットワークを含む。少なくとも一実施例では、モデル112、116は、様々なニューラル・ネットワーク、画像特徴検出、及び埋め込み生成構成要素を含む。
【0010】
少なくとも一実施例では、訓練データ102は、ネットワーク104を通じてGPU106によって得られる。少なくとも一実施例では、ネットワーク104は、GPU106と1つ又は複数の他のシステムとの間の任意の適切な通信経路を表す。少なくとも一実施例では、ネットワーク104は、インターネット、ローカル・エリア・ネットワーク、広域ネットワーク、及び/又はそれらの変形などの、1つ又は複数のネットワークを含む。少なくとも一実施例では、異なるタイプのネットワーク104が、下記の
図20に関連して説明される。少なくとも一実施例では、訓練データ102は、画像データ及び関連するテキスト・データを含む。少なくとも一実施例では、画像データは、二次元(2D)、三次元(3D)、及び/又は四次元(4D)医療画像を含む。少なくとも一実施例では、訓練データ102は、
図1に示されていない外部サービス又はストレージ・デバイスから得られる医療画像を含む。少なくとも一実施例では、訓練データ102は、1つ又は複数のカメラ、医療イメージング設備(たとえば、X線)、スキャナ、又は画像記録デバイスによって捕捉されるデータを含む。少なくとも一実施例では、訓練データ102は、ビデオ、音響、及び/又は発話データを含む。
【0011】
少なくとも一実施例では、GPU106は、訓練データ102(訓練画像を含む)を処理して、ニューラル・ネットワークがどのように訓練されるかを制御するために使用されるパラメータ(たとえば、ハイパー・パラメータ、値)を推定する。少なくとも一実施例では、GPUは、訓練されるべきニューラル・ネットワーク116が訓練データを訓練に使用する前に、訓練データ102を処理して、パラメータを推定する。少なくとも一実施例では、パラメータは、ネットワーク構造(たとえば、隠れ層の数)を決定し、及び/又は、ネットワークがどのように訓練されるか(たとえば、学習率)を決定する変数である。少なくとも一実施例では、パラメータは、活性化関数、ドロップ・アウト正規化、及びニューロン数の値を含む。少なくとも一実施例では、パラメータは、ニューラル・ネットワークを訓練する前に(重み及びバイアスを最適化する前に)設定され、調節可能である。少なくとも一実施例では、GPU106は、各訓練画像内の関心領域を決定し、スコア108を算出する。少なくとも一実施例では、訓練画像内の関心領域は、訓練されているニューラル・ネットワーク116によって認識されることになる特定の物体の周りの境界ボックスを使用して決定される。少なくとも一実施例では、
図1は、各訓練画像が、出荷箱(ただし、他の製品、又は医療画像の場合は臓器が、出荷箱に加えて使用されてもよい)に類似した製品の周りの境界ボックスを含み、上記関心領域が、上記訓練画像内のすべての他の関心の他の対応する関心領域と比較される。少なくとも一実施例では、第1の画像内のボックスが、対応する画像内の他のボックスと比較される。少なくとも一実施例では、GPU106は、(10のうち)1の値などのスコア(たとえば、類似性スコア、重要性スコア、インジケータ)を算出し、上記比較に基づいて、上記スコアを第1の画像内の関心領域に割り当てる。スコアを0~10のスケールに割り当てることは1つの例示的な実施例にすぎず、スコアリング方法は変化してもよく(たとえば、1~100のスコアを割り当てる)、0~10のスケールに基づくスコアに限定されない。少なくとも一実施例では、上記スコアは、リストに記憶され、追加される。少なくとも一実施例では、上記リストは、ストレージ・デバイス、バッファ、キャッシュ、又は、データを記憶するように構成されている任意の記憶媒体に記憶される。少なくとも一実施例では、(10のうち)1のスコアは、上記関心領域内の上記物体が、対応する画像内の他の出荷箱物体に非常に類似していることを示す。少なくとも一実施例では、上記スコア及び訓練画像は、その後、上記リスト内の他のスコアよりも低いランク付けとともに記憶される。少なくとも一実施例では、関心領域の、対応する画像内の他の関心領域への類似性がより低い場合、類似性の低い画像は他の画像に対して冗長でないため、より高い重要性スコアが割り当てられることになる。関心領域間の比較に基づいてリスト内にスコアを記憶し、対応する関心領域間の非類似性に基づいてより高くスコアをランク付けすることは、1つの例示的な実施例にすぎず、スコアを記憶及びランク付けする他の方法(たとえば、より高い類似性を有するスコアを、より低くランク付けする代わりに、より高くランク付けする)を利用することもできる。少なくとも一実施例では、リストは、昇順又は降順のいずれかにソートされた順序でスコアを記憶するように構成されている。
【0012】
少なくとも一実施例では、GPU106はその後、上記リストを使用して、訓練データのサブセット(たとえば、プロキシ・データ)110を識別する。少なくとも一実施例では、訓練画像のサブセット110は、上記リストからの重要性スコアに基づいて選択される。少なくとも一実施例では、GPU106は、プロキシ・データ110を使用して、訓練のためのパラメータが何であるべきかを推定する114。少なくとも一実施例では、プロキシ・データ110は、全訓練データ102の約15%である(ただし、他の割合も適用可能である)。少なくとも一実施例では、GPU106は、訓練されるべき上記ニューラル・ネットワーク116とは異なるニューラル・ネットワーク(たとえば、プロキシ・ネットワーク)112を使用して、プロキシ・データ110に基づいてパラメータ114を推定する。少なくとも一実施例では、プロキシ・ネットワーク112は、訓練されるべきニューラル・ネットワーク116と比較して低減した数のレベル、チャネル、及び/又は残差ブロックを有するU-netである。少なくとも一実施例では、GPU106は、プロキシ・ネットワーク112を使用して、プロキシ・データ110に基づいてパラメータを推定する114。少なくとも一実施例では、GPU106はその後、完全に訓練された機械学習モデル(たとえば、ニューラル・ネットワーク・モデル)をもたらすために、推定されたパラメータ114及び訓練データ102を使用してモデル116を訓練する。
【0013】
図2は、少なくとも一実施例による、訓練データの一意性に基づいてニューラル・ネットワークを訓練するための訓練データのサブセットを選択するための例示的なフレームワーク200を示す。フレームワーク200の上面図は、パラメータ推定を実行するために使用することができる方法(たとえば、すべてのデータ又はデータのランダムなサブセットを使用する)を示す。少なくとも一実施例では、1つ又は複数の回路を備えるプロセッサは、フレームワーク200の最下行を実行して、データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練する。少なくとも一実施例では、1つ又は複数の回路を備えるプロセッサは、フレームワーク200の最下行を実行して、データの一意性(たとえば、入力訓練データの間の類似性)に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのパラメータを推定する。少なくとも一実施例では、GPUは、1つ又は複数のニューラル・ネットワークを訓練するために使用されるデータ(たとえば、3D医療画像を含む訓練データ)を取得する。少なくとも一実施例では、プロキシ・データ(たとえば、すべてのデータの一意性に基づいて決定されるデータのサブセット)が選択され、プロキシ・ネットワーク(たとえば、訓練されるべき上記1つ又は複数のニューラル・ネットワークのより小さい表現)を使用して訓練される。少なくとも一実施例では、GPUは、上記プロキシ・ネットワーク及びプロキシ・データを使用してパラメータを推定(たとえば、算出)する。少なくとも一実施例では、GPUは、その後、すべてのデータ及び上記推定パラメータを使用して、上記1つ又は複数のニューラル・ネットワークを訓練する。
【0014】
少なくとも一実施例では、プロキシ・データ選択戦略が実行される。少なくとも一実施例では、プロキシ・データを選択するために、データ点のセット{x
1,x
2,…x
n }を含むデータセットDが決定され、x
iは単一のデータ・サンプルである。データ点はまた、本明細書においては、訓練データ内の関心領域として参照される場合もある。少なくとも一実施例では、単一のデータ点x
iの重要性を推定するために、各データ点のユーティリティが、他のデータ点x
jに関連して推定され、結果として、対にされた測度のセットがもたらされる。少なくとも一実施例では、x
1の対は{(x
1,x
1),(x
1,x
2),(x
1,x
3)..(x
1,x
n)}となる。少なくとも一実施例では、上記測度の平均が、各データ点の重要性のインジケータ(たとえば、他のデータ点の間での各データ点間の類似性を表すインジケータ)として利用される。少なくとも一実施例では、下記の式1に示される相互情報(MI)が、 3D画像の平坦化ベクトル、及び、 異なる変形形態としての各データ対(x
i,x
j)の(9,9,9)のローカル・ウィンドウ・サイズ内の正規化局所的相互相関(NCC)に対して測定される。
【数1】
【0015】
少なくとも一実施例では、P(x
i)及びP(x
j)は、周辺確率分布であり、一方、P(x
i,x
j)は、同時確率分布である。
【数2】
【0016】
少なくとも一実施例では、p
iは、pの周りのウィンドウ内の3Dボクセル位置であり、
【数3】
及び
【数4】
は、対応して、x
i、x
j内のボクセル位置p
iを取り巻くウィンドウ内の局所平均である。少なくとも一実施例では、Ωはボクセル座標空間である。
【0017】
少なくとも一実施例では、上記画像の間の類似性を決定するための訓練画像の比較は、タスク特有の関心領域に焦点を当てる。少なくとも一実施例では、異なる3Dボリューム・スキャンの取得パラメータ(たとえば、スライスの数、解像度など)は変化し得る。少なくとも一実施例では、対(xi,xj)を考慮するとき、たとえxiがxj画像サイズに再サンプリングされる場合であっても、関心領域(ROI)(たとえば、モデルによってアノテーションを付されるべき臓器)の不整合が存在する。少なくとも一実施例では、既存のラベルから情報を分析することによって、タスク特有のROIが利用される。少なくとも一実施例では、選択されたボリュームが、ROIを使用してトリミングされ、立方体パッチ・サイズに再サンプリングされる。少なくとも一実施例では、データ点は、重要性によってランク付けされ、最も低い相互情報又は最も低い相関を含むデータ点が、所与のバジェットB(たとえば、利用可能な計算リソースの量)内で選択される。
【0018】
少なくとも一実施例では、訓練されるべき上記ニューラル・ネットワークよりも小さいバージョンのU-netである。少なくとも一実施例では、U-netは、医療画像セグメント化タスクに使用される。少なくとも一実施例では、レベルあたり2つの残差ブロック、及び、エンコーダ・ブロックとデコーダ・ブロックとの間のスキップ接続を有する5レベルU-netが、訓練されるべきニューラル・ネットワークとして使用される。少なくとも一実施例では、U-netの粗いハイパー・パラメータは、第1のエンコーダ・ブロック内のチャネルの数(後続のエンコーダ・ブロックは2の倍数である)、残差ブロックの数及びレベルの数である。少なくとも一実施例では、プロキシ・ネットワークを作成するために、チャネルの数を4に低減することができ、残差ブロックが2から1へと低減される。少なくとも一実施例では、プロキシ・ネットワークの変形例は、レベルの数を5、4及び3へと低減すること(たとえば、符号化ブロック及び復号ブロックの数を低減すること)によって作成される。少なくとも一実施例では、ハイパー・パラメータを推定するためのオーバーアーチング強化学習(RL)の一部である再帰ニューラル・ネットワーク(RNN)が使用される。
【0019】
図3は、少なくとも一実施例による、訓練データの一意性に基づいてニューラル・ネットワークを訓練するためのフレームワークを使用したときの結果300の例示的な視覚化を示す。少なくとも一実施例では、訓練データの一意性に基づく訓練データのサブセットは、ハイパー・パラメータを効率的に推定するように選択することができる。少なくとも一実施例では、例示的な図解300は、異なるシードによる分割を示す。少なくとも一実施例では、画像「A)」は、Beyond the Cranial Vault(BTCV)外部データセットの「上界」ダイスであり、すべての医療セグメンテーション・デカスロン(MSD)データに関して訓練されるときに報告される。少なくとも一実施例では、これは、ハイパー・パラメータ空間にわたってプロキシ・データセットに関して訓練されるときに、BTCV上のダイスと比較される。少なくとも一実施例では、画像「B)」は、プロキシ・データの代わりに無作為データが使用されることを示す。少なくとも一実施例では、全データの24%がA)及びB)にそれぞれ使用された。少なくとも一実施例では、画像「C)」は、すべてのMSDデータに関して訓練されるときに報告されるPROSTATExによって提供される外部データセット上の「上界」ダイスを示す。少なくとも一実施例では、これは、ハイパー・パラメータ空間にわたってプロキシ・データセットに関して訓練されるときに、PROSTATEx上のダイスと比較される。少なくとも一実施例では、画像「D)」は、プロキシ・データの代わりに無作為データが使用されることを示す。少なくとも一実施例では、すべてのデータの31%がC)及びD)にそれぞれ使用された。少なくとも一実施例では、実例300は、プロキシ・データ選択方法によるデータの24%が全データセットの性能の最大90%を達成することができることを示している。
【0020】
図4は、少なくとも一実施例による、訓練データの一意性に基づいてニューラル・ネットワークを訓練するためのフレームワークを使用したときの検証スコアの例示的視覚化400を示す。少なくとも一実施例では、上の列の画像(たとえば、MSDからの脾臓タスク・データセットを使用する)は、グランド・トゥルースの内部検証に関するダイス・スコア対全データの使用にわたるプロキシ・ネットワークからのダイス・スコアのプロキシ・ネットワーク相関を示す。少なくとも一実施例では、画像は、左から右へと、U-netのレベルの数が5から3に低減していることを示す(左から右への対応するレベルは5、4、及び3である)。少なくとも一実施例では、すべてのプロキシU-netは4つのチャネルを有し、レベルあたり1つの残差ブロックを有する。少なくとも一実施例では、下の列の画像(たとえば、MSDからの前立腺タスク・データセットを使用する)は、変化したU-netのレベルの数を示し、脾臓と同様に、前立腺データの内部検証に関して相関が比較される。
【0021】
図5は、少なくとも一実施例による、訓練データの一意性に基づいてニューラル・ネットワークを訓練するためのフレームワークを使用することに関する結果の例示的な視覚化500を示す。少なくとも一実施例では、画像「A)」は、脾臓BTCVデータセットの結果を示し、ダイス・スコアが、データ使用に対してプロットされている。少なくとも一実施例では、画像「B)」は、PROSTATExデータセットの結果、及び、データ使用に対してプロットされているダイス・スコアを示す。少なくとも一実施例では、画像「C)」は、学習率及びグランド・トゥルースまでの相対距離による強度シフトの確率の推定ハイパー・パラメータを示す、脾臓データセットの結果を示す。少なくとも一実施例では、画像「D)」は、「C」に類似しているが、上記前立腺データセット例に関する結果を示す。
【0022】
図6は、少なくとも一実施例による、訓練データの一意性に基づいてニューラル・ネットワークを訓練するためのプロセス600の実例を示す。少なくとも一実施例では、プロセス600(或いは本明細書に記載の任意の他のプロセス又はその変形及び/若しくは組合せ)の一部又は全部は、コンピュータ実行可能命令で構成された1つ又は複数のコンピュータ・システムの制御下で実行され、1つ又は複数のプロセッサ上で、ハードウェア、ソフトウェア、又はそれらの組合せによって集合的に実行されるコード(たとえば、コンピュータ実行可能命令、1つ若しくは複数のコンピュータ・プログラム、又は1つ若しくは複数のアプリケーション)として実施される。少なくとも一実施例では、コードは、1つ又は複数のプロセッサによって実行可能な複数のコンピュータ読取り可能命令を備えるコンピュータ・プログラムの形で、コンピュータ可読記憶媒体に記憶される。少なくとも一実施例では、コンピュータ可読記憶媒体は、非一時的コンピュータ読取り可能媒体である。少なくとも一実施例では、プロセス600を実行するために使用可能な少なくともいくつかのコンピュータ読取り可能命令は、一時的な信号(たとえば、伝播する一時的な電気又は電磁送信)のみを使用して記憶されない。少なくとも一実施例では、非一時的コンピュータ読取り可能媒体は、必ずしも、一時的な信号のトランシーバ内の非一時的データ・ストレージ回路(たとえば、バッファ、キャッシュ、及びキュー)を含まない。少なくとも一実施例では、プロセス600は、少なくとも部分的に、本開示の他の箇所に記載のものなどのコンピュータ・システム上で実行される。少なくとも一実施例では、プロセス600は、1つ又は複数の画像内の1つ又は複数の物体の1つ又は複数のラベルに少なくとも部分的に基づいて1つ又は複数のニューラル・ネットワークを訓練するために使用される1つ又は複数の画像を識別するための1つ又は複数の回路によって実行される。
【0023】
少なくとも一実施例では、プロセス600の少なくとも一部を実行するシステムは、1つ又は複数のニューラル・ネットワークを訓練するための訓練データを取得する602ための実行可能コードを含む。少なくとも一実施例では、訓練データは、画像、医療画像、オーディオ・データなどを含む。少なくとも一実施例では、画像は、1つ又は複数のカメラ、イメージング・デバイス、又はスキャナから取得される。少なくとも一実施例では、画像データは、.tif、.jpg、.png.、.gifなどのフォーマットの画像を含む。少なくとも一実施例では、オーディオ・データは、音声の2進表現を含むデジタル・オーディオ・データである。少なくとも一実施例では、オーディオ・データは、生音声ファイル、波形オーディオ・ファイル、MPEG-1オーディオ・レイヤIII(MP3)ファイル、及び/又はリアル・オーディオ・メタデータ(RAM)ファイルを含む。少なくとも一実施例では、訓練データは、サーバ又はストレージ・デバイスから取得される。
【0024】
少なくとも一実施例では、プロセス600の少なくとも一部を実行するシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するための訓練データの一部分を選択する604ための実行可能コードを含む。少なくとも一実施例では、1つ又は複数のニューラル・ネットワークを訓練するために使用することができるハイパー・パラメータを推定するための訓練データの一部分が選択され、使用される。少なくとも一実施例では、上記で言及及び記載されているように、ハイパー・パラメータは、学習プロセスを制御するためにその値が使用されるパラメータである。少なくとも一実施例では、ハイパー・パラメータは、ニューラル・ネットワークのトポロジ、ニューラル・ネットワークのサイズ、学習率、及び入力バッチのサイズを示す。少なくとも一実施例では、データの一意性は、訓練データの間の類似性を指す。少なくとも一実施例では、訓練データの間の類似性は、訓練画像から物体を識別し、第1の画像内の物体と残りの画像内の物体との間の類似性スコアを割り当てることによって測定される。少なくとも一実施例では、上述したように、類似性スコアは、 画像内の1つの物体が別の画像内の上記物体にどれだけ類似しているかに関するスコアを計算する相互情報式(上記の式1に示す)を使用する。少なくとも一実施例では、類似性スコアは、リストに記憶される。少なくとも一実施例では、訓練データの一部分は、上記リストに基づいて選択される。少なくとも一実施例では、上記リストは、訓練データの間の対応する各物体に関するすべての類似性スコアを含み、各スコアは、ソート及び/又はランク付けされた順序に基づいて記憶される。少なくとも一実施例では、プロセス600の少なくとも一部を実行するシステムは、訓練データの一部分を使用して1つ又は複数のニューラル・ネットワークを訓練するためのハイパー・パラメータを推定する604ための実行可能コードを含む。
【0025】
図7は、少なくとも一実施例による、訓練データの一意性に基づいてニューラル・ネットワークを訓練するために使用されるパラメータを推定するプロセス700の実例を示す。少なくとも一実施例では、プロセス700(或いは本明細書に記載の任意の他のプロセス又はその変形及び/若しくは組合せ)の一部又は全部は、コンピュータ実行可能命令で構成された1つ又は複数のコンピュータ・システムの制御下で実行され、1つ又は複数のプロセッサ上で、ハードウェア、ソフトウェア、又はそれらの組合せによって集合的に実行されるコード(たとえば、コンピュータ実行可能命令、1つ若しくは複数のコンピュータ・プログラム、又は1つ若しくは複数のアプリケーション)として実施される。少なくとも一実施例では、コードは、1つ又は複数のプロセッサによって実行可能な複数のコンピュータ読取り可能命令を備えるコンピュータ・プログラムの形で、コンピュータ読取り可能ストレージ媒体に記憶される。少なくとも一実施例では、コンピュータ可読記憶媒体は、非一時的コンピュータ読取り可能媒体である。少なくとも一実施例では、プロセス700を実行するために使用可能な少なくともいくつかのコンピュータ読取り可能命令は、一時的な信号(たとえば、伝播する一時的な電気又は電磁送信)のみを使用して記憶されない。少なくとも一実施例では、非一時的コンピュータ読取り可能媒体は、必ずしも、一時的な信号のトランシーバ内の非一時的データ・ストレージ回路(たとえば、バッファ、キャッシュ、及びキュー)を含まない。少なくとも一実施例では、プロセス700は、少なくとも部分的に、本開示の他の箇所に記載のものなどのコンピュータ・システム上で実行される。少なくとも一実施例では、プロセス700は、1つ又は複数の画像内の1つ又は複数の物体の1つ又は複数のラベルに少なくとも部分的に基づいて1つ又は複数のニューラル・ネットワークを訓練するために使用される1つ又は複数の画像を識別するための1つ又は複数の回路によって実施される。
【0026】
少なくとも一実施例では、プロセス700の少なくとも一部を実行するシステムは、1つ又は複数のニューラル・ネットワークを訓練するために使用される1つ又は複数の訓練画像から物体を識別する702ための実行可能コードを含む。少なくとも一実施例では、訓練画像の全データセットをより正確に反映する訓練画像のサブセットを使用することによって、ニューラル・ネットワークを訓練するためのハイパー・パラメータを推定することができる。少なくとも一実施例では、プロセス700の少なくとも一部を実行するシステムは、訓練されているニューラル・ネットワークによって認識されるべき特定の物体の周りの境界ボックスなどの、各訓練画像内の関心領域を最初に発見するための実行可能コードを含む。少なくとも一実施例では、プロセス700の少なくとも一部を実行するシステムは、各画像について、関心領域を、すべての他の関心の対応する関心領域と比較する704ための実行可能コードを含む。少なくとも一実施例では、関心領域内の物体は、上記1つ又は複数の訓練画像の間で対応する関心領域内の物体と比較される。
【0027】
少なくとも一実施例では、プロセス700の少なくとも一部を実行するシステムは、比較に基づいてスコア(たとえば、類似性スコア)を生成する706ための実行可能コードを含む。少なくとも一実施例では、関心領域の、他の画像内の関心領域への類似性がより低い場合、類似性の低い画像は他の画像に対して冗長でないため、より高い類似性スコアが割り当てられ得る。少なくとも一実施例では、これは、訓練データ・セット内のすべての画像について実行され、各画像は、各画像の関心領域が残りの画像の他の関心領域にどれだけ類似しているかに基づいてスコア付けされる。少なくとも一実施例では、プロセス700の少なくとも一部を実行するシステムは、類似性スコアをリストに記憶する708ための実行可能コードを含み、上記リストは、複数の類似性スコアを含む。少なくとも一実施例では、上記リストは、各画像と関連付けられるスコアを含み、類似性スコアに基づいて、ランク付けされた順序に配列される。
【0028】
少なくとも一実施例では、プロセス700の少なくとも一部を実行するシステムは、上記リストからの類似性スコアに基づいて訓練データのサブセット(たとえば、プロキシ・データ)を識別し710、選択するための実行可能コードを含む。少なくとも一実施例では、上記サブセットは、ニューラル・ネットワークを訓練するためのハイパー・パラメータを算出するために使用される。少なくとも一実施例では、プロセス700の少なくとも一部を実行するシステムは、代替のニューラル・ネットワーク(たとえば、訓練されるべき上記1つ又は複数のニューラル・ネットワークよりも小さいネットワークを表すプロキシ・ネットワーク)を使用して、訓練画像の識別されたサブセットに基づいて上記1つ又は複数のニューラル・ネットワークを訓練するために使用可能な1つ又は複数のハイパー・パラメータを推定する712ための実行可能コードを含む。少なくとも一実施例では、上記プロキシ・ネットワークは、訓練されるべき上記ニューラル・ネットワークと比較してチャネル数の低減及び残差ブロックの低減を有する、U-netなどの畳み込みニューラル・ネットワークである。少なくとも一実施例では、プロキシ・ネットワークは、レベルの数を5、4及び3へと低減すること(たとえば、符号化ブロック及び復号ブロックの数を低減すること)によって作成される。少なくとも一実施例では、各画像に重要性スコアを与えることによって、ハイパー・パラメータを算出するために使用されるデータは、データ・セット全体をより代表するものであり、したがって、結果として、ハイパー・パラメータをより効率的且つ正確に算出することができるようになる。
【0029】
少なくとも一実施例では、プロキシ・データとプロキシ・ネットワークの両方を使用することは、HPO推定プロセスを加速させるための強力なツールであり得る。少なくとも一実施例では、4.4倍の最大訓練加速を得ることができ、これによって、数日の訓練を数時間に短縮することができる。少なくとも一実施例では、本明細書に記載の技法は、複数のハイパー・パラメータの推定のために、並びに、両方ともリソースが重要な状況である、ニューラル・アーキテクチャ探索及び連合学習などの複数のフレームワークに向けて拡張することができる。
【0030】
推論及び訓練の論理
図8Aは、1つ又は複数の実施例に関して推論及び/又は訓練の動作を実行するために使用される推論及び/又は訓練論理815を示す。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて以下に提供される。
【0031】
少なくとも一実施例では、推論及び/又は訓練論理815は、1つ又は複数の実施例の態様において推論するように訓練及び/若しくは使用されるニューラル・ネットワークのニューロン若しくは層を構成するための順伝播及び/若しくは出力の重み、及び/若しくは入力/出力データ、及び/若しくは他のパラメータを記憶するためのコード並びに/又はデータ・ストレージ801を、限定することなく含んでもよい。少なくとも一実施例では、訓練論理815は、タイミング及び/又は順序を制御するためのグラフ・コード又は他のソフトウェアを記憶するためのコード及び/又はデータ・ストレージ801を含んでもよく、又はそれに結合されてもよく、コード及び/又はデータ・ストレージ801には、重み及び/又は他のパラメータ情報がロードされて、整数及び/又は浮動小数点ユニット(総称して算術論理演算ユニット(ALU))を含む論理が構成される。少なくとも一実施例では、グラフ・コードなどのコードは、そのようなコードが対応するニューラル・ネットワークのアーキテクチャに基づき、重み又は他のパラメータ情報をプロセッサALUにロードする。少なくとも一実施例では、コード及び/又はデータ・ストレージ801は、1つ又は複数の実施例の態様を使用した訓練及び/又は推論中に、入力/出力データ及び/又は重みパラメータを順方向伝播する間に1つ又は複数の実施例と併せて訓練又は使用されるニューラル・ネットワークの各層の重みパラメータ及び/又は入力/出力データを記憶する。少なくとも一実施例では、コード及び/又はデータ・ストレージ801の任意の部分は、プロセッサのL1、L2、又はL3のキャッシュ、若しくはシステム・メモリを含む他のオン・チップ又はオフ・チップのデータ・ストレージとともに含められてもよい。
【0032】
少なくとも一実施例では、コード及び/又はデータ・ストレージ801の任意の部分は、1つ若しくは複数のプロセッサ、又は他のハードウェア論理デバイス若しくは回路の内部にあっても外部にあってもよい。少なくとも一実施例では、コード及び/又はコード及び/又はデータ・ストレージ801は、キャッシュ・メモリ、ダイナミック・ランダム・アドレス可能メモリ(「DRAM」:dynamic randomly addressable memory)、スタティック・ランダム・アドレス可能メモリ(「SRAM」:static randomly addressable memory)、不揮発性メモリ(たとえば、フラッシュ・メモリ)、又は他のストレージであってもよい。少なくとも一実施例では、コード及び/又はコード及び/又はデータ・ストレージ801が、たとえばプロセッサの内部にあるか外部にあるかの選択、又はDRAM、SRAM、フラッシュ、若しくは何らか他のタイプのストレージを含むかの選択は、オン・チップ対オフ・チップで利用可能なストレージ、実行される訓練及び/又は推論の機能のレイテンシ要件、ニューラル・ネットワークの推論及び/又は訓練で使用されるデータのバッチ・サイズ、又はこれらの要因の何からの組合せに応じて決められてもよい。
【0033】
少なくとも一実施例では、推論及び/又は訓練論理815は、1つ又は複数の実施例の態様において推論するために訓練及び/若しくは使用されるニューラル・ネットワークのニューロン若しくは層に対応した、逆伝播及び/若しくは出力の重み、及び/若しくは入力/出力データを記憶するためのコード並びに/又はデータ・ストレージ805を、限定することなく含んでもよい。少なくとも一実施例では、コード及び/又はデータ・ストレージ805は、1つ又は複数の実施例の態様を使用した訓練及び/又は推論中に、入力/出力データ及び/又は重みパラメータを逆伝播する間に1つ又は複数の実施例と併せて訓練又は使用されるニューラル・ネットワークの各層の重みパラメータ及び/又は入力/出力データを記憶する。少なくとも一実施例では、訓練論理815は、タイミング及び/又は順序を制御するためのグラフ・コード又は他のソフトウェアを記憶するためのコード及び/又はデータ・ストレージ805を含んでもよく、又はそれに結合されてもよく、コード及び/又はデータ・ストレージ805には、重み及び/又は他のパラメータ情報がロードされて、整数及び/又は浮動小数点ユニット(総称して算術論理演算ユニット(ALU)を含む論理が構成される。
【0034】
少なくとも一実施例では、グラフ・コードなどのコードは、そのようなコードが対応するニューラル・ネットワークのアーキテクチャに基づき、重み又は他のパラメータ情報がプロセッサALUにロードされるようにする。少なくとも一実施例では、コード及び/又はデータ・ストレージ805の任意の部分は、プロセッサのL1、L2、又はL3のキャッシュ、若しくはシステム・メモリを含む他のオン・チップ又はオフ・チップのデータ・ストレージとともに含められてもよい。少なくとも一実施例では、コード及び/又はデータ・ストレージ805の任意の部分は、1つ若しくは複数のプロセッサ、又は他のハードウェア論理デバイス若しくは回路の内部にあっても外部にあってもよい。少なくとも一実施例では、コード及び/又はデータ・ストレージ805は、キャッシュ・メモリ、DRAM、SRAM、不揮発性メモリ(たとえば、フラッシュ・メモリ)、又は他のストレージであってもよい。少なくとも一実施例では、コード及び/又はデータ・ストレージ805が、たとえばプロセッサの内部にあるか外部にあるかの選択、又はDRAM、SRAM、フラッシュ・メモリ、若しくは何らか他のタイプのストレージを含むかの選択は、オン・チップ対オフ・チップで利用可能なストレージ、実行される訓練及び/又は推論の機能のレイテンシ要件、ニューラル・ネットワークの推論及び/又は訓練で使用されるデータのバッチ・サイズ、又はこれらの要因の何からの組合せに応じて決められてもよい。
【0035】
少なくとも一実施例では、コード及び/又はデータ・ストレージ801と、コード及び/又はデータ・ストレージ805とは、別個のストレージ構造であってもよい。少なくとも一実施例では、コード及び/又はデータ・ストレージ801と、コード及び/又はデータ・ストレージ805とは、結合ストレージ構造であってもよい。少なくとも一実施例では、コード及び/又はデータ・ストレージ801と、コード及び/又はデータ・ストレージ805とは、部分的に組み合わされ、部分的に別個のものであってもよい。少なくとも一実施例では、コード及び/又はデータ・ストレージ801と、コード及び/又はデータ・ストレージ805との任意の部分は、プロセッサのL1、L2、又はL3のキャッシュ、若しくはシステム・メモリを含む他のオン・チップ又はオフ・チップのデータ・ストレージとともに含められてもよい。
【0036】
少なくとも一実施例では、推論及び/又は訓練論理815は、訓練及び/又は推論コード(たとえばグラフ・コード)に少なくとも部分的に基づく、又はそれにより示される論理演算及び/又は算術演算を実行するための、整数及び/又は浮動小数点ユニットを含む1つ又は複数の算術論理演算ユニット(「ALU」)810を、限定することなく含んでもよく、その結果が、アクティブ化ストレージ820に記憶されるアクティブ化(たとえば、ニューラル・ネットワーク内の層若しくはニューロンからの出力値)を生成してもよく、これらは、コード及び/若しくはデータ・ストレージ801、並びに/又はコード及び/若しくはデータ・ストレージ805に記憶される入力/出力及び/又は重みパラメータのデータの関数である。少なくとも一実施例では、アクティブ化ストレージ820に記憶されるアクティブ化は、命令又は他のコードを実行したことに応答して、ALU810によって実行される線形代数計算及び又は行列ベースの計算に従って生成され、ここでコード並びに/又はデータ・ストレージ805及び/若しくはデータ・ストレージ801に記憶された重み値は、バイアス値、勾配情報、運動量値などの他の値、又は他のパラメータ若しくはハイパー・パラメータとともにオペランドとして使用され、これらのいずれか又はすべてが、コード及び/若しくはデータ・ストレージ805、又はコード及び/若しくはデータ・ストレージ801、又はオン・チップ若しくはオフ・チップの別のストレージに記憶されてもよい。
【0037】
少なくとも一実施例では、ALU810は、1つ若しくは複数のプロセッサ、又は他のハードウェア論理デバイス若しくは回路内に含まれるが、別の実施例では、ALU810は、それらを使用するプロセッサ又は他のハードウェア論理デバイス若しくは回路の外部にあってもよい(たとえばコプロセッサ)。少なくとも一実施例では、ALU810は、プロセッサの実行ユニット内に含まれてもよく、又は同じプロセッサ内にあるか異なるタイプの異なるプロセッサ(たとえば、中央処理装置、グラフィックス・プロセッシング・ユニット、固定機能ユニットなど)の間で分散されているかのいずれかであるプロセッサの実行ユニットによりアクセス可能なALUバンク内に、他のやり方で含まれてもよい。少なくとも一実施例では、コード及び/又はデータ・ストレージ801、コード及び/又はデータ・ストレージ805、並びにアクティブ化ストレージ820は、プロセッサ又は他のハードウェア論理デバイス若しくは回路を共有してもよく、別の実施例では、それらは異なるプロセッサ又は他のハードウェア論理デバイス若しくは回路にあってもよく、或いは同じプロセッサ又は他のハードウェア論理デバイス若しくは回路と、異なるプロセッサ又は他のハードウェア論理デバイス若しくは回路との何らかの組合せにあってもよい。少なくとも一実施例では、アクティブ化ストレージ820の任意の部分は、プロセッサのL1、L2、又はL3のキャッシュ、若しくはシステム・メモリを含む他のオン・チップ又はオフ・チップのデータ・ストレージとともに含められてもよい。さらに、推論及び/又は訓練コードが、プロセッサ又は他のハードウェア論理若しくは回路にアクセス可能な他のコードとともに記憶されてもよく、プロセッサのフェッチ、デコード、スケジューリング、実行、リタイア、及び/又は他の論理回路を使用してフェッチ及び/又は処理されてもよい。
【0038】
少なくとも一実施例では、アクティブ化ストレージ820は、キャッシュ・メモリ、DRAM、SRAM、不揮発性メモリ(たとえば、フラッシュ・メモリ)、又は他のストレージであってもよい。少なくとも一実施例では、アクティブ化ストレージ820は、完全に又は部分的に、1つ若しくは複数のプロセッサ又は他の論理回路の内部にあってもよく、又は外部にあってもよい。少なくとも一実施例では、アクティブ化ストレージ820が、たとえばプロセッサの内部にあるか外部にあるかの選択、又はDRAM、SRAM、フラッシュ・メモリ、若しくは何らか他のタイプのストレージを含むかの選択は、オン・チップ対オフ・チップの利用可能なストレージ、実行される訓練及び/又は推論機能のレイテンシ要件、ニューラル・ネットワークの推論及び/又は訓練で使用されるデータのバッチ・サイズ、又はこれらの要因の何からの組合せに応じて決められてもよい。
【0039】
少なくとも一実施例では、
図8Aに示す推論及び/又は訓練論理815は、グーグルのTensorFlow(登録商標)処理ユニット、Graphcore(商標)の推論処理ユニット(IPU)、又はIntel CorpのNervana(登録商標)(たとえば「Lake Crest」)プロセッサなどの特定用途向け集積回路(「ASIC」)と併せて使用されてもよい。少なくとも一実施例では、
図8Aに示す推論及び/又は訓練論理815は、中央処理装置(「CPU」)ハードウェア、グラフィックス・プロセッシング・ユニット(「GPU」)ハードウェア、又はフィールド・プログラマブル・ゲート・アレイ(「FPGA」)などの他のハードウェアと併せて使用されてもよい。
【0040】
図8Bは、少なくとも一実施例による、推論及び/又は訓練論理815を示す図である。少なくとも一実施例では、推論及び/又は訓練論理815は、ハードウェア論理を限定することなく含んでもよく、このハードウェア論理では、計算リソースが、ニューラル・ネットワーク内のニューロンの1つ若しくは複数の層に対応する重み値又は他の情報の専用のものであるか、又は他のやり方でそれらと併せてしか使用されない。少なくとも一実施例では、
図8Bに示す推論及び/又は訓練論理815は、グーグルのTensorFlow(登録商標)処理ユニット、Graphcore(商標)の推論処理ユニット(IPU)、又はIntel CorpのNervana(登録商標)(たとえば「Lake Crest」)プロセッサなどの特定用途向け集積回路(「ASIC」)と併せて使用されてもよい。少なくとも一実施例では、
図8Bに示す推論及び/又は訓練論理815は、中央処理装置(「CPU」)ハードウェア、グラフィックス・プロセッシング・ユニット(「GPU」)ハードウェア、又はフィールド・プログラマブル・ゲート・アレイ(「FPGA」)などの他のハードウェアと併せて使用されてもよい。少なくとも一実施例では、推論及び/又は訓練論理815は、限定することなく、コード及び/又はデータ・ストレージ801、並びにコード及び/又はデータ・ストレージ805を含み、これらを使用して、コード(たとえばグラフ・コード)、重み値、並びに/又はバイアス値、勾配情報、運動量値、及び/若しくは他のパラメータ若しくはハイパー・パラメータ情報を含む他の情報を記憶してもよい。
図8Bに示す少なくとも一実施例では、コード及び/又はデータ・ストレージ801並びにコード及び/又はデータ・ストレージ805の各々は、それぞれ計算ハードウェア802及び計算ハードウェア806などの専用計算リソースに関連付けられる。少なくとも一実施例では、計算ハードウェア802及び計算ハードウェア806の各々は、線形代数関数などの数学的関数を、それぞれコード及び/又はデータ・ストレージ801並びにコード及び/又はデータ・ストレージ805に記憶された情報に対してのみ実行する1つ又は複数のALUを備え、その結果は、アクティブ化ストレージ820に記憶される。
【0041】
少なくとも一実施例では、コード並びに/又はデータ・ストレージ801及び805の各々、並びに対応する計算ハードウェア802及び806は、ニューラル・ネットワークの異なる層にそれぞれ対応し、それにより、コード及び/又はデータ・ストレージ801並びに計算ハードウェア802との1つの「ストレージ/計算の対801/802」から結果的に生じるアクティブ化は、ニューラル・ネットワークの概念的組織化を反映させるために、次のコード及び/又はデータ・ストレージ805並びに計算ハードウェア806との「ストレージ/計算の対805/806」への入力として提供される。少なくとも一実施例では、ストレージ/計算の対801/802、及び805/806は、2つ以上のニューラル・ネットワークの層に対応してもよい。少なくとも一実施例では、ストレージ/計算の対801/802、及び805/806の後に、又はそれと並列に、追加のストレージ/計算の対(図示せず)が、推論及び/又は訓練論理815に含まれてもよい。
【0042】
ニューラル・ネットワークの訓練及び導入
図9は、少なくとも一実施例による、ディープ・ニューラル・ネットワークの訓練及び導入を示す。少なくとも一実施例では、未訓練ニューラル・ネットワーク906が、訓練データセット902を使用して訓練される。少なくとも一実施例では、訓練フレームワーク904は、PyTorchフレームワークであり、一方他の実施例では、訓練フレームワーク904は、TensorFlow、Boost、Caffe、マイクロソフトCognitive Toolkit/CNTK、MXNet、Chainer、Keras、Deeplearning4j、又は他の訓練フレームワークである。少なくとも一実施例では、訓練フレームワーク904は、未訓練ニューラル・ネットワーク906を訓練し、本明細書に記載の処理リソースを使用してそれが訓練されるのを可能にして、訓練済みニューラル・ネットワーク908を生成する。少なくとも一実施例では、重みは、ランダムに選択されてもよく、又はディープ・ビリーフ・ネットワークを使用した事前訓練によって選択されてもよい。少なくとも一実施例では、訓練は、教師あり、一部教師あり、又は教師なしのいずれかのやり方で実行されてもよい。
【0043】
少なくとも一実施例では、未訓練ニューラル・ネットワーク906は教師あり学習を使用して訓練され、ここで訓練データセット902は、入力に対する所望の出力と対になった入力を含み、又は訓練データセット902は、既知の出力を有する入力を含み、ニューラル・ネットワーク906の出力が手動で採点される。少なくとも一実施例では、未訓練ニューラル・ネットワーク906は教師ありのやり方で訓練され、訓練データセット902からの入力を処理し、結果として得られた出力を、予想の又は所望の出力のセットと比較する。少なくとも一実施例では、次いで、誤差が、未訓練ニューラル・ネットワーク906を通って逆伝播される。少なくとも一実施例では、訓練フレームワーク904は、未訓練ニューラル・ネットワーク906を制御する重みを調節する。少なくとも一実施例では、訓練フレームワーク904は、未訓練ニューラル・ネットワーク906が、新規データセット912などの入力データに基づき、結果914などにおいて正しい答えを生成するのに好適な訓練済みニューラル・ネットワーク908などのモデルに向かって、どれだけ良好に収束しているかを監視するツールを含む。少なくとも一実施例では、訓練フレームワーク904は、未訓練ニューラル・ネットワーク906を繰り返し訓練する一方、損失関数、及び確率的勾配降下法などの調整アルゴリズムを使用して、未訓練ニューラル・ネットワーク906の出力を精緻化するように重みを調整する。少なくとも一実施例では、訓練フレームワーク904は、未訓練ニューラル・ネットワーク906が所望の精度に到達するまで未訓練ニューラル・ネットワーク906を訓練する。少なくとも一実施例では、次いで訓練済みニューラル・ネットワーク908を、任意の数の機械学習動作を実施するように導入することができる。
【0044】
少なくとも一実施例では、未訓練ニューラル・ネットワーク906は、教師なし学習を使用して訓練され、ここで未訓練ニューラル・ネットワーク906は、ラベルなしデータを使用して自らを訓練しようとする。少なくとも一実施例では、教師なし学習の訓練データセット902は、いかなる関連出力データ又は「グランド・トゥルース」データもない入力データを含む。少なくとも一実施例では、未訓練ニューラル・ネットワーク906は、訓練データセット902内でグループ化を学習することができ、個々の入力が、未訓練データセット902にどのように関係しているかを判定することができる。少なくとも一実施例では、教師なし訓練を使用して、新規データセット912の次元を低減するのに有用な動作を実行することができる訓練済みニューラル・ネットワーク908の自己組織化マップを生成することができる。少なくとも一実施例では、教師なし訓練を使用して異常検出を実行することもでき、異常検出は、新規データセット912の通常のパターンから逸脱した、新規データセット912内のデータ点を識別できるようにする。
【0045】
少なくとも一実施例では、半教師あり学習が使用されてもよく、それは、ラベル付きデータとラベルなしデータが訓練データセット902に混在している技法である。少なくとも一実施例では、訓練フレームワーク904を使用して、伝達学習技法などによる漸次的学習が実行されてもよい。少なくとも一実施例では、漸次的学習により、訓練済みニューラル・ネットワーク908は、初期訓練中に訓練済みニューラル・ネットワーク908内に教え込まれた知識を忘れることなく、新規データセット912に適合できるようになる。
【0046】
少なくとも一実施例では、訓練フレームワーク904は、OpenVINO (Open Visual Inference and Neural network Optimization)ツールキットなどのソフトウェア開発ツールキットに関連して処理されるフレームワークである。少なくとも一実施例では、OpenVINOツールキットは、カリフォルニア州サンタクララのインテルコーポレーションによって開発されたものなどのツールキットである。
【0047】
少なくとも一実施例では、OpenVINOは、人間資格エミュレーション、音声認識、自然言語処理、推薦システム、及び/又はそれらの変形例などの様々なタスク及び動作のためのアプリケーション、特にニューラル・ネットワーク・アプリケーションの開発を容易にするためのツールキットである。少なくとも一実施例では、OpenVINOは、畳み込みニューラル・ネットワーク(CNN)、再帰及び/若しくは注意ベースのニューラル・ネットワーク、並びに/又は様々な他のニューラル・ネットワーク・モデルなどのニューラル・ネットワークをサポートする。少なくとも一実施例では、OpenVINOは、OpenCV、OpenCL、及び/又はそれらの変形例などの様々なソフトウェア・ライブラリをサポートする。
【0048】
少なくとも一実施例では、OpenVINOは、分類、セグメント化、物体検出、顔認識、音声認識、姿勢推定(たとえば、人間及び/又は物体)、単眼深度推定、画像修復、画風変換、動作認識、カラー化、及び/又はそれらの変形例などの様々なタスク及び動作のためのニューラル・ネットワーク・モデルをサポートする。
【0049】
少なくとも一実施例では、OpenVINOは、モデル・オプティマイザとしても参照される、モデル最適化のための1つ又は複数のソフトウェア・ツール及び/又はモジュールを含む。少なくとも一実施例では、モデル・オプティマイザは、ニューラル・ネットワーク・モデルの訓練と展開との間の移行を容易にするコマンド・ライン・ツールである。少なくとも一実施例では、モデル・オプティマイザは、GPU、CPU、PPU、GPGPU、及び/又はそれらの変形例などの、様々なデバイス及び/又は処理ユニット上での実行のためにニューラル・ネットワーク・モデルを最適化する。少なくとも一実施例では、モデル・オプティマイザは、モデルの内部表現を生成し、上記モデルを、中間表現を生成するように最適化する。少なくとも一実施例では、モデル・オプティマイザは、モデルの層の数を低減する。少なくとも一実施例では、モデル・オプティマイザは、訓練に使用されるモデルの層を除去する。少なくとも一実施例では、モデル・オプティマイザは、モデルへの入力の修正(たとえば、モデルへの入力のリサイズ)、モデルの入力のサイズの修正(たとえば、モデルのバッチ・サイズの修正)、モデル構造の修正(たとえば、モデルの層の修正)、正規化、標準化、定量化(たとえば、モデルの重みの、浮動小数点などの第1の表現から整数などの第2の表現への変換)、及び/又はそれらの変形例などの、様々なニューラル・ネットワーク動作を実行する。
【0050】
少なくとも一実施例では、OpenVINOは、推論エンジンとしても参照される、推論のための1つ又は複数のソフトウェア・ライブラリを含む。少なくとも一実施例では、推論エンジンは、C++ライブラリ、又は任意の適切なプログラミング言語ライブラリである。少なくとも一実施例では、推論エンジンは、入力データを推論するために利用される。少なくとも一実施例では、推論エンジンは、入力データを推論し、1つ又は複数の結果を生成するための様々なクラスを実施する。少なくとも一実施例では、推論エンジンは、1つ又は複数のAPI関数を実施して、中間表現を処理し、入力及び/若しくは出力フォーマットを設定し、並びに/又は、1つ若しくは複数のデバイス上でモデルを実行する。
【0051】
少なくとも一実施例では、OpenVINOは、1つ又は複数のニューラル・ネットワーク・モデルの異種実行のための様々な機能を提供する。少なくとも一実施例では、異種実行又は異種コンピューティングは、1つ又は複数のタイプのプロセッサ及び/又はコアを利用する1つ又は複数のコンピューティング・プロセス及び/又はシステムを指す。少なくとも一実施例では、OpenVINOは、1つ又は複数のデバイス上のプログラムを実行するための様々なソフトウェア機能を提供する。少なくとも一実施例では、OpenVINOは、異なるデバイス上でプログラム及び/又はプログラム部分を実行するための様々なソフトウェア機能を提供する。少なくとも一実施例では、OpenVINOは、たとえば、コードの第1の部分をCPU上で作動させ、コードの第2の部分をGPU及び/又はFPGA上で作動させるための様々なソフトウェア機能を提供する。少なくとも一実施例では、OpenVINOは、1つ又は複数のデバイス上で1つ又は複数の層を実行する(たとえば、GPUなどの第1のデバイス上で層の第1のセットを実行し、CPUなどの第2のデバイス上で層の第2のセットを実行する)ための様々なソフトウェア機能を提供する。
【0052】
少なくとも一実施例では、OpenVINOは、TensorFlow、PyTorch、及び/又はそれらの変形例などのフレームワークと関連付けられる様々なニューラル・ネットワーク・モデル動作などの、CUDAプログラミング・モデルと関連付けられる機能と同様の様々な機能を含む。少なくとも一実施例では、1つ又は複数のCUDAプログラミング・モデル動作は、OpenVINOを使用して実行される。少なくとも一実施例では、本明細書に記載の様々なシステム、方法、及び/又は技法は、OpenVINOを使用して実施される。
【0053】
データ・センタ
図10は、少なくとも一実施例が使用されてもよい例示的なデータ・センタ1000を示す。少なくとも一実施例では、データ・センタ1000は、データ・センタ・インフラストラクチャ層1010、フレームワーク層1020、ソフトウェア層1030、及びアプリケーション層1040を含む。
【0054】
図10に示すように、少なくとも一実施例では、データ・センタ・インフラストラクチャ層1010は、リソース・オーケストレータ1012と、グループ化済みコンピューティング・リソース1014と、ノード・コンピューティング・リソース(「ノードC.R.」)1016(1)~1016(N)とを含んでもよく、ここで「N」は正の整数(他の図で使用されるものとは異なる整数「N」であってもよい)を表す。少なくとも一実施例では、ノードC.R.1016(1)~1016(N)は、任意の数の中央処理装置(「CPU」)又は(アクセラレータ、フィールド・プログラマブル・ゲート・アレイ(FPGA)、グラフィックス・プロセッサなどを含む)他のプロセッサ、メモリ・ストレージ・デバイス1018(1)~1018(N)(たとえば、ダイナミック読取り専用メモリ、ソリッド・ステート・ストレージ又はディスク・ドライブ)、ネットワーク入力/出力(「NW I/O」:network input/output)デバイス、ネットワーク・スイッチ、仮想機械(「VM」:virtual machine)、電源モジュール、及び冷却モジュールを含んでもよいが、これらに限定されない。少なくとも一実施例では、ノードC.R.1016(1)~1016(N)のうち1つ又は複数のノードC.R.は、上述したコンピューティング・リソースのうちの1つ又は複数を有するサーバであってもよい。
【0055】
少なくとも一実施例では、グループ化済みコンピューティング・リソース1014は、1つ若しくは複数のラック(図示せず)内に収容されたノードC.R.の別々のグループ、又は様々なグラフィカル・ロケーション(同じく図示せず)においてデータ・センタに収容された多数のラックを含んでもよい。少なくとも一実施例では、グループ化済みコンピューティング・リソース1014内のノードC.R.の別個のグループは、1つ若しくは複数のワークロードをサポートするように構成又は配分されてもよいグループ化済みのコンピュート・リソース、ネットワーク・リソース、メモリ・リソース、又はストレージ・リソースを含んでもよい。少なくとも一実施例では、CPU又はプロセッサを含むいくつかのノードC.R.は、1つ又は複数のラック内でグループ化されて、1つ又は複数のワークロードをサポートするためのコンピュート・リソースが提供されてもよい。少なくとも一実施例では、1つ又は複数のラックはまた、任意の数の電源モジュール、冷却モジュール、及びネットワーク・スイッチを任意の組合せで含んでもよい。
【0056】
少なくとも一実施例では、リソース・オーケストレータ1012は、1つ又は複数のノードC.R.1016(1)~1016(N)及び/若しくはグループ化済みコンピューティング・リソース1014を構成してもよく、又は他のやり方で制御してもよい。少なくとも一実施例では、リソース・オーケストレータ1012は、データ・センタ1000用のソフトウェア設計インフラストラクチャ(「SDI」:software design infrastructure)管理エンティティを含んでもよい。少なくとも一実施例では、リソース・オーケストレータ812は、ハードウェア、ソフトウェア、又はこれらの何らかの組合せを含んでもよい。
【0057】
図10に示す少なくとも一実施例では、フレームワーク層1020は、ジョブ・スケジューラ1022、構成マネージャ1024、リソース・マネージャ1026、及び分配ファイル・システム1028を含む。少なくとも一実施例では、フレームワーク層1020は、ソフトウェア層1030のソフトウェア1032、及び/又はアプリケーション層1040の1つ若しくは複数のアプリケーション1042をサポートするためのフレームワークを含んでもよい。少なくとも一実施例では、ソフトウェア1032又はアプリケーション1042はそれぞれ、アマゾン・ウェブ・サービス、グーグル・クラウド、及びマイクロソフト・アジュールによって提供されるものなど、ウェブ・ベースのサービス・ソフトウェア又はアプリケーションを含んでもよい。少なくとも一実施例では、フレームワーク層1020は、大規模なデータ処理(たとえば「ビック・データ」)のために分配ファイル・システム1028を使用することができるApache Spark(商標)(以下「Spark」)など、無料でオープン・ソースのソフトウェア・ウェブ・アプリケーション・フレームワークの一種であってもよいが、これに限定されない。少なくとも一実施例では、ジョブ・スケジューラ1022は、データ・センタ1000の様々な層によってサポートされるワークロードのスケジューリングを容易にするために、Sparkドライバを含んでもよい。少なくとも一実施例では、構成マネージャ1024は、ソフトウェア層1030、並びに大規模なデータ処理をサポートするためのSpark及び分配ファイル・システム1028を含むフレームワーク層1020などの異なる層を構成することが可能であってもよい。少なくとも一実施例では、リソース・マネージャ1026は、分配ファイル・システム1028及びジョブ・スケジューラ1022をサポートするようにマッピング若しくは配分されたクラスタ化済み又はグループ化済みのコンピューティング・リソースを管理することが可能であってもよい。少なくとも一実施例では、クラスタ化済み又はグループ化済みのコンピューティング・リソースは、データ・センタ・インフラストラクチャ層1010にあるグループ化済みコンピューティング・リソース1014を含んでもよい。少なくとも一実施例では、リソース・マネージャ1026は、リソース・オーケストレータ1012と連携して、これらのマッピング又は配分されたコンピューティング・リソースを管理してもよい。
【0058】
少なくとも一実施例では、ソフトウェア層1030に含まれるソフトウェア1032は、ノードC.R.1016(1)~1016(N)、グループ化済みコンピューティング・リソース1014、及び/又はフレームワーク層1020の分配ファイル・システム1028のうちの少なくとも一部分によって使用されるソフトウェアを含んでもよい。少なくとも一実施例では、1つ又は複数のタイプのソフトウェアは、インターネット・ウェブ・ページ検索ソフトウェア、電子メール・ウイルス・スキャン・ソフトウェア、データベース・ソフトウェア、及びストリーミング・ビデオ・コンテンツ・ソフトウェアを含んでもよいが、これらに限定されない。
【0059】
少なくとも一実施例では、アプリケーション層1040に含まれるアプリケーション1042は、ノードC.R.1016(1)~1016(N)、グループ化済みコンピューティング・リソース1014、及び/又はフレームワーク層1020の分配ファイル・システム1028のうちの少なくとも一部分によって使用される1つ若しくは複数のタイプのアプリケーションを含んでもよい。少なくとも一実施例では、1つ若しくは複数のタイプのアプリケーションは、任意の数のゲノム学アプリケーション、認識コンピュート、並びに訓練若しくは推論のソフトウェア、機械学習フレームワーク・ソフトウェア(たとえば、PyTorch、TensorFlow、Caffeなど)を含むアプリケーション及び機械学習アプリケーション、又は1つ若しくは複数の実施例と併せて使用される他の機械学習アプリケーションを含んでもよいが、これらに限定されない。
【0060】
少なくとも一実施例では、構成マネージャ1024、リソース・マネージャ1026、及びリソース・オーケストレータ1012のうちのいずれかは、任意の技術的に実行可能なやり方で取得された任意の量及びタイプのデータに基づき、任意の数及びタイプの自己修正措置を実施してもよい。少なくとも一実施例では、自己修正措置は、データ・センタ1000のデータ・センタ演算子が、不良の恐れのある構成を決定しないようにし、十分に利用されていない且つ/又は性能の低いデータ・センタの部分をなくせるようにしてもよい。
【0061】
少なくとも一実施例では、データ・センタ1000は、1つ若しくは複数の機械学習モデルを訓練し、又は本明細書に記載の1つ若しくは複数の実施例による1つ若しくは複数の機械学習モデルを使用して情報を予測若しくは推論するためのツール、サービス、ソフトウェア、又は他のリソースを含んでもよい。たとえば、少なくとも一実施例では、機械学習モデルは、データ・センタ1000に関して上述したソフトウェア及びコンピューティング・リソースを使用して、ニューラル・ネットワーク・アーキテクチャに従って重みパラメータを計算することによって、訓練されてもよい。少なくとも一実施例では、1つ又は複数のニューラル・ネットワークに対応する訓練済み機械学習モデルは、本明細書に記載の1つ又は複数の技法によって計算された重みパラメータを使用することにより、データ・センタ1000に関して上述したリソースを使用して、情報を推論又は予測するために使用されてもよい。
【0062】
少なくとも一実施例では、データ・センタは、上述したリソースを使用して訓練及び/又は推論を実行するために、CPU、特定用途向け集積回路(ASIC)、GPU、FPGA、又は他のハードウェアを使用してもよい。さらに、上述した1つ又は複数のソフトウェア及び/又はハードウェアのリソースは、画像認識、音声認識、又は他の人工知能サービスなどの情報の訓練又は推論の実行を、ユーザが行えるようにするためのサービスとして構成されてもよい。
【0063】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のために
図10のシステムにおいて使用されてもよい。
【0064】
少なくとも一実施例では、
図8に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図8に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図8に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0065】
自律車両
図11Aは、少なくとも一実施例による自律車両1100の実例を示す。少なくとも一実施例では、自律車両1100(或いは、本明細書において「車両1100」と呼ばれる)は、限定することなく、車、トラック、バス、及び/又は1人若しくは複数の乗員を収容する別のタイプの車両などの乗用車とすることができる。少なくとも一実施例では、車両1100は、貨物運搬用のセミ・トラクタのトレーラ・トラックであってもよい。少なくとも一実施例では、車両1100は、航空機、ロボット車両、又は他の種類の車両であってもよい。
【0066】
自律車両は、米国運輸省の一部門である全米高速道路交通安全局(「NHTSA」:National Highway Traffic Safety Administration)、及び自動車技術者協会(「SAE」:Society of Automotive Engineers)の「自動車用運転自動化システムのレベル分類及び定義(Taxonomy and Definitions for Terms Related to Driving Automation Systems for On-Road Motor Vehicles)」(たとえば、2018年6月15日発行の規格No.J3016-201806、2016年9月30日発行の規格No.J3016-201609、及びこの規格の旧版及び新版)により定義される自動化レベルという観点から説明されてもよい。少なくとも一実施例では、車両1100は、自律運転レベルのレベル1~レベル5のうちの1つ又は複数による機能性に対応可能であってもよい。たとえば、少なくとも一実施例では、車両1100は、実施例に応じて、条件付き自動化(レベル3)、高度自動化(レベル4)、及び/又は完全自動化(レベル5)に対応可能であってもよい。
【0067】
少なくとも一実施例では、車両1100は、限定することなく、シャシ、車両本体、ホイール(2本、4本、6本、8本、18本など)、タイヤ、車軸、及び車両の他の構成要素などの構成要素を含んでもよい。少なくとも一実施例では、車両1100は、限定することなく、内燃機関、ハイブリッド電力プラント、完全電気エンジン、及び/又は別のタイプの推進システムなどの推進システム1150を含んでもよい。少なくとも一実施例では、推進システム1150は、車両1100のドライブ・トレインに連結されてもよく、ドライブ・トレインは、限定することなく、車両1100の推進を可能にするためのトランスミッションを含んでもよい。少なくとも一実施例では、推進システム1150は、スロットル/アクセル1152からの信号を受信したことに応答して、制御されてもよい。
【0068】
少なくとも一実施例では、限定することなくハンドルを含んでもよい操縦システム1154は、推進システム1150が動作しているときに(たとえば、車両1100が動いているときに)車両1100を(たとえば所望の経路又はルートに沿って)操縦するために使用される。少なくとも一実施例では、操縦システム1154は、操縦アクチュエータ1156から信号を受信してもよい。少なくとも一実施例では、ハンドルは、完全自動化(レベル5)の機能性に関しては任意選択であってもよい。少なくとも一実施例では、ブレーキ・アクチュエータ1148及び/又はブレーキ・センサからの信号を受信したことに応答して車両ブレーキを動作させるために、ブレーキ・センサ・システム1146が使用されてもよい。
【0069】
少なくとも一実施例では、1つ又は複数のシステム・オン・チップ(「SoC」:system on chip)(
図11Aには示さず)及び/若しくはグラフィックス・プロセッシング・ユニット(「GPU」)を限定することなく含んでもよいコントローラ1136は、車両1100の1つ又は複数の構成要素及び/若しくはシステムに(たとえば、コマンドを表す)信号を提供する。たとえば、少なくとも一実施例では、コントローラ1136は、ブレーキ・アクチュエータ1148を介して車両ブレーキを動作させるための信号、操縦アクチュエータ1156を介して操縦システム1154を動作させるための信号、スロットル/アクセル1152を介して推進システム1150を動作させるための信号を送信してもよい。少なくとも一実施例では、コントローラ1136は、自律運転を可能にし、且つ/又は運転車両1100において人間のドライバを支援するために、センサ信号を処理し、動作コマンド(たとえばコマンドを表す信号)を出力する1つ又は複数の搭載(たとえば一体型の)コンピューティング・デバイスを含んでもよい。少なくとも一実施例では、コントローラ1136は、自律運転機能のための第1のコントローラ、機能的安全機能のための第2のコントローラ、人工知能機能(たとえば、コンピュータ・ビジョン)のための第3のコントローラ、インフォテイメント機能のための第4のコントローラ、緊急事態における冗長性のための第5のコントローラ、及び/又は他のコントローラを含んでもよい。少なくとも一実施例では、単一のコントローラが、上記機能性のうちの2つ以上に対処してもよく、2つ以上のコントローラが、単一の機能性に対処してもよく、且つ/又はこれらの何らかの組合せであってもよい。
【0070】
少なくとも一実施例では、コントローラ1136は、1つ又は複数のセンサから受信したセンサ・データ(たとえば、センサ入力)に応答して、車両1100の1つ又は複数の構成要素及び/若しくはシステムを制御するための信号を提供する。少なくとも一実施例では、センサ・データは、たとえば限定することなく、全地球的航法衛星システム(「GNSS」:global navigation satellite system)センサ1158(たとえば、全地球測位システム・センサ)、RADARセンサ1160、超音波センサ1162、LIDARセンサ1164、慣性計測装置(「IMU」:inertial measurement unit)センサ1166(たとえば、加速度計、ジャイロスコープ、1つ又は複数の磁気コンパス、磁力計など)、マイクロフォン1196、ステレオ・カメラ1168、広角カメラ1170(たとえば、魚眼カメラ)、赤外線カメラ1172、周囲カメラ1174(たとえば、360度カメラ)、長距離カメラ(
図11Aには示さず)、中距離カメラ(
図11Aには示さず)、(たとえば、車両1100のスピードを計測するための)スピード・センサ1144、振動センサ1142、操縦センサ1140、(たとえば、ブレーキ・センサ・システム1146の一部分としての)ブレーキ・センサ、及び/又は他のタイプのセンサから、受信されてもよい。
【0071】
少なくとも一実施例では、コントローラ1136のうちの1つ又は複数は、車両1100の計器クラスタ1132からの(たとえば入力データによって表される)入力を受信し、ヒューマン・マシン・インターフェース(「HMI」:human-machine interface)ディスプレイ1134、可聴アナンシエータ、拡声器を介して、且つ/又は車両1100の他の構成要素を介して、(たとえば、出力データ、ディスプレイ・データなどによって表される)出力を提供してもよい。少なくとも一実施例では、出力は、車両速度、スピード、時間、地図データ(たとえば、ハイ・デフィニション・マップ(
図11Aには示さず)、ロケーション・データ(たとえば、地図上などの車両1100のロケーション)、方向、他車両のロケーション(たとえば、占有グリッド)、コントローラ1136が感知した物体及び物体の状態についての情報などの情報を含んでもよい。たとえば、少なくとも一実施例では、HMIディスプレイ1134は、1つ若しくは複数の物体(たとえば、道路標識、警告標識、信号の変化など)の存在についての情報、及び/又は車両が行った、行っている、又はこれから行う運転操作についての情報(たとえば、現在車線変更中、3.22km(2マイル)先の出口34Bを出る、など)を表示してもよい。
【0072】
少なくとも一実施例では、車両1100はさらにネットワーク・インターフェース1124を含み、このネットワーク・インターフェースは、1つ又は複数のネットワークを介して通信するためのワイヤレス・アンテナ1126及び/又はモデムを使用してもよい。たとえば、少なくとも一実施例では、ネットワーク・インターフェース1124は、ロング・ターム・エボリューション(「LTE」:Long-Term Evolution)、広帯域符号分割多元接続(「WCDMA(登録商標)」:Wideband Code Division Multiple Access)、ユニバーサル・モバイル・テレコミュニケーション・システム(「UMTS」:Universal Mobile Telecommunications System)、グローバル・システム・フォー・モバイル・コミュニケーションズ(「GSM」:Global System for Mobile communication)、IMT-CDMAマルチ・キャリア(「CDMA2000」)ネットワークなどを介して通信可能であってもよい。また、少なくとも一実施例では、ワイヤレス・アンテナ1126は、Bluetooth、Bluetooth Low Energy (「LE」:Low Energy)、Z-Wave、ZigBeeなどのローカル・エリア・ネットワーク、及び/又はLoRaWAN、SigFoxなどの低電力広域ネットワーク(「LPWAN」:low power wide-area network)プロトコルを使用して、環境内の物体同士間(たとえば車両、モバイル・デバイスなど)での通信を可能にしてもよい。
【0073】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のために
図11Aのシステムにおいて使用されてもよい。
【0074】
少なくとも一実施例では、
図11Aに示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図11Aに示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図11Aに示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0075】
図11Bは、少なくとも一実施例による
図11Aの自律車両1100についてカメラのロケーション及び視野の実例を示す。少なくとも一実施例では、カメラ及びそれぞれの視野は、一例の実施例であり、限定するものではない。たとえば、少なくとも一実施例では、追加及び/又は代替のカメラが含まれてもよく、且つ/又はカメラが車両1100の異なるロケーションに位置付けられてもよい。
【0076】
少なくとも一実施例では、カメラのカメラ・タイプは、車両1100の構成要素及び/又はシステムとともに使用できるように適合されていてもよいデジタル・カメラを含んでもよいが、これに限定されない。少なくとも一実施例では、カメラは、自動車安全性要求レベル(「ASIL」:automotive safety integrity level)B及び/又は別のASILにおいて動作してもよい。少なくとも一実施例では、カメラ・タイプは、実施例に応じて、毎秒60フレーム(fps:frames per second)、1220fps、240fpsなど、任意の画像捕捉率に対応可能であってもよい。少なくとも一実施例では、カメラは、ロール・シャッタ、グローバル・シャッタ、別のタイプのシャッタ、又はこれらの組合せを使用することが可能であってもよい。少なくとも一実施例では、カラー・フィルタ・アレイは、赤色、クリア、クリア、クリア(「RCCC」:red clear clear clear)のカラー・フィルタ・アレイ、赤色、クリア、クリア、青色(「RCCB:red clear clear blue」)のカラー・フィルタ・アレイ、赤色、青色、緑色、クリア(「RBGC」:red blue green clear)のカラー・フィルタ・アレイ、Foveon X3のカラー・フィルタ・アレイ、ベイヤー・センサ(RGGB)のカラー・フィルタ・アレイ、モノクロ・センサのカラー・フィルタ・アレイ、及び/又は別のタイプのカラー・フィルタ・アレイを含んでもよい。少なくとも一実施例では、光感度を上げるために、RCCC、RCCB、及び/又はRBGCのカラー・フィルタ・アレイを有するカメラなど、クリア・ピクセル・カメラが使用されてもよい。
【0077】
少なくとも一実施例では、カメラのうちの1つ又は複数を使用して、先進ドライバ支援システム(「ADAS」:advanced driver assistance systems)機能が(たとえば、冗長設計又はフェイル・セーフ設計の一部として)実行されてもよい。たとえば、少なくとも一実施例では、多機能モノ・カメラが設置されて、車線逸脱警告、交通標識支援、及びインテリジェント・ヘッドライト制御を含む機能が提供されてもよい。少なくとも一実施例では、カメラのうちの1つ又は複数(たとえばすべてのカメラ)は、画像データ(たとえばビデオ)の記録と提供を同時に行ってもよい。
【0078】
少なくとも一実施例では、1つ又は複数のカメラは、カメラの画像データ捕捉性能を妨げる恐れのある迷光及び車両1100内部からの反射(たとえば、ダッシュボードからフロントガラスに反射される反射)をなくすために、カスタム設計の(3次元(「3D」:three-dimensional)印刷された)アセンブリなどの取付けアセンブリに取り付けられてもよい。ドアミラー取付けアセンブリを参照すると、少なくとも一実施例では、ドアミラー・アセンブリは、カメラ取付けプレートがドアミラーの形の合うように、カスタムで3D印刷されてもよい。少なくとも一実施例では、カメラは、ドアミラーと一体であってもよい。少なくとも一実施例では、サイド・ビュー・カメラについて、カメラはこの場合もキャビンの各角にある4本のピラーに一体化されてもよい。
【0079】
少なくとも一実施例では、車両1100前方の環境の一部分を含む視野を有するカメラ(たとえば正面カメラ)は周囲のビューに対して使用されて、正面の経路及び障害物を識別しやすくするとともに、コントローラ1136及び/又は制御SoCのうちの1つ又は複数とともに使用されて、占有グリッドの生成及び/又は好ましい車両経路の判定に不可欠な情報の提供を補助してもよい。少なくとも一実施例では、正面カメラを使用して、緊急ブレーキ、歩行者検出、及び衝突回避を限定することなく含む、LIDARと同様のADAS機能のうちの多くが実行されてもよい。少なくとも一実施例では、正面カメラはまた、車線逸脱警告(「LDW」:Lane Departure Warnings)、自律クルーズ・コントロール(「ACC」:Autonomous Cruise Control)、及び/又は交通標識認識などの他の機能を限定することなく含むADASの機能及びシステムのために使用されてもよい。
【0080】
少なくとも一実施例では、たとえばCMOS:complementary metal oxide semiconductor(「相補型金属酸化膜半導体」)カラー撮像装置を含む単眼カメラのプラットフォームを含む様々なカメラが、正面構成で使用されてもよい。少なくとも一実施例では、周囲からビューに入ってくる物体(たとえば歩行者、クロス・トラフィック、又は自転車)を感知するために、広角カメラ1170が使用されてもよい。
図11Bには1つの広角カメラ1170しか示していないが、他の実施例では、車両1100には(ゼロを含む)任意の数の広角カメラが存在してもよい。少なくとも一実施例では、特にニューラル・ネットワークがそれに対してまだ訓練されていない物体について、深度ベースの物体検出のために、任意の数の長距離カメラ1198(たとえば、長距離ビューのステレオ・カメラの対)が使用されてもよい。少なくとも一実施例では、長距離カメラ1198はまた、物体検出及び分類、並びに基本的な物体追跡に使用されてもよい。
【0081】
少なくとも一実施例では、任意の数のステレオ・カメラ1168は、正面構成にも含まれてよい。少なくとも一実施例では、1つ又は複数のステレオ・カメラ1168は、拡張可能な処理ユニットを備えた一体型制御ユニットを含んでもよく、この制御ユニットは、一体型のコントローラ・エリア・ネットワーク(「CAN」:Controller Area Network)又はイーサネット(登録商標)・インターフェースを単一チップ上に有するプログラム可能論理(「FPGA」)及びマルチ・コア・マイクロプロセッサを提供してもよい。少なくとも一実施例では、こうしたユニットは、画像内のすべての点に対する距離推定を含め、車両1100の環境の3Dマップを生成するのに使用されてもよい。少なくとも一実施例では、ステレオ・カメラ1168のうちの1つ又は複数は、限定することなくコンパクト・ステレオ・ビジョン・センサを含んでもよく、このセンサは、車両1100からターゲット物体までの距離を測定し、生成された情報(たとえば、メタデータ)を使用して自律緊急ブレーキ及び車線逸脱警告の機能をアクティブ化することができる2つのカメラ・レンズ(左右に1つずつ)及び画像処理チップを、限定することなく含んでもよい。少なくとも一実施例では、本明細書に記載のものに加えて、又はその代わりに、他のタイプのステレオ・カメラ1168が使用されてもよい。
【0082】
少なくとも一実施例では、車両1100の側方の環境の一部分を含む視野を有するカメラ(たとえば、サイド・ビュー・カメラ)が、周囲のビューのために使用されて、占有グリッドの作製及び更新、並びに側面衝突警告の生成のために使用される情報を提供してもよい。たとえば、少なくとも一実施例では、周囲カメラ1174(たとえば
図11Bに示すように4つの周囲カメラ)を、車両1100に配置することができる。周囲カメラ1174は、限定することなく、任意の数及び組合せの広角カメラ1770、魚眼カメラ、及び/又は360度カメラなどを含んでもよい。たとえば、少なくとも一実施例では、4つの魚眼カメラが、車両1100の前方、後方、及び側方に配置されてもよい。少なくとも一実施例では、車両1100は、3つの周囲カメラ1174(たとえば、左、右、及び後方)を使用してもよく、第4の周囲カメラとして、1つ又は複数の他のカメラ(たとえば正面カメラ)を活用してもよい。
【0083】
少なくとも一実施例では、車両1100後方の環境の一部分を含む視野を有するカメラ(たとえば、リア・ビュー・カメラ)が、駐車支援、周囲のビュー、後方衝突警告のために使用されて、占有グリッドの作製及び更新がなされてもよい。少なくとも一実施例では、本明細書に記載の正面カメラとしても好適なカメラ(たとえば、長距離カメラ1198、及び/又は中距離カメラ1176、ステレオ・カメラ1168)、赤外線カメラ1172など)を含むが、これらに限定されない多種多様なカメラが使用されてもよい。
【0084】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のために
図11Bのシステムにおいて使用されてもよい。
【0085】
少なくとも一実施例では、
図11Bに示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図11Bに示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図11Bに示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0086】
図11Cは、少なくとも一実施例による
図11Aの自律車両1100の例示的システム・アーキテクチャを示すブロック図である。少なくとも一実施例では、
図11Cの車両1100の構成要素、特徴、及びシステムのそれぞれは、バス1102を介して接続されるものとして示される。少なくとも一実施例では、バス1102は、限定することなく、CANデータ・インターフェース(或いは、本明細書において(CANバス)と呼ばれる)を含んでもよい。少なくとも一実施例では、CANは、ブレーキの作動、加速、ブレーキ制御、操縦、フロントガラス・ワイパなど、車両1100の様々な特徴及び機能の制御を補助するために使用される車両1100内部のネットワークであってもよい。少なくとも一実施例では、バス1102は、それぞれが独自の一意の識別子(たとえばCAN ID)をもつ数十又はさらには数百のノードを有するように構成されてもよい。少なくとも一実施例では、バス1102は、ハンドル角度、対地スピード、エンジンの毎分回転数(「RPM」:revolutions per minute)、ボタン位置、及び/又は他の車両状態インジケータを見いだすように読み取られてもよい。少なくとも一実施例では、バス1102は、ASILのBに準拠したCANバスであってもよい。
【0087】
少なくとも一実施例では、CANに加えて、又はその代わりに、FlexRay及び/又はEthernet(登録商標)プロトコルが使用されてもよい。少なくとも一実施例では、バス1102を形成する任意の数のバスが存在してもよく、これには、限定することなく、ゼロ以上のCANバス、ゼロ以上のFlexRayバス、ゼロ以上のEthernet(登録商標)バス、及び/又は異なるプロトコルを使用するゼロ以上の他のタイプのバスが含まれてもよい。少なくとも一実施例では、2つ以上のバスを使用して異なる機能が実行されてもよく、且つ/又はそれらを使用して冗長性が与えられてもよい。たとえば、第1のバスが衝突回避機能のために使用され、第2のバスが作動制御のために使用されてもよい。少なくとも一実施例では、バス1102の各バスは、車両1100の構成要素のいずれかと通信してもよく、バス1102の2つ以上のバスが対応する構成要素と通信してもよい。少なくとも一実施例では、任意の数のシステム・オン・チップ(「SoC」)1104(SoC1104(A)及びSoC1104(B)など)のそれぞれ、コントローラ1136のそれぞれ、及び/又は車両内の各コンピュータは、同じ入力データ(たとえば、車両1100のセンサからの入力)にアクセス可能であってもよく、CANバスなどの共通のバスに接続されてもよい。
【0088】
少なくとも一実施例では、車両1100は、
図11Aに関して本明細書に記載するものなど、1つ又は複数のコントローラ1136を含んでもよい。少なくとも一実施例では、コントローラ1136は、様々な機能に使用されてもよい。少なくとも一実施例では、コントローラ1136は、車両1100の様々な他の構成要素及びシステムのうちの任意のものに結合されてもよく、車両1100、車両1100の人工知能、車両1100のインフォテイメント、及び/又は他の機能に使用されてもよい。
【0089】
少なくとも一実施例では、車両1100は、任意の数のSoC1104を含んでもよい。少なくとも一実施例では、SoC1104の各々は、限定することなく、中央処理装置(「CPU」)1106、グラフィックス・プロセッシング・ユニット(「GPU」)1108、プロセッサ1110、キャッシュ1112、アクセラレータ1114、データ・ストア1116、及び/又は図示していない他の構成要素及び特徴を含んでもよい。少なくとも一実施例では、車両1100を様々なプラットフォーム及びシステムにおいて制御するために、SoC1104が使用されてもよい。たとえば、少なくとも一実施例では、SoC1104は、1つ又は複数のサーバ(
図11Cには示さず)からネットワーク・インターフェース1124を介して地図のリフレッシュ及び/又は更新を得ることができる高精細(「HD」)マップ1122を有するシステム(たとえば車両1100のシステム)に組み込まれてもよい。
【0090】
少なくとも一実施例では、CPU1106は、CPUクラスタ、又はCPUコンプレックス(或いは本明細書において「CCPLEX」と呼ばれる)を含んでもよい。少なくとも一実施例では、CPU1106は、複数のコア及び/又はレベル2(「L2」)キャッシュを含んでもよい。たとえば、少なくとも一実施例では、CPU1106は、コヒーレントなマルチプロセッサ構成において8つのコアを含んでもよい。少なくとも一実施例では、CPU1106は、4つのデュアル・コア・クラスタを含んでもよく、ここで各クラスタは、専用のL2キャッシュ(たとえば、2メガバイト(MB)のL2キャッシュ)を有する。少なくとも一実施例では、CPU1106(たとえば、CCPLEX)は、CPU1106のクラスタの任意の組合せを、任意の所与の時間にアクティブ化できるようにする同時のクラスタ動作をサポートするように構成されてもよい。
【0091】
少なくとも一実施例では、CPU1106のうちの1つ又は複数は、電力管理機能を実施してもよく、この機能は限定することなく、以下の特徴のうちの1つ又は複数を含む:個々のハードウェア・ブロックが、アイドル時に自動的にクロック・ゲート制御されて動的電力を節約することができる;割込み待ち(「WFI」:Wait for Interrupt)/イベント待ち(「WFE」:Wait for Event)命令の実行に起因してそのようなコアが能動的に命令を実行していないとき、各コア・クロックをゲート制御することができる;各コアを独立して電力ゲート制御することができる;すべてのコアがクロック・ゲート制御又は電力ゲート制御されるとき、各コア・クラスタを独立してクロック・ゲート制御することができる;且つ/又はすべてのコアが電力ゲート制御されるとき、各コア・クラスタを独立して電力ゲート制御することができる。少なくとも一実施例では、CPU1106はさらに、電力状態を管理するための拡張アルゴリズムを実施してもよく、ここで、許容された電力状態及び予想されるウェイクアップ時間が指定され、コア、クラスタ、及びCCPLEXが入るべき最良の電力状態を、ハードウェア/マイクロコードが判定する。少なくとも一実施例では、処理コアは、作業がマイクロコードにオフロードされた状態で、電力状態に入る簡単なシーケンスをソフトウェアにおいてサポートしてもよい。
【0092】
少なくとも一実施例では、GPU1108は、統合されたGPU(或いは、本明細書において「iGPU」と呼ばれる)を含んでもよい。少なくとも一実施例では、GPU1108は、プログラム可能であってもよく、並列なワークロードに対して効率的であってもよい。少なくとも一実施例では、GPU1108は、拡張テンソル命令セットを使用してもよい。少なくとも一実施例では、GPU1108は、1つ又は複数のストリーミング・マイクロプロセッサを含んでもよく、ここで各ストリーミング・マイクロプロセッサは、レベル1(「L1」)キャッシュ(たとえば少なくとも96KBのストレージ容量を有するL1キャッシュ)を含んでもよく、2つ以上のストリーミング・マイクロプロセッサは、L2キャッシュ(たとえば、512KBのストレージ容量を有するL2キャッシュ)を共有してもよい。少なくとも一実施例では、GPU1108は、少なくとも8つのストリーミング・マイクロプロセッサを含んでもよい。少なくとも一実施例では、GPU1108は、コンピュート・アプリケーション・プログラミング・インターフェース(API)を使用してもよい。少なくとも一実施例では、GPU1108は、1つ又は複数の並列なコンピューティング・プラットフォーム、及び/又はプログラミング・モジュール(たとえば、NVIDIAのCUDAモデル)を使用してもよい。
【0093】
少なくとも一実施例では、GPU1108のうちの1つ又は複数は、自動車用及び組み込まれたユース・ケースにおいて最良の性能になるように電力最適化されてもよい。たとえば、一実施例では、GPU1108は、フィン電界効果トランジスタ(「FinFET」:Fin field-effect transistor)回路上で作製することができる。少なくとも一実施例では、各ストリーミング・マイクロプロセッサは、複数のブロックに区分けされた多数の混合精度の処理コアを組み込んでもよい。たとえば、限定することなく64個のPF32コアと、32個のPF64コアを、4つの処理ブロックに区分けすることができる。少なくとも一実施例では、各処理ブロックに、16個のFP32コア、8個のFP64コア、16個のINT32コア、深層学習の行列演算用の2つの混合精度のNVIDIAテンソル・コア、レベルゼロ(「L0」)命令キャッシュ、ワープ・スケジューラ、ディスパッチ・ユニット、及び/又は64KBのレジスタ・ファイルを配分することができる。少なくとも一実施例では、ストリーミング・マイクロプロセッサは、整数と浮動小数点の独立した並列のデータ経路を含み、コンピュータ処理とアドレッシング計算を混用することによってワークロードの効率的な実行を実現する。少なくとも一実施例では、ストリーミング・マイクロプロセッサは、独立したスレッド・スケジューリング機能を含み、並列スレッド間でよりきめ細かい同期及び連携を可能にしてもよい。少なくとも一実施例では、ストリーミング・マイクロプロセッサは、性能を向上させると同時にプログラミングを簡単にするために、L1データ・キャッシュと共有メモリ・ユニットの組合せを含んでもよい。
【0094】
少なくとも一実施例では、GPU1108のうちの1つ又は複数は、高帯域幅メモリ(「HBM」:high bandwidth memory)及び/又は16GBのHBM2メモリ・サブシステムを含み、いくつかの例では、約900GB/秒のピーク・メモリ帯域幅を提供してもよい。少なくとも一実施例では、HBMメモリに加えて、又はその代わりに、グラフィックス・ダブル・データ・レート・タイプの5つの同期ランダム・アクセス・メモリ(「GDDR5」:graphics double data rate type five)などの同期グラフィックス・ランダム・アクセス・メモリ(「SGRAM」:synchronous graphics random-access memory)が使用されてもよい。
【0095】
少なくとも一実施例では、GPU1108は、統合メモリ技術を含んでもよい。少なくとも一実施例では、アドレス・トランスレーション・サービス(「ATS」:address translation services)サポートを使用して、GPU1108が、CPU1106のページ・テーブルに直接アクセスできるようにしてもよい。少なくとも一実施例では、GPU1108メモリ管理ユニット(「MMU」:memory management unit)のGPUがミスに遭遇したときには、アドレス・トランスレーション要求が、CPU1106に送信されてもよい。少なくとも一実施例では、それに応答して、CPU1106のうちの1つのCPUが、自らのページ・テーブルで、仮想から物理へのアドレスのマッピングを探し、トランスレーションをGPU1108に送り返してもよい。少なくとも一実施例では、統合メモリ技術は、CPU1106とGPU1108の両方のメモリに対して単一の統合された仮想アドレス空間を与えることを可能にし、それにより、GPU1108のプログラミング、及びGPU1108へのアプリケーションの移植を簡単にする。
【0096】
少なくとも一実施例では、GPU1108は、他のプロセッサのメモリへのGPU1108のアクセス頻度を記録することができる任意の数のアクセス・カウンタを含んでもよい。少なくとも一実施例では、アクセス・カウンタは、最も頻繁にページにアクセスしているプロセッサの物理メモリに、メモリ・ページが確実に移動されるのを補助し、それにより、プロセッサ間で共有されるメモリ範囲の効率を向上させてもよい。
【0097】
少なくとも一実施例では、SoC1104のうちの1つ又は複数は、本明細書に記載のものを含む任意の数のキャッシュ1112を含んでもよい。たとえば、少なくとも一実施例では、キャッシュ1112は、CPU1106もGPU1108も利用可能な(たとえば、CPU1106とGPU1108の両方に接続された)レベル3(「L3」)キャッシュを含むことができる。少なくとも一実施例では、キャッシュ1112は、キャッシュ・コヒーレンス・プロトコルなど(たとえば、MEI、MESI、MSIなど)を使用することにより、線の状態を記録することができるライト・バック・キャッシュを含んでもよい。少なくとも一実施例では、L3キャッシュは、実施例に応じて4MB以上のメモリを含んでもよいが、より小さいキャッシュ・サイズが使用されてもよい。
【0098】
少なくとも一実施例では、SoC1104のうちの1つ又は複数は、1つ又は複数のアクセラレータ1114(たとえば、ハードウェア・アクセラレータ、ソフトウェアアクセラレータ、又はこれらの組合せ)を含んでもよい。少なくとも一実施例では、SoC1104は、最適化されたハードウェア・アクセラレータ及び/又は大型のオン・チップ・メモリを含むことができるハードウェア加速クラスタを含んでもよい。少なくとも一実施例では、大型のオン・チップ・メモリ(たとえば、4MBのSRAM)は、ハードウェア加速クラスタが、ニューラル・ネットワーク及び他の計算を加速できるようにしてもよい。少なくとも一実施例では、ハードウェア加速クラスタを使用して、GPU1108を補完し、GPU1108のタスクのうちのいくつかをオフロードしてもよい(たとえば、他のタスクを実行できるようにGPU1108のサイクルをより多く解放してもよい)。少なくとも一実施例では、加速を受け入れるのに十分なほど安定している目的とするワークロード(たとえば、知覚、畳み込みニューラル・ネットワーク(「CNN」:convolutional neural network)、再帰ニューラル・ネットワーク(「RNN」:recurrent neural network)など)のために、アクセラレータ1114を使用することができる。少なくとも一実施例では、CNNは、領域ベースの、すなわち領域畳み込みニューラル・ネットワーク(「RCNN」:regional convolutional neural network)、及び(たとえば、物体検出に使用される)高速RCNN、又は他のタイプのCNNを含んでもよい。
【0099】
少なくとも一実施例では、アクセラレータ1114(たとえば、ハードウェア加速クラスタ)は、1つ又は複数の深層学習アクセラレータ(「DLA」:deep learning accelerator)を含んでもよい。少なくとも一実施例では、DLAは、限定することなく、1つ又は複数のTensor処理ユニット(「TPU」:Tensor processing units)を含んでもよく、このユニットは、深層学習アプリケーション及び推論のために、さらに毎秒10兆の演算を提供するように構成されてもよい。少なくとも一実施例では、TPUは、画像処理機能(たとえば、CNN、RCNNなど)を実行するように構成され、そのために最適化されたアクセラレータであってもよい。少なくとも一実施例では、DLAはさらに、ニューラル・ネットワーク・タイプと浮動小数点演算の特定のセット、並びに推論のために最適化されてもよい。少なくとも一実施例では、DLAの設計により、典型的な汎用GPUよりもミリメートル当たりの性能を向上させることができ、典型的には、CPUの性能を大いに上回る。少なくとも一実施例では、TPUは、たとえば特徴と重みの両方のためのINT8、INT16、及びFP16のデータ型をサポートする単一インスタンスの畳み込み関数、並びに後処理関数を含む、いくつか関数を実行してもよい。少なくとも一実施例では、DLAは、たとえば、限定することなく、カメラ・センサからのデータを使用した物体識別及び検出のためのCNN、カメラ・センサからのデータを使用した距離推定のためのCNN、マイクロフォンからのデータを使用した緊急車両検出、及び識別、及び検出のためのCNN、カメラ・センサからのデータを使用した顔認識及び車両所有者識別ためのCNN、並びに/又はセキュリティ及び/若しくは安全に関するイベントのためのCNNを含め、様々な機能のうちのいずれかのための処理済み若しくは未処理のデータに対して、迅速且つ効率的にニューラル・ネットワーク、特にCNNを実行してもよい。
【0100】
少なくとも一実施例では、DLAは、GPU1108の任意の機能を実行してもよく、たとえば推論アクセラレータを使用することにより、設計者は、任意の機能のためにDLA又はGPU1108のいずれかをターゲットにしてもよい。たとえば、少なくとも一実施例では、設計者は、CNN及び浮動小数点演算の処理をDLAに集中させ、他の機能をGPU1108及び/又はアクセラレータ1114に任せてもよい。
【0101】
少なくとも一実施例では、アクセラレータ1114は、プログラマブル・ビジョン・アクセラレータ(「PVA」:programmable vision accelerator)を含んでもよく、このプログラマブル・ビジョン・アクセラレータは、本明細書において代替的にコンピュータ・ビジョン・アクセラレータと呼ばれてもよい。少なくとも一実施例では、PVAは、先進ドライバ支援システム(「ADAS」)1138、自律運転、拡張現実(「AR」:augmented reality)アプリケーション、及び/又は仮想現実(「VR」:virtual reality)アプリケーションのために、コンピュータ・ビジョン・アルゴリズムを加速するように設計及び構成されてもよい。少なくとも一実施例では、PVAは、性能と柔軟性との間のバランスを提供することができる。たとえば、少なくとも一実施例では、各PVAは、たとえば限定することなく、任意の数の縮小命令セット・コンピュータ(「RISC」:reduced instruction set computer)コア、ダイレクト・メモリ・アクセス(「DMA」:direct memory access)、及び/又は任意の数のベクトル・プロセッサを含んでもよい。
【0102】
少なくとも一実施例では、RISCコアは、画像センサ(たとえば、本明細書に記載の任意のカメラの画像センサ)、及び/又は画像信号プロセッサなどと相互作用してもよい。少なくとも一実施例では、RISCコアのそれぞれは、任意の量のメモリを含んでもよい。少なくとも一実施例では、RISCコアは、実施例に応じて複数のプロトコルのうちの任意のものを使用してもよい。少なくとも一実施例では、RISCコアは、リアル・タイム・オペレーティング・システム(「RTOS」:real-time operating system)を実行してもよい。少なくとも一実施例では、RISCコアは、1つ又は複数の集積回路デバイス、特定用途向け集積回路(「ASIC」)、及び/又はメモリ・デバイスを使用して実施されてもよい。たとえば、少なくとも一実施例では、RISCコアは、命令キャッシュ及び/又は密結合RAMを含むことができる。
【0103】
少なくとも一実施例では、DMAは、PVAの構成要素がCPU1106とは無関係にシステム・メモリにアクセスできるようにしてもよい。少なくとも一実施例では、DMAは、多次元アドレッシング、及び/又はサーキュラ・アドレッシングを含むがこれらに限定されない、PVAに最適化を提供するために使用される任意の数の特徴をサポートしてもよい。少なくとも一実施例では、DMAは、6つ以上のアドレッシング次元までをサポートしてもよく、これには、限定することなく、ブロック幅、ブロック高さ、ブロック深度、水平ブロック・ステッピング、垂直ブロック・ステッピング、及び/又は深度ステッピングが含まれてもよい。
【0104】
少なくとも一実施例では、ベクトル・プロセッサは、コンピュータ・ビジョン・アルゴリズムのためのプログラミングを効率的でフレキシブルに実行するように設計されてもよいプログラム可能なプロセッサとすることができ、信号処理機能を提供する。少なくとも一実施例では、PVAは、PVAコアと、2つのベクトル処理サブシステム・パーティションを含んでもよい。少なくとも一実施例では、PVAコアは、プロセッサ・サブシステム、DMAエンジン(たとえば2つのDMAエンジン)、及び/又は他の周辺装置を含んでもよい。少なくとも一実施例では、ベクトル処理サブシステムは、PVAの一次処理エンジンとして動作してもよく、ベクトル処理ユニット(「VPU」:vector processing unit)、命令キャッシュ、及び/又はベクトル・メモリ(たとえば、「VMEM」)を含んでもよい。少なくとも一実施例では、VPUコアは、たとえば単一命令複数データ(「SIMD」:single instruction, multiple data)、超長命令語(「VLIW」:very long instruction word)のデジタル信号プロセッサなどのデジタル信号プロセッサを含んでもよい。少なくとも一実施例では、SIMDとVLIWの組合せによって、スループット及びスピードが改善されてもよい。
【0105】
少なくとも一実施例では、ベクトル・プロセッサのそれぞれは、命令キャッシュを含んでもよく、専用のメモリに結合されてもよい。その結果、少なくとも一実施例では、ベクトル・プロセッサのそれぞれは、他のベクトル・プロセッサとは無関係に実行されるように構成されてもよい。少なくとも一実施例では、特定のPVAに含まれるベクトル・プロセッサは、データ並列処理を用いるように構成されてもよい。たとえば、少なくとも一実施例では、単一のPVAに含まれる複数のベクトル・プロセッサは、共通のコンピュータ・ビジョン・アルゴリズムを画像の異なる領域上で実行してもよい。少なくとも一実施例では、特定のPVAに含まれるベクトル・プロセッサは、異なるコンピュータ・ビジョン・アルゴリズムを1つの画像上で同時に実行してもよく、又はさらには、異なるアルゴリズムを連続した画像上で、若しくは画像の部分上で実行してもよい。少なくとも一実施例では、とりわけ、任意の数のPVAがハードウェア加速クラスタに含まれてもよく、任意の数のベクトル・プロセッサが各PVAに含まれてもよい。少なくとも一実施例では、PVAは、システムの全体的な安全性を強化するために、追加のエラー訂正コード(「ECC」:Error Correction Code)メモリを含んでもよい。
【0106】
少なくとも一実施例では、アクセラレータ1114は、オン・チップのコンピュータ・ビジョン・ネットワーク、及びスタティック・ランダム・アクセス・メモリ(「SRAM」)を含み、アクセラレータ1114のための高帯域幅、低レイテンシのSRAMを提供してもよい。少なくとも一実施例では、オン・チップ・メモリは、たとえば限定することなく、8つのフィールド設定可能なメモリ・ブロックから成る少なくとも4MBのSRAMを含んでもよく、これは、PVAからもDLAからもアクセス可能であってもよい。少なくとも一実施例では、メモリ・ブロックの各対は、アドバンスト・ペリフェラル・バス(「APB」:advanced peripheral bus)インターフェース、構成回路、コントローラ、及びマルチプレクサを含んでもよい。少なくとも一実施例では、任意のタイプのメモリが使用されてもよい。少なくとも一実施例では、PVA及びDLAは、メモリへの高速アクセスをPVA及びDLAに提供するバックボーンを介して、メモリにアクセスしてもよい。少なくとも一実施例では、バックボーンは、PVA及びDLAを(たとえばAPBを使用して)メモリに相互接続するオン・チップのコンピュータ・ビジョン・ネットワークを含んでもよい。
【0107】
少なくとも一実施例では、オン・チップのコンピュータ・ビジョン・ネットワークは、何らかの制御信号/アドレス/データを送信する前に、PVAとDLAの両方が準備信号及び有効信号を提供することを判定するインターフェースを含んでもよい。少なくとも一実施例では、インターフェースは、制御信号/アドレス/データを送信するための別々の位相及び別々のチャネル、並びに継続的なデータ転送のためのバースト型通信を提供してもよい。少なくとも一実施例では、インターフェースは、国際標準化機構(「ISO」:International Organization for Standardization)26262又は国際電気標準会議(「IEC」:International Electrotechnical Commission)61508の規格に準拠してもよいが、他の規格及びプロトコルが使用されてもよい。
【0108】
少なくとも一実施例では、SoC1104のうちの1つ又は複数は、リアル・タイム・レイ・トレーシングのハードウェア・アクセラレータを含んでもよい。少なくとも一実施例では、リアル・タイム・レイ・トレーシングのハードウェア・アクセラレータを使用して、物体の(たとえば世界モデル内での)位置及び範囲が迅速且つ効率的に判定されて、RADAR信号解釈のため、音伝播合成及び/若しくは分析のため、SONARシステムのシミュレーションのため、一般波形の伝播シミュレーションのため、ローカリゼーション及び/若しくは他の機能を目的としたLIDARデータとの比較のため、並びに/又は他の使用法のためのリアル・タイムの可視化シミュレーションが生成されてもよい。
【0109】
少なくとも一実施例では、アクセラレータ1114は、自律運転のための多様な用途を有する。少なくとも一実施例では、PVAは、ADAS及び自律車両の主要な処理ステージに使用することができる。少なくとも一実施例では、PVAの性能は、低電力及び低レイテンシの予測可能な処理を必要とするアルゴリズム・ドメインに良好に適合する。言い換えれば、PVAは、低レイテンシ及び低電力の予測可能なラン・タイムを必要とし得る半稠密(semi-dense)又は稠密な規則的計算に対して、データ・セットが小さくても良好に機能する。少なくとも一実施例では、車両1100などにおいて、従来のコンピュータ・ビジョン・アルゴリズムを実行するようにPVAが設計され得るが、これは、それらが、物体検出及び整数数値の演算に有効であり得るためである。
【0110】
たとえば、技術の少なくとも一実施例によれば、PVAを使用して、コンピュータ・ステレオ・ビジョンが実行されてもよい。少なくとも一実施例では、いくつかの例においてセミ・グローバル・マッチングに基づくアルゴリズムが使用されてもよいが、これは限定するものではない。少なくとも一実施例では、レベル3~5の自律運転のためのアプリケーションは、動き推定/ステレオ・マッチング(たとえば、動きからの構造化、歩行者認識、車線検出など)をオン・ザ・フライで使用する。少なくとも一実施例では、PVAは、2つの単眼カメラからの入力に対して、コンピュータ・ステレオ・ビジョン機能を実行してもよい。
【0111】
少なくとも一実施例では、PVAを使用して、高密度オプティカル・フローが実行されてもよい。たとえば、少なくとも一実施例では、PVAは、未加工のRADARデータを(たとえば4Dの高速フーリエ変換を使用して)処理して、処理済みRADARデータを提供することができる。少なくとも一実施例では、PVAは、飛行時間の深度処理に使用され、たとえば未加工の飛行時間データを処理することにより、処理済みの飛行時間データが提供される。
【0112】
少なくとも一実施例では、たとえば限定することなく、物体検出ごとに信頼性の尺度を出力するニューラル・ネットワークを含む、制御及び運転の安全性を強化するための任意のタイプのネットワークを実行するために、DLAが使用されてもよい。少なくとも一実施例では、信頼性は、他の検出と比較した各検出の確率として、若しくはその相対的な「重み」を提供するものとして表されても、又は解釈されてもよい。少なくとも一実施例では、信頼性尺度によって、どの検出を誤検出ではなく正検出とみなすべきかに関して、システムがさらなる判定を下せるようになる。少なくとも一実施例では、システムは、信頼性に対して閾値を設定し、閾値を超える検出だけを正検出とみなしてもよい。自動緊急ブレーキ(「AEB」:automatic emergency braking)が使用される実施例では、誤検出によって車両は自動的に緊急ブレーキをかけることになり、これは明らかに望ましくない。少なくとも一実施例では、非常に信頼性の高い検出が、AEBのトリガとみなされてもよい。少なくとも一実施例では、DLAは、信頼値を回帰するようにニューラル・ネットワークを実行してもよい。少なくとも一実施例では、ニューラル・ネットワークは、とりわけ境界ボックスの次元、(たとえば別のサブシステムから)取得した地面推定、車両1100の配向と相関しているIMUセンサ1166からの出力、距離、ニューラル・ネットワーク及び/又は他のセンサ(たとえば、LIDARセンサ1164若しくはRADARセンサ1160)から取得した物体の3Dロケーション推定などのパラメータの少なくともいくつかのサブセットを、その入力として取ってもよい。
【0113】
少なくとも一実施例では、SoC1104のうちの1つ又は複数は、データ・ストア1116(たとえばメモリ)を含んでもよい。少なくとも一実施例では、データ・ストア1116は、SoC1104のオン・チップ・メモリであってもよく、このメモリは、GPU1108及び/又はDLA上で実行されるニューラル・ネットワークを記憶してもよい。少なくとも一実施例では、データ・ストア1116の容量は、冗長性及び安全性のためにニューラル・ネットワークの複数のインスタンスを記憶するのに十分なほど大きくてもよい。少なくとも一実施例では、データ・ストア1116は、L2又はL3のキャッシュを備えてもよい。
【0114】
少なくとも一実施例では、SoC1104のうちの1つ又は複数は、任意の数のプロセッサ1110(たとえば、組み込みプロセッサ)を含んでもよい。少なくとも一実施例では、プロセッサ1110は、ブート電力並びに管理機能及び関連するセキュリティ執行に対処するための専用プロセッサ及びサブシステムであってもよいブート及び電力管理プロセッサを含んでもよい。少なくとも一実施例では、ブート及び電力管理プロセッサは、SoC1104のブート・シーケンスの一部であってもよく、ラン・タイム電力管理サービスを提供してもよい。少なくとも一実施例では、ブート電力及び管理プロセッサは、クロックと電圧のプログラミング、システムの低電力状態への移行の支援、SoC1104の熱及び温度センサの管理、並びに/又はSoC1104の電力状態の管理を提供してもよい。少なくとも一実施例では、各温度センサは、その出力周波数が温度に比例するリング発振器として実施されてもよく、SoC1104は、リング発振器を使用して、CPU1106、GPU1108、及び/又はアクセラレータ1114の温度を検出してもよい。少なくとも一実施例では、温度が閾値を超えると判定された場合には、ブート及び電力管理プロセッサは、温度不良ルーチンに入り、SoC1104を低電力状態にし、且つ/又は車両1100を運転手-安全停止モードにしても(たとえば、車両1100を安全停止させる)よい。
【0115】
少なくとも一実施例では、プロセッサ1110は、多重インターフェースを介した多チャネルのオーディオ、及び幅広くフレキシブルな様々なオーディオI/Oインターフェースのための、完全なハードウェア・サポートを可能にするオーディオ・サブシステムであってもよいオーディオ処理エンジンとしての役割を果たすことができる組み込みプロセッサのセットをさらに含んでもよい。少なくとも一実施例では、オーディオ処理エンジンは、専用RAMのあるデジタル信号プロセッサを有する専用プロセッサ・コアである。
【0116】
少なくとも一実施例では、プロセッサ1110はさらに、低電力センサ管理及び立ち上げのユース・ケースをサポートするのに必要なハードウェア特徴を提供することができる常時オン・プロセッサ・エンジンを含んでもよい。少なくとも一実施例では、常時オン・プロセッサ・エンジンは、限定することなく、プロセッサ・コア、密結合RAM、サポート周辺装置(たとえば、タイマ、及び割込みコントローラ)、様々なI/Oコントローラ周辺装置、及びルーティング論理を含んでもよい。
【0117】
少なくとも一実施例では、プロセッサ1110はさらに安全クラスタ・エンジンを含んでもよく、このエンジンは限定することなく、自動車用途の安全管理に対処するための専用のプロセッサ・サブシステムを含む。少なくとも一実施例では、安全クラスタ・エンジンは、限定することなく、2つ以上のプロセッサ・コア、密結合RAM、サポート周辺装置(たとえば、タイマ、及び割込みコントローラなど)、及び/又はルーティング論理を含んでもよい。安全モードでは、少なくとも一実施例においてロックステップ・モードで2つ以上のコアが動作し、これらの動作間で何らかの差を検出するための比較論理を有する単一コアとして機能してもよい。少なくとも一実施例では、プロセッサ1110はさらにリアル・タイム・カメラ・エンジンを含んでもよく、このエンジンは限定することなく、リアル・タイムのカメラ管理に対処するための専用のプロセッサ・サブシステムを含んでもよい。少なくとも一実施例では、プロセッサ1110はさらに、高ダイナミック・レンジの信号プロセッサを含んでもよく、この信号プロセッサは、カメラ処理パイプラインの一部であるハードウェア・エンジンである画像信号プロセッサを限定することなく含んでもよい。
【0118】
少なくとも一実施例では、プロセッサ1110は、ビデオ画像合成器を含んでもよく、この合成器は、再生装置のウィンドウに最終画像を生成するのにビデオ再生アプリケーションが必要とするビデオ後処理機能を実施する(たとえばマイクロプロセッサに実施された)処理ブロックであってもよい。少なくとも一実施例では、ビデオ画像合成器は、広角カメラ1170、周囲カメラ1174、及び/又はキャビン内監視カメラ・センサに対して、レンズゆがみ補正を実行してもよい。少なくとも一実施例では、キャビン内監視カメラ・センサは、好ましくは、キャビン内のイベントを識別し、それに適宜応答するように構成された、SoC1104の別のインスタンスで実行されているニューラル・ネットワークによって監視される。少なくとも一実施例では、キャビン内システムは、セルラー・サービスをアクティブ化し、電話をかけたり、電子メールを書いたり、車両の行き先を変更したり、車両のインフォテイメント・システム及び設定をアクティブ化又は変更したり、音声作動式のウェブ・サーフィンを提供したりするために、限定することなく読唇を実行してもよい。少なくとも一実施例では、ある一定の機能は、車両が自律モードで動作しているときにドライバにとって利用可能になり、それ以外のときには使用不可になる。
【0119】
少なくとも一実施例では、ビデオ画像合成器は、空間と時間の両方のノイズ低減のための拡張された時間的ノイズ低減を含んでもよい。たとえば、少なくとも一実施例では、ビデオで動きが生じる場合には、ノイズ低減が空間情報に適切に重み付けして、隣接するフレームによって提供される情報の重みを軽くする。少なくとも一実施例では、画像又は画像の一部分が動きを含まない場合には、ビデオ画像合成器により実行される時間的ノイズ低減は、前の画像からの情報を使用して、現在の画像のノイズを低減してもよい。
【0120】
少なくとも一実施例では、ビデオ画像合成器はまた、入力されたステレオ・レンズ・フレームに対してステレオ平行化を実行するように構成されてもよい。少なくとも一実施例では、ビデオ画像合成器はさらに、オペレーティング・システムのデスクトップが使用中のときに、ユーザ・インターフェースを合成するために使用されてもよく、GPU1108は、新規の表面を継続的にレンダリングする必要がなくなる。少なくとも一実施例では、GPU1108の電源が入れられ、アクティブで3Dレンダリングを行っているとき、性能及び応答性を向上させるために、ビデオ画像合成器を使用してGPU1108をオフロードしてもよい。
【0121】
少なくとも一実施例では、SoC1104のうちの1つ又は複数のSoCはさらに、ビデオ及びカメラからの入力を受信するためのモバイル・インダストリ・プロセッサ・インターフェース(「MIPI」:mobile industry processor interface)のカメラ直列インターフェース、高速インターフェース、並びに/又はカメラ及び関連ピクセルの入力機能に使用されてもよいビデオ入力ブロックを含んでもよい。少なくとも一実施例では、SoC1104のうちの1つ又は複数はさらに、入力/出力コントローラを含んでもよく、このコントローラはソフトウェアによって制御されてもよく、特定の役割に縛られていないI/O信号を受信するために使用されてもよい。
【0122】
少なくとも一実施例では、SoC1104のうちの1つ又は複数のSocはさらに、周辺装置、オーディオ・エンコーダ/デコーダ(「コーデック」)、電力管理、及び/又は他の装置との通信を可能にするための幅広い周辺装置インターフェースを含んでもよい。少なくとも一実施例では、SoC1104は、(たとえば、ギガビット・マルチメディア・シリアル・リンク及びイーサネット(登録商標)チャネルを介して接続された)カメラからのデータ、センサ(たとえば、イーサネット(登録商標)チャネルを介して接続されてもよいLIDARセンサ1164、RADARセンサ1160など)からのデータ、バス1102からのデータ(たとえば、車両1100のスピード、ハンドル位置など)、(たとえば、イーサネット(登録商標)バス又はCANバスを介して接続された)GNSSセンサ1158からのデータなどを処理するために使用されてもよい。少なくとも一実施例では、SoC1104のうちの1つ又は複数のSoCはさらに、専用の高性能大容量ストレージ・コントローラを含んでもよく、このコントローラは独自のDMAエンジンを含んでもよく、ルーチンのデータ管理タスクからCPU1106を解放するために使用されてもよい。
【0123】
少なくとも一実施例では、SoC1104は、自動化レベル3~5に及ぶフレキシブルなアーキテクチャを有するエンドツーエンドのプラットフォームであってもよく、それにより、多様性及び冗長性を得るためにコンピュータ・ビジョン及びADAS技法を活用し効率的に利用する包括的な機能的安全性アーキテクチャが提供され、フレキシブルで、信頼性の高い運転ソフトウェア・スタックが、深層学習ツールとともに提供される。少なくとも一実施例では、SoC1104は、従来のシステムより高速で、信頼性が高く、さらにはエネルギー効率及び空間効率が高い。たとえば、少なくとも一実施例では、アクセラレータ1114は、CPU1106、GPU1108、及びデータ・ストア1116と組み合わされると、レベル3~5の自律車両のための高速で効率的なプラットフォームを実現することができる。
【0124】
少なくとも一実施例では、コンピュータ・ビジョン・アルゴリズムはCPU上で実行されてもよく、このアルゴリズムは、Cなどの高レベル・プログラミング言語を使用して構成されて、多様な視覚データにわたって多様な処理アルゴリズムを実行してもよい。しかし、少なくとも一実施例では、CPUは、多くのコンピュータ・ビジョン・アプリケーションの性能要件、たとえば実行時間及び電力消費に関する要件などを満足できないことが多い。少なくとも一実施例では、多くのCPUは、車両内のADASアプリケーション及び現実的なレベル3~5の自律車両において使用される複雑な物体検出アルゴリズムを、リアル・タイムで実行することができない。
【0125】
本明細書に記載の実施例は、複数のニューラル・ネットワークを同時に且つ/又は順番に実行できるようにし、結果を組み合わせて、レベル3~5の自律運転機能を可能にすることができる。たとえば、少なくとも一実施例では、DLA又は個別GPU(たとえば、GPU1120)上で実行しているCNNは、テキスト及び単語認識を含んでもよく、ニューラル・ネットワークがそれについて特に訓練されてこなかった標識を含む交通標識を、読み、理解できるようにする。少なくとも一実施例では、DLAはさらに、標識を識別し、解釈し、標識の意味的理解を提供することができ、その意味的理解を、CPUコンプレックス上で実行されている経路計画モジュールに渡すことができるニューラル・ネットワークを含んでもよい。
【0126】
少なくとも一実施例では、レベル3、4、又は5の運転に関して、複数のニューラル・ネットワークが同時に実行されてもよい。たとえば、少なくとも一実施例では、電光と併せて「注意:点滅時は凍結状態」と記述する警告標識は、いくつかのニューラル・ネットワークによって別々に解釈されても、集合的に解釈されてもよい。少なくとも一実施例では、そのような警告標識自体は、第1の導入済みニューラル・ネットワーク(たとえば、訓練されてきたニューラル・ネットワーク)によって交通標識として識別されてもよく、「点滅時は凍結状態」という文字は、第2の導入済みニューラル・ネットワークによって解釈されてもよく、点滅光が検出された場合には、このニューラル・ネットワークが、凍結状態が存在することを車両の(好ましくはCPUコンプレックス上で実行している)経路計画ソフトウェアに通知する。少なくとも一実施例では、点滅光は、第3の導入済みニューラル・ネットワークを複数のフレームにわたって動作させることによって識別されてもよく、点滅光の存在(又は存在しないこと)が、車両の経路計画ソフトウェアに通知される。少なくとも一実施例では、3つすべてのニューラル・ネットワークが、DLA内及び/又はGPU1108上などで同時に実行されてもよい。
【0127】
少なくとも一実施例では、顔認識及び車両所有者識別のためのCNNは、カメラ・センサからのデータを使用して、車両1100の承認済みのドライバ及び/又は所有者の存在を識別してもよい。少なくとも一実施例では、常時オンのセンサ処理エンジンを使用して、所有者がドライバ用ドアに近づいてきたときに車両を解錠し、ライトを点灯させ、所有者がそのような車両から離れるときには、セキュリティ・モードで車両を使用不可にしてもよい。こうして、SoC1104は、窃盗及び/又は自動車乗っ取りに対するセキュリティを実現する。
【0128】
少なくとも一実施例では、緊急車両の検出及び識別のためのCNNは、マイクロフォン1196からのデータを使用して、緊急車両のサイレンを検出及び識別してもよい。少なくとも一実施例では、SoC1104は、環境及び市街地の音を分類するとともに、視覚データを分類するためにCNNを使用する。少なくとも一実施例では、DLA上で実行されるCNNは、緊急車両が近づいてくる相対的なスピードを(たとえばドップラー効果を使用することによって)識別するように訓練される。少なくとも一実施例では、CNNはまた、GNSSセンサ1158によって識別される、車両が稼働している地域に特有の緊急車両を識別するように訓練されてもよい。少なくとも一実施例では、欧州で稼働している場合には、CNNは欧州のサイレンを検出しようとし、北米の場合には、北米のサイレンだけを識別しようとする。少なくとも一実施例では、緊急車両が検出されると、緊急車両安全ルーチンを実行するための制御プログラムを使用して、車両の速度を落とし、道路脇に寄せ、車両を停止させ、且つ/又は緊急車両が通過するまで、超音波センサ1162を併用して車両をアイドリングにしてもよい。
【0129】
少なくとも一実施例では、車両1100はCPU1118(たとえば、個別CPU又はdCPU)を含んでもよく、このCPUは高速相互接続(たとえば、PCIe)を介してSoC1104に結合されてもよい。少なくとも一実施例では、CPU1118は、たとえばX86プロセッサを含んでもよい。CPU1118は、たとえば、ADASセンサとSoC1104の間で潜在的に不整合な結果を調停すること、並びに/又はコントローラ1136及び/若しくはチップ上のインフォテイメント・システム(「インフォテイメントSoC」)1130の状態及び健全性を監視することを含め、様々な機能のうちの任意の機能を実行するために使用されてもよい。
【0130】
少なくとも一実施例では、車両1100はGPU1120(たとえば、個別GPU又はdGPU)を含んでもよく、このGPUは高速相互接続(たとえば、NVIDIAのNVLINKチャネル)を介してSoC1104に結合されてもよい。少なくとも一実施例では、GPU1120は、冗長な及び/又は異なるニューラル・ネットワークを実行することなどによって、追加の人工知能機能を提供してもよく、車両1100のセンサからの入力(たとえば、センサ・データ)に少なくとも部分的に基づき、ニューラル・ネットワークを訓練及び/又は更新するために使用されてもよい。
【0131】
少なくとも一実施例では、車両1100はさらに、ネットワーク・インターフェース1124を含んでもよく、このインターフェースは限定することなく、ワイヤレス・アンテナ1126(たとえば、セルラー・アンテナ、Bluetoothアンテナなど、異なる通信プロトコル向けの1つ又は複数のワイヤレス・アンテナ)を含んでもよい。少なくとも一実施例では、クラウド(たとえば、サーバ及び/又は他のネットワーク・デバイス)、他の車両、及び/又はコンピューティング・デバイス(たとえば、乗員のクライアント・デバイス)とのインターネット・クラウド・サービスに対するワイヤレス接続を可能にするために、ネットワーク・インターフェース1124が使用されてもよい。少なくとも一実施例では、他の車両と通信するために、車両110と別の車両との間に直接リンクが確立されてもよく、且つ/又は(たとえば、ネットワークにわたって、且つインターネットを介して)間接リンクが確立されてもよい。少なくとも一実施例では、直接リンクは、車車間通信リンクを使用して提供されてもよい。少なくとも一実施例では、車車間通信リンクは、車両1100の近傍の車両(たとえば、車両1100の前方、側方、及び/又は後方の車両)についての情報を車両1100に提供してもよい。少なくとも一実施例では、そのような前述した機能は、車両1100の協調型アダプティブ・クルーズ・コントロール機能の一部であってもよい。
【0132】
少なくとも一実施例では、ネットワーク・インターフェース1124は、変調及び復調の機能を提供し、コントローラ1136がワイヤレス・ネットワークを介して通信できるようにするSoCを含んでもよい。少なくとも一実施例では、ネットワーク・インターフェース1124は、ベースバンドから無線周波数へのアップ・コンバージョン、及び無線周波数からベースバンドへのダウン・コンバージョンのための無線周波数フロント・エンドを含んでもよい。少なくとも一実施例では、周波数変換は、任意の技術的に実行可能なやり方で実行されてもよい。たとえば、周波数変換は、よく知られたプロセスにより、且つ/又はスーパー・ヘテロダイン・プロセスを使用して実行することができる。少なくとも一実施例では、無線周波数フロント・エンド機能は、別個のチップによって提供されてもよい。少なくとも一実施例では、ネットワーク・インターフェースは、LTE、WCDMA(登録商標)、UMTS、GSM、CDMA2000、Bluetooth、Bluetooth LE、Wi-Fi、Z-Wave、ZigBee、LoRaWAN、及び/又は他のワイヤレス・プロトコルを介して通信するためのワイヤレス機能を含んでもよい。
【0133】
少なくとも一実施例では、車両1100はさらにデータ・ストア1128を含んでもよく、このデータ・ストアは限定することなく、オフ・チップ(たとえばSoC1104上にない)ストレージを含んでもよい。少なくとも一実施例では、データ・ストア1128は、RAM、SRAM、ダイナミック・ランダム・アクセス・メモリ(「DRAM」)、ビデオ・ランダム・アクセス・メモリ(「VRAM」:video random-access memory)、フラッシュ・メモリ、ハード・ディスク、並びに/又は少なくとも1ビットのデータを記憶することができる他の構成要素及び/若しくはデバイスを含む1つ若しくは複数のストレージ要素を、限定することなく含んでもよい。
【0134】
少なくとも一実施例では、車両1100はさらに、マッピング、知覚、占有グリッド生成、及び/又は経路計画の機能を支援するためのGNSSセンサ1158(たとえば、GPS及び/又は補助GPSセンサ)を含んでもよい。少なくとも一実施例では、イーサネット(登録商標)からシリアル(たとえばRS-232)へのブリッジを有するUSBコネクタを使用するGPSをたとえば限定することなく含む任意の数のGNSSセンサ1158が使用されてもよい。
【0135】
少なくとも一実施例では、車両1100はさらに、RADARセンサ1160を含んでもよい。少なくとも一実施例では、RADARセンサ1160は、暗闇及び/又は厳しい気象条件の中でも、長距離の車両検出を行うために車両1100によって使用されてもよい。少なくとも一実施例では、RADARの機能的安全性レベルは、ASIL Bであってもよい。少なくとも一実施例では、RADARセンサ1160は、制御のために(たとえば、RADARセンサ1160によって生成されたデータを送信するために)、また物体追跡データにアクセスするために、CANバス及び/又はバス1102を使用してもよく、いくつかの例では、未加工データにアクセスするためにイーサネット(登録商標)チャネルにアクセスできる。少なくとも一実施例では、多様なタイプのRADARセンサが使用されてもよい。たとえば限定することなく、RADARセンサ1160は、前方、後方、及び側方のRADAR使用に好適であってもよい。少なくとも一実施例では、RADARセンサ1160のうちの1つ又は複数のセンサは、パルス・ドップラーRADARセンサである。
【0136】
少なくとも一実施例では、RADARセンサ1160は、狭視野の長距離、広視野の短距離、側面を網羅する短距離など、異なる構成を含んでもよい。少なくとも一実施例では、長距離RADARは、アダプティブ・クルーズ・コントロール機能のために使用されてもよい。少なくとも一実施例では、長距離RADARシステムは、2つ以上の独立した走査によって実現される250m(メートル)の範囲内などの広視野を提供してもよい。少なくとも一実施例では、RADARセンサ1160は、静的物体と移動している物体とを区別しやすくしてもよく、緊急ブレーキ支援及び前方衝突警告を行うためにADASシステム1138によって使用されてもよい。少なくとも一実施例では、長距離RADARシステムに含まれるセンサ1160は、複数の(たとえば6つ以上の)固定RADARアンテナ、並びに高速CAN及びFlexRayインターフェースを有するモノスタティックのマルチモードRADARを、限定することなく含んでもよい。少なくとも一実施例では、6つのアンテナがある場合、中央の4つのアンテナは、隣接した車線からの干渉が最小の状態で、より高速で車両1100の周囲を記録するように設計された集中したビーム・パターンを生成してもよい。少なくとも一実施例では、別の2つのアンテナは、視野を拡張してもよく、車両1100の車線に入る又はそこから出る車両を迅速に検出するのを可能にする。
【0137】
少なくとも一実施例では、中距離RADARシステムは、一例として最大160m(前方)、又は80m(後方)の範囲、及び最大42度(前方)、又は150度(後方)の視野を含んでもよい。少なくとも一実施例では、短距離RADARシステムは、限定することなく、後方バンパの両端部に設置されるように設計された任意の数のRADARセンサ1160を含んでもよい。後方バンパの両端部に設置されたとき、少なくとも一実施例では、RADARセンサ・システムは、後部方向及び車両隣の死角を常に監視する2本のビームを生成してもよい。少なくとも一実施例では、短距離RADARシステムは、死角検出及び/又は車線変更支援を行うために、ADASシステム1138において使用されてもよい。
【0138】
少なくとも一実施例では、車両1100はさらに、超音波センサ1162を含んでもよい。少なくとも一実施例では、車両1100の前方、後方、及び/又は側方ロケーションに配置されてもよい超音波センサ1162は、駐車支援のため、且つ/又は占有グリッドを生成し更新するために使用されてもよい。少なくとも一実施例では、多様な超音波センサ1162が使用されてもよく、異なる検出範囲(たとえば、2.5m、4m)には異なる超音波センサ1162が使用されてもよい。少なくとも一実施例では、超音波センサ1162は、機能的安全性レベルASIL Bで動作してもよい。
【0139】
少なくとも一実施例では、車両1100は、LIDARセンサ1164を含んでもよい。少なくとも一実施例では、LIDARセンサ1164は、物体及び歩行者の検出、緊急ブレーキ、衝突回避、及び/又は他の機能のために使用されてもよい。少なくとも一実施例では、LIDARセンサ1164は、機能的安全性レベルASIL Bにおいて動作してもよい。少なくとも一実施例では、車両1100は、複数のLIDARセンサ1164(たとえば、2つ、4つ、6つなど)を含んでもよく、これらのセンサは、(たとえばデータをギガビット・イーサネット(登録商標)・スイッチに提供するために)イーサネット(登録商標)・チャネルを使用してもよい。
【0140】
少なくとも一実施例では、LIDARセンサ1164は、360度の視野について、物体及びそれらの距離のリストを提供可能であってもよい。少なくとも一実施例では、市販のLIDARセンサ1164は、たとえば宣伝された範囲がおおよそ100mであり、精度が2cm~3cmであり、100Mbpsのイーサネット(登録商標)接続をサポートしてもよい。少なくとも一実施例では、1つ又は複数の非突出型LIDARセンサが使用されてもよい。こうした実施例では、LIDARセンサ1164は、車両1100の前方、後方、側方、及び/又は角ロケーションに組み込むことができる小さいデバイスを含んでもよい。少なくとも一実施例では、こうした実施例のLIDARセンサ1164は、最大120度の水平視野、及び35度の垂直視野を、低反射性の物体に対しても200mの範囲で提供してもよい。少なくとも一実施例では、前方に取り付けられたLIDARセンサ1164は、45度~135度の水平視野をもたらすように構成されてもよい。
【0141】
少なくとも一実施例では、3DフラッシュLIDARなどのLIDAR技術も使用されてよい。少なくとも一実施例では、3DフラッシュLIDARは、レーザのフラッシュを送信源として使用して、車両1100の周囲を最大でおおよそ200mまで照射する。少なくとも一実施例では、フラッシュLIDARユニットは、限定することなくレセプタを含み、このレセプタは、レーザ・パルスの通過時間及び各ピクセルにおける反射光を記録し、それらは、車両1100から物体までの範囲に対応する。少なくとも一実施例では、フラッシュLIDARによって、非常に正確でゆがみのない周囲画像が、レーザのフラッシュごとに生成できるようになる。少なくとも一実施例では、4つのフラッシュLIDARが、車両1100の各側面に1つ導入されてもよい。少なくとも一実施例では、3DフラッシュLIDARシステムは、ファン以外に可動部品のない半導体3D凝視アレイ(staring array)のLIDARカメラ(たとえば、非走査型LIDARデバイス)を、限定することなく含む。少なくとも一実施例では、フラッシュLIDARデバイスは、フレーム当たり5ナノ秒のクラスI(目に安全な)レーザ・パルスを使用してもよく、3D範囲の点群及び位置同期された(co-registered)強度データとして反射レーザ光を捕捉してもよい。
【0142】
少なくとも一実施例では、車両1100はさらに、IMUセンサ1166を含んでもよい。少なくとも一実施例では、IMUセンサ1166は、車両1100の後方車軸の中央に位置付けられてもよい。少なくとも一実施例では、IMUセンサ1166は、たとえば限定することなく、加速度計、磁力計、ジャイロスコープ、磁気コンパス、複数の磁気コンパス、及び/又は他のタイプのセンサを含んでもよい。6軸の用途など少なくとも一実施例では、IMUセンサ1166は限定することなく、加速度計及びジャイロスコープを含んでもよい。9軸の用途など少なくとも一実施例では、IMUセンサ1166は限定することなく、加速度計、ジャイロスコープ、及び磁力計を含んでもよい。
【0143】
少なくとも一実施例では、IMUセンサ1166は、微小電気機械システム(「MEMS」:micro-electro-mechanical systems)慣性センサ、高感度GPS受信機、及び先進のKalmanフィルタリング・アルゴリズムを組み合わせて、位置、速度、及び姿勢の推定値を提供する小型の高性能GPS補強型慣性航法システム(「GPS/INS」:GPS-Aided Inertial Navigation System)として実施されてもよい。少なくとも一実施例では、IMUセンサ1166により、車両1100は、速度変化を直接観察しそれをGPSからIMUセンサ1166に相関させることによって、磁気センサからの入力を必要とせずに車両1100の方位を推定できるようになる。少なくとも一実施例では、IMUセンサ1166及びGNSSセンサ1158は、単一の統合ユニットに組み合わされてもよい。
【0144】
少なくとも一実施例では、車両1100は、車両1100の中及び/又はその周りに設置されたマイクロフォン1196を含んでもよい。少なくとも一実施例では、マイクロフォン1196は、とりわけ緊急車両の検出及び識別のために使用されてもよい。
【0145】
少なくとも一実施例では、車両1100はさらに、ステレオ・カメラ1168、広角カメラ1170、赤外線カメラ1172、周囲カメラ1174、長距離カメラ1198、中距離カメラ1176、及び/又は他のカメラ・タイプを含む任意の数のカメラ・タイプを含んでもよい。少なくとも一実施例では、カメラは、車両1100の全周囲の周りで画像データを捕捉するために使用されてもよい。少なくとも一実施例では、使用されるカメラのタイプは、車両1100に応じて異なる。少なくとも一実施例では、車両1100の周りで必要な被写域を提供するために、カメラ・タイプの任意の組合せが使用されてもよい。少なくとも一実施例では、展開されるカメラの数は、実施例に応じて異なってもよい。たとえば、少なくとも一実施例では、車両1100は6台のカメラ、7台のカメラ、10台のカメラ、12台のカメラ、又は別の数のカメラを含むことができる。少なくとも一実施例では、カメラは、一例として限定することなく、ギガビット・マルチメディア・シリアル・リンク(「GMSL」:Gigabit Multimedia Serial Link)及び/又はギガビット・イーサネット(登録商標)通信をサポートしてもよい。少なくとも一実施例では、各カメラは、
図11A及び
図11Bに関して本明細書でさらに詳細に上で説明されたものであり得る。
【0146】
少なくとも一実施例では、車両1100はさらに、振動センサ1142を含んでもよい。少なくとも一実施例では、振動センサ1142は、車軸など、車両1100の構成要素の振動を測定してもよい。たとえば、少なくとも一実施例では、振動の変化は、路面の変化を示すことがある。少なくとも一実施例では、2つ以上の振動センサ1142が使用される場合には、路面の摩擦又は滑り量を判定するために振動の差が使用されてもよい(たとえば、動力により駆動される車軸と自由回転する車軸との間に振動差がある場合)。
【0147】
少なくとも一実施例では、車両1100は、ADASシステム1138を含んでもよい。少なくとも一実施例では、ADASシステム1138は、限定することなく、いくつかの例においてSoCを含んでもよい。少なくとも一実施例では、ADASシステム1138は、限定することなく、任意の数及び任意の組合せの、自律/アダプティブ/自動のクルーズ・コントロール(「ACC」:autonomous/adaptive/automatic cruise control)システム、協調型アダプティブ・クルーズ・コントロール(「CACC」:cooperative adaptive cruise control)システム、正面衝突警告(「FCW」:forward crash warning)システム、自動緊急ブレーキ(「AEB」:automatic emergency braking)システム、車線逸脱警告(「LDW」:lane departure warning)システム、車線維持支援(「LKA」:lane keep assist)システム、死角警告(「BSW」:blind spot warning)システム、後方クロス・トラフィック警告(「RCTW」:ear cross-traffic warning)システム、衝突警告(「CW」:collision warning)システム、車線センタリング(「LC」:lane centering)システム、並びに/又は他のシステム、特徴、及び/若しくは機能を含んでもよい。
【0148】
少なくとも一実施例では、ACCシステムは、RADARセンサ1160、LIDARセンサ1164、及び/又は任意の数のカメラを使用してもよい。少なくとも一実施例では、ACCシステムは、縦方向ACCシステム及び/又は横方向ACCシステムを含んでもよい。少なくとも一実施例では、縦方向ACCシステムは、車両1100の直前の別の車両までの距離を監視及び制御し、車両1100のスピードを自動的に調節して、前の車両からの安全な距離を維持する。少なくとも一実施例では、横方向ACCシステムは、距離の維持を実行し、必要なときに車線変更するよう車両1100に通知する。少なくとも一実施例では、横方向ACCは、LC及びCWなどの他のADAS用途に関係する。
【0149】
少なくとも一実施例では、CACCシステムは、他の車両からの情報を使用し、この情報は、ワイヤレス・リンクにより、又は間接的にネットワーク接続を介して(たとえばインターネットを介して)、他の車両からネットワーク・インターフェース1124及び/又はワイヤレス・アンテナ1126により受信されてもよい。少なくとも一実施例では、車車間(「V2V」:vehicle-to-vehicle)通信リンクによって直接リンクが提供されてもよく、一方インフラストラクチャ車間(「I2V」:infrastructure-to-vehicle)通信リンクによって間接リンクが提供されてもよい。一般に、V2V通信は、すぐ前の先行車両(たとえば、車両1100のすぐ前で同じ車線にいる車両)についての情報を提供し、I2V通信は、さらにその前の交通についての情報を提供する。少なくとも一実施例では、CACCシステムは、I2VとV2Vの情報源のいずれか又は両方を含んでもよい。少なくとも一実施例では、車両1100の前の車両についての情報があれば、CACCシステムは信頼性をさらに高めることができ、交通の流れをより円滑にし、路上での渋滞を低減できる可能性を有する。
【0150】
少なくとも一実施例では、FCWシステムは、危険物に対してドライバに忠告するように設計され、それによりそのようなドライバは修正措置を取ることができる。少なくとも一実施例では、FCWシステムは正面カメラ及び/又はRADARセンサ1160を使用し、これらは、ディスプレイ、スピーカ、及び/又は振動構成要素などのドライバへのフィードバックを提供するように電気的に結合されている専用のプロセッサ、DSP、FPGA、及び/又はASICに結合されている。少なくとも一実施例では、FCWシステムは、音、視覚的警告、振動、及び/又はクイック・ブレーキ・パルスなどの形で警告を提供してもよい。
【0151】
少なくとも一実施例では、AEBシステムは、別の車両又は他の物体との差し迫った正面衝突を検出し、指定された時間内又は距離パラメータ内にドライバが修正措置を取らない場合には、自動でブレーキをかけてもよい。少なくとも一実施例では、AEBシステムは、専用のプロセッサ、DSP、FPGA、及び/又はASICに結合された正面カメラ及び/又はRADARセンサ1160を使用してもよい。少なくとも一実施例では、AEBシステムが危険物を検出したとき、AEBシステムは通常、修正措置を取って衝突を避けるよう最初にドライバに忠告し、そのドライバが修正措置を取らない場合には、そのAEBシステムは、予測される衝突を防ぐ又は少なくともその衝撃を軽減するために自動的にブレーキをかけてもよい。少なくとも一実施例では、AEBシステムは、ダイナミック・ブレーキ・サポート及び/又は衝突直前ブレーキなどの技法を含んでもよい。
【0152】
少なくとも一実施例では、LDWシステムは、車両1100が車線の目印に交差したときにドライバに忠告するために、ハンドル又は座席の振動など、視覚的、聴覚的、及び/又は触覚的な警告を提供する。少なくとも一実施例では、ドライバが方向指示器を作動させることなどによって意図的な車線逸脱を示す場合には、LDWシステムは作動しない。少なくとも一実施例では、LDWシステムは、正面カメラを使用してもよく、これは、ディスプレイ、スピーカ、及び/又は振動構成要素などのドライバへのフィードバックを提供するように電気的に結合することができる専用のプロセッサ、DSP、FPGA、及び/又はASICに結合されている。少なくとも一実施例では、LKAシステムは、LDWシステムの変形形態である。少なくとも一実施例では、LKAシステムは、車両1100が車両1100の車線からはみ出し始めた場合に、車両1100を修正するように操縦入力又はブレーキ制御を提供する。
【0153】
少なくとも一実施例では、BSWシステムは、自動車の死角にある車両を検出し、ドライバに警告する。少なくとも一実施例では、BSWシステムは、視覚的、聴覚的、及び/又は触覚的なアラートを提供して、合流又は車線変更が安全ではないことを示してもよい。少なくとも一実施例では、BSWシステムは、ドライバが方向指示器を使用したときに追加の警告を提供してもよい。少なくとも一実施例では、BSWシステムは、専用のプロセッサ、DSP、FPGA、及び/又はASICに結合された背面カメラ及び/又はRADARセンサ1160を使用してもよく、これらの専用のプロセッサ、DSP、FPGA、及び/又はASICは、ディスプレイ、スピーカ、及び/又は振動構成要素などのドライバへのフィードバックに電気的に結合されている。
【0154】
少なくとも一実施例では、RCTWシステムは、車両1100の後退時に、後方カメラの範囲外に物体が検出されたときに、視覚的、聴覚的、及び/又は触覚的な通知を提供してもよい。少なくとも一実施例では、RCTWシステムは、衝突を回避するために確実に車両ブレーキがかけられるように、AEBシステムを含む。少なくとも一実施例では、RCTWシステムは、1つ又は複数の背面RADARセンサ1160を使用してもよく、これはディスプレイ、スピーカ、及び/又は振動構成要素などのドライバへのフィードバックを提供するように電気的に結合された専用のプロセッサ、DSP、FPGA、及び/又はASICに結合されている。
【0155】
少なくとも一実施例では、従来のADASシステムは、誤検出結果を出しがちなことがあり、これはドライバにとっては迷惑で気が散るものであり得るが、通常は大したことにはならない。なぜなら、従来のADASシステムは、ドライバに忠告し、安全を要する状態が本当に存在し、それに適宜対応するかどうかを、そのドライバが判断できるようにするからである。少なくとも一実施例では、結果が矛盾する場合、一次コンピュータ(たとえば、コントローラ1136のうちの第1のコントローラ)からの結果に従うか、又は二次コンピュータ(たとえば、コントローラ1136のうちの第2のコントローラ)からの結果に従うかを、車両1100自体が判断する。たとえば、少なくとも一実施例では、ADASシステム1138は、バックアップ・コンピュータの合理性モジュールに知覚情報を抵抗するための、バックアップ及び/又は二次コンピュータであってもよい。少なくとも一実施例では、バックアップ・コンピュータの合理性モニタが、ハードウェア構成要素上の冗長性の多様なソフトウェアを実行して、知覚の誤り及び動的な運転タスクを検出してもよい。少なくとも一実施例では、ADASシステム1138からの出力は、監視MCUに提供されてもよい。少なくとも一実施例では、一次コンピュータからの出力と二次コンピュータからの出力とが矛盾する場合には、監視MCUが、安全な動作を確保するために矛盾をどのように調和させるかを判定する。
【0156】
少なくとも一実施例では、一次コンピュータは、一次コンピュータの選択した結果の信頼性を示す信頼性スコアを、監視MCUに提供するように構成されてもよい。少なくとも一実施例では、その信頼性スコアが閾値を超える場合には、その二次コンピュータが矛盾する又は一貫性のない結果を提供しているかどうかに関わらず、その監視MCUは一次コンピュータの指示に従ってもよい。少なくとも一実施例では、信頼性スコアが閾値を満足せず、一次コンピュータと二次コンピュータが異なる結果(たとえば、矛盾)を示す場合には、監視MCUは、コンピュータ同士を調停して、適切な結果を判定してもよい。
【0157】
少なくとも一実施例では、その二次コンピュータが誤アラームを提供する条件を、一次コンピュータからの出力と二次コンピュータからの出力とに少なくとも部分的に基づき判定するように訓練及び構成されたニューラル・ネットワークを、監視MCUが実行するように構成されてもよい。少なくとも一実施例では、監視MCUのニューラル・ネットワークは、二次コンピュータの出力が信用されてもよいときと、信用できないときとを学習してもよい。たとえば、少なくとも一実施例では、その二次コンピュータがRADARベースのFCWシステムである場合、その監視MCUのニューラル・ネットワークは、アラームをトリガする排水溝の格子又はマンホール・カバーなど、実際には危険物ではない金属物体をFCWシステムが識別するときを学習してもよい。少なくとも一実施例では、二次コンピュータがカメラ・ベースのLDWシステムである場合、自転車や歩行者が存在し、車線逸脱が実際には最も安全な操作であるときに、監視MCUのニューラル・ネットワークはLDWを無効にするように学習してもよい。少なくとも一実施例では、監視MCUは、ニューラル・ネットワークを関連するメモリとともに実行するのに好適なDLA又はGPUのうちの少なくとも1つを含んでもよい。少なくとも一実施例では、監視MCUは、SoC1104の構成要素を備えても、且つ/又はその構成要素として含まれてもよい。
【0158】
少なくとも一実施例では、ADASシステム1138は、コンピュータ・ビジョンの従来のルールを使用してADAS機能を実行する二次コンピュータを含んでもよい。少なくとも一実施例では、その二次コンピュータは、従来のコンピュータ・ビジョン・ルール(if-thenルール)を使用してもよく、ニューラル・ネットワークが監視MCUに存在することによって、信頼性、安全性、及び性能が向上してもよい。たとえば、少なくとも一実施例では、多様な実施及び意図的な非同一性により、特にソフトウェア(又はソフトウェアとハードウェアのインターフェース)の機能によって生じる誤りに対し、システム全体の誤り耐性が高まる。たとえば、少なくとも一実施例では、一次コンピュータ上で実行中のソフトウェアにバグ又はエラーがあり、二次コンピュータ上で実行中の非同一のソフトウェア・コードが、一貫した全体的な結果を提供する場合には、監視MCUは、全体的な結果が正しく、その一次コンピュータ上のソフトウェア又はハードウェアのバグが重大なエラーを引き起こしていないという、より高い信頼性を有してもよい。
【0159】
少なくとも一実施例では、ADASシステム1138の出力は、一次コンピュータの知覚ブロック、及び/又は一次コンピュータの動的運転タスクブロックに供給されてもよい。たとえば、少なくとも一実施例では、ADASシステム1138が、直前の物体に起因して正面衝突警告を示している場合には、知覚ブロックは、物体を識別するときにこの情報を使用してもよい。少なくとも一実施例では、二次コンピュータは、本明細書に記載するように、訓練済みの、したがって誤検出のリスクを低減する独自のニューラル・ネットワークを有してもよい。
【0160】
少なくとも一実施例では、車両1100はさらに、インフォテイメントSoC1130(たとえば、車両内インフォテイメント・システム(IVI):in-vehicle infotainment system)を含んでもよい。SoCとして図示及び説明されるが、インフォテイメント・システムSoC 1130は少なくとも一実施例では、SoCではなくてもよく、限定することなく2つ以上の個別の構成要素を含んでもよい。少なくとも一実施例では、インフォテイメントSoC1130は、限定することなく、ハードウェアとソフトウェアの組合せを含んでもよく、この組合せを使用して、オーディオ(たとえば、音楽、パーソナル・デジタル・アシスタント、ナビゲーション命令、ニュース、ラジオなど)、ビデオ(たとえば、TV、映画、ストリーミングなど)、電話(たとえば、ハンズフリー通話)、ネットワーク接続(たとえば、LTE、Wi-Fiなど)、及び/又は情報サービス(たとえば、ナビゲーション・システム、後方駐車支援、無線データ・システム、車両関連情報、たとえば燃料レベル、合計走行距離、ブレーキ燃料レベル、オイル・レベル、ドアの開閉、空気フィルタ情報など)を車両1100に提供してもよい。たとえば、インフォテイメントSoC1130は、ラジオ、ディスク再生装置、ナビゲーション・システム、ビデオ再生装置、USB及びBluetooth接続、カーピュータ、車内エンタテイメント、Wi-Fi、ハンドル・オーディオ制御、ハンズフリー音声制御、ヘッド・アップ・ディスプレイ(「HUD」:heads-up display)、HMIディスプレイ1134、テレマテックス・デバイス、(たとえば、様々な構成要素、特徴、及び/若しくはシステムを制御及び/若しくは相互作用するための)制御パネル、並びに/又は他の構成要素を含むことができる。少なくとも一実施例では、さらにインフォテイメントSoC1130を使用して、ADASシステム1138からの情報、車両操作計画、軌道などの自律運転情報、周囲環境情報(たとえば、交差点情報、車両情報、道路情報など)、及び/又は他の情報などの(たとえば、視覚的及び/又は聴覚的な)情報が、車両1100のユーザに提供されてもよい。
【0161】
少なくとも一実施例では、インフォテイメントSoC1130は、任意の量及びタイプのGPU機能を含んでもよい。少なくとも一実施例では、インフォテイメントSoC1130は、バス1102を介して、車両1100の他のデバイス、システム、及び/又は構成要素と通信してもよい。少なくとも一実施例では、インフォテイメントSoC1130は監視MCUに結合されてもよく、それにより、一次コントローラ1136(たとえば、車両1100の一次及び/又はバックアップのコンピュータ)が故障したときに、インフォテイメント・システムのGPUが、一部の自己運転機能を実行してもよい。少なくとも一実施例では、インフォテイメントSoC1130は、本明細書に記載するように、車両1100を運転手-安全停止モードにしてもよい。
【0162】
少なくとも一実施例では、車両1100はさらに、計器クラスタ1132(たとえば、デジタル・ダッシュボード、電子計器クラスタ、デジタル計器パネルなど)を含んでもよい。少なくとも一実施例では、計器クラスタ1132は、限定することなく、コントローラ、及び/又はスーパーコンピュータ(たとえば、個別のコントローラ又はスーパーコンピュータ)を含んでもよい。少なくとも一実施例では、計器クラスタ1132は、限定することなく、スピード・メータ、燃料レベル、油圧、タコメータ、オドメータ、方向指示器、シフトレバー位置インジケータ、シート・ベルト警告灯、バーキング・ブレーキ警告灯、エンジン故障灯、補助拘束システム(たとえば、エアバッグ)情報、ライト制御、安全システム制御、ナビゲーション情報など、任意の数及び組合せの計器セットを含んでもよい。いくつかの例では、インフォテイメントSoC1130と計器クラスタ1132との間で、情報が表示及び/又は共有されてもよい。少なくとも一実施例では、計器クラスタ1132は、インフォテイメントSoC1130の一部として含まれてもよく、又はその逆であってもよい。
【0163】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のために
図11Cのシステムにおいて使用されてもよい。
【0164】
少なくとも一実施例では、
図11Cに示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図11Cに示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図11Cに示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0165】
図11Dは、少なくとも一実施例による、クラウド・ベースのサーバと
図11Aの自律車両1100との間で通信するためのシステムの図である。少なくとも一実施例では、システムは、限定することなく、サーバ1178、ネットワーク1190、並びに車両1100を含む任意の数及びタイプの車両を含んでもよい。少なくとも一実施例では、サーバ1178は、限定することなく、複数のGPU1184(A)~1184(H)(本明細書ではまとめてGPU1184と呼ぶ)、PCIeスイッチ1182(A)~1182(D)(本明細書ではまとめてPCIeスイッチ1182と呼ぶ)、及び/又はCPU1180(A)~1180(B)(本明細書ではまとめてCPU1180と呼ぶ)を含んでもよい。少なくとも1つの実施例では、GPU1184、CPU1180、及びPCIeスイッチ1182は、たとえば限定することなく、NVIDIAにより開発されたNVLinkインターフェース1188、及び/又はPCIe接続1186などの高速相互接続によって、相互接続されてもよい。少なくとも一実施例では、GPU1184同士は、NVLink及び/又はNVSスイッチSoCを介して接続され、GPU1184とPCIeスイッチ1182は、PCIe相互接続を介して接続される。8個のGPU1184、2個のCPU1180、及び4個のPCIeスイッチ1182が図示してあるが、これは限定するものではない。少なくとも一実施例では、サーバ1178のそれぞれは、限定することなく、任意の数のGPU1184、CPU1180、及び/又はPCIeスイッチ1182を任意の組合せで含んでもよい。たとえば、少なくとも一実施例では、サーバ1178は、それぞれが8個、16個、32個、及び/又はそれ以上のGPU1184を含むことができる。
【0166】
少なくとも一実施例では、サーバ1178は、最近始まった道路工事などの予想外の又は変更された道路状態を示す画像を表す画像データを、ネットワーク1190を介して車両から受信してもよい。少なくとも一実施例では、サーバ1178は、ニューラル・ネットワーク1192、更新済み若しくは他の様態のニューラル・ネットワーク1192、及び/又は、限定することなく交通状態及び道路状態に関する情報を含む地図情報1194を、ネットワーク1190を介して車両に送信してもよい。少なくとも一実施例では、地図情報1194の更新は、建築現場、穴、迂回路、洪水、及び/又は他の障害物に関する情報など、HDマップ1122に対する更新を、限定することなく含んでもよい。少なくとも一実施例では、ニューラル・ネットワーク1192、及び/又は地図情報1194は、環境内の任意の数の車両から受信したデータに表された新しい訓練及び/又は経験から得られたものであってもよく、且つ/又は、データ・センタにおいて(たとえば、サーバ1178及び/又は他のサーバを使用して)実行された訓練に少なくとも部分的に基づき、得られたものであってもよい。
【0167】
少なくとも一実施例では、サーバ1178を使用して、訓練データに少なくとも部分的に基づき、機械学習モデル(たとえば、ニューラル・ネットワーク)が訓練されてもよい。少なくとも一実施例では、訓練データは車両によって生成されてもよく、且つ/又はシミュレーションで(たとえば、ゲーム・エンジンを使用して)生成されてもよい。少なくとも一実施例では、(たとえば、関連するニューラル・ネットワークが教師あり学習により恩恵を受ける場合には)任意の量の訓練データがタグ付けされ、且つ/又は他の前処理を受ける。少なくとも一実施例では、(たとえば、関連するニューラル・ネットワークが教師あり学習を必要としない場合には)任意の量の訓練データはタグ付け及び/又は前処理されない。少なくとも一実施例では、機械学習モデルが訓練されると、機械学習モデルは車両によって使用されてもよく(たとえば、ネットワーク1190を介して車両に送信されてもよく)、且つ/又は機械学習モデルは、車両を遠隔監視するためにサーバ1178によって使用されてもよい。
【0168】
少なくとも一実施例では、サーバ1178は車両からデータを受信し、リアル・タイムの知的推論ができるように、最新のリアル・タイムのニューラル・ネットワークにデータを適用してもよい。少なくとも一実施例では、サーバ1178は、NVIDIAによって開発されたDGX及びDGXステーション・マシンなど、GPU1184によって動く深層学習スーパーコンピュータ及び/又は専用AIコンピュータを含んでもよい。しかし、少なくとも一実施例では、サーバ1178は、CPUにより動くデータ・センタを使用する深層学習インフラストラクチャを含んでもよい。
【0169】
少なくとも一実施例では、サーバ1178の深層学習インフラストラクチャは、高速のリアル・タイムの推論が可能であってもよく、その機能を使用して、車両1100のプロセッサ、ソフトウェア、及び/又は関連ハードウェアの健全性を評価及び確認してもよい。たとえば、少なくとも一実施例では、深層学習インフラストラクチャは、一連の画像、及び/又はその一連の画像において(たとえば、コンピュータ・ビジョン及び/又は他の機械学習の物体分類技法により)車両1100が位置特定した物体など、周期的な更新を車両1100から受信してもよい。少なくとも一実施例では、深層学習インフラストラクチャは、独自のニューラル・ネットワークを実行して物体を識別し、それを車両1100によって識別された物体と比較してもよく、結果が一致せず、車両1100のAIが故障していると深層学習インフラストラクチャが結論づけた場合には、サーバ1178は、車両1100のフェイル・セーフ・コンピュータに制御を掌握し、乗員に通知し、安全な停車操作を完了するよう命じる信号を車両1100に送信してもよい。
【0170】
少なくとも一実施例では、サーバ1178は、GPU1184、及び1つ又は複数のプログラム可能な推論アクセラレータ(たとえば、NVIDIAのTensorRT3デバイス)を含んでもよい。少なくとも一実施例では、GPUにより動くサーバと、推論の加速とを組み合わせることによって、リアル・タイムの応答を可能にすることができる。性能がそれほど重要ではない場合など、少なくとも一実施例では、CPU、FPGA、及び他のプロセッサにより動くサーバが、推論に使用されてもよい。少なくとも一実施例では、1つ又は複数の実施例を実行するために、ハードウェア構造体815が使用される。ハードウェア構造体815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。
【0171】
コンピュータ・システム
図12は、例示的なコンピュータ・システムを示すブロック図であり、このコンピュータ・システムは、少なくとも一実施例による、命令を実行するための実行ユニットを含んでもよいプロセッサとともに形成された、相互接続されたデバイス及び構成要素、システム・オン・チップ(SoC)、又はこれらの何らかの組合せを有するシステムであってもよい。少なくとも一実施例では、コンピュータ・システム1200は、本明細書に記載の実施例などにおいて本開示に従ってデータを処理するためのアルゴリズムを実行する論理を含む実行ユニットを使用するための、プロセッサ1202などの構成要素を、限定することなく含んでもよい。少なくとも一実施例では、コンピュータ・システム1200は、カリフォルニア州サンタクララのインテルコーポレーションから入手可能なPENTIUM(登録商標)プロセッサ・ファミリー、Xeon(商標)、Itanium(登録商標)、XScale(商標)及び/又はStrongARM(商標)、Intel(登録商標)Core(商標)、又はIntel(登録商標)Nervana(商標)マイクロプロセッサなどのプロセッサを含んでもよいが、(他のマイクロプロセッサ、エンジニアリング・ワークステーション、セット・トップ・ボックスなどを有するPCを含め)他のシステムが使用されてもよい。少なくとも一実施例では、コンピュータ・システム1200は、ワシントン州、レドモンドのマイクロソフトコーポレーションから入手可能なWINDOWS(登録商標)のオペレーティング・システムのあるバージョンを実行してもよいが、他のオペレーティング・システム(たとえば、UNIX(登録商標)及びLinux(登録商標))、組み込みソフトウェア、及び/又はグラフィカル・ユーザ・インターフェースが使用されてもよい。
【0172】
実施例は、携帯型デバイス及び組み込みアプリケーションなど、他のデバイスで使用されてもよい。携帯型デバイスのいくつかの例は、セルラー・フォン、インターネット・プロトコル・デバイス、デジタル・カメラ、パーソナル・デジタル・アシスタント(「PDA」:personal digital assistant)、及び携帯型PCを含む。少なくとも一実施例では、組み込みアプリケーションは、マイクロコントローラ、デジタル信号プロセッサ(「DSP」:digital signal processor)、システム・オン・チップ、ネットワーク・コンピュータ(「NetPC」:network computers)、セット・トップ・ボックス、ネットワーク・ハブ、広域ネットワーク(「WAN」:wide area network)スイッチ、又は少なくとも一実施例による1つ又は複数の命令を実行することができる任意の他のシステムを含んでもよい。
【0173】
少なくとも一実施例では、コンピュータ・システム1200は、限定することなくプロセッサ1202を含んでもよく、このプロセッサ1202は限定することなく、本明細書に記載の技法による機械学習モデルの訓練及び/又は推論を実行するための1つ又は複数の実行ユニット1208を含んでもよい。少なくとも一実施例では、コンピュータ・システム1200は、シングル・プロセッサのデスクトップ又はサーバ・システムであるが、別の実施例では、コンピュータ・システム1200はマルチプロセッサ・システムであってもよい。少なくとも一実施例では、プロセッサ1202は、限定することなく、複合命令セット・コンピュータ(「CISC」:complex instruction set computer)マイクロプロセッサ、縮小命令セット・コンピューティング(「RISC」)マイクロプロセッサ、超長命令語(「VLIW」)マイクロプロセッサ、命令セットの組合せを実施するプロセッサ、又は任意の他のプロセッサ・デバイス、たとえばデジタル信号プロセッサなどを含んでもよい。少なくとも一実施例では、プロセッサ1202は、プロセッサ・バス1210に結合されてもよく、このプロセッサ・バスは、プロセッサ1202とコンピュータ・システム1200内の他の構成要素との間でデジタル信号を送信してもよい。
【0174】
少なくとも一実施例では、プロセッサ1202は、限定することなく、レベル1(「L1」)の内部キャッシュ・メモリ(「キャッシュ」)1204を含んでもよい。少なくとも一実施例では、プロセッサ1202は、単一の内部キャッシュ又は複数レベルの内部キャッシュを有してもよい。少なくとも一実施例では、キャッシュ・メモリは、プロセッサ1202の外部にあってもよい。他の実施例は、特定の実施形態及び必要性に応じて、内部キャッシュと外部キャッシュの両方の組合せも含んでよい。少なくとも一実施例では、レジスタ・ファイル1206は、整数レジスタ、浮動小数点レジスタ、状態レジスタ、及び命令ポインタ・レジスタを限定することなく含む様々レジスタに、異なるタイプのデータを記憶してもよい。
【0175】
少なくとも一実施例では、整数及び浮動小数点の演算を実行するための論理を限定することなく含む実行ユニット1208も、プロセッサ1202にある。少なくとも一実施例では、プロセッサ1202は、ある一定のマクロ命令のためのマイクロコードを記憶するマイクロコード(「uコード」)読取り専用メモリ(「ROM」:read only memory)も含んでよい。少なくとも一実施例では、実行ユニット1208は、パック命令セット1209に対処する論理を含んでもよい。少なくとも一実施例では、パック命令セット1209を、命令を実行する関連回路とともに汎用プロセッサの命令セットに含めることにより、多くのマルチメディア・アプリケーションによって使用される演算を、プロセッサ1202のパック・データを使用して実行することができる。少なくとも一実施例では、プロセッサのデータ・バスの全幅を使用してパック・データの演算を実行することによって、多くのマルチメディア・アプリケーションを加速し、より効率的に実行することができ、これにより、1度に1つのデータ要素に対して1つ又は複数の演算を実行するためにそのプロセッサのデータ・バス間でより小さい単位のデータを転送する必要をなくすことができる。
【0176】
少なくとも一実施例では、実行ユニット1208はまた、マイクロコントローラ、組み込みプロセッサ、グラフィックス・デバイス、DSP、及び他のタイプの論理回路において使用されてもよい。少なくとも一実施例では、コンピュータ・システム1200は、限定することなくメモリ1220を含んでもよい。少なくとも一実施例では、メモリ1220は、ダイナミック・ランダム・アクセス・メモリ(「DRAM」)デバイス、スタティック・ランダム・アクセス・メモリ(「SRAM」)デバイス、フラッシュ・メモリ・デバイス、又は別のメモリ・デバイスであってもよい。少なくとも一実施例では、メモリ1220は、プロセッサ1202によって実行されてもよいデータ信号によって表される命令1219、及び/又はデータ1221を記憶してもよい。
【0177】
少なくとも一実施例では、システム論理チップが、プロセッサ・バス1210及びメモリ1220に結合されてもよい。少なくとも一実施例では、システム論理チップは、限定することなく、メモリ・コントローラ・ハブ(「MCH」)1216を含んでもよく、プロセッサ1202は、プロセッサ・バス1210を介してMCH1216と通信してもよい。少なくとも一実施例では、MCH1216は、命令及びデータを記憶するため、及びグラフィックス・コマンド、データ、及びテクスチャを記憶するために、高帯域幅メモリ経路1218をメモリ1220に提供してもよい。少なくとも一実施例では、MCH1216は、プロセッサ1202と、メモリ1220と、コンピュータ・システム1200の他の構成要素との間でデータ信号を導き、プロセッサ・バス1210と、メモリ1220と、システムI/Oインターフェース1222との間でデータ信号をブリッジしてもよい。少なくとも一実施例では、システム論理チップは、グラフィックス・コントローラに結合するためのグラフィックス・ポートを提供してもよい。少なくとも一実施例では、MCH1216は、高帯域幅メモリ経路1218を介してメモリ1220に結合されてもよく、グラフィックス/ビデオカード1212は、アクセラレーテッド・グラフィックス・ポート(「AGP」)相互接続1214を介してMCH1216に結合されてもよい。
【0178】
少なくとも一実施例では、コンピュータ・システム1200は、MCH1216をI/Oコントローラ・ハブ(「ICH」)1230に結合するためのプロプライエタリ・ハブ・インターフェース・バスであるシステムI/Oインターフェース1222を使用してもよい。少なくとも一実施例では、ICH1230は、ローカルのI/Oバスを介していくつかのI/Oデバイスに直接接続を提供してもよい。少なくとも一実施例では、ローカルI/Oバスは、周辺装置をメモリ1220、チップセット、及びプロセッサ1202に接続するための高速I/Oバスを、限定することなく含んでもよい。例としては、オーディオ・コントローラ1229、ファームウェア・ハブ(「フラッシュBIOS」)1228、ワイヤレス・トランシーバ1226、データ・ストレージ1224、ユーザ入力及びキーボードのインターフェース1225を含むレガシーI/Oコントローラ1223、ユニバーサル・シリアル・バス(「USB」:Universal Serial Bus)ポートなどのシリアル拡張ポート1227、及びネットワーク・コントローラ1234が、限定することなく含まれてもよい。少なくとも一実施例では、データ・ストレージ1224は、ハード・ディスク・ドライブ、フロッピー(登録商標)・ディスク・ドライブ、CD-ROMデバイス、フラッシュ・メモリ・デバイス、又は他の大容量ストレージ・デバイスを備えてもよい。
【0179】
少なくとも一実施例では、
図12は、相互接続されたハードウェア・デバイス又は「チップ」を含むシステムを示すが、一方他の実施例では、
図12は例示的なSoCを示してもよい。少なくとも一実施例では、
図12に示すデバイスは、プロプライエタリ相互接続、標準相互接続(たとえば、PCIe)、又はこれらの何らかの組合せで相互接続されてもよい。少なくとも一実施例では、コンピュータ・システム1200の1つ又は複数の構成要素は、コンピュート・エクスプレス・リンク(CXL:compute express link)相互接続を使用して相互接続されてもよい。
【0180】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のために
図12のシステムにおいて使用されてもよい。
【0181】
少なくとも一実施例では、
図12に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図12に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図12に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0182】
図13は、少なくとも一実施例による、プロセッサ1310を利用するための電子デバイス1300を示すブロック図である。少なくとも一実施例では、電子デバイス1300は、たとえば限定することなく、ノートブック、タワー・サーバ、ラック・サーバ、ブレード・サーバ、ラップトップ、デスクトップ、タブレット、モバイル・デバイス、電話、組み込みコンピュータ、又は任意の他の好適な電子デバイスであってもよい。
【0183】
少なくとも一実施例では、電子デバイス1300は、任意の好適な数又は種類の構成要素、周辺装置、モジュール、若しくはデバイスに通信可能に結合されたプロセッサ1310を、限定することなく含んでもよい。少なくとも一実施例では、プロセッサ1310は、I
2Cバス、システム・マネージメント・バス(「SMBus」:System Management Bus)、ロー・ピン・カウント(LPC:Low Pin Count)バス、シリアル・ペリフェラル・インターフェース(「SPI」:Serial Peripheral Interface)、ハイ・デフィニション・オーディオ(「HDA」:High Definition Audio)バス、シリアル・アドバンス・テクノロジー・アタッチメント(「SATA」:Serial Advance Technology Attachment)バス、ユニバーサル・シリアル・バス(「USB」)(バージョン1、2、3など)、又はユニバーサル非同期レシーバ/トランスミッタ(「UART」:Universal Asynchronous Receiver/Transmitter)バスなどのバス若しくはインターフェースを使用して結合される。少なくとも一実施例では、
図13は、相互接続されたハードウェア・デバイス又は「チップ」を含むシステムを示すが、一方他の実施例では、
図13は例示的なSoCを示してもよい。少なくとも一実施例では、
図13に示すデバイスは、プロプライエタリ相互接続、標準相互接続(たとえば、PCIe)、又はこれらの何らかの組合せで相互接続されてもよい。少なくとも一実施例では、
図13の1つ又は複数の構成要素は、コンピュート・エクスプレス・リンク(CXL)相互接続を使用して相互接続されてもよい。
【0184】
少なくとも一実施例では、
図13は、ディスプレイ1324、タッチ画面1325、タッチ・パッド1330、近距離無線通信ユニット(「NFC」:Near Field Communications unit)1345、センサ・ハブ1340、熱センサ1346、エクスプレス・チップセット(「EC」:Express Chipset)1335、トラステッド・プラットフォーム・モジュール(「TPM」:Trusted Platform Module)1338、BIOS/ファームウェア/フラッシュ・メモリ(「BIOS、FWフラッシュ」:BIOS/firmware/flash memory)1322、DSP1360、ソリッド・ステート・ディスク(「SSD」:Solid State Disk)若しくはハード・ディスク・ドライブ(「HDD」:Hard Disk Drive)などのドライブ1320、ワイヤレス・ローカル・エリア・ネットワーク・ユニット(「WLAN」:wireless local area network unit)1350、Bluetoothユニット1352、ワイヤレス広域ネットワーク・ユニット(「WWAN」:Wireless Wide Area Network unit)1356、全地球測位システム(GPS:Global Positioning System)ユニット1355、USB3.0カメラなどのカメラ(「USB3.0カメラ」)1354、及び/又は、たとえばLPDDR3規格に実施された低電力ダブル・データ・レート(「LPDDR」:Low Power Double Data Rate)メモリ・ユニット(「LPDDR3」)1315を含んでもよい。これらの構成要素は、それぞれ任意の好適なやり方で実施されてもよい。
【0185】
少なくとも一実施例では、本明細書において説明した構成要素を介して、他の構成要素がプロセッサ1310に通信可能に結合されてもよい。少なくとも一実施例では、加速度計1341、周囲光センサ(「ALS」:Ambient Light Sensor)1342、コンパス1343、及びジャイロスコープ1344が、センサ・ハブ1340に通信可能に結合されてもよい。少なくとも一実施例では、熱センサ1339、ファン1337、キーボード1336、及びタッチ・パッド1330が、EC1335に通信可能に結合されてもよい。少なくとも一実施例では、スピーカ1363、ヘッドフォン1364、及びフォン(「mic」)1365が、オーディオ・ユニット(オーディオ・コーデック及びクラスDアンプ)1362に通信可能に結合されてもよく、このオーディオ・ユニットが、DSP1360に通信可能に結合されてもよい。少なくとも一実施例では、オーディオ・ユニット1362は、たとえば限定することなく、オーディオ・コーダ/デコーダ(「コーデック」)及びクラスDアンプリファイアを含んでもよい。少なくとも一実施例では、SIMカード(「SIM」)1357は、WWANユニット1356に通信可能に結合されてもよい。少なくとも一実施例では、WLANユニット13650及びBluetoothユニット1352などの構成要素、並びにWWANユニット1356は、次世代フォーム・ファクタ(「NGFF」:Next Generation Form Factor)に実施されてもよい。
【0186】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のために
図13のシステムにおいて使用されてもよい。
【0187】
少なくとも一実施例では、
図13に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図13に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図13に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0188】
図14は、少なくとも一実施例によるコンピュータ・システム1400を示す。少なくとも一実施例では、コンピュータ・システム1400は、本開示全体を通して説明する様々なプロセス及び方法を実施するように構成される。
【0189】
少なくとも一実施例では、コンピュータ・システム1400は、限定することなく、少なくとも1つの中央処理装置(「CPU」)1402を含み、この処理装置は、PCI:Peripheral Component Interconnect(「ペリフェラル・コンポーネント・インターコネクト」)、ペリフェラル・コンポーネント・インターコネクト・エクスプレス(「PCI-Express」:peripheral component interconnect express)、AGP:Accelerated Graphics Port(「アクセラレーテッド・グラフィックス・ポート」)、ハイパートランスポート、又は任意の他のバス若しくはポイントツーポイントの通信プロトコルなど、任意の好適なプロトコルを使用して実施された通信バス1410に接続される。少なくとも一実施例では、コンピュータ・システム1400は、メイン・メモリ1404、及び(たとえば、ハードウェア、ソフトウェア、又はこれらの組合せとして実施される)制御論理を限定することなく含み、データは、ランダム・アクセス・メモリ(「RAM」:random access memory)の形をとってもよいメイン・メモリ1404に記憶される。少なくとも一実施例では、ネットワーク・インターフェース・サブシステム(「ネットワーク・インターフェース」)1422は、他のシステムからデータを受信し、コンピュータ・システム1400によって他のシステムにデータを送信するための他のコンピューティング・デバイス及びネットワークとのインターフェースを提供する。
【0190】
少なくとも一実施例では、コンピュータ・システム1400は、少なくとも一実施例では、限定することなく、入力デバイス1408、パラレル処理システム1412、及びディスプレイ・デバイス1406を含み、このディスプレイ・デバイスは、従来の陰極線管(「CRT」:cathode ray tube)、液晶ディスプレイ(「LCD」:liquid crystal display)、発光ダイオード(「LED」:light emitting diode)ディスプレイ、プラズマ・ディスプレイ、又は他の好適なディスプレイ技術を使用して実施することができる。少なくとも一実施例では、ユーザ入力は、キーボード、マウス、タッチ・パッド、マイクロフォンなどの入力デバイス1408から受け取られる。少なくとも一実施例では、本明細書に記載の各モジュールを単一の半導体プラットフォームに置いて、処理システムを形成することができる。
【0191】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のために
図14のシステムにおいて使用されてもよい。
【0192】
少なくとも一実施例では、
図14に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図14に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図14に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0193】
図15は、少なくとも一実施例によるコンピュータ・システム1500を示す。少なくとも一実施例では、コンピュータ・システム1500は、限定することなく、コンピュータ1510及びUSBスティック1520を含んでもよい。少なくとも一実施例では、コンピュータ1510は、限定することなく、任意の数及びタイプのプロセッサ(図示せず)、並びにメモリ(図示せず)を含んでもよい。少なくとも一実施例では、コンピュータ1510は、限定することなく、サーバ、クラウド・インスタンス、ラップトップ、及びデスクトップ・コンピュータを含む。
【0194】
少なくとも一実施例では、USBスティック1520は、限定することなく、処理ユニット1530、USBインターフェース1540、及びUSBインターフェース論理1550を含む。少なくとも一実施例では、処理ユニット1530は、命令を実行することができる任意の命令実行システム、装置、又はデバイスであってもよい。少なくとも一実施例では、処理ユニット1530は、限定することなく、任意の数及びタイプの処理コア(図示せず)を含んでもよい。少なくとも一実施例では、処理ユニット1530は、機械学習に関連する任意の量及びタイプの演算を実行するように最適化された特定用途向け集積回路(「ASIC」)を備える。たとえば、少なくとも一実施例では、処理ユニット1530は、機械学習の推論演算を実行するように最適化されたテンソル処理ユニット(「TPC」:tensor processing unit)である。少なくとも一実施例では、処理ユニット1530は、機械視覚及び機械学習の推論演算を実行するように最適化された視覚処理ユニット(「VPU」)である。
【0195】
少なくとも一実施例では、USBインターフェース1540は、任意のタイプのUSBコネクタ又はUSBソケットであってもよい。たとえば、少なくとも一実施例では、USBインターフェース1540は、データ及び電源用のUSB3.0 Type-Cのソケットである。少なくとも一実施例では、USBインターフェース1540は、USB3.0 Type-Aのコネクタである。少なくとも一実施例では、USBインターフェース論理1550は、処理ユニット1530がUSBコネクタ1540を介してデバイス(たとえばコンピュータ1510)とインターフェースをとることを可能にする任意の量及びタイプの論理を含んでもよい。
【0196】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のために
図15のシステムにおいて使用されてもよい。
【0197】
少なくとも一実施例では、
図15に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図15に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図15に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0198】
図16Aは、複数のGPU1610(1)~1610(N)が、高速リンク1640(1)~1640(N)(たとえば、バス、ポイントツーポイント相互接続など)を介して複数のマルチ・コア・プロセッサ1605(1)~1605(M)に通信可能に結合されている例示的なアーキテクチャを示す。少なくとも一実施例では、高速リンク1640(1)~1640(N)は、4GB/秒、30GB/秒、80GB/秒、又はそれ以上の通信スループットをサポートする。少なくとも一実施例では、PCIe4.0又は5.0、及びNVLink2.0を含むがこれらに限定されない様々な相互接続プロトコルが使用されてもよい。様々な図面において、「N」及び「M」は正の整数を表し、その値は図面ごとに異なってもよい。
【0199】
さらに、少なくとも一実施例では、GPU1610のうちの2つ以上は高速リンク1629(1)~1629(2)を介して相互接続され、これらは、高速リンク1640(1)~1640(N)に使用されたものと類似の又は異なるプロトコル/リンクを使用して実施されてもよい。同様に、マルチ・コア・プロセッサ1605のうちの2つ以上は、高速リンク1628を介して接続されてもよく、この高速リンク1628は、20GB/秒、30GB/秒、120GB/秒、又はそれ以上で動作する対称型マルチプロセッサ(SMP)バスとすることができる。代替的に、
図16Aに示す様々なシステム構成要素間のすべての通信は、類似のプロトコル/リンクを使用して(たとえば、共通の相互接続ファブリックを介して)実現されてもよい。
【0200】
一実施例では、各マルチ・コア・プロセッサ1605は、それぞれメモリ相互接続1626(1)~1626(M)を介してプロセッサ・メモリ1601(1)~1601(M)に通信可能に結合され、各GPU1610(1)~1610(N)は、それぞれGPUメモリ相互接続1650(1)~1650(N)を介してGPUメモリ1620(1)~1620(N)に通信可能に結合される。少なくとも一実施例では、メモリ相互接続1626及び1650は、類似の又は異なるメモリ・アクセス技術を利用してもよい。例として、限定ではなく、プロセッサ・メモリ1601(1)~1601(M)及びGPUメモリ1620は、(積層DRAMを含む)ダイナミック・ランダム・アクセス・メモリ(DRAM)、グラフィックスDDR SDRAM(GDDR)(たとえば、GDDR5、GDDR6)、又は高帯域幅メモリ(HBM)などの揮発性メモリであってもよく、且つ/又は3D XPoint又はNano-Ramなどの不揮発性メモリであってもよい。少なくとも一実施例では、(たとえば、2レベルのメモリ(2LM)階層を使用して)、プロセッサ・メモリ1601のいくつかの部分は揮発性メモリであってもよく、別の部分は不揮発性メモリであってもよい。
【0201】
本明細書に記載するように、様々なマルチコア・プロセッサ1605及びGPU1610は、それぞれ特定のメモリ1601、1620に物理的に結合されてもよく、且つ/又は、仮想システムのアドレス空間(「実効アドレス」空間とも呼ぶ)が様々な物理メモリ間に分配されている統合されたメモリ・アーキテクチャが実施されてもよい。たとえば、プロセッサ・メモリ1601(1)~1601(M)はそれぞれ、64GBのシステム・メモリ・アドレス空間を備えてもよく、GPUメモリ1620(1)~1620(N)はそれぞれ、32GBのシステム・メモリ・アドレス空間を備えてもよく、この例では結果的に、M=2且つN=4であるときに、合計256GBのアドレス指定可能メモリが得られる。N及びMの他の値が可能である。
【0202】
図16Bは、1つの例示的な実施例によるマルチ・コア・プロセッサ1607とグラフィックス加速モジュール1646との相互接続のさらなる詳細事項を示す。少なくとも一実施例では、グラフィックス加速モジュール1646は、高速リンク1640(たとえば、PCIeバス、NVLinkなど)を介してプロセッサ1607に結合されるライン・カードに集積された1つ又は複数のGPUチップを含んでもよい。少なくとも一実施例では、グラフィックス加速モジュール1646は、代替的に、プロセッサ1607とともにパッケージ又はチップに集積されてもよい。
【0203】
少なくとも一実施例では、プロセッサ1607は、複数のコア1660A~1660Dを含み、それぞれのコアが、トランスレーション・ルックアサイド・バッファ(「TLB」)1661A~1661Dと、1つ又は複数のキャッシュ1662A~1662Dとを有する。少なくとも一実施例では、コア1660A~1660Dは、命令を実行しデータを処理するための、図示していない様々な他の構成要素を含んでもよい。少なくとも一実施例では、キャッシュ1662A~1662Dは、レベル1(L1)及びレベル2(L2)のキャッシュを備えてもよい。さらに、1つ又は複数の共有キャッシュ1656が、キャッシュ1662A~1662Dに含まれ、コア1660A~1660Dのセットによって共有されてもよい。たとえば、プロセッサ1607の一実施例は、24個のコアを含み、各コアが、独自のL1キャッシュ、12個の共有L2キャッシュ、及び12個の共有L3キャッシュを有する。この実施例では、1つ又は複数のL2及びL3のキャッシュが、2つの隣接するコアによって共有される。少なくとも一実施例では、プロセッサ1607及びグラフィックス加速モジュール1646は、システム・メモリ1614に接続されており、このシステム・メモリは、
図16Aのプロセッサ・メモリ1601(1)~1601(M)を含んでもよい。
【0204】
少なくとも一実施例では、様々なキャッシュ1662A~1662D、1656、及びシステム・メモリ1614に記憶されたデータ及び命令については、コヒーレンス・バス1664を介したコア間通信によって、コヒーレンスが維持される。少なくとも一実施例では、たとえば、各キャッシュは、特定のキャッシュ・ラインに対する読取り又は書込みを検出したことに応答して、コヒーレンス・バス1664を介して通信するために、それに関連するキャッシュ・コヒーレンス論理/回路を有してもよい。少なくとも一実施例では、キャッシュ・アクセスを監視するために、コヒーレンス・バス1664を介してキャッシュ・スヌーピング・プロトコルが実施される。
【0205】
少なくとも一実施例では、プロキシ回路1625が、グラフィックス加速モジュール1646をコヒーレンス・バス1664に通信可能に結合して、グラフィックス加速モジュール1646がコア1660A~1660Dのピアとしてキャッシュ・コヒーレンス・プロトコルに参加できるようにする。特に、少なくとも一実施例では、インターフェース1635は、高速リンク1640を介したプロキシ回路1625への接続を提供し、インターフェース1637は、グラフィックス加速モジュール1646を高速リンク1640に接続する。
【0206】
少なくとも一実施例では、アクセラレータ統合回路1636は、グラフィックス加速モジュール1646の複数のグラフィックス処理エンジン1631(1)~1631(N)の代わりに、キャッシュ管理、メモリ・アクセス、コンテンツ管理、及び割込み管理のサービスを提供する。少なくとも一実施例では、グラフィックス処理エンジン1631(1)~1631(N)はそれぞれ、別個のグラフィックス・プロセッシング・ユニット(GPU)を備えてもよい。少なくとも一実施例では、グラフィックス処理エンジン1631(1)~1631(N)は、代替的に、GPUの中に、グラフィックス実行ユニット、メディア処理エンジン(たとえば、ビデオ・エンコーダ/デコーダ)、サンプラ、及びブリット・エンジンなど、異なるタイプのグラフィックス処理エンジンを備えてもよい。少なくとも一実施例では、グラフィックス加速モジュール1646は、複数のグラフィックス処理エンジン1631(1)~1631(N)を有するGPUであってもよく、又はグラフィックス処理エンジン1631(1)~1631(N)は、共通のパッケージ、ライン・カード、若しくはチップに集積された個々のGPUであっても)よい。
【0207】
少なくとも一実施例では、アクセラレータ統合回路1636は、仮想から物理のメモリ・トランスレーション(実効から実(effective-to-real)のメモリ・トランスレーションとも呼ばれる)など、様々なメモリ管理機能を実行するためのメモリ管理ユニット(MMU)1639、及びシステム・メモリ1614にアクセスするためのメモリ・アクセス・プロトコルを含む。少なくとも一実施例では、MMU1639は、仮想/実効から物理/実へのアドレス・トランスレーションをキャッシュするためのトランスレーション・ルックアサイド・バッファ(TLB)(図示せず)も含むことができる。少なくとも一実施例では、キャッシュ1638は、グラフィックス処理エンジン1631(1)~1631(N)による効率的なアクセスのためにコマンド及びデータを記憶することができる。少なくとも一実施例では、キャッシュ1638及びグラフィックス・メモリ1633(1)~1633(M)に記憶されたデータは、場合によってフェッチ・ユニット1644を使用して、コア・キャッシュ1662A~1662D、1656及びシステム・メモリ1614とコヒーレントに保たれる。述べたように、これは、キャッシュ1638及びメモリ1633(1)~1633(M)の代わりにプロキシ回路1625を介して(たとえば、プロセッサ・キャッシュ1662A~1662D、1656におけるキャッシュ・ラインの修正/アクセスに関するアップデートをキャッシュ1638に送り、キャッシュ1638からのアップデートを受け取って)実現されてもよい。
【0208】
少なくとも一実施例では、レジスタ1645のセットが、グラフィックス処理エンジン1631(1)~1631(N)によって実行されるスレッドのためのコンテキスト・データを記憶し、コンテキスト管理回路1648が、スレッド・コンテキストを管理する。たとえば、コンテキスト管理回路1648は、コンテキスト・スイッチ中に様々なスレッドのコンテキストを保存及び復元するために、保存及び復元の動作を実行してもよい(たとえば、ここで、第2のスレッドをグラフィックス処理エンジンによって実行できるように、第1のスレッドが保存され、第2のスレッドが記憶される)。たとえば、コンテキスト・スイッチ時に、コンテキスト管理回路1648は、現在のレジスタ値を(たとえば、コンテキスト・ポインタによって識別された)メモリの指定領域に記憶してもよい。次いで、コンテキストに戻るときに、コンテキスト管理回路2248がレジスタ値を復元してもよい。少なくとも一実施例では、割込み管理回路1647は、システム・デバイスから受け取った割込みを受け取り、処理する。
【0209】
少なくとも一実施例では、グラフィックス処理エンジン1631からの仮想/実効アドレスは、MMU1639によってシステム・メモリ1614の実/物理アドレスにトランスレートされる。少なくとも一実施例では、アクセラレータ統合回路1636は、複数(たとえば、4個、8個、16個)のグラフィックス・アクセラレータ・モジュール1646、及び/又は他のアクセラレータ・デバイスをサポートする。少なくとも一実施例では、グラフィックス・アクセラレータ・モジュール1646は、プロセッサ1607上で実行される単一のアプリケーション専用のものであってもよく、又は複数のアプリケーション間で共有されてもよい。少なくとも一実施例では、グラフィックス処理エンジン1631(1)~1631(N)のリソースが複数のアプリケーション又は仮想機械(VM)と共有される仮想化グラフィックス実行環境が存在する。少なくとも一実施例では、リソースは、「スライス」に細分化されてもよく、このスライスが、処理要件、並びにVM及び/又はアプリケーションに関連付けられた優先度に基づき、異なるVM及び/又はアプリケーションに割り振られる。
【0210】
少なくとも一実施例では、アクセラレータ統合回路1636は、グラフィックス加速モジュール1646のためのシステムへのブリッジとして機能し、アドレス・トランスレーション及びシステム・メモリのキャッシュ・サービスを提供する。さらに、少なくとも一実施例では、アクセラレータ統合回路1636は、グラフィックス処理エンジン1631(1)~1631(N)の仮想化、割込み、及びメモリ管理をホスト・プロセッサが管理するための仮想化設備を提供してもよい。
【0211】
少なくとも一実施例では、グラフィックス処理エンジン1631(1)~1631(N)のハードウェア・リソースは、ホスト・プロセッサ1607が見る実アドレス空間に明示的にマッピングされるので、いかなるホスト・プロセッサも、実効アドレス値を使用して、これらのリソースに直接アドレス指定することができる。少なくとも一実施例では、アクセラレータ統合回路1636の1つの機能は、グラフィックス処理エンジン1631(1)~1631(N)を、システムにとって独立したユニットに見えるように物理的に分離することである。
【0212】
少なくとも一実施例では、1つ又は複数のグラフィックス・メモリ1633(1)~1633(M)はそれぞれ、グラフィックス処理エンジン1631(1)~1631(N)のそれぞれに結合され、N=Mである。少なくとも一実施例では、グラフィックス・メモリ1633(1)~1633(M)は、それぞれのグラフィックス処理エンジン1631(1)~1631(N)によって処理されている命令及びデータを記憶する。少なくとも一実施例では、グラフィックス・メモリ1633(1)~1633(M)は、(積層DRAMを含む)DRAM、GDDRメモリ、(たとえば、GDDR5、GDDR6)、又はHBMなどの揮発性メモリであってもよく、且つ/又は3D XPoint又はNano-Ramなどの不揮発性メモリであってもよい。
【0213】
少なくとも一実施例では、高速リンク1640を介したデータ・トラフィックを低減するために、グラフィックス・メモリ1633(1)~1633(M)に記憶されるデータが、グラフィックス処理エンジン1631(1)~1631(N)によって最も頻繁に使用されることになるデータであるようにし、好ましくはコア1660A~1660Dによって(少なくとも頻繁に)は使用されないデータであるようにするためのバイアス技法が使用される。同様に、少なくとも一実施例では、バイアス機構は、コアが必要とする(したがって、好ましくはグラフィックス処理エンジン1631(1)~1631(N)は必要としない)データを、キャッシュ1662A~1662D、1656、及びシステム・メモリ1614の中に保つよう試みる。
【0214】
図16Cは、アクセラレータ統合回路1636がプロセッサ1607内に一体化されている別の例示的な実施例を示す。少なくともこの実施例では、グラフィックス処理エンジン1631(1)~1631(N)は、インターフェース1637及びインターフェース1635により、高速リンク1640を介して直接アクセラレータ統合回路1636と通信する(この場合も任意の形のバス又はインターフェース・プロトコルであってもよい)。少なくとも一実施例では、アクセラレータ統合回路1636は、
図16Bに関して説明したのと類似の動作を実行してもよいが、コヒーレンス・バス1664及びキャッシュ1662A~1662D、1656に近接していることを考えると、潜在的には、より高いスループットで動作してもよい。少なくとも一実施例では、アクセラレータ統合回路は、(グラフィックス加速モジュールの仮想化のない)専用プロセスのプログラミング・モデルと、(仮想化のある)共有プログラミング・モデルとを含む異なるプログラミング・モデルをサポートし、これらは、アクセラレータ統合回路1636によって制御されるプログラミング・モデルと、グラフィックス加速モジュール1646によって制御されるプログラミング・モデルとを含んでもよい。
【0215】
少なくとも一実施例では、グラフィックス処理エンジン1631(1)~1631(N)は、単一のオペレーティング・システムの下で単一のアプリケーション又はプロセスに専用のものである。少なくとも一実施例では、単一のアプリケーションは、他のアプリケーション要求をグラフィックス処理エンジン1631(1)~1631(N)に集中させて、VM/パーティション内で仮想化を実現することができる。
【0216】
少なくとも一実施例では、グラフィックス処理エンジン1631(1)~1631(N)は、複数のVM/アプリケーション・パーティションによって共有されてもよい。少なくとも一実施例では、共有モデルはシステム・ハイパーバイザを使用して、グラフィックス処理エンジン1631(1)~1631(N)を仮想化して、各オペレーティング・システムによるアクセスを可能にしてもよい。少なくとも一実施例では、ハイパーバイザのない単一パーティションのシステムでは、グラフィックス処理エンジン1631(1)~1631(N)は、オペレーティング・システムによって所有される。少なくとも一実施例では、オペレーティング・システムは、グラフィックス処理エンジン1631(1)~1631(N)を仮想化して、各プロセス又はアプリケーションへのアクセスを提供することができる。
【0217】
少なくとも一実施例では、グラフィックス加速モジュール1646又は個々のグラフィックス処理エンジン1631(1)~1631(N)は、プロセス・ハンドルを使用して、プロセス要素を選択する。少なくとも一実施例では、プロセス要素は、システム・メモリ1614に記憶されており、本明細書に記載の実効アドレスから実アドレスへのトランスレーション技法を使用してアドレス指定可能である。少なくとも一実施例では、プロセス・ハンドルは、ホスト・プロセスのコンテキストをグラフィックス処理エンジン1631(1)~1631(N)に登録する(すなわち、プロセス要素リンク・リストにプロセス要素を追加するためのシステム・ソフトウェアをコールする)ときに、ホスト・プロセスに提供される実施固有の値であってもよい。少なくとも一実施例では、プロセス・ハンドルの下位16ビットは、プロセス要素リンク・リスト内のプロセス要素のオフセットであってもよい。
【0218】
図16Dは、例示的なアクセラレータ統合スライス1690を示す。少なくとも一実施例では、「スライス」は、アクセラレータ統合回路1636の処理リソースの指定部分を備える。少なくとも一実施例では、システム・メモリ1614内のアプリケーション実効アドレス空間1682は、プロセス要素1683を記憶する。少なくとも一実施例では、プロセス要素1683は、プロセッサ1607上で実行されているアプリケーション1680からのGPU呼出し1681に応答して、記憶される。少なくとも一実施例では、プロセス要素1683は、対応するアプリケーション1680のプロセス状態を収容する。少なくとも一実施例では、プロセス要素1683に収容されたワーク記述子(WD)1684は、アプリケーションによって要求される単一のジョブとすることができ、又はジョブのキューに対するポインタを収容してもよい。少なくとも一実施例では、WD1684は、アプリケーションの実効アドレス空間1682におけるジョブ要求キューに対するポインタである。
【0219】
少なくとも一実施例では、グラフィックス加速モジュール1646及び/又は個々のグラフィックス処理エンジン1631(1)~1631(N)は、システム内のプロセスのすべて又はサブセットによって共有されることが可能である。少なくとも一実施例では、プロセス状態を設定し、WD1684をグラフィックス加速モジュール1646に送信して、仮想化環境においてジョブを開始するためのインフラストラクチャが、含められてもよい。
【0220】
少なくとも一実施例では、専用のプロセス・プログラミング・モデルは、実施固有である。少なくとも一実施例では、このモデルでは、単一のプロセスが、グラフィックス加速モジュール1646又は個々のグラフィックス処理エンジン1631を所有する。少なくとも一実施例では、グラフィックス加速モジュール1646が単一のプロセスによって所有される場合、グラフィックス加速モジュール1646が割り当てられたときに、ハイパーバイザは、所有パーティションについてアクセラレータ統合回路1636を初期化し、オペレーティング・システムは、所有プロセスについてアクセラレータ統合回路1636を初期化する。
【0221】
少なくとも一実施例では、動作時、アクセラレータ統合スライス1690内のWDフェッチ・ユニット1691は、グラフィックス加速モジュール1646の1つ又は複数のグラフィックス処理エンジンによって行われることになるワークの表示を含む次のWD1684をフェッチする。少なくとも一実施例では、図示してあるように、WD1684からのデータは、レジスタ1645に記憶され、MMU1639、割込み管理回路1647、及び/又はコンテキスト管理回路1648によって使用されてもよい。たとえば、MMU1639の一実施例は、OS仮想アドレス空間1685内のセグメント/ページ・テーブル1686にアクセスするためのセグメント/ページ・ウォーク回路を含む。少なくとも一実施例では、割込み管理回路1647は、グラフィックス加速モジュール1646から受け取った割込みイベント1692を処理してもよい。少なくとも一実施例では、グラフィックス動作を実行するとき、グラフィックス処理エンジン1631(1)~1631(N)によって生成された実効アドレス1693は、MMU1639によって実アドレスにトランスレートされる。
【0222】
少なくとも一実施例では、レジスタ1645が、各グラフィックス処理エンジン1631(1)~1631(N)及び/又はグラフィックス加速モジュール1646について複製され、ハイパーバイザ又はオペレーティング・システムによって初期化されてもよい。少なくとも一実施例では、これらの複製されたレジスタのそれぞれは、アクセラレータ統合スライス1690に含まれてもよい。ハイパーバイザによって初期化されてもよい例示的なレジスタを、表1に示す。
【表1】
【0223】
オペレーティング・システムによって初期化されてもよい例示的なレジスタを、表2に示す。
【表2】
【0224】
一実施例では、各WD1684は、特定のグラフィックス加速モジュール1646及び/又はグラフィックス処理エンジン1631(1)~1631(N)に固有のものである。少なくとも一実施例では、WD1684は、グラフィックス処理エンジン1631(1)~1631(N)がワークを行うために必要とするすべての情報を収容し、又は完了すべきワークのコマンド・キューをアプリケーションがセットアップした場所であるメモリ・ロケーションを指すポインタとすることができる。
【0225】
図16Eは、共有モデルの例示的な一実施例のさらなる詳細事項を示す。この実施例は、プロセス要素リスト1699が記憶されているハイパーバイザ実アドレス空間1698を含む。少なくとも一実施例では、ハイパーバイザ実アドレス空間1698は、オペレーティング・システム1695のグラフィックス加速モジュール・エンジンを仮想化するハイパーバイザ1696を介してアクセス可能である。
【0226】
少なくとも一実施例では、共有プログラミング・モデルは、システム内のすべて又はサブセットのパーティションからのすべて又はサブセットのプロセスが、グラフィックス加速モジュール1646を使用できるようにする。少なくとも一実施例では、グラフィックス加速モジュール1646が複数のプロセス及びパーティションによって共有されるプログラミング・モデルが、2つ存在する、すなわち、時間スライス共有及びグラフィックス指定共有(graphics-directed shared)である。
【0227】
少なくとも一実施例において、このモデルでは、システム・ハイパーバイザ1696がグラフィックス加速モジュール1646を所有しており、その機能をすべてのオペレーティング・システム1695にとって利用可能にする。少なくとも一実施例では、システム・ハイパーバイザ1696による仮想化をグラフィックス加速モジュール1646がサポートするために、グラフィックス加速モジュール1646は、(1)アプリケーションのジョブ要求は自律でなくてはならず(すなわち、ジョブ間で状態を維持する必要はなく)、又はグラフィックス加速モジュール1646が、コンテキストの保存及び復元の機構を提供しなくてはならない、(2)アプリケーションのジョブ要求は、あらゆるトランスレーション誤りも含めて指定された時間量で完了するようグラフィックス加速モジュール1646によって保証され、又はグラフィックス加速モジュール1646が、ジョブの処理をプリエンプションする機能を提供する、及び、(3)グラフィックス加速モジュール1646は、指定の共有プログラミング・モデルで動作しているとき、プロセス間で公平性が保証されなくてはならない、などの特定の要件に準拠してもよい。
【0228】
少なくとも一実施例では、アプリケーション1680は、グラフィックス加速モジュールのタイプ、ワーク記述子(WD)、権限マスク・レジスタ(AMR)値、及びコンテキスト保存/復元エリア・ポインタ(CSRP)を伴って、オペレーティング・システム1695のシステム・コールを行う必要がある。少なくとも一実施例では、グラフィックス加速モジュールのタイプは、システム・コールで目的とする加速機能を記述している。少なくとも一実施例では、グラフィックス加速モジュールのタイプは、システム固有値であってもよい。少なくとも一実施例では、WDは、グラフィックス加速モジュール1646のために特にフォーマット化されており、グラフィックス加速モジュール1646のコマンド、ユーザ定義の構造を指す実効アドレス・ポインタ、コマンドのキューを指す実効アドレス・ポインタ、又はグラフィックス加速モジュール1646によって行われるワークを記述するための任意の他のデータ構造の形とすることができる。
【0229】
少なくとも一実施例では、AMR値は、現在のプロセスに使用するためのAMR状態である。少なくとも一実施例では、オペレーティング・システムに渡される値は、AMRをセッティングするアプリケーションと同様である。少なくとも一実施例では、アクセラレータ統合回路1636(図示せず)及びグラフィックス加速モジュール1646の実施形態が、ユーザ権限マスク・オーバーライド・レジスタ(UAMOR)をサポートしていない場合、オペレーティング・システムは、AMR値に現在のUAMOR値を適用してから、ハイパーバイザ・コールにAMRを渡してもよい。少なくとも一実施例では、ハイパーバイザ1696は、任意選択で、現在の権限マスク・オーバーライド・レジスタ(AMOR)値を適用してから、AMRをプロセス要素1683に入れてもよい。少なくとも一実施例では、CSRPは、グラフィックス加速モジュール1646がコンテキスト状態を保存及び復元するためのアプリケーションの実効アドレス空間1682内のエリアの実効アドレスを収容するレジスタ1645のうちの1つである。少なくとも一実施例では、ジョブ間で、又はジョブがプリエンプションされるときに、いかなる状態も保存する必要のない場合は、このポインタは任意選択である。少なくとも一実施例では、コンテキスト保存/復元エリアは、ピン留めされたシステム・メモリであってもよい。
【0230】
システム・コールを受け取ると、オペレーティング・システム1695は、アプリケーション1680が登録済みであり、グラフィックス加速モジュール1646を使用する権限が与えられていることを検証してもよい。少なくとも一実施例では、次いで、オペレーティング・システム1695は、表3に示す情報を伴ってハイパーバイザ1696にコールする。
【表3】
【0231】
少なくとも一実施例では、ハイパーバイザ・コールを受け取ると、ハイパーバイザ1696は、オペレーティング・システム1695が登録済みであり、グラフィックス加速モジュール1646を使用する権限が与えられていることを検証する。少なくとも一実施例では、次いでハイパーバイザ1696は、プロセス要素1683を、対応するグラフィックス加速モジュール1646のタイプのプロセス要素リンク・リストに入れる。少なくとも一実施例では、プロセス要素は、表4に示す情報を含んでもよい。
【表4】
【0232】
少なくとも一実施例では、ハイパーバイザは、複数のアクセラレータ統合スライス1690のレジスタ1645を初期化する。
【0233】
図16Fに示すように、少なくとも一実施例では、物理プロセッサ・メモリ1601(1)~1601(N)及びGPUメモリ1620(1)~1620(N)にアクセスするために使用される共通の仮想メモリ・アドレス空間を介してアドレス指定可能である統合メモリが使用される。この実施形態では、GPU1610(1)~1610(N)で実行される動作は、プロセッサ・メモリ1601(1)~1601(M)にアクセスするのと同じ仮想/実効メモリ・アドレス空間を利用し、且つその逆も同様であり、それによりプログラマビリティが簡単になる。少なくとも一実施例では、仮想/実効アドレス空間の第1の部分はプロセッサ・メモリ1601(1)に割り振られ、第2の部分は第2のプロセッサ・メモリ1601(N)に割り振られ、第3の部分はGPUメモリ1620(1)に割り振られるというように続く。少なくとも一実施例では、仮想/実効メモリ空間全体(実効アドレス空間と呼ばれることもある)は、これによりプロセッサ・メモリ1601及びGPUメモリ1620のそれぞれにわたって分配されて、仮想アドレスが物理メモリにマッピングされた状態で、いずれかのプロセッサ又はGPUが、いずれかの物理メモリにアクセスできるようになる。
【0234】
少なくとも一実施例では、MMU1639A~1639Eのうちの1つ又は複数の中のバイアス/コヒーレンス管理回路1694A~1694Eは、1つ又は複数のホスト・プロセッサ(たとえば、1605)のキャッシュとGPU1610のキャッシュとの間でキャッシュ・コヒーレンスを確保し、バイアス技法を実施して、ある特定のタイプのデータが記憶されるべき物理メモリを示す。少なくとも一実施例では、バイアス/コヒーレンス管理回路1694A~1694Eの複数のインスタンスが
図16Fに示されるが、バイアス/コヒーレンス回路は、1つ又は複数のホスト・プロセッサ1605のMMU内に実施されてもよく、且つ/又はアクセラレータ統合回路1636内に実施されてもよい。
【0235】
一実施例は、GPUメモリ1620をシステム・メモリの一部としてマッピングできるようにし、共有仮想メモリ(SVM)技術を使用してアクセス可能にすることができるが、完全なシステム・キャッシュ・コヒーレンスに関連する性能の低下が生じることはない。少なくとも一実施例では、GPUメモリ1620が、面倒なキャッシュ・コヒーレンス・オーバーヘッドなく、システム・メモリとしてアクセス可能であることにより、GPUオフロードのための有益な動作環境が提供される。少なくとも一実施例では、この構成によって、従来のI/O DMAデータ・コピーのオーバーヘッドがなくても、ホスト・プロセッサ1605のソフトウェアがオペランドを設定し、計算結果にアクセスすることが可能になる。少なくとも一実施例では、こうした従来のコピーは、ドライバ・コール、割込み、及びメモリ・マップドI/O(MMIO)アクセスを必要とし、これらはすべて、単純なメモリ・アクセスより非効率的である。少なくとも一実施例では、キャッシュ・コヒーレンス・オーバーヘッドなしでGPUメモリ1620にアクセスできることが、オフロードされた計算の実行時間に不可欠であり得る。少なくとも一実施例では、たとえば、かなりのストリーミング書込みメモリ・トラフィックがある場合には、キャッシュ・コヒーレンス・オーバーヘッドは、GPU1610が見る有効な書込み帯域幅を大幅に低減することある。少なくとも一実施例では、オペランド設定の効率、結果へのアクセスの効率、及びGPU計算の効率は、GPUオフロードの有効性を判定する際に役立つことがある。
【0236】
少なくとも一実施例では、GPUバイアス及びホスト・プロセッサ・バイアスの選択は、バイアス・トラッカー・データ構造によって決められる。少なくとも一実施例では、たとえばバイアス・テーブルが使用されてもよく、このテーブルは、GPU付きメモリ・ページ当たり1ビット又は2ビットを含むページ粒度構造であってもよい(たとえば、メモリ・ページの粒度で制御されてもよい)。少なくとも一実施例では、バイアス・テーブルは、(たとえば、バイアス・テーブルの頻繁に使用された/最近使用されたエントリをキャッシュするための)バイアス・キャッシュがGPU1610にある状態又はない状態で、1つ又は複数のGPUメモリ1620の奪われたメモリ範囲(stolen memory range)において実施されてもよい。或いは、少なくとも一実施例では、バイアス・テーブル全体が、GPU内に維持されてもよい。
【0237】
少なくとも一実施例では、GPU付きメモリ1620への各アクセスに関連付けられたバイアス・テーブルのエントリが、GPUメモリへの実際のアクセスより先にアクセスされて、以下の動作を生じさせる。少なくとも一実施例では、GPUバイアス内での自らのページを見いだすGPU1610からのローカル要求が、対応するGPUメモリ1620に直接転送される。少なくとも一実施例では、ホスト・バイアスにおいて自らのページを見いだすGPUからのローカル要求は、(たとえば、本明細書に記載の高速リンクを介して)プロセッサ1605に転送される。少なくとも一実施例では、要求されたページをホスト・プロセッサ・バイアスにおいて見いだすプロセッサ1605からの要求は、通常のメモリ読取りと同様に要求を完了させる。或いは、GPUバイアス化ページに向けられた要求は、GPU1610に転送されてもよい。少なくとも一実施例では、次いでGPUは、現在ページを使用していない場合、ホスト・プロセッサ・バイアスにページを移行してもよい。少なくとも一実施例では、ページのバイアス状態は、ソフトウェア・ベースの機構、ハードウェア支援型ソフトウェア・ベースの機構のいずれかによって、又は限られた事例のセットについては、単にハードウェア・ベースの機構によって、変更することができる。
【0238】
少なくとも一実施例では、バイアス状態を変更するための1つの機構は、APIコール(たとえば、OpenCL)を利用し、このAPIコールが、GPUのデバイス・ドライバをコールし、このデバイス・ドライバが、GPUにメッセージを送って(又はコマンド記述子をキューに加えて)、バイアス状態を変更し、一部の移行については、ホストにおいてキャッシュ・フラッシング動作を実行するよう、GPUを導く。少なくとも一実施例では、キャッシュ・フラッシング動作は、ホスト・プロセッサ1605のバイアスからGPUバイアスへの移行のために使用されるが、反対向きの移行には使用されない。
【0239】
少なくとも一実施例では、キャッシュ・コヒーレンスは、ホスト・プロセッサ1605によってキャッシュできないGPUバイアス化ページを一時的にレンダリングすることによって、維持される。少なくとも一実施例では、これらのページにアクセスするために、プロセッサ1605は、GPU1610からのアクセスを要求してもよく、GPU1610は、すぐにアクセスを許可してもよく、又は許可しなくてもよい。少なくとも一実施例では、したがって、プロセッサ1605とGPU1610との間の通信を低減するために、GPUバイアス化ページが、GPUによって要求されるが、ホスト・プロセッサ1605によっては要求されないようにすること、又はその逆にすることが有益である。
【0240】
1つ又は複数の実施例を実行するために、ハードウェア構造体815が使用される。ハードウェア構造体815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供され得る。
【0241】
図17は、本明細書に記載の様々な実施例による、1つ又は複数のIPコアを使用して作製することができる例示的な集積回路及び関連グラフィックス・プロセッサを示す。図示してあるものに加えて、少なくとも一実施例では、追加のグラフィックス・プロセッサ/コア、周辺装置インターフェース・コントローラ、若しくは汎用プロセッサ・コアを含む他の論理及び回路が含まれてもよい。
【0242】
図17は、少なくとも一実施例による1つ又は複数のIPコアを使用して作製することができる例示的なシステム・オン・チップ集積回路1700を示すブロック図である。少なくとも一実施例では、集積回路1700は、1つ又は複数のアプリケーション・プロセッサ1705(たとえば、CPU)、少なくとも1つのグラフィックス・プロセッサ1710を含み、さらに、画像プロセッサ1715及び/又はビデオ・プロセッサ1720を含んでもよく、これらのいずれもが、モジュール式IPコアであってもよい。少なくとも一実施例では、集積回路1700は、USBコントローラ1725、UARTコントローラ1730、SPI/SDIOコントローラ1735、及びI
22S/I
22Cコントローラ1740を含む周辺装置又はバス論理を含む。少なくとも一実施例では、集積回路1700は、ハイ・デフィニション・マルチメディア・インターフェース(HDMI(登録商標):high-definition multimedia interface(登録商標))コントローラ1750及びモバイル・インダストリ・プロセッサ・インターフェース(MIPI)ディスプレイ・インターフェース1755のうちの1つ又は複数に結合されるディスプレイ・デバイス1745を含むことができる。少なくとも一実施例では、フラッシュ・メモリ及びフラッシュ・メモリ・コントローラを含むフラッシュ・メモリ・サブシステム1760によって、ストレージが提供されてもよい。少なくとも一実施例では、SDRAM又はSRAMメモリ・デバイスにアクセスするために、メモリ・コントローラ1765を介してメモリ・インターフェースが提供されてもよい。少なくとも一実施例では、いくつかの集積回路はさらに、組み込みセキュリティ・エンジン1770を含む。
【0243】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のために集積回路1700において使用されてもよい。
【0244】
少なくとも一実施例では、
図17に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図17に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図17に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0245】
図18A~
図18Bは、本明細書に記載の様々実施例による、1つ又は複数のIPコアを使用して作製することができる例示的な集積回路及び関連グラフィックス・プロセッサを示す。図示してあるものに加えて、少なくとも一実施例では、追加のグラフィックス・プロセッサ/コア、周辺装置インターフェース・コントローラ、若しくは汎用プロセッサ・コアを含む他の論理及び回路が含まれてもよい。
【0246】
図18A及び
図18Bは、本明細書に記載の実施例による、SoC内で使用するための例示的なグラフィックス・プロセッサを示すブロック図である。
図18Aは、少なくとも一実施例による、1つ又は複数のIPコアを使用して作製することができるシステム・オン・チップ集積回路の例示的なグラフィックス・プロセッサ1810を示す。
図18Bは、少なくとも一実施例による、1つ又は複数のIPコアを使用して作製することができるシステム・オン・チップ集積回路のさらなる例示的なグラフィックス・プロセッサ1840を示す。少なくとも一実施例では、
図18Aのグラフィックス・プロセッサ1810は、低電力グラフィックス・プロセッサ・コアである。少なくとも一実施例では、
図18Bのグラフィックス・プロセッサ1840は、高性能グラフィックス・プロセッサ・コアである。少なくとも一実施例では、グラフィックス・プロセッサ1810、1840のそれぞれは、
図17のグラフィックス・プロセッサ1710の変形形態とすることができる。
【0247】
少なくとも一実施例では、グラフィックス・プロセッサ1810は、頂点プロセッサ1805と、1つ又は複数のフラグメント・プロセッサ1815A~1815N(たとえば、1815A、1815B、1815C、1815D~1815N-1、及び1815N)とを含む。少なくとも一実施例では、グラフィックス・プロセッサ1810は、別個の論理を介して異なるシェーダ・プログラムを実行することができ、それにより、頂点プロセッサ1805は、頂点シェーダ・プログラムのための動作を実行するように最適化され、一方、1つ又は複数のフラグメント・プロセッサ1815A~1815Nは、フラグメント又はピクセルのシェーダ・プログラムのためのフラグメント(たとえば、ピクセル)シェーディング動作を実行する。少なくとも一実施例では、頂点プロセッサ1805は、3Dグラフィックス・パイプラインの頂点処理ステージを実行し、プリミティブ及び頂点データを生成する。少なくとも一実施例では、フラグメント・プロセッサ1815A~1815Nは、頂点プロセッサ1805によって生成されたプリミティブ及び頂点データを使用して、ディスプレイ・デバイスに表示されるフレーム・バッファを生成する。少なくとも一実施例では、フラグメント・プロセッサ1815A~1815Nは、OpenGLのAPIにおいて提供されるフラグメント・シェーダ・プログラムを実行するように最適化され、OpenGLのAPIは、Direct 3D APIにおいて提供されるピクセル・シェーダ・プログラムと同様の動作を実行するために使用されてもよい。
【0248】
少なくとも一実施例では、グラフィックス・プロセッサ1810はさらに、1つ又は複数のメモリ管理ユニット(MMU)1820A~1820B、キャッシュ1825A~1825B、及び回路相互接続1830A~1830Bを含む。少なくとも一実施例では、1つ又は複数のMMU1820A~1820Bは、頂点プロセッサ1805及び/又はフラグメント・プロセッサ1815A~1815Nを含め、グラフィックス・プロセッサ1810のための仮想から物理のアドレス・マッピングを提供し、それらは、1つ又は複数のキャッシュ1825A~1825Bに記憶された頂点又は画像/テクスチャのデータに加えて、メモリに記憶された頂点又は画像/テキストのデータを参照してもよい。少なくとも一実施例では、1つ又は複数のMMU1820A~1820Bは、
図17の1つ若しくは複数のアプリケーション・プロセッサ1705、画像プロセッサ1715、及び/又はビデオ・プロセッサ1720に関連付けられた1つ若しくは複数のMMUを含む、システム内の他のMMUと同期されてもよく、それにより各プロセッサ1705~1720は、共有の又は統合された仮想メモリ・システムに参加することができる。少なくとも一実施例では、1つ又は複数の回路相互接続1830A~1830Bは、グラフィックス・プロセッサ1810が、SoCの内部バスを介して、又は直接接続を介して、SoC内の他のIPコアとインターフェースをとることができるようにする。
【0249】
少なくとも一実施例では、グラフィックス・プロセッサ1840は、
図18Bに示すような1つ又は複数のシェーダ・コア1855A~1855N(たとえば、1855A、1855B、1855C、1855D、1855E、1855F~1855N-1、及び1855N)を含み、これらは統合されたシェーダ・コア・アーキテクチャを提供し、このアーキテクチャでは、頂点シェーダ、フラグメント・シェーダ、及び/又はコンピュート・シェーダを実施するためのシェーダ・プログラム・コードを含むすべてのタイプのプログラム可能なシェーダ・コードを、単一のコア、又はタイプ、又はコアが実行できる。少なくとも一実施例では、シェーダ・コアの数は変えることができる。少なくとも一実施例では、グラフィックス・プロセッサ1840は、1つ又は複数のシェーダ・コア1855A~1855Nに実行スレッドをディスパッチするためのスレッド・ディスパッチャとして作用するコア間タスク・マネージャ1845と、たとえばシーン内のローカル空間コヒーレンスを利用するため、又は内部キャッシュの使用を最適化するために、シーンのレンダリング動作が画像空間において細分化される、タイル・ベースのレンダリングのためのタイリング動作を加速するためのタイリング・ユニット1858とを含む。
【0250】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のために集積回路18A及び/又は18Bにおいて使用されてもよい。
【0251】
少なくとも一実施例では、
図18A及び/又は
図18Bに示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図18A及び/又は
図18Bに示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図18A及び/又は
図18Bに示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0252】
図19A~
図19Bは、本明細書に記載の実施例による、さらなる例示的なグラフィックス・プロセッサ論理を示す。
図19Aは、グラフィックス・コア1900を示し、このグラフィックス・コア1900は、少なくとも一実施例では
図17のグラフィックス・プロセッサ1710に含められてもよく、少なくとも一実施例では
図18Bのように、統合されたシェーダ・コア1855A~1855Nであってもよい。
図19Bは、少なくとも一実施例におけるマルチ・チップ・モジュールに導入するのに適した高並列の汎用グラフィックス・プロセッシング・ユニット(「GPGPU」)1930を示す。
【0253】
少なくとも一実施例では、グラフィックス・コア1900は、共有命令キャッシュ1902、テクスチャ・ユニット1918、及びキャッシュ/共有メモリ1920を含み、これらは、グラフィックス・コア1900内の実行リソースに共通である。少なくとも一実施例では、グラフィックス・コア1900は、複数のスライス1901A~1901N、又はコアごとのパーティションを含むことができ、グラフィックス・プロセッサは、グラフィックス・コア1900の複数のインスタンスを含むことができる。少なくとも一実施例では、スライス1901A~1901Nは、ローカル命令キャッシュ1904A~1904N、スレッド・スケジューラ1906A~1906N、スレッド・ディスパッチャ1908A~1908N、及びレジスタのセット1910A~1910Nを含むサポート論理を含むことができる。少なくとも一実施例では、スライス1901A~1901Nは、追加機能ユニット(AFU1912A~1912N)、浮動小数点ユニット(FPU1914A~1914N)、整数算術論理演算ユニット(ALU1916A~1916N)、アドレス計算ユニット(ACU1913A~1913N)、倍精度浮動小数点ユニット(DPFPU1915A~1915N)、及び行列処理ユニット(MPU1917A~1917N)のセットを含むことができる。
【0254】
少なくとも一実施例では、FPU1914A~1914Nは、単精度(32ビット)及び半精度(16ビット)の浮動小数点演算を実行することができ、DPFPU1915A~1915Nは、倍精度(64ビット)の浮動小数点演算を実行する。少なくとも一実施例では、ALU1916A~1916Nは、8ビット、16ビット、及び32ビットの精度で可変精度の整数演算を実行することができ、混合精度の演算ができるように構成されることが可能である。少なくとも一実施例では、MPU1917A~1917Nも、半精度浮動小数点及び8ビット整数演算を含む混合精度の行列演算ができるように構成されることが可能である。少なくとも一実施例では、MPU1917A~1917Nは、汎用行列-行列乗算(GEMM)の加速をサポートできるようにすることを含め、機械学習アプリケーション・フレームワークを加速するための様々な行列演算を実行することができる。少なくとも一実施例では、AFU1912A~1912Nは、三角関数演算(たとえば、サイン、コサインなど)を含む、浮動小数点ユニット又は整数ユニットにサポートされていない追加の論理演算を実行することができる。
【0255】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のためにグラフィックス・コア1900において使用されてもよい。
【0256】
少なくとも一実施例では、
図19Aに示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図19Aに示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図19Aに示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0257】
図19Bは、汎用処理ユニット(GPGPU)1930を示し、この処理ユニットは、少なくとも一実施例において、グラフィックス・プロセッシング・ユニットのアレイによる高並列の計算動作を実行可能にするように構成されることが可能である。少なくとも一実施例では、GPGPU1930は、GPGPU1930の他のインスタンスに直接リンクされて、ディープ・ニューラル・ネットワークの訓練スピードを向上させるために複数のGPUクラスタを生成することができる。少なくとも一実施例では、GPGPU1930は、ホスト・プロセッサとの接続を可能にするためのホスト・インターフェース1932を含む。少なくとも一実施例では、ホスト・インターフェース1932は、PCIエクスプレス・インターフェースである。少なくとも一実施例では、ホスト・インターフェース1932は、ベンダー固有の通信インターフェース又は通信ファブリックとすることができる。少なくとも一実施例では、GPGPU1930は、ホスト・プロセッサからコマンドを受け取り、グローバル・スケジューラ1934を使用して、これらのコマンドに関連付けられた実行スレッドを、コンピュート・クラスタ1936A~1936Hのセットに分配する。少なくとも一実施例では、コンピュート・クラスタ1936A~1936Hは、キャッシュ・メモリ1938を共有する。少なくとも一実施例では、キャッシュ・メモリ1938は、コンピュート・クラスタ1936A~1936H内のキャッシュ・メモリ用の高レベル・キャッシュとして作用することができる。
【0258】
少なくとも一実施例では、GPGPU1930は、メモリ・コントローラ1942A~1942Bのセットを介して、コンピュート・クラスタ1936A~1936Hに結合されたメモリ1944A~1944Bを含む。少なくとも一実施例では、メモリ1944A~1944Bは、グラフィックス・ダブル・データ・レート(GDDR:graphics double data rate)メモリを含む同期グラフィックス・ランダム・アクセス・メモリ(SGRAM)など、ダイナミック・ランダム・アクセス・メモリ(DRAM)又はグラフィックス・ランダム・アクセス・メモリを含む、様々なタイプのメモリ・デバイスを含むことができる。
【0259】
少なくとも一実施例では、コンピュート・クラスタ1936A~1936Hはそれぞれ、
図19Aのグラフィックス・コア1900などのグラフィックス・コアのセットを含み、このグラフィックス・コアのセットは、機械学習計算に適したものを含め、様々な精度で計算動作を実行することができる複数のタイプの整数及び浮動小数点の論理ユニットを含むことができる。たとえば、少なくとも一実施例では、コンピュート・クラスタ1936A~1936Hのそれぞれにおける浮動小数点ユニットの少なくともサブセットは、16ビット又は32ビットの浮動小数点演算を実行するように構成されることが可能であり、一方、浮動小数点ユニットの別のサブセットは、64ビットの浮動小数点演算を実行するように構成されることが可能である。
【0260】
少なくとも一実施例では、GPGPU1930の複数のインスタンスは、コンピュート・クラスタとして動作するように構成されることが可能である。少なくとも一実施例では、コンピュート・クラスタ1936A~1936Hにより同期及びデータ交換のために使用される通信は、実施例にわたって異なる。少なくとも一実施例では、GPGPU1930の複数のインスタンスは、ホスト・インターフェース1932を介して通信する。少なくとも一実施例では、GPGPU1930は、I/Oハブ1939を含み、このハブは、GPGPU1930の他のインスタンスへの直接接続を可能にするGPUリンク1940に、GPGPU1930を結合する。少なくとも一実施例では、GPUリンク1940は、GPGPU1930の複数のインスタンス間での通信及び同期を可能にするGPUからGPUへの専用のブリッジに結合される。少なくとも一実施例では、GPUリンク1940は、他のGPGPU又は並列プロセッサにデータを送受信するための高速相互接続に結合される。少なくとも一実施例では、GPGPU1930の複数のインスタンスは、別々のデータ処理システムに位置付けられ、ホスト・インターフェース1932を介してアクセス可能なネットワーク・デバイスを介して通信する。少なくとも一実施例では、GPUリンク1940は、ホスト・インターフェース1932に加えて、又はその代わりに、ホスト・プロセッサへの接続を可能にするように構成することができる。
【0261】
少なくとも一実施例では、GPGPU1930は、ニューラル・ネットワークを訓練するように構成されることが可能である。少なくとも一実施例では、GPGPU1930は、推論プラットフォーム内で使用することができる。GPGPU1930が推論のために使用される少なくとも一実施例では、GPGPU1930は、GPGPU1930がニューラル・ネットワークの訓練に使用されるときよりも少数のコンピュート・クラスタ1936A~1936Hを含んでもよい。少なくとも一実施例では、メモリ1944A~1944Bに関連するメモリ技術は、推論の構成と訓練の構成とで異なってもよく、高帯域幅のメモリ技術が、訓練構成に当てられる。少なくとも一実施例では、GPGPU1930の推論構成は、推論固有の命令をサポートすることができる。たとえば、少なくとも一実施例では、推論構成は、1つ又は複数の8ビットの整数のドット積命令をサポートすることができ、これは、導入済みニューラル・ネットワークの推論動作中に使用されてもよい。
【0262】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のためにGPGPU1930において使用されてもよい。
【0263】
少なくとも一実施例では、
図19Bに示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図19Bに示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図19Bに示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0264】
図20は、少なくとも一実施例によるコンピューティング・システム2000を示すブロック図である。少なくとも一実施例では、コンピューティング・システム2000は、メモリ・ハブ2005を含んでもよい相互接続経路を介して通信する1つ又は複数のプロセッサ2002とシステム・メモリ2004とを有する処理サブシステム2001を含む。少なくとも一実施例では、メモリ・ハブ2005は、チップセット構成要素内の別個の構成要素であってもよく、又は1つ若しくは複数のプロセッサ2002内に一体化されていてもよい。少なくとも一実施例では、メモリ・ハブ2005は、通信リンク2006を介してI/Oサブシステム2011に結合される。少なくとも一実施例では、I/Oサブシステム2011は、コンピューティング・システム2000が1つ又は複数の入力デバイス2008からの入力を受け取れるようにすることができるI/Oハブ2007を含む。少なくとも一実施例では、I/Oハブ2007は、ディスプレイ・コントローラを有効にすることができ、このディスプレイ・コントローラは、1つ又は複数のプロセッサ2002に含まれて、1つ又は複数のディスプレイ・デバイス2010Aに出力を提供してもよい。少なくとも一実施例では、I/Oハブ2007に結合された1つ又は複数のディスプレイ・デバイス2010Aは、ローカルの、内部の、又は組み込まれたディスプレイ・デバイスを含むことができる。
【0265】
少なくとも一実施例では、処理サブシステム2001は、バス又は他の通信リンク2013を介してメモリ・ハブ2005に結合された1つ又は複数の並列プロセッサ2012を含む。少なくとも一実施例では、通信リンク2013は、PCIエクスプレスなどであるがこれに限定されない任意の数の規格に基づく通信リンク技術若しくはプロトコルのうちの1つを使用してもよく、又はベンダー固有の通信インターフェース若しくは通信ファブリックであってもよい。少なくとも一実施例では、1つ又は複数の並列プロセッサ2012は、メニー・インテグレーテッド・コア(MIC:many integrated core)プロセッサなど、多数の処理コア及び/又は処理クラスタを含むことのできる、計算に集中した並列又はベクトルの処理システムを形成する。少なくとも一実施例では、並列プロセッサ2012の一部又は全部が、グラフィックス処理サブシステムを形成し、このサブシステムは、I/Oハブ2007を介して結合された1つ又は複数のディスプレイ・デバイス2010Aのうちの1つに、ピクセルを出力することができる。少なくとも一実施例では、並列プロセッサ2012はまた、1つ又は複数のディスプレイ・デバイス2010Bへの直接接続を可能にするディスプレイ・コントローラ及びディスプレイ・インターフェース(図示せず)を含むことができる。
【0266】
少なくとも一実施例では、システム・ストレージ・ユニット2014は、I/Oハブ2007に接続されて、コンピューティング・システム2000のためのストレージ機構を提供することができる。少なくとも一実施例では、I/Oスイッチ2016を使用して、I/Oハブ2007と、プラットフォームに一体化されてもよいネットワーク・アダプタ2018及び/又はワイヤレス・ネットワーク・アダプタ2019などの他の構成要素、並びに1つ又は複数のアドイン・デバイス2020を介して加えることができる様々な他のデバイスとの通信を可能にするためのインターフェース機構を提供することができる。少なくとも一実施例では、ネットワーク・アダプタ2018は、イーサネット(登録商標)・アダプタ、又は別の有線ネットワーク・アダプタとすることができる。少なくとも一実施例では、ワイヤレス・ネットワーク・アダプタ2019は、Wi-Fi、Bluetooth、近距離無線通信(NFC)、又は1つ若しくは複数のワイヤレス無線を含む他のネットワーク・デバイスのうちの1つ又は複数を含むことができる。
【0267】
少なくとも一実施例では、コンピューティング・システム2000は、USB又は他のポート接続、光学ストレージ・ドライブ、ビデオ捕捉デバイスなどを含む明示されていない他の構成要素を含むことができ、これらもI/Oハブ2007に接続されてもよい。少なくとも一実施例では、
図20の様々な構成要素を相互接続する通信経路が、PCI(ペリフェラル・コンポーネント・インターコネクト)ベースのプロトコル(たとえば、PCI-エクスプレス)などの任意の好適なプロトコル、又はNV-Link高速相互接続などの他のバス若しくはポイントツーポイント通信インターフェース、又は他の相互接続プロトコルを使用して、実施されてもよい。
【0268】
少なくとも一実施例では、並列プロセッサ2012は、たとえばビデオ出力回路を含むグラフィックス及びビデオの処理に最適化された回路を組み込んでおり、グラフィックス・プロセッシング・ユニット(GPU)を構成する。少なくとも一実施例では、並列プロセッサ2012は、汎用処理に最適化された回路を組み込んでいる。少なくとも実施例では、コンピューティング・システム2000の構成要素は、単一の集積回路上の1つ又は複数の他のシステム要素と一体化されてもよい。たとえば、少なくとも一実施例では、並列プロセッサ2012、メモリ・ハブ2005、プロセッサ2002、及びI/Oハブ2007を、システム・オン・チップ(SoC)集積回路に一体化することができる。少なくとも一実施例では、コンピューティング・システム2000の構成要素は、単一のパッケージに一体化されて、システム・イン・パッケージ(SIP:system in package)構成を形成することができる。少なくとも一実施例では、コンピューティング・システム2000の構成要素の少なくとも一部分を、マルチ・チップ・モジュール(MCM:multi-chip module)に一体化することができ、このモジュールを、他のマルチ・チップ・モジュールと相互接続して、モジュール式コンピューティング・システムにすることができる。
【0269】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のために
図2000のシステムにおいて使用されてもよい。
【0270】
少なくとも一実施例では、
図20に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図20に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図20に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0271】
プロセッサ
図21Aは、少なくとも一実施例による並列プロセッサ2100を示す。少なくとも一実施例では、並列プロセッサ2100の様々な構成要素は、プログラム可能なプロセッサ、特定用途向け集積回路(ASIC)、又はフィールド・プログラマブル・ゲート・アレイ(FPGA)などの1つ又は複数の集積回路デバイスを使用して実施されてもよい。少なくとも一実施例では、図示してある並列プロセッサ2100は、例示的な実施例による
図20に示す1つ又は複数の並列プロセッサ2012の変形形態である。
【0272】
少なくとも一実施例では、並列プロセッサ2100は並列処理ユニット2102を含む。少なくとも一実施例では、並列処理ユニット2102は、並列処理ユニット2102の他のインスタンスを含む他のデバイスとの通信を可能にするI/Oユニット2104を含む。少なくとも一実施例では、I/Oユニット2104は、他のデバイスに直接接続されてもよい。少なくとも一実施例では、I/Oユニット2104は、メモリ・ハブ2105などのハブ又はスイッチ・インターフェースの使用を介して、他のデバイスと接続される。少なくとも一実施例では、メモリ・ハブ2105とI/Oユニット2104との間の接続は、通信リンク2113を形成する。少なくとも一実施例では、I/Oユニット2104は、ホスト・インターフェース2106及びメモリ・クロスバー2116に接続され、ここでホスト・インターフェース2106は、処理動作の実行を対象とするコマンドを受け取り、メモリ・クロスバー2116は、メモリ動作の実行を対象とするコマンドを受け取る。
【0273】
少なくとも一実施例では、ホスト・インターフェース2106が、I/Oユニット2104を介してコマンド・バッファを受け取るとき、ホスト・インターフェース2106は、これらのコマンドを実行するためのワーク動作をフロント・エンド2108に向けることができる。少なくとも一実施例では、フロント・エンド2108はスケジューラ2110に結合され、このスケジューラは、コマンド又は他のワーク・アイテムを処理クラスタ・アレイ2112に分配するように構成される。少なくとも一実施例では、スケジューラ2110は、処理クラスタ・アレイ2112のクラスタにタスクが分配される前に、処理クラスタ・アレイ2112が適切に構成され、有効な状態にあることを確実にする。少なくとも一実施例では、スケジューラ2110は、マイクロコントローラで実行しているファームウェア論理を介して実施される。少なくとも一実施例では、マイクロコントローラ実施スケジューラ2110は、複雑なスケジューリング及びワーク分配動作を、粗い粒度と細かい粒度で実行するように構成可能であり、処理アレイ2112で実行しているスレッドの迅速なプリエンプション及びコンテキストのスイッチングを可能にする。少なくとも一実施例では、ホスト・ソフトウェアは、処理クラスタ・アレイ2112でのスケジューリングのワークロードを、複数のグラフィックス処理経路のうちの1つを介して証明することができる。少なくとも一実施例では、次いで、スケジューラ2110を含むマイクロコントローラ内のスケジューラ2110論理によって、ワークロードを自動的に処理クラスタ・アレイ・クラスタ2112全体に分配することができる。
【0274】
少なくとも一実施例では、処理クラスタ・アレイ2112は、最大「N個」の処理クラスタ(たとえば、クラスタ2114A、クラスタ2114B~クラスタ2114N)を含むことができ、ここで「N」は正の整数(他の図で使用されるものとは異なる整数「N」であってもよい)を表す。少なくとも一実施例では、処理クラスタ・アレイ2112の各クラスタ2114A~2114Nは、大量の同時スレッドを実行することができる。少なくとも一実施例では、スケジューラ2110は、様々なスケジューリング及び/又はワーク分配のアルゴリズムを使用して、処理クラスタ・アレイ2112のクラスタ2114A~2114Nにワークを配分することができ、これらのアルゴリズムは、プログラム又は計算のタイプごとに生じるワークロードに応じて、異なってもよい。少なくとも一実施例では、スケジューリングは、スケジューラ2110によって動的に対処されてもよく、又は処理クラスタ・アレイ2112によって実行されるように構成されたプログラム論理のコンパイル中に、コンパイラ論理によって部分的に支援されてもよい。少なくとも一実施例では、処理クラスタ・アレイ2112の異なるクラスタ2114A~2114Nは、異なるタイプのプログラムを処理するように、又は異なるタイプの計算を実行するように配分されることが可能である。
【0275】
少なくとも一実施例では、処理クラスタ・アレイ2112は、様々なタイプの並列処理動作を実行するように構成されることが可能である。少なくとも一実施例では、処理クラスタ・アレイ2112は、汎用の並列コンピュート動作を実行するように構成される。たとえば、少なくとも一実施例では、処理クラスタ・アレイ2112は、ビデオ及び/又はオーディオ・データのフィルタリング、物理動作を含むモデリング動作の実行、及びデータ変換の実行を含む処理タスクを実行するための論理を含むことができる。
【0276】
少なくとも一実施例では、処理クラスタ・アレイ2112は、並列グラフィックス処理動作を実行するように構成される。少なくとも一実施例では、処理クラスタ・アレイ2112は、テクスチャ動作を実行するためのテクスチャ・サンプリング論理、並びにモザイク論理、及び他の頂点処理論理を含むがこれらに限定されないこうしたグラフィックス処理動作の実行をサポートするための追加の論理を含むことができる。少なくとも一実施例では、処理クラスタ・アレイ2112は、頂点シェーダ、モザイク・シェーダ、ジオメトリ・シェーダ、及びピクセル・シェーダなどであるが、これらに限定されないグラフィックス処理関連のシェーダ・プログラムを実行するように構成されることが可能である。少なくとも一実施例では、並列処理ユニット2102は、処理できるようにデータをシステム・メモリからI/Oユニット2104を介して転送することができる。少なくとも一実施例では、処理中、転送されたデータを、処理中にオン・チップ・メモリ(たとえば、並列プロセッサ・メモリ2122)に記憶し、次いでシステム・メモリに書き戻すことができる。
【0277】
少なくとも一実施例では、並列処理ユニット2102を使用してグラフィックス処理が実行される場合には、処理クラスタ・アレイ2112の複数のクラスタ2114A~2114Nにグラフィックス処理動作をよりうまく分配できるようにするため、処理ワークロードをおおよそ等しい大きさのタスクに分割するようにスケジューラ2110を構成することができる。少なくとも一実施例では、処理クラスタ・アレイ2112の一部分は、異なるタイプの処理を実行するように構成されることが可能である。たとえば、少なくとも一実施例では、レンダリング画像を生成して表示するために、第1の部分は、頂点シェーディング及びトポロジ生成を実行するように構成されてもよく、第2の部分は、モザイク及びジオメトリのシェーディングを実行するように構成されてもよく、第3の部分は、ピクセル・シェーディング又は他の画面空間動作を実行するように構成されてもよい。少なくとも一実施例では、クラスタ2114A~2114Nのうちの1つ又は複数によって生成される中間データをバッファに記憶して、さらなる処理ができるようにクラスタ2114A~2114Nの間で中間データを送信できるようにしてもよい。
【0278】
少なくとも一実施例では、処理クラスタ・アレイ2112は、実行される処理タスクをスケジューラ2110を介して受け取ることができ、スケジューラ2110は、処理タスクを定義するコマンドをフロント・エンド2108から受け取る。少なくとも一実施例では、処理タスクは、処理されるデータのインデックス、たとえば、表面(パッチ)データ、プリミティブ・データ、頂点データ、及び/又はピクセル・データ、並びに状態パラメータ、及びデータをどのように処理すべきかを定義するコマンド(たとえば、どのプログラムを実行すべきか)を含むことができる。少なくとも一実施例では、スケジューラ2110は、タスクに対応するインデックスをフェッチするように構成されてもよく、又はフロント・エンド2108からインデックスを受け取ってもよい。少なくとも一実施例では、フロント・エンド2108は、入ってくるコマンド・バッファ(たとえば、バッチ・バッファ、プッシュ・バッファなど)によって指定されるワークロードが開始される前に、処理クラスタ・アレイ2112が有効な状態に構成されていることを保証するように構成されることが可能である。
【0279】
少なくとも一実施例では、並列処理ユニット2102の1つ又は複数のインスタンスの各々は、並列プロセッサ・メモリ2122と結合することができる。少なくとも一実施例では、並列プロセッサ・メモリ2122には、メモリ・クロスバー2116を介してアクセスすることができ、メモリ・クロスバー2116は、処理クラスタ・アレイ2112並びにI/Oユニット2104からメモリ要求を受け取ることができる。少なくとも一実施例では、メモリ・クロスバー2116は、メモリ・インターフェース2118を介して並列プロセッサ・メモリ2122にアクセスすることができる。少なくとも一実施例では、メモリ・インターフェース2118は、複数のパーティション・ユニット(たとえば、パーティション・ユニット2120A、パーティション・ユニット2120B~パーティション・ユニット2120N)を含むことができ、これらのユニットはそれぞれ、並列プロセッサ・メモリ2122の一部分(たとえば、メモリ・ユニット)に結合することができる。少なくとも一実施例では、パーティション・ユニット2120A~2120Nの数は、メモリ・ユニットの数と等しくなるように構成され、それにより、第1のパーティション・ユニット2120Aは、対応する第1のメモリ・ユニット2124Aを有し、第2のパーティション・ユニット2120Bは、対応するメモリ・ユニット2124Bを有し、N番目のパーティション・ユニット2120Nは、対応するN番目のメモリ・ユニット2124Nを有する。少なくとも一実施例では、パーティション・ユニット2120A~2120Nの数は、メモリ・ユニットの数に等しくなくてもよい。
【0280】
少なくとも一実施例では、メモリ・ユニット2124A~2124Nは、グラフィックス・ダブル・データ・レート(GDDR)メモリを含む同期グラフィックス・ランダム・アクセス・メモリ(SGRAM)など、ダイナミック・ランダム・アクセス・メモリ(DRAM)又はグラフィックス・ランダム・アクセス・メモリを含む、様々なタイプのメモリ・デバイスを含むことができる。少なくとも一実施例では、またメモリ・ユニット2124A~2124Nはまた、高帯域幅メモリ(HBM)を含むがこれに限定されない3D積層メモリを含んでもよい。少なくとも一実施例では、並列プロセッサ・メモリ2122の利用可能な帯域幅を効率的に使用するために、フレーム・バッファ又はテクスチャ・マップなどのレンダー・ターゲットが、メモリ・ユニット2124A~2124Nにわたって記憶されて、パーティション・ユニット2120A~2120Nが、各レンダー・ターゲットの部分を並列に書き込みできるようにしてもよい。少なくとも一実施例では、システム・メモリとローカル・キャッシュ・メモリを併用する統合メモリ設計に有利なように、並列プロセッサ・メモリ2122のローカル・インスタンスは除外されてもよい。
【0281】
少なくとも一実施例では、処理クラスタ・アレイ2112のクラスタ2114A~2114Nのうちのいずれか1つは、並列プロセッサ・メモリ2122内のメモリ・ユニット2124A~2124Nのいずれかに書き込まれることになるデータを処理することができる。少なくとも一実施例では、メモリ・クロスバー2116は、各クラスタ2114A~2114Nの出力を、出力に対してさらなる処理動作を実行することができる任意のパーティション・ユニット2120A~2120N、又は別のクラスタ2114A~2114Nに転送するように構成されることが可能である。少なくとも一実施例では、各クラスタ2114A~2114Nは、メモリ・クロスバー2116を通ってメモリ・インターフェース2118と通信して、様々な外部メモリ・デバイスからの読取り、又はそれへの書込みを行うことができる。少なくとも一実施例では、メモリ・クロスバー2116は、I/Oユニット2104と通信するためのメモリ・インターフェース2118への接続部、並びに並列プロセッサ・メモリ2122のローカル・インスタンスへの接続部を有して、異なる処理クラスタ2114A~2114N内の処理ユニットが、システム・メモリ、又は並列処理ユニット2102のローカルにない他のメモリと通信できるようにする。少なくとも一実施例では、メモリ・クロスバー2116は、仮想チャネルを使用して、クラスタ2114A~2114Nと、パーティション・ユニット2120A~2120Nとの間でトラフィック・ストリームを分離することができる。
【0282】
少なくとも一実施例では、並列処理ユニット2102の複数のインスタンスは、単一のアドイン・カードに提供されてもよく、又は複数のアドイン・カードが相互接続されてもよい。少なくとも一実施例では、異なるインスタンスが異なる数の処理コア、異なる量のローカル並列プロセッサ・メモリ、及び/又は他の異なる構成を有する場合でも、並列処理ユニット2102の異なるインスタンスは相互動作するように構成されることが可能である。たとえば、少なくとも一実施例では、並列処理ユニット2102のいくつかインスタンスは、他のインスタンスに比べて高い精度の浮動小数点ユニットを含むことができる。少なくとも一実施例では、並列処理ユニット2102又は並列プロセッサ2100のうちの1つ又は複数のインスタンスを組み込んだシステムは、デスクトップ、ラップトップ、若しくは携帯型のパーソナル・コンピュータ、サーバ、ワークステーション、ゲーム・コンソール、及び/又は組み込みシステムを含むが、これらに限定されない様々な構成及びフォーム・ファクタで実施することができる。
【0283】
図21Bは、少なくとも一実施例によるパーティション・ユニット2120のブロック図である。少なくとも一実施例では、パーティション・ユニット2120は、
図21Aのパーティション・ユニット2120A~2120Nのうちの1つのパーティション・ユニットのインスタンスである。少なくとも一実施例では、パーティション・ユニット2120は、L2キャッシュ2121、フレーム・バッファ・インターフェース2125、及びROP:raster operations unit2126(ラスタ演算ユニット)を含む。少なくとも一実施例では、L2キャッシュ2121は、メモリ・クロスバー2116及びROP2126から受け取ったロード及びストアの動作を実行するように構成された読取り/書込みキャッシュである。少なくとも一実施例では、読取りミス及び至急の書戻し要求が、処理されるようにL2キャッシュ2121によってフレーム・バッファ・インターフェース2125に出力される。少なくとも一実施例では、更新も、処理されるようにフレーム・バッファ・インターフェース2125を介してフレームに送られる。少なくとも一実施例では、フレーム・バッファ・インターフェース2125は、
図21の(たとえば並列プロセッサ・メモリ2122内の)メモリ・ユニット2124A~2124Nなど、並列プロセッサ・メモリのメモリ・ユニットのうちの1つとインターフェースをとる。
【0284】
少なくとも一実施例では、ROP2126は、ステンシル、zテスト、ブレンディングなどのようなラスタ演算を実行する処理ユニットである。少なくとも一実施例では、次いでROP2126は、グラフィックス・メモリに記憶された処理済みグラフィックス・データを出力する。少なくとも一実施例では、ROP2126は、メモリに書き込まれる深度又は色データを圧縮し、メモリから読み取られた深度又は色データを解凍するための圧縮論理を含む。少なくとも一実施例では、圧縮論理は、複数の圧縮アルゴリズムのうちの1つ又は複数を利用するロスレス圧縮論理とすることができる。少なくとも一実施例では、ROP2126によって実行される圧縮のタイプは、圧縮されるデータの統計的特徴に基づき変更することができる。たとえば、少なくとも一実施例では、深度及び色データに対してはタイルごとにデルタ色圧縮が実行される。
【0285】
少なくとも一実施例では、ROP2126は、パーティション・ユニット2120内ではなく、各処理クラスタ内(たとえば、
図21Aのクラスタ2114A~2114N)に含まれる。少なくとも一実施例では、ピクセル・フラグメント・データではなく、ピクセル・データの読取り及び書込み要求が、メモリ・クロスバー2116を介して送信される。少なくとも一実施例では、処理済みグラフィックス・データは、
図20の1つ又は複数のディスプレイ・デバイス2010のうちの1つなどのディスプレイ・デバイスに表示されてもよく、プロセッサ2002によってさらに処理できるようにルーティングされてもよく、又は
図21Aの並列プロセッサ2100内の処理エンティティのうちの1つによってさらに処理できるようにルーティングされてもよい。
【0286】
図21Cは、少なくとも一実施例による並列処理ユニット内の処理クラスタ2114のブロック図である。少なくとも一実施例では、処理クラスタは、
図21Aの処理クラスタ2114A~2114Nのうちの1つの処理クラスタのインスタンスである。少なくとも一実施例では、処理クラスタ2114は、多数のスレッドを並列で実行するように構成されてもよく、ここで「スレッド」とは、入力データの特定のセットに対して実行している特定のプログラムのインスタンスを指す。少なくとも一実施例では、複数の独立した命令ユニットを提供することなく、多数のスレッドの並列実行をサポートするために、単一命令複数データ(SIMD)の命令発行技法が使用される。少なくとも一実施例では、それぞれの処理クラスタ内の処理エンジンのセットに命令を発行するように構成された共通の命令ユニットを使用して、全体的に同期された多数のスレッドの並列実行をサポートするために、単一命令複数スレッド(SIMT:single-instruction, multiple-thread)の技法が使用される。
【0287】
少なくとも一実施例では、処理クラスタ2114の動作は、SIMT並列プロセッサに処理タスクを分配するパイプライン・マネージャ2132を介して制御することができる。少なくとも一実施例では、パイプライン・マネージャ2132は、
図21Aのスケジューラ2110から命令を受け取り、グラフィックス・マルチプロセッサ2134及び/又はテクスチャ・ユニット2136を介してこれらの命令の実行を管理する。少なくとも一実施例では、グラフィックス・マルチプロセッサ2134は、SIMT並列プロセッサの例示的なインスタンスである。しかし、少なくとも一実施例では、アーキテクチャの異なる様々なタイプのSIMT並列プロセッサが、処理クラスタ2114内に含まれてもよい。少なくとも一実施例では、グラフィックス・マルチプロセッサ2134の1つ又は複数のインスタンスは、処理クラスタ2114内に含めることができる。少なくとも一実施例では、グラフィックス・マルチプロセッサ2134はデータを処理することができ、処理済みデータを、他のシェーダ・ユニットを含む複数の可能な宛先のうちの1つに分配するためにデータ・クロスバー2140が使用されてもよい。少なくとも一実施例では、パイプライン・マネージャ2132は、データ・クロスバー2140を介して分配されることになる処理済みデータの宛先を指定することによって、処理済みデータの分配を容易にすることができる。
【0288】
少なくとも一実施例では、処理クラスタ2114内の各グラフィックス・マルチプロセッサ2134は、関数実行論理(たとえば、算術論理演算ユニット、ロード・ストア・ユニットなど)の同一のセットを含むことができる。少なくとも一実施例では、関数実行論理は、前の命令が完了する前に新規の命令を発行することができるパイプライン式に構成されることが可能である。少なくとも一実施例では、関数実行論理は、整数及び浮動小数点の算術、比較演算、ブール演算、ビット・シフト、及び様々な代数関数の計算を含む様々な演算をサポートする。少なくとも一実施例では、同じ関数ユニットのハードウェアを活用して、異なる演算を実行することができ、関数ユニットの任意の組合せが存在してもよい。
【0289】
少なくとも一実施例では、処理クラスタ2114に送信される命令がスレッドを構成する。少なくとも一実施例では、並列処理エンジンのセットにわたって実行されているスレッドのセットが、スレッド・グループである。少なくとも一実施例では、スレッド・グループは、異なる入力データに対して共通のプログラムを実行する。少なくとも一実施例では、スレッド・グループ内の各スレッドを、グラフィックス・マルチプロセッサ2134内の異なる処理エンジンに割り当てることができる。少なくとも一実施例では、スレッド・グループは、グラフィックス・マルチプロセッサ2134内の処理エンジンの数よりも少ないスレッドを含んでもよい。少なくとも一実施例では、スレッド・グループが処理エンジンの数よりも少ないスレッドを含む場合、処理エンジンのうちの1つ又は複数は、そのスレッド・グループが処理されているサイクル中にはアイドルであってもよい。少なくとも一実施例では、スレッド・グループはまた、グラフィックス・マルチプロセッサ2134内の処理エンジンの数よりも多いスレッドを含んでもよい。少なくとも一実施例では、スレッド・グループがグラフィックス・マルチプロセッサ2134内の処理エンジンの数より多くのスレッドを含む場合には、連続したクロック・サイクルにわたって処理を実行することができる。少なくとも一実施例では、複数のスレッド・グループを、グラフィックス・マルチプロセッサ2134上で同時に実行することができる。
【0290】
少なくとも一実施例では、グラフィックス・マルチプロセッサ2134は、ロード及びストアの動作を実行するための内部キャッシュ・メモリを含む。少なくとも一実施例では、グラフィックス・マルチプロセッサ2134は、内部キャッシュをやめて、処理クラスタ2114内のキャッシュ・メモリ(たとえば、L1キャッシュ2148)を使用することができる。少なくとも一実施例では、各グラフィックス・マルチプロセッサ2134は、パーティション・ユニット(たとえば、
図21Aのパーティション・ユニット2120A~2120N)内のL2キャッシュにもアクセスすることができ、これらのキャッシュが、すべての処理クラスタ2114間で共有され、スレッド間でデータを転送するために使用されてもよい。少なくとも一実施例では、グラフィックス・マルチプロセッサ2134は、オフ・チップのグローバル・メモリにもアクセスすることができ、このメモリは、ローカル並列プロセッサ・メモリ及び/又はシステム・メモリのうちの1つ又は複数を含むことができる。少なくとも一実施例では、並列処理ユニット2102の外部にある任意のメモリが、グローバル・メモリとして使用されてもよい。少なくとも一実施例では、処理クラスタ2114は、グラフィックス・マルチプロセッサ2134の複数のインスタンスを含み、共通の命令及びデータを共有することができ、これらはL1キャッシュ2148に記憶されてもよい。
【0291】
少なくとも一実施例では、各処理クラスタ2114は、仮想アドレスを物理アドレスにマッピングするように構成されたMMU2145(メモリ管理ユニット)を含んでもよい。少なくとも一実施例では、MMU2145の1つ又は複数のインスタンスは、
図21Aのメモリ・インターフェース2118内にあってもよい。少なくとも一実施例では、MMU2145は、仮想アドレスを、タイル及び任意選択でキャッシュ・ライン・インデックスの物理アドレスにマッピングするために使用されるページ・テーブル・エントリ(PTE)のセットを含む。少なくとも一実施例では、MMU2145は、アドレスのトランスレーション・ルックアサイド・バッファ(TLB:translation lookaside buffer)又はキャッシュを含んでもよく、これらは、グラフィックス・マルチプロセッサ2134若しくはL1 2148キャッシュ、又は処理クラスタ2114内にあってもよい。少なくとも一実施例では、表面データ・アクセスをローカルに分散するように物理アドレスを処理して、パーティション・ユニット間で要求の効率的なインターリーブが可能になる。少なくとも一実施例では、キャッシュ・ライン・インデックスを使用して、キャッシュ・ラインの要求がヒットかミスかが判定されてもよい。
【0292】
少なくとも一実施例では、各グラフィックス・マルチプロセッサ2134がテクスチャ・ユニット2136に結合されて、テクスチャ・マッピング動作、たとえば、テクスチャ・サンプル位置の判定、テクスチャ・データの読取り、及びテクスチャ・データのフィルタリングが実行されるように、処理クラスタ2114が構成されてもよい。少なくとも一実施例では、テクスチャ・データは、内部テクスチャL1キャッシュ(図示せず)から、又はグラフィックス・マルチプロセッサ2134内のL1キャッシュから読み取られ、必要に応じて、L2キャッシュ、ローカル並列プロセッサ・メモリ、又はシステム・メモリからフェッチされる。少なくとも一実施例では、各グラフィックス・マルチプロセッサ2134は、処理済みタスクをデータ・クロスバー2140に出力して、さらなる処理ができるように別の処理クラスタ2114に処理済みタスクを提供し、又はメモリ・クロスバー2116を介して、L2キャッシュ、ローカル並列プロセッサ・メモリ、又はシステム・メモリに処理済みタスクを記憶する。少なくとも一実施例では、プレROP2142(プレ・ラスタ演算ユニット)は、グラフィックス・マルチプロセッサ2134からデータを受け取り、ROPユニットにデータを仕向けるように構成されており、ROPユニットは、本明細書に記載するように、パーティション・ユニット(たとえば、
図21Aのパーティション・ユニット2120A~2120N)内に位置付けられてもよい。少なくとも一実施例では、プレROP2142ユニットは、色ブレンディングの最適化を実行し、ピクセル色データを組織化し、アドレス・トランスレーションを実行することができる。
【0293】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のためにグラフィックス処理クラスタ2114において使用されてもよい。
【0294】
少なくとも一実施例では、
図21Cに示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図21Cに示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図21Cに示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0295】
図21Dは、少なくとも一実施例によるグラフィックス・マルチプロセッサ2134を示す。少なくとも一実施例では、グラフィックス・マルチプロセッサ2134は、処理クラスタ2114のパイプライン・マネージャ2132と結合する。少なくとも一実施例では、グラフィックス・マルチプロセッサ2134は、命令キャッシュ2152、命令ユニット2154、アドレス・マッピング・ユニット2156、レジスタ・ファイル2158、1つ又は複数の汎用グラフィックス・プロセッシング・ユニット(GPGPU)コア2162、及び1つ又は複数のロード/ストア・ユニット2166を含むがこれらに限定されない実行パイプラインを有する。少なくとも一実施例では、GPGPUコア2162、及びロード/ストア・ユニット2166は、メモリ及びキャッシュ相互接続2168を介して、キャッシュ・メモリ2172及び共有メモリ2170に結合される。
【0296】
少なくとも一実施例では、命令キャッシュ2152は、実行すべき命令のストリームをパイプライン・マネージャ2132から受け取る。少なくとも一実施例では、命令は、命令キャッシュ2152にキャッシュされ、命令ユニット2154により実行されるようにディスパッチされる。少なくとも一実施例では、命令ユニット2154は、命令をスレッド・グループ(たとえば、ワープ)としてディスパッチすることができ、スレッド・グループの各スレッドは、GPGPUコア2162内の異なる実行ユニットに割り当てられる。少なくとも一実施例では、命令は、統一アドレス空間内のアドレスを指定することによって、ローカル、共有、又はグローバルのアドレス空間のいずれかにアクセスすることができる。少なくとも一実施例では、アドレス・マッピング・ユニット2156を使用して、統一アドレス空間のアドレスを、ロード/ストア・ユニット2166がアクセスできる個別メモリ・アドレスにトランスレーションすることができる。
【0297】
少なくとも一実施例では、レジスタ・ファイル2158は、グラフィックス・マルチプロセッサ2134の機能ユニットにレジスタのセットを提供する。少なくとも一実施例では、レジスタ・ファイル2158は、グラフィックス・マルチプロセッサ2134の機能ユニット(たとえばGPGPUコア2162、ロード/ストア・ユニット2166)のデータ経路に接続された、オペランドのための一時的なストレージを提供する。少なくとも一実施例では、レジスタ・ファイル2158は、各機能ユニットがレジスタ・ファイル2158の専用部分に配分されるように、機能ユニットのそれぞれ間で分割される。一実施例では、レジスタ・ファイル2158は、グラフィックス・マルチプロセッサ2134によって実行されている異なるワープ間で分割される。
【0298】
少なくとも一実施例では、GPGPUコア2162はそれぞれ、グラフィックス・マルチプロセッサ2134の命令を実行するために使用される浮動小数点ユニット(FPU)及び/又は整数算術論理演算ユニット(ALU)を含むことができる。少なくとも一実施例では、GPGPUコア2162同士は、同様のアーキテクチャであってもよく、又は異なるアーキテクチャであってもよい。少なくとも一実施例では、GPGPUコア2162の第1の部分は、単精度FPU及び整数ALUを含み、GPGPUコアの第2の部分は、倍精度FPUを含む。少なくとも一実施例では、FPUは、IEEE754-2008規格浮動小数点演算を実施することができ、又は、可変精度の浮動小数点演算を有効にすることができる。少なくとも一実施例では、グラフィックス・マルチプロセッサ2134はさらに、矩形コピー又はピクセル・ブレンディングの動作などの特定の機能を実行するための、1つ若しくは複数の固定機能ユニット又は特別機能ユニットをさらに含むことができる。少なくとも一実施例では、GPGPUコア2162の1つ又は複数は、固定の又は特別な機能論理も含むことができる。
【0299】
少なくとも一実施例では、GPGPUコア2162は、複数のデータ・セットに対して単一の命令を実行することができるSIMD論理を含む。少なくとも一実施例では、GPGPUコア2162は、SIMD4、SIMD8、及びSIMD16の命令を物理的に実行することができ、SIMD1、SIMD2、及びSIMD32の命令を論理的に実行することができる。少なくとも一実施例では、GPGPUコアのためのSIMD命令は、シェーダ・コンパイラによるコンパイル時に生成されてもよく、又は単一プログラム複数データ(SPMD:single program multiple data)又はSIMTのアーキテクチャ向けに書かれコンパイルされたプログラムを実行しているときに、自動的に生成されてもよい。少なくとも一実施例では、SIMT実行モデルのために構成されたプログラムの複数のスレッドは、単一のSIMD命令を介して実行することができる。たとえば、少なくとも一実施例では、同じ又は同様の動作を実行する8個のSIMTスレッドを、単一のSIMD8の論理ユニットを介して並列に実行することができる。
【0300】
少なくとも一実施例では、メモリ及びキャッシュ相互接続2168は、グラフィックス・マルチプロセッサ2134の各機能ユニットをレジスタ・ファイル2158及び共有メモリ2170に接続する相互接続ネットワークである。少なくとも一実施例では、メモリ及びキャッシュ相互接続2168は、ロード/ストア・ユニット2166が、共有メモリ2170とレジスタ・ファイル2158の間でロード及びストアの動作を実施できるようにするクロスバー相互接続である。少なくとも一実施例では、レジスタ・ファイル2158は、GPGPUコア2162と同じ周波数で動作することができ、したがって、GPGPUコア2162とレジスタ・ファイル2158の間のデータ転送は非常に低いレイテンシを有することができる。少なくとも一実施例では、共有メモリ2170を使用して、グラフィックス・マルチプロセッサ2134内の機能ユニットで実行されるスレッド間の通信を可能にすることができる。少なくとも一実施例では、キャッシュ・メモリ2172を、たとえばデータ・キャッシュとして使用して、機能ユニットとテクスチャ・ユニット2136の間で通信されるテクスチャ・データをキャッシュすることができる。少なくとも一実施例では、共有メモリ2170は、プログラム管理キャッシュとしても使用することができる。少なくとも一実施例では、GPGPUコア2162で実行されているスレッドは、キャッシュ・メモリ2172内に記憶される自動キャッシュ・データに加えて、共有メモリ内にプログラム的にデータを記憶することができる。
【0301】
少なくとも一実施例では、本明細書に記載の並列プロセッサ又はGPGPUは、ホスト/プロセッサ・コアに通信可能に結合されて、グラフィックス動作、機械学習動作、パターン分析動作、及び様々な汎用GPU(GPGPU)機能を加速する。少なくとも一実施例では、GPUは、バス又は他の相互接続(たとえば、PCIe又はNVLinkなどの高速相互接続)を介してホスト・プロセッサ/コアに通信可能に結合されてもよい。少なくとも一実施例では、GPUは、コアとしてのパッケージ又はチップに一体化されてもよく、パッケージ又はチップの内部の内部プロセッサ・バス/相互接続を介してコアに通信可能に結合されてもよい。少なくとも一実施例では、GPUの接続方法に関わらず、プロセッサ・コアは、ワーク記述子に含まれたコマンド/命令のシーケンスの形でワークをこうしたGPUに配分してもよい。少なくとも一実施例では、次いでそのGPUは、これらのコマンド/命令を効率的に処理するために専用の回路/論理を使用する。
【0302】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のためにグラフィックス・マルチプロセッサ2134において使用されてもよい。
【0303】
少なくとも一実施例では、
図21Dに示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図21Dに示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図21Dに示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0304】
図22は、少なくとも一実施例による、マルチGPUコンピューティング・システム2200を示す。少なくとも一実施例では、マルチGPUコンピューティング・システム2200は、ホスト・インターフェース・スイッチ2204を介して複数の汎用グラフィックス・プロセッシング・ユニット(GPGPU)2206A~Dに結合されたプロセッサ2202を含むことができる。少なくとも一実施例では、ホスト・インターフェース・スイッチ2204は、プロセッサ2202をPCIエクスプレス・バスに結合するPCIエクスプレス・スイッチ・デバイスであり、このPCIエクスプレス・バスを介して、プロセッサ2202は、GPGPU2206A~Dと通信することができる。少なくとも一実施例では、GPGPU2206A~Dは、高速ポイントツーポイントGPUツーGPUリンク2216-のセットを介して相互接続することができる。少なくとも一実施例では、GPUツーGPUリンク2216は、専用GPUリンクを介して、GPGPU2206A~Dのそれぞれに接続される。少なくとも一実施例では、P2PのGPUリンク2216は、プロセッサ2202が接続されているホスト・インターフェース・バス2204を介した通信を必要とせずに、GPGPU2206A~Dのそれぞれの間で直接通信を可能にする。少なくとも一実施例では、P2PのGPUリンク2216に仕向けられたGPUツーGPUトラフィックがあると、ホスト・インターフェース・バス2204は、システム・メモリへのアクセスができるように、又はたとえば1つ又は複数のネットワーク・デバイスを介して、マルチGPUコンピューティング・システム2200の他のインスタンスと通信するために、利用可能な状態に保たれる。少なくとも一実施例では、GPGPU2206A~Dは、ホスト・インターフェース・スイッチ2204を介してプロセッサ2202に接続され、少なくとも一実施例では、プロセッサ2202は、P2PのGPUリンク2216のための直接サポートを含み、GPGPU2206A~Dに直接接続することができる。
【0305】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のためにマルチGPUコンピューティング・システム2200において使用されてもよい。
【0306】
少なくとも一実施例では、
図22に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図22に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図22に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0307】
図23は、少なくとも一実施例によるグラフィックス・プロセッサ2300のブロック図である。少なくとも一実施例では、グラフィックス・プロセッサ2300は、リング相互接続2302、パイプライン・フロント・エンド2304、メディア・エンジン2337、及びグラフィックス・コア2380A~2380Nを含む。少なくとも一実施例では、リング相互接続2302は、グラフィックス・プロセッサ2300を、他のグラフィックス・プロセッサ又は1つ又は複数の汎用プロセッサ・コアを含む他の処理ユニットに結合する。少なくとも一実施例では、グラフィックス・プロセッサ2300は、マルチ・コア処理システム内に一体化された多数のプロセッサのうちの1つである。
【0308】
少なくとも一実施例では、グラフィックス・プロセッサ2300は、リング相互接続2302を介してコマンドのバッチを受け取る。少なくとも一実施例では、入ってくるコマンドは、パイプライン・フロント・エンド2304のコマンド・ストリーマ2303によって解釈される。少なくとも一実施例では、グラフィックス・プロセッサ2300は、グラフィックス・コア2380A~2380Nを介して3Dジオメトリ処理及びメディア処理を実行するためのスケーラブルな実行論理を含む。少なくとも一実施例では、3Dジオメトリ処理コマンドについては、コマンド・ストリーマ2303はコマンドをジオメトリ・パイプライン2336に供給する。少なくとも一実施例では、少なくとも一部のメディア処理コマンドについては、コマンド・ストリーマ2303はコマンドをビデオ・フロント・エンド2334に供給し、ビデオ・フロント・エンド2334はメディア・エンジン2337に結合される。少なくとも一実施例では、メディア・エンジン2337は、ビデオ及び画像の後処理のためのVideo Quality Engine(VQE)2330と、ハードウェア加速されたメディア・データのエンコード及びデコードを提供するマルチ・フォーマット・エンコード/デコード(MFX)2333エンジンとを含む。少なくとも一実施例では、ジオメトリ・パイプライン2336及びメディア・エンジン2337はそれぞれ、少なくとも1つのグラフィックス・コア2380によって提供されるスレッド実行リソースのための実行スレッドを生成する。
【0309】
少なくとも一実施例では、グラフィックス・プロセッサ2300は、グラフィックス・コア2380A~2380N(モジュール式とすることができ、コア・スライスと呼ばれることもある)を特徴とするスケーラブルなスレッド実行リソースを含み、それぞれのモジュール式コア2380A~2380Nは、複数のサブ・コア2350A~50N、2360A~2360N(コア・サブ・スライスと呼ばれることもある)を有する。少なくとも一実施例では、グラフィックス・プロセッサ2300は、任意の数のグラフィックス・コア2380Aを有することができる。少なくとも一実施例では、グラフィックス・プロセッサ2300は、少なくとも第1のサブ・コア2350A及び第2のサブ・コア2360Aを有するグラフィックス・コア2380Aを含む。少なくとも一実施例では、グラフィックス・プロセッサ2300は、単一のサブ・コア(たとえば、2350A)を有する低電力プロセッサである。少なくとも一実施例では、グラフィックス・プロセッサ2300は、複数のグラフィックス・コア2380A~2380Nを含み、このそれぞれが、第1のサブ・コア2350A~2350Nのセット、及び第2のサブ・コア2360A~2360Nのセットを含む。少なくとも一実施例では、第1のサブ・コア2350A~2350Nの各サブ・コアは、少なくとも、実行ユニット2352A~2352Nとメディア/テクスチャ・サンプラ2354A~2354Nの第1のセットを含む。少なくとも一実施例では、第2のサブ・コア2360A~2360Nの各サブ・コアは、少なくとも、実行ユニット2362A~2362Nとサンプラ2364A~2364Nの第2のセットを含む。少なくとも一実施例では、各サブ・コア2350A~2350N、2360A~2360Nは、共有リソース2370A~2370Nのセットを共有する。少なくとも一実施例では、共有リソースは、共有キャッシュ・メモリ及びピクセル動作論理を含む。
【0310】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815は、本明細書に記載のニューラル・ネットワークの訓練動作、ニューラル・ネットワークの機能及び/若しくはアーキテクチャ、又はニューラル・ネットワークのユース・ケースを使用して計算された重みパラメータに少なくとも部分的に基づき、推論又は予測の動作のためにグラフィックス・プロセッサ2300において使用されてもよい。
【0311】
少なくとも一実施例では、
図23に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図23に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図23に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0312】
図24は、少なくとも一実施例による、命令を実行するための論理回路を含んでもよいプロセッサ2400のマイクロ・アーキテクチャを示すブロック図である。少なくとも一実施例では、プロセッサ2400は、x86命令、ARM命令、特定用途向け集積回路(ASIC)用の特別命令などを含む命令を実行してもよい。少なくとも一実施例では、プロセッサ2400は、カリフォルニア州サンタクララのインテルコーポレーションによる、MMX技術で有効化されたマイクロプロセッサ内の64ビット幅MMX(商標)レジスタなど、パック・データを記憶するためのレジスタを含んでもよい。少なくとも一実施例では、整数形式と浮動小数点形式の両方で利用可能なMMXレジスタは、単一命令複数データ(「SIMD」)及びストリーミングSIMD拡張(「SSE」:streaming SIMD extensions)命令を伴うパック・データ要素で動作してもよい。少なくとも一実施例では、SSE2、SSE3、SSE4、AVX、又はそれ以上(総称して「SSEx」と呼ばれる)の技術に関する128ビット幅のXMMレジスタは、こうしたパック・データのオペランドを保持してもよい。少なくとも一実施例では、プロセッサ2400は、機械学習若しくは深層学習のアルゴリズム、訓練、又は推論を加速するために命令を実行してもよい。
【0313】
少なくとも一実施例では、プロセッサ2400は、実行すべき命令をフェッチし、プロセッサ・パイプラインで後に使用すべき命令を準備するイン・オーダー・フロント・エンド(「フロント・エンド」)2401を含む。少なくとも一実施例では、フロント・エンド2401は、いくつかのユニットを含んでもよい。少なくとも一実施例では、命令プリフェッチャ2426が、メモリから命令をフェッチし、命令デコーダ2428に命令を供給し、命令デコーダが、命令をデコード又は解釈する。たとえば、少なくとも一実施例では、命令デコーダ2428は、受け取った命令を、機械が実行することのできる「マイクロ命令」又は「マイクロ・オペレーション」と呼ばれる(「マイクロ・オプス」又は「uops」とも呼ばれる)1つ又は複数のオペレーションにデコードする。少なくとも一実施例では、命令デコーダ2428は、命令を、オプコード及び対応するデータ、並びに制御フィールドに構文解析して、これらがマイクロ・アーキテクチャによって使用されて、少なくとも一実施例による動作が実行されてもよい。少なくとも一実施例では、トレース・キャッシュ2430は、デコードされたuopsを、実行できるようにuopキュー2434においてプログラム順のシーケンス又はトレースにアセンブルしてもよい。少なくとも一実施例では、トレース・キャッシュ2430が複雑な命令に遭遇すると、マイクロコードROM2432が、動作の完了に必要なuopsを提供する。
【0314】
少なくとも一実施例では、単一のマイクロ・オプスに変換できる命令もあれば、全動作を完了するためにいくつかのマイクロ・オプスを必要とする命令もある。少なくとも一実施例では、命令を完了するために5つ以上のマイクロ・オプスが必要な場合、命令デコーダ2428は、マイクロコードROM2432にアクセスして、その命令を実行してもよい。少なくとも一実施例では、命令は、命令デコーダ2428において処理できるように、少数のマイクロ・オプスにデコードされてもよい。少なくとも一実施例では、そのような動作を完了するのに多数のマイクロ・オプスが必要な場合には、命令は、マイクロコードROM2432に記憶されてもよい。少なくとも一実施例では、トレース・キャッシュ2430は、少なくとも一実施例によるマイクロコードROM2432からの1つ又は複数の命令を完了するために、エントリ・ポイント・プログラマブル論理アレイ(「PLA」:programmable logic array)を参照して、マイクロコード・シーケンスを読み取るための正しいマイクロ命令ポインタを判定する。少なくとも一実施例では、マイクロコードROM2432が命令のためのマイクロ・オプスのシーケンシングを終了した後、機械のフロント・エンド2401は、トレース・キャッシュ2430からマイクロ・オプスのフェッチを再開してもよい。
【0315】
少なくとも一実施例では、アウト・オブ・オーダー実行エンジン(「アウト・オブ・オーダー・エンジン」)2403は、実行できるように命令を準備してもよい。少なくとも一実施例では、アウト・オブ・オーダー実行論理は、命令のフローをなめらかにし、その順序を変更するために多数バッファを有し、命令がパイプラインを下り、実行されるようにスケジューリングされるときの性能を最適化する。少なくとも一実施例では、アウト・オブ・オーダー実行エンジン2403は、限定することなく、アロケータ/レジスタ・リネーマ2440、メモリuopキュー2442、整数/浮動小数点uopキュー2444、メモリ・スケジューラ2446、高速スケジューラ2402、低速/汎用浮動小数点スケジューラ(「低速/汎用FP:floating pointスケジューラ」)2404、及び単純浮動小数点スケジューラ(「単純FPスケジューラ」)2406を含む。少なくとも一実施例では、高速スケジューラ2402、低速/汎用浮動小数点スケジューラ2404、及び単純浮動小数点スケジューラ2406は、本明細書において集合的に「uopスケジューラ2402、2404、2406」とも呼ばれる。少なくとも一実施例では、アロケータ/レジスタ・リネーマ2440は、実行するために各uopが必要とする機械バッファ及びリソースを配分する。少なくとも一実施例では、アロケータ/レジスタ・リネーマ2440は、レジスタ・ファイルへのエントリ時に論理レジスタの名前を変更する。少なくとも一実施例では、アロケータ/レジスタ・リネーマ2440はまた、メモリ・スケジューラ2446及びuopスケジューラ2402、2404、2406の前の、2つのuopキュー、すなわちメモリ動作のためのメモリuopキュー2442と非メモリ動作のための整数/浮動小数点uopキュー2444のうちの1つに、各uopのエントリを配分する。少なくとも一実施例では、uopスケジューラ2402、2404、2406は、uopsがいつ実行準備されるかを、それらの従属入力レジスタ・オペランドのソースが準備されていること、及びそれらの動作を完了するためにuopが必要とする実行リソースが利用可能であることに基づき、判定する。少なくとも一実施例では、高速スケジューラ2402は、メイン・クロック・サイクルの半分ごとにスケジューリングしてもよく、低速/汎用浮動小数点スケジューラ2404及び単純浮動小数点スケジューラ2406は、メイン・プロセッサのクロック・サイクル当たりに1回スケジューリングしてもよい。少なくとも一実施例では、uopスケジューラ2402、2404、2406は、実行できるようにuopsをスケジューリングするためにディスパッチ・ポートを調停する。
【0316】
少なくとも一実施例では、実行ブロック2411は、限定することなく、整数レジスタ・ファイル/バイパス・ネットワーク2408、浮動小数点レジスタ・ファイル/バイパス・ネットワーク(「FPレジスタ・ファイル/バイパス・ネットワーク」)2410、アドレス生成ユニット(「AGU」:address generation unit)2412及び2414、高速算術論理演算ユニット(ALU)(「高速ALU」)2416及び2418、低速算術論理演算ユニット(「低速ALU」)2420、浮動小数点ALU(「FP」)2422、並びに浮動小数点移動ユニット(「FP移動」)2424を含む。少なくとも一実施例では、整数レジスタ・ファイル/バイパス・ネットワーク2408及び浮動小数点レジスタ・ファイル/バイパス・ネットワーク2410は、本明細書において「レジスタ・ファイル2408、2410」とも呼ばれる。少なくとも一実施例では、AGU2412及び2414、高速ALU2416及び2418、低速ALU2420、浮動小数点ALU2422、及び浮動小数点移動ユニット2424は、本明細書において「実行ユニット2412、2414、2416、2418、2420、2422、及び2424」とも呼ばれる。少なくとも一実施例では、実行ブロック2411は、限定することなく、(ゼロを含む)任意の数及びタイプのレジスタ・ファイル、バイパス・ネットワーク、アドレス生成ユニット、及び実行ユニットを、任意の組合せで含んでもよい。
【0317】
少なくとも一実施例では、レジスタ・ネットワーク2408、2410は、uopスケジューラ2402、2404、2406と、実行ユニット2412、2414、2416、2418、2420、2422、及び2424との間に配置されてもよい。少なくとも一実施例では、整数レジスタ・ファイル/バイパス・ネットワーク2408は、整数演算を実行する。少なくとも一実施例では、浮動小数点レジスタ・ファイル/バイパス・ネットワーク2410は、浮動小数点演算を実行する。少なくとも一実施例では、レジスタ・ネットワーク2408、2410のそれぞれは、限定することなく、バイパス・ネットワークを含んでもよく、このバイパス・ネットワークは、レジスタ・ファイルにまだ書き込まれていない完了したばかりの結果を、新しい従属uopsにバイパス又は転送してもよい。少なくとも一実施例では、レジスタ・ネットワーク2408、2410は、互いにデータを通信してもよい。少なくとも一実施例では、整数レジスタ・ファイル/バイパス・ネットワーク2408は、限定することなく、2つの別々のレジスタ・ファイル、すなわち低次32ビットのデータ用の1つのレジスタ・ファイル、及び高次32ビットのデータ用の第2のレジスタ・ファイルを含んでもよい。少なくとも一実施例では、浮動小数点命令は、通常、64~128ビット幅のオペランドを有することから、浮動小数点レジスタ・ファイル/バイパス・ネットワーク2410は、限定することなく、128ビット幅のエントリを含んでもよい。
【0318】
少なくとも一実施例では、実行ユニット2412、2414、2416、2418、2420、2422、2424は、命令を実行してもよい。少なくとも一実施例では、レジスタ・ネットワーク2408、2410は、マイクロ命令が実行する必要のある整数及び浮動小数点のデータのオペランド値を記憶する。少なくとも一実施例では、プロセッサ2400は、限定することなく、任意の数及び組合せの実行ユニット2412、2414、2416、2418、2420、2422、2424を含んでよい。少なくとも一実施例では、浮動小数点ALU2422及び浮動小数点移動ユニット2424は、浮動小数点、MMX、SIMD、AVX、及びSEE、又は特別な機械学習命令を含む他の演算を実行してもよい。少なくとも一実施例では、浮動小数点ALU2422は、限定することなく、64ビットずつの浮動小数点デバイダを含み、除算、平方根、及び残りのマイクロ・オプスを実行してもよい。少なくとも一実施例では、浮動小数点値を含む命令は、浮動小数点ハードウェアによって対処されてもよい。少なくとも一実施例では、ALU演算は、高速ALU2416、2418に渡されてもよい。少なくとも一実施例では、高速ALU2416、2418は、クロック・サイクルの半分の実効レイテンシで高速演算を実行してもよい。少なくとも一実施例では、低速ALU2420は、乗数、シフト、フラグ論理、及びブランチ処理などの長レイテンシ・タイプの演算のための整数実行ハードウェアを、限定することなく含んでもよいことから、ほとんどの複雑な整数演算は低速ALU2420に進む。少なくとも一実施例では、メモリのロード/ストア動作は、AGU2412、2414によって実行されてもよい。少なくとも一実施例では、高速ALU2416、高速ALU2418、及び低速ALU2420は、64ビットのデータ・オペランドで整数演算を実行してもよい。少なくとも一実施例では、高速ALU2416、高速ALU2418、及び低速ALU2420は、16、32、128、256などを含む様々なデータ・ビット・サイズをサポートするように実施されてもよい。少なくとも一実施例では、浮動小数点ALU2422及び浮動小数点移動ユニット2424は、SIMD及びマルチメディア命令と併せて128ビット幅のパック・データ・オペランドなどの、様々なビット幅を有する幅広いオペランドをサポートするように実施されてもよい。
【0319】
少なくとも一実施例では、uopスケジューラ2402、2404、2406は、親ロードが実行を終了する前に、従属演算をディスパッチする。少なくとも一実施例では、uopsは、プロセッサ2400において投機的にスケジューリング及び実行されてもよいので、プロセッサ2400は、メモリ・ミスに対処するための論理も含んでよい。少なくとも一実施例では、データ・キャッシュにおいてデータ・ロードがミスした場合、一時的に不正確なデータを有するスケジューラを通り過ぎたパイプラインに、進行中の従属演算が存在してもよい。少なくとも一実施例では、リプレイ機構が、不正確なデータを使用する命令を追跡及び再実行する。少なくとも一実施例では、従属演算は、リプレイされる必要があってもよく、独立した演算は、完了が許容されてもよい。少なくとも一実施例では、プロセッサの少なくとも一実施例のスケジューラ及びリプレイ機構はまた、テキスト・ストリング比較演算のための命令シーケンスを捕捉するように設計されてもよい。
【0320】
少なくとも一実施例では、「レジスタ」は、オペランドを識別するための命令の一部として使用することができるオンボード・プロセッサのストレージ・ロケーションを指してもよい。少なくとも一実施例では、レジスタは、(プログラマの視点から見て)プロセッサの外部から使用可能であり得るものであってもよい。少なくとも一実施例では、レジスタは、特定のタイプの回路に限定されなくてもよい。むしろ、少なくとも一実施例では、レジスタは、データを記憶し、データを提供し、本明細書に記載の機能を実行してもよい。少なくとも一実施例では、本明細書に記載のレジスタは、専用物理レジスタ、レジスタ・リネーミングを使用して動的に配分される物理レジスタ、専用物理レジスタと動的に配分される物理レジスタとの組合せなど、任意の数の異なる技法を使用して、プロセッサ内の回路によって実施されてもよい。少なくとも一実施例では、整数レジスタは、32ビットの整数データを記憶する。少なくとも一実施例のレジスタ・ファイルは、パック・データのための8つのマルチメディアSIMDレジスタも含む。
【0321】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815の一部又はすべてが、実行ブロック2411、及び図示してある若しくは図示していない他のメモリ又はレジスタに組み込まれてもよい。たとえば、少なくとも一実施例では、本明細書に記載の訓練及び/又は推論の技法は、実行ブロック2411に示すALUのうちの1つ又は複数を使用してもよい。さらに、重みパラメータは、本明細書に記載の1つ又は複数の機械学習アルゴリズム、ニューラル・ネットワーク・アーキテクチャ、ユース・ケース、又は訓練技法を実行するための実行ブロック2411のALUを構成するオン・チップ若しくはオフ・チップのメモリ及び/又はレジスタ(図示する又は図示せず)に記憶されてもよい。
【0322】
少なくとも一実施例では、
図24に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図24に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図24に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0323】
図25は、少なくとも一実施例による深層学習アプリケーション・プロセッサ2500を示す。少なくとも一実施例では、深層学習アプリケーション・プロセッサ2500は、深層学習アプリケーション・プロセッサ2500によって実行される場合に、本開示全体を通して記載するプロセス及び技法の一部又はすべてを、深層学習アプリケーション・プロセッサ2500に実行させる命令を使用する。少なくとも一実施例では、深層学習アプリケーション・プロセッサ2500は、特定用途向け集積回路(ASIC)である。少なくとも一実施例では、アプリケーション・プロセッサ2500は、1つ若しくは複数の命令又は両方を実行した結果としていずれもハードウェアに「ハード・ワイヤード」された行列乗算演算を実行する。少なくとも一実施例では、深層学習アプリケーション・プロセッサ2500は、限定することなく、処理クラスタ2510(1)~2510(12)、チップ間リンク(「ICL」)2520(1)~2520(12)、チップ間コントローラ(「ICC」)2530(1)~2530(2)、高帯域幅メモリ第2世代(「HBM2」)2540(1)~2540(4)、メモリ・コントローラ(「Mem Ctrlr」)2542(1)~2542(4)、高帯域幅メモリ物理層(「HBM PHY」)2544(1)~2544(4)、管理-コントローラ中央処理装置(「管理-コントローラCPU」)2550、シリアル・ペリフェラル・インターフェース、集積回路間、及び汎用入力/出力ブロック(「SPI、I
2C、GPIO」)2560、周辺構成要素相互接続エクスプレス・コントローラ及びダイレクト・メモリ・アクセス・ブロック(「PCIeコントローラ及びDMA」)2570、並びに16レーン周辺構成要素相互接続エクスプレス・ポート(「PCI Expressx16」)2580を含む。
【0324】
少なくとも一実施例では、処理クラスタ2510は、本明細書に記載の技法を含む1つ又は複数の訓練技法を使用して計算された重みパラメータに基づき、推論又は予測の演算を含む深層学習演算を実行してもよい。少なくとも一実施例では、各処理クラスタ2510は、限定することなく、任意の数及びタイプのプロセッサを含んでもよい。少なくとも一実施例では、深層学習アプリケーション・プロセッサ2500は、任意の数及びタイプの処理クラスタ2500を含んでもよい。少なくとも一実施例では、チップ間リンク2520は、双方向性である。少なくとも一実施例では、チップ間リンク2520及びチップ間コントローラ2530は、1つ又は複数のニューラル・ネットワークに具体化された1つ又は複数の機械学習アルゴリズムを実行した結果得られるアクティブ化情報を含む情報を、複数の深層学習アプリケーション・プロセッサ2500が交換できるようにする。少なくとも一実施例では、深層学習アプリケーション・プロセッサ2500は、(ゼロを含む)任意の数及びタイプのICL2520及びICC2530を含んでもよい。
【0325】
少なくとも一実施例では、HBM2 2540は、合計32ギガバイト(GB:Gigabyte)のメモリを提供する。少なくとも一実施例では、HBM2 2540(i)は、メモリ・コントローラ2542(i)とHBM PHY2544(i)の両方に関連付けられ、ここで「i」は任意の整数である。少なくとも一実施例では、任意の数のHBM2 2540が、任意のタイプ及び合計量の高帯域幅メモリを提供してもよく、(ゼロを含む)任意の数及びタイプのメモリ・コントローラ2542及びHBM PHY2544に関連付けられてもよい。少なくとも一実施例では、SPI、I2C、GPIO2560、PCIeコントローラ及びDMA2570、並びに/又はPCIe2580は、任意の技術的に実行可能なやり方で任意の数及びタイプの通信規格を有効にする任意の数及びタイプのブロックに置き換えられてもよい。
【0326】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、深層学習アプリケーション・プロセッサは、深層学習アプリケーション・プロセッサ2500に提供される情報を予測又は推論するようにニューラル・ネットワークなどの機械学習モデルを訓練するために使用される。少なくとも一実施例では、深層学習アプリケーション・プロセッサ2500は、別のプロセッサ若しくはシステムによって、又は深層学習アプリケーション・プロセッサ2500によって訓練されてきた訓練済み機械学習モデル(たとえば、ニューラル・ネットワーク)に基づき、情報を推論又は予測するために使用される。少なくとも一実施例では、プロセッサ2500は、本明細書に記載の1つ又は複数のニューラル・ネットワークのユース・ケースを実行するために使用されてもよい。
【0327】
少なくとも一実施例では、
図25に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図25に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図25に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0328】
図26は、少なくとも一実施例による、ニューロモーフィック・プロセッサ2600のブロック図である。少なくとも一実施例では、ニューロモーフィック・プロセッサ2600は、ニューロモーフィック・プロセッサ2600の外部のソースから1つ又は複数の入力を受信する。少なくとも一実施例では、これらの入力は、ニューロモーフィック・プロセッサ2600内の1つ又は複数のニューロン2602に送信されてもよい。少なくとも一実施例では、ニューロン2602及びその構成要素は、1つ又は複数の算術論理演算ユニット(ALU)を含む回路又は論理を使用して、実施されてもよい。少なくとも一実施例では、ニューロモーフィック・プロセッサ2600は、限定することなく、ニューロン2602の数千又は数百万のインスタンスを含んでもよいが、任意の好適な数のニューロン2602が使用されてもよい。少なくとも一実施例では、ニューロン2602の各インスタンスは、ニューロン入力2604及びニューロン出力2606を含んでもよい。少なくとも一実施例では、ニューロン2602は出力を生成してもよく、この出力は、ニューロン2602の他のインスタンスの入力に送信されてもよい。たとえば、少なくとも一実施例では、ニューロン入力2604及びニューロン出力2606は、シナプス2608を介して相互接続されてもよい。
【0329】
少なくとも一実施例では、ニューロン2602とシナプス2608は、ニューロモーフィック・プロセッサ2600が受信した情報をニューロモーフィック・プロセッサ2600が動作して処理又は分析するように、相互接続されてもよい。少なくとも一実施例では、ニューロン2602は、ニューロン入力2604を介して受信した入力が、閾値を超えているとき、出力パルス(又は「発火」若しくは「スパイク」)を送信してもよい。少なくとも一実施例では、ニューロン2602は、ニューロン入力2604において受信した信号を合計又は積分してもよい。たとえば、少なくとも一実施例では、ニューロン2602は、漏れ積分発火ニューロン(leaky integrate-and-fire neuron)として実施されてもよく、ここで、合計(「膜電位」と呼ばれる)が閾値を超える場合には、ニューロン2602は、シグモイド関数又は閾値関数などの伝達関数を使用して、出力(又は「発火」)を生成してもよい。少なくとも一実施例では、漏れ積分発火ニューロンは、ニューロン入力2604で受信した信号を合計して膜電位にしてもよく、また、崩壊因子(又は漏れ)を適用して膜電位を低減してもよい。少なくとも一実施例では、複数の入力信号が、閾値を超えるほど十分に素早く(すなわち、膜電位の崩壊が少なすぎて発火できなくなる前に)ニューロン入力2604において受信された場合には、漏れ積分発火ニューロンが発火してもよい。少なくとも一実施例では、ニューロン2602は、入力を受信し、入力を積分して膜電位にし、膜電位を崩壊させる回路又は論理を使用して、実施されてもよい。少なくとも一実施例では、入力は平均化されてもよく、又は任意の他の好適な伝達関数が使用されてもよい。さらに、少なくとも一実施例では、ニューロン2602は、ニューロン2604に伝達関数を適用した結果が閾値を超えるとき、ニューロン出力2606において出力スパイクを生成するコンパレータ回路又は論理を、限定することなく含んでもよい。少なくとも一実施例では、ニューロン2602は発火すると、前に受信した入力情報を、たとえば膜電位を0又は他の好適なデフォルト値に再設定することによって、無視してもよい。少なくとも一実施例では、膜電位が0にリセットされると、ニューロン2602は、好適な期間(又は不応期)の後に通常の動作を再開してもよい。
【0330】
少なくとも一実施例では、ニューロン2602は、シナプス2608を通して相互接続されてもよい。少なくとも一実施例では、シナプス2608は、第1のニューロン2602の出力から第2のニューロン2602の入力に信号を送信するように動作してもよい。少なくとも一実施例では、ニューロン2602は、シナプス2608の2つ以上のインスタンスを介して情報を送信してもよい。少なくとも一実施例では、ニューロン出力2606の1つ又は複数のインスタンスは、シナプス2608のインスタンスを介して、同じニューロン2602のニューロン入力2604のインスタンスに接続されてもよい。少なくとも一実施例では、シナプス2608のインスタンスを介して送信されることになる出力を生成するニューロン2602のインスタンスは、シナプス2608のそのインスタンスに対して「シナプス前ニューロン」と呼ばれてもよい。少なくとも一実施例では、シナプス2608のインスタンスを介して送信されることになる入力を受信するニューロン2602のインスタンスは、シナプス2608のそのインスタンスに対して「シナプス後ニューロン」と呼ばれてもよい。少なくとも一実施例では、ニューロン2602のインスタンスは、シナプス2608の1つ又は複数のインスタンスから入力を受信してもよく、また、シナプス2608の1つ又は複数のインスタンスを介して出力を送信してもよいので、ニューロン2602の単一のインスタンスは、したがって、シナプス2608の様々なインスタンスに対して「シナプス前ニューロン」と「シナプス後ニューロン」の両方であってもよい。
【0331】
少なくとも一実施例では、ニューロン2602は、1つ又は複数の層に組織化されてもよい。少なくとも一実施例では、ニューロン2602の各インスタンスは、1つ又は複数のシナプス2608を通って1つ又は複数のニューロン入力2604にファン・アウトすることができる1つのニューロン出力2606を有してもよい。少なくとも一実施例では、第1の層2610のニューロン2602のニューロン出力2606は、第2の層2612のニューロン2602のニューロン入力2604に接続されてもよい。少なくとも一実施例では、層2610は、「フィード・フォワード」層と呼ばれてもよい。少なくとも一実施例では、第1の層2610のインスタンスにおけるニューロン2602の各インスタンスは、第2の層2612におけるニューロン2602の各インスタンスにファン・アウトしてもよい。少なくとも一実施例では、第1の層2610は、「完全に接続されたフィード・フォワード層」と呼ばれてもよい。少なくとも一実施例では、第2の層2612のインスタンスにおけるニューロン2602の各インスタンスは、第3の層2614におけるニューロン2602の全インスタンスより少ないインスタンスにファン・アウトしてもよい。少なくとも一実施例では、第2の層2612は、「疎に接続されたフィード・フォワード層」と呼ばれてもよい。少なくとも一実施例では、第2の層2612のニューロン2602は、同じく第2の層2612におけるニューロン2602を含め、複数の他の層のニューロン2602にファン・アウトしてもよい。少なくとも一実施例では、第2の層2612は、「回帰層」と呼ばれてもよい。少なくとも一実施例では、ニューロモーフィック・プロセッサ2600は、疎に接続されたフィード・フォワード層と完全に接続されたフィード・フォワード層の両方を限定することなく含む、回帰層とフィード・フォワード層の任意の好適な組合せを限定することなく含んでもよい。
【0332】
少なくとも一実施例では、ニューロモーフィック・プロセッサ2600は、シナプス2608をニューロン2602に接続するための再構成可能相互接続アーキテクチャ、又は専用ハード・-ワイヤード相互接続を、限定することなく含んでもよい。少なくとも一実施例では、ニューロモーフィック・プロセッサ2600は、ニューラル・ネットワーク・トポロジ、及びニューロンのファン・イン/ファン・アウトに基づき、必要に応じてシナプスを異なるニューロン2602に配分できるようにする回路又は論理を、限定することなく含んでもよい。たとえば、少なくとも一実施例では、シナプス2608は、ネットワーク・オン・チップなどの相互接続ファブリックを使用して、又は専用の接続を用いて、ニューロン2602に接続されてもよい。少なくとも一実施例では、シナプス相互接続及びその構成要素は、回路又は論理を使用して実施されてもよい。
【0333】
少なくとも一実施例では、
図26に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図26に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図26に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0334】
図27は、少なくとも一実施例による処理システムのブロック図である。少なくとも一実施例では、システム2700は、1つ又は複数のプロセッサ2702、及び1つ又は複数のグラフィックス・プロセッサ2708を含み、単一プロセッサのデスクトップ・システム、マルチプロセッサのワークステーション・システム、又は多数のプロセッサ2702若しくはプロセッサ・コア2707を有するサーバ・システムであってもよい。少なくとも一実施例では、システム2700は、モバイル・デバイス、携帯型デバイス、又は組み込みデバイスで使用するためのシステム・オン・チップ(SoC)集積回路内に組み込まれた処理プラットフォームである。
【0335】
少なくとも一実施例では、システム2700は、サーバ・ベースのゲーミング・プラットフォーム、ゲーム及びメディアのコンソールを含むゲーム・コンソール、モバイル・ゲーミング・コンソール、携帯型ゲーム・コンソール、若しくはオンライン・ゲーム・コンソールを含んでもよく、又はそれらに組み込まれてもよい。少なくとも一実施例では、システム2700は、モバイル・フォン、スマート・フォン、タブレット・コンピューティング・デバイス、又はモバイル・インターネット・デバイスである。少なくとも一実施例では、処理システム2700はまた、スマート・ウォッチ・ウェアラブル・デバイス、スマート・アイウェア・デバイス、拡張現実デバイス、若しくは仮想現実デバイスなどのウェアラブル・デバイスを含んでもよく、それらに結合されてもよく、又はそれらの中に一体化されてもよい。少なくとも一実施例では、処理システム2700は、1つ又は複数のプロセッサ2702と、1つ又は複数のグラフィックス・プロセッサ2708によって生成されるグラフィカル・インターフェースとを有するテレビ又はセット・トップ・ボックス・デバイスである。
【0336】
少なくとも一実施例では、1つ又は複数のプロセッサ2702はそれぞれ、実行されたときにシステム及びユーザ・ソフトウェアのための動作を実行する命令を処理するための1つ又は複数のプロセッサ・コア2707を含む。少なくとも一実施例では、1つ又は複数のプロセッサ・コア2707のそれぞれは、特定の命令シーケンス2709を処理するように構成される。少なくとも一実施例では、命令シーケンス2709は、複合命令セット・コンピューティング(CISC)、縮小命令セット・コンピューティング(RISC)、又は超長命令語(VLIW)を介したコンピューティングを容易にしてもよい。少なくとも一実施例では、プロセッサ・コア2707はそれぞれ、異なる命令シーケンス2709を処理してもよく、この命令セットは、他の命令シーケンスのエミュレーションを容易にする命令を含んでもよい。少なくとも一実施例では、プロセッサ・コア2707はまた、デジタル信号プロセッサ(DSP)などの他の処理デバイスを含んでもよい。
【0337】
少なくとも一実施例では、プロセッサ2702はキャッシュ・メモリ2704を含む。少なくとも一実施例では、プロセッサ2702は、単一の内部キャッシュ又は複数レベルの内部キャッシュを有してもよい。少なくとも一実施例では、キャッシュ・メモリは、プロセッサ2702の様々な構成要素間で共有される。少なくとも一実施例では、プロセッサ2702はまた、外部キャッシュ(たとえば、レベル3(L3)キャッシュ又はラスト・レベル・キャッシュ(LLC))(図示せず)を使用し、このキャッシュは、知られているキャッシュ・コヒーレンス技法を使用して、プロセッサ・コア2707間で共有されてもよい。少なくとも一実施例では、さらにレジスタ・ファイル2706がプロセッサ2702に含まれ、このレジスタ・ファイルは、異なるタイプのデータを記憶するための異なるタイプのレジスタ(たとえば、整数レジスタ、浮動小数点レジスタ、状態レジスタ、及び命令ポインタ・レジスタ)を含んでもよい。少なくとも一実施例では、レジスタ・ファイル2706は、汎用レジスタ又は他のレジスタを含んでもよい。
【0338】
少なくとも一実施例では、1つ又は複数のプロセッサ2702は、1つ又は複数のインターフェース・バス2710に結合されて、アドレス、データ、又は制御信号などの通信信号を、プロセッサ2702とシステム2700内の他の構成要素との間で送信する。少なくとも一実施例では、インターフェース・バス2710はダイレクト・メディア・インターフェース(DMI)バスのバージョンなどのプロセッサ・バスとすることができる。少なくとも一実施例では、インターフェース・バス2710は、DMIバスに限定されず、1つ又は複数のペリフェラル・コンポーネント・インターコネクト・バス(たとえば、PCI、PCIエクスプレス)、メモリ・バス、又は他のタイプのインターフェース・バスを含んでもよい。少なくとも一実施例では、プロセッサ2702は、統合メモリ・コントローラ2716、及びプラットフォーム・コントローラ・ハブ2730を含む。少なくとも一実施例では、メモリ・コントローラ2716は、メモリ・デバイスとシステム2700の他の構成要素との間の通信を容易にし、一方でプラットフォーム・コントローラ・ハブ(PCH)2730は、ローカルI/Oバスを介してI/Oデバイスへの接続を提供する。
【0339】
少なくとも一実施例では、メモリ・デバイス2720は、ダイナミック・ランダム・アクセス・メモリ(DRAM)デバイス、スタティック・ランダム・アクセス・メモリ(SRAM)デバイス、フラッシュ・メモリ・デバイス、相変化メモリ・デバイス、又はプロセス・メモリとしての役割を果たすのに好適な性能を有する何らかの他のメモリ・デバイスとすることができる。少なくとも一実施例では、メモリ・デバイス2720は、システム2700のためのシステム・メモリとして動作して、1つ又は複数のプロセッサ2702がアプリケーション若しくはプロセスを実行するときに使用するためのデータ2722及び命令2721を記憶することができる。少なくとも一実施例では、メモリ・コントローラ2716はまた、任意選択の外部グラフィックス・プロセッサ2712と結合しており、このグラフィックス・プロセッサは、プロセッサ2702内の1つ又は複数のグラフィックス・プロセッサ2708と通信して、グラフィックス及びメディアの動作を実行してもよい。少なくとも一実施例では、ディスプレイ・デバイス2711は、プロセッサ2702に接続することができる。少なくとも一実施例では、ディスプレイ・デバイス2711は、モバイル電子デバイス又はラップトップ・デバイスのような内部ディスプレイ・デバイス、又はディスプレイ・インターフェース(たとえば、ディスプレイ・ポートなど)を介して取り付けられる外部ディスプレイ・デバイスのうちの1つ又は複数を含むことができる。少なくとも一実施例では、ディスプレイ・デバイス2711は、仮想現実(VR)アプリケーション又は拡張現実(AR)アプリケーションで使用するための立体ディスプレイ・デバイスなどの頭部装着型ディスプレイ(HMD)を含むことができる。
【0340】
少なくとも一実施例では、プラットフォーム・コントローラ・ハブ2730は、周辺装置が高速I/Oバスを介してメモリ・デバイス2720及びプロセッサ2702に接続できるようにする。少なくとも一実施例では、I/O周辺装置は、オーディオ・コントローラ2746、ネットワーク・コントローラ2734、ファームウェア・インターフェース2728、ワイヤレス・トランシーバ2726、タッチ・センサ2725、データ・ストレージ・デバイス2724(たとえば、ハード・ディスク・ドライブ、フラッシュ・メモリなど)を含むが、これらに限定されない。少なくとも一実施例では、データ・ストレージ・デバイス2724は、ストレージ・インターフェース(たとえば、SATA)を介して、又はペリフェラル・コンポーネント・インターコネクト・バス(たとえば、PCI、PCIエクスプレス)などのペリフェラル・バスを介して、接続することができる。少なくとも一実施例では、タッチ・センサ2725は、タッチ画面センサ、圧力センサ、又は指紋センサを含むことができる。少なくとも一実施例では、ワイヤレス・トランシーバ2726は、WiFiトランシーバ、Bluetoothトランシーバ、又は3G、4G、若しくはLong Term Evolution(LTE)トランシーバなどのモバイル・ネットワーク・トランシーバとすることができる。少なくとも一実施例では、ファームウェア・インターフェース2728は、システム・ファームウェアとの通信を可能にし、たとえば、ユニファイド・エクステンシブル・ファームウェア・インターフェース(UEFI)とすることができる。少なくとも一実施例では、ネットワーク・コントローラ2734は、有線ネットワークへのネットワーク接続を可能にすることができる。少なくとも一実施例では、高性能ネットワーク・コントローラ(図示せず)は、インターフェース・バス2710と結合する。少なくとも一実施例では、オーディオ・コントローラ2746は、多チャネル・ハイ・デフィニション・オーディオ・コントローラである。少なくとも一実施例では、システム2700は、レガシー(たとえば、パーソナル・システム2(PS/2))デバイスをシステム2700に結合するための任意選択のレガシーI/Oコントローラ2740を含む。少なくとも一実施例では、プラットフォーム・コントローラ・ハブ2730は、キーボードとマウス2743の組合せ、カメラ2744、又は他のUSB入力デバイスなど、1つ又は複数のユニバーサル・シリアル・バス(USB)コントローラ2742の接続入力デバイスにも接続することができる。
【0341】
少なくとも一実施例では、メモリ・コントローラ2716及びプラットフォーム・コントローラ・ハブ2730のインスタンスは、外部グラフィックス・プロセッサ2712などの個別の外部グラフィックス・プロセッサに一体化されてもよい。少なくとも一実施例では、プラットフォーム・コントローラ・ハブ2730及び/又はメモリ・コントローラ2716は、1つ又は複数のプロセッサ2702の外部にあってもよい。たとえば、少なくとも一実施例では、システム2700は、外部のメモリ・コントローラ2716及びプラットフォーム・コントローラ・ハブ2730を含むことができ、これらは、プロセッサ2702と通信するシステム・チップセット内のメモリ・コントローラ・ハブ及び周辺装置コントローラ・ハブとして構成されてもよい。
【0342】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815の一部又はすべてが、グラフィックス・プロセッサ2708に組み込まれてもよい。たとえば、少なくとも一実施例では、本明細書に記載の訓練及び/又は推論の技法は、3Dパイプラインに具体化されたALUのうちの1つ又は複数を使用してもよい。さらに、少なくとも一実施例では、本明細書に記載の推論及び/又は訓練の動作は、
図8A又は
図8Bに示す論理以外の論理を使用して行われてもよい。少なくとも一実施例では、重みパラメータは、本明細書に記載の1つ又は複数の機械学習アルゴリズム、ニューラル・ネットワーク・アーキテクチャ、ユース・ケース、又は訓練技法を実行するためのグラフィックス・プロセッサ2708のALUを構成するオン・チップ若しくはオフ・チップのメモリ及び/又はレジスタ(図示している又は図示せず)に記憶されてもよい。
【0343】
少なくとも一実施例では、
図27に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図27に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図27に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0344】
図28は、少なくとも一実施例による、1つ又は複数のプロセッサ・コア2802A~2802N、統合メモリ・コントローラ2814、及び統合グラフィックス・プロセッサ2808を有するプロセッサ2800のブロック図である。少なくとも一実施例では、プロセッサ2800は、破線の四角によって表される追加コア2802Nを含むそれ以下の数の追加コアを含むことができる。少なくとも一実施例では、プロセッサ・コア2802A~2802Nの各々は、1つ又は複数の内部キャッシュ・ユニット2804A~2804Nを含む。少なくとも一実施例では、各プロセッサ・コアはまた、1つ又は複数の共有キャッシュ・ユニット2806にアクセスできる。
【0345】
少なくとも一実施例では、内部キャッシュ・ユニット2804A~2804N、及び共有キャッシュ・ユニット2806は、プロセッサ2800内のキャッシュ・メモリ階層を表す。少なくとも一実施例では、キャッシュ・メモリ・ユニット2804A~2804Nは、各プロセッサ・コア内の命令及びデータのキャッシュの少なくとも1つのレベル、並びにレベル2(L2)、レベル3(L3)、レベル4(L4)などの共有中間レベル・キャッシュの1つ又は複数のレベル、又はキャッシュの他のレベルを含んでもよく、ここで外部メモリの前の最高レベルのキャッシュは、LLCとして分類される。少なくとも一実施例では、キャッシュ・コヒーレンス論理は、様々なキャッシュ・ユニット2806及び2804A~2804N間でコヒーレンスを維持する。
【0346】
少なくとも一実施例では、プロセッサ2800はまた、1つ又は複数のバス・コントローラ・ユニット2816とシステム・エージェント・コア2810のセットを含んでもよい。少なくとも一実施例では、バス・コントローラ・ユニット2816は、1つ又は複数のPCI若しくはPCIエクスプレス・バスなどのペリフェラル・バスのセットを管理する。少なくとも一実施例では、システム・エージェント・コア2810は、様々なプロセッサ構成要素のための管理機能を提供する。少なくとも一実施例では、システム・エージェント・コア2810は、様々な外部メモリ・デバイス(図示せず)へのアクセスを管理するための1つ又は複数の統合メモリ・コントローラ2814を含む。
【0347】
少なくとも一実施例では、プロセッサ・コア2802A~2802Nの1つ又は複数は、同時マルチスレッディングのサポートを含む。少なくとも一実施例では、システム・エージェント・コア2810は、マルチスレッドの処理中にコア2802A~2802Nを調整し動作させるための構成要素を含む。少なくとも一実施例では、システム・エージェント・コア2810はさらに、電力制御ユニット(PCU)を含んでもよく、このユニットは、プロセッサ・コア2802A~2802N及びグラフィックス・プロセッサ2808の1つ又は複数の電力状態を調整するための論理及び構成要素を含む。
【0348】
少なくとも一実施例では、プロセッサ2800はさらに、グラフィックス処理動作を実行するためのグラフィックス・プロセッサ2808を含む。少なくとも一実施例では、グラフィックス・プロセッサ2808は、共有キャッシュ・ユニット2806と、1つ又は複数の統合メモリ・コントローラ2814を含むシステム・エージェント・コア2810とに結合される。少なくとも一実施例では、システム・エージェント・コア2810はまた、1つ又は複数の結合されたディスプレイに向けてグラフィックス・プロセッサの出力を出させるためのディスプレイ・コントローラ2811を含む。少なくとも一実施例では、ディスプレイ・コントローラ2811はまた、少なくとも1つの相互接続を介してグラフィックス・プロセッサ2808に結合された別個のモジュールであってもよく、又はグラフィックス・プロセッサ2808内に一体化されていてもよい。
【0349】
少なくとも一実施例では、プロセッサ2800の内部構成要素を結合するために、リング・-ベースの相互接続ユニット2812が使用される。少なくとも一実施例では、ポイントツーポイント相互接続、スイッチ相互接続、又は他の技法などの代替的な相互接続ユニットが使用されてもよい。少なくとも一実施例では、グラフィックス・プロセッサ2808は、I/Oリンク2813を介してリング相互接続2812と結合される。
【0350】
少なくとも一実施例では、I/Oリンク2813は、様々なプロセッサ構成要素と、eDRAMモジュールなどの高性能組み込みメモリ・モジュール2818との間の通信を容易にするオン・パッケージI/O相互接続を含む多様なI/O相互接続のうちの少なくとも1つを表す。少なくとも一実施例では、プロセッサ・コア2802A~2802Nのそれぞれ及びグラフィックス・プロセッサ2808は、共有ラスト・レベル・キャッシュとして組み込みメモリ・モジュール2818を使用する。
【0351】
少なくとも一実施例では、プロセッサ・コア2802A~2802Nは、共通の命令セット・アーキテクチャを実行する同種のコアである。少なくとも一実施例では、プロセッサ・コア2802A~2802Nは、命令セット・アーキテクチャ(ISA)の観点から見れば異種であり、ここでプロセッサ・コア2802A~2802Nのうちの1つ又は複数は、共通の命令セットを実行するが、プロセッサ・コア2802A~2802Nのうちの1つ又は複数の他のコアは、共通の命令セットのサブセット、又は異なる命令セットを実行する。少なくとも一実施例では、プロセッサ・コア2802A~2802Nは、マイクロ・アーキテクチャの観点から見れば異種であり、ここで電力消費量が相対的に高い1つ又は複数のコアは、電力消費量がより低い1つ又は複数のコアと結合する。少なくとも一実施例では、プロセッサ2800は、1つ若しくは複数のチップ上に実施することができ、又はSoC集積回路として実施することができる。
【0352】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815の一部又はすべてが、グラフィックス・プロセッサ2808に組み込まれてもよい。たとえば、少なくとも一実施例では、本明細書に記載の訓練及び/又は推論の技法は、3Dパイプライン、グラフィックス・コア2802、共有機能論理、又は
図28の他の論理に具体化されたALUのうちの1つ又は複数を使用してもよい。さらに、少なくとも一実施例では、本明細書に記載の推論及び/又は訓練の動作は、
図8A又は
図8Bに示す論理以外の論理を使用して行われてもよい。少なくとも一実施例では、重みパラメータは、本明細書に記載の1つ又は複数の機械学習アルゴリズム、ニューラル・ネットワーク・アーキテクチャ、ユース・ケース、又は訓練技法を実行するためのプロセッサ2800のALUを構成するオン・チップ若しくはオフ・チップのメモリ及び/又はレジスタ(図示している又は図示せず)に記憶されてもよい。
【0353】
少なくとも一実施例では、
図28に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図28に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図28に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0354】
図29は、グラフィックス・プロセッサ2900のブロック図であり、これは、個別グラフィックス・プロセッシング・ユニットであってもよく、又は複数の処理コアと統合されたグラフィックス・プロセッサであってもよい。少なくとも一実施例では、グラフィックス・プロセッサ2900は、メモリにマッピングされたI/Oインターフェースを介して、メモリに入れられたコマンドを用いて、グラフィックス・プロセッサ2900のレジスタと通信する。少なくとも一実施例では、グラフィックス・プロセッサ2900は、メモリにアクセスするためのメモリ・インターフェース2914を含む。少なくとも一実施例では、メモリ・インターフェース2914は、ローカル・メモリ、1つ若しくは複数の内部キャッシュ、1つ若しくは複数の共有外部キャッシュ、及び/又はシステム・メモリへのインターフェースである。
【0355】
少なくとも一実施例では、グラフィックス・プロセッサ2900はまた、ディスプレイ出力データをディスプレイ・デバイス2920に向けて駆動するためのディスプレイ・コントローラ2902も含む。少なくとも一実施例では、ディスプレイ・コントローラ2902は、ディスプレイ・デバイス2920用の1つ又は複数の重なり平面、及び多層のビデオ若しくはユーザ・インターフェース要素の合成のためのハードウェアを含む。少なくとも一実施例では、ディスプレイ・デバイス2920は、内部又は外部のディスプレイ・デバイスとすることができる。少なくとも一実施例では、ディスプレイ・デバイス2920は、仮想現実(VR)ディスプレイ・デバイス又は拡張現実(AR)ディスプレイ・デバイスなどの頭部装着型ディスプレイ・デバイスである。少なくとも一実施例では、グラフィックス・プロセッサ2900は、MPEG-2などの動画エキスパート・グループ(MPEG)フォーマット、H.264/MPEG-4AVCなどのアドバンスト・ビデオ・コーディング(AVC)フォーマット、並びに映画テレビ技術者協会(SMPTE)421M/VC-1、及びJPEGなどのジョイント・フォトグラフィック・エキスパート・グループ(JPEG)フォーマット、及びモーションJPEG(MJPEG)フォーマットを含むがこれらに限定されない1つ又は複数のメディア符号化フォーマットに、それらのフォーマットから、又はそれらのフォーマット間で、メディアをエンコード、デコード、又はコード変換するためのビデオ・コーデック・エンジン2906を含む。
【0356】
少なくとも一実施例では、グラフィックス・プロセッサ2900は、たとえばビット境界ブロック転送を含む2次元(2D)ラスタライザ動作を実行するためのブロック画像転送(BLIT)エンジン2904を含む。しかし、少なくとも一実施例では、2Dグラフィックス動作は、グラフィックス処理エンジン(GPE)2910の1つ又は複数の構成要素を使用して実行される。少なくとも一実施例では、GPE2910は、3次元(3D)グラフィックス動作及びメディア動作を含むグラフィックス動作を実行するためのコンピュート・エンジンである。
【0357】
少なくとも一実施例では、GPE2910は、3Dのプリミティブ形状(たとえば、矩形、三角形など)に作用する処理関数を使用して、3次元画像及びシーンをレンダリングするなど、3D動作を実行するための3Dパイプライン2912を含む。少なくとも一実施例では、3Dパイプライン2912は、プログラム可能で固定された関数要素を含み、これは、3D/メディア・サブシステム2915に対して様々なタスクを実行し、且つ/又は実行スレッドをスポーンする。3Dパイプライン2912を使用してメディア動作を実行できるが、少なくとも一実施例では、GPE2910は、ビデオの後処理及び画像強調などのメディア動作を実行するために使用されるメディア・パイプライン2916も含む。
【0358】
少なくとも一実施例では、メディア・パイプライン2916は、ビデオ・コーデック・エンジン2906の代わりに、又はそれを代表して、ビデオ・デコード加速、ビデオ・インターレース解除、及びエンコード加速などの1つ又は複数の特別なメディア動作を実行するための固定機能又はプログラム可能論理ユニットを含む。少なくとも一実施例では、メディア・パイプライン2916は、3D/メディア・サブシステム2915で実行するためのスレッドをスポーンするためのスレッド・スポーニング・ユニットをさらに含む。少なくとも一実施例では、スポーンされたスレッドは、3D/メディア・サブシステム2915に含まれた1つ又は複数のグラフィックス実行ユニット上で、メディア動作のための計算を実行する。
【0359】
少なくとも一実施例では、3D/メディア・サブシステム2915は、3Dパイプライン2912及びメディア・パイプライン2916によってスポーンされたスレッドを実行するための論理を含む。少なくとも一実施例では、3Dパイプライン2912及びメディア・パイプライン2916は、スレッド実行要求を3D/メディア・サブシステム2915に送信し、この3D/メディア・サブシステム2915は、様々な要求を調停し、利用可能なスレッド実行リソースにディスパッチするためのスレッド・ディスパッチ論理を含む。少なくとも一実施例では、実行リソースは、3D及びメディア・スレッドを処理するためのグラフィックス実行ユニットのアレイを含む。少なくとも一実施例では、3D/メディア・サブシステム2915は、スレッド命令及びデータのための1つ又は複数の内部キャッシュを含む。少なくとも一実施例では、サブシステム2915はまた、スレッド間でデータを共有し、出力データを記憶するための、レジスタ及びアドレス可能メモリを含む共有メモリも含む。
【0360】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815の一部又はすべてが、グラフィックス・プロセッサ2900に組み込まれてもよい。たとえば、少なくとも一実施例では、本明細書に記載の訓練及び/又は推論の技法は、3Dパイプライン2912に具体化されたALUのうちの1つ又は複数を使用してもよい。さらに、少なくとも一実施例では、本明細書に記載の推論及び/又は訓練の動作は、
図8A又は
図8Bに示す論理以外の論理を使用して行われてもよい。少なくとも一実施例では、重みパラメータは、本明細書に記載の1つ又は複数の機械学習アルゴリズム、ニューラル・ネットワーク・アーキテクチャ、ユース・ケース、又は訓練技法を実行するためのグラフィックス・プロセッサ2900のALUを構成するオン・チップ若しくはオフ・チップのメモリ及び/又はレジスタ(図示している又は図示せず)に記憶されてもよい。
【0361】
少なくとも一実施例では、
図29に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図29に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図29に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0362】
図30は、少なくとも一実施例によるグラフィックス・プロセッサのグラフィックス処理エンジン3010のブロック図である。少なくとも一実施例では、グラフィックス処理エンジン(GPE)3010は、
図29に示すGPE2910の1つのバージョンである。少なくとも一実施例では、メディア・パイプライン3016は任意選択であり、GPE3010内に明示的に含まれなくてもよい。少なくとも一実施例では、別個のメディア及び/又は画像のプロセッサが、GPE3010に結合される。
【0363】
少なくとも一実施例では、GPE3010は、コマンド・ストリーマ3003に結合され、又はそれを含み、このコマンド・ストリーマは、3Dパイプライン3012及び/又はメディア・パイプライン3016にコマンド・ストリームを提供する。少なくとも一実施例では、コマンド・ストリーマ3003はメモリに結合され、このメモリは、システム・メモリであってもよく、又は内部キャッシュ・メモリ及び共有キャッシュ・メモリのうちの1つ若しくは複数であってもよい。少なくとも一実施例では、コマンド・ストリーマ3003は、メモリからコマンドを受信し、3Dパイプライン3012及び/又はメディア・パイプライン3016にコマンドを送信する。少なくとも一実施例では、コマンドは、リング・バッファからフェッチされる命令、プリミティブ、又はマイクロ・オペレーションであり、このリング・バッファは、3Dパイプライン3012及びメディア・パイプライン3016のためのコマンドを記憶する。少なくとも一実施例では、リング・バッファはさらに、複数のコマンドのバッチを記憶するバッチ・コマンド・バッファを含むことができる。少なくとも一実施例では、3Dパイプライン3012用のコマンドはまた、3Dパイプライン3012用の頂点及び形状のデータ、並びに/又はメディア・パイプライン3016用の画像データ及びメモリ・オブジェクトなどであるがこれらに限定されないメモリに記憶されたデータへの参照も含むことができる。少なくとも一実施例では、3Dパイプライン3012及びメディア・パイプライン3016は、演算を実行することにより、又は1つ若しくは複数の実行スレッドをグラフィックス・コア・アレイ3014にディスパッチすることにより、コマンド及びデータを処理する。少なくとも一実施例では、グラフィックス・コア・アレイ3014は、グラフィックス・コア(たとえば、グラフィックス・コア3015A、グラフィックス・コア3015B)の1つ又は複数のブロックを含み、各ブロックは、1つ又は複数のグラフィックス・コアを含む。少なくとも一実施例では、各グラフィックス・コアは、グラフィックス及びコンピュートの動作を実行するための汎用及びグラフィックス専用の実行論理、並びに、
図8A及び
図8Bの推論及び/又は訓練論理815を含め、固定機能のテクスチャ処理及び/又は機械学習、及び人工知能の加速論理を含むグラフィックス実行リソースのセットを含む。
【0364】
少なくとも一実施例では、3Dパイプライン3012は、命令を処理し、実行スレッドをグラフィックス・コア・アレイ3014にディスパッチすることにより、頂点シェーダ、ジオメトリ・シェーダ、ピクセル・シェーダ、フラグメント・シェーダ、コンピュート・シェーダ、又は他のシェーダ・プログラムなどの1つ又は複数のシェーダ・プログラムを処理するための固定機能及びプログラム可能論理を含む。少なくとも一実施例では、グラフィックス・コア・アレイ3014は、シェーダ・プログラムを処理する際に使用するための実行リソースの統合ブロックを提供する。少なくとも一実施例では、グラフィック・コア・アレイ3014のグラフィックス・コア3015A~3015B内の多目的の実行論理(たとえば、実行ユニット)は、様々な3DのAPIシェーダ言語のサポートを含み、複数のシェーダに関連付けられた複数の同時実行スレッドを実行することができる。
【0365】
少なくとも一実施例では、グラフィックス・コア・アレイ3014はまた、ビデオ及び/又は画像の処理など、メディア機能を実行するための実行論理も含む。少なくとも一実施例では、実行ユニットはさらに、グラフィックス処理動作に加えて並列の汎用計算動作を実行するようにプログラム可能な汎用論理を含む。
【0366】
少なくとも一実施例では、グラフィックス・コア・アレイ3014上で実行しているスレッドにより生成される出力データは、統合リターン・バッファ(URB)3018のメモリにデータを出力することができる。少なくとも一実施例では、URB3018は、複数のスレッド用のデータを記憶することができる。少なくとも一実施例では、グラフィックス・コア・アレイ3014上で実行している異なるスレッド間でデータを送信するために、URB3018を使用してもよい。少なくとも一実施例では、グラフィックス・コア・アレイ3014上のスレッドと、共有機能論理3020内の固定機能論理との間の同期のために、URB3018がさらに使用されてもよい。
【0367】
少なくとも一実施例では、グラフィックス・コア・アレイ3014はスケーラブルであり、それにより、グラフィックス・コア・アレイ3014は、可変数のグラフィックス・コアを含み、それぞれのグラフィックス・コアが、GPE3010の目的とする電力及び性能のレベルに基づき可変数の実行ユニットを有する。少なくとも一実施例では、実行リソースは動的にスケーラブルであり、それにより実行リソースは、必要に応じて有効化又は無効化されてもよい。
【0368】
少なくとも一実施例では、グラフィックス・コア・アレイ3014は、グラフィックス・コア・アレイ3014のグラフィックス・コア間で共有される複数のリソースを含む共有機能論理3020に結合される。少なくとも一実施例では、共有機能論理3020によって実行される共有機能は、専用の補足機能をグラフィックス・コア・アレイ3014に提供するハードウェア論理ユニットに具体化される。少なくとも一実施例では、共有機能論理3020は、サンプラ・ユニット3021、数理ユニット3022、及びスレッド間通信(ITC)論理3023の論理を含むが、これらに限定されない。少なくとも一実施例では、1つ又は複数のキャッシュ3025が、共有機能論理3020に含まれ、又はそれに結合される。
【0369】
少なくとも一実施例では、専用機能の需要が不十分でグラフィックス・コア・アレイ3014内に含められない場合に、共有機能が使用される。少なくとも一実施例では、専用機能を1つにインスタンス化したものが、共有機能論理3020において使用され、グラフィックス・コア・アレイ3014内の他の実行リソース間で共有される。少なくとも一実施例では、共有機能論理3020内の、グラフィックス・コア・アレイ3014によってのみ使用される特定の共有機能は、グラフィックス・コア・アレイ3014内の共有機能論理3026内に含まれてもよい。少なくとも一実施例では、グラフィックス・コア・アレイ3014内の共有機能論理3026は、共有機能論理3020内の一部又はすべての論理を含むことができる。少なくとも一実施例では、共有機能論理3020内のすべての論理要素は、グラフィックス・コア・アレイ3014の共有機能論理3026内で複製されてもよい。少なくとも一実施例では、共有機能論理3020は、グラフィックス・コア・アレイ3014内の共有機能論理3026に有利なように除外される。
【0370】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815の一部又はすべてが、グラフィックス・プロセッサ3010に組み込まれてもよい。たとえば、少なくとも一実施例では、本明細書に記載の訓練及び/又は推論の技法は、3Dパイプライン3012、グラフィックス・コア3015、共有機能論理3026、共有機能論理3020、又は
図30の他の論理に具体化されたALUのうちの1つ又は複数を使用してもよい。さらに、少なくとも一実施例では、本明細書に記載の推論及び/又は訓練の動作は、
図9A又は
図9Bに示す論理以外の論理を使用して行われてもよい。少なくとも一実施例では、重みパラメータは、本明細書に記載の1つ又は複数の機械学習アルゴリズム、ニューラル・ネットワーク・アーキテクチャ、ユース・ケース、又は訓練技法を実行するためのグラフィックス・プロセッサ3010のALUを構成するオン・チップ若しくはオフ・チップのメモリ及び/又はレジスタ(図示している又は図示せず)に記憶されてもよい。
【0371】
少なくとも一実施例では、
図30に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図30に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図30に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0372】
図31は、本明細書に記載の少なくとも一実施例によるグラフィックス・プロセッサ・コア3100のハードウェア論理のブロック図である。少なくとも一実施例では、グラフィックス・プロセッサ・コア3100は、グラフィックス・コア・アレイ内に含まれる。少なくとも一実施例では、コア・スライスと呼ばれることもあるグラフィックス・プロセッサ・コア3100は、モジュール式グラフィックス・プロセッサ内の1つ又は複数のグラフィックス・コアとすることができる。少なくとも一実施例では、グラフィックス・プロセッサ・コア3100は、1つのグラフィックス・コア・スライスの例示であり、本明細書に記載のグラフィックス・プロセッサは、目的の電力及び性能のエンベロープに基づき、複数のグラフィックス・コア・スライスを含んでもよい。少なくとも一実施例では、各グラフィックス・コア3100は、汎用及び固定の機能論理のモジュール式ブロックを含むサブ・スライスとも呼ばれる複数のサブ・コア3101A~3101Fに結合された固定機能ブロック3130を含むことができる。
【0373】
少なくとも一実施例では、固定機能ブロック3130は、たとえば低性能及び/又は低電力のグラフィックス・プロセッサ実施形態において、グラフィックス・プロセッサ3100内のすべてのサブ・コアが共有できるジオメトリ及び固定機能パイプライン3136を含む。少なくとも一実施例では、ジオメトリ及び固定機能パイプライン3136は、3D固定機能パイプライン、ビデオ・フロント・エンド・ユニット、スレッド・スポーナ(spawner)及びスレッド・ディスパッチャ、並びに統合リターン・バッファを管理する統合リターン・バッファ・マネージャを含む。
【0374】
少なくとも一実施例では、固定機能ブロック3130はまた、グラフィックスSoCインターフェース3137、グラフィックス・マイクロコントローラ3138、及びメディア・パイプライン3139を含む。少なくとも一実施例では、グラフィックスSoCインターフェース3137は、グラフィックス・コア3100と、システム・オン・チップ集積回路内の他のプロセッサ・コアとのインターフェースを提供する。少なくとも一実施例では、グラフィックス・マイクロコントローラ3138は、スレッド・ディスパッチ、スケジューリング、及びプリエンプションを含め、グラフィックス・プロセッサ3100の様々な機能を管理するように構成可能なプログラム可能サブ・プロセッサである。少なくとも一実施例では、メディア・パイプライン3139は、画像及びビデオのデータを含むマルチメディア・データのデコーディング、エンコーディング、前処理、及び/又は後処理を容易にする論理を含む。少なくとも一実施例では、メディア・パイプライン3139は、サブ・コア3101~3101F内のコンピュート論理又はサンプリング論理への要求を介して、メディア動作を実施する。
【0375】
少なくとも一実施例では、SoCインターフェース3137は、汎用アプリケーション・プロセッサ・コア(たとえば、CPU)、及び/又はSoC内の他の構成要素と、グラフィックス・コア3100が通信できるようにし、SoC内の他の構成要素には、共有ラスト・レベル・キャッシュ・メモリ、システムRAM、及び/又は組み込みオン・チップ若しくはオン・パッケージのDRAMなどのメモリ階層要素が含まれる。少なくとも一実施例では、SoCインターフェース3137はまた、カメラ・イメージング・パイプラインなど、SoC内の固定機能デバイスとの通信を可能にし、グラフィックス・コア3100とSoC内のCPUとの間で共有することができるグローバル・メモリ・アトミックの使用を可能にし、且つ/又はそれを実施する。少なくとも一実施例では、グラフィックスSoCインターフェース3137はまた、グラフィックス・プロセッサ・コア3100の電力管理制御を実施することができ、グラフィックス・プロセッサ・コア3100のクロック・ドメインと、SoC内の他のクロック・ドメインとの間でインターフェースをとれるようにする。少なくとも一実施例では、SoCインターフェース3137は、グラフィックス・プロセッサ内の1つ又は複数のグラフィックス・コアのそれぞれにコマンド及び命令を提供するように構成されたコマンド・ストリーマ及びグローバル・スレッド・ディスパッチャから、コマンド・バッファを受信できるようにする。少なくとも一実施例では、コマンド及び命令は、メディア動作が実行されるときにはメディア・パイプライン3139にディスパッチされることが可能であり、又はグラフィックス処理動作が実行されるときには、ジオメトリ及び固定機能パイプライン(たとえば、ジオメトリ及び固定機能パイプライン3136、並びに/又はジオメトリ及び固定機能パイプライン3114)にディスパッチされることが可能である。
【0376】
少なくとも一実施例では、グラフィックス・マイクロコントローラ3138は、グラフィックス・コア3100のための様々なスケジューリング及び管理タスクを実行するように構成されることが可能である。少なくとも一実施例では、グラフィックス・マイクロコントローラ3138は、サブ・コア3101A~3101F内の実行ユニット(EU:execution unit)アレイ3102A~3102F、3104A~3104F内の様々なグラフィックス並列エンジンで、グラフィックスを実行し、且つ/又はワークロードのスケジューリングをコンピュートすることができる。少なくとも一実施例では、グラフィックス・コア3100を含むSoCのCPUコア上で実行されているホスト・ソフトウェアは、複数のグラフィックス・プロセッサ経路のうちの1つにワークロードを送出することができ、この経路が、適切なグラフィックス・エンジンに対するスケジューリング動作を呼び出す。少なくとも一実施例では、スケジューリング動作は、どのワークロードを次に実行すべきかを判定すること、コマンド・ストリーマにワークロードを送出すること、エンジン上で実行されている既存のワークロードをプリエンプションすること、ワークロードの進行を管理すること、及びワークロードが完了したときにホスト・ソフトウェアに通知することを含む。少なくとも一実施例では、グラフィックス・マイクロコントローラ3138はまた、グラフィックス・コア3100の低電力又はアイドル状態を促進して、オペレーティング・システム及び/又はシステム上のグラフィックス・ドライバ・ソフトウェアとは無関係に、低電力状態の移行全体にわたってグラフィックス・コア3100内のレジスタを保存及び復元する機能をグラフィックス・コア3100に提供することができる。
【0377】
少なくとも一実施例では、グラフィックス・コア3100は、図示してあるサブ・コア3101A~3101Fより多くの、又はそれより少ない、N個までのモジュール式サブ・コアを有してもよい。N個のサブ・コアのセットごとに、少なくとも一実施例では、グラフィックス・コア3100はまた、共有機能論理3110、共有及び/又はキャッシュ・メモリ3112、ジオメトリ/固定機能パイプライン3114、並びに様々なグラフィックスを加速し、処理動作をコンピュートするための追加の固定機能論理3116を含むことができる。少なくとも一実施例では、共有機能論理3110は、グラフィックス・コア3100内の各N個のサブ・コアが共有できる論理ユニット(たとえば、サンプラ、数理、及び/又はスレッド間通信の論理)を含むことができる。少なくとも一実施例では、共有の、及び/又はキャッシュのメモリ3112は、グラフィックス・コア3100内のN個のサブ・コア3101A~3101Fのためのラスト・レベル・キャッシュとすることができ、また、複数のサブ・コアがアクセスできる共有メモリとしての役割も果たすことができる。少なくとも一実施例では、ジオメトリ/固定機能パイプライン3114は、固定機能ブロック3130内のジオメトリ/固定機能パイプライン3136の代わりに含まれてもよく、同様の論理ユニットを含むことができる。
【0378】
少なくとも一実施例では、グラフィックス・コア3100は、グラフィックス・コア3100が使用するための様々な固定機能加速論理を含むことができる追加の固定機能論理3116を含む。少なくとも一実施例では、追加の固定機能論理3116は、位置限定シェーディング(position only shading)に使用するための追加のジオメトリ・パイプラインを含む。位置限定シェーディングでは、少なくとも2つのジオメトリ・パイプラインが存在しているが、ジオメトリ及び固定機能パイプライン3114、3136内の完全ジオメトリ・パイプラインと選別パイプライン(cull pipeline)においてであり、この選別パイプラインは、追加の固定機能論理3116内に含まれてもよい追加のジオメトリ・パイプラインである。少なくとも一実施例では、選別パイプラインは、完全ジオメトリ・パイプラインの縮小版である。少なくとも一実施例では、完全パイプライン及び選別パイプラインは、アプリケーションの異なるインスタンスを実行することができ、各インスタンスは別個のコンテキストを有する。少なくとも一実施例では、位置限定シェーディングは、切り捨てられた三角形の長い選別ランを隠すことができ、いくつかのインスタンスにおいてシェーディングを早く完了させることができる。たとえば、少なくとも一実施例では、選別パイプラインは、ピクセルをフレーム・バッファにラスタ化及びレンダリングすることなく、頂点の位置属性をフェッチしシェーディングするので、追加の固定機能論理3116内の選別パイプライン論理は、メイン・アプリケーションと並列で位置シェーダを実行することができ、完全パイプラインよりも全体的に早く臨界結果(critical result)を生成する。少なくとも一実施例では、選別パイプラインは、生成された臨界結果を使用して、すべての三角形について、これらの三角形が選別されているかどうかに関わらず、可視性情報をコンピュートすることができる。少なくとも一実施例では、(このインスタンスではリプレイ・パイプラインと呼ばれてもよい)完全パイプラインは、可視性情報を消費して、選別された三角形を飛ばして可視三角形だけをシェーディングすることができ、この可視性三角形が、最終的にラスタ化フェーズに渡される。
【0379】
少なくとも一実施例では、追加の固定機能論理3116はまた、機械学習の訓練又は推論の最適化を含む実施形態のために、固定機能の行列乗算論理など、機械学習の加速論理を含むことができる。
【0380】
少なくとも一実施例では、各グラフィックス・サブ・コア3101A~3101F内において、実行リソースのセットを含み、このセットは、グラフィックス・パイプライン、メディア・パイプライン、又はシェーダ・プログラムからの要求に応答して、グラフィックス動作、メディア動作、及びコンピュート動作を実行するために使用されてもよい。少なくとも一実施例では、グラフィックス・サブ・コア3101A~3101Fは、複数のEUアレイ3102A~3102F、3104A~3104F、スレッド・ディスパッチ及びスレッド間通信(TD/IC:thread dispatch and inter-thread communication)論理3103A~3103F、3D(たとえば、テクスチャ)サンプラ3105A~3105F、メディア・サンプラ3106A~3106F、シェーダ・プロセッサ3107A~3107F、及び共有ローカル・メモリ(SLM:shared local memory)3108A~3108Fを含む。少なくとも一実施例では、EUアレイ3102A~3102F、3104A~3104Fはそれぞれ、複数の実行ユニットを含み、これらは、グラフィックス、メディア、又はコンピュート・シェーダ・プログラムを含むグラフィックス動作、メディア動作、又はコンピュート動作のサービスにおいて浮動小数点及び整数/固定小数点の論理演算を実行することができる汎用グラフィックス・プロセッシング・ユニットである。少なくとも一実施例では、TD/IC論理3103A~3103Fは、サブ・コア内の実行ユニットのためのローカル・スレッド・ディスパッチ及びスレッド制御動作を実行し、サブ・コアの実行ユニット上で実行されているスレッド間の通信を容易にする。少なくとも一実施例では、3Dサンプラ3105A~3105Fは、テクスチャ又は他の3Dグラフィックス関連のデータをメモリに読み取ることができる。少なくとも一実施例では、3Dサンプラは、所与のテクスチャに関連付けられた構成済みサンプル状態及びテクスチャ・フォーマットに基づき、テクスチャ・データを異なるやり方で読み取ることができる。少なくとも一実施例では、メディア・サンプラ3106A~3106Fは、メディア・データに関連付けられたタイプ及びフォーマットに基づき、同様の読取り動作を実行することができる。少なくとも一実施例では、各グラフィックス・サブ・コア3101A~3101Fは、代替的に3Dとメディアの統合サンプラを含むことができる。少なくとも一実施例では、各サブ・コア3101A~3101F内の実行ユニット上で実行しているスレッドは、スレッド・グループ内で実行しているスレッドが、オン・チップ・メモリの共通プールを使用して実行できるようにするために、各サブ・コア内の共有ローカル・メモリ3108A~3108Fを利用することができる。
【0381】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815の一部又はすべてが、グラフィックス・プロセッサ3100に組み込まれてもよい。たとえば、少なくとも一実施例では、本明細書に記載の訓練及び/又は推論の技法は、3Dパイプライン、グラフィックス・マイクロコントローラ3138、ジオメトリ及び固定機能パイプライン3114及び3136、又は
図31の他の論理に具体化されたALUのうちの1つ又は複数を使用してもよい。さらに、少なくとも一実施例では、本明細書に記載の推論及び/又は訓練の動作は、
図8A又は
図8Bに示す論理以外の論理を使用して行われてもよい。少なくとも一実施例では、重みパラメータは、本明細書に記載の1つ又は複数の機械学習アルゴリズム、ニューラル・ネットワーク・アーキテクチャ、ユース・ケース、又は訓練技法を実行するためのグラフィックス・プロセッサ3100のALUを構成するオン・チップ若しくはオフ・チップのメモリ及び/又はレジスタ(図示している又は図示せず)に記憶されてもよい。
【0382】
少なくとも一実施例では、
図31に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図31に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図31に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0383】
図32A及び
図32Bは、少なくとも一実施例による、グラフィックス・プロセッサ・コアの処理要素のアレイを含むスレッド実行論理3200を示す。
図32Aは、スレッド実行論理3200が使用される少なくとも一実施例を示す。
図32Bは、少なくとも一実施例による、実行ユニット3208の例示的な内側細部を示す図である。
【0384】
図32Aに示すように、少なくとも一実施例では、スレッド実行論理3200は、シェーダ・プロセッサ3202、スレッド・ディスパッチャ3204、命令キャッシュ3206、複数の実行ユニット3207A~3207N及び3208A~3208Nを含むスケーラブル実行ユニット・アレイ、サンプラ3210、データ・キャッシュ3212、及びデータ・ポート3214を含む。少なくとも一実施例では、スケーラブル実行ユニット・アレイは、1つ又は複数の実行ユニット(たとえば、実行ユニット3208A~N又は3207A~Nのうちのいずれか)を、たとえばワークロードの計算要件に基づき有効又は無効にすることによって、動的に拡大縮小することができる。少なくとも一実施例では、スケーラブル実行ユニットは、各実行ユニットにリンクされる相互接続ファブリックを介して相互接続される。少なくとも一実施例では、スレッド実行論理3200は、命令キャッシュ3206、データ・ポート3214、サンプラ3210、及び実行ユニット3207又は3208のうちの1つ又は複数を介した、システム・メモリ又はキャッシュ・メモリなどのメモリへの1つ又は複数の接続を含む。少なくとも一実施例では、各実行ユニット(たとえば、3207A)は、スレッドごとに複数のデータ要素を並列で処理しながら、複数の同時のハードウェア・スレッドを実行することができるスタンドアロンのプログラム可能な汎用計算ユニットである。少なくとも一実施例では、実行ユニット3207及び/又は3208のアレイは、任意の数の個々の実行ユニットを含むように拡大縮小可能である。
【0385】
少なくとも一実施例では、実行ユニット3207及び/又は3208は、シェーダ・プログラムを実行するために主に使用される。少なくとも一実施例では、シェーダ・プロセッサ3202は、様々なシェーダ・プログラムを処理し、シェーダ・プログラムに関連付けられた実行スレッドを、スレッド・ディスパッチャ3204を介してディスパッチすることができる。少なくとも一実施例では、スレッド・ディスパッチャ3204は、グラフィックス及びメディア・パイプラインからのスレッド開始要求を調停し、要求されたスレッドを、実行ユニット3207及び/又は3208の1つ又は複数の実行ユニット上でインスタンス化するための論理を含む。たとえば、少なくとも一実施例では、ジオメトリ・パイプラインは、頂点シェーダ、モザイク・シェーダ、又はジオメトリ・シェーダを、処理できるようにスレッド実行論理にディスパッチすることができる。少なくとも一実施例では、スレッド・ディスパッチャ3204はまた、実行しているシェーダ・プログラムからのラン・タイム・スレッド・スポーニング要求(spawning request)を処理することができる。
【0386】
少なくとも一実施例では、実行ユニット3207及び/又は3208は、多くの標準的な3Dグラフィックス・シェーダ命令のネイティブ・サポートを含む命令セットをサポートし、それにより、グラフィックス・ライブラリ(たとえば、Direct3D及びOpenGL)からのシェーダ・プログラムが、最小のトランスレーションで実行される。少なくとも一実施例では、実行ユニットは、頂点及びジオメトリの処理(たとえば、頂点プログラム、ジオメトリ・プログラム、及び/又は頂点シェーダ)、ピクセル処理(たとえば、ピクセル・シェーダ、フラグメント・シェーダ)、及び汎用処理(たとえば、コンピュート及びメディアのシェーダ)をサポートする。少なくとも一実施例では、1つ又は複数の算術論理演算ユニット(ALU)を含む実行ユニット3207及び/又は3208のそれぞれは、単一命令複数データ(SIMD)の実行を複数発行することができ、マルチスレッド化された動作によって、メモリ・アクセスのレイテンシが高いにもかかわらず、効率的な実行環境が可能になる。少なくとも一実施例では、各実行ユニット内の各ハードウェア・スレッドは、専用の高帯域幅レジスタ・ファイル及び関連する独立したスレッド状態を有する。少なくとも一実施例では、実行は、整数演算、単精度及び倍精度の浮動小数点演算、SIMDブランチ性能、論理演算、超越演算、及び他の種々の演算を行うことができるパイプラインに対して、クロック当たり複数発行される。少なくとも一実施例では、メモリ、又は共有機能のうちの1つからのデータを待機している間に、実行ユニット3207及び/又は3208内の従属論理は、要求したデータが戻されるまで、待機スレッドをスリープ状態にする。少なくとも一実施例では、待機スレッドがスリープ状態の間に、ハードウェア・リソースは他のスレッドの処理に専念してもよい。たとえば、少なくとも一実施例では、頂点シェーダ動作に関連する遅延中に、実行ユニットは、ピクセル・シェーダ、フラグメント・シェーダ、又は異なる頂点シェーダを含む別のタイプのシェーダ・プログラムを実行することができる。
【0387】
少なくとも一実施例では、実行ユニット3207及び/又は3208の各実行ユニットは、データ要素のアレイに対して動作する。少なくとも一実施例では、データ要素の数は「実行サイズ」であり、又は命令に対するチャネルの数である。少なくとも一実施例では、実行チャネルは、データ要素のアクセス、マスキング、及び命令内のフロー制御に関する実行の論理ユニットである。少なくとも一実施例では、チャネルの数は、特定のグラフィックス・プロセッサのための物理的な算術論理演算ユニット(ALU)又は浮動小数点ユニット(FPU)の数とは無関係であってもよい。少なくとも一実施例では、実行ユニット3207及び/又は3208は、整数及び浮動小数点のデータ・タイプをサポートしてもよい。
【0388】
少なくとも一実施例では、実行ユニット命令セットは、SIMD命令を含む。少なくとも一実施例では、様々なデータ要素が、パック・データ・タイプとしてレジスタに記憶されてもよく、実行ユニットは、要素のデータ・サイズに基づき様々な要素を処理する。たとえば、少なくとも一実施例では、256ビット幅ベクトルで動作しているとき、ベクトルの256ビットがレジスタに記憶され、実行ユニットは、4個の別々の64ビット・パック・データ要素(クワッド・ワード(QW:Quad-Word)サイズのデータ要素)、8個の別々の32ビット・パック・データ要素(ダブル・ワード(DW:Double Word)サイズのデータ要素)、16個の別々の16ビット・パック・データ要素(ワード(W:Word)サイズのデータ要素)、又は32個の別々の8ビット・データ要素(バイト(B:byte)サイズのデータ要素)としてベクトル上で動作する。しかし少なくとも一実施例では、異なるベクトル幅及びレジスタサイズが考えられる。
【0389】
少なくとも一実施例では、1つ又は複数の実行ユニットを組み合わせて、実行ユニット3207Aと実行ユニット3208Aとが融合した融合実行ユニット3209Aなどの、融合EUに共通のスレッド制御論理(3211A~3211N)を有する融合実行ユニット3209A~3209Nにすることができる。少なくとも一実施例では、複数のEUを融合して、EUグループにすることができる。少なくとも一実施例では、融合EUグループの各EUは、別々のSIMDハードウェア・スレッドを実行するように構成されることが可能であり、融合EUグループのEUの数は、様々な実施例に応じて、場合によって異なってもよい。少なくとも一実施例では、SIMD8、SIMD16、及びSIMD32を含むがこれに限定されない様々なSIMD幅を、EUごとに実行することができる。少なくとも一実施例では、各融合グラフィックス実行ユニット3209A~3209Nは、少なくとも2つの実行ユニットを含む。たとえば、少なくとも一実施例では、融合実行ユニット3209Aは、第1のEU3207A、第2のEU3208A、及び第1のEU3207Aと第2のEU3208Aに共通のスレッド制御論理3211Aを含む。少なくとも一実施例では、スレッド制御論理3211Aは、融合グラフィックス実行ユニット3209Aで実行されているスレッドを制御して、融合実行ユニット3209A~3209N内の各EUを、共通の命令ポインタ・レジスタを使用して実行できるようにする。
【0390】
少なくとも一実施例では、1つ又は複数の内部命令キャッシュ(たとえば、3206)は、実行ユニットに対するスレッド命令をキャッシュするためにスレッド実行論理3200に含まれる。少なくとも一実施例では、1つ又は複数のデータ・キャッシュ(たとえば、3212)は、スレッド実行中にスレッド・データをキャッシュするために含まれる。少なくとも一実施例では、サンプラ3210は、3D動作のためのテクスチャ・サンプリング、及びメディア動作のためのメディア・サンプリングを実行するために含まれる。少なくとも一実施例では、サンプラ3210は、特別なテクスチャ又はメディア・サンプリング機能を含み、サンプリングされたデータを実行ユニットに提供する前に、サンプリング処理中にテクスチャ又はメディアのデータを処理する。
【0391】
実行中、少なくとも一実施例では、グラフィックス及びメディア・パイプラインは、スレッド開始要求を、スレッド・スポーニング及びディスパッチ論理を介してスレッド実行論理3200に送る。少なくとも一実施例では、幾何学的物体のグループが処理され、ピクセル・データにラスタ化されたら、シェーダ・プロセッサ3202内のピクセル・プロセッサ論理(たとえば、ピクセル・シェーダ論理、フラグメント・シェーダ論理など)が呼び出されて、出力情報をさらにコンピュートし、結果を出力面(たとえば、色バッファ、深度バッファ、ステンシル・バッファなど)に書き込ませる。少なくとも一実施例では、ピクセル・シェーダ又はフラグメント・シェーダは、ラスタ化された物体間で補間されることになる様々な頂点属性の値を計算する。少なくとも一実施例では、次いで、シェーダ・プロセッサ3202内のピクセル・プロセッサ論理が、アプリケーション・プログラミング・インターフェース(API)付きのピクセル・シェーダ・プログラム又はフラグメント・シェーダ・プログラムを実行する。少なくとも一実施例では、シェーダ・プログラムを実行するために、シェーダ・プロセッサ3202は、スレッド・ディスパッチャ3204を介してスレッドを実行ユニット(たとえば、3208A)にディスパッチする。少なくとも一実施例では、シェーダ・プロセッサ3202は、サンプラ3210のテクスチャ・サンプリング論理を使用して、メモリに記憶されたテクスチャ・マップのテクスチャ・データにアクセスする。少なくとも一実施例では、テクスチャ・データ及び入力ジオメトリ・データに対する算術演算によって、各ジオメトリ・フラグメントのピクセル色データがコンピュートされ、又はさらに処理されないように1つ又は複数のピクセルが切り捨てられる。
【0392】
少なくとも一実施例では、データ・ポート3214は、スレッド実行論理3200のためのメモリ・アクセス機構を提供して、処理済みデータを、グラフィックス・プロセッサ出力パイプラインでさらに処理できるようにメモリに出力する。少なくとも一実施例では、データ・ポート3214は、1つ又は複数のキャッシュ・メモリ(たとえば、データ・キャッシュ3212)を含み、又はそれに結合されて、データ・ポートを介したメモリ・アクセスのためのデータをキャッシュする。
【0393】
図32Bに示してあるように、少なくとも一実施例では、グラフィック実行ユニット3208は、命令フェッチ・ユニット3237、汎用レジスタ・ファイル・アレイ(GRF:general register file array)3224、アーキテクチャ・レジスタ・ファイル・アレイ(ARF)3226、スレッド調停装置(arbiter)3222、送信ユニット3230、ブランチ・ユニット3232、SIMD浮動小数点ユニット(FPU)3234のセット、及び、専用整数SIMD ALU3235のセットを含むことができる。少なくとも一実施例では、GRF3224及びARF3226は、各同時ハードウェア・スレッドに関連付けられた汎用レジスタ・ファイルとアーキテクチャ・レジスタ・ファイルのセットを含み、このハードウェア・スレッドは、グラフィックス実行ユニット3208においてアクティブであってもよい。少なくとも一実施例では、スレッドごとのアーキテクチャ状態が、ARF3226において維持され、スレッド実行中に使用されるデータが、GRF3224に記憶される。少なくとも一実施例では、各スレッドに対する命令ポインタを含む各スレッドの実行状態は、ARF3226のスレッド専用レジスタに保持することが可能である。
【0394】
少なくとも一実施例では、グラフィックス実行ユニット3208は、同時マルチスレッディング(SMT:Simultaneous Multi-Threading)と微細化インターリーブ・マルチスレッディング(IMT:Interleaved Multi-Threading)の組合せであるアーキテクチャを有する。少なくとも一実施例では、アーキテクチャは、実行ユニット当たりの同時スレッドのターゲット数及びレジスタ数に基づき設計時に微調整することができるモジュール式構成を有し、ここで実行ユニットのリソースは、複数の同時スレッドを実行するために使用される論理にわたって分割される。
【0395】
少なくとも一実施例では、グラフィックス実行ユニット3208は複数の命令を共同発行することができ、この命令は、それぞれ異なる命令であってもよい。少なくとも一実施例では、グラフィックス実行ユニット・スレッド3208のスレッド調停装置3222は、送信ユニット3230、ブランチ・ユニット3232、又はSIMD FPU3234のうちの1つに命令をディスパッチして実行できるようにすることができる。少なくとも一実施例では、各実行スレッドは、GRF3224内の128個の汎用レジスタにアクセスすることができ、ここで各レジスタは、32ビットのデータ要素のSIMD8要素のベクトルとしてアクセス可能な32バイトを記憶することができる。少なくとも一実施例では、各実行ユニット・スレッドは、GRF3224内の4キロバイトにアクセスすることができるが、実施例はこのように限定されず、他の実施例ではより多くの、又はより少ないリソースが提供されてもよい。少なくとも一実施例では、最大7個のスレッドを同時に実行できるが、実行ユニット当たりのスレッド数も、実施例に応じて変えることができる。7個のスレッドが4キロバイトにアクセスできる少なくとも一実施例では、GRF3224は、合計28キロバイトを記憶することができる。少なくとも一実施例では、フレキシブルなアドレッシング・モードにより、複数のレジスタがともにアドレスされてより幅広いレジスタを構築したり、ストライド設定された矩形ブロック・データ構造を表したりできるようにすることができる。
【0396】
少なくとも一実施例では、メモリ動作、サンプラ動作、及び他のレイテンシの長いシステム通信は、メッセージ引渡し送信ユニット3230によって実行される「送信」命令を介してディスパッチされる。少なくとも一実施例では、ブランチ命令は、SIMDの発散及び最終的な収束を容易にするために、ブランチ・ユニット3232にディスパッチされる。
【0397】
少なくとも一実施例では、グラフィックス実行ユニット3208は、浮動小数点演算を実行するための1つ又は複数のSIMD浮動小数点ユニット(FPU)3234を含む。少なくとも一実施例では、FPU3234は、整数計算もサポートする。少なくとも一実施例ではFPU3234は、最大M個の32ビット浮動小数点(若しくは整数)演算をSIMDで実行し、又は最大で2M個の16ビット整数演算、若しくは16ビット浮動小数点演算をSIMDで実行することができる。少なくとも一実施例では、少なくとも1つのFPUは、拡張数理機能を提供して、高スループットの超越数理関数、及び倍精度の64ビット浮動小数点をサポートする。少なくとも一実施例では、8ビットの整数SIMD ALU3235のセットも存在し、機械学習計算に関連する動作を実行するように特に最適化されてもよい。
【0398】
少なくとも一実施例では、グラフィックス実行ユニット3208の複数のインスタンスのアレイが、グラフィックス・サブ・コア・グループ(たとえば、サブ・スライス)においてインスタンス化されてもよい。少なくとも一実施例では、実行ユニット3208は、複数の実行チャネルにわたって命令を実行することができる。少なくとも一実施例では、グラフィックス実行ユニット3208で実行される各スレッドは、異なるチャネルで実行される。
【0399】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、推論及び/又は訓練論理815の一部又はすべてが、スレッド実行論理3200に組み込まれてもよい。さらに、少なくとも一実施例では、本明細書に記載の推論及び/又は訓練の動作は、
図8A又は
図8Bに示す論理以外の論理を使用して行われてもよい。少なくとも一実施例では、重みパラメータは、本明細書に記載の1つ又は複数の機械学習アルゴリズム、ニューラル・ネットワーク・アーキテクチャ、ユース・ケース、又は訓練技法を実行するための実行論理3200のALUスレッドを構成するオン・チップ若しくはオフ・チップのメモリ及び/又はレジスタ(図示する又は図示せず)に記憶されてもよい。
【0400】
少なくとも一実施例では、
図32Bに示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図32Bに示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図32Bに示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0401】
図33は、少なくとも一実施例による並列処理ユニット(「PPU」)3300を示す。少なくとも一実施例では、PPU3300は、PPU3300によって実行された場合に、本開示全体を通して記載するプロセス及び技法の一部又はすべてを、PPU3300に実行させる機械可読コードで構成される。少なくとも一実施例では、PPU3300はマルチスレッド・プロセッサであり、このプロセッサは、1つ又は複数の集積回路デバイスに実施され、コンピュータ可読命令(機械可読命令若しくは単に命令とも呼ばれる)を、複数のスレッドで並列に処理するように設計されたレイテンシ隠蔽技法としてマルチスレッディングを利用する。少なくとも一実施例では、スレッドとは、実行スレッドを指し、PPU3300によって実行されるように構成された命令のセットをインスタンス化したものである。少なくとも一実施例では、PPU3300は、液晶ディスプレイ(「LCD」)デバイスなどのディスプレイ・デバイスに表示できるように2次元(「2D」)画像データを生成するために、3次元(「3D」)グラフィックス・データを処理するためのグラフィックス・レンダリング・パイプラインを実施するように構成されたグラフィックス・プロセッシング・ユニット(「GPU」)である。少なくとも一実施例では、PPU3300を利用して、線形代数演算及び機械学習演算などの計算が実行される。
図33は、単に例示を目的とした例示的な並列プロセッサを示しており、本開示の範囲内で企図されるプロセッサ・アーキテクチャの非限定的な例として解釈されるべきであり、同プロセッサに追加するため、且つ/又はそれを置き換えるために、任意の好適なプロセッサが利用されてもよいことが解釈されるべきである。
【0402】
少なくとも一実施例では、1つ又は複数のPPU3300は、高性能コンピューティング(「HPC」:High Performance Computing)、データ・センタ、及び機械学習のアプリケーションを加速するように構成される。少なくとも一実施例では、PPU3300は、以下の非限定的な例を含む深層学習システム及びアプリケーションを加速するように構成される:自律車両プラットフォーム、深層学習、高精度音声、画像、テキスト認識システム、インテリジェント・ビデオ分析、分子シミュレーション、創薬、病気診断、天気予報、ビッグ・データ分析、天文学、分子動態シミュレーション、金融モデリング、ロボット工学、工場自動化、リアル・タイム言語翻訳、オンライン検索最適化、及び個別化ユーザ推奨など。
【0403】
少なくとも一実施例では、PPU3300は、限定することなく、入力/出力(「I/O」)ユニット3306、フロント・エンド・ユニット3310、スケジューラ・ユニット3312、ワーク分配ユニット3314、ハブ3316、クロスバー(「XBar」:crossbar)3320、1つ又は複数の汎用処理クラスタ(「GPC」:general processing cluster)3318、及び1つ又は複数のパーティション・ユニット(「メモリ・パーティション・ユニット」)3322を含む。少なくとも一実施例では、PPU3300は、1つ又は複数の高速GPU相互接続(「GPU相互接続」)3308を介してホスト・プロセッサ又は他のPPU3300に接続される。少なくとも一実施例では、PPU3300は、システム・バス3302を介してホスト・プロセッサ又は他の周辺デバイスに接続される。少なくとも一実施例では、PPU3300は、1つ又は複数のメモリ・デバイス(「メモリ」)3304を備えるローカル・メモリに接続される。少なくとも一実施例では、メモリ・デバイス3304は、限定することなく、1つ又は複数のダイナミック・ランダム・アクセス・メモリ(「DRAM」)デバイスを含む。少なくとも一実施例では、1つ又は複数のDRAMデバイスは、複数のDRAMダイが各デバイス内で積層された高帯域幅メモリ(「HBM」)サブシステムとして構成されても、且つ/又は構成可能であってもよい。
【0404】
少なくとも一実施例では、高速GPU相互接続3308は、有線ベースのマルチ・レーン通信リンクを指してもよく、このリンクは、拡張縮小するためにシステムによって使用され、1つ又は複数の中央処理装置(「CPU」)と組み合わされた1つ又は複数のPPU3300を含み、PPU3300とCPUとの間のキャッシュ・コヒーレンス、及びCPUマスタリングをサポートする。少なくとも一実施例では、データ及び/又はコマンドは、高速GPU相互接続3308により、ハブ3316を介して、1つ又は複数のコピー・エンジン、ビデオ・エンコーダ、ビデオ・デコーダ、電力管理ユニット、及び
図33に明示されていないこともある他の構成要素などのPPU3300の別のユニットに/から送信される。
【0405】
少なくとも一実施例では、I/Oユニット3306は、システム・バス3302を介してホスト・プロセッサ(
図33には示さず)から通信(たとえば、コマンド、データ)を送受信するように構成される。少なくとも一実施例では、I/Oユニット3306は、システム・バス3302を介して直接、又は1つ若しくは複数の、メモリ・ブリッジなどの中間デバイスを介して、ホスト・プロセッサと通信する。少なくとも一実施例では、I/Oユニット3306は、システム・バス3302を介してPPU3300のうちの1つ又は複数などの1つ又は複数の他のプロセッサと通信してもよい。少なくとも一実施例では、I/Oユニット3306は、ペリフェラル・コンポーネント・インターコネクト・エクスプレス(「PCIe」)インターフェースを実施して、PCIeバスを介して通信できるようにする。少なくとも一実施例では、I/Oユニット3306は、外部デバイスと通信するためのインターフェースを実施する。
【0406】
少なくとも一実施例では、I/Oユニット3306は、システム・バス3302を介して受信したパケットをデコードする。少なくとも一実施例では、少なくともいくつかのパケットは、PPU3300に様々な動作を実行させるように構成されたコマンドを表す。少なくとも一実施例では、I/Oユニット3306は、デコードされたコマンドを、コマンドによって指定されるPPU3300の様々な他のユニットに送信する。少なくとも一実施例では、コマンドは、フロント・エンド・ユニット3310に送信され、且つ/又はハブ3316、若しくは(
図33には明示していない)1つ若しくは複数のコピー・エンジン、ビデオ・エンコーダ、ビデオ・デコーダ、電力管理ユニットなどのPPU3300の他のユニットに送信される。少なくとも一実施例では、I/Oユニット3306はPPU3300の様々な論理ユニット間で、通信をルーティングするように構成される。
【0407】
少なくとも一実施例では、ホスト・プロセッサによって実行されるプログラムは、ワークロードをPPU3300に提供して処理できるようにするバッファにおいて、コマンド・ストリームをエンコードする。少なくとも一実施例では、ワークロードは、命令と、これらの命令によって処理されることになるデータとを含む。少なくとも一実施例では、バッファは、ホスト・プロセッサとPPU3300の両方がアクセス(たとえば、書込み/読取り)可能なメモリ内の領域であり、ホスト・インターフェース・ユニットは、I/Oユニット3306によってシステム・バス3302を介して送信されるメモリ要求を介して、システム・バス3302に接続されたシステム・メモリ内のそのバッファにアクセスするように構成されてもよい。少なくとも一実施例では、ホスト・プロセッサは、バッファにコマンド・ストリームを書き込み、次いでコマンド・ストリームの開始点を指すポインタをPPU3300に送信し、それによりフロント・エンド・ユニット3310は、1つ又は複数のコマンド・ストリームを指すポインタを受信し、1つ又は複数のコマンド・ストリームを管理して、コマンド・ストリームからコマンドを読み取り、コマンドをPPU3300の様々なユニットに転送する。
【0408】
少なくとも一実施例では、フロント・エンド・ユニット3310は、1つ又は複数のコマンド・ストリームによって定義されるタスクを処理するように様々なGPC3318を構成するスケジューラ・ユニット3312に結合される。少なくとも一実施例では、スケジューラ・ユニット3312は、スケジューラ・ユニット3312によって管理される様々なタスクに関連する状態情報を追跡するように構成され、ここで状態情報は、どのGPC3318にタスクが割り当てられるか、タスクがアクティブか非アクティブか、タスクに関連付けられた優先レベルなどを示してもよい。少なくとも一実施例では、スケジューラ・ユニット3312は、GPC3318のうちの1つ又は複数において、複数のタスクの実行を管理する。
【0409】
少なくとも一実施例では、スケジューラ・ユニット3312は、GPC3318で実行するためのタスクをディスパッチするように構成されたワーク分配ユニット3314に結合される。少なくとも一実施例では、ワーク分配ユニット3314は、スケジューラ・ユニット3312から受信したスケジュール済みタスクの数を追跡し、ワーク分配ユニット3314は、GPC3318のそれぞれについて、ペンディング・タスク・プール、及びアクティブ・タスク・プールを管理する。少なくとも一実施例では、ペンディング・タスク・プールは、特定のGPC3318によって処理されるように割り当てられたタスクを含むいくつかのスロット(たとえば、32スロット)を備え、アクティブ・タスク・プールは、GPC3318によりアクティブに処理されているタスクのためのいくつかのスロット(たとえば、4スロット)を備え、それにより、GPC3318のうちの1つがタスクの実行を完了すると、GPC3318のそのアクティブ・タスク・プールからそのタスクが排除され、ペンディング・タスク・プールからの別のタスクが選択され、GPC3318で実行されるようにスケジューリングされる。少なくとも一実施例では、データ依存性が解決されるのを待機している間など、アクティブ・タスクがGPC3318上でアイドルである場合には、そのアクティブ・タスクがGPC3318から排除され、そのペンディング・タスク・プールに戻され、その間に、そのペンディング・タスク・プールの別のタスクが選択され、GPC3318で実行されるようにスケジューリングされる。
【0410】
少なくとも一実施例では、ワーク分配ユニット3314は、Xバー3320を介して1つ又は複数のGPC3318と通信する。少なくとも一実施例では、Xバー3320は、PPU3300のユニットのうちの多くを、PPU3300の別のユニットに結合する相互接続ネットワークであり、ワーク分配ユニット3314を特定のGPC3318に結合するように構成されることが可能である。少なくとも一実施例では、PPU3300の1つ又は複数の他のユニットも、ハブ3316を介してXバー3320に接続されてもよい。
【0411】
少なくとも一実施例では、タスクはスケジューラ・ユニット3312によって管理され、ワーク分配ユニット3314によってGPC3318のうちの1つにディスパッチされる。少なくとも一実施例では、GPC3318は、タスクを処理し、結果を生成するように構成される。少なくとも一実施例では、結果は、GPC3318内の他のタスクによって消費されてもよく、Xバー3320を介して異なるGPC3318にルーティングされてもよく、又はメモリ3304に記憶されてもよい。少なくとも一実施例では、結果を、パーティション・ユニット3322を介してメモリ3304に書き込むことができ、パーティション・ユニット3322は、メモリ3304への/からのデータの読取り及び書込みを行うためのメモリ・インターフェースを実施する。少なくとも一実施例では、結果を、高速GPU相互接続3308を介して別のPPU又はCPUに送信することができる。少なくとも一実施例では、PPU3300は、
図35に関連して本明細書においてより詳細に説明されているように、PPU3300に結合された別々の個別メモリ・デバイス3304の数に等しいU個のパーティション・ユニット3322を、限定することなく含む。
【0412】
少なくとも一実施例では、ホスト・プロセッサはドライバ・カーネルを実行し、このカーネルは、ホスト・プロセッサで実行されている1つ又は複数のアプリケーションがPPU3300で実行するための動作をスケジューリングできるようにするアプリケーション・プログラミング・インターフェース(API)を実施している。少なくとも一実施例では、複数のコンピュート・アプリケーションが、PPU3300によって同時に実行され、PPU3300は、複数のコンピュート・アプリケーションに対して、隔離、サービス品質(「QoS」:quality of service)、及び独立したアドレス空間を提供する。少なくとも一実施例では、アプリケーションは、PPU3300によって実行するための1つ又は複数のタスクをドライバ・カーネルに生成させる(たとえば、APIコールの形の)命令を生成し、そのドライバ・カーネルは、PPU3300によって処理されている1つ又は複数のストリームにタスクを出力する。少なくとも一実施例では、各タスクは、ワープと呼ばれてもよい関連スレッドの1つ又は複数のグループを備える。少なくとも一実施例では、ワープは、並列に実行することができる複数の関連スレッド(たとえば、32個のスレッド)を備える。少なくとも一実施例では、連動スレッドとは、タスクを実行するための命令を含み、共有メモリを介してデータを交換する複数のスレッドを指してもよい。少なくとも一実施例では、スレッド及び連動スレッドは、
図35と併せてさらに詳細に説明される。
【0413】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、深層学習アプリケーション・プロセッサは、PPU3300に提供される情報を予測又は推論するようにニューラル・ネットワークなどの機械学習モデルを訓練するために使用される。少なくとも一実施例では、深層学習アプリケーション・プロセッサは、別のプロセッサ若しくはシステムによって、又はPPU3300によって訓練されてきた訓練済み機械学習モデル(たとえば、ニューラル・ネットワーク)に基づき、情報を推論又は予測するために使用される。少なくとも一実施例では、PPU3300は、本明細書に記載の1つ又は複数のニューラル・ネットワークのユース・ケースを実行するために使用されてもよい。
【0414】
少なくとも一実施例では、
図33に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図33に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図33に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0415】
図34は、少なくとも一実施例による汎用処理クラスタ(「GPC」)3400を示す。少なくとも一実施例では、GPC3400は、
図33のGPC3318である。少なくとも一実施例では、各GPC3400は、限定することなく、タスクを処理するためのいくつかのハードウェア・ユニットを含み、各GPC3400は、限定することなく、パイプライン・マネージャ3402、プレ・ラスタ演算ユニット(「プレPROP」:pre-raster operations unit)3404、ラスタ・エンジン3408、ワーク分配クロスバー(「WDX」:work distribution crossbar)3416、メモリ管理ユニット(「MMU」)3418、1つ又は複数のデータ処理クラスタ(「DPC」:Data Processing Cluster)3406、及びパーツの任意の好適な組合せを含む。
【0416】
少なくとも一実施例では、GPC3400の動作は、パイプライン・マネージャ3402によって制御される。少なくとも一実施例では、パイプライン・マネージャ3402は、GPC3400に配分されたタスクを処理するために1つ又は複数のDPC3406の構成を管理する。少なくとも一実施例では、パイプライン・マネージャ3402は、グラフィックス・レンダリング・パイプラインの少なくとも一部分を実施するように、1つ又は複数のDPC3406のうちの少なくとも1つを構成する。少なくとも一実施例では、DPC3406は、プログラム可能なストリーミング・マルチプロセッサ(「SM」:streaming multi-processor)3414で頂点シェーダ・プログラムを実行するように構成される。少なくとも一実施例では、パイプライン・マネージャ3402は、少なくとも一実施例では、ワーク分配ユニットから受信したパケットを、GPC3400内の適切な論理ユニットにルーティングするように構成され、いくつかのパケットは、プレPROP3404の固定機能ハードウェア・ユニット及び/又はラスタ・エンジン3408にルーティングされてもよく、他のパケットは、プリミティブ・エンジン3412又はSM3414によって処理されるようにDPC3406にルーティングされてもよい。少なくとも一実施例では、パイプライン・マネージャ3402は、ニューラル・ネットワーク・モデル及び/又はコンピューティング・パイプラインを実施するように、DPC3406のうちの少なくとも1つを構成する。
【0417】
少なくとも一実施例では、プレPROPユニット3404は、少なくとも一実施例では、ラスタ・エンジン3408及びDPC3406によって生成されたデータを、
図33と併せて上でより詳細に説明したパーティション・ユニット3322のラスタ動作(「ROP」)ユニットにルーティングするように構成される。少なくとも一実施例では、プレPROPユニット3404は、色ブレンディングの最適化を実行し、ピクセル・データを組織化し、アドレス・トランスレーションを実行し、その他の動作を行うように構成される。少なくとも一実施例では、ラスタ・エンジン3408は、少なくとも一実施例では様々なラスタ動作を実行するように構成されたいくつかの固定機能ハードウェア・ユニットを、限定することなく含み、ラスタ・エンジン3408は、限定することなく、セットアップ・エンジン、粗いラスタ・エンジン、選別エンジン、クリッピング・エンジン、細かいラスタ・エンジン、タイル合体エンジン、及びこれらの任意の好適な組合せを含む。少なくとも一実施例では、セットアップ・エンジンは、変換された頂点を受信し、頂点によって定義された幾何プリミティブに関連付けられた平面方程式を生成し、平面方程式が、粗いラスタ・エンジンに送信されて、プリミティブに対するカバレッジ情報(たとえば、タイルのx、yカバレッジ・マスク)が生成され、粗いラスタ・エンジンの出力が、選別エンジンに送信され、ここでzテストに落ちたプリミティブに関連付けられたフラグメントが選別され、クリッピング・エンジンに送信され、ここで視錐台の外側にあるフラグメントがクリップされる。少なくとも一実施例では、クリッピング及び選別を通過したフラグメントは、細かいラスタ・エンジンに渡されて、セットアップ・エンジンによって生成された平面方程式に基づき、ピクセル・フラグメントに対する属性が生成される。少なくとも一実施例では、ラスタ・エンジン3408の出力は、DPC3406内に実施されたフラグメント・シェーダによってなど任意の好適なエンティティによって処理されることになるフラグメントを含む。
【0418】
少なくとも一実施例では、GPC3400に含まれる各DPC3406は、限定することなく、Mパイプ・コントローラ(「MPC」:M-Pipe Controller)3410、プリミティブ・エンジン3412、1つ又は複数のSM3414、及びこれらの任意の好適な組合せを含む。少なくとも一実施例では、MPC3410は、DPC3406の動作を制御して、パイプライン・マネージャ3402から受信したパケットを、DPC3406内の適切なユニットにルーティングする。少なくとも一実施例では、頂点に関連付けられたパケットは、頂点に関連付けられた頂点属性をメモリからフェッチするように構成されたプリミティブ・エンジン3412にルーティングされ、対照的に、シェーダ・プログラムに関連付けられたパケットは、SM3414に送信されてもよい。
【0419】
少なくとも一実施例では、SM3414は、いくつかのスレッドにより表されたタスクを処理するように構成されたプログラム可能なストリーミング・プロセッサを、限定することなく含む。少なくとも一実施例では、SM3414はマルチスレッド化されており、スレッドの特定のグループからの複数のスレッド(たとえば、32個のスレッド)を同時に実行するように構成され、単一命令複数データ(SIMD)アーキテクチャを実施し、ここでスレッドのグループ(ワープ)内の各スレッドは、同じ命令セットに基づき、異なるデータ・セットを処理するように構成される。少なくとも一実施例では、スレッド・グループ内のすべてのスレッドが同じ命令を実行する。少なくとも一実施例では、SM3414は、単一命令複数スレッド(SIMT)アーキテクチャを実施し、ここで、スレッド・グループの各スレッドは、命令のその共通のセットに基づき、異なるデータ・セットを処理するように構成されるが、スレッド・グループ内の個々のスレッドは、実行中に発散することが許容される。少なくとも一実施例では、プログラム・カウンタ、コール・スタック、及び実行状態がワープごとに維持されて、ワープ内のスレッドが発散するときに、ワープ間の同時処理、及びワープ内での直列実行が可能になる。別の実施例では、プログラム・カウンタ、コール・スタック、及び実行状態が個々のスレッドごとに維持されて、すべてのスレッド間、ワープ内、及びワープ間で等しい同時処理が可能になる。少なくとも一実施例では、実行状態が個々のスレッドごとに維持され、共通の命令を実行しているスレッドが、より効率的になるように収束され並列に実行されてもよい。SM3414の少なくとも一実施例は、本明細書でさらに詳細に説明される。
【0420】
少なくとも一実施例では、MMU3418は、GPC3400とメモリ・パーティション・ユニット(たとえば、
図33のパーティション・ユニット3322)との間でインターフェースを提供し、MMU3418は、仮想アドレスから物理アドレスへのトランスレーション、メモリ保護、及びメモリ要求の調停を提供する。少なくとも一実施例では、MMU3418は、仮想アドレスからメモリの物理アドレスへのトランスレーションを実行するための1つ又は複数のトランスレーション・ルックアサイド・バッファ(「TLB」)を提供する。
【0421】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、深層学習アプリケーション・プロセッサは、GPC3400に提供される情報を予測又は推論するようにニューラル・ネットワークなどの機械学習モデルを訓練するために使用される。少なくとも一実施例では、GPC3400は、別のプロセッサ若しくはシステムによって、又はGPC3400によって訓練されてきた訓練済み機械学習モデル(たとえば、ニューラル・ネットワーク)に基づき、情報を推論又は予測するために使用される。少なくとも一実施例では、GPC3400は、本明細書に記載の1つ又は複数のニューラル・ネットワークのユース・ケースを実行するために使用されてもよい。
【0422】
少なくとも一実施例では、
図34に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図34に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図34に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0423】
図35は、少なくとも一実施例による並列処理ユニット(「PPU」)のメモリ・パーティション・ユニット3500を示す。少なくとも一実施例では、メモリ・パーティション・ユニット3500は、限定することなく、ラスタ演算(「ROP」)ユニット3502、レベル2(「L2」)キャッシュ3504、メモリ・インターフェース3506、及びそれらの任意の好適な組合せを含む。少なくとも一実施例では、メモリ・インターフェース3506は、メモリに結合される。少なくとも一実施例では、メモリ・インターフェース3506は、高速データ転送のために、32、64、128、1024ビットのデータ・バスなどを実施してもよい。少なくとも一実施例では、PPUは、U個のメモリ・インターフェース3506、Uは正の整数、をパーティション・ユニット3500の対当たりに1つのメモリ・インターフェース3506に組み込んでおり、ここでパーティション・ユニット3500の各対は、対応するメモリ・デバイスに接続される。たとえば、少なくとも一実施例では、PPUは、高帯域幅メモリ・スタック、又はグラフィックス・ダブル・データ・レート、バージョン5、同期ダイナミック・ランダム・アクセス・メモリ(「GDDR5 SDRAM」)など、最大Y個のメモリ・デバイスに接続されてもよい。
【0424】
少なくとも一実施例では、メモリ・インターフェース3506は、高帯域幅メモリの第2世代(「HBM2」:high bandwidth memory second generation)メモリ・インターフェースを実施し、YはUの半分に等しい。少なくとも一実施例では、HBM2メモリ・スタックは、PPUとともに物理パッケージに位置付けられて、従来のGDDR5 SDRAMシステムに比べて実質的な電力と面積の節約を実現する。少なくとも一実施例では、各HBM2スタックは、限定することなく4個のメモリ・ダイを含み、Y=4であり、各HBM2スタックは、1つのダイ当たりに2つの128ビット・チャネルの合計8チャネル、及び1024ビットのデータ・バス幅を含む。少なくとも一実施例では、そのメモリは、1ビット・エラー訂正2ビット・エラー検出(「SECDED」:Single-Error Correcting Double-Error Detecting)エラー訂正コード(「ECC」)をサポートしてデータを保護する。少なくとも一実施例では、ECCは、データ破損を受けやすいコンピュート・アプリケーションに、より高い信頼性を提供することができる。
【0425】
少なくとも一実施例では、PPUは、マルチ・レベルのメモリ階層を実施する。少なくとも一実施例では、メモリ・パーティション・ユニット3500は、統合されたメモリをサポートして、中央処理装置(「CPU」)及びPPUメモリに単一の統合された仮想アドレス空間を提供し、仮想メモリ・システム間でのデータの共有を可能にする。少なくとも一実施例では、他のプロセッサに位置付けられたメモリにPPUがアクセスする、頻度を追跡して、より頻繁にページにアクセスしているPPUの物理メモリに、メモリ・ページが確実に移動されるようにする。少なくとも一実施例では、高速GPU相互接続3308は、アドレス・トランスレーション・サービスをサポートして、PPUが直接CPUのページ・テーブルにアクセスできるようにし、PPUによるCPUメモリへのフル・アクセスを実現する。
【0426】
少なくとも一実施例では、コピー・エンジンは、複数のPPU間、又はPPUとCPUの間で、データを転送する。少なくとも一実施例では、コピー・エンジンは、ページ・テーブルにマッピングされていないアドレスについてページ誤りを生成することができ、次いでメモリ・パーティション・ユニット3500がページ誤りに対応して、アドレスをページ・テーブルにマッピングし、その後で、コピー・エンジンが転送を実行する。少なくとも一実施例では、メモリは、複数のプロセッサ間でコピー・エンジンの複数の動作についてピン留めされて(たとえば、ページ移動不可能にされて)、実質的に利用可能なメモリを低減させる。少なくとも一実施例では、ハードウェアのページ誤りがある場合、メモリ・ページが常駐であるかどうかに関わらず、アドレスをコピー・エンジンに渡すことができ、コピー・プロセスは透過的である。
【0427】
少なくとも一実施例によれば、
図33のメモリ3304又は他のシステム・メモリからのデータは、メモリ・パーティション・ユニット3500によってフェッチされ、L2キャッシュ3504に記憶され、このL2キャッシュは、オン・チップに位置付けられ、様々なGPC間で共有される。少なくとも一実施例では、各メモリ・パーティション・ユニット3500は、対応するメモリ・デバイスに関連付けられたL2キャッシュの少なくとも一部分を、限定することなく含む。少なくとも一実施例では、より低いレベルのキャッシュが、GPC内の様々なユニットに実施される。少なくとも一実施例では、
図34のSM3414の各々は、レベル1(「L1」)キャッシュを実施してもよく、ここでそのL1キャッシュは、特定のSM3414専用のプライベート・メモリであり、L2キャッシュ3504からのデータは、SM3414の機能ユニットで処理するために、L1キャッシュの各々にフェッチされ記憶される。少なくとも一実施例では、L2キャッシュ3504は、
図33に示すメモリ・インターフェース3506及びXバー3320に結合される。
【0428】
少なくとも一実施例では、ROPユニット3502は、色圧縮、ピクセル・ブレンディングなど、ピクセル色に関係するグラフィックス・ラスタ演算を実行する。ROPユニット3502は、少なくとも一実施例では、ラスタ・エンジン3408と併せて深度テストを実施して、ピクセル・フラグメントに関連付けられたサンプル・ロケーションの深度を、ラスタ・エンジン3408の選別エンジンから受信する。少なくとも一実施例では、深度は、フラグメントに関連付けられたサンプル・ロケーションの深度バッファにおける対応する深度と比べてテストされる。少なくとも一実施例では、そのフラグメントが、そのサンプル・ロケーションのその深度テストを通過すると、ROPユニット3502は、深度バッファを更新し、その深度テストの結果をラスタ・エンジン3408に送信する。パーティション・ユニット3500の数はGPCの数とは異なってもよく、したがって、各ROPユニット3502は、少なくとも一実施例では、各GPCに結合されてもよいことが理解されよう。少なくとも一実施例では、ROPユニット3502は、異なるGPCから受信したパケットを追跡し、ROPユニット3502によって生成された結果が、Xバー3320を通してルーティングされるべきであるか否かを判定する。
【0429】
図36は、少なくとも一実施例による、ストリーミング・マルチプロセッサ(「SM」)3600を示す。少なくとも一実施例では、SM3600は、
図34のSMである。少なくとも一実施例では、SM3600は、限定することなく、命令キャッシュ3602、1つ又は複数のスケジューラ・ユニット3604、レジスタ・ファイル3608、1つ又は複数の処理コア(「コア」)3610、1つ又は複数の特殊機能ユニット(「SFU」:special function unit)3612、1つ又は複数のロード/ストア・ユニット(「LSU」load/store unit)3614、相互接続ネットワーク3616、共有メモリ/レベル1(「L1」)キャッシュ3618、及び/又はこれらの任意の好適な組合せを含む。
【0430】
少なくとも一実施例では、ワーク分配ユニットは、並列処理ユニット(「PPU」)の汎用処理クラスタ(「GPC」)で実行するためにタスクをディスパッチし、各タスクは、GPC内の特定のデータ処理クラスタ(「DPC」)に配分され、タスクがシェーダ・プログラムに関連する場合には、そのタスクはSM3600のうちの1つに配分される。少なくとも一実施例では、スケジューラ・ユニット3604は、ワーク分配ユニットからタスクを受信し、SM3600に割り当てられた1つ又は複数のスレッド・ブロックについて命令スケジューリングを管理する。少なくとも一実施例では、スケジューラ・ユニット3604は、並列スレッドのワープとして実行できるようにスレッド・ブロックをスケジューリングし、ここで各スレッド・ブロックは、少なくとも1つのワープに配分される。少なくとも一実施例では、各ワープは、スレッドを実行する。少なくとも一実施例では、スケジューラ・ユニット3604は、複数の異なるスレッド・ブロックを管理して、異なるスレッド・ブロックにワープを配分し、次いで複数の異なる連動グループからの命令を、各クロック・サイクル中に様々な機能ユニット(たとえば、処理コア3610、SFU3612、及びLSU3614)にディスパッチする。
【0431】
少なくとも一実施例では、連動グループとは、通信するスレッドのグループを組織化するためのプログラミング・モデルを指し、このモデルは、スレッドが通信する粒度をデベロッパが表せるようにして、より豊富でより効率的な並列分解の表現を可能にする。少なくとも一実施例では、連動した起動APIは、並列アルゴリズムを実行できるようにスレッド・ブロック間の同期をサポートする。少なくとも一実施例では、従来のプログラミング・モデルのアプリケーションは、連動スレッドを同期するための単一の簡単な構造、すなわちスレッド・ブロックのすべてのスレッドにわたるバリア(たとえば、syncthreads()関数)を提供する。しかし、少なくとも一実施例では、プログラマは、スレッド・ブロックの粒度よりも小さいスレッド・グループを定義し、定義されたグループ内で同期して、集合的なグループ全般にわたる機能インターフェースの形で、より高い性能、設計の融通性、及びソフトウェア再利用を可能にしてもよい。少なくとも一実施例では、連動グループによって、プログラマは、サブ・ブロック(すなわち、単一スレッドと同じ大きさ)の粒度及びマルチ・ブロックの粒度において、スレッドのグループを明示的に定義し、連動グループ内のスレッドに対する同期などの集合的な動作を実行できるようになる。少なくとも一実施例では、そのプログラミング・モデルは、ソフトウェア境界を横切るクリーンな合成をサポートし、それにより、ライブラリ及びユーティリティ関数を、収束について仮定する必要なくそれらのローカルなコンテキスト内で安全に同期することができる。少なくとも一実施例では、連動グループのプリミティブは、プロデューサ-コンシューマ並列性、日和見並列性(opportunistic parallelism)、及びスレッド・ブロックのグリッド全体にわたるグローバルな同期を限定することなく含む新しいパターンの連動並列性を可能にする。
【0432】
少なくとも一実施例では、ディスパッチ・ユニット3606は、機能ユニットのうちの1つ又は複数に命令を送信するように構成され、スケジューラ・ユニット3604は、共通のワープからの2つの異なる命令を、各クロック・サイクル中にディスパッチできるようにする2つのディスパッチ・ユニット3606を限定することなく含む。少なくとも一実施例では、各スケジューラ・ユニット3604は、単一のディスパッチ・ユニット3606又は追加のディスパッチ・ユニット3606を含む。
【0433】
少なくとも一実施例では、各SM3600は、少なくとも一実施例では、SM3600の機能ユニットにレジスタのセットを提供するレジスタ・ファイル3608を限定することなく含む。少なくとも一実施例では、レジスタ・ファイル3608は、各機能ユニットがレジスタ・ファイル3608の専用部分に配分されるように、各機能ユニット間で分割される。少なくとも一実施例では、レジスタ・ファイル3608は、SM3600によって実行されている異なるワープ間で分割され、レジスタ・ファイル3608は、機能ユニットのデータ経路に接続されたオペランド用の一時的なストレージを提供する。少なくとも一実施例では、各SM3600は、限定することなく複数L個の処理コア3610を含み、ここでLは正の整数である。少なくとも一実施例では、各SM3600は、限定することなく、多数の(たとえば、128個以上の)個別の処理コア3610を含む。少なくとも一実施例では、各処理コア3610は、浮動小数点算術論理演算ユニット及び整数算術論理演算ユニットを限定することなく含む完全にパイプライン化された、単精度の、倍精度の、及び/又は混合精度の処理ユニットを限定することなく含む。少なくとも一実施例では、浮動小数点算術論理演算ユニットは、浮動小数点演算のためのIEEE754-2008規格を実施する。少なくとも一実施例では、処理コア3610は、限定することなく、64個の単精度(32ビット)浮動小数点コア、64個の整数コア、32個の倍精度(64ビット)浮動小数点コア、及び8個のテンソル・コアを含む。
【0434】
テンソル・コアは、少なくとも一実施例による行列演算を実行するように構成される。少なくとも一実施例では、1つ又は複数のテンソル・コアは、処理コア3610に含まれる。少なくとも一実施例では、テンソル・コアは、ニューラル・ネットワークの訓練及び推論のための畳み込み演算など、深層学習の行列演算を実行するように構成される。少なくとも一実施例では、各テンソル・コアは、4×4の行列で動作し、行列の積和演算(matrix multiply and accumulate operation)D=A×B+Cを実行し、ここでA、B、C、及びDは4×4の行列である。
【0435】
少なくとも一実施例では、行列乗算の入力A及びBは、16ビットの浮動小数点行列であり、和の行列C及びDは、16ビットの浮動小数点又は32ビットの浮動小数点行列である。少なくとも一実施例では、テンソル・コアは、32ビットの浮動小数点の和を有する16ビットの浮動小数点入力データで動作する。少なくとも一実施例では、16ビットの浮動小数点乗算は、64個の演算を使用し、結果的に完全精度の積をもたらし、次いでその積が、4×4×4の行列乗算の他の中間積との32ビット浮動小数点加算を使用して加算される。テンソル・コアを使用して、少なくとも一実施例では、これらの小さい要素から構築される、はるかに大きい2次元又はさらに高次元の行列演算が実行される。少なくとも一実施例では、CUDA9C++APIなどのAPIは、CUDA-C++プログラムからテンソル・コアを効率的に使用するために、特殊な行列ロード演算、行列積和演算、及び行列ストア演算を公開している。少なくとも一実施例では、CUDAレベルにおいて、ワープ・レベル・インターフェースは、ワープの32スレッドすべてにわたる16×16のサイズの行列を仮定している。
【0436】
少なくとも一実施例では、各SM3600は、特殊関数(たとえば、属性評価、逆数平方根など)を実行するM個のSFU3612を、限定することなく含む。少なくとも一実施例では、SFU3612は、限定することなく、階層ツリー・データ構造をトラバースするように構成されたツリー・トラバーサル・ユニットを含む。少なくとも一実施例では、SFU3612は、テクスチャ・マップのフィルタリング動作を実行するように構成されたテクスチャ・ユニットを、限定することなく含む。少なくとも一実施例では、テクスチャ・ユニットは、メモリ及びサンプル・テクスチャ・マップからテクスチャ・マップ(たとえば、テクセルの2Dアレイ)をロードして、SM3600により実行されるシェーダ・プログラムで使用するためのサンプリングされたテクスチャ値を生成するように構成される。少なくとも一実施例では、テクスチャ・マップは、共有メモリ/レベル1キャッシュ3618に記憶される。少なくとも一実施例では、テクスチャ・ユニットは、少なくとも一実施例によれば、ミップ・マップ(たとえば、詳細さのレベルが異なるテクスチャ・マップ)を使用したフィルタリング動作などのテクスチャ動作を実施する。少なくとも一実施例では、各SM3600は、限定することなく、2つのテクスチャ・ユニットを含む。
【0437】
各SM3600は、少なくとも一実施例では、共有メモリ/L1キャッシュ3618とレジスタ・ファイル3608の間でロード及びストア動作を実施するN個のLSU3614を、限定することなく含む。少なくとも一実施例では、相互接続ネットワーク3616は、各機能ユニットをレジスタ・ファイル3608に接続し、LSU3614をレジスタ・ファイル3608及び共有メモリ/L1キャッシュ3618に接続する。少なくとも一実施例では、相互接続ネットワーク3616はクロスバーであり、このクロスバーは、機能ユニットのいずれかをレジスタ・ファイル3608のレジスタのいずれかに接続し、LSU3614をレジスタ・ファイル3608と共有メモリ/L1キャッシュ3618のメモリ・ロケーションとに接続するように構成されてもよい。
【0438】
少なくとも一実施例では、共有メモリ/L1キャッシュ3618は、少なくとも一実施例では、SM3600とプリミティブ・エンジンの間、及びSM3600のスレッド間でデータ・ストレージ及び通信を可能にするオン・チップ・メモリのアレイである。少なくとも一実施例では、共有メモリ/L1キャッシュ3618は、限定することなく、128KBのストレージ容量を備え、SM3600からパーティション・ユニットに向かう経路にある。少なくとも一実施例では、共有メモリ/L1キャッシュ3618は、少なくとも一実施例では、読取り及び書込みをキャッシュするために使用される。少なくとも一実施例では、共有メモリ/L1キャッシュ3618、L2キャッシュ、及びメモリのうちの1つ又は複数は、補助ストレージである。
【0439】
少なくとも一実施例では、データ・キャッシュと共有メモリ機能とを単一のメモリ・ブロックに組み合わせることによって、両方のタイプのメモリ・アクセスについて性能が向上する。少なくとも一実施例では、容量は、共有メモリを使用しないプログラムによってキャッシュとして使用され、又は使用可能であり、それにより、共有メモリが容量の半分を使用するように構成されている場合、テクスチャ及びロード/ストア動作が、残りの容量を使用することができる。少なくとも一実施例によれば、共有メモリ/L1キャッシュ3618内に統合することによって、共有メモリ/L1キャッシュ3618が、データをストリームするための高スループットの管として機能しながら、同時に高帯域幅及び低レイテンシのアクセスを、頻繁に再使用されるデータに提供できるようになる。少なくとも一実施例では、汎用並列計算向けに構成されるときには、グラフィックス処理と比べてより簡単な構成を使用することができる。少なくとも一実施例では、固定機能のグラフィックス・プロセッシング・ユニットがバイパスされて、はるかに簡単なプログラミング・モデルが作製される。汎用並列計算の構成では、ワーク分配ユニットは、少なくとも一実施例においてスレッド・ブロックを直接DPCに割当て及び分配する。少なくとも一実施例では、ブロック内のスレッドは、各スレッドが確実に一意の結果を生成するように、計算において一意のスレッドIDを使用して共通のプログラムを実行し、SM3600を使用して、プログラムを実行し計算を行い、共有メモリ/L1キャッシュ3618を使用してスレッド間で通信し、LSU3614を使用して、共有メモリ/L1キャッシュ3618及びメモリ・パーティション・ユニットを介してグローバル・メモリを読み取り、書き込む。少なくとも一実施例では、汎用並列計算向けに構成されるときには、SM3600は、DPC上で新規のワークを起動するためにスケジューラ・ユニット3604が使用できるコマンドを書き込む。
【0440】
少なくとも一実施例では、PPUは、デスクトップ・コンピュータ、ラップトップ・コンピュータ、タブレット・コンピュータ、サーバ、スーパーコンピュータ、スマート・フォン(たとえば、ワイヤレスの携帯型デバイス)、パーソナル・デジタル・アシスタント(「PDA」)、デジタル・カメラ、車両、頭装着型ディスプレイ、携帯型電子デバイスなどに含まれ、又はこれらに結合される。少なくとも一実施例では、PPUは、単一の半導体基板に具体化される。少なくとも一実施例では、PPUは、追加のPPU、メモリ、縮小命令セット・コンピュータ(「RISC」)CPU、メモリ管理ユニット(「MMU」)、デジタル-アナログ変換器(「DAC」:digital-to-analog converter)などの1つ又は複数の他のデバイスとともにシステム・オン・チップ(「SoC」)に含まれる。
【0441】
少なくとも一実施例では、PPUは、1つ又は複数のメモリ・デバイスを含むグラフィックス・カードに含まれてもよい。少なくとも一実施例では、そのグラフィックス・カードは、デスクトップ・コンピュータのマザーボード上のPCIeスロットとインターフェースをとるように構成されてもよい。少なくとも一実施例では、そのPPUは、マザーボードのチップセットに含まれる統合グラフィックス・プロセッシング・ユニット(「iGPU」:integrated graphics processing unit)であってもよい。
【0442】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。少なくとも一実施例では、深層学習アプリケーション・プロセッサは、SM3600に提供される情報を予測又は推論するようにニューラル・ネットワークなどの機械学習モデルを訓練するために使用される。少なくとも一実施例では、SM3600は、別のプロセッサ若しくはシステムによって、又はSM3600によって訓練されてきた訓練済み機械学習モデル(たとえば、ニューラル・ネットワーク)に基づき、情報を推論又は予測するために使用される。少なくとも一実施例では、SM3600は、本明細書に記載の1つ又は複数のニューラル・ネットワークのユース・ケースを実行するために使用されてもよい。
【0443】
少なくとも一実施例では、
図36に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図36に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図36に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0444】
医療用途における画像推論及び画像処理などの、先進コンピューティングのための仮想化コンピューティング・プラットフォームに関連する実施例が開示される。限定ではなく、実施例は、X線写真撮影、磁気共鳴イメージング(MRI)、核医学、超音波、ソノグラフィ、エラストグラフィ、光音響イメージング、トモグラフィ、心エコー検査、機能的近赤外分光法、及び磁粉イメージング、又はそれらの組合せを含んでもよい。少なくとも一実施例では、本明細書に記載の仮想化コンピューティング・プラットフォーム及び関連するプロセスは、付加的に又は代替的に、限定ではなく、法医学的科学分析、地下検出及びイメージング(たとえば、石油探索、考古学、古生物学など)、地形学、海洋学、地質学、骨学、気象学、知的領域若しくは物体追跡及び監視、センサ・データ処理(たとえば、RADAR、SONAR、LIDARなど)、並びに/又はゲノミクス及び遺伝子配列解析において使用されてもよい。
【0445】
図37を参照すると、これは、少なくとも一実施例による、画像処理及び推論パイプラインを生成及び展開するプロセス3700の例示的なデータ・フロー図である。少なくとも一実施例では、プロセス3700は、医療施設、病院、健康管理機関、診療所、研究又は診断研究所などのような、1つ又は複数の施設3702にあるイメージング・デバイス、処理デバイス、ゲノミクス・デバイス、遺伝子配列解析デバイス、放射線デバイス、及び/又は、他のデバイス・タイプとともに使用するために展開されてもよい。少なくとも一実施例では、プロセス3700は、遺伝子解析及びシーケンシング・データに対する推論を実行するために展開されてもよい。本明細書に記載のシステム及びプロセスを使用して実行されてもよい遺伝子解析の例は、限定ではなく、バリアント・コール、変異検出、及び遺伝子発現定量化を含む。
【0446】
少なくとも一実施例では、プロセス3700は、訓練システム3704及び/又は展開システム3706内で実行されてもよい。少なくとも一実施例では、訓練システム3704を使用して、展開システム3706において使用するための機械学習モデル(たとえば、ニューラル・ネットワーク、物体検出アルゴリズム、コンピュータ・ビジョン・アルゴリズムなど)の訓練、展開、及び実施を実行することができる。少なくとも一実施例では、展開システム3706は、処理をオフロードし、分散コンピューティング環境の間でリソースを計算して、施設3702におけるインフラストラクチャ要件を低減するように構成されてもよい。少なくとも一実施例では、展開システム3706は、施設3702にあるイメージング・デバイス(たとえば、MRI、CTスキャン、X線、超音波など)又はシーケンシング・デバイスとともに使用するための仮想機器を選択、カスタマイズ、及び実施するための合理化されたプラットフォームを提供することができる。少なくとも一実施例では、仮想機器は、イメージング・デバイス、シーケンシング・デバイス、放射線デバイス、及び/又は他のデバイス・タイプによって生成されるイメージング・データに関する1つ又は複数の処理動作を実行するためのソフトウェア定義のアプリケーションを含んでもよい。少なくとも一実施例では、パイプライン内の1つ又は複数のアプリケーションは、アプリケーションの実行中に展開システム3706のサービス(たとえば、推論、仮想化、計算、AIなど)を使用するか又は呼び出してもよい。
【0447】
少なくとも一実施例では、先進処理及び推論パイプラインにおいて使用されるアプリケーションのうちのいくつかは、機械学習モデル又は他のAIを使用して、1つ又は複数の処理ステップを実行してもよい。少なくとも一実施例では、機械学習モデルは、施設3702において生成され(また、施設3702にある1つ又は複数の画像保管通信システム(PACS)サーバに記憶され)るデータ3708(イメージング・データなど)を使用して施設3702において訓練されてもよく、1つ又は複数の別の施設(たとえば、異なる病院、研究所、診療所など)からのイメージング又はシーケンシング・データ3708を使用して訓練されてもよく、又はそれらの組合せであってもよい。少なくとも一実施例では、訓練システム3704を使用して、展開システム3706のための実用的で展開可能な機械学習モデルを生成するためのアプリケーション、サービス、及び/又は他のリソースを提供することができる。
【0448】
少なくとも一実施例では、モデル・レジストリ3724は、バージョニング及びオブジェクト・メタデータをサポートすることができるオブジェクト・ストレージによって支援することができる。少なくとも一実施例では、オブジェクト・ストレージは、クラウド・プラットフォーム内から、たとえば、クラウド・ストレージ(たとえば、
図38のクラウド3826)対応アプリケーション・プログラミング・インターフェース(API)を通じてアクセス可能であってもよい。少なくとも一実施例では、モデル・レジストリ3724内の機械学習モデルは、APIと対話するシステムの開発者又はパートナによってアップロード、列挙、修正、又は削除することができる。少なくとも一実施例では、APIは、モデルをアプリケーションのコンテナ化されたインスタンス化の実行の一部として実行することができるように、適切な資格を有するユーザが、モデルをアプリケーションと関連付けることを可能にする方法にアクセスすることを可能にすることができる。
【0449】
少なくとも一実施例では、訓練パイプライン3804(
図38)は、施設3702がそれら自体の機械学習モデルを訓練しているか、又は、最適化若しくは更新される必要がある既存の機械学習モデルを有するシナリオを含んでもよい。少なくとも一実施例では、イメージング・デバイス、シーケンシング・デバイス、及び/又は他のデバイス・タイプによって生成されるイメージング・データ3708が受信されてもよい。少なくとも一実施例では、イメージング・データ3708が受信されると、AI支援アノテーション3710を使用して、機械学習モデルのグランド・トゥルース・データとして使用されるべきイメージング・データ3708に対応するアノテーションの生成を補助することができる。少なくとも一実施例では、AI支援アノテーション3710は、特定のタイプのイメージング・データ3708(たとえば、特定のデバイスからの)及び/又はイメージング・データ3708内の特定のタイプの異常に対応するアノテーションを生成するように訓練することができる1つ又は複数の機械学習モデル(たとえば、畳み込みニューラル・ネットワーク(CNN))を含んでもよい。少なくとも一実施例では、その後、AI支援アノテーション3710を、直接的に使用し、又は、(たとえば、研究者、臨床医、医師、科学者などによって)アノテーション・ツールを使用して調整若しくは微調整して、グランド・トゥルース・データを生成することができる。少なくとも一実施例では、いくつかの実例において、ラベル付き臨床データ3712(たとえば、臨床医、医師、科学者、技術者などによって提供されるアノテーション)が、機械学習モデルを訓練するためのグランド・トゥルース・データとして使用されてもよい。少なくとも一実施例では、AI支援アノテーション3710、ラベル付き臨床データ3712、又はそれらの組合せが、機械学習モデルを訓練するためのグランド・トゥルース・データとして使用されてもよい。少なくとも一実施例では、訓練済み機械学習モデルは、出力モデル3716として参照されてもよく、本明細書において説明されているように、展開システム3706によって使用されてもよい。
【0450】
少なくとも一実施例では、訓練パイプライン3804(
図38)は、施設3702が、展開システム3706内の1つ又は複数のアプリケーションのための1つ又は複数の処理タスクを実行するのに使用するための機械学習モデルを必要とするが、施設3702が現在そのような機械学習モデルを有し得ない(又はそのような目的のために最適化された、効率的な、若しくは効果的なモデルを有し得ない)シナリオを含んでもよい。少なくとも一実施例では、既存機械学習モデルが、モデル・レジストリ3724から選択されてもよい。少なくとも一実施例では、モデル・レジストリ3724は、イメージング・データに対する様々な異なる推論タスクを実行するように訓練された機械学習モデルを含んでもよい。少なくとも一実施例では、モデル・レジストリ3724内の機械学習モデルは、施設3702とは異なる施設(たとえば、遠隔に位置する施設)からのイメージング・データに対して訓練されていてもよい。少なくとも一実施例では、機械学習モデルは、1つのロケーション、2つのロケーション、又は任意の数のロケーションからのイメージング・データに対して訓練されていてもよい。少なくとも一実施例では、特定のロケーションからのイメージング・データに対して訓練されているとき、訓練は、そのロケーションにおいて、又は、(たとえば、HIPAA規制、プライバシー規制などに従うように)イメージング・データの機密性を保護するか若しくはイメージング・データが施設外に転送されるのを制限するように行うことができる。少なくとも一実施例では、モデルが1つのロケーションにおいて訓練されるか、又は部分的に訓練されると、機械学習モデルをモデル・レジストリ3724に加えることができる。少なくとも一実施例では、その後、機械学習モデルは、任意の数の他の施設において再訓練又は更新することができ、再訓練又は更新されたモデルを、モデル・レジストリ3724において利用可能にすることができる。少なくとも一実施例では、その後、機械学習モデルをモデル・レジストリ3724から選択し、出力モデル3716として参照することができ、展開システム3706において、展開システムの1つ又は複数のアプリケーションの1つ又は複数の処理タスクを実行するために使用することができる。
【0451】
少なくとも一実施例では、訓練パイプライン3804(
図38)は、施設3702が、展開システム3706内の1つ又は複数のアプリケーションのための1つ又は複数の処理タスクを実行するのに使用するための機械学習モデルを必要とするが、施設3702が現在そのような機械学習モデルを有し得ない(又はそのような目的のために最適化された、効率的な、若しくは効果的なモデルを有し得ない)シナリオに使用することができる。少なくとも一実施例では、モデル・レジストリ3724から選択される機械学習モデルは、母集団の差、遺伝的変異、機械学習モデルを訓練するために使用される訓練データのロバスト性、訓練データの異常の多様性、及び/又は、訓練データに伴う他の課題のために、施設3702において生成されるイメージング・データ3708に対して微調整又は最適化され得ない。少なくとも一実施例では、AI支援アノテーション3710を使用して、機械学習モデルを再訓練又は更新するためのグランド・トゥルース・データとして使用されるべきイメージング・データ3708に対応するアノテーションの生成を補助することができる。少なくとも一実施例では、ラベル付き臨床データ3712(たとえば、臨床医、医師、科学者などによって提供されるアノテーション)が、機械学習モデルを訓練するためのグランド・トゥルース・データとして使用されてもよい。少なくとも一実施例では、機械学習モデルの再訓練又は更新が、モデル訓練3714として参照されてもよい。少なくとも一実施例では、モデル訓練3714、たとえば、AI支援アノテーション3710、ラベル付き臨床データ3712、又はそれらの組合せが、機械学習モデルを再訓練又は更新するためのグランド・トゥルース・データとして使用されてもよい。
【0452】
少なくとも一実施例では、展開システム3706は、ソフトウェア3718、サービス3720、ハードウェア3722、並びに/又は他の構成要素、特徴、及び機能を含んでもよい。少なくとも一実施例では、展開システム3716は、ソフトウェア3718が、サービス3720の上に構築され得、サービス3720を使用して処理タスクの一部又はすべてを実行することができ、サービス3720及びソフトウェア3718が、ハードウェア3722の上に構築され得、ハードウェア3722を使用して、展開システム3706の処理、記憶、及び/又は他の計算タスクを実行することができるように、ソフトウェア「スタック」を含んでもよい。
【0453】
少なくとも一実施例では、ソフトウェア3718は、任意の数の異なるコンテナを含んでもよく、各コンテナが、アプリケーションのインスタンス化を実行することができる。少なくとも一実施例では、各アプリケーションが、先進処理及び推論パイプラインにおける1つ又は複数の処理タスク(たとえば、推論、物体検出、特徴検出、セグメント化、画像処理、較正など)を実行してもよい。少なくとも一実施例では、各タイプのイメージング・デバイス(たとえば、CT、MRI、X線、超音波、ソノグラフィ、心エコー検査など)、シーケンシング・デバイス、放射線デバイス、ゲノミクス・デバイスなどについて、デバイスによって生成されるイメージング・データ3708(又は、本明細書において説明されているものなどの、他のデータ・タイプ)に関するデータ処理タスクを実行することができる任意の数のコンテナが存在してもよい。少なくとも一実施例では、先進処理及び推論パイプラインは、イメージング・データを受信し、(たとえば、出力を、施設3702における記憶及び表示のために、医用におけるデジタル画像と通信(DICOM)データ、放射線医学情報システム(RIS)データ、臨床情報システム(CIS)データ、リモート・プロシージャ・コール(RPC)データ、表象状態転送(REST)インターフェースに実質的に従うデータ、ファイル・ベースのインターフェースに実質的に従うデータ、及び/又は生データなどの使用可能なデータ/タイプに変換し戻すために)パイプラインを通じて処理された後に、各コンテナによって使用するために及び/又は施設3702によって使用するために構成するコンテナに加えて、イメージング・データ3708を処理するために所望又は必要とされる異なるコンテナの選択に基づいて規定されてもよい。少なくとも一実施例では、(たとえば、パイプラインを構成する)ソフトウェア3718内のコンテナの組合せは、仮想機器(本明細書においてより詳細に説明されているような)として参照されてもよく、仮想機器は、サービス3720及びハードウェア3722を活用して、コンテナ内にインスタンス化されたアプリケーションのいくつか又はすべての処理タスクを実行することができる。
【0454】
少なくとも一実施例では、データ処理パイプラインは、推論要求(たとえば、臨床医、医師、放射線科医などのような、展開システム3706のユーザからの要求)に応答して、DICOM、RIS、CIS、REST準拠、RPC、生、及び/又は他のフォーマットの入力データ(たとえば、イメージング・データ3708)を受信することができる。少なくとも一実施例では、入力データは、1つ又は複数のイメージング・デバイス、シーケンシング・デバイス、放射線デバイス、ゲノミクス・デバイス、及び/又は他のデバイス・タイプによって生成される1つ若しくは複数の画像、ビデオ、及び/又は他のデータ表現を代表してもよい。少なくとも一実施例では、データは、1つ又は複数のアプリケーションによる処理に向けてデータを準備するために、データ処理パイプラインの一部としての前処理を受けてもよい。少なくとも一実施例では、出力データを次のアプリケーションに向けて準備し、並びに/又は、出力データを送信及び/若しくはユーザによる使用(たとえば、推論要求に対する応答としての)に向けて準備するために、1つ又は複数の推論タスク又はパイプラインの他の処理タスクの出力に対して後処理が実行されてもよい。少なくとも一実施例では、推論タスクは、訓練システム3704の出力モデル3716を含んでもよい、訓練済み又は展開済みニューラル・ネットワークなどの、1つ又は複数の機械学習モデルによって実行されてもよい。
【0455】
少なくとも一実施例では、データ処理パイプラインのタスクは、各々が、アプリケーションの別個の完全に機能的なインスタンス化、及び、機械学習モデルを参照することが可能な仮想化コンピューティング環境を表すコンテナ内にカプセル化されてもよい。少なくとも一実施例では、コンテナ又はアプリケーションは、コンテナ・レジストリのプライベート(たとえば、アクセスが制限された)領域に公開されてもよく、訓練済み又は展開済みモデルは、モデル・レジストリ3724に記憶され、1つ又は複数のアプリケーションと関連付けられてもよい。少なくとも一実施例では、アプリケーションの画像(たとえば、コンテナ画像)が、コンテナ・レジストリ内で利用可能であってもよく、ユーザによってパイプラインにおける展開のためにコンテナ・レジストリから選択されると、画像を使用して、ユーザのシステムによって使用するためのアプリケーションのインスタンス化のためのコンテナを生成することができる。
【0456】
少なくとも一実施例では、開発者(たとえば、ソフトウェア開発者、臨床医、医師など)は、供給されるデータに対する画像処理及び/又は推論を実行するために、(たとえば、コンテナとして)アプリケーションを開発、公開、及び記憶することができる。少なくとも一実施例では、開発、公開、及び/又は記憶は、(たとえば、開発されるアプリケーション及び/又はコンテナがシステムに準拠又は適合することを保証するために)システムと関連付けられるソフトウェア開発キット(SDK)を使用して実行されてもよい。少なくとも一実施例では、開発されるアプリケーションは、サービス3720のうちの少なくともいくつかをシステム(たとえば、
図38のシステム3800)としてサポートすることができるSDKによってローカルに(たとえば、第1の施設において、第1の施設からのデータに関して)テストされてもよい。少なくとも一実施例では、DICOMオブジェクトは、1から数百までの範囲の画像又は他のデータ・タイプを含み得るため、また、データの変動に起因して、開発者は、入来するDICOMデータの抽出及び準備を管理(たとえば、アプリケーションの構成の設定、アプリケーションへの前処理の構築など)する役割を担い得る。少なくとも一実施例では、システム3800によって(たとえば、正確度、安全性、患者プライバシーなどについて)検証されると、アプリケーションは、ユーザの施設(たとえば、第2の施設)におけるデータに関する1つ又は複数の処理タスクを実行するために、ユーザ(たとえば、病院、診療所、研究所、医療介護提供者など)による選択及び/又は実施のために、コンテナ・レジストリ内で利用可能になり得る。
【0457】
少なくとも一実施例では、開発者はその後、システム(たとえば、
図38のシステム3800)によるアクセス及び使用のために、ネットワークを通じてアプリケーション又はコンテナを共有してもよい。少なくとも一実施例では、完成し、検証されたアプリケーション又はコンテナは、コンテナ・レジストリに記憶されてもよく、関連する機械学習モデルが、モデル・レジストリ3724に記憶されてもよい。少なくとも一実施例では、推論又は画像処理要求を提供する要求元エンティティ(たとえば、医療施設にいるユーザ)は、アプリケーション、コンテナ、データセット、機械学習モデルなどについてコンテナ・レジストリ及び/又はモデル・レジストリ3724を閲覧し、データ処理パイプラインに含めるために要素の所望される組合せを選択し、イメージング処理要求を提出することができる。少なくとも一実施例では、要求は、要求を実行するために必要な入力データ(及び、いくつかの実例では関連する患者データ)を含んでもよく、並びに/又は、要求の処理において実行されるべきアプリケーション及び/若しくは機械学習モデルの選択を含んでもよい。少なくとも一実施例では、要求は、その後、データ処理パイプラインの処理を実行するために、展開システム3706の1つ又は複数の構成要素(たとえば、クラウド)に渡すことができる。少なくとも一実施例では、展開システム3706による処理は、コンテナ・レジストリ及び/又はモデル・レジストリ3724から、選択されている要素(たとえば、アプリケーション、コンテナ、モデルなど)を参照することを含んでもよい。少なくとも一実施例では、結果がパイプラインによって生成されると、結果は、参照のために(たとえば、ローカルな施設内のワークステーション又は端末上で実行する閲覧アプリケーションにおいて閲覧するために)ユーザに返すことができる。少なくとも一実施例では、放射線科医が、任意の数のアプリケーション及び/又はコンテナを含むデータ処理パイプラインからの結果を受信してもよく、結果は、X線、CTスキャン、MRIなどにおける異常検出を含んでもよい。
【0458】
パイプラインにおけるアプリケーション又はコンテナの処理又は実行を補助するために、サービス3720が活用されてもよい。少なくとも一実施例では、サービス3720は、計算サービス、人工知能(AI)サービス、視覚化サービス、及び/又は他のサービス・タイプを含んでもよい。少なくとも一実施例では、サービス3720は、ソフトウェア3718内の1つ又は複数のアプリケーションに共通である機能を提供することができ、したがって、機能は、アプリケーションによって呼び出し又は活用することができるサービスに抽象化することができる。少なくとも一実施例では、サービス3720によって提供される機能は、アプリケーションがデータを並列に(たとえば、並列コンピューティング・プラットフォーム3830(
図38)を使用して)処理することを可能にすることによって良好にスケーリングもしながら、動的且つより効率的に作動することができる。少なくとも一実施例では、サービス3720によって適用される同じ機能を共有する各アプリケーションがサービス3720のそれぞれのインスタンスを有することを要求されるのではなく、サービス3720は、様々なアプリケーションの間及び中で共有することができる。少なくとも一実施例では、サービスは、非限定例として、検出又はセグメント化タスクを実行するために使用することができる推論サーバ又はエンジンを含むことができる。少なくとも一実施例では、機械学習モデル訓練及び/又は再訓練機能を提供することができるモデル訓練サービスが含まれてもよい。少なくとも一実施例では、GPU加速化データ(たとえば、DICOM、RIS、CIS、REST準拠、RPC、生など)抽出、リサイズ、スケーリング、及び/又は他の増強を提供することができるデータ増強サービスがさらに含まれてもよい。少なくとも一実施例では、二次元(2D)及び/又は三次元(3D)モデルに現実感を加えるために、レイ・トレーシング、ラスタ化、ノイズ除去、鮮明化などのような、画像レンダリング効果を加えることができる視覚化サービスが使用されてもよい。少なくとも一実施例では、ビーム形成、セグメント化、推論、イメージング、及び/又は仮想機器のパイプライン内の他のアプリケーションのサポートを可能にする仮想機器サービスが含まれてもよい。
【0459】
少なくとも一実施例では、サービス3720がAIサービス(たとえば、推論サービス)を含む場合、異常検出(たとえば、腫瘍、発育異常、瘢痕化など)のためのアプリケーションと関連付けられる1つ又は複数の機械学習モデルを、推論サービス(たとえば、推論サーバ)を(たとえば、APIコールとして)呼び出して、機械学習モデル又はその処理をアプリケーション実行の一部として実行することによって、実行することができる。少なくとも一実施例では、別のアプリケーションがセグメント化タスクのための1つ又は複数の機械学習モデルを含む場合、アプリケーションは、推論サービスを呼び出して、セグメント化タスクと関連付けられる処理動作のうちの1つ又は複数を実施するために機械学習モデルを実行することができる。少なくとも一実施例では、セグメント化アプリケーション及び異常検出アプリケーションを含む先進処理及び推論パイプラインを実施するソフトウェア3718は、各アプリケーションが1つ又は複数の推論タスクを実行するための同じ推論サービスを呼び出し得るため、合理化することができる。
【0460】
少なくとも一実施例では、ハードウェア3722は、GPU、CPU、グラフィックス・カード、AI/深層学習システム(たとえば、NVIDIAのDGXなどのAIスーパーコンピュータ・システム)、クラウド・プラットフォーム、又はそれらの組合せを含んでもよい。少なくとも一実施例では、種々のタイプのハードウェア3722を使用して、展開システム3706内のソフトウェア3718及びサービス3720の効率的な専用のサポートを提供することができる。少なくとも一実施例では、GPU処理の使用は、画像処理、画像再構築、セグメント化、MRI試験、(たとえば、リアル・タイムでの)脳卒中又は心発作検出、レンダリングにおける画像品質などの効率、正確度、及び有効性を改善するために、ローカルな(たとえば、施設3702における)、AI/深層学習システム内での、クラウド・システム内での、及び/又は展開システム3706の他の処理構成要素内での処理のために実施されてもよい。少なくとも一実施例では、施設は、GPUを活用して被検者の解剖学的構造を表すイメージング・データを生成することができるイメージング・デバイス、ゲノミクス・デバイス、シーケンシング・デバイス、及び/又は施設内の他のデバイス・タイプを含んでもよい。
【0461】
少なくとも一実施例では、ソフトウェア3718及び/又はサービス3720は、非限定例として、深層学習、機械学習、及び/又は高性能コンピューティングに関するGPU処理のために最適化されてもよい。少なくとも一実施例では、展開システム3706及び/又は訓練システム3704のコンピューティング環境の少なくとも一部は、GPU最適化ソフトウェアを有する、データセンタの1つ若しくは複数のスーパーコンピュータ又は高性能コンピューティング・システム(たとえば、NVIDIAのDGXシステムのハードウェアとソフトウェアとの組合せ)において実行されてもよい。少なくとも一実施例では、データセンタは、イメージング・データ及び/又は他の患者データの送信が患者データのプライバシーに関して安全に処理されるように、HIPAAの規定に従うことができる。少なくとも一実施例では、ハードウェア3722は、本明細書において説明されているように、データの処理を並列に実行するために呼び出すことができる任意の数のGPUを含んでもよい。少なくとも一実施例では、クラウド・プラットフォームは、深層学習タスク、機械学習タスク、又は他のコンピューティング・タスクのGPU最適化実行のためのGPU処理をさらに含んでもよい。少なくとも一実施例では、クラウド・プラットフォーム(たとえば、NVIDIAのNGC)は、AI/深層学習スーパーコンピュータ及び/又はGPU最適化ソフトウェア(たとえば、NVIDIAのDGXシステム上で提供されるような)をハードウェア抽象化及びスケーリング・プラットフォームとして使用して実行されてもよい。少なくとも一実施例では、クラウド・プラットフォームは、アプリケーション・コンテナ・クラスタ化システム又はオーケストレーション・システム(たとえば、KUBERNETES)を複数のGPUに統合して、シームレスなスケーリング及び負荷平衡を可能にすることができる。
【0462】
少なくとも一実施例では、
図37に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図37に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図37に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0463】
図38は、少なくとも一実施例による、イメージング展開パイプラインを生成及び展開するための例示的なシステム3800のシステム図である。少なくとも一実施例では、システム3800を使用して、
図37のプロセス3700並びに/又は先進処理及び推論パイプラインを含む他のプロセスを実施することができる。少なくとも一実施例では、システム3800は、訓練システム3704及び展開システム3706を含んでもよい。少なくとも一実施例では、訓練システム3704及び展開システム3706は、本明細書において説明されているように、ソフトウェア3718、サービス3720、及び/又はハードウェア3722を使用して実施されてもよい。
【0464】
少なくとも一実施例では、システム3800(たとえば、訓練システム3704及び/又は展開システム3706)は、クラウド・コンピューティング環境において(たとえば、クラウド3826を使用して)実施されてもよい。少なくとも一実施例では、システム3800は、医療介護サービス施設に関してローカルに、又は、クラウドとローカル・コンピューティング・リソースの両方の組合せとして実施されてもよい。少なくとも一実施例では、クラウド・コンピューティングが実施される実施例において、患者データは、HIPAA並びに/又は他のデータ取り扱い及びプライバシー規制若しくは法令に準拠しない処理をレンダリングするシステム3800の1つ又は複数の構成要素から分離することができ、又は、当該構成要素によって処理されないようにすることができる。少なくとも一実施例では、クラウド3826におけるAPIへのアクセスは、制定されたセキュリティ方策又はプロトコルを通じて、認可されたユーザに制限することができる。少なくとも一実施例では、セキュリティ・プロトコルは、認証(たとえば、AuthN、AuthZ、Glueconなど)サービスによって署名することができるウェブ・トークンを含んでもよく、適切な権限付与を行うことができる。少なくとも一実施例では、仮想機器(本明細書において説明される)のAPI又はシステム3800の他のインスタンス化は、対話のために検査又は認可されている公衆IPのセットに制限され得る。
【0465】
少なくとも一実施例では、システム3800の様々な構成要素は、限定ではないが、有線及び/又は無線通信プロトコルを介したローカル・エリア・ネットワーク(LAN)及び/又は広域ネットワーク(WAN)を含む様々な異なるネットワーク・タイプのいずれかを使用して互いの間及び中で通信することができる。少なくとも一実施例では、施設とシステム3800の構成要素との間の通信(たとえば、推論要求を送信するための、推論要求の結果を受信するための、などの)は、1つ又は複数のデータ・バス、無線データ・プロトコル(Wi-Fi)、有線データ・プロトコル(たとえば、Ethernet)などを介して通信されてもよい。
【0466】
少なくとも一実施例では、訓練システム3704は、
図37に関して本明細書において説明されているものと同様の、訓練パイプライン3804を実行してもよい。少なくとも一実施例では、1つ又は複数の機械学習モデルが、展開システム3706によって展開パイプライン3810内で使用されるべきである場合、訓練パイプライン3804を使用して、1つ又は複数の(たとえば、事前に訓練された)モデルを訓練若しくは再訓練し、及び/又は、事前に訓練されたモデル3806のうちの1つ又は複数を(たとえば、再訓練又は更新する必要なしに)実施することができる。少なくとも一実施例では、訓練パイプライン3804の結果として、出力モデル3716を生成することができる。少なくとも一実施例では、訓練パイプライン3804は、限定ではないが、イメージング・データ(又は他の入力データ)の変換又は適合(たとえば、DICOMアダプタ3802Aを使用してDICOM画像を、ニューロイメージング情報技術イニシアチブ(NIfTI)フォーマットなどのそれぞれの機械学習モデルによる処理に適した別のフォーマットに変換すること)、AI支援アノテーション3710、ラベル付き臨床データ3712を生成するためにイメージング・データ3708にラベル若しくはアノテーションを付すこと、モデル・レジストリからのモデル選択、モデル訓練3714、モデルの訓練、再訓練、若しくは更新、及び/又は他の処理ステップなどの、任意の数の処理ステップを含んでもよい。少なくとも一実施例では、展開システム3706によって使用される異なる機械学習モデルに対して、異なる訓練パイプライン3804が使用されてもよい。少なくとも一実施例では、
図37に関して説明されている第1の実例と同様の訓練パイプライン3804が、第1の機械学習モデルに使用されてもよく、
図37に関して説明されている第2の実例と同様の訓練パイプライン3804が、第2の機械学習モデルに使用されてもよく、
図37に関して説明されている第3の実例と同様の訓練パイプライン3804が、第3の機械学習モデルに使用されてもよい。少なくとも一実施例では、各それぞれの機械学習モデルに必要とされるものに応じて、訓練システム3704内のタスクの任意の組合せが使用されてもよい。少なくとも一実施例では、機械学習モデルのうちの1つ又は複数は、すでに訓練されており、展開の準備が整っていてもよく、したがって、機械学習モデルは、訓練システム3704によっていかなる処理も受けなくてもよく、展開システム3706によって実施されてもよい。
【0467】
少なくとも一実施例では、出力モデル3716及び/又は事前に訓練されたモデル3806は、実施形態又は実施例に応じて任意のタイプの機械学習モデルを含んでもよい。少なくとも一実施例では、限定ではなく、システム3800によって使用される機械学習モデルは、線形回帰、ロジスティック回帰、決定木、サポート・ベクタ・マシン(SVM)、ナイーブ・ベイズ、k最近傍(Knn)、K平均クラスタリング、ランダム・フォレスト、次元削減アルゴリズム、勾配ブースティング・アルゴリズム、ニューラル・ネットワーク(たとえば、オート・エンコーダ、畳み込み、再帰、パーセプトロン、長・短期記憶(LSTM)、ホップフィールド、ボルツマン、ディープ・ビリーフ、逆畳み込み、敵対的生成、リキッド・ステート・マシンなど)、及び/又は他のタイプの機械学習モデルを使用する機械学習モデルを含んでもよい。
【0468】
少なくとも一実施例では、訓練パイプライン3804は、少なくとも
図41Bに関して本明細書においてより詳細に説明されるような、AI支援アノテーションを含んでもよい。少なくとも一実施例では、ラベル付き臨床データ3712(たとえば、従来のアノテーション)が、任意の数の技法によって生成されてもよい。少なくとも一実施例では、ラベル又は他のアノテーションは、いくつかの実例において、描画プログラム(たとえば、アノテーション・プログラム)、コンピュータ支援設計(CAD)プログラム、ラベリング・プログラム、グランド・トゥルースのためのアノテーション若しくはラベルを生成するのに適した別のタイプのプログラム内で生成されてもよく、及び/又は、手書きされてもよい。少なくとも一実施例では、グランド・トゥルース・データは、合成的に生成(たとえば、コンピュータ・モデル又はレンダリングか生成)されてもよく、現実的に生成(たとえば、実世界のデータから設計及び生成)されてもよく、機械によって自動化されてもよく(たとえば、特徴分析及び学習を使用してデータから特徴を抽出し、その後、ラベルを生成する)、人間がアノテーションを付してもよく(たとえば、ラベラ、又はアノテーション専門家がラベルのロケーションを規定する)、及び/又はそれらの組合せであってもよい。少なくとも一実施例では、イメージング・データ3708(又は機械学習モデルによって使用される他のデータ・タイプ)の各インスタンスについて、訓練システム3704によって対応するグランド・トゥルース・データが生成されてもよい。少なくとも一実施例では、AI支援アノテーションは、訓練パイプライン3804に含まれるAI支援アノテーションに加えて、又は、その代わりに、展開パイプライン3810の一部として実行されてもよい。少なくとも一実施例では、システム3800は、1つ又は複数の医用イメージング及び診断機能を実行することができる診断アプリケーション(又は他のアプリケーション・タイプ)のソフトウェア層(たとえば、ソフトウェア3718)を含むことができる多層プラットフォームを含んでもよい。少なくとも一実施例では、システム3800は、(たとえば、暗号化リンクを介して)1つ又は複数の施設のPACSサーバ・ネットワークに通信可能に結合されてもよい。少なくとも一実施例では、システム3800は(たとえば、DICOMアダプタ3802、又は、RIS、CIS、REST準拠、RPC、生などのような別のデータ・タイプ・アダプタを介して)、PACSサーバからのデータ(たとえば、DICOMデータ、RISデータ、生データ、CISデータ、REST準拠データ、RPCデータ、生データなど)にアクセスし、参照して、機械学習モデルの訓練、機械学習モデルの展開、画像処理、推論、及び/又は他の動作などの動作を実行するように構成されてもよい。
【0469】
少なくとも一実施例では、ソフトウェア層は、セキュアな、暗号化された、及び/又は認証されたAPIとして実施されてもよく、当該APIを通じて、アプリケーション又はコンテナを外部環境(たとえば、施設3702)から呼び出す(たとえば、コールする)ことができる。少なくとも一実施例では、アプリケーションは、その後、それぞれのアプリケーションと関連付けられる計算、AI、又は視覚化タスクを実行するために1つ又は複数のサービス3720をコール又は実行することができ、ソフトウェア3718及び/又はサービス3720はハードウェア3722を活用して、処理タスクを効果的且つ効率的に実行することができる。
【0470】
少なくとも一実施例では、展開システム3706は、展開パイプライン3810を実行することができる。少なくとも一実施例では、展開パイプライン3810は、上述したように、AI支援アノテーションを含む、イメージング・デバイス、シーケンシング・デバイス、ゲノミクス・デバイスなどによって生成されるイメージング・データ(及び/又は他のデータ・タイプ)に連続的に、不連続に、又は他の様態で適用されてもよい任意の数のアプリケーションを含んでもよい。少なくとも一実施例では、本明細書において説明されているように、個々のデバイスの展開パイプライン3810が、デバイスの仮想機器(たとえば、仮想超音波機器、仮想CTスキャン機器、仮想シーケンシング機器など)として参照されてもよい。少なくとも一実施例では、デバイスによって生成されるデータから所望される情報に応じて、単一のデバイスについて、2つ以上の展開パイプライン3810が存在してもよい。少なくとも一実施例では、異常の検出がMRIマシンから所望される場合、第1の展開パイプライン3810が存在してもよく、画像増強がMRIマシンの出力から所望される場合、第2の展開パイプライン3810が存在してもよい。
【0471】
少なくとも一実施例では、展開パイプライン3810にとって利用可能なアプリケーションは、イメージング・データ又はデバイスからの他のデータに対する処理タスクの実行に使用することができる任意のアプリケーションを含んでもよい。少なくとも一実施例では、複数の異なるアプリケーションが、画像増強、セグメント化、再構築、異常検出、物体検出、特徴検出、治療計画、線量測定、ビーム計画(又は他の放射線治療手順)、及び/又は他の分析、画像処理、又は推論タスクを担ってもよい。少なくとも一実施例では、展開システム3706は、アプリケーションの各々の構成を規定することができ、結果、展開システム3706のユーザ(たとえば、医療施設、研究所、診療所など)は、構成を理解し、それらのそれぞれの施設内での実施にアプリケーションを適合させることができる。少なくとも一実施例では、画像再構築のためのアプリケーションが、展開パイプライン3810に含めるために選択されてもよいが、イメージング・データによって生成されるデータ・タイプは、アプリケーション内で使用されるデータ・タイプとは異なってもよい。少なくとも一実施例では、データを展開システム3706内のアプリケーションによって使用可能な形態に変換するために、DICOMアダプタ3802B(及び/又はDICOMリーダ)又は別のデータ・タイプ・アダプタ若しくはリーダ(たとえば、RIS、CIS、REST準拠、RPC、生など)が、展開パイプライン3810内で使用されてもよい。少なくとも一実施例では、復号、抽出、並びに/又は、任意の畳み込み、色補正、鮮明度、ガンマ、及び/若しくはデータに対する他の増強を含む、DICOM、RIS、CIS、REST準拠、RPC、生、及び/又は他のデータ・タイプ・ライブラリへのアクセスを累積し、前処理することができる。少なくとも一実施例では、DICOM、RIS、CIS、REST準拠、RPC、及び/又は生データは順序付けられていない場合があり、前処理パスを実行して、収集されたデータを編成又はソートすることができる。少なくとも一実施例では、様々なアプリケーションが共通の画像動作を共有することができるため、いくつかの実施例では、データ増強ライブラリ(たとえば、サービス3720のうちの1つとしての)を使用して、これらの動作を加速させることができる。少なくとも一実施例では、CPU処理に依拠する従来の処理手法のボトルネックを回避するために、並列コンピューティング・プラットフォーム3830を、これらの処理タスクのGPU加速に使用することができる。
【0472】
少なくとも一実施例では、画像再構築アプリケーションは、機械学習モデルの使用を含む処理タスクを含んでもよい。少なくとも一実施例では、ユーザは、ユーザ自身の機械学習モデルを使用すること、又は、モデル・レジストリ3724から機械学習モデルを選択することを所望し得る。少なくとも一実施例では、ユーザは、ユーザ自身の機械学習モデルを実施してもよく、又は、処理タスクを実行するためのアプリケーションに含めるための機械学習モデルを選択してもよい。少なくとも一実施例では、アプリケーションは選択可能且つカスタマイズ可能であってもよく、アプリケーションの構成を規定することによって、特定のユーザのためのアプリケーションの展開及び実施形態が、よりシームレスなユーザ体験として提示される。少なくとも一実施例では、サービス3720及びハードウェア3722などのシステム3800の他の特徴を活用することによって、展開パイプライン3810は、さらによりユーザ・フレンドリになり得、より容易な統合を可能にすることができ、より正確、効率的、且つ時機を得た結果を生成することができる。
【0473】
少なくとも一実施例では、展開システム3706は、展開パイプライン3810に含めるためのアプリケーションを選択し、アプリケーションを構成し、アプリケーション又はそのパラメータ若しくは構成を修正若しくは変更し、セットアップ及び/若しくは展開中に展開パイプライン3810を使用してこれと対話し、並びに/又は、他の様態で展開システム3706と対話するために使用することができるユーザ・インターフェース3814(たとえば、グラフィカル・ユーザ・インターフェース、ウェブ・インターフェースなど)を含むことができる。少なくとも一実施例では、訓練システム3704に関して示されていないが、ユーザ・インターフェース3814(又は異なるユーザ・インターフェース)は、展開システム3706において使用するためのモデルを選択するため、訓練システム3704における訓練若しくは再訓練のためのモデルを選択するため、及び/又は、他の様態で訓練システム3704と対話するために使用されてもよい。
【0474】
少なくとも一実施例では、展開パイプライン3810のアプリケーション及びコンテナと、サービス3720及び/又はハードウェア3722との間の対話を管理するために、アプリケーション・オーケストレーション・システム3828に加えて、パイプライン・マネージャ3812が使用されてもよい。少なくとも一実施例では、パイプライン・マネージャ3812は、アプリケーション間の、アプリケーションからサービス3720への、及び/又はアプリケーション若しくはサービスからハードウェア3722への対話を容易にするように構成することができる。少なくとも一実施例では、ソフトウェア3718に含まれるものとして示されているが、これは、限定であるようには意図されておらず、いくつかの実例において(たとえば、
図39に示すような)、パイプライン・マネージャ3812は、サービス3720に含まれてもよい。少なくとも一実施例では、アプリケーション・オーケストレーション・システム3828(たとえば、クバネティス、DOCKERなど)は、調整、管理、スケーリング、及び展開のための論理ユニットとしてのコンテナにアプリケーションをグループ化することができるコンテナ・オーケストレーション・システムを含んでもよい。少なくとも一実施例では、展開パイプライン3810からのアプリケーション(たとえば、再構築アプリケーション、セグメント化アプリケーションなど)を個々のコンテナと関連付けることによって、各アプリケーションは、自己完結環境内で(たとえば、カーネル・レベルにおいて)実行して、速度及び効率を増大させることができる。
【0475】
少なくとも一実施例では、各アプリケーション及び/又はコンテナ(又はその画像)は、個々に開発、修正、及び展開されてもよく(たとえば、第1のユーザ又は開発者が第1のアプリケーションを開発、修正、及び展開してもよく、第2のユーザ又は開発者が、第1のユーザ又は開発者とは別個に第2のアプリケーションを開発、修正、及び展開してもよい)、これによって、別のアプリケーション又はコンテナのタスクによって妨害されることなく、単一のアプリケーション及び/又はコンテナのタスクに焦点を当て、注意することが可能になり得る。少なくとも一実施例では、異なるコンテナ又はアプリケーション間の通信及び調整は、パイプライン・マネージャ3812及びアプリケーション・オーケストレーション・システム3828によって支援することができる。少なくとも一実施例では、各コンテナ又はアプリケーションの予測入力及び/又は出力がシステムに分かっている限り(たとえば、アプリケーション又はコンテナの構成に基づいて)、アプリケーション・オーケストレーション・システム3828及び/又はパイプライン・マネージャ3812は、アプリケーション又はコンテナの各々の中及び間での通信、並びにそれらの中及び間でのリソースの共有を容易にすることができる。展開パイプライン3810内のアプリケーション又はコンテナのうちの1つ又は複数は、同じサービス及びリソースを共有することができるため、アプリケーション・オーケストレーション・システム3828は、様々なアプリケーション又はコンテナの間及び中でのサービス又はリソースの共有を取りまとめ、負荷平衡させ、決定することができる。少なくとも一実施例では、スケジューラを使用して、アプリケーション又はコンテナのリソース要件、これらのリソースの現在の使用又は計画されている使用、及びリソース可用性を追跡することができる。したがって、少なくとも一実施例では、スケジューラは、システムの要件及び可用性に照らして、リソースを複数の異なるアプリケーションに配分し、複数のアプリケーションの間及び中でリソースを分配することができる。いくつかの実例において、スケジューラ(及び/又はアプリケーション・オーケストレーション・システム3828の他の構成要素)は、サービス品質(QoS)、データ出力に対する需要の緊急性(たとえば、リアル・タイム処理を実行すべきか、又は、遅延した処理を実行すべきかを判定するための)などの、システムに課される制約(たとえば、ユーザ制約)に基づいて、リソース可用性及び分配を決定することができる。
【0476】
少なくとも一実施例では、展開システム3706内のアプリケーション又はコンテナによって活用及び共有されるサービス3720は、計算サービス3816、AIサービス3818、仮想化サービス3820、及び/又は他のサービス・タイプを含んでもよい。少なくとも一実施例では、アプリケーションは、アプリケーションの処理動作を実行するために、サービス3720のうちの1つ又は複数をコール(たとえば、実行)することができる。少なくとも一実施例では、スーパー・コンピューティング又は他の高性能コンピューティング(HPC)タスクを実行するために、計算サービス3816が、アプリケーションによって活用されてもよい。少なくとも一実施例では、計算サービス3816を活用して、実質的に同時に、アプリケーションのうちの1つ若しくは複数及び/又は単一のアプリケーションの1つ若しくは複数のタスクを通じてデータを処理するための並列処理を(たとえば、並列コンピューティング・プラットフォーム3830を使用して)実行することができる。少なくとも一実施例では、並列コンピューティング・プラットフォーム3830(たとえば、NVIDIAのCUDA)は、GPU上での汎用計算(GPGPU)を可能にしてもよい(たとえば、GPU3822)。少なくとも一実施例では、並列コンピューティング・プラットフォーム3830のソフトウェア層は、計算カーネルの実行のために、GPUの仮想機器セット及び並列計算要素へのアクセスを可能にすることができる。少なくとも一実施例では、並列コンピューティング・プラットフォーム3830は、メモリを含んでもよく、いくつかの実施例では、メモリは、複数のコンテナの間及び中で、並びに/又は、単一のコンテナ内の複数の異なる処理タスクの間及び中で共有されてもよい。少なくとも一実施例では、(たとえば、1つのアプリケーションの複数の異なる段又は複数のアプリケーションが同じ情報を処理している場合)並列コンピューティング・プラットフォーム3830のメモリの共有セグメントからの同じデータを使用するために、複数のコンテナ及び/又は1つのコンテナ内の複数のプロセスについて、プロセス間通信(IPC)コールを生成することができる。少なくとも一実施例では、データのコピーを作成し、データをメモリ内の異なるロケーションに移動する(たとえば、読出し/書込み動作)のではなく、メモリの同じロケーション内の同じデータを、任意の数の処理タスクに使用することができる(たとえば、同時に、異なる時点において、など)。少なくとも一実施例では、データが使用されて処理の結果として新たなデータが生成されるため、データの新たなロケーションのこの情報を記憶し、様々なアプリケーションの間で共有することができる。少なくとも一実施例では、データのロケーション及び更新又は修正されたデータのロケーションは、コンテナ内でペイロードがどのように理解されるかの定義の一部であり得る。
【0477】
少なくとも一実施例では、AIサービス3818を活用して、(たとえば、アプリケーションの1つ又は複数の処理タスクを実行するタスクを負う)アプリケーションと関連付けられる機械学習モデルを実行するために推論サービスを実行することができる。少なくとも一実施例では、AIサービス3818は、AIシステム3824を活用して、セグメント化、再構築、物体検出、特徴検出、分類、及び/又は他の推論タスクのために機械学習モデル(たとえば、CNNなどのニューラル・ネットワーク)を実行することができる。少なくとも一実施例では、展開パイプライン3810のアプリケーションは、訓練システム3704からの出力モデル3716及び/又はアプリケーションの他のモデルを使用して、イメージング・データ(たとえば、DICOMデータ、RISデータ、CISデータ、REST準拠データ、RPCデータ、生データなど)に対する推論を実行することができる。少なくとも一実施例では、アプリケーション・オーケストレーション・システム3828(たとえば、スケジューラ)を使用した推論の2つ以上の実例が利用可能であってもよい。少なくとも一実施例では、第1のカテゴリは、緊急事態中に緊急要求に対する推論を実行するためのもの、又は、診断中の放射線科医のためのものなどの、より高いサービス・レベルの合意を達成することができる高優先度/低レイテンシ経路を含んでもよい。少なくとも一実施例では、第2のカテゴリは、緊急でなくてもよい要求に対して、又は、後の時点において分析が実行され得る場合に使用され得る標準優先度経路を含んでもよい。少なくとも一実施例では、アプリケーション・オーケストレーション・システム3828は、AIサービス3818の異なる推論タスクの優先度経路に基づいてリソース(たとえば、サービス3720及び/又はハードウェア3722)を分配することができる。
【0478】
少なくとも一実施例では、共有ストレージが、システム3800内のAIサービス3818に実施されてもよい。少なくとも一実施例では、共有ストレージはキャッシュ(又は他のストレージ・デバイス・タイプ)として動作してもよく、アプリケーションからの推論要求を処理するために使用されてもよい。少なくとも一実施例では、推論要求が提出されると、展開システム3706のAPIインスタンスのセットによって要求を受信することができ、1つ又は複数のインスタンスが、要求を処理するために(たとえば、最良適合、負荷平衡などのために)選択され得る。少なくとも一実施例では、要求を処理するために、要求をデータベースに入力することができ、機械学習モデルを、まだキャッシュ内にない場合にモデル・レジストリ3724から配置することができ、検証ステップが、適切な機械学習モデルがキャッシュ(たとえば、共有ストレージ)にロードされることを保証することができ、及び/又は、モデルのコピーをキャッシュに保存することができる。少なくとも一実施例では、(たとえば、パイプライン・マネージャ3812の)スケジューラを使用して、アプリケーションがまだ作動していない場合、又は、アプリケーションの十分なインスタンスが存在しない場合、要求において参照されているアプリケーションを立ち上げることができる。少なくとも一実施例では、推論サーバがまだモデルを実行するために立ち上げられていない場合、推論サーバを立ち上げることができる。少なくとも一実施例では、モデルあたり任意の数の推論サーバが立ち上げられてもよい。少なくとも一実施例では、推論サーバがクラスタ化されるプル・モデルにおいて、負荷平衡が有利であるときはいつでも、モデルをキャッシュすることができる。少なくとも一実施例では、推論サーバは、対応する分散サーバ内に静的にロードすることができる。
【0479】
少なくとも一実施例では、推論は、コンテナ内で作動する推論サーバを使用して実行されてもよい。少なくとも一実施例では、推論サーバのインスタンスは、モデル(及び、任意選択的に、モデルの複数のバージョン)と関連付けられてもよい。少なくとも一実施例では、モデルに対して推論を実行することを求める要求が受信されたときに、推論サーバのインスタンスが存在しない場合、新たなインスタンスがロードされてもよい。少なくとも一実施例では、推論サーバを始動するとき、推論サーバが異なるインスタンスとして作動している限り、同じコンテナを使用して複数の異なるモデルにサービスすることができるように、モデルを推論サーバに渡すことができる。
【0480】
少なくとも一実施例では、アプリケーション実行中、所与のアプリケーションに対する推論要求が受信されてもよく、コンテナ(たとえば、推論サーバのインスタンスをホストする)がロードされてもよく(まだ存在しない場合)、開始手順がロードされてもよい。少なくとも一実施例では、コンテナ内の前処理論理が、入来するデータに対する任意の追加の前処理を(たとえば、CPU及び/又はGPUを使用して)ロード、復号、及び/又は実行してもよい。少なくとも一実施例では、データが推論のために準備されると、コンテナがデータに対して必要に応じて推論を実行することができる。少なくとも一実施例では、これは、1つの画像に対する単一の推論コールを含み得(たとえば、手のX線)、又は、数百の画像に対する推論を要求し得る(たとえば、胸部CT)。少なくとも一実施例では、アプリケーションは、完了前に結果を要約することができ、これは、限定ではなく、単一の信頼スコア、ピクセル・レベル・セグメント化、ボクセル・レベル・セグメント化、視覚化の生成、又は、所見を要約するためのテキストの生成を含んでもよい。少なくとも一実施例では、異なるモデル又はアプリケーションは、異なる優先度を割り当てられてもよい。たとえば、いくつかのモデルは、リアル・タイムの(1分未満のTAT)優先度を有してもよく、一方、他のモデルは、より低い優先度(たとえば、10分未満のTAT)を有してもよい。少なくとも一実施例では、モデル実行時間が、要求元機関又はエンティティから測定され得、パートナ・ネットワーク横断時間及び推論サービス上での実行を含み得る。
【0481】
少なくとも一実施例では、サービス3720と推論アプリケーションとの間の要求の転送は、ソフトウェア開発キット(SDK)の背後に隠すことができ、キューを通じてロバストな輸送を提供することができる。少なくとも一実施例では、要求は、個々のアプリケーション/テナントID組合せについてAPIを介してキューに配置され、SDKは、キューから要求をプルし、要求をアプリケーションに与える。少なくとも一実施例では、キューの名前は、SDKがキューをピック・アップする環境内で与えられてもよい。少なくとも一実施例では、キューを通じた非同期通信が、アプリケーションの任意のインスタンスがワークを利用可能になったときにピック・アップすることを可能にすることができるため、有用であり得る。少なくとも一実施例において、データが喪失されないことを保証するために、結果は、キューを通じて転送し戻すことができる。少なくとも一実施例では、キューはまた、最も優先度の高いワークが、アプリケーションのインスタンスが最も多く接続されているキューに行くことができ、一方で、優先度の最も低いワークが、タスクを受信された順に処理する、単一のインスタンスが接続されているキューに行くことができるため、ワークをセグメント化することを可能にすることもできる。少なくとも一実施例では、アプリケーションは、クラウド3826内で生成されるGPU加速化インスタンス上で作動することができ、推論サービスは、GPU上で推論を実行することができる。
【0482】
少なくとも一実施例では、視覚化サービス3820を活用して、アプリケーション及び/又は展開パイプライン3810の出力を閲覧するための視覚化を生成することができる。少なくとも一実施例では、GPU3822を、視覚化サービス3820によって活用して、視覚化を生成することができる。少なくとも一実施例では、レイ・トレーシングなどのレンダリング効果を、視覚化サービス3820によって実施して、より高い品質の視覚化を生成することができる。少なくとも一実施例では、視覚化は、限定ではなく、2D画像レンダリング、3Dボリューム・レンダリング、3Dボリューム再構築、2D断層撮影スライス、仮想現実ディスプレイ、拡張現実ディスプレイなどを含んでもよい。少なくとも一実施例では、仮想化環境を使用して、システムのユーザ(たとえば、医師、看護師、放射線科医など)による対話のための仮想対話型ディスプレイ又は環境(たとえば、仮想環境)を生成することができる。少なくとも一実施例では、視覚化サービス3820は、内部ビジュアライザ、シネマティクス、及び/又は他のレンダリング若しくは画像処理能力又は機能(たとえば、レイ・トレーシング、ラスタ化、内部光学系など)を含んでもよい。
【0483】
少なくとも一実施例では、ハードウェア3722は、GPU3822、AIシステム3824、クラウド3826、並びに/又は、訓練システム3704及び/若しくは展開システム3706の実行に使用される任意の他のハードウェアを含んでもよい。少なくとも一実施例では、GPU3822(たとえば、NVIDIAのTESLA及び/又はQUADRO GPU)は、計算サービス3816、AIサービス3818、視覚化サービス3820、他のサービス、及び/又は、ソフトウェア3718の特徴若しくは機能のいずれかの処理タスクの実行に使用することができる任意の数のGPUを含んでもよい。たとえば、AIサービス3818に関して、GPU3822を使用して、イメージング・データ(又は機械学習モデルによって使用される他のデータ・タイプ)に対する前処理、機械学習モデルの出力に対する後処理を実行し、及び/又は、推論(たとえば、機械学習モデルを実行するための)を実行することができる。少なくとも一実施例では、クラウド3826、AIシステム3824、及び/又はシステム3800の他の構成要素は、GPU3822を使用することができる。少なくとも一実施例では、クラウド3826は、深層学習タスクのためのGPU最適化プラットフォームを含んでもよい。少なくとも一実施例では、AIシステム3824は、GPUを使用することができ、クラウド3826又は深層学習若しくは推論のタスクを負う少なくとも一部分は、1つ又は複数のAIシステム3824を使用して実行することができる。したがって、ハードウェア3722は個別の構成要素として示されているが、これは、限定であるようには意図されておらず、ハードウェア3722の任意の構成要素が、ハードウェア3722の任意の他の構成要素と組み合わされてもよく、又は、任意の他の構成要素によって活用されてもよい。
【0484】
少なくとも一実施例では、AIシステム3824は、推論、深層学習、機械学習、及び/又は他の人工知能タスクのために構成されている専用コンピューティング・システム(たとえば、スーパー・コンピュータ又はHPC)を含んでもよい。少なくとも一実施例では、AIシステム3824(たとえば、NVIDIAのDGX)は、CPU、RAM、ストレージ、及び/又は他の構成要素、特徴、若しくは機能に加えて、複数のGPU3822を使用して実行することができるGPU最適化ソフトウェア(たとえば、ソフトウェア・スタック)を含んでもよい。少なくとも一実施例では、1つ又は複数のAIシステム3824は、システム3800のAIベースの処理タスクの一部又はすべてを実行するために、クラウド3826内に(たとえば、データ・センタ内に)実施されてもよい。
【0485】
少なくとも一実施例では、クラウド3826は、システム3800の処理タスクを実行するためにGPU最適化プラットフォームを提供することができるGPU加速化インフラストラクチャ(たとえば、NVIDIAのNGC)を含んでもよい。少なくとも一実施例では、クラウド3826は、(たとえば、ハードウェア抽象化及びスケーリング・プラットフォームとしての)システム3800のAIベースのタスクのうちの1つ又は複数を実行するためのAIシステム3824を含んでもよい。少なくとも一実施例では、クラウド3826は、複数のGPUを活用して、アプリケーション及びサービス3720の間及び中でのシームレスなスケーリング及び負荷平衡を可能にするアプリケーション・オーケストレーション・システム3828と統合することができる。少なくとも一実施例では、クラウド3826は、本明細書において説明されているような、計算サービス3816、AIサービス3818、及び/又は視覚化サービス3820を含む、システム3800のサービス3720の少なくとも一部を実行するタスクを負うことができる。少なくとも一実施例では、クラウド3826は、小さい及び大きいバッチの推論(たとえば、NVIDIAのTENSOR RTを実行して)を実行し、加速化並列コンピューティングAPI及びプラットフォーム3830(たとえば、NVIDIAのCUDA)を提供し、アプリケーション・オーケストレーション・システム3828(たとえば、KUBERNETES)を実行し、グラフィックス・レンダリングAPI及びプラットフォームを提供してもよく(たとえば、レイ・トレーシング、2Dグラフィックス、3Dグラフィックス、及び/又は、より高い品質のシネマティクスを生成する他のレンダリング技法のために)、及び/又は、システム3800の他の機能を提供してもよい。
【0486】
少なくとも一実施例では、患者の機密性を保持するための努力の一環として(たとえば、患者データ又は記録が施設外で使用されることになる場合)、クラウド3826は、深層学習コンテナ・レジストリなどのレジストリを含んでもよい。少なくとも一実施例では、レジストリは、患者データに対する前処理、後処理、又は他の処理タスクを実行することができるアプリケーションのインスタンス化のためのコンテナを記憶することができる。少なくとも一実施例では、クラウド3826は、コンテナ内の患者データ及びセンサ・データを含むデータを受信し、それらのコンテナ内のセンサ・データのみに対する要求された処理を実行し、その後、結果としての出力及び/又は視覚化を適切なパーティ及び/又はデバイス(たとえば、視覚化又は診断に使用される施設内の医療デバイス)に転送することができ、これらすべては、患者データを抽出、記憶、又は他の様態でアクセスすることを必要としない。少なくとも一実施例では、患者データの機密性は、HIPAA及び/又は他のデータ規制に従って保持される。
【0487】
少なくとも一実施例では、
図38に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図38に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図38に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0488】
図39は、少なくとも一実施例による、イメージング・データを処理するための展開パイプライン3810Aの例示的な図解を含む。少なくとも一実施例では、システム3800、具体的には展開システム3706は、展開パイプライン3810Aをカスタマイズ、更新、及び/又は統合して、1つ又は複数の生産環境にするために使用されてもよい。少なくとも一実施例では、
図39の展開パイプライン3810Aは、施設において(たとえば、病院、診療所、研究所、研究環境などにおいて)特定のユーザ(又はユーザのチーム)によってカスタム定義されてもよい展開パイプライン3810Aの非限定例を含む。少なくとも一実施例では、CTスキャナ3902向けに展開パイプライン3810Aを定義するために、ユーザは、たとえばコンテナ・レジストリから、CTスキャナ3902によって生成されるイメージング・データに関する特定の機能又はタスクを実行する1つ又は複数のアプリケーションを選択することができる。少なくとも一実施例では、アプリケーションは、システム3800のサービス3720及び/又はハードウェア3722を活用することができるコンテナとして、展開パイプライン3810Aに適用されてもよい。加えて、展開パイプライン3810Aは、アプリケーションが使用するためのデータを準備するために実施することができる追加の処理タスク又はアプリケーションを含んでもよい(たとえば、DICOMアダプタ3802B及びDICOMリーダ3906を展開パイプライン3810A内で使用して、CT再構築3908、臓器セグメンテーション3910などが使用するためのデータを準備してもよい)。少なくとも一実施例では、展開パイプライン3810Aは、恒常的展開、単回使用、又は別の頻度若しくは間隔のためにカスタマイズ又は選択されてもよい。少なくとも一実施例では、ユーザは、特定の間隔にわたって数人の対象にCT再構築3908及び臓器セグメンテーション3910を行うことを所望する場合があり、したがって、その期間にわたってパイプライン3810Aを展開し得る。少なくとも一実施例では、ユーザは、システム3800からの各要求に対して、ユーザがその要求についてそのデータに対して処理を実行することを所望するアプリケーションを選択してもよい。少なくとも一実施例では、展開パイプライン3810Aは、任意の間隔をおいて調整することができ、システム3800内のコンテナ構造の適応性及びスケーラビリティのために、これはシームレスなプロセスであり得る。
【0489】
少なくとも一実施例では、
図39の展開パイプライン3810Aは、患者又は対象のイメージング・データを生成するCTスキャナ3902を含んでもよい。少なくとも一実施例では、CTスキャナ3902からのイメージング・データは、CTスキャナ3902を収容する施設と関連付けられるPACSサーバ3904に記憶されてもよい。少なくとも一実施例では、PACSサーバは、施設にあるイメージング・モダリティ(たとえば、CTスキャナ3902)と直接インターフェースをとることができるソフトウェア及び/又はハードウェア構成要素を含んでもよい。少なくとも一実施例では、DICOMアダプタは、DICOMプロトコルを使用したDICOMオブジェクトの送信及び受信を可能にすることができる。少なくとも一実施例では、DICOMアダプタ3802Bは、展開パイプライン3810Aが使用するためのPACSサーバ3904からのDICOMデータの作成又は構成を支援することができる。少なくとも一実施例では、DICOMアダプタ3802Bを通じてDICOMデータが処理されると、パイプライン・マネージャ3812は、データを展開パイプライン3810Aへとルーティングすることができる。少なくとも一実施例では、DICOMリーダ3906は、DICOMデータ(たとえば、視覚化3916Aに示されているような、生サイノグラム・データ)から画像ファイル及び任意の関連するメタデータを抽出してもよい。少なくとも一実施例では、抽出される作業ファイルは、展開パイプライン3810A内の他のアプリケーションによるより高速な処理のためにキャッシュに記憶されてもよい。少なくとも一実施例では、DICOMリーダ3906がデータの抽出及び/又は記憶を完了すると、完了の信号がパイプライン・マネージャ3812に通信されてもよい。少なくとも一実施例では、パイプライン・マネージャ3812は、その後、展開パイプライン3810A内の1つ又は複数の他のアプリケーション又はコンテナを開始又はコールしてもよい。
【0490】
少なくとも一実施例では、CT再構築3908アプリケーション及び/又はコンテナは、データ(たとえば、生サイノグラム・データ)がCT再構築3908アプリケーションによる処理のために利用可能になると、実行することができる。少なくとも一実施例では、CT再構築3908は、キャッシュから生サイノグラム・データを読み出し、生サイノグラム・データから画像ファイルを再構築し(たとえば、視覚化3916Bに示すように)、結果もたらされた画像ファイルをキャッシュに記憶してもよい。少なくとも一実施例では、再構築の完了時に、パイプライン・マネージャ3812は、再構築タスクが完了したことをシグナリングされてもよい。少なくとも一実施例では、再構築が完了すると、再構築画像ファイルをキャッシュ(又は他のストレージ・デバイス)に記憶することができ、臓器セグメンテーション3910アプリケーション及び/又はコンテナを、パイプライン・マネージャ3812によってトリガすることができる。少なくとも一実施例では、臓器セグメンテーション3910アプリケーション及び/又はコンテナは、キャッシュから画像ファイルを読み出し、画像ファイルを推論に適したフォーマットに正規化又は変換し(たとえば、画像ファイルを機械学習モデルの入力解像度に変換し)、正規化画像に対して推論を実行することができる。少なくとも一実施例では、正規化画像に対して推論を実行するために、臓器セグメンテーション3910アプリケーション及び/又はコンテナは、サービス3720に依拠してもよく、パイプライン・マネージャ3812及び/又はアプリケーション・オーケストレーション・システム3828は、臓器セグメンテーション3910アプリケーション及び/又はコンテナによるサービス3720の使用を容易にすることができる。少なくとも一実施例では、たとえば、臓器セグメンテーション3910アプリケーション及び/又はコンテナは、AIサービス3818を活用して、正規化画像に対して推論を実行することができ、AIサービス3818は、ハードウェア3722(たとえば、AIシステム3824)を活用して、AIサービス3818を実行することができる。少なくとも一実施例では、推論の結果は、キャッシュ(又は他のストレージ・デバイス)に記憶されてもよいマスク・ファイル(たとえば、視覚化3916Cに示すような)であってもよい。
【0491】
少なくとも一実施例では、DICOMデータ及び/又はDICOMデータから抽出されるデータを処理するアプリケーションが処理を完了すると、パイプライン・マネージャ3812のための信号を生成することができる。少なくとも一実施例では、パイプライン・マネージャ3812は、その後、DICOMライタ3912を実行して、キャッシュ(又は他のストレージ・デバイス)から結果を読み出し、要求を生成した施設のユーザによって使用するためのDICOMフォーマットに結果を(たとえば、DICOM出力3914として)パッケージすることができる。少なくとも一実施例では、その後、DICOM出力3914をDICOMアダプタ3802Bに送信して、DICOM出力3914を(たとえば、施設のDICOMビューワによる閲覧のために)PACSサーバ3904に記憶するために準備することができる。少なくとも一実施例では、再構築及びセグメンテーションを求める要求に応答して、視覚化3916B及び3916Cを生成し、診断、研究、及び/又は他の目的のためにユーザにとって利用可能にすることができる。
【0492】
展開パイプライン3810A内の連続的なアプリケーションとして示されているが、CT再構築3908及び臓器セグメンテーション3910アプリケーションは、少なくとも一実施例では、並列に処理されてもよい。少なくとも一実施例では、アプリケーションが互いに依存しておらず、且つ、データが各アプリケーションにとって利用可能である(たとえば、DICOMリーダ3906がデータを抽出した後)、アプリケーションは、同時に、実質的に同時に、又はいくらか重複して実行されてもよい。少なくとも一実施例では、2つ以上のアプリケーションが類似のサービス3720を要求する場合、システム3800のスケジューラを使用して、様々なアプリケーションの間で及びそれらの中で負荷を平衡させ、計算又は処理リソースを分配することができる。少なくとも一実施例では、いくつかの実施例において、並列コンピューティング・プラットフォーム3830を使用して、アプリケーションの並列処理を実行して、展開パイプライン3810Aの実行時間を低減してリアル・タイム結果を提供することができる。
【0493】
少なくとも一実施例では、
図40A~
図40Bを参照すると、展開システム3706は、画像処理、セグメンテーション、増強、AI、視覚化、及び推論などの種々の機能を、イメージング・デバイス(たとえば、CTスキャナ、X線マシン、MRIマシンなど)、シークエンシング・デバイス、ゲノミクス・デバイス、及び/又は他のデバイス・タイプとともに実行するための1つ又は複数の仮想機器として実施されてもよい。少なくとも一実施例では、システム3800は、デバイスによって生成される生/未処理の入力データを受信し、処理済み/再構築データを出力することができるソフトウェア定義の展開パイプライン3810を含んでもよい仮想機器を作成及び提供することを可能にすることができる。少なくとも一実施例では、仮想機器を表す展開パイプライン3810(たとえば、3810A及び3810B)は、機械学習モデルを活用することなどによって、パイプラインにインテリジェンスを実施して、コンテナ推論サポートをシステムに提供することができる。少なくとも一実施例では、仮想機器は、各々がアプリケーションのインスタンス化を含む任意の数のコンテナを実行してもよい。少なくとも一実施例では、リアル・タイム処理が所望される場合などに、仮想機器を表す展開パイプライン3810は静的であってもよく(たとえば、コンテナ及び/又はアプリケーションが設定されてもよく)、一方、他の実例では、仮想機器のためのコンテナ及び/又はアプリケーションが、(たとえば、コンテナ・レジストリ内の)アプリケーション又はリソースのプールから(たとえば、要求ごとに)選択されてもよい。
【0494】
少なくとも一実施例では、システム3800は、たとえば、施設にある放射線マシン、イメージング・デバイス、及び/又は別のデバイス・タイプに隣接して展開されるか又は他の様態でそれらと通信するコンピューティング・システム内の、施設にある施設内の1つ又は複数の仮想機器としてインスタンス化又は実行されてもよい。しかしながら、少なくとも一実施例では、施設内の設備は、デバイス自体のコンピューティング・システム(たとえば、イメージング・デバイスと一体のコンピューティング・システム)、ローカル・データセンタ(たとえば、施設内のデータセンタ)、及び/又はクラウド環境(たとえば、クラウド3826)内でインスタンス化又は実行されてもよい。少なくとも一実施例では、仮想機器として動作する展開システム3706は、いくつかの実例では、スーパーコンピュータ又は他のHPCシステムによってインスタンス化されてもよい。少なくとも一実施例では、施設内の設備は、リアル・タイム処理のための高帯域幅使用を(たとえば、RFオーバーEthernetなどの、よりスループットの高いローカル通信インターフェースを介して)可能にすることができる。少なくとも一実施例では、リアル・タイム又は近リアル・タイム処理は、仮想機器が、超音波デバイス、又は、即時の視覚化が正確な診断及び分析のために期待若しくは要求される他のイメージング・モダリティをサポートする場合に、特に有用であり得る。少なくとも一実施例では、クラウド・コンピューティング・アーキテクチャは、ローカルの需要が施設内の容量又は能力を超えるときに、クラウド・コンピューティング・サービス・プロバイダ又は他の計算クラスタに動的にバーストすることが可能であってもよい。少なくとも一実施例では、クラウド・アーキテクチャは、実施されると、訓練システム3704に関連して本明細書に記載のように、ニューラル・ネットワーク又は他の機械学習モデルを訓練するように調整することができる。少なくとも一実施例では、適所にある訓練パイプラインによって、機械学習モデルは、それらがサポートするデバイスからの追加のデータを処理するときに、連続的に学習及び改善することができる。少なくとも一実施例では、仮想機器は、追加のデータ、新たなデータ、既存の機械学習モデル、及び/又は新たな若しくは更新された機械学習モデルを使用して連続的に改善することができる。
【0495】
少なくとも一実施例では、コンピューティング・システムは、本明細書に記載のハードウェア3722の一部又は全部を含んでもよく、ハードウェア3722は、デバイス内、デバイスに結合されており、その近位に位置するコンピューティング・デバイスの一部として、施設のローカル・データセンタ内、及び/又はクラウド3826を含む、任意の数の様式で分散されてもよい。少なくとも一実施例では、展開システム3706及び関連するアプリケーション又はコンテナは、ソフトウェアにおいて(たとえば、アプリケーションの別個のコンテナ・インスタンス化として)作成されるため、仮想機器の挙動、動作、及び構成、並びに、仮想機器によって生成される出力は、仮想機器がサポートするデバイスの生出力を変更又は改変する必要なしに、所望に応じて修正又はカスタマイズすることができる。
【0496】
少なくとも一実施例では、
図39に示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図39に示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図39に示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0497】
図40Aは、少なくとも一実施例による、超音波デバイスをサポートする仮想機器の例示的なデータ・フロー図である。少なくとも一実施例では、展開パイプライン3810Bは、システム3800のサービス3720のうちの1つ又は複数を活用することができる。少なくとも一実施例では、展開パイプライン3810B及びサービス3720は、ローカル又はクラウド3826内のいずれかの、システムのハードウェア3722を活用することができる。少なくとも一実施例では、図示されていないが、プロセス4000は、パイプライン・マネージャ3812、アプリケーション・オーケストレーション・システム3828、及び/又は並列コンピューティング・プラットフォーム3830によって容易にすることができる。
【0498】
少なくとも一実施例では、プロセス4000は、超音波デバイス4002からイメージング・データを受信することを含むことができる。少なくとも一実施例では、イメージング・データは、DICOMフォーマット(又は、RIS、CIS、REST準拠、RPC、生などのような他のフォーマット)において、PACSサーバに記憶されてもよく、超音波デバイス4002の仮想機器(たとえば、仮想超音波)として選択又はカスタマイズされた展開パイプライン3810を通じた処理のために、システム3800によって受信されてもよい。少なくとも一実施例では、イメージング・データは、イメージング・デバイス(たとえば、超音波デバイス4002)から直接的に受信されてもよく、仮装機器によって処理されてもよい。少なくとも一実施例では、イメージング・デバイスと仮想機器との間に通信可能に結合されているトランスデューサ又は他の信号変換器が、イメージング・デバイスによって生成される信号データを仮想機器によって処理することができる画像データに変換することができる。少なくとも一実施例では、生データ及び/又は画像データをDICOMリーダ3906に適用して、展開パイプライン3810Bのアプリケーション又はコンテナによって使用するためのデータを抽出することができる。少なくとも一実施例では、DICOMリーダ3906は、アプリケーション又はコンテナによって使用するために、データを抽出、リサイズ、再スケーリング、及び/又は他の様態で準備するために、データ増強ライブラリ4014(たとえば、NVIDIAのDALI(登録商標))をサービス3720として(たとえば、計算サービス3816のうちの1つとして)活用することができる。
【0499】
少なくとも一実施例では、データが準備されると、再構築4006アプリケーション及び/又はコンテナを実行して、超音波デバイス4002からデータを再構築して画像ファイルにすることができる。少なくとも一実施例では、再構築4006の後、又は、再構築4006と同時に、検出4008アプリケーション及び/又はコンテナは、異常検出、物体検出、特徴検出、及び/又はデータに関する他の検出タスクのために実行することができる。少なくとも一実施例では、再構築4006中に生成される画像ファイルを、検出4008中に使用して、異常、物体、特徴などを識別することができる。少なくとも一実施例では、検出4008アプリケーションは、推論エンジン4016(たとえば、AIサービス3818のうちの1つとしての)を活用して、データに対して推論を実行して検出を生成することができる。少なくとも一実施例では、1つ又は複数の機械学習モデル(たとえば、訓練システム3704からの)を、検出4008アプリケーションによって実行又はコールすることができる。
【0500】
少なくとも一実施例では、再構築4006及び/又は検出4008が完了すると、これらのアプリケーション及び/又はコンテナから出力されるデータを使用して、ワークステーション又はディスプレイ端末に表示される視覚化4012(たとえば、グレースケール出力)などの視覚化4010を生成することができる。少なくとも一実施例では、視覚化は、技術者又は他のユーザが、超音波デバイス4002に関する展開パイプライン3810Bの結果を視覚化することを可能にすることができる。少なくとも一実施例では、視覚化4010は、システム3800のレンダリング構成要素4018(たとえば、視覚化サービス3820のうちの1つ)を活用することによって実行することができる。少なくとも一実施例では、レンダリング構成要素4018は、2D、OpenGL、又はレイ・トレーシング・サービスを実行して視覚化4012を生成することができる。
【0501】
少なくとも一実施例では、
図40Aに示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図40Aに示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図40Bに示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0502】
図40Bは、少なくとも一実施例による、CTスキャナをサポートする仮想機器の例示的なデータ・フロー図を含む。少なくとも一実施例では、展開パイプライン3810Cは、システム3800のサービス3720のうちの1つ又は複数を活用することができる。少なくとも一実施例では、展開パイプライン3810C及びサービス3720は、ローカル又はクラウド3826内のいずれかの、システムのハードウェア3722を活用することができる。少なくとも一実施例では、図示されていないが、プロセス4020は、パイプライン・マネージャ3812、アプリケーション・オーケストレーション・システム3828、及び/又は並列コンピューティング・プラットフォーム3830によって容易にすることができる。
【0503】
少なくとも一実施例では、プロセス4020は、CTスキャナ4022が、DICOMリーダ3906によって(たとえば、直接的に、PACSサーバ3904を介して、処理後に、など)受信することができる生データを生成することを含んでもよい。少なくとも一実施例では、仮想CT(展開パイプライン3810Cによってインスタンス化される)は、患者を監視し(たとえば、患者運動検出AI4026)、及び/又は、CTスキャナ4022の露出を(たとえば、露出制御AI4024を使用して)調整若しくは最適化するための第1のリアル・タイム・パイプラインを含んでもよい。少なくとも一実施例では、アプリケーション(たとえば、4024及び4026)のうちの1つ又は複数は、AIサービス3818などのサービス3720を活用してもよい。少なくとも一実施例では、露出制御AI4024アプリケーション(若しくはコンテナ)及び/又は患者運動検出AI4026アプリケーション(若しくはコンテナ)の出力は、露出(若しくはCTスキャナ4022の他の設定)を調整し、及び/又は、患者に動きを小さくするように通知するための、CTスキャナ4022及び/又は技術者へのフィードバックとして使用されてもよい。
【0504】
少なくとも一実施例では、展開パイプライン3810Cは、CTスキャナ4022によって生成されるデータを分析するための非リアル・タイム・パイプラインを含んでもよい。少なくとも一実施例では、第2のパイプラインが、CT再構築3908アプリケーション及び/又はコンテナ、粗検出AI4028アプリケーション及び/又はコンテナ、精細検出AI4032アプリケーション及び/又はコンテナ(たとえば、いくらかの結果が粗検出AI4028によって検出された場合)、視覚化4030アプリケーション及び/又はコンテナ、並びにDICOMライタ3912(及び/若しくはRIS、CIS、REST準拠、RPC、生などのような、他のデータ・タイプのライタ)アプリケーション及び/又はコンテナを含んでもよい。少なくとも一実施例では、CTスキャナ4022によって生成される生データは、展開パイプライン3810C(仮想CT機器としてインスタンス化されている)の複数のパイプラインを通過して、結果を生成することができる。少なくとも一実施例では、DICOMライタ3912からの結果は、表示のために送信されてもよく、及び/又は、技術者、施術者、若しくは他のユーザによる後の検索、分析、若しくは表示のためにPACSサーバ3904に記憶されてもよい。
【0505】
少なくとも一実施例では、
図40Bに示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図40Bに示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図40Bに示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0506】
図41Aは、少なくとも一実施例による、機械学習モデルを訓練、再訓練、又は更新するプロセス4100のデータ・フロー図を示す。少なくとも一実施例では、プロセス4100は、非限定例として、
図38のシステム3800を使用して実行されてもよい。少なくとも一実施例では、プロセス4100は、本明細書において説明されているように、システム3800のサービス3720及び/又はハードウェア3722を活用することができる。少なくとも一実施例では、プロセス4100によって生成される精緻化モデル4112が、展開システム3706によって、展開パイプライン3810内の1つ又は複数のコンテナ化アプリケーションのために実行されてもよい。
【0507】
少なくとも一実施例では、モデル訓練3714は、新たな訓練データ(たとえば、顧客データセット4106などの新たな入力データ、及び/又は、入力データと関連付けられる新たなグランド・トゥルース・データ)を使用して初期モデル4104(たとえば、事前に訓練されたモデル)を再訓練又は更新することを含んでもよい。少なくとも一実施例では、初期モデル4104を再訓練又は更新するために、初期モデル4104の出力又は損失層が、リセット若しくは削除されてもよく、及び/又は、更新された又は新たな出力又は損失層に置換されてもよい。少なくとも一実施例では、初期モデル4104は、以前の訓練から維持される、以前に微調整されたパラメータ(たとえば、重み及び/又はバイアス)を有してもよく、したがって、訓練又は再訓練3714は、スクラッチからモデルを訓練することほど長くかからなくてもよく、又は、それほど多くの処理を必要としなくてもよい。少なくとも一実施例では、モデル訓練3714の間、初期モデル4104の出力又は損失層をリセット又は置換させることによって、新たな顧客データセット4106(たとえば、
図37の画像データ3708)に対する予測の生成において、出力又は損失層の正確度と関連付けられる損失計算に基づいて、新たなデータ・セットに対してパラメータを更新及び再調整することができる。
【0508】
少なくとも一実施例では、事前に訓練されたモデル3806がデータ・ストア又はレジストリ(たとえば、
図37のモデル・レジストリ3724)に記憶されてもよい。少なくとも一実施例では、事前に訓練されたモデル3806は、少なくとも部分的に、プロセス4100を実行する施設以外の1つ又は複数の施設において訓練されていてもよい。少なくとも一実施例では、異なる施設の患者、被検者、又は顧客のプライバシー及び権利を保護するために、事前に訓練されたモデル3806は、施設内で生成された顧客又は患者データを使用して、施設内で訓練されていてもよい。少なくとも一実施例では、事前に訓練されたモデル3806は、クラウド3826及び/又は他のハードウェア3722を使用して訓練することができるが、機密性のプライバシー保護された患者データは、クラウド3826(又は他の施設外ハードウェア)のいかなる構成要素にも転送されず、それらによって使用されず、又はそれらにとってアクセス可能でないものとすることができる。少なくとも一実施例では、事前に訓練されたモデル3806が2つ以上の施設からの患者データを使用して訓練される場合、事前に訓練されたモデル3806は、別の施設からの患者又は顧客データに関して訓練される前に、各施設について個別に訓練されていてもよい。少なくとも一実施例では、顧客若しくは患者データがプライバシー問題から解放されている場合(たとえば、権利放棄によって、実験的使用のためなど)、又は、顧客若しくは患者データが公開データ・セットに含まれている場合などに、任意の数の施設からの顧客又は患者データを使用して、データセンタ又は他のクラウド・コンピューティング・インフラストラクチャにおいてなど、施設内及び/又は施設外で、事前に訓練されたモデル3806を訓練することができる。
【0509】
少なくとも一実施例では、展開パイプライン3810内で使用するためのアプリケーションを選択するとき、ユーザはまた、特定のアプリケーションに使用される機械学習モデルを選択することもできる。少なくとも一実施例では、ユーザは、使用するためのモデルを有しない場合があり、したがって、ユーザは、アプリケーションとともに使用するために、事前に訓練されたモデル3806を選択してもよい。少なくとも一実施例では、事前に訓練されたモデル3806は、(たとえば、患者多様性、人口統計、使用される医用イメージング・デバイスのタイプなどに基づいて)ユーザの施設の顧客データセット4106に対して正確な結果を生成するように最適化されなくてもよい。少なくとも一実施例では、事前に訓練されたモデル3806をアプリケーションとともに使用するために展開パイプライン3810に展開する前に、事前に訓練されたモデル3806は、それぞれの施設において使用するために更新、再訓練、及び/又は微調整されてもよい。
【0510】
少なくとも一実施例では、ユーザは、更新、再訓練、及び/又は微調整されることになる事前に訓練されたモデル3806を選択することができ、事前に訓練されたモデル3806は、プロセス4100内で訓練システム3704の初期モデル4104として参照される場合がある。少なくとも一実施例では、顧客データセット4106(たとえば、イメージング・データ、ゲノミクス・データ、シーケンシング・データ、又は、施設にあるデバイスによって生成される他のデータ・タイプ)を使用して、初期モデル4104に対するモデル訓練3714(限定ではなく、転移学習を含んでもよい)を実行して精緻化モデル4112を生成することができる。少なくとも一実施例では、顧客データセット4106に対応するグランド・トゥルース・データが、訓練システム3704によって生成されてもよい。少なくとも一実施例では、グランド・トゥルース・データは、少なくとも部分的に、施設において臨床医、科学者、医師、施術者によって生成されてもよい(たとえば、
図37のラベル付き臨床データ3712として)。
【0511】
少なくとも一実施例では、AI支援アノテーション3710を、いくつかの実例において使用して、グランド・トゥルース・データを生成することができる。少なくとも一実施例では、AI支援アノテーション3710(たとえば、AI支援アノテーションSDKを使用して実施される)は、機械学習モデル(たとえば、ニューラル・ネットワーク)を活用して、顧客データセットの示唆又は予測されたグランド・トゥルース・データを生成することができる。少なくとも一実施例では、ユーザ4110は、コンピューティング・デバイス4108上のユーザ・インターフェース(グラフィカル・ユーザ・インターフェース(GUI))内のアノテーション・ツールを使用してもよい。
【0512】
少なくとも一実施例では、ユーザ4110は、コンピューティング・デバイス4108を介してGUIと対話して、アノテーション又は自動アノテーションを編集又は微調整することができる。少なくとも一実施例では、ポリゴン編集機能を使用して、ポリゴンの頂点をより正確な又は微調整されたロケーションへと動かすことができる。
【0513】
少なくとも一実施例では、顧客データセット4106がグランド・トゥルース・データを関連付けると、グランド・トゥルース・データ(たとえば、AI支援アノテーション、手動ラベル付けなどからの)をモデル訓練3714中に使用して、精緻化モデル4112を生成することができる。少なくとも一実施例では、顧客データセット4106は、初期モデル4104に任意の回数だけ適用することができ、グランド・トゥルース・データを使用して、精緻化モデル4112のために許容可能なレベルの正確度が達成されるまで、初期モデル4104のパラメータを更新することができる。少なくとも一実施例では、精緻化モデル4112が生成されると、精緻化モデル4112は、医用イメージング・データに関する1つ又は複数の処理タスクを実行するために、施設において1つ又は複数の展開パイプライン3810内に展開することができる。
【0514】
少なくとも一実施例では、精緻化モデル4112は、別の施設によって選択されるように、モデル・レジストリ3724内の事前に訓練されたモデル3806にアップロードされてもよい。少なくとも一実施例では、彼のプロセスは、任意の数の施設において遂行されてもよく、結果、精緻化モデル4112を新たなデータセットに対して任意の回数だけさらに精緻化して、より普遍的なモデルを生成することができる。
【0515】
少なくとも一実施例では、
図41Aに示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図41Aに示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図41Aに示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0516】
図41Bは、少なくとも一実施例による、事前に訓練されたアノテーション・モデルによってアノテーション・ツールを強化するためのクライアント・サーバ・アーキテクチャ4132の例示的な図である。少なくとも一実施例では、AI支援アノテーション・ツール4136は、クライアント・サーバ・アーキテクチャ4132に基づいてインスタンス化されてもよい。少なくとも一実施例では、イメージング・アプリケーション内のアノテーション・ツール4136は、放射線科医が、たとえば、臓器及び異常を識別するのを支援することができる。少なくとも一実施例では、イメージング・アプリケーションは、ユーザ4110が、非限定例として、生画像4134内の(たとえば、3D MRI又はCTスキャン内の)特定の関心臓器上のいくつかの端点を識別するのを助け、特定の臓器のすべての2Dスライスの自動アノテーション結果を受信するソフトウェア・ツールを含んでもよい。少なくとも一実施例では、結果は、訓練データ4138としてデータ・ストアに記憶することができ、(たとえば、限定ではなく)グランド・トゥルース・データとして訓練に使用することができる。少なくとも一実施例では、コンピューティング・デバイス4108がAI支援アノテーション3710のための端点を送信すると、たとえば、深層学習モデルは、このデータを入力として受診して、セグメント化された臓器又は異常の推論結果を返すことができる。少なくとも一実施例では、
図41BのAI支援アノテーション・ツール4136Bなどの、事前にインスタンス化されたアノテーション・ツールは、たとえば、アノテーション・モデル・レジストリに記憶されている、事前に訓練されたモデル4142のセットを含んでもよいアノテーション支援サーバ4140などのサーバに対するAPIコール(たとえば、APIコール4144)を行うことによって増強することができる。少なくとも一実施例では、アノテーション・モデル・レジストリは、特定の臓器又は異常に対してAI支援アノテーションを実行するように事前に訓練されている、事前に訓練されたモデル4142(たとえば、深層学習モデルなどの機械学習モデル)を記憶することができる。少なくとも一実施例では、これらのモデルは、訓練パイプライン3804を使用することによって、さらに更新することができる。少なくとも一実施例では、事前にインストールされたアノテーション・ツールは、新たなラベル付き臨床データ3712が追加されるときに、経時的に改善することができる。
【0517】
1つ若しくは複数の実施例に関連する推論及び/又は訓練の動作を実行するために、推論及び/又は訓練論理815が使用される。推論及び/又は訓練論理815に関する詳細事項は、
図8A及び/又は
図8Bと併せて本明細書に提供される。
【0518】
少なくとも一実施例では、
図41Bに示す1つ又は複数のシステムは、訓練データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのフレームワークを実施するために利用される。少なくとも一実施例では、
図41Bに示す1つ又は複数のシステムは、
図1~
図7に関連して説明されているものなどの様々なプロセスを実行するために利用される。少なくとも一実施例では、
図41Bに示す1つ又は複数のシステムは、訓練画像などの、訓練データのサブセットを使用して、訓練データの一意性に基づいて、ニューラル・ネットワーク・モデルの1つ又は複数の訓練プロセスの一部としてパラメータを推定するために利用される。
【0519】
少なくとも一実施例は、以下の項に照らして説明することができる。
項1. プロセッサであって、
1つ又は複数のニューラル・ネットワークを訓練するために使用されるデータの一意性に少なくとも部分的に基づいて1つ又は複数のニューラル・ネットワークを訓練するための1つ又は複数の回路
を備える、プロセッサ。
項2. 1つ又は複数の回路が、さらに、データの一意性に少なくとも部分的に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのパラメータを推定するためのものである、項1に記載のプロセッサ。
項3. 1つ又は複数の回路が、さらに、データの間の類似性を算出することによってデータの一意性を示すための1つ又は複数の動作を実行するためのものである、項1から2までのいずれか一項に記載のプロセッサ。
項4. 1つ又は複数の回路が、さらに、データの一意性を、少なくとも、
訓練画像内の関心領域を、データの他の訓練画像内の対応する関心領域と比較すること
によって算出するためのものである、項1から3までのいずれか一項に記載のプロセッサ。
項5. データが画像を含み、1つ又は複数の回路が、さらに、
画像をデータの他の画像と比較することによって画像の一意性を示すスコアを算出することと、
複数のスコアを含むリストにスコアを記憶することと
を行うためのものである、項1から4までのいずれか一項に記載のプロセッサ。
項6. 1つ又は複数の回路が、さらに、
リストに少なくとも部分的に基づいてデータのサブセットを選択することと、
データの選択されているサブセットに基づいて1つ又は複数のニューラル・ネットワークを訓練するためのパラメータを推定するために、プロキシ・ニューラル・ネットワークを使用することであって、プロキシ・ニューラル・ネットワークが、1つ又は複数のニューラル・ネットワークのより小さい表現である、使用することと
を行うためのものである、項1から5のいずれか一項に記載のプロセッサ。
項7. システムであって、
1つ又は複数のニューラル・ネットワークを訓練するために使用されるデータの一意性に少なくとも部分的に基づいて1つ又は複数のニューラル・ネットワークを訓練するための1つ又は複数のプロセッサ
を備える、システム。
項8. 1つ又は複数のプロセッサが、さらに、
データの一意性に基づいてデータのサブセットを識別することと、
データのサブセットに少なくとも部分的に基づいて1つ又は複数のニューラル・ネットワークを訓練するために使用される1つ又は複数の値を推定することと
を行うためのものである、項7に記載のシステム。
項9. 1つ又は複数の値が、学習率、1つ又は複数のニューラル・ネットワークのサイズ、及び、1つ又は複数のニューラル・ネットワークのトポロジのうちの少なくとも1つを含む、項7から8までのいずれか一項に記載のシステム。
項10. 1つ又は複数のプロセッサが、さらに、
データの1つ又は複数の画像から物体を識別することと、
物体を1つ又は複数の画像からの対応する物体と比較することと、
物体と対応する物体との間の類似性を表すインジケータを生成することと、
インジケータをリストに記憶することであって、リストが、ランク付けされた順序で配列されている複数のインジケータを含む、記憶することと
を行うためのものである、項7から9までのいずれか一項に記載のシステム。
項11. 1つ又は複数のプロセッサが、さらに、
リストに基づいてデータのサブセットを識別することと、
データのサブセットに基づいて1つ又は複数のニューラル・ネットワークを訓練するために使用される1つ又は複数の値を推論するために異なるニューラル・ネットワークを使用することであって、異なるニューラル・ネットワークが、1つ又は複数のニューラル・ネットワークの一部分である、使用することと
を行うためのものである、項7から10のいずれか一項に記載のシステム。
項12. 1つ又は複数のニューラル・ネットワークが、U-Netを含み、
異なるニューラル・ネットワークが、U-Netの一部分を含み、残差ブロック、チャネル、及びレベルのうちの少なくとも1つが、U-Netと比較して低減されている、項7から11までのいずれか一項に記載のシステム。
項13. 方法であって、
1つ又は複数のニューラル・ネットワークを訓練するために使用されるデータの一意性に少なくとも部分的に基づいて1つ又は複数のニューラル・ネットワークを訓練するステップ
を含む、方法。
項14. 物体を含む画像内の領域を識別するためにデータを使用するステップと、
物体を含む複数の他の画像内の他の領域を識別するためにデータを使用するステップと、
類似性スコアを生成するために領域と他の領域とを比較するステップと、
類似性スコアをインデックスに追加するステップであって、インデックスは、類似性スコアに基づくランク付けされた順序を含む、追加するステップと
をさらに含む、項13に記載の方法。
項15. 類似性スコアが、領域内の物体と他の領域内の物体との間の非類似性に基づいて、より高いインデックスにランク付けされる、項13から14までのいずれか一項に記載の方法。
項16. インデックスに基づいてデータのサブセットを識別するステップと、
データのサブセットに基づいて1つ又は複数のニューラル・ネットワークを訓練するためのパラメータを推定するために使用される1つ又は複数の値を生成するために異なるニューラル・ネットワークを使用するステップと
をさらに含む、項13から14までのいずれか一項に記載の方法。
項17. データの1つ又は複数の医療画像の間の相互情報に基づいてデータの一意性を示すための動作を実行するステップをさらに含む、項13から16までのいずれか一項に記載の方法。
項18. 1つ又は複数のニューラル・ネットワークが、畳み込みニューラル・ネットワークを含む、項13から17までのいずれか一項に記載の方法。
項19. 命令セットを記憶されている機械可読媒体であって、前記命令セットが、1つ又は複数のプロセッサによって実行されると、前記1つ又は複数のプロセッサに、少なくとも、
1つ又は複数のニューラル・ネットワークを訓練するために使用されるデータの一意性に少なくとも部分的に基づいて1つ又は複数のニューラル・ネットワークが訓練されるようにすること
を行わせる、機械可読媒体。
項20. さらなる命令セットが、1つ又は複数のプロセッサによって実行されると、1つ又は複数のプロセッサに、
データの画像から物体を識別することと、
データの他の画像から物体を識別することと、
画像からの物体と他の画像からの物体との間の非類似性に基づいてスコアを生成することと、
スコアをテーブルに追加することであって、テーブルが、複数のスコアをソートされた順序において含む、追加することと
を行わせる命令をさらに含む、項19に記載の機械可読媒体。
項21. さらなる命令セットが、1つ又は複数のプロセッサによって実行されると、1つ又は複数のプロセッサに、少なくとも、
データのサブセットを選択するためにテーブルを使用することと、
サブセットに基づいて1つ又は複数のニューラル・ネットワークを訓練するために使用される1つ又は複数のハイパー・パラメータを推定するために、1つ又は複数のニューラル・ネットワークとは異なる代替的なニューラル・ネットワークを使用することと
を行わせる命令をさらに含む、項19から20までのいずれか一項に記載の機械可読媒体。
項22. さらなる命令セットが、1つ又は複数のプロセッサによって実行されると、1つ又は複数のプロセッサに、データの間の非類似性を算出することによってデータの一意性を示すための動作を実行させる命令をさらに含む、項19から21までのいずれか一項に記載の機械可読媒体。
項23. データが、オーディオ・データを含む、項19から22までのいずれか一項に記載の機械可読媒体。
項24. 1つ又は複数のニューラル・ネットワークが、U-Netを含む、項19から23までのいずれか一項に記載の機械可読媒体。
項25. システムであって、
1つ又は複数のニューラル・ネットワークを訓練するために使用されるデータの一意性に少なくとも部分的に基づいて1つ又は複数のニューラル・ネットワークを訓練するための1つ又は複数のプロセッサを有する1つ又は複数のコンピュータ
を備える、システム。
項26. 1つ又は複数のプロセッサが、さらに、
データの一意性に基づいて1つ又は複数のニューラル・ネットワークを訓練するためのハイパー・パラメータを算出するためのものである、項25に記載のシステム。
項27. ハイパー・パラメータが、1つ又は複数のニューラル・ネットワークの構造、及び、1つ又はニューラル・ネットワークがどのように訓練されるべきかを示す1つ又は複数の変数を含む、項25から26までのいずれか一項に記載のシステム。
項28. 1つ又は複数のプロセッサが、さらに、
データから得られる画像のセットの間で1つ又は複数の物体を比較することによってスコアを生成することであって、スコアが、第1の画像内の物体と、他の画像内の対応する物体との間の類似性を示す情報を含む、生成することと、
複数のスコアを含むリストにスコアを記憶することと
を行うためのものである、項25から27までのいずれか一項に記載のプロセッサ。
項29. 1つ又は複数のプロセッサが、さらに、複数のスコアに基づいて1つ又は複数のニューラル・ネットワークを訓練するために使用されるパラメータを推定するためのデータの一部分を選択するために、リストを使用するためのものである、項25から28までのいずれか一項に記載のシステム。
項30. 1つ又は複数のニューラル・ネットワークが、再帰ニューラル・ネットワーク(RNN)を含む、項25から29までのいずれか一項に記載のシステム。
項31. データが、医療画像を含む、項25から30までのいずれか一項に記載のシステム。
【0520】
少なくとも一実施例では、単一の半導体プラットフォームとは、単独で単体の半導体ベースの集積回路又はチップを指してもよい。少なくとも一実施例では、マルチ・チップ・モジュールは、オン・チップ動作をシミュレートする接続性が向上した状態で使用されてもよく、従来の中央処理装置(「CPU」)及びバスの実施形態の利用を大幅に改善する。少なくとも一実施例では、ユーザの希望に応じて、半導体プラットフォームとは別々に、又は半導体プラットフォームとの様々な組合せで、様々なモジュールがさらに設置されてもよい。
【0521】
少なくとも一実施例では、
図14に戻って参照すると、機械読取り可能で実行可能なコード若しくはコンピュータ制御論理アルゴリズムの形のコンピュータ・プログラムが、メイン・メモリ1404及び/又は二次ストレージに記憶される。コンピュータ・プログラムは、1つ又は複数のプロセッサによって実行された場合に、少なくとも一実施例による様々な機能をシステム1400が実行できるようにする。少なくとも一実施例では、メモリ1404、ストレージ、及び/又は任意の他のストレージが、コンピュータ読取り可能媒体の考えられる例である。少なくとも一実施例では、二次ストレージとは、フロッピー(登録商標)・ディスク・ドライブ、磁気テープ・ドライブ、コンパクト・ディスク・ドライブ、デジタル多用途ディスク(「DVD」:digital versatile disk)ドライブ、記録デバイス、ユニバーサル・シリアル・バス(「USB」)フラッシュ・メモリなどを表すハード・ディスク・ドライブ及び/若しくはリムーバブル・ストレージ・ドライブなどの任意の好適なストレージ・デバイス又はシステムを指してもよい。少なくとも一実施例では、様々な先の図面のアーキテクチャ及び/又は機能は、CPU1402、並列処理システム1412、CPU1402と並列処理システム1412の両方の機能の少なくとも一部分を実現可能な集積回路、チップセット(たとえば、関連機能を実行するためのユニットとして機能し、販売されるように設計された集積回路のグループなど)、及び/又は集積回路の任意の好適な組合せの文脈において実施される。
【0522】
少なくとも一実施例では、様々な先の図面のアーキテクチャ及び/又は機能は、汎用コンピュータ・システム、回路板システム、エンタテイメント目的専用のゲーム・コンソール・システム、及び特定用途システムなどの文脈において実施される。少なくとも一実施例では、コンピュータ・システム1400は、デスクトップ・コンピュータ、ラップトップ・コンピュータ、タブレット・コンピュータ、サーバ、スーパーコンピュータ、スマート・フォン(たとえば、ワイヤレスの携帯型デバイス)、パーソナル・デジタル・アシスタント(「PDA」)、デジタル・カメラ、車両、頭装着型ディスプレイ、携帯型電子デバイス、モバイル・フォン・デバイス、テレビ、ワークステーション、ゲーム・コンソール、組み込みシステム、及び/又は任意の他のタイプの論理の形をとってもよい。
【0523】
少なくとも一実施例では、並列処理システム1412は、限定することなく、複数の並列処理ユニット(「PPU」)1414、及び関連メモリ1416を含む。少なくとも一実施例では、PPU1414は、相互接続1418及びスイッチ1420又はマルチプレクサを介してホスト・プロセッサ又は他の周辺デバイスに接続される。少なくとも一実施例では、並列処理システム1412は、計算タスクをPPU1414にわたって分配し、これは、たとえば複数のグラフィックス・プロセッシング・ユニット(「GPU」)のスレッド・ブロックにわたる計算タスクの分配の一部として、並列化可能とすることができる。少なくとも一実施例では、メモリは、PPU1414の一部又は全部にわたって共有され、(たとえば、読取り及び/又は書込みアクセスのために)アクセス可能であるが、こうした共有メモリは、PPU1414に常駐しているローカル・メモリ及びレジスタの使用に対して、性能に不利益をもたらすことがある。少なくとも一実施例では、PPU1414の動作は、_syncthreads()などのコマンドを使用することによって同期され、ここで(たとえば、複数のPPU1414にわたって動作している)ブロック内のすべてのスレッドが、進行前にコードのある一定の実行ポイントに到達する。
【0524】
他の変形形態は、本開示の範囲内にある。したがって、開示した技法は、様々な修正及び代替的な構成が可能であるが、それらのうち一定の例示的な実施例が図面に示され、上で詳細に説明されてきた。しかし、特定の1つ又は複数の開示された形に本開示を限定する意図はなく、その反対に、特許請求の範囲に定義される開示の趣旨及び範囲に入るすべての修正形態、代替的な構成、及び等価物を網羅することを意図している。
【0525】
開示される実施例を説明する文脈において(特に、以下の特許請求の範囲の文脈において)「a」及び「an」及び「the」という用語、並びに同様の指示語を使用することは、本明細書に別段の記載のない限り、又は文脈によって明らかに否定されない限り、単数と複数の両方を網羅すると解釈されるべきであり、用語の定義であると解釈されるべきではない。「備える(comprising)」、「有する(having)」、「含む(including)」、「収容する(containing)」という用語は、別段の記載のない限り、オープンエンドの用語(「含むが、これに限定されない」を意味する)と解釈される。「接続される」は、修飾されずに物理的接続を指している場合には、何か介在するものがあったとしても、部分的に又は完全に中に収容される、取り付けられる、又は互いに接合されるものとして解釈される。本明細書において値の範囲を詳述することは、本明細書において別段の記載がない限り、またそれぞれ別々の値が、本明細書に個々に詳述されているかのように明細書に組み込まれていない限り、範囲内に含まれるそれぞれ別々の値を個々に参照する簡潔な方法として機能することを単に意図しているにすぎない。少なくとも一実施例では、「セット」(たとえば、「アイテムのセット」)又は「サブセット」という用語の使用は、文脈によって別段の記載がない、又は否定されていない限り、1つ又は複数の部材を備える空ではない集合として解釈されるべきである。さらに、文脈によって別段の記載がない、又は否定されていない限り、対応するセットの「サブセット」という用語は、対応するセットの厳密なサブセットを必ずしも指すのではなく、サブセットと対応するセットは等しくてもよい。
【0526】
「A、B、及びCのうちの少なくとも1つ」又は「A、B、及びCのうちの少なくとも1つ」という形の言い回しなどの結合語は、別段の具体的な記載のない限り、又は文脈によって明確に否定されていない限り、項目、用語などが、AかBかCである、又はAとBとCのセットのいずれかの空でないサブセットであることを提示するために一般に使用される文脈で理解される。たとえば、3つの部材を有するセットの説明的な例では、「A、B、及びCのうちの少なくとも1つ」並びに「A、B、及びCのうちの少なくとも1つ」という結合句は、次のセットのうちのいずれかを指す:{A}、{B}、{C}、{A、B}、{A、C}、{B、C}、{A、B、C}。したがって、こうした結合語は、ある一定の実施例が、少なくとも1つのA、少なくとも1つのB、及び少なくとも1つのCのそれぞれの存在を必要とすることを全体的に暗示するものではない。さらに、別段の記載のない、又は文脈によって否定されていない限り、「複数」という用語は、複数である状態を示す(たとえば、「複数の項目(a plurality of items)」は複数の項目(multiple items)を示す)。少なくとも一実施例では、複数である項目の数は、少なくとも2つであるが、明示的に、又は文脈によって示されている場合にはそれより多くてもよい。さらに、別段の記載のない、又は文脈からそうでないことが明らかでない限り、「~に基づく」という言い回しは、「少なくとも部分的に~に基づく」を意味し、「~だけに基づく」を意味しない。
【0527】
本明細書に記載のプロセスの動作は、本明細書に別段の記載のない、又は文脈によって明確に否定されない限り、任意の好適な順序で実行することができる。少なくとも一実施例では、本明細書に記載のプロセス(又はその変形及び/又は組合せ)などのプロセスは、実行可能命令で構成された1つ又は複数のコンピュータ・システムの制御下で実行され、1つ又は複数のプロセッサ上で、ハードウェアによって、又はそれらの組合せによって集合的に実行されるコード(たとえば、実行可能な命令、1つ若しくは複数のコンピュータ・プログラム、又は1つ若しくは複数のアプリケーション)として実施される。少なくとも一実施例では、コードは、たとえば1つ又は複数のプロセッサによって実行可能な複数の命令を備えるコンピュータ・プログラムの形で、コンピュータ可読記憶媒体に記憶される。少なくとも一実施例では、コンピュータ可読記憶媒体は、一時的な信号(たとえば、伝播する一時的な電気若しくは電磁送信)を除外するが、一時的な信号のトランシーバ内の非一時的なデータ・ストレージ回路(たとえば、バッファ、キャッシュ、及びキュー)を含む非一時的コンピュータ可読記憶媒体である。少なくとも一実施例では、コード(たとえば、実行可能コード又はソース・コード)は、1つ又は複数の非一時的コンピュータ可読記憶媒体のセットに記憶され、このストレージ媒体には、コンピュータ・システムの1つ又は複数のプロセッサによって実行されたときに(すなわち、実行された結果として)、コンピュータ・システムに本明細書に記載の動作を実行させる実行可能命令が記憶されている(又は、実行可能命令を記憶するための他のメモリを有する)。少なくとも一実施例では、非一時的コンピュータ可読記憶媒体のセットは、複数の非一時的コンピュータ可読記憶媒体を備え、複数の非一時的コンピュータ可読記憶媒体の個々の非一時的なストレージ媒体のうちの1つ又は複数には、すべてのコードがないが、複数の非一時的コンピュータ可読記憶媒体は、集合的にすべてのコードを記憶している。少なくとも一実施例では、実行可能命令は、異なる命令が異なるプロセッサによって実行されるように実行され、たとえば、非一時的コンピュータ可読記憶媒体は命令を記憶し、メインの中央処理装置(「CPU」)は一部の命令を実行し、グラフィックス・プロセッシング・ユニット(「GPU」)は他の命令を実行する。少なくとも一実施例では、コンピュータ・システムの異なる構成要素は、別々のプロセッサを有し、異なるプロセッサは、命令の異なるサブセットを実行する。
【0528】
少なくとも一実施例では、算術論理ユニットは、1つ又は複数の入力を取り込んで結果を生成する組合せ論理回路のセットである。少なくとも一実施例では、算術論理ユニットは、プロセッサによって、加算、減算、又は乗算などの算術演算を実施するために使用される。少なくとも一実施例では、算術論理ユニットは、論理AND/OR又はXORなどの論理演算を実施するために使用される。少なくとも一実施例では、算術論理ユニットは、ステートレスであり、論理ゲートを形成するように配列された半導体トランジスタなどの物理スイッチング構成要素から作成される。少なくとも一実施例では、算術論理ユニットは、内部的に、関連するクロックを有するステートフル論理回路として動作してもよい。少なくとも一実施例では、算術論理ユニットは、関連するレジスタ・セット内に維持されない内部状態を有する非同期論理回路として構築されてもよい。少なくとも一実施例では、算術論理ユニットは、プロセッサによって、プロセッサの1つ又は複数のレジスタに記憶されているオペランドを組み合わせ、プロセッサによって別のレジスタ又はメモリ・ロケーションに記憶することができる出力を生成するために使用される。
【0529】
少なくとも一実施例では、プロセッサによって取り出された命令の処理の結果として、プロセッサは、1つ又は複数の入力又はオペランドを算術論理ユニットに提示し、算術論理ユニットに、算術論理ユニットの入力に提供される命令コードに少なくとも部分的に基づいて結果を生成させる。少なくとも一実施例では、プロセッサによってALUに提供される命令コードは、プロセッサによって実行される命令に少なくとも部分的に基づく。少なくとも一実施例では、ALU内の組合せ論理は、入力を処理し、プロセッサ内のバス上に配置される出力を生成する。少なくとも一実施例では、プロセッサは、プロセッサをクロッキングすることによって、ALUによって生成される結果が所望のロケーションに送られるように、宛先レジスタ、メモリ・ロケーション、出力デバイス、又は出力バス上の出力ストレージ・ロケーションを選択する。
【0530】
本出願の範囲内で、算術論理ユニット又はALUという用語は、オペランドを処理して結果を生成する任意の計算論理回路を指す。たとえば、本明細書内でALUという用語は、浮動小数点ユニット、DSP、テンソル・コア、シェーダ・コア、コプロセッサ、又はCPUを指すことができる。
【0531】
したがって、少なくとも一実施例では、コンピュータ・システムは、本明細書に記載のプロセスの動作を単独で又は集合的に実行する1つ又は複数のサービスを実施するように構成され、こうしたコンピュータ・システムは、動作の実行を可能にする適用可能なハードウェア及び/又はソフトウェアで構成される。さらに、本開示の少なくとも一実施例を実施するコンピュータ・システムは、単一のデバイスであり、別の実施例では、異なるやり方で動作する複数のデバイスを備える分散型のコンピュータ・システムであり、それにより単一のデバイスがすべての動作を実行しないように分散型のコンピュータ・システムが本明細書に記載の動作を実行する。
【0532】
本明細書に提供されるあらゆる例、又は例示的な言葉(たとえば、「など」)の使用は、本開示の実施例をより明らかにすることだけを意図しており、別段の主張のない限り、本開示の範囲に制限を加えるものではない。本明細書のいかなる言葉も、特許請求されていない任意の要素を、本開示の実践に不可欠なものとして示すと解釈されるべきではない。
【0533】
本明細書に引用される出版物、特許出願、及び特許を含むすべての参考文献は、各参考文献が参照により組み込まれることがあたかも個別に明確に示され、その全体が本明細書に記載されたかのように、それと同程度まで参照により本明細書に組み込まれる。
【0534】
明細書及び特許請求の範囲において、「結合される」及び「接続される」という用語が、その派生語とともに使用されてもよい。これらの用語は、互いに同義語として意図されていない場合があることを理解すべきである。むしろ、特定の例では、「接続される」又は「結合される」は、2つ以上の要素が物理的又は電気的に互いに直接又は間接的に接触していることを示すために使用されてもよい。また「結合される」は、2つ以上の要素が直接互いに接触していないが、なお互いに連動又は相互作用することを意味してもよい。
【0535】
別段の具体的な記載のない限り、明細書全体を通して「処理する」、「コンピューティング」、「計算する」、又は「判定する」などの用語は、コンピューティング・システムのレジスタ及び/又はメモリ内の、電子的などの物理的な量として表されるデータをコンピューティング・システムのメモリ、レジスタ、又は他のそのような情報ストレージ・デバイス、送信デバイス、若しくはディスプレイ・デバイス内の物理的な量として同様に表される他のデータになるよう操作及び/又は変換するコンピュータ若しくはコンピューティング・システム、又は同様の電子コンピューティング・デバイスの行為及び/又はプロセスを指す。
【0536】
同様に、「プロセッサ」という用語は、レジスタ及び/又はメモリからの電子データを処理し、その電子データを、レジスタ及び/又はメモリに記憶することができる他の電子データに変換する任意のデバイス、又はデバイスの一部分を指してもよい。非限定的な例として、「プロセッサ」は、CPU又はGPUであってもよい。「コンピューティング・プラットフォーム」は、1つ又は複数のプロセッサを備えてもよい。本明細書で使用する「ソフトウェア」プロセスは、たとえば、タスク、スレッド、及び知的エージェントなど、経時的にワークを実行するソフトウェア及び/又はハードウェアのエンティティを含んでもよい。また、各プロセスは、命令を直列で又は並列で連続的に又は断続的に実行するための複数のプロセスを指してもよい。少なくとも一実施例では、用語「システム」及び「方法」は、1つ又は複数の方法をシステムが具体化することができ、方法がシステムと考えられてもよい場合に限り、本明細書において交換可能に使用される。
【0537】
本明細書では、アナログ・データ又はデジタル・データを得る、取得する、受信する、又はそれらをサブシステム、コンピュータ・システム、又はコンピュータ実施機械に入力することに言及することができる。少なくとも一実施例では、アナログ・データ又はデジタル・データを得る、取得する、受信する、又は入力するプロセスは、関数呼出し、又はアプリケーション・プログラミング・インターフェースへの呼出しのパラメータとしてデータを受信するなど、様々なやり方で実現することができる。少なくとも一実施例では、アナログ・データ又はデジタル・データを得る、取得する、受信する、又は入力するプロセスは、直列又は並列のインターフェースを介してデータを転送することによって実現することができる。少なくとも一実施例では、アナログ・データ又はデジタル・データを得る、取得する、受信する、又は入力するプロセスは、提供するエンティティから取得するエンティティにコンピュータ・ネットワークを介してデータを転送することによって実現することができる。少なくとも一実施例では、また、アナログ・データ又はデジタル・データを提供する、出力する、送信する、送る、又は提示することにも言及することができる。様々な例では、アナログ・データ又はデジタル・データを提供する、出力する、送信する、送る、又は提示するプロセスは、関数呼出しの入力又は出力のパラメータ、アプリケーション・プログラミング・インターフェース若しくはプロセス間通信機構のパラメータとしてデータを転送することによって実現することができる。
【0538】
本明細書の記述は、記載した技法の例示的な実施形態について述べているが、記載した機能を実施するために他のアーキテクチャが使用されてもよく、この他のアーキテクチャは、本開示の範囲内にあることが意図される。さらに、説明を目的として、役割の具体的な分配が定義され得るが、様々な機能及び役割は、状況に応じて異なるやり方で分配及び分割されてもよい。
【0539】
さらに、主題は、構造的特徴及び/又は方法論的動作に特有の言語で説明されてきたが、添付の特許請求の範囲で特許請求される主題は、説明した特有の特徴又は動作に必ずしも限定されないことが理解されるべきである。むしろ、特有の特徴及び動作は、特許請求の範囲を実施する例示的な形として開示されている。
【外国語明細書】