(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2024-01-04
(45)【発行日】2024-01-15
(54)【発明の名称】コントロール装置
(51)【国際特許分類】
G05B 19/05 20060101AFI20240105BHJP
G06F 8/65 20180101ALI20240105BHJP
G06F 9/50 20060101ALI20240105BHJP
G06F 9/455 20180101ALI20240105BHJP
【FI】
G05B19/05 F
G06F8/65
G06F9/50 120A
G06F9/455 150
(21)【出願番号】P 2020116582
(22)【出願日】2020-07-06
【審査請求日】2022-09-21
(73)【特許権者】
【識別番号】502129933
【氏名又は名称】株式会社日立産機システム
(74)【代理人】
【識別番号】110002365
【氏名又は名称】弁理士法人サンネクスト国際特許事務所
(72)【発明者】
【氏名】前野 裕樹
【審査官】藤崎 詔夫
(56)【参考文献】
【文献】特開2019-175375(JP,A)
【文献】特開平06-250869(JP,A)
【文献】国際公開第2019/097800(WO,A1)
【文献】特開2004-094473(JP,A)
【文献】特開平09-251389(JP,A)
【文献】特開2005-084800(JP,A)
【文献】国際公開第2000/062134(WO,A1)
【文献】国際公開第2007/110953(WO,A1)
【文献】特開2002-328813(JP,A)
【文献】特開2002-222092(JP,A)
(58)【調査した分野】(Int.Cl.,DB名)
G05B 19/05
G06F 8/65
G06F 9/50
G06F 9/455
(57)【特許請求の範囲】
【請求項1】
1以上の制御対象装置に接続された1以上のI/Oポートの少なくとも1つのI/Oポートにアクセスすることにより当該I/Oポートに接続された制御対象装置の動作を制御し複数台の演算支援装置が接続されたコントロール装置であって、
複数のプログラムの各々がアクセス可能な1以上の共有領域の基になる第1の記憶部と、
前記複数のプログラムを実行する第1のプロセッサ部と
を備え、
前記複数のプログラムは、制御プログラムの他に、1以上の情報プログラムを含み、
前記1以上の共有領域の各々について、当該共有領域は、前記制御プログラムと前記1以上の情報プログラムの少なくとも1つの情報プログラムがアクセス可能な記憶領域であり、当該制御プログラムによりアクセスされるI/Oポートに関する情報と当該制御プログラムに関する情報とのうちの少なくとも一方を含んだ共有情報が格納される記憶領域であり、
前記制御プログラムは、当該制御プログラムにとっての制御対象装置の制御のためにアクセスされるI/Oポートに当該I/Oポートに接続された当該制御対象装置の制御情報を出力するスキャン処理を行うプログラムであり、
前記1以上の情報プログラムの各々は、スキャン処理を含まない情報処理を行うプログラムであり、
前記第1の記憶部は、実行管理情報を格納し、
前記実行管理情報は、前記複数のプログラムの各々について、当該プログラムの動作の範囲を規定した複数のパラメータ値を含み、
前記複数のプログラムの各々について、前記複数のパラメータ値は、下記(a)乃至(c)、
(a)当該プログラムの優先度、
(b)1種類以上の計算リソースに対応した1以上のリソース上限、及び、
(c)当該プログラムが利用可能な1以上のI/OポートのうちのいずれのI/Oポートが当該プログラムに専有のI/OポートでありいずれのI/Oポートが当該プログラムを含む2以上のプログラムで共有可能なI/Oポートであるかを表す専有/共有デバイス、
のうちの少なくとも(b)を含み、
前記複数台の演算支援装置の各々は、
前記制御プログラムと前記情報プログラムを実行する第2のプロセッサ部と、第2の記憶部とを備え、
リフレッシュサイクルがあり、
前記リフレッシュサイクルは、
前記制御プログラムによる制御の期間である制御演算期間と、
前記コントロール装置と前記演算支援装置との間でのデータ共有のための期間で
あり前記制御演算期間の次の期間であるデータ共有期間と、
前記制御演算期間及び前記データ共有期間以外の期間を含
み前記データ共有期間の次の期間であるアイドル期間と
で構成されており、
前記コントロール装置の前記第1のプロセッサ部が、
当該コントロール装置における1又は2以上の情報プログラムの各々の必要リソース量を、前記実行管理情報から特定し、当該1又は2以上の情報プログラムの各々について、前記複数台の演算支援装置のうちの、当該情報プログラムの必要リソース量以上のリソース量のリソースを持つ一台又は二台以上の演算支援装置を、前記コントロール装置に割り当て、
前記制御演算期間内で、前記コントロール装置のみで演算可能な処理の演算を行い、
前記データ共有期間において、データ送受信相手の演算支援装置とデータを共有し共同で演算を行うことを、データ送受信相手の演算支援装置を順次に変えながら、前記複数台の演算支援装置の各々とデータの共有と演算を行い、
前記コントロール装置が異常となった場合に、前記第1のプロセッサ部が、前記制御プログラムによる演算処理の結果としてのデータを含む移行対象を、前記割り当てられた一台又は二台以上の演算支援装置に転送することを、
1又は複数のリフレッシュサイクルにおける前記アイドル期間に実施する、
ことを特徴とするコントロール装置。
【請求項2】
1以上の制御対象装置に接続された1以上のI/Oポートの少なくとも1つのI/Oポートにアクセスすることにより当該I/Oポートに接続された制御対象装置の動作を制御し複数台の演算支援装置が接続されたコントロール装置により行われるコントロール方法であって、
前記コントロール装置は、
前記1以上のI/Oポートに関する情報を格納し複数のプログラムの各々がアクセス可能な1以上の共有領域の基になる第1の記憶部と、
前記複数のプログラムを実行する第1のプロセッサ部と
を備え、
前記複数のプログラムは、制御プログラムの他に、1以上の情報プログラムを含み、
前記1以上の共有領域の各々について、当該共有領域は、前記制御プログラムと前記1以上の情報プログラムの少なくとも1つの情報プログラムがアクセス可能な記憶領域であり、当該制御プログラムによりアクセスされるI/Oポートに関する情報と当該制御プログラムに関する情報とのうちの少なくとも一方を含んだ共有情報が格納される記憶領域であり、
前記制御プログラムは、当該制御プログラムにとっての制御対象装置の制御のためにアクセスされるI/Oポートに当該I/Oポートに接続された当該制御対象装置の制御情報を出力するスキャン動作を行うプログラムであり、
前記1以上の情報プログラムの各々は、スキャン処理を含まない情報処理を行うプログラムであり、
前記第1の記憶部は、実行管理情報を記憶しており、
前記実行管理情報は、前記複数のプログラムの各々について、当該プログラムの動作の範囲を規定した複数のパラメータ値を含み、
前記複数のプログラムの各々について、前記複数のパラメータ値は、下記(a)乃至(c)、
(a)当該プログラムの優先度、
(b)1種類以上の計算リソースに対応した1以上のリソース上限、及び、
(c)当該プログラムが利用可能な1以上のI/OポートのうちのいずれのI/Oポートが当該プログラムに専有のI/OポートでありいずれのI/Oポートが当該プログラムを含む2以上のプログラムで共有可能なI/Oポートであるかを表す専有/共有デバイス、
のうちの少なくとも(b)を含み、
前記複数台の演算支援装置の各々は、
前記制御プログラムと前記情報プログラムを実行する第2のプロセッサ部と、第2の記憶部とを備え、
リフレッシュサイクルがあり、
前記リフレッシュサイクルは、
前記制御プログラムによる制御の期間である制御演算期間と、
前記コントロール装置と前記演算支援装置との間でのデータ共有のための期間で
あり前記制御演算期間の次の期間であるデータ共有期間と、
前記制御演算期間及び前記データ共有期間以外の期間を含
み前記データ共有期間の次の期間であるアイドル期間と
で構成されており、
前記コントロール方法が、
当該コントロール装置における1又は2以上の情報プログラムの各々の必要リソース量を、前記実行管理情報から特定し、当該1又は2以上の情報プログラムの各々について、前記複数台の演算支援装置のうちの、当該情報プログラムの必要リソース量以上のリソース量のリソースを持つ一台又は二台以上の演算支援装置を、前記コントロール装置に割り当てるステップと、
前記制御演算期間内で、前記コントロール装置のみで演算可能な処理の演算を行うステップと、
前記データ共有期間において、データ送受信相手の演算支援装置とデータを共有し共同で演算を行うことを、データ送受信相手の演算支援装置を順次に変えながら、前記複数台の演算支援装置の各々とデータの共有と演算を行うステップと、
前記コントロール装置が異常となった場合に、前記制御プログラムによる演算処理の結果としてのデータを含む移行対象を、前記割り当てられた一台又は二台以上の演算支援装置に転送することを、
1又は複数のリフレッシュサイクルにおける前記アイドル期間に実施するステップと
を有することを特徴とするコントロール方法。
【発明の詳細な説明】
【技術分野】
【0001】
本発明は、概して、コントロール装置に関する。
【背景技術】
【0002】
特許文献1(特開2004-362327号公報)には、「プラントの監視制御設備における監視用パーソナルコンピュータと制御用プログラマブルロジックコントローラをネットワークで接続した分散型監視制御システムにおいて、監視用汎用パーソナルコンピュータに制御用汎用プログラマブルロジックコントローラの情報管理ファイルを設け、前記制御用汎用プログラマブルロジックコントローラに、この制御用汎用プログラマブルロジックコントローラの情報自動掃出ツールを設けて、前記汎用パーソナルコンピュータに入力された情報と前記汎用制御用プログラマブルロジックコントローラのプロセス情報を汎用ソフトウェアで統合管理することを特徴とする分散型監視制御システム。」が開示されている(請求項1参照)。
【0003】
特許文献2(特開2006-178818号公報)には、「リアルタイムOSと、メモリと、ラダー言語プログラムをモーション制御周期に同期させて実行する実行手段と、前記ラダー言語プログラムとC言語プログラムの両方が動作するマイクロプロセッサとを備えたモーションコントローラにおいて、エンジニアリングツールのプロジェクト設定ファイルに従ってロードされた前記C言語プログラムがタスク型プロジェクトであれば前記リアルタイムOSのタスクとして動作させ、前記C言語プログラムが関数型プロジェクトであれば他のタスクから関数としてコール可能な状態で前記メモリに格納することを特徴とするモーションコントローラ。」が開示されている(請求項1参照)。
【先行技術文献】
【特許文献】
【0004】
【文献】特開2004-362327号公報
【文献】特開2006-178818号公報
【発明の概要】
【発明が解決しようとする課題】
【0005】
特許文献1には、「しかしながら、従来の分散型監視制御システム41は、オペレータズテーション50a~50n、ディジタル制御装置60a~60n、伝送路52a~52n、基幹伝送路42、伝送路61a~61n等が分散型監視制御システムメーカ毎の専用機器であり、高価かつ、他メーカー製品と互換性がないため、拡張性が劣り、また、近年のパソコン等汎用機器の性能向上に伴い、能力的にも専用機器を凌ぐものもあるにもかかわらず、汎用機器が使用されていない。」と記載されている(0004段落参照)。
【0006】
分散型監視制御システムメーカ毎の専用機器はプログラマブルロジックコントローラであり、このような装置構成とする背景には、プログラマブルロジックコントローラはI/Oユニット等の制御を行うものであり、工場内の生産や搬送等に用いられる装置に接続されるため、制御に遅延が生じると工場内の装置等の動作が不安定になったり、予期しない動作が生じたりする場合がある。そのため、従来のプログラマブルロジックコントローラは、複雑な処理をさせないようになっていた。特許文献1に開示される発明も同様に複雑な処理をさせないようにし、監視用汎用パーソナルコンピュータに制御用汎用プログラマブルロジックコントローラの情報管理ファイルを設けることで、プログラマブルロジックコントローラの制御に影響を与えないようにすることが開示されている。
【0007】
したがって、特許文献1は、プログラマブルロジックコントローラ内でI/Oユニットを制御しつつ情報処理を行うことは考慮されておらず、さらに情報処理がより高度になった場合にCPUユニットの演算を支援する演算装置を追加した場合の追加された演算装置を管理することについては考慮されていない。
【0008】
特許文献2の課題の欄には、「ラダー言語アプリケーションプログラムとC言語アプリケーションプログラムが異なるマイクロプロセッサ上で動作するため、ラダー言語アプリケーションからC言語アプリケーションプログラムを関数としてコールすることができないという問題もあった。」と記載されている。
【0009】
すなわち、特許文献2は、同一のマイクロプロセッサ上で、ラダー言語アプリケーションプログラムがC言語アプリケーションプログラムを関数としてコールすることを目的としている。
【0010】
特許文献2には、モーションコントローラとエンジニアリングツールとからなり、モーションコントローラにおいてラダー言語タスクとC言語タスクとが共存して動作し、エンジニアリングツールは、C言語のプログラムと設定ファイルとをモーションコントローラにダウンロードするシステムの発明が記載されている。
【0011】
また、モーションコントローラにラダー言語タスクとC言語タスクが共存し、ラダー言語タスクとC言語プログラムのタスクは、リアルタイムOS(Operating System)上で動作することが記載されている。
【0012】
C言語プログラムがタスク型プロジェクトであれば、リアルタイムOSのタスクとして動作し、関数型プロジェクトであれば他のタスクから関数としてコール可能な状態でモーションコントローラのメモリに格納される。
【0013】
すなわち、関数型プロジェクトであれば、他のタスク、例えばラダー言語タスクは、関数型プロジェクトのプロジェクト名称を引数として入力してC言語関数呼び出し用ファンクション・ブロックを実行する。
【0014】
つまり、ラダー言語タスクがC言語の関数型プロジェクトを呼び出し、モーションコントローラに接続された工作機械等を数値制御することとなる。
【0015】
C言語タスクは、タスク型プロジェクトのプロジェクト名称とタスクの起床や中断など操作の種別を引数として入力してタスク操作用APIをコールする。タスク操作用APIは、プロジェクト名称をタスク名称として扱いタスク操作の種別に対応したリアルタイムOSが提供する機能をコールして他のタスク型プロジェクトのタスク操作を間接的に実現することが記載されている。
【0016】
また、タスク型プロジェクトとしてロードされたC言語プログラムについては、ラダー言語プログラムの実行タイミングで、タスク型プロジェクトとしてロードされたC言語プログラムの実行制御が可能であることが記載されている。
【0017】
すなわち、タスク型プロジェクトとしてロードされたC言語プログラムは、モーション制御に同期した動作を行う用途、高度な数値計算のように処理に時間がかかるような用途に用いることができるとされている。
【0018】
つまり、モーションコントローラに接続された工作機械等を制御するためラダー言語プログラムの実行タイミングで、タスク型プロジェクトとしてロードされたC言語プログラムの実行制御を行うために利用されている。
【0019】
よって、関数型とタスク型のいずれの場合であっても、ラダー言語の一部をC言語として記述あるいはラダー言語プログラムの実行タイミングでC言語プログラムの実行制御をする。つまり、特許文献2に記載のC言語プログラムについては、モーションコントローラに接続された工作機械等を制御するために用いられる技術的思想が開示されている。
【0020】
したがって、特許文献2には、C言語プログラムを装置に接続された工作機械等のハードウェアを制御する以外の目的に利用することは考慮されていない。
【0021】
本発明は以上の点を考慮してなされたもので、コントロール装置に搭載されたハードウァ及びプログラムを柔軟に変更することが可能な技術を提供することを目的とする。
【課題を解決するための手段】
【0022】
かかる課題を解決するため、本発明の一例を挙げるならば、コントロール装置は、1以上の共有領域の基になる記憶部と、複数のプログラムを実行するプロセッサ部とを備る。複数のプログラムは、1以上の制御プログラムの他に、1以上の情報プログラムを含む。1以上の共有領域の各々は、1以上の制御プログラムの少なくとも1つの制御プログラムと1以上の情報プログラムの少なくとも1つの情報プログラムがアクセス可能な記憶領域であり、当該制御プログラムによりアクセスされるI/Oポートに関する情報と当該制御プログラムに関する情報とのうちの少なくとも一方を含んだ共有情報が格納される記憶領域である。
【0023】
1以上の制御プログラムの各々は、当該制御プログラムにとっての制御対象装置の制御のためにアクセスされるI/Oポートに当該I/Oポートに接続された当該制御対象装置の制御情報を出力するスキャン動作を行うプログラムである。
【0024】
一方、1以上の情報プログラムの各々は、スキャン動作を含まない情報処理を行うプログラムである。
【発明の効果】
【0025】
本発明によれば、コントロール装置に搭載されたハードウェア及びプログラムを柔軟に変更することが可能である。
【図面の簡単な説明】
【0026】
【
図1】第1の実施の形態に係るコントロール装置を含むシステムのハードウェア構成例を示すブロック図である。
【
図2】第1の実施の形態に係るコントロール装置を含むシステムの機能的な概略構成を示すブロック図である。
【
図3】実行管理テーブルのテーブル構成例を示す図である。
【
図4】プログラムダウンロード処理の流れの一例を示すフローチャートである。
【
図5】プログラム実行処理の流れの一例を示すフローチャートである。
【
図6A】実行管理テーブルのテーブル構成例を示す図である。
【
図6B】実行管理テーブルのテーブル構成例を示す図である。
【
図7】設定範囲テーブルのテーブル構成例を示す図である。
【
図8A】リソース境界とその変更の第1の例を模式的に示す図である。
【
図8B】リソース境界とその変更の第2の例を模式的に示す図である。
【
図8C】リソース境界とその変更の第3の例を模式的に示す図である。
【
図9】制御プログラムと情報プログラムが共存するプラットフォームの別の一例を示す。
【
図10】制御プログラムと情報プログラムが共存するプラットフォームのまた別の一例を示す。
【
図11】追加のハードウェアである演算支援ユニットを含む機能的構成例を示すブロック図の一例。
【
図12】コントロール装置の管理テーブルの構成一例。
【
図13】演算支援ユニットが異常になった場合に、コントロール装置が他の演算支援ユニットへの演算切り替えを行う例を示したフローチャート。
【
図14】演算支援ユニットの管理プログラムのバージョンを変更する際の例を示したフローチャート。
【
図15】コントロール装置と演算支援ユニットがデータバスを介してデータを送受信する際のタイミングの一例。
【発明を実施するための形態】
【0027】
以下、図面について、本発明の実施の形態について説明する。
【0028】
特に必要なとき以外は同一又は同様な部分の説明を原則として繰り返さない。所定の図に記載された符号について他の図で説明をする場合であっても同一又は同様な部分の説明は省略する。
【0029】
以下の実施の形態では便宜上その必要があるときは、複数のセクション又は実施の形態に分割して説明するが、特に明示した場合を除き、それらはお互いに無関係なものではなく、一方は他方の一部又は全部の変形例、詳細、補足説明などの関係にある。
【0030】
以下の実施の形態において、要素の数など(個数、数値、量、範囲などを含む)に言及する場合、特に明示した場合及び原理的に明らかに特定の数に限定される場合などを除き、その特定の数に限定されるものではなく、特定の数以上でも以下でも良いものとする。
【0031】
以下の実施の形態において、「インターフェース部」は、1以上のインターフェースを含む。1以上のインターフェースは、1以上の同種のインターフェース装置であっても良いし2以上の異種のインターフェース装置であっても良い。
【0032】
以下の実施の形態において、「記憶部」は、1以上のメモリを含む。記憶部に関して少なくとも1つのメモリは、揮発性メモリで良い。記憶部は、主に、プロセッサ部による処理の際に使用される。記憶部は、メモリの他に、1以上の不揮発性の記憶装置(例えば、HDD(Hard Disk Drive)又はSSD(Solid State Drive))を含んでも良い。
【0033】
以下の実施の形態において、「プロセッサ部」は、1以上のプロセッサを含む。少なくとも1つのプロセッサは、典型的には、CPU(Central Processing Unit)のようなマイクロプロセッサであるが、GPU(Graphics Processing Unit)のような他種のプロセッサでも良い。1以上のプロセッサの各々は、シングルコアでも良いしマルチコアでも良い。プロセッサは、処理の一部又は全部を行うハードウェア回路を含んでも良い。
【0034】
以下の実施の形態において、「kkk部」(インターフェース部、記憶部及びプロセッサ部を除く)の表現にて機能を説明することがあるが、機能は、1以上のコンピュータプログラム(後述の制御プログラム及び情報プログラムを除く)がプロセッサ部によって実行されることで実現されても良いし、1以上のハードウェア回路(例えばFPGA(Field-Programmable Gate Array)又はASIC(Application Specific Integrated Circuit))によって実現されても良い。プログラムがプロセッサ部によって実行されることで機能が実現される場合、定められた処理が、適宜に記憶部及び/又はインターフェース部等を用いながら行われるため、機能はプロセッサ部の少なくとも一部とされても良い。機能を主語として説明された処理は、プロセッサ部あるいはそのプロセッサ部を有する装置が行う処理としても良い。プログラムは、プログラムソースからインストールされても良い。プログラムソースは、例えば、プログラム配布計算機又は計算機が読み取り可能な記録媒体(例えば非一時的な記録媒体)であっても良い。各機能の説明は一例であり、複数の機能が1つの機能にまとめられたり、1つの機能が複数の機能に分割されたりしても良い。
【0035】
また、以下の説明では、「xxxテーブル」といった表現にて、入力に対して出力が得られる情報を説明することがあるが、当該情報は、どのような構造のデータでも良いし、入力に対する出力を発生するニューラルネットワークのような学習モデルでも良い。従って、「xxxテーブル」を「xxx情報」と言うことができる。また、以下の説明において、各テーブルの構成は一例であり、1つのテーブルは、2以上のテーブルに分割されても良いし、2以上のテーブルの全部又は一部が1つのテーブルであっても良い。
【0036】
以下の実施の形態において、その構成要素(要素ステップ等も含む)は、特に明示した場合及び原理的に明らかに必須であると考えられる場合等を除き、必ずしも必須のものではないことは言うまでもない。
【0037】
コントロール装置は、シーケンス制御装置、モーション制御装置又はプログラマブル・ロジック・コントローラ(PLC)とも呼ばれている。コントロール装置において、ラダー・ロジック(LD言語)、シーケンシャル・ファンクション・チャート(SFC言語)、ファンクション・ブロック(FBD言語)、ストラクチャード・テキスト(ST言語)、インストラクション・リスト(IL言語)のような制御装置特有のプログラミング言語、あるいはC言語のような情報通信分野で使われる汎用的なプログラミング言語を用いて記述され、シーケンス制御やモーション制御に代表される制御処理を実行するプログラムを「制御プログラム」と呼ぶ。制御プログラムは、I/Oモジュール等を介して実際にモータ等を含む周辺機器を操作し、生産システム等を適切に動作させる必要がある。そのため、制御プログラムは、処理を設定された時間内に確実に実行すること(リアルタイム性)が求められる。
【0038】
制御プログラムは、制御内容が記述された命令によって制御対象装置(例えば、装置部品のようなハードウェアモジュール、1以上のハードウェアモジュールを備えた装置、又は、複数の装置を備えたシステム)を制御する。例えば、「I/Oモジュール等を介して実際にモータ等を含む周辺機器を操作し、生産システムを適切に動作させる」といった制御では、「生産システム」、又は、「生産システムを構成する少なくとも1つの装置」が、「制御対象装置」である。制御対象装置は、典型的には、コントロール装置におけるI/O制御装置(インターフェース部の一例)経由で接続された装置である。制御対象装置は、制御プログラムから直接的に(例えば、コントロール装置に接続されたI/Oモジュールや周辺機器を介さずに)制御されても良いし、制御プログラムから間接的に(例えば、コントロール装置に接続されたI/Oモジュールや周辺機器を介して)制御されても良い。
【0039】
制御対象装置を制御する言語は、ラダー言語等の制御特有のプログラミング言語に限らず、C言語等の汎用プログラミング言語で記述される場合もあるため、制御対象装置(典型的にはハードウェア)を制御するプログラムを「制御プログラム」と呼ぶ。
【0040】
ラダー言語等で記述された制御プログラムは、当該ラダー言語等の記述において指定された制御対象装置の状態を読み込み又は書き込み(取得又は更新)をする「スキャン動作」を行う。
【0041】
このスキャン動作は所定間隔で行う必要があり、この所定間隔を「スキャンタイム」と呼ぶ。スキャンタイムは、制御プログラムの演算時間に関するものであり、制御に関する演算周期又は制御に関する演算を繰り返し所定間隔で行うことから「サイクルタイム」とも呼ばれることもある。
【0042】
コントロール装置に接続される制御対象装置は、例えば、工場内の生産や搬送等に用いられる装置に接続されるため、スキャン動作が遅れると、工場内の装置等の動作が不安定になったり、予期しない動作が生じたりする場合がある。このため、所定のスキャンタイム内にスキャン動作を行う必要がある。
【0043】
スキャンタイムはコントロール装置が制御する制御対象装置の数や種類の増加に応じて長くなるが、スキャンタイム内で制御対象装置のスキャン動作をすることが重要である。
【0044】
コントロール装置に、I/O(Input/Output)ポートが内蔵又は接続される。I/Oポートは、I/Oモジュール又はI/Oユニット等が有する場合がある。以下、I/Oポートそれ自体、又は、I/Oポートを有する装置(I/Oモジュール又はI/Oユニット等)を、「I/Oポート」と総称する場合がある。
【0045】
I/Oポートは、制御対象装置、例えば、生産設備におけるベルトコンベア、リミットスイッチ、アクチュエータ(例えばモータ)に接続され、制御対象装置の動作に関する制御に使用されるものである。I/Oポートは、デジタル又はアナログのI/Oポートである。例えば、アナログI/Oポートは、コントロール装置の制御対象装置の電圧、電流、温度等の情報の読み書きに使用される。
【0046】
制御プログラムに基づいてコントロール装置のI/Oポートから送信される制御情報を有線又は無線で受信するインバータユニットやCNC(Computerized Numerical Control)はインバータやCNC自体がアクチュエータのモーション制御を行うため、リアルタイム性が求められる。
【0047】
また、制御対象装置の制御とは、制御対象装置が接続されている状態のI/Oポートの動作を制御することをいう。つまり、制御プログラムとは、制御対象装置が接続されたI/Oポートの制御を行うプログラム、言い換えれば、制御対象装置が接続されたI/Oポートに当該制御対象装置の制御情報を出力する(具体的には、例えば、当該制御情報の出力を含むスキャン動作を行う)プログラムである。
【0048】
このようなコントロール装置において、制御対象装置の制御に加えて、情報処理(例えば、複雑な算術演算やSCADA、MES、クラウドシステムとの情報の送受信のような情報通信処理)を行うことを検討する。このような情報処理は、上述の制御特有の言語でプログラミングすることが困難な場合があり、C言語又はJava(登録商標)言語などの情報処理分野で使われるプログラミング言語を用いて記述することがある。このような情報処理を実行するプログラムを「情報プログラム」と呼ぶ。
【0049】
制御プログラムと情報プログラムの違いの一例について説明する。
【0050】
上記したように制御プログラムは、コントロール装置のI/Oポートの制御に関係したプログラムであり、情報プログラムは、情報処理(例えば、上述のように、算術演算や、クラウドとの通信)を行うプログラムである。
【0051】
制御プログラムは、ラダーやST言語等で記述され、java(登録商標)やpython等に代表される汎用言語に比べてリアルタイム性が高い。情報プログラムは、java(登録商標)やpython等に代表される言語で記述され、ラダー等よりも情報処理に適している。
【0052】
C言語等のリアルタイム性が高く、ハードウェアの制御にも適しており、また、情報処理にも適した言語は制御プログラムと情報プログラムのいずれにも利用可能な場合がある。
【0053】
また、情報プログラムは、先に説明した制御プログラム以外のプログラム(但し、例えば、後述のタスク管理部110、制御プログラム実行部111、情報プログラム実行部112及びI/O制御部117を実現するための1以上のプログラムを除く)である。制御対象装置がI/Oポートを介してコントロール装置に接続されるが、情報プログラムは、制御対象装置に接続されるアナログやデジタルのI/Oポート(但し、情報プログラムとの共有が許容されているI/Oポートを除く)へアクセスしないプログラムである。別の言い方をすれば、制御プログラムは、制御対象装置に接続されるアナログやデジタルのI/Oポートに制御対象装置の制御情報を送信することを含むスキャン動作を行うプログラムであるが。一方、情報プログラムは、スキャン動作を含まない(スキャン動作とは異なる)情報処理を行うプログラム(つまり、スキャン動作を行うことがないプログラム)である。
【0054】
制御プログラムと情報プログラムを搭載する以下の実施の形態に係るコントロール装置は、制御プログラムの他に情報プログラムを実行しても、制御プログラムを停止させることなく、又は、制御プログラムのスキャン動作を遅らせたり、制御プログラムの予期しない動作をさせたりすることなく、情報プログラムの追加、削除、更新(書き換え)又は入れ替えといったプログラム変更を行うことを実現するものである。さらに、制御プログラムの追加、削除、更新(書き換え)及びハードウェアの追加、削除、更新(書き換え)も実現する。
[第1の実施の形態]
【0055】
【0056】
図1は、第1の実施の形態に係るコントロール装置を含むシステムのハードウェア構成例を示すブロック図である。
【0057】
プログラム配布装置101、コントロール装置109、1以上の管理ユーザ計算機151M及び1以上の一般ユーザ計算機151Gが情報ネットワーク108に接続されている。また、コントロール装置109及び1以上のI/Oモジュール119(I/Oポートの一例)が制御ネットワーク118に接続されている。情報ネットワーク108は、情報プログラムが行う情報通信処理(つまり、制御情報の送信とは異なる通信処理)の際に使用される通信ネットワークである。制御ネットワーク118は、制御プログラムが行う制御情報送信の際に使用される通信ネットワークである。情報ネットワーク108及び制御ネットワーク118は、異種のネットワークでも良いし、同種のネットワーク(例えばいずれもLAN(Local Area Network))でも良い。また、情報ネットワーク108の少なくとも一部と制御ネットワーク118の少なくとも一部が一体であっても良い。
【0058】
管理ユーザ計算機151Mは、少なくとも管理ユーザが操作する計算機である。一般ユーザ計算機151Gは、少なくとも一般ユーザが操作する計算機である。いずれの計算機も、プログラム配布装置101及びコントロール装置109の少なくとも1つに対する入出力コンソールとして機能する。具体的には、例えば、いずれの計算機も、キーボード及びポインティングデバイスのような入力デバイスと、表示デバイスのような出力デバイスとを有する。「管理ユーザ」は、制御プログラムを記述するユーザ(例えば、自動機械や生産設備といった制御対象に関して深い知識を有する技術者)であり、「一般ユーザ」は、情報プログラムを記述するユーザ(例えば、制御対象に関して深い知識を持たない一般的なシステムエンジニア)である。コントロール装置109が、管理ユーザ計算機151M及び一般ユーザ計算機151Gのうちの少なくとも1つから制御プログラム及び情報プログラムの少なくとも1つについての記述(パラメータ群の設定を含む)を受け付けても良いし、コントロール装置109に代えて又は加えて、プログラム配布装置101が、当該記述を受け付けても良い。以下、管理ユーザ及び一般ユーザを「ユーザ」と総称することがある。ユーザは、管理ユーザ及び一般ユーザのいずれかに代えて、システム管理者(例えば、プログラム配布装置101とコントロール装置109で構成されたシステムであるコントロールシステムの管理者)といった別種のユーザであってもよい。
【0059】
1以上のI/Oモジュール119に1以上の周辺機器120が接続されている。周辺機器120は、センサ及びドライブなどの少なくとも1つの機器である。I/Oモジュール119は、周辺機器120が必要に応じて着脱可能に装着されるバススロットとして機能する。制御対象装置は、周辺機器120経由又は非経由でI/Oモジュール119に接続される。制御対象装置とI/Oモジュール119は、1:1、1:多、多:1及び多:多のいずれでも良い。また、一部のI/Oモジュール119は、制御ネットワーク118に加えて情報ネットワーク108に接続されても良い、すなわち、当該一部のI/Oモジュール119は、制御プログラムと情報プログラムに共有のデバイスであっても良い。
【0060】
プログラム配布装置101は、制御プログラム及び情報プログラムを管理している。プログラム配布装置101は、EPROM201、CPU202、メインメモリ203、周辺制御装置205、不揮発性記憶装置206及びネットワークインターフェース(図示のネットワークI/Fに相当)207を備える。プログラム配布装置101は、ネットワークインターフェース207を介して情報ネットワーク108に接続されている。
【0061】
プログラム配布装置101は、周辺制御装置205の制御によって情報ネットワーク108を経由してコントロール装置109に対して制御プログラムを提供したり情報プログラムを提供したりする。このプログラム配布装置101では、CPU202の制御によって、不揮発性記憶装置206に予め格納されている制御プログラム及び情報プログラムを要求に応じて提供する。
【0062】
周辺制御装置205は、バス204を介してEPROM201、CPU202及びメインメモリ203に接続されている。CPU202は、EPROM201に予め格納されている管理プログラムをメインメモリ203上に読み出して実行し、この管理プログラムによって上記制御プログラム及び情報プログラムを管理している。
【0063】
この管理プログラムは、要求に応じて逐次、上述した制御プログラム及び情報プログラムのうち少なくとも一方のプログラムを提供する。この管理プログラムがCPU202によって実行されることにより、後述するプログラム配布部102及び実行管理生成部103が実現される。
【0064】
一方、コントロール装置109は、EPROM208、CPU209、メインメモリ210、周辺制御装置212、I/O制御装置214、不揮発性記憶装置215及びネットワークインターフェース(図示のネットワークI/Fに相当)213を備えている。I/O制御装置214及びネットワークI/F213が、インターフェース部の一例である。EPROM208、メインメモリ210及び不揮発性記憶装置215が、記憶部の一例である。CPU209及び周辺制御装置212がプロセッサ部の一例である。コントロール装置109では、プログラム配布装置101から提供される制御プログラム及び情報プログラムが同一のプラットフォーム上で共存しつつ動作する。
【0065】
周辺制御装置212は、ネットワークI/F213、I/O制御装置214、不揮発性記憶装置215及びバス211に接続されている。このバス211には、その他にもEPROM208、CPU209及びメインメモリ210が接続されている。
【0066】
EPROM208には、初期状態で予めコントロール装置109に用意されている制御プログラム及び情報プログラムが格納されている。CPU209は、複数のコアを備えており、各コアを独立させて動作させることができる。
【0067】
コントロール装置109に搭載される制御プログラムと情報プログラムはそれぞれひとつずつだけでなく、コントロール装置109が使用できるリソースをプログラムごとに設定することにより、複数の制御プログラム及び/又は複数の情報プログラムを搭載することができる。
【0068】
CPU209は、EPROM208に予め格納されている制御プログラム及び情報プログラムをメインメモリ210に読み出して実行し、これら制御プログラム及び情報プログラムの動作を制御する。
【0069】
すなわち、これらの制御プログラム及び情報プログラムが読み出されて実行されると、後述する
図2の制御プログラム114及び情報プログラム115となる。
【0070】
制御プログラム114と情報プログラム115は異なる役割を有する。
【0071】
制御プログラム114は、コントロール装置109のI/Oモジュール119にアクセスし、制御対象装置を制御する。また、制御プログラム114は、読み込んだ結果を基に演算を行い、制御対象装置の制御のために、当該演算結果に基づくアクセスを、I/O制御装置214に対して行っても良い。制御プログラム114は、制御対象装置の制御のために、当該制御対象装置が接続されたネットワークI/F213に対するアクセスを行っても良い。すなわち、I/Oモジュール119に代えて又は加えて、I/O制御装置214及びネットワークI/F213の少なくとも1つも、「I/Oポート」の一例となり得る。つまり、制御プログラム114は、制御対象装置の制御のために(制御対象装置の制御情報の送信のために)、当該制御対象装置が接続されたI/Oポートに対するアクセスを行う、言い換えると、当該I/Oポートを制御する命令を送信する。
【0072】
一方、情報プログラム115は、I/O制御装置214等の情報を取得し、演算し、演算した結果を、ネットワークI/F213を介して、コントロール装置109に接続されている他の装置又は設備に送信する。この段落で言う「他の装置又は設備」は、コントロール装置109に接続されているが制御プログラム114の制御対象装置とは異なる装置又は設備である。
【0073】
コントロール装置109は、制御プログラム114と情報プログラム115の両者がアクセスできる共有領域(図示しない)を有することができる。この共有領域は、メインメモリ210及び不揮発性記憶装置215に確保されて良い。共有領域は、例えば、共有ディレクトリといった論理的な記憶領域でもよいし、物理アドレス(例えばメモリアドレス)で指定された物理的な記憶領域でもよい。例えば、制御プログラム114が、情報プログラム115に見せてもよいデータの値を共有領域に読み書きするタスクを生成し、当該タスクが実行されることで、情報プログラムから、当該共有領域内のデータの値にアクセス可能になって良い。「見せてもよいデータの値」とは、広義には、1以上の情報プログラム115と共有する情報である共有情報である。共有情報は、例えば、I/Oポートの状態を示す(又は、I/Oポートに関して他種の情報を含んだ)ポート情報や、制御プログラムの内部変数等に関する制御プログラム情報が挙げられる。共有領域は、例えば、後述のタスク管理部110により設けられてもよいし、同一の共有領域にアクセスする制御プログラム114及び情報プログラム115の少なくとも1つにより設けられてもよい。
【0074】
このように、情報プログラム115が、制御プログラム114の制御対象装置が接続されたI/Oポートに直接アクセスすることを防止できるため安全性が向上する。言い換えれば、情報プログラム115が、制御プログラム114の制御対象装置が接続されたI/Oポートに直接アクセスすることに代えて、共有領域内の共有情報を参照することで、I/Oポートの状態、又は、制御プログラム114の状態を知ることができる。
【0075】
また、情報プログラム115は、ネットワークI/F213を介して接続されているが制御プログラム114の制御対象装置ではない設備又は装置から情報を受信しても良い。情報プログラム115は、この受信した情報等を演算し、ネットワークI/F213を介して他の装置又は設備と通信することができる。
【0076】
CPU209は、周辺制御装置212を制御してネットワークI/F213を介してプログラム配布装置101からの制御プログラム及び情報プログラムのダウンロードを制御する。
【0077】
CPU209は、周辺制御装置212を制御してI/O制御装置214及び複数のI/Oモジュール119を介して複数の周辺機器120を制御する。周辺機器120は、I/Oモジュール119に1:1で対応付けられており、CPUは、例えば、I/Oモジュール119と1:1のデジタルI/Oレジスタを管理し、レジスタ操作で逐一I/Oモジュール119の操作が可能となっている。
【0078】
図2は、第1の実施の形態に係るコントロール装置を含むシステムの機能的な概略構成例を示すブロック図である。
【0079】
プログラム配布装置101は、プログラム管理データベース(図示のプログラム管理DBに相当)104、プログラム配布部102及び実行管理生成部103を備えている。プログラム管理DB104は、メインメモリ203及び不揮発性記憶装置206の少なくとも一部に基づく。これらプログラム配布部102及び実行管理生成部103は、既述の管理プログラムがCPU202に実行されることにより実現される。
【0080】
プログラム管理データベース104は、制御プログラム105及び情報プログラム106を管理する。実行管理生成部103は、制御プログラム105及び情報プログラム106のうち少なくとも一方のプログラムがコントロール装置109において実行される際のパラメータを表す実行管理データを生成する。この実行管理データは、例えば、制御プログラム105及び情報プログラム106の各タスクの優先度、及び、制御プログラム105及び情報プログラム106ごとに使用可能な上限記憶容量のような1以上のパラメータである。
【0081】
プログラム配布部102は、要求に応じて上記少なくとも一方のプログラムを提供する際に併せて上記少なくとも一方のプログラムに対応するパラメータ値を示す実行管理データを提供する。
【0082】
コントロール装置109は、シーケンス制御装置、モーション制御装置、又はプログラマブル・ロジック・コントローラ(PLC)とも呼ばれることがある。ラダー・ロジック(LD言語)、シーケンシャル・ファンクション・チャート(SFC言語)、ファンクション・ブロック(FBD言語)、ストラクチャード・テキスト(ST言語)、インストラクション・リスト(IL言語)のような制御特有のプログラミング言語で制御内容が記述される。また、場合により、C言語等の汎用プログラミング言語での記述が、ラダー言語等での記述の一部又は全部に差し替えられても良い。
【0083】
このようなコントロール装置109に接続される制御対象を制御する制御プログラム105(114)は、ラダー言語を代表とする制御特有のプログラミング言語を用いることが有効である。ラダーの表示が可能であり、制御対象の状態の監視等に有効である。
【0084】
一方、情報プログラム106(115)は、このようなコントロール装置109における情報処理(例えば、複雑な算術演算や、SCADA、MES、クラウドシステムとの情報の送受信のような情報通信処理)に有効である。
【0085】
このような情報処理は、制御特有の言語でプログラミングすることが困難な場合があり、いわゆるC言語又はJava(登録商標)言語などの情報通信分野で使われるプログラミング言語を用いて記述する場合がある。
【0086】
プログラム管理データベース104は、上述した制御内容を実行する機能を有する制御プログラム105、及び、上述した情報処理を実行する機能を有する情報プログラム106を管理している。
【0087】
コントロール装置109は、タスク管理部110、制御プログラム実行部111、情報プログラム実行部112、実行管理テーブル113及びI/O制御部117を備えている。
【0088】
制御プログラム実行部111は、例えばランタイムライブラリであり、制御プログラム114からの呼び出しに応じて制御プログラム114とともに動作する。情報プログラム実行部112は、例えばいわゆるライブラリであり、情報プログラム115からの呼び出しに応じて情報プログラム115とともに動作する。
【0089】
なお、制御プログラム114は、プログラム配布装置101からコントロール装置109に配布済みの制御プログラム105(又は当該制御プログラム105の実行に伴い生成された1以上のタスク)に相当し、情報プログラム115は、プログラム配布装置101からコントロール装置109に配布済みの情報プログラム106(又は当該情報プログラム106の実行に伴い生成された1以上のタスク)に相当する。
【0090】
実行管理テーブル113は、プログラム配布装置101から提供された上記少なくとも一方のプログラムとともに受け取った上記実行管理データが保存される。
【0091】
一方、タスク管理部110は、主として2つの機能、具体的には、プログラム受信機能及びプログラム実行管理機能を有する。プログラム受信機能は、要求に応じてプログラム配布装置101から提供される上記少なくとも一方のプログラムを受信する機能である。一方、プログラム実行管理機能は、上記少なくとも一方のプログラムを実行する際に、実行管理テーブル113に保存された実行管理データに基づいて上記少なくとも一方のプログラムの実行を制御する機能である。
【0092】
I/O制御部117は、制御プログラム114からの制御情報を当該制御情報の送信先に転送する。
【0093】
上述したようにコントロール装置109は、制御プログラム114及び情報プログラム115の各タスクが使用する所定の記憶容量の記憶領域を有するメインメモリ210を備える。
【0094】
ここで、プログラム配布装置101では、実行管理生成部103が、実行管理データとして少なくとも、制御プログラム105及び情報プログラム106の各タスクの優先度、及び、制御プログラム105及び情報プログラム106の各タスクによって使用可能なメインメモリ210の上限記憶容量の少なくとも一方のパラメータ値を示す実行管理データを生成する。
【0095】
図3は、
図2に示す実行管理テーブル113のテーブル構成例を示す。
【0096】
実行管理テーブル113は、制御プログラム114及び情報プログラム115の各々について、エントリを有する。各エントリは、例えば、プログラム名301、プログラム種別302、タスク優先度303、実行周期304、メモリ上限305、CPUコア番号306、利用デバイス307及び専有デバイス308といった情報を格納する。以下、1つのプログラムを例に取る(
図3の説明において「対象プログラム」)。
【0097】
プログラム名301は、対象プログラムの名称を表している。プログラム種別302は、対象プログラムが制御プログラム114であるか情報プログラム115であるかというプログラムの種別を表している。なお、上述したプログラム名301の先頭3文字においても、制御プログラム114であるか情報プログラム115であるかを識別可能である。「CTL」は制御プログラム114を表しており、「ITL」は情報プログラム115を表している。以下、制御プログラム114及び情報プログラム115の各々を、プログラム名で表現することがある。
【0098】
タスク優先度303は、対象プログラムに対応するタスクの優先度を表している。タスク優先度303では、例えば「0(優先度:高)」から「20(優先度:低)」までの間で優先度が設定可能である。つまり、タスク優先度303としての値が小さいほど優先度が高い。
【0099】
実行周期304は、対象プログラムにおける定常処理が実行される周期を表している。「実行周期」とはスキャンタイムである。図示の例によれば、CTL001のスキャンタイムが10msecであり、CTL002のスキャンタイムは1msecでる。スキャン動作は、制御プログラム114及び情報プログラム115のうちの制御プログラム114に特有の動作であるため、実行周期304は、制御プログラム114について有効な値であるが、情報プログラム115については無効な値である。実行周期304(スキャンタイム)は、エンジニアリングツールでシミュレーションによって特定された値、又は、実際にコントロール装置109にて制御プログラム114を実行することにより特定されたスキャンタイムであっても良い。
【0100】
メモリ上限305は、対象プログラムがメインメモリ203の記憶領域において使用可能な記憶容量の上限を表している。
【0101】
CPUコア番号306は、コントロール装置109のCPU209に搭載されている複数のコアのうちの対象プログラムに割り当てるコアの番号を表している。
【0102】
利用デバイス307は、対象プログラムが利用可能なデバイスである利用デバイス、具体的には、対象プログラムが利用可能なI/Oモジュール119(I/Oモジュール119に接続されている利用可能な周辺機器120)を表している。
【0103】
専有デバイス308は、対象プログラムに対応した利用デバイス307が表す1以上の利用デバイス(I/Oモジュール119)のうち対象プログラムに専有されるデバイスである専有デバイス(すなわち、対象プログラムが他の制御プログラム114又は情報プログラム115と共有不可のI/Oモジュール119)を表す。
【0104】
図示の例によれば、例えば、下記のことが言える。
【0105】
CTL001は、制御プログラムである。CTL001について、例えば次の通りである。すなわち、タスク優先度は、CTL002よりも低く設定されている。また、メモリ上限は16MBであり、使用するCPUコアの番号は0である。利用デバイスはDI1とDO1(コントロール装置のデジタル入力1とデジタル出力1)である。
【0106】
DI1とDO1を、他のプログラムが使用しないようにCTL001が専有して利用するように設定されている。コントロール装置において、専有デバイス(専有デバイス308として設定されたデバイス)が複数のプログラム間で共有されないため、専有デバイス(ここではDI1とDO1)に関係する制御が不安定になることを防止することができる。
【0107】
また、CTL002は、利用デバイスがeth1、eth2、シリアル1である制御プログラム、具体的には、Ethernet(登録商標)のポートを2つ、RS-232Cのポートを1つ利用する制御プログラムである。また、CTL001よりもCTL002の方がリアルタイム性が高いため、タスク優先度は、CTL001よりも高い。
【0108】
CTL002は、eth2が例えばモーション制御に利用されるデバイスである場合を示す。モーション制御はリアルタイム性が高く他の処理も優先されるため、4つのプログラムの中で最も優先度が高く設定されている。
【0109】
また、CTL002が使用するCPUコアの番号は1であり、CTL001とITL001とITL006の使用するCPUコアの番号が0であることから、CTL002は、番号が1のCPUコアを専有する。
【0110】
CTL002は、タスク優先度303に規定される優先度のみならず、CPU209が有する複数のコアのうち番号1のコアを専有する観点からも、優先度が高いことがわかる。このような設定を行うことで、CTL002が制御プログラムの中でも優先度を高い状態とすることができる。
【0111】
次に、メモリ上限305について説明する。
【0112】
メモリ上限が設定されない場合には、実際に演算を行う際に各プログラムが際限なくメモリを確保し使用することが可能となる。例えば、情報プログラムが使用できるメモリ上限が設定されない場合には、制御プログラムが使用する可能性があるが確保されていない領域を情報プログラムが確保する場合がある。しかし、例えば、大量にメモリを使用するプログラムを追加した場合、当該プログラムの追加に伴いシステム全体のメモリを使い切ってしまうような場合が起こりうる。このような場合、コントロール装置又はOSがダウンすることで制御プログラムの動作が停止したり、OSによる強制的なメモリ開放機能の発動により制御プログラムの処理が妨げられスキャンタイム内にスキャン動作を完了できなくなったりといったような場合がある。
【0113】
そこで、本実施の形態では、メモリ上限305の合計値をコントロール装置のシステム全体で利用できる値以下とすることでコントロール装置等のダウンを防止することができる。
【0114】
なお、システム全体で利用できる値は、コントロール装置に搭載されたメモリからOS等で使用された部分を除いた値であることが望ましい。OS等の領域に制御又は情報プログラムの処理が影響を与えないようにするためである。
【0115】
また、プログラムごとにメモリ上限305の値を設定することにより、もしあるプログラムに想定以上のメモリを使用してしまう不具合があった場合には、当該プログラムのみが停止し他のプログラムに影響を与える事を防止できる。
【0116】
次に、タスク優先度303について説明する。
【0117】
タスク優先度は、各プログラムが実行させる場合の優先度である。各プログラムにタスク優先度を設定することにより、OSのスケジューラ等にプログラムへのCPU割当ての優先順位を認識させることができる。
【0118】
複数のプログラムを、明示的にタスク優先度を設定せずに実行すると、あらかじめOSのスケジューラが有するルールにしたがってCPU割当てのようなリソース割り当てが行われる。例えば、複数のプログラムに平等にCPUの割当てが行われるようなスケジューリングが行われる。
【0119】
このようなスケジューリングは、制御プログラムのようなスキャンタイム内に確実に処理を終えることが重要であるプログラムの場合、他のプログラムの動作によってスキャンタイム内に処理を終えることができなくなるなど、制御プログラムの動作に影響を及ぼす場合がある。
【0120】
例えば、第1のプログラムの処理実行(CPU割当て)中に、タイマ割込み等により第1のプログラムよりも相対的にタスク優先度の高い第2のタスクの処理開始要求が発行されると、第1のプログラムの処理が中断されて第2のプログラムの処理が開始される。その後第2のプログラムがSleep等によりCPUの割当てを終了すると第1のプログラムの処理が再開される。
【0121】
また、例えば、第1のプログラムの処理実行(CPU割当て)中に、タイマ割込み等により第1のプログラムよりも相対的にタスク優先度の低い第3のタスクの処理開始要求が発行されると、第1のプログラムがSleep等によりCPUの割当てを終了するまで第3のプログラムの処理開始が待たされる。
【0122】
したがって、タスク優先度303を設定することで、より優先度の高いプログラムの処理を優先して行うことができる。
【0123】
これにより、ユーザがより重要性が高いと判断したプログラムを優先して処理させることができる。情報プログラムをコントロール装置で処理し、情報プログラムが複雑な計算を行う場合であっても、制御プログラムに影響を与えないようにすることができる。
【0124】
ITL001とITL002は、実行周期304であるスキャンタイムが設定されていないが、制御プログラムに比べて情報プログラムのタスク優先度が低いため、制御プログラムの計算にCPUコアを利用していない時間(例えば、空いている時間)に情報プログラムの処理を行うことができる。これにより、制御プログラムの処理に影響を与えることなく情報プログラムを処理することができる。
【0125】
ITL001とITL002は、利用デバイスがeth1であり、eth1は専有設定されていない。そのため、eth1のポートについては、ITL001とITL002が共有して利用可能である。
【0126】
ITL001とITL006がeth1を同時に使用しようとした場合には、タスク優先度303が高いITL001が先にeth1を使用する。ITL001がeth1の使用を終了した際に、タスク優先度303が高いITL006がeth1を使用することが可能となる。このように、プログラムそれぞれがタスク優先度に応じた処理が可能となる。
【0127】
図4は、コントロール装置109がプログラム配布装置101から所望のプログラムをダウンロードするプログラムダウンロード処理の一例を示すフローチャートである。
【0128】
まず、プログラム配布装置101では、図示しない操作画面を用いたユーザの操作に応じて、ダウンロードすべきプログラムが選択される(ステップS401)。これにより、プログラム配布部102は、対応する特定のプログラムをプログラム管理データベース104において特定する。
【0129】
次にプログラム配布装置101では、操作画面においてユーザの操作に応じて上記特定のプログラムについて実行管理データが設定される(ステップS402)。この実行管理データには、例えば
図3に示すようにタスク優先度303が含められている。
【0130】
これにより、実行管理生成部103は、ユーザの入力内容に応じて上記特定のプログラムの動作態様に関するパラメータとして、例えば、各プログラムの各タスクが実行される際の優先度、及び、各タスクが使用可能なメインメモリ210内の上限記憶容量の少なくとも一方のパラメータを設定することができる。
【0131】
以下、一例として主として優先度を取り上げて説明する。以上までが、プログラム配布装置101における処理を表しており、これ以降はコントロール装置109における処理を表している。
【0132】
プログラム配布装置101は、コントロール装置109の要求に応じて、上記特定のプログラム及びこれに対応付けられた実行管理データをコントロール装置109にダウンロードする(ステップS403)。
【0133】
次にコントロール装置109では、タスク管理部110が、上記ダウンロードされた上記特定のプログラムを受信する(既述のプログラム受信機能に相当)。タスク管理部110は、受信が完了すると、上記特定のプログラムが制御プログラムである場合には制御プログラム114としてメインメモリ210に保存する(ステップS404)。
【0134】
次にコントロール装置109では、タスク管理部110が上記特定のプログラムとともにダウンロードした実行管理データを実行管理テーブル113に追記する(既述のプログラム実行管理機能に相当)(ステップS405)。
【0135】
図5は、プログラム実行処理の一例を示すフローチャートである。このプログラム実行処理は、コントロール装置109において上記特定のプログラムが実行される場合の処理内容を表している。
【0136】
タスク管理部110は、ある所定のプログラムを新たに実行しようとした際、実行管理テーブル113から当該所定のプログラムに対応する実行管理データを読み出す(ステップS501)。
【0137】
当該所定のプログラムに対応する実行管理データとしては、実行管理テーブル113における優先度303において管理している当該所定のプログラムの各タスクが実行される際における優先度を含む。
【0138】
次にタスク管理部110は、当該読み出された実行管理データに基づいて当該所定のプログラムのパラメータとして、例えば、当該所定のプログラム(制御プログラム105及び情報プログラム106の少なくとも一方のプログラム)の各タスクの優先度を設定したり、各タスクが使用可能なメインメモリ210の上限記憶容量を設定又は特定したりする(ステップS502)。
【0139】
タスク管理部110は、このような優先度を所定のコマンドを用いて設定する。一方、タスク管理部110は、上述した上限記憶容量を設定する。
【0140】
以上のような実施の形態によれば、同一プラットフォーム(つまりコントロール装置109)に共存する制御プログラム114及び情報プログラム115が当該プラットフォーム上でそれぞれ対応するパラメータに応じて動作するようになる。タスク管理部110が、制御プログラム114及び情報プログラム115を、当該プログラム114及び115の各々のタスク優先度などのパラメータ値を基に制御プログラム実行部111及び情報プログラム実行部112を制御することで、当該プログラム114及び115の各々の実行を制御する(ステップS503)。
【0141】
この場合は、情報プログラム115であるITL001とITL002が所定のリソースで動作する。また、制御プログラム114であるCTL001とCTL002が所定のリソースでITL001とITL002よりも高い優先度で動作する。
【0142】
実行管理テーブル113を適宜変更することによって、制御プログラム114及び情報プログラム115は、互いに、例えばタスクの追加、更新又は削除のような機能変更に際し、他のプログラムが動作したまま、一部の制御プログラム114又は情報プログラム115を変更することができる。
【0143】
また、情報プログラム115は、所定のリソースが確保された場合であって、他のプログラムとの影響がない場合には再コンパイルや再ダウンロードを必要とせず実行管理テーブル113を変更しても動作させることができる(再コンパイルや再ダウンロードが必要となる一比較例については後述する)。
【0144】
このため、制御プログラム114及び情報プログラム115の各タスクの追加、更新及び削除のいずれの機能的な変更も行い易くなるため、コントロール装置109は柔軟な機能変更を可能とする。
[第2の実施の形態]
【0145】
第2の実施の形態について
図3等を用いて説明する。その際、第1の実施の形態と異なる点を中心として説明し、第1の実施の形態と共通する点については説明を省略又は簡略する。
【0146】
第2の実施の形態では、上述した操作画面(図示せず)に、
図3に示す実行管理テーブル113に基づいて、上述した各プログラムが使用可能なメインメモリ210の上限記憶容量に応じて導き出される残りリソース、例えば、各プログラムが使用可能なメインメモリ210の残容量が表示される。
【0147】
プログラム配布装置101では、上述した操作画面において所定の操作に応じて、例えば残りリソースなどが選択されると、当該残りリソースを含むパラメータ値を示す実行管理データを、選択されたプログラムとともにコントロール装置109にダウンロードする。
【0148】
コントロール装置109では、タスク管理部110が、当該選択されたプログラムとともに上記実行管理データを受け取り、この実行管理データを実行管理テーブル113に登録する。
【0149】
当該選択されたプログラムが制御プログラム114であれば、制御プログラム実行部111が、上記実行管理データに基づく残りリソースをパラメータ値として、当該選択されたプログラムである制御プログラム114を実行する。
【0150】
一方、当該選択されたプログラムが情報プログラム115であれば、情報プログラム実行部112が、上記実行管理データに基づく残りリソースをパラメータ値として、当該選択されたプログラムである情報プログラム115を実行する。
【0151】
以上のような構成とすると、第1の実施の形態と同様な効果を得ることができるとともに、さらに、そのような各タスクが使用可能なメインメモリ210の残りリソースに接したユーザが適切な情報に基づいてダウンロード設定を行うことができるとともに、上述した選択されたプログラムが既存のプログラムに影響を与えないようにすることができる。
[幾つかの変形例]
【0152】
次に、変型例について説明する。上述した第1及び第2の実施の形態のうちの少なくとも1つでは、次のような変型例のうちの少なくとも1つを採用することができる。
【0153】
第1の変型例としては、例えばハイパバイザ等を利用してOS層から分けるようにしても良い。
【0154】
第2の変形例としては、各種プログラムの処理をシーケンシャルに行うことに代えて、処理結果に矛盾が生じない限り、処理の順序を入れ替え又は並行動作するように構成しても良い。
【0155】
第3の変形例としては、
図6A及び
図6Bに示す例がある。すなわち、制御プログラムの動作中に情報プログラムが変更される。具体的には、例えば、
図6Aが示すように、CTL007とITL008についてCPUコア番号306が共通している。
これは、制御プログラムであるCTL007の動作中に、情報プログラムであるITL008の実行のために同一コアが使用され得ること、つまり、タスク優先度303や利用デバイス307が違うもののCTL007の処理がITL008の影響を受け得ることを示している。
【0156】
ITL008は、情報プログラムであるため、制御プログラムの実行中に変更可能なプログラムである。コントロール装置109が有するITL008を削除した後に、ITL009をコントロール装置109に転送する。転送はプログラム配布装置101等により行われる。これにより、ITL008をITL009に変更することができる。
[上記説明の概念の一例]
【0157】
上記説明の概念の一例を説明するならば、次の通りである。物理的に(直接的だけでなく、ネットワークを通じて間接的に接続される場合も含む。)接続された制御対象装置ハードウェアのI/Oポートにアクセスすることによりハードウェアの動作を制御するコントロール装置であって、I/Oポートの情報を読み込み制御プログラムと情報プログラムがアクセス可能な共有領域に格納する格納手段と、制御プログラムは、I/Oポート又は格納されたI/Oポートの情報を取得し、I/Oポートに当該I/Oポートに接続された装置の制御情報を出力し、情報プログラムは、格納されたI/Oポートの情報を取得し、取得したI/Oポートの情報を演算することによって処理情報を特定することを特徴とするコントロール装置である。
[総括、及び、より具体的な実施の形態の一例]
【0158】
以下の説明は、これまでの説明の総括と、より具体的な実施の形態の一例とを含む。言い換えれば、以下の説明は、これまでの説明の重複部分と、これまでの説明に無い事項とのいずれを含んでもよい。
【0159】
制御対象装置の制御に必要な情報(例えば、センサによる測定値)を取得するための通信を制御プログラムによる制御の一部とすること(すなわち、通信について制御プログラムに記述されていること)が考えられるが、通信のような情報処理は制御プログラムによる制御とは分離しておくことが望ましいと考えられる。そのように考えられる1つの理由は、コントロール装置の制御対象装置は、一般に、工作機械、自動組み立て装置又は自動搬送装置のような自動機械や生産設備であるため、高い安定性、つまりリアルタイム性が求められるためである。
【0160】
そこで、制御プログラムに加えて、通信のような情報処理について記述されたプログラムである情報プログラムを用意しておくことが考えられる。リアルタイム性を維持するために制御プログラムを優先するべく、情報プログラムをコントロール装置とは別の装置で実行することが考えられるが、資源節約の観点から、制御プログラムと情報プログラムの両方をコントロール装置のような同一プラットフォーム上で実行することが考えられる。この場合、制御プログラムと情報プログラムがコントロール装置内に適切に共存することが求められる。
【0161】
しかし、上述した特許文献1及び2は、既に述べた理由から、制御プログラムと情報プログラムの適切な共存のための技術を開示も示唆もしていない。
【0162】
同一のプラットフォーム上で、1以上の制御プログラム114と1以上の情報プログラム115とを含んだ複数のプログラムが実行される。「同一のプラットフォーム」とは、上述の説明によればコントロール装置109である。
【0163】
1以上の制御プログラムの各々は、当該制御プログラムにとっての制御対象装置の制御のためのスキャン動作を行うプログラムである。一方、1以上の情報プログラムの各々は、スキャン動作を含まない情報処理を行うプログラムである。
【0164】
下記に例示する少なくとも1つによって、情報プログラムを柔軟に変更することが可能である。
・複数のプログラム114及び115の各々について、当該プログラムの動作の範囲を規定した複数のパラメータ値が設定される。制御プログラム114の実行と情報プログラム115の実行が、当該制御プログラム114と当該情報プログラム115の各々についての複数のパラメータ値に基づき行われる。情報プログラム115の複数のパラメータ値を、いずれの制御プログラム114の実行に悪影響が出ないよう調整可能である。
・1以上の共有領域が設けられる。1以上の共有領域の各々について、次のことが言える。すなわち、当該共有領域は、1以上の制御プログラム114の少なくとも1つの制御プログラム114と1以上の情報プログラム115の少なくとも1つの情報プログラム115がアクセス可能な記憶領域である。当該記憶領域には、例えば、当該制御プログラム114によりアクセスされるI/Oポートに関する情報と当該制御プログラム114に関する情報(例えば内部変数)とのうちの少なくとも一方を含んだ共有情報が格納される。当該共有領域に格納された共有情報を基に、当該共有領域にアクセス可能な情報プログラム115が、情報処理を行うことができる。言い換えれば、制御プログラム114の実行結果に基づく共有情報を基に情報プログラム115が実行されるため、情報プログラム115の実行が制御プログラム114に悪影響を与えないことが期待される。故に、制御プログラム114に悪影響を与えること無しに情報プログラム115を変更することが期待できる。
【0165】
例えば、複数のプログラム114及び115の各々について動作の範囲を規定した複数のパラメータ値を含む実行管理テーブル113が用意される。これにより、情報プログラム115の実行(動作)により制御プログラム114の実行に悪影響が出ることを防ぐことができる。当該複数のプログラム114及び115の各々について、複数のパラメータ値は、下記、
・タスク優先度303(当該プログラムの優先度の一例)、
・メモリ上限305(1種類以上の計算リソースに対応した1以上のリソース上限の一例)、
・利用デバイス307及び専有デバイス308(当該プログラムが利用可能な1以上のI/OポートのうちのいずれのI/Oポートが当該プログラムに専有のI/OポートでありいずれのI/Oポートが当該プログラムを含む2以上のプログラムで共有可能なI/Oポートであるかを表す専有/共有デバイスの一例)、
のうちの少なくとも1つを含む。
【0166】
タスク優先度303のようなプログラム優先度というパラメータ値があることで、制御プログラム114に求められるリアルタイム性の維持を優先した処理が可能である。例えば、計算リソースの節約の観点から、CPUコア、メモリ領域及びI/Oポートといった少なくとも1つの計算リソースを共有デバイスとすること、具体的には、制御プログラム114と情報プログラム115が共有することが考えられる。タスク優先度303の設定により、制御プログラム114と情報プログラム115が計算リソースを共有しても、制御プログラム114のリアルタイム性を損なわないよう情報プログラム115を実行することができる。
【0167】
メモリ上限305のようなリソース上限があることでも、制御プログラム114に求められるリアルタイム性の維持を優先した処理が可能である。例えば、情報プログラム115が再現なくメモリ量を使用した後で停止した場合にはメモリ量解放の処理が走ることになるが、この処理は、制御プログラム114よりも優先して行われることが考えられる。メモリ量を解放しないことには制御プログラム114が適切な処理を行うことができないことが考えられるためである。しかし、そうなると、制御プログラム114に求められるリアルタイム性が損なわれてしまう。このようなことを回避するために、リソース上限は有用である。
【0168】
制御プログラム114及び情報プログラム115の各々について、専有/共有デバイスという設定は、2以上のパラメータ値の組合せの設定であってよい。専有デバイスが設定されることで、安定した性能、例えば、リアルタイム性の維持が期待できる。共有デバイスが設定されることで、計算リソースを節約しつつ柔軟な処理が期待できる。
【0169】
例えば、
図7に例示する設定範囲テーブル700が用意されてよい。
図6Aと
図6Bで説明した例とは異なる設定方法を示す。また、
図8Aと
図8Bに示されるCPUコア、メモリ上限、LANポートは、それぞれ
図7のデフォルト値703と設定値704の値に対応する情報プログラム115が利用できるリソースを示す図である。すなわち、
図8Aは制御プログラム114がCPUコア1から4を専有しているが、3から4は未だ利用しておらず、5から8は情報プログラム115が専有する状態を示す。
【0170】
またメモリは、制御プログラム114と情報プログラム115がそれぞれ最大128MB使用できる。次に、制御プログラム114がLAN1と2を情報プログラム115がLAN4を専有し、これらのプログラムがLAN3を共有することを示す。
図8Bには、
図7に示す設定値704の値に対応するリソースが示される。設定範囲テーブル700は、ユーザが使用する計算機(例えば、管理ユーザ計算機151M)からプログラム配布装置101経由又は非経由でコントロール装置109に格納されてよい。設定範囲テーブル700は、情報プログラム115に関するパラメータ値の範囲を定めたテーブルであり、複数のパラメータ項目(例えば、
図3に例示したようなパラメータ項目303~308のうちの少なくとも1つと同じパラメータ項目を含んだ複数のパラメータ項目)の各々について、属性701、設定可能範囲702及びデフォルト値703といった情報を格納する。以下、1つのパラメータ項目を例に取る(
図7の説明において「対象パラメータ項目」)。設定値704はデフォルト値703を用いない場合に設定される値である。設定値704の一部が入力または設定された場合に、入力又は設定されていない値はデフォルト値703の値を用いるとよい。これにより、ユーザは情報プログラム115を利用する際に、すべての項目または一部の項目を設定せずとも情報プログラム115を実行させることができる。
図7に示すように表示手段に表示し、入力手段によって入力してもよいし、別途設定値704だけを設定してもよい。
【0171】
次に、
図8Cについて説明する。
図8Cは
図8Aの設定を変更した状態を示す。
図8Cには、CPUコア1と2を制御プログラム114が専有し、CPUコア7と8を情報プログラム115が専有し、CPUコア3から5を共有する場合が示されている。共有されるCPUコアは、それぞれのプログラム114と115の計算処理が足りない場合に利用することができる。また、タスク優先度に応じて使用量を変更することもできる。
【0172】
共有されるCPUコアは破線の境界線を用いると
図8Bとの違いがユーザに明確に示され便利であるが、当該違いの表現として他の表現が採用されてもよい。例えば、専有、共有それぞれの背景色を変更する、または、それぞれ異なるハッチング処理を施す等が採用されてもよい。メモリの設定は、
図8Bと同様のため説明を省略する。LANポートは、LAN1を制御プログラム114が専有し、LAN3を情報プログラム115が専有し、LAN2と4を制御プログラム114と情報プログラム115が共有する。
【0173】
属性701は、いずれかの情報プログラム115について対象パラメータ項目に対応したパラメータ値を変更するといずれかの制御プログラム114の実行(動作)へ悪影響が出る可能性があるか否かを表す。“A:設定注意”が、悪影響が出る可能性があることを意味する。“B:自由に設定可能”が、悪影響が出ないことを意味する。属性701を示すことにより、ユーザは悪影響が出ない項目を容易に知ることができる。
【0174】
設定可能範囲702は、対象パラメータ項目について情報プログラム115に関し設定可能なパラメータ値の範囲を表す。当該範囲内でパラメータ値を調整可能である。少なくとも1つのパラメータ項目について、設定可能範囲702は、個々の情報プログラム115についての値を表していてもよいが、
図7の例では、いずれのパラメータ項目についても、全ての情報プログラム115の合計としての値を表す。例えば、パラメータ項目“CPUコア数”は、情報プログラム114がCPUコア2から8のうちどのコアを使用するかを設定できるが、特に設定しない場合には、デフォルト値703に記載されるようにCPUコア4-8を使用する。“メモリ上限”に対応した設定可能範囲702は、全ての情報プログラム115についてのメモリ量合計の上限の範囲である。
図8Bに示す例では、情報プログラム115は、16から256MBまで設定可能であるが、設定値704が設定されていない場合はデフォルト値703の値である128MB使用し、設定値704を160MBと設定した場合には160MB使用することができる。これにより、
図8Aに示す例では、情報プログラム114はメモリを十分に利用できるため、情報プログラム114の動作をより安定させることができる。
【0175】
なお、少なくとも1つのパラメータ項目について、設定可能範囲702が、自動で設定又は変更されてよい。自動で設定される際には、制御プログラム114がデバイスのリソースや専有または共有する情報を参考に設定することができる。例えば、タスク管理部110が、制御プログラム114の使用リソースを基に、情報プログラム115についての設定可能範囲702を自動で設定又は変更してよい。例えば、制御プログラム114がLANポートのうちLAN1とLAN2を専有し、LAN3を共有する場合には、利用可能LANポートの設定可能範囲702をLAN3,LAN4とし、専有LANの設定可能範囲702をLAN4とするとよい。この場合は、LAN3を情報プログラム115が専有するように設定すると、制御プログラム114が使用できなくなるため、属性701には設定注意と記載される。なお、利用可能LANポートの設定可能範囲702をLAN4のみに設定すると、専有LANポートの設定可能範囲702はLAN4のみとなる。これは、利用できないLANポートを自動的に専有できない設定に変更することを意味する。
【0176】
また、パラメータ項目“ルーティング方式”は、
図9に例示するOS共通実装において採用される。例えば、後述の
図9を参照していえば、“Masquerade”は、コンテナ953(実行環境の一例)がコントロール装置909の外から通信を受け付けないことを意味する。“Port forward”は、コントロール装置909の外からの通信のうち、あるポートに対する通信のみ受け付けることを意味する。“IP forward”は、物理的なネットワークI/F(例えば
図1のネットワークI/F213)に、情報コンテナ953B専用のIPアドレスを追加で付与し、当該IPアドレスを指定した通信を、情報コンテナ953B内の情報プログラム115に転送することを意味する。
【0177】
また、パラメータ項目“利用可能LANポート”が情報プログラム115で利用できるLANポートを、“専有LANポート”が、情報プログラム115が専有するLANポートを示す。すなわち、情報プログラム115はデフォルトでLANポート3と4を制御プログラム114と共有し、LANポート4を専有する設定となる。
【0178】
また、パラメータ値“共有フォルダ”が、共有領域の一例である共有フォルダへのパスを表している。デフォルト値703には、共有なしであるため、特に設定がない限り共有フォルダがない状態となる。
【0179】
デフォルト値703は、対象パラメータ項目に対応したデフォルト値を表す。例えば、パラメータ項目“LANポート”に対応したデフォルト値によれば、情報プログラム115にパラメータ値“LAN3”と“LAN4”が、専有LANポートのパラメータ値に“LAN4”が設定される。つまり、LAN3は、共有デバイスであり、LAN4は情報プログラム115が専有するデバイスである。LANポートは
図8Aに示されるように、制御プログラムが1ポート専有し、情報プログラムが1ポート専有し、制御プログラムと情報プログラムが2ポートを共用する状態を示す。ここでの共有とは、制御プログラムであっても必ずしもリアルタイム性が要求されない通信と情報プログラムそれぞれがLANポートを利用する場合である。
【0180】
例えば、一方のプログラムが共有LANポートを使用する際に、他方のプログラムが使用する場合には、一方のプログラムの通信が終わるまで待機し、他方のプログラムが使用する。制御プログラム114がLANポートを専有することで、リアルタイム制御通信を使用する場合に有効である。制御プログラム114と情報プログラム115がLANポートを共有することで、一般のEthernet通信等の非リアルタイム通信を行う場合に有効である。情報プログラム115がコントロール装置109の外部である、例えば工場の外やインターネット等との通信を行う際に、コントロール装置109の外部から制御プログラム114やコントロール装置に109に接続された装置を見せないようにすることができるため、セキュリティの観点から有効である。
【0181】
複数のプログラム114及び115の各々に関し、
図8Aに例示するように、1種類以上の計算リソース(例えば、CPUコア、メモリ、LAN(I/Oポートの一例))の各々について、当該種類(それぞれのパラメータ項目)の計算リソースに対応したリソース上限は、当該種類の計算リソースについて定められたリソース境界(
図8において太線で示す)に基づいている。LANを共有する場合は、便宜的に中間位置に境界線を設けて表現している。1種類以上の計算リソースの各々について、リソース境界は、下記(x)と(y)で定義される境界である。制御プログラム114は(x)以下のリソースで、情報プログラム115は(y)以下のリソースで実行されることにより、それぞれのプログラムに影響を与えずに実行可能となる。なお、CPUはコア数に限らず、単一コアの場合を含めてスケジューリングの優先度を設定することも可能である。また、CPUコアが複数の場合に、CPUコアの専有の設定を変更せずに制御プログラム114が所定のスキャンタイムで実行されるようにスケジューリングすることも可能であり、この場合は、複数のコアを効率よく使用することができる。
(x)当該種類の計算リソースのリソース上限であって、当該種類の計算リソースを全制御プログラム114が使用可能なリソースの合計。
(y)当該種類の計算リソースのリソース上限であって、当該種類の計算リソースを1以上の情報プログラムが使用可能なリソースの合計。
【0182】
このようなリソース境界により、リアルタイム性の維持が期待できる。なお、
図8では、各種計算リソースについて、リソース境界より左側にある灰色帯は、全制御プログラム114が使用しているリソースの合計である総使用リソースを意味し、リソース境界より左側にある白色帯は、制御プログラム114に関しての余裕リソース(リソース境界と総使用リソースとの差分)を表す。つまり、灰色帯は実際の利用状態、白色帯は使用されていないが使用できるリソースを示す。一方、各種計算リソースについて、リソース境界より右側にある灰色帯は、全情報プログラム115が使用しているリソースの合計である総使用リソースを意味し、リソース境界より左側にある白色帯は、情報プログラム115に関しての余裕リソース(リソース境界と総使用リソースとの差分)を表す。これをリアルタイム表示やデバッグ時に表示することにより、リソースの使用量を特定し、設定値704によってより制御プログラム114または情報プログラム115を効率よく実行させることができる。
【0183】
複数のプログラム114及び115の実行を制御するタスク管理部110が、
図8A~
図8Cに例示するように、当該1種類以上の計算リソースの少なくとも1種類の計算リソースのリソース境界を動的に変更する。当該変更は、例えば、リソース境界変更のための所定のイベントが発生した場合に(例えば、ユーザからリソース境界の変更要求をタスク管理部110が受けた場合に)行われる。これにより、例えば、制御プログラム114に関して余裕リソースが十分ある種類の計算リソースについては、制御プログラム114にとってのリソースが減るリソース境界変更が実行される(例えば、計算リソース種類“メモリ”を参照)。このように、柔軟にリソース境界を変更することで、リアルタイム性を維持しつつ高スループットが期待できる。すなわち、リアルタイム性と高スループットの両立が期待できる。
【0184】
なお、少なくとも1種類の計算リソースについて、当該種類の計算リソースのリソース境界の変更が、制御プログラム114にとってのリソースが減る変更の場合、タスク管理部110が、下記の(A)及び(B)を行ってよい。下記の(A)及び(B)により、制御プログラム114にとってのリソースが減る境界変更、言い換えれば、情報プログラム115を追加したときの前提が変更されても、リアルタイム性の維持が期待できる。
(A)1以上の情報プログラム115の少なくとも1つを停止する。
(B)少なくとも1つの制御プログラム114について、下記(b1)及び(b2)のうちの少なくとも1つを実行する。
(b1)停止した情報プログラム115に割り当てられていた共有デバイス(例えばI/Oポートのうちの少なくとも1つ)を、当該制御プログラム114の専有デバイスに変更する。
(b2)当該制御プログラムのタスク優先度303を相対的に上げる(すなわち、当該制御プログラムのタスク優先度303を上げることと、停止した情報プログラム115のタスク優先度303を下げることの少なくとも1つを行う)。
【0185】
また、上述の説明では、制御プログラム114と情報プログラム115が共存するプラットフォームは、物理的なコンピュータとしてのコントロール装置109であるが、
図9に例示するように、別の例として、同一のOS952を採用することができる。つまり、制御プログラム114と情報プログラム115のOSは共通している。ここでも、複数のプログラム114及び115の各々について、当該プログラムの動作の範囲を規定した複数のパラメータ値を含んだ実行管理テーブル113が設定される。
【0186】
制御に関しては、一般に、高いリアルタイム性が求められ、情報処理に関しては、一般に、高いスループットが求められる。そして、OSとしても、一般に、制御向けのOSとしての専用OS(リアルタイムOS)と、情報処理向けのOSとしての汎用OSとがある。
【0187】
一般に、制御プログラムは専用OSが搭載された計算機で実行され、また、専用OSが搭載された計算機から情報系の計算に必要な情報を受信した汎用OSが搭載された計算機が実行されている。ここで、仮に、昨今の汎用計算機分野の技術を考慮すると制御プログラムは専用OS上で実行され、情報プログラムは汎用OS上で実行されることで本願発明と類似する構成とすることができると考えられる。このため、同一の計算機に制御プログラムと情報プログラムを共存させる場合、通常、計算機における計算リソース集合(物理的な計算リソースの集合としてのハードウェア)をエミュレートする仮想マシン技術を採用することになる。具体的には、例えば、ハイパバイザが、制御プログラム用に、ゲストOSとして専用OSを搭載した仮想マシンを生成し、情報プログラム用に、ゲストOSとして汎用OSを搭載した仮想マシンを生成し、制御プログラムと情報プログラムが、OSが異なる別々の仮想マシンで実行されることが考えられる。
【0188】
しかし、仮想マシン技術では、仮想マシンにおけるゲストOSの他に、仮想マシンのベースとなるホストOSが存在する。結果として、管理対象が多く、管理が煩雑となることが考えられる。
【0189】
また、計算機に機器が接続されても、当該計算機における全ての制御プログラムや情報プログラムが容易に当該機器を認識できるわけではない。仮想マシン別に、ゲストOSを介して、当該機器を認識するための処理が必要となる。言い換えれば、制御プログラムと情報プログラムがデバイスを共有することが困難である。
【0190】
本願の発明者の考察によれば、汎用OSの系統ではあるものの必要とされるリアルタイム性を提供できるリアルタイム機能を持ったOS(以下、便宜上、「リアルタイム汎用OS」と呼ぶ)が提供されている。
【0191】
このため、リアルタイム汎用OSを、
図9に例示するように、制御プログラム114及び情報プログラム115が共存するOS952として採用することが考えられる。
【0192】
しかし、制御プログラム114及び情報プログラム115がリアルタイム汎用OS上に共存するとなると、制御プログラム114のリアルタイム性の低下が懸念される。具体的には、例えば、リアルタイム汎用OSは、スケジューラを有し、当該スケジューラに割込みが発生するようになっている。スケジューラは、実行すべきリアルタイムタスク(制御プログラム114に対応したタスク)があれば、タスク優先度303に従い当該リアルタイムタスクへ制御を渡し、実行すべきリアルタイムタスクがなければ、通常タスク(例えば情報プログラム115に対応したタスク)へ制御を渡すようになっている。実行すべきリアルタイムタスクがあっても、通常タスクについて所定の処理まで終わらなければ、当該通常タスクは停止されない。このため、リアルタイムタスクの開始が遅れ、結果として、リアルタイム性が損なわれるおそれがある。
【0193】
そこで、制御プログラム114及び情報プログラム115の同一プラットフォームとしてOS952を採用し、且つ、当該環境において、上述した工夫のうちの少なくとも1つ、例えば、下記のうちの少なくとも1つを採用することにより、リアルタイム性が維持される。
・上述した実行管理テーブル113が設定される。すなわち、制御プログラム114及び情報プログラム115の各々についてリアルタイム性の維持を目的に決定されたパラメータ値が設定される。
・デバイスの共有化が容易になる代わりにリアルタイム性が低下することを避けるため、上述したようなリソース境界が設定される。
【0194】
パラメータ値の設置として、具体的には、例えば、
図3に例示したパラメータ値303~308の組み合わせにより、制御プログラム114及び情報プログラム115が同一OS952上に共存しても、リアルタイム性の維持が図られる。例えば、通常タスクについて所定の処理まで終わらなければ当該通常タスクは停止されないことを考慮してパラメータ値303~308を決定することが行われる。
【0195】
また、適宜にスループットを考慮して、リソース境界が、例えば、ホストプログラムの一例である実行制御プログラム957により動的に変更されてよい。その際、リソース境界の変更が、制御プログラム114にとってのリソースが減る境界変更の場合、上述の(A)及び(B)が、例えば、実行制御プログラム957により行われてよい。
【0196】
図9のコントロール装置909については、例えば以下の通りである。
【0197】
コントロール装置909の物理リソース集合951上で、OS952が実行される。OS952上でのプログラム実行環境として、コンテナ型仮想化に従うコンテナ953が採用される。すなわち、プログラムが、コンテナ953に設定され、OS952上で、コンテナ953の単位で実行される。コンテナ953としては、例えば、制御コンテナ953Aと情報コンテナ953Bの2種類のコンテナがある。
【0198】
制御コンテナ953Aは、制御プログラム114が格納され実行されるコンテナである。制御プログラム114は、例えば、ソフトウェアPLC系ランタイム961上で実行されて良い。制御プログラム114は、制御系通信を行っても良い。なお、制御系通信はシリアル又はパラレルの有線通信であっても、無線通信であっても良い。
【0199】
情報コンテナ953Bは、情報プログラム115が格納され実行されるコンテナである。少なくとも1つの情報プログラム115は、情報系通信を行うことができる。
【0200】
コントロール装置909で実行されるプログラムとして、上述のプログラム114及び115に加えて、他のプログラム、例えば、Webサーバプログラム956及び実行制御プログラム957がある。Webサーバプログラム956及び実行制御プログラム957は、いずれも、コンテナ953の外で実行されるホストプログラムの一例である。実行制御プログラム957は、コンテナ953の生成又は削除等を行うコンテナエンジンでよい。Webサーバプログラム956及び実行制御プログラム957が実行されることで上述のタスク管理部110が実現されてよい。
【0201】
Webサーバプログラム956は、Webサーバとして機能するためのプログラムである。Webサーバプログラム956が、管理ユーザ計算機151M及び一般ユーザ計算機151Gの各々(クライアント)と通信する。Webサーバプログラム956が、1以上の情報プログラム115のうちの少なくとも1つが格納されるコンテナについて、パラメータ値の設定を受け付けるユーザインターフェースプログラムの一例である。
【0202】
実行制御プログラム957は、コンテナ953におけるプログラムに関して設定されている複数のパラメータ値を基に、コンテナ953(正確には、コンテナ953におけるプログラム)の実行を制御する。
【0203】
制御プログラムと情報プログラムが動作する例について説明した。情報プログラムの処理が高度である場合、コントロール装置単体では情報プログラムの演算リソースが足りないことがあり得る。
【0204】
そこで、第3の実施の形態では、追加のハードウェアである演算支援ユニットをコントロールシステムに追加することができる。第3の実施の形態を、
図10から16を用いて説明する。なお、第3の実施の形態は、上述した第1の実施の形態と、第2の実施形態と、変形例とのうちの少なくとも一つと組み合わせることができる。
[第3の実施の形態]
【0205】
図10は、追加のハードウェアである演算支援ユニット1102を含むシステムのハードウェア構成例を示すブロック図である。コントロール装置109内の構成及び情報ネットワーク108に接続されるプログラム配布装置、管理ユーザ計算機、一般ユーザ計算機は
図1と同様のため図示及び説明を省略する。
【0206】
演算支援ユニット1102について説明する。演算支援ユニット1102は、
図11に示すデータバス1103に接続され、データバス1103はコントロール装置109とも接続されている。これにより、演算支援ユニット1102とコントロール装置109は通信を行うことができる。データバス1103は、演算支援ユニット1102とコントロール装置109が例えば筐体に差し込まれることで接続されるベースボード(筐体内に設けられたベースボード)内に設けられた通信I/Fでよい。データバス1103は、バスの一例で良い。
【0207】
図10には、コントロール装置109の構成を簡略化して示しており、コントロール装置109はデータバス1103と接続するバスI/F1104を有している。一方、
図10には示されていないが
図1に示したI/O制御装置214は、制御ネットワーク118に接続される。
【0208】
演算支援ユニット1102は、EPROM1105、CPU1106、メインメモリ1107、不揮発性記憶装置1110、ネットワークI/F1111、I/O制御装置1112、およびバスI/F1109を有している。
【0209】
EPROM1105には例えば演算支援ユニット1102の基本ソフトウェア等の管理プログラムとコントロール装置109や他の演算支援ユニット1102と連携または通信等をするための状態情報等を格納することが可能である。
【0210】
不揮発性記憶装置1110には、例えば演算支援ユニット1102で演算した演算結果等を格納することが可能である。
【0211】
CPU1106は、EPROM1105に予め格納されている管理プログラムをメインメモリ1107上に読み出して実行し、この管理プログラムによって演算を実行する。
【0212】
ネットワークI/F1111は、演算支援ユニット1102と外部のネットワーク(例えば上述の情報ネットワーク108)を接続するためのインターフェースである。ネットワークI/F1111は、RJ-45や数本の通信線等のI/Fであってもよい。
【0213】
I/O制御装置1112は、他のコントロール装置109や演算支援ユニット1102を外部機器と接続するための物理的なI/Fである。I/O制御装置1112は、制御ネットワーク118に接続される。なお、演算支援ユニット1102は、コントロール装置109の演算を支援できればよく、故に、データバス1103経由でコントロール装置109と通信できればよい。このため、I/O制御装置1112が設けられなくとも、演算支援ユニット1102は、コントロール装置109の演算を支援できる。
【0214】
データバス1103に、複数台の演算支援ユニット1102の接続が可能である。この場合、コントロール装置109と複数台の演算支援ユニット1102がデータバス1103を介して相互に接続される。
【0215】
データバス1103へのアクセスは、コントロール装置109内のバスI/F1104または演算支援ユニット1102のバスI/F1109を通して行われる。コントロール装置109と演算支援ユニット1102は、データバス1103を介してメインメモリ1107、EPROM1105、不揮発性記憶装置1110内の情報を更新、転送、共有等を行う事が可能である。
【0216】
演算支援ユニット1102のハードウェア構成は、コントロール装置109と同等のハードウェア構成で良い。このため、演算支援ユニット1102は、コントロール装置109同等の処理を実行することが可能である。同等の処理とは、例えばコントロール装置109の演算処理の一部を演算支援ユニットに実行させたり、コントロール装置109の処理を全て演算支援ユニット1102に実行させたりする処理がある。コントロール装置109がマスターとなり、コントロール装置109の一部の演算処理または所定の単位の演算処理を演算支援ユニット1102のいずれかがスレーブとして行い、その演算結果をマスターであるコントロール装置109に戻す処理を行うことができる。
【0217】
一部の演算処理をスレーブである演算支援ユニット1102が実施可能であるということは、コントロール装置109に設定されたスキャンタイムまたはサイクルタイム内に、演算支援ユニット1102が当該一部の演算処理を行い、演算結果(当該一部の演算処理の結果)をデータバス1103を介してコントロール装置109に戻す処理を行うことが、完了することである。
【0218】
また、演算支援ユニット1102がデータバス1103に複数台接続される場合には、当該複数台の演算支援ユニット1102のそれぞれが、当該演算支援ユニット1102に与えられた(割り当てられた)一部の演算処理を行い、且つ、当該一部の演算結果をコントロール装置109に戻す処理を行う。複数台の演算支援ユニット1102が、データバス1103を同時に使用できない場合は、所定の順序で演算支援ユニット1102が演算結果を順次戻す処理を行う。複数台の演算支援ユニット1102がデータバス1103に接続されるケースでは、それぞれ一部の演算処理を演算支援ユニット1102が実施可能であるということは、複数台の演算支援ユニット1102がそれぞれ行う一部の演算処理と演算結果を戻す処理との全てが、コントロール装置109のスキャンタイム内に行われることである。
【0219】
上記条件の下、演算支援ユニット1102はコントロール装置109の演算の一部の割り当てを受けて実施することができ、結果として、コントロールシステムが、分散コンピューティングシステムのように処理を実施できる。
【0220】
また、演算支援ユニット1102はベースボードに設けられたデータバス1103に接続される以外に、Ethernet等で接続することも可能である。この場合は、コントロール装置109が制御する制御対象機器に演算支援ユニット1102が直接アクセスできないため、制御対象機器のI/Oの状態を読み込んで演算する処理はベースボードに接続された演算支援ユニット1102またはコントロール装置109に優先的に割り当てられるとよい。
【0221】
したがって、演算支援ユニット1102には、例えばコントロール装置109(またはプログラム配布装置101)により、情報プログラムの一部または全部の演算処理(例えば、コントロール装置109に接続されるI/Oポートを直接読み込みまたは書き込みを行わない演算処理)が割り当てられるとよい。
【0222】
コントロール装置109にベースボードを介して接続されたI/Oモジュールに接続された産業機器への書き込みとは別の演算処理が演算支援ユニット1102に割り当てられると、産業機器の制御を熟知したプログラマーでなくとも、当該演算支援ユニット1102で実行される情報プログラムを作成することができる。また、産業機器の制御を熟知したプログラマーは、情報プログラムが制御プログラムに影響を与えずにそれぞれ別に動作するため、安心して産業機器を運用することができる。
【0223】
図11は、追加のハードウェアである演算支援ユニットを含む機能的構成例を示すブロック図である。
【0224】
コントロール装置109は、演算プログラム実行部1204、演算支援ユニット管理部1205、管理プログラム送受信部1208、および、データ共有部1209を有する。演算支援ユニット管理部1205は、管理テーブル1206を管理し、タイミング管理部を有する。演算プログラム実行部1204は、
図2の制御プログラム実行部111および情報プログラム実行部112に対応する。演算支援ユニット管理部1205、管理プログラム送受信部1208およびデータ共有部1209は、コントロール装置109のCPU209により所定の1以上のプログラムが実行されることにより実現される機能である。管理テーブル1206は、実行管理テーブル113と別に用意されるテーブルでもよいし、実行管理テーブル113を含んだテーブルでもよい。データ共有部1209が、I/O制御部117を含んでも良いし、I/O制御部117に含まれても良い。
【0225】
演算支援ユニット1102は、少なくとも演算プログラム実行部1210と、プログラム実行管理部1211と、ステータス管理部1212と、データ共有部1213とを有す構成る。これらの機能1210~1213は、演算支援ユニット1102のCPU1106により所定の1以上のプログラムが実行されることにより実現される機能である。
【0226】
コントロール装置109と演算支援ユニット1102は、データバス1103を介して接続されており、コントロール装置109のデータ共有部1209と演算支援ユニット1102のデータ共有部1213を介して、データを共有することが可能である。
【0227】
コントロール装置109内の演算プログラム実行部1204は、制御プログラムや情報プログラムを実行する部分である。演算支援ユニット1102の演算プログラム実行部1210は、コントロール装置109の演算プログラム実行部1204の演算だけでは、処理能力が不足する場合、コントロール装置109の演算を支援する(例えば、不足分の処理の少なくとも一部の演算)を実行する。
【0228】
コントロール装置109で実行された制御プログラム(または制御プログラムを実行した演算プログラム実行部1204)がスキャンタイムの開始後にI/Oモジュール等の状態を読み込んだ後に、当該制御プログラムがデータ共有部1209を通じてデータ共有部1213にデータ(例えば読み込んだ状態を表すデータ)をコピーまたは直接書き込みを行う。また、適宜、コントロール装置109で実行された制御プログラム(または制御プログラムを実行した演算プログラム実行部1204)がI/Oモジュールを制御するための演算を行った演算結果を、データ共有部1209を通じてデータ共有部1213にコピーまたは直接書き込みを行う。データ共有部1213は、複数台の演算支援ユニット1102から所定のタイミングで読み込みを行う。演算支援ユニット1102で実行された制御プログラムまたは情報プログラム(あるいは、当該プログラムを実行した演算プログラム実行部1210)は、所定の演算処理を行った後に、必要に応じて他の演算支援ユニット1102やコントロール装置109と競合しないタイミングでデータ共有部1213に演算結果を書き込む。
【0229】
なお、第一の演算支援ユニット1102の演算プログラム実行部1210が、情報プログラムの演算処理を行う場合であって、演算結果としてのデータを第二の演算支援ユニット1102と共有する必要がない場合には、第一の演算支援ユニット1102の演算プログラム実行部1210は、第一の演算ユニット1102のデータ共有部1213にデータの書き込みを行わなくてもよい。この場合は、データ共有部1213へのデータの書き込みが不要となるため、スキャンタイムを短く設定することができ、より細かいスキャンタイムで産業機器を制御することが可能となる。
【0230】
演算支援ユニット管理部1205は、演算支援ユニット1102の管理を行う機能である。例えば、演算支援ユニット管理部1205は、演算支援ユニット1102のステータス管理部1212が管理する情報(当該演算支援ユニット1102のステータスを表す情報)を取得することで、当該演算支援ユニット1102の支援ユニットステータスを把握することが可能である。ここで言う「支援ユニットステータス」とは、演算支援ユニット1102の温度、通信速度、計算速度、演算支援ユニット1102におけるファームウェアまたはカーネル等の状態である。
【0231】
タイミング管理部1207は、コントロール装置109と複数台の演算支援ユニット1102がデータバス1103を介してデータを送受信する際のタイミングを管理している。
【0232】
通常時、データバス1103上は、コントロール装置109と演算支援ユニット1102の間で上記したように演算結果等を定周期またはイベント発生のタイミングでデータの送受信を行う。
【0233】
しかし、例えば演算支援ユニット1102に異常が発生した場合は、演算を継続することが不可能になるため、コントロールシステムとして動作を継続させるために他の演算支援ユニット1102に演算を移行する必要が生じる。この場合、演算プログラム(典型的には制御プログラムまたは情報プログラム)や演算に必要なパラメータ等を一方の演算支援ユニット1102からもう一方の演算支援ユニット1102へ移行する必要がある。
【0234】
そこで、タイミング管理部1207は、演算支援ユニット1102において演算プログラム(制御プログラム又は情報プログラム)の実行中に当該演算支援ユニット1102について切替タイミングが検出された場合に、当該演算支援ユニット1102において実行されたプログラムの演算結果としてのデータを含む移行対象を、切替元の演算支援ユニット1102から切替先の演算支援ユニット1102に、転送する(移行する)切替処理を実施する。当該移行対象を用いて、処理が、切替先の演算支援ユニット1102により継続される。
【0235】
「切替タイミング」は、切替処理を実施するタイミングであり、例えば、以下のうちの少なくとも一つで良い。
・いずれかの演算支援ユニット1102から取得された支援ユニットステータスが、異常であることが検出されたタイミング。
・いずれかの演算支援ユニット1102から取得された支援ユニットステータスが、定常状態と異なる状態を表していることを検出され、且つ、そのような支援ユニットステータスが一定時間継続して検出されるといった異常予兆条件が満たされたが故に異常発生のおそれありが検出されたタイミング。
【0236】
「切替元の演算支援ユニット」は、異常が検出された演算支援ユニット1102、あるいは、異常発生のおそれありが検出された演算支援ユニット1102で良い。
【0237】
「切替先の演算支援ユニット」は、定常状態が検出された演算支援ユニット1102でよい。一台の切替元の演算支援ユニットに対して切替先の演算支援ユニットは一台または複数台存在してよい。すなわち、本コントロールシステムは分散コンピューティングも可能であるため、一台の演算支援ユニット1102だけを演算切替先とせず、複数台の演算支援ユニット1102に分散させるよう演算切替先を指定することができる。
【0238】
タイミング管理部1207は、異常が生じることを予測した状態(異常発生のおそれありの演算支援ユニット1102が検出されたこと)を表示手段(例えば、一般ユーザ計算機151Gや管理ユーザ計算機151M)に表示すると(具体的には、当該予測した状態を表す情報を表示手段に送信すると)、演算支援ユニット1102の交換時期をユーザや管理者が知ることができ便利である。
【0239】
管理プログラム送受信部1208は、演算支援ユニット1102の管理プログラムの送受信を行う。
【0240】
演算支援ユニット1102のプログラム実行管理部1211は、ステータス管理部1212が管理する情報を基に演算プログラム実行部1210で実行する演算のタイミングを管理している。
【0241】
図12は、コントロール装置109の管理テーブル1206の構成例を示したものである。コントロール装置109のタイミング管理部1207は、各演算支援ユニット1102のステータス管理部1212の情報を読取り、読み取った情報を管理テーブル1206に登録する。
【0242】
管理テーブル1206は、例えば演算支援ユニット1202毎にレコードを有する。各レコードは、ユニット番号1301、演算実行種別1302、管理プログラムバージョン1303、演算プログラム名称1304、実行状態1305、支援ユニットステータス1306および切替先番号1307といった情報を有する。一つの演算支援ユニット1202を例に取る(
図12の説明において、「対象支援ユニット1202」)。
【0243】
ユニット番号1301は、対象支援ユニット1102を識別するための番号である。
【0244】
演算実行種別1302は、対象支援ユニット1102で実行される演算プログラムが情報プログラムであるのか制御プログラムであるのかを示している。対象支援ユニット1102において複数の演算プログラムが実行される場合、対象支援ユニット1102に対応したレコードに、演算プログラム毎に、演算実行種別1302が含まれて良い。
【0245】
管理プログラムバージョン1303は、対象支援ユニット1102の管理プログラムのバージョンを示している。
【0246】
演算プログラム名称1304は、対象支援ユニット1102により実行される演算プログラム(情報プログラムまたは制御プログラム)の名称を示している。
【0247】
実行状態1305は、対象支援ユニット1102により実行される演算プログラムの演算実行状態(例えば、“実行”または“停止”)を示している。
【0248】
支援ユニットステータス1306は、対象支援ユニット1102の支援ユニットステータスを示している。
【0249】
切替先番号1307は、対象支援ユニット1102が切替元である場合の切替先(演算切替先)の演算支援ユニットの識別番号を示している。例えば、対象支援ユニット1102に対して、切替先の演算支援ユニットは、以下のように割り当てられてよい。すなわち、タイミング管理部1207が、支援ユニットステータス“正常”の演算支援ユニット1102のリソースを確認する。タイミング管理部1207が、支援ユニットステータス“異常”(または、上述のように異常発生のおそれあり)と検出された演算支援ユニット1102における一つ以上の演算プログラムの各々の必要リソース量を所定のテーブル(例えば、実行管理テーブル113および/または設定範囲テーブル700)から特定する。タイミング管理部1207が、支援ユニットステータス“異常”(または、上述のように異常発生のおそれあり)と検出された演算支援ユニット1102における一つ以上の演算プログラムの各々について、当該演算プログラムの必要リソース量以上のリソース量のリソースを持つ、支援ユニットステータス“正常”の演算支援ユニット1102を特定する。二つ以上の演算プログラムの総必要リソース量以上のリソース量を持つ一台の演算支援ユニット1102が特定されても良い。このようにして、タイミング管理部1207が、一台の演算支援ユニット1102に対し、自動で、一台または複数台の演算支援ユニット1102を演算切替先として割り当てることができる。
【0250】
これまでに示した仕組みを利用して、例えば演算支援ユニットが異常となった場合に他の演算支援ユニットに演算を切り替える仕組みについて説明する。
【0251】
図13は、演算支援ユニットが異常になった場合に、コントロール装置が他の演算支援ユニットへの演算切り替えを行う例を示したフローチャートである。
【0252】
まず、ある演算支援ユニットが異常となった場合、コントロール装置109のタイミング管理部1207は、管理テーブル1206の支援ユニットステータス1306を基に演算支援ユニット1102の異常を検出する(ステップS1401)。次に、タイミング管理部1207は、異常となった演算支援ユニット1102のデータをバックアップし(S1401-1)、異常となった演算支援ユニット1102の切替先ユニット(異常となった演算支援ユニット1102に対応した切替先番号1307から同定される演算支援ユニット1102)の支援ユニットステータス1306が“正常”か否かを判定する(S1402)。
【0253】
ここで、S1402の判定結果が偽の場合は、タイミング管理部1207は、演算の切り替え(移行処理)を中止する。
【0254】
S1402の判定結果が真の場合は、タイミング管理部1207は、異常となった演算支援ユニットの演算データ(移行対象の一例)を切替先ユニットに転送する(S1404)。演算データの転送が完了すると、切替先ユニットで演算が開始される(S1405)。このようにして、コントロールシステムがシステムダウンすることなく演算を継続できる。
【0255】
ここで異常となった演算支援ユニットはシステムから取り外して、正常な演算支援ユニットの取り付けを行う事により、例えば切替先演算支援ユニットの演算を取り換えた演算支援ユニットに切替えて戻すことが可能である。「システムから取り外す」とは、演算支援ユニット1102をベースボードのソケットから外すまたはethernet等で接続された状態からコネクタを外すということである。ベースボードから演算支援ユニット1102を取り外す場合に、ホットスワップに対応にしたベースボードやシステムであると、コントロール装置109の電源をオフにする必要がなく、つまり、制御プログラムは制御機器の制御を継続することができる。
【0256】
次に、演算支援ユニットの管理プログラムのバージョン変更を行う場合の仕組みについて説明する。管理プログラムは、例えばOSのような基本プログラムを含む機器固有のファームウェアで良く、バージョンを変更して使用したい場合が有る。
【0257】
コントロール装置109の不揮発性記憶装置215には、各演算支援ユニットの管理プログラムが格納されている。この管理プログラムは管理ユーザ計算機151M、もしくは一般ユーザ計算機151Gから提供される。
【0258】
演算支援ユニットの管理プログラムのバージョン変更を行う際は、切替先の演算支援ユニット1102へ演算の実行を移行した後に(つまり切替処理が行われた後に)切替元の演算支援ユニットの管理プログラムのバージョン変更を、管理プログラム送受信部1208が行う。
【0259】
図14は、演算支援ユニットの管理プログラムのバージョンを変更する際の例を示したフローチャートである。
【0260】
まず、管理プログラムのバージョン変更を行う場合、管理プログラム送受信部1208が、切替元ユニット1102(バージョンが変更される管理プログラムを有する演算支援ユニット1102)に対応した切替先ユニット1102の支援ユニットステータス1306が“正常”か否かを判定する(S1501)。ここでS1501の判定結果が偽の場合は、管理プログラムバージョン変更が中止される。
【0261】
S1501の判定結果が真の場合は、管理プログラム送受信部1208が、切替元ユニット1102の演算データを含む移行対象を切替先ユニットに転送する(S1503)。演算データの転送が完了すると、切替先の演算支援ユニット1102で演算が開始される(S1504)。システムダウンすることなく演算が継続できる。
【0262】
次に、管理プログラム送受信部1208が、切替元ユニット1102への変更後のバージョンの管理プログラムを転送することと、当該切替元ユニットの管理プログラムの書き換えとを行う(S1505)。書換えは、例えば、コントロール装置109の不揮発性記憶装置215に格納されている管理プログラムを、切替元ユニットのEPROM1105に転送することにより行われて良い。
【0263】
管理プログラムの書き換えが完了した後、管理プログラム送受信部1208が、切替先ユニットの演算データを含む移行対象を、切替元ユニット(管理プログラムが書き換えられた演算支援ユニット)に転送する(S1506)。最後に、切替元ユニットが演算を開始する(S1507)。
【0264】
これまで、演算支援ユニット1102の演算切替の仕組みと管理プログラムのバージョン変更の仕組みとについて説明したが、コントロール装置109と演算支援ユニット1102間のデータ転送のタイミングについて以降にて説明する。
【0265】
図15はコントロール装置109と演算支援ユニット1102がデータバス1103を介してデータを送受信する際のタイミングを示した図である。
【0266】
1つのコントロール装置109に演算支援ユニット1102は複数接続され、順番にデータの送受信が行われる。データの送受信は、例えば次のように行われる。すなわち、コントロール装置109が、送受信先の演算支援ユニットx(xは、0、1、…、nのいずれかの整数)のスロットへの選択信号csxのレベルを変化させることで(例えばLowレベルとすることで)演算支援ユニットxを選択し、選択した演算支援ユニットxに対してアドレス(ADR)を指定し、データ(DATA)の送受信を行う。
【0267】
演算方法は大きく以下の2つに分けられる。
(演算方法A)コントロール装置109にのみ制御プログラムが格納され実行される。
(演算方法B)コントロール装置109と演算支援ユニット1102のそれぞれに制御プログラムが格納されコントロール装置109と演算支援ユニット1102が共同で制御プログラムが実行される。
【0268】
以下、それぞれの演算方法を説明する。
【0269】
<演算方法A>
【0270】
制御プログラムが、リフレッシュサイクルの開始からデータ共有期間が始まる前までの時間でI/Oモジュール等の状態の読み込みやI/Oモジュール等に接続された産業機器の演算処理を行い、演算結果(演算処理の結果)を書き込む。
【0271】
演算支援ユニット1102や情報プログラムの処理を行うために、制御プログラムが、I/Oモジュール等の演算結果を、選択した演算支援ユニットxのデータ共有部1213(例えば、データ共有部1213が提供するアドレス空間)に書き込む。この処理はデータ共有の一例である。
【0272】
コントロール装置109に格納された情報プログラムや演算支援ユニット1102に格納された情報プログラムはアイドル期間やCPUが空いている時間帯または空いているCPUのコアがある場合に適宜実行される。なお、この演算方法Aについても、切替処理のような転送処理は、アイドル期間に行われてよい。
【0273】
<演算方法B>
【0274】
制御演算時間が開始されると、コントロール装置109のI/Oモジュール等に接続された制御対象機器(典型的には産業機器)の情報がコントロール装置109に読み込まれる。その後、コントロール装置109のみで演算可能な処理については制御演算時間で演算が行われる。つまり、制御演算期間は、一つ以上の制御プログラムによる制御の期間である。
【0275】
そして、演算支援ユニット1102と共同で演算を行う処理に向けて、時がデータ共有期間に移行する。移行後は、演算支援ユニット0とのデータ送受信はCS0がLOWレベルのタイミングでコントロール装置109と演算支援ユニット0でデータの共有と演算を行う。同様に、演算支援ユニット1とのデータ送受信はCS1がLOWレベルのタイミングで演算とデータの共有を行う。なお、データの共有を優先して行い、その後、コントロール装置109と複数の演算支援ユニットで演算処理を行うこともできる。
【0276】
このように順番にデータの送受信を行うが、演算支援ユニットnとのデータ送受信を行った後は(すなわち、演算支援ユニット0から演算支援ユニットnまでといった全ての演算支援ユニットとのデータ送受信が行われた後は)、次のリフレッシュサイクルを開始するまで一定期間データ送受信をしないアイドル期間がある。つまり、演算終了後は、演算時間が遅延した場合を考慮して設定されたアイドル期間を経て、一周期のリフレッシュサイクルが終了する。アイドル期間においては、制御対象機器の制御に影響を与えない情報プログラムの演算処理が実施されて良い。
【0277】
また、上記した異常が生じた演算支援ユニット1102が検出された場合の管理プログラムや情報プログラムの切替処理(移行処理)は、このアイドル期間に行われて良い。これにより、一周期(一つのリフレッシュサイクル内)で切替処理が完了する必要はなく、複数の周期に跨って切替処理を行うことができる。
【0278】
さらに、上記の切替処理に限定されることなく、新たにベースボードに差し込まれた演算支援ユニット1102と他の演算支援ユニット1102とのファームウェアが異なる場合には、差し込まれた演算支援ユニット1102に他の演算支援ユニット1102に格納されたプログラムが移行されてよい。すなわち、切替元ユニットが、支援ユニットステータス“正常”のいずれかの既存の演算支援ユニットでよく、切替先ユニットが、新たにコントロールシステムに追加された(例えば、上述のベースボードに新たに接続された)演算支援ユニットでよい。
【0279】
切替処理後に、既存の各演算支援ユニット1102は、差し込まれた演算支援ユニット1102のファームウェアを自身にコピーし、ファームウェアの更新を行って良い。ファームウェアの更新が成功した場合には、差し込まれた演算支援ユニット1102が演算プログラムの演算を続行しても良い。アイドル期間に既存の他の演算支援ユニット1102に差し込まれた演算支援ユニット1102から演算プログラムを再度移行されてもよい。これにより、演算支援ユニット間のファームウェアを統一することができ、よりコントロールシステムの安定性を向上させることができる。なお、切替処理は、データ転送を含む転送処理の一例でよい。
【0280】
演算支援ユニット1102間の切替処理は、演算支援ユニット管理部1205によって制御されて良い。コントロール装置109が、切替元ユニットにも切替先ユニットにもなり得る。つまり、コントロール装置109が、演算支援ユニットの一つを兼ねても良い。
【0281】
また、演算支援ユニットのファームウェアに関する情報は、例えば、当該演算支援ユニットのステータス管理部1212が管理する、支援ユニットステータスを表す情報に含まれていてよく、支援ユニットステータスからファームウェア(例えばそれのバージョン)が検出されてよい。新たに追加された演算支援ユニットのファームウェアと既存の演算支援ユニットのファームウェアが同じか否かは、演算支援ユニット管理部1205により判定されてよい。ファームウェアが異なる演算支援ユニット1102が接続された場合に、例えば演算支援ユニット管理部1205により、表示手段に、演算支援ユニット間で異なるファームウェアを有することを検出したことが表示されてよい。ユーザまたは管理者の指示によって、ファームウェアを更新するか、そのまま更新せずにシステムを稼働し続けることを選択することができる。
【0282】
上記したファームウェアや管理プログラムの更新処理について
図13及び
図14を用いて説明する。
図13に示すデータ転送(S1404)及び
図14に示すデータ転送(S1503、S1505、S1506)はアイドル期間で行われる。アイドル期間でデータの転送を行う事により、システムの動作に影響を与えずに演算ユニットの切替、管理プログラムのバージョンアップ、及び、ファームウェアの更新を行う事が可能である。
【0283】
また、演算支援ユニット1102は、コントロール装置109の演算を支援するものであるが、コントロール装置109のCPUやメモリよりも高性能であってもよい。この場合は、コントロール装置109は信頼性が高い旧機種としながらも、演算支援ユニット1102を交換が容易な装置を選択することで、コントロールシステムの信頼性と高性能化を両立させることができる。
【0284】
上記の説明した実施例で説明した仕組みによって、従来は生産ラインの性能を向上させるにはコントロール装置109を交換しなければならなかったが、生産ラインの稼働後に、新たな機能や新たな処理が必要となった場合であっても、必要な演算量に応じて演算支援ユニット1102を追加することで、生産ラインやユーザが所望するコントロールシステムを構築することが可能となる。
【0285】
以上、本発明者によってなされた発明を発明の実施の形態に基づき具体的に説明したが、本発明は前記発明の実施の形態に限定されるものではなく、その要旨を逸脱しない範囲で種々変更可能であることは言うまでもない。
【0286】
なお、本発明は上記した実施の形態に限定されるものではなく、様々な変形例が含まれる。例えば、上記した実施の形態は本発明を分かりやすく説明するために詳細に説明したものであり、必ずしも説明した全ての構成を備えるものに限定されるものではない。
【0287】
また、ある実施の形態の構成の一部を他の実施の形態の構成に置き換えることが可能であり、また、ある実施の形態の構成に他の実施の形態の構成を加えることも可能である。
【符号の説明】
【0288】
101……プログラム配布装置、102……プログラム配布部、103……実行管理生成部、104……プログラム管理データベース、105……制御プログラム、106……情報プログラム、109……コントロール装置、110……タスク管理部、113……実行管理テーブル、114……制御プログラム、115……情報プログラム