JP6329734B2 - 出力変数の全導関数を使用した協調シミュレーションプロシージャ - Google Patents

出力変数の全導関数を使用した協調シミュレーションプロシージャ Download PDF

Info

Publication number
JP6329734B2
JP6329734B2 JP2013136884A JP2013136884A JP6329734B2 JP 6329734 B2 JP6329734 B2 JP 6329734B2 JP 2013136884 A JP2013136884 A JP 2013136884A JP 2013136884 A JP2013136884 A JP 2013136884A JP 6329734 B2 JP6329734 B2 JP 6329734B2
Authority
JP
Japan
Prior art keywords
derivative
processor
input
computer
output
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.)
Active
Application number
JP2013136884A
Other languages
English (en)
Other versions
JP2014026649A (ja
JP2014026649A5 (ja
Inventor
ベルスキー ウラジミール
ベルスキー ウラジミール
エドワード エンゲルマン ブルース
エドワード エンゲルマン ブルース
エルムクビスト ヒルディング
エルムクビスト ヒルディング
ローランド オルソン ハンス
ローランド オルソン ハンス
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.)
Dassault Systemes SE
Original Assignee
Dassault Systemes SE
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 Dassault Systemes SE filed Critical Dassault Systemes SE
Publication of JP2014026649A publication Critical patent/JP2014026649A/ja
Publication of JP2014026649A5 publication Critical patent/JP2014026649A5/ja
Application granted granted Critical
Publication of JP6329734B2 publication Critical patent/JP6329734B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/38Concurrent instruction execution, e.g. pipeline or look ahead
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F17/00Digital computing or data processing equipment or methods, specially adapted for specific functions
    • G06F17/10Complex mathematical operations
    • G06F17/11Complex mathematical operations for solving equations, e.g. nonlinear equations, general mathematical optimization problems
    • G06F17/13Differential equations
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F17/00Digital computing or data processing equipment or methods, specially adapted for specific functions
    • G06F17/10Complex mathematical operations
    • G06F17/16Matrix or vector computation, e.g. matrix-matrix or matrix-vector multiplication, matrix factorization
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F30/00Computer-aided design [CAD]
    • G06F30/20Design optimisation, verification or simulation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2111/00Details relating to CAD techniques
    • G06F2111/10Numerical modelling

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Mathematical Physics (AREA)
  • Computational Mathematics (AREA)
  • Mathematical Analysis (AREA)
  • Mathematical Optimization (AREA)
  • Pure & Applied Mathematics (AREA)
  • Data Mining & Analysis (AREA)
  • General Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Algebra (AREA)
  • Databases & Information Systems (AREA)
  • Operations Research (AREA)
  • Computer Hardware Design (AREA)
  • Evolutionary Computation (AREA)
  • Geometry (AREA)
  • Computing Systems (AREA)
  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)
  • Complex Calculations (AREA)
  • Testing And Monitoring For Control Systems (AREA)

Description

