The present invention relates to an SCADA web HMI system.
Supervisory Control And Data Acquisition (SCADA) is known as a mechanism that monitors and controls social infrastructure systems. The social infrastructure systems include a steel rolling system, a power transmission and transformation system, a water and sewage treatment system, a building management system, a road system, and the like.
The SCADA, which is a kind of industrial control systems, performs system monitoring and process control by a computer. In the SCADA, a quick responsiveness (real-time property) corresponding to system processing performance is necessary.
The SCADA is typically constituted of sub-systems as follows:
A Human Machine Interface (HMI) is a mechanism that presents data of a target process (monitor target device) to an operator and allows the operator to monitor and control the process. For example, in PTL 1, an SCADA HMI including an HMI screen that operates on an SCADA client is disclosed.
A monitor control system collects signal data (PLC signal) on a process and transmits a control command to the process. The monitor control system is constituted of a Programmable Logic Controller (PLC), and the like.
A remote input/output device, which is connected with a sensor installed within the process, converts a sensor signal into digital data and transmits the digital data to the monitor control system.
A communication base connects the monitor control system and the remote input/output device.
A client program of an HMI sub-system in PTL 1 is constructed by a program that depends on a machine environment. In order to achieve cost reduction in the SCADA HMI subsystem, the inventor of the present application has developed a browser-based SCADA HMI subsystem that does not depend on a machine environment.
When the SCADA HMI subsystem is constructed as a web application that operates on a web browser, the following advantages are provided.
In conventional SCADA HMI subsystems, an HMI screen is created by using a drawing creation device called an engineering tool.
On the HMI screen, a plurality of parts are arranged. In conventional SCADA, at least one data element called “tag” or “point” is assigned to each part. For each data element, a unique PLC signal is assigned. For n data elements (for example, display colors of parts) on the HMI screen, n PLC signals are assigned; and from a monitor control system (PLC) to an HMI subsystem, n PLC signals are transmitted. The HMI subsystem changes colors of parts or changes animation or the like according to the PLC signals received from the monitor control system (PLC).
However, in an actual system, an electrical ON/OFF is determined by a breaker state and therefore, some adjacent parts have an identical color.
Thus, on the HMI screen of the SCADA HMI subsystem, color change patterns for some adjacent display parts are the same and can be controlled by an identical PLC signal.
An object of the present invention is to provide an SCADA web HMI system that by integrating information assigned to parts on an HMI screen, makes it possible to achieve a reduction in the number of PLC signals, an improvement in engineering efficiency, and an improvement in runtime performance.
In order to achieve the object, an SCADA web HMI system according to the present invention is configured as follows.
The SCADA web HMI system includes a web browser for displaying an HMI screen. The SCADA web HMI system changes the appearance of a part arranged on the HMI screen according to a value of a PLC signal received from a programmable logic controller.
The SCADA web HMI system includes first part data generation means, second part data generation means, integrated part identifier generation means, part data change means, integrated item name generation means, and web HMI data generation means.
The first part data generation means generates first part data in which arrangement information of a first part arranged on the HMI screen, a first part identifier for the first part, a first attribute identifier indicating a dynamic display attribute of the first part, and first display information defining a display state of the first part corresponding to an attribute value assigned to the first attribute identifier are associated.
The second part data generation means generates second part data in which arrangement information of a second part arranged on the HMI screen, a second part identifier for the second part, a second attribute identifier indicating a dynamic display attribute of the second part, and second display information defining a display state of the second part corresponding to an attribute value assigned to the second attribute identifier are associated.
The integrated part identifier generation means newly generates an integrated part identifier when the first attribute identifier of the first part data and the second attribute identifier of the second part data are an identical attribute identifier.
The part data change means changes the first part identifier of the first part data and the second part identifier of the second part data to the integrated part identifier.
The integrated item name generation means generates an integrated item name in which a screen identifier of the HMI screen, the integrated part identifier, and the identical attribute identifier are combined.
The web HMI data generation means generates web HMI data that includes the arrangement information of the first part, the arrangement information of the second part, the integrated item name, the first display information, the second display information, and a script for changing the display states of the first part and the second part according to the received PLC signal.
The web HMI data includes static display attribute data and runtime attribute data. The static display attribute data is data in which the arrangement information of the first part, the arrangement information of the second part, and the integrated item name are associated. The runtime attribute data is data in which the integrated item name, the first display information, the second display information, and the script are associated.
The web browser includes static display means and dynamic display means. The static display means reads the static display attribute data and displays the HMI screen. The dynamic display means reads the runtime attribute data; and when the received PLC signal corresponds to the integrated item name, updates the display state of the first part based on the first display information and updates the display state of the second part based on the second display information according to a value of the received PLC signal by using the script in which the integrated item name, the first display information, and the second display information are applied as setting parameters.
According to the present invention, by integrating parts having an identical attribute on the HMI screen, a reduction in the number of PLC signals, an improvement in engineering efficiency, and an improvement in runtime performance can be achieved.
Hereinafter, embodiments of the present invention will be described in detail with reference to drawings. However, when numbers such as the number, quantity, volume, or range of elements are referred to in the embodiments presented below, the present invention is not limited by the numbers referred to except where especially explicitly specified and where explicitly specified to the numbers in principle. In addition, structures and the like that are described in the embodiments presented below are not necessarily required for this invention except where especially explicitly specified and where obviously specified thereto in principle. It should be noted that common elements in the figures are denoted by the same reference signs to omit redundant explanation.
Descriptions of the monitor control system 4, the communication base 5, and the RIO 6 are as described in Background and therefore, is omitted. The monitor control system 4 includes a programmable logic controller (PLC). The monitor target device 7 is a sensor, an actuator, or the like that constitutes a plant that is a monitor control target.
The SCADA web HMI design device 1 executes an engineering tool 10. The engineering tool 10 generates web HMI data 2 and a device list 23 that are necessary to function the SCADA web HMI execution device 3 that is an HMI execution environment. Details of the SCADA web HMI design device 1 will be described later.
The SCADA web HMI execution device 3 (HMI subsystem) executes a web server 31 and a web browser 32. The SCADA web HMI execution device 3 operates as an HMI subsystem in coordination between an HMI server runtime 311 operating on the web server 31 and an HMI web runtime 321 operating on the web browser 32.
The web browser 32 displays an HMI screen that is a screen for monitoring a plant. On the HMI screen, parts for displaying a plant state are arranged. The web server 31 communicates with the web browser 32 and the monitor control system 4. For example, the web server 31 transmits, when a PLC signal received from the monitor control system 4 is a signal related to the HMI screen currently displayed on the web browser 32, the PLC signal to the web browser 32. This causes the SCADA web HMI execution device 3 to change the appearances of parts arranged on the HMI screen according to a value of the PLC signal received from the monitor control system 4. Details of the SCADA web HMI execution device 3 will be described later.
The SCADA web HMI design device 1 includes, as shown in
The engineering tool 10 that operates on the SCADA web HMI design device 1 includes: an advanced drawing editing function; a function allowing drawing data to be saved in a Scalable Vector Graphics (SVG) format; and an extension function. The drawing editing function and the SVG data saving function are realized by, as one example, Microsoft Visio (registered trademark).
The engineering tool 10 can execute, as major processing, drawing processing 11, part data generation processing 12, part data editing processing 13, web HMI data generation processing 14, device list generation processing 15, and integration processing 16.
With reference to
The drawing processing 11 displays, side by side, a stencil area 110 in which prototypes (master shapes) of parts necessary for creating a drawing are arranged and a drawing area 111 in which a drawing for an HMI screen is drawn. The drawing processing 11 allows parts in the stencil area 110 which are selected by an HMI screen designer to be arranged on a drawing in the drawing area 111 by using the input/output interface 1d (
In the example in
It should be noted that types of parts are not limited thereto and in the stencil area 110, prototypes such as triangle parts and tire parts may be displayed.
The HMI screen designer can copy (drag and drop) a prototype in the stencil area 110 in
The part data generation processing 12 in
The part data generation processing 12 generates part data, in which the “arrangement information,” “part identifier,” “attribute identifier,” and “display information” of a part arranged in the drawing area 111, are associated.
The “arrangement information” is a static display attribute including the shape, position, size, and the like of the part arranged in the drawing area 111. The static display attribute is information that does not cause the appearance of the part to be changed irrespective of a value of a received PLC signal. The static display attribute can be changed on the drawing area 111.
The “part identifier” is a unique identifier specifying each of the parts arranged on one drawing and is, for example, a part number.
The “attribute identifier” is an identifier that represents a dynamic display attribute of the part.
The “display information” is information that defines a display state of the part which corresponds to an attribute value assigned to the attribute identifier. If the attribute is a display color, it is also referred to as a color rule.
In addition, the part data generation processing 12 generates an “item name,” unique to the system, in which a screen identifier of the HMI screen, a part identifier, and an attribute identifier are combined.
First part data 41 is part data of the first rectangle that is the first part. The first part identifier is “part number 1.” A first attribute identifier is “display color 1.” First display information indicates, “When the PLC signal is 0, the part color is changed to gray and when the PLC signal is 1, the part color is changed to red.” In addition, an item name “G1_1SL1” is an identifier that is obtained by combining “G1” indicating a screen identifier of the HMI screen, “1” indicating the part number 1, and “SL1” indicating the display color 1. “G1_1SL1” is a signal name corresponding to signal data (PLC signal) that is transmitted from the monitor control system 4 to the SCADA web HMI execution device 3. The item name and the PLC signal are associated one-to-one.
Second part data 42 is part data of the second rectangle that is the second part. The second part identifier is “part number 2.” A second attribute identifier is “display color 1.” Second display information indicates, “When the PLC signal is 0, the part color is changed to gray and when the PLC signal is 1, the part color is changed to green.” In addition, an item name “G1_2SL1” is an identifier that is obtained by combining “G1” indicating the screen identifier of the HMI screen, “2” indicating the part number 2, and “SL1” indicating the display color 1. “G1_2SL1” is a signal name corresponding to signal data (PLC signal) that is transmitted from the monitor control system 4 to the SCADA web HMI execution device 3.
The part data editing processing 13 in
In addition, the engineering tool 10 integrates item names which are assigned to parts on the HMI screen of the HMI subsystem, thereby being able to execute integration processing 16 for a reduction in the number of PLC signals, an improvement in engineering efficiency and an improvement in runtime performance.
Integration processing 16 in
Integratable parts are only display parts which change their display states according to a PLC signal transmitted from the monitor control system 4 (PLC) to the SCADA web HMI execution device 3 (HMI subsystem). The display parts each has, as an attribute related to an appearance of the part, any of “display color,” “non-display,” “width/height,” “position,” and “rotation;” and has, as a type of an attribute value, any of “Boolean,” “integer,” and “floating point number.”
Integratable parts are display parts, which are parts having an identical attribute identifier. For example, in
In a description below, the description will be made on an assumption that the first part and the second part are to be integrated, for easy description; however, three or more parts may be integrated.
With reference to
The integration processing 16 in
The integrated part identifier generation processing 17 newly generates, when the first attribute identifier of the first part data 41 and the second attribute identifier of the second part data 42 are an identical attribute identifier, an integrated part identifier.
For example, the first attribute identifier “display color 1” of the first part data 41 and the second attribute identifier “display color 1” of the second part data 42 in
The part data change processing 18 changes the first part identifier of the first part data 41 and the second part identifier of the second part data 42 to the integrated part identifier.
For example, the part data change processing 18 changes the first part identifier “part number 1” of the first part data 41 in
The integrated item name generation processing 19 generates an integrated item name in which the screen identifier of the HMI screen, the integrated part identifier, and the identical attribute identifier are combined.
In an example shown in
Thus, two item names “G1_1SL1” and “G1_2SL1” in
First, in step S100 in
In step S101, the HMI screen designer changes display information of the part data according to the HMI screen specifications of the monitor control target plant. For example, as for display information of the attribute identifier “display color,” the display color of a part when an attribute value (PLC signal value) is 0, the display color of the part when the attribute value (PLC signal value) is 1, and the presence or absence of a flicker attribute are changed.
In step S102, the HMI screen designer selects target parts of the integration processing by using range specification 112 in
In step S103, the engineering tool 10 executes an integration processing subroutine shown in
First, in step S104, the integration processing 16 determines whether the selected parts are integratable parts. The integratable parts refer to display parts which change their display states according to a PLC signal transmitted from the monitor control system 4 (PLC) to the SCADA web HMI execution device 3 (HMI subsystem). If the selected parts are integratable parts, a determination condition is established. If the determination condition is established, an advance to step S105 is made.
At step S105, whether or not two or more parts are being selected is determined. If two or more parts are being selected, a determination condition is established. If the determination condition is established, an advance to step S106 is made.
At step S106, the engineering tool 10 groups a plurality of parts.
At step S107, separately from the part data of original parts (first part, second part), part data of an integrated part is newly generated.
At step S108, attributes of the parts are given to the integrated part.
At step S109, a new part number is assigned. A new integrated part identifier “part number 11” is assigned to the part data of the integrated part.
At step S110, the part numbers of the original parts (first part, second part) are changed to 11.
If the determination condition in processing at step S104 or step S105 in the above description is not established, the engineering tool 10 displays on the display 1c, at step S111, to the effect that the selected parts cannot be integrated.
After step S110 or step S111, the integration processing subroutine in
According to the integration processing 16 described above, the part data in
After the routine in
The web HMI data generation processing 14 in
The web HMI data generation processing 14 generates the web HMI data 2. The web HMI data 2 includes static display attribute data 21 and runtime attribute data 22. The static display attribute is information that does not cause the appearance of a part to be changed irrespective of a value of a received PLC signal. An example is part arrangement information (shape, position, size, and the like). A runtime attribute is information for changing the appearance of a part according to a value of a received PLC signal and a script (program) that can be executed on the web browser 32. Examples are a dynamic display attribute of a part and a signal data processing algorithm.
The static display attribute data 21 is data in which the arrangement information of the first part, the arrangement information of the second part, and the integrated item name which are described above are associated. The static display attribute data is data in the Scalable Vector Graphics (SVG) format and includes, as an attribute of an SVG element, arrangement information (shape, position, and size) of a part.
The static display attribute data 21 that is generated from the part data exemplified in
The runtime attribute data 22 is data in which the integrated item name, the first display information of the first part, the second display information of the second part, and a script are associated. As described above, the “display information” is information that defines a display state of the part which corresponds to an attribute value assigned to the attribute identifier. The script is a JavaScript (registered trademark) program defined for each part type. The script can be executed on the web browser 32 by applying runtime attribute data (item name and display information) as a setting parameter. The script changes the display states of the first part and the second part according to a PLC signal received from the monitor control system 4.
The runtime attribute data 22 that is generated from the part data exemplified in
The script included in the runtime attribute data 22 will be described. In an example in
The script functions as a script of the first part by applying the integrated item name “G1_11SL1_1” and the first display information as setting parameters. The script of the first part operates on the web browser 32 described later; and when a value of the PLC signal is 0 (attribute value is 0), changes the display color of the first part to gray and when a value of the PLC signal is 1 (attribute value is 1), changes the display color of the first part to red.
In addition, the script functions as a script of the second part by applying the integrated item name “G1_11SL1_1” and the second display information as setting parameters. The script of the second part operates on the web browser 32 described later; and when a value of the PLC signal is 0 (attribute value is 0), changes the display color of the second part to gray and when a value of the PLC signal is 1 (attribute value is 1), changes the display color of the second part to green.
The device list generation processing 15 in
The device list generation processing 15 generates, for each part, the device list 23 that is a list of data in which item names and PLC signals are associated. In the device list 23, item names and PLC signals (PLC addresses for receiving the PLC signals) are associated in a one-to-one relation. The device list is read by the web server 31 and is used for transmitting and receiving a signal between the web browser 32 and the monitor control system 4.
In the example in
Returning to
As described above, the SCADA web HMI execution device 3 executes the web server 31 and the web browser 32.
The web server 31 reads the web HMI data 2 and the device list 23. The web server 31 reads the web HMI data 2 and arranges the static display attribute data 21 and the runtime attribute data 22 as HMI web runtime contents. The web server 31 reads the device list 23 and sets a state in which a signal can be transmitted and received between the web browser 32 and the monitor control system 4.
Processing of the HMI server runtime 311 that operates on the web server 31 is as follows:
With reference to
The static display processing reads the static display attribute data 21 that is drawing data in the SVG format from the web server 31, and displays an HMI screen. On the HMI screen, the first part and the second part in
The dynamic display processing reads the runtime attribute data 22; and when a received PLC signal corresponds to the integrated item name, updates the display state of the first part based on the first display information and updates the display state of the second part based on the second display information according to a value of the received PLC signal by using a script in which the integrated item name, the first display information, and the second display information are applied as setting parameters.
A script can be executed on the web browser 32 by applying an item name and display information as setting parameters. In the example in
The script changes the display states of the first part and the second part according to the PLC signal received from the monitor control system 4. As shown in
An example in which the integration processing 16 described above is applied to the power transformation control system will be described with reference to
Therefore, adjacent display parts having an identical display color attribute are grouped into four groups as in
Thus, by combinations of four PLC signals associated with four integrated item names, four color change patterns, the power transformation control circuit diagram for which is shown in
Thus, according to the SCADA web HMI system of the present embodiment, by integrating signals assigned to parts on the HMI screen, the number of PLC signals is reduced, and an improvement in engineering efficiency and an improvement in runtime performance can be achieved.
Incidentally, in the system of the first embodiment described above, the web server 31 and the web browser 32 are executed on an identical computer; however, it is not limited thereto. A plurality of web browsers 32 may be connected to one web server 31. Therefore, the web server 31 and the web browser 32 may be operated on different computers. In this respect, embodiments below are also the same.
In addition, in the system of the first embodiment described above, drawing data in the SVG format is used; however, the drawing data is not limited thereto. If the web browser 32 is compliant with WebGL, drawing data may be in a format compliant with Web GL.
A hardware configuration of a main part of the SCADA web HMI system will be described with reference to
Processes of the SCADA web HMI design device 1 shown in
Processes of the SCADA web HMI execution device 3 shown in
Next, a second embodiment of the present invention will be described with reference to
In the first embodiment described above, one color rule is defined for one part. However, a plurality of color rules can also be defined for one part. In the present embodiment, parts for which a plurality of color rules are defined are integrated.
First part data A51 is part data defining a first color rule of the first part. A first part identifier is “part number 1.” A first attribute identifier A is “display color 1.” First display information A indicates, “When the PLC signal is 0, the part color is changed to gray and when the PLC signal is 1, the part color is changed to red.” In addition, an item name “G1_1SL1” is an identifier that is obtained by combining “G1” indicating the screen identifier of the HMI screen, “1” indicating the part number 1, and “SL1” indicating the display color 1.
First part data B52 is part data defining a second color rule of the first part. The first part identifier is “part number 1.” A first attribute identifier B is “display color 2.” First display information B indicates, “When the PLC signal is 1, the part color is changed to orange.” In addition, an item name “G1_1SL2” is an identifier that is obtained by combining “G1” indicating the screen identifier of the HMI screen, “1” indicating the part number 1, and “SL2” indicating the display color 2.
Second part data A53 is part data defining a first color rule of the second part. A second part identifier is “part number 2.” A second attribute identifier A is “display color 1.” Second display information A indicates, “When the PLC signal is 0, the part color is changed to gray and when the PLC signal is 1, the part color is changed to green.” In addition, an item name “G1_2SL1” is an identifier that is obtained by combining “G1” indicating the screen identifier of the HMI screen, “2” indicating the part number 2, and “SL1” indicating the display color 1.
Second part data B54 is part data defining a second color rule of the second part. The second part identifier is “part number 2.” A second attribute identifier B is “display color 2.” Second display information B indicates, “When the PLC signal is 1, the part color is changed to blue.” In addition, an item name “G1_2SL2” is an identifier that is obtained by combining “G1” indicating the screen identifier of the HMI screen, “2” indicating the part number 2, and “SL2” indicating the display color 2.
Second part data C55 is part data defining a third color rule of the second part. The second part identifier is “part number 2.” A second attribute identifier C is “display color 3.” Second display information C indicates, “When the PLC signal is 1, the part color is changed to purple.” In addition, an item name “G1_2SL3” is an identifier that is obtained by combining “G1” indicating the screen identifier of the HMI screen, “2” indicating the part number 2, and “SL3” indicating the display color 3.
With reference to
The integration processing 16 is executed with the first part and the second part selected.
The first attribute identifier “display color 1” of the first part data A51 and the second attribute identifier “display color 1” of the second part data A53 in
The part data change processing 18 changes the first part identifier “part number 1” of the first part data AM and the second part data B52 in
The integrated item name generation processing 19 generates, based on the first part data A51 and the second part data A53, an integrated item name “G1_11SL1” in which the screen identifier “G1” of the HMI screen, “11” indicating the integrated part identifier “part number 11,” and “SL1” indicating the identical attribute identifier “display color 1” are combined.
In addition, the integrated item name generation processing 19 generates, based on the first part data B52 and the second part data B54, an integrated item name “G1_11SL2” in which the screen identifier “G1” of the HMI screen, “11” indicating the integrated part identifier “part number 11,” and “SL2” indicating an identical attribute identifier “display color 2” are combined.
In addition, the integrated item name generation processing 19 generates, based on the second part data C55, an integrated item name “G1_11SL3” in which the screen identifier “G1” of the HMI screen, “11” indicating the integrated part identifier “part number 11,” and “SL3” indicating an attribute identifier “display color 3” are combined.
According to the integration processing described above, five item names shown in
An example shown in
In this case, a color rule indicating a voltage class signal is added to the transformers as a second color rule. The color rule indicating a voltage class signal has a higher priority order than a color rule indicating an ON/OFF signal. Therefore, when a voltage class signal is ON and an ON/OFF signal is ON, a higher priority is given to a color rule indicating the voltage class signal. The color rule indicating a voltage class signal is defined only for the drawing parts of transformers (407, 408, 413, 414).
For a color rule that is to be added to the parts of higher voltage class transformers (407, 413), purple is assigned; and for a color rule that is to be added to parts of lower voltage class transformers (408, 414), light blue is assigned.
For color rules of an integrated group, two PLC signals are assigned; however, display parts other than transformers have only one color rule and therefore, are not affected by a value of a second PLC signal.
As in
Next, a third embodiment of the present invention will be described with reference to
In the first embodiment described above, a case in which when a part attribute is set as a display color, the display color is changed has been described. However, the part attribute is not limited thereto. In the third embodiment, a description will be given by using an animation attribute as an example.
As described above, in conventional SCADA, it has been required for this drawing that five PLC signals are provided and each value of the signals is controlled by a PLC logic. When integration is performed by using the integration processing 16 in the first embodiment described above, these PLC signals are integrated into two PLC signals. By values of this two signals, the following animation can be realized.
In the system of the present embodiment, an animation attribute can also be given to an integrated part. An integrated part 66 is a part obtained by grouping all the tire parts and vehicle body parts. In an example in
When three PLC signals shown by patterns (a) to (d) shown in a lower table in
In an example shown in
On the other hand, when the PLC signals are integrated by using an integration function of the present embodiment, even if the number of drawing parts constituting a vehicle body and tires of a vehicle is changed, the PLC logic is not affected. Productivity is increased and the number of signals is reduced; and therefore, improvement in communication performance at an execution time can also be expected.
The embodiments according to the present invention have been described above; however, the present invention is not limited to the above embodiments and various modifications can be made without departing from the scope of the present invention.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2019/046195 | 11/26/2019 | WO | 00 |