JP2016501401A - 動的グラフ性能監視 - Google Patents

動的グラフ性能監視 Download PDF

Info

Publication number
JP2016501401A
JP2016501401A JP2015542845A JP2015542845A JP2016501401A JP 2016501401 A JP2016501401 A JP 2016501401A JP 2015542845 A JP2015542845 A JP 2015542845A JP 2015542845 A JP2015542845 A JP 2015542845A JP 2016501401 A JP2016501401 A JP 2016501401A
Authority
JP
Japan
Prior art keywords
performance metrics
data flow
flow graph
data
micrograph
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
JP2015542845A
Other languages
English (en)
Inventor
ブックスバウム,マーク
ジー. ムリガン,マイケル
ジー. ムリガン,マイケル
ウェイクリング,ティム
ダーシー アターバリー,マシュー
ダーシー アターバリー,マシュー
Original Assignee
アビニシオ テクノロジー エルエルシー
アビニシオ テクノロジー エルエルシー
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by アビニシオ テクノロジー エルエルシー, アビニシオ テクノロジー エルエルシー filed Critical アビニシオ テクノロジー エルエルシー
Publication of JP2016501401A publication Critical patent/JP2016501401A/ja
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/3003Monitoring arrangements specially adapted to the computing system or computing system component being monitored
    • G06F11/3041Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system component is an input/output interface
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/3003Monitoring arrangements specially adapted to the computing system or computing system component being monitored
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/32Monitoring with visual or acoustical indication of the functioning of the machine
    • G06F11/323Visualisation of programs or trace data
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3404Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for parallel or distributed programming
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3466Performance evaluation by tracing or monitoring
    • G06F11/3476Data logging
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/3065Monitoring arrangements determined by the means or processing involved in reporting the monitored data
    • G06F11/3072Monitoring arrangements determined by the means or processing involved in reporting the monitored data where the reporting involves data filtering, e.g. pattern matching, time or event triggered, adaptive or policy-based reporting
    • G06F11/3082Monitoring arrangements determined by the means or processing involved in reporting the monitored data where the reporting involves data filtering, e.g. pattern matching, time or event triggered, adaptive or policy-based reporting the data filtering being achieved by aggregating or compressing the monitored data
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3409Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment
    • G06F11/3419Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment by assessing time
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/865Monitoring of software
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q30/00Commerce
    • G06Q30/02Marketing; Price estimation or determination; Fundraising
    • G06Q30/0201Market modelling; Market analysis; Collecting market data

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Quality & Reliability (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Computing Systems (AREA)
  • Mathematical Physics (AREA)
  • Data Mining & Analysis (AREA)
  • Debugging And Monitoring (AREA)
  • Stored Programmes (AREA)

Abstract

【課題】 動的グラフ性能監視のための、コンピュータ記憶媒体上に符号化されたコンピュータプログラムを含む方法、システム、及び装置。【解決手段】 方法の1つは、各々が1つ以上のワーク要素を含む多数のワークユニットを受信することを含む。この方法は、第1のワークユニットの特性を判定することを含む。この方法は、判定した特性に基づいて、第1のデータフローグラフのコンポーネントによって、データ記憶システムに記憶されている多数の利用可能なデータフローグラフから第2のデータフローグラフを識別することを含む。この方法は、第2のデータフローグラフを用いて第1のワークユニットを処理することを含む。この方法は、処理に関連付けられた1つ以上の性能測定基準を確定することを含む。【選択図】 図2

Description

(優先権の主張)
本出願は、米国特許法第120条に基づき、2012年11月16日に出願された米国特許出願番号第13/678,921号に対する優先権を主張する。その全体的な内容は引用により本願にも含まれるものとする。
本記載は、動的グラフ性能測定基準の監視に関する。
多くの場合、演算は、有向グラフ(「データフローグラフ」と呼ばれる)を介したデータフローとして表現することができる。演算のコンポーネントはグラフの頂点に関連付けられ、コンポーネント間のデータフローはグラフのリンク(アーク、エッジ)に対応する。そのような演算を実行するためのシステムの物理的実施においては、適切なプログラム命令を実行するマイクロプロセッサ等のデータ処理要素を用いて、コンポーネント及びデータフローをインスタンス化することができる。コンポーネントには、1つ以上の入力ポートでデータを受信し、データを処理し、1つ以上の出力ポートからデータを供給するデータ処理コンポーネントと、データフローのソース又はシンクとして機能するデータセットコンポーネントと、が含まれ得る。また、コンポーネントは、データを例えば「動的コンポーネント」又は「マイクログラフ(micrograph)」において実行する際に動的にロードすることができる1つ以上のデータグラフも含む場合がある。このようなグラフベースの演算を実施するシステムが、「Executing Computations Expressed as Graphs」と題する米国特許第5,966,072号に記載されている。また、このようなグラフベースの演算において動的コンポーネントを実施するためのシステムが、例えば、「Dynamically Loading Graph-Based Computations」と題する米国特許出願第13/161,010号に示されている。
データフローグラフシステムは、大量のデータを極めて高速で処理しなければならない場合に用いられる。データフローグラフシステムの性能を監視することで、ユーザは、改善の可能性があるか又は不適切に実行している可能性のあるデータフローグラフのコンポーネントを個別に又はグループとして識別することができる。例えば性能の監視によって、ユーザは、過度のプロセッサ時間量を費やすか、待ち時間遅延を生じるか、又は故障を発生する傾向のあるコンポーネントを識別することができる。これらのコンポーネントは、そういった欠点を修正するために調べて変更することができる。
動的にロードされるコンポーネント(データフローグラフの実行時に選択されロードされるコンポーネント)は、既存のグラフを再コンパイルせずに新しい機能性の導入を可能とすることでデータフローグラフの機能性を強化する。しかしながら、動的にロードされるコンポーネントの監視は、複雑な問題を増やしてしまう。
一般に、データフローグラフの作成者は後に導入される動的コンポーネントの特性を知らないため、そのようなコンポーネントの監視が難しいことがある。従来、データフローグラフは、これらの動的コンポーネントの性能特性を適切に通知することができなかった。
同時に、動的コンポーネントは、性能上の問題を生じる可能性が高い。例えば動的コンポーネントの作成者は、そのコンポーネントをロードするデータフローグラフの構築におけるニュアンスを知らないことがある。従って、動的コンポーネントが不必要な動作を実行したり、データフローグラフの残りの部分の処理又は性能に悪影響を及ぼしたりする恐れがある。
動的コンポーネントを考慮に入れるようにデータフローグラフの監視機能を拡張することで、データフローグラフシステムを監視する能力が向上する。
1つの態様において、概して、データを処理するための方法は、各々が1つ以上のワーク要素を含む多数のワークユニットを受信することを含む。この方法は、第1のワークユニットの特性を判定することを含む。この方法は、判定した特性に基づいて、第1のデータフローグラフのコンポーネントによって、データ記憶システムに記憶されている多数の利用可能なデータフローグラフから第2のデータフローグラフを識別することを含む。この方法は、第2のデータフローグラフを用いて第1のワークユニットを処理することを含む。この方法は、処理に関連付けられた1つ以上の性能測定基準を確定することを含む。
態様は、以下の特徴の1つ以上を含むことができる。第2のデータフローグラフは、第1のデータフローグラフとは無関係にコンパイルすることができる。この方法は、1つ以上の性能測定基準をメモリ内データ記憶に記憶することを含むことができる。この方法は、記憶した1つ以上の性能測定基準を永続データ記憶に転送することを含むことができる。この方法は、1つ以上の性能測定基準を以前に取得した性能測定基準と集約することを含むことができる。1つ以上の性能測定基準を集約することは、第2のデータフローグラフに関連付けられた識別子に基づいて1つ以上の性能測定基準を集約することを含むことができる。1つ以上の性能測定基準を集約することは、第1のデータフローグラフに関連付けられた識別子に基づいて1つ以上の性能測定基準を集約することを含むことができる。この方法は、1つ以上の性能測定基準をユーザに表示することを含むことができる。
態様は、以下の利点の1つ以上を含むことができる。動的コンポーネントの性能測定基準を収集し通知することができる。動的な実行の性能を監視することで生じる待ち時間を短縮することができる。
本発明の他の特徴及び利点は、以下の記載及び特許請求の範囲から明らかとなろう。
グラフベースの演算を実行するためのシステムのブロック図である。 マイクログラフのための性能測定基準を収集することができる例示的な環境を示す。 マイクログラフから性能測定基準を収集するためのフローチャートである。 マイクログラフ識別子によって性能測定基準を集約する一例を示す。 マイクログラフ作動コンポーネントが並列に実行される一例としての環境を示す。 「クレジット限度額引き上げ」トランザクションのためのマイクログラフの一例を示す。 システム監視アプリケーションのための一例としてのユーザインタフェースを示す。 マイクログラフを表示する一例としてのユーザインタフェースを示す。 追加の性能測定基準を表示する一例としてのユーザインタフェースを示す。 性能測定基準を収集するための一例としてのプロセスのフローチャートである。
図1は、性能監視技法を導入し得る例示的なデータ処理システム100を示す。システム100に含まれるデータソース102は、記憶デバイス又はオンラインデータストリームに対する接続のような1つ以上のデータソースを含むことができ、それらの各々が多種多様な記憶フォーマットのいずれかで(例えばデータベーステーブル、スプレッドシートファイル、フラットテキストファイル、又はメインフレームにより用いられるネイティブフォーマット)データを記憶することができる。実行環境104は、性能監視モジュール106及び実行モジュール112を含む。実行環境104は、UNIX(登録商標)オペレーティングシステム等の適切なオペレーティングシステムの制御のもとで、1つ以上の汎用コンピュータをホストとして動作することができる。例えば実行環境104は、多数の中央処理ユニット(CPU)(CPU「コア」と同様)を用いた複数のコンピュータシステムの構成を含む多ノード並列コンピューティング環境を含むことができ、これらは、ローカルである(例えば対称型マルチプロセッシング(SMP:symmetric multiprocessing)コンピュータ等のマルチプロセッサシステム)か、又はローカルに分散されている(例えばクラスタ又は超並列処理(MPP:massively parallel processing)として結合された多数のプロセッサ)か、又はリモートであるか、又はリモートに分散されている(例えば1つ以上のローカルエリアネットワーク(LAN)及び/又はワイドエリアネットワーク(WAN)を介して結合された多数のプロセッサ)か、又はそれらのいずれかの組み合わせであり得る。
実行モジュール112は、データソース102からデータを読み取る。データソース102を提供する記憶デバイスは、例えば実行環境104を動作させるコンピュータに接続された記憶媒体(例えばハードドライブ108)上に記憶することで、実行環境104に対してローカルとすることができ、又は、例えば実行環境104を動作させるコンピュータとリモート接続を介して通信するリモートシステム(例えばメインフレーム110)をホストとして動作することで、実行環境104に対してリモートとすることができる。
実行モジュール112は、データソース102からのデータを用いて、実行環境104にアクセス可能なデータ記憶システム116に記憶される出力レコード114を生成する。データ記憶システム116は、開発環境118にもアクセス可能である。開発環境118は、いくつかの実施では、データフローグラフとしてアプリケーションを開発するためのシステムである。データフローグラフは、頂点(コンポーネント又はデータセットを表す)を含み、頂点は、それらの間の有向リンク(ワーク要素のフローを表す)によって接続されている。例えばそのような環境は、「Managing Parameters for Graph-Based Applications」と題する米国公報第2007/0011668号に、より詳細に記載されている。この出願は引用により本願にも含まれるものとする。このようなグラフベースの演算を実行するためのシステムは、「Executing Computations Expressed as Graphs」と題する米国特許第5,566,072号に記載されている。この出願は引用により本願にも含まれるものとする。本明細書において用いる場合、「グラフ」及び「マイクログラフ」という用語は、1組の命令を指し、これらの命令を実行するプロセッサに関連付けられている。このシステムに従って生成されたデータフローグラフは、グラフコンポーネントにより表される個々のプロセスに対する情報の出し入れをするため、プロセス間で情報を移動させるため、及びプロセスについて実行順序を規定するための機構を提供する。このシステムは、プロセス間の通信方法を選択するアルゴリズムを含む(例えば、グラフのリンクに従った通信経路は、プロセス間のデータの受け渡しのためにTCP/IP又はUNIX(登録商標)ドメインソケット又は共有メモリを用いることができる)。
実行モジュール112は、異なる形態のデータベースシステムを含む多種多様なタイプのシステムからデータを受信することができる。データは、ヌル値を含むことがある、各フィールド(「属性」又は「列」とも呼ばれる)のための値を有するレコードとして組織化することができる。最初にデータソースからデータを読み取る際、実行モジュール112は典型的に、そのデータソース内のレコードに関する何らかの初期フォーマット情報から開始する。いくつかの状況では、データソースのレコード構造は最初は知られていないことがあり、データソースの解析後に確定することができる。レコードに関する初期情報は、別個の値を表すビット数、レコード内のフィールドの順序、及びビットにより表される値のタイプ(例えばストリング、符号付き/符号なし整数)を含み得る。
性能監視モジュール106は、実行モジュール112の性能に関する性能測定基準を収集する。以下で論じるように、これらの測定基準は例えば、読み取ったレコード数、読み取ったバイト数、書き込んだレコード数、書き込んだバイト数、費やしたプロセッサ時間、及び経過時間のいくつか又は全てを含み得る。図2は、実行モジュールにより実行されるマイクログラフの性能測定基準を収集するための例示的な環境を示す。一般に、マイクログラフは、動的に取得されてマイクログラフ作動コンポーネント210内に埋め込まれるように構成された特別なサブグラフである。そのような動的にロードされたグラフを実行するためのシステムは、「Dynamically Loading Graph-Based Computations」と題する米国出願第13/161,010号に記載されている。この出願は引用により本願にも含まれるものとする。いくつかの実施では、マイクログラフはプリコンパイルすることができる。
実行モジュール112はグラフ202を実行する。実行モジュールは、例えばコンピュータシステムにより実行されている1つのプロセス又は1組のプロセスとすることができる。グラフは、データ記憶116等の非一時的な(non-transitory)コンピュータ読み取り可能記憶デバイスに記憶することができる1組のコンピュータ読み取り可能命令であり得る。グラフ202は、例えば図1のデータ記憶116のようなデータ記憶からロードすることができる。
この例では、グラフ202は、データソース204からデータを読み取るコンポーネント206を含む。コンポーネント206は、リンク208によってマイクログラフ作動コンポーネント210に接続されている。コンポーネント206の出力ポートからのデータレコードは、マイクログラフ作動コンポーネント210の入力ポートに渡される。一般に、ポートとは、データフローグラフのコンポーネントがデータを受信又は供給することを可能とするいずれかの機構を指す。ポートは例えば、伝送制御プロトコル(TCP)/インターネットプロトコル(IP)ポート、ネットワークソケット、又はソフトウェアパイプとすればよい。また、ポートは、例えば共有メモリに対する読み取り及び書き込み等、コンポーネント間の他の通信方法を指す場合もある。
マイクログラフ作動コンポーネント210は、実行するマイクログラフ212を選択する。例えば、クレジット処理システムは、異なるユーザのために多数のアクションを実行し得る。アクションは、アドレスの変更、クレジット限度額の引き上げ、及びクレジットカードのキャンセルを含むことができる。これらのアクティビティの各々は、データレコードに記憶された異なるコードに関連付けることができる。一連のデータレコードは、例えば第1のユーザからの第1のアドレス変更、第2のユーザからの第2のアドレス変更、第3のユーザからのクレジットカードキャンセル要求、第4のユーザからの第3のアドレス変更、及び第5のユーザからのクレジット限度額の引き上げ要求を含み得る。
これらのレコードの各々を処理するため、1つ以上の異なるマイクログラフ212を選択することができる。例えば、アドレス変更をアドレス変更マイクログラフによって処理し、クレジットカードキャンセルをクレジットカードキャンセルマイクログラフによって処理し、クレジット限度額の引き上げをクレジット限度額引き上げマイクログラフによって処理することができる。マイクログラフは、データ記憶内に記憶し、実行時に動的にロードすればよい。いくつかの実施では、マイクログラフは、マイクログラフ作動コンポーネントによってアクセスされるプリコンパイルされたデータフローグラフとすることができる。
マイクログラフ作動コンポーネントは、出力ポート214上に出力レコードを生成することができ、出力レコードはデータ記憶216に記憶することができる。
マイクログラフ作動コンポーネント210は、マイクログラフ212の性能特性を監視し記録することができる。例えばマイクログラフ作動コンポーネント210は、費やしたプロセッサ時間、経過時間、読み取ったバイト数、読み取ったレコード数、書き込んだバイト数、書き込んだレコード数、実行数、失敗した実行数、全持続時間、平均レコード処理率(レコード/秒)、平均バイト処理率(バイト/秒)等の性能測定基準を収集することができる。
性能測定基準は、マイクログラフ作動コンポーネント210の第2の出力ポート218上に生成され得る。例えば性能測定基準は、他の選択されたマイクログラフと共に、選択されたマイクログラフ212の性能に関する情報を含む1つ以上のレコードであり得る。
性能測定基準は、性能監視モジュール106のデータ記憶220に記憶することができる。いくつかの実施では、データ記憶220は、性能測定基準を書き込むことの性能上の影響を最小限に抑えるように選択される。例えば、性能測定基準をデータ記憶220に書き込むことによって生じる待ち時間を短縮することが有利となり得る。いくつかの実施では、データ記憶220は共有メモリ220内に配置することができる。共有(例えば半導体)メモリに書き込む動作は、概ねオーバーヘッドが小さいために、磁気ディスク等の永続データ記憶に書き込む同様の動作に比べて高速である。
例えば5分ごと、10分ごと、又は30分ごとのように定期的に、転送コンポーネント222がデータ記憶220から性能測定基準を読み取って、この性能測定基準をシステム監視ログ224に書き込む。いくつかの実施では、システム監視ログは永続データ記憶内に配置することができる。
システム監視コンポーネント226は、データ記憶220から性能測定基準を読み取り、データを更に処理して集約することができる。例えばシステム監視アプリケーションは、一緒に単一のビジネストランザクションを構成する多数のデータフローグラフに関連付けられた性能測定基準を組み合わせることができる。システム監視アプリケーションは、性能測定基準をユーザ228に提示することができる。一般に、各データレコードがマイクログラフ作動コンポーネント210により受信された結果として、異なるマイクログラフのロード及び処理が行われるが、多数のデータレコードを処理するために同一のマイクログラフを用いることも可能である。
図3は、データレコードの内容に基づいてロードされたマイクログラフから性能測定基準を収集するプロセスのフローチャートである。このプロセスは、例えば図1の実行モジュール112のような実行モジュールによって実行することができる。
302において、例えばマイクログラフ作動コンポーネントの入力ポートでデータを受信する。一般に、データは1つ以上のレコードの形態とすることができる。レコードは、1つ以上のフィールドに対応し得る1つ以上の値を含むことができる。例えばクレジットカードトランザクションのデータレコードは、口座識別子フィールドに対応する4つの整数値から成る4つのグループ(例えば「1234 1234 1234 1234」)を含む場合がある。
各レコードについて、304ではマイクログラフをロードすることができ、306ではマイクログラフを実行することができ、308では測定基準を処理することができる。
マイクログラフは、永続データ記憶等の1つ以上の位置又はデバイスからロードするか、又はメモリ内に記憶することができる。マイクログラフのロードは、例えばレコード内のデータの一部を含むデータを評価することによってロードに適したマイクログラフを選択することを含み得る。レコードに含まれるデータの評価に基づいて、1つ以上のマイクログラフからマイクログラフを選択することができる。例えば、特定のフィールド又はフィールドの組み合わせが、どのマイクログラフをロードするかを決定することができる。
一般に、マイクログラフの選択に用いられるデータは制御データと称される。いくつかの実施において、制御データは、処理対象のデータとは別個のデータレコードでマイクログラフ作動コンポーネントに提供することができる。他の実施では、制御データは、各データレコードに組み込まれ、いくつかの例では処理対象のデータも含む場合がある。
マイクログラフは、コンパイルしてデータ記憶に記憶することができる。いくつかの構成において、マイクログラフは、以前にコンパイルされてデータ記憶システムに記憶されたデータフローグラフであるか、又はそのようなデータフローグラフから導出される。いくつかの構成では、マイクログラフは、データ記憶からのロード時にはコンパイルされていない形態のままである。マイクログラフは、マイクログラフ作動コンポーネントを含むデータフローグラフとは無関係にコンパイルすることができる。
306におけるマイクログラフの実行は、マイクログラフの入力ポートにデータレコードを提供すること及びマイクログラフの出力ポートから出力レコードを受信することを含むことができる。いくつかの実施では、マイクログラフは、ゼロ以上のデータレコードを受信し、ゼロ以上の出力レコードを生成することができる。
308における測定基準の処理は、マイクログラフのための性能測定基準を確定することを含むことができる(例えばプロセッサ時間、経過時間、読み取ったバイト、及び書き込んだバイト)。測定基準は集約することができる。すなわち、マイクログラフの1回以上の実行を通して測定基準を合計することができる。例えば性能測定基準は、マイクログラフに関連付けられた名前又は他のラベルに基づいて集約すればよい。例えば、「クレジットカードキャンセル」マイクログラフの全ての実行の性能を組み合わせることができる。更に、マイクログラフが実行された回数を追跡することができる。性能測定基準は、メモリ内データ記憶に記憶すればよい。
310において、処理対象のレコードが更に存在するか否かを判定する。例えば、1つのマイクログラフは多数の入力レコードを処理して単一の出力レコードを生成することができる。マイクログラフ又はマイクログラフ作動コンポーネントが追加のレコードを必要とする場合、302において新しいレコードをデータとして受信する。これ以上レコードが必要でない場合、312において出力レコードが供給され、記憶される。
性能測定基準は、マイクログラフ作動コンポーネントに基づいて集約することができる。すなわち、特定のマイクログラフ作動コンポーネントによる全てのマイクログラフの全ての実行を集約する。また、性能測定基準は、上述のようにマイクログラフ識別子によって集約することも可能である。すなわち、特定のタイプのマイクログラフによる全ての実行を集約する。マイクログラフ識別子は、例えばマイクログラフの名前であり得る。
性能測定基準は、集約せずに、マイクログラフの個々の実行ごとに記憶してもよい。いくつかの実施において、マイクログラフ作動コンポーネントは、どのように性能測定基準を集約するかを指示するユーザ定義パラメータを受信するように構成することができる。
上述のように、マイクログラフの実行中に収集される性能測定基準は、測定基準の収集の際に集約することができる。図4は、マイクログラフ識別子によって性能測定基準を集約する一例を示す。集約された性能測定基準は、システム監視アプリケーションによって用いられ、ユーザに表示することができる。表400は、例えば図2のデータ記憶220のようなデータ記憶に配置することができる。この例において、表は、「マイクログラフ識別子」列402、「プロセッサ時間」列404、「経過時間」列406、及び「呼び出し」列408を含む。最初に、表は、「クレジットカードキャンセル」マイクログラフの識別子、「購入」マイクログラフの識別子、及び「支払い」マイクログラフの識別子のための行を含む。
例えば図2のマイクログラフ作動コンポーネント210のようなマイクログラフ作動コンポーネントがマイクログラフを実行した場合、表400を更新することができる。この例では、データレコード412により表される「クレジットカードキャンセル」マイクログラフの新しい呼び出しに基づいて表400が更新される。新しい呼び出しは、0.04秒のプロセッサ時間及び0.10秒の経過時間を含む。
表400から、「クレジットカードキャンセル」行410が読み取られ、新しい呼び出しからの情報によって更新される。この例では、「クレジットカードキャンセル」マイクログラフの累積性能測定基準は、32回の呼び出しで1.23秒のプロセッサ時間及び2.62秒の経過時間を含む。新しいレコードが追加された後、更新されたクレジットカードキャンセル行414は、33回の呼び出しで1.27秒のプロセッサ時間(1.23秒+0.04秒)及び2.72秒の経過時間を含む。
このように、マイクログラフの実行中に性能測定基準を集約することができる。性能測定基準の集約は、表400を記憶し管理するのに必要なメモリオーバーヘッドの量を最小限に抑えるという利点を有することができる。
同一のデータフローグラフの異なるインスタンスが並列に実行されることがあるので、性能測定基準の集約は複雑化する。例えば、多数の異なる計算機が、同一のマイクログラフの異なるインスタンスについて同時に実行及び性能測定基準の収集を行っている場合がある。
図5は、マイクログラフ作動コンポーネントが並列に実行する一例としての環境を示す。マイクログラフ作動コンポーネントの各インスタンスは、1つの計算機、仮想計算機、プロセッサ等において実行することができる。
この例では、分割部502は、マイクログラフ作動コンポーネント210a、210b、及び210cの多数のインスタンス間で入力レコードのフローを分割する。いったんマイクログラフ作動コンポーネントが入力レコードを処理して出力レコードを生成すると、出力レコードは収集部504により収集される。
各マイクログラフ作動コンポーネントの性能測定基準は、データ記憶220に送出して、各並列インスタンスについて集約するか、又は並列インスタンスごとに別個に記憶することができる。いくつかの実施では、各並列インスタンスの性能測定基準は、マイクログラフ作動インスタンスと同じ計算機又はデバイス上に配置された別個のデータ記憶に記憶することができる。
サブグラフとして、各マイクログラフは、データレコードを用いて1つ以上の異なる動作を実行する多数の個別コンポーネントを含むことができる。いくつかの実施では、マイクログラフは、マイクログラフの個々のコンポーネントの性能に関する追加情報(例えばより詳細な情報)を通知するような機器を備えることができる。図6は、「クレジット限度額引き上げ」トランザクションのためのマイクログラフの一例を示す。
この例において、「クレジット限度額引き上げ」マイクログラフ602は、入力ポート604において入力レコードを受け取る。「クレジット限度額引き上げ」マイクログラフ602は多数のコンポーネントを含む。例えば、クレジット限度額引き上げを要求するユーザの支払い履歴を取得する履歴取得コンポーネント606、ユーザのクレジットをチェックするクレジットチェックコンポーネント608、履歴及びクレジットチェックに基づいて新しいクレジット限度額を選択する限度額選択コンポーネント610、新しいクレジット限度額によって出力レコードを更新又は生成するレコード更新コンポーネント612である。出力レコードは、マイクログラフ602の出力ポート614に提供される。
マイクログラフ602は、性能監視出力ポート616に、その構成コンポーネントの性能特性を通知することができる。例えば「クレジット限度額引き上げ」マイクログラフ602は、履歴取得コンポーネント606、クレジットチェックコンポーネント608、限度額選択コンポーネント610、及びレコード更新コンポーネント612について、プロセッサ時間及び経過時間を通知することができる。マイクログラフ作動コンポーネント(図示せず)は、上述のような集約スキームに基づいてこれらの性能測定基準を収集し通知することができる。
いくつかの実施において、マイクログラフ作動コンポーネントは、例えば専用の入力ポート(図示せず)を介してメッセージを送信することで、マイクログラフの構成コンポーネントのリストを要求することができる。マイクログラフ作動コンポーネントは、性能監視出力ポート616にコンポーネントのリストを提供することができる。例えばマイクログラフ作動コンポーネント(図示せず)からの要求に応じて、「クレジット限度額引き上げ」マイクログラフは、「履歴取得、クレジットチェック、限度額選択、レコード更新」のカンマ区切り形式のリストを性能測定基準ポートに提供することができる。
いくつかの実施では、マイクログラフ作動コンポーネントは、以前にロードしたマイクログラフのレコードを維持する。マイクログラフがロードされると、マイクログラフ作動コンポーネントは、そのマイクログラフが以前にロードされたことがあるか否かを判定することができる。マイクログラフが以前にロードされたことがない場合、マイクログラフ作動コンポーネントは、マイクログラフの構成コンポーネントのリストを要求する。構成コンポーネントのアイデンティティはデータ記憶に記憶することができる。
いったん、例えば図2の永続データ記憶224のような永続データ記憶に性能測定基準が記憶されると、性能監視アプリケーションは、記憶された性能測定基準にアクセスしてこれを用いることが可能となる。一般に、性能監視アプリケーションは、ユーザによる測定基準の理解を支援するような方法で、収集した測定基準をユーザに提示する。
図7は、収集した性能測定基準をユーザに提示するためのシステム用の、一例としてのユーザインタフェースを示す。この例では、ユーザインタフェース700は、このユーザインタフェースの部分702にデータの要約を提示する。ユーザインタフェース700は、例えばユーザのコンピュータシステム上のウェブブラウザに表示されるウェブページのような、異なるタイプのネットワークベースの資産等の1つ以上の形態で提示することができる。
モニタ選択部714によって、ユーザは、マイクログラフの実行を監視するか否かを動的に決定することができる。いくつかの実施においては、ユーザがマイクログラフの実行を監視しないことを選択した場合、性能測定基準は収集されない。また、モニタ選択部714によってユーザは、どのように性能測定基準を集約するかを選択することができる。例えばユーザは、マイクログラフの名前によってマイクログラフの性能測定基準を要約すること、全てのマイクログラフにわたって性能測定基準を要約すること、各マイクログラフの最新の実行のみを記憶すること、又はマイクログラフの各実行の詳細をセーブすることを選択することができる。
一般に、ジョブとは、1つ以上のデータフローグラフによって1組のデータレコードを処理することを指す。性能測定基準は、ジョブごとに異なる方法で要約することができる。例えば、あるマイクログラフ716(「mg_runner_all.mp」という名称が付いている)は、全てのマイクログラフ実行を通して要約される。別のマイクログラフ718(「mg_runner_name.mp」という名称が付いている)は、そのマイクログラフの名前によって要約される。更に別のマイクログラフ720(「mg_runner.mp」という名称が付いている)は、各実行の性能測定基準を別個に記録する。
各マイクログラフの性能測定基準は、永続データ記憶に記憶された性能測定基準から取得される。例えば、開始時間708及び経過時間710が、用いた合計プロセッサ時間712と共に通知される。
いくつかの実施では、このユーザインタフェースによって、ユーザは特定のジョブ、マイクログラフ等の詳細を拡大して見ることができる。図8は、マイクログラフを表示する一例としてのユーザインタフェース800を示す。この例では、リフォーマットマイクログラフ804が表示されている。リフォーマットマイクログラフ804に入力レコードを提供するための入力ポート802、及びリフォーマットマイクログラフ804から出力レコードを取得するための出力ポート806も表示されている。
性能測定基準はユーザインタフェースに組み込まれている。この例では、ユーザインタフェースは、1つのレコードがマイクログラフに提供され(808)、1つのレコードがマイクログラフによって生成された(810)ことを表示している。
図9は、追加の性能測定基準を表示する一例としてのユーザインタフェースを示す。ユーザインタフェース900は、集約した性能測定基準を表の形態で提示する。測定基準列902には測定基準の名前がリスト化され、値列904には測定基準に対応する値が示されている。単位列906には、値904を規定する単位が示されている。測定基準のリストには、マイクログラフが実行された回数及びマイクログラフが実行に成功しなかった回数が含まれる。
図10は、性能測定基準を収集するための一例としてのプロセスのフローチャートである。プロセス1000は、例えば図1の実行モジュール104のような実行モジュールを含む1つ以上のコンピュータシステムによって実行することができる。簡略化のため、このプロセスは、プロセスを実行するシステムに関連付けて説明する。
1002において、多数のワークユニットを受信する。ワークユニットは、データフローグラフのコンポーネントによって受信することができる。ワークユニットは、ゼロ以上の入力データレコードを含み得る。入力データレコードは、データ記憶から、又はデータフローグラフ内の先行するコンポーネントの出力ポートから供給することができる。
1004において、ワークユニットの特性を判定する。特性は、入力データレコードのうち1つのフィールドに記憶された1つ以上の値とすることができる。例えば特性は、データフローグラフのコンポーネントにより実行される動作を識別するフィールド内の値とすればよい。
1006において、特性に基づいてマイクログラフを識別する。例えばこのプロセスは、フィールドによって識別された動作を実行するマイクログラフを識別することができる。マイクログラフは、例えば参照テーブル、辞書、又は同様のデータ構造を用いて、ワークユニットの特性を利用可能なマイクログラフのリストと比較することによって、識別可能である。
1008において、識別されたデータフローグラフをロードする。マイクログラフ作動コンポーネントがデータフローグラフをロードすることができる。マイクログラフは、例えばデータ記憶に記憶されたデータフローグラフとすることができる。マイクログラフは、例えば図2のマイクログラフ作動コンポーネント222のようなデータフローグラフのコンポーネントによってロードされ実行されるように構成することができる。いくつかの構成では、マイクログラフは、データ記憶システムからのロード時にはコンパイルされていない形態のままである。いくつかの構成では、マイクログラフは、データ記憶システムに記憶される前にシリアル化される。一般に、シリアル化とは、コンパイル済みの形態又はコンパイルされていない形態のデータフローグラフをゼロ及び1の二進ストリームに変換して、データ記憶に容易に記憶可能な形態とするプロセスである。
1010において、識別されたデータフローグラフを用いてワークユニットを処理する。いくつかの実施では、識別されたマイクログラフの入力ポートにワークユニットを提供する。出力レコードが生成された場合は、識別されたマイクログラフの出力ポートによって提供される。
1012において、1つ以上の性能測定基準を確定する。性能測定基準はマイクログラフ作動コンポーネントによって確定することができ、又は、マイクログラフは、その専用出力ポートに性能測定基準を提供するような機器を備えることができる。
上述の性能監視手法は、コンピュータ上で実行するソフトウェアを用いて実施可能である。例えばこのソフトウェアは、1つ以上のプログラムされた又はプログラム可能なコンピュータシステム(これは、分散型、クライアント/サーバ、又はグリッド等の様々なアーキテクチャのものであり得る)上で実行する1つ以上のコンピュータプログラムにおいて手順を形成する。これらのコンピュータシステムの各々は、少なくとも1つのプロセッサ、少なくとも1つのデータ記憶システム(揮発性及び不揮発性メモリ及び/又は記憶要素を含む)、少なくとも1つの入力デバイス又はポート、及び少なくとも1つの出力デバイス又はポートを含む。ソフトウェアは、より大きなプログラムの1つ以上のモジュールを形成することも可能である。例えばソフトウェアは、データフローグラフの設計及び構成に関連した他のサービスを提供することができる。グラフのノード及び要素は、コンピュータ読み取り可能媒体に記憶されたデータ構造として、又はデータリポジトリに記憶されたデータモデルに従った他の組織化されたデータとして、実施することができる。
ソフトウェアは、汎用もしくは特殊用途のプログラム可能コンピュータにより読み取り可能なCD−ROM等の記憶媒体上に提供するか、又は実行時にネットワークの通信媒体を介してコンピュータの記憶媒体に(伝搬信号で符号化して)送出することができる。機能は全て、特殊用途コンピュータ上で、又はコプロセッサ等の特殊用途ハードウェアを用いて実行可能である。ソフトウェアは、このソフトウェアにより規定される演算の異なる部分が異なるコンピュータによって実行される分散型で実施することができる。そのようなコンピュータプログラムは各々、汎用又は特殊用途プログラム可能コンピュータによって読み取り可能な有形の非一時的な記憶媒体又はデバイス(例えば固体メモリもしくは媒体、又は磁気もしくは光媒体)上に記憶するか、又はそれにダウンロードすることが好ましい。これにより、本明細書に記載した手順を実行するためにこの記憶媒体又はデバイスがコンピュータシステムによって読み取られた場合、コンピュータを構成し動作させ得る。また、本発明のシステムは、コンピュータプログラムによって構成されたコンピュータ読み取り可能記憶媒体として実施されると見なすことができ、そのように構成された記憶媒体によって、コンピュータシステムは、本明細書に記載した機能を実行するために特定かつ既定の方法で動作する。
本発明の多数の実施形態について記載した。前述の記載は例示を意図し、添付の特許請求の範囲の範囲により規定される本発明の範囲を限定することは意図していないことは理解されよう。本発明の精神及び範囲から逸脱することなく、様々な変形を行い得ることは理解されよう。例えば、上述のステップのいくつかは順序に依存しない場合があり、従って記載したものとは異なる順序で実行可能である。他の実施形態も以下の特許請求の範囲の範囲内である。

Claims (32)

  1. 第1のデータフローグラフが実行される、データ処理システムにおいてデータを処理するための方法であって、
    各々が1つ以上のワーク要素を含む多数のワークユニットを受信することと、
    第1のワークユニットの特性を判定することと、
    前記判定した特性に基づいて、前記第1のデータフローグラフのコンポーネントによって、データ記憶システムに記憶されている多数の利用可能なデータフローグラフから第2のデータフローグラフを識別することと、
    前記第2のデータフローグラフを用いて前記第1のワークユニットを処理することと、
    前記処理に関連付けられた1つ以上の性能測定基準を確定することと、
    を含む、方法。
  2. 前記第2のデータフローグラフが前記第1のデータフローグラフとは無関係にコンパイルされている、請求項1に記載の方法。
  3. 前記1つ以上の性能測定基準をメモリ内データ記憶に記憶することを更に含む、請求項1に記載の方法。
  4. 前記記憶した1つ以上の性能測定基準を永続データ記憶に転送することを更に含む、請求項3に記載の方法。
  5. 前記1つ以上の性能測定基準を以前に取得した性能測定基準と集約することを更に含む、請求項3に記載の方法。
  6. 前記1つ以上の性能測定基準を集約することが、前記第2のデータフローグラフに関連付けられた識別子に基づいて前記1つ以上の性能測定基準を集約することを含む、請求項5に記載の方法。
  7. 前記1つ以上の性能測定基準を集約することが、前記第1のデータフローグラフに関連付けられた識別子に基づいて前記1つ以上の性能測定基準を集約することを含む、請求項5に記載の方法。
  8. 前記1つ以上の性能測定基準をユーザに表示することを更に含む、請求項1に記載の方法。
  9. データ処理システムにおいてデータを処理するためのコンピュータプログラムを記憶するコンピュータ読み取り可能記憶媒体であって、前記コンピュータプログラムが、
    各々が1つ以上のワーク要素を含む多数のワークユニットを受信することと、
    第1のワークユニットの特性を判定することと、
    前記判定した特性に基づいて、前記第1のデータフローグラフのコンポーネントによって、データ記憶システムに記憶されている多数の利用可能なデータフローグラフから第2のデータフローグラフを識別することと、
    前記第2のデータフローグラフを用いて前記第1のワークユニットを処理することと、
    前記処理に関連付けられた1つ以上の性能測定基準を確定することと、
    をコンピューティングシステムに実行させるための命令を含む、コンピュータ読み取り可能記憶媒体。
  10. 前記第2のデータフローグラフが前記第1のデータフローグラフとは無関係にコンパイルされている、請求項9に記載の媒体。
  11. 前記コンピュータプログラムが、コンピューティングシステムに、前記1つ以上の性能測定基準をメモリ内データ記憶に記憶させるための命令を更に含む、請求項9に記載の媒体。
  12. 前記コンピュータプログラムが、コンピューティングシステムに、前記記憶した1つ以上の性能測定基準を永続データ記憶に転送させるための命令を更に含む、請求項11に記載の媒体。
  13. 前記コンピュータプログラムが、コンピューティングシステムに、前記1つ以上の性能測定基準を以前に取得した性能測定基準と集約させるための命令を更に含む、請求項11に記載の媒体。
  14. 前記1つ以上の性能測定基準を集約することが、前記第2のデータフローグラフに関連付けられた識別子に基づいて前記1つ以上の性能測定基準を集約することを含む、請求項13に記載の媒体。
  15. 前記1つ以上の性能測定基準を集約することが、前記第1のデータフローグラフに関連付けられた識別子に基づいて前記1つ以上の性能測定基準を集約することを含む、請求項13に記載の媒体。
  16. 前記コンピュータプログラムが、コンピューティングシステムに、前記1つ以上の性能測定基準をユーザに表示させるための命令を更に含む、請求項9に記載の媒体。
  17. データを処理するためのコンピューティングシステムであって、
    各々が1つ以上のワーク要素を含む多数のワークユニットを受信するように構成された入力デバイス又はポートと、
    データを処理するように構成された少なくとも1つのプロセッサと、を含み、前記処理が、
    第1のワークユニットの特性を判定することと、
    前記判定した特性に基づいて、前記第1のデータフローグラフのコンポーネントによって、データ記憶システムに記憶されている多数の利用可能なデータフローグラフから第2のデータフローグラフを識別することと、
    前記第2のデータフローグラフを用いて前記第1のワークユニットを処理することと、
    前記処理に関連付けられた1つ以上の性能測定基準を確定することと、
    を含む、コンピューティングシステム。
  18. 前記第2のデータフローグラフが前記第1のデータフローグラフとは無関係にコンパイルされている、請求項17に記載のシステム。
  19. 前記処理が、前記1つ以上の性能測定基準をメモリ内データ記憶に記憶することを更に含む、請求項17に記載のシステム。
  20. 前記処理が、前記記憶した1つ以上の性能測定基準を永続データ記憶に転送することを更に含む、請求項19に記載のシステム。
  21. 前記処理が、前記1つ以上の性能測定基準を以前に取得した性能測定基準と集約することを更に含む、請求項19に記載のシステム。
  22. 前記1つ以上の性能測定基準を集約することが、前記第2のデータフローグラフに関連付けられた識別子に基づいて前記1つ以上の性能測定基準を集約することを含む、請求項21に記載のシステム。
  23. 前記1つ以上の性能測定基準を集約することが、前記第1のデータフローグラフに関連付けられた識別子に基づいて前記1つ以上の性能測定基準を集約することを含む、請求項21に記載のシステム。
  24. 前記処理が、前記1つ以上の性能測定基準をユーザに表示することを更に含む、請求項17に記載のシステム。
  25. データを処理するコンピューティングシステムであって、
    各々が1つ以上のワーク要素を含む多数のワークユニットを受信するための手段と、
    第1のワークユニットの特性を判定するための手段と、
    前記判定した特性に基づいて、前記第1のデータフローグラフのコンポーネントによって、データ記憶システムに記憶されている多数の利用可能なデータフローグラフから第2のデータフローグラフを識別するための手段と、
    前記第2のデータフローグラフを用いて前記第1のワークユニットを処理するための手段と、
    前記処理に関連付けられた1つ以上の性能測定基準を確定するための手段と、
    を含む、コンピューティングシステム。
  26. 前記第2のデータフローグラフが前記第1のデータフローグラフとは無関係にコンパイルされている、請求項25に記載のシステム。
  27. 前記1つ以上の性能測定基準をメモリ内データ記憶に記憶することを更に含む、請求項25に記載のシステム。
  28. 前記記憶した1つ以上の性能測定基準を永続データ記憶に転送するための手段を更に含む、請求項27に記載のシステム。
  29. 前記1つ以上の性能測定基準を以前に取得した性能測定基準と集約するための手段を更に含む、請求項27に記載のシステム。
  30. 前記1つ以上の性能測定基準を集約することが、前記第2のデータフローグラフに関連付けられた識別子に基づいて前記1つ以上の性能測定基準を集約することを含む、請求項29に記載のシステム。
  31. 前記1つ以上の性能測定基準を集約することが、前記第1のデータフローグラフに関連付けられた識別子に基づいて前記1つ以上の性能測定基準を集約することを含む、請求項29に記載のシステム。
  32. 前記1つ以上の性能測定基準をユーザに表示するための手段を更に含む、請求項25に記載のシステム。
JP2015542845A 2012-11-16 2013-11-15 動的グラフ性能監視 Pending JP2016501401A (ja)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US13/678,921 2012-11-16
US13/678,921 US9507682B2 (en) 2012-11-16 2012-11-16 Dynamic graph performance monitoring
PCT/US2013/070391 WO2014078714A2 (en) 2012-11-16 2013-11-15 Dynamic graph performance monitoring

Related Child Applications (1)

Application Number Title Priority Date Filing Date
JP2019118252A Division JP6742478B2 (ja) 2012-11-16 2019-06-26 動的グラフ性能監視

Publications (1)

Publication Number Publication Date
JP2016501401A true JP2016501401A (ja) 2016-01-18

Family

ID=49725353

Family Applications (2)

Application Number Title Priority Date Filing Date
JP2015542845A Pending JP2016501401A (ja) 2012-11-16 2013-11-15 動的グラフ性能監視
JP2019118252A Active JP6742478B2 (ja) 2012-11-16 2019-06-26 動的グラフ性能監視

Family Applications After (1)

Application Number Title Priority Date Filing Date
JP2019118252A Active JP6742478B2 (ja) 2012-11-16 2019-06-26 動的グラフ性能監視

Country Status (10)

Country Link
US (1) US9507682B2 (ja)
EP (1) EP2920686B1 (ja)
JP (2) JP2016501401A (ja)
KR (1) KR102284985B1 (ja)
CN (1) CN104937548B (ja)
AU (1) AU2013344538B2 (ja)
CA (1) CA2890144C (ja)
HK (1) HK1209868A1 (ja)
SG (1) SG11201503473VA (ja)
WO (1) WO2014078714A2 (ja)

Families Citing this family (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102317911B (zh) 2009-02-13 2016-04-06 起元技术有限责任公司 管理任务执行
US10108521B2 (en) 2012-11-16 2018-10-23 Ab Initio Technology Llc Dynamic component performance monitoring
AU2014360308B2 (en) 2013-12-05 2018-11-29 Ab Initio Technology Llc Managing interfaces for dataflow graphs composed of sub-graphs
US9800662B2 (en) * 2014-07-16 2017-10-24 TUPL, Inc. Generic network trace with distributed parallel processing and smart caching
US10657134B2 (en) 2015-08-05 2020-05-19 Ab Initio Technology Llc Selecting queries for execution on a stream of real-time data
US10671669B2 (en) 2015-12-21 2020-06-02 Ab Initio Technology Llc Sub-graph interface generation
WO2017141176A1 (en) * 2016-02-18 2017-08-24 New Relic, Inc. Identifying the root cause of an issue observed during application execution
US10853376B2 (en) 2016-06-19 2020-12-01 Data.World, Inc. Collaborative dataset consolidation via distributed computer networks
SG10201705700RA (en) * 2017-07-11 2019-02-27 Custodio Tech Pte Ltd Digital asset tracking system and method
KR102054070B1 (ko) * 2018-05-03 2019-12-09 충북대학교 산학협력단 변경 추적 및 이력 그래프 검색을 위한 그래프 저장 관리 방법 및 그래프 저장 관리 장치
WO2023034328A2 (en) * 2021-08-30 2023-03-09 Data.World, Inc. Correlating parallelized data from disparate data sources to aggregate graph data portions to predictively identify entity data
EP4356251A1 (de) * 2021-08-30 2024-04-24 Siemens Mobility GmbH Überwachungsverfahren

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2012027560A1 (en) * 2010-08-25 2012-03-01 Ab Initio Technology Llc Evaluating dataflow graph characteristics

Family Cites Families (219)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3662343A (en) 1970-07-29 1972-05-09 Docutel Corp Credit card automatic currency dispenser
US3662401A (en) 1970-09-23 1972-05-09 Collins Radio Co Method of program execution
US4228496A (en) 1976-09-07 1980-10-14 Tandem Computers Incorporated Multiprocessor system
US4814979A (en) 1981-04-01 1989-03-21 Teradata Corporation Network to transmit prioritized subtask pockets to dedicated processors
US4972314A (en) 1985-05-20 1990-11-20 Hughes Aircraft Company Data flow signal processor method and apparatus
US4720780A (en) 1985-09-17 1988-01-19 The Johns Hopkins University Memory-linked wavefront array processor
US4914568A (en) 1986-10-24 1990-04-03 National Instruments, Inc. Graphical system for modelling a process and associated method
US5127104A (en) 1986-12-29 1992-06-30 Dataflow Computer Corporation Method and product involving translation and execution of programs by automatic partitioning and data structure allocation
JPS63231613A (ja) 1987-03-20 1988-09-27 Matsushita Giken Kk コマンド設定方法
JPH0526792Y2 (ja) 1987-07-14 1993-07-07
JPH0194431U (ja) 1987-12-14 1989-06-21
US5357632A (en) 1990-01-09 1994-10-18 Hughes Aircraft Company Dynamic task allocation in a multi-processor system employing distributed control processors and distributed arithmetic processors
US5280619A (en) 1990-05-17 1994-01-18 Texas Instruments Incorporated System for accessing shared data using a serialization graph constructed from a history file showing completed locking dependencies between transactions
US5323452A (en) 1990-12-18 1994-06-21 Bell Communications Research, Inc. Visual programming of telephone network call processing logic
DE4216871C2 (de) 1991-05-21 2001-09-06 Digital Equipment Corp Ausführungsordnen zum Sicherstellen der Serialisierbarkeit verteilter Transaktionen
EP0529303A3 (en) 1991-08-29 1993-09-22 International Business Machines Corporation Checkpoint synchronization with instruction overlap enabled
US6400996B1 (en) 1999-02-01 2002-06-04 Steven M. Hoffberg Adaptive pattern recognition based control system and method
US5333319A (en) 1992-03-02 1994-07-26 International Business Machines Corporation Virtual storage data processor with enhanced dispatching priority allocation of CPU resources
JP3223933B2 (ja) 1993-02-10 2001-10-29 日本電信電話株式会社 知識ベース推論方法およびその装置
US5745778A (en) 1994-01-26 1998-04-28 Data General Corporation Apparatus and method for improved CPU affinity in a multiprocessor system
US6044211A (en) 1994-03-14 2000-03-28 C.A.E. Plus, Inc. Method for graphically representing a digital device as a behavioral description with data and control flow elements, and for converting the behavioral description to a structural description
US5694546A (en) 1994-05-31 1997-12-02 Reisman; Richard R. System for automatic unattended electronic information transport between a server and a client by a vendor provided transport software with a manifest list
JPH08106540A (ja) 1994-10-06 1996-04-23 Toshiba Corp 編集装置
US5692168A (en) 1994-10-18 1997-11-25 Cyrix Corporation Prefetch buffer using flow control bit to identify changes of flow within the code stream
JPH08305576A (ja) 1995-01-12 1996-11-22 Internatl Business Mach Corp <Ibm> コンピュータ・ユーザとの対話を行うためのエキスパート・システム及びその方法
US5673369A (en) 1995-03-02 1997-09-30 International Business Machines Corporation Authoring knowledge-based systems using interactive directed graphs
US5701400A (en) 1995-03-08 1997-12-23 Amado; Carlos Armando Method and apparatus for applying if-then-else rules to data sets in a relational data base and generating from the results of application of said rules a database of diagnostics linked to said data sets to aid executive analysis of financial data
US5805462A (en) 1995-08-18 1998-09-08 Vlsi Technology, Inc. Automatic synthesis of integrated circuits employing boolean decomposition
JP3154942B2 (ja) 1995-09-11 2001-04-09 株式会社東芝 分散チェックポイント生成方法および同方法が適用される計算機システム
US5630047A (en) 1995-09-12 1997-05-13 Lucent Technologies Inc. Method for software error recovery using consistent global checkpoints
US5712971A (en) 1995-12-11 1998-01-27 Ab Initio Software Corporation Methods and systems for reconstructing the state of a computation
JP3258228B2 (ja) 1996-03-15 2002-02-18 株式会社東芝 チェックポイント生成方法
US7415466B2 (en) 1996-03-19 2008-08-19 Oracle International Corporation Parallel transaction recovery
US6006242A (en) 1996-04-05 1999-12-21 Bankers Systems, Inc. Apparatus and method for dynamically creating a document
JP3672208B2 (ja) 1996-07-02 2005-07-20 インターナショナル・ビジネス・マシーンズ・コーポレーション 階層化トランザクション処理方法
US5857204A (en) 1996-07-02 1999-01-05 Ab Initio Software Corporation Restoring the state of a set of files
US5966072A (en) 1996-07-02 1999-10-12 Ab Initio Software Corporation Executing computations expressed as graphs
US6016516A (en) 1996-08-07 2000-01-18 Fuji Xerox Co. Ltd. Remote procedure processing device used by at least two linked computer systems
US6760903B1 (en) 1996-08-27 2004-07-06 Compuware Corporation Coordinated application monitoring in a distributed computing environment
US5799266A (en) 1996-09-19 1998-08-25 Sun Microsystems, Inc. Automatic generation of test drivers
US5930794A (en) 1996-10-18 1999-07-27 Sagent Technologies, Inc. Database repository with deferred transactions
US6038558A (en) 1996-10-18 2000-03-14 Sagent Technology, Inc. Extensible database retrieval and viewing architecture
US6151531A (en) 1996-12-12 2000-11-21 Charles Frankel Et Al System and method for managing the alteration of garments
US5924095A (en) 1997-02-05 1999-07-13 Oracle Corporation Processing distributed transactions in heterogeneous computing environments using two-phase commit
US6330008B1 (en) 1997-02-24 2001-12-11 Torrent Systems, Inc. Apparatuses and methods for monitoring performance of parallel computing
US5933640A (en) 1997-02-26 1999-08-03 Digital Equipment Corporation Method for analyzing and presenting test execution flows of programs
US5999729A (en) 1997-03-06 1999-12-07 Continuum Software, Inc. System and method for developing computer programs for execution on parallel processing systems
US5950212A (en) 1997-04-11 1999-09-07 Oracle Corporation Method and system for workload based group committing for improved performance
US6088716A (en) 1997-04-28 2000-07-11 Ab Initio Software Corporation Method for preventing buffer deadlock in dataflow computations
US6032158A (en) 1997-05-02 2000-02-29 Informatica Corporation Apparatus and method for capturing and propagating changes from an operational database to data marts
US6044394A (en) 1997-07-21 2000-03-28 International Business Machines Corporation Managing independently executing computer tasks that are interrelated by dataflow
US6145017A (en) 1997-08-05 2000-11-07 Adaptec, Inc. Data alignment system for a hardware accelerated command interpreter engine
US6173276B1 (en) 1997-08-21 2001-01-09 Scicomp, Inc. System and method for financial instrument modeling and valuation
US6615258B1 (en) 1997-09-26 2003-09-02 Worldcom, Inc. Integrated customer interface for web based data management
US6332212B1 (en) 1997-10-02 2001-12-18 Ltx Corporation Capturing and displaying computer program execution timing
US5958004A (en) 1997-10-28 1999-09-28 Microsoft Corporation Disabling and enabling transaction committal in transactional application components
US6339775B1 (en) 1997-11-07 2002-01-15 Informatica Corporation Apparatus and method for performing data transformations in data warehousing
US6014670A (en) 1997-11-07 2000-01-11 Informatica Corporation Apparatus and method for performing data transformations in data warehousing
US6044374A (en) 1997-11-14 2000-03-28 Informatica Corporation Method and apparatus for sharing metadata between multiple data marts through object references
JPH11184766A (ja) 1997-12-18 1999-07-09 Nippon Telegr & Teleph Corp <Ntt> ビジネスイベントサーバ
US6272650B1 (en) 1998-02-03 2001-08-07 Amazing Media, Inc. System and method for disambiguating scene graph loads
US6437796B2 (en) 1998-02-17 2002-08-20 Sun Microsystems, Inc. Multiple processor visibility search system and method
US6208345B1 (en) 1998-04-15 2001-03-27 Adc Telecommunications, Inc. Visual data integration system and method
US6256637B1 (en) 1998-05-05 2001-07-03 Gemstone Systems, Inc. Transactional virtual machine architecture
US6480876B2 (en) 1998-05-28 2002-11-12 Compaq Information Technologies Group, L.P. System for integrating task and data parallelism in dynamic applications
US6675189B2 (en) 1998-05-28 2004-01-06 Hewlett-Packard Development Company, L.P. System for learning and applying integrated task and data parallel strategies in dynamic applications
US6314114B1 (en) 1998-06-23 2001-11-06 Oracle Corporation Distributed resource management
JP2000010788A (ja) 1998-06-25 2000-01-14 Sharp Corp 緊急動作処理機能を有するコンピュータ装置
US6259988B1 (en) 1998-07-20 2001-07-10 Lockheed Martin Corporation Real-time mission adaptable route planner
JP2000099317A (ja) 1998-09-18 2000-04-07 Toshiba Corp ユーザインタフェース設計装置及び方法
US6401216B1 (en) 1998-10-29 2002-06-04 International Business Machines Corporation System of performing checkpoint/restart of a parallel program
US6608628B1 (en) 1998-11-06 2003-08-19 The United States Of America As Represented By The Administrator Of The National Aeronautics And Space Administration (Nasa) Method and apparatus for virtual interactive medical imaging by multiple remotely-located users
US6744472B1 (en) 1998-11-09 2004-06-01 Broadcom Corporation Graphics display system with video synchronization feature
US6449711B1 (en) 1999-02-04 2002-09-10 Sun Microsystems, Inc. Method, apparatus, and article of manufacture for developing and executing data flow programs
US6538651B1 (en) 1999-03-19 2003-03-25 John Hayman Parametric geometric element definition and generation system and method
US6728879B1 (en) 1999-06-02 2004-04-27 Microsoft Corporation Transactional log with multi-sector log block validation
US6816825B1 (en) 1999-06-18 2004-11-09 Nec Corporation Simulation vector generation from HDL descriptions for observability-enhanced statement coverage
JP2001022571A (ja) 1999-07-09 2001-01-26 Riso Kagaku Corp 電子機器及び該電子機器の制御プログラム書き換え方法
US6647408B1 (en) 1999-07-16 2003-11-11 Novell, Inc. Task distribution
US6715145B1 (en) 1999-08-31 2004-03-30 Accenture Llp Processing pipeline in a base services pattern environment
US20020129340A1 (en) 1999-10-28 2002-09-12 Tuttle Douglas D. Reconfigurable isomorphic software representations
US7137116B2 (en) 1999-11-09 2006-11-14 Microsoft Corporation Method and system for performing a task on a computer
US6879946B2 (en) 1999-11-30 2005-04-12 Pattern Discovery Software Systems Ltd. Intelligent modeling, transformation and manipulation system
US6584581B1 (en) 1999-12-06 2003-06-24 Ab Initio Software Corporation Continuous flow checkpointing data processing
US7409679B2 (en) 1999-12-20 2008-08-05 Headway Research Limited System and method for computer-aided graph-based dependency analysis
US6848100B1 (en) 2000-03-31 2005-01-25 Intel Corporation Hierarchical software path profiling
US7062483B2 (en) 2000-05-18 2006-06-13 Endeca Technologies, Inc. Hierarchical data-driven search and navigation system and method for information retrieval
US6922685B2 (en) 2000-05-22 2005-07-26 Mci, Inc. Method and system for managing partitioned data resources
US6813761B1 (en) 2000-06-30 2004-11-02 Microsoft Corporation Methods for enhancing flow analysis
US7164422B1 (en) 2000-07-28 2007-01-16 Ab Initio Software Corporation Parameterized graphs with conditional components
US6832369B1 (en) 2000-08-01 2004-12-14 International Business Machines Corporation Object oriented method and apparatus for class variable initialization
US6496961B2 (en) 2000-10-27 2002-12-17 Nec Usa, Inc. Dynamic detection and removal of inactive clauses in SAT with application in image computation
US20020152244A1 (en) 2000-12-22 2002-10-17 International Business Machines Corporation Method and apparatus to dynamically create a customized user interface based on a document type definition
US6975628B2 (en) 2000-12-22 2005-12-13 Intel Corporation Method for representing and controlling packet data flow through packet forwarding hardware
US6804800B2 (en) 2000-12-29 2004-10-12 Intel Corporation Method and apparatus for detecting and recovering from errors in a source synchronous bus
JP4294879B2 (ja) 2001-02-05 2009-07-15 株式会社日立製作所 サービスレベル制御機構を有するトランザクション処理システム及びそのためのプログラム
US20020111876A1 (en) 2001-02-09 2002-08-15 Rudraraju Panduranga R. Transaction aggregation system and method
US7082386B2 (en) 2001-02-21 2006-07-25 International Business Machines Corporation Generalized software modeling tool
US7188091B2 (en) 2001-03-21 2007-03-06 Resolutionebs, Inc. Rule processing system
US6651234B2 (en) 2001-04-06 2003-11-18 Nec Corporation Partition-based decision heuristics for SAT and image computation using SAT and BDDs
US20020147745A1 (en) 2001-04-09 2002-10-10 Robert Houben Method and apparatus for document markup language driven server
US7082604B2 (en) 2001-04-20 2006-07-25 Mobile Agent Technologies, Incorporated Method and apparatus for breaking down computing tasks across a network of heterogeneous computer for parallel execution by utilizing autonomous mobile agents
US20040093559A1 (en) 2001-05-25 2004-05-13 Ruth Amaru Web client for viewing and interrogating enterprise data semantically
GB2376094A (en) 2001-05-30 2002-12-04 Ibm Flexible navigation of a workflow graph in a data processing system
US7069536B2 (en) 2001-06-28 2006-06-27 International Business Machines Corporation Method, system, and program for executing a workflow
US20030033432A1 (en) 2001-08-08 2003-02-13 Simpson Shell S. Web based imaging service that converts web pages into content on behalf of another web site
US7594220B2 (en) 2001-08-14 2009-09-22 National Instruments Corporation Configuration diagram with context sensitive connectivity
US20040006745A1 (en) 2001-08-31 2004-01-08 Van Helden Wico Methods, apparatuses, system, and articles for associating metadata with datastream
US7165030B2 (en) 2001-09-17 2007-01-16 Massachusetts Institute Of Technology Concatenative speech synthesis using a finite-state transducer
US7085426B2 (en) 2001-10-15 2006-08-01 Jonas August Volterra filters for enhancement of contours in images
US7130484B2 (en) 2001-10-15 2006-10-31 Jonas August Biased curve indicator random field filters for enhancement of contours in images
DE10152213B4 (de) 2001-10-23 2006-04-27 Onespin Solutions Gmbh Verfahren zur Verifikation digitaler arithmetischer Schaltungen mittels eines Äquivalenzvergleiches
US7092401B2 (en) 2001-11-15 2006-08-15 International Business Machines Corporation Apparatus and method for managing work and completion queues using head and tail pointers with end-to-end context error cache for reliable datagram
EP1320217B1 (en) 2001-12-14 2004-10-13 Hewlett-Packard Company, A Delaware Corporation Method of installing monitoring agents, system and computer program for monitoring objects in an IT network
US7240247B2 (en) 2002-04-29 2007-07-03 Intel Corporation Providing a chain of tokenized error and state information for a call stack
US20040041838A1 (en) 2002-09-04 2004-03-04 Adusumilli Venkata J.R.B. Method and system for graphing data
US6975963B2 (en) 2002-09-30 2005-12-13 Mcdata Corporation Method and system for storing and reporting network performance metrics using histograms
US7103597B2 (en) 2002-10-03 2006-09-05 Mcgoveran David O Adaptive transaction manager for complex transactions and business process
US7167850B2 (en) 2002-10-10 2007-01-23 Ab Initio Software Corporation Startup and control of graph-based computation
US7694272B2 (en) 2002-10-21 2010-04-06 Sungard (Israel) Ltd Method, a language and a system for the definition and implementation of software solutions by using a visualizable computer executable modeling language
US7412658B2 (en) 2002-11-14 2008-08-12 Sap Ag Modeling system for graphic user interface
US7711772B2 (en) 2002-11-15 2010-05-04 Schlumberger Technology Corporation Web-based system and method for electronic data delivery
US7430747B2 (en) 2002-12-04 2008-09-30 Microsoft Corporation Peer-to peer graphing interfaces and methods
US7441008B2 (en) 2002-12-18 2008-10-21 International Business Machines Corporation Method for correlating transactions and messages
US20050193056A1 (en) 2002-12-26 2005-09-01 Schaefer Diane E. Message transfer using multiplexed connections in an open system interconnection transaction processing environment
US20040148373A1 (en) 2003-01-23 2004-07-29 International Business Machines Corporation Service level agreement compliance measurement
WO2004072796A2 (en) 2003-02-05 2004-08-26 Arizona Board Of Regents Reconfigurable processing
US7707564B2 (en) 2003-02-26 2010-04-27 Bea Systems, Inc. Systems and methods for creating network-based software services using source code annotations
US7088374B2 (en) 2003-03-27 2006-08-08 Microsoft Corporation System and method for managing visual structure, timing, and animation in a graphics processing system
US7417645B2 (en) 2003-03-27 2008-08-26 Microsoft Corporation Markup language and object model for vector graphics
US7669129B2 (en) 2003-04-04 2010-02-23 Avid Technology, Inc. Graphical user interface for providing editing of transform hierarchies within an effects tree
US7665025B2 (en) 2003-04-16 2010-02-16 The Mathworks, Inc. Signal navigation and label propagation in block diagrams
US20040225657A1 (en) 2003-05-07 2004-11-11 Panacea Corporation Web services method and system
US8265979B2 (en) 2003-06-17 2012-09-11 International Business Machines Corporation Automatic generation of process models
WO2004113557A2 (en) 2003-06-18 2004-12-29 Applera Corporation Methods and systems for the analysis of biological sequence data
EP1639510A1 (en) 2003-06-24 2006-03-29 BAE Systems PLC A method, tool and system for increasing the efficiency of a design process
CA2891196C (en) 2003-06-25 2018-03-20 Ab Initio Technology Llc Computer-aided parallelizing of computation graphs
US7185322B2 (en) 2003-07-11 2007-02-27 Computer Associates Think, Inc. Method and apparatus for parallel action processing
GB0318196D0 (en) 2003-08-02 2003-09-03 Ibm A method apparatus and computer program for processing a queue of messages
US7243088B2 (en) 2003-08-06 2007-07-10 Oracle International Corporation Database management system with efficient version control
US7444595B2 (en) 2003-08-13 2008-10-28 National Instruments Corporation Graphical programming system and method for creating and managing a scene graph
US8307109B2 (en) 2003-08-27 2012-11-06 International Business Machines Corporation Methods and systems for real time integration services
US7174479B2 (en) 2003-09-10 2007-02-06 Microsoft Corporation Method and system for rollback-free failure recovery of multi-step procedures
CA2538568C (en) 2003-09-15 2009-05-19 Ab Initio Software Corporation Data profiling
US20050102670A1 (en) 2003-10-21 2005-05-12 Bretl Robert F. Shared object memory with object management for multiple virtual machines
US20050097515A1 (en) 2003-10-31 2005-05-05 Honeywell International, Inc. Data empowered laborsaving test architecture
US7840949B2 (en) 2003-11-03 2010-11-23 Ramal Acquisition Corp. System and method for data transformation using dataflow graphs
US7480863B2 (en) 2003-11-26 2009-01-20 International Business Machines Corporation Dynamic and intelligent hover assistance
US7296072B2 (en) 2003-12-12 2007-11-13 International Business Machines Corporation Enhanced port type agnostic proxy support for web services intermediaries
US7404189B2 (en) 2003-12-30 2008-07-22 International Business Machines Corporation Scheduler supporting web service invocation
US7543275B2 (en) 2004-01-29 2009-06-02 Sun Microsystems, Inc. Mechanism for executing test suites written for different harnesses under one test execution harness
US7467383B2 (en) 2004-03-08 2008-12-16 Ab Initio Software Llc System for controlling task execution using a graphical representation of task dependency
US7594227B2 (en) 2004-03-08 2009-09-22 Ab Initio Technology Llc Dependency graph parameter scoping
US9094615B2 (en) 2004-04-16 2015-07-28 Intheplay, Inc. Automatic event videoing, tracking and content generation
US20050256818A1 (en) 2004-04-30 2005-11-17 Xerox Corporation Workflow auto generation from user constraints and hierarchical dependence graphs for workflows
JP2007536634A (ja) 2004-05-04 2007-12-13 フィッシャー−ローズマウント・システムズ・インコーポレーテッド プロセス制御システムのためのサービス指向型アーキテクチャ
US7614037B2 (en) 2004-05-21 2009-11-03 Microsoft Corporation Method and system for graph analysis and synchronization
US7316001B2 (en) 2004-06-05 2008-01-01 Graphlogic Inc. Object process graph system
US20050289559A1 (en) 2004-06-08 2005-12-29 Daniel Illowsky Method and system for vertical layering between levels in a processing unit facilitating direct event-structures and event-queues level-to-level communication without translation
US7398514B2 (en) 2004-09-29 2008-07-08 Microsoft Corporation Test automation stack layering
US7343482B2 (en) 2004-10-20 2008-03-11 Arm Limited Program subgraph identification
JP4759983B2 (ja) 2004-11-04 2011-08-31 船井電機株式会社 ディスク装置のファームウェア書き換え方法、及びファームウェア書き換えプログラム
US7598953B2 (en) 2004-11-05 2009-10-06 Microsoft Corporation Interpreter for simplified programming of graphics processor units in general purpose programming languages
US8082541B2 (en) 2004-12-09 2011-12-20 Advantest Corporation Method and system for performing installation and configuration management of tester instrument modules
US20060282474A1 (en) 2005-01-18 2006-12-14 Mackinnon Allan S Jr Systems and methods for processing changing data
US7620947B2 (en) 2005-03-11 2009-11-17 Autodesk, Inc. Enhanced directed graph representation for dependency systems
US7505975B2 (en) 2005-04-14 2009-03-17 Bea Systems, Inc. Use of transaction context to select single database instance for global transaction
JP4246176B2 (ja) 2005-04-25 2009-04-02 株式会社日立製作所 トランザクション処理方法及びその実施装置並びにその処理プログラムを記録した媒体
US7716630B2 (en) 2005-06-27 2010-05-11 Ab Initio Technology Llc Managing parameters for graph-based computations
US7877350B2 (en) 2005-06-27 2011-01-25 Ab Initio Technology Llc Managing metadata for graph-based computations
US20070118839A1 (en) 2005-10-24 2007-05-24 Viktors Berstis Method and apparatus for grid project modeling language
US7555619B2 (en) 2005-12-07 2009-06-30 Microsoft Corporation Efficient per-object operations in software transactional memory
US8073671B2 (en) 2006-03-31 2011-12-06 Microsoft Corporation Dynamic software performance models
US7870556B2 (en) 2006-05-16 2011-01-11 Ab Initio Technology Llc Managing computing resources in graph-based computations
CN103729330B (zh) 2006-08-10 2017-04-19 起元科技有限公司 在基于图的计算中分配服务
US7844946B2 (en) 2006-09-26 2010-11-30 Intel Corporation Methods and apparatus to form a transactional objective instruction construct from lock-based critical sections
EP2092424B1 (en) 2006-10-19 2015-12-30 Checkmarx Ltd. Locating security vulnerabilities in source code
US8191052B2 (en) 2006-12-01 2012-05-29 Murex S.A.S. Producer graph oriented programming and execution
US20080244524A1 (en) 2007-03-27 2008-10-02 Tim Kelso Program Test System
US7805635B2 (en) 2007-04-09 2010-09-28 International Business Machines Corporation Constraint programming for reduction of system test-configuration-matrix complexity
US8069129B2 (en) 2007-04-10 2011-11-29 Ab Initio Technology Llc Editing and compiling business rules
WO2008131106A1 (en) 2007-04-17 2008-10-30 Earl Industries Llc Digital system for organizing diverse information
JP4073033B1 (ja) 2007-04-27 2008-04-09 透 降矢 結合演算の処理機能の向上を考慮した合成関係演算を利用したマルチオペレーション・プロセッシングを用いたデータベースのクエリー処理システム
US8706667B2 (en) 2007-07-26 2014-04-22 Ab Initio Technology Llc Transactional graph-based computation with error handling
US8347292B2 (en) 2007-08-30 2013-01-01 International Business Machines Corporation Transaction aggregation to increase transaction processing throughout
JP5453273B2 (ja) 2007-09-20 2014-03-26 アビニシオ テクノロジー エルエルシー グラフベース計算におけるデータフロー管理
US7886141B2 (en) 2007-10-27 2011-02-08 Asix Electronics Corporation Method and systems for advanced reprogrammable boot codes and in-application programming of embedded microprocessor systems
US8775441B2 (en) 2008-01-16 2014-07-08 Ab Initio Technology Llc Managing an archive for approximate string matching
US20090193417A1 (en) 2008-01-24 2009-07-30 Nec Laboratories America, Inc. Tractable dataflow analysis for concurrent programs via bounded languages
US8225288B2 (en) 2008-01-29 2012-07-17 Intuit Inc. Model-based testing using branches, decisions, and options
US8797178B2 (en) 2008-03-10 2014-08-05 Microsoft Corporation Efficient stream sharing for multi-user sensor data collection
US20090235267A1 (en) * 2008-03-13 2009-09-17 International Business Machines Corporation Consolidated display of resource performance trends
US9184874B2 (en) 2008-03-31 2015-11-10 Qualcomm Incorporated Storing log likelihood ratios in interleaved form to reduce hardware memory
US8336052B2 (en) * 2008-06-16 2012-12-18 International Business Machines Corporation Management, control, and monitoring of workload including unrelated processes of different containers
WO2010002919A1 (en) 2008-06-30 2010-01-07 Ab Initio Software Llc Data logging in graph-based computations
US20100070955A1 (en) 2008-07-08 2010-03-18 Nec Laboratories America Alias analysis for concurrent software programs
US8782613B2 (en) * 2008-08-12 2014-07-15 Hewlett-Packard Development Company, L.P. Optimizing applications using source code patterns and performance analysis
US8286176B1 (en) 2008-09-29 2012-10-09 Amazon Technologies, Inc. Optimizing resource configurations
US20100169137A1 (en) 2008-12-31 2010-07-01 Ebay Inc. Methods and systems to analyze data using a graph
US7979479B2 (en) 2009-01-08 2011-07-12 International Business Machines Corporation Transaction-controlled graph processing and management
US8635694B2 (en) 2009-01-10 2014-01-21 Kaspersky Lab Zao Systems and methods for malware classification
CN102317911B (zh) 2009-02-13 2016-04-06 起元技术有限责任公司 管理任务执行
US7992040B2 (en) 2009-02-20 2011-08-02 International Business Machines Corporation Root cause analysis by correlating symptoms with asynchronous changes
US8332811B2 (en) * 2009-04-30 2012-12-11 United Parcel Service Of America, Inc. Systems and methods for generating source code for workflow platform
US8327377B2 (en) 2009-04-30 2012-12-04 Ca, Inc. Detecting, logging and tracking component dependencies in web service transactions
US8473901B1 (en) 2009-06-12 2013-06-25 The Mathworks, Inc. Non-literal representation of programming language code
US8205113B2 (en) 2009-07-14 2012-06-19 Ab Initio Technology Llc Fault tolerant batch processing
US8667329B2 (en) 2009-09-25 2014-03-04 Ab Initio Technology Llc Processing transactions in graph-based applications
US8875145B2 (en) * 2010-06-15 2014-10-28 Ab Initio Technology Llc Dynamically loading graph-based computations
US8458729B2 (en) 2010-07-20 2013-06-04 International Business Machines Corporation Managing and optimizing workflows among computer applications
US9158650B2 (en) * 2010-08-04 2015-10-13 BoxTone, Inc. Mobile application performance management
US8997024B2 (en) 2010-12-09 2015-03-31 Microsoft Technology Licensing, Llc Navigating between views of a graph using placemarkers
AU2012100128A4 (en) 2011-02-22 2012-03-08 Zensar Technologies Ltd A computer implemented system and method for indexing and optionally annotating use cases and generating test scenarios therefrom
US8732669B2 (en) 2011-03-11 2014-05-20 Oracle International Corporation Efficient model checking technique for finding software defects
US9165029B2 (en) 2011-04-12 2015-10-20 Microsoft Technology Licensing, Llc Navigating performance data from different subsystems
US8595262B1 (en) * 2012-03-29 2013-11-26 Amazon Technologies, Inc. Resource resolution in computing environments using directed graphs
US9875094B2 (en) * 2012-08-29 2018-01-23 International Business Machines Corporation Microcode upgrade in a storage system
US9274926B2 (en) 2013-01-03 2016-03-01 Ab Initio Technology Llc Configurable testing of computer programs
AU2014360308B2 (en) 2013-12-05 2018-11-29 Ab Initio Technology Llc Managing interfaces for dataflow graphs composed of sub-graphs

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2012027560A1 (en) * 2010-08-25 2012-03-01 Ab Initio Technology Llc Evaluating dataflow graph characteristics

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
"Javaプログラムの処理速度向上を支援するパフォーマンス計測/負荷テスト・ツール", JAVA WORLD, vol. 第9巻,第4号, JPN6018010553, 1 April 2005 (2005-04-01), JP, pages 020 - 021 *
和田卓人: "実演!リファクタリング", WEB+DB PRESS, vol. 第37巻, JPN6017026197, 25 March 2007 (2007-03-25), JP, pages 41 - 47 *

Also Published As

Publication number Publication date
JP2019179575A (ja) 2019-10-17
US20140143760A1 (en) 2014-05-22
EP2920686B1 (en) 2024-04-17
AU2013344538A1 (en) 2015-05-21
CN104937548A (zh) 2015-09-23
EP2920686A4 (en) 2016-08-03
AU2013344538B2 (en) 2018-11-22
JP6742478B2 (ja) 2020-08-19
US9507682B2 (en) 2016-11-29
WO2014078714A2 (en) 2014-05-22
HK1209868A1 (en) 2016-04-08
KR20150084892A (ko) 2015-07-22
SG11201503473VA (en) 2015-05-28
EP2920686A2 (en) 2015-09-23
KR102284985B1 (ko) 2021-08-02
WO2014078714A3 (en) 2014-07-17
CA2890144A1 (en) 2014-05-22
CN104937548B (zh) 2018-11-13
CA2890144C (en) 2019-07-23

Similar Documents

Publication Publication Date Title
JP6742478B2 (ja) 動的グラフ性能監視
AU2021203955B2 (en) Dynamic component performance monitoring
US9215153B2 (en) Providing status information for virtual resource computing environment
CN110546615A (zh) 超动态java管理扩展
US20240152444A1 (en) Online query execution using a big data framework
US11860887B2 (en) Scalable real-time analytics
Diez Dolinski et al. Distributed simulation of P systems by means of map-reduce: first steps with Hadoop and P-Lingua
CN115185665A (zh) 链路数据获取方法、装置、电子设备及存储介质

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20161021

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20170712

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20171006

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20171129

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20180112

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20180326

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20180607

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20180815

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20180926

A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20190228