本明細書で説明する実施形態は、一般に、現実世界のオブジェクトのモデルのシミュレーションに使用する協調シミュレーション(co-simulation)の方法に関し、特に、そのようなシミュレーションの最中に、当該方法の並列実行を使用することに関する。
科学および工学は、問題を解決するために物理的システムのモデル化を必要とすることが多い。そして、物理的な見本を構築し、および頻繁に破壊する必要なしに、問題のモデルを解決することができる。しかしながら、複合的な多様な分野にわたるシステムを、複数のサブシステムモデルに分解する必要があり、そこでは様々な下位の問題が考察され、および解決される。用語「協調シミュレーション」は、一般に、結合された技術システムをシミュレーションするアプローチを言う。例えば、マスター/スレーブシステムでは、1つまたは複数のスレーブサブシステムは、下位の問題をシミュレートし、マスターシステムがシミュレーション全体を調整し、およびスレーブサブシステム間でデータを転送する。スレーブサブシステムを、シミュレーション中の特定のときに、データを通信するために「結合」することができる。
協調シミュレーション問題に対処するための、少なくとも一部の公知のプロセスは、出力変数、または出力変数の何らかの組合せを、「ランデブー(rendezvous)」すなわち「通信」時に、1つのサブシステムから別のサブシステムに入力変数として転送し、それと同時またはそれより前の時に、逆方向の転送を行う、特定の規則を確立することに基づく。そのようなプロセスの安定性は、サブシステム自体の堅牢性(stiffness)に対する結合条件がどの程度強いかに依存する。一般に、そのようなプロセスは、サブシステムが特定の順序で処理されることを必要とする。しかしながら、その要件は、個々のサブシステムおよび結合条件の数値的特性の知識が必要となる。このことは、汎用的な協調シミュレーションプロシージャを構築し、種々の問題を分析するのに使用することの妨げとなる。さらに、協調シミュレーション計算プロシージャを並行させることができないため、そのような要件により、モデル全体を分析する際の性能が大幅に低下する可能性がある。
他のより高度なプロセスは、結合微分代数方程式に適用することができる、安定化したモジュール式の時間積分のアプローチを利用することにより、協調シミュレーション技術の安定性および精度の問題に対処している。そのようなプロセスは、入力変数と出力変数との間の代数方程式に対応するヤコビ行列を使用することに基づく。システムに代数ループが存在する場合、公知の協調シミュレーションプロセスは計算的に不安定になる可能性がある。例えば、明示的に依存している第1のサブシステムの入力変数と第2のサブシステムの出力変数とのペアについて、第2のサブシステムの入力変数も明示的に第1のサブシステムの出力変数に依存する場合に、このことが発生する。そのような場合には、代数変数に対する反復プロセスを使用して、安定性を向上させることもある。
代数ループを含まないシステムに対し、非反復的な線形陰的な安定化プロセスによって、通信の時点における入力変数および出力変数の増分間に特定の通信の系統を確立することが可能になる。各サブシステムに対する通信点間では、出力変数および状態変数の線形陰的な挙動が想定されることが多い。しかしながら、このアプローチは、特定のサブシステムの積分方式に対応するヤコビ行列の特定の乗算を、協調シミュレートされるサブシステム間で通信する必要がある。
さらに、公知のプロセスの中には、例えば構造動力学における問題を解決するために領域分割のアプローチを使用するものがある。そのようなプロセスは、サブシステム間のインタフェースで公開されるサブシステム行列の縮約されたコンポーネントを使用して、協調シミュレーションに対処する。そのような行列を、各サブシステムに対する時間積分方程式に基づいて構築する。
上記説明したアプローチは、出力変数および入力変数のみを通信点でのみ通信することを前提としたモジュール式のアプローチを使用し、それにより、協調シミュレーションプロセスが不安定になる可能性がある。また、それらのアプローチは、入力−出力関係の代数系に代数ループが存在するかどうかを検査する必要がある。さらに、それらのアプローチは、サブシステムを処理する順序に依存し、その結果協調シミュレーションプロセスを並行して実行することができない。
一態様では、コンピュータで実行される方法は、複数のサブシステムの各々について対応する第1の入力変数に関連する、出力導関数に基づいてヤコビ行列を算出するステップと、第1の入力変数を変更するステップと、対応する状態変数の導関数に基づいて、複数のサブシステムの各々に対する第2の入力変数および残差を算出するステップとを含む。
別の態様では、コンピュータは、メモリ領域、およびそのメモリ領域に結合されたプロセッサを含む。メモリ領域を、ヤコビ行列、出力導関数、複数のサブシステムの各々に対する第1および第2の入力変数、複数のサブシステムの各々に対する残差、ならびに第1の入力変数に対応する状態変数の導関数および残差、を記憶するように構成する。プロセッサを、メモリ領域と通信して、複数のサブシステムの各々について対応する第1の入力変数に関連する出力導関数に基づいてヤコビ行列を算出し、第1の入力変数を変更し、および対応する状態変数の導関数に基づいて、複数のサブシステムの各々に対する第2の入力変数および残差を算出するように構成する。
別の態様では、コンピュータプログラム製品は、コンピュータ実行可能コンポーネントを有する1つまたは複数の不揮発性コンピュータ可読記憶媒体を含む。コンピュータ実行可能コンポーネントは、プロセッサにより実行されると、プロセッサに、複数のサブシステムの各々に対数、対応する第1の入力変数に関連する出力導関数に基づいて、ヤコビ行列を算出させるヤコビ行列コンポーネントを含む。当該コンポーネントは、プロセッサにより実行されると、プロセッサに第1の入力変数を修正させる修正コンポーネント、および、プロセッサにより実行されると、プロセッサに、対応する状態変数の導関数に基づいて、複数のサブシステムの各々に対する第2の入力変数および残差を算出させる第2の導関数コンポーネントも含む。
本発明の1つまたは複数の実施形態の詳細を、添付図面および以下の説明で述べる。本発明の他の特徴、目的、および利点は、以下の説明、図面、および特許請求の範囲から明らかになるであろう。
物理的オブジェクトのモデルをシミュレーションする際に使用する、例示的なコンピュータで実行される方法を示すフローチャートである。 図1に示す方法により使用する例示的なコンピュータネットワークの概略ブロック図である。 図1に示す方法により使用する例示的なコンピュータアーキテクチャの概略ブロック図である。
3次元オブジェクトのモデルをシミュレートする際に使用するシステム、方法、装置(コンピュータ)、およびコンピュータプログラム製品の例示的な実施形態を本明細書で説明する。本明細書で説明する実施形態は、いくつかのサブシステムを備え、および全体システムが必然的にいくつかのサブシステムに分解されるモジュール方式により実行されることが多い、複合工学システムの動的挙動をシミュレートすることを容易にする。このアプローチの結果として、各サブシステムをモデル化するのに使用される種々のソフトウェアコンポーネント間の情報交換をする手段により、各個々のサブシステムをモデル化し、およびそれぞれ別個に、さらには並行して分析することができる。そのようなシステムの例は、異なる工学分野(異なる物理学)、例えば機械工学、制御光学、電子工学、水力工学等を意味し得る複数のコンポーネントのモデル化を必要とする、高精度工作機械または最新の自動車などがある。特に、本明細書で説明する実施形態は、全ヤコビ行列の適切な成分のやりとりを容易にする。そのようなヤコビ行列は、入力に関する出力変数の偏導関数を含み、それにより直接的な出力−入力間の依存関係を表す。また、ヤコビ行列は、状態変数を介した出力−入力間の依存関係に関連する導関数を含み、それにより間接的な出力−入力間の依存関係を表す。さらに、本明細書で説明する実施形態は、代数ループの存在に対する検査の必要性を排除し、および入力増分を更新するために使用することができる、改良した全体システムのヤコビ行列を提供する。加えて、本明細書で説明する実施形態は、個々のサブシステムの並列時間積分を容易にし、それにより、モデルのシミュレーションおよび解析全体の性能を向上させる。
図1は、いくつかのサブシステムを備える複合工学システムの動的挙動をシミュレートする際に使用する例示的なコンピュータで実行される方法を示すフローチャート100である。上記説明したように、協調シミュレーションプロセスは、いくつかの時間依存のシミュレーションが、「ランデブー」すなわち「通信」時点t間に独立して進行するプロセスの1つであり、n=0,1,...nであり、nは協調シミュレーションステップの総数である。各通信点において、個々のサブシステムのシミュレーション間で情報の交換が発生する。全協調シミュレーションプロセスは、最初の時間tstart=tから終了時間
Figure 0006329734
まで進行する。その結果として、一部の実施形態では、tとtn+1との間の任意の点において、個々のサブシステムのシミュレーション間のデータ交換がない。しかしながら、そのような実施形態では、Δtn+1=tn+1−tの間の協調シミュレーションの時間ステップが同じであることが前提とされない。さらに、一部の実施形態では、各個々のサブシステムのシミュレーションの挙動を、式(1)および(2)に示すように常微分方程式により記述する。
Figure 0006329734
Figure 0006329734
(t)は、i番目のサブシステムの状態変数を表し、uおよびyはそれぞれ同一のサブシステムに対する入力変数および出力変数を表し、およびr≧2は、協調シミュレーションプロセスにおけるサブシステムの数である。
2つ以上のサブシステムを結合することは、式(3)に示すように、線形または非線形代数入力−出力関係によって決定される。
Figure 0006329734
例えば、サブシステムが2つの場合は、結合方程式は式(4)に示すように記述することができる。
Figure 0006329734
通信点間で入力のすべてが線形であると仮定すると、式(5)になる。
Figure 0006329734
時間tn+1におけるすべての個々のサブシステムに対する状態変数および出力変数は、式(6)に示すように近似してもよい。
Figure 0006329734
特に、変数
Figure 0006329734
および
Figure 0006329734
は、常に各シミュレーション時間のステップの開始時に利用可能である。そのステップの終了時における入力変数の近似値
Figure 0006329734
が公知であるとき、式(7)に示すように入力変数の増分
Figure 0006329734
が線形方程式の系の解から求められる。
Figure 0006329734
Jは、入力−出力関係の全結合ヤコビ行列であり、式(8)のように表す。
Figure 0006329734
ここで、hは入力−出力関係の現在の残差であり、式(9)のように表される。
Figure 0006329734
上記式に基づいて、各個々のサブシステムのシミュレーションjは、その入力
Figure 0006329734
に関する自身の出力の全導関数を供給することが明らかであり、当該入力は、状態変数の対応する導関数からの寄与分を含み、および個々の協調シミュレーションステップの開始において算出される。
Figure 0006329734
を多数の方法で近似させることができる。2つの方法を説明するが、当業者は他の方法を使用してもよいことを理解されよう。本明細書で説明する2つの方法は、導関数を近似させる方法の適用に依拠する。
Figure 0006329734
を近似させる第1の方法は、式(10)に示すように差分商を使用することである。
Figure 0006329734
εは適切な小数であり、eはm番目の単位ベクトルである。各行列
Figure 0006329734
の列の次元は、対応する入力変数uのベクトルの次元に等しい。
Figure 0006329734
を近似させる第2の方法は、線形化系に対する行列指数関数のパデ近似を使用することである。具体的には、(2,1)のパデ近似の結果は式(11)になる。
Figure 0006329734
より高次のパデ近似を使用してもよいことが理解されよう。この近似を、直接算出することができ、または、サブシステムjのシミュレーションと組み合わせてもよい。後者の理由は、各サブシステムの陰的積分方法も、およそ
Figure 0006329734
であるためである。さらに一部の実施形態は、この行列をヘッセンベルグ(Hessenberg)形式に変換して、可変ステップサイズによるサブシステムの積分をより効率的に処理し、それにより、任意の行列γおよび任意の非ゼロのスカラーα,βについて
Figure 0006329734
を解く際の速度が向上する。
本明細書で説明する実施形態の1つの効果は、互いに完全に独立し、および各個々のサブシステムのシミュレーションプロセスで並行して算出するこれらの導関数を使用することである。状態変数、当該状態変数の導関数、および、通信点間で積分を実行する各個々のサブシステムのシミュレーションプロセスで使用されるアルゴリズムは、完全に各プロセスの内部にあり、もしくは各プロセス内に局所化され、および他のサブシステムのシミュレーションプロセス、もしくは全体すなわちマスターの協調シミュレーションドライバからは見ることができない。各サブシステムのシミュレーションプロセスにより提供される唯一の可視的な数量であって、ヤコビ行列の算出に必要な数量は、各現在の協調シミュレーションの時間増分の終了時における入力変数の予測値に対して計算された入力に対するサブシステムのシミュレーションプロセス出力の全導関数である。全体のヤコビ行列を、結合方程式におけるすべての他の出力の関数として、各入力の偏導関数を使用して構築し、または算出し、当該結合方程式は主として、代数式および個々の出力導関数で表される。
さらに、所与の協調シミュレーションの時間増分tn+1の終了時におけるすべてのサブシステムのシミュレーションプロセスに対するすべての入力変数の最終値を、反復プロセスの結果として判定する。反復kの毎に、上記提示した線形方程式の系の解として入力増分を判定する。主として、ヤコビ行列を、協調シミュレーションの時間増分につき1度のみ算出し、および因数分解するのに対して、全体の残差ベクトルを、式(12)における更新された入力変数に基づいて反復の毎に再計算する。
Figure 0006329734
例示的実施形態では、全体の残差ベクトルの最初の近似を、予測子を使用して各サブシステムプロセスに対して判定する。1つの予測子を式(13)に表す。
Figure 0006329734
一部の実施形態では、単一の反復のみを実行して、個々のサブシステムのシミュレーションプロセスのすべてについての入力増分を判定する。しかしながら、例示的実施形態では、何回かの非線形の反復を実行して、性能を犠牲にすることなく精度の向上を促進する。
本明細書で説明する実施形態の別の効果は、残差の計算のために各個々のサブシステムのシミュレーションプロセス内の残差算出のための時間積分プロセスがないことである。代わりに、対応する入力
Figure 0006329734
に関する個々の状態変数の導関数を、各個々のサブシステムのシミュレーションプロセスにより算出し、および記憶する。したがって、更新した状態変数および出力変数を、式(14)に基づいて近似させる。
Figure 0006329734
例示的実施形態では、式(14)を、式(15)に示す常微分方程式の厳密解に基づいて、より効率的に計算する。
Figure 0006329734
特に、式(15)では、隣り合う通信時点間で状態変数の線形挙動の想定の下で得られる解とは異なる解が得られる。
入力−出力関係の非線形系に対する反復プロセスが完了した後に、入力変数
Figure 0006329734
の最終値を判定し、および各個々のサブシステムのシミュレーションプロセスに対する修正子の積分が算出して、所与の協調シミュレーションの時間増分についての積分プロセスを完了する。これらの計算は互いに独立しており、したがって並行して実行することができる。この計算を式(16)および(17)に示す。
Figure 0006329734
Figure 0006329734
ここで図1を参照すると、複数のシミュレーションサブシステムにわたって単一の協調シミュレーション時間増分を行う処理ステップを示す。本明細書で使用されるように、用語「予測子」は、操作または変更される値を表す独立変数を意味する。予測子−修正子法は、2ステップに進行する。初めに、予測ステップは所望の数量の大まかな近似を計算する。2番目に、修正子ステップは別の手段を使用して初期の近似を精緻化する。例示的な実施形態では、単一の協調シミュレーション増分は、対応する予測子を使用してすべてのサブシステムに対する入力増分および残差の第1の集合を算出する(102)ことにより開始する。次に、各サブシステムについて対応する入力変数の第1の集合に関連する出力導関数に基づいて、ヤコビ行列を算出する(104)。より具体的には、サブシステムについて対応する入力変数の第1の集合に関連する出力導関数を算出し(106)、ヤコビ行列を構築し(108)、ヤコビ行列を因数分解する(110)。
例示的実施形態では、そのヤコビ行列を使用して入力変数を変更する(112)。より具体的には、残差を集め(114)、因数分解したヤコビ行列に基づいて入力増分を算出する。次に、対応する状態変数の導関数に基づいて、各サブシステムに対する入力変数の第2の集合および残差の第2の集合を算出する(116)。対応する修正子に基づいて、各サブシステムに対する最終出力を算出し(118)、および関連するデータをメモリ領域に記憶する(120)。tn+1<tfinishのときに、後続の時間増分が必要な場合は、プロセスは、後続の時間ステップ上で対応する予測子を使用したすべてのサブシステムに対する入力増分および残差の算出102から再度開始する。
図2は、いくつかのサブシステムを備える複合工学システムの動的挙動のシミュレーションで使用するため、おおび/または上記のプロセスおよび/または上記プロセスに関連し得る追加的プロセスを実行する際に使用するための例示的コンピュータネットワーク200の概略ブロック図である。例示的実施形態では、メモリ領域202は、入力増分、残差、予測子、出力導関数、1つまたは複数のヤコビ行列、状態変数の導関数、最終的なシステム出力、修正子、または他の適当なデータなどのデータを記憶するのに使用する1つまたは複数の記憶装置204を含む。一部の実施形態では、メモリ領域202をサーバシステム206に結合し、サーバシステム206は、ネットワーク210を介して管理者システムおよび/またはユーザシステムなどのクライアントシステム208に結合する。記憶装置204は、1つもしくは複数のデータベースとして実施してもよく、1つもしくは複数の地理的場所に配置してもよく、またはサーバシステム206に統合してもよい。
理解できるように、ネットワーク210は、インターネットなどの公衆ネットワーク、LANやWANネットワークなどの私設ネットワーク、またはそれらの組合せとすることができ、およびPSTNもしくはISDNのサブネットワークを含むこともできる。ネットワーク210はまた、イーサネット(登録商標)ネットワークなど有線であることもでき、またはEDGE、3G、および4G無線セルラシステムを含むセルラネットワークなどの無線であることもできる。無線ネットワークはまた、WiFi、Bluetooth(登録商標)、または他の公知の無線形態の通信とすることができる。したがって、ネットワーク210は例示に過ぎず、および本発明の範囲を限定するものではない。
クライアントシステム208は、下記で図3を参照して説明するものなどの適切なコンピュータアーキテクチャ、または公知の他のコンピューティングアーキテクチャとすることができる。さらに、サーバシステム206を、上記のプロセスおよび/または上記プロセスに関連し得る追加的なプロセスを実行するように構成することが理解されよう。
サーバシステム206は、上記プロセスを実行するコンピュータ可読命令を記憶し、およびそれらの命令を、ネットワーク210を介してクライアントシステム208に提供する。さらに、サーバシステム206はまた、必要に応じてメモリ領域202からクライアントシステム208にデータを提供することができ、それによってクライアントシステム208は上記のプロセスを実行することができる。そのため、図2は、クラウドコンピューティングおよび分散コンピューティングなどを介したコンピュータシステム200の実装を含む。
演算中に、サーバシステム206およびクライアントシステム208は対話して、上記図1で説明したステップを実行する。例えば、サーバシステム206は、対応する予測子を使用して、すべてのサブシステムに対する入力増分および第1の残差の集合を算出することにより、単一の協調シミュレーション増分内の演算を実行する。そして、サーバシステム206は、各サブシステムについて対応する第1の入力変数の集合に関連する出力導関数に基づいて、ヤコビ行列を算出する。より具体的には、サブシステムごとに、入力変数の対応する第1の集合に関連する出力導関数を、対応する状態変数の導関数に基づいて算出し、ヤコビ行列を構築し、およびヤコビ行列を因数分解する。さらに、例示的実施形態では、サーバシステム206は、因数分解したヤコビ行列を使用して、入力変数の第1の集合を変更する。より具体的には、因数分解したヤコビ行列に基づいて、残差の第1の集合を集め、および入力増分を算出する。次いでサーバシステム206は、対応する状態変数の導関数に基づいて、各サブシステムに対する入力変数の第2の集合と残差の第2の集合を算出する。サーバシステム206はまた、対応する修正子に基づいて各サブシステムの最終出力を算出し、およびそのデータをメモリ領域202に記憶する。サーバシステム206はまた、最終出力および/またはデータをユーザに表示するために、1つまたは複数のクライアントシステム208に送信してもよい。
図3は、サーバシステム206および/またはクライアントシステム208(それぞれ図2に示す)で使用するための例示的コンピュータアーキテクチャ300の概略ブロック図である。
例示的実施形態では、コンピュータアーキテクチャ300は、上記のプロセスおよび/または上記プロセスに関連し得る追加的プロセスを実行する、1つまたは複数のプロセッサ302(CPU)を含む。用語「プロセッサ」は、一般に、システムおよびマイクロコントローラ、縮小命令セット回路(RISC)、特定用途集積回路(ASIC)、プログラマブル論理回路、および/または本明細書で説明する機能を実行することが可能な他の回路もしくはプロセッサを含むプログラム可能なシステムを指すことが理解されよう。上記の例は例示に過ぎず、したがって、用語「プロセッサ」の定義および/または意味を限定するものではない。
上記のプロセスおよび/または上記プロセスに関連し得る追加的プロセスのステップを、コンピュータ実行可能命令として、例えば、システムバス306によりプロセッサ302に動作可能にかつ/または通信可能に結合されたメモリ領域304に記憶してもよい。本明細書で使用する「メモリ領域」は、一般に、いくつかのサブシステムを備える複合工学システムの動的挙動のシミュレーションを支援するために、および/または上記のプロセスおよび/または上記プロセスに関連し得る追加的プロセスを実行する際に使用するために、1つまたは複数のプロセッサにより実行可能な非一時的プログラムコードおよび命令を記憶する任意の手段を指す。メモリ領域304は、1つまたは複数の形態のメモリを含んでもよい。例えば、メモリ領域304はランダムアクセスメモリ(RAM)308を含んでもよく、RAM308は、不揮発性RAM、磁気RAM、強誘電体RAM、および/または他の形態のRAMを含むことができる。メモリ領域304はまた、リードオンリメモリ(ROM)310、フラッシュメモリおよび/または電気的消去可能ROM(EEPROM)を含むことができる。ハードディスクドライブ(HDD)312などの他の適切な磁気、光学、および/または半導体メモリを、単独で、または他の形態のメモリと組み合わせて、メモリ領域304に含めることができる。HDD312を、プロセッサ302との間でメッセージを送受信するために使用されるディスクコントローラ314にも結合してもよい。さらに、メモリ領域304は、適切なカートリッジディスク、CD−ROM、DVD、またはUSBメモリなどの取外可能もしくは着脱可能メモリ316であってもよく、またはそのようなメモリを含むことができる。上記の例は例示に過ぎず、したがって、用語「メモリ領域」の定義および/または意味を限定するものではない。
コンピュータアーキテクチャ300はまた、ディスプレイコントローラ320に動作可能に結合される等して結合された表示装置318を含む。ディスプレイコントローラ320は、表示装置318により表示するためのデータを、システムバス306を介して受信する。表示装置318は、モニタ、テレビディスプレイ、プラズマディスプレイ、液晶ディスプレイ(LCD)、発光ダイオード(LED)に基づくディスプレイ、有機LED(OLED)に基づくディスプレイ、高分子LEDに基づくディスプレイ、表面伝導電子エミッタに基づくディスプレイ、投影像および/または反射像を含むディスプレイ、または任意の他の適切な電子機器もしくは表示機構とすることができる。さらに、表示装置318は、関連するタッチスクリーンコントローラ320を備えるタッチスクリーンを含んでもよい。上記の例は例示に過ぎず、したがって用語「表示装置」の定義および/または意味を決して限定するものではない。
加えて、コンピュータアーキテクチャ300は、ネットワーク(図3には図示せず)と通信する際に使用するネットワークインタフェース322を含む。さらに、コンピュータアーキテクチャ300は、キーボード324および/またはローラーボール、マウス、タッチパッドなどのポインティングデバイス326などの1つまたは複数の入力装置を含む。入力装置は、入力/出力(I/O)インタフェース328に結合され、入力/出力(I/O)インタフェース328によって制御され、入力/出力(I/O)インタフェース328はさらにシステムバス306に結合される。
表示装置318、キーボード324、ポインティングデバイス326、ならびにディスプレイコントローラ320、ディスクコントローラ314、ネットワークインタフェース322、およびI/Oインタフェース328の特徴は公知であるため、それらの一般的な特徴および機能の説明は簡略のために本明細書では省略する。
演算中、プロセッサ302は、上記図1で説明したステップを実行する。例えば、プロセッサ302は、対応する予測子を使用して、すべてのサブシステムに対する入力増分および残差の第1の集合を算出することにより、単一の協調シミュレーション増分内の演算を実行する。そして、プロセッサ302は、各サブシステムについて、入力変数の対応する第1の集合に関連する出力導関数に基づいてヤコビ行列を算出する。より具体的には、各サブシステムについて、対応する状態変数の導関数に基づいて、入力変数の対応する第1の集合に関連する出力導関数を算出し、ヤコビ行列を構築し、およびヤコビ行列を因数分解する。さらに、例示的実施形態では、プロセッサ302は、因数分解したヤコビ行列を使用して、入力変数の第1の集合を変更する。より具体的には、残差の第1の集合を集め、因数分解したヤコビ行列に基づいて入力増分を算出する。プロセッサ302は、次いで、対応する状態変数の導関数に基づいて、各サブシステムに対する入力変数の第2の集合および残差の第2の集合を算出する。プロセッサ302はまた、対応する修正子に基づいて各サブシステムに対する最終出力を算出し、およびそのデータをメモリ領域304に記憶する。プロセッサ302はまた、表示装置318を介してユーザに表示するために最終出力および/またはデータをディスプレイコントローラ320に送信してもよい。
いくつかのサブシステムを備える複合工学システムの動的挙動をシミュレートするのに使用する方法、システム、装置、およびコンピュータプログラム製品の例示的実施形態について上記で詳細に説明した。それらの方法、システム、装置、およびコンピュータプログラム製品は、本明細書で説明した特定の実施形態に限定されず、方法の動作の一部ならびに/またはシステムおよび/もしくは装置のコンポーネントを、本明細書で説明した他の動作および/またはコンポーネントとは独立して別個に利用してもよい。しかしながら、一部の実施形態では、上記で説明した方法の動作の順番ならびに/またはシステムおよび/もしくは装置のコンポーネントの使用が正確な動作のために必要となる。さらに、本明細書で説明した動作および/またはコンポーネントを、他のシステム、方法、および/または装置と組み合わせて定義し、または使用してもよく、ならびに本明細書で説明したシステム、方法、および記憶媒体のみによる実施に限定されない。
本明細書に説明したものなどのクライアントコンピュータおよびサーバは、少なくとも1つのプロセッサまたは処理装置と、システムメモリとを含む。クライアントコンピュータおよびサーバは、主として、少なくとも何らかの形態のコンピュータ可読媒体を有する。限定ではなく例として、コンピュータ可読媒体は、コンピュータ記憶媒体および通信媒体を含む。コンピュータ記憶媒体は、コンピュータ可読命令、データ構造、プログラムモジュール、または他のデータなどの情報を記憶するための任意の方法または技術で実装された揮発性および不揮発性、着脱可能媒体および着脱不能媒体を含む。通信媒体は、主として、コンピュータ可読命令、データ構造、プログラムモジュール、または他のデータを、搬送波などの変調データ信号または他の搬送メカニズムとして具現化し、および任意の情報伝達媒体を含む。当業者は、信号における情報を符号化するような方式で、特性の1つまたは複数を設定または変化させた変調データ信号に精通している。上記媒体の組合せもコンピュータ可読媒体の範囲に含まれる。
本発明を、例示的シミュレーションシステム環境と関連して説明したが、本発明の実施形態は、多数の他の汎用シミュレーションシステム環境もしくは構成、または専用シミュレーションシステム環境もしくは構成により動作可能である。上記シミュレーションシステム環境は、本発明の態様の使用または機能の範囲に関して何らの制限を示唆するものではない。さらに、上記シミュレーションシステム環境は、例示的動作環境に示されるコンポーネントのいずれか1つまたは組合せに関連する依存性または要件を有するものと解釈すべきでない。本発明の態様による使用に適する公知のシミュレーションシステム、環境、および/または構成の例は、パーソナルコンピュータ、サーバコンピュータ、ハンドヘルドまたはラップトップ機器、マルチプロセッサシステム、マイクロプロセッサを利用したシステム、セットトップボックス、プログラミング可能な家庭用電化製品、携帯電話、ネットワークPC、ミニコンピュータ、メインフレームコンピュータ、上記システムもしくは機器のいずれかを含む分散コンピューティング環境等を含むが、これらに限定されない。
本発明の実施形態を、1つまたは複数のコンピュータまたは他の機器によって実行されるプログラムコンポーネントやモジュール等のコンピュータ実行可能命令の一般的なコンテキストにおいて説明してもよい。本発明の態様を、任意の数および構成のコンポーネントまたはモジュールによって実装してもよい。例えば、本発明の態様は、図に示され、本明細書で説明される特定のコンピュータ実行可能命令または特定のコンポーネントもしくはモジュールに限定されない。本発明の代替実施形態を、図に示し、本明細書で説明されるよりも多い、または少ない機能を有する種々のコンピュータ実行可能命令またはコンポーネントを含んでもよい。
例示的なコンピュータプログラム製品は、例えば、コンピュータ実行可能コンポーネントを有する1つまたは複数の非一時的なコンピュータ可読記憶媒体を含む。コンピュータ実行可能コンポーネントは、プロセッサ302(図3に示す)またはサーバシステム206のプロセッサ(図2に示す)などのプロセッサに実行されると、プロセッサに、物理的オブジェクトを表すマスターシステムの複数のサブシステムの各々に対し、入力変数の第1の集合からの対応する入力変数に関連する出力導関数に基づいて、ヤコビ行列を算出させるヤコビ行列コンポーネントを含む。一部の実施形態では、ヤコビ行列コンポーネントはさらに、プロセッサにヤコビ行列を因数分解させる。さらに、一部の実施形態では、ヤコビ行列コンポーネントはさらに、プロセッサに、残差の第1の集合を集めさせ、入力変数の第2の集合を算出するために、因数分解したヤコビ行列に基づいて、入力増分を算出させる。
例示的実施形態では、コンピュータ実行可能コンポーネントは、プロセッサに入力変数の第1の集合を変更させる変更コンポーネントも含む。さらに、例示的実施形態では、コンピュータ実行可能コンポーネントは、プロセッサに、対応する状態変数の導関数に基づいて、複数のサブシステムの各々に入力変数の第2の集合および残差の第2の集合を算出させる第2の導関数コンポーネントを含む。一部の実施形態では、残差が、残差の第2の集合であるとき、第2の導関数コンポーネントは、プロセッサに、対応する予測子に基づいて、複数のサブシステムの各々の入力増分および残差の第1の集合を算出させる。
一部の実施形態では、コンピュータ実行可能コンポーネントは、プロセッサに、複数のサブシステムの各々について、対応する入力変数の第1の集合に関連する出力導関数を算出させて、ヤコビ行列の算出を容易にする第1の導関数コンポーネントも含む。さらに、一部の実施形態では、コンピュータ実行可能コンポーネントは、プロセッサに、対応する修正子に基づいて複数のサブシステムの各々の出力を算出させる出力コンポーネントを含む。そのような実施形態では、出力コンポーネントはまた、プロセッサに、ヤコビ行列、出力導関数、第1の入力変数、第2の入力変数、残差、および出力、の1つまたは複数をメモリ領域に記憶させる。
図示し、本明細書で説明した本発明の実施形態における動作の実行または演算の順序は、特に指定しない限り必須ではない。すなわち、演算は特に指定しない限り任意の順序で実行してもよく、および本発明の実施形態は、追加的な演算または本明細書に開示されるよりも少ない演算を含むことができる。例えば、特定の演算を、別の演算よりも前、同時、または後に実行または実施することは、本発明の態様の範囲内にあることが企図される。
本発明の態様またはその実施形態の要素を紹介するときに、冠詞「a」、「an」、「the」、および「前記(said)」は、その要素が1つまたは複数あることを意味するものである。用語「〜を備える(comprising)」「〜を含む(including)」、および「〜を有する」は包含的な意味であり、列記される要素以外に追加的な要素があってよいことを意味する。
この書面による説明は、例を使用して最良の形態を含む本発明を開示し、および当業者が、任意の機器またはシステムを作製および使用し、それに組み込まれる方法を実行することを含めて、本発明を実施することを可能にする。本発明の特許可能な範囲を、特許請求の範囲により定義し、および当業者に想到される他の例を含む。そのような他の例は、特許請求の範囲の字句通りの文言と異ならない構造的要素を有する場合、または特許請求の範囲の字句通りの文言とわずかに異なる均等の構造的要素を含む場合には、特許請求の範囲にあるものとする。

