The present disclosure relates to methods and systems for viewing data related to automation systems in an industrial environment.
Most modern automation systems rely heavily on industrial controllers. Industrial controllers may include any one of or a combination of a Programmable Logic Controller (PLC), a Programmable Logic Relay (PLR), a Programmable Controller, a Distributed Control System (DCS), and other known automation controllers. Industrial controllers may store and execute user-defined parameters to effect decisions during a process. Industrial controllers may have various programming functions that may include ladder logic, structured text, function block diagramming, instruction lists, and sequential flow charts, for example. As one example, most modern manufacturing processes rely heavily on PLCs to control sequential and combinatorial logic in industrial processes. PLCs may be used to control aspects of industrial processes such as those involving assembly lines and robotic devices, for example. Depending on the scale of the industrial application, industrial automation devices can generate a significant amount of real time data. For example, machine health data, alarm statuses, operational statistics, electrical loads, mechanical loads, and operator interaction may be monitored and/or recorded continually during testing and during the manufacturing process.
The abovementioned data may be stored in a computer memory and stored in a database, for example. The data may be stored for a variety of reasons, some examples of which may include: monitoring of machine health, analysis for improving efficiency, scheduling maintenance operations, monitoring of production output, troubleshooting, and determining the cause of faults and/or crashes. Because the amount of real time data may be significant, an operator may view the collection of data via a user interface to improve review efficiency. For example, a user interface may be configured so as to allow the operator to select a particular collection of data and to view expanded data elements. The user interface may further allow an operator to view a collection of data from a particular time interval for various components to troubleshoot the individual components separately and/or to analyze the interaction among various components. While the abovementioned method may improve an operator's ability analyze a significant amount of data, it may be still be difficult and inefficient to determine a frame of reference over which an error, fault, or crash occurred when troubleshooting, even when using the abovementioned user interface. Further, it may be necessary analyze the effect of external factors on the manufacturing process. Therefore, a further need exists to simplify the viewing and analysis of large collections of data. Further advantages will become apparent from the disclosure provided below.
This summary is provided to introduce a selection of concepts in a simplified form that are further described below in the DETAILED DESCRIPTION. This summary is not intended to identify key features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
In accordance with one aspect, a method for displaying performance characteristics of a device is disclosed. The method may include accessing a database of data log files from a data storage source, wherein the data log files include at least one of a data input and a data output from a device. The method may further include accessing a database of video files comprising at least one video feed that includes an image of the device. The database of video files and data log files may be synchronized with respect to time and represented via a graphical user interface as a first timeline graphical representation of the at least one video feed and a second timeline graphical representation of data log files. The first and second timeline graphical representations may be represented in parallel on the graphical user interface. The graphical user interface may further include a scroll element. In response to a scroll command, for example, the first timeline graphical representation and the second timeline graphical representation may be contemporaneously scrolled.
In accordance with another aspect of the disclosure, a non-transitory computer readable medium having instructions stored therein is disclosed. When the instructions are executed by one or more processors, the instructions cause the one or more processors to access a database of data log files from a data storage source, wherein the data log files include at least one of a data input and a data output from a device and/or a string of commands to be executed, and/or recording or log files related to a string of commands. The processor(s) further access a database of video files comprising at least one video feed, including an image of the device, and synchronize the database of the video files and the data log files with respect to time. The processor(s) may generate a first timeline graphical representation of the at least one video feed and a second timeline graphical representation of data log files, wherein the graphical representations include a scroll element. The processor may further display the first timeline graphical representation and the second timeline graphical representation in parallel, via a graphical user interface (GUI) on a display device; and in response to a scroll command, contemporaneously scroll the first timeline graphical representation and the second timeline graphical representation.
In accordance with another aspect of the disclosure, a system for processing and displaying performance characteristics of a device is disclosed. The system comprises at least one memory element that stores instructions for executing a process for displaying performance characteristics of the device and at least one processor configured to execute the process. The process may include accessing a database of data log files from a data storage source, wherein the data log files include at least one of a data input, a data output, a string of commands to be executed, or a recording or log file of a string of commands for a device. The process may further include accessing a database of video files comprising at least one video feed that includes an image of the device. The database of video files and data log files may be synchronized with respect to time and represented via a graphical user interface as a first timeline graphical representation of the at least one video feed and a second timeline graphical representation of data log files. The first and second timeline graphical representations may be represented in parallel on the graphical user interface. The graphical user interface may further include a scroll element. In response to a scroll command, the first timeline graphical representation and the second timeline graphical representation may be simultaneously scrolled.
Additional advantages and novel features of these aspects will be set forth in part in the description that follows, and in part will become more apparent to those skilled in the art upon examination of the following or upon learning by practice of the disclosure.
The novel features believed to be characteristic of aspects of the disclosure are set forth in the appended claims. In the description that follows, like parts are marked throughout the specification and drawings with the same numerals, respectively. The drawing figures are not necessarily drawn to scale and certain figures may be shown in exaggerated or generalized form in the interest of clarity and conciseness. The disclosure itself, however, as well as a preferred mode of use, further objects and advantages thereof, will be best understood by reference to the following detailed description of illustrative aspects of the disclosure when read in conjunction with the accompanying drawings, wherein:
The following includes definitions of selected terms employed herein. The definitions include various examples and/or forms of components that fall within the scope of a term and that may be used for implementation. The examples are not intended to be limiting.
As discussed in further detail below, the data processing application may synchronize multiple stored sources of video and/or audio data with respect to time. Further, the data processing application may synchronize any one of or plurality of the data sources mentioned above with respect to time. Depending on the data to be displayed and the nature of the video and/or audio data, the processing device may scale the data such that relevant data is synchronized with a corresponding video frame. For example, when a robot is not moving or idle, very little data may be generated, whereas when a robot is performing tasks and/or movements, a larger amount of data may be produced. Thus, in the abovementioned example, the data corresponding with the device may be scaled, such that a larger amount of data is shown at once during an operational period of an apparatus. Thus, the amount of device data that corresponds with a single or multiple frames of video of the device may scaled, such that all relevant data with respect to the particular video frame may be displayed.
The synchronized data may be provided via the GUI and represented in a timeline format having a cursor 56 that may be scrollable by a user in directions 52, and where the timeline may include a plurality of video feeds, which may comprise a series of individual scrollable video frames that represent the respective frame of each stored video feed from cameras 16A and 16B with respect to time. The system and GUI may be scalable, and thus any number of video feeds may be added either by default or as configured by a user. Each video feed may be expanded into a larger window 62, which may represent a frame of a video feed at a time corresponding to a position of the cursor/scroll element 56, for example. A user may be able to scroll along the timeline by controlling a cursor and/or scroll element 56. A scrolling function may occur by a user using conventional pointing device (e.g., a mouse) and clicking and dragging the scrod element 56, for example, in either direction 52. As another example, a scrolling function may occur by keystroke (e.g., by pressing arrow keys on a keyboard), or by turning a designated scroll wheel. Further, for example, the GUI may be displayed on a touch sensitive display and may initiate a scrod command based on a user touching and/or dragging scroll element 56 in either direction 56. In addition, a user may be able to move the cursor 56 to a particular video frame, and may be able to selectively play the video feed from the particular time corresponding with the scrod element 56. Thus, a user may be able to play a video feed as it occurred live based on the position of the cursor 56. Further, while the timeline in
The timeline may further include any number of data feeds. Each data feed may include, for example, a simplified version of recorded data with respect to that data source and/or may include all data recorded with respect to the corresponding data source. For example, an enlarged series of windows 58 may be configured to show a ladder logic that corresponds to output programming and/or output of data from either one of PLCs 12A and/or 12B for example. Accordingly, in the simplified version of the GUI 50 shown in
Aspects of the disclosure discussed below may enable significant improvement in the efficiency of troubleshooting operations for a facility. For example, in a traditional facility a significant amount of data may be stored, and while data may be timestamped or organized in some other way, the volume of data may make it difficult to determine what may have caused an error during an operation, for example. Further, in traditional schemes, it may be difficult to determine if an error during a manufacturing process and/or test run was due to an error in programming, an error in hardware, and/or an unexpected outside occurrence (e.g., a person Interfering with the operation of the process). By implementing the aspects of the disclosure discussed herein, a user may determine exactly when an a particular operation and/or error occurred by scrolling through the stored video feed and may then view all time synchronized data and/or programming associated with the industrial device at the time the operation and/or error occurred. A user may also be able to play, pause, and/or rewind a video feed and/or a data stream at the speed at which it occurred and/or at a faster or slower speed to assist in determining the exact root cause of an identified problem.
Once the cause of an problem is determined, a user and/or software may correct any design, engineered, and/or human issues, for example. Further, potential design and/or engineering flaws may be determined and corrected. In addition, by implementing the systems mentioned throughout, best practices in troubleshooting may be identified and shared amongst multiple facilities, for example, to quickly track down errors and make modifications to equipment, systems, and/or programming from known root cause problems. In other aspects, recorded and synchronized data may be utilized for training purposes. Additional aspects, implementations, and advantages will become apparent to one of ordinary skill in the art upon review of the example implementations of the disclosure discussed in detail below.
As shown in
The input-output section (I/O device) 102 may include a series of sensors, and/or other devices that may be configured to detect the occurrence of an event and/or to constantly or intermittently record data, for example. The I/O source 102 may also include a single or multiple PLCs that are programmed to operate manufacturing processes via user-designed logic programs or user programs, for example. The abovementioned PLCs may be used to coordinate the action(s) of a single or multiple industrial devices. Industrial devices may include, but are not limited to, robots, conveyors, pumps, fans, ovens, filters, alarms, fixtures and/or safety fixtures, for example. In each of the abovementioned PLCs, user programs may be stored in memory and generally executed by the PLC in a sequential manner as is known in the art. Examples of such programs include, but are not limited to, sequentially executed instructions, instruction jumping, looping, and interrupt routines. Associated with the user program may be a plurality of memory elements or variables that provide dynamics to PLC operations and programs. These variables may be user-defined, for example, and may be defined as bits, bytes, words, integers, floating point numbers, timers, counters and/or other data types to name but a few examples. Each PLC may output data to a storage device and/or may be coupled to a data logger and/or may include data logging functions. Each PLC may communicate via known protocols, that include but are not limited to: Ethernet IP, Devicenet, Modbus TCP, and Profinet. Further, an input-output section may provide a string of commands or execute software that provides a string of commands to operate at least one or any combination of manufacturing processes discussed above.
As one example, each I/O device (e.g., a PLC) may output a data stream 120 to a storage element 114. The storage element 114 may include a hard drive or other known storage element within a data server 110, for example, as shown in
As shown in
As shown in
Cloud services may include, but are not limited to, data storage 418, data processing 416, control applications (e.g., applications that can generate and deliver control instructions to automation systems 100A, 1008, 100C, and/or 100D based on analysis of real-time system data or other factors), visualization applications 414 (e.g., for generating a GUI and/or for scaling a graphical representation of data with respect to a video feed), reporting applications, notification services, and/or other such applications. For example, in a cloud based system, data storage from either of data storage(s) 112, 114 may be cloud based. Further, in another aspect that may be used in combination with the abovementioned aspects, at least one automation system may include local storage (e.g., as shown by reference 300 In
If the cloud platform is a web-based cloud, industrial devices 100A, 1008, 100C, and/or 100D at the respective industrial facilities 412 and 410 may, for example, interact with cloud services 400 via the Internet. In an example configuration, automation systems 100A, 1008, 100C, and/or 100D may access the cloud services 400 through separate cloud gateways 404 and 402 at the respective industrial facilities 412 and 410, where the automation systems 100A, 1008, 100C, and/or 100D connect to the cloud gateways 404 and 402 through a physical, wireless local area network, and/or radio link. In another example configuration, the industrial devices may access the cloud platform directly using an integrated cloud interface.
Providing automation systems with cloud capability may offer a number of advantages particular to industrial automation. For example, cloud-based storage offered by the cloud platform may be easily scaled. Moreover, multiple industrial facilities at different geographical locations may 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 among the facilities. Automation systems 100A, 1008, 100C, and/or 100D having smart configuration capability, for example, may be configured to automatically detect and communicate with the cloud platform 400 upon installation at any facility, simplifying integration with existing cloud-based data storage, analysis, or reporting applications used by the enterprise. In another example implementation, cloud-based diagnostic applications may monitor the health of respective automation systems and/or their associated industrial devices across an entire plant, or across multiple industrial facilities (e.g., Faculty N, shown as reference 410) that make up an enterprise. The cloud platform may allow software vendors to provide software as a service, removing the burden of software maintenance, upgrade, and backup from customers. It is noted that while two facilities are shown in
The data processing applications 200 and/or 416 may be configured to display a graphical user interface (GUI) showing image information along the lines shown in
A scrolling function may occur by a user using conventional pointing/selecting device (e.g., a mouse) and clicking and dragging the scroll element 504 in either direction 506. As another example, a scrolling function may occur by keystroke (e.g., by pressing arrow keys on a keyboard), and/or by turning a designated scroll wheel. Further, the GUI may be displayed on a touch sensitive display and may initiate a scroll command based on a user touching and/or dragging scroll element 504, for example, in either direction 506. While the timeline 501 in
Further, a user may be provided with the capability to move the scroll element 504 to a particular video frame, and may be able to select to play the video feed from the particular time corresponding with the cursor. For example, a user may be able to play a video feed as it occurs live. Further, a user may be able to view a video feed at a rate that is decreased with relation to time (e.g., in slow motion) and/or at a rate that is increased with relation to time (e.g., in fast motion). A user may also be provided with the option to rewind the feed in any one of the abovementioned states. While only a single enlarged video feed 502B is shown in
Each video feed may be expanded into a larger windows 62 that may display a frame of a video feed at a time corresponding to a position of the cursor/scroll element 56. A user may be able to select to scroll along the timeline by controlling a cursor and/or scroll element 56, for example. A scrolling function may occur by a user using a conventional pointing device (e.g., a mouse) to move the cursor and select and “drag” the scroll element 56 in either direction 52. As another example, a scrolling function may be selected by use of a keystroke (e.g., by pressing one or more arrow keys on a keyboard), or by turning a designated scroll wheel. Further, the GUI may alternatively be displayed on a touch sensitive display, and the user may have the option to select to initiate a scroll command based on the user touching with the cursor and/or dragging the scroll element 56 in either direction 52. Further, a user may be provided with the option to select to move the cursor 56 to a particular video frame, and may be able to play the video feed from the particular time corresponding with the location of the scroll element 56. Thus, for example, a user may thereby be able to play a video feed as it occurs live based on the position of the cursor 56. Further, while the timeline in
The timeline 501 may further include any suitable number of data feeds 508, 511, 512, and/or 513. Each data feed may include a simplified version of recorded data with respect to that data source and/or may include all data recorded with respect to the corresponding data source. In the example shown in
While the scroll element 504 is represented as a line in
implementing the above-mentioned cursor significantly improves efficiency of troubleshooting operations, as a user may more easily and readily determine exactly when an a particular operation and/or error occurred by scrolling through the stored video feed and then viewing any selected time synchronized data and/or programming associated with the industrial device at the time the operation and/or error occurred, for example. Further, the data processing application may be configured do display only relevant data that pertains to a particular data feed or a particular video and/or audio feed. For example, window 502 may be set by the user to selectively display a single or multiple views of a robot arm during a manufacturing process. A window 508B or a plurality of windows may be selected to only show data that is relevant to the particular robot arm being displayed in window 502B; this selection may also be set to occur automatically, for example. Accordingly, if the ladder logic for a particular robot is selected to be displayed, the processing application may be configured to only provide video feeds in window 502B that show the particular robot that is controlled by the ladder logic shown in window 508B.
The abovementioned synchronization and GUI may be implemented using hardware, software, or a combination thereof and may be implemented in one or more computer systems or other processing systems. In an aspect of the present invention, features are directed toward one or more computer systems capable of carrying out the functionality of the data processing disclosed above. An example of such a computer system 1000 is shown in
Computer system 1000 includes one or more processors, such as processor 1004. The processor 1004 is connected to a communication infrastructure 1006 (e.g., a communications bus, cross-over bar, or network). Various software aspects are described in terms of this example computer system. After reading this description, it will become apparent to a person skilled in the relevant art(s) how to implement aspects of the invention using other computer systems and/or architectures.
Computer system 1000 may include a display interface 1002 that forwards graphics, text, and other data from the communication infrastructure 1006 (or from a frame buffer not shown) for display on a display unit 1030. Computer system 1000 also includes a main memory 1008, preferably random access memory (RAM), and may also include a secondary memory 1010. The secondary memory 1010 may include, for example, a hard disk drive 1012, and/or a removable storage drive 1014, representing a floppy disk drive, a magnetic tape drive, an optical disk drive, a universal serial bus (USB) flash drive, etc. The removable storage drive 1014 reads from and/or writes to a removable storage unit 1018 in a well-known manner. Removable storage unit 1018 represents a floppy disk, magnetic tape, optical disk, USB flash drive etc., that is read by and written to removable storage drive 1014. As will be appreciated, the removable storage unit 1018 includes a computer usable storage medium having stored therein computer software and/or data.
Alternative aspects of the present invention may include secondary memory 1010 and may include other similar devices for allowing computer programs or other instructions to be loaded into computer system 1000. Such devices may include, for example, a removable storage unit 1022 and an interface 1020. Examples of such may include a program cartridge and cartridge interface (such as that found in video game devices), a removable memory chip (such as an erasable programmable read only memory (EPROM), or programmable read only memory (PROM)) and associated socket, and other removable storage units 1022 and interfaces 1020, that allow software and data to be transferred from the removable storage unit 1022 to computer system 1000.
Computer system 1000 may also include a communications interface 1024. Communications interface 1024 allows software and data to be transferred between computer system 1000 and external devices. Examples of communications interface 1024 may include a modem, a network interface (such as an Ethernet card), a communications port, a Personal Computer Memory Card International Association (PCMCIA) slot and card, etc. Software and data transferred via communications interface 1024 are in the form of signals 1028, which may be electronic, electromagnetic, optical or other signals capable of being received by communications interface 1024. These signals 1028 are provided to communications interface 1024 via a communications path (e.g., channel) 1026. This path 1026 carries signals 1028 and may be implemented using wire or cable, fiber optics, a telephone line, a cellular link, a radio frequency (RF) link and/or other communications channels. In this document, the terms “computer program medium” and “computer usable medium” are used to refer generally to media such as a removable storage drive 1018, a hard disk installed in hard disk drive 1012, and signals 1028. These computer program products provide software to the computer system 1000. Aspects of the present invention are directed to such computer program products.
Computer programs (also referred to as computer control logic) are stored in main memory 1008 and/or secondary memory 1010. Computer programs may also be received via communications interface 1024. Such computer programs, when executed, enable the computer system 1000 to perform the features in accordance with aspects of the present invention, as discussed herein. In particular, the computer programs, when executed, enable the processor 1004 to perform the features in accordance with aspects of the present invention. Accordingly, such computer programs represent controllers of the computer system 1000.
In an aspect of the present invention where the invention is implemented using software, the software may be stored in a computer program product and loaded into computer system 1000 using removable storage drive 1014, hard drive 1012, or communications interface 1020. The control logic (software), when executed by the processor 1004, causes the processor 1004 to perform the functions described herein. In another aspect of the present invention, the system is implemented primarily in hardware using, for example, hardware components, such as application specific integrated circuits (ASICs).
In some implementations, one or more microcontrollers may be implemented in the external device 128 for carrying out features of the present invention. An example of such a microcontroller 1100 is shown in
The CPU 1102 may be implemented as one or more single core or multi-core processors, and receive signals from an interrupt controller 1120 and a clock 1104. The clock 1104 sets the operating frequency of the entire microcontroller 1100 and may include one or more crystal oscillators having predetermined frequencies. Alternatively, the clock 1104 may receive an external clock signal. The interrupt controller 1120 may also send interrupt signals to the CPU to suspend CPU operations. The interrupt controller 1120 may transmit an interrupt signal to the CPU when an event requires immediate CPU attention.
The RAM 1108 may include one or more SRAM, DRAM, SDRAM, DDR SDRAM, DRRAM or other suitable volatile memory. The ROM 1110 may include one or more PROM, EPROM, EEPROM, flash memory, or other types of non-volatile memory.
The timer 1112 may keep time and/or calculate the amount of time between events occurring within the microcontroller 1100, count the number of events, and/or generate baud rate for communication transfer. The BUS controller 1114 prioritizes BUS usage within the microcontroller 1100. The ADC 1118 allows the microcontroller 1100 to send out pulses to signal other devices.
The interface 1116 is an input/output device that allows the microcontroller 1100 to exchange information with other devices. In some implementations, the interface 1116 may include one or more parallel port, a serial port, or other computer interfaces.
The aspects discussed herein can also be described and implemented in the context of computer-readable storage medium storing computer-executable instructions. Computer-readable storage media includes computer storage media and communication media. For example, flash memory drives, digital versatile discs (DVDs), compact discs (CDs), floppy disks, and tape cassettes. Computer-readable storage media can include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, modules or other data.
The foregoing description of various aspects and examples have been presented for purposes of illustration and description. It is not intended to be exhaustive nor to limit the disclosure to the forms described. The embodiment(s) illustrated in the figures can, in some instances, be understood to be shown to scale for illustrative purposes. Numerous modifications are possible in light of the above teachings, including a combination of the abovementioned aspects. Some of those modifications have been discussed and others will be understood by those skilled in the art. The various aspects were chosen and described in order to best illustrate the principles of the present disclosure and various aspects as are suited to the particular use contemplated. The scope of the present disclosure is, of course, not limited to the examples or aspects set forth herein, but can be employed in any number of applications and equivalent devices by those of ordinary skill in the art. Rather, it is hereby intended the scope be defined by the claims appended hereto.