(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2023-12-06
(45)【発行日】2023-12-14
(54)【発明の名称】ディープ・フォレスト・モデルの開発および訓練
(51)【国際特許分類】
G06N 20/20 20190101AFI20231207BHJP
【FI】
G06N20/20
(21)【出願番号】P 2021552716
(86)(22)【出願日】2020-03-06
(86)【国際出願番号】 IB2020051956
(87)【国際公開番号】W WO2020183316
(87)【国際公開日】2020-09-17
【審査請求日】2022-08-24
(32)【優先日】2019-03-12
(33)【優先権主張国・地域又は機関】US
(73)【特許権者】
【識別番号】390009531
【氏名又は名称】インターナショナル・ビジネス・マシーンズ・コーポレーション
【氏名又は名称原語表記】INTERNATIONAL BUSINESS MACHINES CORPORATION
【住所又は居所原語表記】New Orchard Road, Armonk, New York 10504, United States of America
(74)【代理人】
【識別番号】100112690
【氏名又は名称】太佐 種一
(72)【発明者】
【氏名】シュウ、ジン
(72)【発明者】
【氏名】ワン、ルイ
(72)【発明者】
【氏名】マー、シャオ ミン
(72)【発明者】
【氏名】ヤン、ジ フイ
(72)【発明者】
【氏名】ツァン、シゥ イン
(72)【発明者】
【氏名】シュウ、ジン、ジェームス
(72)【発明者】
【氏名】ハン、シー エア
【審査官】▲はま▼中 信行
(56)【参考文献】
【文献】米国特許出願公開第2016/0078625(US,A1)
【文献】米国特許出願公開第2019/0303943(US,A1)
【文献】国際公開第2020/008919(WO,A1)
【文献】特開2016-091306(JP,A)
【文献】国際公開第2020/086604(WO,A1)
【文献】米国特許出願公開第2019/0133482(US,A1)
【文献】三沢翔太郎ほか,汎化性能を考慮したAlternating Decision Forestsの改良に関する一考察,日本経営工学会2015年秋季大会予稿集,公益社団法人日本経営工学会,2015年11月28日,第242~243頁
(58)【調査した分野】(Int.Cl.,DB名)
G06N 3/00 - 99/00
(57)【特許請求の範囲】
【請求項1】
コンピュータの
情報処理により、データ分析用のモデルの開発および訓練方法であって、
1つまたは複数のコンピュータ・プロセッサによって、データ・セットから決定木のランダム・フォレストを成長させることと、
1つまたは複数のコンピュータ・プロセッサによって、前記ランダム・フォレストについてのアウト・オブ・バッグ(OOB)予測を決定することと、
1つまたは複数のコンピュータ・プロセッサによって、前記アウト・オブ・バッグ予測を前記データ・セットに付加することと、
1つまたは複数のコンピュータ・プロセッサによって、OOB予測が付加された前記データ・セットを使用して追加のランダム・フォレストを成長させることと、
1つまたは複数のコンピュータ・プロセッサによって、前記追加のランダム・フォレストの出力を結合器で結合することと、
によってモデルを構築することを含む、方法。
【請求項2】
各ランダム・フォレストは、数値、テキスト、オーディオ、ビデオ、画像データ、位置、音声、音楽、娯楽、医療、金融情報、乗り物、物流、および販売データから成る群から選択されるデータから成長させる、請求項1に記載の方法。
【請求項3】
データ・セットを使用して前記決定木のランダム・フォレストを成長させることは、前記データ・セットから置換を伴って採択されたブートストラップしたサンプルを使用して各木を成長させ、決定木を成長させることを含む、請求項1に記載の方法。
【請求項4】
各ランダム・フォレストのOOB精度を決定することと、前記OOB精度が有意に改善しなくなるまでランダム・フォレストを追加することと、を更に含む、請求項1に記載の方法。
【請求項5】
前記結合器は、ランダム・フォレストおよび勾配ブースティング構造から成る群から選択された構造を含む、請求項1に記載の方法。
【請求項6】
前記モデルは一連の層を備え、各層は単一のランダム・フォレストを備える、請求項1に記載の方法。
【請求項7】
1つまたは複数のコンピュータ・プロセッサによって、
データ・セットを受け取ることと、
前記ランダム・フォレストについてのOOB精度を決定することと、
1つまたは複数のコンピュータ・プロセッサによって、前記追加のランダム・フォレストについてのOOB精度を決定することと、
1つまたは複数のコンピュータ・プロセッサによって、前記ランダム・フォレストおよび前記追加のランダム・フォレストの前記OOB精度を比較することと、
を含む、請求項1に記載の方法。
【請求項8】
1つまたは複数のコンピュータ・プロセッサによって、
データ・セットを受け取ることと、
1つまたは複数のコンピュータ・プロセッサによって、1個のフォレストあたりの決定された木の数およびクラス・ベクトル指定を受け取ることと、
1つまたは複数のコンピュータ・プロセッサによって、前記
データ・セットを使用して第1のフォレストについての前記決定された数の木を成長させることと、
1つまたは複数のコンピュータ・プロセッサによって、前記第1のフォレストについての第1のアウト・オブ・バッグ(OOB)予測を決定することと、
1つまたは複数のコンピュータ・プロセッサによって、OOB予測を前記データ・セットに付加することと、
1つまたは複数のコンピュータ・プロセッサによって、前記第1のフォレストについてのOOB精度を決定することと、
1つまたは複数のコンピュータ・プロセッサによって、OOB予測を付加された前記
データ・セットを使用して追加のフォレストについての前記決定された数の木を成長させることと、
1つまたは複数のコンピュータ・プロセッサによって、前記追加のフォレストについての追加のOOB予測を決定することと、
1つまたは複数のコンピュータ・プロセッサによって、追加のOOB予測を前記データ・セットに付加することと、
1つまたは複数のコンピュータ・プロセッサによって、前記追加のフォレストについての追加のOOB精度を決定することと、
1つまたは複数のコンピュータ・プロセッサによって、前記追加のOOB精度が改善されなくなるまでフォレストを追加することと、
1つまたは複数のコンピュータ・プロセッサによって、前記追加のフォレストの出力を結合することと、によって、各層が単一のランダム・フォレストを含む連続層のモデルを構築すること
を含む、請求項7に記載の方法。
【請求項9】
請求項1~8の何れか1項に記載のステップをコンピュータに実行させる、コンピュータ・プログラム。
【請求項10】
請求項9に記載の前記コンピュータ・プログラムを、コンピュータ可読ストレージ媒体に記録したストレージ媒体。
【請求項11】
請求項1~8の何れか1項に記載の方法のステップを、コンピュータ・ハードウェアによる手段として構成した、コンピュータ・システム。
【発明の詳細な説明】
【技術分野】
【0001】
本開示は一般に、データ分析用のモデルの開発および訓練をするためのシステムおよび方法に関する。本開示は詳細には、データを分析するためのモデルの自動的な開発および訓練をするためにディープ・ランダム・フォレストを使用するシステムに関する。
【背景技術】
【0002】
ディープ・ラーニングは周知のものであるが、その理由の少なくとも一部は、深層ニューラル・ネットワークの適用が特に画像および音声情報を含むタスクにおいて成功していることにある。深層ニューラル・ネットワークには欠点もある。深層ニューラル・ネットワークは訓練用データの必要量が大きくなる場合があり、このため深層ニューラル・ネットワークは小スケールのデータには全く適していない。深層ニューラル・ネットワークは、非常に多くのハイパー・パラメータを含む非常に複雑なモデルである。所望の学習精度に達するようにこれらのパラメータを慎重に調整する必要があり、深層ニューラル・ネットワークの訓練は科学またはエンジニアリングよりもむしろアートのようになっている。
【0003】
Zhouらは、新しいディープ・ラーニングの方法であるgcForest(multi-Grained Cascade Forest)[Z.-H. ZhouおよびF. Ji、Deep forest: towards an alternative to deep neural networks、arXiv:1702.08835v2、2017]を提案した。この方法は非常に重要なディープ・ラーニングの発想、すなわち、カスケードの各層が、先行する層によって生成された特徴情報を受け取り、その結果を次の層へと出力する、ランダム・フォレストのカスケード構造による表現学習の実現を試みるものである。gcForestは深層ニューラル・ネットワークに匹敵するが上述した欠点は緩和されている性能を達成できる。
【0004】
ランダム・フォレストは2001年にBreimanによって提唱された[L. Breiman、Random forests、Machine Learning、45(1):5~32、2001]。これは決定木のアンサンブルである。アンサンブルにおいてこれらの決定木を育成(grow)するとき、特別な処置が適用される。第1に、各木はブートストラップ・サンプルに対して育成(成長させる)される。ブートストラップ・サンプルは訓練データから置換を伴うサンプリングによって取得され、サンプル・サイズは訓練データのサイズと等しい。第2に、各葉ノード(リーフノード)が同じクラスのインスタンスのみを含むまでサンプル上で十分に成長する必要があり、刈込は必要ない。更に重要なことには、木の任意のノードを分割するとき、予測器(予測変数)の一部をランダムに選択し、そこから分割に最良のジニ(gini)値を有するものを選択することである。
【0005】
データ・インスタンスをスコアリングするとき、ランダム・フォレストは、個々の木からの予測を結合するために多数決を用いる。例えば、3個のクラスc1、c2、およびc3を有する標的変数ならびにフォレスト中の1000個の決定木を考慮されたい。3個のクラスに対する投票数がそれぞれ200、300、および500であると仮定する。その場合、ランダム・フォレストはスコアリング中のインスタンスについて、クラス確率のベクトル、すなわち[0.2,0.3,0.5]を報告することになる。c3が最大の予測確率を有するため、そのラベル予測も報告されることになる。
【0006】
インスタンスが訓練インスタンスである場合、ランダム・フォレストはアウト・オブ・バッグ(Out-of-bag)(OOB)予測を生成するオプションを提供する。そのような予測は、ブートストラップ・サンプルにそのインスタンスを含んでいない木の投票を用いて計数される結果である。上記の例を続けると、この訓練用のインスタンスを使用していない400個の木が存在する場合、c1、c2、およびc3の投票数はそれぞれ100、100、および200であり、インスタンスについてのOOB予測(確率ベクトル)は[0.25,0.25,0.50]となる。ラベル予測はc3となるが、この理由はこれが最大の確率に対応しているからである。インスタンス・ラベルを訓練データに対するOOBラベル予測と比較することによって、フォレストについてのOOB精度が算出される。
【0007】
gcForestの方法は、新しい特徴情報を生成するために交差検証を使用する。
交差検証は有効であるが課題ももたらす。第1に、gcForestの方法は、各層に複数のランダム・フォレスト学習器Nを含み、学習器ごとにk分割交差検証を必要とする。したがって、層ごとに合計でN*k個の学習器が必要である。データ・セットが大きい場合、データ・セットのサイズと共に学習器の数が増えるので性能問題が生じる場合があり、また学習器の構築は1個だけでも高価である。非常に強力な演算能力が要求されることになる。第2に、交差検証と訓練データ・セットから導出される検証データ・セットの必要性とに起因して、訓練データが十分に使用されない場合がある。gcForestの方法はデータを訓練サンプルと検証サンプルとに分割し、検証サンプルに対する精度が改善できない場合は訓練を停止する。検証サンプルを使用することで、小さいデータの問題は更に悪化する。
【発明の概要】
【0008】
ハイパー・パラメータの数が減らされ調整要件が緩和されたディープ・ランダム・フォレストを利用するシステム、方法およびコンピュータ・プログラム製品によって、データが分析され得る。一態様では、ランダム・フォレストの層から機械学習モデルが自動的に構築される。ランダム・フォレストについての決定木がデータ・セットから育成される。ランダム・フォレストを使用して、アウト・オブ・バッグ(OOB)予測およびクラス・ラベル予測が決定される。データ・セットの各インスタンスについてのOOB予測は、データ・セットに付加される。モデルはフォレストのより多くの層を追加することによって拡張される。新しいフォレストはそれぞれ、前の層によって生成された、付加を受けた形式のデータ・セットから育成される。最後のデータ付加層の後ろに、モデル出力を作り出すための結合器層が追加される。
【0009】
一態様では、ユーザが提供する単一のハイパー・パラメータが1個のフォレストあたりの木の数である方法を使用することによって、コンピューティング・リソースが低減され得る。この態様では、機械学習モデルは、訓練データ・セットと1個のランダム・フォレストあたりの決定木の指定される数とを受け取ることによって、自動的に構築され得る。次いで訓練データ・セットから指定された数の決定木が育成される。訓練データ・セットの各インスタンスについて、OOB予測およびクラス・ラベルが決定される。OOB予測は各インスタンスの訓練データに付加され、付加を受けたデータ・セットは次いでフォレストの次の層を生成するために使用される。OOBラベル予測を使用して各層のOOB精度が決定される。追加の層によるOOB精度の有意な改善が見られなくなるまで、追加の層が追加される。最後の追加のフォレスト層の出力を統合しモデル出力を提供するための、結合器が追加される。
【0010】
一態様では、フォレストについての決定木が訓練データ・セットから育成される。1個のフォレストあたりの木の数および木を育成するために使用されるクラス・ベクトル次元数が指定される。複数の層を有するモデルの1つの層あたり1個のフォレストが提供され、この結果分類のためのコンピューティング・リソースの不足が低減される。フォレストについてのアウト・オブ・バッグ(OOB)予測が決定される。OOB予測は、各データ・セット・インスタンスに関する新しい特徴としてデータ・セットに付加される。OOB予測を付加することによって、特徴情報が失われる結果となり得るモデルを使用せずに、各層から後続の層に新しい特徴情報を追加するための手段が提供される。フォレストについてOOB精度が決定される。記載されるステップを繰り返すことおよび前の層の付加を受けたデータ・セットを訓練に使用することによって、単一のフォレストの追加の層が、新しい層のOOB精度が有意に改善されなくなるまで追加される。OOB精度の使用によって、分析における交差検証の必要性が排除され、計算リソースが更に低減される。最後のフォレストの出力が結合され、この完成したモデルを使用して訓練データ・セットの外部からのデータが分析される。
【図面の簡単な説明】
【0011】
【
図1】本発明の実施形態に係るシステムの概略図である。
【
図2】本発明の実施形態に係る動作シークエンスを描いたフローチャートである。
【
図3】本発明の実施形態に係るデータ・フローを描いた図である。
【
図4】本発明の実施形態に係るクラウド・コンピューティング環境を描いた図である。
【
図5】本発明の実施形態に係る抽象化モデル層を描いた図である。
【発明を実施するための形態】
【0012】
機械学習用途への深層ニューラル・ネットワーク(DNN)構造の適用は、これまで成功を収めている。DNNはいくつかのハイパー・パラメータを含む場合があり、したがって手元の問題およびデータ・セットに合わせた調整が困難な場合がある。DNNはまた小さいデータ・セットに関連する用途に適用するのが困難な場合もあるが、その理由は、モデルを許容可能な精度レベルまで訓練するために、DNNでは大きいデータ・セットが必要になる場合があるからである。DNN構造の動作の複雑さおよび不透明性の結果、システムは、DNN構造を開発または特定する際に、過度の実験を行うことなく所望のまたは必要な精度を達成するために必要な層数および1つの層あたりのノードの観点から最適な構造を決定するのが、困難なものとなり得る。必要とされているのは、小さいデータ・セットであっても適用可能であり、DNNに関連する手間をかけずに容易に特定および調整でき、最適な精度が達成されると自動的にモデル開発を完了できる、機械学習モデル構造である。
【0013】
開示されるシステム、方法およびコンピュータ製品は、与えられた訓練データ・セットから置き換えて選択されたブートストラップした訓練データ・セットを使用することにより、小さいデータ・セットに適用可能な、機械学習モデルの開発および訓練を提供する。本発明の実施形態は、モデル開発用の単一のハイパー・パラメータ-1個のフォレストあたりのランダム木の数-だけを記述する。本発明の実施形態は、1つの層あたりのランダム・フォレストが単一である単純化された構造を提供し、精度のそれ以上の改善が見込めない場合にはモデル開発を自動的に停止するが、この結果、計算の複雑さが比較的低い正確なモデルが得られる。ある実施形態では、一層あたり2個以上のフォレストを有するモデルが生成され得る。そのようなフォレストは追加のコンピューティング・リソースを必要とし、モデル精度の有意な改善を何ら示さない場合がある。
【0014】
ある実施形態では、データ分析用のモデルの開発および訓練をするためのコンピュータ実装方法は、機械学習モデルの開発および構築から開始され得る。このモデルは分類または回帰分析のために使用できる。モデル開発は、モデルが意図している機械学習タスクと関連付けられた訓練データ・セットから行われる。訓練データは、ネットワークを介して提供されても、センサからローカルで取得されても、またはコンピュータ可読媒体を介して提供されてもよい。
【0015】
データは、数値データ、テキスト・データ、オーディオ・データ、または画像データを含んでもよい。データは、位置、音声、音楽、娯楽、医療、金融情報、乗り物データ、物流データ、販売データ、または機械学習分析に割り当てられる他のデータ・タイプと関連し得る。
【0016】
モデルが必要とする1個のフォレストあたりのランダム決定木の数を指定しなければならない。数はユーザ入力として指定されてもよく、以前のモデル開発の取り組みに基づくデフォルトの量に設定されてもよい。ある実施形態では、数は500個の木として指定されてもよい。ある実施形態では、数は乱数発生器または疑似乱数発生器を使用してランダムに選択されてもよい。1個のフォレストあたりの木の数は、モデルに各層/フォレストが追加される際に一定のままであり得る。ある実施形態では、1個のフォレストあたりの木の数は、層/フォレストごとに異なり得る。
【0017】
各決定木は、訓練データ・セットから置換で選択された、ブートストラップしたデータ・サンプルから育成される。ブートストラップしたサンプルは訓練データ・セットとサイズが等しい。置換を伴う選択は、訓練データ・セットから木を成長させる方法を提供する一方で、訓練データに対する木の過学習(オーバーフィッティング)のリスクを低減する。例として、訓練データ・セット[1,2,3,4,5,6]に関して、置換を伴って選択されたブートストラップしたサンプルは、[1,2,2,3,5,6]で構成される。
【0018】
各木は、木の各ノードが同じクラスのインスタンスしか含まず剪定が必要なくなるまで、その対応するブートストラップしたサンプルから十分に育成される。各木が育成されるにつれクラス予測器のランダム選択によって木ノードの分割が定義され、最低のジニ不純度値を有する部分的セットがノードを定義するために使用される。クラス・ベクトルの次元の数はモデルを構築するためのパラメータとして指定されてもよく、またはモデルは、可能なクラス・ベクトル次元値の範囲を考慮して開発されてもよい。ジニ不純度値は、データ・セットからランダムに選ばれるデータ・インスタンスが適正にラベル付けされると考えられる尤度を反映している。ゼロのジニ不純度値は、インスタンスの不適正なラベリングの確率が0%であることを示し、ノードの全てのインスタンスが同じクラスのものであることを示している。
【0019】
例として、訓練データ・セットは、4個のインスタンス属性d、e、f、およびgと分類ラベルcとを各々備える、1000個のデータ・インスタンスを含む。木を育成する際、システムは、データ・セットを分けるためにインスタンス属性の様々な組合せを使用して根ノードにおいてデータを分割した結果を評価することになる。この評価は、ランダム・データ・インスタンスを不適正にラベリングする尤度が最も低い、すなわちクラス不純度が最低である、属性の組合せを選択する。この例の場合、根ノードは属性dの値に基づいて分けられる。属性dの取り得る各値は根ノードからの枝として定義され、例えば、属性dは4個の異なる値d1、d2、d3、およびd4を有し、したがって根ノードから4本の枝が定義される。次いで評価プロセスは属性dの枝によって定義された各ノードへと進む。ここでもまた、各ノードにおいて枝を定義するために、ランダム・データ・インスタンスを不適正に分類する可能性の最も低いデータ分割を生む属性または属性の組合せが選ばれる。この選択は、データの元の分割によって定義されるノードごとに異なっていてもよい。例えば、d1,e、d2,e、d3,f、およびd4,gという組合せが、次の枝のセットを定義する。2個以上のクラスのラベル付けされたデータを依然として含むが、枝上に最低数を超えるインスタンスも含んで、指定された最高数のノード・レベルに達していないかまたは別の分割によってクラス不純度を改善できない各枝について、このプロセスが継続される。
【0020】
ある実施形態では、ランダム木のフォレストについてアウト・オブ・バッグ(OOB)予測が計算され得る。OOB予測は、ある特定のインスタンスをブートストラップしたデータ・セットの一部として有さなかった全てのランダム木による、その特定の訓練データ・セットのデータ・インスタンスについての投票の総和から導出される次元を備えるベクトルを構成する。例として、3個のクラスc1、c2、およびc3を有するデータを分析する、500個のランダム決定木を有するフォレストを考慮されたい。この例では、訓練データのインスタンス1は、木のうちの200個についてはブートストラップしたデータ・セットの一部ではなかった。これら200個の木によるインスタンス1の評価は、100個のc1としての分類と、c2およびc3の各々についての50個の分類とをもたらした。インスタンス1についてのフォレストに関するOOBベクトルは[0.5,0.25,0.25]になると考えられ、これら3個の次元は、木によって選択されている分類の確率を表す。OOB予測ベクトルからの最高確率のクラスとして、各インスタンスについてのOOBラベル予測も決定される。この例では、OOBラベル予測はc1になると考えられる。
【0021】
ある実施形態では、OOB予測クラス・ベクトルは、インスタンスの新しい特徴としてデータ・インスタンスに付加され得る。この例では、データ・セットのインスタンス1は、ベクトル[0.5,0.25,0.25]が、フォレストによって決定された新しい特徴としてデータ・インスタンスに付加されると考えられる。次いで付加を受けたデータ・セットはモデルの次の層に渡されて、その層の単一のフォレストの決定木を育成するのに使用される。
【0022】
ある実施形態では、フォレスト/層のOOB精度も計算される。OOB精度は、OOBラベル予測とラベル付けされたデータの実際のデータ・ラベルの比較として計算される。この例では、c1とラベル付けされ[0.5,0.25,0.25]のOOB予測を有するインスタンス1は、c1のOOBラベル予測を有し、適正にラベル付けされている。データ・セット全体に対するフォレスト全体のOOB精度は、ラベル予測によって適正に分類されるインスタンスのパーセンテージとして計算される。
【0023】
ある実施形態では、元の層から出力された付加を受けたデータ・セットを新しい訓練データ・セットとして使用して、第2のフォレスト/層が生成される。第2のフォレストについての所定の数のランダム木の各木は、付加を受けた訓練データ・セットから置換を伴って採択されたブートストラップしたデータ・セットから育成される。新しいフォレストについてOOB予測が計算され、これらが訓練データ・セットに更に付加される。新しいフォレストのOOB精度が決定され、モデルの前のフォレスト/層のOOB精度と比較される。
【0024】
反復:フォレスト生成、データ付加、OOB予測、およびOOB精度計算が、現在の層のOOB精度が先行する層のOOB精度から有意に変化しなくなるまで継続される。ある実施形態では、0.005%を超えるOOB精度の変化を有意な改善と見なす。
【0025】
ある実施形態では、各層のフォレストの出力は、使用されるモデルの各層についてデータ・セットの各インスタンスに新しい特徴が追加されるように、データ・セットに付加される。この実施形態では、各データ・インスタンスへの新しい特徴の追加によって、そのインスタンスについての決定された新しい情報を後続の層に関する補助的データ・モデルへと凝縮するのではなく、各インスタンスについての新しい情報が後続の各層に提供される。そのような補助的なモデルは結果的に、モデルのフィデリティ問題に起因して特徴情報の喪失をもたらす場合があるが、その理由はモデルが、特定の新しい特徴情報を各インスタンスに付加するのではなく、データ・インスタンスにわたって特徴情報を平滑化する場合があるためである。
【0026】
新しいフォレストの追加によってOOB精度が有意に改善されなくなった後で、最後の層の出力を結合するための結合器関数が追加される。結合器として別のランダム・フォレストを使用してもよく、このときOOB予測またはOOB精度は計算されない。ある実施形態では、XGBoostなどの勾配ブースティング関数を最後のフォレストの出力を結合するための関数として使用してもよい。結合器の追加は、モデルに追加された最後のフォレストによってデータ・セットに付加された追加の特徴を活用する。結合器を用いずにモデルを利用すれば、データ・セットに追加されたこの最後のOOB予測器を考慮しない結果が生じ、得られる予測精度はより低くなるであろう。結合器を層/フォレストへと追加した後では、機械学習のコンテキストにおける訓練データ・セットの範囲外からのデータを分析するという意図する目的のために、モデルを使用できる。
【0027】
例。
【0028】
ある実施形態では、データ・セットから機械学習モデルが構築される。データ・セットから決定木のランダム・フォレストが育成される。フォレストについてのOOB予測が決定され、データ・セットに付加される。付加を受けたデータ・セットから、追加の決定木のフォレストが育成される。モデルに、追加のフォレストの出力を結合しモデル出力を提供するための結合器が追加される。
【0029】
ある実施形態では、1個のフォレストあたりの決定木の数の指定と共に、訓練データ・セットが受け取られる。データ・セットから、指定された数の決定木を有する第1のランダム・フォレストが育成される。ランダム・フォレストを使用してOOB予測およびクラス・ラベルが決定される。OOB予測は訓練データ・セットに付加される。フォレストのOOB精度が決定される。付加を受けたデータ・セットから、指定された数の決定木を有する追加のランダム・フォレストが育成される。追加のフォレストについて、OOB予測およびクラス・ラベルが決定される。OOB予測は既に付加を受けたデータ・セットに付加される。追加のフォレストのOOB精度が決定され、元のフォレストOOB精度と比較される。フォレストを育成し、OOB予測、クラス・ラベル、および精度を決定し、予測をデータ・セットに付加し、精度を先行するフォレストの精度と比較するプロセスを、新しいフォレストに起因してOOB精度の有意な(<0.005%)改善が見られなくなるまで継続する。最後のフォレストに、モデルの出力を提供するための結合構造が追加される。
【0030】
ある実施形態では、1個のフォレストあたりの決定木の数の指定およびその決定木に関するクラス・ベクトルの指定と共に、訓練データ・セットが受け取られる。次いで複数の連続層を有するモデルが構築される。各層は、モデルを構築する際のコンピューティング・リソース要件を緩和するように、単一のランダム・フォレストを含む。データ・セットから、指定された数の決定木を有するランダム・フォレストが育成される。ランダム・フォレストを使用してOOB予測およびクラス・ラベルが決定される。OOB予測は訓練データ・セットに付加される。フォレストのOOB精度が決定される。付加を受けたデータ・セットから、指定された数の決定木を有する追加のフォレストが育成される。追加のフォレストについて、OOB予測およびクラス・ラベルが決定される。OOB予測は既に付加を受けたデータ・セットに付加される。追加のフォレストのOOB精度が決定され、元のフォレストのOOB精度と比較される。フォレストを育成し、OOB予測、クラス・ラベル、および精度を決定し、予測をデータ・セットに付加し、精度を先行するフォレストの精度と比較するプロセスを、新しいフォレストに起因してOOB精度の有意な(<0.005%)改善が見られなくなるまで継続する。最後のフォレストに、モデルの出力を提供するための結合構造が追加される。
【0031】
実験結果。
【0032】
本発明の実施形態を構築し、標準的なデータ・セットを使用して以下の標準と比較した。ランダム・フォレスト・モデル、XGBoostモデル、およびgcForestモデル。この実験では、1個のフォレストあたりの木の数が500個と指定され、ランダムに選択される属性の数は√d(dはデータ・インスタンス属性の数)であり、各木は純粋な葉ノードまで育成される。ランダム・フォレストおよびXGBoostの結合器の各々を用いて本発明の実施形態を構築した。XGBoostでは、デフォルト設定を使用した。gcForestでは、各層は4個の完全ランダム・フォレストと4個の通常のランダム・フォレストとから成るものであった。3分割のクラス・ベクトルを使用してクラス・ベクトルを生成した。
【0033】
各データ・セットを訓練サンプル(50%)および試験サンプル(50%)へと分割した。訓練サンプルを使用してモデルを訓練し、試験サンプルを使用して訓練されたモデルを評価した。各モデル・タイプの構築、訓練、および評価を、各データ・セットについて5回行った。結果を下の表1に示す。本発明の実施形態は、ランダム・フォレスト結合器を用いる逐次ディープ・フォレスト(IDF)、およびXGBoost結合器を用いるIDFとラベル付けされている。表に示されているように、これらの実施形態の精度は、評価した標準的なデータ・セットのほとんどについて、既知の機械学習モデルIの精度を上回る。
【0034】
【0035】
図1は、開示される発明の実施と関連付けられた例示的なネットワーク・リソースの概略図を提供する。本発明は、命令ストリームを処理する開示されているどの要素のプロセッサにおいても実施され得る。図に示すように、ネットワーク化したクライアント・デバイス110はサーバ・サブシステム102にワイヤレスで接続する。クライアント・デバイス104はネットワーク114を介してサーバ・サブシステム102にワイヤレスで接続する。クライアント・デバイス104および110は、機械学習プログラム(図示せず)を、プログラムを実行するための十分なコンピューティング・リソース(プロセッサ、メモリ、ネットワーク通信ハードウェア)と共に含む。
図1に示すように、サーバ・サブシステム102はサーバ・コンピュータ150を含む。
図1には、本発明の実施形態に係る、ネットワーク化したコンピュータ・システム1000内のサーバ・コンピュータ150の構成要素のブロック図が描かれている。
図1は一実装形態を例示しているに過ぎず、様々な実施形態が実施され得る環境に関してどのような限定も示唆していないことが諒解されるべきである。描かれている環境に対して多くの変更を行うことができる。
【0036】
サーバ・コンピュータ150は、プロセッサ154、キャッシュ162、メモリ158、永続的ストレージ170、通信ユニット152、入力/出力(I/O)インターフェース156、および通信ファブリック140を含んでもよい。通信ファブリック140によって、キャッシュ162、メモリ158、永続的ストレージ170、通信ユニット152、および入力/出力(I/O)インターフェース156の間の通信が提供される。通信ファブリック140は、システム内のプロセッサ(例えばマイクロプロセッサ、通信およびネットワーク・プロセッサ、等)、システム・メモリ、周辺デバイス、および任意の他のハードウェア・コンポーネントの間で、データを渡すまたは情報を制御するあるいはその両方を行うように設計された、任意のアーキテクチャを用いて実装され得る。例えば、通信ファブリック140は、1つまたは複数のバスを用いて実装することができる。
【0037】
メモリ158および永続的ストレージ170は、コンピュータ可読記憶媒体である。この実施形態では、メモリ158はランダム・アクセス・メモリ160(RAM)を含む。一般に、メモリ158は、任意の好適な揮発性または不揮発性のコンピュータ可読記憶媒体を含んでもよい。キャッシュ162は、最近アクセスしたデータおよび最近アクセスしたデータの近くのデータをメモリ158から取り置くことによってプロセッサ154の性能を高める、高速メモリである。
【0038】
本発明の実施形態を実施するために使用されるプログラム命令およびデータ、例えば機械学習プログラム175は、キャッシュ162を介してサーバ・コンピュータ150の対応するプロセッサ154のうちの1つまたは複数によって実行されるまたはアクセスされるあるいはその両方であるように、永続的ストレージ170に記憶される。この実施形態では、永続的ストレージ170は磁気ハード・ディスク・ドライブを含む。磁気ハード・ディスク・ドライブの代替としてまたはこれに加えて、永続的ストレージ170は、ソリッド・ステート・ハード・ドライブ、半導体ストレージ・デバイス、読取り専用メモリ(ROM)、消去可能プログラマブル読取り専用メモリ(EPROM)、フラッシュ・メモリ、またはプログラム命令もしくはデジタル情報を格納できる任意の他のコンピュータ可読記憶媒体を含んでもよい。
【0039】
永続的ストレージ170が使用する媒体は、取り外し可能であってもよい。例えば、永続的ストレージ170のために、取り外し可能なハード・ドライブを使用してもよい。他の例としては、光学および磁気ディスク、サム・ドライブ、ならびにスマート・カードが挙げられ、これらは、やはり永続的ストレージ170の一部である別のコンピュータ可読記憶媒体への転送のために、ドライブに挿入される。
【0040】
通信ユニット152は、これらの例では、クライアント・コンピューティング・デバイス104および110のリソースを含む、他のデータ処理システムまたはデバイスとの通信を行う。これらの例では、通信ユニット152は、1つまたは複数のネットワーク・インターフェース・カードを含む。通信ユニット152は、物理的通信リンクまたはワイヤレス通信リンクの一方または両方の使用を介して、通信を提供してもよい。ソフトウェア配布プログラム、ならびに本発明の実施のために使用される他のプログラムおよびデータは、通信ユニット152を介してサーバ・コンピュータ150の永続的ストレージ170にダウンロードされてもよい。
【0041】
I/Oインターフェース156により、サーバ・コンピュータ150に接続され得る他のデバイスに対するデータの入出力が可能になる。例えば、I/Oインターフェース156は、キーボード、キーパッド、タッチ・スクリーン、マイクロフォン、デジタル・カメラ、または何らかの他の好適な入力デバイス、あるいはそれらの組合せなどの、外部デバイス190への接続を提供し得る。外部デバイス190は、例えばサム・ドライブ、携帯型の光学または磁気ディスク、およびメモリ・カードなどの、携帯型コンピュータ可読記憶媒体も含み得る。本発明の実施形態を実施するために使用されるソフトウェアおよびデータ、例えばサーバ・コンピュータ150上の機械学習プログラム175は、そのような携帯型コンピュータ可読記憶媒体に記憶することができ、I/Oインターフェース156を介して永続的ストレージ170にロードすることができる。I/Oインターフェース156はディスプレイ180にも接続する。
【0042】
ディスプレイ180はユーザにデータを表示するための機構を提供するもので、例えばコンピュータ・モニタであり得る。ディスプレイ180はまた、タブレット・コンピュータのディスプレイなどのタッチ・スクリーンとしても機能し得る。
【0043】
図2は、本発明の実施形態の実施と関連付けられた例示的な動作を説明する、フローチャート200を提供する。プログラム開始後、210において訓練データ・セットが受け取られる。訓練データ・セットは、所望のモデルが意図している機械学習タスクと関連付けられた、任意の形態のデータから構成されてもよい。例としては、数値データ、文字データ、オーディオ・データ、ビデオ・データ、および画像データ、ならびにこれらの組合せが挙げられる。220において、1個のフォレストあたりのランダム木の数が受け取られる。数はユーザによって選ばれても、データ・セットおよび機械学習タスクの性質に応じて自動的に決定されても、乱数または疑似乱数発生器を使用してランダムに選ばれてもよい。230においてランダム木が育成される(ランダム木を成長させる)。各ツリーは、訓練データ・セットと同等のサイズで、訓練データ・セットから置き換え可能に選択されたブートストラップしたデータ・サンプルから成長(育成)させても良い。ブートストラップされるデータは置き換えなしで選択されてもよく、訓練データよりも小さいセットを使用してもよいが、これらの選択は完成したモデルの精度を下げ、モデルを訓練データ・セットに対して過学習(オーバーフィッティング)につながる可能性がある。240において、訓練データの各インスタンスについてのアウト・オブ・バッグ(OOB)予測およびラベル予測が決定される。OOB予測はデータの各インスタンスについての新しい特徴情報を提供するもので、250においてデータ・セットの対応するインスタンスに付加される。260において、完成したフォレストについてOOB精度が決定される。OOB精度は、各インスタンスについてのOOBラベル予測を使用し、フォレストにわたっておよび訓練データ・セットにわたって適正な予測を集約して計算される。270において、OOB精度はモデルの前の層からのOOB精度と比較される。OOB精度の有意な(ある実施形態では、0.005%以上の改善が有意な改善を構成する)改善が見られる場合、方法はステップ230に戻り、別の層/フォレストが育成され、モデルに追加される。ある実施形態では、有意な改善の後で、方法はステップ220に戻り、新しい層/フォレストにおける木の数を決定することができるが、この数は前の層/フォレストとは異なっていてもよい。OOB精度の有意な改善が見られない場合、280において、最後の層/フォレストの出力を集約するための結合器(コンバイナー)がモデルに追加されて使用される。この方法のモデルは、OOB精度を最適化するために必要な数のフォレスト/層だけで構成される。モデルは、モデルによって決定された新しい特徴情報が転送中にも失われないように、すべての新しい特徴情報(OOB予測)を後続の各層に渡す。
【0044】
図3には、モデルが構築される際の訓練データ・セットの展開が説明されている。図に示すように、データ・セット300はデータ・インスタンスXを備えており、フォレスト1 310への入力として提供される。データ・セット300の各データ・インスタンスに関して、フォレスト1 310によってインスタンスXについてのクラス・ベクトルP1が決定され、これがインスタンスXに付加され、付加を受けたデータ・セット320が生み出される。付加を受けたデータ・セット320は次いでフォレスト2 330への入力として提供され、フォレスト2がインスタンスXについてのクラス・ベクトルP2を生み出す。クラス・ベクトルP2はインスタンスに付加されて、付加を受けたデータ・セット340を生み出す。新しいフォレストのOOB精度が前のフォレストと比べて有意に改善されなくなるまで、これが継続される。最後に追加されたフォレストの出力を集約するための結合器360がモデルに追加されるが、この出力は、図では最後のクラス・ベクトルPnを含む付加された全てのクラス・ベクトルを備える、付加を受けたデータ・セット350として表されている。結合器360の出力370は、データ・インスタンスについてのクラス予測を構成する。
【0045】
本開示はクラウド・コンピューティングについての詳細な説明を含むものの、本明細書に記載する教示の実施はクラウド・コンピューティング環境に限定されないことが理解されるべきである。むしろ、本発明の実施形態は、現在知られているまたは今後開発される、任意の他のタイプのコンピューティング環境と関連させて実施可能である。
【0046】
クラウド・コンピューティングは、最小限の管理労力またはサービスのプロバイダとの対話で迅速にプロビジョニングおよびリリースできる、自由に構成可能なコンピューティング・リソース(例えば、ネットワーク、ネットワーク帯域幅、サーバ、処理、メモリ、ストレージ、アプリケーション、仮想マシン、およびサービス)の共有プールへの、便利なオン・デマンドのネットワーク・アクセスを可能にするための、サービス提供のモデルである。このクラウド・モデルは、少なくとも5つの特徴、少なくとも3つのサービス・モデル、および少なくとも4つの配置モデルを含み得る。
【0047】
特徴は以下の通りである。
【0048】
オン・デマンド・セルフ・サービス:クラウド利用者は、サーバ時間およびネットワーク・ストレージなどのコンピューティング機能を、サービスのプロバイダとの人的対話を要することなく、必要に応じて自動的に、一方的にプロビジョニングすることができる。
【0049】
広範なネットワーク・アクセス:機能はネットワークを介して利用可能であり、異種のシンまたはシック・クライアント・プラットフォーム(例えば、携帯電話、ラップトップ、およびPDA)による使用を促進する、標準の機構を通じてアクセスされる。
【0050】
リソース・プーリング:プロバイダのコンピューティング・リソースは、マルチ・テナント・モデルを使用して、様々な物理リソースおよび仮想リソースが需要に応じて動的に割り当ておよび再割り当てされて、複数の利用者にサービスされるようにプールされる。利用者は、より高い抽象化レベル(例えば、国、州、またはデータセンタ)での位置の特定は可能であり得るものの、一般には提供されるリソースの正確な位置は制御できないかまたは把握していないという点で、位置非依存の感覚がある。
【0051】
迅速なエラスティック性:機能を迅速かつ弾性的に、場合により自動的にプロビジョニングして急速にスケール・アウトする、および迅速にリリースして急速にスケール・インすることができる。利用者には、プロビジョニングのために利用可能な機能は多くの場合見掛け上無限であり、任意の時点で任意の量で購入可能である。
【0052】
測定サービス:クラウド・システムは、サービスのタイプ(例えば、ストレージ、処理、帯域幅、およびアクティブなユーザ・アカウント)に適したある程度の抽象化レベルでメータリング機能を活用することによって、リソース使用を自動的に制御および最適化する。リソース使用状況を監視、制御、および報告することができ、利用されているサービスのプロバイダおよび利用者の両方に対して透明性がもたらされる。
【0053】
サービス・モデルは以下の通りである。
【0054】
ソフトウェア・アズ・ア・サービス(SaaS):利用者に提供される機能は、クラウド・インフラストラクチャ上で実行されるプロバイダのアプリケーションを使用することである。これらのアプリケーションは、ウェブ・ブラウザ(例えば、ウェブ・ベースの電子メール)などのシン・クライアント・インターフェースを介して、様々なクライアント・デバイスからアクセス可能である。基礎となるクラウド・インフラストラクチャにはネットワーク、サーバ、オペレーティング・システム、ストレージ、または個々のアプリケーション機能さえも含まれるが、利用者はその管理または制御は行わない。ただし、限定されたユーザ専用のアプリケーション構成設定は例外となり得る。
【0055】
プラットフォーム・アズ・ア・サービス(PaaS):利用者に提供される機能は、利用者が製作または取得した、プロバイダがサポートするプログラミング言語およびツールを使用して製作されたアプリケーションを、クラウド・インフラストラクチャ上に配置することである。基礎となるクラウド・インフラストラクチャにはネットワーク、サーバ、オペレーティング・システム、またはストレージが含まれるが、利用者はその管理または制御は行わず、ただし、配置されたアプリケーションおよび場合によってはアプリケーションのホスティング環境構成を制御することはできる。
【0056】
インフラストラクチャ・アズ・ア・サービス(IaaS):利用者に提供される機能は、オペレーティング・システムおよびアプリケーションを含み得る、利用者が任意のソフトウェアを配置および実行できる、処理、ストレージ、ネットワーク、および他の基本的なコンピューティング・リソースのプロビジョニングである。利用者は、基礎となるクラウド・インフラストラクチャを管理または制御することはないが、オペレーティング・システム、ストレージ、配置されたアプリケーションを制御することはでき、場合によっては、選択されたネットワーキング・コンポーネント(例えば、ホスト・ファイアウォール)の限定的な制御も行える。
【0057】
配置モデルは以下の通りである。
【0058】
プライベート・クラウド:このクラウド・インフラストラクチャはある組織に対してのみ運用される。これはその組織または第三者によって管理されてもよく、オン・プレミスに存在してもオフ・プレミスに存在してもよい。
【0059】
コミュニティ・クラウド:このクラウド・インフラストラクチャはいくつかの組織によって共有され、共通の関心(例えばミッション、セキュリティ要件、ポリシ、およびコンプライアンス考慮事項)を有する特定のコミュニティをサポートする。これはそれらの組織または第三者によって管理されてもよく、オン・プレミスに存在してもオフ・プレミスに存在してもよい。
【0060】
パブリック・クラウド:このクラウド・インフラストラクチャは、一般人または大きな業界グループが利用可能となっており、クラウド・サービスを販売する組織が所有している。
【0061】
ハイブリッド・クラウド:このクラウド・インフラストラクチャは、2つ以上のクラウド(プライベート、コミュニティ、またはパブリック)の複合体であり、これらのクラウドは独自のエンティティのままであるが、データおよびアプリケーションのポータビリティ(例えばクラウド間のロード・バランシングのためのクラウド・バースティング)を可能にする標準化されたまたは独自の技術によって、1つに結合されている。
【0062】
クラウド・コンピューティング環境は、ステートレス性、低結合性、モジュール性、および意味相互運用性に焦点を当てて指向されたサービスである。クラウド・コンピューティングの中心となるのは、相互接続されたノードのネットワークを含むインフラストラクチャである。
【0063】
ここで
図4を参照すると、例示のクラウド・コンピューティング環境50が描かれている。示されているように、クラウド・コンピューティング環境50は、1つまたは複数のクラウド・コンピューティング・ノード10を含み、これを用いて、クラウド利用者が使用するローカルのコンピューティング・デバイス、例えば、携帯情報端末(PDA)もしくは携帯電話54A、デスクトップ・コンピュータ54B、ラップトップ・コンピュータ54C、または自動車コンピュータ・システム54N、あるいはそれらの組合せなどが、通信を行うことができる。ノード10は互いに通信してもよい。これらは、本明細書で上記したような、プライベート、コミュニティ、パブリック、もしくはハイブリッドのクラウド、またはこれらの組合せなどの、1つまたは複数のネットワークにおいて、物理的または仮想的にグループ化されてもよい(図示せず)。このことにより、クラウド・コンピューティング環境50が、インフラストラクチャ、プラットフォーム、またはソフトウェア、あるいはそれらの組合せを、クラウド利用者がローカルのコンピューティング・デバイス上でリソースを保守する必要のないサービスとして提供することが可能になる。
図4に示すいくつかのタイプのローカルのコンピューティング・デバイス54A~54Nは、単に例を示すことを意図していること、ならびに、コンピューティング・ノード10およびクラウド・コンピューティング環境50は、任意のタイプのネットワークまたは(例えばウェブ・ブラウザを使用した)ネットワーク・アドレス指定可能な接続あるいはその両方を介して、任意のタイプのコンピュータ化されたデバイスと通信できることが、理解される。
【0064】
ここで
図5を参照すると、クラウド・コンピューティング環境50(
図4)が提供する1組の機能抽象化層が示されている。
図5に示すコンポーネント、層、および機能は、単に例を示すことを意図しており、本発明の実施形態はこれらに限定されないことが、予め理解されるべきである。描かれているように、以下の層および対応する機能が提供される。
【0065】
ハードウェアおよびソフトウェア層60は、ハードウェアおよびソフトウェアのコンポーネントを含む。ハードウェア・コンポーネントの例には、メインフレーム61、RISC(縮小命令セット・コンピュータ)アーキテクチャ・ベースのサーバ62、サーバ63、ブレード・サーバ64、ストレージ・デバイス65、ならびにネットワークおよびネットワーキング・コンポーネント66が含まれる。いくつかの実施形態では、ソフトウェア・コンポーネントは、ネットワーク・アプリケーション・サーバ・ソフトウェア67とデータベース・ソフトウェア68とを含む。
【0066】
仮想化層70は、以下の仮想エンティティの例を提供し得る抽象化層を提供する。仮想サーバ71、仮想ストレージ72、仮想プライベート・ネットワークを含む仮想ネットワーク73、仮想アプリケーションおよびオペレーティング・システム74、ならびに仮想クライアント75。
【0067】
一例では、管理層80は、以下に記載する機能を提供し得る。リソース・プロビジョニング81は、クラウド・コンピューティング環境内でタスクを実行するために利用されるコンピューティング・リソースおよび他のリソースの、動的な調達を提供する。メータリングおよびプライシング82は、クラウド・コンピューティング環境内でリソースが利用される際のコスト追跡、およびこれらのリソースの消費に対する請求処理またはインボイス処理を行う。一例では、これらのリソースはアプリケーション・ソフトウェア・ライセンスを含んでもよい。セキュリティは、クラウド利用者およびタスクについての身元情報の検証、ならびにデータおよび他のリソースの保護を提供する。ユーザ・ポータル83は、利用者およびシステム管理者にクラウド・コンピューティング環境へのアクセスを提供する。サービス・レベル管理84は、要求されるサービス・レベルが満たされるように、クラウド・コンピューティング・リソースの割り当ておよび管理を提供する。サービス・レベル・アグリーメント(SLA)計画および履行85は、SLAによって将来必要となることが予期されるクラウド・コンピューティング・リソースの、事前調整および調達を提供する。
【0068】
ワークロード層90は、クラウド・コンピューティング環境が利用され得る機能の例を提供する。この層から提供され得るワークロードおよび機能の例には、マッピングおよびナビゲーション91、ソフトウェア開発およびライフサイクル管理92、仮想教室教育配信93、データ分析処理94、トランザクション処理95、ならびに機械学習プログラム175が含まれる。
【0069】
本発明は、任意の可能な技術詳細レベルで組み込まれた、システム、方法、またはコンピュータ・プログラム製品あるいはそれらの組合せであり得る。本発明は、命令ストリームを処理する任意のシングルまたはパラレルのシステムにおいて有益に実施され得る。コンピュータ・プログラム製品は、プロセッサに本発明の態様を実行させるためのコンピュータ可読プログラム命令を有する、コンピュータ可読記憶媒体を含んでもよい。
【0070】
コンピュータ可読記憶媒体は、命令実行デバイスによって使用される命令を保持および保存できる有形のデバイスとすることができる。コンピュータ可読記憶媒体は、例えば、電子ストレージ・デバイス、磁気ストレージ・デバイス、光ストレージ・デバイス、電磁ストレージ・デバイス、半導体ストレージ・デバイス、または以上の任意の好適な組合せであり得るが、これらに限定されない。コンピュータ可読記憶媒体のより具体的な例の非網羅的なリストには、以下、すなわち、ポータブル・コンピュータ・ディスケット、ハード・ディスク、ランダム・アクセス・メモリ(RAM)、読取り専用メモリ(ROM)、消去可能プログラマブル読取り専用メモリ(EPROMもしくはフラッシュ・メモリ)、スタティック・ランダム・アクセス・メモリ(SRAM)、ポータブル・コンパクト・ディスク読取り専用メモリ(CD-ROM)、デジタルバーサタイルディスク(DVD)、メモリ・スティック、フロッピー(R)・ディスク、命令が記録されているパンチ・カードもしくは溝の中の隆起構造などの機械的に符号化されたデバイス、および以上の任意の好適な組合せが含まれる。本明細書において使用されるコンピュータ可読記憶媒体は、電波もしくは他の自由に伝播する電磁波、導波路もしくは他の伝送媒体を通じて伝播する電磁波(例えば、光ファイバ・ケーブルを通過する光パルス)、または配線を介して伝送される電気信号などの、一過性の信号そのものであると解釈されるべきではない。
【0071】
本明細書に記載するコンピュータ可読プログラム命令は、コンピュータ可読記憶媒体からそれぞれのコンピューティング/処理デバイスに、あるいは、ネットワーク、例えば、インターネット、ローカル・エリア・ネットワーク、ワイド・エリア・ネットワーク、もしくはワイヤレス・ネットワーク、またはその組合せを経由して外部のコンピュータまたは外部ストレージ・デバイスに、ダウンロードされ得る。ネットワークは、銅伝送ケーブル、光伝送ファイバ、ワイヤレス伝送、ルータ、ファイアウォール、スイッチ、ゲートウェイ・コンピュータ、またはエッジ・サーバ、あるいはそれらの組合せを備え得る。各コンピューティング/処理デバイス内のネットワーク・アダプタ・カードまたはネットワーク・インターフェースが、ネットワークからコンピュータ可読プログラム命令を受信し、それらのコンピュータ可読プログラム命令を、それぞれのコンピューティング/処理デバイス内のコンピュータ可読記憶媒体に保存されるように転送する。
【0072】
本発明の動作を実行するためのコンピュータ可読プログラム命令は、アセンブラ命令、命令セット・アーキテクチャ(ISA)命令、マシン命令、マシン依存型命令、マイクロコード、ファームウェア命令、状態設定データ、集積回路用の構成データ、または、Smalltalk(R)、C++などのオブジェクト指向プログラミング言語、および「C」プログラミング言語もしくは類似のプログラミング言語などの手続き型プログラミング言語を含む、1つもしくは複数のプログラミング言語の任意の組合せで書かれた、ソース・コードもしくはオブジェクト・コードのいずれか、であり得る。コンピュータ可読プログラム命令は、専らユーザのコンピュータ上で、スタンド・アロン・ソフトウェア・パッケージとして部分的にユーザのコンピュータ上で、部分的にユーザのコンピュータ上でかつ部分的に遠隔のコンピュータ上で、または専ら遠隔のコンピュータもしくはサーバ上で、実行することができる。後者のシナリオでは、遠隔のコンピュータを、ローカル・エリア・ネットワーク(LAN)もしくはワイド・エリア・ネットワーク(WAN)を含む任意の種類のネットワークを介してユーザのコンピュータに接続してもよく、または、外部のコンピュータへの接続を(例えば、インターネット・サービス・プロバイダを利用してインターネットを介して)行ってもよい。いくつかの実施形態では、例えばプログラマブル・ロジック回路、フィールド・プログラマブル・ゲート・アレイ(FPGA)、またはプログラマブル・ロジック・アレイ(PLA)を含む電子回路は、本発明の態様を行うために、コンピュータ可読プログラム命令の状態情報を利用することによって、コンピュータ可読プログラム命令を実行して電子回路を個人化することができる。
【0073】
本明細書には、本発明の実施形態に係る方法、装置(システム)、およびコンピュータ・プログラム製品のフローチャート図またはブロック図あるいはその両方を参照して、本発明の態様が記載されている。フローチャート図またはブロック図あるいはその両方の各ブロック、およびフローチャート図またはブロック図あるいはその両方におけるブロックの組合せを、コンピュータ可読プログラム命令によって実施できることが理解されるであろう。
【0074】
これらのコンピュータ可読プログラム命令は、コンピュータまたは他のプログラム可能データ処理装置のプロセッサを介して実行される命令が、フローチャートまたはブロック図あるいはその両方の1つまたは複数のブロックに指定される機能/動作を実施する手段を作り出すべく、汎用コンピュータ、専用コンピュータ、または他のプログラム可能データ処理装置のプロセッサに提供されてマシンを作り出すものであってよい。これらのコンピュータ可読プログラム命令はまた、命令が保存されたコンピュータ可読記憶媒体が、フローチャートまたはブロック図あるいはその両方の1つまたは複数のブロックに指定される機能/動作の態様を実施する命令を含んだ製品を備えるように、コンピュータ可読記憶媒体に保存され、コンピュータ、プログラム可能データ処理装置、または他のデバイス、あるいはそれらの組合せに特定の方式で機能するように指示できるものであってもよい。
【0075】
コンピュータ可読プログラム命令はまた、コンピュータ、他のプログラム可能装置、または他のデバイスで実行される命令が、フローチャートまたはブロック図あるいはその両方の1つまたは複数のブロックに指定される機能/動作を実施するように、コンピュータによって実行されるプロセスを作り出すべく、コンピュータ、他のプログラム可能データ処理装置、または他のデバイスにロードされ、コンピュータ、他のプログラム可能装置、または他のデバイス上で一連の動作ステップを実行させるものであってもよい。
【0076】
図中のフローチャートおよびブロック図には、本発明の様々な実施形態に係るシステム、方法、およびコンピュータ・プログラム製品の、可能な実装形態のアーキテクチャ、機能性、および動作が説明されている。この関連において、フローチャートまたはブロック図内の各ブロックは、指定された論理機能を実施するための1つまたは複数の実行可能命令を備える、モジュール、セグメント、または命令の一部分を表すことができる。いくつかの代替的実装形態において、ブロック内に記された機能は、図に記されたものとは異なる順序で行われ得る。例えば連続して示される2つのブロックは、実際は実質的に並行して実行され得、またはこれらのブロックは時には関わる機能に応じて、逆の順序で実行され得る。また、ブロック図またはフローチャート図あるいはその両方の各ブロック、およびブロック図またはフローチャート図あるいはその両方におけるブロックの組合せは、指定された機能もしくは動作を行う、または専用ハードウェアとコンピュータ命令の組合せを実行する、専用ハードウェア・ベースのシステムによって実施され得ることも、留意されるであろう。
【0077】
本発明の様々な実施形態の説明は例示の目的で提示されてきたが、網羅的であることも開示される実施形態に限定されることも意図していない。当業者には本発明の範囲および思想から逸脱することなく多くの変更および変形が明らかであろう。本明細書で用いられる専門用語は、実施形態の原理、実際の用途、もしくは市場で見られる技術に対する技術的な改善を最もよく説明するように、または、他の当業者が本明細書において開示される実施形態を理解できるように、選択された。