Claims (14)

  1. コンピュータにより実行される方法であって、
    出力導関数に基づいてヤコビ行列を算出するステップであって、前記出力導関数は、複数のサブシステムの各々について対応する入力変数に関連する、対応する状態変数の導関数に基づく、ステップと、
    時間増分ごとに、
    前記複数のサブシステムの各々について入力増分および残差を算出するステップであって、前記入力増分を算出することは、対応する状態変数の導関数に基づく、ステップと、
    前記算出した入力増分に基づいて、前記入力変数を変更するステップと
    を備えることを特徴とするコンピュータにより実行される方法。
  2. 対応する予測子に基づいて、前記複数のサブシステムの各々についての初期入力増分および初期残差を算出するステップをさらに備えることを特徴とする請求項1に記載のコンピュータにより実行される方法。
  3. ヤコビ行列を算出するステップは、前記複数のサブシステムの各々について前記対応する入力変数に関連する、前記対応する状態変数の導関数に基づいて、前記出力導関数を算出するステップを含むことを特徴とする請求項1に記載のコンピュータにより実行される方法。
  4. ヤコビ行列を算出するステップは、前記ヤコビ行列を因数分解するステップを含むことを特徴とする請求項1に記載のコンピュータにより実行される方法。
  5. 前記入力増分を算出するステップは、
    前記残差を得ることと、
    前記因数分解したヤコビ行列に基づいて、前記入力増分を算出することと
    を含むことを特徴とする請求項4に記載のコンピュータにより実行される方法。
  6. 対応する修正子に基づいて、前記複数のサブシステムの各々についての出力を算出するステップをさらに備えることを特徴とする請求項1に記載のコンピュータにより実行される方法。
  7. コンピュータ実行可能コンポーネントを有するコンピュータプログラムであって、前記コンピュータ実行可能コンポーネントは、
    プロセッサにより実行されると、前記プロセッサに、出力導関数に基づいてヤコビ行列を算出させるヤコビ行列コンポーネントであって、前記出力導関数は、複数のサブシステムの各々について対応する入力変数に関連する、対応する状態変数の導関数に基づく、ヤコビ行列コンポーネントと、
    時間増分ごとに、
    プロセッサにより実行されると、前記プロセッサに、前記複数のサブシステムの各々についての入力増分および残差を算出させる第2の導関数コンポーネントであって、前記入力増分を算出することは、対応する状態変数の導関数に基づく、第2の導関数コンポーネントと、
    プロセッサにより実行されると、前記プロセッサに、前記算出した入力増分に基づいて、前記入力変数を変更させる変更コンポーネントと
    を備えることを特徴とするコンピュータプログラム。
  8. 前記第2の導関数コンポーネントはさらに前記プロセッサに、対応する予測子に基づいて前記複数のサブシステムの各々についての初期入力増分および初期残差を算出させることを特徴とする請求項7に記載のコンピュータプログラム。
  9. 前記コンピュータ実行可能コンポーネントは、プロセッサにより実行されると、前記プロセッサに、前記複数のサブシステムの各々について前記対応する入力変数に関連する、前記出力導関数を算出させて、前記ヤコビ行列の算出を容易にする第1の導関数コンポーネントをさらに含むことを特徴とする請求項7に記載のコンピュータプログラム。
  10. 前記ヤコビ行列コンポーネントはさらに、前記プロセッサに、前記ヤコビ行列を因数分解させることを特徴とする請求項7に記載のコンピュータプログラム。
  11. 前記第2の導関数コンポーネントはさらに、前記プロセッサに、
    前記残差を得させ、
    前記因数分解したヤコビ行列に基づいて前記入力増分を算出させることを特徴とする請求項10に記載のコンピュータプログラム。
  12. 前記コンピュータ実行可能コンポーネントは、プロセッサにより実行されると、前記プロセッサに、対応する修正子に基づいて前記複数のサブシステムの各々についての出力を算出させる出力コンポーネントをさらに含むことを特徴とする請求項7に記載のコンピュータプログラム。
  13. 前記出力コンポーネントはさらに、前記プロセッサに、前記ヤコビ行列、前記出力導関数、前記入力変数、前記残差、および前記出力、のうちの1つまたは複数をメモリ領域に記憶させることを特徴とする請求項12に記載のコンピュータプログラム。
  14. メモリと
    前記メモリに結合されたプロセッサと
    を備え、
    前記メモリは、請求項7乃至13のいずれか一項に記載のコンピュータプログラムを記憶したことを特徴とするコンピュータ。
