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

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

▶ コミッサリア ア レネルジー アトミーク エ オ ゼネルジ ザルタナテイヴの特許一覧

<>
  • 特許-通信を形式的に監視するためのシステム 図1
  • 特許-通信を形式的に監視するためのシステム 図2
  • 特許-通信を形式的に監視するためのシステム 図3A
  • 特許-通信を形式的に監視するためのシステム 図3B
  • 特許-通信を形式的に監視するためのシステム 図3C
  • 特許-通信を形式的に監視するためのシステム 図4A
  • 特許-通信を形式的に監視するためのシステム 図4B
< >
(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-05-17
(45)【発行日】2024-05-27
(54)【発明の名称】通信を形式的に監視するためのシステム
(51)【国際特許分類】
   G06F 11/36 20060101AFI20240520BHJP
   G06F 8/10 20180101ALI20240520BHJP
【FI】
G06F11/36 108
G06F8/10
【請求項の数】 13
(21)【出願番号】P 2021535802
(86)(22)【出願日】2019-12-19
(65)【公表番号】
(43)【公表日】2022-02-24
(86)【国際出願番号】 FR2019053201
(87)【国際公開番号】W WO2020128363
(87)【国際公開日】2020-06-25
【審査請求日】2022-12-19
(31)【優先権主張番号】1873585
(32)【優先日】2018-12-20
(33)【優先権主張国・地域又は機関】FR
(73)【特許権者】
【識別番号】502124444
【氏名又は名称】コミッサリア ア レネルジー アトミーク エ オ ゼネルジ ザルタナテイヴ
(74)【代理人】
【識別番号】100108453
【弁理士】
【氏名又は名称】村山 靖彦
(74)【代理人】
【識別番号】100110364
【弁理士】
【氏名又は名称】実広 信哉
(74)【代理人】
【識別番号】100133400
【弁理士】
【氏名又は名称】阿部 達彦
(72)【発明者】
【氏名】ポール・デュブリュレ
【審査官】山本 俊介
(56)【参考文献】
【文献】特表2013-542474(JP,A)
【文献】特開2013-77048(JP,A)
【文献】国際公開第2011/096037(WO,A1)
【文献】国際公開第2016/151710(WO,A1)
【文献】特開2017-33562(JP,A)
【文献】米国特許出願公開第2015/0199249(US,A1)
(58)【調査した分野】(Int.Cl.,DB名)
G06F 11/36
G06F 8/10
(57)【特許請求の範囲】
【請求項1】
プラットフォームの具体的なアプリケーションのセットの通信を形式的に監視するためのシステムであって、
- 一方向通信チャネルを通じて、定量化可能な情報を相互に交換するアクタのセットを備えるデータストリームの形式モデルであって、前記形式モデルが、具体的なアプリケーションの前記セットをモデル化するアクタの前記セットの挙動を記述する、形式モデル、および、前記アクタによってモデル化された前記アプリケーションを実装するソフトウェア実装を記述する通信仕様であって、前記ソフトウェア実装が、前記プラットフォームのプログラミングインターフェースに関連するあらかじめ決定された通信機能を呼び出すように構成された、通信仕様を取得するように構成された取得モジュールと、
- 前記通信機能への呼出しのシーケンスが、アクタの前記セットの予期される挙動に従っていることを検証するように構成された監視モジュール(11)と
を備えることを特徴とする、システム。
【請求項2】
前記監視モジュール(11)が、アクタに対応するソフトウェア実装ごとにオートマトンを構築するように構成され、各オートマトンが、ある状態から別の状態への移行が、前記ソフトウェア実装から前記通信機能のうちの1つへの呼出しによってトリガされる状態のセットを備え、前記オートマトンが、前記通信機能への有効な呼出しシーケンスを追跡するために、前記形式モデルによって予期される挙動に依存していることを特徴とする、請求項1に記載のシステム。
【請求項3】
各オートマトンが、前記ソフトウェア実装の初期化に関連付けられる第1の部分と、前記ソフトウェア実装の動作に関連付けられる第2の部分とを備え、前記第1の部分の最終状態から前記第2の部分の初期状態への前記移行が、同期信号が前記ソフトウェア実装によって受信されたときにトリガされ、具体的なアプリケーションの実行を示すことを特徴とする、請求項2に記載のシステム。
【請求項4】
前記監視モジュール(11)が、通信機能への呼出しをキャプチャするように構成されたソフトウェア要素を生成することと、具体的なアプリケーションの実行時に行われる呼出しの前記シーケンスが前記オートマトンによって定義された前記シーケンスに対応することを確認することとを行うように構成されることを特徴とする、請求項2または3に記載のシステム。
【請求項5】
前記ソフトウェア要素が、前記通信機能ごとの拡張機能、入力データ期限管理機能、および現在のアクティベーション管理機能を備えることを特徴とする、請求項4に記載のシステム。
【請求項6】
前記通信仕様が、サービス指向実装の仕様であることを特徴とする、請求項1から5のいずれか一項に記載のシステム。
【請求項7】
前記通信機能が、サービス指向であり、サービス提供機能、インターフェース公開機能、公開インターフェースサブスクリプション機能、放出機能、受信機能、要求機能、およびインターフェース上の処理機能を備えることを特徴とする、請求項1から6のいずれか一項に記載のシステム。
【請求項8】
前記形式モデルが、前記アクタの前記実装に必要な構成データのセットを備えることを特徴とする、請求項1から7のいずれか一項に記載のシステム。
【請求項9】
前記構成データが、前記アクタごとに、予算、初期遅延、初期期限、入力期限、デフォルトの入力ポリシ、永続的/一時的インジケータ、および厳密な/緩和されたインジケータデータを備えることを特徴とする、請求項8に記載のシステム。
【請求項10】
前記通信仕様が、ソフトウェア実装と前記形式モデルにおけるアクタとの間のリンクを備えることを特徴とする、請求項1から9のいずれか一項に記載のシステム。
【請求項11】
請求項1から10のいずれか一項に記載の監視システムを使用して設計されたリアルタイムの搭載機器であって、前記搭載機器が、その環境に固有の測定値を受信し、機能的動作を作動させる結果をもたらすように構成されることを特徴とする、リアルタイムの搭載機器。
【請求項12】
前記機器が、陸上、鉄道、航空宇宙、または海軍タイプの自律型または非自律型の車両であることを特徴とする、請求項11に記載の機器。
【請求項13】
具体的なアプリケーションのセットの通信を形式的に監視するための方法であって、
- 一方向通信チャネルを通じて、定量化可能な情報を相互に交換するアクタのセットを備えるデータストリームの形式モデルであって、前記形式モデルが、具体的なアプリケーションの前記セットをモデル化するアクタのセットの挙動を記述する、形式モデル、および、前記アクタによってモデル化された前記アプリケーションを実装するソフトウェア実装を記述する通信仕様であって、前記ソフトウェア実装が、前記プラットフォームの前記プログラミングインターフェースに関連するあらかじめ決定された通信機能を呼び出すように構成された、通信仕様を取得するステップと、
- 前記通信機能への呼出しのシーケンスが、アクタの前記セットの予期される挙動に従っていることを検証するステップと
を含むことを特徴とする、方法。
【発明の詳細な説明】
【技術分野】
【0001】
本発明は、具体的なアプリケーションのセットの通信を形式的に監視するためのシステムに関し、より詳細には、サービス指向アーキテクチャにおける、具体的なアプリケーションのセットの通信を形式的に監視するためのシステムに関する。
【背景技術】
【0002】
本発明は、具体的なアプリケーションが、相互にデータを交換するためにあらかじめ定義されたインターフェース機能を使用するシステムに適用される。特に、本発明は、いくつかのタスクの予期される挙動の順守が重要であると見なされる、すなわち、順守がない場合、非常に否定的な結果が生じる可能性があるようなシステムに適用される。一般的に言えば、本発明は、異なるレベルの重要度のタスクが共存するシステムに適用され、いくつかのタスクは、予期される挙動に厳密に準拠する必要があると見なされ、他のタスクは、挙動における逸脱が一時的に許容され、または、さらに他のタスクは、挙動の保証がない。これらは混合臨界システムとして知られている。
【0003】
自律走行車用の最近のリアルタイム搭載システムは、そのようなシステムの例である。車両用の新しい搭載アーキテクチャは分散されており、異種であり、それらをプログラムするために使用されるパラダイムはサービス指向である。重要なタスクの予期される挙動から逸脱すると、非常に危険な誤動作が発生する可能性がある。一方、快適性や運転経験に関連するいくつかのタスクは、実際には挙動に制約がないため、混合臨界システムである。
【0004】
したがって、そのようなシステムの形式的な仕様を作成できるツールを有し、指定されたシステムの実装の適合性の形式的な検証が行われることが重要である。
【0005】
しかしながら、すべての制約を考慮したそのようなシステムの仕様は、非常に複雑な技術的問題である。次いで、指定されたシステムの実装にリソースを割り当て、これらのリソースが、仕様に同意したとおりに実装が機能するのに十分であることを検証する作業が行われる。
【0006】
再構成可能なリアルタイムデータフローシステムを指定するための形式モデルベースのアルゴリズムがある。そのような方法の1つは、たとえば文書[1]に記載されている。この方法により、実装に必要なリソースと、アクタ間のインターロックがないことを検証することが可能になる。しかしながら、実行中に、指定されたシステムの実装の挙動とその仕様との適合性を検証することはできない。
【0007】
もう1つの問題は、形式的方法論における指定されたシステムの実装である。これには、各アクタによってモデル化された具体的なアプリケーションを実装するソフトウェアを開発し、形式的に指定された通信を実行するためにこのソフトウェアにおいて通信インターフェースを使用することが含まれる。この実装は、これらの通信が形式的な仕様に準拠するように、インターフェース間の通信用に実装されたソフトウェア要素を構成することを必要とする。
【0008】
この種のシステム、特にサービス指向システム用のソフトウェアを記述するための多くの言語およびプログラミングインターフェースがある。しかしながら、それらのプログラミングインターフェースはすべて同様の概念、すなわち、サーバによるデータの公開と1つもしくは複数のクライアントによるそのデータのサブスクリプション、または必要な処理の実行を担当するサーバへの1つもしくは複数のクライアントによる要求の放出に基づいている。クライアントとサーバとの間の接続は、システムの存続期間中に変更される可能性があり、システムの適切な動作を保証するために時間の制約が課される場合がある。
【0009】
文書[2、3]は、データフローアクタを実装するソフトウェアを記述するための言語と、指定されたシステムの挙動を実行するようにコードを生成する関連コンパイラについて説明している。
【0010】
しかしながら、このソフトウェアは、形式的な仕様のすべての制約を表現できないため、考慮されるコンテキストに制限されており、ほとんどの場合、対象となるソフトウェアアーキテクチャは混合臨界システムに適合していない。さらに、様々なソフトウェアプロデューサがアクタ仕様を実装する開発モデルの範囲では、それらを同じインテグレータに提供するために、インテグレータが特定の言語の使用を強制することは非常に困難である。
【発明の概要】
【発明が解決しようとする課題】
【0011】
したがって、本発明の目的は、特に異種分散プラットフォーム上で任意の言語で記述されたソフトウェア実装の統合を可能にすることによって、前述の欠点を克服するアプリケーションのセットの通信を形式的に監視するためのシステムを提供することである。
【課題を解決するための手段】
【0012】
本発明は、プラットフォームの具体的なアプリケーションのセットの通信を形式的に監視するためのシステムであって、
- 一方向通信チャネルを通じて、定量化可能な情報を相互に交換するアクタのセットを備えるデータストリームの形式モデルであって、前記形式モデルが、具体的なアプリケーションの前記セットをモデル化するアクタの前記セットの挙動を記述する、形式モデル、および、前記アクタによってモデル化されたアプリケーションを実装するソフトウェア実装を記述する通信仕様であって、前記ソフトウェア実装が、前記プラットフォームのプログラミングインターフェースに関連するあらかじめ決定された通信機能を呼び出すように構成された、通信仕様を取得するように構成された取得モジュールと、
- 前記通信機能への呼出しのシーケンスが、アクタの前記セットの予期される挙動に従っていることを検証するように構成された監視モジュールと
を備える、システムに関する。
【0013】
したがって、監視モジュールは、考えられるすべての予期される挙動(および、考えられる多くのシナリオの中のあらかじめ決定されたシナリオだけでなく)を認識し、異常な動作が検出された場合に修正措置を適用することができる。さらに、このシステムは、アクタを実装するソフトウェアを修正する必要なしに、形式モデルにおいて指定されたものに従った通信挙動を示す異種分散プラットフォーム上で任意の言語で記述されたソフトウェア実装の統合を可能にする。ソフトウェア実装は、動作環境においてオンラインで搭載することができる。
【0014】
本発明の好ましい実施形態によれば、監視モジュールは、アクタに対応するソフトウェア実装ごとにオートマトンを構築するように構成され、各オートマトンは、ある状態から別の状態への移行が、ソフトウェア実装から前記通信機能のうちの1つへの呼出しによってトリガされる状態のセットを備え、前記オートマトンは、ソフトウェア実装の前記通信機能への有効な呼出しシーケンスを追跡するために、形式モデルによって予期される挙動に基づいている。
【0015】
有利なことに、各オートマトンは、ソフトウェア実装の初期化に関連付けられる第1の部分と、ソフトウェア実装の動作に関連付けられる第2の部分とを備え、前記第1の部分の最終状態から前記第2の部分の初期状態への移行は、同期信号がソフトウェア実装によって受信されたときにトリガされ、プラットフォーム上での具体的なアプリケーションの実行を示す。
【0016】
有利なことに、監視モジュールは、通信機能呼出しをキャプチャするように構成されたソフトウェア要素を生成することと、具体的なアプリケーションの実行時に行われる呼出しのシーケンスがオートマトンによって定義されたシーケンスに対応することを確認することとを行うように構成される。
【0017】
有利なことに、ソフトウェア要素は、通信機能ごとの拡張機能、入力データ期日管理機能、および現在のアクティベーション管理機能を備えている。
【0018】
有利なことに、通信仕様はサービス指向実装の仕様である。
【0019】
有利なことに、通信機能はサービス指向であり、サービス提供機能、インターフェース公開機能、公開インターフェースサブスクリプション機能、放出機能、受信機能、要求機能、およびインターフェース処理機能を備える。
【0020】
有利なことに、形式モデルは、前記アクタの実装に必要な構成データのセットを備えるため、搭載システムの予期される挙動を記述することができる。
【0021】
有利なことに、構成データは、アクタごとに、予算、初期遅延、初期期限、入力期限、デフォルトの入力ポリシ、永続的/一時的インジケータ、および厳密な/緩和されたインジケータデータを含む。
【0022】
有利なことに、通信仕様は、ソフトウェア実装と形式モデルのアクタとの間のリンクを含む。
【0023】
本発明はまた、前述の特性のいずれかに従って監視システムを使用して設計されたリアルタイムの搭載機器を対象とし、前記搭載機器は、その環境に固有の測定値を受信し、機能的動作を作動させる結果をもたらすように構成されている。
【0024】
有利なことに、前記機器は、陸上、鉄道、航空宇宙、または海軍タイプの自律型または非自律型の車両である。
【0025】
本発明はまた、プラットフォームの具体的なアプリケーションのセットの通信を形式的に監視するための方法であって、
- 一方向通信チャネルを通じて、定量化可能な情報を相互に交換するアクタのセットを備えるデータストリームの形式モデルであって、前記形式モデルが、具体的なアプリケーションの前記セットをモデル化するアクタのセットの挙動を記述する、形式モデル、および、前記アクタによってモデル化されたアプリケーションを実装するソフトウェア実装を記述する通信仕様であって、前記ソフトウェア実装が、前記プラットフォームのプログラミングインターフェースに関連するあらかじめ決定された通信機能を呼び出すように構成された、通信仕様を取得するステップと、
- 前記通信機能への呼出しのシーケンスが、アクタの前記セットの予期される挙動に従っていることを検証するステップと
を含む方法を対象とする。
【0026】
本発明によるデバイスおよび方法のさらなる特徴および利点は、以下の添付の図面を参照して、決して限定するものではなく目的を示すために、以下に与える説明を読むとより明確になる。
【図面の簡単な説明】
【0027】
図1】本発明の一実施形態による、プラットフォームの具体的なアプリケーションのセットの通信を形式的に監視するためのシステムを概略的に示す図である。
図2】本発明の一実施形態による、グラフによって定義される形式モデルの例を概略的に示す図である。
図3A】本発明の一実施形態による、形式モデルのアクタと通信仕様のサービス指向インターフェースの記述との間の対応を概略的に示す図である。
図3B】本発明の一実施形態による、形式モデルのアクタと通信仕様のサービス指向インターフェースの記述との間の対応を概略的に示す図である。
図3C】本発明の一実施形態による、形式モデルのアクタと通信仕様のサービス指向インターフェースの記述との間の対応を概略的に示す図である。
図4A】本発明の一実施形態による、オートマトンの構築を概略的に示す図である。
図4B】本発明の一実施形態による、オートマトンの構築を概略的に示す図である。
【発明を実施するための形態】
【0028】
本発明の原理は、形式的な仕様に従ってデータ交換を観察するために、形式的方法論において指定されたコンポーネントを実装する計算タスク間のデータ交換を監視することである。
【0029】
図1は、本発明の一実施形態による、プラットフォームの具体的なアプリケーションのセットの通信を形式的に監視するためのシステムを概略的に示している。
【0030】
形式的な監視システム1は、マイクロプロセッサ5およびメモリ7を備える計算機またはコンピュータ3などの情報処理機械を備えるハードウェア手段によって実装される。マイクロプロセッサ5は、コンピュータのメモリ7に記憶され、アプリケーションのセットの通信を形式的に監視するためのシステムを実装するように設計された、プログラムコード命令を備える1つまたは複数のコンピュータプログラムを実行するように構成される。
【0031】
監視システムは、プラットフォームの具体的なアプリケーションのセットの通信の形式的な監視を実行することを目的としている。本発明によれば、監視システムは、取得モジュール9および監視モジュール11を備える。
【0032】
取得モジュールは、具体的なアプリケーションのセットをモデル化するアクタのセットの挙動を記述するデータストリームの形式モデル13を取得するように構成される。さらに、取得モジュール9は、アクタによってモデル化されたアプリケーションを実装するソフトウェア実装を記述する通信仕様15を取得するように構成される。ソフトウェア実装は、あらかじめ決定された通信機能を呼び出すように構成される。
【0033】
監視モジュール11は、通信機能への呼出しのシーケンスが、アクタのセットの予期される挙動に従っていることを検証するように構成される。
【0034】
データストリームの形式モデル13は、一方向通信チャネルを通じて、定量化可能な情報を相互に交換する独立したアクタを備える。アクタは、ソフトウェアエンティティ(たとえば、アプリケーション)および/またはハードウェアエンティティ(たとえば、センサ、カメラ、プローブ、マイクロプロセッサなど)である可能性がある。各アクタは、静的に指定された量のデータを消費するために、その量のデータを各アクタの入力チャネルで受信するまで待機することと、そのデータの処理を実行することと(または、実行しないことと)、その出力チャネルで静的に指定された量のデータを新しいアクタに生成することとを行うように構成され、それぞれがこの挙動を無期限に繰り返す。消費/処理/放出処理は、一般にアクティベーションと呼ばれる。
【0035】
各アクティベーションはあらかじめ定義された再構成に従って行われ、特定の再構成に対して、アクティベーションは消費/処理/生成(いわゆる実行)する、または何もしない(いわゆるパス)のいずれかであり、構成を変更する選択は予測できない。
【0036】
各アクタは、可能な周波数制約(または、同等に期間制約)を使用して、あらかじめ定義された時間内の再構成(リアルタイムと呼ばれる)ウィンドウに従ってアクティブ化する。
【0037】
さらに、通信仕様15は、アプリケーション、それらが提供するサービス、それらが使用するサービス、チャネル上を通過するデータのタイプ、異なるアプリケーション間の相互作用に関する情報、プラットフォームのアプリケーションと形式モデルのアクタとの間のリンクまたは対応に関する情報などを含む。
【0038】
監視モジュール11は、形式的方法論(すなわち、形式モデル13)からの構成および通信仕様15のアプリケーションの記述を入力として受け取り、アクタの実装によって実行される通信を観察し、場合によっては形式的な仕様からの逸脱を修正することを担当する監視ソフトウェア層を自動的に生成するコード生成ツールである。
【0039】
したがって、本発明による監視システム11は、任意の既存の言語で記述されたアクタの実装を、異種分散プラットフォーム上に自動的に統合する手段を提供する。
【0040】
対象となるアーキテクチャがインターネット、自動車、航空、気象学などの多くの分野において使用されていることを考えると、この監視システムの潜在的なアプリケーションは数多くある。
【0041】
特に、本発明は、搭載システムまたはデバイス用の異種分散プラットフォームに適用され、予期される挙動への準拠は、そのようなシステムで提供される機器の安全性および適切な機能にとって非常に重要であると考えられる。
【0042】
自律走行車用の最近のリアルタイム搭載システムは、そのようなシステムの例であり、エンティティは、具体的なアプリケーションが相互にデータを交換できるようにする一般的なインターフェースを提供し、各アプリケーションは独立しており、分散アーキテクチャのコンピュータで実行される。アプリケーション間の接続は、車両の現在の動作モード、および/またはサービスの可用性に応じて再構成することができる。
【0043】
以下では、本発明は、アクタのセットからなる形式モデルによってモデル化されたシステムを参照することによって、およびモデルによって予期される挙動の記述を与えることによって、詳細に説明される。
【0044】
実際、図2は、本発明の例示的な実施形態による、グラフによって定義される形式モデルの例を概略的に示している。
【0045】
この例によれば、形式モデル13は、30Hzにおいてセンサによって供給されるデータを取得する「取得」アクタと、10Hzにおいてアクチュエータにコマンドを送信する「コマンド」アクタとを備える。コマンドは、可能なすべての再構成におけるデータの前処理を実行する「前処理」アクタ、および、ある再構成では、前処理されたデータの高速で低解像度の処理を実行する「高速処理」アクタ、および、もう1つの再構成では、低速で高解像度の処理を実行する「高品質処理」アクタで構成される再構成可能な処理チェーンの結果に従って決定される。現在の再構成の選択は、利用可能な場合に高解像度処理を使用することが好ましい「モード」アクタによって行われる。
【0046】
グラフは、周波数制約、異なる再構成モード、および初期消費に使用可能な初期データを使用してデータストリームをモデル化する。円a1~a5は、データの処理を実行する、いわゆる一般的なアクタを表している。したがって、これらの一般的なアクタa1~a5は、データを消費することと、データを変換するために計算を実行することと、結果を生成することとを行うように適合されている。三角形a6およびa7は、周波数制約のあるデータを生成および消費する「クロック」a6または「期限」a7と呼ばれるアクタを表す。正方形a8は、シグナリングの再構成を担当する「モード」アクタa8を表す。有向アークc1~c10は単方向チャネルであり、それぞれが2つのアクタ間のデータストリームと、チャネル上で生成または消費されるデータの量を与える関連付けられる数値を示す。
【0047】
この例によれば、モデル化されたシステムは、5つの一般的なアクタa1~a5(取得a1、前処理a2、高速処理a3、高品質処理a4、およびコマンドa5)、2つの一時的なアクタa6およびa7(クロックおよび期限)、ならびに1つのモードアクタa8で構成される。「取得」アクタa1は、クロックアクタa6によって提供されたデータを30Hzにおいて取得する。コマンドアクタa5は、10Hzにおいて期限アクチュエータアクタa7にコマンドを送信する。コマンドは、すべての可能な再構成において取得アクタa1によって生成されたデータの前処理を実行する別の一般的な「前処理」アクタa2で構成される再構成可能な処理チェーンの結果に従って決定される。第1の構成(λ1によって示されるモード)では、「高速処理」アクタa3(高速アクタ)は、前処理アクタa2によって前処理されたデータの高速および低解像度の処理を実行する。第2の再構成(λ2によって示されるモード)では、「高品質処理」アクタa4(低速アクタ)が低速であるが高解像度の処理を実行する。したがって、第1の構成λ1のデータ処理パスは、取得アクタa1を前処理アクタa2、高速処理アクタa3、次いで最後に制御アクタa5に接続するパスである。第2の構成λ2は、取得アクタa1を前処理アクタa2、低速処理アクタa4、次いで最後に制御アクタa5に接続するパスによって定義される。したがって、構成はあるアクタから別のアクタに伝播するため、これらの再構成モードでの集中同期は必要ない。各アクタは、動作する必要のある構成モードを近隣に通信する。現在の構成の選択は、可能な場合は高解像度処理を使用することが好ましいモードアクタa8によって行われる。
【0048】
この例によれば、高速処理アクタa3は、アクティブ化されるたびに、その入力チャネルc3(チャネルc3では「1」によって表される)でデータの一部を消費し、その出力チャネルc4(チャネルc4では「1」によって表される)でデータの一部を生成する。同じことが、その入力チャネルc5においてデータの一部を消費し、その出力チャネルc6においてデータの一部を生成する低速処理アクタa4にも当てはまる。制御アクタa5は、その第1の入力チャネルc4またはその第2の入力チャネルc4(構成モードによって異なる)においてデータの一部を消費し、アクティブ化されるたびにその出力チャネルc2においてデータの一部を生成する。前処理アクタa2は、アクティブ化されるたびに、その第1の入力チャネルc1においてデータの一部を消費し、その第2の入力チャネルc9においてデータの一部を消費し、その第1の出力チャネルc3またはその第2の出力チャネルc5(構成モードによって異なる)においてデータの一部を生成する。
【0049】
一方、取得アクタa1は、その入力チャネルc2(入力チャネルc2において値「1/3」によって表される)において有理数のデータを消費し、その出力チャネルc1(出力チャネルc1において値「1/3」によって表される)において有理数のデータを生成する。これは、取得アクタa1が3回のアクティベーションごとにデータの一部を消費または生成することを意味する。図2における例は、初期状態において、チャネルc2(制御アクタa5と取得アクタa1の間)で使用可能なトークンT1(すなわち、データの一部)があることを示している。次に、取得アクタa1は、このチャネルc2でこの既存のデータの一部を消費し、その出力チャネルc1(すなわち、取得アクタa1を前処理アクタa2に接続するチャネルc1)でデータの一部を生成する。したがって、取得アクタa1は、データの一部を消費し、データの一部を生成した。しかしながら、次の2つのアクティベーションにおいて、ゼロデータを消費し、ゼロデータを生成する。言い換えれば、取得アクタa1は、3回のアクティベーションごとにデータの一部を消費し、データの一部を生成する。これにより、データを失うことなく、異なる周波数において動作する2つのアクタ間でデータを同期することが可能になる。実際、この例によれば、取得はコマンドごとに3回表示されるため、データを失うことなく、30Hzにおいて動作する取得アクタa1と10Hzにおいて動作するコマンドアクタa5との間でデータを転送することができる。
【0050】
以下では、形式モデル13を定義する要素を、図2における例を参照して要約する。この形式によれば、データストリームの仕様は、以下の要素F1~F9で構成される。
【0051】
F1:データを処理する一般的なアクタa1~a5のセット、ならびにデータを処理する、および/または構成モードを選択するモードアクタa6およびa7のセットが定義される。
【0052】
F2:アクタを相互に接続するチャネルのセットc1~c10が定義され、各アクタは少なくとも1つの入力または出力チャネルに関連付けられている。
【0053】
F3:その入力チャネルまたは出力チャネルごとに各アクタによって生成または消費されるデータの数が定義され、チャネルがこれらの数のうちの1つだけを有理数にすることができるという利点がある。これらの数値は、アクタを接続するアークc1~c10の値によって表される。
【0054】
F4:空でないモードのセットのモードアクタa8ごとに、モードアクタa8は、そのアクティベーションごとにこれらのモードの1つだけを動的に選択することを担当する(これらのモードはλ1およびλ2と表記される)。現在の構成の選択は、単一のa8モードアクタによって有利に行われ、この現在の構成は、あるアクタから別のアクタに分散された方法で伝播される。
【0055】
F5:一般的なアクタa1~a5ごとに、それを実行するモードのセット、およびそれが通過する他のすべてのモードの暗黙のセットが定義される。一般的なアクタが実行するモードのセットは、システム全体に共通の公称モード、またはモードアクタによって選択されたモードのサブセットのいずれかである点に留意されたい。図2の例では、前処理アクタa2がモードλ1およびλ2において実行され、高速処理アクタa3がモードλ1において実行され、低速処理アクタa4がモードλ2において実行される限り、前処理a2、高速処理a3、および低速処理a4アクタを除くすべてのアクタが公称モードで実行される。
【0056】
F6:異なるモードが与えられると、フィードバックチャネルの暗黙のセットは、同じモードアクタによって選択されたモードのうちの少なくとも1つにおいてそれぞれ実行される2つの一般的なアクタを接続するチャネルのセットとして定義され、したがって、モードアクタから始まり、そのチャネルの生成アクタで終わり、消費アクタを通過する非反復パスがある。
【0057】
F7:最大周波数制約は、一部の一般的なまたはモードアクタに対して定義されている。それらを表現する1つの可能な方法は、周波数が関連付けられているいわゆるクロックアクタa6によるものである。図2の例において、取得アクタa1の最大周波数制約は30Hzであり、周波数30Hzのクロックアクタa6、それらを接続するアークc7、および関連付けられるデータ量によって表される。
【0058】
F8:最小周波数制約は、一部の一般的なまたはモードアクタに対して定義されている。それらを表現する1つの可能な方法は、頻度を関連付ける、いわゆる期限アクタa7を使用することである。図2の例において、制御アクタa2の最小周波数制約は10Hzであり、周波数10Hzの期限アクタa7、それらを接続するアークc8、および関連付けられるデータ量によって表される。同じアクタが最小および最大周波数において動作するように制約される可能性がある点に留意されたい。その場合、それは正確な周波数制約である。言い換えれば、周波数制約は、最大(1秒あたりの回数以下)、最小(1秒あたりの回数以上)、または正確(1秒あたりの正確な回数)のいずれかである。
【0059】
F9:システムの初期状態は、チャネルごとに、有理数、およびこの有理数を最も近い整数に切り捨てたものに等しい長さのモードのシーケンスで構成され、その初期モードの一般的なアクタごとに構成される。図2の例において、すべてのアクタの初期モードとして公称モードがあり、小さな円T1およびT2でマーク付けされたチャネルの初期状態は値「1」である。もちろん、初期状態は、任意の有理数(たとえば2/5、4/3など)によって表すことができ、これは、本発明の1つの有利な実施形態によれば、生成および消費率が合理的であるという事実に起因する。
【0060】
以下のTable 1(表1)は、例として、図2の形式モデル13の実装に必要な構成データを示している。
【0061】
【表1】
【0062】
第1の行は、取得a1、前処理a2、高速処理a3、高品質処理a4、およびコマンドa5アクタの、5つの一般的なアクタを表している。
【0063】
第2の行、第3の行、第4の行、第5の行は、それぞれ予算、初期遅延、初期期限、および入力期限のミリ秒単位の値を示している。第6の行、第7の行、および第8の行は、デフォルトの入力ポリシ、永続的/一時的インジケータ、および厳密な/緩和されたインジケータを示している。
【0064】
値は通常、プラットフォームインテグレータによって課され、ここでは例としてのみ示されている。予算は、異なるタスクを実行するために各アクタに割り当てられる期間をミリ秒単位で指定する。初期遅延および初期期限は、異なるサンプルのルーティングと処理を考慮に入れるために、サンプルの通信および生成に必要な時間を示している。初期遅延がゼロの場合は、強制的なレイテンシの制約がなく、準備が整うとすぐにアクタが開始することを意味する。入力期限は、アクタの実装によって消費されるデータの到着期限を指定するため、アクタは、作業を開始する前に目的のデータを待機する待機時間を割り当てることができる。
【0065】
この例におけるデフォルトの入力ポリシは、2種類のポリシを参照している。入力データがない場合、「無視」ポリシは置換データを生成せず、「以前の」ポリシは最後に受信した入力をコピーする。あるいは、同じデフォルト値を体系的に生成する第3の「デフォルト」ポリシを設定することもできる。
【0066】
別の入力構成データの一部は、生成の欠如が障害として指定されているかどうかに関連している可能性がある。図2の例において、キャリブレーション要求が必須ではないため、コマンドアクタから取得アクタへの出力がないことだけが障害とは見なされない。
【0067】
さらに、以下の説明において、サービス指向アーキテクチャにおける形式的な通信監視システムについてより具体的に説明する。言い換えれば、通信仕様15はサービス指向実装の仕様であり、通信機能はサービス指向機能である。
【0068】
例として、サービス指向アーキテクチャは、AcquisitionService、PreprocessService、およびProcessServiceの3つのサービスで構成されていると見なされる。各サービスは、次のインターフェースを提供する。
- AcquisitionServiceは、センササンプルを生成するAcquisitionService::Samplesインターフェースを公開し、キャリブレーション要求を処理するためのAcquisitionService::Calibrateインターフェースを提供する。
- PreprocessServiceは、前処理されたサンプルを生成するインターフェースを公開し、再構成を実装するために、このインターフェースはPreprocessService::Samples1およびPreprocessService::Samples2インターフェースに複製され、これは現在の再構成に従って使用される。
- ProcessServiceは、処理されたサンプルを生成するProcessService::Samplesインターフェースを公開する。
【0069】
各サービスの実装は、一意の識別子によって識別される。AcquisitionServiceの実装Acq1、PreprocessServiceの実装Pre1、およびProcessServiceの2つの実装Proc1とProc2がある。クライアントのみの実装Com1もある。これらの実装とモデル内のアクタとの間のリンクを次のTable 2(表2)に示す。
【0070】
【表2】
【0071】
モデルの5つのアクタを実装するソフトウェアは、異なるソフトウェアプロバイダによって作成することができる。このソフトウェアは、サービス指向の通信を確立するために通信機能を呼び出す。
【0072】
例として、文書[4、5]に記載されている適応型自動車プラットフォームAutoSARのプログラミングインターフェースに関連する通信機能を以下に説明する。これらの通信機能は、サービス提供機能(OfferService)、インターフェース公開機能(PublishInterface)、公開インターフェースサブスクリプション機能(SubscribeInterface)、放出機能(Emit)、受信機能(Receive)、要求機能(Request)、およびインターフェース処理機能(Process)を含む。
【0073】
OfferService関数(サービス識別子)を使用すると、呼出し元のソフトウェアを識別子に関連付けられる実装として識別することができる。
【0074】
PublishInterface(インターフェース識別子)関数を使用すると、呼出し元のソフトウェアは、他のソフトウェアの識別子に関連付けられるインターフェースにアクセスすることができる。
【0075】
SubscribeInterface(サービス識別子、インターフェース識別子)関数を使用すると、呼出し元のソフトウェアは、インターフェース識別子に関連付けられるインターフェースを通じて、サービス識別子に関連付けられるソフトウェアによって放出されたデータを受信することができる。
【0076】
Emit(インターフェース識別子、データの一部)関数を使用すると、呼出し元のソフトウェアは、インターフェース識別子に関連付けられるインターフェースを通じて、提供されたデータの一部を放出することができ、これは、データストリームの形式モデル13においてトークンを生成することに相当する。
【0077】
Receive関数(サービス識別子、インターフェース識別子)を使用すると、呼出し元のソフトウェアは、Receiveへの最後の呼出し以降に識別子に関連付けられるインターフェースを通じて送信されたデータを検索することができ、これは、データストリームの形式モデル13において参照されたデータと同じ数のトークンの消費に相当する。
【0078】
Request(サービス識別子、インターフェース識別子、パラメータ)関数を使用すると、呼出し元のソフトウェアは、所与のパラメータを処理するために、インターフェース識別子に関連付けられる処理要求をサービス識別子に関連付けられるソフトウェアに送信し、要求が処理されると可能な結果を取り出すことができ、これは、データストリームの形式モデル13におけるトークンの生成に相当し、結果の抽出はトークンの消費に相当する。
【0079】
Process(インターフェース識別子)関数を使用すると、呼出し元のソフトウェアは、識別されたインターフェースにおいて受信した要求のパラメータを取り出し、必要な処理を実行し、最終的には要求を送信したソフトウェアに結果を放出することができ、要求を取り出すことは、データストリームの形式モデル13においてトークンを消費することに相当し、結果を放出することは、トークンを生成することに相当する。
【0080】
図3A図3Cは、本発明の一実施形態による、形式モデルのアクタと通信仕様のサービス指向インターフェースの記述との間の対応を概略的に示している。
【0081】
より具体的には、図3Aは、形式モデル13のグラフトポロジと、サービスを提供することと、インターフェースを公開することと、公開されたインターフェースにサブスクライブすることとを行うためのサービス指向インターフェースとの間の対応を示している。説明のために、この例では、取得a1と前処理a2の2つのアクタのみが考慮されている。取得a1アクタの挙動を実行するソフトウェアAcq1は、取得サービスに対応するPublishinterface(Samples)インターフェースを公開する。より具体的には、ソフトウェアAcq1はOfferService関数を呼び出し、次いでPublishInterface関数を呼び出して、データが公開される接続ポートを作成する。次いで、前処理アクタa2を実装するソフトウェアPre1は、生成されたサンプルを消費するためにソフトウェアAcq1のインターフェースにサブスクライブするために、SubscribeInterface関数を呼び出す。したがって、図3Aは、これらの異なる要素間の接続を行い、関数の呼出しが行われるときにデータストリームグラフを再描画することを可能にする。図3Aは、通信が実際に図2の形式モデル13のグラフに対応することを検証するための初期化フェーズに関する点に留意されたい。グラフが構築されると、図3Bによって説明されている第2の動作フェーズが開始される。
【0082】
実際、図3Bは、形式モデル13のグラフのチャネルにおける生成/消費と、サービス指向インターフェースにおけるデータの放出/受信との間の対応を示している。ソフトウェアAcq1は、そのインターフェースにおいて定期的にEmit関数を呼び出し、このインターフェースにおいて具体的なデータの一部を提供する。前処理アクタを実装するソフトウェアPre1は、このデータの一部を消費するためにReceive関数を呼び出す。
【0083】
図3Cは、形式モデル13のグラフのチャネルにおける生成/消費と、サービス指向インターフェースにおける要求の送信および処理との間の対応を示している。より具体的には、コマンドアクタを実装するソフトウェアCom1は、パラメータおよび要求識別子を使用して要求を送信し、これは、図2の形式モデルのグラフにおけるトークンの生成に対応する。一方、取得アクタのソフトウェアAcq1は、そのインターフェースにおいて要求を処理するためにProcess関数を呼び出す。
【0084】
図3A図3Cの例におけるアクタの実装の予期される挙動は次のとおりである。
- Acq1:上記の構成では、図2における形式モデル13の例は、取得アクタが3つの連続したアクティベーションを有し、第1のアクティベーションが0ミリ秒から20ミリ秒の間に行われる必要があり、その出力チャネルにおいてトークンを生成し、その入力チャネルにおいてトークンを消費する必要があると決定する。次の2つのアクティベーションは通信しない。したがって、実装の予期される挙動は、AcquisitionService::SamplesインターフェースにおいてEmit関数を1回呼び出し、AcquisitionService::Calibrateインターフェースの要求を0ミリ秒から20ミリ秒の間に処理するためにProcess関数を呼び出すことである。この挙動は、100ミリ秒から120ミリ秒、200ミリ秒から220ミリ秒などの間で繰り返される必要がある。
- Pre1:上記の構成では、図2における形式モデル13の例は、前処理アクタが0ミリ秒から50ミリ秒の間に行われる必要があるアクティベーションを有し、その入力チャネルにおいてトークンを消費し、出力チャネルのうちの1つにおいてデータを含むトークンと、他のチャネルにおいてデータを含まないトークンとを生成する必要があると決定する。可能な再構成を考慮に入れるために、この実装は、実装Proc2がOfferService関数を呼び出したかどうかを検証する。したがって、実装の予期される挙動は、データの一部を検索するためにAcq1のSamplesインターフェースにおいてReceive関数を呼び出すことと、Samples1インターフェースにおいて、またはSamples2インターフェースにおいて、0ミリ秒から50ミリ秒の間にSend関数を1回呼び出すこととを行うことである。この挙動は、100ミリ秒から150ミリ秒、200ミリ秒から250ミリ秒などの間で繰り返される必要がある。
- Proc1:上記の構成では、図2における形式モデル13の例は、高速処理アクタがその入力チャネルにおいてトークンを消費し、その出力チャネルにおいてトークンを生成する必要があるアクティベーションを有し、このトークンは、データを含むか、データを含まないと決定する。したがって、この実装の予期される挙動は、1つまたは0のデータの一部を検索するためにPre1のSamples1インターフェースにおいてReceive関数を呼び出し、そのSamplesインターフェースにおいて、データが実際に受信された場合にのみ、Emit関数を1回呼び出すことであり、これは0ミリ秒から90ミリ秒の間である。この挙動は、100ミリ秒から190ミリ秒、200ミリ秒から290ミリ秒などの間で繰り返される必要がある。
- Proc2:予期される挙動は、Receiveのインターフェースが、Pre1のSamples2インターフェースであることを除いて、Proc1と同じである。
- Com1:上記の構成では、図2における形式モデル13の例は、コマンドアクタは、その一方の入力チャネルにデータを含むトークンと、もう一方の入力チャネルにデータを含まないトークンを消費し、その出力チャネルにおいてトークンを生成する必要があるアクティベーションを有すると決定する。したがって、この実装の予期される挙動は、Proc1およびProc2のSamplesインターフェースにおいてReceive関数を呼び出して、どちらかのデータの一部を検索し、任意で、Calibrateインターフェースの要求関数を0ミリ秒から110ミリ秒の間に1回呼び出すことである。この挙動は、100ミリ秒から210ミリ秒、200ミリ秒から310ミリ秒などの間で繰り返される必要がある。
【0085】
アクタの記述が定義されると、監視モジュール11は、この記述を入力として受け取り、サービス指向通信機能への呼出しシーケンスが、アクタの予期される挙動に従っていることを検証する。
【0086】
監視モジュール11は、たとえば、オートマトン、ツリー、リスト、ネストされた条件を備えたコード選択、文法を備えた正規表現などを使用して、異なる技法に従って実装することができる点に留意されたい。
【0087】
しかしながら、以下の説明では、オートマトンに基づくコード生成技法を例として考える。したがって、監視モジュール11は、実装の予期される挙動を記述するオートマトンを構築し、移行は上記の通信機能のうちの1つへの呼出しに対応する。
【0088】
より具体的には、監視モジュール11は、アクタに対応するソフトウェア実装ごとにオートマトンを構築するように構成され、各オートマトンは、ある状態から別の状態への移行が、ソフトウェア実装から通信機能のうちの1つへの呼出しによってトリガされる状態のセットを備える。オートマトンは、ソフトウェア実装の通信機能への有効な呼出しシーケンスを追跡するために、形式モデルによって予期される挙動に依存する。
【0089】
そのようなオートマトンの構築の例は、2つの部分に分割されたオートマトンの構築であり、1つはソフトウェア実装の初期化に対応し、もう1つは初期化された後の動作に対応し、プラットフォームの同期開始後にのみ許可される移行によって接続される。
【0090】
実際、図4Aおよび図4Bは、本発明の一実施形態によるオートマトンの第1の部分および第2の部分の構築を概略的に示している。
【0091】
より具体的には、図4Aは、オートマトンの第1の部分の構築を示している。この構築は、初期状態から始まり、次の場合にトリガされるいくつかの中間状態および移行を通じて最終状態に到達する。
- 実装が、この実装に関連付けられるサービス識別子を使用してOfferService関数を呼び出す。
- 実装が、OfferServiceへの呼出しが現在の状態にしたサービスのインターフェースに対応するインターフェース識別子を使用してPublishInterface関数を呼び出す。
- 実装が、そのサービス識別子に関連付けられるソフトウェアへの予期される接続に対応するインターフェースおよびサービス識別子を使用してSubscribeInterface関数を呼び出す。
【0092】
より具体的には、図4Aにおける例は、図2の例における前処理アクタa2の実装Pre1に対して生成された初期化オートマトンを表している。初期化フェーズにおいて、実装は初期状態EI0(黒丸によって表される)にある。オートマトンは任意の関数を呼び出すことができるが、OfferService関数を呼び出すまで、前処理アクタの実装Pre1として認識されない。前処理アクタの実装Pre1として識別されると、Samples1またはSamples2インターフェースのいずれかをEI1状態に公開することができる。Samples1インターフェースを公開することから始めた場合、Samples2インターフェース(状態EI2)を公開する。一方、Samples2インターフェースを公開することから開始した場合、Samples1インターフェース(状態EI3)を公開する。これらのインターフェースを公開すると、インターフェースAcq1(状態EI4)にサブスクライブでき、最後に、状態EI5において、終了したと見なされる。
【0093】
この場合、オートマトンの第1の部分の最終状態から第2の部分の初期状態への移行は、プラットフォーム上での具体的なアプリケーションの実行を示す同期信号(すなわち、システムの起動を示す)が実装によって受信されたときに可能である。
【0094】
さらに、図4Bにおける例によれば、オートマトンの第2の部分の構築は、第2の部分の初期状態から始まり、以下の場合にトリガされるいくつかの中間状態および移行を通じてこの状態に戻る。
- 実装が、以前に公開されたインターフェース識別子を使用してEmit関数を呼び出し、すでに放出されたデータの量は、そのインターフェースで予期される量を超えない。
- 実装が、以前にサブスクライブされたインターフェース識別子を使用してReceive関数を呼び出し、すでに受信されたデータの量は、そのインターフェースで予期される量を超えない。
- 実装が、モデルにおける出力チャネルに対応するサービスおよびインターフェース識別子を使用してRequest関数を呼び出し、すでに送信された要求の数は、このインターフェースで予期される量を超えない。
- 実装が、モデルにおける入力チャネルに対応するインターフェース識別子を使用してProcess関数を呼び出し、すでに処理された要求の数は、このインターフェースで予期される量を超えない。
- 現在のアクティベーションの期限が過ぎた。
【0095】
より具体的には、図4Bにおける例は、前処理アクタの実装Pre1に対して生成された動作オートマトンを表している。
【0096】
初期動作状態EF0(黒丸によって表される)では、オートマトンはReceive関数を呼び出すことができ、サンプルを受信しない限り、初期状態EF0に戻る。
【0097】
Receive関数を呼び出してサンプルを受信すると、オートマトンは状態EF1に移行する。状態EF1において、オートマトンは、初期状態EF0に戻る前に、Samples1インターフェースにおいてサンプルを送信するか、Samples2インターフェースにおいてサンプルを放出する。しかしながら、状態EF1において期限違反が検出された場合、オートマトンはその初期状態EF0に直接戻る。
【0098】
一方、Receiveで開始する代わりに、オートマトンがEmit関数を呼び出すことによって開始する場合、オートマトンは状態EF2に移行する。状態EF2において、オートマトンは、その初期状態EF0に戻る前に、Samples1インターフェースにおいてサンプルを放出するか、Samples2インターフェースにおいてサンプルを放出する。さらに、サンプルを受信しない限り、状態EF2に戻る。以前と同様に、状態EF2において期限違反が検出された場合、オートマトンはその初期状態EF0に直接戻る。
【0099】
したがって、実装Pre1用に作成された動作オートマトンは、その前処理アクタの挙動に対応する有効な通信機能のシーケンスを記述する。
【0100】
このオートマトンが構築されると、監視モジュールは、通信機能呼出しをキャプチャするように構成されたソフトウェア要素を生成し、具体的なアプリケーションの実行時に行われる呼出しのシーケンスがオートマトンによって定義されたシーケンスに対応することを確認する。
【0101】
ソフトウェア要素は、次のソフトウェア要素を含む。
- 上記の各通信機能の各々の拡張機能。ソフトウェア呼出しが行われるたびに、その呼出しに対応する現在の状態からの発信移行があるかどうかを決定するために、各拡張機能がオートマトンに照会する。そのような移行がある場合、拡張機能は元の関数を呼び出す。そのような移行がない場合、拡張機能は、必要に応じて障害を登録し、許可されている場合は障害処理の直後に戻る。特定のケースは、アクセスされたデータの数が事前に知られていないReceive関数に関連している。この関数の拡張バージョンでは、最大で指定された量のデータをアプリケーションで使用できるようになり、任意の追加のデータは、使用可能になったときに次のアクティベーションを待つためにバッファリングされる。したがって、1回のアクティベーションでReceiveへの複数の呼出しが可能であるが、検索されるデータの数が指定された数を超えることはない。
- 入力データの期限を管理するための機能。初期状態を通過するたびに、次のアクティベーションの入力データを受信する期限が計算され、その日に呼び出されるように関数がプログラムされる。この方法で関数が呼び出されると、必要に応じて障害が記録され、障害処理ポリシが実装される。たとえば、実装Pre1の場合、最後に受信したサンプルの値は、受信したかのように使用可能になる。
- 現在のアクティベーションの期限を管理するための機能。初期状態を通過するたびに、次のアクティベーションの期限が計算され、その日に呼び出されるように関数がプログラムされる。この方法で関数が呼び出されると、新しいアクティベーションを開始するためにオートマトンの現在の状態を更新し、許可されている場合は障害管理の直後に戻る。
【0102】
監視モジュールは、プラットフォームのすべての実装の初期化フェーズから動作フェーズへの移行を許可することを担当するソフトウェアも生成するように構成されている。監視モジュールが同期された起動を許可しない限り、アクタ実装ソフトウェアは動作フェーズに入ることができない。このコードは、たとえば、ソフトウェアのサブセットが動作する準備ができるのを待つか、期限を管理することができる。このコードは、サービス指向ソフトウェアプラットフォームにおいて一般的に利用可能な、ソフトウェア間の時刻同期のための既存の技術に依存している。
【0103】
したがって、本発明は、標準関数を呼び出す標準プログラミングインターフェースから、プログラミングインターフェースソフトウェアを修正することなく、呼出しが正しい順序で、予期される挙動に従って行われることを確実にすることを可能にする。これにより、独自の方法論を使用しながら、標準ソフトウェアサプライヤからインテグレータを提供できるようになる。
【0104】
本発明は、すべてのデータストリームシステムに適用可能である。第1のアプリケーションは、リアルタイムの重要な分散システムに関連する。特に、機器とその環境に固有の測定値を受信し、その機器が適切に動作するように動作を作動させる結果をもたらすように構成された、機器のリアルタイム搭載システムである。機器は、陸上、鉄道、航空宇宙、または海軍タイプの自律型または非自律型の車両であり得る。
【0105】
特に、車両データストリームシステムの範囲内で、本発明によれば、異なる周波数および異なる構成で動作するセンサおよびプロセッサを有することが有利である。さらに、ドライバーがいる車の場合、特定の速度からの歩行者の検出が興味深い例と見なすことができる。したがって、歩行者検出処理が特定の速度から、または特定の範囲の速度にわたって行われるように、異なる再構成モードを使用して、マイクロプロセッサがこの範囲外の実行リソースを不必要に消費しないようにすることができる。
【0106】
第2のアプリケーションは、リアルタイムの重要度を実現するFPGAシステムに関連している。FPGAシステムは、処理装置をトリガするクロックによってタイミングが調整されるデータストリームであり、データのルーティングを動的に変更することができる。
【0107】
第3のアプリケーションは、特定のスループット制約に従って、および再構成可能な処理に従って、オブジェクトの工業的製造のために構成された工業的処理のシステムに関する。実際、工業的製造方法は、技術的な理由からフローの制約があるデータストリームと見なすことができる。
【0108】
(参考文献)
1. X. K. Do, S. Louise and A. Cohen, Transaction Parameterized Dataflow: A model for context-dependent streaming applications, 2016 Design, Automation & Test in Europe Conference & Exhibition (DATE), Dresden, 2016, pp. 960-965.
2. Haitao Wei, Stephane Zuckerman, Xiaoming Li, Guang R. Gao, A Dataflow Programming Language and its Compiler for Streaming Systems, Procedia Computer Science, Volume 29, 2014, Pages 1289-1298, ISSN 1877-0509.
3. Gustav Cedersjo and Jorn W. Janneck. Software code generation for dynamic dataflow programs. In Proceedings of the 17th International Workshop on Software and Compilers for Embedded Systems (SCOPES '14). ACM, New York, NY, USA, 2014, 31-39.
4. Explanation of ara::com API, AUTOSAR AP Release 17-03.
5. Specification of Time Synchronization for Adaptive Platform, AutoSAR AP Release 17-10
【符号の説明】
【0109】
1 監視システム
3 計算機またはコンピュータ
5 マイクロプロセッサ
7 メモリ
9 取得モジュール
11 監視モジュール
13 形式モデル
15 通信仕様
図1
図2
図3A
図3B
図3C
図4A
図4B