The subject matter disclosed herein relates generally to industrial automation systems, and, for example, to high-level or redundant control of such automation systems.
The following presents a simplified summary in order to provide a basic understanding of some aspects described herein. This summary is not an extensive overview nor is intended to identify key/critical elements or to delineate the scope of the various aspects described herein. Its sole purpose is to present some concepts in a simplified form as a prelude to the more detailed description that is presented later.
In one or more embodiments, a system for performing remote industrial automation operation is provided, comprising a device interface component configured to collect device data from industrial devices at one or more industrial facilities and store the device data on cloud-based storage of a cloud platform; and a control component configured to execute a control program on the cloud platform using the device data as program variables, wherein the device interface component is further configured to send control instructions to at least one of the industrial devices based on outputs generated by the control program.
Also, one or more embodiments provide a method for remotely operating one or more industrial automation systems, comprising collecting, by a system comprising at least one processor, device data from industrial devices deployed at one or more industrial facilities; storing, by the system, the device data on cloud-based storage of a cloud platform; processing, by the system, the device data using a control program that executes on the cloud platform; and sending, by the system, a control instruction to at least one of the industrial devices based on outputs generated by the control program.
Also, according to one or more embodiments, a non-transitory computer-readable medium is provided having stored thereon instructions that, in response to execution, cause a system to perform operations, the operations comprising collecting device data from industrial devices deployed at one or more industrial facilities; storing the device data on cloud-based storage of a cloud platform; executing a control program on the cloud platform that uses the device data as program inputs; and sending a control instruction to at least one of the industrial devices based on outputs generated by the control program.
To the accomplishment of the foregoing and related ends, certain illustrative aspects are described herein in connection with the following description and the annexed drawings. These aspects are indicative of various ways which can be practiced, all of which are intended to be covered herein. Other advantages and novel features may become apparent from the following detailed description when considered in conjunction with the drawings.
The subject disclosure is now described with reference to the drawings, wherein like reference numerals are used to refer to like elements throughout. In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding thereof. It may be evident, however, that the subject disclosure can be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to facilitate a description thereof.
As used in this application, the terms “component,” “system,” “platform,” “layer,” “controller,” “terminal,” “station,” “node,” “interface” are intended to refer to a computer-related entity or an entity related to, or that is part of, an operational apparatus with one or more specific functionalities, wherein such entities can be either hardware, a combination of hardware and software, software, or software in execution. For example, a component can be, but is not limited to being, a process running on a processor, a processor, a hard disk drive, multiple storage drives (of optical or magnetic storage medium) including affixed (e.g., screwed or bolted) or removable affixed solid-state storage drives; an object; an executable; a thread of execution; a computer-executable program, and/or a computer. By way of illustration, both an application running on a server and the server can be a component. One or more components can reside within a process and/or thread of execution, and a component can be localized on one computer and/or distributed between two or more computers. Also, components as described herein can execute from various computer readable storage media having various data structures stored thereon. The components may communicate via local and/or remote processes such as in accordance with a signal having one or more data packets (e.g., data from one component interacting with another component in a local system, distributed system, and/or across a network such as the Internet with other systems via the signal). As another example, a component can be an apparatus with specific functionality provided by mechanical parts operated by electric or electronic circuitry which is operated by a software or a firmware application executed by a processor, wherein the processor can be internal or external to the apparatus and executes at least a part of the software or firmware application. As yet another example, a component can be an apparatus that provides specific functionality through electronic components without mechanical parts, the electronic components can include a processor therein to execute software or firmware that provides at least in part the functionality of the electronic components. As further yet another example, interface(s) can include input/output (I/O) components as well as associated processor, application, or Application Programming Interface (API) components. While the foregoing examples are directed to aspects of a component, the exemplified aspects or features also apply to a system, platform, interface, layer, controller, terminal, and the like.
As used herein, the terms “to infer” and “inference” refer generally to the process of reasoning about or inferring states of the system, environment, and/or user from a set of observations as captured via events and/or data. Inference can be employed to identify a specific context or action, or can generate a probability distribution over states, for example. The inference can be probabilistic—that is, the computation of a probability distribution over states of interest based on a consideration of data and events. Inference can also refer to techniques employed for composing higher-level events from a set of events and/or data. Such inference results in the construction of new events or actions from a set of observed events and/or stored event data, whether or not the events are correlated in close temporal proximity, and whether the events and data come from one or several event and data sources.
In addition, the term “or” is intended to mean an inclusive “or” rather than an exclusive “or.” That is, unless specified otherwise, or clear from the context, the phrase “X employs A or B” is intended to mean any of the natural inclusive permutations. That is, the phrase “X employs A or B” is satisfied by any of the following instances: X employs A; X employs B; or X employs both A and B. In addition, the articles “a” and “an” as used in this application and the appended claims should generally be construed to mean “one or more” unless specified otherwise or clear from the context to be directed to a singular form.
Furthermore, the term “set” as employed herein excludes the empty set; e.g., the set with no elements therein. Thus, a “set” in the subject disclosure includes one or more elements or entities. As an illustration, a set of controllers includes one or more controllers; a set of data resources includes one or more data resources; etc. Likewise, the term “group” as utilized herein refers to a collection of one or more entities; e.g., a group of nodes refers to one or more nodes.
Various aspects or features will be presented in terms of systems that may include a number of devices, components, modules, and the like. It is to be understood and appreciated that the various systems may include additional devices, components, modules, etc. and/or may not include all of the devices, components, modules etc. discussed in connection with the figures. A combination of these approaches also can be used.
Industrial controllers and their associated I/O devices are central to the operation of modern automation systems. These controllers interact with field devices on the plant floor to control automated processes relating to such objectives as product manufacture, material handling, batch processing, supervisory control, and other such applications. Industrial controllers store and execute user-defined control programs to effect decision-making in connection with the controlled process. Such programs can include, but are not limited to, ladder logic, sequential function charts, function block diagrams, structured text, or other such platforms.
Industrial devices 120 may include both input devices that provide data relating to the controlled industrial systems to the industrial controllers 118, and output devices that respond to control signals generated by the industrial controllers 118 to control aspects of the industrial systems. Example input devices can include telemetry devices (e.g., temperature sensors, flow meters, level sensors, pressure sensors, etc.), manual operator control devices (e.g., push buttons, selector switches, etc.), safety monitoring devices (e.g., safety mats, safety pull cords, light curtains, etc.), and other such devices. Output devices may include motor drives, pneumatic actuators, signaling devices, robot control inputs, valves, and the like.
Industrial controllers 118 may communicatively interface with industrial devices 120 over hardwired or networked connections. For example, industrial controllers 118 can be equipped with native hardwired inputs and outputs that communicate with the industrial devices 120 to effect control of the devices. The native controller I/O can include digital I/O that transmits and receives discrete voltage signals to and from the field devices, or analog I/O that transmits and receives analog voltage or current signals to and from the devices. The controller I/O can communicate with a controller's processor over a backplane such that the digital and analog signals can be read into and controlled by the control programs. Industrial controllers 118 can also communicate with industrial devices 120 over a network using, for example, a communication module or an integrated networking port. Exemplary networks can include the Internet, intranets, Ethernet, DeviceNet, ControlNet, Data Highway and Data Highway Plus (DH/DH+), Remote I/O, Fieldbus, Modbus, Profibus, wireless networks, serial protocols, and the like. The industrial controllers 118 can also store persisted data values that can be referenced by the control program and used for control decisions, including but not limited to measured or calculated values representing operational states of a controlled machine or process (e.g., tank levels, positions, alarms, etc.) or captured time series data that is collected during operation of the automation system (e.g., status information for multiple points in time, diagnostic occurrences, etc.). Similarly, some intelligent devices—including but not limited to motor drives, instruments, or condition monitoring modules—may store data values that are used for control and/or to visualize states of operation. Such devices may also capture time-series data or events on a log for later retrieval and viewing.
Industrial automation systems often include one or more human-machine interfaces (HMIs) 114 that allow plant personnel to view telemetry and status data associated with the automation systems, and to control some aspects of system operation. HMIs 114 may communicate with one or more of the industrial controllers 118 over a plant network 116, and exchange data with the industrial controllers to facilitate visualization of information relating to the controlled industrial processes on one or more pre-developed operator interface screens. HMIs 114 can also be configured to allow operators to submit data to specified data tags or memory addresses of the industrial controllers 118, thereby providing a means for operators to issue commands to the controlled systems (e.g., cycle start commands, device actuation commands, etc.), to modify setpoint values, etc. HMIs 114 can generate one or more display screens through which the operator interacts with the industrial controllers 118, and thereby with the controlled processes and/or systems. Example display screens can visualize present states of industrial systems or their associated devices using graphical representations of the processes that display metered or calculated values, employ color or position animations based on state, render alarm notifications, or employ other such techniques for presenting relevant data to the operator. Data presented in this manner is read from industrial controllers 118 by HMIs 114 and presented on one or more of the display screens according to display formats chosen by the HMI developer. HMIs may comprise fixed location or mobile devices with either user-installed or pre-installed operating systems, and either user-installed or pre-installed graphical application software.
Some industrial environments may also include other systems or devices relating to specific aspects of the controlled industrial systems. These may include, for example, a data historian 110 that aggregates and stores production information collected from the industrial controllers 118 or other data sources, or a device documentation store 104 containing electronic documentation for the various industrial devices making up the controlled industrial systems. Other systems may include an inventory tracking system 102, a work order management system 106, repositories for machine or process drawings and documentation, vendor product documentation storage, vendor knowledgebases, internal knowledgebases, work scheduling applications, or other such systems, some or all of which may reside on an office network 108 of the industrial environment.
Many industrial enterprises distribute their operations across multiple geographically diverse plant facilities. While some or all of these distributed plant facilities may be designed to carry out respective industrial operations in the service of common high-level goals of the larger industrial enterprise, daily operations of the industrial automation systems at each facility are typically carried out substantially independently of one another due to the lack of information connectivity between geographically diverse systems, even though the high-level goals of the industrial enterprise may be better served through more coordinated operation between the automation systems.
Moreover, some industrial systems are located in remote environments that cannot be easily accessed, such as oil rigs, certain waste water facilities, automation systems associated with mining operations, or other such environments. Because of the limited accessibility to these remote environments, implementing control program changes or control system maintenance for automation systems in such areas is challenging.
To address these and other issues, one or more embodiments of the present disclosure provide a cloud-based remote industrial automation site operation system that leverages the wide array of configuration and operational data generated by the industrial assets of an industrial enterprise to facilitate remote industrial automation site operation. According to one or more embodiments, selected sets of operational data generated by one or more industrial assets (e.g., industrial controllers or other such devices) is migrated to a cloud platform that executes remote site operation services, which performs substantially real-time control functions for one or more plant-side automation systems from the cloud platform. By transferring some or all control functions to the cloud platform, which is accessible from multiple plant facilities, the cloud-based services can allow geographically diverse industrial systems to be collectively controlled together using a centralized, cloud-based virtual controller. The cloud-based system can also provide control backup services, allowing control of important automation systems to be switched from a local controller to the cloud-based control in the event of a failure at the local controller.
Example automation systems can include one or more industrial controllers that facilitate monitoring and control of their respective processes. The controllers exchange data with the field devices using native hardwired I/O or via a plant network such as Ethernet/IP, Data Highway Plus, ControlNet, Devicenet, or the like. A given controller typically receives any combination of digital or analog signals from the field devices indicating a current state of the devices and their associated processes (e.g., temperature, position, part presence or absence, fluid level, etc.), and executes a user-defined control program that performs automated decision-making for the controlled processes based on the received signals. The controller then outputs appropriate digital and/or analog control signaling to the field devices in accordance with the decisions made by the control program. These outputs can include device actuation signals, temperature or position control signals, operational commands to a machining or material handling robot, mixer control signals, motion control signals, and the like. The control program can comprise any suitable type of code used to process input signals read into the controller and to control output signals generated by the controller, including but not limited to ladder logic, sequential function charts, function block diagrams, structured text, or other such platforms.
Although the example overview illustrated in
According to one or more embodiments of this disclosure, industrial devices 208 and 210 can be coupled to a cloud platform to leverage cloud-based applications. That is, the industrial device 208 and 210 can be configured to discover and interact with cloud-based computing services 212 hosted by cloud platform 202. Cloud platform 202 can be any infrastructure that allows shared computing services 212 to be accessed and utilized by cloud-capable devices. Cloud platform 202 can be a public cloud accessible via the Internet by devices having Internet connectivity and appropriate authorizations to utilize the services. Alternatively, cloud platform 202 can be a private cloud operated internally by the enterprise. An example private cloud can comprise a set of servers hosting the cloud services 212 and residing on a corporate network protected by a firewall.
Cloud services 212 can include, but are not limited to, data storage, data analysis, control applications (e.g., applications that can generate and deliver control instructions to industrial devices 208 and 210 based on analysis of near real-time system data or other factors), visualization applications such as cloud-based HMIs, reporting applications, Enterprise Resource Planning (ERP) applications, notification services, or other such applications. If cloud platform 202 is a web-based cloud, industrial devices 208 and 210 at the respective industrial facilities 204 may interact with cloud services 212 via the Internet. In an exemplary configuration, industrial devices 208 and 210 may access the cloud services 212 through separate cloud gateway devices 206 at the respective industrial facilities 204, where the industrial devices 208 and 210 connect to the cloud gateway devices 206 through a physical or wireless local area network or radio link. In another exemplary configuration, the industrial devices may access the cloud platform directly using an integrated cloud interface.
Providing industrial devices with cloud capability can offer a number of advantages particular to industrial automation. For one, cloud-based storage offered by the cloud platform can be easily scaled to accommodate the large quantities of data generated daily by an industrial enterprise. Moreover, multiple industrial facilities at different geographical locations can migrate their respective automation data to the cloud for aggregation, collation, collective analysis, and enterprise-level reporting without the need to establish a private network between the facilities. Industrial devices 208 and 210 having smart configuration capability can be configured to automatically detect and communicate with the cloud platform 202 upon installation at any facility, simplifying integration with existing cloud-based data storage, analysis, or reporting applications used by the enterprise. In another example application, cloud-based diagnostic applications can monitor the health of respective automation systems or their associated industrial devices across an entire plant, or across multiple industrial facilities that make up an enterprise. Cloud-based lot control applications can be used to track a unit of product through its stages of production and collect production data for each unit as it passes through each stage (e.g., barcode identifier, production statistics for each stage of production, quality test data, abnormal flags, etc.). These industrial cloud-computing applications are only intended to be exemplary, and the systems and methods described herein are not limited to these particular applications. The cloud platform 202 can allow builders of industrial applications to provide scalable solutions as a service, removing the burden of maintenance, upgrading, and backup of the underlying infrastructure and framework.
Remote industrial automation site operation system 302 can include a device interface component 304, a control component 306, a client interface component 308, a discovery component 310, a transform component 312, an indexing component 314, one or more processors 316, and memory 318. In various embodiments, one or more of the device interface component 304, control component 306, client interface component 308, discovery component 310, transform component 312, indexing component 314, the one or more processors 316, and memory 318 can be electrically and/or communicatively coupled to one another to perform one or more of the functions of the remote industrial automation site operation system 302. In some embodiments, components 304, 306, 308, 310, 312, and 314 can comprise software instructions stored on memory 318 and executed by processor(s) 316. Remote industrial automation site operation system 302 may also interact with other hardware and/or software components not depicted in
The device interface component 304 can be configured to exchange information between the remote industrial automation site operation system 302 one or more industrial devices or cloud gateway devices located at one or more industrial plant facilities. In some embodiments, device interface component 304 can exchange data with the industrial devices (e.g., industrial controllers, telemetry devices, motor drives, quality check systems, etc.) via the plant networks on which the devices reside, as well as via a public network such as the Internet. The device interface component 304 can directly access the data generated by these industrial devices via the one or more public and/or private networks in some embodiments. Alternatively, the device interface component 304 can access the data on these industrial devices via a proxy or gateway device that aggregates the data from multiple industrial devices for migration to the cloud platform via the device interface component. The data received by the device interface component 304 is stored on cloud-based storage associated with the remote site operation system 302 for processing by the control component 306.
The control component 306 can be configured to execute one or more industrial control programs or algorithms based on the industrial data collected by the device interface component 304. These control programs may include, for example, a supervisory control program designed to perform high-level control coordination between multiple automation systems at multiple different plant facilities. The control programs may also be redundant backup versions of control programs being executed at the plant facilities on one or more industrial controllers. In yet another example, the control programs may include a control program segment that performs a portion primary control of an industrial machine or process located at a remote industrial facility. The control component 306 can also be configured to perform other related functions, including but not limited to generating and delivering alarm notifications, or logging selected data items from data sources at the plant facility on cloud-based storage.
Client interface component 308 can be configured to exchange information between the remote site operation system 302 and a client device having authorization to access the system. For example, the client interface component 308 can receive from the client device control programming to be executed by the system for remote automation control of one or more industrial facilities, as well as other configuration information. The client interface component 308 can also be configured to deliver information to the client device, including but not limited to interface displays that render configuration views of the remote site operation system, or operational or statistical views relating to remote operation of the industrial facilities.
The discovery component 310 can be configured to detect available data items located on one or more industrial devices distributed across one or more plant facilities. The transform component 312 can be configured to transform the data retrieved by the device interface component 304. This can include, for example, transforming heterogeneous data items discovered on different types of data platforms to a homogeneous format for collective processing by the control component 306. In some embodiments, the transform component 312 may also tag the retrieved data with relevant contextual information—e.g., a plant, production area, machine, or device from which the data was received; a relationship or interdependency between a given data item and another data item; or other data modifications. The transform component 312 may also be configured to transform information about data items discovered by the discovery component 310 so that the information identifying the data items can be indexed in a federated data model.
Indexing component 314 can be configured to generate a federated data model defining locations and sources of data items throughout the industrial system, as well as relationships between the data items, based on the data discovered by the discovery component 310. The one or more processors 316 can perform one or more of the functions described herein with reference to the systems and/or methods disclosed. Memory 318 can be a computer-readable storage medium storing computer-executable instructions and/or information for performing the functions described herein with reference to the systems and/or methods disclosed.
The remote site operation system 302 collects selected subsets of data 408 from automation systems operating at the facilities 406 and stores the collected data 408 on cloud-based storage. The collected data 408 can include, for example, selected data items generated by or stored on industrial controllers or other industrial devices that control respective machines or processes at the facilities; telemetry data from telemetry devices that measure process values for the controlled machines or processes; status data from one or more sensors, safety devices, control panel devices, or other types of input devices; or other such data. To facilitate substantially real-time remote control and operation of machines and/or processes at the industrial facilities 406, the data 408 can be collected continuously or at high-frequency collection rates.
Processing services executed by the remote site operation services can process the collected and stored data and issue control data 410 to the local automation systems based on results of the processing. In this regard, the remote site operation system 302 can execute one or more control programs using cloud-based processing and storage, using the collected data 408 as parameters or variable values. In this way, the cloud-based services perform substantially real-time control functions from the cloud platform. In an example implementation, the cloud-based control programming or routine may be a high-level supervisory control algorithm that executes in conjunction with the local automation control carried out at the plant facilities 406, allowing the geographically diverse industrial systems to be collectively controlled using a centralized, cloud-based virtual controller. In another implementation, the facilities may perform no localized control of their machines or processes, which are instead controlled exclusively by the cloud-based control services executed by the remote site operation system 302. In still another implementation, the remote site operation system 302 may provide redundancy services whereby control of the automation systems at the plant facilities 406 switches from the local controllers at the facilities 406 to the cloud-based controller services in the event that the local controllers experience a fault.
In some embodiments, to facilitate safe operations during cloud-based control of industrial systems on the plant floor, I/O modules of the local controller and/or associated sensors can support a configurable timeout sequence, whereby a detected loss of communication to the cloud platform causes the local controller or I/O devices to place the industrial system in a safe state (if control cannot be seamlessly transitioned to a local controller). For example, in the case of an industrial system comprising moving parts (e.g., a stamping press, a machining or material handling robot, etc.), when the local controller or I/O devices detect that communication to the cloud platform has been lost (or, more specifically, after communication has been lost for a defined timeout duration specified by the user), the local controller and/or I/O devices can execute a coordinated operating sequence that causes the moving parts of the system to move to a safe position, or to stop at their current locations. The safety sequence can also cause power to be removed from the moving parts to ensure user safety until reliable control can be resumed.
As noted above, device interface component 304 of the remote site operation system 302 can be configured to receive data from one or more industrial devices 514 and/or 516. In some embodiments, the device interface component 304 can retrieve the data from each industrial device individually via the network layers (e.g., via a secure connection between the plant network and the public or private network on which the system 302 resides), where the selection of data items to be retrieved by the device interface component 304 is determined based on the needs of the control component 306 (to be described in more detail below). Alternatively, the industrial data from devices 514 and 516 can be sent to the cloud platform via one or more cloud gateway devices 206 located on the plant floor, which collect the required data items from one or more industrial devices and sends this data to the system 302 on the cloud platform.
In the configuration depicted in
While the gateway device illustrated in
In one or more embodiments, cloud interface component 708 can also receive data from the cloud-based application, and route this data to one or more of the industrial devices 7061-706N. As will be described in more detail below, this allows the remote site operation system 302 to send control data to the devices based on cloud-side processing of the collected industrial data.
Returning to
Control component 306 retrieves selected values of collected plant data 804 from cloud storage as required by control programs 502, and generates control instructions 806 based on the collected data 804 and the programming performed thereon. These control instructions 806 may take the form of digital or analog output values to be written to corresponding data tags or registers of the plant floor devices to initiate a local control action on the plant floor, to change a setpoint value or other process variable in an industrial controller, to initiate a notification to be directed to a plant employee, or other such control actions. The device interface component 304 sends the control instructions 806 to the appropriate devices on the plant floor from the cloud platform.
The control programs 502 may be written to programmatically link a defined program input or output to a specified data register or data tag of an industrial device on the plant floor; e.g., by referencing a unique tag name associated with the data tag. In some embodiments, the control component 306 may allow the user (via interaction with dashboards 508) to define the inputs and outputs of control programs 502 using hierarchical tag names that identify the location of the corresponding data item or tag on the plant floor within the larger industrial enterprise. For example, an input or output of a control program executed by control component 306 may be defined in terms of the enterprise name, the name of the plant facility in which the target device reside, the name of the industrial device containing the data tag, and the name of the data tag on the industrial device.
Also, in some embodiments, the program development tools provided by dashboards 508 may allow the program developer to define an input or output for a control program by browsing a hierarchical data tag list that defines the available data tags in terms of their hierarchical locations within the industrial enterprise. To facilitate discovery of the data tags available throughout the plant facilities, as well as to provide the device interface component 304 with communication pathway information for communicating with the respective data tags, one or more embodiments of system 302 can maintain a federated data model 518 that maps the available data tags under a common namespace, and defines the hierarchical locations of these tags within the larger industrial enterprise. To generate and maintain this data model 518, one or more embodiments of remote site operation system may include an indexing system configured to discover available data tags on industrial devices throughout the various plant facilities 512.
In an example scenario, when the discovery agent discovers a new industrial device 910 during traversal of the plant network, the agent will examine the device to identify the data items on that device that are eligible for indexing in the federated data model 518. If the discovered device is an industrial controller, for example, the available data items may comprise data tags or registers defined by the industrial controller's configuration and programming file. The discovery agent can also identify how and where the data items are used in the industrial controller's program (e.g., ladder logic, sequential function chart, structured text, etc.) so that this information can be indexed as well. For example, upon discovery of the industrial controller on the plant network, the discovery agent may subsequently identify a tag named Tank1 defined in the controller's program file, representing a particular tank of an industrial batch process. In response to discovering this tag, the discovery agent can scan the control program to identify the routines and program locations (e.g., ladder logic rungs) on which Tank1 is referenced. The discovery agent can also identify how each instance of Tank1 is used at each program location (e.g., output coil, normally open contact, function block argument, etc.).
The discovery agent may additionally identify other data items defined in the industrial controller that have a functional relationship with Tank1. For example, upon identifying a reference to Tank1 on an output coil of a rung of the control program running on the industrial controller, the discovery agent can then identify the other data values and statuses defined on that rung that control the state of the Tank1 output coil, and record this relationship between Tank1 and each of the other data values and statuses. In some embodiments, the discovery agent can perform additional scans of the control program to determine additional data values and statuses that affect the states of each of the related data items, since those additional data values/statuses also affect the status of the Tank1 output coil. The discovery agent may iteratively cycle through the control program multiple times in this fashion in order to discover all relevant data items having a functional relationship with Tank1. In some embodiments, the discovery agent can also scan cloud-based virtual controllers (e.g., virtual controllers implemented by control component 306) for relevant information, and record associations between this cloud-based control data and other on-premise devices at the plant site. For example, a cloud-based virtual controller may generate alarm information for one or more controlled devices of an automation system. This alarm information can be discovered by the discovery agent; e.g. by scanning the cloud-based virtual controller in a similar manner to that used to scan local controllers at the plant facility.
In another example, the discovered device may be an interface terminal executing an HMI application for visualizing a controlled process. In this scenario, the discovery agent may identify the terminal and proceed to scan the tag list defined in the HMI application to identify the data tags referenced by the HMI. These data items can include HMI tags linked to data tags of a networked industrial controller for display of associated controller data values or statuses on one or more of the HMI screens, or for writing values to the controller tags via an input object rendered on an HMI screen (e.g., a data entry field, a virtual push-button, etc.). For each discovered HMI tag, the discovery agent can identify the display screens on which the HMI tag is registered, as well as the external controller tags corresponding to the HMI tag. In some scenarios, the HMI tag may be identified by the same name as the corresponding controller tag (e.g., Tank1), although this may not always be the case.
The discovery agent can package the information collected as described above—including an identity of the device and its type (e.g., industrial controller, HMI, motor drive, etc.), data items discovered on the device, locations of the data items within an application running on the device (e.g., routine and rung of a ladder logic program, HMI screen, etc.), correlations between the data items, etc.—and send this information back to the discovery component 310 as discovered data 912. Since the discovery agent is capable of performing appropriate analysis on a number of different types of data platforms (e.g., industrial controller, HMI, etc.) in order to identify the data platform and its available data, the discovery agent may pre-format the discovered data 912 to conform a format compatible with the remote site operation system 302 prior to returning the discovered data 912 to the discovery component 310. In this way, the discovery component 310 and its associated discovery agent can automatically normalize heterogeneous data from diverse data formats into a common, homogeneous format that can be collectively processed and indexed by the indexing system.
In addition to passive devices 904, the industrial facility may include one or more smart devices 906 having integrated self-reporting functionality. Such devices can provide uploaded data 914 regarding their identity and available data items to the indexing system 902 directly without the need for analysis by a discovery agent. Turning to
When smart device 906 is installed as part of an industrial automation system, index system interface component 1012 can establish communication with the indexing system 902. In one or more embodiments, the index system interface component 1012 can be configured to auto-discover the indexing system 902 on the common network. For example, the smart device 906 may be pre-configured with the identification of the indexing system to which the device is to provide its identity and configuration information (e.g., a name associated with the indexing system, a machine identifier, a cloud or web address, etc.), or may be configured to perform a search of the plant network for compatible industrial indexing systems that may be present on the network. Any suitable handshaking protocol may be used to establish communication between the smart device 906 and the indexing system.
Upon discovery of the indexing system, the smart device 906 can package and send relevant information about the device and its available data items or tags to the indexing system 902, which integrates the reported data items in federated data model 518. In some embodiments, a profile generation component 1016 can generate a device profile 1014 for smart device 906 to be sent to the indexing system 902 via index system interface component 1012. Device profile 1014 can convey information about smart device 906, including but not limited to an identity and type of the device, readable and/or writable device data items 1022 available on the device, a context of the device within the industrial environment, any built-in displays or dialog screens (e.g., HTML pages) that provide access to the device's data, etc. In some embodiments, profile generation component 1016 may collect configuration information encoded in a configuration file 1020 stored on the smart device 906, which may be a control program, a configuration or parameters settings file, an application file (e.g., an HMI application or HTML page), or other such file. The profile generation component 1016 can also identify available device data items 1022 on the device (e.g., real-time or historical data tags, etc.). In some embodiments, the profile generation component 1016 can also identify relationships between the data items using techniques similar to those used by the discovery agent, including but not limited to the iterative relationship discovery process described above. The profile generation component 1016 can package this information into a device profile 1014, which is then sent to the indexing system as uploaded data 914 by index system interface component 1012.
Some embodiments of smart device 906 may also include a plant context component 1008 configured to collect additional contextual information about the smart device 906 for delivery to indexing system 902. Plant context component 1008 can determine a context of smart device 906 within the plant or enterprise environment. For example, one or more embodiments of plant context component 1008 can identify other devices and systems within its local environment and make a determination regarding a location of smart device 906 within a hierarchical enterprise context or device topology. Some embodiments of the federated data model 518 may represent a given industrial enterprise in terms of multiple hierarchical levels and device hierarchies, where each level comprises units of the enterprise organized as instances of types and their properties. For example, a given data item may be tagged in the data model 518 with hierarchical location data identifying the location of origin of the data item in terms of the following increasingly granular hierarchical levels—a plant facility, a work area within the facility, a production line within the work area, a machine within the production line, and a device associated with the machine. These levels are only intended to be exemplary, and it is to be appreciated that other combinations of hierarchical levels are within the scope of one or more embodiments of this disclosure.
Plant context component 1008 can gather information that facilitates locating its associated smart device 906 within an organizational or device hierarchy in a number of ways. In one example, plant context component 1008 can identify a topology of devices sharing a common network with smart device 906 and interconnections between the devices. For example, if smart device 906 is an industrial controller, plant context component 1008 can identify one or more discrete or analog I/O devices connected to the controller (e.g. based on a configuration file 1020 that defines the I/O module configurations for the controller). In addition, plant context component 1008 can identify other controllers on the network and their role within the overall industrial enterprise (e.g., the production areas, workcells, or processes associated with the respective controllers). In some embodiments, plant context component 1008 can also determine an identity of a particular network (e.g., a network name) to which smart device 906 is attached. This information can be leveraged (either by profile generation component 1016 or an external application) to determine the device's location and role within the industrial enterprise, since some networks may be dedicated to a particular production area. Some embodiments of plant context component 1008 may also identify a type of machine to which smart device 906 is connected (e.g., a palletizer, wrapper, conveyor, etc.).
By gathering information about the local device topology, plant context component 1008 can facilitate identifying a location of smart device 906 within the enterprise hierarchy. In some embodiments, this determination of the location within the enterprise hierarchy can be made by plant context component 1008 itself. Alternatively, profile generation component 1016 can include information gathered by plant context component 1008 in device profile 1014 so that the indexing system 902 can accurately represent smart device 906 within the enterprise or device hierarchy.
Returning to
Transform component 312 can perform any necessary transformation on the information collected by the discovery component prior to indexing. This can include, for example, normalizing any data that was not appropriately formatted by the discovery agent, so that all collected information about the discovered data items or tags accords to a common format usable by the indexing system 902. In some embodiments, transform component 312 can also add contextual data to the collected data tag information to achieve highly granular indexing for search and communication purposes, as well as to facilitate subsequent discovery of interdependencies between the diverse and plant-wide data items.
Contextual data that can be added by transform component 318 for a given data item can include, but is not limited to, an identifier of a plant and/or production area at which the source of the data item resides; a machine or product to which the data item relates; one or more employees to be associated with the data item (e.g., based on the production area, shift during which the data item was collected, etc.); a concurrent alarm condition determined to be relevant to the discovered data item; an actionable data flag indicating that the value of the collected data item requires a response from plant personnel; or a tag indicating the location of the data time within the context of a hierarchical organizational model of the plant (e.g., in terms of an enterprise level, plant level, work area level, machine level, control level, etc.).
In some embodiments, the transform component 312 can selectively tag discovered data items with one or more pre-defined tags 1108 defined in association with the indexing system 902. These tags may be used to contextualize the discovered data based on one or more user-defined tag categories based on tagging rules. For example, the user may define a tagging rule indicating that data collected from industrial devices within a particular workcell or machine of the plant are to be tagged with a pre-defined tag that associates the data items with a person, product, or other classifier for indexing and searching purposes. The tags 1108 allow the user to define relationships between data items that may not be automatically discoverable by the discovery component 310 and its associated discovery agents.
In some embodiments, the transform component 312 may also auto-generate tags for a given data item based on contextual information, including but not limited to rung comments associated with a controller tag, learned interdependencies between a newly discovered data item and a previously discovered data item (e.g., the transform component 312 may learn that Pump5 is associated with Tank1, and tag Pump5 as being associated with Tank1, or tag both Tank1 and Pump5 according to the larger system in which they operate), or other discovered contextual information. The indexing component 314 can associate similarly tagged data items in the federated data model 518 regardless of the platform in which they were discovered. For example, the indexing component 314 can associate common or related data items discovered, respectively, in an industrial controller, an HMI, and a data historian.
Returning now to
In some high availability systems (e.g., systems with redundant communication channels.), there may be multiple communication paths to certain devices and the data items thereon. For example, some systems may include two cloud gateways that both serve a common set of devices on the plant floor, and the cloud-based system may send requests for data items over both channels substantially simultaneously. In such embodiments, the on-premise device receiving the multiple requests over the two channels may be configured to determine that the requests are redundant (i.e., represent the same request for a data item), and only respond to one of these requests with the requested data item. ON the cloud side, the indexing system may be aware of the duplicate communication path to the data tag, and store this information in such a way that the path and the data tag information are separate but linked.
In order to facilitate real-time control of plant-side automation systems from the cloud platform, the device interface component 304 can be configured to retrieve and store industrial data from the plant-side industrial devices substantially continuously, or at a high update frequency. This ensures that cloud-side control of the plant floor systems is performed with low latency.
The architecture described above for performing cloud-based remote operation of plant-level automation systems can be leveraged in a number of different ways.
Conventionally, although there may be dependencies between operations at the various facilities 512—e.g., the production rate at one facility depends on a supply of parts produced at another facility; the rate at which parts are to be produced at one facility depends on the rate at which those parts are being used at another facility; etc.—coordination of operations between the facilities is typically reliant upon human communication between the plants, a technique that does not allow operations at a given facility to immediately react to real-time operational statuses at other plants.
The architecture described above, and illustrated in
During operation, the device interface component 304 on the cloud platform collects values of respective data items from the controllers and/or other industrial devices located at the facilities. To facilitate substantially real-time control, the device interface component 304 collects these data values substantially continuously, or at a high update frequency. In this example the control component 306 executes a supervisory program 1202 that collectively processes the plant floor data and generates control data 1204 directed to the respective facilities based on results of the processing. The supervisory program 1202 may be designed to perform high-level coordination between operations at the respective facilities 512 based on the real-time data collected from the local devices, as described in previous examples.
The device interface component 304 can determine which plant-side data items to collect for storage and processing based on the requirements of the supervisory program 1202. For example, the device interface component 304 can determine which of the plant-side data items are referenced by the supervisory program 1202 as inputs, and collect those referenced data items from the appropriate local devices at the facilities 512 in order to provide supervisory program 1202 with the appropriate input values. For the control (output) data, the device interface component 304 can determine the which data tag corresponds to each of the digital and analog output values defined by supervisory program 1202, and send the values of those output to their appropriate data tags or registers in the plant-side industrial devices (e.g., controllers 514) using device interface component 304. Depending on the configuration, the device interface component 304 can send these values either directly to the respective plant floor devices, or via cloud gateway devices 206 at the respective facilities.
This configuration yields a two-layer control architecture, whereby immediate control functions of the automation systems at facilities 512 are controlled locally by programs that execute on local controllers 514, while higher-level, collective control of the automation systems is performed by the remote site operation system 302 using control component 306 executing supervisory program 1202. Users can design supervisory program 1202 to manage substantially any high-level goal of the industrial enterprise that requires coordination between the facilities 512. For example, the cloud-based supervisory program 1202 may be configured to regulate a production rate of a manufacturing line at one of the facilities 512 based on a measured rate of part production at an upstream facility, or a measured demand at a downstream facility. Such changes in production rate may be carried out, for example, by writing a new setpoint value to a data tag in one of the local controllers that sets a speed of a production line.
In another example of cloud-based supervisory control of a locally controlled process, a local device, a controller or other device on the plant floor may carry out an autonomous control of a local automation system; e.g., a proportional-integral-derivative (PID) loop control of a motion system. As this local control is executed, the local control device can send time-stamped status and operational values relating to control of the local automation system to the cloud-based control system (e.g., loop tuning parameter values, current speed and position of the motion system, current or predicted control output signals generated by the local controller, etc.) Based on these values, the cloud controller can predict a future status (e.g., position, velocity, etc.) or trajectory of the motion system, and generate new control setpoint values or other control parameters for the local controller based on these predicted statuses, in anticipation of where the motion system will be at a future time. The cloud-based system can then send these new setpoint or control values to the local controller.
As noted above, to allow data from multiple geographically diverse input points to be correlated and proper event ordering determined (thereby ensuring accurate coordination between the facilities), the industrial data can be time-stamped and converted to a common time standard as the data is moved from the plant floor to the cloud-based remote site operation system 302. In some embodiments, the data may be time-stamped by the device interface component 304 using a common clock associated with the system 302. Alternatively, the data may be stamped by the plant-floor devices (or gateway devices) prior to moving the data to the cloud platform. In the latter scenario, system 302 may synchronize the internal clocks of the plant floor devices that will be moving data to the cloud platform, to ensure that the relative times between events that occur at geographically diverse facilities are accurately represented.
The cloud-based remote site operation architecture can also be used to implement control redundancy to ensure that plant-floor operations are not interrupted in the event of a failure of the local controller.
In the event of a failure of local controller 514, the remote site operation system 302 on the cloud platform assumes remote control of the automation system 1310 using control component 306 executing backup program 1302. In an example embodiment, remote site operation system 302 may detect such a failure by remotely monitoring one or more health statistics of the local controller 514 (e.g., a run mode register on the controller, one or more fault registers on the controller, etc.). Upon detection of the failure, device interface component 304 can begin collecting data from the industrial devices (if this data was not already being collected during normal operation), and control component 306 begins sending control data to the automation system devices at the facility 512 based on processing performed on the collected device data by the backup program 1302. The control data sent by the remote site operation system, comprising digital and analog values set by backup program 1302, may be linked to appropriate data registers of one or more industrial devices that make up the automation system (e.g., motor drives, actuation systems, etc.). Some of the control data values may be linked to control registers of remote I/O modules on the plant floor that have hardwired links to I/O devices that would otherwise be controlled by the local controller 514 during normal operation. In this way, the cloud-based remote site operation system provides reliable active backup services for industrial automation systems at any location with access to the cloud platform.
In some embodiments, the architecture described above can allow the user to segment or partition data items or control functions in terms of where the data or functions are to be processed (e.g., on the local controller or in the cloud platform). These selections can be made by tagging the data items or routines on the local controller using the control program development environment
Additionally, the control program development application also allows the user to indicate whether the data tag is to be processed locally on the industrial controller or, alternatively, by the control component 306 of remote site operation system 302. In some embodiments (as depicted in
At 1706, a control program is executed on the cloud platform using the collected industrial data as program variables. Any suitable programming language for development of the cloud-based control program is within the scope of one or more embodiments of this disclosure. For example, the cloud-based system may allow the cloud-based control program to be developed using a common industrial controller programming language, including but not limited to ladder logic, sequential function charts, function block diagrams, structured text, or other such platforms. To facilitate program development, some embodiments of the cloud-based system can include a client interface component that serves program development interface displays to remote client devices (e.g., laptop computers, tablet computers, desktop computers, phones, etc.) to facilitate development of the cloud-based control program. During execution, the control program can retrieve data values from the cloud storage corresponding to defined program variables (e.g., data values corresponding to discrete and analog I/O values generated by plant-floor industrial devices, telemetry values generated by meters associated with the automation systems, operator input values indicating statuses of control panel devices or HMI input values, etc.), and generate discrete and/or analog output values based on the collected data values in accordance with the control program.
At 1708, control instructions are sent to one or more of the industrial devices associated with the automation systems based on the outputs generated by the cloud-based control program. The cloud-based system may send these control instructions to the industrial devices directly via the plant network, or may send the instructions by way of the gateway devices if such gateway devices are used to interface the industrial devices to the cloud platform. The control instructions may comprise, for example, digital values that instruct an industrial device to initiate a particular action or operating mode, analog setpoint values, messages directed to an operator on the plant floor, or other such instructions.
Embodiments, systems, and components described herein, as well as industrial control systems and industrial automation environments in which various aspects set forth in the subject specification can be carried out, can include computer or network components such as servers, clients, programmable logic controllers (PLCs), automation controllers, communications modules, mobile computers, wireless components, control components and so forth which are capable of interacting across a network. Computers and servers include one or more processors—electronic integrated circuits that perform logic operations employing electric signals—configured to execute instructions stored in media such as random access memory (RAM), read only memory (ROM), a hard drives, as well as removable memory devices, which can include memory sticks, memory cards, flash drives, external hard drives, and so on.
Similarly, the term PLC or automation controller as used herein can include functionality that can be shared across multiple components, systems, and/or networks. As an example, one or more PLCs or automation controllers can communicate and cooperate with various network devices across the network. This can include substantially any type of control, communications module, computer, Input/Output (I/O) device, sensor, actuator, instrumentation, and human machine interface (HMI) that communicate via the network, which includes control, automation, and/or public networks. The PLC or automation controller can also communicate to and control various other devices such as standard or safety-rated I/O modules including analog, digital, programmed/intelligent I/O modules, other programmable controllers, communications modules, sensors, actuators, output devices, and the like.
The network can include public networks such as the internet, intranets, and automation networks such as control and information protocol (CIP) networks including DeviceNet, ControlNet, and Ethernet/IP. Other networks include Ethernet, DH/DH+, Remote I/O, Fieldbus, Modbus, Profibus, CAN, wireless networks, serial protocols, near field communication (NFC), Bluetooth, and so forth. In addition, the network devices can include various possibilities (hardware and/or software components). These include components such as switches with virtual local area network (VLAN) capability, LANs, WANs, proxies, gateways, routers, firewalls, virtual private network (VPN) devices, servers, clients, computers, configuration tools, monitoring tools, and/or other devices.
In order to provide a context for the various aspects of the disclosed subject matter,
With reference to
The system bus 1918 can be any of several types of bus structure(s) including the memory bus or memory controller, a peripheral bus or external bus, and/or a local bus using any variety of available bus architectures including, but not limited to, 8-bit bus, Industrial Standard Architecture (ISA), Micro-Channel Architecture (MSA), Extended ISA (EISA), Intelligent Drive Electronics (IDE), VESA Local Bus (VLB), Peripheral Component Interconnect (PCI), Universal Serial Bus (USB), Advanced Graphics Port (AGP), Personal Computer Memory Card International Association bus (PCMCIA), and Small Computer Systems Interface (SCSI).
The system memory 1916 includes volatile memory 1920 and nonvolatile memory 1922. The basic input/output system (BIOS), containing the basic routines to transfer information between elements within the computer 1912, such as during start-up, is stored in nonvolatile memory 1922. By way of illustration, and not limitation, nonvolatile memory 1922 can include read only memory (ROM), programmable ROM (PROM), electrically programmable ROM (EPROM), electrically erasable PROM (EEPROM), or flash memory. Volatile memory 1920 includes random access memory (RAM), which acts as external cache memory. By way of illustration and not limitation, RAM is available in many forms such as synchronous RAM (SRAM), dynamic RAM (DRAM), synchronous DRAM (SDRAM), double data rate SDRAM (DDR SDRAM), enhanced SDRAM (ESDRAM), Synchlink DRAM (SLDRAM), and direct Rambus RAM (DRRAM).
Computer 1912 also includes removable/non-removable, volatile/non-volatile computer storage media.
It is to be appreciated that
A user enters commands or information into the computer 1912 through input device(s) 1936. Input devices 1936 include, but are not limited to, a pointing device such as a mouse, trackball, stylus, touch pad, keyboard, microphone, joystick, game pad, satellite dish, scanner, TV tuner card, digital camera, digital video camera, web camera, and the like. These and other input devices connect to the processing unit 1914 through the system bus 1918 via interface port(s) 1938. Interface port(s) 1938 include, for example, a serial port, a parallel port, a game port, and a universal serial bus (USB). Output device(s) 1940 use some of the same type of ports as input device(s) 1936. Thus, for example, a USB port may be used to provide input to computer 1912, and to output information from computer 1912 to an output device 1940. Output adapters 1942 are provided to illustrate that there are some output devices 1940 like monitors, speakers, and printers, among other output devices 1940, which require special adapters. The output adapters 1942 include, by way of illustration and not limitation, video and sound cards that provide a means of connection between the output device 1940 and the system bus 1918. It should be noted that other devices and/or systems of devices provide both input and output capabilities such as remote computer(s) 1944.
Computer 1912 can operate in a networked environment using logical connections to one or more remote computers, such as remote computer(s) 1944. The remote computer(s) 1944 can be a personal computer, a server, a router, a network PC, a workstation, a microprocessor based appliance, a peer device or other common network node and the like, and typically includes many or all of the elements described relative to computer 1912. For purposes of brevity, only a memory storage device 1946 is illustrated with remote computer(s) 1944. Remote computer(s) 1944 is logically connected to computer 1912 through a network interface 1948 and then physically connected via communication connection 1950. Network interface 1948 encompasses communication networks such as local-area networks (LAN) and wide-area networks (WAN). LAN technologies include Fiber Distributed Data Interface (FDDI), Copper Distributed Data Interface (CDDI), Ethernet/IEEE 802.3, Token Ring/IEEE 802.5 and the like. WAN technologies include, but are not limited to, point-to-point links, circuit switching networks like Integrated Services Digital Networks (ISDN) and variations thereon, packet switching networks, and Digital Subscriber Lines (DSL). Network interface 1948 can also encompass near field communication (NFC) or Bluetooth communication.
Communication connection(s) 1950 refers to the hardware/software employed to connect the network interface 1948 to the system bus 1918. While communication connection 1950 is shown for illustrative clarity inside computer 1912, it can also be external to computer 1912. The hardware/software necessary for connection to the network interface 1948 includes, for exemplary purposes only, internal and external technologies such as, modems including regular telephone grade modems, cable modems and DSL modems, ISDN adapters, and Ethernet cards.
What has been described above includes examples of the subject innovation. It is, of course, not possible to describe every conceivable combination of components or methodologies for purposes of describing the disclosed subject matter, but one of ordinary skill in the art may recognize that many further combinations and permutations of the subject innovation are possible. Accordingly, the disclosed subject matter is intended to embrace all such alterations, modifications, and variations that fall within the spirit and scope of the appended claims.
In particular and in regard to the various functions performed by the above described components, devices, circuits, systems and the like, the terms (including a reference to a “means”) used to describe such components are intended to correspond, unless otherwise indicated, to any component which performs the specified function of the described component (e.g., a functional equivalent), even though not structurally equivalent to the disclosed structure, which performs the function in the herein illustrated exemplary aspects of the disclosed subject matter. In this regard, it will also be recognized that the disclosed subject matter includes a system as well as a computer-readable medium having computer-executable instructions for performing the acts and/or events of the various methods of the disclosed subject matter.
In addition, while a particular feature of the disclosed subject matter may have been disclosed with respect to only one of several implementations, such feature may be combined with one or more other features of the other implementations as may be desired and advantageous for any given or particular application. Furthermore, to the extent that the terms “includes,” and “including” and variants thereof are used in either the detailed description or the claims, these terms are intended to be inclusive in a manner similar to the term “comprising.”
In this application, the word “exemplary” is used to mean serving as an example, instance, or illustration. Any aspect or design described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other aspects or designs. Rather, use of the word exemplary is intended to present concepts in a concrete fashion.
Various aspects or features described herein may be implemented as a method, apparatus, or article of manufacture using standard programming and/or engineering techniques. The term “article of manufacture” as used herein is intended to encompass a computer program accessible from any computer-readable device, carrier, or media. For example, computer readable media can include but are not limited to magnetic storage devices (e.g., hard disk, floppy disk, magnetic strips . . . ), optical disks [e.g., compact disk (CD), digital versatile disk (DVD) . . .], smart cards, and flash memory devices (e.g., card, stick, key drive . . . ).