IP Force 特許公報掲載プロジェクト 2022.1.31 β版

知財求人 - 知財ポータルサイト「IP Force」

▶ シー3, アイオーティー, インコーポレイテッドの特許一覧

特許7565267全履歴動的ネットワーク分析のためのシステムおよび方法
<>
  • 特許-全履歴動的ネットワーク分析のためのシステムおよび方法 図1
  • 特許-全履歴動的ネットワーク分析のためのシステムおよび方法 図2
  • 特許-全履歴動的ネットワーク分析のためのシステムおよび方法 図3
< >
(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-10-02
(45)【発行日】2024-10-10
(54)【発明の名称】全履歴動的ネットワーク分析のためのシステムおよび方法
(51)【国際特許分類】
   G06F 16/28 20190101AFI20241003BHJP
   G06Q 50/10 20120101ALI20241003BHJP
【FI】
G06F16/28
G06Q50/10
【請求項の数】 43
(21)【出願番号】P 2021523899
(86)(22)【出願日】2019-10-30
(65)【公表番号】
(43)【公表日】2022-01-17
(86)【国際出願番号】 US2019058951
(87)【国際公開番号】W WO2020092637
(87)【国際公開日】2020-05-07
【審査請求日】2022-09-26
(31)【優先権主張番号】62/754,786
(32)【優先日】2018-11-02
(33)【優先権主張国・地域又は機関】US
(73)【特許権者】
【識別番号】517423327
【氏名又は名称】シー3.エーアイ, インコーポレイテッド
【住所又は居所原語表記】1400 Seaport Boulevard, Redwood City, CA 94063 U.S.A.
(74)【代理人】
【識別番号】100078282
【弁理士】
【氏名又は名称】山本 秀策
(74)【代理人】
【識別番号】100113413
【弁理士】
【氏名又は名称】森下 夏樹
(74)【代理人】
【識別番号】100181674
【弁理士】
【氏名又は名称】飯田 貴敏
(74)【代理人】
【識別番号】100181641
【弁理士】
【氏名又は名称】石川 大輔
(74)【代理人】
【識別番号】230113332
【弁護士】
【氏名又は名称】山本 健策
(72)【発明者】
【氏名】オールソン, ヘンリック
(72)【発明者】
【氏名】サンディリヤ, ウマシャンカール
(72)【発明者】
【氏名】ハギギ, メヘディ マーソウミー
【審査官】甲斐 哲雄
(56)【参考文献】
【文献】特開2015-184704(JP,A)
【文献】特開2017-005891(JP,A)
【文献】特表2010-541426(JP,A)
【文献】特開2014-230041(JP,A)
【文献】特開2017-162450(JP,A)
【文献】特開2008-027315(JP,A)
(58)【調査した分野】(Int.Cl.,DB名)
G06F 16/00-16/958
G06Q 10/00-99/00
(57)【特許請求の範囲】
【請求項1】
システムの履歴状態を決定するために、1つ以上のプロセッサを有するコンピュータによって実装される方法であって、前記方法は、
前記1つ以上のプロセッサが、複数の異なるデータソースから前記システムについてのデータを取得することと、
前記1つ以上のプロセッサが、前記データを使用して、前記システムのための全履歴動的ネットワーク(FHDN)を構築することであって、前記FHDNは、前記システムを表すグラフを備え、前記グラフは、
(1)前記システムの要素を表す複数のノードであって、動的に変化することが可能である複数のノードと、
(2)前記ノードを接続する複数のエッジであって、前記複数のエッジの各エッジは、前記複数のノードのノード対の間の関係を表し、前記複数のエッジは、動的に変化することが可能である、複数のエッジと、
(3)前記複数のノードのそれぞれと関連付けられる第1の時系列と、
(4)前記複数のエッジのそれぞれと関連付けられる第2の時系列と
を備え、前記第1の時系列は、経時的な前記複数のノードのアズオペレーテッド状態の変化を示し、前記第2の時系列は、経時的な前記複数のエッジのアズオペレーテッド状態の変化を示す、ことと、
前記1つ以上のプロセッサが、履歴時間インスタンスに関する前記FHDNのクエリに応答して、前記履歴時間インスタンスに関する前記システムの動作状態のグラフィカル表現を提供することと
を含む、方法。
【請求項2】
前記システムの前記アズオペレーテッド状態の変化は、ノードの追加、ノードの除去、エッジの追加、および、エッジの除去を含む、請求項1に記載の方法。
【請求項3】
前記システムの前記動作状態は、前記履歴時間インスタンスにおける前記システムのサブセットに関する厳密なグラフィカル状態を備える、請求項1に記載の方法。
【請求項4】
前記FHDNの履歴動的挙動が、異なる時点で捕捉される前記システムのスナップショットのシーケンスを分析することなく前記1つ以上のプロセッサによって決定される、請求項1に記載の方法。
【請求項5】
前記FHDNは、前記履歴時間インスタンスに関するクエリが、前記履歴時間インスタンスにおける全ネットワークインスタンス化を要求することなく回答されることを可能にする、請求項1に記載の方法。
【請求項6】
前記複数のノードおよびエッジは、(1)所与の時間インスタンスにおいて開始して前記システム内に以前に存在していた全てのノードおよびエッジと、(2)前記システム内に現在存在している全てのノードおよびエッジとを備える、請求項1に記載の方法。
【請求項7】
選択されたノードに関する前記第1の時系列または選択されたエッジに関する前記第2の時系列は、前記システム内の前記選択されたノードまたはエッジの追加または除去の時間を備える、請求項1に記載の方法。
【請求項8】
前記第1の時系列は、選択されたノードにおいて起こる事象または変化に基づいており、前記第2の時系列は、選択されたエッジにおいて起こる事象または変化に基づいている、請求項1に記載の方法。
【請求項9】
前記履歴時間インスタンスにおける前記システムの前記動作状態は、前記複数のノードにわたって反復し、前記第1の時系列および前記第2の時系列を通して探索する探索アルゴリズムを使用することによって取得される、請求項1に記載の方法。
【請求項10】
前記探索アルゴリズムは、必要に応じて特定のノードまたはエッジのステータスのみをチェックするように構成される反復グラフ探索アルゴリズムを備える、請求項9に記載の方法。
【請求項11】
前記クエリは、所与の時間インスタンスにおけるノードのサブセットについての情報要求を備え、前記探索アルゴリズムは、前記ノードのサブセットにのみ直接クエリを行うように構成される、請求項9に記載の方法。
【請求項12】
前記1つ以上のプロセッサが、ブロッキング技法を利用し、任意の所与の時点のインスタンスに関してメモリ内に前記FHDNの接続されたグラフィカル領域全体をキャッシュすることをさらに含む、請求項1に記載の方法。
【請求項13】
前記FHDNの前記接続されたグラフィカル領域は、他のノードから到達不能ないかなるノードも含有しない、請求項12に記載の方法。
【請求項14】
前記システムは、配電システムを備える、請求項1に記載の方法。
【請求項15】
前記配電システムは、複数の配電フィーダを備える、請求項14に記載の方法。
【請求項16】
前記ステムの前記動作状態は、前記履歴時間インスタンスにおける前記複数の配電フィーダの厳密なグラフィカル状態を備える、請求項15に記載の方法。
【請求項17】
前記ステムの前記動作状態は、前記履歴時間インスタンスにおける前記配電フィーダのサブセットの厳密なグラフィカル状態を備える、請求項15に記載の方法。
【請求項18】
前記FHDNは、前記履歴時間インスタンスに関する前記クエリが、前記履歴時間インスタンスにおける前記配電システムの全ネットワークインスタンス化を要求することなく回答されることを可能にする、請求項14に記載の方法。
【請求項19】
(1)前記複数のノードおよびエッジと、(2)前記第1の時系列および前記第2の時系列とは、前記複数の配電フィーダおよび各フィーダ内の前記接続されたノードおよびブランチと関連付けられる、請求項15に記載の方法。
【請求項20】
選択されたノードに関する前記第1の時系列または選択されたエッジに関する前記第2の時系列は、前記システム内の前記選択されたノードまたはエッジの追加または除去の時間を備える、請求項19に記載の方法。
【請求項21】
前記選択されたノードまたはエッジの追加または除去は、前記配電システム内のブレーカスイッチの開または閉に対応し、前記ブレーカスイッチは、前記選択されたエッジと関連付けられる、請求項20に記載の方法。
【請求項22】
前記クエリは、任意の所与の時間インスタンスにおける1つ以上の選択された配電フィーダの電気構成のクエリを備える、請求項19に記載の方法。
【請求項23】
グラフ探索アルゴリズムが、前記1つ以上の選択された配電フィーダ内に含有される前記ノードおよびエッジのみを探索することによって、任意の所与の時間インスタンスにおける前記1つ以上の選択された配電フィーダの厳密な状態にクエリを行うために前記1つ以上のプロセッサによって利用される、請求項22に記載の方法。
【請求項24】
前記グラフ探索アルゴリズムは、必要に応じて前記選択された配電フィーダ内に含有される前記ノードおよびエッジのテータスのみにクエリを行うように構成される、請求項23に記載の方法。
【請求項25】
前記グラフ探索アルゴリズムは、他の選択されていない配電フィーダ内に含有される前記ノードおよびエッジにクエリを行うように構成されない、請求項24に記載の方法。
【請求項26】
前記FHDNは、複数の行および列を備える2次元行列内に記憶され、前記複数の行の各行は、前記複数のノードのうちの1つを表し、前記複数の列の各列は、前記複数のエッジのうちの1つを表し、前記複数のエッジのうちの1つを表す前記2次元行列内の行および列におけるエントリは、前記列によって表される前記エッジが、前記行によって表される前記ノードに接続されているかどうかを示す、請求項1に記載の方法。
【請求項27】
前記エントリは、前記第1の時系列および前記第2の時系列のうちの一方または両方の一部である、請求項26に記載の方法。
【請求項28】
前記FHDNは、グラフデータベース内に記憶される、請求項1に記載の方法。
【請求項29】
前記グラフデータベースは、前記複数のノードの間の複数のポインタを備え、各ポインタは、前記複数のエッジのうちの1つを表す、請求項28に記載の方法。
【請求項30】
前記複数のポインタは、双方向性であるポインタを備える、請求項29に記載の方法。
【請求項31】
前記複数のポインタは、一方向性であるポインタを備える、請求項29に記載の方法。
【請求項32】
前記複数のエッジは、ノードの間の接続または関係の強さを示す重みを備える、請求項1に記載の方法。
【請求項33】
前記システムは、任意の製造企業に関する材料表を備える、請求項1に記載の方法。
【請求項34】
前記システムは、サプライチェーン流通ネットワークを備える、請求項1に記載の方法。
【請求項35】
前記システムは、複数のユーザのソーシャルネットワークを備える、請求項1に記載の方法。
【請求項36】
前記システムは、複数の原子と、複数の結合とを備える分子であり、前記複数のノードは、前記複数の原子を表し、前記複数のエッジは、前記複数の結合を表す、請求項1に記載の方法。
【請求項37】
前記システムは、掘削資産と、精製資産と、パイプライン資産とを備える石油およびガス処理パイプラインであり、前記複数のノードは、前記掘削資産および前記精製資産を表し、前記複数のエッジは、前記パイプライン資産を表す、請求項1に記載の方法。
【請求項38】
前記システムは、ニューロンと、それらの接続とを備える生物学的ニューラルネットワークである、請求項1に記載の方法。
【請求項39】
前記システムは、道路ネットワークである、請求項1に記載の方法。
【請求項40】
前記FHDNは、異なる時点における前記システムのスナップショットを要求することなく構築される、請求項1に記載の方法。
【請求項41】
前記システムのFHDNを構築することは、前記複数のノード、前記複数のエッジ、ならびに、前記第1の時系列および前記第2の時系列を表すデータオブジェクトを生成することを含む、請求項1に記載の方法。
【請求項42】
システムの履歴状態を決定するためのシステムであって、前記システムは、
複数の異なるデータソースから前記システムについてのデータを連続的に取得するためのデータ集約コンポーネントと、
ネットワークグラフ化コンポーネントであって、
前記データを使用して、前記システムの全履歴動的ネットワーク(FHDN)を構築することであって、前記FHDNは、
(1)動的に変化することが可能である複数のノードと、
(2)前記ノードを接続する複数のエッジと、
(3)前記複数のノードのそれぞれと関連付けられる第1の時系列と、
(4)前記複数のエッジのそれぞれと関連付けられる第2の時系列と
を備え、前記第1の時系列は、経時的な前記複数のノードのアズオペレーテッド状態の変化を示し、前記第2の時系列は、経時的な前記複数のエッジのアズオペレーテッド状態の変化を示し、前記FHDNは、異なる時点における前記システムのスナップショットを要求することなく構築される、ことと、
履歴時間インスタンスに関する前記FHDNのクエリに応答して、前記履歴時間インスタンスに関する前記システムの動作状態のグラフィカル表現を提供することと
を行うように構成される、ネットワークグラフ化コンポーネントと
を備える、システム。
【請求項43】
非一過性コンピュータ可読媒体であって、前記非一過性コンピュータ可読媒体は、命令を記憶しており、前記命令は、1つ以上のサーバによって実行されると、前記1つ以上のサーバに動作を実施させ、前記動作は、
複数の異なるデータソースからシステムについてのデータを取得することと、
前記データを使用して、前記システムの全履歴動的ネットワーク(FHDN)を構築することであって、前記FHDNは、
(1)動的に変化することが可能である複数のノードと、
(2)前記ノードを接続する複数のエッジと、
(3)前記複数のノードのそれぞれと関連付けられる第1の時系列と、
(4)前記複数のエッジのそれぞれと関連付けられる第2の時系列と
を備え、前記第1の時系列は、経時的な前記複数のノードのアズオペレーテッド状態の変化を示し、前記第2の時系列は、経時的な前記複数のエッジのアズオペレーテッド状態の変化を示し、前記FHDNは、異なる時点における前記システムのスナップショットを要求することなく構築される、ことと、
履歴時間インスタンスに関する前記FHDNのクエリに応答して、前記履歴時間インスタンスに関する前記システムの動作状態のグラフィカル表現を提供することと
を含む、非一過性コンピュータ可読媒体。
【発明の詳細な説明】
【技術分野】
【0001】
(関連出願)
本願は、参照することによって本明細書に完全に組み込まれる、2018年11月2日に出願された米国仮特許出願第62/754,786号の優先権を主張する。
【背景技術】
【0002】
ネットワーク科学は、大規模かつ複雑なネットワークの研究である。そのようなネットワークは、コンピュータネットワーク、サイバーフィジカルシステム、電気通信ネットワーク、生物学的ネットワーク、認知および意味論ネットワーク、およびソーシャルネットワークを含み得る。そのようなネットワークでは、明確に異なる要素または行為者(actor)は、ノード(または頂点)によって表されることができ、要素または行為者の間の接続は、リンク(またはエッジ)によって表されることができる。
【0003】
ネットワークは、グラフによって図示されることができる。いくつかの産業および企業は、静的グラフィカル分析のために設計されるネットワークおよびグラフ処理アプローチのアプリケーションを開発している。例えば、Google Mapsは、国の道路ネットワークの現在のスナップショットにわたって複雑なルートを計画することができ、Facebookは、そのソーシャルネットワークを大きいグラフとして表すことができ、そのようなグラフのクエリを行うためのGraphQL言語を開発している。これらのグラフは、ノードおよびエッジが、経時的に追加および除去されることができ、ノードまたはエッジの特徴が、変化し得るため、従来的意味での「静的」ではない。しかしながら、これらのグラフは、動的プロセスの全履歴を記憶していない。例えば、Google Mapsは、具体的時間(例えば、2013年4月23日午後7時45分(PT))および地域における交通の精密な状態を図示することができない場合があり、Facebookは、例えば、1年前からの恣意的な時点におけるそのソーシャルネットワークグラフの状態を図示することができない場合がある。これらのネットワークは、動的であるが、記憶エンジンは、これが、ネットワークの現在の状態およびある所定の時点におけるネットワークの以前の状態のみを示し、それらが、任意の恣意的な時点におけるグラフにクエリを行う能力を提供しない点において静的である。
【発明の概要】
【課題を解決するための手段】
【0004】
ネットワークの履歴状態を決定するための現在の技法は、ネットワークのグラフのスナップショットを周期的に撮影し、次いで、履歴動的挙動を理解するためにこれらのスナップショットのシーケンスを分析するステップを含み得る。しかしながら、これは、異なるネットワークドメインのために十分ではない場合がある。例えば、エネルギー分配システム等のモノのインターネット(IoT)用途に関して、電気の流動は、ネットワークの精密な物理的接続によって決定され得、カスケード障害のような複雑な事象を理解することは、電気ネットワーク内のスイッチおよび接続性の秒単位の精密な構成の知識を要求し得る。
【0005】
本明細書に提供されるものは、動的ネットワークの全履歴を分析および理解するための方法およびシステムである。全てのネットワークは、ネットワークのエッジおよびノードが、ネットワークが、発展するにつれて、常に追加される、除去される、または状態を変化させ得るため、そのコアにおいて、動的なオブジェクトであり得る。例えば、電力グリッドでは、物理的資産(電線、変圧器等)が、経時的に追加および除去され、スイッチが、開および閉にされ、これらの変化はそれぞれ、ネットワークの結果として生じる物理的流動性質を根本的に改変する。例えば、交通ネットワークでは、道路が、開放および閉鎖され、所与の道路上の交通パターンが、経時的に急速に変化する。そのようなネットワークについて効果的に推論するために、ネットワークが経時的に変化する様子を正確に捕捉し得るモデルの必要性が、存在する。加えて、クエリが、任意の所与の時刻におけるネットワークの精密な状態について行われ得る、動的ネットワークのグラフィカル分析の必要性が、存在する。
【0006】
ある側面では、動的ネットワークの履歴状態を決定するコンピュータ実装方法は、複数の異なるデータソースからシステムと関連付けられるデータを連続的に取得するステップと、データを使用して、本システムの全履歴動的ネットワーク(FHDN)を構築するステップであって、FHDNは、(1)動的に変化することが可能である、複数のノードと、(2)ノードを接続する、複数のエッジであって、エッジは、動的に変化することが可能である、複数のエッジと、(3)複数のノードおよびエッジのそれぞれと関連付けられる、時系列とを備える、ステップと、履歴時間インスタンスに関するFHDNのクエリに応答して、該履歴時間インスタンスに関する本システムの状態を提供するステップとを含む。時系列は、経時的な複数のノードおよび複数のエッジの状態の変化を示してもよい。FHDNは、異なる時点における本システムのスナップショットの周期的捕捉および記憶を要求することなく構築されてもよい。
【0007】
いくつかの実施形態では、本システムの状態は、履歴時間インスタンスにおける、アズオペレーテッド状態におけるネットワーク全体のグラフィカル状態を備える。いくつかの実施形態では、本システムの状態は、履歴時間インスタンスにおけるネットワークのサブセットに関するグラフィカル状態を備える。ネットワークまたはネットワークのサブセットのグラフィカル状態は、厳密なグラフィカル状態、実質的に厳密なグラフィカル状態、またはおおよそのグラフィカル状態であってもよい。いくつかの実施形態では、FHDNは、異なる時点におけるネットワークのスナップショットの周期的捕捉および記憶を要求することなく構築される。いくつかの実施形態では、FHDNの履歴動的挙動が、異なる時点で捕捉されるネットワークのスナップショットのシーケンスを分析することなく決定される。いくつかの実施形態では、FHDNは、履歴時間インスタンスに関するクエリが、該履歴時間インスタンスにおける全ネットワークインスタンス化を要求することなく回答されることを可能にする。
【0008】
いくつかの実施形態では、複数のノードおよびエッジは、(1)任意の所与の時刻におけるネットワーク内に以前に存在していた全てのノードおよびエッジと、(2)ネットワーク内に現在存在している全てのノードおよびエッジとを備える。いくつかの実施形態では、選択されたノードまたはエッジに関する時系列は、ネットワーク内の選択されたノードまたはエッジに関する追加または除去の精密な時間を備える。いくつかの実施形態では、時系列は、選択されたノードまたはエッジにおいて起こる事象または変化に基づく。
【0009】
いくつかの実施形態では、履歴時間インスタンスにおける本システムの状態は、複数のノードにわたって反復し、時系列を通して探索する、探索アルゴリズムを使用することによって取得される。いくつかの実施形態では、探索アルゴリズムは、必要に応じて選択されたノードまたはエッジのステータスのみをチェックするように構成される、反復グラフ探索アルゴリズムを備える。いくつかの実施形態では、クエリは、所与の時刻におけるノードのサブセットについての情報要求を備え、探索アルゴリズムは、他の不必要なノードにクエリを行うことなく、ノードのサブセットにのみ直接クエリを行うように構成される。
【0010】
いくつかの実施形態では、本方法はさらに、ブロッキング技法を利用し、任意の所与時刻に関してメモリ内にFHDNの接続されたグラフィカル領域全体をキャッシュするステップを含む。いくつかの実施形態では、ブロッキング技法は、標準ブロッキング、トークンブロッキング、または属性クラスタリングブロッキングを備える。いくつかの実施形態では、メモリ内の接続されたグラフィカル領域全体のキャッシュは、探索が、従来のネットワークグラフ化技法と比較して、より迅速に実行されることを可能にする。
【0011】
いくつかの実施形態では、FHDNの使用は、従来のネットワークグラフ化技法と比較して、数桁のメモリ/記憶域の節約を可能にする。いくつかの実施形態では、記憶域の要件は、従来のネットワークグラフ化技法と比較して、少なくとも約1~3桁低減されることができる。ある実施形態では、記憶域の要件は、3桁を上回って、または1桁を下回って低減されることができる。
【0012】
いくつかの実施形態では、本システムは、配電システムを備える。いくつかの実施形態では、配電システムは、複数の配電フィーダを備える。いくつかの実施形態では、配電システムの状態は、履歴時間インスタンスにおける複数の配電フィーダのグラフィカル状態を備える。いくつかの実施形態では、配電システムの状態は、履歴時間インスタンスにおける配電フィーダのサブセットのグラフィカル状態を備える。いくつかの実施形態では、FHDNは、履歴時間インスタンスに関するクエリが、該履歴時間インスタンスにおける配電システムの全ネットワークインスタンス化を要求することなく回答されることを可能にする。
【0013】
いくつかの実施形態では、(1)複数のノードおよびエッジおよび(2)時系列は、複数の配電フィーダおよび各フィーダ内の接続されたノードおよびブランチと関連付けられる。いくつかの実施形態では、選択されたノードまたはエッジに関する時系列は、ネットワーク内の選択されたノードまたはエッジに関する追加または除去の精密な時間を備える。いくつかの実施形態では、選択されたエッジの追加または除去は、配電システム内のブレーカスイッチの開または閉に対応し、該ブレーカスイッチは、選択されたエッジと関連付けられる。
【0014】
いくつかの実施形態では、クエリは、任意の所与の時刻における1つ以上の選択された配電フィーダの精密な電気構成のクエリを備える。いくつかの実施形態では、グラフ探索アルゴリズムが、1つ以上の選択された配電フィーダ内に含有されるノードおよびエッジのみを探索することによって、任意の所与の時刻における1つ以上の選択された配電フィーダの状態にクエリを行うために利用される。
【0015】
いくつかの実施形態では、グラフ探索アルゴリズムは、必要に応じて選択された配電フィーダ内に含有されるノードおよびエッジのステータスのみにクエリを行うように構成される。いくつかの実施形態では、グラフ探索アルゴリズムは、他の選択されていない配電フィーダ内に含有されるノードおよびエッジにクエリを行うように構成されない。いくつかの実施形態では、ネットワークは、6年の周期にわたってログをとられる、280,000個のグリッドノードと、320,000個のエッジと、1,000,000個の開/閉時系列事象とを備える。上記の実施形態では、FHDNは、履歴時間インスタンスにおけるネットワークの任意の部分におけるクエリが、従来のグラフ化技法を使用する2.1TBと比較して、13.4MBのみの記憶域を要求しながら回答されることを可能にする。いくつかの実施形態では、本システムは、任意の製造企業に関する材料表を備える。いくつかの実施形態では、本システムは、サプライチェーン流通ネットワークを備える。いくつかの実施形態では、本システムは、複数のユーザから成る、ソーシャルネットワークを備える。
【0016】
別の側面では、動的ネットワークの履歴状態を決定するためのシステムは、複数の異なるデータソースからシステムと関連付けられるデータを連続的に取得するためのデータ集約コンポーネントと、ネットワークグラフ化コンポーネントであって、データを使用して、本システムの全履歴動的ネットワーク(FHDN)を構築し、FHDNは、(1)動的に変化することが可能である、複数のノードと、(2)ノードを接続する、複数のエッジであって、エッジは、動的に変化することが可能である、複数のエッジと、(3)複数のノードおよびエッジのそれぞれと関連付けられる、時系列とを備え、履歴時間インスタンスに関するFHDNのクエリに応答して、該履歴時間インスタンスに関する本システムの状態を提供するように構成される、ネットワークグラフ化コンポーネントとを備える。
【0017】
別の側面では、非一過性コンピュータ可読媒体は、1つ以上のサーバによって実行されると、1つ以上のサーバに、複数の異なるデータソースからシステムと関連付けられるデータを連続的に取得するステップと、データを使用して、本システムの全履歴動的ネットワーク(FHDN)を構築するステップであって、FHDNは、(1)動的に変化することが可能である、複数のノードと、(2)ノードを接続する、複数のエッジであって、エッジは、動的に変化することが可能である、複数のエッジと、(3)複数のノードおよびエッジのそれぞれと関連付けられる、時系列とを備える、ステップと、履歴時間インスタンスに関するFHDNのクエリに応答して、該履歴時間インスタンスに関する本システムの状態を提供するステップとを含む、方法を実施させる命令を記憶する。
【0018】
本開示の付加的側面および利点が、本開示の例証的実施形態のみが、示され、説明される、以下の詳細な説明から当業者に容易に明白となるであろう。理解されるであろうように、本開示は、他の異なる実施形態が可能であり、そのいくつかの詳細は、全て本開示から逸脱することなく、種々の明白な点において修正が可能である。故に、図面および説明は、本質的に例証的と見なされ、制限的と見なされるものではない。
(参照による組み込み)
【0019】
本明細書に言及される全ての刊行物、特許、および特許出願は、各個々の刊行物、特許、または特許出願が具体的かつ個々に参照することによって組み込まれることが示される場合と同程度に、参照することによって本明細書に組み込まれる。参照することによって組み込まれる刊行物および特許または特許出願が、本明細書に含有される開示と矛盾する範囲について、本明細書は、任意のそのような矛盾する資料に対して優先および/または先行することを意図している。
本発明は、例えば、以下の項目を提供する。
(項目1)
システムの履歴状態を決定するためのコンピュータ実装方法であって、前記方法は、
複数の異なるデータソースから前記システムについてのデータを取得することと、
前記データを使用して、前記システムの全履歴動的ネットワーク(FHDN)を構築することであって、前記FHDNは、(1)動的に変化することが可能である複数のノードと、(2)前記ノードを接続する複数のエッジであって、前記複数のエッジは、動的に変化することが可能である、複数のエッジと、(3)前記複数のノードおよび前記複数のエッジのそれぞれと関連付けられる時系列であって、前記時系列は、経時的な前記複数のノードおよび前記複数のエッジの状態の変化を示す、時系列とを備える、ことと、
履歴時間インスタンスに関する前記FHDNのクエリに応答して、前記履歴時間インスタンスに関する前記システムの状態を提供することと
を含む、方法。
(項目2)
前記システムの状態は、前記履歴時間インスタンスにおけるアズオペレーテッド状態における前記システムの厳密なグラフィカル状態を備える、項目1に記載の方法。
(項目3)
前記システムの状態は、前記履歴時間インスタンスにおける前記システムのサブセットに関する厳密なグラフィカル状態を備える、項目1に記載の方法。
(項目4)
前記FHDNの履歴動的挙動が、異なる時点で捕捉される前記ネットワークのスナップショットのシーケンスを分析することなく決定される、項目1に記載の方法。
(項目5)
前記FHDNは、前記履歴時間インスタンスに関するクエリが、前記履歴時間インスタンスにおける全ネットワークインスタンス化を要求することなく回答されることを可能にする、項目1に記載の方法。
(項目6)
前記複数のノードおよびエッジは、(1)所与の時間インスタンスにおいて開始されて前記ネットワーク内に以前に存在していた全てのノードおよびエッジと、(2)前記ネットワーク内に現在存在している全てのノードおよびエッジとを備える、項目1に記載の方法。
(項目7)
選択されたノードまたはエッジに関する前記時系列は、前記ネットワーク内の前記選択されたノードまたはエッジの追加または除去の時間を備える、項目1に記載の方法。
(項目8)
前記時系列は、選択されたノードまたはエッジにおいて起こる事象または変化に基づく、項目1に記載の方法。
(項目9)
前記履歴時間インスタンスにおける前記システムの状態は、前記複数のノードにわたって反復し、前記時系列を通して探索する探索アルゴリズムを使用することによって取得される、項目1に記載の方法。
(項目10)
前記探索アルゴリズムは、必要に応じて前記選択されたノードまたはエッジのステータスのみをチェックするように構成される反復グラフ探索アルゴリズムを備える、項目9に記載の方法。
(項目11)
前記クエリは、所与の時間インスタンスにおけるノードのサブセットについての情報要求を備え、前記探索アルゴリズムは、他の不必要なノードにクエリを行うことなく、前記ノードのサブセットにのみ直接クエリを行うように構成される、項目9に記載の方法。
(項目12)
ブロッキング技法を利用し、任意の所与の時点のインスタンスに関してメモリ内に前記FHDNの接続されたグラフィカル領域全体をキャッシュすることをさらに含む、項目1に記載の方法。
(項目13)
前記FHDNの接続されたグラフィカル領域は、いかなる到達不能なノードも含有しない、項目12に記載の方法。
(項目14)
前記ブロッキング技法は、標準ブロッキング、トークンブロッキング、または属性クラスタリングブロッキングを備える、項目13に記載の方法。
(項目15)
前記メモリ内の接続されたグラフィカル領域全体のキャッシュは、探索が、従来のネットワークグラフ化技法と比較して、より迅速に実行されることを可能にする、項目13に記載の方法。
(項目16)
前記FHDNの使用は、従来のネットワークグラフ化技法と比較して、数桁のメモリ/記憶域の節約を可能にする、項目1に記載の方法。
(項目17)
前記記憶域の要件は、従来のネットワークグラフ化技法と比較して、少なくとも3桁低減されることができる、項目16に記載の方法。
(項目18)
前記システムは、配電システムを備える、項目1に記載の方法。
(項目19)
前記配電システムは、複数の配電フィーダを備える、項目18に記載の方法。
(項目20)
前記配電システムの状態は、前記履歴時間インスタンスにおける前記複数の配電フィーダの厳密なグラフィカル状態を備える、項目19に記載の方法。
(項目21)
前記配電システムの状態は、前記履歴時間インスタンスにおける前記配電フィーダのサブセットの厳密なグラフィカル状態を備える、項目19に記載の方法。
(項目22)
前記FHDNは、前記履歴時間インスタンスに関する前記クエリが、前記履歴時間インスタンスにおける前記配電システムの全ネットワークインスタンス化を要求することなく回答されることを可能にする、項目18に記載の方法。
(項目23)
(1)前記複数のノードおよびエッジと、(2)前記時系列とは、前記複数の配電フィーダおよび各フィーダ内の前記接続されたノードおよびブランチと関連付けられる、項目19に記載の方法。
(項目24)
選択されたノードまたはエッジに関する前記時系列は、前記ネットワーク内の前記選択されたノードまたはエッジの追加または除去の時間を備える、項目23に記載の方法。
(項目25)
前記選択されたノードまたはエッジの追加または除去は、前記配電システム内のブレーカスイッチの開または閉に対応し、前記ブレーカスイッチは、前記選択されたエッジと関連付けられる、項目24に記載の方法。
(項目26)
前記クエリは、任意の所与の時間インスタンスにおける1つ以上の選択された配電フィーダの電気構成のクエリを備える、項目23に記載の方法。
(項目27)
グラフ探索アルゴリズムが、前記1つ以上の選択された配電フィーダ内に含有される前記ノードおよびエッジのみを探索することによって、任意の所与の時間インスタンスにおける前記1つ以上の選択された配電フィーダの厳密な状態にクエリを行うために利用される、項目26に記載の方法。
(項目28)
前記グラフ探索アルゴリズムは、必要に応じて前記選択された配電フィーダ内に含有される前記ノードおよびエッジのステータスのみにクエリを行うように構成される、項目27に記載の方法。
(項目29)
前記グラフ探索アルゴリズムは、他の選択されていない配電フィーダ内に含有される前記ノードおよびエッジにクエリを行うように構成されない、項目28に記載の方法。
(項目30)
前記FHDNは、複数の行および列を備える2次元行列内に記憶され、前記複数の行の各行は、前記複数のノードのうちの1つを表し、前記複数の列の各列は、前記複数のエッジのうちの1つを表し、前記2次元行列内の行および列におけるエントリは、前記列によって表される前記エッジが、前記行によって表される前記ノードに接続されているかどうかを示す、項目1に記載の方法。
(項目31)
前記エントリは、時系列である、項目30に記載の方法。
(項目32)
前記FHDNは、グラフデータベース内に記憶される、項目1に記載の方法。
(項目33)
前記グラフデータベースは、前記複数のノードの間の複数のポインタを備え、各ポインタは、前記複数のエッジのうちの1つを表す、項目32に記載の方法。
(項目34)
前記複数のポインタは、双方向性であるポインタを備える、項目33に記載の方法。
(項目35)
前記複数のポインタは、一方向性であるポインタを備える、項目33に記載の方法。
(項目36)
前記複数のノードおよび前記複数のエッジは、タグまたはプロパティを備える、項目1に記載の方法。
(項目37)
前記複数のエッジは、ノードの間の接続または関係の強さを示す加重を備える、項目1に記載の方法。
(項目38)
前記システムは、任意の製造企業に関する材料表を備える、項目1に記載の方法。
(項目39)
前記システムは、サプライチェーン流通ネットワークを備える、項目1に記載の方法。
(項目40)
前記システムは、複数のユーザから成るソーシャルネットワークを備える、項目1に記載の方法。
(項目41)
前記システムは、複数の原子と、複数の結合とを備える分子であり、前記複数のノードは、前記複数の原子を表し、前記複数のエッジは、前記複数の結合を表す、項目1に記載の方法。
(項目42)
前記システムは、掘削資産と、精製資産と、パイプライン資産とを備える石油およびガス処理パイプラインであり、前記複数のノードは、前記掘削資産および前記パイプライン資産を表し、前記複数のエッジは、前記パイプライン資産を表す、項目1に記載の方法。
(項目43)
前記システムは、ニューロンと、それらの接続とを備える生物学的ニューラルネットワークである、項目1に記載の方法。
(項目44)
前記システムは、道路ネットワークである、項目1に記載の方法。
(項目45)
前記FHDNは、異なる時点における前記システムのスナップショットの周期的捕捉および記憶を要求することなく構築される、項目1に記載の方法。
(項目46)
前記システムのFHDNを構築することは、前記複数のノード、前記複数のエッジ、および前記時系列を表すデータオブジェクトを生成することを含む、項目1に記載の方法。
(項目47)
システムの履歴状態を決定するためのシステムであって、前記システムは、
複数の異なるデータソースからシステムについてのデータを連続的に取得するためのデータ集約コンポーネントと、
ネットワークグラフ化コンポーネントであって、
前記データを使用して、前記システムの全履歴動的ネットワーク(FHDN)を構築することであって、
前記FHDNは、(1)動的に変化することが可能である複数のノードと、(2)前記ノードを接続する複数のエッジであって、前記複数のエッジは、動的に変化することが可能である、複数のエッジと、(3)前記複数のノードおよび前記複数のエッジのそれぞれと関連付けられる時系列であって、前記時系列は、経時的な前記複数のノードおよび前記複数のエッジの状態の変化を示す、時系列とを備え、前記FHDNは、異なる時点における前記システムのスナップショットの周期的捕捉および記憶を要求することなく構築される、ことと、
履歴時間インスタンスに関する前記FHDNのクエリに応答して、前記履歴時間インスタンスに関する前記システムの状態を提供することと
を行うように構成される、ネットワークグラフ化コンポーネントと
を備える、システム。
(項目48)
非一過性コンピュータ可読媒体であって、前記非一過性コンピュータ可読媒体は、命令を記憶しており、前記命令は、1つ以上のサーバによって実行されると、前記1つ以上のサーバに、方法を実施させ、前記方法は、
複数の異なるデータソースからシステムについて取得することと、
前記データを使用して、前記システムの全履歴動的ネットワーク(FHDN)を構築することであって、前記FHDNは、(1)動的に変化することが可能である複数のノードと、(2)前記ノードを接続する複数のエッジであって、前記複数のエッジは、動的に変化することが可能である、複数のエッジと、(3)前記複数のノードおよび前記複数のエッジのそれぞれと関連付けられる時系列であって、前記時系列は、経時的な前記複数のノードおよび前記複数のエッジの状態の変化を示す、時系列とを備え、前記FHDNは、異なる時点における前記システムのスナップショットの周期的捕捉および記憶を要求することなく構築される、ことと、
履歴時間インスタンスに関する前記FHDNのクエリに応答して、前記履歴時間インスタンスに関する前記システムの状態を提供することと
を含む、非一過性コンピュータ可読媒体。
【図面の簡単な説明】
【0020】
本発明の新規の特徴は、添付される請求項に具体的に記載される。本発明の特徴および利点のより深い理解が、本発明の原理が利用される例証的実施形態を記載する、以下の詳細な説明および付随の図面(また、本明細書では「図」)を参照することによって取得されるであろう。
【0021】
図1図1は、全履歴動的ネットワーク(FHDN)のグラフの実施例を示す。
【0022】
図2図2は、時間tにおける動的ネットワークのグラフの実施例を示す。
【0023】
図3図3は、異なる時間における複数のスナップショットの実施例を示す。
【発明を実施するための形態】
【0024】
本発明の種々の実施形態が、本明細書に示され、説明されているが、そのような実施形態は、実施例としてのみ提供されることが当業者に明白であろう。多数の変形例、変更、および代用が、本発明から逸脱することなく、当業者に想起され得る。本明細書に説明される本発明の実施形態の種々の代替が、採用され得ることを理解されたい。
【0025】
別様に定義されない限り、本明細書に使用される全ての技術的および科学的用語は、請求される主題が属する技術分野における当業者によって一般的に理解されるものと同一の意味を有する。前述の一般的説明および以下の詳細な説明は、例示的かつ説明的にすぎず、請求される任意の主題の制限ではないことを理解されたい。本願では、単数形の使用は、別様に具体的に記載されない限り、複数形を含む。
【0026】
本説明では、任意のパーセンテージ範囲、比率範囲、または整数範囲は、別様に示されない限り、列挙される範囲内の任意の整数、および適切であるとき、その分数(ある整数の10分の1および100分の1等)の値を含むように理解されるものである。本明細書に使用されるような用語「a」および「an」は、その文脈によって別様に示されない、または指示されない限り、列挙されるコンポーネントの「1つ以上のもの」を指すことを理解されたい。代替物(例えば、「または」)の使用は、代替物のいずれか一方、両方、またはその任意の組み合わせを意味するように理解されるべきである。本明細書に使用されるように、用語「~を含む」および「~を備える」は、同義的に使用される。
【0027】
用語「約」または「およそ」は、当業者によって決定されるような特定の値に関する許容可能な誤差範囲内を意味することができ、これは、部分的に、値が測定または決定される方法、例えば、測定システムの限界に依存するであろう。例えば、「約」は、当技術分野における慣習に従って、±10%を意味することができる。代替として、「約」は、所与の値の±20%、±10%、±5%、または±1%の範囲を意味することができる。特定の値が、本願および請求項に説明される場合、別様に記載されない限り、特定の値に関する許容可能な誤差範囲内を意味する用語「約」が、想定されるべきである。また、値の範囲および/または部分範囲が、提供される場合、範囲および/または部分範囲は、範囲および/または部分範囲の端点を含むことができる。
緒言
【0028】
本明細書に提供されるものは、全履歴動的ネットワーク(FHDN)を記憶し、それにクエリを行うための新しいパラダイムである。FHDNは、ユーザが、履歴における任意の瞬間におけるネットワークの状態にクエリを行うことを可能にすることができる。FHDNを使用することによって、「オンデマンド」のグラフのスナップショットが、再構成されることができ、所与の時点における全ネットワークが、データベース内にスナップショットを明示的に記憶することなく作られることができる。FHDNは、ユーザが、ある時刻におけるグラフについてのクエリに、この時点における全グラフをインスタンス化することなく回答することを可能にすることができる。例えば、配電システムにおける一般的クエリは、所与の時点における配電フィーダの精密な電気構成にクエリを行うことである。ネットワーク全体は、数千個もの配電フィーダを備え得るが、FHDNは、ユーザが、グラフ探索アルゴリズムを使用し、着目配電フィーダ内にあるノードおよびエッジのみを探索することによって、任意の時刻における着目配電フィーダの状態にクエリを行うことを可能にすることができる。
【0029】
FHDNは、任意の時点におけるネットワーク内にこれまで存在していた全てのノードおよびエッジを備えるグラフを作成することによって動作してもよい。各エッジおよびノードは、ネットワーク内のそのノードまたはエッジに関する変化(例えば、追加または除去)の時間を示す時系列を含んでもよい。変化は、エッジまたはノードの追加または除去等のトポロジ変化を備えてもよい。ある場合には、変化はまた、エッジまたはノードの属性またはプロパティ(例えば、加重)の変化を含んでもよい。例えば、エネルギー分配システムの場合では、エッジが、ブレーカスイッチ開または閉に対応して、複数回、追加または除去されてもよい。所与の時点におけるグラフを再構成するために、ユーザは、全てのノードにわたって反復し、(例えば、多数の事象を伴うノードおよびエッジに関して二分探索を使用して)時系列を通して探索し、この時点におけるネットワークに対応するグラフを作ることができる。接続成分を見出すこと等のグラフにわたる探索を要求する任意の分析が、必要に応じてノードまたはブランチのステータスのみをチェックする反復グラフ探索アルゴリズムを使用して実行されることができる。分析が、所与の時点におけるノードの小さいサブセットについての情報を要求する場合、FHDNデータ構造は、いかなる不必要なノードも処理することなく本分析の結果を査定するために、直接クエリを行われることができる。FHDNの大部分は、メモリ内に記憶するために十分に小さいため、ブロッキング技法が、任意の所与の時点でメモリ内にグラフの接続された領域全体をキャッシュするために採用され、ユーザが、メモリからグラフの一部のみをロードすることを要求して、これらの探索を迅速に随時実行することを可能にすることができる。
コンピュータ実装方法
【0030】
ある側面では、動的ネットワークの履歴状態を決定するコンピュータ実装方法は、複数の異なるデータソースからシステムと関連付けられるデータを連続的に取得するステップと、データを使用して、本システムの全履歴動的ネットワーク(FHDN)を構築するステップと、履歴時間インスタンスに関するFHDNのクエリに応答して、履歴時間インスタンスに関する本システムの状態を提供するステップとを含んでもよい。
【0031】
動的ネットワークは、経時的に変動するネットワークであってもよい。動的ネットワークに関して、ネットワークトポロジが、経時的に変化してもよい。例えば、ノードおよび/またはエッジは、経時的に形成および除去されてもよい。動的ネットワークは、例えば、ローカルエリアネットワーク、モバイルアドホック無線ネットワーク、通信ネットワーク、ソーシャルネットワーク、エネルギー分配ネットワーク、ウェブ、および交通ネットワークを備えてもよい。動的ネットワークは、敵対的モデル、確率論的モデル、またはゲーム理論的モデルによって駆動されてもよい。
【0032】
データソースは、家電製品、スマートメータ、ウェアラブル、監視システム、データストア、顧客システム、請求システム、金融システム、クラウドソースデータ、気象データ、ソーシャルネットワーク、または任意の他のセンサ、エンタープライズシステム、またはデータストア等のセンサまたはスマートデバイスからのデータを含んでもよい。スマートメータまたはセンサの実施例は、顧客地点に位置するメータまたはセンサ、または顧客と発生またはソース場所との間に位置するメータまたはセンサを含んでもよい。例えば、電気グリッド上の顧客メータ、グリッドセンサ、または任意の他のセンサは、測定データまたは他の情報をグリッドオペレータに提供してもよい。センサはまた、限定ではないが、ジオホン、ハイドロホン、レースセンサ、マイクロホン、地震計、音波探知機、風量計、AFRセンサ、ブラインドスポットモニタ、欠陥検出器、ホール効果センサ、車輪速度センサ、エアバッグセンサ、冷却液温度センサ、燃料レベルセンサ、燃料圧力センサ、光センサ、MAPセンサ、酸素センサ、オイルレベルセンサ、呼気分析計、二酸化炭素センサ、一酸化炭素センサ、電気化学ガスセンサ、水素センサ、電流センサ、デーリー検出器、検電器、磁気異常検出器、MEMS磁場センサ、金属検出器、無線方位測定機、電圧検出器、感光計、空気汚染センサ、雲高計、ガス検出器、ヒュミスタ、葉センサ、雨量計、雨センサ、雪量計、土中水分量センサ、量水標、潮位計、質量流量センサ、水量計、霧箱、ニューロン検出、風速指示器、深度計、磁気コンパス、旋回釣合計、炎検出器、フォトダイオード、波面センサ、気圧計、圧力センサ、レベルセンサ、粘度計、ボロメータ、比色計、温度計、近接センサ、リードスイッチ、およびバイオセンサを備えてもよい。幅広いアレイのソースからのデータを組み込むことによって、本システムは、複雑かつ詳細な分析を実施することが可能であり、さらなる事業上の洞察を可能にし得る。データソースは、他の産業およびシステムに関するセンサまたはデータベースを限定なく含んでもよい。
【0033】
データソースは、任意のタイプの産業に関するセンサ、スマートデバイス、または家電製品の大きいセットを含んでもよい。データソースは、コンピューティングネットワーク内のシステム、ノード、またはデバイス、または企業体、企業、顧客または依頼者、または他の実体によって使用される他のシステムを含んでもよい。一実施形態では、データソースは、顧客または企業情報のデータベースを含んでもよい。データソースは、Hadoop分散ファイルシステム(HDFS)等の非構造化データベースまたはフォーマット内に記憶されるデータを含んでもよい。データソースは、顧客情報システム(CIS)、顧客関係管理(CRM)システム、またはコールセンターシステム等の顧客システムによって記憶されるデータを含んでもよい。データソースは、請求システム、金融システム、サプライチェーン管理(SCM)システム、資産管理システム、および/または労働力管理システム等のエンタープライズシステムによって記憶または管理されるデータを含んでもよい。データソースは、分散リソース管理システム(DRMS)、文書管理システム(DMS)、コンテンツ管理システム(CMS)、エネルギー管理システム(EMS)、地理情報システム(GIS)、グローバル化管理システム(GMS)、および/またはスーパーバイザリ制御およびデータ入手(SCADA)システム等の運用システムによって記憶または管理されるデータを含んでもよい。データソースは、デバイス事象についてのデータを含んでもよい。デバイス事象は、例えば、デバイス故障、再起動、停電、改竄、および同等物を含んでもよい。データソースは、Facebook(登録商標)、LinkedIn(登録商標)、Twitter(登録商標)、または別のソーシャルネットワークまたはソーシャルネットワークデータベースからのデータ等のソーシャルメディアデータを含んでもよい。データソースはまた、気象サービスまたはウェブサイトからのデータおよび/またはGoogle(登録商標)によって提供されるもの等のオンラインアプリケーションプログラムインターフェース(API)からのデータ等の他の外部ソースを含んでもよい。データソースは、外部データベースを備えてもよい。
【0034】
全履歴動的ネットワーク(FHDN)は、動的ネットワークの全履歴を備えてもよい。例えば、FHDNは、動的ネットワークの履歴における任意の時点での動的ネットワークのノード、エッジ、およびノードとエッジとの間の関係を備えてもよい。例えば、動的ネットワークが、2010年に作成された場合、FHDNは、2010年以降に動的ネットワーク内にこれまで存在していた全てのエッジ、全てのノード、および時系列を備えてもよい。加えて、FHDNはまた、経時的な動的ネットワーク内の全てのエッジおよび全てのノードの変化に関する情報を備えてもよい。FHDNは、動的ネットワークの情報を記憶し、それにクエリを行うように構成されてもよい。FHDNは、動的ネットワークの履歴における任意の瞬間での本システムの状態にクエリを行うように構成されてもよい。
【0035】
FHDNは、(1)動的に変化することが可能である、複数のノードと、(2)ノードを接続する、複数のエッジであって、エッジは、動的に変化することが可能である、複数のエッジと、(3)複数のノードおよびエッジのそれぞれと関連付けられる、時系列とを備えてもよい。
【0036】
複数のノードの所与のノードは、再分配ポイントまたは通信エンドポイントであってもよい。ネットワークが、物理的ネットワークである場合、ノードは、ネットワークに取り付けられるアクティブ電子デバイスであってもよい。本状況では、ノードは、通信チャネルを経由して情報を作成、受信、または伝送することが可能であってもよい。物理的ネットワークノードは、モデム、ハブ、ブリッジ、またはスイッチ等のデータ通信機器(DCE)、またはデジタル電話送受器、プリンタ、またはホストコンピュータ等のデータ端末機器(DTE)であってもよい。ネットワークが、ローカルエリアネットワーク(LAN)または広域ネットワーク(WAN)である場合、少なくともデータリンク層デバイスである全てのLANまたはWANノードは、典型的には、これが保有するネットワークインターフェースコントローラ毎に1つのネットワークアドレスであってもよい。物理的ネットワーク内のノードの実施例は、コンピュータ、パケットスイッチ、xDSLモデム(イーサネット(登録商標)インターフェースを伴う)、および無線LANアクセスポイントを備えてもよい。ネットワークが、インターネットまたはイントラネットである場合、物理的ネットワークノードは、IPアドレスによって識別されるホストコンピュータであってもよい。
【0037】
固定電話ネットワークでは、ノードは、公共または民間の電話交換局、遠隔集信装置、またはある知的ネットワークサービスを提供するコンピュータであってもよい。セルラー通信では、ノードの実施例は、基地局コントローラ、ホームロケーションレジスタ、ゲートウェイGPRSサポートノード(GGSN)、およびサービングGPRSサポートノード(SGSN)等のスイッチングポイントおよびデータベースを備えてもよい。ケーブルテレビシステム(CATV)では、ノードは、光ファイバノードを備えてもよい。光ファイバノードは、共通の光ファイバ受信機からサービス提供される具体的地理的エリア内の家庭または企業であってもよい。ネットワークが、分散システムである場合、ノードは、クライアント、サーバ、またはピアであってもよい。
【0038】
複数のエッジの所与のエッジは、ネットワークの2つのノード(または頂点)の間の接続のうちの1つであってもよい。エッジは、有向であり得、それらが、1つのノードから別のノードに向くことを意味する。この場合では、有向エッジによって接続される2つのノードは、一方向関係にあり得る。一方向関係は、1つのノードが、情報を他のノードに送信するが、他のノードからいかなる情報も受信しないようなものであり得る。エッジはまた、無向であり得、その場合では、それらは、双方向性である。この場合では、有向エッジによって接続される2つのノードは、二方向関係にあり得る。二方向関係は、1つのノードが、情報を他のノードに送信し、また、他のノードから任意の情報を受信するようなものであり得る。ある場合には、ノードは、情報を相互に送信しない場合がある。
【0039】
時系列は、時間順における一連のデータ点であってもよい。時系列は、時間において連続的な等間隔の点において得られるシーケンスであってもよい。時系列は、離散時間データのシーケンスを備えてもよい。時系列は、ノードまたはエッジが変化するとき、例えば、ノードまたはエッジが追加される、除去される、アクティブ化される、非アクティブ化される、または別のノードに接続される、またはそれから接続解除されるときを示してもよい。代替として、または加えて、時系列は、ノードまたはエッジの時変プロパティを示してもよい。配電ネットワークの場合では、ノードは、例えば、発電所、送電変電所、配電フィーダ、変圧器、ブレーカ、および消費者であってもよい。エッジは、そのようなノードを接続する送電線および他のワイヤであってもよい。時系列は、例えば、発電所が作動中である、または作動中ではないとき、またはブレーカが開または閉であるときを示してもよい。時系列は、加えて、例えば、経時的な発電所の電力出力を示してもよい。ソーシャルネットワークの場合では、ノードは、ソーシャルネットワーク上にプロフィールを有する企業および人々であってもよい。エッジは、それらの企業と人々との間の関係(例えば、友人、フォロワー等)であってもよい。時系列は、ソーシャルネットワーク上の関係が開始または終了したときを示してもよい。時系列は、加えて、例えば、ソーシャルネットワーク内の企業または人々のプロパティが経時的に変化する様子(例えば、人物の関係ステータス、職業、または場所が経時的に変化する様子)を示してもよい。サプライチェーン流通ネットワークの場合では、ノードは、供給業者工場、組立工場、地方の流通センター、地域の流通センター、および顧客場所であってもよい。ノードは、サプライチェーンネットワーク内のノードを相互に接続する、道路、鉄道線路、航路、および飛行経路であってもよい。時系列は、例えば、工場が特定の時間に運転しているかどうか、および道路または鉄道線路が特定の時間に開放されているかどうかを示してもよい。
【0040】
時系列は、FHDN内の動的に変化するノードおよびエッジを表してもよい。変化は、系統的または非系統的であってもよい。変化が、系統的である場合、時系列は、系統的時間間隔において取得されてもよい。変化が、非系統的である場合、時系列は、非系統的時間間隔において取得されてもよい。例えば、時系列は、最初に、1分の時間周期にわたって1s毎に取得され、次いで、10時間の時間周期にわたって10s毎に取得されてもよい。ある場合には、本システムは、ノードおよびエッジの変化に関して連続的または周期的に監視されてもよいが、時系列エントリは、ノードおよびエッジの実際の変化が起こるときにのみメモリ内に記憶されてもよい。これは、FHDNを記憶するために要求されるメモリの量を低減させることができる。FHDNへのクエリは、FHDNからの情報に関する要求を備えてもよい。クエリは、履歴時刻における動的ネットワークの状態を要求するステップを含んでもよい。クエリは、メニューからパラメータを選定することによって行われることができ、そこで、データベースシステムは、それからユーザが選定し得るパラメータのリストを提示する。クエリはまた、例示クエリによって行われることができ、本システムは、空白の記録を提示し、ユーザにクエリを定義するフィールドおよび値を規定させる。フィールドまたは値は、履歴時刻を直接規定してもよい、またはそれらは、履歴時刻を間接的に規定してもよい。例えば、フィールドまたは値は、特定のノードに起こる変化を規定してもよい。クエリは、クエリ言語によって行われることができ、ユーザは、特別なクエリ言語で書き込まれなければならない定型化クエリの形態において情報に関する要求を行う。
【0041】
図1は、FHDNのグラフの実施例を示す。図1では、FHDN100は、動的に変化することが可能である、複数のノード102と、ノードを接続し、動的に変化することが可能である、複数のエッジ104と、複数のノード106およびエッジ108のそれぞれと関連付けられる、時系列とを備える。FHDNは、動的ネットワーク内にこれまで存在していた全てのノードおよびエッジを備えてもよい。1つのノードの時系列106は、T1=[A, I, A, A, A,…]であってもよく、これは、具体的時間間隔において、経時的なノードの変化が、「アクティブ, 非アクティブ, アクティブ, アクティブ, アクティブ, …」であることを表す。1つのエッジの時系列108は、T2=[A, I, I, A, A,…]であってもよく、これは、具体的時間間隔において、経時的なエッジの変化が、「アクティブ, 非アクティブ, 非アクティブ, アクティブ, アクティブ, …」であることを表す。
【0042】
図2は、時間tにおける動的ネットワークのグラフの実施例を示す。図2では、動的ネットワーク200は、時間tにおいてアクティブ化される、複数のノード202(影付き)と、時間tにおいてアクティブ化されるノードを接続する、複数のアクティブエッジ204(実線によって表される)とを備える。時間tにおいて、残りのノード206(影なし)および残りのエッジ208(破線によって表される)は、アクティブ化されない。
【0043】
本システムの状態は、履歴時間インスタンスにおける、アズオペレーテッド状態におけるネットワーク全体のグラフィカル状態を備えてもよい。履歴時間インスタンスは、ユーザによって定義される動的ネットワークの履歴における任意の時間であってもよい。例えば、履歴時間インスタンスは、動的ネットワークの履歴におけるある時点(例えば、2000年8月12日の午前10時における)、動的ネットワークの履歴におけるある時間周期(例えば、1980年10月11日の午前1時~午後12時)、またはそれらの組み合わせであり得る。グラフィカル状態は、グラフ構造を備えてもよく、これは、ノードの間の関係(エッジ)を伴うデータのグラフィカル表現であってもよい。グラフは、エッジのセットとともにノードのセットを備える、順序付けられた対であってもよい。ノードは、2つのノードを接続する各エッジと関連付けられる生起の関係とともに、セットであってもよい。
【0044】
グラフは、多くのタイプの関係およびプロセスをモデル化するために使用されることができる。例えば、コンピュータ科学では、グラフは、通信、データ編成、コンピュータデバイス、算出のフロー等のネットワークを表すために使用されてもよい。一実施例では、ウェブサイトのリンク構造が、有向グラフによって表されることができ、ノードは、ウェブページを表し、有向エッジは、1つのページから別のものへのリンクを表す。別の実施例は、化学におけるものであり、グラフは、分子に関する自然なモデルを作製してもよく、ノードは、原子を表し、エッジは、結合を表す。統計物理学では、グラフは、システムの相互作用する部分の間の局所的接続およびそのようなシステム上の物理的プロセスの動力学を表すことができる。同様に、計算論的神経科学では、グラフは、種々の認知プロセスをもたらすように相互作用する脳面積の間の機能的接続を表すために使用されることができ、ノードは、脳の異なる面積を表し、エッジは、それらの面積の間の接続を表す。グラフは、多孔性媒体のマイクロスケールチャネルを表すために使用されてもよく、ノードは、細孔を表し、エッジは、細孔を接続するより小さいチャネルを表す。生物学では、ノードは、ある種が存在する(または生息する)地域を表すことができ、エッジは、地域の間の移住経路または移動を表す。グラフはまた、ソーシャルメディア、旅行、コンピュータチップ設計、神経変性疾患の進行のマッピング、および多くの他の分野における問題に適用されることができる。旅行の場合では、本明細書に説明されるシステムおよび方法は、旅行ネットワーク(例えば、道路、水路、飛行経路等)のFHDNを作成するために使用されることができる。ノードは、旅行ネットワーク内の異なる目的地(例えば、都市)を表してもよく、エッジは、そのような目的地の間の異なる経路を表してもよい。エッジは、距離または移動時間によって加重されてもよい。FHDN内の時系列は、特定の経路が特定の時間に開放されているかどうか(例えば、特定の道路がアクセス可能であるかどうかまたは特定の飛行が利用可能であるかどうか)を示してもよい。旅行ネットワークのFHDNは、1つの目的地から別のものへの最適なルート(例えば、最も速いまたは最も短いルート)を決定するために使用されることができる。
【0045】
コンピュータチップ設計の場合では、本明細書に説明されるシステムおよび方法は、経時的なコンポーネント故障を分析し、続けて、将来の故障を予測するために使用され得る、コンピュータチップのFHDNを作成するために使用されることができる。
【0046】
神経変性疾患の場合では、本明細書に説明されるシステムおよび方法は、ヒトの脳のFHDNを作成するために使用されることができる。FHDNのノードは、脳におけるニューロンを表してもよく、エッジは、ニューロンの間の接続であってもよい。時系列は、特定のニューロンが疾患進行によって悪影響を受けているかどうかを示してもよい。患者の脳のFHDNを作成することは、医師が他の患者において疾患進行を予測および予防することを支援することができる。
【0047】
本明細書に説明されるシステムおよび方法はまた、石油およびガス処理パイプラインのFHDNを作成するために使用されることができる。石油およびガス処理パイプラインは、掘削資産、精製資産、およびパイプライン資産(例えば、ポンプ、コンプレッサ、熱交換器、および弁)を含んでもよい。FHDN内のノードは、掘削および精製資産を表してもよく、エッジは、パイプライン資産を表してもよい。時系列は、ある資産がある時間に運転しているかどうかを示してもよく、それらはまた、経時的なそれらの資産の容量または出力を示してもよい。
【0048】
グラフ構造は、グラフの各エッジに加重を割り当てることによって拡張されることができる。加重を伴うグラフまたは加重グラフは、対毎の接続がいくつかの数値を有する構造を表すために使用されてもよい。例えば、グラフが、道路ネットワークを表す場合、加重は、各道路の長さを表し得る。距離(前述の実施例におけるように)、移動時間、または金銭的費用を含む、各エッジと関連付けられるいくつかの加重が、存在してもよい。グラフ構造はまた、時系列をグラフの各エッジおよびノードに割り当てることによって拡張されることができる。時系列を伴うグラフは、対毎の接続が経時的に変化するいくつかの値を有する構造を表すために使用されてもよい。例えば、グラフが、道路ネットワークを表す場合、時系列は、経時的な各道路の交通を表し得る。加重は、代替として、または加えて、ノードの間の関係または接続の強さを表してもよい。
【0049】
グラフは、コンピュータシステム内に記憶されることができる。グラフを記憶するために使用されるデータ構造は、グラフ構造およびグラフを操作するために使用されるアルゴリズムの両方に依存し得る。データ構造は、リスト構造、行列構造、または両方の組み合わせを備えてもよい。リスト構造は、それらが、より小さいメモリ要件を有するため、疎グラフのために使用されてもよい。行列構造は、いくつかの用途のためのより高速のアクセスを提供し得るが、大量のメモリを消費し得る。異なるリスト構造および行列構造は、隣接リスト、隣接行列、および生起行列を備えてもよい。隣接リストに関して、ノードは、記録またはオブジェクトとして記憶されてもよく、全ての頂点は、隣接する頂点のリストを記憶してもよい。本データ構造は、ノード上の付加的データの記憶を可能にし得る。隣接行列に関して、2次元行列が、使用されてもよく、行は、ソースノードを表し、列は、宛先ノードを表し、エッジおよびノード上のデータは、外部に記憶されてもよい。生起行列に関して、2次元ブール行列が、使用されてもよく、行は、ノードを表し、列は、エッジを表し、エントリは、ある行における頂点が、ある列におけるエッジに付帯するかどうかを示してもよい。エントリは、任意の所与の時間インスタンスにおいて、ある行における頂点が、ある列におけるエッジに付帯するかどうかを示す時系列であってもよい。
【0050】
提供されるFHDNは、グラフデータベースに関するグラフ構造として使用されてもよい。データオブジェクトが、FHDNの形態においてグラフデータベース内に記憶されてもよい。グラフデータベースは、データを表し、記憶するために、ノード、エッジ、およびプロパティを伴うクエリのためのグラフ構造を使用するデータベースであってもよい。一実施形態では、全ての要素は、その隣接する要素への直接ポインタを含有し、いかなるインデックスルックアップも、必要ではない。本システムの重要な概念は、ストア内のデータアイテムに直接関連する、グラフ(またはエッジまたは関係)であり得る。関係は、ストア内のデータが、直接ともにリンクされ、多くの場合では、1つの動作で読み出されることを可能にし得る。ポインタは、一方向性または双方向性であってもよい。
【0051】
グラフデータベースは、関係システムにおいてモデル化することが困難である複雑な階層構造の単純かつ高速の読出を可能にし得る。グラフデータベースの記憶機構は、関係エンジンに依存し、テーブル内にグラフデータを「記憶する」機構、または記憶のためにキーバリューストアまたはドキュメント指向データベースを使用し、それらを本質的にNoSQL構造にする機構を備えてもよい。非関係記憶エンジンに基づくいくつかのグラフデータベースはまた、本質的に、別のドキュメントへのポインタを有する関係である、タグまたはプロパティの概念を追加してもよい。グラフデータベースからデータを読み出すことは、クエリ言語を要求してもよい。いくつかのグラフデータベースは、アプリケーションプログラミングインターフェース(API)を通してアクセスされてもよい。
【0052】
グラフデータベースは、ノード、エッジ、およびプロパティを備えるグラフ構造を採用してもよい。グラフ構造は、本明細書の別の場所に説明されるようなFHDNであってもよい。例えば、ノードまたはエッジの変化の時間を示す時系列が、ノードまたはエッジとともに記録されてもよい。ノードは、人々、企業、アカウント、または追跡されるべき任意の他のアイテム等の実体を表してもよい。エッジは、ノードを他のノードに接続する線であってもよく、それらは、それらの間の関係を表してもよい。エッジは、本システムにおいて直接実装されない抽象概念を表してもよい。プロパティは、ノードについてのメタデータまたはデータであってもよい。例えば、人々がノードであるソーシャルネットワークの場合では、プロパティは、人々についての人口統計または個人情報(例えば、年齢、性別、雇用者、学校、場所等)を含んでもよい。本明細書に開示される方法は、外部グラフデータベースを備えてもよい。外部グラフデータベースは、AllegroGraph、AnzoGraph、ArangoDB、DataStax、InfiniteGraph、Marklogic、Microsoft SQLサーバ、Neo4j、OpenLink Virtuoso、Oracle Spatial and Graph、OrientDB、SAP HANA、Sparksee、Sqrrl Enterprise、Teradata Aster、または他の類似するタイプのデータベースを備えてもよい。
【0053】
本システムの状態は、履歴時間インスタンスにおけるネットワークのサブセットに関するグラフィカル状態を備えてもよい。グラフィカル状態は、動的ネットワークのユーザによって定義される履歴時間インスタンスにおけるクエリによって要求される全てのノードおよびエッジを備えてもよい。ユーザによって定義される履歴時間インスタンスにおけるクエリによって要求される全てのノードおよびエッジは、ネットワークのサブセットであってもよい。ユーザによって定義される履歴時間インスタンスにおけるクエリによって要求される全てのノードおよびエッジは、全ネットワークであってもよい。ネットワークのサブセットは、全ネットワークのノードのサブセット、エッジのサブセット、および/または時系列のサブセットを備えてもよい。ネットワークのサブセットは、全ネットワークのノードの少なくとも約4%、5%、6%、7%、8%、9%、10%、15%、20%、30%、40%、50%、60%、70%、80%、90%、またはそれを上回るものを備えてもよい。他の場合では、ネットワークのサブセットは、全ネットワークのノードの多くても約90%、80%、70%、60%、50%、40%、30%、20%、15%、10%、9%、8%、またはそれを下回るものを備えてもよい。ネットワークのサブセットは、全ネットワークのエッジの少なくとも約4%、5%、6%、7%、8%、9%、10%、15%、20%、30%、40%、50%、60%、70%、80%、90%、またはそれを上回るものを備えてもよい。他の場合では、ネットワークのサブセットは、全ネットワークのエッジの多くても約90%、80%、70%、60%、50%、40%、30%、20%、15%、10%、9%、8%、またはそれを下回るものを備えてもよい。ネットワークのサブセットは、全ネットワークの時系列の少なくとも約4%、5%、6%、7%、8%、9%、10%、15%、20%、30%、40%、50%、60%、70%、80%、90%、またはそれを上回るものを備えてもよい。他の場合では、ネットワークのサブセットは、全ネットワークの時系列の多くても約90%、80%、70%、60%、50%、40%、30%、20%、15%、10%、9%、8%、またはそれを下回るものを備えてもよい。
【0054】
FHDNは、異なる時点におけるネットワークのスナップショットの周期的捕捉および記憶を要求することなく構築されてもよい。
【0055】
スナップショットは、特定の時点におけるシステムの状態を備えてもよい。図3は、異なる時点における動的ネットワークの複数のスナップショットの実施例を示す。図3では、時刻t=1~t=6にわたる動的ネットワークのスナップショットの時系列が、示される。点線エッジは、いかなる関係も存在しないことを示し、実線エッジは、関係を示す。例えば、(1, 2)は、t=1においていかなる関係も有しておらず、(2, 4)は、t=6においていかなる関係も有していない。
【0056】
FHDNの履歴動的挙動は、異なる時点で捕捉されるネットワークのスナップショットのシーケンスを分析することなく決定されてもよい。履歴動的挙動は、ユーザによって定義される履歴時間インスタンスにおけるFHDNの変化を備えてもよい。履歴動的挙動は、ユーザによって定義される時間周期にわたるFHDNの変化を備えてもよい。異なる時点で捕捉されるネットワークのスナップショットのシーケンスを分析することなくFHDNの履歴動的挙動を決定するために、時系列が、取得され、動的ネットワーク内のノードおよびエッジに関する情報と併用されてもよい。本状況では、スナップショットを横断するノードおよびエッジについての情報のいかなる複製も、要求され得ない。
【0057】
FHDNは、履歴時間インスタンスに関するクエリが、履歴時間インスタンスにおける全ネットワークインスタンス化を要求することなく回答されることを可能にし得る。インスタンス化は、現実のインスタンスの作成またはオブジェクトのクラスまたはコンピュータプロセス等の抽象概念またはテンプレートの特定の実現であってもよい。履歴時間インスタンスにおける全ネットワークインスタンス化を要求することなく履歴時間インスタンスに関するクエリに回答するために、時系列が、取得され、動的ネットワーク内のノードおよびエッジに関する情報と併用されてもよい。本状況では、クエリに関連する時系列、ノード、およびエッジのみが、探索および取得されてもよく、クエリに関連しない時系列、ノード、およびエッジは、探索/処理される必要はない。ある場合には、特定の時系列、ノード、およびエッジが、他の時系列、ノード、およびエッジから推測されてもよい。例えば、個別のノードの状態は、個別のノードに隣接するノードおよびエッジから推測されることができる。ノードについてのデータが、例えば、誤動作するセンサまたは他の接続問題に起因して欠落しているとき、そのノードの状態を推測することが、望ましくあり得る。
【0058】
複数のノードおよびエッジは、(1)ネットワークについてのデータの収集が開始された後の所与の時刻におけるネットワーク内に以前に存在していた全てのノードおよびエッジと、(2)ネットワーク内に現在存在している全てのノードおよびエッジとを備えてもよい。他の実施形態では、複数のノードおよびエッジは、(1)任意の所与の時刻におけるネットワーク内に以前に存在していた全てのノードおよびエッジと、(2)ネットワーク内に現在存在している全てのノードおよびエッジと、(3)ネットワーク内に存在しているであろう全てのノードおよびエッジとを備える。全てのノードの数は、少なくとも1個、10個、50個、100個、200個、300個、400個、500個、1,000個、10,000個、100,000個、1,000,000個、10,000,000個、100,000,000個、1,000,000,000個、またはそれを上回るものであってもよい。全てのノードの数は、多くても1,000,000,000個、100,000,000個、10,000,000個、1,000,000個、100,000個、10,000個、1,000個、500個、400個、300個、200個、100個、50個、10個、またはそれを下回るものであってもよい。エッジの数は、ノードの数に匹敵してもよい、またはエッジの数は、ノードの数を上回ってもよい。ある場合には、エッジの数は、ノードの数を下回ってもよい。
【0059】
時系列は、選択されたノードまたはエッジにおいて起こる事象または変化に基づいてもよい。ある場合には、事象または変化は、トポロジ変化を含んでもよい。代替として、または加えて、変化は、エッジまたはノードのプロパティまたは属性(例えば、加重、方向性)の変化を含んでもよい。事象または変化は、ノードを選択すること、ノードを選択しないこと、エッジを選択すること、およびエッジを選択しないことを含んでもよい。選択されたノードまたはエッジに関する時系列は、ネットワーク内の選択されたノードまたはエッジに関する追加または除去の精密な時間を備えてもよい。選択されたノードまたはエッジに関する時系列は、ネットワーク内の選択されたノードまたはエッジに関する追加、除去、および訂正の精密な時間を備えてもよい。時系列は、系統的または非系統的時間間隔において取得されてもよい。系統的時間間隔は、少なくとも0.1マイクロ秒(μs)、1μs、10μs、100μs、1ミリ秒(ms)、10ms、100ms、1秒(s)、2s、3s、10s、30s、60s、2分(m)、3m、4m、5m、10m、またはそれを上回るもの毎であってもよい。いくつかの実施形態では、系統的時間間隔は、多くても10m、5m、4m、3m、2m、1m、30s、10s、3s、2s、1s、100ms、10ms、1ms、100μs、10μs、1μs、1μsまたはそれを下回るもの毎であってもよい。非系統的時間間隔に関して、時系列は、最初に、第1の時間周期にわたって第1の時間に取得され、次いで、第2の時間周期にわたって第2の時間に取得されてもよい。例えば、時系列は、最初に、1分の第1の時間周期にわたって1s毎に取得され、次いで、10時間の第2の時間周期にわたって10s毎に取得されてもよい。
【0060】
時系列は、高スループットの分散キーバリューデータストアを含む、記憶装置内に記憶されてもよい。分散キー/バリューストアは、大量のデータセットを記憶し、高い信頼性で動作する能力を用いて信頼性およびスケーラビリティを提供してもよい。キー/バリューストアはまた、可用性と、一貫性と、費用対効果との間のトレードオフに対する厳格な制御を用いて最適化されてもよい。データ永続化プロセスは、付加的処理が、分散待ち行列上へのメッセージの到着率に合わせるために要求される場合、柔軟なコンピュータノードおよびスケールアウトを利用するように設計されてもよい。記憶装置は、多種多様なデータベースタイプを含んでもよい。例えば、分散キーバリューデータストアが、時系列および他の非構造化データを取り扱うために理想的であり得る。キーバリューデータストアは、多くのコモディティサーバを横断する大量のデータを取り扱うように設計されてもよく、いかなる単一障害点も伴わない高い可用性を提供してもよい。関係データストアが、複雑な実体関係を伴う企業タイプを記憶し、それにクエリを行うために使用されてもよい。多次元データストアが、複数の異なるデータソースまたはデータストアからのものである集約データを含む集約物を記憶し、それにアクセスするために使用されてもよい。
【0061】
履歴時間インスタンスにおける本システムの状態は、複数のノードにわたって反復し、時系列を通して探索する、探索アルゴリズムを使用することによって取得されてもよい。複数のノードの数は、動的ネットワーク内にこれまで存在していた全てのノードではない場合がある。他の場合では、複数のノードの数は、動的ネットワーク内にこれまで存在していた全てのノードであってもよい。
【0062】
履歴時間インスタンスにおける本システムの状態は、複数のエッジにわたって反復し、時系列を通して探索する、探索アルゴリズムを使用することによって取得されてもよい。複数のエッジの数は、動的ネットワーク内にこれまで存在していた全てのエッジではない場合がある。他の場合では、複数のエッジの数は、動的ネットワーク内にこれまで存在していた全てのエッジであってもよい。
【0063】
探索アルゴリズムは、データ構造内に記憶される、または問題ドメインの探索空間内で計算される情報を読み出すために探索問題を解く、任意のアルゴリズムであってもよい。探索アルゴリズムの実施例は、限定ではないが、リンク付きリスト、アレイデータ構造、または探索木を含んでもよい。適切な探索アルゴリズムは、探索されているデータ構造およびデータについての事前知識に依存し得る。探索は、SQL SELECTコマンド等のデータ構造にクエリを行うアルゴリズムを包含してもよい。
【0064】
探索アルゴリズムは、線形探索アルゴリズム、二分探索アルゴリズム、ジャンプ探索アルゴリズム、補間探索アルゴリズム、指数関数的探索アルゴリズム、サブリスト探索アルゴリズム、比較探索アルゴリズム、およびデジタル探索アルゴリズムを備えることができる。線形探索アルゴリズムは、線形方式で標的キーと関連付けられるものに関する全ての記録をチェックし得る。二分探索アルゴリズムは、探索構造の中心を繰り返し標的化し、探索空間を半分に分割し得る。比較探索アルゴリズムは、標的記録が見出されるまで、キーの比較に基づいて記録を連続的に排除することによって、線形探索を改良し得る。比較探索アルゴリズムは、定義された順序を伴うデータ構造上に適用されることができる。デジタル探索アルゴリズムは、数値キーを使用するデータ構造内のディジットの性質に基づいて機能し得る。
【0065】
探索アルゴリズムは、必要に応じて選択されたノードまたはエッジのステータスのみをチェックするように構成される、反復グラフ探索アルゴリズムを備えてもよい。グラフ探索アルゴリズムは、グラフのノードを通して探索する順序を規定してもよい。グラフ探索アルゴリズムは、例えば、深さ優先探索または幅優先探索等の接続成分探索であってもよい。例えば、グラフ探索アルゴリズムは、ソースノードにおいて開始され、標的ノードが見出されるまで探索を続けてもよく、次いで、フロンティアは、まだ探索されていないノードを備えてもよく、反復の度に、ノードは、フロンティアから外され、その隣接物をフロンティアに追加してもよい。必要性基準は、ユーザによって設定されることができる。例えば、分析が、所与の時点におけるノードの小さいサブセットについての情報を要求する場合、FHDNデータ構造は、いかなる不必要なノードにも触れることなく本分析の結果を査定するために、直接クエリを行われることができる。不必要なノードは、クエリに関連しないノードであり得る。不必要なノードは、FHDN内の全てのノードの少なくとも約4%、5%、6%、7%、8%、9%、10%、15%、20%、30%、40%、50%、60%、70%、80%、90%、またはそれを上回るものを備えてもよい。他の場合では、不必要なノードは、FHDN内の全てのノードの多くても約90%、80%、70%、60%、50%、40%、30%、20%、15%、10%、9%、8%、またはそれを下回るものを備えてもよい。
【0066】
クエリは、所与の時刻におけるノードのサブセットについての情報要求を備えてもよい。クエリは、所与の時刻におけるエッジのサブセットについての情報要求を備えてもよい。クエリは、所与の時刻におけるノードおよびエッジのサブセットについての情報要求を備えてもよい。クエリは、複数の所与の時刻におけるノードのサブセットについての情報要求を備えてもよい。クエリは、複数の所与の時刻におけるエッジのサブセットについての情報要求を備えてもよい。クエリは、複数の所与の時刻におけるノードおよびエッジのサブセットについての情報要求を備えてもよい。
【0067】
探索アルゴリズムは、他の不必要なノードにクエリを行うことなく、ノードのサブセットにのみ直接クエリを行うように構成されてもよい。これは、より迅速な応答時間およびより標的化された/焦点を絞ったクエリを可能にすることができる。ある場合には、ノード/エッジのサブセットまたはグラフを再現するためにクエリを行われるように選択されたノード/エッジは、頻繁な事象変化を伴うノード/エッジであってもよい。例えば、ある閾値を上回る変化の回数を伴うノードまたはエッジが、クエリを行われてもよい。別の実施例では、より多い数の変化を伴うノードまたはエッジが、より少ない数の変化を伴うノードまたはエッジに先立ってクエリを行われる。探索アルゴリズムは、他の不必要なノードにクエリを行うことなく、ノードのサブセットにのみ間接的にクエリを行うように構成されてもよい。探索アルゴリズムは、他の不必要なエッジにクエリを行うことなく、ノードのサブセットにのみ直接クエリを行うように構成されてもよい。探索アルゴリズムは、他の不必要なエッジにクエリを行うことなく、ノードのサブセットにのみ間接的にクエリを行うように構成されてもよい。探索アルゴリズムは、他の不必要なノードおよびエッジにクエリを行うことなく、ノードのサブセットにのみ直接クエリを行うように構成されてもよい。探索アルゴリズムは、他の不必要なノードおよびエッジにクエリを行うことなく、ノードのサブセットにのみ間接的にクエリを行うように構成されてもよい。不必要なノードおよびエッジは、クエリに関連しないノードおよびエッジであり得る。不必要なノードは、FHDN内の全てのノードの少なくとも約4%、5%、6%、7%、8%、9%、10%、15%、20%、30%、40%、50%、60%、70%、80%、90%、またはそれを上回るものを備えてもよい。他の場合では、不必要なノードは、FHDN内の全てのノードの多くても約90%、80%、70%、60%、50%、40%、30%、20%、15%、10%、9%、8%、またはそれを下回るものを備えてもよい。不必要なエッジは、FHDN内の全てのエッジの少なくとも約4%、5%、6%、7%、8%、9%、10%、15%、20%、30%、40%、50%、60%、70%、80%、90%、またはそれを上回るものを備えてもよい。他の場合では、不必要なエッジは、FHDN内の全てのエッジの多くても約90%、80%、70%、60%、50%、40%、30%、20%、15%、10%、9%、8%、またはそれを下回るものを備えてもよい。
【0068】
本方法はさらに、ブロッキング技法を利用し、任意の所与の時刻に関してメモリ内にFHDNの1つ以上の接続されたグラフィカル領域をキャッシュするステップを含んでもよい。メモリは、揮発性RAMまたは不揮発性メモリであってもよい。揮発性RAMは、メモリ内のデータをリフレッシュまたは維持するために電力を絶えず要求する、ダイナミックRAM(DRAM)として実装されてもよい。不揮発性メモリは、磁気ハードドライブ、磁気光学ドライブ、光学ドライブ(例えば、DVD RAM)、または電力が本システムから除去された後でもデータを維持する他のタイプのメモリシステムであってもよい。不揮発性メモリはまた、ランダムアクセスメモリであってもよい。不揮発性メモリは、データ処理システム内の残りのコンポーネントに直接結合される、ローカルデバイスであり得る。モデムまたはイーサネット(登録商標)インターフェース等のネットワークインターフェースを通して、本明細書に説明されるコンピュータシステムのうちのいずれかに結合されるネットワーク記憶デバイス等の本システムから遠隔にある不揮発性メモリもまた、使用されることができる。
【0069】
ブロッキング技法は、標準ブロッキング、トークンブロッキング、または属性クラスタリングブロッキングを備えてもよい。ブロッキング技法は、いくつかの用途においてメモリ帯域幅ボトルネックを回避することに役立ち得る。ブロッキング技法は、データが複数回の使用を横断してキャッシュ内に残ることを確実にすることによって、用途において利用可能な固有データ再使用を活用してもよい。ブロッキング技法は、1D、2D、または3D空間データ構造に対して実施されることができる。いくつかの反復用途はさらに、帯域幅ボトルネックをさらに軽減するために、複数回の反復にわたってブロックすることから利益を享受することができる。ブロッキング技法は、ループ分割および交換の組み合わせを備えてもよい。キャッシュブロッキングは、データアクセスを再配列し、データのサブセット(ブロック)をキャッシュに取り込み、本ブロックに作用し、主要メモリからデータを繰り返しフェッチする必要性を回避するための技法であり得る。
【0070】
メモリ内の1つ以上の接続されたグラフィカル領域のキャッシュは、探索が、従来のネットワークグラフ化技法と比較して、より迅速に実行されることを可能にし得る。接続されたグラフィカル領域は、いかなる到達不能な頂点/ノードも含有しないグラフの接続された領域を指し得る。例えば、グラフの接続された領域は、キャッシュにロードされ、複数回の使用を横断して残されてもよい。メモリ内の1つ以上の接続されたグラフィカル領域のキャッシュは、探索が、従来のネットワークグラフ化技法と比較して、5~65倍またはそれを上回ってより速く実行されることを可能にし得る。
【0071】
FHDNの使用は、従来のネットワークグラフ化技法と比較して、数桁のメモリ/記憶域の節約を可能にし得る。記憶域の要件は、従来のネットワークグラフ化技法と比較して、少なくとも3桁低減されることができる。記憶域の要件は、従来のネットワークグラフ化技法と比較して、1~10、2~9、3~8、4~7、5~6桁低減されることができる。記憶域の要件は、従来のネットワークグラフ化技法と比較して、少なくとも3、4、5、6、7、8、9、10、またはそれを上回る桁低減されることができる。ある場合には、記憶域の要件は、従来のネットワークグラフ化技法と比較して、少なくとも10、9、8、7、6、5、4、またはそれを下回る桁低減されることができる。

配電システム
【0072】
本システムは、配電システムを備えてもよい。配電システムは、異なる配列を備えてもよい。配列は、半径方向システム、拡張半径方向システム、一次選択性を伴う半径方向システム、一次および二次単純半径方向システム、一次ループシステム、二次選択的システム、一次選択的システム、節電変圧器システム、二次スポットネットワーク、および複合システムを備えてもよい。
【0073】
配電システムは、複数の配電フィーダを備えてもよい。複数の配電フィーダは、複数の接続を通して相互に接続されてもよい。配電フィーダは、複数のノードを備えてもよい。ノードは、電気消費デバイスと、電気グリッドとを備えてもよい。配電フィーダは、複数のエッジを備えてもよい。エッジは、ノードを接続する電線を備えてもよい。
【0074】
配電システムの状態は、履歴時間インスタンスにおける複数の配電フィーダのグラフィカル状態を備えてもよい。配電システムの状態は、履歴時間インスタンスにおける配電フィーダを接続する複数の接続のグラフィカル状態を備えてもよい。
【0075】
配電システムの状態は、履歴時間インスタンスにおける配電フィーダのサブセットのグラフィカル状態を備えてもよい。グラフィカル状態は、履歴時間インスタンスにおけるクエリによって要求される全ての配電フィーダを備えてもよい。履歴時間インスタンスにおける全ての配電フィーダは、配電システムのサブセットであってもよい。配電フィーダのサブセットは、配電システムの配電フィーダの少なくとも約4%、5%、6%、7%、8%、9%、10%、15%、20%、30%、40%、50%、60%、70%、80%、90%、またはそれを上回るものを備えてもよい。他の場合では、配電フィーダのサブセットは、配電システムの配電フィーダの多くても約90%、80%、70%、60%、50%、40%、30%、20%、15%、10%、9%、8%、またはそれを下回るものを備えてもよい。
【0076】
FHDNは、履歴時間インスタンスに関するクエリが、履歴時間インスタンスにおける配電システムの全ネットワークインスタンス化を要求することなく回答されることを可能にし得る。インスタンス化は、現実のインスタンスの作成またはデータオブジェクトのクラスまたはコンピュータプロセス等の抽象概念またはテンプレートの特定の実現であってもよい。
【0077】
複数のノードおよびエッジおよび時系列は、複数の配電フィーダおよび各フィーダ内の接続されたノードおよびブランチと関連付けられてもよい。複数のノードおよびエッジは、(1)任意の所与の時刻における配電フィーダ内に以前に存在していた全てのノードおよびエッジと、(2)配電フィーダ内に現在存在している全てのノードおよびエッジとを備えてもよい。他の実施形態では、複数のノードおよびエッジは、(1)任意の所与の時刻における配電フィーダ内に以前に存在していた全てのノードおよびエッジと、(2)配電フィーダ内に現在存在している全てのノードおよびエッジと、(3)配電フィーダ内に存在しているであろう全てのノードおよびエッジとを備える。
【0078】
時系列は、配電フィーダ内の選択されたノードまたはエッジに関する追加または除去の精密な時間を備えてもよい。時系列は、配電フィーダ内の選択されたノードまたはエッジに関する追加、除去、または訂正の精密な時間を備えてもよい。時系列は、系統的または非系統的時間間隔を通して取得されてもよい。非系統的時間間隔に関して、時系列は、最初に、第1の時間周期にわたって第1の時間に取得され、次いで、第2の時間周期にわたって第2の時間に取得されてもよい。例えば、時系列は、最初に、1分の第1の時間周期にわたって1s毎に取得され、次いで、10時間の第2の時間周期にわたって10s毎に取得されてもよい。選択されたエッジの追加または除去は、配電システム内のブレーカスイッチの開または閉に対応してもよく、ブレーカスイッチは、選択されたエッジと関連付けられる。選択されたエッジの訂正は、選択されたエッジの電気消費の変化を表してもよい。
【0079】
クエリは、任意の所与の時刻における1つ以上の選択された配電フィーダの精密な電気構成のクエリを備えてもよい。
【0080】
グラフ探索アルゴリズムは、1つ以上の選択された配電フィーダ内に含有されるノードおよびエッジのみを探索することによって、任意の所与の時刻における1つ以上の選択された配電フィーダの状態にクエリを行うために利用されてもよい。探索アルゴリズムは、あるデータ構造内に記憶される、または問題ドメインの探索空間内で計算される情報を読み出すために探索問題を解く、任意のアルゴリズムであってもよい。探索アルゴリズムの実施例は、限定ではないが、リンク付きリスト、アレイデータ構造、または探索木を含む。探索アルゴリズムはまた、線形探索アルゴリズム、二分探索アルゴリズム、ジャンプ探索アルゴリズム、補間探索アルゴリズム、指数関数的探索アルゴリズム、サブリスト探索アルゴリズム、比較探索アルゴリズム、およびデジタル探索アルゴリズムを備えることができる。
【0081】
グラフ探索アルゴリズムは、他の選択されていない配電フィーダ内に含有されるノードおよびエッジにクエリを行うように構成されなくてもよい。探索アルゴリズムは、他の不必要なノードにクエリを行うことなく、ノードのサブセットにのみ直接クエリを行うように構成されてもよい。探索アルゴリズムは、他の不必要なノードにクエリを行うことなく、ノードのサブセットにのみ間接的にクエリを行うように構成されてもよい。探索アルゴリズムは、他の不必要なエッジにクエリを行うことなく、ノードのサブセットにのみ直接クエリを行うように構成されてもよい。探索アルゴリズムは、他の不必要なエッジにクエリを行うことなく、ノードのサブセットにのみ間接的にクエリを行うように構成されてもよい。探索アルゴリズムは、他の不必要なノードおよびエッジにクエリを行うことなく、ノードのサブセットにのみ直接クエリを行うように構成されてもよい。探索アルゴリズムは、他の不必要なノードおよびエッジにクエリを行うことなく、ノードのサブセットにのみ間接的にクエリを行うように構成されてもよい。不必要なノードおよびエッジは、クエリに関連しないノードおよびエッジであり得る。
【0082】
FHDNは、履歴時間インスタンスにおけるネットワークの任意の部分におけるクエリが、従来のグラフ化技法を使用する2.1TBと比較して、約10MB~100MBのみの記憶域を使用しながら回答されることを可能にし得る。FHDNを記憶するために要求されるメモリの量は、多くても40MB、30MB、25MB、20MB、19MB、18MB、17MB、16MB、15MB、14MB、13.4MB、13MB、12MB、11MB、10MB、9MB、8MB、7MB、6MB、5MB、4MB、3MB、2MB、1MB、またはそれを下回るものであってもよい。ある場合には、FHDNを記憶するために要求されるメモリの量は、FHDNが表すシステムのサイズ、複雑性、および年数に応じて、はるかに多くてもよい。
材料表
【0083】
本システムは、任意の製造企業に関する材料表を備えてもよい。材料表(BOM)は、未加工材料、サブアセンブリ、中間アセンブリ、部分的コンポーネント、部品、および最終製品を製造するために必要とされるそれぞれの数量のリストを備えてもよい。BOMは、製造協力者の間のやり取りのために使用される、または単一の製造工場に限定されてもよい。
【0084】
BOMは、それらが設計される際(工学設計材料表)、それらが注文される際(販売材料表)、それらが構築される際(製造材料表)、またはそれらが保守される際(サービス材料表)の製品を定義することができる。異なるタイプのBOMは、ビジネス需要およびそれらが意図される使用に依存する。BOMはまた、調合表、レシピ、または原料リストを備えてもよい。電子機器では、BOMは、印刷配線基板または印刷回路基板上で使用されるコンポーネントのリストを表してもよい。
【0085】
本システムは、サプライチェーン流通ネットワークを備えてもよい。サプライチェーン流通ネットワークは、複数のプレーヤ(例えば、買い手または売り手)を備えてもよい。複数のプレーヤは、複数の接続を通して相互に接続されてもよい。接続は、購入、販売、または購入および販売を表してもよい。
【0086】
サプライチェーン流通ネットワークの状態は、履歴時間インスタンスにおける複数のプレーヤのグラフィカル状態を備えてもよい。サプライチェーン流通ネットワークの状態は、履歴時間インスタンスにおけるプレーヤを接続する複数の接続のグラフィカル状態を備えてもよい。
【0087】
サプライチェーン流通ネットワークの状態は、履歴時間インスタンスにおけるプレーヤのサブセットのグラフィカル状態を備えてもよい。グラフィカル状態は、履歴時間インスタンスにおけるサプライチェーン流通ネットワーク内でアクティブである全てのプレーヤを備えてもよい。履歴時間インスタンスにおける全てのプレーヤは、本システムのサブセットであってもよい。プレーヤのサブセットは、サプライチェーン流通ネットワークのプレーヤの少なくとも約4%、5%、6%、7%、8%、9%、10%、15%、20%、30%、40%、50%、60%、70%、80%、90%、またはそれを上回るものを備えてもよい。他の場合では、プレーヤのサブセットは、サプライチェーン流通ネットワークのプレーヤの多くても約90%、80%、70%、60%、50%、40%、30%、20%、15%、10%、9%、8%、またはそれを下回るものを備えてもよい。
【0088】
FHDNは、履歴時間インスタンスに関するクエリが、履歴時間インスタンスにおけるサプライチェーン流通ネットワークの全ネットワークインスタンス化を要求することなく回答されることを可能にし得る。サプライチェーン流通ネットワークでは、FHDNは、複数のプレーヤ(複数のノードによって表される)と、プレーヤを接続する、複数の接続(複数のエッジによって表される)と、複数のプレーヤおよび接続のそれぞれと関連付けられる、時系列とを備えてもよい。サプライチェーン流通システムのFHDNは、サプライチェーン流通システム内にこれまで存在していた全てのプレーヤおよび全ての接続を備えてもよい。
【0089】
複数のノードおよびエッジおよび時系列は、複数のプレーヤと関連付けられてもよい。複数のノードおよびエッジは、(1)任意の所与の時刻におけるサプライチェーン流通システム内に以前に存在していた全てのノードおよびエッジと、(2)サプライチェーン流通システム内に現在存在している全てのノードおよびエッジとを備えてもよい。他の実施形態では、複数のノードおよびエッジは、(1)任意の所与の時刻におけるサプライチェーン流通システム内に以前に存在していた全てのノードおよびエッジと、(2)サプライチェーン流通システム内に現在存在している全てのノードおよびエッジと、(3)サプライチェーン流通システム内に存在しているであろう全てのノードおよびエッジとを備える。
【0090】
時系列は、サプライチェーン流通システム内の選択されたノードまたはエッジに関する追加または除去の精密な時間を備えてもよい。時系列は、サプライチェーン流通システム内の選択されたノードまたはエッジに関する追加、除去、または訂正の精密な時間を備えてもよい。サプライチェーン流通システムでは、追加は、プレーヤが他のプレーヤから購入する、またはそれに販売するために開かれていることを表してもよく、除去は、プレーヤが他のプレーヤから購入する、またはそれに販売するために開かれていないことを表してもよく、訂正は、プレーヤが他のプレーヤから購入する、またはそれに販売する際の自身の立場を変更することを表してもよい。時系列は、系統的または非系統的時間間隔を通して取得されてもよい。非系統的時間間隔に関して、時系列は、最初に、第1の時間周期にわたって第1の時間に取得され、次いで、第2の時間周期にわたって第2の時間に取得されてもよい。例えば、時系列は、最初に、1分の第1の時間周期にわたって1s毎に取得され、次いで、10時間の第2の時間周期にわたって10s毎に取得されてもよい。
【0091】
グラフ探索アルゴリズムは、サプライチェーン流通ネットワーク内でアクティブであるノードおよびエッジのみを探索することによって、所与の時刻におけるサプライチェーン流通ネットワークの状態にクエリを行うために利用されてもよい。グラフ探索アルゴリズムは、グラフのノードを通して探索する順序を規定してもよい。グラフ探索アルゴリズムは、例えば、深さ優先探索または幅優先探索等の接続成分探索であってもよい。例えば、グラフ探索アルゴリズムは、ソースノードにおいて開始され、標的ノードが見出されるまで探索を続けてもよく、次いで、フロンティアは、まだ探索されていないノードを備えてもよく、反復の度に、ノードは、フロンティアから外され、その隣接物をフロンティアに追加してもよい。必要性基準は、ユーザによって設定されることができる。例えば、分析が、所与の時点におけるノードの小さいサブセットについての情報を要求する場合、FHDNデータ構造は、いかなる不必要なノードにも触れることなく本分析の結果を査定するために、直接クエリを行われることができる。探索アルゴリズムは、あるデータ構造内に記憶される、または問題ドメインの探索空間内で計算される情報を読み出すために探索問題を解く、任意のアルゴリズムであってもよい。例示的探索アルゴリズムが、本明細書の別の場所に説明される。グラフ探索アルゴリズムは、グラフのノードを通して探索する順序を規定してもよい。グラフ探索アルゴリズムは、深さ優先探索アルゴリズム、幅優先探索アルゴリズム、ダイクストラアルゴリズム、または同等物であってもよい。
【0092】
グラフ探索アルゴリズムは、サプライチェーン流通ネットワーク内に含有される選択されていないノードおよびエッジにクエリを行うように構成されなくてもよい。探索アルゴリズムは、他の不必要なノードおよび/またはエッジにクエリを行うことなく、ノードおよび/またはエッジのサブセットにのみ直接クエリを行うように構成されてもよい。探索アルゴリズムは、他の不必要なノードおよび/またはエッジにクエリを行うことなく、ノードおよび/またはエッジのサブセットにのみ間接的にクエリを行うように構成されてもよい。不必要なノードまたはエッジは、それぞれ、FHDN内の全てのノードまたはエッジの少なくとも約4%、5%、6%、7%、8%、9%、10%、15%、20%、30%、40%、50%、60%、70%、80%、90%、またはそれを上回るものを備えてもよい。他の場合では、不必要なノードまたはエッジは、それぞれ、FHDN内の全てのノードまたはエッジの多くても約90%、80%、70%、60%、50%、40%、30%、20%、15%、10%、9%、8%、またはそれを下回るものを備えてもよい。
【0093】
FHDNは、履歴時間インスタンスにおけるサプライチェーン流通ネットワークの任意の部分におけるクエリが、少ない記憶域のみを要求しながら回答されることを可能にし得る。FHDNを記憶するために要求されるメモリの量は、多くても40MB、30MB、25MB、20MB、19MB、18MB、17MB、16MB、15MB、14MB、13.4MB、13MB、12MB、11MB、10MB、9MB、8MB、7MB、6MB、5MB、4MB、3MB、2MB、1MB、またはそれを下回るものであってもよい。ある場合には、FHDNを記憶するために要求されるメモリの量は、FHDNが表すシステムのサイズ、複雑性、および年数に応じて、はるかに多くてもよい。
ソーシャルネットワーク
【0094】
本システムは、複数のユーザから成る、ソーシャルネットワークを備えてもよい。本システムは、複数のソーシャルネットワークを備えてもよい。複数のソーシャルネットワークは、複数の接続を通して相互に接続されてもよい。複数のソーシャルネットワークの所与のソーシャルネットワークは、複数のユーザ(ノードによって表される)と、複数の接続(エッジによって表される)とを備えてもよい。
【0095】
本明細書に説明されるシステムは、履歴における特定の時点でのソーシャルネットワークの状態にクエリを行うために使用されることができる。そのような状態は、例えば、ソーシャルネットワーク上の人々の人口における人口統計学的変化を追跡するために使用されることができる。そのような状態はまた、ソーシャルネットワークのユーザにとって興味深いものであり得、したがって、そのようなユーザは、自身のソーシャルサークルが経時的に成長している様子を確認することができる。本システムの状態は、履歴時間インスタンスにおける複数のソーシャルネットワークのグラフィカル状態を備えてもよい。本システムの状態は、履歴時間インスタンスにおけるソーシャルネットワークを接続する複数の接続のグラフィカル状態を備えてもよい。履歴時間におけるソーシャルネットワークの数は、少なくとも1個、10個、50個、100個、200個、300個、400個、500個、1,000個、10,000個、またはそれを上回るものであってもよい。履歴時間におけるソーシャルネットワークの数は、多くても10,000個、1,000個、500個、400個、300個、200個、100個、50個、10個、またはそれを下回るものであってもよい。履歴時間インスタンスにおけるソーシャルネットワークを接続する接続の数は、少なくとも1個、10個、50個、100個、200個、300個、400個、500個、1,000個、10,000個、またはそれを上回るものであってもよい。履歴時間インスタンスにおけるソーシャルネットワークを接続する接続の数は、多くても10,000個、1,000個、500個、400個、300個、200個、100個、50個、10個、またはそれを下回るものであってもよい。
【0096】
本システムの状態は、履歴時間インスタンスにおけるソーシャルネットワークのサブセットのグラフィカル状態を備えてもよい。グラフィカル状態は、履歴時間インスタンスにおいてアクティブである全てのソーシャルネットワークを備えてもよい。履歴時間インスタンスにおける全てのソーシャルネットワークは、本システムのサブセットであってもよい。ソーシャルネットワークのサブセットは、本システムの全ソーシャルネットワークの少なくとも約4%、5%、6%、7%、8%、9%、10%、15%、20%、30%、40%、50%、60%、70%、80%、90%、またはそれを上回るものを備えてもよい。他の場合では、ソーシャルネットワークのサブセットは、本システムの全ソーシャルネットワークの多くても約90%、80%、70%、60%、50%、40%、30%、20%、15%、10%、9%、8%、またはそれを下回るものを備えてもよい。
【0097】
FHDNは、履歴時間インスタンスに関するクエリが、履歴時間インスタンスにおける本システムの全ネットワークインスタンス化を要求することなく回答されることを可能にし得る。本システムでは、FHDNは、複数のユーザ(複数のノードによって表される)と、ユーザを接続する、複数の接続(複数のエッジによって表される)と、複数のユーザおよび接続のそれぞれと関連付けられる、時系列とを備えてもよい。接続は、友人をフォローまたは追加することを表してもよい。ソーシャルネットワークのFHDNは、本システム内にこれまで存在していた全てのユーザおよび全ての接続を備えてもよい。
【0098】
複数のノードおよびエッジおよび時系列は、複数のソーシャルネットワークおよび各ソーシャルネットワーク内の接続されたノードおよびブランチと関連付けられてもよい。複数のノードおよびエッジは、(1)任意の所与の時刻におけるソーシャルネットワーク内に以前に存在していた全てのノードおよびエッジと、(2)ソーシャルネットワーク内に現在存在している全てのノードおよびエッジとを備えてもよい。他の実施形態では、複数のノードおよびエッジは、(1)任意の所与の時刻におけるソーシャルネットワーク内に以前に存在していた全てのノードおよびエッジと、(2)ソーシャルネットワーク内に現在存在している全てのノードおよびエッジと、(3)ソーシャルネットワーク内に存在しているであろう全てのノードおよびエッジとを備えてもよい。
【0099】
時系列は、ソーシャルネットワーク内の選択されたノードまたはエッジに関する追加または除去の精密な時間を備えてもよい。時系列は、ソーシャルネットワーク内の選択されたノードまたはエッジに関する追加、除去、または訂正の精密な時間を備えてもよい。ソーシャルネットワークでは、追加は、ユーザが友人として別のユーザを追加する、または別のユーザをフォローすることを表してもよく、除去は、ユーザが別のユーザをブロックする、または友人から削除することを表してもよく、訂正は、ユーザが別のユーザに対する自身の立場を変更することを表してもよい。系統的時間間隔に関して、時系列は、最初に、第1の時間周期にわたって第1の時間に取得され、次いで、第2の時間周期にわたって第2の時間に取得されてもよい。例えば、時系列は、最初に、1分の第1の時間周期にわたって1s毎に取得され、次いで、10時間の第2の時間周期にわたって10s毎に取得されてもよい。
【0100】
グラフ探索アルゴリズムは、着目ソーシャルネットワーク内に含有されるノードおよびエッジのみを探索することによって、任意の所与の時刻におけるソーシャルネットワークの状態にクエリを行うために利用されてもよい。探索アルゴリズムは、あるデータ構造内に記憶される、または問題ドメインの探索空間内で計算される情報を読み出すために探索問題を解く、任意のアルゴリズムであってもよい。例示的探索アルゴリズムが、本明細書の別の場所に説明される。
【0101】
グラフ探索アルゴリズムは、必要に応じて選択されたソーシャルネットワーク内に含有されるノードおよびエッジのステータスのみにクエリを行うように構成されてもよい。グラフ探索アルゴリズムは、他の選択されていないソーシャルネットワーク内に含有されるノードおよびエッジにクエリを行うように構成されなくてもよい。探索アルゴリズムは、他の不必要なノードおよび/またはエッジにクエリを行うことなく、ノードおよび/またはエッジのサブセットにのみ直接クエリを行うように構成されてもよい。他の実施形態では、探索アルゴリズムは、他の不必要なノードおよび/またはエッジにクエリを行うことなく、ノードおよび/またはエッジのサブセットにのみ間接的にクエリを行うように構成されてもよい。不必要なノードまたはエッジは、それぞれ、FHDN内の全てのノードおよびエッジの少なくとも約4%、5%、6%、7%、8%、9%、10%、15%、20%、30%、40%、50%、60%、70%、80%、90%、またはそれを上回るものを備えてもよい。他の場合では、不必要なノードまたはエッジは、それぞれ、FHDN内の全てのノードおよびエッジの多くても約90%、80%、70%、60%、50%、40%、30%、20%、15%、10%、9%、8%、またはそれを下回るものを備えてもよい。FHDNを記憶するために要求されるメモリの量は、多くても40MB、30MB、25MB、20MB、19MB、18MB、17MB、16MB、15MB、14MB、13.4MB、13MB、12MB、11MB、10MB、9MB、8MB、7MB、6MB、5MB、4MB、3MB、2MB、1MB、またはそれを下回るものであってもよい。ある場合には、FHDNを記憶するために要求されるメモリの量は、FHDNが表すシステムのサイズ、複雑性、および年数に応じて、はるかに多くてもよい。
他の実施形態
【0102】
別の側面では、動的ネットワークの履歴状態を決定するためのシステムは、データ集約コンポーネントと、ネットワークグラフ化コンポーネントとを備えてもよい。
【0103】
データ集約コンポーネントは、複数の異なるデータソースからシステムと関連付けられるデータを連続的に取得するように構成されてもよい。データソースは、本明細書の別の場所に解説される。データ集約コンポーネントは、データ集約を実施してもよい。データ集約は、グラフ集約を備えてもよい。グラフ集約では、トポロジおよびパラメータ値における時間的変動は、空間ネットワークを表すために使用されるグラフ内のエッジ/ノード属性として集約物を使用して表されることができる。エッジおよびノードは、ある時刻の間にネットワークから消失することができ、新しいノードおよびエッジが、追加されることができる。時間集約グラフは、種々の時刻におけるその存在を示す、各ノードおよびエッジに取り付けられる時系列を通してこれらの変化を追跡することができる。
【0104】
ネットワークグラフ化コンポーネントは、データを使用して、本システムの全履歴動的ネットワーク(FHDN)を構築し、履歴時間インスタンスに関するFHDNのクエリに応答して、履歴時間インスタンスに関する本システムの状態を提供するように構成されてもよい。FHDNは、(1)動的に変化することが可能である、複数のノードと、(2)ノードを接続する、複数のエッジであって、エッジは、動的に変化することが可能である、複数のエッジと、(3)複数のノードおよびエッジのそれぞれと関連付けられる、時系列とを備えてもよい。FHDNは、本明細書の別の場所に説明される。
【0105】
本システムはさらに、ディスプレイコンポーネントを備えてもよい。ディスプレイコンポーネントは、スピーカまたはディスプレイ画面を備えてもよい。スピーカおよび/またはディスプレイ画面は、電子デバイスと動作的に結合されてもよい。スピーカおよび/またはディスプレイ画面は、電子デバイスと統合されてもよい。電子デバイスは、小型アラート装置であってもよい。電子デバイスは、ポータブル電子デバイスであってもよい。電子デバイスは、モバイル電話、PC、タブレット、プリンタ、家庭用電子機器、および家電製品であってもよい。電子デバイスは、限定ではないが、Fitbit、Apple watch、Samsung health、Misfit、Xiaomi Mi band、およびMicrosoft bandを含む、ウェアラブルデバイスであってもよい。ディスプレイ画面は、タブレットコンピュータと同様に、液晶ディスプレイであってもよい。ディスプレイ画面は、1つ以上のスピーカを伴ってもよく、視覚的および聴覚的命令をユーザに提供するように構成されてもよい。スピーカは、スマートスピーカを備えてもよい。スマートスピーカは、Alexa、Google Home、Google Assistant、Clova、Microsoft Cortana、AliGenie、Ambient、Apple HomeKit、Apple Siri、およびApple Podを備えてもよい。
【0106】
別の側面では、非一過性コンピュータ可読媒体は、1つ以上のサーバによって実行されると、1つ以上のサーバに、複数の異なるデータソースからシステムと関連付けられるデータを連続的に取得するステップと、データを使用して、本システムの全履歴動的ネットワーク(FHDN)を構築するステップと、履歴時間インスタンスに関するFHDNのクエリに応答して、履歴時間インスタンスに関する本システムの状態を提供するステップとを含む、方法を実施させる、命令を記憶してもよい。
【0107】
データは、データベース内に記憶されてもよい。データベースが、コンピュータ可読フォーマットにおいて記憶されてもよい。コンピュータプロセッサが、コンピュータ可読メモリ内に記憶されるデータにアクセスするように構成されてもよい。コンピュータシステムが、データを分析し、結果を取得するために使用されてもよい。結果は、非一過性コンピュータ可読媒体上で遠隔または内部で記憶され、本システムまたはFHDNのユーザに通信されてもよい。非一過性コンピュータ可読媒体は、結果を伝送するためのコンポーネントと動作的に結合されてもよい。伝送するためのコンポーネントは、有線および無線コンポーネントを含むことができる。有線通信コンポーネントの実施例は、ユニバーサルシリアルバス(USB)接続、同軸ケーブル接続、Cat5またはCat6ケーブル等のイーサネット(登録商標)ケーブル、光ファイバケーブル、または電話回線を含むことができる。無線通信コンポーネントの実施例は、Wi-Fi受信機、3Gまたは4G LTEデータ信号等のモバイルデータ規格にアクセスするためのコンポーネント、またはBluetooth(登録商標)受信機を含むことができる。非一過性コンピュータ可読媒体内の全てのこれらのデータは、データウェアハウスを構築するために収集およびアーカイブ化されてもよい。
【0108】
FHDNは、(1)動的に変化することが可能である、複数のノードと、(2)ノードを接続する、複数のエッジであって、エッジは、動的に変化することが可能である、複数のエッジと、(3)複数のノードおよびエッジのそれぞれと関連付けられる、時系列とを備えてもよい。FHDNは、本明細書の別の場所に説明される。
【0109】
本明細書に説明されるシステムおよび方法は、例えば、米国特許出願公開第2018/0191867号(「Systems, Methods, and Devices for an Enterprise AI and Internet-of-Things Platform」と題される)(参照することによってその全体として本明細書に組み込まれる)に説明されるプラットフォームの種々の実施形態を使用して実装されることができる。
【0110】
本発明の好ましい実施形態が、本明細書に示され、説明されているが、そのような実施形態は、実施例としてのみ提供されることが当業者に明白であろう。本発明は、本明細書内に提供される具体的実施例によって限定されることを意図していない。本発明は、前述の本明細書を参照して説明されているが、本明細書の実施形態の説明および例証は、限定的意味で解釈されることを意味していない。多数の変形例、変更、および代用が、ここで、本発明から逸脱することなく、当業者に想起されるであろう。さらに、本発明の全ての側面は、種々の条件および変数に依存する、本明細書に記載される具体的描写、構成、または相対的割合に限定されないことを理解されたい。本明細書に説明される本発明の実施形態の種々の代替が、本発明を実践する際に採用され得ることを理解されたい。したがって、本発明はまた、任意のそのような代替、修正、変形例、または均等物を網羅することが想定される。以下の請求項は、本発明の範囲を定義し、これらの請求項の範囲内の方法および構造およびその均等物が、それによって網羅されることを意図している。
図1
図2
図3