US20150073751A1 - Embedded Prognostics on PLC Platforms for Equipment Condition Monitoring, Diagnosis and Time-to-Failure/Service Prediction - Google Patents

Embedded Prognostics on PLC Platforms for Equipment Condition Monitoring, Diagnosis and Time-to-Failure/Service Prediction Download PDF

Info

Publication number
US20150073751A1
US20150073751A1 US14/391,268 US201314391268A US2015073751A1 US 20150073751 A1 US20150073751 A1 US 20150073751A1 US 201314391268 A US201314391268 A US 201314391268A US 2015073751 A1 US2015073751 A1 US 2015073751A1
Authority
US
United States
Prior art keywords
data
analysis program
buffer
programmable logic
features
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
US14/391,268
Other versions
US9996405B2 (en
Inventor
Linxia Liao
Ertan Eligul
Zachery Edmondson
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Siemens AG
Original Assignee
Siemens Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Siemens Corp filed Critical Siemens Corp
Priority to US14/391,268 priority Critical patent/US9996405B2/en
Publication of US20150073751A1 publication Critical patent/US20150073751A1/en
Assigned to SIEMENS CORPORATION reassignment SIEMENS CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: ELIGUL, Ertan, LIAO, LINXIA
Assigned to SIEMENS CORPORATION reassignment SIEMENS CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: EDMONDSON, Zachery
Application granted granted Critical
Publication of US9996405B2 publication Critical patent/US9996405B2/en
Assigned to SIEMENS AKTIENGESELLSCHAFT reassignment SIEMENS AKTIENGESELLSCHAFT ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: SIEMENS CORPORATION
Assigned to SIEMENS AKTIENGESELLSCHAFT reassignment SIEMENS AKTIENGESELLSCHAFT ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: SIEMENS CORPORATION
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B19/00Programme-control systems
    • G05B19/02Programme-control systems electric
    • G05B19/04Programme control other than numerical control, i.e. in sequence controllers or logic controllers
    • G05B19/05Programmable logic controllers, e.g. simulating logic interconnections of signals according to ladder diagrams or function charts
    • G05B19/058Safety, monitoring
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B23/00Testing or monitoring of control systems or parts thereof
    • G05B23/02Electric testing or monitoring
    • G05B23/0205Electric testing or monitoring by means of a monitoring system capable of detecting and responding to faults
    • G05B23/0218Electric testing or monitoring by means of a monitoring system capable of detecting and responding to faults characterised by the fault detection method dealing with either existing or incipient faults
    • G05B23/0224Process history based detection method, e.g. whereby history implies the availability of large amounts of data
    • G05B23/024Quantitative history assessment, e.g. mathematical relationships between available data; Functions therefor; Principal component analysis [PCA]; Partial least square [PLS]; Statistical classifiers, e.g. Bayesian networks, linear regression or correlation analysis; Neural networks
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B2219/00Program-control systems
    • G05B2219/20Pc systems
    • G05B2219/24Pc safety
    • G05B2219/24075Predict control element state changes, event changes
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B2223/00Indexing scheme associated with group G05B23/00
    • G05B2223/06Remote monitoring

Definitions

  • This invention relates generally to techniques for machine monitoring. More particularly, the invention relates to embedding prognostics analysis software in a programmable logic controller platform to perform equipment prognosis.
  • the present disclosure proposes a technology to add local data processing capability to programmable logic control (PLC) systems for prognostics.
  • PLC programmable logic control
  • the proposed system can potentially be applied to broader applications.
  • the proposed system utilizes the computational power (e.g., multi-core CPU) of modern PLC platforms to provide equipment prognostics information as a value-added function.
  • the system adapts to various operating conditions/usages and is capable of identifying and diagnosing equipment faults during regular operations with minimum human intervention. Before a major failure occurs, the system alerts the user of the need for maintenance to be performed, using PLC diagnosis messages or simple physical indicators such as lighting.
  • Multi-sensory data are collected (synchronously or asynchronously) in the background during regular operation and are converted to a single-digit health indicator through a set of data analysis algorithms. If the health indicator exceeds a statistical/predefined threshold, diagnosis and prediction functions are triggered to determine the type of fault and/or potential remaining useful life or time to service.
  • a method for determining prognostic information for equipment controlled by a programmable logic controller utilizes a prognostics analysis program embedded in a software platform of the programmable logic controller. A determination is made whether the prognostics analysis program has an idle status. If so, then, by the programmable logic controller during programmable logic controller real-time cycles, a predetermined number of data samples are read from a data acquisition device and the data samples are written to a buffer.
  • a system function block of the programmable logic controller software platform then activates the prognostics analysis program to have an active status.
  • the data samples are read from the buffer into the prognostics analysis program.
  • An operating condition of the equipment is identified based on the data samples from the buffer, and, based on the operating condition of the equipment, a plurality of features are extracted from the data samples from the buffer.
  • a non-transitory computer-usable medium having computer readable instructions stored thereon for execution by a processor to perform operations for determining prognostic information for equipment controlled by a programmable logic controller, using a prognostics analysis program embedded in a software platform of the programmable logic controller, as described above.
  • a programmable logic controller having a prognostics analysis program embedded in a software platform of the programmable logic controller, as described above.
  • FIG. 1 is a schematic diagram showing operation of a PLC with embedded prognostics according to one embodiment of the invention.
  • FIG. 2 is a block diagram showing a PLC with embedded prognostics according to an embodiment of the invention.
  • FIG. 3 is a block diagram showing a particular configuration of a PLC with embedded prognostics according to an embodiment of the invention.
  • FIG. 4 is a flow chart showing a method in accordance with one embodiment of the invention.
  • FIG. 5 is a schematic block diagram illustrating a data processing schema according to an embodiment of the invention.
  • FIG. 6 is a block diagram showing a test bed for testing a system in accordance with one embodiment of the invention.
  • FIGS. 7 a , 7 b , 7 c , 7 d and 7 e are plots of raw vibration data produced in testing a system in accordance with one embodiment of the invention.
  • FIG. 8 is a plot showing a calculated deviation from baseline for several test runs using the test bed of FIG. 6 .
  • FIG. 9 is a schematic block diagram of a data processing system in accordance with one embodiment of the invention.
  • the system described herein delivers simple, reliable machine diagnostics and prognostics information to the equipment users.
  • a key requirement of the technology is that it should generate this information without custom machine modeling, custom parameterization, or special machine test cycles—that is, as close to “plug and play” as possible.
  • the development of prognostics solutions on embedded PLC platforms brings the analysis functions closer to the equipment, targeting broader applications with lower cost controllers.
  • External sensors 130 measure attributes relating to the equipment 110 or its environment.
  • the equipment may, for example, be a machining center as shown.
  • a broad range of sensors types may be chosen by the customer.
  • Sensor measurements are read by a data acquisition device (DAQ) 140 that conditions and/or compiles the data.
  • DAQ data acquisition device
  • a broad range of data acquisition device types may also be chosen by the customer.
  • Data is periodically transferred from the data acquisition device 140 to an embedded prognostics analysis program 120 on the PLC system 115 .
  • Results 150 computed by the prognostics analysis program 120 are then transferred to a man-machine interface (MMI) or storage 160 .
  • MMI man-machine interface
  • the prognostics analysis program results are available locally to machine operators, etc. Because the analysis takes place locally, there is no need to transport large amounts of measurement data through the factory network.
  • the prognostics functions are integrated into a PLC platform.
  • the integrated system collects data from sensors using the PLC input modules and/or third-party devices and/or internal sensor signals.
  • the system automatically converts data to prognostics information using an embedded prognostics library.
  • a PLC system 200 in accordance with the present disclosure is shown in FIG. 2 .
  • the system comprises a PLC 215 running at least two programs: a program 216 running in the real-time operating system of the PLC, and embedded prognosis software 220 .
  • a PLC cycle program 217 runs cyclically from the real-time operating system program 216 .
  • the PLC cycle program 217 collects data from the DAQ device 240 which is connected to sensors 230 installed on the equipment 210 .
  • the PLC cycle program 217 can also collect data from internal sensors.
  • the PLC cycle can execute regular or high speed cycles depending on the requirement of sampling frequency. Multiple PLC cycles can be used to collect data under different sampling frequency requirements.
  • a system function block 218 is initialized to activate the embedded prognostics software 220 and to transfer the data in buffer to the prognostics software 220 .
  • the prognostics analysis software 220 processes the received data.
  • the prognostics analysis software is implemented as a plug-in software component such as in DLL format. It also provides opportunity to use a third-party device 260 , such as a commercial industrial man-machine interface.
  • FIG. 3 An example implementation 300 of the system structure 200 ( FIG. 2 ) on a Siemens PLC system 315 running WinAC is shown in FIG. 3 .
  • the organizational blocks 317 run cyclically from the Step 7 program 316 running in WinLC real time extension.
  • the program in the organizational blocks 317 collects data from the DAQ device 340 which is connected to sensors 330 installed on the equipment 310 .
  • a system function call is initialized to call a custom code extension (CCX) function 321 in the dynamic link library to transfer the data in the Step 7 buffer to Siemens PnP analysis software 320 .
  • the Siemens WinAC ODK CCX provides tools to implement a DLL or RTDLL from a high-level programming language environment.
  • the PnP analysis software 320 is implemented using CCX DLL (in C++ language) to process the received data. It also may provide interfacing to use a third-party device 360 in the CCX DLL.
  • FIG. 4 A flowchart 400 showing the operation of a system integrating the PLC cycle program 410 and the analysis program (AP) 450 is shown in FIG. 4 .
  • the left-hand side represents the PLC cycle program 410 and the right-hand side represents the AP 450 .
  • data acquisition is the primary task.
  • the program starts at 420 , and data acquisition proceeds only when the AP is idle (decision 422 ).
  • the system assures that adequate processing resources are available in the PLC because only one of the data acquisition cycle and the AP run at any given time.
  • the requirement also synchronizes the relatively fast data acquisition cycle with the relatively slow analysis program, preventing the former from overwhelming the latter with data.
  • Data acquisition further proceeds only when the DAQ trigger condition (e.g. equipment is running or operational) is met (decision 424 ), avoiding the collection and analysis of meaningless or null data.
  • the DAQ trigger condition e.g. equipment is running or operational
  • the program reads (operation 426 ) one data sample from the DAQ device (and/or third-party device) and writes (operation 428 ) the data sample into the PLC buffer created in the PLC data blocks.
  • the data counter is increased when a data sample is read.
  • the PLC program stops data collection and calls AP (operation 434 ) to transfer the data. If either of the trigger conditions 422 , 424 is no longer met before the predefined threshold is reached (decision 430 ), the data buffer is cleared and data counter is reset (operation 432 ).
  • the PLC program starts to wait (operation 420 ) until the trigger condition is met.
  • the AP 450 is responsible for analyzing data and generating prognostics information. Once the AP is called (operation 462 ) by the PLC program, it sets the AP status to busy (operation 464 ) so that the PLC program stops reading data. The AP reads the data record (containing multiple data samples) saved in the PLC buffer (operation 466 ), and applies operating condition identification (operation 468 ) and then signal processing algorithms to extract features (operation 470 ) from the raw data. Before the AP starts predicting, it is determined whether a baseline has been trained based on a predefined number (e.g. 100) of data records (decision 474 ). If the model has not been trained and if the predefined threshold is not met (decision 474 ), the AP saves the extracted features into a data array and sets AP status to idle (operation 480 ) to wait for more data records to come.
  • a predefined number e.g. 100
  • the AP applies the training algorithm (operation 478 ) to train a baseline base on the saved data array which contains all the extracted features. After a baseline is trained (decision 472 ), the AP applies the testing algorithm and outputs prediction results (operation 476 ) when new data arrives.
  • the AP is in CCX DLL format if implemented on a Siemens PLC system running WinAC.
  • FIG. 5 An overview data analysis flowchart 500 in accordance with the present disclosure is shown in FIG. 5 .
  • the operating condition O n of a piece of equipment is alternating over time (block 510 ) due to different usages of the machine.
  • the operating condition can be determined (block 520 ) by a single variable such as speed, voltage, and direction, or can be determined using a combination of multiple variables. If the operating condition has already existed (O 1 . . . O n ) the measurement data is input to the prediction model 530 (M 1 . . . M n ) associated with the operating condition to generate prediction result (R 1 . . . R n ).
  • a new operating condition O — new is created and the associated prediction model M — new is trained when a pre-defined number of data records are collected. Once the prediction model is trained, it can start generating prediction results. The prediction results are organized (block 540 ) according to the sequence of the appearance of the operating condition over time (block 510 ).
  • An example of the data analysis flow for anomaly detection and fault diagnosis of industrial machine tools is given as follows.
  • the algorithms used in the prediction model associated with one operating condition O n are indicated by M n in FIG. 5 .
  • the specific algorithms in the prediction model can be customized for different applications.
  • a “most stable window” from each data record is selected to avoid noise that may change quickly over time in the time domain and/or to avoid dramatic frequency changes.
  • FFT fast Fourier transform
  • Band energies are calculated within equally distributed frequency ranges along the FFT spectrum.
  • a wavelet packet transform represents a signal in terms of a waveform (known as a mother wavelet) with a finite length or fast decaying oscillating characteristic.
  • Time domain feature extraction is also applied to the selected data segment to calculate statistics such as mean, standard deviation, Root Mean Square (RMS) and kurtosis, etc. After all the aforementioned features are extracted, they are used as input to self-organized maps (SOM) for anomaly detection or diagnosis purposes.
  • SOM self-organized maps
  • This section demonstrates the concept of the embedded prognostics system using a motor test bed to test anomaly detection and diagnosis functions.
  • a Maxon dc motor 610 (A-max 26), a rubber wheel (loading) 640 and coupling 645 are assembled.
  • a mount 630 is designed to support the motor on a base 620 .
  • the motor is powered with a 24 VDC power supply 615 .
  • An accelerometer 650 (IMI PCB 624B61) is installed on the housing of the motor 610 .
  • the output range of the accelerometer 650 is between ⁇ 5 and +5 volts.
  • the data is conditioned using a signal conditioner 660 (IMI 682A02) which provides 4 mA current excitation to the accelerometer and an output of the original signal on the scale of 1:1.
  • the data is taken at a sampling frequency 1 kHz (OB's cycle is set to 1 ms) using regular AI module 672 (e.g. AI 2 ⁇ 12 bit 6ES7 331-7 KB02-0AB0; higher data conversion speed of 52 ⁇ s can be achieved using high speed AI module, e.g. AI 8 ⁇ 14 bit 6ES7 331-7HF01-0AB0).
  • the DI module 674 (DI 16 ⁇ DC24V 6ES7 321-1BH02-0AA0) is used to detect the running or operating state (on/off) of the motor 610 .
  • the AI and DI modules are connected to an interface module 670 (IM513-4PN 6ES7 153-4AA00-0XB0) which is connected to the industrial Ethernet 690 .
  • a PC 680 (can be replaced by a PC based controller) on which WinAC is running is connected to the industrial Ethernet 690 via a PCI interface card 691 (CP1616-CP1604).
  • imbalance faults were introduced manually to the motor test bed. Small screws were installed on various angular locations of a wheel flange that rotates with the shaft. As the location of the screw changes, the imbalance patterns change as well.
  • the purpose of the test was firstly to detect whether there is an imbalance situation (using unsupervised learning) and secondly to differentiate various imbalance patterns (using supervised training) when an imbalance situation appears. It was noticed that there exists misalignment inherent in the installation. The misalignment existed in all balanced and imbalanced situations. The algorithms were able to detect the imbalanced patterns despite the misalignment.
  • the manually introduced imbalance patterns on the motor test bed include (a) no imbalance screws installed (“balanced”), (b) one screw installed on the flange angularly close to the set screw used to fix the flange to the shaft (“1 screw near”), (c) one screw installed angularly opposite (approximately 180 degrees from) the set screw (“1 screw far”), (d) two screws installed close to the set screw (“2 screw near”), (e) two screws installed opposite the set screw (“2 screw far”). ‘Near’ and ‘far’ are both relative to the position of the set screw.
  • the motor was run approximately 500 seconds for each different imbalance situation, and the data was collected using the AI module. 500 data records are generated randomly into segments of 4096 data samples from the 500 seconds' data. The raw vibration data under different balanced and imbalanced situations is shown in FIGS. 7 a through 7 e . It is not simple to differentiate the imbalance situations by looking only at the time domain signals.
  • the rotation speed of the motor was selected as determining the operating condition. To be simple, the motor was run at a constant speed, creating only one operating condition. The following analysis is within that specific operating condition.
  • a self-organizing map (SOM) was trained with only balanced data, which was used as the baseline. The map was then tested with other data collected in situations of 1screwNear, 1screwFar, 2screwNear and 2screwFar.
  • FIG. 8 shows the distances of different imbalances to the baseline, which differentiating 4 types of imbalance situations with the balanced situation using the output of the SOM (MQE is an indicator of deviation from baseline).
  • the diagnosis test with supervised training is therefore done with 4 classes: balanced, 1screwFar, 2screwNear, 2screwFar.
  • a cross validation method is applied. Four folds are created and each fold contains 80 data records. These data records are composed of 4 classes, which are the imbalanced situations. In each test, a SOM map is trained with 3 folds and the remaining fold is tested.
  • the following features are used as input to the supervised SOM algorithm: Energys centered at the 2nd, 3rd, 4th and 6th of the running speed within a 20 Hz band, crest factor of the signal and standard deviation of the signal. There are therefore 6 features for each data record.
  • peaks can be seen at the frequency of 167 Hz and its multiples, which means at that frequency is dominated.
  • the range is chosen 20 Hz which means 167 +/ ⁇ 20 Hz.
  • the energies represent those values.
  • the 2nd energy includes the energies between frequency 167*2 ⁇ 20 Hz and 167*2+20 Hz;
  • the 3rd energy is between 167*3 ⁇ 20 Hz and 167*3+20 Hz; and so on.
  • the program can predict the classes with an accuracy of 95% in the cross validation tests.
  • PLC programmable logic controller
  • the PLC 910 is preferably a commercial industrial unit capable of collecting data cyclically from internal or external sensors and processing that data. The PLC may further be capable of controlling equipment using the collected data. The PLC 910 may receive the data through a data acquisition device 950 or directly from sensors (not shown).
  • Input/output data may be passed between the PLC 910 and a man-machine interface (MMI) 948 via a wide area network such as the Internet, via a local area network or via a direct bus connection.
  • MMI man-machine interface
  • the PLC 910 may be configured to operate and display information by using, e.g., the MMI 948 to execute certain tasks.
  • data acquisition is initiated via the MMI 948 , and prognostic results are displayed to the user via the same device.
  • the PLC 910 includes one or more processors 920 such as a central processing unit (CPU) and further includes a memory 930 .
  • the processor 920 when configured using software according to the present disclosure, includes a prognostics analysis software module 922 that is configured for performing one or more methods for determining prognostic information for equipment controlled by the PLC 910 , as discussed herein.
  • Those modules include a PLC run-time program 924 that collects data from external sensors and may also transmit machine control commands to the controlled equipment.
  • the memory 930 may include a random access memory (RAM) and a read-only memory (ROM).
  • the memory may also include removable media such as a disk drive, tape drive, memory card, etc., or a combination thereof.
  • the RAM functions as a data memory that stores data used during execution of programs in the processor 920 ; the RAM is also used as a program work area.
  • the ROM functions as a program memory for storing a program executed in the processor 920 .
  • the program may reside on the ROM or on any other tangible or non-volatile computer-readable media 940 as computer readable instructions stored thereon for execution by the processor to perform the methods of the invention.
  • the ROM may also contain data for use by the program or by other programs.
  • program modules 922 , 924 described above include routines, objects, components, data structures and the like that perform particular tasks or implement particular abstract data types.
  • program as used herein may connote a single program module or multiple program modules acting in concert.
  • the disclosure may be implemented on a variety of types of computers, including dedicated PLCs, personal computers (PCs), hand-held devices, multi-processor systems, microprocessor-based programmable consumer electronics, network PCs, mini-computers, mainframe computers and the like.
  • the disclosed technique may also be employed in distributed computing environments, where tasks are performed by remote processing devices that are linked through a communications network.
  • modules may be located in both local and remote memory storage devices.
  • An exemplary processing module for implementing the methodology above may be hardwired or stored in a separate memory that is read into a main memory of a processor or a plurality of processors from a computer readable medium such as a ROM or other type of hard magnetic drive, optical storage, tape or flash memory.
  • a computer readable medium such as a ROM or other type of hard magnetic drive, optical storage, tape or flash memory.
  • execution of sequences of instructions in the module causes the processor to perform the process steps described herein.
  • the embodiments of the present disclosure are not limited to any specific combination of hardware and software and the computer program code required to implement the foregoing can be developed by a person of ordinary skill in the art.
  • a computer-readable medium refers to any tangible machine-encoded medium that provides or participates in providing instructions to one or more processors.
  • a computer-readable medium may be one or more optical or magnetic memory disks, flash drives and cards, a read-only memory or a random access memory such as a DRAM, which typically constitutes the main memory.
  • Such media excludes propagated signals, which are not tangible. Cached information is considered to be stored on a computer-readable medium.
  • Common expedients of computer-readable media are well-known in the art and need not be described in detail here.
  • the present disclosure describes a system and method including embedded equipment prognostics (anomaly detection, diagnosis and time-to-failure/service prediction) analysis functions on PLC platforms.
  • the systems collects data from the sensors installed on a device using the PLC input modules in the PLC cycle program.
  • Prognostics analysis software is implemented as plug-in software components such as DLLs to be called by the PLC cycle program after data is collected.
  • the system has been demonstrated using a motor test-bed, and was shown to successfully detect and identify anomaly situations of different imbalance faults on the motor loading.
  • the system can be potentially applied to a variety of applications including but not limited to machine tool components (e.g. motor, gearbox, and bearing), gas/wind turbines and trains.

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Automation & Control Theory (AREA)
  • Theoretical Computer Science (AREA)
  • Artificial Intelligence (AREA)
  • Evolutionary Computation (AREA)
  • Mathematical Physics (AREA)
  • Quality & Reliability (AREA)
  • General Engineering & Computer Science (AREA)
  • Testing And Monitoring For Control Systems (AREA)

Abstract

A prognostics analysis software module is embedded in a programmable logic controller (PLC) software platform. During cycling of the PLC real-time operating program, data is read from sensors and written to a buffer only when the prognostics analysis software module is idle. The prognostics analysis software module is then activated by a system function block of the PLC software platform. Before determining any prognostic information, prediction models within the prognostics analysis software module are automatically trained using features extracted from the sensor data.

Description

    CLAIM OF PRIORITY
  • This application claims priority to, and incorporates by reference herein in its entirety, pending U.S. Provisional Patent Application Ser. No. 61/623,647, filed Apr. 13, 2012, and entitled “Embedded Prognostics on PLC Platforms for Equipment Condition Monitoring, Diagnosis and Time-to-Failure/Service Prediction.”
  • FIELD OF THE INVENTION
  • This invention relates generally to techniques for machine monitoring. More particularly, the invention relates to embedding prognostics analysis software in a programmable logic controller platform to perform equipment prognosis.
  • BACKGROUND OF THE INVENTION
  • Unexpected downtime remains an important issue impacting productivity and total cost of ownership in the manufacturing industry. Early detection of emerging faults and degradation trends can prevent downtime, target maintenance efforts, increase productivity and save costs. Condition-based maintenance systems in manufacturing plants continuously deliver data related to the machine's status and performance, but the challenge for field engineers and management staff is making effective use of the huge amount of data to accurately detect equipment degradation.
  • SUMMARY OF THE INVENTION
  • To address the aforementioned issues, the present disclosure proposes a technology to add local data processing capability to programmable logic control (PLC) systems for prognostics. The proposed system can potentially be applied to broader applications. The proposed system utilizes the computational power (e.g., multi-core CPU) of modern PLC platforms to provide equipment prognostics information as a value-added function. The system adapts to various operating conditions/usages and is capable of identifying and diagnosing equipment faults during regular operations with minimum human intervention. Before a major failure occurs, the system alerts the user of the need for maintenance to be performed, using PLC diagnosis messages or simple physical indicators such as lighting. Multi-sensory data are collected (synchronously or asynchronously) in the background during regular operation and are converted to a single-digit health indicator through a set of data analysis algorithms. If the health indicator exceeds a statistical/predefined threshold, diagnosis and prediction functions are triggered to determine the type of fault and/or potential remaining useful life or time to service.
  • Presently disclosed is a method for determining prognostic information for equipment controlled by a programmable logic controller. The method utilizes a prognostics analysis program embedded in a software platform of the programmable logic controller. A determination is made whether the prognostics analysis program has an idle status. If so, then, by the programmable logic controller during programmable logic controller real-time cycles, a predetermined number of data samples are read from a data acquisition device and the data samples are written to a buffer.
  • A system function block of the programmable logic controller software platform then activates the prognostics analysis program to have an active status. The data samples are read from the buffer into the prognostics analysis program. An operating condition of the equipment is identified based on the data samples from the buffer, and, based on the operating condition of the equipment, a plurality of features are extracted from the data samples from the buffer.
  • A determination is made whether a model corresponding to the identified operating condition has been trained and, only if the model has been trained, the model is used in determining the prognostic information based on the features. After determining the prognostic information, the prognostics analysis program status is set to idle.
  • In another aspect of the invention, a non-transitory computer-usable medium is provided having computer readable instructions stored thereon for execution by a processor to perform operations for determining prognostic information for equipment controlled by a programmable logic controller, using a prognostics analysis program embedded in a software platform of the programmable logic controller, as described above.
  • In another aspect of the invention, a programmable logic controller is provided having a prognostics analysis program embedded in a software platform of the programmable logic controller, as described above.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 is a schematic diagram showing operation of a PLC with embedded prognostics according to one embodiment of the invention.
  • FIG. 2 is a block diagram showing a PLC with embedded prognostics according to an embodiment of the invention.
  • FIG. 3 is a block diagram showing a particular configuration of a PLC with embedded prognostics according to an embodiment of the invention.
  • FIG. 4 is a flow chart showing a method in accordance with one embodiment of the invention.
  • FIG. 5 is a schematic block diagram illustrating a data processing schema according to an embodiment of the invention.
  • FIG. 6 is a block diagram showing a test bed for testing a system in accordance with one embodiment of the invention.
  • FIGS. 7 a, 7 b, 7 c, 7 d and 7 e are plots of raw vibration data produced in testing a system in accordance with one embodiment of the invention.
  • FIG. 8 is a plot showing a calculated deviation from baseline for several test runs using the test bed of FIG. 6.
  • FIG. 9 is a schematic block diagram of a data processing system in accordance with one embodiment of the invention.
  • DESCRIPTION OF THE INVENTION
  • Many challenges remain in adapting prognostics algorithms to the numerous types of equipment and applications in use, without requiring significant effort to implement each case. Further challenges exist in bringing prognostics solutions closer to the equipment to ensure information is delivered to the right people at the right time.
  • For example, current approaches may use a condition monitoring server, remote from the PLCs, where the actual calculation is performed. A large amount of data must be transferred from the PLCs to remote computers for information processing. That data transfer may incur network traffic problems as well as extensive costs in storing and maintaining large amounts of data. Moreover, the lag of the data transfer may delay the information processing and lead to a lag of maintenance decision-making.
  • The system described herein delivers simple, reliable machine diagnostics and prognostics information to the equipment users. A key requirement of the technology is that it should generate this information without custom machine modeling, custom parameterization, or special machine test cycles—that is, as close to “plug and play” as possible. The development of prognostics solutions on embedded PLC platforms brings the analysis functions closer to the equipment, targeting broader applications with lower cost controllers.
  • A basic concept of the prognostics solution on embedded PLC platforms is illustrated by the system 100 shown in FIG. 1. External sensors 130 measure attributes relating to the equipment 110 or its environment. The equipment may, for example, be a machining center as shown. A broad range of sensors types may be chosen by the customer.
  • Sensor measurements are read by a data acquisition device (DAQ) 140 that conditions and/or compiles the data. A broad range of data acquisition device types may also be chosen by the customer. Data is periodically transferred from the data acquisition device 140 to an embedded prognostics analysis program 120 on the PLC system 115. Results 150 computed by the prognostics analysis program 120 are then transferred to a man-machine interface (MMI) or storage 160. The prognostics analysis program results are available locally to machine operators, etc. Because the analysis takes place locally, there is no need to transport large amounts of measurement data through the factory network.
  • Methodology
  • The prognostics functions are integrated into a PLC platform. The integrated system collects data from sensors using the PLC input modules and/or third-party devices and/or internal sensor signals. The system automatically converts data to prognostics information using an embedded prognostics library.
  • The following acronyms are used in the present disclosure:
      • WinAC—Windows automation center
      • RT—Real-time
      • RTX—Real-time extension
      • ODK—Open development kit
      • OB—Organizational block
      • DB—Data block
      • CCX—Custom code extension
      • DLL—Dynamic-link library
      • RTDLL—Real-time dynamic-link library
      • WinLC—Windows logic controller
      • SFB—System function block
      • DAQ—Data acquisition
      • AI—Analogue input
      • DI—Digital input
      • SOM—Self-organizing maps
  • System Structure
  • A PLC system 200 in accordance with the present disclosure is shown in FIG. 2. The system comprises a PLC 215 running at least two programs: a program 216 running in the real-time operating system of the PLC, and embedded prognosis software 220. A PLC cycle program 217 runs cyclically from the real-time operating system program 216. The PLC cycle program 217 collects data from the DAQ device 240 which is connected to sensors 230 installed on the equipment 210. The PLC cycle program 217 can also collect data from internal sensors. The PLC cycle can execute regular or high speed cycles depending on the requirement of sampling frequency. Multiple PLC cycles can be used to collect data under different sampling frequency requirements.
  • When a preset number of data samples is collected, a system function block 218 is initialized to activate the embedded prognostics software 220 and to transfer the data in buffer to the prognostics software 220. The prognostics analysis software 220 processes the received data. The prognostics analysis software is implemented as a plug-in software component such as in DLL format. It also provides opportunity to use a third-party device 260, such as a commercial industrial man-machine interface.
  • An example implementation 300 of the system structure 200 (FIG. 2) on a Siemens PLC system 315 running WinAC is shown in FIG. 3. The organizational blocks 317 run cyclically from the Step 7 program 316 running in WinLC real time extension. The program in the organizational blocks 317 collects data from the DAQ device 340 which is connected to sensors 330 installed on the equipment 310.
  • When a preset number of data samples is collected, a system function call is initialized to call a custom code extension (CCX) function 321 in the dynamic link library to transfer the data in the Step 7 buffer to Siemens PnP analysis software 320. The Siemens WinAC ODK CCX provides tools to implement a DLL or RTDLL from a high-level programming language environment. The PnP analysis software 320 is implemented using CCX DLL (in C++ language) to process the received data. It also may provide interfacing to use a third-party device 360 in the CCX DLL.
  • Program Flowchart
  • A flowchart 400 showing the operation of a system integrating the PLC cycle program 410 and the analysis program (AP) 450 is shown in FIG. 4. The left-hand side represents the PLC cycle program 410 and the right-hand side represents the AP 450.
  • In the PLC cycle program 410, data acquisition is the primary task. The program starts at 420, and data acquisition proceeds only when the AP is idle (decision 422). By requiring the AP program to be idle before cycling the data acquisition routine, the system assures that adequate processing resources are available in the PLC because only one of the data acquisition cycle and the AP run at any given time. The requirement also synchronizes the relatively fast data acquisition cycle with the relatively slow analysis program, preventing the former from overwhelming the latter with data.
  • Data acquisition further proceeds only when the DAQ trigger condition (e.g. equipment is running or operational) is met (decision 424), avoiding the collection and analysis of meaningless or null data.
  • In each PLC cycle, the program reads (operation 426) one data sample from the DAQ device (and/or third-party device) and writes (operation 428) the data sample into the PLC buffer created in the PLC data blocks. The data counter is increased when a data sample is read. When the number of the collected data samples reaches a predefined threshold (e.g. 100) (decision 430), the PLC program stops data collection and calls AP (operation 434) to transfer the data. If either of the trigger conditions 422, 424 is no longer met before the predefined threshold is reached (decision 430), the data buffer is cleared and data counter is reset (operation 432). The PLC program starts to wait (operation 420) until the trigger condition is met.
  • The AP 450 is responsible for analyzing data and generating prognostics information. Once the AP is called (operation 462) by the PLC program, it sets the AP status to busy (operation 464) so that the PLC program stops reading data. The AP reads the data record (containing multiple data samples) saved in the PLC buffer (operation 466), and applies operating condition identification (operation 468) and then signal processing algorithms to extract features (operation 470) from the raw data. Before the AP starts predicting, it is determined whether a baseline has been trained based on a predefined number (e.g. 100) of data records (decision 474). If the model has not been trained and if the predefined threshold is not met (decision 474), the AP saves the extracted features into a data array and sets AP status to idle (operation 480) to wait for more data records to come.
  • When the predefined number of data records is reached (decision 474), the AP applies the training algorithm (operation 478) to train a baseline base on the saved data array which contains all the extracted features. After a baseline is trained (decision 472), the AP applies the testing algorithm and outputs prediction results (operation 476) when new data arrives. In terms of a specific implementation, for example, the AP is in CCX DLL format if implemented on a Siemens PLC system running WinAC.
  • Embedded Prognostics Library—Data Analysis Software
  • An overview data analysis flowchart 500 in accordance with the present disclosure is shown in FIG. 5. In many cases, the operating condition On of a piece of equipment is alternating over time (block 510) due to different usages of the machine. The operating condition can be determined (block 520) by a single variable such as speed, voltage, and direction, or can be determined using a combination of multiple variables. If the operating condition has already existed (O1 . . . On) the measurement data is input to the prediction model 530 (M1 . . . Mn) associated with the operating condition to generate prediction result (R1 . . . Rn). If an operating condition has never been encountered in the past, a new operating condition O new is created and the associated prediction model M new is trained when a pre-defined number of data records are collected. Once the prediction model is trained, it can start generating prediction results. The prediction results are organized (block 540) according to the sequence of the appearance of the operating condition over time (block 510).
  • An example of the data analysis flow for anomaly detection and fault diagnosis of industrial machine tools is given as follows. The algorithms used in the prediction model associated with one operating condition On are indicated by Mn in FIG. 5. The specific algorithms in the prediction model can be customized for different applications.
  • After raw data is taken from the data acquisition device under a particular operating condition, a “most stable window” from each data record is selected to avoid noise that may change quickly over time in the time domain and/or to avoid dramatic frequency changes. Then, a fast Fourier transform (FFT) is applied to decompose the signal into its component frequencies and their amplitudes. Band energies are calculated within equally distributed frequency ranges along the FFT spectrum. A wavelet packet transform represents a signal in terms of a waveform (known as a mother wavelet) with a finite length or fast decaying oscillating characteristic. Energies are calculated for all the nodes at the end of the decomposition level to reveal unusual frequency changes that may introduced by potential faults at different resolutions. Time domain feature extraction is also applied to the selected data segment to calculate statistics such as mean, standard deviation, Root Mean Square (RMS) and kurtosis, etc. After all the aforementioned features are extracted, they are used as input to self-organized maps (SOM) for anomaly detection or diagnosis purposes.
  • More detail about the mathematic background of the algorithms may be found in L. Liao and R. Pavel, “Machine Anomaly Detection and Diagnosis Incorporating Operational Data Incorporating Operational Data Applied to Feed Axis Health Monitoring,” ASME 2011 International Manufacturing Science and Engineering Conference, Corvallis, Oreg., USA, 2011, the contents of which is incorporated by reference herein.
  • Experiment and Result
  • This section demonstrates the concept of the embedded prognostics system using a motor test bed to test anomaly detection and diagnosis functions.
  • Experiment Setup
  • For the test bed 600, shown in FIG. 6, a Maxon dc motor 610 (A-max 26), a rubber wheel (loading) 640 and coupling 645 are assembled. A mount 630 is designed to support the motor on a base 620. The motor is powered with a 24 VDC power supply 615. An accelerometer 650 (IMI PCB 624B61) is installed on the housing of the motor 610. The output range of the accelerometer 650 is between −5 and +5 volts. The data is conditioned using a signal conditioner 660 (IMI 682A02) which provides 4 mA current excitation to the accelerometer and an output of the original signal on the scale of 1:1. The data is taken at a sampling frequency 1 kHz (OB's cycle is set to 1 ms) using regular AI module 672 (e.g. AI 2×12 bit 6ES7 331-7 KB02-0AB0; higher data conversion speed of 52 μs can be achieved using high speed AI module, e.g. AI 8×14 bit 6ES7 331-7HF01-0AB0). The DI module 674 (DI 16×DC24V 6ES7 321-1BH02-0AA0) is used to detect the running or operating state (on/off) of the motor 610. The AI and DI modules are connected to an interface module 670 (IM513-4PN 6ES7 153-4AA00-0XB0) which is connected to the industrial Ethernet 690. A PC 680 (can be replaced by a PC based controller) on which WinAC is running is connected to the industrial Ethernet 690 via a PCI interface card 691 (CP1616-CP1604).
  • Introduce Faults
  • In order to test the anomaly detection and diagnosis functions, imbalance faults were introduced manually to the motor test bed. Small screws were installed on various angular locations of a wheel flange that rotates with the shaft. As the location of the screw changes, the imbalance patterns change as well. The purpose of the test was firstly to detect whether there is an imbalance situation (using unsupervised learning) and secondly to differentiate various imbalance patterns (using supervised training) when an imbalance situation appears. It was noticed that there exists misalignment inherent in the installation. The misalignment existed in all balanced and imbalanced situations. The algorithms were able to detect the imbalanced patterns despite the misalignment.
  • The manually introduced imbalance patterns on the motor test bed include (a) no imbalance screws installed (“balanced”), (b) one screw installed on the flange angularly close to the set screw used to fix the flange to the shaft (“1 screw near”), (c) one screw installed angularly opposite (approximately 180 degrees from) the set screw (“1 screw far”), (d) two screws installed close to the set screw (“2 screw near”), (e) two screws installed opposite the set screw (“2 screw far”). ‘Near’ and ‘far’ are both relative to the position of the set screw.
  • Results
  • The motor was run approximately 500 seconds for each different imbalance situation, and the data was collected using the AI module. 500 data records are generated randomly into segments of 4096 data samples from the 500 seconds' data. The raw vibration data under different balanced and imbalanced situations is shown in FIGS. 7 a through 7 e. It is not simple to differentiate the imbalance situations by looking only at the time domain signals. The rotation speed of the motor was selected as determining the operating condition. To be simple, the motor was run at a constant speed, creating only one operating condition. The following analysis is within that specific operating condition.
  • For the data sets shown in FIGS. 7 a through 7 e, the energy of 10 frequency bands equally distributed in the FFT spectrum, time domain features (including mean, RMS, and crest factor, variance and skewness, standard deviation and kurtosis) and wavelet packet energies were extracted. Two energies centered at 167 Hz (motor rotating speed) and 334 Hz within 20 Hz ranges in the FFT spectrum were extracted as features as well.
  • Anomaly detection—unsupervised test results: Data was collected from each fault situation. For testing, 80 different records were used. Each data record contained 4092 data samples. There were 5 different imbalance situations tested. For that test, 2 energy features and 6 time domain features were selected as features to input to the anomaly detection algorithm.
  • A self-organizing map (SOM) was trained with only balanced data, which was used as the baseline. The map was then tested with other data collected in situations of 1screwNear, 1screwFar, 2screwNear and 2screwFar.
  • The results show that when the balanced situation is trained as the baseline, the 2screwFar imbalanced fault creates the biggest difference. FIG. 8 shows the distances of different imbalances to the baseline, which differentiating 4 types of imbalance situations with the balanced situation using the output of the SOM (MQE is an indicator of deviation from baseline).
  • A possible explanation of the increasing the distance (MQE) of class ‘2screwNear’ is that the data might not be taken in a perfect environment due to the non-fixed mounting to the ground. However, the different levels of imbalance can still be well differentiated. In order to predict the label of each data record, the following supervised test (diagnosis) is carried out.
  • Diagnosis—supervised test results: The same data sets of unsupervised test are used for diagnosis except for the 1screwNear data set. The reason the 1screwNear data set is not used is that it is very close to the baseline. When examining the signals and their properties, it turns out that there is nearly no difference between 1screwNear and the balanced situation. That is why it is discarded from the test. The diagnosis test with supervised training is therefore done with 4 classes: balanced, 1screwFar, 2screwNear, 2screwFar.
  • In the test, a cross validation method is applied. Four folds are created and each fold contains 80 data records. These data records are composed of 4 classes, which are the imbalanced situations. In each test, a SOM map is trained with 3 folds and the remaining fold is tested.
  • The following features are used as input to the supervised SOM algorithm: Energies centered at the 2nd, 3rd, 4th and 6th of the running speed within a 20 Hz band, crest factor of the signal and standard deviation of the signal. There are therefore 6 features for each data record. When the signal coming from the motor is examined, peaks can be seen at the frequency of 167 Hz and its multiples, which means at that frequency is dominated. In order to reduce the error due to resolution issue, the range is chosen 20 Hz which means 167+/−20 Hz. The energies represent those values. For example, the 2nd energy includes the energies between frequency 167*2−20 Hz and 167*2+20 Hz; the 3rd energy is between 167*3−20 Hz and 167*3+20 Hz; and so on.
  • The program can predict the classes with an accuracy of 95% in the cross validation tests.
  • System
  • The elements of the methodology as described above are implemented in a programmable logic controller (PLC) computer system. An exemplary system 900 is shown in FIG. 9.
  • The PLC 910 is preferably a commercial industrial unit capable of collecting data cyclically from internal or external sensors and processing that data. The PLC may further be capable of controlling equipment using the collected data. The PLC 910 may receive the data through a data acquisition device 950 or directly from sensors (not shown).
  • Input/output data may be passed between the PLC 910 and a man-machine interface (MMI) 948 via a wide area network such as the Internet, via a local area network or via a direct bus connection. The PLC 910 may be configured to operate and display information by using, e.g., the MMI 948 to execute certain tasks. In one embodiment, data acquisition is initiated via the MMI 948, and prognostic results are displayed to the user via the same device.
  • The PLC 910 includes one or more processors 920 such as a central processing unit (CPU) and further includes a memory 930. The processor 920, when configured using software according to the present disclosure, includes a prognostics analysis software module 922 that is configured for performing one or more methods for determining prognostic information for equipment controlled by the PLC 910, as discussed herein. Those modules include a PLC run-time program 924 that collects data from external sensors and may also transmit machine control commands to the controlled equipment.
  • The memory 930 may include a random access memory (RAM) and a read-only memory (ROM). The memory may also include removable media such as a disk drive, tape drive, memory card, etc., or a combination thereof. The RAM functions as a data memory that stores data used during execution of programs in the processor 920; the RAM is also used as a program work area. The ROM functions as a program memory for storing a program executed in the processor 920. The program may reside on the ROM or on any other tangible or non-volatile computer-readable media 940 as computer readable instructions stored thereon for execution by the processor to perform the methods of the invention. The ROM may also contain data for use by the program or by other programs.
  • Generally, the program modules 922, 924 described above include routines, objects, components, data structures and the like that perform particular tasks or implement particular abstract data types. The term “program” as used herein may connote a single program module or multiple program modules acting in concert. The disclosure may be implemented on a variety of types of computers, including dedicated PLCs, personal computers (PCs), hand-held devices, multi-processor systems, microprocessor-based programmable consumer electronics, network PCs, mini-computers, mainframe computers and the like. The disclosed technique may also be employed in distributed computing environments, where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, modules may be located in both local and remote memory storage devices.
  • An exemplary processing module for implementing the methodology above may be hardwired or stored in a separate memory that is read into a main memory of a processor or a plurality of processors from a computer readable medium such as a ROM or other type of hard magnetic drive, optical storage, tape or flash memory. In the case of a program stored in a memory media, execution of sequences of instructions in the module causes the processor to perform the process steps described herein. The embodiments of the present disclosure are not limited to any specific combination of hardware and software and the computer program code required to implement the foregoing can be developed by a person of ordinary skill in the art.
  • The term “computer-readable medium” as employed herein refers to any tangible machine-encoded medium that provides or participates in providing instructions to one or more processors. For example, a computer-readable medium may be one or more optical or magnetic memory disks, flash drives and cards, a read-only memory or a random access memory such as a DRAM, which typically constitutes the main memory. Such media excludes propagated signals, which are not tangible. Cached information is considered to be stored on a computer-readable medium. Common expedients of computer-readable media are well-known in the art and need not be described in detail here.
  • Conclusion
  • The present disclosure describes a system and method including embedded equipment prognostics (anomaly detection, diagnosis and time-to-failure/service prediction) analysis functions on PLC platforms. The systems collects data from the sensors installed on a device using the PLC input modules in the PLC cycle program. Prognostics analysis software is implemented as plug-in software components such as DLLs to be called by the PLC cycle program after data is collected. The system has been demonstrated using a motor test-bed, and was shown to successfully detect and identify anomaly situations of different imbalance faults on the motor loading. The system can be potentially applied to a variety of applications including but not limited to machine tool components (e.g. motor, gearbox, and bearing), gas/wind turbines and trains.
  • The foregoing detailed description is to be understood as being in every respect illustrative and exemplary, but not restrictive, and the scope of the disclosure herein is not to be determined from the description, but rather from the claims as interpreted according to the full breadth permitted by the patent laws. It is to be understood that various modifications will be implemented by those skilled in the art, without departing from the scope and spirit of the disclosure.

Claims (17)

What is claimed is:
1. A method for determining prognostic information for equipment controlled by a programmable logic controller, using a prognostics analysis program embedded in a software platform of the programmable logic controller, the method comprising:
determining whether the prognostics analysis program has an idle status;
only if the prognostics analysis program has an idle status, then, by the programmable logic controller during programmable logic controller real-time cycles, reading a predetermined number of data samples from a data acquisition device and writing the data samples to a buffer;
after writing the predetermined number of data samples to the buffer, activating, by a system function block of the programmable logic controller software platform, the prognostics analysis program to have an active status;
reading the data samples from the buffer into the prognostics analysis program;
identifying an operating condition of the equipment based on the data samples from the buffer;
based on the operating condition of the equipment, extracting a plurality of features from the data samples from the buffer;
determining whether a model corresponding to the identified operating condition has been trained;
only if the model has been trained, using the model, determining the prognostic information based on the features; and
after determining the prognostic information, setting the prognostics analysis program status to idle.
2. A method as in claim 1, further comprising:
only if the model corresponding to the operating condition is not trained, then performing the following:
saving the extracted features into a data array containing data records accumulated from previous activations of the prognosis analysis program, each data record comprising features extracted during a single activation; and
only if a number of data records in the data array exceeds a threshold number of records, training the model using the data records.
3. A method as in claim 1, further comprising:
before reading the predetermined number of data samples, determining that a data acquisition trigger is met.
4. A method as in claim 3, wherein the data acquisition trigger is that the equipment is operating.
5. A method as in claim 1, further comprising:
before reading the predetermined number of data samples, determining that a data acquisition trigger is not met;
in response to determining the data acquisition trigger is not met:
clearing the buffer; and
returning to determining whether the prognosis analysis program has an idle status.
6. A method as in claim 5, wherein the data acquisition trigger is that the equipment is operating.
7. A method as in claim 1, further comprising:
after reading the data samples from the data buffer to the prognosis analysis program, selecting a most stable window of the data samples for extracting the plurality of features.
8. A method as in claim 1, further comprising:
applying a fast Fourier transform to the window of the data samples to decompose a subject signal into component frequencies and amplitudes.
9. A method as in claim 8, wherein the features comprise band energies calculated within equally distributed frequency ranges along a fast Fourier transform spectrum.
10. A method as in claim 1, wherein the features comprise a wavelet packet transform representing a signal as a waveform having a finite length or a fast decaying oscillating characteristic.
11. A method as in claim 10, wherein the features further comprise energies calculated for all nodes at an end of a decomposition level.
12. A method as in claim 1, wherein the features comprise at least one time domain feature selected from the group consisting of: mean, standard deviation, root mean square and kurtosis.
13. A method as in claim 1, wherein determining the prognostic information based on the features further comprises using the features as an input to a self-organizing map.
14. A non-transitory computer-readable medium having stored thereon computer readable instructions for determining prognostic information for equipment controlled by a programmable logic controller, using a prognostics analysis program embedded in a software platform of the programmable logic controller, wherein execution of the computer readable instructions by a processor causes the processor to perform operations comprising:
determining whether the prognostics analysis program has an idle status;
only if the prognostics analysis program has an idle status, then, by the programmable logic controller during programmable logic controller real-time cycles, reading a predetermined number of data samples from a data acquisition device and writing the data samples to a buffer;
after writing the predetermined number of data samples to the buffer, activating, by a system function block of the programmable logic controller software platform, the prognostics analysis program to have an active status;
reading the data samples from the buffer into the prognostics analysis program;
identifying an operating condition of the equipment based on the data samples from the buffer;
based on the operating condition of the equipment, extracting a plurality of features from the data samples from the buffer;
determining whether a model corresponding to the identified operating condition has been trained;
only if the model has been trained, using the model, determining the prognostic information based on the features; and
after determining the prognostic information, setting the prognostics analysis program status to idle.
15. A tangible computer-readable medium as in claim 14, wherein the operations further comprise:
only if the model corresponding to the operating condition is not trained, then performing the following:
saving the extracted features into a data array containing data records accumulated from previous activations of the prognosis analysis program, each data record comprising features extracted during a single activation; and
only if a number of data records in the data array exceeds a threshold number of records, training the model using the data records.
16. A programmable logic controller comprising data acquisition inputs, a prognosis analysis output, a processor and a non-transitory computer-readable medium having stored thereon computer readable instructions for determining prognostic information for equipment controlled by the programmable logic controller, wherein execution of the computer readable instructions by the processor causes the processor to perform operations comprising:
determining whether a prognostics analysis program embedded in a software platform of the programmable logic controller has an idle status;
only if the prognostics analysis program has an idle status, then, by the programmable logic controller during programmable logic controller real-time cycles, reading, by the data acquisition inputs, a predetermined number of data samples from a data acquisition device and writing the data samples to a buffer;
after writing the predetermined number of data samples to the buffer, activating, by a system function block of the programmable logic controller software platform, the prognostics analysis program to have an active status;
reading the data samples from the buffer into the prognostics analysis program;
identifying an operating condition of the equipment based on the data samples from the buffer;
based on the operating condition of the equipment, extracting a plurality of features from the data samples from the buffer;
determining whether a model corresponding to the identified operating condition has been trained;
only if the model has been trained, using the model, determining the prognostic information based on the features;
after determining the prognostic information, setting the prognostics analysis program status to idle; and
presenting, via the prognosis analysis output, the prognostic information to a user.
17. A programmable logic controller as in claim 16, wherein the operations further comprise:
only if the model corresponding to the operating condition is not trained, then performing the following:
saving the extracted features into a data array containing data records accumulated from previous activations of the prognosis analysis program, each data record comprising features extracted during a single activation; and
only if a number of data records in the data array exceeds a threshold number of records, training the model using the data records.
US14/391,268 2012-04-13 2013-04-12 Embedded prognostics on PLC platforms for equipment condition monitoring, diagnosis and time-to-failure/service prediction Active 2034-12-07 US9996405B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US14/391,268 US9996405B2 (en) 2012-04-13 2013-04-12 Embedded prognostics on PLC platforms for equipment condition monitoring, diagnosis and time-to-failure/service prediction

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US201261623647P 2012-04-13 2012-04-13
PCT/US2013/036382 WO2013155421A1 (en) 2012-04-13 2013-04-12 Embedded prognostics on plc platforms for equipment condition monitoring, diagnosis and time-to-failure/service prediction
US14/391,268 US9996405B2 (en) 2012-04-13 2013-04-12 Embedded prognostics on PLC platforms for equipment condition monitoring, diagnosis and time-to-failure/service prediction

Publications (2)

Publication Number Publication Date
US20150073751A1 true US20150073751A1 (en) 2015-03-12
US9996405B2 US9996405B2 (en) 2018-06-12

Family

ID=48170832

Family Applications (1)

Application Number Title Priority Date Filing Date
US14/391,268 Active 2034-12-07 US9996405B2 (en) 2012-04-13 2013-04-12 Embedded prognostics on PLC platforms for equipment condition monitoring, diagnosis and time-to-failure/service prediction

Country Status (4)

Country Link
US (1) US9996405B2 (en)
EP (1) EP2836881B1 (en)
CN (1) CN104350435B (en)
WO (1) WO2013155421A1 (en)

Cited By (19)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20140310394A1 (en) * 2013-04-12 2014-10-16 Solera Networks, Inc. Apparatus and Method for Utilizing Fourier Transforms to Characterize Network Traffic
US20160239011A1 (en) * 2015-02-12 2016-08-18 Siemens Aktiengesellschaft Extending a Programmable Logic Controller with Apps
AU2016201794B1 (en) * 2015-03-24 2016-09-22 Accenture Global Services Limited Analyzing equipment degradation for maintaining equipment
CN108763377A (en) * 2018-05-18 2018-11-06 郑州轻工业学院 Multi-source telemetering big data feature extraction preprocess method is diagnosed based on satellite failure
US10444121B2 (en) * 2016-05-03 2019-10-15 Sap Se Fault detection using event-based predictive models
CN110361418A (en) * 2019-07-03 2019-10-22 华电通用轻型燃机设备有限公司 The real-time calorific value forecast analysis device and method of natural gas
WO2020140103A1 (en) * 2018-12-27 2020-07-02 Wang Yajuan Scalable system and engine for forecasting wind turbine failure
US20200210537A1 (en) * 2018-12-27 2020-07-02 Utopus Insights, Inc. System and method for evaluating models for predictive failure of renewable energy assets
US10768188B2 (en) 2016-08-01 2020-09-08 Siemens Aktiengesellschaft Diagnostic device and method for monitoring operation of a technical system
US10796242B2 (en) 2016-08-25 2020-10-06 Oracle International Corporation Robust training technique to facilitate prognostic pattern recognition for enterprise computer systems
CN112101220A (en) * 2020-09-15 2020-12-18 哈尔滨理工大学 Rolling bearing service life prediction method based on unsupervised model parameter migration
US10984338B2 (en) 2015-05-28 2021-04-20 Raytheon Technologies Corporation Dynamically updated predictive modeling to predict operational outcomes of interest
US11275345B2 (en) * 2015-07-31 2022-03-15 Fanuc Corporation Machine learning Method and machine learning device for learning fault conditions, and fault prediction device and fault prediction system including the machine learning device
US11443850B2 (en) 2017-06-27 2022-09-13 General Electric Company Max-margin temporal transduction for automatic prognostics, diagnosis and change point detection
EP4060433A1 (en) * 2021-03-19 2022-09-21 Siemens Aktiengesellschaft Method and system for predicting the operation of a technical system
US20220342377A1 (en) * 2019-10-14 2022-10-27 Siemens Aktiengesellschaft Artificial intelligence (ai) companions for function blocks in a programmable logic controller (plc) program for integrating ai in automation
US11509136B2 (en) 2019-12-30 2022-11-22 Utopus Insights, Inc. Scalable systems and methods for assessing healthy condition scores in renewable asset management
US11640152B2 (en) 2017-09-28 2023-05-02 Siemens Aktiengesellschaft Method and device for providing service for a programmable logic controller
US11681597B2 (en) 2017-12-29 2023-06-20 Siemens Aktiengesellschaft Anomaly detection method and system for process instrument, and storage medium

Families Citing this family (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP5530020B1 (en) * 2013-11-01 2014-06-25 株式会社日立パワーソリューションズ Abnormality diagnosis system and abnormality diagnosis method
CN104376755B (en) * 2014-11-05 2017-02-15 苏州迈创信息技术有限公司 Automatic process control teaching experiment table
EP3182235B1 (en) * 2015-12-18 2019-03-27 Siemens Aktiengesellschaft Method and industrial control for calling a function of a control program by means of an opc ua call
WO2018089998A1 (en) 2016-11-14 2018-05-17 Fluid Handling Llc Pump cloud-based management and control technique customized hydronic components
CN106843134A (en) * 2017-03-27 2017-06-13 北京昌立达科技有限公司 Multi-storied garage EPLC electric-control systems and its adjustment method
CN111221247A (en) * 2018-11-23 2020-06-02 西门子股份公司 Method and system for fault diagnosis, training method of model, and medium
CN109784572A (en) * 2019-01-24 2019-05-21 泰华智慧产业集团股份有限公司 High-pressure sodium lamp Failure Rate Forecasting Method based on LightGBM
CN111953554B (en) * 2019-05-16 2022-09-27 北京车和家信息技术有限公司 Data traffic management method and device
CN110427297B (en) * 2019-07-10 2023-08-04 西门子工厂自动化工程有限公司 Diagnostic information acquisition method, system, gateway and computer readable medium
TWI719786B (en) * 2019-12-30 2021-02-21 財團法人工業技術研究院 Data processing system and method
CN114328639A (en) * 2020-09-30 2022-04-12 中强光电股份有限公司 Abnormality detection system and abnormality detection method
CN114352478B (en) * 2022-03-16 2022-05-31 中国华能集团清洁能源技术研究院有限公司 Control system and control method for offshore wind turbine generator
CN115455651B (en) * 2022-08-10 2024-01-05 中国长江电力股份有限公司 Fault diagnosis and trend analysis method for public auxiliary equipment of hydropower station

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6789030B1 (en) * 2000-06-23 2004-09-07 Bently Nevada, Llc Portable data collector and analyzer: apparatus and method

Family Cites Families (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6326758B1 (en) * 1999-12-15 2001-12-04 Reliance Electric Technologies, Llc Integrated diagnostics and control systems
WO2005038613A2 (en) * 2003-10-17 2005-04-28 Hydralift Amclyde, Inc. Equipment component monitoring and replacement management system
CN101436047A (en) * 2008-12-15 2009-05-20 芜湖新兴铸管有限责任公司 Control system of industrial production material transferring equipment
JP5207987B2 (en) * 2009-01-06 2013-06-12 三菱電機株式会社 PLC system construction support device
CN102262690B (en) 2011-06-07 2013-10-30 中国石油大学(北京) Modeling method of early warning model of mixed failures and early warning model of mixed failures

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6789030B1 (en) * 2000-06-23 2004-09-07 Bently Nevada, Llc Portable data collector and analyzer: apparatus and method

Cited By (33)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9491070B2 (en) * 2013-04-12 2016-11-08 Symantec Corporation Apparatus and method for utilizing fourier transforms to characterize network traffic
US20140310394A1 (en) * 2013-04-12 2014-10-16 Solera Networks, Inc. Apparatus and Method for Utilizing Fourier Transforms to Characterize Network Traffic
US10454792B2 (en) 2013-04-12 2019-10-22 Symantec Corporation Apparatus and method for utilizing fourier transforms to characterize network traffic
US20160239011A1 (en) * 2015-02-12 2016-08-18 Siemens Aktiengesellschaft Extending a Programmable Logic Controller with Apps
US10365626B2 (en) * 2015-02-12 2019-07-30 Siemens Aktiengesellschaft Extending the functionality of a programmable logic controller (PLC) with apps without changing the PLC programming
AU2016201794B1 (en) * 2015-03-24 2016-09-22 Accenture Global Services Limited Analyzing equipment degradation for maintaining equipment
US10067038B2 (en) 2015-03-24 2018-09-04 Accenture Global Services Limited Analyzing equipment degradation for maintaining equipment
US10984338B2 (en) 2015-05-28 2021-04-20 Raytheon Technologies Corporation Dynamically updated predictive modeling to predict operational outcomes of interest
US12066797B2 (en) 2015-07-31 2024-08-20 Fanuc Corporation Fault prediction method and fault prediction system for predecting a fault of a machine
US11275345B2 (en) * 2015-07-31 2022-03-15 Fanuc Corporation Machine learning Method and machine learning device for learning fault conditions, and fault prediction device and fault prediction system including the machine learning device
US10444121B2 (en) * 2016-05-03 2019-10-15 Sap Se Fault detection using event-based predictive models
US10768188B2 (en) 2016-08-01 2020-09-08 Siemens Aktiengesellschaft Diagnostic device and method for monitoring operation of a technical system
US10796242B2 (en) 2016-08-25 2020-10-06 Oracle International Corporation Robust training technique to facilitate prognostic pattern recognition for enterprise computer systems
US11443850B2 (en) 2017-06-27 2022-09-13 General Electric Company Max-margin temporal transduction for automatic prognostics, diagnosis and change point detection
US11640152B2 (en) 2017-09-28 2023-05-02 Siemens Aktiengesellschaft Method and device for providing service for a programmable logic controller
US11681597B2 (en) 2017-12-29 2023-06-20 Siemens Aktiengesellschaft Anomaly detection method and system for process instrument, and storage medium
CN108763377A (en) * 2018-05-18 2018-11-06 郑州轻工业学院 Multi-source telemetering big data feature extraction preprocess method is diagnosed based on satellite failure
US20210216682A1 (en) * 2018-12-27 2021-07-15 Utopus Insights, Inc. System and method for evaluating models for predictive failure of renewable energy assets
US10984154B2 (en) * 2018-12-27 2021-04-20 Utopus Insights, Inc. System and method for evaluating models for predictive failure of renewable energy assets
WO2020140103A1 (en) * 2018-12-27 2020-07-02 Wang Yajuan Scalable system and engine for forecasting wind turbine failure
US10956632B2 (en) 2018-12-27 2021-03-23 Utopus Insights, Inc. Scalable system and engine for forecasting wind turbine failure
US11803676B2 (en) 2018-12-27 2023-10-31 Utopus Insights, Inc. Scalable system and engine for forecasting wind turbine failure
US20230342521A1 (en) * 2018-12-27 2023-10-26 Utopus Insights, Inc. System and method for evaluating models for predictive failure of renewable energy assets
EP3902992A4 (en) * 2018-12-27 2022-09-28 Wang, Yajuan Scalable system and engine for forecasting wind turbine failure
US11734474B2 (en) * 2018-12-27 2023-08-22 Utopus Insights, Inc. System and method for evaluating models for predictive failure of renewable energy assets
US20200210537A1 (en) * 2018-12-27 2020-07-02 Utopus Insights, Inc. System and method for evaluating models for predictive failure of renewable energy assets
CN110361418A (en) * 2019-07-03 2019-10-22 华电通用轻型燃机设备有限公司 The real-time calorific value forecast analysis device and method of natural gas
US20220342377A1 (en) * 2019-10-14 2022-10-27 Siemens Aktiengesellschaft Artificial intelligence (ai) companions for function blocks in a programmable logic controller (plc) program for integrating ai in automation
US11509136B2 (en) 2019-12-30 2022-11-22 Utopus Insights, Inc. Scalable systems and methods for assessing healthy condition scores in renewable asset management
US11977375B2 (en) 2019-12-30 2024-05-07 Utopus Insights, Inc. Scalable systems and methods for assessing healthy condition scores in renewable asset management
CN112101220A (en) * 2020-09-15 2020-12-18 哈尔滨理工大学 Rolling bearing service life prediction method based on unsupervised model parameter migration
WO2022195050A1 (en) * 2021-03-19 2022-09-22 Siemens Aktiengesellschaft Method and system for predicting the operation of a technical installation
EP4060433A1 (en) * 2021-03-19 2022-09-21 Siemens Aktiengesellschaft Method and system for predicting the operation of a technical system

Also Published As

Publication number Publication date
CN104350435B (en) 2016-12-14
EP2836881B1 (en) 2018-08-15
CN104350435A (en) 2015-02-11
US9996405B2 (en) 2018-06-12
EP2836881A1 (en) 2015-02-18
WO2013155421A1 (en) 2013-10-17

Similar Documents

Publication Publication Date Title
US9996405B2 (en) Embedded prognostics on PLC platforms for equipment condition monitoring, diagnosis and time-to-failure/service prediction
US20240068864A1 (en) Systems and methods for monitoring of mechanical and electrical machines
CN110647133B (en) Rail transit equipment state detection maintenance method and system
JP6810097B2 (en) Anomaly detector
Jin et al. Anomaly detection and fault prognosis for bearings
EP3508833B1 (en) Diagnostic device, diagnostic method, and diagnostic program
Lee et al. Prognostics and health management design for rotary machinery systems—Reviews, methodology and applications
CN103038559B (en) The diagnosis of control valve
US6694286B2 (en) Method and system for monitoring the condition of an individual machine
CA2772816C (en) Methods and systems for monitoring operation of equipment
US9959738B2 (en) Reciprocating machinery monitoring system and method
US20200143292A1 (en) Signature enhancement for deviation measurement-based classification of a detected anomaly in an industrial asset
WO2021027213A1 (en) Detection method and apparatus, electronic device and computer-readable medium
US20180066503A1 (en) System and method for reservoir management using electric submersible pumps as a virtual sensor
WO2015053773A1 (en) Correlation and annotation of time series data sequences to extracted or existing discrete data
CN106662869B (en) System and method for advanced process control
WO2019045699A1 (en) Recurrent gaussian mixture model for sensor state estimation in condition monitoring
KR102694136B1 (en) Oil gas plant equipment failure prediction and diagnosis system based on artificial intelligence
KR102545672B1 (en) Method and apparatus for machine fault diagnosis
KR20210111502A (en) Pre-designated equipment of a facility and Predictive maintenance method using the same
Yang et al. Unknown Bearing Fault Recognition in Strong Noise Background
CN114638060A (en) Fault prediction method, system, electronic device and computer program product
US11463032B2 (en) Detecting rotor anomalies by determining vibration trends during transient speed operation
Nogin et al. A non-intrusive IoT system for the detection of faults in internal combustion engines
Costa Predictive Maintenance Support System in Industry 4.0 Scenario

Legal Events

Date Code Title Description
AS Assignment

Owner name: SIEMENS CORPORATION, NEW JERSEY

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:LIAO, LINXIA;ELIGUL, ERTAN;SIGNING DATES FROM 20141006 TO 20141010;REEL/FRAME:042501/0550

AS Assignment

Owner name: SIEMENS CORPORATION, NEW JERSEY

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:EDMONDSON, ZACHERY;REEL/FRAME:042768/0417

Effective date: 20040216

STCF Information on status: patent grant

Free format text: PATENTED CASE

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 4

AS Assignment

Owner name: SIEMENS AKTIENGESELLSCHAFT, GERMANY

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SIEMENS CORPORATION;REEL/FRAME:063681/0116

Effective date: 20230503

Owner name: SIEMENS AKTIENGESELLSCHAFT, GERMANY

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SIEMENS CORPORATION;REEL/FRAME:063681/0070

Effective date: 20230503