This application claims the priority of European Patent Application Serial No. EP 16171365.6, filed May 25, 2016, the subject matter of which is incorporated herein by reference.
The present invention relates to an approach of updating configurable parameters of a user-defined control program during runtime.
The following discussion of related art is provided to assist the reader in understanding the advantages of the invention, and is not to be construed as an admission that this related art is prior art to this invention.
Industrial automation is used to control machines and processes in manufacturing. An industrial automation installation comprises multiple computerized devices that control industrial processes and devices. The industrial devices generate a large number of variables to be monitored by the industrial automation. The devices of an industrial automation installation must work together in a coordinated way and performing operations. The local control algorithm may also perform local data analytics (on-board analytics).
Industrial controllers and their associated devices are central to the operation of modern industrial automation systems. These controllers interact with field devices on the field floor to control the automated processes relating to such objectives as product manufacture etc. Industrial automation installations can include one or more industrial controllers that monitor and control their processes. The controllers exchange data with field devices using native hardwired I/O or via a plant network such as Ethernet/IP, ControlNet or the like. Industrial controllers receive typically any combination of digital or analog signals from the field devices indicating current states of the devices and their associate processes. Industrial controllers are, for example, programmable logic controllers, (hereinafter referred to as PLC), or programmable controllers.
Industrial controllers store and execute user-defined control programs to effect decision-making in connection with the controlled process based on the received signals by changing the original parameters of the user-defined control program. PLC programs are typically written in a special application on a personal computer, then downloaded by a direct connection cable or over a network to the PLC. Such user-defined control programs can be, according to the IEC 61131-3 (IEC 61131 is an IEC standard for programmable controllers), but are not limited to, a ladder diagram (LD), sequential function charts (SFC), function block programming codes (FBD), structured text (ST), or other such programming structures.
Nowadays, variables from field devices and automation systems are collected and brought (arrow 5) to a network device with a cloud computing infrastructure (hereinafter referred to as cloud 6,
In the cloud 6 of
The control parameters are mainly the process parameters (e.g., certain process set-points, threshold values, parameters of a PID controller, etc.).
Typically, an automation expert takes the results of cloud based analytics, accesses the programming system of the PLC (e.g., STEP7 or TIA portal), modifies the FBs, builds the project and deploys again on the PLC. As this process is manual in nature, it limits the frequency of updating the local control parameters or the control logic. Cloud-based analytics may provide new control parameters several times a day. Due to its manual nature, this is also cost-intensive and error-prone.
It would therefore be desirable and advantageous to provide an improved system and method for updated optimized cloud variables in an automation system based on data analytics in a cloud to obviate prior art shortcomings.
According to one aspect of the present invention, a system for executing a closed loop control on data for cloud-based applications includes an industrial automation device configured to generate cloud variables, a cloud-based application which is hosted by a network device with a cloud-computing infrastructure, an industrial controller configured to control the industrial automation device by a user-defined control program, hosted by the industrial controller, said user-defined control program being configured to receive the cloud variables; a cloud agent configured to communicate with the user-defined control program and to communicate with the cloud-based application, said cloud agent configured to collect the cloud variables and to send the cloud variables to the cloud-based application, the cloud-based application being configured to determine updated optimized values of the cloud variables and to notify the cloud agent in the industrial controller with the updated optimized values of the cloud variables, the cloud agent being configured to reload the updated optimized values of the cloud variables and to notify the user-defined control program with the updated optimized values of the cloud variables, and the user-defined control program being configured to include cloud constructs which request the updated optimized values of the cloud variables during runtime and to reload the updated optimized values of the cloud variables in the user-defined control program.
According to another aspect of the present invention, a method for executing a closed loop control on data for a cloud-based application includes generating cloud variables by an industrial automation device, hosting a cloud-based application by a network device with a cloud-computing infrastructure, controlling the industrial automation device by a user-defined control program which is hosted by an industrial controller, receiving the cloud variables by the user-defined program, collecting the cloud variables and sending the cloud variables to the cloud-based application with a cloud agent configured for communication with the user-defined control program and for communication with the cloud-based application, determining by the cloud-based application updated optimized values of the cloud variables and notifying the cloud agent in the industrial controller with the updated optimized values of the cloud variables, reloading the updated optimized values of the cloud variables by the cloud agent, notifying the user-defined control program with the updated optimized values of the cloud variables by the cloud agent, and providing cloud constructs by the user-defined control program which requests the updated optimized values of the cloud variables during runtime and reloading the updated optimized values of the cloud variables in the user-defined control program.
According to still another aspect of the present invention, an industrial controller configured to execute a data transfer includes a user-defined control program hosted by the industrial controller, the user-defined control program being configured to control an industrial automation device and to receive cloud variables generated by the industrial automation device, a cloud agent configured to communicate with the user-defined control program and to communicate with a cloud-based application, said cloud agent configured to collect the cloud variables, to send the cloud variables to the cloud-based application, to notify the user-defined control program with updated optimized values of the cloud variables generated by the cloud-based application based on the received cloud variables, and to reload the updated optimized values of the cloud variables by the cloud agent, the cloud-based application being configured to determine the updated optimized values of the cloud variables and to notify the cloud agent in the industrial controller with the updated optimized values of the cloud variables, and the user-defined control program being configured to include cloud constructs which request the updated optimized values of the cloud variables during runtime and to reload the updated optimized values of the cloud variables in the user-defined control program.
Cloud variables are variables which are provided for updating in the cloud.
In accordance with the present invention, an automated method and system is therefore created of changing the variables in industrial automation systems based on results from cloud based analytics. In the manual update case, in the state of the art, there is always a delay from when an optimization is identified by a cloud based analytics application to when the controller is updated. The method described here eliminates this time delay, resulting in a better process optimization. The method also eliminates the need of manual intervention (and thus costs and errors) when updating the user-defined control program, for example, the control logic of a process.
The present invention is enabled by the definition of cloud constructs within the user-defined control program and cloud variables which can be dynamically updated on the industrial controller at runtime (for example, at the beginning of a scan cycle) based on a cloud based application in the network device with a cloud-computing infrastructure. The network device with a cloud-computing infrastructure is referred to afterwards as a cloud. A cloud definition is given in the description of
The approach of defining the cloud variables directly into the programming language of the controller enables the user-defined control program, which interacts with the cloud, to be written in a simple manner.
Cloud based data analytics techniques have resulted in better process control and optimization, for example, better quality, reduced energy, etc. These results can only be leveraged effectively when there is an automated and efficient way of changing the process control logic in the field systems based on results from cloud based analytics. This problem is now solved by the invention. This effectively helps businesses to provide cloud based data analytics capabilities for automation systems in the field.
The present invention can analyze the cloud variables of an industrial device in the cloud. The optimized cloud variables can dynamically update the variables, for example, by modifying cloud variables on the controller controlling the loop.
Advantageously, the cloud agent can be hosted in the industrial controller. The advantages in this case are that the cloud agent is a part of the PLC software and is executed adjacent to the user-defined control program. This leads to better performance as network communications or inter process communications are avoided.
According to another advantageous feature of the present invention, the industrial controller can be configured as a PLC (programmable logic controller). The user-defined control program can be configured as a PLC program in a special language. Therefore, IEC 61131 deals with programming languages and defines two graphical and two textual PLC programming language standards: Ladder diagram (LD, graphical), Function block diagram (FBD, graphical), Structured text (ST, textual), Instruction list (IL, textual), Sequential function chart (SFC, having elements to organize programs for sequential and parallel control processing) and Continuous Function Chart (CFC). IEC 61131-3 is the third part of the open international standard IEC 61131 for programmable logic controllers.
According to another advantageous feature of the present invention, the cloud agent can include a unique ID (identity number) for identifying the user-defined control program, for which the cloud variables are collected and on which the cloud variables are to be updated.
According to another advantageous feature of the present invention, the cloud agent can be configured to aggregate continuously the cloud variables from the user-defined control program and send them to the cloud-based application. Furthermore, the cloud agent may also be configured to collect the variables, if any.
Other features and advantages of the present invention will be more readily apparent upon reading the following description of currently preferred exemplified embodiments of the invention with reference to the accompanying drawing, in which:
Throughout all the figures, same or corresponding elements may generally be indicated by same reference numerals. These depicted embodiments are to be understood as illustrative of the invention and not as limiting in any way. It should also be understood that the figures are not necessarily to scale and that the embodiments may be illustrated by graphic symbols, phantom lines, diagrammatic representations and fragmentary views. In certain instances, details which are not necessary for an understanding of the present invention or which render other details difficult to perceive may have been omitted.
Turning now to the drawing, and in particular to
Thus, the PLC program 22 is compiled, linked and built using the special compiler that understands the cloud constructs. That means that control program is built using a special compiler and a build tool that is designed to interpret the cloud constructs; then the PLC program 22 is deployed on the PLC 20 and executed. On execution, the PLC program 22 initializes the cloud variables with their default values.
The PLC program 22 has a sub-component that continuously listens, for example, to another program and/or process for any changes to the cloud variables. When the values of the cloud variables need to be changed, the PLC program 22 receives the new values, and updates the values of the cloud variables for use in the next scan cycle.
The user-defined control program is therefore typically an operating system process. The PLC program 22 controlling an industrial process is written in a programming language by an automation expert using an engineering tool.
In operation mode, the non-cloud variables and cloud variables are received and/or generated by the PLC program 22, A cloud agent 21, which is in communication with the PLC program 22, is configured to collect the cloud variables and to send the values of the cloud variables to the cloud-based application. That means that the cloud agent 21 on the PLC 20 collects at least the values of the cloud variables and sends them to the cloud 60 for analysis (arrow 50). The cloud agent 21 is, for example, another program and/or process running on the PLC 20. It continuously aggregates the values of the cloud variables from the PLC 20 and sends them to the cloud 60. The data analytics cloud-based application 70 in the cloud 60 analyzes the cloud variables and determines the optimal values of the cloud variables for the industrial process, which means generating updated optimized values of the cloud variables. That means that the cloud-based application 70 in the cloud 60 analyzes the data coming from a device in the field. Based on the data analysis, the data analytics cloud-based application 70 may determine that the values of the cloud variables of the industrial process in the PLC program 22 have to be changed.
The data analytics cloud-based application 70 notifies the cloud agent 21 (arrow 80) on the PLC 20 with the updated optimized values of the cloud variables of the industrial process.
The cloud agent 21 receives new values of the cloud variables from the data analytical applications 70 in the cloud 60 and notifies the PLC program 22 accordingly.
The cloud agent 21 has a unique ID (identity number) which is used to identify the PLC/PLC program 22 for which the values of the cloud variables are collected and on which the values of the cloud variables are to be updated.
The cloud agent 21 notifies the PLC program 22 with the updated optimized configuration of variables, and the constructs of the PLC program 22 request the updated optimized values of the cloud variables during runtime, for example, at the beginning of a new scan cycle and a reloading of the updated optimized values of the cloud variables.
Now the process 30 is controlled using the updated optimized values of the cloud variables as received from the cloud 60.
This example relates to a Function Block (Timed Counter) that implements a timed counter by an incremental count of the timed interval. The variable “Time_Increment” has a default value of “1.25”.
This invention describes a method of updating a set of cloud variables of a control program dynamically during runtime based on data analytics in the cloud 70. The idea is to define those data and/or parameters in a PLC program 22, which would be dynamically updated from the cloud 70 during the programming step. These are then the updated optimized cloud variables. The compilers for the PLC program 22 are developed accordingly so as to understand the cloud related programming constructs.
While the invention has been illustrated and described in connection with currently preferred embodiments shown and described in detail, it is not intended to be limited to the details shown since various modifications and structural changes may be made without departing in any way from the spirit and scope of the present invention. The embodiments were chosen and described in order to explain the principles of the invention and practical application to thereby enable a person skilled in the art to best utilize the invention and various embodiments with various modifications as are suited to the particular use contemplated.
What is claimed as new and desired to be protected by Letters Patent is set forth in the appended claims and includes equivalents of the elements recited therein:
Number | Date | Country | Kind |
---|---|---|---|
16171365 | May 2016 | EP | regional |
Number | Name | Date | Kind |
---|---|---|---|
9971317 | Maturana | May 2018 | B2 |
20090319060 | Wojsznis | Dec 2009 | A1 |
20130166621 | Zhu | Jun 2013 | A1 |
20130212214 | Lawson | Aug 2013 | A1 |
20140047064 | Maturana et al. | Feb 2014 | A1 |
20140058537 | Jost | Feb 2014 | A1 |
20140129688 | Asenjo et al. | May 2014 | A1 |
20140337429 | Asenjo | Nov 2014 | A1 |
20150277404 | Maturana | Oct 2015 | A1 |
20150277406 | Maturana et al. | Oct 2015 | A1 |
20160182309 | Maturana | Jun 2016 | A1 |
20160274552 | Strohmenger | Sep 2016 | A1 |
20160364649 | Ding | Dec 2016 | A1 |
20170139702 | You | May 2017 | A1 |
20170315541 | Kreidler | Nov 2017 | A1 |
20180052451 | Billi-Duran | Feb 2018 | A1 |
20180063244 | Maturana et al. | Mar 2018 | A1 |
20180107230 | Sai | Apr 2018 | A1 |
Number | Date | Country |
---|---|---|
103631680 | Mar 2014 | CN |
103685442 | Mar 2014 | CN |
103957228 | Jul 2014 | CN |
104950741 | Sep 2015 | CN |
104950836 | Sep 2015 | CN |
2544059 | Jan 2013 | EP |
2924570 | Sep 2015 | EP |
2924572 | Sep 2015 | EP |
2924572 | Sep 2015 | EP |
3070548 | Sep 2016 | EP |
Entry |
---|
Cloud Adaptation with Control Theory in Industrial Clouds; Wiggleworth; 8 pages; 2016 IEEE; printed form the Internet on Oct. 10, 2018. |
Number | Date | Country | |
---|---|---|---|
20170343967 A1 | Nov 2017 | US |