JP2013136884A 2012-06-29 2013-06-28 出力変数の全導関数を使用した協調シミュレーションプロシージャ Active JP6329734B2 (ja)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US13/538,343 US9223754B2 (en) 2012-06-29 2012-06-29 Co-simulation procedures using full derivatives of output variables
US13/538,343 2012-06-29

Publications (3)

Publication Number Publication Date
JP2014026649A JP2014026649A (ja) 2014-02-06
JP2014026649A5 JP2014026649A5 (ja) 2016-08-04
JP6329734B2 true JP6329734B2 (ja) 2018-05-23

Family

ID=48703175

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2013136884A Active JP6329734B2 (ja) 2012-06-29 2013-06-28 出力変数の全導関数を使用した協調シミュレーションプロシージャ

Country Status (7)

Country Link
US (1) US9223754B2 (ja)
EP (1) EP2680157B1 (ja)
JP (1) JP6329734B2 (ja)
KR (1) KR20140002556A (ja)
CN (1) CN103530439B (ja)
CA (1) CA2819763A1 (ja)
IN (1) IN2013MU02122A (ja)

Families Citing this family (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10755003B2 (en) * 2013-11-08 2020-08-25 Rockwell Automation Technologies, Inc. Time synchronization of signal transmission intervals for simulating a machine in industrial automation
EP3136267A1 (en) 2015-08-25 2017-03-01 Volvo Car Corporation Method and system for control and co-simulation of physical systems
EP3188053A1 (de) * 2015-12-30 2017-07-05 Kompetenzzentrum - Das virtuelle Fahrzeug Forschungsgesellschaft mbH Verfahren zum konfigurieren einer co-simulation für ein gesamtsystem
CN107357976B (zh) * 2017-06-27 2020-12-11 四川腾盾科技有限公司 一种飞行器的动导数的计算方法
EP3579126A1 (en) * 2018-06-07 2019-12-11 Kompetenzzentrum - Das virtuelle Fahrzeug Forschungsgesellschaft mbH Co-simulation method and device
CN115718986B (zh) * 2022-10-31 2023-12-12 南方电网数字电网研究院有限公司 一种基于分布式内存架构的多核并行时域仿真方法
CN115758784B (zh) * 2022-11-30 2023-12-12 南方电网数字电网研究院有限公司 支撑电力系统时域仿真的大型雅各比矩阵低耗时迭代方法

Family Cites Families (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4918643A (en) * 1988-06-21 1990-04-17 At&T Bell Laboratories Method and apparatus for substantially improving the throughput of circuit simulators
SE9400579L (sv) * 1994-02-21 1995-08-22 Asea Brown Boveri Förfarande för att styra en industrirobots rörelse i och i närheten av singulariteter
JPH08147267A (ja) * 1994-11-25 1996-06-07 Sanyo Electric Co Ltd 連立方程式解法
US5629845A (en) * 1995-08-17 1997-05-13 Liniger; Werner Parallel computation of the response of a physical system
US7596474B2 (en) * 2000-08-02 2009-09-29 Comsol Ab Method for assembling the finite element discretization of arbitrary weak equations involving local or non-local multiphysics couplings
IL155719A0 (en) * 2000-11-02 2003-11-23 Protein Mechanics Inc Method for self-validation of molecular modeling
US7164800B2 (en) * 2003-02-19 2007-01-16 Eastman Kodak Company Method and system for constraint-consistent motion estimation
WO2007134598A1 (en) * 2006-05-24 2007-11-29 Maersk Olie & Gas A/S Flow simulation in a well or pipe
US7548840B2 (en) * 2006-06-06 2009-06-16 Chevron U.S.A. Inc. Efficient application of reduced variable transformation and conditional stability testing in reservoir simulation flash calculations
US7626534B1 (en) * 2007-06-12 2009-12-01 Lockheed Martin Corporation Unified navigation and inertial target tracking estimation system
US20090299929A1 (en) * 2008-05-30 2009-12-03 Robert Kozma Methods of improved learning in simultaneous recurrent neural networks
JP4988789B2 (ja) * 2009-05-19 2012-08-01 インターナショナル・ビジネス・マシーンズ・コーポレーション シミュレーション・システム、方法及びプログラム
US8271237B2 (en) * 2010-02-02 2012-09-18 Livermore Software Technology Corporation Fully-integrated hexahedral elements configured for reducing shear locking in finite element method
US8688616B2 (en) * 2010-06-14 2014-04-01 Blue Prism Technologies Pte. Ltd. High-dimensional data analysis
WO2012016596A1 (de) * 2010-08-05 2012-02-09 Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e. V. Vorrichtung und verfahren zum bearbeiten einer prozesssimulationsdatenbasis eines prozesses
US8914262B2 (en) * 2011-11-08 2014-12-16 The Mathworks, Inc. Visualization of data dependency in graphical models
US9002692B2 (en) * 2012-03-13 2015-04-07 Synopsys, Inc. Electronic circuit simulation method with adaptive iteration

Also Published As

Publication number Publication date
US20140005989A1 (en) 2014-01-02
EP2680157B1 (en) 2023-08-09
KR20140002556A (ko) 2014-01-08
CA2819763A1 (en) 2013-12-29
CN103530439B (zh) 2018-01-02
US9223754B2 (en) 2015-12-29
EP2680157A1 (en) 2014-01-01
JP2014026649A (ja) 2014-02-06
CN103530439A (zh) 2014-01-22
IN2013MU02122A (ja) 2015-07-10

Similar Documents

Publication Publication Date Title
JP6329734B2 (ja) 出力変数の全導関数を使用した協調シミュレーションプロシージャ
CN107016154B (zh) 用于对结构动力学系统的机械特征进行建模的方法和系统
CN103106182B (zh) 使用自动多级子结构化生成子结构
Ramos Linearization techniques for singular initial-value problems of ordinary differential equations
Haut et al. An asymptotic parallel-in-time method for highly oscillatory PDEs
Li et al. Adjoint sensitivity analysis for time-dependent partial differential equations with adaptive mesh refinement
Prebeg et al. Application of a surrogate modeling to the ship structural design
Rico-Martınez et al. Coarse projective kMC integration: forward/reverse initial and boundary value problems
US10853535B2 (en) Accelerated algorithm for modal frequency response calculation
Birken et al. Preconditioning for modal discontinuous Galerkin methods for unsteady 3D Navier–Stokes equations
CN115427981A (zh) 用于分子和旋转系统的量子模拟的方法和系统
US10255386B2 (en) Space exploration with quantitative pruning and ranking system and method
US10282498B2 (en) Processor-implemented systems and methods for time domain decomposition transient simulation in parallel
Engsig-Karup et al. Fast hydrodynamics on heterogenous many-core hardware
Fidkowski A hybridized discontinuous Galerkin method on mapped deforming domains
Cotter et al. Embedded discontinuous Galerkin transport schemes with localised limiters
Rossinelli et al. Vortex methods for incompressible flow simulations on the GPU
Southworth et al. Implicit-explicit Runge-Kutta for radiation hydrodynamics I: gray diffusion
US10599879B2 (en) Optimal pressure-projection method for incompressible transient and steady-state navier-stokes equations
Rao et al. An adjoint-based scalable algorithm for time-parallel integration
Abide et al. Multigrid defect correction and fourth-order compact scheme for Poisson’s equation
US11475184B1 (en) Real-time finite element method solving for contact on cartesian grids with level-set geometry description
Bergamaschi et al. Parallel matrix-free polynomial preconditioners with application to flow simulations in discrete fracture networks
Dutta et al. MicroSim: A high-performance phase-field solver based on CPU and GPU implementations
Zhu et al. Error estimates for approximations of a gradient dynamics for phase field elastic bending energy of vesicle membrane deformation

Legal Events

Date Code Title Description
A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20160617

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20160617

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20170419

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20170613

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20170908

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20180227

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20180329

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: 20180403

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20180423

R150 Certificate of patent or registration of utility model

Ref document number: 6329734

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250