The present disclosure relates to Internet of Things (IoT) systems, and more specifically, to detecting rearrangements of manufacturing machines on a factory floor deploying IoT solutions.
When applying IoT solutions to the manufacturing field, an information technology (IT) server collects the data that represents behavior of manufacturing machines on the field via Programmable Logic Controller (PLC).
However, the IT server will retrieve the data for different manufacturing machines via the same PLC when a KAIZEN event occurs. During a KAIZEN event, the location and order of deployment of manufacturing machines can be changed, which would also cause a change to the connections between PLCs and manufacturing machines. Such events are referred to herein as ‘rearrangement’. Further, the IoT system configured to manage the manufacturing field and the IT servers are located on isolated networks that are siloed from each other, so administrators of the IT server cannot obtain the rearrangement data. Thus, there is a need to detect when rearrangements occur from the IT server side.
In a related art implementation, there are systems and methods for discovery and mapping of a network topology which involves network topology discovery, classification on network devices, identification of silent devices, fingerprinting and mapping the network map including PLCs.
Aspects of the present disclosure can include a method for a system involving a first network coupled to a plurality of programmable logic controllers (PLCs) and one or more assets, and a second network coupled to a server managing a camera monitoring the one or more assets, and an asset manager managing the one or more assets, the method involving, for received images from the camera being indicative of an asset from the one or more assets being moved, monitoring the asset being moved to a final location through the camera; determining a PLC from the plurality of PLCs that is associated with the final location; transmitting information to the asset manager indicative of a change of the asset being moved to the final location and the PLC determined to be associated with the asset being moved based on the final location; reconfiguring the first network according to the change indicated by the information regarding the asset being moved; and processing data from the reconfigured first network.
Aspects of the present disclosure further involve a computer program storing instructions for a system involving a first network coupled to a plurality of programmable logic controllers (PLCs) and one or more assets, and a second network coupled to a server managing a camera monitoring the one or more assets, and an asset manager managing the one or more assets, the instructions involving for received images from the camera being indicative of an asset from the one or more assets being moved, monitoring the asset being moved to a final location through the camera; determining a PLC from the plurality of PLCs that is associated with the final location; transmitting information to the asset manager indicative of a change of the asset being moved to the final location and the PLC determined to be associated with the asset being moved based on the final location; reconfiguring the first network according to the change indicated by the information regarding the asset being moved; and processing data from the reconfigured first network. The computer program may be stored in a non-transitory computer readable medium storing instructions configured to be executed by one or more processors.
Aspects of the present disclosure further involve a system, which can include a first network having a plurality of programmable logic controllers (PLCs) and one or more assets, and a second network having a server managing a camera monitoring the one or more assets, and an asset manager managing the one or more assets. The server can involve a processor, configured to, for received images from the camera being indicative of an asset from the one or more assets being moved, monitor the asset being moved to a final location through the camera; determine a PLC from the plurality of PLCs that is associated with the final location; transmit information to the asset manager indicative of a change of the asset being moved to the final location and the PLC determined to be associated with the asset being moved based on the final location; reconfigure the first network according to the change indicated by the information regarding the asset being moved; and process data from the reconfigured first network.
The following detailed description provides further details of the figures and example implementations of the present application. Reference numerals and descriptions of redundant elements between figures are omitted for clarity. Terms used throughout the description are provided as examples and are not intended to be limiting. For example, the use of the term “automatic” may involve fully automatic or semi-automatic implementations involving user or administrator control over certain aspects of the implementation, depending on the desired implementation of one of ordinary skill in the art practicing implementations of the present application. Selection can be conducted by a user through a user interface or other input means, or can be implemented through a desired algorithm. Example implementations as described herein can be utilized either singularly or in combination and the functionality of the example implementations can be implemented through any means according to the desired implementations.
Example implementations involve a rearrangement detection method and system as follows.
The manufacturing field system 100 involves a data level network 101, a control level network 102, and a field level network 103. The data level network 101 involves a MES 110 (Manufacturing Execution Systems) and at least one higher PLC 112. The control level network 102 involves at least one higher PLC 112, one or more SCADA (Supervisory Control and Data Acquisition) 113, and PLCs 116-1, 116-2. The field level network 103 involves PLCs 116-1, 116-2 and manufacturing machines 117-1, 117-2.
The IT server 120 involves one or more metrics retriever 121, a data lake 122 and one or more solution application 123. The IT server 120 is connected onto the data level network 101 and the control level network 102. The metrics retriever 121 acquires data from MES 110, Higher PLC 112, SCADA 113 and PLCs 116-1, 116-2, annotates metadata onto the acquired data, and stores the annotated data into the data lake 122. For example, if the acquired data is “130, 120” and it is acquired from a PLC designated as PLC-A, the metrics retriever 121 generates annotated data such as “PLC-A, oil temp, 130, coolant temp, 120”. The solution application 123 reads the annotated data from the data lake 122, conducts analytics and provides them to the manufacturing manager 124.
The retriever configurator 130 involves an asset manager 131 and an asset repository 132. The asset manager 131 provides a configuration for the metrics retriever 121 based on the asset repository 132. The configuration indicates how to annotate metadata onto the acquired data.
The rearrangement detect server 140 involves a rearrangement detection module 141, an image to location module 142, a location to location identifier (ID) module 143, a location ID to PLC name module 144, a normal condition database (DB) 145, a camera location DB 146, a physical map 147, a logical map 148 and a tracking status storage 149. The rearrangement detect server 140 acquires images from the camera 150 periodically and sends signals to the retriever configurator 130 as needed in accordance with the desired implementation.
In the system as illustrated in
There is also a second network involving the retriever configurator 130 and the rearrangement detect server 140. The field operator 133 manages the retriever configurator 130 based on the results of the IT server 120. However, in such systems, the first network is isolated from the second network, as the manufacturing field system is isolated from the outside world for security reasons and inaccessible other than by a managing server such as IT server 120. Thus, the remote field operator 133 cannot determine when changes are made to the field level network 103 if manufacturing machines 117-1, 117-2 are moved to different locations and managed by different PLCs.
To address the issue, a camera 150 is used to monitor the assets in the manufacturing field system 100 so that when such manufacturing machines move, the images from the camera are processed by the rearrangement detect server 140, which determines the change to the assets and provides such information to the retriever configurator 130 to update the asset repository 132. In this manner, the field operator 133 can thereby be informed of the changes made to the hierarchy and PLC management of the asset repository 132, despite having no direct access to the data level network 101.
Then the image to location module 142 converts the message 202 to another message 203 by using the camera location DB 146, which allows for the coordinates within the image to be translated to global positioning satellite (GPS) coordinates so as to designate the actual physical location of the asset being moved. The resulting message 203 indicates the location of the moving asset in terms of GPS coordinates.
Then the location to location ID 143 is used to compare the GPS coordinates to the particular manufacturing area of the manufacturing field system 100. In example implementations, such systems are divided into various manufacturing areas, each managed by one or more PLCs. The physical map 147 defines the area in terms of a range of GPS coordinates encompassing the area. The GPS coordinates of the moving asset is compared to the physical map 147. The resulting message 204 indicates the location ID of the moving asset in terms of the area.
Then the location ID to PLC name 144 refers to the logical map 148 to determine the PLC that manages the associated area. The resulting message 205 involves the PLC associated with the moving asset.
The flow diagram of
At 804, a determination is made as to whether a moving object is detected from the processing at 803. If so (Y) the flow proceeds to 805, otherwise (N) the flow proceeds to 841.
At 805 the normal condition image is obtained from the normal condition DB to determine what object is moving (e.g., an asset that is being relocated, a new object being moved into the camera view such as a human, etc.). At 806, based on the processing at 805, a determination is made as to whether the object is an asset. If so (Y) then the flow proceeds to 807, otherwise (N) the flow proceeds to 841.
At 807, a bounding box is obtained for the original location of the asset by comparing the image obtained from the camera versus the normal condition image from the normal condition DB. Based on the processing conducted at 805, the rearrangement detector determines which asset corresponds to the moving object and then obtains the bounding box corresponding to the asset from processing the normal condition image. At 808 a bounding box is obtained for the current location of the asset by comparing the current image and the normal condition image. Based on the processing conducted at 805 and 803, the asset location can be identified in the image from the processing for detecting a moving object within the image.
At 809, the rearrangement detector searches the tracking status DB to determine if an entry for the moving object has been made before by searching for the camera ID corresponding to the camera that provided the image, and for the bounding on the original location having the same bounding box as a record made previously. At 810, if such a record exists (Y) then the flow proceeds to 811, otherwise (N) the flow proceeds to 851.
At 811, the timestamp of the record in the tracking status DB is updated with the present timestamp and the current location of the record is updated with the bounding box of the current location of the asset. Then the flow proceeds back to 802 to take the next images from the cameras.
If no record is found, then a new record is made in the tracking status DB. At 851, a new record is inserted in the format as illustrated in
At 852, as a new record was made regarding a moving asset, the asset information is thereby deleted from the record. Thus, a message is sent to indicate a deletion of the asset, along with the object ID and the bounding box on the original location to the image to location module. Then the flow proceeds back to 802 to take the next images from the cameras.
At 841, in which there has been no moving asset detected, the rearrangement detector initiates a process to conduct updates on the record. At first the rearrangement detector searches the tracking status DB for the camera corresponding to the received image. At 842, if such a record is found (Yes) then the flow proceeds to 843, otherwise (N) it proceeds back to 802 to obtain the next image for processing. At 843, a determination is made as to whether the timestamp is too old as determined by a preset policy that indicates how long such records should be kept. If the timestamp is not too old (N) then the flow proceeds back to 802 to process the next image, otherwise (Y) the flow proceeds to 844. At 844, the rearrangement detector updates the image to location module with the current assets by sending a message to add the asset, along with the detected object ID and the bounding box on the current location to the image to location module. At 845, the record that indicated that the asset was moving is deleted from the tracking status DB.
Computer device 1105 can be communicatively coupled to input/user interface 1135 and output device/interface 1140. Either one or both of input/user interface 1135 and output device/interface 1140 can be a wired or wireless interface and can be detachable. Input/user interface 1135 may include any device, component, sensor, or interface, physical or virtual, that can be used to provide input (e.g., buttons, touch-screen interface, keyboard, a pointing/cursor control, microphone, camera, braille, motion sensor, optical reader, and/or the like). Output device/interface 1140 may include a display, television, monitor, printer, speaker, braille, or the like. In some example implementations, input/user interface 1135 and output device/interface 1140 can be embedded with or physically coupled to the computer device 1105. In other example implementations, other computer devices may function as or provide the functions of input/user interface 1135 and output device/interface 1140 for a computer device 1105. In example implementations involving a touch screen display, a television display, or any other form of display, the display is configured to provide a user interface.
Examples of computer device 1105 may include, but are not limited to, highly mobile devices (e.g., smartphones, devices in vehicles and other machines, devices carried by humans and animals, and the like), mobile devices (e.g., tablets, notebooks, laptops, personal computers, portable televisions, radios, and the like), and devices not designed for mobility (e.g., desktop computers, other computers, information kiosks, televisions with one or more processors embedded therein and/or coupled thereto, radios, and the like).
Computer device 1105 can be communicatively coupled (e.g., via I/O interface 1125) to external storage 1145 and network 1150 for communicating with any number of networked components, devices, and systems, including one or more computer devices of the same or different configuration. Computer device 1105 or any connected computer device can be functioning as, providing services of, or referred to as a server, client, thin server, general machine, special-purpose machine, or another label.
I/O interface 1125 can include, but is not limited to, wired and/or wireless interfaces using any communication or I/O protocols or standards (e.g., Ethernet, 802.11x, Universal System Bus, WiMax, modem, a cellular network protocol, and the like) for communicating information to and/or from at least all the connected components, devices, and network in computing environment 1100. Network 1150 can be any network or combination of networks (e.g., the Internet, local area network, wide area network, a telephonic network, a cellular network, satellite network, and the like).
Computer device 1105 can use and/or communicate using computer-usable or computer-readable media, including transitory media and non-transitory media. Transitory media include transmission media (e.g., metal cables, fiber optics), signals, carrier waves, and the like. Non-transitory media include magnetic media (e.g., disks and tapes), optical media (e.g., CD ROM, digital video disks, Blu-ray disks), solid state media (e.g., RAM, ROM, flash memory, solid-state storage), and other non-volatile storage or memory.
Computer device 1105 can be used to implement techniques, methods, applications, processes, or computer-executable instructions in some example computing environments. Computer-executable instructions can be retrieved from transitory media, and stored on and retrieved from non-transitory media. The executable instructions can originate from one or more of any programming, scripting, and machine languages (e.g., C, C++, C#, Java, Visual Basic, Python, Perl, JavaScript, and others).
Processor(s) 1110 can execute under any operating system (OS) (not shown), in a native or virtual environment. One or more applications can be deployed that include logic unit 1160, application programming interface (API) unit 1165, input unit 1170, output unit 1175, and inter-unit communication mechanism 1195 for the different units to communicate with each other, with the OS, and with other applications (not shown). The described units and elements can be varied in design, function, configuration, or implementation and are not limited to the descriptions provided. Processor(s) 1110 can be in the form of physical processors or central processing units (CPU) that is configured to execute instructions loaded from Memory 1115.
In some example implementations, when information or an execution instruction is received by API unit 1165, it may be communicated to one or more other units (e.g., logic unit 1160, input unit 1170, output unit 1175). In some instances, logic unit 1160 may be configured to control the information flow among the units and direct the services provided by API unit 1165, input unit 1170, output unit 1175, in some example implementations described above. For example, the flow of one or more processes or implementations may be controlled by logic unit 1160 alone or in conjunction with API unit 1165. The input unit 1170 may be configured to obtain input for the calculations described in the example implementations, and the output unit 1175 may be configured to provide output based on the calculations described in example implementations.
In example implementations involving a server managing a camera monitoring assets as illustrated by the rearrangement detect server 140 of
Processor(s) 1110 can be configured to determine if the received images from the camera are indicative of the asset from the one or more assets being moved, by comparing the received images to a normal condition image indicative of a normal state of the one or more assets; and for the comparison indicative of a moving object being the asset from the one or more assets being moved, determining that the received images are indicative of the asset from the one or more assets being moved as illustrated in the flow from 804 to 807 from
Processor(s) 1110 can be configured to determine the PLC from the plurality of PLCs that is associated with the final location by determining the PLC from the plurality of PLCs that is managing an area associated with the final location through execution of the flow of
Processor(s) 1110 can be configured to, for the received images from the camera not being indicative of the asset from the one or more assets being moved, for a record in a tracking status database associated with the camera having a time stamp older than a predetermined threshold, generating a normal condition image indicative of a normal state of the one or more assets from the received images; and deleting the record from the tracking status database as illustrated in the flow of 841-845 of
Processor(s) 1110 can be configured to, monitor the asset being moved to the final location through the camera by determining a bounding box on an original location of the asset being moved and another bounding box on a current location of the asset being moved based on a comparison of the received images to a normal condition image indicative of a normal state of the one or more assets as illustrated in the flow of 807-809 of
Processor(s) 1110 can be configured to monitor the asset being moved to a final location through the camera by, for a tracking status database having a record associated with the camera having the bounding box on the original location, updating the record with a current timestamp and with the another bounding box on the current location; and for the tracking status database not having the record associated with the camera having the bounding box on the original location, generating the record for the tracking status database comprising information associated with the camera, the asset being moved, the bounding box on the original location of the asset being moved, and the another bounding box on the current location of the asset being moved; and generating a message to the asset manager to delete the asset being moved from the one or more assets as illustrated in the flow of 811, 851 and 852 of
Some portions of the detailed description are presented in terms of algorithms and symbolic representations of operations within a computer. These algorithmic descriptions and symbolic representations are the means used by those skilled in the data processing arts to convey the essence of their innovations to others skilled in the art. An algorithm is a series of defined steps leading to a desired end state or result. In example implementations, the steps carried out require physical manipulations of tangible quantities for achieving a tangible result.
Unless specifically stated otherwise, as apparent from the discussion, it is appreciated that throughout the description, discussions utilizing terms such as “processing,” “computing,” “calculating,” “determining,” “displaying,” or the like, can include the actions and processes of a computer system or other information processing device that manipulates and transforms data represented as physical (electronic) quantities within the computer system's registers and memories into other data similarly represented as physical quantities within the computer system's memories or registers or other information storage, transmission or display devices.
Example implementations may also relate to an apparatus for performing the operations herein. This apparatus may be specially constructed for the required purposes, or it may include one or more general-purpose computers selectively activated or reconfigured by one or more computer programs. Such computer programs may be stored in a computer readable medium, such as a computer-readable storage medium or a computer-readable signal medium. A computer-readable storage medium may involve tangible mediums such as, but not limited to optical disks, magnetic disks, read-only memories, random access memories, solid state devices and drives, or any other types of tangible or non-transitory media suitable for storing electronic information. A computer readable signal medium may include mediums such as carrier waves. The algorithms and displays presented herein are not inherently related to any particular computer or other apparatus. Computer programs can involve pure software implementations that involve instructions that perform the operations of the desired implementation.
Various general-purpose systems may be used with programs and modules in accordance with the examples herein, or it may prove convenient to construct a more specialized apparatus to perform desired method steps. In addition, the example implementations are not described with reference to any particular programming language. It will be appreciated that a variety of programming languages may be used to implement the teachings of the example implementations as described herein. The instructions of the programming language(s) may be executed by one or more processing devices, e.g., central processing units (CPUs), processors, or controllers.
As is known in the art, the operations described above can be performed by hardware, software, or some combination of software and hardware. Various aspects of the example implementations may be implemented using circuits and logic devices (hardware), while other aspects may be implemented using instructions stored on a machine-readable medium (software), which if executed by a processor, would cause the processor to perform a method to carry out implementations of the present application. Further, some example implementations of the present application may be performed solely in hardware, whereas other example implementations may be performed solely in software. Moreover, the various functions described can be performed in a single unit, or can be spread across a number of components in any number of ways. When performed by software, the methods may be executed by a processor, such as a general purpose computer, based on instructions stored on a computer-readable medium. If desired, the instructions can be stored on the medium in a compressed and/or encrypted format.
Moreover, other implementations of the present application will be apparent to those skilled in the art from consideration of the specification and practice of the teachings of the present application. Various aspects and/or components of the described example implementations may be used singly or in any combination. It is intended that the specification and example implementations be considered as examples only, with the true scope and spirit of the present application being indicated by the following claims.