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

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

▶ ミツビシ・エレクトリック・アールアンドディー・センター・ヨーロッパ・ビーヴィの特許一覧

特許7442692ネットワークにおいてメッセージを送信する方法、デバイス及びシステム
(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-02-22
(45)【発行日】2024-03-04
(54)【発明の名称】ネットワークにおいてメッセージを送信する方法、デバイス及びシステム
(51)【国際特許分類】
   H04L 47/43 20220101AFI20240226BHJP
【FI】
H04L47/43
【請求項の数】 11
(21)【出願番号】P 2022578016
(86)(22)【出願日】2021-03-04
(65)【公表番号】
(43)【公表日】2023-04-14
(86)【国際出願番号】 JP2021009697
(87)【国際公開番号】W WO2021250960
(87)【国際公開日】2021-12-16
【審査請求日】2022-08-29
(31)【優先権主張番号】20305628.8
(32)【優先日】2020-06-10
(33)【優先権主張国・地域又は機関】EP
(73)【特許権者】
【識別番号】503163527
【氏名又は名称】ミツビシ・エレクトリック・アールアンドディー・センター・ヨーロッパ・ビーヴィ
【氏名又は名称原語表記】MITSUBISHI ELECTRIC R&D CENTRE EUROPE B.V.
【住所又は居所原語表記】Capronilaan 46, 1119 NS Schiphol Rijk, The Netherlands
(74)【代理人】
【識別番号】100110423
【弁理士】
【氏名又は名称】曾我 道治
(74)【代理人】
【識別番号】100111648
【弁理士】
【氏名又は名称】梶並 順
(74)【代理人】
【識別番号】100122437
【弁理士】
【氏名又は名称】大宅 一宏
(74)【代理人】
【識別番号】100147566
【弁理士】
【氏名又は名称】上田 俊一
(74)【代理人】
【識別番号】100161171
【弁理士】
【氏名又は名称】吉田 潤一郎
(72)【発明者】
【氏名】マンガン、クリストフ
【審査官】和平 悠希
(56)【参考文献】
【文献】特開2017-041769(JP,A)
【文献】米国特許出願公開第2020/0099762(US,A1)
【文献】特表2018-525761(JP,A)
【文献】特開2007-037196(JP,A)
【文献】OPC 10000-14: UA Part 14: PubSub Released 1.04,OPC UA Online Reference,OPC Foundation,2018年02月06日,https://reference.opcfoundation.org/Core/Part14/v104/docs
(58)【調査した分野】(Int.Cl.,DB名)
H04L 12/00-12/66
H04L 41/00-101/695
(57)【特許請求の範囲】
【請求項1】
オープンプラットフォーム通信統一アーキテクチャというタイプの規格に従って運用されるネットワークにおいてネットワークメッセージを送信する方法であって、前記ネットワークは、該ネットワーク上にパブリッシャデバイス及びサブスクライバデバイスを含む通信モードを有し、該方法は、
受信されたネットワークメッセージのペイロード(データセットメッセージ)を抽出することであって、各受信されたネットワークメッセージは、該受信されたネットワークメッセージを送出したデバイスである送出デバイスに関連したパブリッシングオフセットのタイミングを定義する識別子であるライタグループIDを含むことと、
前記ペイロードを同じ組み合わされたネットワークメッセージ内で連結することであって、送出機識別子である前記ライタグループIDは、前記パブリッシングオフセットのタイミングを定義し、それによって、前記ペイロードの連結内の前記受信されたメッセージの前記ペイロードの順序を定義することと、
前記組み合わされたネットワークメッセージにヘッダを追加することであって、前記ヘッダは、パブリッシャデバイスの単一の識別子(パブリッシャID=k)であるパブリッシャ識別子を含み、前記パブリッシャ識別子は、パブリッシャIDのタイプを有し、前記組み合わされたネットワークメッセージを少なくとも1つの選ばれたサブスクライバデバイスに向けるように予め定められることと
を含み、
前記選ばれたサブスクライバデバイスは、前記受信されたネットワークメッセージを送出するネットワークデバイスのコントローラデバイスである方法。
【請求項2】
前記ネットワークデバイスの中で前記方法を実施するデバイスが、前記コントローラデバイス及び/又は前記送出デバイスに対する基準に基づいて選択される請求項に記載の方法。
【請求項3】
前記基準は、少なくとも前記ネットワークの現在のトポロジを含む請求項に記載の方法。
【請求項4】
オープンプラットフォーム通信統一アーキテクチャというタイプの規格に従って運用されるネットワークにおいてネットワークメッセージを送信する方法であって、前記ネットワークは、該ネットワーク上にパブリッシャデバイス及びサブスクライバデバイスを含む通信モードを有し、該方法は、
受信されたネットワークメッセージのペイロード(データセットメッセージ)を抽出することであって、各受信されたネットワークメッセージは、該受信されたネットワークメッセージを送出したデバイスである送出デバイスに関連したパブリッシングオフセットのタイミングを定義する識別子であるライタグループIDを含むことと、
前記ペイロードを同じ組み合わされたネットワークメッセージ内で連結することであって、送出機識別子である前記ライタグループIDは、前記パブリッシングオフセットのタイミングを定義し、それによって、前記ペイロードの連結内の前記受信されたメッセージの前記ペイロードの順序を定義することと、
前記組み合わされたネットワークメッセージにヘッダを追加することであって、前記ヘッダは、パブリッシャデバイスの単一の識別子(パブリッシャID=k)であるパブリッシャ識別子を含み、前記パブリッシャ識別子は、パブリッシャIDのタイプを有し、前記組み合わされたネットワークメッセージを少なくとも1つの選ばれたサブスクライバデバイスに向けるように予め定められることと
を含み、
前記受信されたネットワークメッセージは、同じ前記パブリッシャ識別子を有するヘッダを有する一方、前記受信されたネットワークメッセージは、複数の異なるパブリッシャデバイスによって送出される方法。
【請求項5】
オープンプラットフォーム通信統一アーキテクチャというタイプの規格に従って運用されるネットワークにおいてネットワークメッセージを送信する方法であって、前記ネットワークは、該ネットワーク上にパブリッシャデバイス及びサブスクライバデバイスを含む通信モードを有し、該方法は、
受信されたネットワークメッセージのペイロード(データセットメッセージ)を抽出することであって、各受信されたネットワークメッセージは、該受信されたネットワークメッセージを送出したデバイスである送出デバイスに関連したパブリッシングオフセットのタイミングを定義する識別子であるライタグループIDを含むことと、
前記ペイロードを同じ組み合わされたネットワークメッセージ内で連結することであって、送出機識別子である前記ライタグループIDは、前記パブリッシングオフセットのタイミングを定義し、それによって、前記ペイロードの連結内の前記受信されたメッセージの前記ペイロードの順序を定義することと、
前記組み合わされたネットワークメッセージにヘッダを追加することであって、前記ヘッダは、パブリッシャデバイスの単一の識別子(パブリッシャID=k)であるパブリッシャ識別子を含み、前記パブリッシャ識別子は、パブリッシャIDのタイプを有し、前記組み合わされたネットワークメッセージを少なくとも1つの選ばれたサブスクライバデバイスに向けるように予め定められることと
を含み、
前記ネットワークは、タイムセンシティブネットワーキングというタイプの規格に従って更に運用される方法。
【請求項6】
前記連結されたペイロードは、同じ所定のサイクル継続時間(パブリッシング間隔)内で受信されたメッセージから抽出される請求項1から請求項までのいずれか1項に記載の方法。
【請求項7】
マルチプレクサデバイスとして動作するように選択され、請求項1から請求項までのいずれか1項に記載の方法を実施するように構成されるネットワークデバイス。
【請求項8】
前記ネットワークメッセージを送出するネットワークデバイスと、前記ネットワークメッセージを受信し、請求項1から請求項までのいずれか1項に記載の方法を実施するように構成されるマルチプレクサデバイスとを備えるシステム。
【請求項9】
請求項に記載のシステムのコントローラデバイスであって、所定の前記パブリッシャ識別子を有する前記組み合わされたネットワークメッセージを受信し、前記ペイロードの連結を解釈するように構成されるコントローラデバイス。
【請求項10】
命令を含むコンピュータプログラムであって、該命令は、ネットワークデバイスのプロセッサ(PROCC;PROCD)によって実行されると、請求項1から請求項までのいずれか1項に記載の方法を前記ネットワークデバイスに実施させるコンピュータプログラム。
【請求項11】
請求項1から請求項までのいずれか1項に記載の方法の実施から得られ、したがって、ネットワークのパブリッシャデバイス及びサブスクライバデバイスを含む通信モードを有する前記ネットワークにおいてパブリッシュされるネットワークメッセージのデータを含む信号であって、
該信号は、
パブリッシャデバイスの単一の識別子を含むヘッダのデータと、
前記ネットワークのそれぞれのデバイスによって開始される複数の連結されたペイロードのデータと
を含む信号。
【発明の詳細な説明】
【技術分野】
【0001】
本開示は、ネットワーク上にパブリッシャデバイス及びサブスクライバデバイスを含む通信モードを有するネットワークにおいてメッセージを送信する方法、デバイス、及びシステムに関する。
【背景技術】
【0002】
オープンプラットフォーム通信統一アーキテクチャ(OPC UA:Open Platform Communications Unified Architecture)が、OPCクラシックに加えて多くのベンダー固有のプロトコルに次第に取って代わり、オートメーションにおけるフレキシブルなベストエフォート型通信に広く使用されている。OPC UAは、アプリケーションドメイン及びオートメーション制御階層レベルにわたって均一で標準化されたセキュアな通信を達成するように設計されている。
【0003】
OPC UA仕様は、パブリッシュ/サブスクライブ(Publish/Subscribe)データ交換(以下「PubSub」)の原理に基づく通信を用いて拡張されており、「多対多」通信を含む新たな使用シナリオをもたらす。加えて、OPC UA PubSubとタイムセンシティブネットワーキング(TSN:Time-Sensitive Networking)との統合は、クリティカルなリアルタイム要件を有する通信を可能にするように設計されている。
【0004】
OPC UAに関するより詳細な内容を以下に示す。OPC UAは、IEC62541として標準化されたTCP/IPに基づく産業通信用のクライアントサーバプロトコルである。OPC UAサーバは、オブジェクト指向情報モデルにおいて構造化されたデータ及び機能へのアクセスを提供する。クライアントは、標準化されたサービスのセットを使用して情報モデルとインタラクトする。各サービスは、インタラクション用の要求メッセージ及び応答メッセージを定義する。ただし、通知が生じたときにのみ通知をプッシュするために、サブスクリプションメカニズムも使用することができる。
【0005】
いわゆる「タイムセンシティブネットワーキング(TSN)」に関するより詳細な内容を以下に示す。IEEE802.1規格シリーズ内において、当初、オーディオビデオブリッジング(AVB:Audio Video Bridging)として開発されたリアルタイム通信のためのイーサネットの強化は、近年、タイムセンシティブネットワーキング(TSN)として拡張された。IEEE802.1ASにおいて仕様化されたクロック同期方式及びIEEE802.1Qbvのタイムスロットを介した伝送容量の確保は、リアルタイム制約を有するオートメーションネットワークにおいて使用される基本規格である。
【0006】
産業通信トラフィックタイプが、それらとTSN規格との関係を含めて、産業アプリケーションにおいて見られる種々の一般的なユースケースを満たすように定義されている。産業通信へのTSNの導入は、オープン標準フレームワークであるという利点をもたらすことに加えて、以下のいくつかの技術的改良及び性能改善ももたらす。
・潜在的により高いスループット、
・ブリッジされたネットワークにおける複数のホップにわたる差別化及び保証されたサービス品質を有する接続を混合する際のフレキシビリティ、
・産業ユースケース及び消費者デバイスの双方を対象とした広範な技術の規模の経済。
【0007】
パブリッシュされたメッセージがメッセージのトピックの全てのサブスクライバに転送されるOPC UAにおけるメカニズム「パブリッシュ/サブスクライブ」は、トピックについて多くのサブスクライバに登録を認める。この特徴によって、多くのサブスクライバが、レガシーフィールドバスにおいて実施される通信方式と同様の方法で同じメッセージを受信することが可能になる。パブリッシュされたメッセージの内容は、OPC UAサーバの情報モデルからの変数及びイベントソースの集合体を表すいわゆるパブリッシュドデータセット(PublishedDataSet)によって定義される。パブリッシュドデータセットは、フレキシブルに構成することができ、その説明は、パブリッシュされた情報のセマンティクスを解釈するためにサーバ内で検索することができる。
【0008】
OPC UA規格の仕様(セクション14)は、既存のパブリッシュ/サブスクライブプロトコル、特にMQTT(メッセージキューイングテレメトリートランスポート:Message Queuing Telemetry Transport)及びAMQP(アドバンストメッセージキューイングプロトコル:Advanced Message Queuing Protocol)上へのOPC UA PubSubのマッピングを定義する。これらのプロトコルは、メッセージ配信の中央ブローカを定義し、公衆インターネットにおいて一般に使用される。この規格は、IP規格によって提供されるマルチキャストメカニズムに依拠したカスタムUDPベースの配信プロトコル及び対応するメッセージレイアウト(UADP)も定義する。UADPを使用するとき、サブスクライバは、特定のIPマルチキャストアドレスによって識別されるマルチキャストグループの登録を行う。
【0009】
バイナリー符号化メッセージを用いたこのトランスポートは、少量のデータを頻繁に送信する本番環境によく適合している。このアドレスに送信されたPubSubメッセージは、グループの全てのメンバーに転送される。そのようなマッピングは、パブリッシャの複雑度の大部分を既存のネットワークインフラストラクチャ(ルータ、スイッチ等)に委ねる。最後に、この規格は、データリンクレイヤ、すなわちイーサネットを直接介した、同じUADPレイアウトを用いたPubSubメッセージのトランスポートも定義する。
【0010】
その構成では、OPC UA PubSubをリアルタイムトランスポート用のTSNと統合することができ、UADPペイロードを運ぶイーサネットフレームは、特定のイーサタイプ(0xB62C)によって識別される。イーサネットTSN上へのこのマッピングは、固定されたパブリッシュドデータセットを前提とし、OPC UAサーバに見られるソフトウェア及びネットワークの交換オーバヘッドを伴わずに所望のネットワークメッセージを直接生成する非常に軽量のOPC UA PubSubの実施の可能性を開く。
【0011】
OPC UAにおけるPub/Sub原理に関するより詳細な内容を以下に示す。データセット(DataSet)は、パブリッシャ(Publisher)によって提供されてサブスクライバ(Subscriber)によって消費されるメッセージのペイロードを構成する。パブリッシャ及びサブスクライバは、疎結合され、それらの主要な関係は、データセットと、これらのデータを含むメッセージのパブリッシュ特性と、メッセージ指向ミドルウェア(Message Oriented Middleware)との理解を共用していることである。PubSubメッセージは、ネットワークメッセージ(NetworkMessage)と呼ばれる。それらのメッセージは、以下のものを含む。
・ヘッダ情報(例えば識別データ及びセキュリティデータ)、及び
・1つ以上のデータセットメッセージ(DataSetMessage)(ペイロード)。
【0012】
各データセットメッセージは、データセットから作成される。データセットライタ(DataSetWriter)と呼ばれるパブリッシャの構成要素は、連続的な一連のデータセットメッセージを生成する。データセットのシンタックス及びセマンティクスは、データセットメタデータ(DataSetMetaData)によって記述される。パブリッシャにおけるデータセットの情報の選択及びデータ取得パラメータは、パブリッシュドデータセットと呼ばれる。
【0013】
図1は、これらの異なる役割及びエンティティを示している。データセットは、イベント又は変数値サンプルから作成される。このアプリケーションデータコレクタの構成は、パブリッシュドデータセットと呼ばれる。データセットフィールドは、パブリッシャ内の内部変数、パブリッシャからのイベント若しくはパブリッシャによって収集されたイベント、ネットワークデータ、又はサブデバイスからのデータを表すことができる。データセットの構造及び内容は、データセットメタデータによって定義される。
【0014】
パブリッシュするために、図2に示すように、データセットは、データセットメッセージに符号化され、データセットメッセージは、場合によっては、他のデータセットメッセージと更に組み合わされてネットワークメッセージのペイロードを形成する。データセットライタは、データセットデータを含むデータセットメッセージの符号化及びトランスポート用に構成される。データセットの構成及びデータがパブリッシングのために取得される方法は、OPC UA PubSub規格の仕様において定義されたPubSub構成モデルを使用して構成することができる。
【0015】
データセットメッセージフィールド、データセットメッセージ、ネットワークメッセージ及びトランスポートプロトコルを含むネットワークメッセージの構成における種々のレイヤを図3に示す。
【0016】
データセットメッセージフィールドは、データセットメッセージ内の特定のデータセットフィールドを表すものと定義することができる。データセットフィールドは、実際の値を、その値に関連したステータス及びタイムスタンプ等の付加情報とともに含む。データセットメッセージは、データセットから生成され、ヘッダと、データセットの符号化されたフィールドとからなる。構成に応じて、データセットメッセージヘッダは、以下のような付加情報を含むことができる。
・データセットライタを識別するとともに、パブリッシュドデータセットを間接的に識別する識別子であるデータセットライタId(DataSetWriterId)、
・シーケンス番号、
・タイムスタンプ、
・バージョンID、
・「キープアライブ」ステータス。
【0017】
データコントラクトとしてのデータセットメタデータは、データセットメッセージに含まれるフィールドを定義する。データセットメッセージ及びネットワークメッセージのヘッダの設定は、パブリッシャとサブスクライバとの間の通信コントラクトを定義する。ネットワークメッセージは、データセットメッセージに共通の以下の情報を搬送するヘッダを含むデータセットメッセージのコンテナである。
・パブリッシャId(PublisherId):パブリッシャを識別する。
・セキュリティデータ:メッセージセキュリティをサポートする符号化にのみ利用可能である。関連のある情報は、メッセージマッピングにおいて指定される。
・昇格フィールド(promoted field):ヘッダにおいても送信されるデータセットから選択されたフィールド。
・ペイロード:1つ以上のデータセットメッセージ。
【0018】
データセットメッセージからなるペイロードは、構成されたメッセージセキュリティに従って暗号化することができる。データセットメッセージの個々のフィールドは、暗号化を「免れる(escape)」ように「昇格(promoted)」させることができ、したがって、フィルタリング及び転送に使用することができる。昇格フィールドの構成は、ネットワークメッセージのフォーマット及び使用されるプロトコルに依存する。いずれにしても、ネットワークメッセージヘッダは、フィルタリング及び転送を可能にするために暗号化されない。
【0019】
次に、このメッセージ交換に関与するエンティティに関して、パブリッシャは、(図2に示すように)ネットワークメッセージを送信するPubSubエンティティである。このエンティティは、任意のエンティティであり、必ずしも特定のネットワークノード(例えば、特定のIPアドレス又はMACアドレスを有するノード)又はアプリケーションでない。パブリッシャは、通常、メッセージを送信する1つ以上のネットワークノードからなることができる。
【0020】
単一のパブリッシャが、複数のパブリッシュドデータセット及び複数のデータセットライタをサポートすることができる。データセットライタは、パブリッシャの論理的な構成要素である。メッセージ送信のために、メッセージの作成は、パブリッシュドデータセットに従って、パブリッシュされるデータ(データセット)を収集し、データセットの個々のフィールドを生成することから開始する。
【0021】
データセットライタは、その後、データセットからデータセットメッセージを作成する。同じライタグループ(WriterGroup)に属するデータセットライタからのデータセットメッセージは、単一のネットワークメッセージ内に挿入することができる。データセットメッセージのフォーマット及び符号化は、いくつかの構成パラメータ(ここでは定義しない)によって定められる。
【0022】
ネットワークメッセージは、PubSub接続(PubSubConnection)上で定義されるパブリッシャIdとともに、データセットメッセージ、データセットライタId、データセットクラスId(DataSetClassId)、データセットメタデータから得られる構成バージョン(ConfigurationVersion)から作成される。メッセージの構造は、プロトコル固有である。
【0023】
ネットワークメッセージは、ライタグループに関連付けられたパブリッシング間隔(PublishingInterval)に基づいて、各パブリッシング間隔の開始からの所与のオフセットであるパブリッシングオフセット(PublishingOffset)において、サイクリックに送信することができる。
【0024】
サブスクライバは、どのデータセットメッセージについて、どのメッセージ指向ミドルウェア上でサブスクライブするのかを判断するように構成され、及び/又は、発見メカニズムを使用してこれを判断する。ネットワークメッセージヘッダ内の暗号化されていないデータは、サブスクライバが、関連のあるパブリッシャ、データセットメッセージ、データセットクラス(DataSetClass)を識別してフィルタリングするために使用される。
【0025】
データセットメッセージは、関連があると判断されると、データセットへの復号化を行う対応するデータセットリーダ(DataSetReader)に転送される。その結果のデータセットは、その後、サブスクライバ内で更に処理又はディスパッチされる。
【0026】
サブスクライバは、接続を確立することによって、例えばUDPマルチキャストグループ又はイーサネットマルチキャストグループに参加することによって、メッセージ指向ミドルウェアによってサポートされる配信グループに登録される。
【0027】
サブスクライバは、関連のあるネットワークメッセージにおいて対象となるデータセットメッセージを各データセットリーダにディスパッチし、各データセットリーダは、それらを、データセットメタデータにおいて提供される情報を使用してデータセットに復号化する。
【0028】
図4は、PubSub構成要素と、種々のメッセージ符号化ステージを作成する際のそれらの役割との間の関係を要約している。PubSubメッセージマッピングに関して、以下の説明は、UDP/IP又はイーサネットを介してトランスポートすることができるメッセージのUADP符号化に関連した一例として与えることができる。UADPメッセージマッピングは、種々の任意選択のヘッダフィールドと、フィールド設定と、種々のメッセージタイプ及びデータ符号化とを定義する。
【0029】
一般的なUADP ネットワークメッセージのレイアウトを図5に示す。PubSub通信構成パラメータに応じて、異なるヘッダ及びフィールドが存在する又は存在しない。セキュリティを使用するとき、ペイロード及びパディングフィールドが暗号化され、署名及び暗号化がアクティブとして構成されている場合には、ネットワークメッセージ全体が署名される。ネットワークメッセージは、署名のみがアクティブである場合にのみ署名される。
【0030】
図6は、ネットワークメッセージのペイロード及びペイロードヘッダの一般的なフォーマットを更に示している。ここでも同様に、ヘッダ及びフィールドは、データセットメッセージのレイアウト構成に応じて存在する場合もあるし、無視される場合もある。
【0031】
OPC UA UDP及びOPC UAイーサネットの2つのトランスポートプロトコルが、ネットワークメッセージのトランスポート用に指定される。以下の詳細な説明では、OPC UAイーサネットのみが説明される。UADP ネットワークメッセージは、1522バイトの最大サイズのVLANタグ付きイーサネットIIフレームのペイロードとしてトランスポートされる。UADP通信用にIEEEに登録されたOPC UAイーサタイプは0xB62Cである。
【0032】
TSNを介したトランスポートの場合には、ライタグループによって作成されたネットワークメッセージは、IEEE802.1CBに仕様化されたストリーム識別機能によって識別することができるTSNストリームを介して送信される。通常の識別機能は、デスティネーションMACアドレス又はソースMACアドレスを、ネットワークメッセージをカプセル化したイーサネットフレームのVLAN-IDと組み合わせて使用する。
【0033】
TSNタイミングパラメータ上へのPubSubレベルタイミングパラメータ(パブリッシング間隔及びパブリッシングオフセット)のマッピングは、主として、送信サイクルと、これらのサイクル内の送信時刻、すなわち送信オフセットとを定義することを可能にするIEEE802.1Qbvによって提供されるスケジューリング方式を使用することによって行われる。
【0034】
固定されたレイアウトデータを有する周期的な通信のネットワークメッセージのフォーマットを以下に説明する。ネットワークメッセージ及びデータセットメッセージのUADPヘッダフォーマットは、ヘッダ内の個々のフィールドを有効又は無効にすることによって、フレキシブルであるとともに種々のユースケースをサポートするように設計される。
【0035】
その結果、可能なヘッダフィールドの組み合わせの数は、それらの実施態様の複雑度を増加させる。逆に、特定のユースケースを有する或るアプリケーションドメインは、ヘッダレイアウトが、種々のユースケースのフレキシビリティ、相互運用性及びサポートの間の妥協を提供するヘッダオプションの妥当なセットを含む構成に依拠することができる。
【0036】
OPC UAパート14の付属書Cは、これらのユースケースのうちの1つ、すなわち、リアルタイムデータのサイクリックな交換におけるPubSubの使用を示している。この構成では、あらゆるパブリッシング間隔の際に伝送されるデータのレイアウトは固定され、構成によってパブリッシャ及びサブスクライバから知られている。最適化は、データセットメッセージのサイズが一定であるときに更に推し進めることもできる。
【0037】
次に、以下の条件が仮定される。
・各ネットワークメッセージは、同じ数のデータセットメッセージを含む、
・ネットワークメッセージ内のデータセットメッセージのシーケンスは、あらゆるパブリッシング間隔にわたって同一である、
・あらゆるデータセットメッセージ内のフィールドのレイアウトは、あらゆるパブリッシング間隔にわたって同一である。
【0038】
パブリッシャId及びライタグループId(WriterGroupId)は、ライタグループを識別する。ネットワークメッセージ番号(NetworkMessageNumber)は、いくつかのネットワークメッセージにおいてそれらのデータセットを送信するライタグループに使用される。グループバージョン(GroupVersion)は、サブスクライバが、データセットメッセージ及びそれらのデータセットフィールドの予想されるレイアウトを検証することを可能にする。
【0039】
図7に示すヘッダのレイアウトは、セキュリティが実施されないときのこのユースケースを示している。セキュリティ(例えば署名のみ)が実施されるとき、ヘッダレイアウトは、図8aに示すような追加のセキュリティヘッダ及び署名を含む。データセットメッセージのヘッダは、図8bに示すフィールドに削減される。
【0040】
メッセージレイアウトの例を以下に示す。第1の例は、セキュリティを有しない固定されたメッセージレイアウトである。この構成は、あらゆるネットワークメッセージが一定のヘッダ及びデータセットフィールドのレイアウトを有することを保証する。メッセージの符号化及び復号化は、全てのフィールドの一定のオフセットに起因して簡単化される。ペイロードヘッダ(Payload Header)は省略され、このヘッダが通常含む情報は、データセットメタデータ、データセットライタ及びライタグループの設定からサブスクライバによって導出される。この構成は、構成によって保証することができる各データセットメッセージの一定のサイズを仮定する。
【0041】
適切な構成は、データセットメッセージの数及びネットワークメッセージ内のそれらのシーケンスが、送信された全てのネットワークメッセージにわたって同一のままであることも保証する。これらの特性を図9に示す。
【0042】
第2の例は、セキュリティを有する固定されたメッセージレイアウトである。同じ構成は、セキュリティを用いて拡張することができ、図10に示すコンパクト化されたネットワークメッセージフォーマットを与える。
【発明の概要】
【発明が解決しようとする課題】
【0043】
OPC UAは、その場合に、多種多様なアプリケーションドメインをサポートすることができる複雑なシステムのエンティティ間の情報の交換のための非常にフレキシブルな方式を指定する。このフレキシビリティは、これらの交換をサポートする通信プロトコルに反映される。
【0044】
このフレキシビリティは、図5に示す基本のネットワークメッセージのフォーマットによって示されるように、潜在的に拡大するオーバヘッドを犠牲にして得られる。図19は、セキュリティを有しないPubSub ネットワークメッセージに見ることができる種々のヘッダによって引き起こされるオーバヘッドをまとめた表を示している。
【0045】
(N+1)個のデータセットライタの場合、このレイアウトは、
21+11+[1+(N+1)×2]+10+PF+(N+1)×2+PLバイト
の最大メッセージ長をもたらす可能性がある。
【0046】
フィールドが昇格されない(ネットワークメッセージの非暗号化部分に複製されない)ことを考慮すると、これは、47+4Nバイトの潜在的なオーバヘッドを与える。
【0047】
上述したコンパクト化されたUADPレイアウトを使用してサイクリックなデータを送信するとき、オーバヘッドは、図20に示す残りの白地の行によって要約されるように削減される。
【0048】
データセットライタの数がいくつであっても、セキュリティを有しないコンパクト化されたレイアウトは、
4+11+PLバイト
の最大メッセージ長をもたらす可能性があり、15バイトの潜在的なオーバヘッドを与える。
【0049】
コンパクト化されたUADPレイアウトは、PubSubオーバヘッドの大幅な削減をもたらすが、PubSubオーバヘッドは、そのアプリケーション環境、特にペイロードが多くの場合に約100バイトに制限される高速イーサネットTSNベースの制御の環境では依然として考慮されなければならない。
【0050】
そのような構成では、
・MACデスティネーションアドレス(6バイト)、
・MACソースアドレス(6バイト)、
・VLANタグ(4バイト)、
・イーサタイプ(2バイト)、
から構成される最小のMACレイヤイーサネットオーバヘッドが、別の18バイトをOPC UAメッセージに加える。
【課題を解決するための手段】
【0051】
本発明は、この状況を改善することを目的とする。そのため、本発明は、ネットワーク上にパブリッシャデバイス及びサブスクライバデバイスを含む通信モードを有するネットワークにおいてメッセージを送信する方法であって、該方法は、
・受信されたメッセージのペイロードを抽出し、当該ペイロードを同じ組み合わされたメッセージ内で連結することと、
・上記組み合わされたメッセージにヘッダを追加することであって、当該ヘッダは、パブリッシャデバイスの単一の識別子を含み、当該パブリッシャ識別子は、組み合わされたメッセージを少なくとも1つの選ばれたサブスクライバデバイスに向けるように予め定められることと
を含む方法を対象とする。
【0052】
そのような実施態様の一例は、以下で解説する図14に示されている。この図は、特に、前述の組み合わされたメッセージの構造(1つのヘッダを有するが、それぞれのデバイスから到来する多数の連結されたペイロードを有する)を示している。この実施態様によって、とりわけ、通常のコントローラデバイスのオーバヘッドを削減することが可能になる。
【0053】
通常、一実施の形態において、前述の選ばれたサブスクライバデバイスをそのコントローラデバイスとすることができる。このコントローラデバイスは、前述の受信されたメッセージを送出したネットワーク内のデバイスを制御する。
【0054】
特に、これらのネットワークデバイスの中でこの方法を実施する1つのデバイスを、コントローラデバイス及び/又は送出デバイスに対して基準に基づいて選択することができる。より詳細には、上記に示したような方法は、これらの送出デバイスのうちの1つによって実施することもできるし、これらの送出デバイスに接続され、それらのコントローラデバイスに関連した1つのデバイスによって実施することもできる。
【0055】
通常、前述の基準は、少なくともネットワークの現在のトポロジ(一方において送出デバイスと他方においてそれらのコントローラデバイスとの間の最適な中間デバイスを指定して上記方法を実施するために考慮される)を含むことができる。
【0056】
一実施の形態において、受信されたメッセージは、同じパブリッシャ識別子(図14におけるパブリッシャId=k)を有するヘッダを有する一方、受信されたメッセージは、複数の異なるパブリッシャデバイスによって送出される。この方法を実行するデバイスは、その後、これらのメッセージを識別し、図14に示すような1つの単一の組み合わされたメッセージに集約することができる。
【0057】
各受信されたメッセージは、当該受信されたメッセージを送出したデバイスに関連した識別子(通常のパブリッシャIdと異なる識別子とすることができ、例えば、これらのメッセージの受信の順序を定義することができるいわゆる「ライタグループId」(図14では、=1,2,3・・・)とすることができる)を含むことができる。加えて、この送出機識別子は、その実施の形態において、前述のペイロードの連結内の受信されたメッセージのペイロードの順序を定義する。これらの識別子は、規格の仕様「オープンプラットフォーム通信統一アーキテクチャ」から既に知られている。
【0058】
より一般的には、一実施の形態において、この方法に関与するデバイスを接続するネットワークは、「オープンプラットフォーム通信統一アーキテクチャ」というタイプの規格に従って運用され、パブリッシャデバイスの前述の単一の識別子はパブリッシャID識別子である。
【0059】
より詳細には、ネットワークは、「タイムセンシティブネットワーキング」というタイプの規格に従って更に運用することができる。
【0060】
通常、上記に示したように、送出機識別子は、パブリッシングオフセットのタイミングを定義し、それによって、上記ペイロードの連結内の受信されたメッセージのペイロードの順序を定義するライタグループIDのタイプとすることができる。
【0061】
その上、図14に示すように、連結されたペイロードは、同じ所定のサイクル継続時間で受信されたメッセージから抽出することができる。通常、図15に示す実施の形態において、このサイクル継続時間は、マルチプレクサデバイスのパブリッシング間隔に対応することができる。
【0062】
本発明は、マルチプレクサデバイスとして動作するように選択され、上記に示したような方法を実施するように構成される、ネットワークデバイスも対象とする。このデバイスは、現在のトポロジ(例えば、他のデバイスに対するネットワークにおけるその中心性)等の基準に従って、及び/又は、以下に示すように、デバイスのそれぞれの特定の機能にも従って選択することができる。
【0063】
本発明は、メッセージを送出するネットワークデバイスと、上記メッセージを受信し、上記に示したような方法を実施するように構成されるマルチプレクサデバイスとを備えるシステムも対象とする。
【0064】
本発明は、そのようなシステムのコントローラデバイスであって、
・所定のパブリッシャ識別子を有する組み合わされたメッセージを受信し、
・ペイロードの連結を解釈するように構成される
コントローラデバイスも対象とする。
【0065】
本発明は、命令を含むコンピュータプログラムであって、該命令は、ネットワークデバイスのプロセッサによって実行されると、上記に示したような方法をそのネットワークデバイスに実施させる、コンピュータプログラムも対象とする。本発明は、そのような命令を記憶する非一時的コンピュータ記憶媒体も対象とする。
【0066】
ネットワークのデバイス(通常は例えばコントローラデバイス)における上記に示すような組み合わされたメッセージ構造を含む信号の受信は、このデバイスにその信号を特定の方法で解釈させるので、本発明は、そのような信号も対象とする。この信号は、通常、ネットワークのパブリッシャデバイス及びサブスクライバデバイスを含む通信モードを有するネットワークにおいてパブリッシュされたメッセージのデータを含み、この信号は、
・パブリッシャデバイスの単一の識別子を含むヘッダのデータと、
・ネットワークのそれぞれのデバイスによって開始される複数の連結されたペイロードのデータと
を含む。
【0067】
本発明の可能な実施形態のより詳細な内容及び利点を、添付図面を参照して以下に示す。
【図面の簡単な説明】
【0068】
図1】従来のパブリッシュ/サブスクライブ方式を示す図である。
図2】データセット及びデータセットメッセージを示す図である。
図3】PubSubメッセージレイヤ及びカプセル化を示す図である。
図4】PubSubエンティティ及び交換メッセージを示す図である。
図5】一般的なUADP ネットワークメッセージのフォーマットを示す図である。
図6】ネットワークメッセージのペイロードの詳細及びデータセットメッセージのヘッダフォーマットを示す図である。
図7】セキュリティを有しないサイクリックなPubSub通信用のコンパクト化されたネットワークメッセージのフォーマットを示す図である。
図8A】署名のみを有するサイクリックなPubSub通信用のコンパクト化されたネットワークメッセージのフォーマットを示す図である。
図8B】署名のみを有するサイクリックなPubSub通信用のコンパクト化されたネットワークメッセージのフォーマットを示す図である。
図9】セキュリティを有しない固定のコンパクト化されたメッセージレイアウトを示す図である。
図10】セキュリティ(署名のみ)を有する固定のコンパクト化されたメッセージレイアウトを示す図である。
図11】産業制御用のネットワークトポロジと、実施形態の一例に従って本発明を実施する特定のトポロジ(図11の下部)の使用とを示す図である。
図12】従来技術によるコントローラデバイスPLCに向けた独立したネットワークメッセージを示す図である。
図13】本発明による組み合わされたネットワークメッセージを示す図である。
図14】マルチプレクサの動作を示す図である。
図15】実施形態の一例における多重化レイテンシを最小にするネットワークメッセージのスケジューリングを示す図である。
図16】いくつかのデバイス、この例ではネットワーク内のいくつかのコントローラを有するシステムを概略的に示す図である。
図17】ネットワークのトポロジ及び/又はネットワーク内のデバイスの機能に従って作成され、特定のコントローラにリンクされたデバイスの各グループの可能なマルチプレクサデバイスを定義する対応表を示す図であり、このコントローラは、そのグループのデバイスによってパブリッシュされたメッセージに対するサブスクライバとして定義される。
図18】本発明による方法(場合によっては、本発明によるコンピュータプログラムの一般的なアルゴリズムを表す)の可能なステップを示す図である。
図19】セキュリティを有しないPubSub ネットワークメッセージに見ることができる異なるヘッダによって引き起こされるオーバヘッドをまとめた表を示す図である。
図20】サイクリックなデータがコンパクト化されたUADPレイアウトを使用して送信されるときに、セキュリティを有しないPubSub ネットワークメッセージに見ることができる種々のヘッダによって引き起こされるオーバヘッドをまとめた表を示す図である。
【発明を実施するための形態】
【0069】
本発明は、デバイス(通常、ネットワークにおける通信デバイスとしてのセンサ及び/又はアクチュエータ)のセットによって送信された独立したネットワークメッセージを単一のネットワークメッセージに組み合わせることによってPubSub通信におけるオーバヘッドを削減することを提案する。以下に示すように、マルチプレクサデバイス(図11の下部の参照符号mux)が、そのために以下のことを実施することができる。
・デバイスのPubSubパブリッシング機能の適合された構成を使用する。
・PubSub多重化機能を実施する。この多重化は、とりわけ、ネットワークトポロジにおけるロケーションに依存する可能性がある。
・ネットワークメッセージのスケジューリング機能を実施する。
【0070】
この実施によって、当初デバイスのセットによって生成された複数のネットワークメッセージを、サブスクライバによって受信される単一のネットワークメッセージに組み合わせることが可能になる。一実施形態において、サブスクライバは、単一のエンティティとすることができ、好ましくは、(図11に示すようなPLCリンクにわたる)ネットワークトポロジにおけるデバイス(センサ及び/又はアクチュエータ)のセットをローカルに制御するいわゆる「プログラマブルロジックコントローラ」(以下、PLC(Programmable Logic Controller))等のコントローラデバイスとすることができる。
【0071】
図11は、PLC(プログラマブルロジックコントローラ)がデバイス(センサ及び/又はアクチュエータ)のセットを制御する産業生産ライン又は機械内に見ることができる制御トポロジの通常の実施形態を示している。コントローラとデバイスとの間の情報及びコマンドは、サイクリックに交換され、各デバイスは、通常、短い情報データ(例えば、16ビットコマンド、8ビットカウンタ値等)をハンドリングする。
【0072】
従来技術の解決策では、OPC UA PubSub通信を使用するとき、簡単な構成は、パブリッシャ及び/又はサブスクライバを含む各デバイスを有することとすることができる。そのようなマッピングでは、パブリッシャは、デバイスによって送信されるデータセットメッセージを含むネットワークメッセージを生成するライタグループを含む。各デバイスは、その場合に、図12に示すように、PLCリンク上に一連のメッセージを生成するそれ自身の独立したネットワークメッセージを送信する。
【0073】
各サイクル内で対処することができるデバイスの数は、以下のものの関数である。
・サイクルの継続時間、
・ネットワークメッセージの長さ。
【0074】
ネットワークメッセージのオーバヘッドの総量、すなわちイーサネットオーバヘッド及びPubSubオーバヘッドによって占有されるリンク容量の部分は、以下の2つの二重の効果を有する。
・一定数のデバイスの制御サイクル継続時間の制限、
・1つのサイクル内で制御されるデバイスの数の制限。
【0075】
イーサネットTSNネットワーク上でOPC UA PubSubを実施するとき、イーサネットフレームヘッダに起因したオーバヘッドは圧縮可能でない。すなわち、双方のMACアドレス、VLANタグ及びイーサタイプは、TSNブリッジによる対応するストリームのハンドリングに必要とされる。したがって、PubSubオーバヘッドの削減のみが上述した従来技術の制限の克服を可能にする。
【0076】
実際、図12及び図13の比較によって示すように、図13に示すような本発明による
・異なるデバイスのペイロードを集約するとともに、
・1つの単一のパブリッシャを識別する単一のヘッダと、
図13の例における単一のイーサネットヘッダと、
を有する単一のネットワークメッセージが、上述したオーバヘッドを制限することを可能にする。
【0077】
そのような単一のネットワークメッセージのリーダの他方では、PLCのサブスクライバエンティティのリーダグループ(ReaderGroup)が、本明細書において以下に示すように、そのような単一のネットワークメッセージで受信されたデータセットメッセージを適切に解釈して多重分離するように構成される。
【0078】
デバイスのパブリッシャ構成に関して、ネットワークメッセージヘッダに関連した構成は、一実施形態において、ネットワークメッセージを組み合わせなければならない全てのデバイスが、分散したパブリッシャを形成するとみなされ、同じパブリッシャIdを用いて構成されるようになっている。
【0079】
グループヘッダ(Group Header)に関連した構成は、各デバイスがそれらのネットワークメッセージを、パブリッシャ内でデバイスを識別する特定のライタグループIdとともに送信するようになっている。
【0080】
ネットワークメッセージ番号は、所与のライタグループが、パブリッシング間隔又はサイクルごとに1つのネットワークメッセージしか送信しないという制約下では無視することができる。ライタグループがパブリッシング間隔ごとに数個のネットワークメッセージを送信する場合には、それらのネットワークメッセージは、一貫したネットワークメッセージ番号とともに連続して送信される。
【0081】
シーケンス番号(SequenceNumber)は、ライタグループによる各ネットワークメッセージの送信の際に単調増加する。
【0082】
ネットワークメッセージのペイロードに関連した構成は、ペイロードのレイアウトが、OPC UAパート14の付属書Cに記載されているように保持されるようになっている、すなわち所定の一連の固定フォーマットデータセットメッセージである。
【0083】
データセットメッセージ内の個々のデータセットフィールドは、変更されずに保持される。
【0084】
各データセットメッセージ内のデータセットフィールドのうちの1つは、データセットメッセージ全体にわたって計算された完全性チェックコードの挿入用に確保することができる。この完全性コード(例えばCRC16)は、その後、デスティネーションサブスクライバエンティティにおけるデータセットリーダが、データセットメッセージの有効性をチェックするために使用することができる。
【0085】
次に、多重化機能を以下に説明する。
PubSubマルチプレクサは、イーサネットカプセル化ネットワークメッセージをそのネットワーク入力を介して受信することができ、組み合わされたイーサネットカプセル化ネットワークメッセージをそのネットワーク出力を介して送信する。PubSubマルチプレクサは、図11の下部に示すように、少なくとも2つの入力と単一の出力とを有する。
【0086】
デバイス内に統合されるとき、マルチプレクサの少なくとも1つの入力は、マルチプレクサと同じ場所に配置されたアプリケーションによって生成される未処理のネットワークメッセージ、すなわちイーサネットフレームにカプセル化されていないネットワークメッセージを受信する。
【0087】
図14に示すように、マルチプレクサは、ネットワークメッセージの組み合わせを行う以下のいくつかのデータ構造及び変数に依拠する。
・各パブリッシャId、すなわち受信されたネットワークメッセージが組み合わされる各パブリッシャ、に関連付けられたペイロード送信バッファ(PLTxBuf)。
・受信されたネットワークメッセージが組み合わされるパブリッシャに含まれる各ライタグループに関連付けられたペイロードオフセット(PLOffset)。
【0088】
PLTxBufkは、パブリッシャkに関連付けられている。
PLOffsetkiは、パブリッシャk(パブリッシャId=k)に含まれるライタグループi(ライタグループId=i)に関連付けられている。PLOffsetkiは、パブリッシャId=k及びライタグループId=iとともに受信されたネットワークメッセージのペイロード(データセットメッセージ)が記憶されるPLTxBufkのベースに対するオフセットを示す。
【0089】
マルチプレクサによって生成されるネットワークメッセージは、以下の情報を含む。
・ネットワークメッセージヘッダ内:パブリッシャId=k
・グループヘッダ内:
ライタグループId=mux。ここで、muxは、マルチプレクサに関連付けられた値である。
グループバージョン=構成によって固定された、マルチプレクサエンティティに関連付けられた値。
ネットワークメッセージ番号=1:パブリッシング間隔ごとに1つのネットワークメッセージのみがネットワークメッセージの組み合わせから生成されると仮定される。
シーケンス番号=新たなネットワークメッセージが生成されるごとにマルチプレクサのネットワークメッセージ生成機能によってインクリメントされる値。
【0090】
組み合わされたネットワークメッセージ内のペイロードのレイアウト、特にデータセットメッセージの順序は、マルチプレクサ構成によって定義される。
【0091】
好ましい構成は、マルチプレクサによる余分な並べ替えを回避するために、特定のライタグループに関連付けられたデータセットメッセージを、着信したネットワークメッセージ内において当初からそうであるようにグループ化された状態に維持することである。
【0092】
ネットワークメッセージのスケジューリングを図15に示す。通常、デバイス及びマルチプレクサに共通のパブリッシング間隔を利用して、ネットワークメッセージの組み合わせ動作のレイテンシを削減することが可能である。これは、デバイスに含まれるライタグループごとに適切なパブリッシングオフセットを構成することによって達成することができる。実際、TSNタイミングパラメータ上へのPubSubレベルタイミングパラメータ(パブリッシング間隔及びパブリッシングオフセット)のマッピングが、主として、送信サイクルに加えてこれらのサイクル内の送信時刻、すなわち送信オフセットを定義することを可能にするIEEE802.1Qbvによって提供されるスケジューリング方式を使用することによって行われることを想起されたい。サイクリックな送信タイミングは、そのようなオフセット規格制約によって上記のように定義することができる。
【0093】
図15(ネットワーク伝播遅延又は内部伝播遅延によって引き起こされる可能性があるレイテンシを考慮していない説明図)に示すように、デバイスライタグループのパブリッシングオフセットは、マルチプレクサがネットワークメッセージの組み合わせを行うために必要とされる最小のヘッドルームが設けられ、したがって、最小の多重化レイテンシが保証されるように構成することができる。
【0094】
次に図16を参照すると、デバイスDEVi、DEVj、・・・がパブリッシャであるときにPLC-Aがサブスクライバとなるように、複数のデバイスDEVi、DEVj、・・・をコントローラPLC-Aにリンクすることができる。他のコントローラ(PLC-B等)をネットワークに設けることが可能であり、他のパブリッシャデバイスDEVk、DEVl等にリンクすることができる。もちろん、デバイスDEVi、DEVj、・・・の中の1つ又はいくつかのデバイスを、第2のコントローラPLC-Bのパブリッシャとすることもできるし、逆に、DEVk、DEVl等の中の1つ又はいくつかのデバイスをコントローラPLC-Aのパブリッシャとすることもできる。
【0095】
ネットワークの少なくとも1つのノードは、デバイスDEVi、DEVj等によって送信されたPubSubメッセージを処理するマルチプレクサとして動作することができる。通常(強制的にということではない)、マルチプレクサは、DEVi、DEVj等の中で、ネットワークのトポロジ及び/又はノードのそれぞれの機能等に従って選ばれたデバイスとすることができる。任意選択で、いくつかのマルチプレクサは、一方においてデバイスDEVi、・・・、DEVmによって送信されたメッセージと、他方においてデバイスDEVm+1、・・・、DEVjによって送信されたメッセージとをそれぞれ処理するために選ぶことができる。ここで、第3のマルチプレクサが、デバイスDEVi、・・・、DEVmのグループと、DEVm+1、・・・、DEVjのグループとの双方から受信されたPubSubメッセージを処理して、それらを共通のコントローラPLC-A用に組み合わせることができる。
【0096】
したがって、ネットワークのノードのうちの少なくともいくつかは、図13及び図14に示すように、異なるPubSubメッセージを単一のメッセージに組み合わせ、異なるペイロード(データセットメッセージ)を加えるが単一のヘッダを維持するために多重化機能を有するようにプログラミングすることができる。通常、図14の例では、メッセージを多重化するノードエンティティは、そのような多重化機能を用いてプログラミングされるデバイスmである。他のデバイス1、2、・・・、nは、同じパブリッシャ識別子パブリッシャID=kを有するそれらのメッセージをパブリッシュするようにプログラミングすることができる。このパブリッシャ識別子は、mと等しいものとすることもできるし、mと異なるものとすることもできる。デバイスmが、パブリッシャID=kの下でパブリッシュされたメッセージを受信したとき、デバイスmは、それらを組み合わせるようにプログラミングされ、より詳細には、図15を参照して上記で説明したように、それらのそれぞれのパブリッシングオフセットを考慮するために、それらのペイロードを、各メッセージヘッダに示されたライタグループIDに応じた順序で連結するようにプログラミングされる。別の実施形態において、図14のパブリッシャデバイス1、2、・・・、nは、それらのメッセージをそれら自身のパブリッシャID(1、2、・・・、n)とともにパブリッシュするようにプログラミングすることができ、多重化デバイスmは、対応するデバイス1、2、・・・、nから受信されたメッセージを組み合わせるために、これらの識別子であるパブリッシャID(1、2、・・・、n)を識別するようにプログラミングすることができる。
【0097】
図16を再び参照すると、各デバイスは、通常、メモリMEMDと協働するプロセッサPROCDに接続された通信インタフェースCOMDを備えることができ、メモリMEMDは、パブリッシャのそれらの識別子であるパブリッシャID、ライタグループのそれらの識別子等のデータと、ペイロードととりわけそのような識別子を含むヘッダとを有するネットワークメッセージを作成して送信するコンピュータプログラムの命令とを記憶する。それらのパブリッシャIDが多重化デバイスのパブリッシャIDIに置き換えられるいくつかの実施形態において、コンピュータプログラムは、そのような機能を適用することができる。より詳細には、これらのデバイスのうちの1つが、(例えばネットワークのトポロジに従って)多重化デバイスとして動作するように指定された場合に、コンピュータプログラム(このデバイスのメモリMEMDに記憶される)は、そのような多重化機能を用いて強化することができる。
【0098】
その上、各コントローラPLCも、メモリMEMCと協働するプロセッサPROCCに接続された通信インタフェースCOMCを備えることができ、メモリMEMCは、とりわけ、マルチプレクサデバイスによってパブリッシュされた、組み合わされたメッセージ(及びその組み合わされたペイロード)を解釈するコンピュータプログラムの命令を記憶する。
【0099】
次に図17を参照すると、とりわけネットワークトポロジ及び/又はネットワークにおけるデバイス機能に従って対応表を(例えばネットワークスケジューラによって)定義することができる。この表は、したがって、各コントローラPLC-A;PLC-B等については、以下のものを定義することができる。
・このコントローラのパブリッシャデバイスとすることができるデバイス(それぞれDEVi、DEVj等;DEVk、DEVl等)、及び
・そのようなパブリッシャデバイスによってパブリッシュされたメッセージを組み合わせるマルチプレクサデバイス(DEVm1;DEVm2)。
【0100】
コントローラPLC-A、PLC-B等がいくつかのメッセージを受信し、それらのヘッダを解釈するためのオーバヘッドは、したがって、コントローラ側において単一のメッセージで受信されたペイロードのみを処理するために、マルチプレクサDEVm1、DEVm2において追放することができる。
【0101】
その上、各コントローラは、1つのサイクル内でより多くのメッセージを処理し、その後、より多くのデバイスを制御することもできるし、同じ数のデータの送信(又は最終的に同じ数のデバイスの制御)を行う制御サイクルをより短くすることもできる。
【0102】
次に図18を参照すると、第1のステップS1において、図17を参照して上記に示したような対応表を(例えばネットワークスケジューラ側において)定義することができる。この表の命令は、ステップS2において少なくとも各マルチプレクサデバイスに送信することができる。各マルチプレクサデバイスは、一実施形態において少なくとも以下のものを記憶する。
・マルチプレクサデバイスm及び対応するコントローラPLC-AがリンクされるグループのパブリッシャID=k、及び
・任意の今後組み合わされるネットワークメッセージのヘッダが含むライタグループID=m。
【0103】
このステップS2では、メッセージがサブスクライバとしてのPLC-Aを用いてパブリッシュされるときにパブリッシャID=kを使用するために、パブリッシャID=kもデバイスDEV1、DEV2等に送信することができる。コントローラPLC-Aは、組み合わされたメッセージがそのようなパブリッシャIDとともに受信されたときに、この組み合わされたメッセージを考慮するために、パブリッシャID=kも記憶することができる。
【0104】
この実施形態においては、ステップS3において、マルチプレクサデバイスMUXは、デバイスDEV1、DEV2、DEV3等によってパブリッシュされたメッセージを、パブリッシャID=k(マルチプレクサデバイスにそれらのメッセージを考慮させる)及びそれら自身のライタグループID=1、3、2等とともに受信する。これらのそれぞれの識別子であるライタグループID=1、3、2に基づいて、マルチプレクサデバイスは、ステップS4において、対応するオフセットを用いて、これらのメッセージのペイロードの順序を管理し、場合によっては、その順序を並べ替える(ペイロードの順序は、例えば#1、次に#2、次に#3となる)ように構成される。
【0105】
グループ(パブリッシャID=k)からメッセージを受信し、それらのペイロードを組み合わせるステップS3及びS4は、1つのサイクルがステップS5において終了するまで実行することができる。好ましくは、ペイロードは、メッセージがデバイスDEV1、DEV2及びDEV3から受信されるとすぐに組み合わされ、ペイロードの組み合わせを実施するためにサイクルの終了を待つ必要はない。そのサイクルの継続時間は、図15に示すように、マルチプレクサデバイスのパブリッシング間隔によって定義することができる。パブリッシングオフセットは、ネットワークメッセージを送信することができる時刻をサイクルの開始を基準として定義する。そのために、パブリッシング間隔及びパブリッシングオフセットは、ステップS2においてマルチプレクサデバイスによって記憶される他のデータとすることができる。
【0106】
サイクルの終了前(テストS5からの矢印KO)、マルチプレクサは、デバイスDEV1、DEV2、DEV3から連続して受信され、その順序で配置されたメッセージの連続するペイロードを含む連結されたネットワークメッセージを送信することができる。マルチプレクサは、このペイロードに少なくとも以下のものを追加する。
・コントローラPLC-Aが、その順序で配置されたこれらのペイロードの組み合わせから得られるメッセージを考慮するように、グループのパブリッシャID(=k)、
・いくつかの組み合わされたメッセージ間で優先順位を調停する必要がある他の任意のマルチプレクサ又はコントローラがライタグループID=mによって与えられるそのオフセットを使用することができるように、それ自身のライタグループID(=m)。
【0107】
実際、この情報ライタグループIDは、PubSubメッセージの一般的にはパブリッシングオフセットを管理することを確かに可能にすることが想起される。
【0108】
最後に、ステップS7において、マルチプレクサデバイスは、サブスクライバとしてのコントローラPLC-Aによって考慮されるように、このヘッダを有する組み合わされた新たなメッセージをパブリッシュする。
【0109】
テストS5からの矢印OKは、現在のサイクルが終了したときの状況に対応し、新たなサイクルを開始するために、マルチプレクサデバイスは、新たなメッセージがデバイスDEV1、DEV2、DEV3、又は場合によっては他のデバイスから受信されるのを待機する。
【0110】
したがって、本発明は、IEEE802.1TSN規格及びOPC UAパート14(PubSub)規格に仕様化された異なるメカニズムを利用し、その実施に更なる標準化は必要とされないことは明らかである。
【0111】
この最適化は、OPC UA Pub通信性能の改善を可能にするので、本発明は、もちろんOPC UA PubSubベースの制御システムに有利に適用することができ、したがって、高性能(短い制御ループ)のOPC UA PubSubベースのファクトリオートメーション製品を提供する。ただし、同じ原理は、同種の情報編成を使用する他の通信プロトコルに適用することができる。
図1
図2
図3
図4
図5
図6
図7
図8A
図8B
図9
図10
図11
図12
図13
図14
図15
図16
図17
図18
図19
図20