The field of the invention relates to automation environments, and in particular, to managing software updates in an automation environment.
Industrial plants with automated systems often have numerous machines that perform various tasks. These machines may be controlled and/or monitored by computerized controllers and/or data loggers. A single computer may monitor or control a single machine. Alternatively, a single computer may control or monitor multiple machines. When monitoring or controlling a machine, these computers may exchange status and control data with a central information system. Thus, the central information system can track or control the status of individual machines, or control and track many machines at the plant level.
An operator may use a specialized computer called an operator interface terminal to control or monitor an individual machine. The operator provides control inputs to the operator interface terminal, and the operator interface terminal processes the control inputs to transfer a corresponding control signal to the machine. The machine operates in response to the control signal. The operator interface terminal may also receive status data from the machine and may transmit that data to a central server.
In a large automation environment (e.g. a plant or factory), there may be tens, hundreds, or even thousands of operator interface terminals, central information systems, or other automation computers. Collectively, and for the sake of brevity, these will be referred to herein as automation computers.
These automation computers run software installed on them which instructs them in the various tasks involved with controlling and monitoring their respective machines. Examples of such software are RS-View™, RSlogix™, and Factory Talk™ developed by Rockwell Automation.
From time to time, some or all of these automation computers may need one or more software updates or installations. These software installations may be developed by an external software provider, such as Rockwell Automation, or may be internally developed software or configuration changes.
Unfortunately, these software installations may require that the automation computer, or the machine it is associated with, be shut down or otherwise inactivated to perform the installation. This may result in a total or partial shutdown of production in the automation environment. To compound the problem, modern automation environment efficiency may dictate that at least a portion of the automation environment is always in operation. In other words, it may not be economically efficient to shut down the entire plant or a manufacturing line or process to perform software installations on the automation computers. Also, there may not be enough or any IT personnel, 3rd party provider or service personnel, or other critical resources available to install software on the automation computers in a plant or on a manufacturing line during a scheduled shutdown period.
In some embodiments of the invention, a scheduling computer receives a first schedule that contains a time that a new or different version of a software program will be available. The scheduling computer also receives a second schedule that contains at least one time period that the machine controlled or monitored by the automation computer will be inactive. The scheduling computer also receives a third schedule that contains at least one time period that a necessary resource (such as, but not limited to, certain personnel) will be available to perform a software installation on the automation computer. The scheduling computer then compares the three schedules to determine the time or times when the necessary resource is available, the new or different version of the software is available, and the machine controlled or monitored by the automation computer is inactive. The scheduling computer then displays these times or time so that software may be installed on the automation computer without disrupting the manufacturing process or inefficiently halting a machine performing a manufacturing step.
In some embodiments of the invention, a scheduling computer also compares the inactivity schedule of at least one more machine being controlled or monitored by a different automation computer. In this case, the scheduling computer displays by using different indicia (such as, but not limited to, color) the times or time when each automation computer may advantageously receive a software installation and when multiple computers may receive a software installation at substantially the same time.
Automation computers 111-113 store and execute software installed on them which instructs them in the various tasks involved with controlling and monitoring their respective machines 101-103. Examples of such software are RS-View™, RSlogix™, and Factory Talk™ developed by Rockwell Automation. Other monitoring or controlling software may also be stored and executed on automation computers 111-113.
Automation environment 100 also includes necessary resources 160. Examples of such necessary resources are IT or 3rd party provider or service personnel 161, or a master distribution disc 162 or other memory device, or another machine (e.g. a substitute for an inactive machine on the production line) or computer 163 necessary to perform a software installation on a particular automation computer. Computer 163 may also be networked to automation computers 111-113 and capable of distributing or installing software 171 automatically or according to a schedule determined by an embodiment of the invention.
Automation computers 111-113 may comprise human-machine interfaces that allow human operators to control machines 101-103. An example of an automation computer is the PanelView™ product line from Rockwell Automation. Other automation computers are possible. Automation computers 111-113 receive control inputs from their human operators and transfer corresponding control signals 131-133 to machines 101-103, respectively. For example, a human operator may input an instruction to automation computer 111 to increase the speed of machine 101. In response, automation computer 111 would transfer a control signal 131 to machine 101 that causes machine 101 to increase its speed. Because automation computer 111 and machine 101 transfer control signals or data between them, machine 101 is said to be associated with automation computer 111.
Automation computers 111-113 also receive data signals 141-143 from respective machines 101-103. Data signals 141-143 may indicate the status of respective machines 101-103. For example, data signals 141-143 could indicate the speeds of respective machines 101-103 every 5 seconds. Automation computers 111-113 may also record the data from data signals 141-143.
Automation computers 111-113 may display this data to their human operators. For example, automation computer 111 may receive data signal 141 indicating the current speed of machine 101. In response, terminal 111 would display that current speed along with other data it knows or has collected.
Periodically, automation computers 111-113 may transfer data 151-153 to another automation computer known as a central information system 120. Data 151-153 may indicate the data that was recorded by automation computers 111-113 based on data signals 141-143. Thus, data 151-153 may indicate the data produced by machines 101-103. Data 151-153 may also indicate other information contained in or known by automation computers 111-113 such as, but not limited to, the operational status (e.g. on or off, active or inactive, fast or slow) of machines 101-103, respectively, or the operational schedule of machines 101-103. Central information system 120 may record the machine data for all machines 101-103.
For example, every ten minutes, automation computer 111 may transfer data to central information system 120 indicating the speed of machine 101 at five second intervals for the past ten minutes. Automation computers 112-113 may do the same for machines 102-103. Central information system 120 may then record this data and may generate a single graph comparing the speeds of machines 101-103 over the last ten minutes. Central information system 120 could run enterprise historian software, such as the RSBizWare™ Historian™ software from Rockwell Automation, to collect and record the data. Other enterprise historian software is possible.
In a step 204, the software, machine, and resource schedules are compared to determine times when the software will be available to install, a machine or machines will be inactive, and certain resources necessary to install the software will all be available. In a step 206, the time or times when the software will be available to install, a machine or machines will be inactive, and certain resources necessary to install the software will all be available are displayed. In an alternative embodiment, the software would be installed on an automation computer or computers associated with the inactive machine or machines according to when the software will be available to install, a machine or machines will be inactive, and certain resources necessary to install the software will all be available. This software installation may be performed automatically using a necessary resource such as computer 163 or central information system 120 or any other computer that is networked to automation computers 111, 112, or 113. Alternatively, the software installation may also be performed manually using necessary resources such as master distribution disc 162 or personnel 161.
Operator interface 201 receives inputs from a human operator and transfers corresponding user instructions to processing circuitry 204. Operator interface 201 receives display information from processing circuitry 204 and displays the information to the human operator. Operator interface 201 may comprise a touch screen, keypad, display, speaker, microphone, control buttons, joystick, control switches, or some other user interface. Operator interface 201 may be a single device or be distributed among multiple devices.
Machine interface 202 receives control information from processing circuitry 204 and transfers a corresponding control signal 131 to machine 101. Machine interface 202 receives data signal 141 from machine 101 and transfers corresponding data to processing circuitry 204. Machine interface 202 may exchange signals 131 and 141 with machine 101 over wireless, metallic, optical, or some other data transmission media. Machine interface 202 may comprise a transceiver, port, antenna, circuitry, or some other communication components. Machine interface 202 may use Ethernet, Internet Protocol, Wireless Fidelity, or some other communication protocol. Machine interface 202 may be a single device or be distributed among multiple devices.
In the case of automation computers 111-112, central information system interface 203 may receive or send data 208 from processing circuitry 204 and may exchange data 151 with central information system 120. Central information system interface 203 may exchange data 151 with central information system 120 over wireless, metallic, optical, or some other data transmission media. Central information system interface 203 comprises a transceiver, port, antenna, circuitry, or some other communication components. Central information system interface 203 may use Ethernet, Internet Protocol, Wireless Fidelity, or some other communication protocol. Central information system interface 203 may be a single device or be distributed among multiple devices.
In the case of automation computer 120, the central information system interface 203 may receive or send data 208 from processing circuitry 204 and may exchange data 151 with the other automation computers 111-113. Central information system interface 203 may exchange data 151 with automation computers 111-113 over wireless, metallic, optical, or some other data transmission media. Central information system interface 203 comprises a transceiver, port, antenna, circuitry, or some other communication components. Central information system interface 203 may use Ethernet, Internet Protocol, Wireless Fidelity, or some other communication protocol. Central information system interface 203 may be a single device or be distributed among multiple devices.
Processing circuitry 204 receives user instructions from operator interface 201. Processing circuitry 204 processes the user instructions to transfer corresponding control information to machine interface 202. Processing circuitry 204 receives data from machine interface 202. Processing circuitry 204 may correlate the data to time and date to form data 208 and transfer data 208 to storage system 205. Processing circuitry may also process data 208 to generate display information indicating, for example, the data plotted against time. Processing circuitry may also transfer the display information to operator interface 201. Periodically, processing circuitry may retrieve data 208 from storage system 205 and transfer data 208 to central information system interface 203. Processing circuitry may receive data 208 from central information system interface 203 and transfer data 208 or software 207 to storage system 205.
Processing circuitry 204 retrieves and executes software 207 from storage system 205. Software 207 may comprise an operating system, utilities, drivers, networking software, application programs, firmware, or some other form of machine-readable processing instructions. When executed by processing circuitry 204, software 207 directs processing circuitry 204 to operate as described herein. Processing circuitry 204 may comprise a microprocessor, logic circuitry, computer, or some other processing device. Processing circuitry 204 may be distributed among multiple devices.
Storage system 205 may comprise a memory device, such as a disk, flash memory circuitry, or some other machine-readable memory apparatus. Storage system 205 may be distributed among multiple devices. Portions of storage system 205 may contain software configured to cause automation computer 111 to perform steps of an embodiment of the invention. Likewise, portions of software 207 may be configured with steps of an embodiment of the invention. Portions of storage system 205 may be external to automation computer 111 in some embodiments. For example, a memory device that is external to automation computer 111 may store application software that is subsequently transferred into automation computer 111 to form a portion of software 207.
From time to time, new or different versions of software 207 may become available. This new software or different version may contain increased or improved functionality, new configurations, bug fixes, or may be less expensive to license or use. When new software or a different version of software 207 becomes available from the producer of such software 207, it may be desirable to install that new or different version on one or more of automation computers 111-113, 120. However, because, for example, automation computer 111 may be actively controlling or monitoring machine 101, and installing software 207 may cause or require that automation computer 111 interrupt its controlling or monitoring of at least one machine 101, and such interruption may cause undesirable effects such as data loss, equipment malfunction, or a safety hazard, installing software 207 as soon as a new or different version of software 207 is available may be undesirable. In addition, the resources necessary to install software 207 may also not be available at the same time the new software or different version is first available so that installing software 207 immediately after the new software or different version is available may be impossible.
In the case of
To illustrate step 608 by way of example, consider the schedules shown in
In a step 610, the results of the comparison produced in step 608 are displayed.
In
In a step 906, a second machine active/inactive schedule is received. An exemplary illustration of a machine active/inactive schedule is shown in
In a step 908, the software version schedule, first machine active/inactive schedule, and the second machine active/inactive schedule are compared to find at least one time when a new or different version of the software is available, the machine associated with a first automation computer is inactive, and the machine associated with a second automation computer is inactive. In an alternative embodiment, the software version schedule, first machine active/inactive schedule, the second machine active/inactive schedule, and a necessary resource schedule are compared to find at least one time when a new or different version of the software is available, the machine associated with a first automation computer is inactive, the machine associated with a second automation computer is inactive, and a necessary resource is available.
To illustrate step 908 by way of example, consider the schedules shown in
The comparison in step 908 also examines the second machine active/inactive schedule exemplified by
In a step 910, the results of the comparison produced in step 908 are displayed.
In
The above description and associated figures teach the best mode of the invention. The following claims specify the scope of the invention. Note that some aspects of the best mode may not fall within the scope of the invention as specified by the claims. Those skilled in the art will appreciate that the features described above can be combined in various ways to form multiple variations of the invention. As a result, the invention is not limited to the specific embodiments described above, but only by the following claims and their equivalents.