Nothing Special   »   [go: up one dir, main page]

JP2008158759A - Programming method, program processing method, processing program, and information processing device - Google Patents

Programming method, program processing method, processing program, and information processing device Download PDF

Info

Publication number
JP2008158759A
JP2008158759A JP2006346162A JP2006346162A JP2008158759A JP 2008158759 A JP2008158759 A JP 2008158759A JP 2006346162 A JP2006346162 A JP 2006346162A JP 2006346162 A JP2006346162 A JP 2006346162A JP 2008158759 A JP2008158759 A JP 2008158759A
Authority
JP
Japan
Prior art keywords
data structure
program
graph data
node
information
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.)
Granted
Application number
JP2006346162A
Other languages
Japanese (ja)
Other versions
JP4965995B2 (en
Inventor
Ryuji Sakai
隆二 境
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Toshiba Corp
Original Assignee
Toshiba Corp
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 Toshiba Corp filed Critical Toshiba Corp
Priority to JP2006346162A priority Critical patent/JP4965995B2/en
Publication of JP2008158759A publication Critical patent/JP2008158759A/en
Application granted granted Critical
Publication of JP4965995B2 publication Critical patent/JP4965995B2/en
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Stored Programmes (AREA)

Abstract

<P>PROBLEM TO BE SOLVED: To solve a problem that in order to process programs to be processed in parallel while keeping execution orders properly, it is necessary to decide dependency relations between programs or between threads in a fixed manner in advance. <P>SOLUTION: In this processing method, based on graph data configuration generation information including previous information and following information extracting portions associated with respective program modules from a parallel operation control description describing a parallel processing relation between program modules, a predetermined program module is extracted to be added to the graph data configuration according to the dependency relation, and operation is carried out from a node, before which all the nodes are already processed. <P>COPYRIGHT: (C)2008,JPO&INPIT

Description

本発明は、プログラムの処理に関するもので、特に並列処理のためのプログラム処理に関する。   The present invention relates to program processing, and more particularly to program processing for parallel processing.

従来のマルチスレッドによる並列処理プログラムは複数のスレッドを生成し、そのそれぞれが同期処理を意識したプログラミングを強いられていた。たとえば実行順序を適切に保つためにはプログラムのさまざまな場所に同期を保証する処理をちりばめる必要があり、プログラムのデバッグが困難になるなどメンテナンスコストを押し上げていた。   A conventional multi-thread parallel processing program generates a plurality of threads, each of which is forced to perform programming in consideration of synchronous processing. For example, in order to keep the execution order appropriate, it is necessary to add processing that guarantees synchronization to various places in the program, which increases the maintenance cost because it becomes difficult to debug the program.

特許文献1は複数のスレッドを生成したとき、そのスレッドの実行結果とスレッド間の依存関係に基づいて並列処理を実現する方法が開示されている。この手法ではあらかじめ重複して実行されるスレッドを定量的に特定しておく必要が生じ、このことからプログラム変更の柔軟性に欠けるという問題がある。
特開2005−258920号公報
Patent Document 1 discloses a method for realizing parallel processing based on execution results of threads and dependency relationships between threads when a plurality of threads are generated. In this method, it is necessary to quantitatively specify the redundantly executed threads in advance, which causes a problem that the flexibility of program change is lacking.
JP 2005-258920 A

並列処理されるプログラム同士が実行順序を適切に保ちながら処理するには、プログラム間あるいはスレッド間であらかじめ依存関係を固定的に決定しておく必要がある。   In order for programs to be processed in parallel to perform processing while maintaining an appropriate execution order, it is necessary to fix the dependency relationship between programs or threads in advance.

本発明は上記問題に鑑みてなされたもので、マルチスレッドによる並列処理においても柔軟に対応可能なプログラム方法、生成プログラム及び情報処理装置を提供する。   The present invention has been made in view of the above problems, and provides a program method, a generation program, and an information processing apparatus that can flexibly cope with multi-thread parallel processing.

本発明にかかるプログラミング方法によれば、
他のプログラムの実行状況に関係なく、最初に入力データが与えられたことを条件に実行可能となる複数のプログラムモジュールと、前記プログラムモジュール同士の並列処理の関係を記述した並列実行制御記述を用いたプログラミング方法であって、前記並列実行制御記述から、個々の前記プログラムモジュールに関連する部分を抽出した少なくとも該プログラムモジュールの先行情報と後続情報を含むグラフデータ構造生成情報を、該プログラムモジュールごとに作成し、ある入力データが与えられた場合には、この入力データを入力とするプログラムモジュールを、前記グラフデータ構造生成情報に含まれる先行情報に基づいて抽出し、この抽出したグラフデータ構造生成情報について前記プログラムモジュールの実行単位を表すノードを生成し、この生成したノードを、前記グラフデータ構造生成情報で定義された先行情報および後続情報に基づいて構成された、その時点に存在するグラフデータ構造に自動的に追加するために前記並列実行制御記述を用いることを特徴とするプログラミングが可能となる。
According to the programming method of the present invention,
Regardless of the execution status of other programs, use multiple program modules that can be executed on condition that input data is first given, and a parallel execution control description that describes the parallel processing relationship between the program modules. A graph data structure generation information including at least preceding information and subsequent information of the program module obtained by extracting a portion related to each of the program modules from the parallel execution control description for each program module. When the input data is created and given, the program module that receives the input data is extracted based on the preceding information included in the graph data structure generation information, and the extracted graph data structure generation information No representing the execution unit of the program module In order to automatically add the generated node to the current graph data structure configured based on the preceding information and subsequent information defined in the graph data structure generation information. Programming characterized by using an execution control description becomes possible.

本発明にかかるプログラム処理方法によれば、
他のプログラムの実行状況に関係なく、最初に入力データが与えられたことを条件に実行可能となる複数のプログラムモジュールを並列に処理するためのプログラム処理方法であって、前記プログラムモジュール同士の並列処理の関係を記述した並列実行制御記述から、個々の前記プログラムモジュールに関連する部分を抽出した少なくとも該プログラムモジュールの先行情報と後続情報を含むグラフデータ構造生成情報を、該プログラムモジュールごとに作成し、ある入力データが与えられた場合には、この入力データを入力とするプログラムモジュールを、前記グラフデータ構造生成情報に含まれる先行情報に基づいて抽出し、この抽出したグラフデータ構造生成情報について前記プログラムモジュールの実行単位を表すノードを生成し、この生成したノードを、それ以前に生成されたノードの前記グラフデータ構造生成情報で定義された先行情報および後続情報に基づいて構成されたグラフデータ構造に自動的に追加し、その時点に存在するグラフデータ構造に含まれるあるノードについて、該ノードに対応する並列実行制御記述に含まれる、先行情報で定義されるプログラムモジュールを表すノードすべてが処理済である場合、該ノードの実行を開始することができる。
According to the program processing method of the present invention,
A program processing method for processing in parallel a plurality of program modules that can be executed on condition that input data is first given regardless of the execution status of other programs, wherein the program modules are connected in parallel. For each program module, graph data structure generation information including at least preceding information and subsequent information of the program module obtained by extracting a part related to each of the program modules from a parallel execution control description describing a processing relationship is created for each program module. When certain input data is given, a program module that receives the input data is extracted based on the preceding information included in the graph data structure generation information, and the extracted graph data structure generation information Generate a node representing the execution unit of the program module This generated node is automatically added to the graph data structure configured based on the preceding information and subsequent information defined in the graph data structure generation information of the previously generated node, and exists at that time For a certain node included in the graph data structure, when all nodes representing program modules defined by the preceding information included in the parallel execution control description corresponding to the node have been processed, execution of the node is started. Can do.

さらに、本発明の処理プログラムとすれば、
他のプログラムの実行状況に関係なく、最初に入力データが与えられたことを条件に実行可能となる複数のプログラムモジュールを並列に処理するための処理プログラムであって、前記プログラムモジュール同士の並列処理の関係を記述した並列実行制御記述から、個々の前記プログラムモジュールに関連する部分を抽出した少なくとも該プログラムモジュールの先行情報と後続情報を含むグラフデータ構造生成情報を、該プログラムモジュールごとに作成し、ある入力データが与えられた場合には、この入力データを入力とするプログラムモジュールを、前記グラフデータ構造生成情報に含まれる先行情報に基づいて抽出し、 この抽出したグラフデータ構造生成情報について前記プログラムモジュールの実行単位を表すノードを生成し、この生成したノードを、それ以前に生成されたノードの前記グラフデータ構造生成情報で定義された先行情報および後続情報に基づいて構成されたグラフデータ構造に自動的に追加し、その時点に存在するグラフデータ構造に含まれるあるノードについて、該ノードに対応する並列実行制御記述に含まれる、先行情報で定義されるプログラムモジュールを表すノードすべてが処理済である場合、該ノードを実行させることが可能となる。
Furthermore, with the processing program of the present invention,
A processing program for processing in parallel a plurality of program modules that can be executed on condition that input data is first given regardless of the execution status of other programs, and parallel processing between the program modules For each program module, graph data structure generation information including at least preceding information and succeeding information of the program module obtained by extracting a portion related to each of the program modules from a parallel execution control description describing the relationship of When certain input data is given, a program module that receives the input data is extracted based on the preceding information included in the graph data structure generation information, and the program is generated for the extracted graph data structure generation information. Create a node representing the module execution unit Is automatically added to the graph data structure configured based on the preceding information and the succeeding information defined in the graph data structure generation information of the previously generated node, and exists at that time For a node included in the graph data structure, if all nodes representing program modules defined by the preceding information included in the parallel execution control description corresponding to the node have been processed, the node can be executed. It becomes.

また、上記機能を提供する情報処理装置が提供される。   An information processing apparatus that provides the above functions is also provided.

マルチスレッドによる並列処理においても柔軟に対応可能なプログラミング環境を提供することができる。   It is possible to provide a programming environment that can flexibly cope with multi-thread parallel processing.

(第1の実施形態)
図1は、本実施形態に係るシステム構成図の一例を示す図である。図1では、複数のプロセッサ100、メモリ101、HDD102及び内部バス103が示されている。
(First embodiment)
FIG. 1 is a diagram illustrating an example of a system configuration diagram according to the present embodiment. In FIG. 1, a plurality of processors 100, a memory 101, an HDD 102, and an internal bus 103 are shown.

プロセッサ100は、種々の記憶装置に記憶したプログラムコードを解釈しプログラムとしてあらかじめ記述された処理を実行する機能を有する。図1では互いに同等のプロセッサ100が3つ示されているが、必ずしも同等のプロセッサである必要はなくそれぞれで処理能力が異なるものや、別種のコードを処理するプロセッサが含まれていてもかまわない。   The processor 100 has a function of interpreting program codes stored in various storage devices and executing processing described in advance as a program. In FIG. 1, three processors 100 that are equivalent to each other are shown. However, the processors need not necessarily be equivalent to each other, and may include processors having different processing capabilities or processors that process different types of codes. .

メモリ101は、たとえば半導体で構成された記憶装置を指す。プロセッサ100が処理するプログラムは処理前に比較的高速にアクセス可能なメモリ101上に読み込まれ、プログラム処理に従ってプロセッサ100からアクセスされる。   The memory 101 indicates a storage device made of, for example, a semiconductor. A program processed by the processor 100 is read into the memory 101 accessible at a relatively high speed before the processing, and is accessed from the processor 100 according to the program processing.

HDD102は、たとえば磁気ディスク装置を指す。HDD102はメモリ101に比べて大容量のデータを記憶できるがアクセス速度において不利である場合が多い。プロセッサ100が処理するプログラムコードはHDD102に記憶しておき、処理する部分のみをメモリ101上に読み出すように構成される。   The HDD 102 indicates a magnetic disk device, for example. The HDD 102 can store a larger amount of data than the memory 101, but is often disadvantageous in terms of access speed. The program code processed by the processor 100 is stored in the HDD 102, and only the part to be processed is read out on the memory 101.

内部バス103は、プロセッサ100、メモリ101及びHDD102を相互に接続し、互いにデータの授受ができるように構成した共通バスである。   The internal bus 103 is a common bus configured such that the processor 100, the memory 101, and the HDD 102 are connected to each other and can exchange data with each other.

また、図示していないが処理結果を出力するための画像表示装置あるいは処理データを入力するためのキーボードなどの入出力装置を備えていてもかまわない。   Although not shown, an image display device for outputting processing results or an input / output device such as a keyboard for inputting processing data may be provided.

図2は、本実施形態に係るプログラムのトランスレーションの一例を示す図である。   FIG. 2 is a diagram showing an example of program translation according to the present embodiment.

基本モジュール200は本実施形態に係るシステムで実行するプログラムであり、並列実行制御記述201は実行する際に参照されるデータである。並列実行制御記述201は基本モジュール200各々の並列処理時の依存関係を示しており、情報処理装置203で実行される前にトランスレータ202によってグラフデータ構造生成情報204に変換される。   The basic module 200 is a program executed by the system according to the present embodiment, and the parallel execution control description 201 is data referred to when executing. The parallel execution control description 201 indicates the dependency of each basic module 200 during parallel processing, and is converted into graph data structure generation information 204 by the translator 202 before being executed by the information processing apparatus 203.

トランスレータ202は基本モジュール200を処理する前に事前に変換する場合以外にも、基本モジュール200の実行中、ランタイムタスク等によって逐次トランスレートしながら処理する方法も考えられる。   In addition to the case where the translator 202 converts the basic module 200 in advance before processing, a method of performing the translation while sequentially translating by a runtime task or the like during execution of the basic module 200 is also conceivable.

情報処理装置203上の実行時点のソフトウェアは、基本モジュール200、グラフデータ構造生成情報204、ランタイムライブラリ205及びOS206から構成される。ランタイムライブラリ205は、基本モジュール200を情報処理装置203上で実行する際のAPI(Application Interface)などを含み、また基本モジュール200を並列処理する際に必要となる排他制御を実現するための機能を有する。一方、ランタイムライブラリ205からトランスレータ202の機能を呼び出すように構成し、基本モジュール200の処理の過程で呼び出されるとき、次に処理する部分の並列実行制御記述201を都度変換するようにしても良い。このように構成すればトランスレートするための常駐タスクが不要になり、並列処理をよりコンパクトに構成できる。   Software at the time of execution on the information processing apparatus 203 includes a basic module 200, graph data structure generation information 204, a runtime library 205, and an OS 206. The runtime library 205 includes an API (Application Interface) when the basic module 200 is executed on the information processing apparatus 203, and has a function for realizing exclusive control required when the basic module 200 is processed in parallel. Have. On the other hand, the function of the translator 202 may be called from the runtime library 205, and when called during the process of the basic module 200, the parallel execution control description 201 of the part to be processed next may be converted each time. This configuration eliminates the need for a resident task for translation and allows parallel processing to be configured more compactly.

OS206は情報処理装置203のハードウェアやタスクのスケジューリングなど、システム全体を管理している。OS206を導入することで、基本モジュール200を実行する際、プログラマーはシステムの雑多な管理から解放されプログラミングに専念できるとともに、一般的に多機種でも稼動可能なソフトウェアを容易に記述することができるというメリットがある。 The OS 206 manages the entire system such as hardware of the information processing apparatus 203 and task scheduling. By introducing the OS 206, when the basic module 200 is executed, the programmer is freed from miscellaneous management of the system and can concentrate on programming, and generally can easily describe software that can be operated on many models. There are benefits.

図3は、従来の並列処理プログラムの処理フローの一例を示す図である。図3ではプログラムA300、B301及びC302の複数のプログラムが並行して処理されている模式図を示している。   FIG. 3 is a diagram illustrating an example of a processing flow of a conventional parallel processing program. FIG. 3 shows a schematic diagram in which a plurality of programs A300, B301 and C302 are processed in parallel.

プログラム同士はそれぞれ無関係に処理されているわけではなく、他のプログラムの処理結果を自身の処理に使用する場合、あるいはデータの整合性を確保するという理由で他のプログラムの特定部分の処理が終わるのを待たねばならないことがある。このような特性を持つプログラムを並列に処理する場合、プログラムの各所に他のプログラムの実行状況を知得するための仕組みを埋め込まねばならない。この仕組みを埋め込むことによってプログラム間でデータ保証や、排他制御を実現し協調動作するように構成していた。   The programs are not processed independently of each other. When the processing results of other programs are used for their own processing, or because the data consistency is ensured, the processing of a specific part of the other program ends. Sometimes you have to wait. When a program having such characteristics is processed in parallel, a mechanism for knowing the execution status of another program must be embedded in each part of the program. By embedding this mechanism, data guarantees and exclusive control are realized between programs to perform cooperative operation.

たとえばプログラムA300の処理中に所定のイベントが発生したとき、プログラムB301に対してなんらかの処理をするように依頼する(イベント303)。プログラムB301はイベント303を受けて所定の処理を実行し、所定の条件が成立したときさらにイベント304をプログラムC302に発行する。プログラムB301はイベント303によってプログラムA300から受けた処理の結果をイベント305としてプログラムA300に応答する。   For example, when a predetermined event occurs during the processing of the program A300, the program B301 is requested to perform some processing (event 303). The program B301 receives the event 303, executes a predetermined process, and further issues an event 304 to the program C302 when a predetermined condition is satisfied. The program B301 responds to the program A300 as an event 305 with the processing result received from the program A300 by the event 303.

しかしながら、プログラム自身に並列処理における同期処理を実現するための記述をした場合、本来のロジックとは別の配慮が必要となりプログラムが複雑になってしまう。また、他のプログラムの処理終了を待つ間、無駄にリソースを消費することにもなる。さらにはちょっとしたタイミングのずれによって処理効率が大きく変動するなど、後からのプログラム修正が困難になる場合が多い。   However, if a description for realizing synchronous processing in parallel processing is written in the program itself, consideration different from the original logic is required and the program becomes complicated. Further, resources are wasted while waiting for the end of processing of other programs. Furthermore, it is often difficult to modify the program later, for example, processing efficiency fluctuates greatly due to a slight timing shift.

本実施形態に係る情報処理装置では、同期処理やデータの授受の必要な部分で分割し、その間の関連を並列実行制御記述として定義することで基本モジュールの部品化を促進し、並列処理定義をコンパクトに管理できる手法を提案する。   In the information processing apparatus according to the present embodiment, it is divided into parts that require synchronous processing and data exchange, and the relationship between them is defined as a parallel execution control description, thereby facilitating the componentization of the basic module, and the parallel processing definition. We propose a method that can be managed in a compact manner.

図4は、本実施形態に係るプログラムの分割方法の一例を説明する図である。図4では相互に同期処理をするプログラムA400及びB401を示している。   FIG. 4 is a diagram for explaining an example of a program dividing method according to this embodiment. FIG. 4 shows programs A400 and B401 that perform synchronization processing with each other.

まずプログラムA400がスレッド402を、プログラムB401がスレッド407を実行している場合を想定する。プログラムA400はポイント406まで実行すると、その処理結果をプログラムB401に受け渡す必要があるとする。このためプログラムA400はスレッド402を終了すると処理結果をイベント404としてプログラムB401に通知する。プログラムB401は、このイベント404とスレッド407の処理結果の両方が揃ったとき初めてスレッド405が実行可能な処理である。一方、プログラムA400は、スレッド402の終了を受けてポイント406以降のプログラムをスレッド403として実行する。   First, it is assumed that the program A 400 is executing the thread 402 and the program B 401 is executing the thread 407. When the program A400 is executed up to the point 406, the processing result needs to be transferred to the program B401. Therefore, when the program A 400 terminates the thread 402, the program A 400 notifies the program B 401 of the processing result as an event 404. The program B 401 is a process that can be executed by the thread 405 for the first time when both the event 404 and the processing result of the thread 407 are obtained. On the other hand, the program A 400 receives the end of the thread 402 and executes the program after the point 406 as the thread 403.

上記のスレッド402のように無条件に処理を進めて良い部分と、ポイント406のようにプログラムを処理していく間に他のスレッドに通知すべきある処理結果が得られるポイント、あるいは他のスレッドからの処理結果を得ることが処理開始の条件となっているポイントなどが存在する。   A portion where processing can proceed unconditionally like the above thread 402, and a point where a certain processing result to be notified to other threads can be obtained while processing a program, such as point 406, or another thread There is a point where obtaining a processing result from the above is a condition for starting the processing.

そこで図4に示すように、ポイント406のようなポイントでプログラムを分割し、その分割後のプログラムの処理単位をそれぞれ基本モジュールa1〜a3、基本モジュールb1〜b3と定義する。図4では相互に関連するプログラムが2つ示されているが、それ以上の数の相互に関連するプログラムがあっても同様の考え方で分割可能である。   Therefore, as shown in FIG. 4, the program is divided at a point such as point 406, and the processing units of the program after the division are defined as basic modules a1 to a3 and basic modules b1 to b3, respectively. Although two mutually related programs are shown in FIG. 4, even if there are more programs that are related to each other, they can be divided in the same way.

図5は、本実施形態に係る基本モジュールの依存関係の一例を説明する図である。基本モジュール500は図4で説明した基本モジュールを表し、他のスレッドに関係なく無条件に進めて良いモジュール化されたプログラムがそれぞれに割り当てられている。このモジュール化されたプログラムが基本モジュール200に対応する。さらにそれらの基本モジュールは他の基本モジュールとの依存関係を示すリンク501に基づいて関連付けられている。各基本モジュールはリンク501によって関連を定義された先行基本モジュールからの計算結果出力のようなイベントを受け、同時にリンクにより関連を定義された後続基本モジュールへのイベントを発生させることを示している。また、複数のリンクが入っている基本モジュールでは、自身の処理のために複数のイベント条件が必要であることを表している。   FIG. 5 is a diagram for explaining an example of the dependency relationship of the basic modules according to the present embodiment. The basic module 500 represents the basic module described with reference to FIG. 4, and modularized programs that can be unconditionally advanced regardless of other threads are assigned to the respective modules. This modularized program corresponds to the basic module 200. Further, these basic modules are associated based on a link 501 indicating a dependency relationship with other basic modules. Each basic module receives an event such as a calculation result output from a preceding basic module whose relation is defined by a link 501 and simultaneously generates an event to a subsequent basic module whose relation is defined by a link. In addition, a basic module containing a plurality of links indicates that a plurality of event conditions are necessary for its own processing.

図6は、本実施形態に係るノード600の一例を説明する図である。ここでいうノードとは個々の基本モジュールに対応しており、前出の並列実行制御記述201をトランスレータ202でグラフデータ構造生成情報204に変換後、この情報に基づいて基本モジュールをグラフデータ構造化したものである。   FIG. 6 is a diagram illustrating an example of the node 600 according to the present embodiment. The node here corresponds to each basic module. After the parallel execution control description 201 is converted into the graph data structure generation information 204 by the translator 202, the basic module is converted into the graph data structure based on this information. It is a thing.

前述のように基本モジュールをグラフデータ構造化したノード600は、リンクにより他のノードと依存関係を有している。図6(a)のようにノードとしてみたとき、リンクとして先行ノードへのリンク601と後続ノードへの結合子602の2種類のリンクが存在する。 As described above, the node 600 obtained by structuring the basic module in the graph data structure has a dependency relationship with other nodes through links. When viewed as a node as shown in FIG. 6A, there are two types of links, a link 601 to the preceding node and a connector 602 to the succeeding node.

リンク601は、ノード600が所定の処理を実行するのに必要なデータを得るために必要な他のノードの出力端に結合されるリンクである。リンク601のそれぞれにはどのような出力端とのリンクが必要かなどの定義情報を持っている。   The link 601 is a link coupled to an output terminal of another node necessary for obtaining data necessary for the node 600 to execute a predetermined process. Each link 601 has definition information such as what kind of output end a link is necessary with.

結合子602は、ノード600の処理後に出力するデータがいかなるものであるかを示す識別情報を備えている。後続のノードは、この結合子602の識別情報と並列実行制御記述201とに基づいて自身が実行可能な条件がそろったか否かを判断することができる。   The connector 602 includes identification information indicating what kind of data is output after the processing of the node 600. Subsequent nodes can determine whether or not the conditions under which they can be executed are complete based on the identification information of the connector 602 and the parallel execution control description 201.

ノード600はシステムにより実行可能な条件がそろったとみなされると、図6(b)に示すようにノードの単位で実行可能キュー603にキューイングされ、キューされたノードの中から次に実行すべきノードが取り出されて処理される。   When it is considered that the conditions executable by the system are satisfied, the node 600 is queued in the executable queue 603 in units of nodes as shown in FIG. 6B, and should be executed next from the queued nodes. The node is retrieved and processed.

図7は、本実施形態に係るノードのグラフデータ構造生成情報204の一例を示す図である。図7には、並列実行制御記述201からトランスレートされたグラフデータ構造生成情報700が示されている。情報としては、基本モジュールID、先行ノードへの複数のリンク情報、当該ノードの出力バッファの種別、及び当該ノードの処理コストが含まれる。ここでいうコスト情報は、当該ノードに対応する基本モジュール200の処理に係るコストを示している。この情報は実行可能キュー603にキューイングされたノードのうち、次に取り出すノードを選択する際に考慮される。   FIG. 7 is a diagram showing an example of the node graph data structure generation information 204 according to the present embodiment. FIG. 7 shows graph data structure generation information 700 translated from the parallel execution control description 201. The information includes the basic module ID, a plurality of pieces of link information to the preceding node, the output buffer type of the node, and the processing cost of the node. The cost information here indicates a cost related to processing of the basic module 200 corresponding to the node. This information is considered when selecting the next node to be extracted from among the nodes queued in the executable queue 603.

先行ノードへのリンク情報には、当該ノードの先行ノードとなるべきノードの条件が定義されている。たとえば所定のデータタイプを出力するノード、特定のIDを持つノードなどの定義が考えられる。   In the link information to the preceding node, a condition for a node to be the preceding node of the node is defined. For example, the definition of a node that outputs a predetermined data type, a node having a specific ID, and the like can be considered.

このグラフデータ構造生成情報700は、対応する基本モジュール200をノードとして表現するとともに、リンク情報などに基づいて図5に示すような既存のグラフデータ構造にこの基本モジュールを追加するための情報として用いる。   The graph data structure generation information 700 represents the corresponding basic module 200 as a node, and is used as information for adding the basic module to an existing graph data structure as shown in FIG. 5 based on link information or the like. .

図8は、本実施形態に係るグラフデータ構造の追加処理フローの一例を示す図である。このフローを実行するとグラフデータ構造生成情報700に基づいてその時々に実行可能なノードを生成し実行可能キュー603にキューイングする。   FIG. 8 is a diagram showing an example of a processing flow for adding a graph data structure according to this embodiment. When this flow is executed, an executable node is generated based on the graph data structure generation information 700 and is queued in the executable queue 603.

まずマルチスレッド処理を管理するランタイムタスクが処理対象となる入力データを受け付ける(ステップS01)。入力データの有無を判断し(ステップS02)、入力データが無ければ(No)再び入力データを受け付ける。 First, a runtime task that manages multithread processing receives input data to be processed (step S01). The presence or absence of input data is determined (step S02). If there is no input data (No), the input data is accepted again.

ステップS02で入力データがある場合(Yes)、この入力データを入力とするグラフデータ構造生成情報204を抽出してこれらを取得する(ステップS03)。基本モジュール200の出力データは、あらかじめグラフデータ構造生成情報700の出力バッファ種別に記載すべき複数のタイプに分別されている。入力データを入力とするグラフデータ構造生成情報204の抽出にあたっては、グラフデータ構造生成情報700に記載の先行ノードへのリンク情報に含まれる入力データとなるべきデータタイプに基づき、このデータタイプが先の入力データと一致するものを抽出すればよい。 If there is input data in step S02 (Yes), the graph data structure generation information 204 that receives the input data is extracted and acquired (step S03). The output data of the basic module 200 is classified in advance into a plurality of types to be described in the output buffer type of the graph data structure generation information 700. When extracting the graph data structure generation information 204 with input data as an input, this data type is determined based on the data type to be input data included in the link information to the preceding node described in the graph data structure generation information 700. It is sufficient to extract data that matches the input data.

次に、ステップS03で取得したグラフデータ構造生成情報700に対応するノード600を生成する(ステップS04)。ここで複数のグラフデータ構造生成情報700が抽出された場合には、複数のそれぞれに対応するノード600が生成される。   Next, the node 600 corresponding to the graph data structure generation information 700 acquired in step S03 is generated (step S04). When a plurality of graph data structure generation information 700 is extracted here, a plurality of nodes 600 corresponding to the plurality of graph data structure generation information 700 are generated.

生成したノード600は、次に既存のグラフデータ構造に追加される(ステップS05)。ここでいう既存のグラフデータ構造とは、グラフデータ構造生成情報700から生成されたノード600の先行ノードへのリンク情報と出力バッファタイプに基づいて、生成済みノードの前後の依存関係を、たとえば図5に示すように構造化したものである。   The generated node 600 is then added to the existing graph data structure (step S05). The existing graph data structure here refers to the dependency relationship before and after the generated node based on the link information to the preceding node of the node 600 generated from the graph data structure generation information 700 and the output buffer type. This is structured as shown in FIG.

次に、既存のグラフデータ構造に含まれる各ノードについて、それぞれの先行ノードが処理を完了したかどうかを判断する(ステップS06)。あるノードについてすべての先行ノードが完了しているならば(Yes)、このノードが実行開始のための条件が整ったとみなし、このノードを実行可能キュー603にキューイングする(ステップS07)。一方、依然として処理が完了していない先行ノードがある場合(No)自身の処理を始めることが出来ず、フローは終了する。このようにノード600が生成されても、そのノードに対応する基本モジュール200がすぐに実行されるわけではなく、追加されたグラフデータ構造の他のノードとの依存関係が満たされるまでその処理は保留される。   Next, for each node included in the existing graph data structure, it is determined whether or not each preceding node has completed processing (step S06). If all the preceding nodes have been completed for a certain node (Yes), it is considered that this node has a condition for starting execution, and this node is queued in the executable queue 603 (step S07). On the other hand, if there is a preceding node that has not yet completed processing (No), the processing cannot be started, and the flow ends. Even if the node 600 is generated in this way, the basic module 200 corresponding to the node is not immediately executed, and the processing is not performed until the dependency relationship with the other nodes of the added graph data structure is satisfied. Deferred.

図9は、本実施形態に係る基本モジュール処理の一例を示す図である。このフローでは実行可能キュー603にキューイングされたノードを読み出して各基本モジュール200を実行する例を示している。   FIG. 9 is a diagram illustrating an example of basic module processing according to the present embodiment. This flow shows an example in which each basic module 200 is executed by reading a node queued in the executable queue 603.

最初に実行可能キュー603にキューイングされている実行可能となっているノードのうちから所定の条件に基づいて次に実行するノードを選択する(ステップS11)。所定の条件とはたとえば、キューイングされた最も古いノード、後続ノードが多いノードあるいはコストの高いノードなどの基準に基づいて選択することができる。   First, a node to be executed next is selected based on a predetermined condition from among the executable nodes queued in the executable queue 603 (step S11). The predetermined condition can be selected based on criteria such as the oldest queued node, the node with many subsequent nodes, or the node with high cost.

各ノードのコストを次のように計算して求めても良い。   The cost of each node may be calculated and calculated as follows.

追加ノードのコスト = ( α × 過去の平均実行時間 )
+( β × 出力バッファの使用量 )
+( γ × 後続ノード数 )
+( δ × 非スケジュール時の実行頻度 )
一般的にはコストが高いノードから処理していく方が、並列処理のスループットが上がると考えられる。ここで非スケジュール時の実行頻度とは、その基本モジュールが実行中に、実行可能キュー603にいずれのノードもキューイングされていない状況が出現する頻度をいう。この状況が発生すると実行可能キュー603のアンダーフローが発生し、基本モジュール200の並列処理度が低下するため好ましくない。このような基本モジュール200はコストがより高く算出されることから早めに処理されボトルネック回避に効果が期待できる。
Cost of additional node = (α × past average execution time)
+ (Β x Output buffer usage)
+ (Γ x number of subsequent nodes)
+ (Δ x execution frequency when not scheduled)
In general, it is considered that the throughput of parallel processing increases when processing is performed from a node with high cost. Here, the non-scheduled execution frequency refers to a frequency at which a situation in which no node is queued in the executable queue 603 appears while the basic module is being executed. If this situation occurs, an underflow of the executable queue 603 occurs, and the parallel processing degree of the basic module 200 decreases, which is not preferable. Since such a basic module 200 is calculated at a higher cost, it can be processed early and expected to avoid bottlenecks.

コスト計算式の一次式の各係数α〜δはあらかじめ定めた値を使用しても良いし、処理の状況を見ながら動的に変化するように構成しても良い。   Predetermined values may be used for the coefficients α to δ of the linear expression of the cost calculation formula, or the coefficients α to δ may be dynamically changed while observing the processing status.

次に実行するノードを取得したら、次にこのノードの処理結果を格納する出力用バッファを実行前に確保する(ステップS12)。出力用バッファは、グラフデータ構造生成情報700で定義された出力バッファタイプの定義に基づいて確保される。   When the node to be executed next is acquired, an output buffer for storing the processing result of this node is secured before execution (step S12). The output buffer is secured based on the definition of the output buffer type defined in the graph data structure generation information 700.

出力用バッファが確保できると、このノードに対応する基本モジュール200の実行を開始する(ステップS13)。当該基本モジュール200が処理を終了すると、グラフデータ構造内の当該ノードの実行済みフラグを処理済に設定する(ステップS14)。   When the output buffer can be secured, the execution of the basic module 200 corresponding to this node is started (step S13). When the basic module 200 ends the processing, the executed flag of the node in the graph data structure is set to processed (step S14).

次に、当該ノードのグラフデータ構造に含まれる後続ノードがすべて処理済となっているか否かを判断する(ステップS15)。後続ノードのすべてが処理済であれば(Yes)当該ノードをグラフデータ構造から削除することができる(ステップS16)。このとき、当該ノードの出力データも使用することがないのでステップS12で確保した出力用バッファも開放される。逆に後続ノードのうちまだ処理済でないものがあれば、当該ノードの出力データを後続ノードの基本モジュールで使用する可能性があるため、グラフデータ構造から削除してはいけない。   Next, it is determined whether all subsequent nodes included in the graph data structure of the node have been processed (step S15). If all the subsequent nodes have been processed (Yes), the node can be deleted from the graph data structure (step S16). At this time, since the output data of the node is not used, the output buffer secured in step S12 is also released. Conversely, if there is a subsequent node that has not been processed yet, the output data of that node may be used in the basic module of the subsequent node, and therefore it should not be deleted from the graph data structure.

次に、グラフデータ構造に含まれるすべてのノードそれぞれについて、そのノードの先行ノードすべてが処理済となっているか否かを判断する(ステップS17)。先行ノードのすべてが処理済となっているノードがあれば(Yes)、当該ノードは実行開始条件が整ったとみなし実行可能キュー603にキューイングする(ステップS18)。先行ノードの一つでも処理済でないノードは(No)、その先行ノードの処理の終了を待たなければ実行できない。   Next, for each of all nodes included in the graph data structure, it is determined whether all preceding nodes of the node have been processed (step S17). If there is a node for which all of the preceding nodes have been processed (Yes), the node is considered to have been executed and the queue is queued in the executable queue 603 (step S18). A node that has not been processed even at one of the preceding nodes (No) cannot be executed without waiting for the end of the processing of the preceding node.

このように構成すると、ランタイムタスクが自立的に実行可能な基本モジュール200を選択し、併せてグラフデータ構造を逐次更新することで並列処理がなされることから、これら一連の処理はアプリケーションとして考慮する必要がない。また、基本モジュール200は他のタスクと分岐する部分を含まないことから、実行中の他のタスクとの調停を考慮する必要もない。   With this configuration, since the parallel processing is performed by selecting the basic module 200 that can be independently executed by the runtime task and simultaneously updating the graph data structure, the series of processing is considered as an application. There is no need. In addition, since the basic module 200 does not include a part that branches from another task, it is not necessary to consider arbitration with another task being executed.

よってマルチスレッドによる並列処理においても柔軟に対応可能なプログラミング環境を提供することができる。   Therefore, it is possible to provide a programming environment that can flexibly cope with multi-thread parallel processing.

なお、本発明は上記実施形態そのままに限定されるものではなく、実施段階ではその要旨を逸脱しない範囲で構成要素を変形して具体化できる。また、上記実施形態に開示されている複数の構成要素の適宜な組み合わせにより、種々の発明を形成できる。例えば、実施形態に示される全構成要素から幾つかの構成要素を削除してもよい。さらに、異なる実施形態にわたる構成要素を適宜組み合わせてもよい。   Note that the present invention is not limited to the above-described embodiment as it is, and can be embodied by modifying the constituent elements without departing from the scope of the invention in the implementation stage. In addition, various inventions can be formed by appropriately combining a plurality of constituent elements disclosed in the embodiment. For example, some components may be deleted from all the components shown in the embodiment. Furthermore, constituent elements over different embodiments may be appropriately combined.

本実施形態に係るシステム構成図の一例を示す図である。It is a figure which shows an example of the system block diagram concerning this embodiment. 本実施形態に係るプログラムのトランスレーションの一例を示す図である。It is a figure which shows an example of the translation of the program which concerns on this embodiment. 従来の並列処理プログラムの処理フローの一例を示す図である。It is a figure which shows an example of the processing flow of the conventional parallel processing program. 本実施形態に係るプログラムの分割方法の一例を説明する図である。It is a figure explaining an example of the division method of the program concerning this embodiment. 本実施形態に係るノードの依存関係の一例を説明する図である。It is a figure explaining an example of the dependency relation of the node concerning this embodiment. 本実施形態に係るノードの一例を説明する図である。It is a figure explaining an example of the node concerning this embodiment. 本実施形態に係るノードのグラフデータ構造生成情報の一例を示す図である。It is a figure which shows an example of the graph data structure production | generation information of the node which concerns on this embodiment. 本実施形態に係るグラフデータ構造の追加処理フローの一例を示す図である。It is a figure which shows an example of the addition process flow of the graph data structure which concerns on this embodiment. 本実施形態に係る基本モジュール処理の一例を示す図である。It is a figure which shows an example of the basic module process which concerns on this embodiment.

符号の説明Explanation of symbols

100・・・プロセッサ、101・・・メモリ、102・・・HDD、103・・・内部バス、200・・・基本モジュール、201・・・並列実行制御記述、202・・・トランスレータ、203・・・情報処理装置、204・・・グラフデータ構造生成情報、205・・・ランタイムライブラリ、206・・・OS、300・・・プログラムA、301・・・プログラムB、302・・・プログラムC、303・・・イベント、402・・・スレッド、500・・・基本モジュール、501・・・リンク、601・・・リンク、602・・・結合子、603・・・実行可能キュー、700・・・グラフデータ構造生成情報 DESCRIPTION OF SYMBOLS 100 ... Processor, 101 ... Memory, 102 ... HDD, 103 ... Internal bus, 200 ... Basic module, 201 ... Parallel execution control description, 202 ... Translator, 203 ... Information processing device 204: Graph data structure generation information 205: Runtime library 206: OS, 300: Program A 301: Program B 302: Program C 303 ... Event, 402 ... Thread, 500 ... Basic module, 501 ... Link, 601 ... Link, 602 ... Connector, 603 ... Executable queue, 700 ... Graph Data structure generation information

Claims (10)

他のプログラムの実行状況に関係なく、最初に入力データが与えられたことを条件に実行可能となる複数のプログラムモジュールと、
前記プログラムモジュール同士の並列処理の関係を記述した並列実行制御記述を用いたプログラミング方法であって、
前記並列実行制御記述から、個々の前記プログラムモジュールに関連する部分を抽出した少なくとも該プログラムモジュールの先行情報と後続情報を含むグラフデータ構造生成情報を、該プログラムモジュールごとに作成し、
ある入力データが与えられた場合には、この入力データを入力とするプログラムモジュールを、前記グラフデータ構造生成情報に含まれる先行情報に基づいて抽出し、
この抽出したグラフデータ構造生成情報について前記プログラムモジュールの実行単位を表すノードを生成し、
この生成したノードを、前記グラフデータ構造生成情報で定義された先行情報および後続情報に基づいて構成された、その時点に存在するグラフデータ構造に自動的に追加するために前記並列実行制御記述を用いることを特徴とするプログラミング方法。
Regardless of the execution status of other programs, a plurality of program modules that can be executed on condition that input data is given first,
A programming method using a parallel execution control description describing a parallel processing relationship between the program modules,
Graph data structure generation information including at least preceding information and subsequent information of the program module obtained by extracting a part related to each program module from the parallel execution control description is created for each program module,
When certain input data is given, a program module that receives the input data is extracted based on the preceding information included in the graph data structure generation information,
Generate a node representing the execution unit of the program module for the extracted graph data structure generation information,
In order to automatically add the generated node to the graph data structure existing at that time, which is configured based on the preceding information and the succeeding information defined in the graph data structure generation information, the parallel execution control description is added. A programming method characterized by using.
その時点に存在する前記グラフデータ構造に含まれるあるノードについて、該ノードに対応する並列実行制御記述に含まれる、先行情報で定義されるプログラムモジュールを表すノードすべてが処理済である場合、該ノードの実行を開始するために前記並列実行制御記述を用いることを特徴とする、請求項1に記載のプログラミング方法。   For a node included in the graph data structure existing at that time, when all nodes representing program modules defined in the preceding information included in the parallel execution control description corresponding to the node have been processed, the node The programming method according to claim 1, wherein the parallel execution control description is used to start execution of a program. その時点に存在する前記グラフデータ構造に含まれる、あるノードに対応するグラフデータ構造生成情報の後続情報に基づいて抽出したすべてのノードが処理済である場合、該ノードを前記グラフデータ構造から自動的に削除するために前記並列実行制御記述を用いることを特徴とする、請求項1に記載のプログラミング方法。   If all the nodes extracted based on the subsequent information of the graph data structure generation information corresponding to a certain node included in the graph data structure existing at that time have been processed, the node is automatically extracted from the graph data structure. The programming method according to claim 1, wherein the parallel execution control description is used in order to be deleted. 他のプログラムの実行状況に関係なく、最初に入力データが与えられたことを条件に実行可能となる複数のプログラムモジュールを並列に処理するためのプログラム処理方法であって、
前記プログラムモジュール同士の並列処理の関係を記述した並列実行制御記述から、個々の前記プログラムモジュールに関連する部分を抽出した少なくとも該プログラムモジュールの先行情報と後続情報を含むグラフデータ構造生成情報を、該プログラムモジュールごとに作成し、
ある入力データが与えられた場合には、この入力データを入力とするプログラムモジュールを、前記グラフデータ構造生成情報に含まれる先行情報に基づいて抽出し、
この抽出したグラフデータ構造生成情報について前記プログラムモジュールの実行単位を表すノードを生成し、
この生成したノードを、それ以前に生成されたノードの前記グラフデータ構造生成情報で定義された先行情報および後続情報に基づいて構成されたグラフデータ構造に自動的に追加し、
その時点に存在するグラフデータ構造に含まれるあるノードについて、該ノードに対応する並列実行制御記述に含まれる、先行情報で定義されるプログラムモジュールを表すノードすべてが処理済である場合、該ノードの実行を開始する
ことを特徴とするプログラム処理方法。
A program processing method for processing in parallel a plurality of program modules that can be executed on condition that input data is first given regardless of the execution status of other programs,
Graph data structure generation information including at least preceding information and succeeding information of the program module obtained by extracting a portion related to each of the program modules from a parallel execution control description that describes a parallel processing relationship between the program modules, Create for each program module,
When certain input data is given, a program module that receives the input data is extracted based on the preceding information included in the graph data structure generation information,
Generate a node representing the execution unit of the program module for the extracted graph data structure generation information,
The generated node is automatically added to the graph data structure configured based on the preceding information and the subsequent information defined in the graph data structure generation information of the previously generated node,
For a node included in the graph data structure existing at that time, when all the nodes representing the program modules defined in the preceding information included in the parallel execution control description corresponding to the node have been processed, A program processing method characterized by starting execution.
その時点に存在する前記グラフデータ構造に含まれる、あるノードに対応するグラフデータ構造生成情報の後続情報に基づいて抽出したすべてのノードが処理済である場合、該ノードを該グラフデータ構造から自動的に削除することを特徴とする、請求項4に記載のプログラム処理方法。   If all the nodes extracted based on the subsequent information of the graph data structure generation information corresponding to a certain node included in the graph data structure existing at that time have been processed, the node is automatically extracted from the graph data structure. The program processing method according to claim 4, wherein the program processing method is deleted. 前記グラフデータ構造生成情報の作成は、該並列実行制御記述のうち当該プログラム処理で実行されるプログラムモジュールに関連する部分について自動的に行われることを特徴とする請求項4に記載のプログラム処理方法。   5. The program processing method according to claim 4, wherein the creation of the graph data structure generation information is automatically performed for a portion related to a program module executed in the program processing in the parallel execution control description. . 他のプログラムの実行状況に関係なく、最初に入力データが与えられたことを条件に実行可能となる複数のプログラムモジュールを並列に処理するための処理プログラムであって、
前記プログラムモジュール同士の並列処理の関係を記述した並列実行制御記述から、個々の前記プログラムモジュールに関連する部分を抽出した少なくとも該プログラムモジュールの先行情報と後続情報を含むグラフデータ構造生成情報を、該プログラムモジュールごとに作成し、
ある入力データが与えられた場合には、この入力データを入力とするプログラムモジュールを、前記グラフデータ構造生成情報に含まれる先行情報に基づいて抽出し、
この抽出したグラフデータ構造生成情報について前記プログラムモジュールの実行単位を表すノードを生成し、
この生成したノードを、それ以前に生成されたノードの前記グラフデータ構造生成情報で定義された先行情報および後続情報に基づいて構成されたグラフデータ構造に自動的に追加し、
その時点に存在するグラフデータ構造に含まれるあるノードについて、該ノードに対応する並列実行制御記述に含まれる、先行情報で定義されるプログラムモジュールを表すノードすべてが処理済である場合、該ノードを実行させる
ことを特徴とする処理プログラム。
A processing program for processing in parallel a plurality of program modules that can be executed on condition that input data is first given regardless of the execution status of other programs,
Graph data structure generation information including at least preceding information and subsequent information of the program module obtained by extracting a portion related to each of the program modules from a parallel execution control description describing a parallel processing relationship between the program modules, Create for each program module,
When certain input data is given, a program module that receives the input data is extracted based on the preceding information included in the graph data structure generation information,
Generate a node representing the execution unit of the program module for the extracted graph data structure generation information,
The generated node is automatically added to the graph data structure configured based on the preceding information and the subsequent information defined in the graph data structure generation information of the previously generated node,
For a certain node included in the graph data structure existing at that time, when all the nodes representing the program modules defined in the preceding information included in the parallel execution control description corresponding to the node have been processed, A processing program characterized by being executed.
その時点に存在する前記グラフデータ構造に含まれる、あるノードに対応するグラフデータ構造生成情報の後続情報に基づいて抽出したすべてのノードが処理済である場合、該ノードを該グラフデータ構造から自動的に削除することを特徴とする、請求項7に記載の処理プログラム。   If all the nodes extracted based on the subsequent information of the graph data structure generation information corresponding to a certain node included in the graph data structure existing at that time have been processed, the node is automatically extracted from the graph data structure. The processing program according to claim 7, wherein the processing program is deleted. 前記グラフデータ構造生成情報は、該並列実行制御記述のうち当該プログラム処理で実行されるプログラムモジュールに関連する部分について自動的に作成することを特徴とする請求項7に記載の処理プログラム。   8. The processing program according to claim 7, wherein the graph data structure generation information is automatically created for a portion related to a program module executed in the program processing in the parallel execution control description. 他のプログラムの実行状況に関係なく最初に入力データが与えられたことを条件に実行可能となる複数のプログラムモジュールを記憶する記憶手段と、
前記プログラムモジュールの並列処理の関係を記述した並列実行制御記述から、個々の前記プログラムモジュールに関連する部分を抽出した少なくとも該プログラムモジュールの先行情報と後続情報を含むグラフデータ構造生成情報を該プログラムモジュールごとに作成する処理手段と、
前記処理手段はさらに、
前記プログラムモジュールを実行した結果ある入力データが得られた場合、この入力データを入力とするプログラムモジュールを、前記グラフデータ構造生成情報に含まれる先行情報に基づいて抽出し、
この抽出したグラフデータ構造生成情報について前記プログラムモジュールの実行単位を表すノードを生成し、
この生成したノードを、それ以前に生成されたノードの前記グラフデータ構造生成情報で定義された先行情報および後続情報に基づいて構成されたグラフデータ構造に自動的に追加し、
その時点に存在するグラフデータ構造に含まれるあるノードについて、該ノードに対応する並列実行制御記述に含まれる、先行情報で定義されるプログラムモジュールを表すノードすべてが処理済である場合、該ノードに対応するプログラムモジュールを実行する
ことを特徴とする情報処理装置。
Storage means for storing a plurality of program modules that can be executed on condition that input data is first given regardless of the execution status of other programs;
Graph data structure generation information including at least preceding information and succeeding information of the program module obtained by extracting a part related to each of the program modules from a parallel execution control description describing a parallel processing relationship of the program module. Processing means to create for each,
The processing means further includes
When certain input data is obtained as a result of executing the program module, the program module having the input data as an input is extracted based on the preceding information included in the graph data structure generation information,
Generate a node representing the execution unit of the program module for the extracted graph data structure generation information,
The generated node is automatically added to the graph data structure configured based on the preceding information and the subsequent information defined in the graph data structure generation information of the previously generated node,
For a node included in the graph data structure existing at that time, when all the nodes representing the program modules defined in the preceding information included in the parallel execution control description corresponding to the node have been processed, An information processing apparatus that executes a corresponding program module.
JP2006346162A 2006-12-22 2006-12-22 Program processing method, processing program, and information processing apparatus Expired - Fee Related JP4965995B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2006346162A JP4965995B2 (en) 2006-12-22 2006-12-22 Program processing method, processing program, and information processing apparatus

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2006346162A JP4965995B2 (en) 2006-12-22 2006-12-22 Program processing method, processing program, and information processing apparatus

Publications (2)

Publication Number Publication Date
JP2008158759A true JP2008158759A (en) 2008-07-10
JP4965995B2 JP4965995B2 (en) 2012-07-04

Family

ID=39659604

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2006346162A Expired - Fee Related JP4965995B2 (en) 2006-12-22 2006-12-22 Program processing method, processing program, and information processing apparatus

Country Status (1)

Country Link
JP (1) JP4965995B2 (en)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2008276547A (en) * 2007-04-27 2008-11-13 Toshiba Corp Program processing method and information processor
CN101887367A (en) * 2010-06-22 2010-11-17 天津大学 Multi-level parallel programming method
US8914391B2 (en) 2011-05-20 2014-12-16 International Business Machines Corporation Method, program, and system for converting part of graph data to data structure as an image of homomorphism
US9208590B2 (en) 2011-05-20 2015-12-08 International Business Machines Corporation Manipulation of an object as an image of a mapping of graph data
CN109377177A (en) * 2018-10-18 2019-02-22 东软集团股份有限公司 Flow path processing method, device, equipment and computer readable storage medium
JP2019145065A (en) * 2018-02-21 2019-08-29 株式会社デンソー Parallelizing method, parallelizing tool, multi-core microcomputer and on-vehicle unit
CN113076129A (en) * 2021-03-23 2021-07-06 成都安恒信息技术有限公司 Automatic checking and processing method for complex configuration dependency relationship
CN114816433A (en) * 2022-06-01 2022-07-29 携程旅游网络技术(上海)有限公司 Encoding method, system, device and medium in project based on asynchronous programming

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10650481B2 (en) 2016-03-24 2020-05-12 Fuji Xerox Co., Ltd. Image processing device, image processing method, and non-transitory computer readable medium for image processing
US10795725B2 (en) 2016-03-24 2020-10-06 Fuji Xerox Co., Ltd. Image processing device, image processing method, and non-transitory computer readable medium for image processing
WO2019053915A1 (en) 2017-09-15 2019-03-21 富士ゼロックス株式会社 Image processing device, image processing method, and image processing program
JP6891153B2 (en) 2018-09-18 2021-06-18 富士フイルムビジネスイノベーション株式会社 Image processing equipment, image processing method, and image processing program

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001318798A (en) * 2000-03-16 2001-11-16 Square Co Ltd Parallel object task engine, and parallel processing method
JP2005258920A (en) * 2004-03-12 2005-09-22 Fujitsu Ltd Multithread executing method, multithread execution program and multithread execution apparatus

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001318798A (en) * 2000-03-16 2001-11-16 Square Co Ltd Parallel object task engine, and parallel processing method
JP2005258920A (en) * 2004-03-12 2005-09-22 Fujitsu Ltd Multithread executing method, multithread execution program and multithread execution apparatus

Cited By (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8943084B2 (en) 1920-05-20 2015-01-27 International Business Machines Corporation Method, program, and system for converting part of graph data to data structure as an image of homomorphism
JP2008276547A (en) * 2007-04-27 2008-11-13 Toshiba Corp Program processing method and information processor
CN101887367A (en) * 2010-06-22 2010-11-17 天津大学 Multi-level parallel programming method
US8914391B2 (en) 2011-05-20 2014-12-16 International Business Machines Corporation Method, program, and system for converting part of graph data to data structure as an image of homomorphism
US9208590B2 (en) 2011-05-20 2015-12-08 International Business Machines Corporation Manipulation of an object as an image of a mapping of graph data
JP2019145065A (en) * 2018-02-21 2019-08-29 株式会社デンソー Parallelizing method, parallelizing tool, multi-core microcomputer and on-vehicle unit
JP7095513B2 (en) 2018-02-21 2022-07-05 株式会社デンソー Multi-core microcomputers and in-vehicle devices
CN109377177A (en) * 2018-10-18 2019-02-22 东软集团股份有限公司 Flow path processing method, device, equipment and computer readable storage medium
CN109377177B (en) * 2018-10-18 2020-12-01 东软集团股份有限公司 Flow processing method, device, equipment and computer readable storage medium
CN113076129A (en) * 2021-03-23 2021-07-06 成都安恒信息技术有限公司 Automatic checking and processing method for complex configuration dependency relationship
CN113076129B (en) * 2021-03-23 2023-11-28 成都安恒信息技术有限公司 Automatic checking and processing method for complex configuration dependency relationship
CN114816433A (en) * 2022-06-01 2022-07-29 携程旅游网络技术(上海)有限公司 Encoding method, system, device and medium in project based on asynchronous programming

Also Published As

Publication number Publication date
JP4965995B2 (en) 2012-07-04

Similar Documents

Publication Publication Date Title
JP4965995B2 (en) Program processing method, processing program, and information processing apparatus
US7882498B2 (en) Method, system, and program of a compiler to parallelize source code
US8255911B2 (en) System and method for selecting and assigning a basic module with a minimum transfer cost to thread
US20090313600A1 (en) Concurrent code generation
US9645802B2 (en) Technique for grouping instructions into independent strands
JP2011070256A (en) Debugger and program
US20090327669A1 (en) Information processing apparatus, program execution method, and storage medium
JP2009151645A (en) Parallel processor and program parallelizing device
US8266416B2 (en) Dynamic reconfiguration supporting method, dynamic reconfiguration supporting apparatus, and dynamic reconfiguration system
US20120047353A1 (en) System and Method Providing Run-Time Parallelization of Computer Software Accommodating Data Dependencies
JP2008276547A (en) Program processing method and information processor
CN113296788B (en) Instruction scheduling method, device, equipment and storage medium
JP2009080583A (en) Information processor, parallel processing optimization system, and program
WO2024222552A1 (en) Model compiling method and apparatus, and device and storage medium
WO2024109312A1 (en) Task scheduling execution method, and generation method and apparatus for task scheduling execution instruction
US20220300322A1 (en) Cascading of Graph Streaming Processors
JP5360506B2 (en) Multi-core programming system, method and program
US20230236878A1 (en) Efficiently launching tasks on a processor
US20110225400A1 (en) Device for Testing a Multitasking Computation Architecture and Corresponding Test Method
JP2015038646A (en) Information processing apparatus and information processing method
US20100223596A1 (en) Data processing device and method
US10606602B2 (en) Electronic apparatus, processor and control method including a compiler scheduling instructions to reduce unused input ports
CN114443139B (en) Method, system, device and medium for converting sequential code into parallel code
US20090276777A1 (en) Multiple Programs for Efficient State Transitions on Multi-Threaded Processors
JP7026563B2 (en) High-level synthesis method, high-level synthesis program, high-level synthesis device

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20091021

RD02 Notification of acceptance of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7422

Effective date: 20091021

RD04 Notification of resignation of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7424

Effective date: 20100630

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20111003

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20111129

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20120118

RD02 Notification of acceptance of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7422

Effective date: 20120118

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20120118

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20120306

A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20120330

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20150406

Year of fee payment: 3

LAPS Cancellation because of no payment of annual fees