JP2023164999A - Program creation assistance device for programmable logic controller - Google Patents
Program creation assistance device for programmable logic controller Download PDFInfo
- Publication number
- JP2023164999A JP2023164999A JP2023147288A JP2023147288A JP2023164999A JP 2023164999 A JP2023164999 A JP 2023164999A JP 2023147288 A JP2023147288 A JP 2023147288A JP 2023147288 A JP2023147288 A JP 2023147288A JP 2023164999 A JP2023164999 A JP 2023164999A
- Authority
- JP
- Japan
- Prior art keywords
- unit
- program
- display
- event
- data
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000003860 storage Methods 0.000 claims description 136
- 230000015654 memory Effects 0.000 claims description 111
- 238000010586 diagram Methods 0.000 claims description 65
- 238000004891 communication Methods 0.000 claims description 59
- 238000000034 method Methods 0.000 claims description 46
- 230000008569 process Effects 0.000 claims description 34
- 238000012545 processing Methods 0.000 claims description 20
- 238000003780 insertion Methods 0.000 claims description 4
- 230000037431 insertion Effects 0.000 claims description 4
- 101100408464 Caenorhabditis elegans plc-1 gene Proteins 0.000 abstract description 91
- 230000008859 change Effects 0.000 abstract description 13
- 230000006870 function Effects 0.000 description 132
- 230000000875 corresponding effect Effects 0.000 description 44
- 238000001514 detection method Methods 0.000 description 22
- 238000000605 extraction Methods 0.000 description 22
- 238000013024 troubleshooting Methods 0.000 description 21
- 230000033001 locomotion Effects 0.000 description 20
- 238000007726 management method Methods 0.000 description 18
- 238000013500 data storage Methods 0.000 description 17
- 102100026205 1-phosphatidylinositol 4,5-bisphosphate phosphodiesterase gamma-1 Human genes 0.000 description 12
- 101000691599 Homo sapiens 1-phosphatidylinositol 4,5-bisphosphate phosphodiesterase gamma-1 Proteins 0.000 description 12
- 239000000284 extract Substances 0.000 description 12
- 230000001360 synchronised effect Effects 0.000 description 8
- 238000012546 transfer Methods 0.000 description 8
- 230000002093 peripheral effect Effects 0.000 description 7
- 230000001276 controlling effect Effects 0.000 description 6
- 238000004364 calculation method Methods 0.000 description 5
- 238000012217 deletion Methods 0.000 description 5
- 230000037430 deletion Effects 0.000 description 5
- PWPJGUXAGUPAHP-UHFFFAOYSA-N lufenuron Chemical compound C1=C(Cl)C(OC(F)(F)C(C(F)(F)F)F)=CC(Cl)=C1NC(=O)NC(=O)C1=C(F)C=CC=C1F PWPJGUXAGUPAHP-UHFFFAOYSA-N 0.000 description 5
- 238000012795 verification Methods 0.000 description 5
- 238000004458 analytical method Methods 0.000 description 4
- 230000001343 mnemonic effect Effects 0.000 description 4
- 238000012986 modification Methods 0.000 description 4
- 230000004048 modification Effects 0.000 description 4
- 230000006399 behavior Effects 0.000 description 3
- 230000005540 biological transmission Effects 0.000 description 3
- 230000007717 exclusion Effects 0.000 description 3
- 238000001914 filtration Methods 0.000 description 3
- 230000014759 maintenance of location Effects 0.000 description 3
- 238000012544 monitoring process Methods 0.000 description 3
- 230000003203 everyday effect Effects 0.000 description 2
- 238000004088 simulation Methods 0.000 description 2
- 101100214695 Staphylococcus aureus aacA-aphD gene Proteins 0.000 description 1
- 230000001133 acceleration Effects 0.000 description 1
- 230000003466 anti-cipated effect Effects 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 238000004040 coloring Methods 0.000 description 1
- 238000004590 computer program Methods 0.000 description 1
- 238000012790 confirmation Methods 0.000 description 1
- 238000012937 correction Methods 0.000 description 1
- 230000002596 correlated effect Effects 0.000 description 1
- 238000013480 data collection Methods 0.000 description 1
- 230000001934 delay Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000003384 imaging method Methods 0.000 description 1
- 238000007689 inspection Methods 0.000 description 1
- 238000004519 manufacturing process Methods 0.000 description 1
- 230000000873 masking effect Effects 0.000 description 1
- 239000000463 material Substances 0.000 description 1
- 239000011159 matrix material Substances 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 238000003825 pressing Methods 0.000 description 1
- 238000011084 recovery Methods 0.000 description 1
- 230000004044 response Effects 0.000 description 1
- 238000012552 review Methods 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 238000012360 testing method Methods 0.000 description 1
- 230000007704 transition Effects 0.000 description 1
- 230000003936 working memory Effects 0.000 description 1
Images
Landscapes
- Programmable Controllers (AREA)
Abstract
Description
本発明は、プログラマブルロジックコントローラ用プログラム作成支援装置に関する。 The present invention relates to a program creation support device for a programmable logic controller.
プログラマブルロジックコントローラ(Programmable Logic Controller:以下、「PLC」という。)はファクトリーオートメーション(Factory Automation:FA)において製造機器や搬送装置、検査装置を制御するコントローラである。PLCはユーザによって作成されるラダープログラム等のユーザープログラムを実行することで様々な拡張ユニットや被制御機器を制御する。ユーザープログラムを実際にPLC上で実行してみて、ユーザープログラムの作成時には想定していなかった事象が見つかり、ユーザープログラムの修正が必要となることがある。ユーザは修正箇所を特定するためにユーザープログラムを見直すだけでなく、PLCが生成したログデータを参照する。ログデータにはユーザープログラムを実行しているときに収集されたデバイスの値(デバイス値)が記憶される。PLCの分野においてデバイスとは情報を記憶する記憶領域を意味する。デバイスとしては、一ビットの情報を保持するリレーデバイスや一ワードの情報を保持するワードデバイス等がある。 A programmable logic controller (hereinafter referred to as "PLC") is a controller that controls manufacturing equipment, transport equipment, and inspection equipment in factory automation (FA). The PLC controls various expansion units and controlled devices by executing user programs such as ladder programs created by the user. When a user program is actually executed on a PLC, a phenomenon that was not anticipated when the user program was created may be discovered, and the user program may need to be modified. The user not only reviews the user program to identify correction points, but also refers to the log data generated by the PLC. Log data stores device values (device values) collected while a user program is running. In the field of PLC, a device means a storage area that stores information. Devices include relay devices that hold one bit of information, word devices that hold one word of information, and the like.
FAの分野でシーケンス制御を行うため、PLC用のプログラムを、プログラム編集用のアプリケーションプログラムを設計する。設計者は、プログラムを設計した後、このプログラムのシーケンス動作をシミュレーションし、シミュレーションの結果を検証しながらプログラムをデバッグして、完成したプログラムをPLCに転送し、実行させる。しかしながら、必ずしも想定したとおりの動作が実現されるとは限らず、実運用を踏まえて、プログラムを再度デバッグするなど、編集することが行われる。特に実運用時に、想定どおりの動作が実現できていない場合は、その原因がどこにあるのか、トラブルの元となった事象の特定が重要となる。例えば、必ずしもプログラムの設計とは別の原因で、動作が止まっていることもある(一例として、想定しないワークがライン上に流れていることが原因で制御が停止している場合など)。 In order to perform sequence control in the FA field, we design programs for PLC and application programs for program editing. After designing a program, the designer simulates the sequence operation of the program, debugs the program while verifying the simulation results, and transfers the completed program to the PLC for execution. However, it is not always possible to realize the expected operation, and the program must be edited, such as debugging it again, based on actual operation. In particular, if the expected behavior is not achieved during actual operation, it is important to identify the cause and the event that caused the problem. For example, operations may be stopped for reasons other than the program design (for example, control may be stopped due to unexpected work flowing on the line).
このようなデバイス値を保存する技術とは別に、イベントログ(故障が発生した等)を保存する技術が知られている(例えば特許文献1)。 Apart from such a technique of storing device values, a technique of storing an event log (for example, when a failure occurs) is known (for example, Patent Document 1).
しかしながら、保存したイベントログの種類は非常に多いため(1000種類オーダー)、重要なイベントログが埋もれてしまうと、ユーザがトラブルの原因を探るとき、時間がかかり使い勝手が悪いという問題があった。一方で、予め保存対象となるイベントログをユーザが絞り込んでおくことも考えられるが、保存対象とするイベントの選定が難しく、トラブル解決に役立つイベントを保存し損なう虞があった。 However, since there are a large number of saved event log types (on the order of 1,000 types), there is a problem in that if important event logs are buried, it takes time for the user to search for the cause of a problem, making it inconvenient to use. On the other hand, it is conceivable that the user narrows down the event logs to be saved in advance, but it is difficult to select the events to be saved, and there is a risk that events useful for troubleshooting may not be saved.
本発明の目的の一は、トラブル解決に有用なイベントのログを取得できるようにしたプログラマブルロジックコントローラ用プログラム作成支援装置を提供することにある。 One object of the present invention is to provide a program creation support device for a programmable logic controller that is capable of acquiring event logs useful for troubleshooting.
本発明の第1の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、一以上のユニットで構成されたプログラマブルロジックコントローラであり、ユーザープログラムを繰り返し実行するプログラム実行部、該プログラム実行部によって参照される記憶領域であるデバイスを有するデバイス部、該デバイス部に記憶されているデバイス値を現在時刻と共にログデータとして時系列に記録すると共に、前記プログラマブルロジックコントローラ又は該プログラマブルロジックコントローラにより制御される被制御装置にて発生した複数のイベントを発生時刻と共にイベントデータとして時系列に記録する一時記録部、及び運転時において所定の保存条件が満たされると該一時記録部に記録されているログデータ及びイベントデータを保存する保存メモリを備える前記プログラマブルロジックコントローラにおいて実行される、グラフィカルプログラミング言語で記述される前記ユーザープログラムの作成を支援するためのプログラム作成支援装置であって、前記プログラマブルロジックコントローラの運転時に前記保存メモリに保存されたログデータ及びイベントデータを、運転記録データとして記憶する運転記録データ保持部と、前記ユーザープログラムを表示させる表示部と、前記運転記録データ保持部から読み出したイベントデータに含まれる複数のイベント及び該複数のイベントの各々の発生時刻を、前記表示部に一覧表示するイベント表示制御部と、前記イベント表示制御部により一覧表示された複数のイベントの中から一つの選択を受け付ける選択受付部と、前記運転記録データ保持部から読み出したログデータに含まれ、かつ、前記選択受付部により選択されたイベントの発生時刻に対応する時刻に記録されたデバイス値を、前記ユーザープログラム上に重ねて表示するデバイス表示制御部とを備え、前記イベント表示制御部は、前記プログラマブルロジックコントローラの動作状態又は該プログラマブルロジックコントローラにより制御される被制御装置の動作状態を変更する特定イベントを、前記表示部上に選択的に一覧表示するよう構成できる。上記構成により、多種多様なイベントの内から、トラブル解決に有用なイベントを選択的に表示させて、トラブルの原因究明に役立てることができる。 According to the program creation support device for a programmable logic controller according to the first aspect of the present invention, the programmable logic controller is composed of one or more units, and includes a program execution section that repeatedly executes a user program, and a program execution section that repeatedly executes a user program. A device unit that has a device that is a referenced storage area, records device values stored in the device unit in chronological order as log data together with the current time, and is controlled by the programmable logic controller or the programmable logic controller. A temporary recording section that records multiple events occurring in the controlled device in chronological order as event data together with the time of occurrence, and log data and log data recorded in the temporary recording section when predetermined storage conditions are met during operation. A program creation support device for supporting the creation of the user program written in a graphical programming language, which is executed in the programmable logic controller and includes a storage memory for storing event data, the program creation support device comprising: a storage memory for storing event data; a driving record data holding unit that stores the log data and event data stored in the storage memory as driving record data; a display unit that displays the user program; and an event data read out from the driving record data holding unit. an event display control section that displays a list of a plurality of events and the times of occurrence of each of the plurality of events on the display section; and a selection of one from among the plurality of events displayed as a list by the event display control section. A selection reception unit and a device value recorded at a time that is included in the log data read from the driving record data storage unit and that corresponds to the time of occurrence of the event selected by the selection reception unit are displayed on the user program. and a device display control section that displays a specific event that changes the operating state of the programmable logic controller or the operating state of a controlled device controlled by the programmable logic controller. It can be configured to selectively display a list on the display section. With the above configuration, events useful for troubleshooting can be selectively displayed from among a wide variety of events, and can be useful for investigating the cause of troubles.
また、第2の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、上記構成に加えて、さらに、
って、さらに、前記プログラマブルロジックコントローラの前記一時記録部に対し、前記複数のイベントのうち前記特定イベントのみを記録するよう設定する記録設定部を備えることができる。
Further, according to the program creation support device for a programmable logic controller according to the second aspect, in addition to the above configuration, further:
Accordingly, it is possible to further include a recording setting section that configures the temporary recording section of the programmable logic controller to record only the specific event among the plurality of events.
さらに、第3の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、上記何れかの構成に加えて、前記特定イベントが、前記プログラム実行部による前記ユーザープログラムの実行と独立してユーザが行った操作に関するイベントを含むことができる。 Furthermore, according to the program creation support device for a programmable logic controller according to a third aspect, in addition to any of the above configurations, the specific event is executed by the user independently of the execution of the user program by the program execution unit. It can contain events related to operations performed.
さらにまた、第4の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、上記何れかの構成に加えて、前記ユーザ操作に関するイベントが、少なくとも、前記ユーザープログラム及び前記プログラマブルロジックコントローラの構成情報を含むプロジェクトデータの書き換え、前記プログラマブルロジックコントローラの設定を行う設定モードと、前記プログラマブルロジックコントローラ上で前記ユーザープログラムを実行させる運転モードとのモード切替、前記プログラマブルロジックコントローラに接続可能なケーブルの挿抜、前記プログラマブルロジックコントローラに取り付け可能な記憶媒体の挿抜、及び前記被制御装置の電源のON/OFFを含むことができる。 Furthermore, according to the program creation support device for a programmable logic controller according to a fourth aspect, in addition to any of the above configurations, the event related to the user operation is configured to include at least configuration information of the user program and the programmable logic controller. rewriting project data including rewriting the project data, switching the mode between a setting mode in which the programmable logic controller is configured and an operation mode in which the user program is executed on the programmable logic controller, insertion and removal of a cable connectable to the programmable logic controller, This may include inserting and removing a storage medium that can be attached to the programmable logic controller, and turning on and off the power of the controlled device.
さらにまた、第5の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、上記何れかの構成に加えて、前記イベント表示制御部は、前記プログラム実行部による前記ユーザープログラムの実行に従って、前記プログラマブルロジックコントローラ内で自動的に実行される処理に応じたイベントを非表示とすることができる。 Furthermore, according to the program creation support device for a programmable logic controller according to a fifth aspect, in addition to any of the above configurations, the event display control section may cause the event display control section to display the program according to the execution of the user program by the program execution section. Events corresponding to processing automatically executed within the programmable logic controller can be hidden.
さらにまた、第6の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、上記何れかの構成に加えて、前記自動実行される処理に応じたイベントは、少なくとも、前記プログラマブルロジックコントローラと接続された外部装置とTCP接続又はFTP接続するときの通信開始又は通信切断、及び前記プログラマブルロジックコントローラ内に用意されたフォルダ又はファイルへの書き込みを含むことができる。 Furthermore, according to the program creation support device for a programmable logic controller according to the sixth aspect, in addition to any of the above configurations, an event corresponding to the automatically executed process is at least connected to the programmable logic controller. This may include starting or terminating communication when establishing a TCP connection or FTP connection with an external device that has been installed, and writing to a folder or file prepared in the programmable logic controller.
さらにまた、第7の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、上記何れかの構成に加えて、さらに、前記デバイス表示制御部における表示対象時刻と、前記イベント表示制御部における表示対象時刻とを同期させる同期ソフトウエアモジュールを備え、前記同期ソフトウエアモジュールが、前記デバイス表示制御部と、前記イベント表示制御部を、前記表示部において連動させて表示させることができる。 Furthermore, according to the program creation support device for a programmable logic controller according to the seventh aspect, in addition to any of the above configurations, the display target time in the device display control section and the display in the event display control section are further provided. A synchronization software module is provided for synchronizing the target time, and the synchronization software module can display the device display control section and the event display control section in conjunction with each other on the display section.
さらにまた、第8の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、上記何れかの構成に加えて、前記表示部は、イベントを一覧表示させるイベント表示欄と、前記ユーザープログラムであるラダー図を表示させるラダーモニタ欄とを備え、前記選択受付部で、前記イベント表示欄から任意のイベントが選択されると、該選択されたイベントの時刻と対応するラダー図が前記ラダーモニタ欄で選択されて表示されるように構成できる。 Furthermore, according to the program creation support device for a programmable logic controller according to the eighth aspect, in addition to any of the above configurations, the display section includes an event display field for displaying a list of events, and the user program. and a ladder monitor column for displaying a ladder diagram, and when an arbitrary event is selected from the event display column in the selection reception section, a ladder diagram corresponding to the time of the selected event is displayed in the ladder monitor column. Can be configured to be selected and displayed.
さらにまた、第9の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、上記何れかの構成に加えて、前記記憶装置をSDカード(商品名)とすることができる。 Furthermore, according to the program creation support device for a programmable logic controller according to the ninth aspect, in addition to any of the above configurations, the storage device can be an SD card (product name).
さらにまた、第10の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、上記何れかの構成に加えて、前記イベント表示制御部が、デバイス値を時系列波形として前記表示部に表示することができる。 Furthermore, according to the program creation support device for a programmable logic controller according to the tenth aspect, in addition to any of the above configurations, the event display control section displays device values as a time series waveform on the display section. be able to.
以下、本発明の実施形態を図面に基づいて説明する。ただし、以下に示す実施形態は、本発明の技術思想を具体化するための例示であって、本発明は以下のものに特定されない。また、本明細書は特許請求の範囲に示される部材を、実施形態の部材に特定するものでは決してない。特に実施形態に記載されている構成部品の寸法、材質、形状、その相対的配置等は特に特定的な記載がない限りは、本発明の範囲をそれのみに限定する趣旨ではなく、単なる説明例にすぎない。なお、各図面が示す部材の大きさや位置関係等は、説明を明確にするため誇張していることがある。さらに以下の説明において、同一の名称、符号については同一若しくは同質の部材を示しており、詳細説明を適宜省略する。さらに、本発明を構成する各要素は、複数の要素を同一の部材で構成して一の部材で複数の要素を兼用する態様としてもよいし、逆に一の部材の機能を複数の部材で分担して実現することもできる。 Embodiments of the present invention will be described below based on the drawings. However, the embodiment shown below is an illustration for embodying the technical idea of the present invention, and the present invention is not limited to the following. Moreover, this specification does not in any way specify the members shown in the claims to the members of the embodiments. In particular, the dimensions, materials, shapes, relative arrangements, etc. of the components described in the embodiments are not intended to limit the scope of the present invention, unless otherwise specified, and are merely illustrative examples. It's nothing more than that. Note that the sizes, positional relationships, etc. of members shown in each drawing may be exaggerated for clarity of explanation. Furthermore, in the following description, the same names and symbols indicate the same or homogeneous members, and detailed descriptions will be omitted as appropriate. Furthermore, each element constituting the present invention may be configured so that a plurality of elements are made of the same member so that one member serves as a plurality of elements, or conversely, the function of one member may be performed by a plurality of members. It can also be accomplished by sharing.
図1に、プログラマブルロジックコントローラシステムの概要図を示す。この図に示すプログラマブルロジックコントローラシステム1000は、ラインを流れる対象物WKをカメラ部98で撮像して検査するシステムを例示している。このプログラマブルロジックコントローラシステム1000は、PC2と接続されて、プロジェクトデータ編集プログラムを編集する。
FIG. 1 shows a schematic diagram of a programmable logic controller system. A programmable logic controller system 1000 shown in this figure exemplifies a system in which an object WK flowing on a line is imaged by a
プログラマブルロジックコントローラ1は、複数のユニットを接続して構成される。複数のユニット間は、ユニット間バス90を介して通信可能に接続されている。ユニットは、CPUユニット3と拡張ユニット4に大別される。CPUユニット3はメインユニットや基本ユニットとも呼ばれ、プログラマブルロジックコントローラの基本動作を行う。また拡張ユニット4は、CPUユニット3の機能を拡張する機能拡張ユニットである。図1の例では、拡張ユニット4はカメラ入力拡張ユニット4cと、モーションユニット4dと、通信ユニット4eを含む。拡張ユニット4の一種であるカメラ入力拡張ユニット4cは、カメラ部98と接続されて、対象物WKを所定のタイミングで撮像して、CPUユニットに送出する。モーションユニット4dは、位置決めユニットとも呼ばれ、軸とよばれる制御対象の位置を制御する。一般に軸ごとにモータ等の駆動源が存在する。通信ユニット4eは、外部機器と通信を行う。またCPUユニット3は、これら拡張ユニット4からのデータを収集して、必要な制御を行う。
<システム構成>
The
<System configuration>
ここで、プログラマブルロジックコントローラ(以下「PLC」とも呼ぶ。)を当業者にとってよりよく理解できるようにするために、一般的なPLCの構成とその動作について説明する。 Here, in order to help those skilled in the art better understand the programmable logic controller (hereinafter also referred to as "PLC"), the configuration and operation of a typical PLC will be described.
図2は、本発明の実施の形態によるプログラマブルロジックコントローラシステムの一構成例を示す概念図である。図2が示すように、このシステムは、ラダープログラム等のユーザープログラムの編集を行うためのPC2と、工場等に設置される各種制御装置を統括的に制御するためのPLC1とを備えている。PCはパーソナルコンピュータの略称である。ユーザープログラムは、ラダー言語やSFC(シーケンシャルファンクションチャート)等のフローチャート形式のモーションプログラム等のグラフィカルプログラミング言語を用いて作成されてもよいし、C言語等の高級プログラミング言語を用いて作成されてもよい。以下では、説明の便宜上、ユーザープログラムはラダープログラムとする。PLC1は、CPUが内蔵されたCPUユニット3と、1つないし複数の拡張ユニット4を備えている。CPUユニット3に対して1つないし複数の拡張ユニット4が着脱可能となっている。例えば、拡張ユニット4aはモータ(フィールドデバイス10a)を駆動してワークの位置決めする位置決めユニットであり、拡張ユニット4bはカウンタユニットであってもよい。カウンタユニットは手動パルサ等のエンコーダ(フィールドデバイス10b)からの信号をカウントする。なお、参照符号の末尾に付与されているa、b、c・・・の文字は省略されることがある。なお、PLC1とPC2とを含むシステムはプログラマブルロジックコントローラシステムと呼ばれてもよい。
FIG. 2 is a conceptual diagram showing a configuration example of a programmable logic controller system according to an embodiment of the present invention. As shown in FIG. 2, this system includes a
CPUユニット3には、PLC側表示部5及びPLC側操作部6が備えられている。PLC側表示部5は、CPUユニット3に取り付けられている各拡張ユニット4の動作状況等を表示することができる。PLC側操作部6の操作内容に応じてPLC側表示部5は表示内容を切り替える。またPLC側操作部6は、CPUユニット3と一体に組み込まれたボタン等とする他、外付けのコンソールやマウスやキーボード等の入力装置としてもよい。あるいは、PLC側表示部5をタッチパネルとして操作部の機能を兼用させることもできる。
The
PLC側表示部5は、通常、PLC1内のデバイスの現在値(デバイス値)やPLC1内で生じたエラー情報等を表示する。デバイスとは、デバイス値(デバイスデータ)を格納するために設けられたメモリ上の領域を指す名称であり、デバイスメモリと呼ばれてもよい。デバイス値とは、入力機器からの入力状態、出力機器への出力状態及びユーザープログラム上で設定される内部リレー(補助リレー)、タイマ、カウンタ、データメモリ等の状態を示す情報である。デバイス値の型にはビット型とワード型がある。ビットデバイスは1ビットのデバイス値を記憶する。ワードデバイスは1ワードのデバイス値を記憶する。
The PLC-
拡張ユニット4は、PLC1の機能を拡張するために用意されている。各拡張ユニット4には、その拡張ユニット4の機能に対応するフィールドデバイス(被制御装置)10が接続され、これにより、各フィールドデバイス10が拡張ユニット4を介してCPUユニット3に接続される。フィールドデバイス10は、センサやカメラ部等の入力機器であってもよいし、アクチュエータ等の出力機器であってもよい。また、一つの拡張ユニット4に対して複数のフィールドデバイスが接続されてもよい。
(プログラマブルロジックコントローラ用エンジニアリングツール)
The
(Engineering tool for programmable logic controllers)
PC2は、プログラマブルロジックコントローラ用エンジニアリングツール(以下「PLC用エンジニアリングツール」ともいう。)を実現する。PLC用エンジニアリングツールとは、PLC1と接続して、その設定や、運用時の制御や動作確認等を行うための部材である。また、PLC1やこれを含めたプログラマブルロジックコントローラシステムを動作させる各種プログラムの作成や、作成済みのプログラムの編集、修正を行うこともできる。この意味ではプログラム作成支援装置と呼ばれてもよい。さらにPLC用エンジニアリングツールは、過去のプログラマブルロジックコントローラシステムの動作を記録した運転記録データに基づいて、その当時の各デバイスの動作状況を再現することもできる。運転記録データは、ラダープログラム等のユーザープログラムや、各ユニットのユニット構成情報などの設定データを含むプロジェクトデータ、及び運転当時の各デバイスのデバイス値やカメラ部の画像データ等の運用データであるログデータを含んでいる。このPLC用エンジニアリングツールは運転記録データの内、プロジェクトデータを読み込んで編集することも可能である。この意味でPLC用エンジニアリングツールは、プロジェクトデータ編集プログラムと呼ばれてもよい。
The
PC2は、例えば携帯可能なノートタイプやタブレットタイプのパーソナルコンピュータであって、表示部7及びPC側操作部8を備えている。PLC1を制御するためのユーザープログラムの一例であるラダープログラムは、PC2を用いて作成される。その作成されたラダープログラムは、PC2内でニモニックコードに変換される。PC2は、USB(Universal Serial Bus)等の通信ケーブル9を介してPLC1のCPUユニット3に接続され、ニモニックコードに変換されたラダープログラムをCPUユニット3に送る。CPUユニット3はラダープログラムをマシンコードに変換し、CPUユニット3に備えられたメモリ内に記憶する。なお、ここではニモニックコードがCPUユニット3に送信されているが、本発明はこれに限られない。例えば、PC2は、ニモニックコードを中間コードに変換し、中間コードをCPUユニット3に送信してもよい。
The
なお、図2は示していないが、PC2のPC側操作部8には、PC2に接続されたマウス等のポインティングデバイスが含まれていてもよい。またPC2は、USB以外の他の通信ケーブル9を介して、PLC1のCPUユニット3に対して着脱可能に接続されるような構成であってもよい。また、通信ケーブル9を介さず、PLC1のCPUユニット3に対して無線によって接続されるような構成であってもよい。
<ラダープログラム>
Although not shown in FIG. 2, the PC-
<Ladder program>
図3は、ラダープログラムの作成時にPC2の表示部7に表示されるラダー図Ldの一例を示す図である。PC2は、マトリックス状に配置された複数のセルを表示部7に表示する。各セルには、仮想デバイスのシンボルが配置される。シンボルは、入力リレーや出力リレー等を示している。このような複数のシンボルによってリレー回路が形成される。ラダー図Ldには、例えば10列×N行(Nは任意の自然数)のセルが配置されている。そして各行のセル内には、仮想デバイスのシンボルが適宜配置される。
FIG. 3 is a diagram showing an example of a ladder diagram Ld displayed on the
図3が示すリレー回路は、入力装置からの入力信号に基づいてON/OFFされる3つの仮想デバイス(以下、「入力デバイス」と呼ぶ。)のシンボルと、出力装置の動作を制御するためにON/OFFされる仮想デバイス(以下、「出力デバイス」と呼ぶ。)のシンボルと、が適宜結合されることにより構成されている。 The relay circuit shown in FIG. 3 has symbols for three virtual devices (hereinafter referred to as "input devices") that are turned ON/OFF based on input signals from input devices, and a symbol for controlling the operation of an output device. It is configured by appropriately combining symbols of virtual devices (hereinafter referred to as "output devices") to be turned on and off.
各入力デバイスのシンボルの上方に表示されている文字(「R0001」、「R0002」及び「R0003」)は、その入力デバイスのデバイス名(アドレス名)を表している。各入力デバイスのシンボルの下方に表示されている文字(「フラグ1」、「フラグ2」及び「フラグ3」)は、その入力デバイスに対応付けられたデバイスコメントを表している。出力デバイスのシンボルの上方に表示されている文字(「原点復帰」)は、その出力デバイスの機能を表す文字列からなるラベルである。
The characters (“R0001,” “R0002,” and “R0003”) displayed above the symbol of each input device represent the device name (address name) of that input device. The characters (“
図3が示す例では、デバイス名「R0001」及び「R0002」にそれぞれ対応する2つの入力デバイスのシンボルが直列的に結合されることにより、AND回路が構成されている。また、これらの2つの入力デバイスのシンボルからなるAND回路に対して、デバイス名「R0003」に対応する入力デバイスのシンボルが並列的に結合されることにより、OR回路が構成されている。すなわち、このリレー回路では、一行目の2つのシンボルに対応する入力デバイスがいずれもONした場合、又は二行目のシンボルに対応する入力デバイスがONした場合にのみ、一行目のシンボルに対応する出力デバイスがONになる。
<プログラム作成支援装置>
In the example shown in FIG. 3, the symbols of two input devices corresponding to device names "R0001" and "R0002" are connected in series to form an AND circuit. Furthermore, an OR circuit is constructed by connecting in parallel the symbol of the input device corresponding to the device name "R0003" to the AND circuit composed of the symbols of these two input devices. That is, in this relay circuit, the relay circuit corresponds to the symbol in the first row only when both input devices corresponding to the two symbols on the first row are turned on, or when an input device corresponding to the symbol on the second row is turned on. The output device turns on.
<Program creation support device>
図4は、PC2の電気的構成について説明するためのブロック図である。図4が示すように、PC2は、PC側メモリ部11、PC側CPU21、表示部7、PC側操作部8、PC側記憶装置22及びPC側通信部23を備えている。表示部7、PC側操作部8、PC側記憶装置22及びPC側通信部23は、それぞれPC側CPU21に対して電気的に接続されている。
FIG. 4 is a block diagram for explaining the electrical configuration of the
PC側メモリ部11は、PC側CPU21が処理を実行するための作業空間となる作業メモリであり、典型的にはRAM等で構成される。PC側記憶装置22は、後述する運転記録データ記憶部36Bの機能を実現する。運転記録データは、プロジェクトデータを含んでいる。
The PC-
PC側記憶装置22はハードディスクや半導体メモリ、ROM等を含み、さらに着脱可能なメモリカードを含んでもよい。CPUは中央演算処理装置の略称である。ROMはリードオンリーメモリの略称である。RAMはランダムアクセスメモリの略称である。
The PC
ユーザは、PC側記憶装置22に記憶されているコンピュータプログラムである編集ソフトウエアをPC側CPU21に実行させて、PC側操作部8を通じてプロジェクトデータを編集する。この編集ソフトウエアは、プロジェクトデータ編集プログラムにあたる。
(プロジェクトデータ)
The user causes the
(project data)
プロジェクトデータは、一つ以上のユーザープログラム(例えばラダープログラム)と、CPUユニット3や拡張ユニット4のユニット構成情報等を含む。またプロジェクトデータは、ユーザープログラムがどのようなプログラム部品から構成されているかを示すプログラム構成情報を含めてもよい。さらにユニット構成情報は、CPUユニット3に対する複数の拡張ユニット4の接続位置や、CPUユニット3に備えられた機能(例えば通信機能や位置決め機能)を示す情報、拡張ユニット4の機能(例えば撮影機能)等を示す情報である。
The project data includes one or more user programs (for example, a ladder program), unit configuration information of the
ここで、プロジェクトデータの編集には、プロジェクトデータの作成及び変更が含まれる。プロジェクトデータ編集プログラムを用いて作成されたプロジェクトデータは、PC側記憶装置22に記憶される。またユーザは、必要に応じてPC側記憶装置22に記憶されているプロジェクトデータを読み出し、そのプロジェクトデータを、プロジェクトデータ編集プログラムを用いて変更することができる。PC側通信部23は、通信ケーブル9を介してPC2をCPUユニット3に通信可能に接続するためのものである。PC側CPU21はPC側通信部23を介してプロジェクトデータをCPUユニット3に転送する。
Here, editing the project data includes creating and changing the project data. Project data created using the project data editing program is stored in the PC-
プロジェクトデータ編集プログラムは、編集モードとモニタモードと履歴再生モードを備える。編集モードはエディットモード等とも呼ばれ、プロジェクトデータを編集することができる。またモニタモードはユーザープログラムのデバッグ等を行うためのシミュレーション動作を行うことができる。さらに履歴再生モードはリプレイモードやタイムマシン再生等とも呼ばれ、再生表示を行うことができる。これらの編集モード、モニタモード、履歴再生モードの切り替えは、後述するモード選択部50Dで行われる。
<PLC1>
The project data editing program has an editing mode, a monitor mode, and a history playback mode. The edit mode is also called an edit mode, and allows project data to be edited. Also, in the monitor mode, simulation operations can be performed for debugging the user program. Furthermore, the history playback mode is also called replay mode, time machine playback, etc., and allows playback and display. Switching between the editing mode, monitor mode, and history playback mode is performed by a
<PLC1>
図5はPLC1の電気的構成について説明するためのブロック図である。この図に示すように、CPUユニット3は、PLC側CPU31、PLC側表示部5、PLC側操作部6、PLC側記憶装置32及びPLC側通信部33を備えている。PLC側表示部5、PLC側操作部6、PLC側記憶装置32及びPLC側通信部33は、それぞれPLC側CPU31に電気的に接続されている。
(PLC側記憶装置32)
FIG. 5 is a block diagram for explaining the electrical configuration of the
(PLC side storage device 32)
PLC側記憶装置32は、プロジェクト記憶部35、デバイス部34、一時記録部91a、保存メモリ36を備えている。
The PLC
プロジェクト記憶部35は、PC2から入力されたプロジェクトデータを記憶する。またPLC側記憶装置32はCPUユニット3用の制御プログラムも記憶する。
The
デバイス部34はビットデバイスやワードデバイス等を有し、各デバイスはデバイス値を記憶する。このデバイス部34は、複数のデバイスの各デバイス値を記憶するデバイスメモリとして機能する。またユーザープログラムに従い参照される記憶領域として機能させてもよい。
The
一時記録部91aは、デバイス部34に記憶されているデバイス値を時系列に記録する。この一時記録部91aは、リングバッファ等で構成できる。
The
保存メモリ36は、一時記録部91aに時系列に記録されたデバイス値を保存する。保存メモリ36は、不揮発性メモリとして、内部メモリ37や着脱可能なメモリカード36A等で構成される。
The
このようにPLC側記憶装置32は複数の記憶領域を有している。このPLC側記憶装置32はRAMやROM、メモリカード等を含んでもよい。例えば図5の例では、保存メモリ36は着脱可能なメモリカード36Aで構成されている。
(PLC側CPU31)
In this way, the PLC
(PLC side CPU31)
PLC側CPU31は、プログラム実行部514と、保存条件設定部45と、記録制御部39と、保存制御部50Cを備えている。プログラム実行部514は、ユーザープログラムを繰り返し実行するラダー実行エンジンとして機能する。ユーザープログラムに従い、プログラム実行部514により参照される記憶領域であるデバイス部34は、複数のデバイスの各デバイス値を記憶している。
The
保存条件設定部45は、各種の条件を設定するための部材である。ここでは保存条件設定部45は、一時記録部91aに記録するための記録トリガについての第1トリガ条件と、保存メモリ36に保存するための保存トリガについての第2トリガ条件と、記録トリガが示す時点を基準時とし、この基準時までの期間及び該基準時からの期間の少なくとも一方を含む期間であって、一時記録部91aに一時的な記録を行う期間を示すバッファ記録期間を設定する。
The storage
保存条件設定部45で、第1トリガ条件として、一時記録部91aへの記録を開始するための記録開始トリガについての条件を設定することができる。またバッファ記録期間として、この記録開始トリガが示す基準時からの期間を設定することができる。
The storage
記録制御部39は、記録トリガについての第1トリガ条件が成立すると、この記録トリガが示す時点を基準時とするバッファ記録期間に対応した時系列のデバイス値をログデータとして一時記録部91aに記録する。また記録制御部39は、保存トリガについての第2トリガ条件が成立する時点、又は次に記録トリガについての第1トリガ条件が成立する時点の、いずれか早い時点までの間、記録した該ログデータを一時記録部91aに保持させる。そして、次に記録トリガについての第1トリガ条件が成立すると、次に該記録トリガが示す時点を基準時とするバッファ記録期間に対応した時系列のデバイス値をログデータとして、一時記録部91aに記録する。
When the first trigger condition for the recording trigger is satisfied, the
保存制御部50Cは、保存トリガについての第2トリガ条件が成立すると、記録制御部39により一時記録部91aに保持されたログデータを保存メモリ36に保存する。ここで保存制御部50Cは、保存トリガについての第2トリガ条件が成立すると、記録制御部39により一時記録部91aに保持され、保存トリガからみて直前の記録トリガに対応するログデータを、保存メモリに保存することが好ましい。このように保存制御部50Cは、バッファ記録期間を経過した後も、バッファ記録期間中に記録したログデータを保持しておき、保存トリガが起動すると、記録トリガに対応付けて保持されたログデータを保存する。ただ記録制御部39が保存するログデータは、直近の記録トリガに対応するログデータに限らず、2個前の記録トリガや、3回前の記録トリガとしてもよい。
The
図5が示すように,CPUユニット3と拡張ユニット4とは拡張バスの一種であるユニット間バス90を介して接続されている。なお、ユニット間バス90に関する通信機能は、PLC側通信部33の一部として実装されてもよい。またPLC側通信部33は、ネットワーク通信回路を有してもよい。PLC側CPU31は、PLC側通信部33を介してログデータ等をPC2やクラウド等に送信してもよい。
As shown in FIG. 5, the
ここで、ユニット間バス90について、補足説明する。このユニット間バス90は、次に説明する入出力リフレッシュ等が行われるバスである。ユニット間バス90における通信制御は、いわゆるバスマスタ38によって実現される(なお、PLC側通信部33の一部としてバスマスタを設けてもよいし、PLC側CPU31の一部としてバスマスタ38を設けてもよい)。バスマスタ38は、ユニット間バス90での通信を制御するための制御回路であって、PLC側CPU31からの通信要求を受けて、拡張ユニット4との間で、後述する入出力リフレッシュ等の通信を行う。
Here, a supplementary explanation will be given regarding the
拡張ユニット4はCPU41とメモリ42を備えている。CPU41は、デバイスに格納されたCPUユニット3からの指示(デバイス値)に従って、フィールドデバイス10を制御する。またCPU41は、フィールドデバイス10の制御結果をバッファメモリとよばれるデバイスに格納する。デバイスに格納された制御結果は入出力リフレッシュによってCPUユニット3に転送される。またデバイスに格納されている制御結果は、CPUユニット3からの読み出し命令に従って、入出力リフレッシュとは異なるタイミングであっても、CPUユニット3に転送される。メモリ42はRAMやROM等を含む。とりわけ、RAMにはバッファメモリとして使用される記憶領域が確保されている。またメモリ42は、フィールドデバイス10によって取得されたデータ(例:静止画データや動画データ)を一時的に保持するバッファを有してもよい。
The
図6はCPUユニット3のスキャンタイムを示す模式図である。図6が示すように1つのスキャンタイムTは、入出力のリフレッシュを行うためのユニット間通信201、プログラム実行202、END処理204により構成されている。ユニット間通信201で、CPUユニット3は、ラダープログラムを実行して得られた出力データをCPUユニット3内のPLC側記憶装置32から拡張ユニット4等の外部機器に送信する。さらにCPUユニット3は、拡張ユニット4等の外部機器から受信した入力データをCPUユニット3内のPLC側記憶装置32に取り込む。つまり、CPUユニット3のデバイスに記憶されているデバイス値は出力リフレッシュによって拡張ユニット4のデバイスに反映される。同様に、拡張ユニット4のデバイスに記憶されているデバイス値は、入力リフレッシュによってCPUユニット3のデバイスに反映される。このように入出力リフレッシュによって、CPUユニット3のデバイスと拡張ユニット4のデバイスが同期する。
FIG. 6 is a schematic diagram showing the scan time of the
なお、リフレッシュ以外のタイミングでデバイス値をユニット間で更新する仕組み(ユニット間同期)が採用されてもよい。ただ、CPUユニット3のデバイスは、CPUユニット3が随時書き換えており、同様に拡張ユニット4のデバイスは拡張ユニット4が随時書き換えている。つまり、CPUユニット3のデバイスは、CPUユニット3の内部の装置によって随時アクセス可能である。同様に、拡張ユニット4のデバイスは拡張ユニット4の内部の装置によって随時アクセス可能になっている。CPUユニット3と拡張ユニット4との間では、基本的にリフレッシュのタイミングにおいて相互にデバイス値を更新して同期する。プログラム実行202で、CPUユニット3は、更新された入力データを用いてプログラムを実行(演算)する。図6が示すように、プログラム実行202においては複数のプログラムモジュール又はラダープログラムがプロジェクトデータに従って順番に実行されてもよい。CPUユニット3はプログラムの実行によりデータを演算処理する。なお、END処理とは、PC2やCPUユニット3に接続された表示器(図示せず)等の外部機器とのデータ通信、システムのエラーチェック等の周辺サービスに関する処理全般を意味する。
Note that a mechanism (inter-unit synchronization) in which device values are updated between units at a timing other than refresh may be adopted. However, the devices of the
このように、PC2はユーザの操作に応じたラダープログラムを作成し、作成したラダープログラムをPLC1に転送する。PLC1は、入出力リフレッシュ、ラダープログラムの実行及びEND処理を1サイクル(1スキャン)として、このサイクルを周期的、すなわちサイクリックに繰り返し実行する。これにより、各種の入力機器(センサ等)からのタイミング信号に基づいて、各種の出力機器(モータ等)を制御する。なお、スキャン周期とは別に、CPUユニット3や拡張ユニット4はそれぞれ内部制御周期を有している。CPUユニット3や拡張ユニット4は内部制御周期を基準としてフィールドデバイス10等の機能を制御する。
<ロギング>
In this way, the
<Logging>
ユーザがユーザープログラムを改良したり、修正したりする際に、PLC1がユーザープログラムを実行している際に取得されたデバイス値が役に立つことがある。そこで、PLC1は予め指定されたデバイス値を取得し、ログデータを作成する。ここで、PLC1が管理するデバイスには、ユーザープログラムによって利用されるものだけでなく、ユーザープログラムによって利用されないものも存在する。また、ユーザープログラムを改良したり、修正したりする際に役立つデバイスもあれば、役に立たないデバイスもある。一般にデバイスの数は数千個に及ぶため、ユーザが必要なデバイスを指定することは大きな負担となっていた。そこで、PC2は、ユーザープログラムを解析し、ユーザープログラムに使用又は記述されているデバイスをロギング対象として抽出する。これにより、ユーザの負担が軽減される。
When a user improves or modifies a user program, the device values acquired while the
PLC1が管理するすべてのデバイスをロギングの対象とすると、スキャンタイムが長くなってしまう。なぜなら、ロギングは、ユーザープログラムの一つとして実行されたり、入出力リフレッシュの際に実行されたりするからである。時には、ロギングのもたらす遅延によって、ユーザープログラムがユーザの希望通りに動作しないこともありうる。したがって、ロギング対象のデバイスの数は適切に維持されるべきであろう。
If all devices managed by the
ユーザープログラムは、複数のプログラム部品(例えばプログラムモジュール(メインのラダープログラムとサブのラダープログラム)、ファンクションブロック)から構成されることがある。この内、ユーザが修正を希望するプログラム部品に関連したデバイスがロギングされれば、ユーザにとって十分な場合がある。また、複数のプログラム部品の内で、ユーザは特定のプログラム部品を抽出対象から除外したり、特定のプログラム部品を抽出対象に追加したりすることを希望することもあろう。よって、プログラム部品を単位として、ロギング対象からデバイスを追加又は削除できればユーザにとって便利であろう。 A user program may be composed of a plurality of program parts (eg, program modules (main ladder program and sub ladder program), function blocks). Of these, it may be sufficient for the user if devices related to the program component that the user desires to modify are logged. Furthermore, the user may desire to exclude a specific program component from being extracted from among a plurality of program components or to add a specific program component to be extracted. Therefore, it would be convenient for the user if devices could be added or deleted from the logging targets for each program component.
上述したようにCPUユニット3や拡張ユニット4は一つ以上の機能を有している。各機能には様々なデバイスが割り付けられている。よって、これらの機能を単位として、ロギング対象からデバイスを追加又は削除できれば、ユーザにとって便利であろう。例えば、CPUユニット3の通信機能に関する望ましくないイベントが発生した場合、ユーザはCPUユニット3の通信機能に関するデバイスのデバイス値を参照することで、このイベントを解消することが容易になろう。
(プログラム作成支援装置)
As described above, the
(Program creation support device)
プログラム作成支援装置の一例を、図7のブロック図に示す。この図に示すプログラム作成支援装置1200は、一以上のユニットで構成されたPLC1で実行されるユーザープログラムの作成を支援する。このプログラム作成支援装置1200は、PC2にユーザープログラム作成支援プログラムをロードさせて実行させて実現する他、専用のハードウェアで構築してもよい。図7に示す例では、PC2にユーザープログラム作成支援プログラムをインストールして実現した例を示している。このプログラム作成支援装置1200は、PC側CPU21と、PC側メモリ部11と、PC側記憶装置22と、表示部7と、PC側操作部8と、通信部を備える。
An example of the program creation support device is shown in the block diagram of FIG. A program
PC側メモリ部11はPC側CPU21が処理を実行するための作業空間である。このような作業メモリとして、RAM等が利用できる。
The PC
PC側記憶装置22は、PC2で読み取り可能なストレージである。典型的には、PC2が備えるハードディスクなどの記憶装置であるが、固定式に限らず、可搬式の媒体やメディアとすることもできる。例えば、PLC1が備えるメモリカード36Aを、PLC1側から抜き取り、PC2側に挿入して読み取る態様としてもよい。または、PC2とネットワーク接続されたPLC1のPLC側記憶装置32にアクセスする態様としてもよい。
The PC-
このPC側記憶装置22は、運転記録データを記憶する運転記録データ記憶部36Bの機能を実現する。運転記録データは、プロジェクトデータと、ログデータを含んでいる。プロジェクトデータは、PLC1のユーザープログラム及び各ユニットのユニット構成情報を含む。ユニット構成情報には、各ユニットの機能、ユニット間の接続位置の情報等が含まれる。ログデータは、PLC1の運転時におけるデバイス値等のデータである。これらプロジェクトデータとログデータとが関連付けられた運転記録データが、運転記録データ記憶部36Bに記憶されている。
This PC-
表示部7は、ログ表示制御部61によりログを表示させる。ログ表示制御部61は、運転記録データ記憶部36Bから運転記録データをPC側メモリ部11に読み出して、運転記録データ内のログデータとプロジェクトデータとを関連付けて表示する。
The
PC側CPU21は、プロジェクト編集部50B、保存制御部50C等の機能を実現する。プロジェクト編集部50Bは、ログ表示制御部61により表示部7に表示されたプロジェクトデータの編集指示を受け付けて、このプロジェクトデータを編集する。そして編集後のプロジェクトデータを保存する際には、そのプロジェクトデータと対応するログデータとを関連付けた運転記録データとして、運転記録データ記憶部36Bに記憶される。
The PC-
保存制御部50Cは、運転記録データ記憶部36Bに記憶された運転記録データ内のプロジェクトデータに対して、プロジェクト編集部50Bにより編集された状態で保存することを規制する。これにより、ユーザによるプロジェクトデータ内のユーザープログラム等の修正によって意図せずプロジェクトデータ全体の信ぴょう性が損なわれる事態を回避できる。具体的には、保存制御部50Cが、運転記録データ記憶部36Bに記憶された運転記録データ内のプロジェクトデータに対して、プロジェクト編集部50Bにより編集された状態で上書き保存することを規制する。例えば、プロジェクト編集部50Bによりプロジェクトデータに対して上書き操作が試みられたことを検出して、表示部7上に上書き禁止ポップアップが表示される。あるいは、編集後のプロジェクトデータを保存しようとしたとき、この編集後のプロジェクトデータを、運転記録データに含まれる元のプロジェクトデータとは別のファイルとして保存する。例えば別名での保存を促すよう、保存ファイル名の入力ダイヤログを表示させたり、自動で名称を変更して新たにコピー保存させてもよい。
(運転記録データ)
The
(driving record data)
運転記録データは、所定のタイミングで記録される。具体的には、トラブルが発生する可能性のある時期を指定して、この間のデータを運転記録データとしてまとめて保存しておくことで、トラブル発生時の原因解析に役立てることができる。 Driving record data is recorded at predetermined timing. Specifically, by specifying the time when a problem is likely to occur and storing the data during that period as driving record data, it can be used to analyze the cause of a problem when it occurs.
運転記録データは、複数のファイルをパッケージしたものとできる。運転記録データに含める情報は、例えば管理情報データ、プロジェクトデータ、プロジェクト識別情報、デバイスデータ、画像データ、イベントデータ等が挙げられる。管理情報データは、運転記録データに何が含まれているかの情報である。その拡張子は、例えばTMNとする。プロジェクトデータは、運転記録データの記録時点(例えばトラブル発生時)でのプロジェクトデータである。その拡張子は、例えばTPJとする。詳細については後述する。 Driving record data can be a package of multiple files. Examples of the information included in the driving record data include management information data, project data, project identification information, device data, image data, and event data. The management information data is information about what is included in the driving record data. The extension is, for example, TMN. The project data is project data at the time of recording the driving record data (for example, when a trouble occurs). The extension is, for example, TPJ. Details will be described later.
プロジェクト識別情報は、この運転記録データ記録時点でのプロジェクトデータを識別するための情報である。その拡張子は、例えばTPIとする。デバイスデータは、運転記録データの記録時点でのデバイスを記録したデータであり、デバイスの数だけ存在する。その拡張子は、例えばTDVとする。画像データは、運転記録データの記録時点の画像を記録したデータである。その拡張子は、例えばTCAとする。イベントデータは、運転記録データの記録時点に発生していたイベントやエラーを記録したデータである。その拡張子は、例えばTEVとする。これらは一例であって、この内いずれかの情報のみを運転記録データに含めてもよいし、あるいはこれ以外の情報を追加してもよい。
(プロジェクトデータの構成)
The project identification information is information for identifying the project data at the time of recording this driving record data. The extension is, for example, TPI. The device data is data recording the devices at the time of recording the driving record data, and exists as many as the number of devices. The extension is, for example, TDV. The image data is data that records an image at the time of recording the driving record data. The extension is, for example, TCA. The event data is data recording events and errors that occurred at the time the driving record data was recorded. The extension is, for example, TEV. These are just examples, and only one of these pieces of information may be included in the driving record data, or other information may be added.
(Project data structure)
プロジェクトデータは、複数のデータで構成される。データの数が多い場合は、圧縮形式で保存することが好ましい。プロジェクトデータには、プロジェクトファイル、モジュール、ファンクションブロック、ユニット設定ファイル、メール設定ファイル等を含めることができる。プロジェクトファイルは、プロジェクトの設定に関する情報である。その拡張子は、kpr例えばとする。モジュールは、ラダープログラムの情報である。その拡張子は、例えばmodとする。ファンクションブロックは、部品化されたラダープログラムの情報である。その拡張子は、例えばkfbとする。ユニット設定ファイルは、ユニットの構成情報である。その拡張子は、例えばue2とする。メール設定ファイルは、メールの設定情報である。その拡張子は、例えばmilとする。これら以外にも、ユニット毎に拡張子が異なるファイルを含めてもよい。またこれらは一例であって、この内いずれかの情報のみをプロジェクトデータに含めてもよいし、あるいはこれ以外の情報を追加してもよい。 Project data consists of multiple pieces of data. If there is a large amount of data, it is preferable to save it in a compressed format. Project data can include project files, modules, function blocks, unit configuration files, email configuration files, and the like. The project file is information regarding project settings. For example, the extension is kpr. A module is information about a ladder program. The extension is, for example, mod. A function block is information of a ladder program made into components. The extension is, for example, kfb. The unit setting file is the configuration information of the unit. The extension is, for example, ue2. The email configuration file is email configuration information. The extension is, for example, mil. In addition to these, files with different extensions may be included for each unit. Further, these are just examples, and only one of these pieces of information may be included in the project data, or other information may be added.
各データファイルの種別を示す識別情報には、ファイルの拡張子を利用できる。またファイルの拡張子を用いて、運転記録データとプロジェクトデータの関連付けを行うこともできる。例えば運転記録データについてはTMNファイルが、プロジェクトデータについてはkprファイルが、それぞれPC2上でユーザープログラム作成支援プログラムに関連付けられている。PC2上の該当するファイルをダブルクリックすることで、ユーザープログラム作成支援プログラムが起動される。この様子を図8に示す。ここでは、ユーザープログラム作成支援プログラムのプロジェクト編集部50Bは、識別情報解釈部を備えている。ここでは識別情報解釈部の例として、TPJ解釈部50B1とkpr解釈部50B2を示している。表示部7上でエクスプローラ等のファイラ画面上から、TMNファイルをダブルクリックした場合、ユーザープログラム作成支援プログラムは、圧縮形式で保存されたTPJファイルを解凍し、PC側メモリ部11上にロードする。またkprファイルをダブルクリックした場合、ユーザープログラム作成支援プログラムは、kprと同じフォルダに配置された、他の設定ファイルを合わせてPC側メモリ部11上にロードする。一方、TPJファイル及びkprファイルは、TPJ解釈部50B1とkpr解釈部50B2により共通のモデルデータとして解釈され、PC側メモリ部11上にロードされる。
(モード選択部50D)
A file extension can be used as identification information indicating the type of each data file. It is also possible to associate driving record data and project data using file extensions. For example, a TMN file for driving record data and a kpr file for project data are each associated with the user program creation support program on the
(
さらにPC側CPU21は、モード選択部50Dの機能を実現することもできる。モード選択部50Dは、編集モードや履歴再生モードを選択できる。編集モードは、プロジェクトデータを編集するモードであり、エディットモード等とも呼ばれる。また履歴再生モードは、ログ表示制御部61による表示を行うモードであり、リプレイモード等とも呼ばれる。このように、ユーザープログラム作成支援プログラムでは、一のプログラム中で動作モードを切り替えて、トラブル解決のため過去のイベントを再生させつつ、原因と思われる箇所のユーザープログラムを修正するという作業に移行することができる。また履歴再生モードと編集モードとで共通のGUIを用いることで、スムーズな作業の移行を行わせることが可能となる。
(ユーザープログラム作成支援プログラム1300)
Furthermore, the
(User program creation support program 1300)
まず、モード選択部50Dで履歴再生モードを選択した場合の、ユーザープログラム作成支援プログラム1300のGUIを図9に示す。この図に示すGUIは、プロジェクト表示領域420と、ラダーモニタ450と、カメラモニタ430と、ユニットモニタ440を備えている。図9において、左欄のプロジェクト表示領域420には、プロジェクトデータ71を構成する様々な情報が表示されている。上から順に、ユニット構成(CPUユニット、モーションユニット、アナログ入力ユニット、カメラ入力拡張ユニット等)、プログラム構成(毎スキャンモジュール、定周期モジュール、ユニット間同期モジュール、ファンクションブロック、マクロ等)が表示されている。モーションユニットについては、機能設定として軸構成や軸制御の設定パラメータが表示されている。ユーザは、図9に示すGUI上において、軸構成や軸制御をダブルクリックすることで、これらの設定パラメータについて、どのような設定内容になっているかを確認することができる。また、プロジェクト表示領域420において、毎スキャンモジュールに対してMainとSubが表示されているところ、ユーザがMainをクリックすると、中央のラダーモニタ450のプログラム表示領域410に、Mainプログラムが表示される。
(履歴再生モード)
First, FIG. 9 shows the GUI of the user program creation support program 1300 when the history playback mode is selected in the
(history playback mode)
次に履歴再生モードにおいて、トラブル発生時等に記録された運転記録データを再生する手順を、図10に基づいて説明する。例えば、予め保存された運転記録データのデータファイル(上述した拡張子TMNの運転記録データファイル)やプロジェクトファイル(拡張子kprのプロジェクトデータファイル)をダブルクリックすると、図10に示すユーザープログラム作成支援プログラム1300が起動されると共に、ダブルクリックされたファイルを解析して、含まれているファイルを展開したり、関連付けられた別ファイルを呼び出すなどして、運転記録データ保存時の状況が自動で再現される。あるいは、ユーザープログラム作成支援プログラム1300をユーザが起動した上で、ファイルメニューなどから、運転記録データファイル等の該当するファイルを選択して展開することもできる。 Next, a procedure for reproducing driving record data recorded when a trouble occurs in the history reproducing mode will be explained based on FIG. 10. For example, if you double-click a pre-saved driving record data file (the driving record data file with the extension TMN mentioned above) or a project file (the project data file with the extension kpr), the user program creation support program shown in FIG. 1300 is started, it analyzes the double-clicked file, expands the included file, calls another associated file, etc., and automatically reproduces the situation when the driving record data was saved. Ru. Alternatively, after starting the user program creation support program 1300, the user can select and expand a corresponding file such as a driving record data file from a file menu or the like.
この例では、運転記録データをダブルクリックした場合は、図10に示す履歴再生モードでユーザープログラム作成支援プログラム1300が起動するよう構成している。一方、プロジェクトデータをダブルクリックした場合は、図11に示す編集モードでユーザープログラム作成支援プログラム1300が起動するよう構成している。このようにユーザが選択したファイルに応じて、初期選択される動作モードを異ならせることで、想定されるユーザの操作に沿った動作モードを予め選択してスムーズな操作環境を提供できる。
(履歴再生モードと編集モードの切り替え)
In this example, the user program creation support program 1300 is configured to start in the history playback mode shown in FIG. 10 when driving record data is double-clicked. On the other hand, when project data is double-clicked, the user program creation support program 1300 is configured to start in the edit mode shown in FIG. 11. In this way, by varying the initially selected operation mode depending on the file selected by the user, it is possible to select in advance an operation mode that is in line with the expected user operation and provide a smooth operation environment.
(Switching between history playback mode and edit mode)
ユーザープログラム作成支援プログラム1300の起動後に、編集モードと履歴再生モードの2つの動作モードを切り替えるには、モード選択部50Dの一形態であるモード選択欄50D1から、切り替えたい動作モードを選択する。例えばモード選択欄50D1を、図12に示すようなプルダウンメニューで構成して、ユーザは所望の動作モードを容易に選択できる。図12の例では、「リプレイ」を選択すると履歴再生モード(リプレイモード)に、「エディタ」を選択すると編集モード(エディタモード)に、それぞれ切り替えられる。またモード選択欄50D1には、現在選択中の動作モードが表示されており、ユーザに対して現在の動作モードを告知する機能も奏している。
After starting the user program creation support program 1300, to switch between the two operating modes, edit mode and history playback mode, select the desired operating mode from the mode selection column 50D1, which is one form of the
なおプロジェクトデータをダブルクリックして編集モードで起動したユーザープログラム作成支援プログラムを、履歴再生モードに切り替える場合、プロジェクトデータにはデバイスデータ等が指定されていないため、履歴再生モードで使用するためのデバイスデータを含む運転記録データを、別途指定するように促される。例えば、運転記録データを選択するダイヤログ画面を表示させる。 Note that when switching the user program creation support program started in edit mode by double-clicking the project data to history playback mode, the device data for use in history playback mode is not specified in the project data. You will be prompted to separately specify the driving record data including the data. For example, a dialog screen for selecting driving record data is displayed.
このように履歴再生モードにおいて、保存された運転記録データを読み込んでトラブル発生時のイベントを再生し、ユーザはトラブルの原因を推定し、これを改善するように必要な処置を検討できる。例えば、トラブルを解消できるようにラダープログラムを編集する。 In this way, in the history playback mode, the saved driving record data is read and the event when the trouble occurred is played back, allowing the user to estimate the cause of the trouble and consider necessary measures to improve it. For example, edit the ladder program to resolve the problem.
図9の履歴再生モードにおいては、ユーザープログラムの編集が禁止されるようにしている。言い換えると、運転記録データの再生すなわち閲覧が許可され、改ざんは禁止される。これによってトラブル発生時の運転記録データの信ぴょう性が確保される。なお、ユーザープログラムの編集が禁止された履歴再生モードを、ログ再生モードと呼ぶ。
(編集モード)
In the history playback mode of FIG. 9, editing of the user program is prohibited. In other words, reproduction or viewing of the driving record data is permitted, but falsification is prohibited. This ensures the reliability of driving record data when trouble occurs. Note that the history playback mode in which editing of the user program is prohibited is called the log playback mode.
(edit mode)
ここで編集モードとしたユーザープログラム作成支援プログラム1300を用いて、ユーザープログラムの編集を行う手順として、ラダープログラムを修正する例を図13~図15に基づいて説明する。この例では、ユーザープログラム作成支援プログラム1300を用いてモーションユニットの位置決め制御を行っている途中で、現在座標を示すデバイスの値が12000を超えていたら、動作をトルク制御に変更するようなユーザープログラムを検討している。ここでは、履歴再生モードでトラブルの発生原因を検証した結果、図13に示すようにプログラム表示領域410に示すラダー図のデバイス値が12000を超えてから動作を変更すると、可動アームがワークに接触してしまうことが判明したため、編集モードにおいて、しきい値を12000から10000に変更したいケースを想定する。まず、図13のユーザープログラム作成支援プログラム1300において、破線で囲む部分を選択して、PC側操作部8を構成するキーボードのEnterキーを押す等して、図14のプログラム編集画面1310を表示させる。このプログラム編集画面1310から、デバイス値入力欄1312において、値12000を、10000に修正して、「上書」ボタン1314を押下する。これにより、図15のユーザープログラム作成支援プログラム1300のプログラム表示領域410に示すように、ラダープログラムが変更される。
Here, as a procedure for editing a user program using the user program creation support program 1300 in the edit mode, an example of modifying a ladder program will be described based on FIGS. 13 to 15. In this example, a user program is created that changes the operation to torque control if the value of the device indicating current coordinates exceeds 12,000 while positioning control of the motion unit is being performed using the user program creation support program 1300. We are considering. Here, as a result of verifying the cause of the trouble in the history playback mode, as shown in FIG. 13, if the operation is changed after the device value in the ladder diagram shown in the
またユーザープログラムを編集する他の例として、モーションユニットの位置決め制御のパラメータを修正する手順を、図16のユーザープログラム作成支援プログラム1300に基づいて説明する。ここでは、履歴再生モードでトラブルの発生原因を検証した結果、ワークの加速が急すぎたことが判明したため、編集モードの切り替えて、ポイントパラメータNo1に移動する際のワークの速度を減少させることを考える。まず図16のユーザープログラム作成支援プログラム1300において、左側に表示されるプロジェクト表示欄420にツリー表示されるユニット構成から、モーションユニットの「ポイントパラメータ」を選択する。この状態で、変更したいパラメータを選択し、PC側操作部8であるキーボード等から値を入力する。ここで画面右側のポイントパラメータ編集欄1320において、速度指定欄1322から、速度を低い値(例えば300mm/s)に変更する。このような操作により、ユーザープログラムを所望の値に変更できる。
As another example of editing a user program, a procedure for modifying parameters for positioning control of a motion unit will be described based on the user program creation support program 1300 in FIG. 16. Here, as a result of verifying the cause of the trouble in history playback mode, it was found that the acceleration of the workpiece was too rapid, so we decided to switch the editing mode and reduce the speed of the workpiece when moving to point parameter No. 1. think. First, in the user program creation support program 1300 of FIG. 16, the "point parameter" of the motion unit is selected from the unit configuration displayed in a tree in the
このようにしてユーザープログラムを編集した結果を保存する手順を、図17~図18に基づいて説明する。ユーザープログラムを保存する際、運転記録データに含まれる元のユーザープログラムを編集してしまうと、履歴再生モードにおいてトラブル発生時のユーザープログラムを再現できなくなるため、元のユーザープログラムとは別に保存する必要がある。ここでは、別のプロジェクトデータとして保存する場合を考える。まず、図17に示すユーザープログラム作成支援プログラム1300のファイルメニュー1330のように、通常のプロジェクトと同様の手順で、プロジェクトデータの保存操作を行う。ここで、ファイルメニュー1330から「プロジェクトを別名保存」1332を選択する場合は、図18に示すように「プロジェクトの別名保存」ダイヤログ画面1340が表示され、ユーザはプロジェクト名やデータファイルの保存場所を指定するよう促される。この手順であれば、運転記録データに含まれるユーザープログラムを維持したまま、新たなプロジェクトデータとして保存される。 The procedure for saving the result of editing a user program in this way will be explained based on FIGS. 17 and 18. When saving a user program, if you edit the original user program included in the driving record data, you will not be able to reproduce the user program when a problem occurred in history playback mode, so it is necessary to save it separately from the original user program. There is. Here, we will consider the case of saving as separate project data. First, the project data is saved using the same procedure as for a normal project, as shown in the file menu 1330 of the user program creation support program 1300 shown in FIG. Here, when selecting "Save project as" 1332 from the file menu 1330, a "Save project as" dialog screen 1340 is displayed as shown in FIG. You will be prompted to specify. With this procedure, the user program included in the driving record data is preserved as new project data.
一方、図17のファイルメニュー1330において「プロジェクトを上書き保存」1334や、一般的なショートカットキーであるCtrl+Sのキーボード操作を行って上書き保存しようとすると、保存制御部50Cが上書き保存を制御する。すなわち、上書き保存の指示に拘わらず、図18に示す「プロジェクトの別名保存」ダイヤログ画面1340を表示させて、別名でのプロジェクトデータの保存を促す。あるいは、図17の保存画面において、上書き保存を禁止するように、該当する「プロジェクトを上書き保存」をグレーアウトさせて選択できないようにしたり、「プロジェクトを上書き保存」をファイルメニューの選択肢として表示させないようにしてもよい。あるいは、自動的にプロジェクトデータを別名で保存することもできる。例えばファイル名に「-1」等の枝番号を付すなどして、別名のファイルを自動生成する。あるいはまた「プロジェクトを上書き保存」を選択すると、上書き保存操作が禁止されていることを示す上書き禁止ポップアップを表示させてもよい。
On the other hand, if an attempt is made to overwrite and save by using the "overwrite save project" 1334 or the general keyboard shortcut keys Ctrl+S in the file menu 1330 of FIG. 17, the save
なお、既に別名での保存を行ったユーザープログラムに対して、さらに上書き保存を指示した場合は、運転記録データに含まれる元のユーザープログラムに対する操作ではないため、そのまま上書き保存が実行される。すなわち、上述した上書き保存操作を規制する保存制御部50Cの動作は、トラブル発生時の運転記録データに含まれる元のプロジェクトデータやユーザープログラムが未だ別名でコピーされて保存されていない場合に実行され、一旦別名で保存されると、上書き保存操作が許容される。
(運転記録データの保存操作)
Note that if you instruct to overwrite and save a user program that has already been saved under a different name, the overwrite save will be executed as is since this is not an operation for the original user program included in the driving record data. That is, the operation of the
(Save operation of driving record data)
以上のように、ユーザはPC2上にあらかじめ保存された、装置のバックアッププロジェクトに基づいて、運転記録データを再生できる。また、装置のバックアッププロジェクトがない場合は、運転記録データに保存されたプロジェクトデータに基づいて、運転記録を再生できる。ユーザは履歴再生モードで運転記録データを再生することにより、そのプロジェクトデータが対象とする処理の問題個所を見つけ、編集モードにてその問題個所を修正した場合、その変更内容をPC2上に保存する操作を行うことができる。
As described above, the user can reproduce the driving record data based on the backup project of the device stored in advance on the
一方で運転記録の再生に、運転記録データ内のプロジェクトデータを使用していた場合、編集モードで編集したプロジェクトデータの保存操作実行時に、ユーザープログラム作成支援プログラムは、保存制御部で上書き保存禁止メッセージを出して、保存をブロックしてもよい。あるいは、新しいプロジェクトデータとして、PCのハードディスク等に保存してもよい。
(「上書き保存禁止」の手順)
On the other hand, if project data in the driving record data is used to play back the driving record, when executing the save operation for the project data edited in edit mode, the user program creation support program will display an overwrite save prohibition message in the save control section. You can block the save by issuing . Alternatively, the data may be saved as new project data on the hard disk of the PC.
(Procedure for "Prohibit overwriting")
このような保存制御部50Cによる「上書き保存禁止」処理の一例を、図19のフローチャートに基づいて説明する。まずステップS1901において、保存操作を開始をすると、ステップS1902において、運転記録データに保存されたプロジェクトデータを編集中か否かを判定する。編集中の場合は、ステップS1903において、ユーザに対して、保存できない旨のメッセージを表示し、保存処理をキャンセルする。一方、編集中でない場合は、ステップS1904に進んで保存処理を実行する。
(「新しいプロジェクトデータとして保存」の手順)
An example of such "overwrite storage prohibition" processing by the
(Procedure for "Save as new project data")
また保存制御部50Cによる「新しいプロジェクトデータとして保存」処理の一例を、図20のフローチャートに基づいて説明する。まずステップS2001において、保存操作を開始をすると、ステップS2002において、運転記録データに保存されたプロジェクトデータを編集中か否かを判定する。編集中の場合は、ステップS2003において、ユーザに対して、新しいプロジェクトとして保存するため、PC2上のファイル保存パスの入力を要求する。そしてステップS2004において、入力された保存パスに、プロジェクトの保存を実行する。一方、ステップS2002において編集中でない場合は、ステップS2005に進み、保存処理を実行する。
(保存したプロジェクトの照合機能)
An example of the "save as new project data" process by the
(Verification function for saved projects)
編集後のプロジェクトデータは、通常のプロジェクトデータと同様に、ユーザープログラム作成支援プログラム1300が提供する照合機能によって、現在ユーザープログラム作成支援プログラムで表示しているプロジェクトと、PC2上に保存した編集後のプロジェクトデータの間の差分を確認することができる。例えば図21のユーザープログラム作成支援プログラム1300の画面において、ファイルメニュー1330から「プロジェクト-プロジェクトの照合」1336を選択すると、指定されたプロジェクトデータの差分を自動で抽出して、ユーザープログラム作成支援プログラム1300の画面上に表示させる。例えば、照合先のプロジェクトデータに対して追加された部分や変更された部分をハイライトさせつつ、削除された部分をグレーアウトさせる。また、差分を一覧表示させてハイライトさせてもよい。一例として、図13~図15で編集したラダープログラムに対して、照合機能を実行した結果を図22に示す。図22はユーザープログラム作成支援プログラム1300でプロジェクトデータの比較表示を行う比較表示画面1350の一例を示している。この図に示す例では、ラダープログラム中で編集された項目について、ステップ番号と、照合元の値及び照合先の値を、赤文字で示している。このようにしてユーザは、参照先のプロジェクトデータ、例えばトラブル発生時のユーザープログラムに対して、編集した箇所を視覚的に把握することが容易となる。
●ロギングの設定(自動抽出と加除)
Like normal project data, the edited project data can be compared with the project currently displayed in the user program creation support program and the edited project data saved on the
●Logging settings (automatic extraction and addition/subtraction)
図23は、PC2のPC側CPU21が、PC側記憶装置22に記憶されているプロジェクトデータ編集プログラムを実行することで実現される機能を示している。これらの機能の一部又はすべては、ASICやFPGA等のハードウエア回路により実現されてもよい。ASICは特定用途集積回路の略称である。FPGAはフィールドプログラマブルゲートアレイの略称である。
FIG. 23 shows functions realized by the PC-
図23のPC側CPU21は、プロジェクト作成部50と、ログ設定部51と、ログ表示制御部61の機能を実現する。なお本実施形態では、図23に示す機能をPC2上で実現することとしたが、本発明はこれに限られず、PLC1上で実現しても構わない。
(プロジェクト作成部50)
The PC-
(Project creation department 50)
プロジェクト作成部50は、プログラム作成部63と、機能設定部62の機能を実現する。このプロジェクト作成部50は、表示部7にプロジェクトデータ71を作成するためのUIを表示し、PC側操作部8から入力されたユーザ指示に従ってプロジェクトデータ71を作成し、PC側記憶装置22に記憶する。UIはユーザーインターフェースの略称である。プロジェクトデータ71には、ユーザープログラムと、PLC1のユニット構成情報等が含まれている。
The
プログラム作成部63は、UIを介したユーザ操作に基づいて、ユーザープログラムを構成する複数のプログラム部品(各モジュール)を作成する。機能設定部62は、CPUユニット3の機能や拡張ユニット4の機能に関する設定を実行する。例えば、機能設定部62は、CPUユニット3に設けられた機能に対していずれかのデバイスを割り付けたり、拡張ユニット4に設けられた機能に対していずれかのデバイスを割り付けたりし、機能とデバイスとの関係を示す割付情報をユニット構成情報に書き込む。なおプロジェクト作成部50は、ユーザープログラムがどのようなプログラム部品から構成されているかを示すプログラム構成情報も、プロジェクトデータ71として記憶させる。PLC1全体がどのようなユニットから構成されるかを示すユニット構成情報も、プロジェクトデータ71として記憶させる。
(ログ設定部51)
The
(Log setting section 51)
ログ設定部51は、部品指定部52と、機能指定部60と、デバイス抽出部53と、手動設定部58と、推定部59の機能を実現する。このログ設定部51は、プロジェクトデータ71を解析することで、このプロジェクトデータ71に記述されているデバイスを抽出し、抽出されたデバイスをロギング対象として設定するためのログ設定データ72を作成する。ログ設定部51は各種の機能を有している。部品指定部52は、PC側操作部8から入力されるユーザ指示に従って、デバイスの抽出対象となるプログラム部品を指定する。また部品指定部52は、PC側操作部8から入力されるユーザ指示に従って、デバイスの抽出対象から除外されるプログラム部品を指定する。
The
デバイス抽出部53は、追加部54と、削除部55と、マージ部56と、特定部57の機能を実現する。このデバイス抽出部53は、プロジェクトデータ71を解析することでプロジェクトデータ71に記述されているデバイスを抽出し、ログ設定データ72を作成する。追加部54は、部品指定部52により抽出対象として指定されたプログラム部品を解析し、プログラム部品に記述されているデバイスを抽出し、抽出リストに追加する。 削除部55は、部品指定部52により除外対象として指定されたプログラム部品を解析し、プログラム部品に記述されているデバイスを抽出し、抽出されたデバイスを抽出リストから削除する。あるいは、削除部55は、抽出されたデバイスを除外リストに追加する。マージ部56は、複数のプログラム部品からそれぞれ抽出されたデバイスの内、重複して抽出されたデバイスを抽出リストから削除する。特定部57は、プロジェクトデータ71においてメモリカードに対する命令語を検知し、当該命令語の対象となっているデバイスを特定し、特定されたデバイスを抽出リストに追加する。
The
本実施形態では、部品指定部52がプログラム部品を指定した後、追加部54が、その指定されたプログラム部品を解析することにより、ロギング対象となるデバイスを抽出・追加することとしたが、本発明はこれに限られない。例えば、追加部54は、プロジェクトデータ71に含まれる一又は複数のプログラム部品を先に解析することでデバイスを抽出し、抽出されたデバイスを抽出リストに追加した後で、部品指定部52によって指定されたプログラム部品に記述されたデバイスを抽出し、これを抽出リストへ追加するようにしてもよい。
In this embodiment, after the
同様にして、削除部55は、プロジェクトデータ71に含まれる一又は複数のプログラム部品を先に解析することで抽出リストを作成した後で、部品指定部52によって指定されたプログラム部品に記述されたデバイスを抽出し、これを抽出リストから削除するようにしてもよい。
Similarly, the
なお、本実施形態では、説明の便宜上、追加部54と削除部55を分けているが、一つの機能ブロックであってもよいことは言うまでもない。
Note that in this embodiment, for convenience of explanation, the adding
手動設定部58は、PC側操作部8を通じて入力されるユーザ指示に従って一つのデバイスや、関連した一連のデバイスを抽出リストに追加する。推定部59は、デバイス抽出部53により記録対象として抽出されたデバイスの数に基づきPLC1によるデバイス値の記録がユーザープログラムの実行に与える影響を推定する。ロギングによってデバイス値の数に相関した遅延時間がスキャンタイムに加算される。よって、推定部59は、デバイス値の数に所定係数を乗算することで遅延時間を求め、遅延時間を推定結果として表示部7に表示してもよい。この遅延時間はスキャンタイムの伸びと呼ばれてもよい。
The
機能指定部60は、PC側操作部8から入力されるユーザ指示に従って、デバイスの抽出対象となるCPUユニット3の機能や拡張ユニット4の機能を指定する。また、機能指定部60は、PC側操作部8から入力されるユーザ指示に従って、デバイスの抽出対象から除外されるCPUユニット3の機能や拡張ユニット4の機能を指定する。追加部54は、機能指定部60により抽出対象として指定された機能のユニット構成情報を解析し、ユニット構成情報により当該機能に割り付けられたデバイスを抽出し、抽出リストに追加する。削除部55は、機能指定部60により除外対象として指定された機能のユニット構成情報を解析し、ユニット構成情報により当該機能に割り付けられているデバイスを抽出し、抽出されたデバイスを抽出リストから削除する。マージ部56は、複数の機能のそれぞれについて抽出されたデバイスの内、重複して抽出されたデバイスを抽出リストから削除する。特定部57は、プロジェクトデータ71においてメモリカードに対する命令語を検知し、当該命令語の対象となっているデバイスを特定し、特定されたデバイスを抽出リストに追加する。
The
ログ表示制御部61は、PLC1において生成されたログデータ73を、ログデータ保存部74に保存する。ログデータ保存部74は、メモリカード36A等が利用できる。ログデータ保存部74に保存されたログデータ73を、メモリカード36Aを介して読み出し、表示部7にログデータ73を表示する。例えば、ログ表示制御部61は、ログデータ73に記録されているデバイス値と、プロジェクトデータ71のプログラム部品とを関連付けて表示部7に表示してもよい。ログ表示制御部61は、プログラマブルロジックコントローラ用のエンジニアリングツールの中核をなす。またログデータ73は、デバイス値の他、カメラ部で撮像した画像データ等を含めてもよい(詳細は後述)。これらプロジェクトデータとログデータを含めて運転記録データとしてパッケージ化して保存する。あるいはプロジェクトデータとログデータとを関連付けて別々のファイルで保存し、プロジェクトデータ又はログデータの一方を開くと、他方のファイルも関連付け情報を参照して読み出し可能としてもよい(詳細は後述)。
●ロギングの実行
The log
● Executing logging
図24はCPUユニット3のPLC側CPU31の機能を示している。これらの機能の一部又はすべてはASICやFPGA等のハードウエア回路により実現されてもよい。ASICは特定用途集積回路の略称である。FPGAはフィールドプログラマブルゲートアレイの略称である。
FIG. 24 shows the functions of the
PLC側CPU31は、PC2から受信したプロジェクトデータ71とログ設定データ72をPLC側記憶装置32に記憶しているものとする。実行部80は、ユーザープログラムを繰り返し実行するラダー実行エンジン80aと、このラダー実行エンジン80aを制御したり、拡張ユニット4との入出力リフレッシュを実行したりするユニット制御部80bと、を有している。実行部80のラダー実行エンジン80aは、プロジェクトデータ71に含まれるユーザープログラムを繰り返し実行し、ユーザープログラムに従って拡張ユニット4を制御する。なお、実行部80のラダー実行エンジン80aは、ユーザープログラムに従って、デバイス部34のCPUユニットデバイス部34aに保持されている出力系のデバイスにデバイス値を書き込んだり、CPUユニットデバイス部34aに保持されている入力系のデバイスからデバイス値を読み込んだりする。
It is assumed that the
一方で、実行部80のユニット制御部80bは、入出力リフレッシュにより取得した拡張ユニット4に関するデバイス値を、拡張ユニットデバイス部34bに読み書きする。また、CPUユニット3と拡張ユニット4は、ユニット間バス90によって電気的に接続されており、ユニット制御部80bは、このユニット間バス90における通信制御を行う機能、いわゆるバスマスタとしての機能を有している。ユニット制御部80bがバスマスタとして機能する場合には、図23を用いて説明したユニット構成情報、すなわち、PLC1全体がどのようなユニットから構成されるかを示す情報に基づいて、各拡張ユニット4とリフレッシュ通信を行う。
On the other hand, the
記録部81は、ログ設定データ72に従ってデバイス部34(CPUユニットデバイス部34a又は拡張ユニットデバイス部34b)からデバイス値を取得したり、拡張ユニット4のバッファメモリからデバイス値を取得したりして、ログデータ73としてメモリ(例えばリングバッファ)に書き込む。上述されたように、記録部81は、END処理の際等に、ロギング処理を実行する。
The
END処理におけるロギング処理について、更に詳細に説明する。ログ設定データ72には、部品指定部52によって指定されたプログラム部品に記述されたデバイスや、機能指定部60によって指定された機能(例えばユニットモニタによる監視の対象)に割り付けられたデバイスが、ロギング対象として含まれている。前者のデバイスについては、END処理の際に、ログデータ73に書き込む一方で、後者のデバイスについては、END処理の際に、拡張ユニット4から対象となるデバイス(UG)のデバイス値を読み出して、ログデータ73に書き込む。
The logging process in the END process will be explained in more detail. The
ここで、モータの現在座標や指令座標の更新周期(いわゆる制御周期)は、ラダープログラムのスキャン周期と比べて格段に短い。したがって、本実施形態では、スキャン周期と同期してUGのデバイス値を読み出すようにしているので、全ての現在座標や指令座標がログデータ73に書き込まれるわけではない。しかし、本発明はこれに限られず、例えば、拡張ユニット4のメモリに、制御周期ごとに現在座標や指令座標を格納していき、スキャン周期のタイミングで、それまで格納した複数の現在座標や指令座標等を読み出すように構成することも可能である。
Here, the update cycle (so-called control cycle) of the current coordinates and command coordinates of the motor is much shorter than the scan cycle of the ladder program. Therefore, in this embodiment, since the device values of the UG are read out in synchronization with the scan cycle, not all current coordinates and command coordinates are written to the
また、記録部81は、時刻管理部83により保持されている時刻情報をログデータ73の各レコードに付与する。これによりログデータ73には時系列にデバイス値が並べられる。
Furthermore, the
ロギング対象となるデバイスは、基本的に、ログ設定データ72のロギング対象リストによって指定されるが、検知部82によって追加のデバイスが指定されてもよい。検知部82は、例えば、デバイス部34に含まれているいずれかのデバイスに対する外部機器からのデバイス値の書き換えを検知してもよい。一般にデバイス値はユーザープログラムに従って書き換えられる場合と、外部機器によって書き換えられることがある。このような書き換えはユーザープログラムを解析するだけでは事前に把握することができない。記録部81は、検知部82によりデバイス値の書き換えが検知されたデバイスをロギング対象に追加してもよい。一般に外部機器からのデバイス値の書き換えは、ユーザにとって想定外の事象の原因となりやすい。よって、記録部81は、外部機器により書き換えられたデバイス値をロギングすることで、ユーザによるプログラムの改良に役立つであろう。
Devices to be logged are basically designated by the logging target list of the
ところで、END処理において、ユーザープログラムとは無関係に発行されるUG読み出し命令が発行されることがある。UGはバッファメモリを示すデバイス種別である。検知部82は、ユーザープログラムとは無関係に発行されるUG読み出し命令を検知してもよい。記録部81は、検知部82により検知されたUG読み出し命令の対象となっているバッファメモリを特定し、特定したバッファメモリを記録対象として追加してもよい。この拡張ユニット4がモーションユニットである場合、このようなバッファメモリには、トルク値や現在座標位置等が記憶されている。
By the way, in the END process, a UG read command may be issued regardless of the user program. UG is a device type indicating a buffer memory. The
検知部82はFPGA等により実現されてもよい。実行部80はASICにより実現されてもよい。この場合、実行部80はPLC側記憶装置32に対してアドレス線を用いて読み出し/書き込み対象となっているデバイスのアドレスを指定する。よって、検知部82はこのアドレス線を監視することで、動的に、デバイス値を更新されたデバイスを検知してもよい。これはユーザープログラムに記述されていないデバイスを記録対象として追加する際に有用であろう。
The
検知部82は実行部80に設けられてもよい。この場合、実行部80は、デバイス部34の特定のデバイスに対してデバイス値を書き込むと共に、このデバイス値とデバイス名(デバイス番号)をログデータ73に書き込んでもよい。この手法は、ユーザープログラムに記述されていないデバイスであって、動的に割り付け割れるデバイスを記録対象として追加する際に有用であろう。
The
このように記録部81はログ設定データ72に含まれているデバイスリストとは無関係にデバイスを記録してもよい。極端な場合、ユーザはログ設定データ72を作成せずに、ログデータ73を取得可能となる。例えば、実行部80が起動すると、実行部80は、デバイス部34におけるすべてのデバイスからデバイス値を取得する。検知部82は、デバイスを監視しているため、実行部80がデバイス値を読み出したことを検知し、記録部81にデバイス値を読み出されたデバイスの情報(アドレス情報)を伝達する。記録部81は、検知部82により伝達されたアドレス情報に基づきデバイス部34に含まれているすべてのデバイスからデバイス値を読み出してログデータ73に書き込む。それ以降もデバイス部34へのアクセスを検知部82が検知するたびに、記録部81はデバイス値をロギングする。
In this way, the
ところで、記録部81はスキャン周期ごと、又は所定の収集周期ごとにデバイス値をログデータ73に書き込んでもよい。例えば、一周期内で検知部82が複数回にわたるデバイスへのアクセスを検知したとしても、記録部81は、最後のアクセスが検知されたときのデバイス値だけでログデータ73に書き込んでもよい。これにより、ログデータ73のデータサイズを削減することが可能となる。
By the way, the
実行部80はデバイスを保持するキャッシュを有していてもよい。この場合、検知部82はキャッシュを監視することで、デバイスの書き込みを検知してもよい。
The
ログ設定データ72には記録対象となるデバイスを示すデバイスリストが含まれているが、記録の除外対象となるデバイスを示すデバイスリストが含まれていてもよい。この場合、記録部81は、除外対象となるデバイスへのアクセスを検知部82が検知すると、そのデバイスについてのデバイス値の記録をスキップする。
The
検知部82は実行部80による拡張ユニット4のバッファメモリへのアクセスを検知してもよい。この場合、実行部80は、拡張ユニット4のバッファメモリから読み出したデバイス値をPLC側記憶装置32内に確保されたバッファ等に書き込む。記録部81はバッファからデバイス値を読み出してログデータ73に書き込む。
The
実行部80はユーザープログラムを繰り返し実行し、ユーザープログラムに従ってデバイス値を書き換える。検知部82が実行部80に実装されている場合、実行部80はデバイス値を書き換える命令語を検知すると、その命令語と共にデバイス値を記録部81に出力する。記録部81は、命令語、デバイス値及びタイムスタンプ(デバイス値を取得した時刻)をログデータ73に書き込んでもよい。
The
ところで、ログ設定データ72には、ログデータ73のデータ形式(例:バイナリー形式やテキスト形式)が含まれてもよい。データ形式としては、10進数16ビット、10進数32ビット、±10進数16ビット、±10進数32ビット、16進数16ビット、16進数32ビット、文字列、Float、DoubleFloat等が、デバイスごとに設定されてもよい。このようなデータ形式はプログラム部品における命令語を解析することで判別可能である。
Incidentally, the
出力部84は、ユーザープログラムの実行が終了したとき、或いは、メモリカードへの保存トリガリレーがONした場合等、所定の出力条件が満たされると、プロジェクトデータ71、ログデータ73、画像データをメモリカード36Aに書き込む。所定の出力条件が満たされるまでは、ログデータ73がメモリ(例えばリングバッファ)に記録されていき、容量が一杯になると、一番古いログデータ73が消去され、新しいログデータ73が追加記録されていく(いわゆるFIFO形式で記録する)。このメモリカード36AはCPUユニット3から取り外されて、PC2の装着部に装着される。これにより、PC2の表示部7にログデータ73が表示されるようになる。なお、出力部84は、PLC側通信部33を介してPC2やクラウド等にログデータ73を送信してもよい。
The
なお、本実施形態では、所定の出力条件が満たされたときに、ログデータ73等をメモリカード36Aに書き込むこととしたが、本発明はこれに限られず、例えば、内部メモリ(フラッシュメモリやハードディスク等の不揮発性メモリ)に保存しても構わない。また、少なくともログデータ73については、所定の出力条件が満たされたときにメモリカード36A又は内部メモリ37に保存される必要がある一方、プロジェクトデータ71については、所定の出力条件が満たされたときに限られない。例えば、PLC1が設定モード(PROGRAMモード)から運転モード(RUNモード)になったタイミングで、予めメモリカード36Aや内部メモリ37に保存しておいてもよい。
●ユニット構成情報の作成
Note that in this embodiment, the
●Creation of unit configuration information
図25は機能設定部62が実行するユニット構成情報の作成処理(ユニット設定)を説明する図である。機能設定部62はユニットエディタと呼ばれてもよい。機能設定部62はユニットエディタの起動を支持されると、ユニット設定UI150を表示部7に表示する。名称欄151は各ユニットの名称(例:型番等)を表示する欄である。なお、各ユニットには自動的にユニット番号が付与される。この例では、CPUユニット3にユニット番号として“0”が付与されている。入力領域欄152は入力系のデバイスを割り付けるための欄である。この例では、CPUユニット3に入力系のデバイスとしてR000からR015までのデバイスが割り付けられている。出力領域欄153は出力系のデバイスを割り付けるための欄である。この例では、CPUユニット3に出力系のデバイスとしてR500からR507までのデバイスが割り付けられている。占有領域欄154は、入出力混合系のデバイスを割り付けるための欄である。エンドユニットは、いわゆる終端ユニットである。ユーザはPC側操作部8を通じて拡張ユニット4の種類、接続順番、割り付けられるデバイスを設定する。機能設定部62は、拡張ユニット4の種類、接続順番(ユニット番号)、CPUユニット3と拡張ユニット4とのそれぞれに割り付けられるデバイスを示す情報をユニット構成情報に格納する。ユニット構成情報はユニット設定情報と呼ばれてもよい。ここでは、ユニットごとにデバイスが割り付けられているが、各ユニットの機能ごとにデバイスが割り付けられてもよい。機能設定部62はユニット構成情報をプロジェクトデータ71の一部として管理している。
FIG. 25 is a diagram illustrating the unit configuration information creation process (unit setting) executed by the
このようにユニット構成情報には各ユニットに割り付けられているデバイスを示す情報や各機能に割り付けられているデバイスを示す情報が含まれている。そのため、デバイス抽出部53はユニット構成情報を参照することで、各ユニットに割り付けられているデバイスや各機能に割り付けられているデバイスを抽出することができる。
<デバッグ>
In this way, the unit configuration information includes information indicating devices assigned to each unit and information indicating devices assigned to each function. Therefore, by referring to the unit configuration information, the
<Debug>
図26はユーザにより実行されるユーザープログラムのデバッグ処理の概要を示すフローチャートである。 FIG. 26 is a flowchart showing an overview of the user program debugging process executed by the user.
ステップS2601でユーザはPC2を操作し、複数のプログラム部品から構成されるユーザープログラムを作成し、ユーザープログラムを含むプロジェクトデータ71を作成する。プログラム作成部63はユーザ入力に従ってユーザープログラムを作成し、PC側記憶装置22に格納する。プロジェクト作成部50はユーザ入力に従ってプロジェクトデータ71を作成し、PC側記憶装置22に格納する。プロジェクトデータ71は、プロジェクトデータ71又はユーザープログラムを識別するための識別情報を含む。プロジェクト作成部50は、プロジェクトデータ71又はユーザープログラムに対して演算を実行してハッシュ値又は誤り検出符号等を求め、これらを識別情報としてプロジェクトデータ71に付加してもよい。なお、識別情報はGUID(グローバル一意識別子)等であってもよい。
In step S2601, the user operates the
ステップS2602でユーザはPC2を操作し、プロジェクトデータ71をPLC1に転送する。プロジェクト作成部50はプロジェクトデータ71をPC側記憶装置22から読み出し、PC側通信部23を介してPLC1へ送信する。PLC1のCPUユニット3はプロジェクトデータ71を受信すると、PLC側記憶装置32に書き込む。
In step S2602, the user operates the
ステップS2603でユーザはCPUユニット3のPLC側操作部6を操作し(例えば、PROGRAMモードからRUNモードに切り替えるモード切替スイッチを操作することにより)、プロジェクトの実行を指示する。実行部80はプロジェクトデータ71に含まれているユーザープログラムを実行する。記録部81はデバイス値等をロギングし、ロギングしたデバイス値を一時記録部91aに格納(記録)する。出力部84の内の保存部93は、所定の出力条件が満たされると、一時記録部91aに記録されているデバイス値や、上述した画像データを、メモリカード36A又は内部メモリ37に保存することで、ログデータ73を作成する。
In step S2603, the user operates the PLC
また、保存部93は、ログデータ73に加えて、プロジェクトデータ71をメモリに保存する。これにより、PC2において、トラブル発生時のプロジェクトデータ71を使って、トラブル発生時の動きをモニタ上で再現できるようになる。詳細については後述する。
In addition to the
また、保存部93は、プロジェクトデータ71に加えて、プロジェクトデータ71の識別情報(ハッシュ値等)をメモリに保存する。これにより、PC2は、その識別情報を使って、現在の(リプレイ対象にしようとしている)プロジェクトデータが、実際のトラブル発生時のプロジェクトデータ71と一致するか否かを検証できるようになる。詳細については後述する。
In addition to the
なお、本実施形態では、所定の出力条件が満たされたタイミングで、ログデータ73に加えて、プロジェクトデータ71及びその識別情報をメモリに保存することとしたが、本発明はこれに限られない。例えば、PLC1の運転開始前、運転開始時、又は運転中に、プロジェクトデータ71及びその識別情報をメモリに保存しておき、所定の出力条件が満たされたタイミングで、ログデータ73のみをメモリに保存するようにしてもよい。要するに、所定の出力条件が満たされた時点で、ログデータ73と、プロジェクトデータ71と、その識別情報とが対応付けられた状態で、メモリに保存されていればよい。
Note that in this embodiment, the
また、本実施形態では、プロジェクトデータ71をメモリに保存しているが、本発明はこれに限られず、例えば、プロジェクトデータ71に代えて、プロジェクトデータ71の識別情報のみをメモリに保存するようにしてもよい。この場合、PC2における現在のプロジェクトデータは、実際のトラブル発生時のプロジェクトデータ71と一致することを前提としている。すなわち、プロジェクトデータをPLC1に転送した後、現在のプロジェクトデータは編集・改変されていないことを前提としている。仮に、両データが不一致と判定された場合には、ユーザは、現在のプロジェクトデータが、実際のトラブル発生時のプロジェクトデータ71とは異なることを認識した上でリプレイを行えばよいので、ユーザがこれを認識しない状態でリプレイ(不正確なトラブルシューティング)が行われるのを防ぐことができる。
Further, in this embodiment, the
ステップS2604でユーザはCPUユニット3のPLC側操作部6を操作し、プロジェクトデータ71とログデータ73をPC2へ転送するよう指示する。或いは、PC2のPC側操作部8を操作して、メモリカード36Aに書き込まれたプロジェクトデータ71、プロジェクトデータ71の識別情報、及びログデータ73を読み出してもよい。出力部84はプロジェクトデータ71とログデータ73をPC2へ送信する。なお、出力部84はプロジェクトデータ71の転送が禁止されていると判定した場合に、プロジェクトデータ71の識別情報をログデータ73に付加する構成を採用してもよい。プロジェクトデータ71の識別情報とログデータ73とは別々に送信されてもよい。出力部84は、メモリカード36Aに書き込むための所定の条件が成立したタイミングで、プロジェクトデータ71又はユーザープログラムに対して(例えばハッシュ関数を用いた)演算を実行してハッシュ値又は誤り検出符号等を求め、これらを識別情報としてログデータ73に付加してもよい。なお、PC2が実行する識別情報の作成ルールと、CPUユニット3が実行する識別情報の作成ルールとが一致していれば、どのようなルールが採用されてもよい。
In step S2604, the user operates the PLC
ステップS2605でユーザはPC2を操作し、ログデータ73を再生(リプレイ)しつつトラブルの原因究明を行って、プロジェクトデータ71を構成するユーザープログラムのデバッグを実行する。ログデータ73の再生は、ログデータ73に含まれている時系列のデバイス値を波形として表示部7に表示することや、デバイス値をユーザープログラムに関連付けて表示することや、ログデータ73に含まれている時系列の画像データを表示部7に表示することを含む。ログ表示制御部61は、仮想的な時刻を計時する内部時計を有しており、内部時計に同期してログデータ73からデバイス値を取得して表示部7に表示する。プロジェクトデータ71がPLC1から送信されないこともある。この場合、ログ表示制御部61は、PC側記憶装置22に保持されているプロジェクトデータ71(マスタデータ)のユーザープログラムを使用して、デバイス値をユーザープログラムに関連付けて表示してもよい。ログデータ73を再生することによるトラブルの原因究明の詳細については、後述する。
In step S2605, the user operates the
ここで注意すべき点としては、ログデータ73を取得するために使用されたプロジェクトデータ71のバージョンと、PC2に保持されているプロジェクトデータ71のバージョンとが異なることがある。この場合、デバイス値をユーザープログラムに関連付けて表示することが不可能となるか、又はユーザープログラムとデバイス値との関連付が誤ってしまうことも考えられる。この場合、ログ表示制御部61は、プロジェクトデータの識別情報を使って、ログデータ73を取得するために使用されたプロジェクトデータ71のバージョンと、PC2に保持されているプロジェクトデータ71のバージョンとが異なることを示す警告を表示部7に表示してもよい。なお、ログ表示制御部61は、第一のバージョンのプロジェクトデータ71を使用して取得されたログデータ73を、PC2に保持されている第2のバージョンのプロジェクトデータ71に関連付けて表示するかどうかをユーザに問い合わせもよい。ユーザがこのような表示を希望する場合、ログ表示制御部61は、第一のバージョンのプロジェクトデータ71を使用して取得されたログデータ73を、PC2に保持されている第2のバージョンのプロジェクトデータ71に関連付けて表示部7に表示する。なお、バージョンは識別情報によって管理される。ユーザがログデータ73に問題がないことを確認すると、デバッグは不要であり、後続のステップS2606やステップS2607も不要である。ユーザはログデータ73を分析し、ユーザープログラムのバグ等を発見し、ユーザープログラムを修正する。プロジェクト作成部50はユーザ入力に従ってプロジェクトデータ71を修正(更新)し、PC側記憶装置22に格納する。
It should be noted here that the version of the
ステップS2606でユーザはPC2を操作し、プロジェクトデータ71をPLC1に転送する。なお、プロジェクトデータ71内のユーザープログラムが変更されると、識別情報が更新される。これにより、修正前のプロジェクトデータ71と修正後のプロジェクトデータ71とが区別可能となる。
In step S2606, the user operates the
ステップS2607でユーザはCPUユニット3を操作し、プロジェクトデータ71に含まれるユーザープログラムの実行を指示することで、プロジェクトデータ71を検証する。実行部80はプロジェクトデータ71に含まれているユーザープログラムを実行する。PLC1がユーザの想定通りに稼働していれば、ユーザはプロジェクトデータ71のデバッグに成功したと判断する。なお、PLC1がユーザの想定通りに稼働していなければ、記録部81によって再びデバイス値等をロギングし、保存部93によってログデータ73を作成する。そして、ユーザはステップS2604ないしステップS2607を再び実行する。
In step S2607, the user operates the
このようにユーザはログデータ73を参照しながらプロジェクトデータ71をデバッグできる。そのため、デバッグの効率が向上すると考えられる。
In this way, the user can debug the
なお、プロジェクトデータ71の転送はメモリカード36Aを介して実行されてもよい。つまり、PC2はメモリカード36Aに書き込む。ユーザはメモリカード36AをPC2から取り外し、CPUユニット3にメモリカード36Aを取り付ける。CPUユニット3はメモリカード36Aからプロジェクトデータ71を読み出してPLC側記憶装置32に書き込む。同様に、ログデータ73の転送もメモリカード36Aを介して実行されてもよい。
<プロジェクト作成部50>
Note that the
<
図27はプロジェクト作成部50の詳細を示している。機能設定部62はPC側操作部8から入力される情報に基づき拡張ユニット4のユニット構成情報、CPUユニット3の機能及び拡張ユニット4の機能を設定し、設定内容を示すユニット構成情報を作成する。CPUユニット3の機能の設定としては、IPアドレスの設定、FTPクライアントに関する設定、プロジェクトデータ71のアクセス権限の設定等がある。拡張ユニット4の機能の設定としては、入力チャネルの設定やPLC同士の通信に関する設定等がある。ユニット構成情報はプロジェクトデータ71の一部である。編集部311(図23に示すプログラム作成部63を兼ねてもよい)は、表示部7にユーザープログラムの編集UIを表示し、PC側操作部8から入力される情報に基づきユーザープログラムを編集する。デバッグ部314はプロジェクトデータ71を使用してユーザープログラムをデバッグする。付加部312はプロジェクトデータ71に識別情報を付加する。演算部313は識別情報(例:ハッシュ値や誤り検出符号)を演算により求める。なお、この演算部313による識別情報の演算(算出)機能については、出力部84が、同機能を発揮するようにしてもよい。
<ログ表示制御部61>
FIG. 27 shows details of the
<Log
図28はログ表示制御部61の詳細を示している。プログラム表示モジュール321はプロジェクトデータ71に含まれるユーザープログラムと共に、ログデータ73に含まれるデバイス値を表示部7に表示するモジュールである。また、プログラム表示モジュール321は、ユーザープログラムのみならず、プロジェクトデータ71に含まれるプログラム構成情報、複数のプログラム部品、ユニット構成、ユニット毎の機能設定等、ユーザがプロジェクトデータ71の設定内容を視認するための各種情報を表示可能となっている。画像表示モジュール323は、ログデータ73に含まれる時系列の画像データを表示部7に表示する。波形表示モジュール322は、ログデータ73に含まれる時系列のデバイス値を波形化して表示部7に表示するモジュールである。再生制御モジュール324は、プログラム表示モジュール321によって表示される情報と波形表示モジュール322によって表示される情報とを時間的に同期させる。これらのモジュールはエンジニアリングソフトウエアと呼ばれてもよい。なお、画像表示モジュール323は、プログラム表示モジュール321の一機能(画像表示部)として具現化されてもよいし、波形表示モジュール322の一機能(画像表示部)として具現化されてもよい。
●プログラム表示モジュール
FIG. 28 shows details of the log
●Program display module
図29はプログラム表示モジュール321の詳細を示している。時刻UI330aは、ユーザープログラムと共に表示されるデバイスの取得時刻(表示時刻)を操作するためのUI(例:スライドバーやカーソル等)を提供する。表示時刻制御部331aは時刻UI330aにより指定された表示時刻を再生制御モジュール324に送出したり、再生制御モジュール324から通知された表示時刻を時刻UI330aに設定したりする。プログラム表示部332は、プロジェクトデータ71を表示部7に表示したり、識別情報に対応したプロジェクトデータ71をPC側記憶装置22から読み出して表示部7に表示したりする。また、プログラム表示部332はデバイス値取得部333aにより取得されたデバイス値を、ユーザープログラムに使用又は記述されているデバイスと関連付けて表示する。デバイス値取得部333aは、リアルタイム再生モードと履歴再生モード(ログ再生モード)とを有している。デバイス値取得部333aは、リアルタイム再生モードにおいて、PLC1のリアルタイム送信部にアクセスし、デバイス値を取得し、プログラム表示部332に渡す。デバイス値取得部333aは、ログ再生モードにおいて、図28の再生制御モジュール324にアクセスし、表示時刻とデバイス値を取得し、プログラム表示部332に渡す。
FIG. 29 shows details of the
図9は、プログラム表示部332等によって表示部7に表示されるGUIの一例を示す模式図である。図9において、左欄のプロジェクト表示領域420には、プロジェクトデータ71を構成する様々な情報が表示されている。上から順に、ユニット構成(CPUユニット、モーションユニット、アナログ入力ユニット、カメラ入力拡張ユニット)、プログラム構成(毎スキャンモジュール、定周期モジュール、ユニット間同期モジュール、ファンクションブロック、マクロ)が表示されている。モーションユニットについては、機能設定として軸構成や軸制御の設定パラメータが表示されている。ユーザは、図9に示すGUI上において、軸構成や軸制御をダブルクリックすることで、これらの設定パラメータについて、どのような設定内容になっているかを確認することができる。また、プロジェクト表示領域420において、毎スキャンモジュールに対してMainとSubが表示されているところ、ユーザがMainをクリックすると、中央のラダーモニタ450のプログラム表示領域410に、Mainプログラムが表示される。このように、図28に示すプログラム表示モジュール321は、メモリカード36Aからプロジェクトデータ71を読み出して、プロジェクト表示領域420に各種情報を表示したり、プログラム表示領域410に所望プログラムを表示したりする。
FIG. 9 is a schematic diagram showing an example of a GUI displayed on the
ここで、プログラム表示領域410は、いわゆるラダーモニタ450の一部であり、リアルタイム再生モードにおいて単独で動作させることができるものである。×印をクリックすることで、ラダーモニタ450のみを非表示にすることも可能である。一方で、ログ再生モードでは、プログラム表示部332によって、運転記録を保存した際のプロジェクトに含まれるラダープログラムを再現することができるようになっている。また、プログラム表示部332は、ログ再生モードにおいて、デバイス値取得部333aを介してログデータ73に含まれるデバイス値を、Mainプログラムに記述されているデバイスと関連付けて表示する。表示対象となるデバイス値は、時刻指定カーソル404によって指定された時刻に対応するデバイス値となる(より詳細は、後述する図32を用いて説明する)。
Here, the
図9でいえば、時刻表示領域409に表示されている20XX/10/01の18:52:54と対応付けられたデバイス値が、Mainプログラムに記述されているデバイスと関連付けて表示される。この日付の右側に表示された[35000/74286]は、全スキャン回数74286に対する現在のスキャン回数35000を示している。ユーザは、時刻指定カーソル404をドラッグして移動させることで、表示時刻及びスキャン回数の更新と共に、デバイス値の表示も更新される。例えば、更新後の表示時刻において、ONしているリレーデバイスの箇所にはON表示(例えば色で塗潰す等)がなされ、OFFしているリレーデバイスの箇所にはOFF表示(例えば色抜き等)がなされる。再生ボタン406の機能等の詳細については、図32を用いて後述する。
In FIG. 9, the device value associated with 18:52:54 on 20XX/10/01 displayed in the
図9において、右上欄には、カメラモニタ430の画像表示領域が設けられている。画像表示モジュール323は、プログラム表示モジュール321によってラダーモニタ450に表示された表示時刻と同期して、ログデータ73から画像データを読み出してカメラモニタ430の画像表示領域に表示する。図9では、表示時刻である20XX/10/01の18:52:54と対応付けられた画像データが、カメラモニタ430に表示されている。また、この表示時刻の右側には、282/601と表示されているが、これは、全撮像枚数601に対する現在の画像データの順番(282枚目)を表している。ユーザは、カメラモニタ430において、時刻指定カーソル404aをドラッグして移動させることで、表示時刻及び現在の画像データの順番を更新させることができる。
In FIG. 9, an image display area of the
このとき、時刻指定カーソル404aの移動に伴って、上述したラダーモニタ450における時刻指定カーソル404も連動して移動する。例えば、時刻指定カーソル404aを、表示時刻20XX/10/01の19:00:00に合わせた場合には、ラダーモニタ450における時刻指定カーソル404も、表示時刻20XX/10/01の19:00:00の位置に追従して移動する。そして、時刻指定カーソル404の移動に伴って、ラダーモニタ450におけるデバイス値も更新される。ここでは時刻指定カーソル404aを移動させたが、逆も同様である。例えば、ラダーモニタ450における時刻指定カーソル404を移動させると、それに応じて、カメラモニタ430における時刻指定カーソル404aも移動する。このような処理動作が可能になるのは、プログラム表示モジュール321と、画像表示モジュール323とが、再生制御モジュール324を介して表示時刻に関する同期制御を実行しているからである。
At this time, as the time designation cursor 404a moves, the
また、図9において、右下欄には、ユニットモニタ440が表示されている。例えば、ユニットモニタ440は、モーションユニットにおけるバッファメモリ(UG)のデバイス値を表示する。より具体的には、ログ表示制御部61のユニット表示モジュール325は、再生制御モジュール324から現在再生すべき表示時刻を受け取ると、その時刻と対応付けられたデバイス値をメモリカード36Aから読み出して、ユニットモニタ440に表示させる。したがって、例えば図9でいえば、表示時刻20XX/10/01の18:52:54と対応付けられたデバイス値の一覧が、ユニットモニタ440に表示される。
Further, in FIG. 9, a
図30は、ログ再生モードにおけるGUIを表示するためのデータソースを模式化した図である。図30に示すように、プロジェクト表示領域420は、プロジェクトデータ71に含まれるユニット構成、機能設定、プログラム構成、プログラム部品をメモリから読み出して、これらをツリー形式で表示する。ラダーモニタ450は、プログラム構成(どのようなプログラム部品からなるか)、プログラム部品をメモリから読み出して、ユーザによって指定されたプログラム部品を表示すると共に、ログデータ73から表示時刻に対応するデバイス値を読み出して表示する。カメラモニタ430は、ユニット構成(カメラモニタがあるか否か)と機能設定(カメラモニタの機能。例えば複数ポートある場合にはポート番号、撮像周期やゲイン設定等)等の情報に基づいて、ログデータ73から表示時刻に対応する画像データを読み出して表示する。ユニットモニタ440は、ユニット構成(どのようなユニットがあるか)と機能設定(モーションユニットであれば軸構成や軸制御等)等の情報に基づいて、ログデータ73から表示時刻に対応するデバイス値を読み出して表示する。
FIG. 30 is a diagram schematically showing a data source for displaying a GUI in log playback mode. As shown in FIG. 30, the
図9や図30から分かるように、再生制御モジュール324の機能によって、プログラム表示モジュール321、画像表示モジュール323、ユニット表示モジュール325を同期制御して、連携させることができる。なお、波形表示モジュール322の連携の詳細については後述する。
As can be seen from FIGS. 9 and 30, the function of the
ここで、本実施形態では、現在のプロジェクトデータが、実際のトラブル発生時のプロジェクトデータ71と一致するか否かを検証できるようにしている。より具体的には、図29に示すプログラム表示モジュール321の内の照合部334は、PLC1から出力されるプロジェクトデータ71(ユーザープログラム)の識別情報と、PC側記憶装置22に記憶されているプロジェクトデータ71(ユーザープログラム)の識別情報とを照合し、照合結果を警告部335に出力する。警告部335は、PLC1から出力される、運転記録を保存した時のプロジェクトデータ71(ユーザープログラム)の識別情報と、PC側記憶装置22に記憶されているプロジェクトデータ(ユーザープログラム)の識別情報とが不一致である場合に、警告を表示部7に表示させる。
Here, in this embodiment, it is possible to verify whether the current project data matches the
なお、本実施形態では、2つのプロジェクトデータの識別情報を比較して、一致・不一致を検証することとした。より詳細には、プロジェクトデータに含まれるプログラム構成、複数のプログラム部品、ユニット構成、ユニット毎に機能設定に対し、それぞれ識別情報が付加されており、それら全てが一致するか否かにより検証することとした。しかし、本発明はこれに限られず、少なくとも、複数のプログラム部品から構成されるユーザープログラムの識別情報を比較して、一致・不一致を検証すればよい。
●再生制御モジュール324
Note that in this embodiment, the identification information of two pieces of project data are compared to verify whether they match or do not match. More specifically, identification information is added to the program configuration, multiple program parts, unit configuration, and function settings for each unit included in the project data, and verification is performed by checking whether all of them match. And so. However, the present invention is not limited to this, and at least the identification information of user programs composed of a plurality of program parts may be compared to verify whether they match or do not match.
●
図31は再生制御モジュール324の詳細を示している。デバイス値提供部341は、ログデータ取得部344によりログデータ73から取得されたデバイス値をプログラム表示モジュール321と波形表示モジュール322とに提供する。また、デバイス値提供部341は、ユニット表示モジュール325にも、ログデータ73から取得されたデバイス値を提供する。なお、ログデータ73から取得されたデバイス値は一時的にログデバイス345に格納されてもよい。プログラム表示モジュール321と波形表示モジュール322のデバイス値取得部333aはデバイス値提供部341にデバイス値を要求する。デバイス値取得部333aはログデバイス345からデバイス値を取得し、デバイス値取得部333aに送信する。時刻デバイス342は再生制御部343により設定された表示時刻を保持するデバイスである。時刻デバイス342に保持されているデバイス値(時刻情報)もデバイス値提供部341がデバイス値取得部333aへ送信してもよい。あるいは、再生制御部343がプログラム表示モジュール321の表示時刻制御部331aや波形表示モジュール322の表示時刻制御部に時刻情報を提供してもよい。再生制御部343は、表示時刻を計時するための仮想的な内部時計を有し、この内部時計に従って時刻デバイス342に保持されている時刻情報を更新する。再生制御部343は、表示時刻制御部331a、波形表示モジュール322の表示時刻制御部に時刻デバイス342に保持されている時刻情報を送信する。再生制御部343は、表示時刻制御部331a、波形表示モジュール322の表示時刻制御部から表示時刻の指定を受信すると、受信した表示時刻を内部時計に設定する(時刻合わせ)。よって、プログラム表示モジュール321の表示時刻制御部331aから表示時刻が指定されると、この表示時刻は再生制御部343を介して波形表示モジュール322の表示時刻制御部に伝達される。同様に、波形表示モジュール322の表示時刻制御部から表示時刻が指定されると、この表示時刻は再生制御部343を介して表示時刻制御部331aに伝達される。これによりプログラム表示モジュール321の表示時刻と波形表示モジュール322の表示時刻とが同期する。スロー再生、早送り再生、巻き戻し再生等を実現するために、再生制御部343は、PC側操作部8からのユーザ入力に従って内部時計の更新速度を変更する。再生制御部343は、ログデータ73に含まれている最も古いレコードの時刻情報を内部時計の初期値に設定してもよい。ログデータ取得部344は時刻デバイス342に保持されている表示時刻に関連付けられているデバイス値をログデータ73から取得して、デバイス値提供部341に渡す。
FIG. 31 shows details of the
同様にして、再生制御部343は、プログラム表示モジュール321の表示時刻と波形表示モジュール322の表示時刻に加えて、画像表示モジュール323やユニット表示モジュール325の時刻を同期させるようにしてもよい。
Similarly, the
なお、本実施形態では、ログ再生モードにおいて、プログラム表示モジュール321、波形表示モジュール322、画像表示モジュール323、ユニット表示モジュール325の各表示時刻を常に同期させることとしたが、本発明はこれに限られず、例えば、同期させるか否かをユーザが選択できるようにしてもよい。例えば、各モニタ画面上に同期有無のチェックボックスを設け、デフォルトでチェック有の状態にしてもよい。そして、ユーザは、同期したくないモジュールについて、チェックを外すことにより、そのモジュールについてだけ同期させないことも可能である。このように、ログ表示制御部61は、再生制御モジュールによって同期制御(追従制御)されるモジュールを選択する、選択機能を有していてもよい。
<プログラムの表示UI>
In this embodiment, the display times of the
<Program display UI>
図32はプログラム表示モジュール321によって提供される表示UI400を示している。図9等で説明した表示UI400を別の観点から、更に詳述する。プログラム表示領域410は、プロジェクトデータ71のユーザープログラムを表示する領域である。この例ではプログラム表示領域410はラダープログラム(ラダー図)を表示している。プログラム表示部332は、ユーザープログラムに使用又は記述されているデバイスのデバイス値をデバイス値取得部333aにより取得し、ユーザープログラムと共に表示する。例えば、プログラム表示部332は、リレーデバイスがONであればONを示すアイコン401aをユーザープログラム上に重ねて表示してもよい。プログラム表示部332は、リレーデバイスがOFFであればOFFを示すアイコン401bをユーザープログラム上に重ねて表示してもよい。プログラム表示部332は、出力系のデバイスであるDM100のデバイス値をデバイス値取得部333aにより取得し、ユーザープログラムにおけるDM100の記述と重ねて表示してもよい。この例では、DM100の記述の下にデバイス値の表示領域403が設けられている。プログラム表示部332は表示領域403にデバイス値を表示する。なお、再生制御モジュール324は表示時刻の更新と共にデバイス値も更新するため、プログラム表示部332は、ユーザープログラムと共に表示されているデバイス値を更新する。
(再生制御欄402)
FIG. 32 shows a
(Playback control column 402)
プログラム表示領域410の下段には、保存されたデバイス値等のログデータの再生を操作するための再生制御欄402を設けている。具体的には、時刻UI330aは時刻デバイス342から取得した表示時刻に応じて時刻指定カーソル404を右から左へ移動させる。時刻指定カーソル404はポインタ101によりドラッグ可能である。時刻指定カーソル404がポインタ101によりドラッグされたことを時刻UI330aが検知すると、表示時刻制御部331aは再生制御部343に表示時刻の更新を停止させ、時刻指定カーソル404のドラッグ量を再生制御部343に通知する。再生制御部343は、ドラッグ量に応じて内部時計のカウント値(表示時刻)を調整する。時刻UI330aは、表示時刻の更新速度(例:・・・、2.0倍、1.0倍、0.5倍、0.1倍、・・・)を速度指定部405に表示してもよい。なお、速度指定部405は、複数の更新速度のリストを表示し、その内の一つの更新速度を選択可能なプルダウメニューによって実現されてもよい。時刻UI330aは、速度指定部405に対するポインタ101によるクリックを検知すると、このようなプルダウメニューを表示し、更新速度の選択を受け付けてもよい。
At the bottom of the
再生ボタン406はデバイス値の時系列的な表示を指示するためのボタンである。時刻UI330aは再生ボタン406がポインタ101によりクリックされたことを検知すると、表示時刻制御部331aに表示時刻の更新を開始するよう再生制御部343に指示する。この指示はデバイス値の表示の開始の指示又は表示の再開の指示に相当する。ワンステップ逆再生ボタン407は、表示時刻をワンステップずつ更新(巻き戻し)しながらデバイス値を時系列的に表示することを指示するためのボタンである。時刻UI330aはワンステップ逆再生ボタン407がポインタ101によりクリックされたことを検知すると、表示時刻制御部331aに表示時刻を一ステップ戻すように指示する。ワンステップ再生ボタン408は、表示時刻をワンステップずつ更新しながらデバイス値を時系列的に表示することを指示するためのボタンである。時刻UI330aはワンステップ再生ボタン408がポインタ101によりクリックされたことを検知すると、表示時刻制御部331aに表示時刻を一ステップ進めるように指示する。なお、ワンステップ再生が実行されているときは、ワンステップ逆再生ボタン407又はワンステップ再生ボタン408が操作されない限り、再生制御部343は表示時刻を更新しない。ワンステップ再生が実行されているときに、再生ボタン406が操作されると、再生制御部343は速度指定部405により指定された更新速度で表示時刻の更新を再開する。時刻表示領域409は時刻デバイス342に保持されている表示時刻を表示する領域である。表示時刻制御部331aは、時刻デバイス342から取得された表示時刻を時刻表示領域409に表示する。
<表示部HMIのエミュレータ>
A
<Display HMI emulator>
PLC1は外付けの表示装置である表示器HMIを接続可能である。表示器HMIはタッチパネル式の入力装置を有していてもよい。表示器HMIはPLC1のデバイス部34に保持されているデバイス値を読み出して表示装置に表示する。プロジェクト作成部50は表示器HMIに表示されるUIと、UIに表示されるデバイス値を設定し、プロジェクトデータ71に保存する。デバッグ部314は、表示器HMIのエミュータを有しており、プロジェクトデータ71に従ってエミュータを動作させることで、表示器HMIの動作を確認する。ログ表示制御部61は、表示器HMIのエミュレータに対してログデータ73のデバイス値を供給する。表示器HMIのエミュレータは、時系列的に提供されたデバイス値をUIに表示する。
<ログ表示に関するフローチャート>
●プログラム表示モジュール
The
<Flowchart regarding log display>
●Program display module
図33はプログラム表示モジュール321によって実行される表示処理を示している。なお、ステップS3301、ステップS3302及びステップS3309はPLC1からプロジェクトデータ71を取得できない場合にのみ実行されてもよい。PLC1からプロジェクトデータ71を取得できる場合、PLC1からプロジェクトデータ71が使用される。PLC1からプロジェクトデータ71を取得できない場合、PC2に保持されているプロジェクトデータ71が使用される。
FIG. 33 shows display processing executed by the
ステップS3301でPC側CPU21(照合部334)はPLC1に保持されているプロジェクトデータ71の識別情報と、PC2に保持されているプロジェクトデータ71の識別情報とを取得する。
In step S3301, the PC side CPU 21 (verification unit 334) acquires the identification information of the
ステップS3302でPC側CPU21(照合部334)はPLC1に保持されているプロジェクトデータ71の識別情報と、PC2に保持されているプロジェクトデータ71の識別情報とが一致するかどうかを判定する。両者が一致しなければ、PC側CPU21はステップS3309に進む。ステップS3309でPC側CPU21(警告部335)はPLC1に保持されているプロジェクトデータ71の識別情報と、PC2に保持されているプロジェクトデータ71の識別情報とが一致しないことを示す警告を表示部7に表示する。両者が一致する場合、PC側CPU21はステップS3303に進む。
In step S3302, the PC side CPU 21 (verification unit 334) determines whether the identification information of the
ステップS3303でPC側CPU21(プログラム表示部332)はPLC1又はPC側記憶装置22からプロジェクトデータ71を取得する。
In step S3303, the PC side CPU 21 (program display unit 332) acquires the
ステップS3304でPC側CPU21(プログラム表示部332)はPC側操作部8から入力された情報に基づきログ再生モードが選択されているのか、それともリアルタイム再生モードが選択されているのかを判定する。リアルタイム再生モードが選択されていれば、PC側CPU21はステップS3310に進む。ステップS3310でPC側CPU21(デバイス値取得部333a)は再生制御モジュール324を介さずにPLC1のリアルタイム送信部からデバイス値を取得する。ステップS3311でPC側CPU21(プログラム表示部332)はプロジェクトデータ71に含まれるユーザープログラムと共にデバイス値を表示部7に表示する。ログ再生モードが選択されていれば、PC側CPU21はステップS3305に進む。
In step S3304, the PC-side CPU 21 (program display section 332) determines whether the log playback mode or the real-time playback mode is selected based on the information input from the PC-
ステップS3305でPC側CPU21(デバイス値取得部333a)は再生制御モジュール324を起動し、再生制御モジュール324から表示時刻とログデータ73のデバイス値と取得する。
In step S3305, the PC side CPU 21 (device
ステップS3306でPC側CPU21(プログラム表示部332)はプロジェクトデータ71に含まれるユーザープログラムと共にデバイス値と表示時刻を表示部7に表示する。
In step S3306, the PC side CPU 21 (program display section 332) displays the user program included in the
ステップS3307でPC側CPU21(表示時刻制御部331a)は時刻UI330aにより時刻指定が検知されたかどうかを判定する。上述したように時刻指定は時刻指定カーソル404の操作によって実行される。時刻指定が検知されていなければ、PC側CPU21はステップS3305に戻る。時刻指定が検知されていれば、PC側CPU21はステップS3308に進む。
In step S3307, the PC-side CPU 21 (display
ステップS3308でPC側CPU21(表示時刻制御部331a)は再生制御モジュール324の再生制御部343に、時刻指定カーソル404により入力された指定時刻を通知する。PC側CPU21はステップS3305に戻る。
●波形表示モジュール
In step S3308, the PC side CPU 21 (display
●Waveform display module
図34は波形表示モジュール322によって実行される表示処理を示している。
FIG. 34 shows display processing performed by the
ステップS3401でPC側CPU21(波形表示部336)はPC側操作部8から入力された情報に基づきログ再生モードが選択されているのか、それともリアルタイム再生モードが選択されているのかを判定する。リアルタイム再生モードが選択されていれば、PC側CPU21はステップS3406に進む。ステップS3406でPC側CPU21(波形表示モジュール322のデバイス値取得部)は再生制御モジュール324を介さずにPLC1のリアルタイム送信部からデバイス値を取得する。ステップS3407でPC側CPU21(波形表示部336)はデバイス値を表示部7に表示する。ログ再生モードが選択されていれば、PC側CPU21はステップS3402に進む。
In step S3401, the PC-side CPU 21 (waveform display section 336) determines whether the log playback mode or the real-time playback mode is selected based on the information input from the PC-
ステップS3402でPC側CPU21(波形表示モジュール322のデバイス値取得部)は再生制御モジュール324を起動し、再生制御モジュール324からデバイス値と表示時刻を取得する。
In step S3402, the PC-side CPU 21 (device value acquisition unit of the waveform display module 322) starts the
ステップS3403でPC側CPU21(波形表示部336)はデバイス値と表示時刻を表示部7に表示する。
In step S3403, the PC side CPU 21 (waveform display section 336) displays the device value and display time on the
ステップS3404でPC側CPU21(波形表示モジュール322の表示時刻制御部)は時刻UI330bにより時刻指定が検知されたかどうかを判定する。上述したように時刻指定はバー103によって実行される。時刻指定が検知されていなければ、PC側CPU21はステップS3402に戻る。時刻指定が検知されていれば、PC側CPU21はステップS3405に進む。
In step S3404, the PC-side CPU 21 (display time control unit of the waveform display module 322) determines whether time designation is detected by the time UI 330b. As described above, the time specification is performed using the bar 103. If the time designation is not detected, the PC-
ステップS3405でPC側CPU21(波形表示モジュール322の表示時刻制御部)は再生制御モジュール324の再生制御部343に、バー103により入力された指定時刻を通知する。PC側CPU21はステップS3402に戻る。
●再生制御モジュール
In step S3405, the PC-side CPU 21 (display time control unit of the waveform display module 322) notifies the
●Reproduction control module
図35は再生制御モジュール324によって実行される再生制御を示している。
FIG. 35 shows the playback control performed by the
ステップS3501でPC側CPU21(ログデータ取得部344)はPLC1からログデータ73を取得し、PC側記憶装置22に格納する。
In step S3501, the PC side CPU 21 (log data acquisition unit 344) acquires the
ステップS3502でPC側CPU21(再生制御部343)は内部時計の時刻を初期化する。 In step S3502, the PC side CPU 21 (playback control unit 343) initializes the time of the internal clock.
ステップS3503でPC側CPU21(再生制御部343)は内部時計の時刻を取得し、時刻を時刻デバイス342に格納する。
In step S3503, the PC side CPU 21 (playback control unit 343) obtains the time of the internal clock and stores the time in the
ステップS3504でPC側CPU21(再生制御部343)は時刻デバイス342に保持されている表示時刻に対応するデバイス値をログデータ73から取得し、ログデバイス345に格納する。これにより、デバイス値提供部341はプログラム表示モジュール321や波形表示モジュール322に対してデバイス値と表示時刻とを提供可能となる。
In step S3504, the PC side CPU 21 (playback control unit 343) obtains the device value corresponding to the display time held in the
ステップS3505でPC側CPU21(再生制御部343)は表示時刻制御部331aから時刻指定を受信したかどうかを判定する。時刻指定を受信していれば、PC側CPU21はステップS3506に進む。時刻指定を受信していなければ、PC側CPU21はステップS3507に進む。
In step S3505, the PC side CPU 21 (playback control unit 343) determines whether or not a time designation has been received from the display
ステップS3506でPC側CPU21(再生制御部343)は表示時刻制御部331aからの時刻指定に従って内部時計の時刻を変更する。
In step S3506, the PC side CPU 21 (playback control section 343) changes the time of the internal clock according to the time specification from the display
ステップS3507でPC側CPU21(再生制御部343)は表示時刻制御部331aから更新速度の変更指示を受信したかどうかを判定する。変更指示を受信していれば、PC側CPU21はステップS3508に進む。変更指示を受信していなければ、PC側CPU21はステップS3503に進む。
In step S3507, the PC side CPU 21 (playback control unit 343) determines whether an instruction to change the update speed has been received from the display
ステップS3508でPC側CPU21(再生制御部343)は表示時刻制御部331aから指定された更新速度に従って内部時計の更新速度を変更する。その後、PC側CPU21はステップS3503に進む。
(イベント履歴表示機能)
In step S3508, the PC side CPU 21 (playback control section 343) changes the update speed of the internal clock according to the update speed specified by the display
(Event history display function)
また本実施形態に係るPLC用エンジニアリングツールは、トラブル解決につながるイベントログを厳選して記録し、表示させることができる。PLCやその拡張ユニット4には、発生した各種イベントを記録するイベントログ機能が存在している。また、デバイスの値を、制御周期毎、任意周期、書き換え毎等のタイミングで記録するロギング機能も存在している。ユーザはトラブルが発生した時に、それらの機能を組み合わせることにより、事後的に原因を探ることができる。しかしながら、各種のログ機能は、PLC上の不揮発性記憶領域に主に記録されることが多く、このようなPLCの不揮発性記憶領域は、サイズに制約があることが多い。また、ログの件数が増えて記憶領域が上限に達すると、新しいログを残すため古いログから順次消去していくことが一般的である。このため、発生しているログが数千件や数万件のオーダーになると、トラブル解決に繋がる原因のログが消去されている可能性が高くなり、トラブルの原因追跡が難しくなるという問題があった。これに対して、記録時間を延ばすためユーザが保存対象となるイベントを絞り込むと、今度はトラブル解決に役立つイベントを保存し損なうおそれが出てくる。また一方で、記録が消去されず残っていたとしても、表示される件数が多いとトラブル解決に繋がるイベントが他のイベントに埋もれてしまい、見つけ難くなる。
Furthermore, the PLC engineering tool according to the present embodiment can carefully select and record event logs that can lead to troubleshooting, and display the logs. The PLC and its
そこで本実施形態に係るPLC用エンジニアリングツールでは、トラブル解決に繋がるイベントを厳選して記録する。またその厳選して記録されたイベントを表示する際には、フィルタして表示したり、関連するログ情報を表示したりすることができ、これによってユーザのトラブル解決を容易にすることが可能となる。このようなPLC用エンジニアリングツールの一例を、図36のブロック図に示す。 Therefore, the PLC engineering tool according to the present embodiment carefully selects and records events that lead to troubleshooting. In addition, when displaying the carefully selected recorded events, it is possible to filter them and display related log information, making it easier for users to troubleshoot problems. Become. An example of such a PLC engineering tool is shown in the block diagram of FIG. 36.
PLC用エンジニアリングツールは、PLC1の動作を規定するユーザープログラムを評価するためのツールである。図36は、PLC用エンジニアリングツールである専用のプログラムをインストールしたPC2に、PLC1を接続したプログラマブルロジックコントローラシステムを示している。このPLC用エンジニアリングツールは、専用プログラムをインストールしたPC2で実現しているが、本発明はPLC用エンジニアリングツールを専用プログラムをインストールしたPCに限定するものでなく、専用のハードウェアでPLC用エンジニアリングツールを実現してもよい。また図36の例では、PC2とPLC1が別体で構成されているが、これらを統合してもよい。
The PLC engineering tool is a tool for evaluating a user program that defines the operation of the
図36に示すPLC1も、上述したPLCと同様の構成を備える。すなわち、ユーザープログラムを繰り返し実行するプログラム実行部514、このプログラム実行部514によって参照される記憶領域であるデバイスを有するデバイス部34、このデバイス部34に記憶されているデバイス値を現在時刻と共にログデータとして時系列に記録すると共に、PLC1又はこのPLC1により制御される被制御装置にて発生した複数のイベントを発生時刻と共にイベントデータとして時系列に記録する一時記録部91a、及び運転時において所定の保存条件が満たされるとこの一時記録部91aに記録されているログデータ及びイベントデータを保存する保存メモリ36を備える。そしてPLC用エンジニアリングツールは、このPLC1において実行される、グラフィカルプログラミング言語で記述されるユーザープログラムの作成を支援するためのプログラム作成支援装置である。
The
図36に示すPLC用エンジニアリングツールは、表示部7と、PC側CPU21と、PC側記憶装置22と、PC側メモリ部11と、PC側操作部8と、PC側通信部23とを備えている。表示部7は、ラダー図などのユーザープログラムを表示させる。また表示部7は、PC2に接続したモニタとする他、表示器HMIを利用してもよい。
The PLC engineering tool shown in FIG. 36 includes a
PC側記憶装置22は、運転記録データ保持部22bの機能を実現する。運転記録データ保持部22bは、PLC1の運転時に保存メモリ36に保存されたログデータ及びイベントデータを、運転記録データとして記憶する。
The PC
PC側CPU21は、記録設定部12と、デバイス表示制御部13と、イベント表示制御部14と、選択受付部16の機能を実現する。イベント表示制御部14は、運転記録データ保持部22bから読み出したイベントデータに含まれる複数のイベント及びこの複数のイベントの各々の発生時刻を、表示部7に一覧表示する。選択受付部16は、イベント表示制御部14により一覧表示された複数のイベントの中から一つの選択を受け付ける。デバイス表示制御部13は、運転記録データ保持部22bから読み出したログデータに含まれ、かつ、選択受付部16により選択されたイベントの発生時刻に対応する時刻に記録されたデバイス値を、ユーザープログラム上に重ねて表示する。イベント表示制御部14は、PLC1の動作状態又はこのPLC1により制御される被制御装置の動作状態を変更する特定イベントを、表示部7上に選択的に一覧表示するよう構成している。
The PC-
また記録設定部12は、PLC1の一時記録部91aに対し、複数のイベントのうち特定イベントのみを記録するよう設定する。
The
ここで特定イベントは、プログラム実行部514によるユーザープログラムの実行と独立してユーザが行った操作に関するイベントを含む。ユーザ操作に関するイベントとしては、例えばユーザープログラム及びPLC1の構成情報を含むプロジェクトデータの書き換え、PLC1の設定を行う設定モードと、PLC1上でユーザープログラムを実行させる運転モードとのモード切替、PLC1に接続可能なケーブルの挿抜、PLC1に取り付け可能な記憶媒体の挿抜、被制御装置の電源のON/OFF等が挙げられる。
Here, the specific event includes an event related to an operation performed by the user independently of execution of the user program by the
一方でイベント表示制御部14は、プログラム実行部514によるユーザープログラムの実行に従って、PLC1内で自動的に実行される処理に応じたイベントを非表示とする。このような自動実行される処理に応じたイベントとしては、例えばPLC1と接続された外部装置とTCP接続又はFTP接続するときの通信開始又は通信切断や、PLC1内に用意されたフォルダ又はファイルへの書き込み等が挙げられる。このように、イベント表示制御部14でもって、ユーザが介在したユーザ操作に応じたイベントは、トラブル解決に役立つので表示させる。その一方で、ユーザが介在しなくても自動的に実行される処理に応じたイベントについては非表示としている。非表示とする理由は、自動実行される処理は頻度が多すぎるのでログとして残すと膨大になる上、内部処理であるためイベントログを参照したところで、これに基づいてどのようにすればトラブル解決につながるのかが判り難いため、これらがトラブル解決に有用な場面は少ないと思われないからである。このように、イベントの表示内容を、トラブル解決に有用と思われるものと、そうでないものに分類して、選択的に表示部7に表示させることで、ユーザによるトラブルシューティングを支援することが期待できる。
On the other hand, the event
以下、図36に基づき各部材の詳細を説明する。記録設定部12は、運転記録データ等各種のデータをPLC側記憶装置32に保存させるよう設定する。PLC側記憶装置32に保存されるデータとしては、PLC1の運用時に、PLC1で記録された時系列の複数のデバイス値、各デバイス値の記録時刻に応じた第一時刻データ、PLC1又はPLC1により制御される被制御装置にて発生した複数のイベント、各イベントの発生時刻に応じた第二時刻データ等が挙げられる。PLC側記憶装置32は、PLC1内部の書き換え可能な不揮発性メモリや、挿抜可能なSDカード(商品名)等が利用できる。特にSDカードは、データの移行が簡単なため、好ましい。例えばPC2をPLC1に接続していなくとも、PLC側記憶装置32に保存されたデータにアクセスすることが可能となる。
Hereinafter, details of each member will be explained based on FIG. 36. The
デバイス表示制御部13は、表示部7で表示させたラダー図上に、デバイス値を表示する。イベント表示制御部14は、表示部7上に複数のイベントを一覧表示する。この際イベント表示制御部14は、PLC1の動作状態又はPLC1により制御されるモータ等の被制御装置の動作状況を変更する特定イベントを、選択的に表示させることができる。
The device
図36に示すPLC用エンジニアリングツールでPLC用の設定を行った後、プロジェクトデータをPLC側に転送する。具体的には、PC側通信部23から、PLC1のPLC側通信部33に、記録すべきイベントやその優先順位を規定したプロジェクトデータを転送する。またプロジェクトデータには、運転記録データに関する設定や、ユーザープログラム、各機能の設定などを含めてもよい。
(表示部7)
After making settings for the PLC using the PLC engineering tool shown in FIG. 36, the project data is transferred to the PLC side. Specifically, project data defining events to be recorded and their priorities is transferred from the PC-
(Display section 7)
表示部7は、ラダー図等を表示させる。具体的には表示部7は、イベントを一覧表示させるイベント表示欄1400と、ラダー図を表示させるラダーモニタ欄1500を備えることができる。そしてイベント表示欄1400で、ユーザが選択受付部16を用いて、ここではPC側操作部8を操作してGUI上から任意のイベントを選択すると、この選択されたイベントの時刻と対応するラダー図がラダーモニタ欄1500で選択されて表示される。
The
また表示部7は、さらにカメラモニタ欄1600を備えてもよい。カメラモニタ欄1600は、プログラマブルロジックコントローラシステムに接続されたカメラ部98で時系列に撮像された複数の画像データを表示させる。そしてイベント表示欄1400で、任意のイベントを選択すると、この選択されたイベントの時刻と対応するラダー図がラダーモニタ欄1500で選択されると共に、選択されたイベントの時刻と対応する画像データがカメラモニタ欄1600に表示される。
Further, the
PLC1は、PLC側CPUと、PLC側記憶装置32と、PLC側通信部33を備える。PLC側記憶装置32には、上述の通り記録設定部12での設定に従い、PLC1にて記録された時系列の複数のデバイス値、各デバイス値の記録時刻に応じた第一時刻データ、PLC1又はPLC1により制御される被制御装置にて発生した複数のイベント、各イベントの発生時刻に応じた第二時刻データ等が保存される。
The
複数のデバイス値とイベントとは、PLC側記憶装置32に分けて記録される。デバイス値もイベントも、ある程度収集した後は、古いデータを削除していくが、好ましくはイベントをデバイス値よりも長い時間残す。トラブルの原因が、直近のイベントのみならず、過去の変更に起因することが起こり得ることに対応させたものである。また、これらデバイス値の第一時刻データと特定イベントの第二時刻データも保存することで、これらを同期させることが可能となる(詳細は後述)。
A plurality of device values and events are recorded separately in the PLC
ここでイベント表示制御部14は、PLC1の動作状態又はPLC1により制御される被制御装置の動作状態を変更する特定イベントを、選択的に表示部7上に表示させる。例えばプログラマブルロジックコントローラ用エンジニアリングツールは、トラブル解決に繋がる厳選されたイベントをPLC側記憶装置32に記録すると共に、これを表示させる際には、それらのイベントのみをフィルタ表示させてもよい。これにより、多種多様なイベントの内から、トラブル解決に有用なイベントを選択的に表示させて、トラブルの原因究明に役立てることができる。またこのイベント表示制御部14は、デバイス値を時系列波形として表示部7に表示させることができる。
Here, the event
またPLC用エンジニアリングツールは、同期ソフトウエアモジュール15を備えてもよい。同期ソフトウエアモジュール15は、デバイス表示制御部13における表示対象時刻である第一時刻データと、イベント表示制御部14における表示対象時刻である第二時刻データとを同期させて、表示部7において連動させて表示させることができる。
The PLC engineering tool may also include a
あるいは、すべてのイベントを記録する他、イベントの内から選別した特定イベントのみをPLC側記憶装置32に記録するよう構成してもよい。例えば記録設定部12で、特定イベントのみをPLC側記憶装置32に記録させるように設定できる。これにより、トラブルシューティングに有用な特定イベントのみを記憶装置に記憶させて、これを表示部7に表示させることで、検索や絞り込みなどを行わずともトラブルシューティングに無関係なイベントに埋もれてしまう事態を回避できる。この場合、デバイス値については運転記録データとしてすべて記録しつつ、イベントについては、PLC1の動作状態又はPLC1により制御されるモータ等の被制御装置の動作状態を変更する特定イベントのみを記録している。これにより、選別した特定イベントのみをイベント表示欄1400に選択的に表示させることが可能となる。また特定イベントを、別途記録されたデバイス値と同期させることで、トラブル解析に有益となる。さらに選択的に表示される特定イベントは、優先順位付けしてもよい。
(特定イベント)
Alternatively, instead of recording all events, only specific events selected from among the events may be recorded in the
(Specific event)
表示部7に表示させる特定イベントには、PLC1のユーザープログラム及び各ユニットのユニット構成情報を含むプロジェクトデータの書き換え、被制御装置の電源のON/OFF、プログラマブルロジックコントローラの設定を行う設定モード又はプログラマブルロジックコントローラを実行させる運転モードのモード切替、各種履歴のクリア、記憶装置の挿抜、他の機器と通信を行うイーサネットケーブルの挿抜、PLCシステムに接続される表示器HMIから要求されるデバイス書換信号、あるいはPLCシステムに接続されるモーションユニットのモーションエラー等が挙げられる。例えばモード切替は、PLC1の設定時の動作モードであるPROGRAMモードと、実運用時のRUNモードの切り替えを行ったタイミングを示している。また表示器HMIからのデバイス書換信号は、トラブル発生時に、予め定められた復旧手順に沿って操作したか否かを確認したい場合に、有用となる。
(イベントログの記録動作)
Specific events to be displayed on the
(Event log recording operation)
ここで、イベントログの記録動作を、プログラマブルロジックコントローラシステムの機能ブロック図である図37に基づいて説明する。この図に示すプログラマブルロジックコントローラシステムは、CPUユニット3と拡張ユニット4を備える。
(CPUユニット3)
Here, the event log recording operation will be explained based on FIG. 37, which is a functional block diagram of the programmable logic controller system. The programmable logic controller system shown in this figure includes a
(CPU unit 3)
CPUユニット3は、PLC側CPU31と、PLC側時刻管理部83と、イベント管理部76と、イベントログメモリ部75と、ログメモリ部73Bと、デバイスメモリ部34Bを備える。PLC側CPU31は、ユーザープログラムの実行や拡張ユニット4とのデータ交換、データ収集処理等を行う。
(PLC側時刻管理部83)
The
(PLC side time management section 83)
PLC側時刻管理部83は、イベントやログデータの記録時の時刻を管理するための部材である。
(デバイスメモリ部34B)
The PLC-side
(
デバイスメモリ部34Bは、プログラムや各機能で使用する値が格納されているデバイスが配置されているメモリである。デバイスメモリ部34Bは、通信からのデバイス書換に関してもイベントとして記録可能である。検知はPLC側CPU31で行う。
(イベント管理部76)
The
(Event management department 76)
イベント管理部76は、発生したイベントをイベントログメモリ部75に記録する。このイベント管理部76は、PLC1のスキャン動作とは非同期に、PLC側CPU31から発行されたイベントを受け取り、イベントログに保存する。すなわちPLC1のEND処理の繰り返し周期とは独立して、任意のタイミングでイベントログの記録を行うことができる。またイベント管理部76は、複数のイベントが同時に発生した場合の調停や、イベントログメモリ部75のメモリ容量がフルになった場合に古いデータから順次消去する制御等も行う。
(イベントログメモリ部75)
The
(Event log memory section 75)
イベントログメモリ部75は、発生したイベントを格納するメモリである。イベントログメモリ部75には、第二時刻データと共にイベントが格納されている。
(ログメモリ部73B)
The event
(
ログメモリ部73Bは、収集したデータを格納するメモリである。これらイベントログメモリ部75やログメモリ部73Bは、共通のμsオーダの時刻データを有しており、表示時にスキャンレベルで連動させることが可能である。このためログメモリ部73Bは、スキャン動作と同期して、スキャン動作の一部として収集したデータを記録する。またログデータの記録時には、第一時刻データと共に記録する。
(拡張ユニット4)
The
(Expansion unit 4)
拡張ユニット4は、カメラ部98やモーションユニットなどの被制御装置を接続する、一以上のユニットである。各拡張ユニット4は、バッファメモリ部77と、機能実行部96を備える。バッファメモリ部77は、拡張ユニット4の機能を制御するための値やモニタ値が格納されているメモリである。機能実行部96は、拡張ユニット4の機能を実行している。また機能実行部96は、拡張バス-CPUユニット制御部と情報を伝達する。例えばPLC側CPU31からの要求を受けて、又は自動的に動作して、状態や結果をバッファメモリ部77に格納する。一例として、モーション系の拡張ユニットの場合は、ワークが装置のリミットに達した等モーション系のエラーが発生した場合、それを機能実行部96が検出する。また、拡張ユニット4側からイベントを発行することも可能である。
(イベントログ記録動作のフローチャート(CPUユニット3で発生するイベントの場合))
The
(Flowchart of event log recording operation (for events occurring in CPU unit 3))
図37のプログラマブルロジックコントローラシステムにおいて、イベントログを記録する動作は、CPUユニット3側で発生するイベントに対して行うことも、拡張ユニット4側で発生するイベントに対して行うこともできる。
In the programmable logic controller system of FIG. 37, the operation of recording an event log can be performed for events occurring on the
次に、CPUユニット3で発生するイベントを記録する動作を、図38のフローチャートに基づいて説明する。まずステップS3801において、CPUユニット3のPLC側CPU31がイベントを検出する。次にステップS3802において、イベント管理部76が、CPUユニット3のPLC側CPU31からイベントを受け取る。そしてステップS3803において、イベントログメモリ部75の残容量を確認する。残容量がない場合は、ステップS3804に進み、古いイベントをイベントログメモリ部75から削除する。一方、残容量がある場合はステップS3805に進み、μsオーダの時刻データを取得して、イベントログメモリ部75にイベントを格納する。
Next, the operation of recording events occurring in the
次に、拡張ユニット4で発生するイベントを記録する動作を、図39のフローチャートに基づいて説明する。まずステップS3901において、拡張ユニット4の機能実行部96がイベントを検出する。次にステップS3902において、拡張ユニット4の機能実行部96が、イベントを入れたメッセージ通信を、拡張バスに送信する。さらにステップS3903において、CPUユニット3のPLC側CPU31が割り込み処理を用いて、イベントを入れたメッセージ通信を、拡張バスから受信する。次いでステップS3904において、CPUユニット3のPLC側CPU31が、メッセージ通信からイベントを取り出す。さらにステップS3905において、イベント管理部76が、CPUユニット3のPLC側CPU31からイベントを受け取る。そしてステップS3906において、イベントログメモリ部75の残容量を確認する。ここで残容量がない場合はステップS3907において、古いイベントをイベントログメモリ部75から削除した上で、ステップS3908に進む。一方、ステップS3906において残容量がある場合は、ステップS3908に進んで、μsオーダの時刻データを取得して、イベントログにイベントを格納する。
Next, the operation of recording events occurring in the
次に、イベントログ表示時のフィルタ動作を、図40のフローチャートに基づいて説明する。まずステップS4001において、イベントログ全件をメモリに読み込む。次にステップS4002において、イベント表示時にフィルタしたい、イベントのグループをUIで選択する。さらにステップS4003において、イベントログから1件、イベントを取り出す。そしてステップS4004において、取り出したイベントが、UIで選択したイベントに該当している場合、表示用イベントログに格納する。さらにステップS4005において、イベントログメモリ部75にイベントが残っているか否かを判定し、残っている場合はステップS4003に戻って処理を繰り返す。一方、残っていない場合はステップS4006に進み、表示用イベントログをGUIに全件表示する。
(選択的に表示するイベントの例)
Next, the filtering operation when displaying the event log will be explained based on the flowchart of FIG. 40. First, in step S4001, all event logs are read into memory. Next, in step S4002, a group of events to be filtered when displaying events is selected using the UI. Furthermore, in step S4003, one event is extracted from the event log. In step S4004, if the extracted event corresponds to the event selected on the UI, it is stored in the display event log. Furthermore, in step S4005, it is determined whether or not there are any events left in the event
(Example of events to be selectively displayed)
選択的に表示するイベントの例を、以下に示す。まず重度エラーは、PLC1が運転を継続できない重篤なエラーである。重度エラーの検出主体は、CPUユニット3(制御部・周辺制御)である。
Examples of events that are selectively displayed are shown below. First, a severe error is a serious error that prevents the
また軽度エラーは、PLC1が運転を継続できる軽微なエラーである。ただし軽度エラーは、トラブルの解決に繋がらない可能性もある。経度エラーの検出主体は、CPUユニット3(制御部・周辺制御)や拡張ユニット4である。
Moreover, a minor error is a minor error that allows the
電源ON/OFFは、電源の投入と遮断についてのイベントである。トラブルの周辺で発生することがある。電源ON/OFFの検出主体は、CPUユニット3(周辺制御)である。 Power ON/OFF is an event related to power on and off. It may occur around trouble. The main body for detecting power ON/OFF is the CPU unit 3 (peripheral control).
アラームリレーは、ユーザが指定したアラーム履歴である。アラームリレーの検出主体は、CPUユニット3(PLC側CPU31)である。 Alarm relay is a user-specified alarm history. The main body that detects the alarm relay is the CPU unit 3 (PLC side CPU 31).
デバイス値変更は、通信によるデバイス値の書き換えである。装置によってはトラブルに関係なく発生するが、トラブルの起点となることもある。このデバイス値変更の検出主体は、CPUユニット3(PLC側CPU31)である。 Device value modification is rewriting of device values through communication. Depending on the device, this may occur regardless of the problem, but it may also be the starting point of the problem. The main body that detects this device value change is the CPU unit 3 (PLC side CPU 31).
運転記録保存は、運転記録データの保存トリガのタイミングや記録に関する。この運転記録データも、トラブル解析の起点となり得る。運転記録保存の検出主体は、CPUユニット3(PLC側CPU31)である。 Driving record storage relates to the timing of a storage trigger and recording of driving record data. This driving record data can also serve as a starting point for trouble analysis. The main body that detects the storage of driving records is the CPU unit 3 (PLC side CPU 31).
RUN/PROGRAMの切換は、PLC1の運転モードの切り替えに関する情報である。モード切換の際にトラブルが起きることもあるが、通常運用時にも普通に発生する。RUN/PROGRAMの切換の検出主体は、CPUユニット3(PLC側CPU31)である。 The RUN/PROGRAM switching is information related to switching the operation mode of the PLC1. Trouble may occur when switching modes, but it also occurs during normal operation. The main body that detects the RUN/PROGRAM switching is the CPU unit 3 (PLC side CPU 31).
プロジェクト変更は、例えばPLC1のプログラム変更がきっかけとなり、トラブルが発生することが多いため、トラブル解析に有益と考えられる。プロジェクト変更の検出主体は、CPUユニット3(PLC側CPU31)である。
Project changes are considered useful for trouble analysis because troubles often occur due to changes in the program of the
履歴クリアも、トラブルを解決するための判断材料になる。特に、これがいつ消去されたかは重要な要素となり得る。履歴クリアの検出主体も、CPUユニット3(イベント管理部76)である。 Clearing the history can also be used as a basis for determining troubleshooting. In particular, when it was deleted can be an important factor. The CPU unit 3 (event management section 76) also detects the history clearing.
メモリカードは、その挿抜等がトラブル解決の鍵となることがある。その反面、装置の運用方法によってはトラブルが発生していなくても日々イベントが発生することもある。メモリカードの検出主体は、CPUユニット3(周辺制御)である。 Inserting and removing a memory card may be the key to solving problems. On the other hand, depending on how the device is operated, events may occur every day even when no trouble occurs. The main body for detecting the memory card is the CPU unit 3 (peripheral control).
カレンダタイマは、履歴データを元にトラブル解決の解析をするため、このカレンダタイマ値の変更を記録することが重要な場合があるため、候補に挙げられる。反面、時刻の自動調整をするような運営をしている場合は、定期的にイベントが発生する。カレンダタイマの検出主体は、CPUユニット3(周辺制御)である。 The calendar timer is a candidate because it may be important to record changes in the calendar timer value in order to analyze troubleshooting based on historical data. On the other hand, if you operate a system that automatically adjusts the time, events will occur periodically. The detection main body of the calendar timer is the CPU unit 3 (peripheral control).
イーサネット通信は、イーサネットのハードウェアレベルの接続イベントは、接触不良等の障害の予兆として発生することがあるため、候補に挙げられる。ただ、電源ON/OFFのタイミングでも日々発生する。イーサネット通信の検出主体は、CPUユニット3(周辺制御)や拡張ユニット4である。
Ethernet communication is a candidate because connection events at the Ethernet hardware level may occur as a sign of a failure such as a poor contact. However, it occurs every day even when the power is turned on and off. The main body that detects Ethernet communication is the CPU unit 3 (peripheral control) and the
シリアル通信は、シリアルのハードウェアレベルの接続が、接触不良等の障害の予兆として発生することがあるため、有益と考えられる。シリアル通信の検出主体は、拡張ユニット4である。
Serial communication is considered beneficial because serial hardware-level connections can be a sign of failure, such as poor contact. The main body that detects serial communication is the
イベントエラーは、イベントが大量に発生した場合のエラーである。イベントエラーの検出主体は、CPUユニット3(イベント管理部76)である。 An event error is an error that occurs when a large number of events occur. The main body that detects event errors is the CPU unit 3 (event management section 76).
このようなトラブルに対する考察に記述している通り、イベントの種類によってはマスクしたくなる場合もあるし、マスクせず表示したい場合もある。つまり、ユーザの装置の運用方法次第でマスクの必要性が変化する。そこで、ユーザにグループ毎に表示を選択させることを可能とした。 As described in the discussion on such problems, depending on the type of event, there are times when you want to mask it, and there are times when you want to display it without masking it. In other words, the necessity of a mask changes depending on how the user operates the device. Therefore, we made it possible for the user to select the display for each group.
イベントの選定に際しては、例えば図41に示すエラーイベント履歴フィルタ設定部1370で、グループ毎に個別に表示のフィルタリング設定を行うことができる。ここでは、表示される候補となるエラーやイベント中から、非表示とするエラーやイベントを選択する。この例では、画面左側に表示対象のイベントを表示一覧1371に、右側に非表示とするイベントを非表示一覧1372に、それぞれ列挙しており、イベント毎に自由に移動させることで表示か非表示かを選択できる。
(イベントとして記録しているが、敢えて表示しないイベントの例)
When selecting an event, display filtering settings can be made individually for each group, for example, in the error event history filter setting section 1370 shown in FIG. Here, you select an error or event to hide from among the displayed candidate errors or events. In this example, events to be displayed are listed on the left side of the screen in a display list 1371, and events to be hidden are listed on the right side in a hidden list 1372, and each event can be displayed or hidden by moving freely. You can choose which.
(Example of an event that is recorded as an event but not displayed)
次に、イベントとして記録しているが、敢えて表示していないイベントの例を説明する。これらは、ユーザに公開しても、ユーザでのトラブルの公開に直結しないイベントである。 Next, an example of an event that is recorded as an event but intentionally not displayed will be explained. These are events that, even if disclosed to the user, do not directly lead to disclosure of troubles by the user.
まず、PLC1上でのプログラムのコンパイルエラー発生時の詳細情報は、ユーザに公開しても、対処方法を示すことが難しいため表示しない。
First, detailed information when a program compilation error occurs on the
ファームウェアアップデート情報は、ファームウェアの更新により記録フォーマットが変化する可能性があり、継続して記録を残せない可能性があるため、表示しない。 Firmware update information is not displayed because the recording format may change due to firmware updates and it may not be possible to continue recording.
自己テストの実施履歴は、ユーザに公開しても、対処方法を示すことが難しいため表示していない。
(敢えて記録していないイベントのリスト(優先度高))
The self-test implementation history is not displayed because it is difficult to show users how to deal with it even if it is made public.
(List of events that are intentionally not recorded (high priority))
次に、敢えて記録していないイベントの内で、優先度の高いものの例を以下に示す。まずユーザープログラムの組み方によっては、件数が多すぎて簡単にログが溢れるため、記録から除外しているものとして、TCP接続の交信開始/終了がある。これは通信毎に交信を切断するシステムの場合、1秒に複数回のオーダーでイベントが発生する可能性がある。 Next, examples of events with high priority among the events that are intentionally not recorded are shown below. First, depending on how the user program is configured, the number of events can easily overflow the log, so the start/end of TCP connection communication is excluded from the record. In the case of a system that disconnects communication after each communication, events may occur on the order of multiple times per second.
またFTP接続開始/切断は、データを1件収集する毎に、上位にファイルをアップデートするような使い方の場合、イベント件数が増加する。 Furthermore, when starting/disconnecting an FTP connection, the number of events will increase if the FTP connection is used in such a way that a file is updated to a higher level every time one piece of data is collected.
さらにフォルダ/ファイルの書込みは、データを1件収集する毎に、メモリカードに記録するような使い方の場合、イベント件数が増加する。 Furthermore, when writing to a folder/file, the number of events increases if data is recorded on a memory card each time data is collected.
次に、システムの運用時には発生する可能性が低く、トラブル解決に繋がらない可能性があるため、記録から除外するイベントの例を説明する。まず、リモート操作要求受付は、運用時ではなく、装置のプログラミング時や立ち上げ時やデバッグ時に使用する可能性が高い機能であるのため、記録から除外する。また、強制値リフレッシュのセット、強制値リフレッシュのリセット、強制値リフレッシュの全解除、強制値リフレッシュの解除等は、いずれも運用時ではなく、装置のデバッグ時やトラブル発生後の解析に使用する可能性が高い機能のため、記録から除外する。
(敢えて記録していないイベントの例(優先度低))
Next, we will explain examples of events that are excluded from recording because they are unlikely to occur during system operation and may not lead to troubleshooting. First, remote operation request reception is excluded from the record because it is a function that is likely to be used not during operation but during device programming, startup, and debugging. In addition, setting forced value refresh, resetting forced value refresh, canceling all forced value refresh, canceling forced value refresh, etc. can all be used not during operation, but when debugging the device or analyzing after a problem occurs. This function is highly sensitive, so it will be excluded from recording.
(Example of an event that is intentionally not recorded (low priority))
さらに敢えて記録していないイベントの内、優先度の低いものの例を、説明する。まず、レシピ実行操作は、システムの組み方次第では、ワーク1件毎にイベントが発生して簡単にログ容量が溢れる可能性がある。 Furthermore, an example of a low priority event that is intentionally not recorded will be explained. First, depending on how the system is set up, recipe execution operations can cause an event to occur for each work, easily overflowing the log capacity.
またDB接続サービス開始、DB接続サービス停止、DB接続サービス終了は、いずれも運用時に頻繁に発生するイベントになり、簡単にログ容量が溢れる可能性がある。 Furthermore, the start of the DB connection service, the stop of the DB connection service, and the end of the DB connection service are all events that occur frequently during operation, and the log capacity may easily overflow.
またユーザ認証有効/無効、ログオン成功、ログオン失敗、CPUユニットのバックアップ成功、CPUユニットのバックアップ失敗、CPUユニットのリストア成功、CPUユニットのリストア失敗等は、いずれも運用時ではなく、装置のプログラミング時や立ち上げ時やデバッグ時に使用する可能性が高い機能である。 In addition, user authentication enable/disable, logon success, logon failure, CPU unit backup success, CPU unit backup failure, CPU unit restore success, CPU unit restore failure, etc. all occur during device programming, not during operation. This is a function that is likely to be used when starting up or debugging.
ここで、デバイス表示制御部13とイベント表示制御部14で特定イベントを選択的に表示部7上に表示させる様子を、図42のPLC用エンジニアリングツール1380のGUI画面に基づいて説明する。この図に示すPLC用エンジニアリングツール1380は、プロジェクトデータ編集プログラム、あるいはプログラム表示モジュール321によって提供される表示UIを示している。このプロジェクトデータ編集プログラムは、モード選択部50Dでログ再生モード(リプレイモード)が選択されており、編集が禁止されたプロジェクトデータ再生プログラムとして機能する。なお、編集機能を有しないプロジェクトデータの再生のみを行うプロジェクトデータ再生プログラムも、PLC用エンジニアリングツールの一種に包含される。
Here, how the device
このプロジェクトデータ編集プログラムは、左側にプロジェクト表示領域420、中央にプログラム表示領域410、右側にイベント表示欄1400を、それぞれ設けている。またプログラム表示領域410は、上段にラダーモニタ欄1500を、下段に再生制御欄402を、それぞれ設けている。ラダーモニタ欄1500ではラダープログラム(ラダー図)を表示している。
(再生制御欄402)
This project data editing program has a
(Playback control column 402)
再生制御欄402では、イベント表示欄1400等で選択されたイベントを再生するための再生制御を行う。具体的には、図31の再生制御モジュール324の機能によって、選択されたイベントと対応する、記録済みのデバイス値と画像データを含む運転記録データをPLC側記憶装置32から読み込んで、再生させる。再生制御欄402は、図32等で説明したのと同様、時間軸を表すスライダ状の操作バー404dと、この操作バー404d上を移動可能な時刻指定カーソル404、速度指定部405、再生ボタン406、ワンステップ逆再生ボタン407、ワンステップ再生ボタン408等を備えている。
In the
再生ボタン408を押下することで、過去のイベントの状態を再生できる。また操作バー404d上の時刻指定カーソル404を操作することにより、どの時刻の状態を再生するのかを選択できる。さらに、デバイス表示制御部13とイベント表示制御部14は連動しており、いずれかで選択した項目に対応して、各部の表示が連動される。例えば再生制御欄402で操作バー404d上をクリックする等して再生時刻を指示すると、指定した再生時刻のデバイス値が、ラダーモニタ欄1500のラダー図上に表示される。同様にイベント表示欄1400において、操作バー404d上で指定された再生時刻に発生したイベントが反転表示される。一方で、イベント表示欄1400において、一覧表示されたイベントのいずれかをクリックすることにより、操作バー404d上の再生時間が連動して移動する。このように、ESM同士の連動を行うことにより、トラブルの解析が容易になる。
By pressing the
なおイベント表示欄1400に表示されるイベントが、収集された運転記録データ内で発生したイベントか否かを、判別できるようにしてもよい。例えば運転記録データ内に発生したイベントを着色して表示させることで、ユーザは視覚的に判別できる。
Note that it may be possible to determine whether the event displayed in the
特定イベントをイベント表示欄1400に表示させる例を図43に示す。ここでは、イベント表示欄1400において、イーサネットリンクアップとイーサネットリンクダウンが一覧表示されている。イーサネットリンクアップは、イーサネットの接続が開始したことを表す。このイーサネットリンクアップは、例えばイーサネットケーブルが接続された場合、ハブの電源がONされた場合等に発生する。またイーサネットリンクダウンは、イーサネットの接続が終了したことを表す。例えばイーサネットケーブルが切断された場合や、ハブの電源がOFFになった場合等に発生する。図43の例では、短期間にイーサネットリンクアップとイーサネットリンクダウンが繰り返されており、イーサネットの接続が不安定になり、その結果としてトラブルが発生して保存トリガがONになったものと想定される。
FIG. 43 shows an example of displaying a specific event in the
なお図43において、イベント表示欄1400において表示されるイベントの内、着色される等ハイライトされたイベント1402は、デバイス表示制御部13の記録時間に発生したイベントであることを示す。またイベント表示欄1400において反転表示されたイベント1401は、現在選択中の再生表示に係るイベントである。イベント表示欄1400において選択された再生時刻に対応して、再生制御欄402における時刻指定カーソル404の位置が移動される。同様に、ラダーモニタ欄1500において対応するラダー図にデバイス値が表示される。また、再生制御欄402における時刻指定カーソル404を移動させると、これに応じてイベント表示欄1400やラダーモニタ欄1500の表示も連動して、対応する再生時刻の表示に更新される。
Note that in FIG. 43, among the events displayed in the
また再生制御欄402における操作バー404dは、保存トリガを発生させるイベント(保存トリガ発生イベント)の発生した時刻に保存トリガバー404eを表示させてもよい。保存トリガバー404eは、赤色等で示すことで視認し易くしている。なお図43の例では、イベント表示欄1400においてトリガ発生イベントが選択されているので、操作バー404dにおいて、灰色の時刻指定カーソル404と赤色のトリガ発生イベントが重なって表示されている。このため時刻指定カーソル404の指定する再生時刻を示す時刻表示領域409においては、イベント表示欄1400で選択され反転表示されている第二時刻データと同じ2018/11/20 11:20:46が表示されている。
The operation bar 404d in the
さらに再生制御欄402において、時刻表示領域409と並べて、総スキャン回数及び表示中のスキャン回数を示すスキャン回数表示領域409bを設けてもよい。図43の例では、全部で360629スキャン分のデバイス値セットが運転記録データとして記憶されていることが判る。また時刻表示領域409には、現在時刻指定カーソル404で現在指定されている再生時刻(11:20:46)が表示されているところ、この再生時刻では、193526スキャン目のデバイス値セットがラダーモニタ表示欄に表示されていることが、スキャン回数表示領域409bに示されている。
Further, in the
図43の状態から、時刻指定カーソル404を、右側、すなわち図43より時間を進めた時刻に移動させた状態を、図44に示す。ここでは、操作バー404dの保存トリガバー404eよりも時間的に遅い位置に、時刻指定カーソル404を位置させている。すなわち、時刻指定カーソル404を右に移動させるほど時刻が進み、左に行くほど時刻が戻る。
FIG. 44 shows a state in which the
また操作バー404dは、PLC側記憶装置32に保存された運転記録データの記録時間に対応させている。すなわち、操作バー404dの左端が、運転記録データの記録開始時、右端が運転記録データの記録終了時となる。そして上述の通り、運転記録データの記録を行う保存トリガ発生イベントの発生した時刻に保存トリガバー404eが操作バー404d上に表示されている。すなわち操作バー404dにおいて、保存トリガバー404eの左側が、保存トリガより前の収集時間Ta、保存トリガバー404eの右側が、保存トリガよりも後の収集時間Tbを示している。
Further, the operation bar 404d corresponds to the recording time of the driving record data stored in the PLC
図44の例では、イベント表示欄1400で選択されているイベントである「イーサネットリンクダウン」のイベントの第二時刻データは、2018/11/20の11:20:49であるため、これに連動して再生制御欄402の時刻表示領域409に表示される時刻も、この時刻と一致されて表示されている。なお、図44のラダーモニタ欄では、一部の入力接点及び一部の出力要素において、色塗り表示がなされている。これは、時刻指定カーソル404が図44に示す位置にあるときの時刻において、それらの入力接点及び出力要素がONになっていることを示している。
In the example of FIG. 44, the second time data of the event "Ethernet link down", which is the event selected in the
さらに、イベント表示欄1400において、ハイライトされたイベント1402以外のイベントを選択した例を、図45に示す。イベント表示欄1400においてハイライトされていないイベントは、デバイス値などの運転記録データが保存されていないため、保存期間外となり、対応する運転記録データが存在しない。この例では、イベント表示欄1400において2018/11/20 10:38:08が選択されているが、この時刻の運転記録データが保存されていないため、再生制御欄402においては、時刻指定カーソル404は、操作バー404dの下限である左端に貼り付いた状態となる。すなわち操作バー404dでは保存期間よりも以前や以後の時刻を表現できないため、保存期間外の時間がイベント表示欄1400で選択された場合は、連動表示ができないため、操作バー404dで対応する最も近い値に移動される。具体的には、保存期間よりも古い時刻の場合は操作バー404dの左端に、保存期間よりも新しい時刻の場合は操作バー404dの右端に、時刻指定カーソル404が位置される。
Further, FIG. 45 shows an example in which an event other than the highlighted event 1402 is selected in the
また時刻表示領域409には、操作バー404dの右端に対応する時刻2018/11/20 11:20:20が表示されており、保存トリガバー404eが示す保存トリガによって保存された運転記録データは、2018/11/20 11:20:20以降となる。またスキャン回数表示領域409bは、最も古いスキャン回数である1回目を指している。
In addition, the
なお、イベント表示欄1400においては、2018/11/20 11:20:38以降のイベントがハイライト表示されている。これは、保存期間の内、2018/11/20 11:20:20~11:20:37までは特に何のイベントもなかったためであり、この間に記録されたイベントが存在しない以上、イベント表示欄1400でも表示がない状態となっている。また、図45では、図44と比較して、色塗り表示された入力接点及び出力要素が増加している。これは、時刻指定カーソル404が図45に示す位置にあるときの時刻では、図44よりもONになった入力接点及び出力要素が増えていることを示している。
(カメラモニタ欄1600)
Note that in the
(Camera monitor column 1600)
以上の例では、イベント表示欄1400と再生制御欄402とラダーモニタ欄1500の表示を同期させる例を説明したが、これに加えて、カメラ部98で撮像した画像データも同様に、同期させて表示させることができる。このような例を図46のGUIに示す。この例では、画面右上に、画像データを表示するカメラモニタ欄1600を設けている。この例でも同様に、イベント表示欄1400で任意のイベントを選択すると、この選択されたイベントの時刻と対応する時刻に撮像された画像データが表示され、再生制御欄402における時刻指定カーソル404も、対応する再生時刻に移動される。また、再生ボタン406を押下すると、カメラモニタ欄1600において動画が再生されると共に、時間の経過に応じて対応するイベントにイベント表示欄1400の選択が切り替わり、またラダーモニタ欄1500におけるラダー図のデバイス値も更新されていく。これによって、トラブル発生時の動作を動的に再現できるので、トラブルの原因究明に有効となり得る。
In the above example, the display of the
本発明に係るプログラマブルロジックコントローラ用プログラム作成支援装置は、FAにおけるPLCシステムのトラブルシューティングに好適に利用できる。 The program creation support device for a programmable logic controller according to the present invention can be suitably used for troubleshooting a PLC system in an FA.
1…PLC
2…PC
3…CPUユニット
4、4a、4b…拡張ユニット
4c…カメラ入力拡張ユニット
4d…モーションユニット
4e…通信ユニット
5…PLC側表示部
6…PLC側操作部
7…表示部
8…PC側操作部
9…通信ケーブル
10、10a、10b…フィールドデバイス
11…PC側メモリ部
12…記録設定部
13…デバイス表示制御部
14…イベント表示制御部
15…同期ソフトウエアモジュール
16…選択受付部
21、21B…PC側CPU
22…PC側記憶装置
22b…運転記録データ保持部
23…PC側通信部
31…PLC側CPU
32…PLC側記憶装置
33…PLC側通信部
34…デバイス部;34a…CPUユニットデバイス部;34b…拡張ユニットデバイス部
34B…デバイスメモリ部
35…プロジェクト記憶部
36…保存メモリ;36A…メモリカード
36B…運転記録データ記憶部
37…内部メモリ
38…バスマスタ
39…記録制御部
41…CPU
42…メモリ
45…保存条件設定部
46…記録バッファ設定部
47…保存トリガ設定部
50…プロジェクト作成部
50B…プロジェクト編集部
50B1…TPJ解釈部;50B2…kpr解釈部
50C…保存制御部
50D…モード選択部;50D1…モード選択欄
51、51B…ログ設定部
52…部品指定部
53…デバイス抽出部
54…追加部
55…削除部
56…マージ部
57…特定部
58…手動設定部
59…推定部
60…機能指定部
61…ログ表示制御部
62…機能設定部
63…プログラム作成部
71…プロジェクトデータ
72…ログ設定データ
73…ログデータ
73B…ログメモリ部
74…ログデータ保存部
75…イベントログメモリ部
76…イベント管理部
77…バッファメモリ部
80…実行部
80a…ラダー実行エンジン
80b…ユニット制御部
81…記録部
82…検知部
83…時刻管理部
84…出力部
90…ユニット間バス
91a…一時記録部
93…保存部
96…機能実行部
98…カメラ部
101…ポインタ
150…ユニット設定UI
151…名称欄
152…入力領域欄
153…出力領域欄
154…占有領域欄
201…ユニット間通信
202…プログラム実行
204…END処理
311…編集部
312…付加部
313…演算部
314…デバッグ部
321…プログラム表示モジュール
322…波形表示モジュール
323…画像表示モジュール
324…再生制御モジュール
325…ユニット表示モジュール
330a…時刻UI
331a…表示時刻制御部
332…プログラム表示部
333a…デバイス値取得部
334…照合部
335…警告部
341…デバイス値提供部
342…時刻デバイス
343…再生制御部
344…ログデータ取得部
345…ログデバイス
400…表示UI
401a…アイコン
401b…アイコン
402…再生制御欄
403…表示領域
404、404a…時刻指定カーソル
404d…操作バー
404e…保存トリガバー
405…速度指定部
406…再生ボタン
407…ワンステップ逆再生ボタン
408…ワンステップ再生ボタン
409…時刻表示領域
409b…スキャン回数表示領域
410…プログラム表示領域
420…プロジェクト表示領域
430…カメラモニタ
440…ユニットモニタ
450…ラダーモニタ
514…プログラム実行部
1000、2000…プログラマブルロジックコントローラシステム
1200…プログラム作成支援装置
1300…ユーザープログラム作成支援プログラム
1310…プログラム編集画面
1312…デバイス値入力欄
1314…「上書」ボタン
1320…ポイントパラメータ編集欄
1322…速度指定欄
1330…ファイルメニュー
1332…「プロジェクトを別名保存」
1334…「プロジェクトを上書き保存」
1340…「プロジェクトの別名保存」ダイヤログ画面
1336…「プロジェクト-プロジェクトの照合」
1350…比較表示画面
1370…エラーイベント履歴フィルタ設定部
1371…表示一覧
1372…非表示一覧
1400…イベント表示欄
1401…反転表示されたイベント
1402…ハイライトされたイベント
1500…ラダーモニタ欄
1600…カメラモニタ欄
Ld…ラダー図
T…スキャンタイム
Ta…収集時間
Tb…収集時間
WK…対象物
1...PLC
2...PC
3...
22...PC
32... PLC
42...
151...Name column 152...Input area column 153...Output area column 154...Occupied
331a...Display
401a...
1334..."Saveproject"
1340..."Save project under another name" dialog screen 1336..."Project - project matching"
1350... Comparison display screen 1370... Error event history filter setting section 1371... Display list 1372...
本発明の第1の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、カメラ部が接続されるユニットを含む一以上のユニットで構成されたプログラマブルロジックコントローラであり、ユーザープログラムを繰り返し実行するプログラム実行部、該プログラム実行部によって参照される記憶領域であるデバイスを有するデバイス部、該デバイス部に記憶されているデバイス値を現在時刻と共にログデータとして時系列に記録すると共に、前記プログラマブルロジックコントローラ又は該プログラマブルロジックコントローラにより制御される被制御装置にて発生した複数のイベントを発生時刻と共にイベントデータとして時系列に記録する一時記録部、及び運転時において所定の保存条件が満たされると該一時記録部に記録されているログデータ及びイベントデータを保存メモリに保存すると共に、前記カメラ部で時系列に撮像された複数の画像データを該保存メモリに保存する保存部を備える前記プログラマブルロジックコントローラにおいて実行される、グラフィカルプログラミング言語で記述される前記ユーザープログラムの作成を支援するためのプログラム作成支援装置であって、前記プログラマブルロジックコントローラの運転時に前記保存メモリに保存されたログデータ及びイベントデータ並びに前記複数の画像データを、運転記録データとして記憶する運転記録データ保持部と、前記イベントを一覧表示させるイベント表示欄、前記ユーザープログラムであるラダー図を表示させるラダーモニタ欄、及び前記運転記録データ保持部から読み出した前記複数の画像データを時系列に表示させるカメラモニタ欄を表示させる表示部と、前記運転記録データ保持部から読み出したイベントデータに含まれる複数のイベント及び該複数のイベントの各々の発生時刻を、前記イベント表示欄に一覧表示するイベント表示制御部と、前記イベント表示制御部により一覧表示された複数のイベントの中から一つの選択を受け付ける選択受付部と、前記運転記録データ保持部から読み出したログデータに含まれ、かつ、前記選択受付部により選択されたイベントの発生時刻に対応する時刻に記録されたデバイス値を、前記ラダーモニタ欄に表示された前記ユーザープログラム上に重ねて表示するデバイス表示制御部とを備え、前記イベント表示欄において選択受付部により一つのイベントが選択されると、選択されたイベントの発生時刻に応じて、前記ラダーモニタ欄におけるデバイス値の表示が連動して更新されると共に、該選択されたイベントの発生時刻と対応する画像データが前記カメラモニタ欄に表示されるよう構成できる。上記構成により、多種多様なイベントの内から、トラブル解決に有用なイベントを選択的に表示させて、トラブルの原因究明に役立てることができる。
According to the program creation support device for a programmable logic controller according to the first aspect of the present invention, the programmable logic controller is composed of one or more units including a unit to which a camera section is connected , and repeatedly executes a user program. a program execution unit; a device unit having a device that is a storage area referenced by the program execution unit; and a device unit that records device values stored in the device unit in chronological order as log data together with the current time; or a temporary recording unit that records multiple events occurring in a controlled device controlled by the programmable logic controller in chronological order as event data together with the time of occurrence, and the temporary recording when predetermined storage conditions are met during operation. Executed in the programmable logic controller, which includes a storage unit that stores log data and event data recorded in the unit in a storage memory, and stores a plurality of image data captured in chronological order by the camera unit in the storage memory. A program creation support device for supporting the creation of the user program written in a graphical programming language, the program creation support device comprising: log data and event data stored in the storage memory during operation of the programmable logic controller; image data from a driving record data storage unit that stores the image data as driving record data, an event display field that displays a list of the events, a ladder monitor field that displays the ladder diagram that is the user program, and the driving record data storage unit. a display unit that displays a camera monitor field that displays the plurality of read image data in chronological order ; a plurality of events included in the event data read from the driving record data storage unit; and times of occurrence of each of the plurality of events. an event display control unit that displays a list of events in the event display field , a selection reception unit that receives a selection from among a plurality of events listed by the event display control unit, and reads out the driving record data from the driving record data storage unit. displaying a device value included in the selected log data and recorded at a time corresponding to the time of occurrence of the event selected by the selection reception unit over the user program displayed in the ladder monitor field; and a device display control section, when one event is selected by the selection reception section in the event display field, the display of the device value in the ladder monitor field is linked according to the occurrence time of the selected event. The image data may be updated and the image data corresponding to the time of occurrence of the selected event may be displayed in the camera monitor field . With the above configuration, events useful for troubleshooting can be selectively displayed from among a wide variety of events, and can be useful for investigating the cause of troubles.
また、第2の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、上記構成に加えて、前記デバイス表示制御部における表示対象時刻と、前記イベント表示欄における表示対象時刻と、前記カメラモニタ欄に表示される画像データの表示とを同期させるための同期ソフトウエアモジュールを備えることができる。
Further, according to the program creation support device for a programmable logic controller according to the second aspect, in addition to the above configuration , the display target time in the device display control section, the display target time in the event display field, and the camera monitor A synchronization software module may be provided for synchronizing the display of image data displayed in the column.
さらに、第3の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、上記何れかの構成に加えて、前記表示部は、前記ラダーモニタ欄に表示されるデバイス値の表示対象時刻を操作するための時刻UIを表示する時刻UI表示領域を有し、前記イベント表示欄において選択受付部により一つのイベントが選択されると、選択されたイベントの発生時刻に応じて、前記時刻UI表示領域における時刻UIの表示が連動して更新されると共に、該選択されたイベントの発生時刻と対応する画像データが前記カメラモニタ欄に表示されることができる。
Furthermore, according to the program creation support device for a programmable logic controller according to a third aspect, in addition to any of the above configurations , the display section operates the display target time of the device value displayed in the ladder monitor field. When one event is selected by the selection reception unit in the event display field, the time UI display area displays a time UI for The display of the time UI in is updated in conjunction, and image data corresponding to the time of occurrence of the selected event can be displayed in the camera monitor field.
さらにまた、第4の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、上記何れかの構成に加えて、前記時刻UIは再生ボタンを含み、前記時刻UI表示領域において再生ボタンが操作されると、前記ラダーモニタ欄においてデバイス値が時系列的に表示更新されるとともに、前記カメラモニタ欄において前記複数の画像データからなる動画が再生され、前記イベント表示欄において時間の経過に応じて対応するイベントが切り替わることができる。
Furthermore, according to the program creation support device for a programmable logic controller according to a fourth aspect, in addition to any of the above configurations, the time UI includes a play button, and the play button is operated in the time UI display area. Then, device values are displayed and updated in chronological order in the ladder monitor field, a video consisting of the plurality of image data is played in the camera monitor field, and a response is displayed in the event display field according to the passage of time. The events to be performed can be switched .
さらにまた、第5の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、上記何れかの構成に加えて、前記表示部は、さらに、前記カメラモニタ欄に表示させる画像データに対応付けられた時刻を指定する時刻指定カーソルを表示し、前記時刻指定カーソルによって指定された時刻に応じて、前記カメラモニタ欄に表示される画像データが更新されると共に、前記時刻UI表示領域における時刻UIの表示が連動して更新されることができる。
Furthermore, according to the program creation support device for a programmable logic controller according to the fifth aspect, in addition to any of the above configurations , the display section is further configured to be associated with image data to be displayed in the camera monitor column. A time designation cursor for designating the time specified by the time designation cursor is displayed, and the image data displayed in the camera monitor field is updated according to the time designated by the time designation cursor, and the time UI in the time UI display area is updated. The display can be updated accordingly .
さらにまた、第6の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、上記何れかの構成に加えて、前記プログラマブルロジックコントローラの前記保存部は、前記ログデータ及び前記イベントデータ並びに前記複数の画像データを、複数のファイルからなるパッケージとして前記保存メモリに保存し、前記運転記録データ保持部は、前記保存メモリに保存された複数のファイルからなるパッケージを前記運転記録データとして記憶することができる。
Furthermore, according to the program creation support device for a programmable logic controller according to a sixth aspect, in addition to any of the above configurations , the storage section of the programmable logic controller stores the log data, the event data, and the plurality of log data. image data is stored in the storage memory as a package made up of a plurality of files, and the driving record data holding unit stores the package made up of the plurality of files stored in the storage memory as the driving record data. can.
さらにまた、第7の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、上記何れかの構成に加えて、前記運転記録データは、前記複数のファイルからなるパッケージの内容を示す管理情報データを含むことができる。
Furthermore, according to the program creation support device for a programmable logic controller according to the seventh aspect, in addition to any of the above configurations , the driving record data includes management information data indicating the contents of the package consisting of the plurality of files. can include .
さらにまた、第8の態様に係るプログラマブルロジックコントローラ用プログラム作成支援装置によれば、上記何れかの構成に加えて、前記保存部は、前記ログデータ及び前記イベントデータ並びに前記複数の画像データを前記保存メモリに保存すると共に、前記ユーザープログラム及び前記ユニットの構成情報を含むプロジェクトデータを保存し、
前記表示部は、前記運転記録データ保持部から読み出したプロジェクトデータに含まれる前記ユーザープログラム及び前記ユニットの構成情報を表示させ、前記デバイス表示制御部は、前記運転記録データ保持部から読み出したログデータに含まれ、かつ、前記選択受付部により選択されたイベントの発生時刻に対応する時刻に記録されたデバイス値を、前記運転記録データ保持部から読み出したプロジェクトデータに含まれる前記ユーザープログラム上に重ねて表示することができる。
Furthermore, according to the program creation support device for a programmable logic controller according to an eighth aspect, in addition to any of the above configurations , the storage unit stores the log data, the event data, and the plurality of image data. storing project data including configuration information of the user program and the unit in a storage memory;
The display section displays the user program and the configuration information of the unit included in the project data read from the driving record data holding section, and the device display control section displays the log data read from the driving record data holding section. and is recorded at a time corresponding to the time of occurrence of the event selected by the selection receiving unit, on the user program included in the project data read from the driving record data holding unit. can be displayed .
Claims (11)
前記プログラマブルロジックコントローラの運転時に前記保存メモリに保存されたログデータ及びイベントデータを、運転記録データとして記憶する運転記録データ保持部と、
前記ユーザープログラムを表示させる表示部と、
前記運転記録データ保持部から読み出したイベントデータに含まれる複数のイベント及び該複数のイベントの各々の発生時刻を、前記表示部に一覧表示するイベント表示制御部と、
前記イベント表示制御部により一覧表示された複数のイベントの中から一つの選択を受け付ける選択受付部と、
前記運転記録データ保持部から読み出したログデータに含まれ、かつ、前記選択受付部により選択されたイベントの発生時刻に対応する時刻に記録されたデバイス値を、前記ユーザープログラム上に重ねて表示するデバイス表示制御部と、
を備えるプログラマブルロジックコントローラ用プログラム作成支援装置。 A programmable logic controller composed of one or more units, including a program execution unit that repeatedly executes a user program, a device unit that has a device that is a storage area referenced by the program execution unit, and a device that is stored in the device unit. Device values are recorded in chronological order as log data together with the current time, and multiple events occurring in the programmable logic controller or a controlled device controlled by the programmable logic controller are recorded in chronological order as event data together with the time of occurrence. A graphical programming language executed in the programmable logic controller, comprising a temporary recording section for storing log data and event data recorded in the temporary recording section when predetermined storage conditions are met during operation. A program creation support device for supporting the creation of the user program described in
an operation record data holding unit that stores log data and event data stored in the storage memory during operation of the programmable logic controller as operation record data;
a display unit that displays the user program;
an event display control unit that displays a list of a plurality of events included in the event data read from the driving record data holding unit and the occurrence times of each of the plurality of events on the display unit;
a selection reception unit that accepts one selection from among the plurality of events listed by the event display control unit;
Displaying a device value included in the log data read from the driving record data holding unit and recorded at a time corresponding to the time of occurrence of the event selected by the selection reception unit over the user program. a device display control section;
A program creation support device for a programmable logic controller.
前記プログラマブルロジックコントローラの前記一時記録部に対し、前記複数のイベントのうち前記特定イベントのみを記録するよう設定する記録設定部を備えてなるプログラマブルロジックコントローラ用プログラム作成支援装置。 The program creation support device for a programmable logic controller according to claim 1, further comprising:
A program creation support device for a programmable logic controller, comprising a recording setting section configured to set the temporary recording section of the programmable logic controller to record only the specific event among the plurality of events.
前記特定イベントが、前記プログラム実行部による前記ユーザープログラムの実行と独立してユーザが行った操作に関するイベントを含んでなるプログラマブルロジックコントローラ用プログラム作成支援装置。 The program creation support device for a programmable logic controller according to claim 1,
A program creation support device for a programmable logic controller, wherein the specific event includes an event related to an operation performed by a user independently of execution of the user program by the program execution unit.
前記ユーザ操作に関するイベントが、少なくとも、
前記ユーザープログラム及び前記プログラマブルロジックコントローラの構成情報を含むプロジェクトデータの書き換え、
前記プログラマブルロジックコントローラの設定を行う設定モードと、前記プログラマブルロジックコントローラ上で前記ユーザープログラムを実行させる運転モードとのモード切替、
前記プログラマブルロジックコントローラに接続可能なケーブルの挿抜、
前記プログラマブルロジックコントローラに取り付け可能な記憶媒体の挿抜、及び
前記被制御装置の電源のON/OFF
を含むプログラマブルロジックコントローラ用プログラム作成支援装置。 The program creation support device for a programmable logic controller according to claim 3,
The event related to the user operation includes at least
rewriting project data including configuration information of the user program and the programmable logic controller;
mode switching between a setting mode for setting the programmable logic controller and an operation mode for executing the user program on the programmable logic controller;
Insertion and removal of a cable connectable to the programmable logic controller;
Inserting and removing a storage medium that can be attached to the programmable logic controller, and turning on/off the power of the controlled device
A program creation support device for programmable logic controllers, including:
前記イベント表示制御部は、前記プログラム実行部による前記ユーザープログラムの実行に従って、前記プログラマブルロジックコントローラ内で自動的に実行される処理に応じたイベントを非表示としてなるプログラマブルロジックコントローラ用プログラム作成支援装置。 The program creation support device for a programmable logic controller according to claim 1,
The event display control unit is configured to hide events corresponding to processing automatically executed within the programmable logic controller in accordance with execution of the user program by the program execution unit.
前記自動実行される処理に応じたイベントは、少なくとも、
前記プログラマブルロジックコントローラと接続された外部装置とTCP接続又はFTP接続するときの通信開始又は通信切断、及び
前記プログラマブルロジックコントローラ内に用意されたフォルダ又はファイルへの書き込み
を含むプログラマブルロジックコントローラ用プログラム作成支援装置。 The program creation support device for a programmable logic controller according to claim 5,
The event corresponding to the automatically executed process includes at least the following:
Program creation support for the programmable logic controller, including starting or disconnecting communication when making a TCP connection or FTP connection with an external device connected to the programmable logic controller, and writing to a folder or file prepared in the programmable logic controller. Device.
前記デバイス表示制御部における表示対象時刻と、前記イベント表示制御部における表示対象時刻とを同期させる同期ソフトウエアモジュールを備え、
前記同期ソフトウエアモジュールが、前記デバイス表示制御部と、前記イベント表示制御部を、前記表示部において連動させて表示させてなるプログラマブルロジックコントローラ用プログラム作成支援装置。 The program creation support device for a programmable logic controller according to claim 1, further comprising:
comprising a synchronization software module that synchronizes the display target time in the device display control unit and the display target time in the event display control unit,
A program creation support device for a programmable logic controller, wherein the synchronization software module causes the device display control section and the event display control section to be displayed in conjunction with each other on the display section.
前記表示部は、
前記イベントを一覧表示させるイベント表示欄と、
前記ユーザープログラムであるラダー図を表示させるラダーモニタ欄と
を備え、
前記選択受付部で、前記イベント表示欄から任意のイベントが選択されると、該選択されたイベントの時刻と対応するラダー図が前記ラダーモニタ欄で選択されて表示されるプログラマブルロジックコントローラ用プログラム作成支援装置。 The program creation support device for a programmable logic controller according to claim 7,
The display section is
an event display field for displaying a list of the events;
and a ladder monitor field for displaying the ladder diagram that is the user program,
Creating a program for a programmable logic controller in which, when an arbitrary event is selected from the event display field in the selection reception section, a ladder diagram corresponding to the time of the selected event is selected and displayed in the ladder monitor field. Support equipment.
前記記録設定部は、前記プログラマブルロジックコントローラに接続されたカメラ部で時系列に撮像された複数の画像データを前記保存メモリに保存させるよう設定しており、
前記表示部は、さらに
前記カメラ部で時系列に撮像された複数の画像データを表示させるカメラモニタ欄
を備え、
前記選択受付部で、前記イベント表示欄から任意のイベントが選択されると、該選択されたイベントの時刻と対応するラダー図が前記ラダーモニタ欄で選択され、かつ該選択されたイベントの時刻と対応する画像データが前記カメラモニタ欄に表示されるプログラマブルロジックコントローラ用プログラム作成支援装置。 The program creation support device for a programmable logic controller according to claim 8,
The recording setting unit is configured to store a plurality of image data captured in chronological order by a camera unit connected to the programmable logic controller in the storage memory,
The display unit further includes a camera monitor field for displaying a plurality of image data captured in chronological order by the camera unit,
When an arbitrary event is selected from the event display column in the selection reception section, a ladder diagram corresponding to the time of the selected event is selected in the ladder monitor column, and a ladder diagram corresponding to the time of the selected event is selected. A program creation support device for a programmable logic controller in which corresponding image data is displayed in the camera monitor field.
前記保存メモリが、SDカード(商品名)であるプログラマブルロジックコントローラ用プログラム作成支援装置。 A program creation support device for a programmable logic controller according to claim 9,
A program creation support device for a programmable logic controller, wherein the storage memory is an SD card (product name).
前記イベント表示制御部が、デバイス値を時系列波形として前記表示部に表示してなるプログラマブルロジックコントローラ用プログラム作成支援装置。 A program creation support device for a programmable logic controller according to any one of claims 1 to 10,
A program creation support device for a programmable logic controller, wherein the event display control section displays device values as time-series waveforms on the display section.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2023147288A JP2023164999A (en) | 2019-02-12 | 2023-09-12 | Program creation assistance device for programmable logic controller |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2019023077A JP2020134986A (en) | 2019-02-12 | 2019-02-12 | Program creation support device for programmable logic controller |
JP2023147288A JP2023164999A (en) | 2019-02-12 | 2023-09-12 | Program creation assistance device for programmable logic controller |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2019023077A Division JP2020134986A (en) | 2019-02-12 | 2019-02-12 | Program creation support device for programmable logic controller |
Publications (1)
Publication Number | Publication Date |
---|---|
JP2023164999A true JP2023164999A (en) | 2023-11-14 |
Family
ID=72278544
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2019023077A Pending JP2020134986A (en) | 2019-02-12 | 2019-02-12 | Program creation support device for programmable logic controller |
JP2023147288A Pending JP2023164999A (en) | 2019-02-12 | 2023-09-12 | Program creation assistance device for programmable logic controller |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2019023077A Pending JP2020134986A (en) | 2019-02-12 | 2019-02-12 | Program creation support device for programmable logic controller |
Country Status (1)
Country | Link |
---|---|
JP (2) | JP2020134986A (en) |
Families Citing this family (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11641131B2 (en) * | 2020-11-06 | 2023-05-02 | Asco Power Technologies, L.P. | Power control system (PCS) commissioning agent |
JP2023122186A (en) * | 2022-02-22 | 2023-09-01 | オムロン株式会社 | Control system, support device and support program |
WO2024013915A1 (en) * | 2022-07-13 | 2024-01-18 | 三菱電機株式会社 | Logging device, log data analysis assistance system, information provision method, and program |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2012118567A (en) * | 2009-03-27 | 2012-06-21 | Mitsubishi Electric Corp | Programmable display |
CN105103064B (en) * | 2013-04-12 | 2017-03-08 | 三菱电机株式会社 | The peripheral device of Programmable Logic Controller and debugging householder method |
JP2015176370A (en) * | 2014-03-14 | 2015-10-05 | オムロン株式会社 | Control system, method, program and information processor |
-
2019
- 2019-02-12 JP JP2019023077A patent/JP2020134986A/en active Pending
-
2023
- 2023-09-12 JP JP2023147288A patent/JP2023164999A/en active Pending
Also Published As
Publication number | Publication date |
---|---|
JP2020134986A (en) | 2020-08-31 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11188048B2 (en) | Programmable logic controller and main unit | |
JP6757386B2 (en) | Programmable logic controller and program creation support device | |
JP2023164999A (en) | Program creation assistance device for programmable logic controller | |
US10983743B2 (en) | Programmable display and programmable logic controller system including the same | |
US7849364B2 (en) | Kernel-mode in-flight recorder tracing mechanism | |
JP7320953B2 (en) | Programmable logic controller and its log data storage method | |
JP7273935B2 (en) | External setting device, logging setting method and program | |
JP7173826B2 (en) | Programmable logic controller system, programming support device and computer program | |
JP7212496B2 (en) | Programmable logic controller system, programming support device and computer program | |
JP7466319B2 (en) | Programmable display and programmable logic controller system equipped with the same | |
JP2022158228A (en) | Monitoring device and programmable logic controller system | |
CN106462139A (en) | Programmable display device and rendering software | |
JP6948450B2 (en) | Programmable logic controller and main unit | |
JP6806946B2 (en) | External setting devices and programs | |
JP7405714B2 (en) | programmable logic controller | |
JP6986125B2 (en) | Programmable logic controller and main unit | |
JP7356778B2 (en) | Program creation support device for programmable logic controllers | |
JP7412076B2 (en) | Engineering tools for programmable logic controllers | |
JP2019159868A (en) | Control system, controller and display device | |
JP2001154711A (en) | Method and device for debugging process stepping type program | |
CN114490285A (en) | System and method for replaying RPA flow execution process | |
EP3767407A1 (en) | Control device, control method, and control program | |
EP3767409A1 (en) | Factory automation (fa) system, controller, and control method | |
JP3168993B2 (en) | Remote program debugging system, remote program debugging method, and recording medium recording remote debugging program | |
JP7581861B2 (en) | CONTROL SYSTEM, SUPPORT DEVICE AND LABELING METHOD |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20231005 |
|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20231005 |