Embodiments of the invention relate generally to data analysis, and more specifically relate to systems and methods for analyzing reporting data.
Wind turbine generators with ratings of 1.5 MW or more are now available. Many power generation developers are installing wind farms having one hundred or more wind turbine generators. The “block” of power available from wind farms with 1.5 MW wind turbine generators can be comparable to a modem gas turbine generator. Accordingly, wind turbine generators are increasingly becoming feasible sources of power for the power grid. Maintenance costs and power generation efficiency can be improved by accurate, timely, and effective reporting of turbine operation.
Accordingly, a need to improve turbine and other system reporting and monitoring exists. There further exists a need for system and methods that analyze reporting data.
Embodiments of the invention can address some or all of the needs addressed above. According to one embodiment, there is provided a method for analyzing reporting data. The method can include: receiving data associated with the operation of at least one machine; storing the data as historical data; defining at least one analytical report for identifying at least one machine status of the machine; and generating an output of the at analytical report based on the historical data. The method can further include defining at least one trigger condition for identifying an indication of the machine status in the output of the analytical report; and automatically processing the output of the analytical report with respect to the trigger condition. The method may also include automatically identifying the indication of the machine status based at least in part on automatically processing the output of the analytical report with respect to the trigger condition; and performing at least one resulting action in response to automatically identifying the indication of the machine status.
According to another embodiment, there is provided a system for analyzing reporting data. The system can include at least one communication interface; at least one memory operable to store instructions; and at least one processor in communication with the communication interface and the memory. The processor can be operable to execute the instructions to: receive data associated with the operation of at least one machine via the communication interface; store the data as historical data in the memory; define at least one analytical report for identifying at least one machine status of the machine; generate an output of the analytical report based on the historical data; and define at least one trigger condition for identifying an indication of the machine status in the output of the analytical report. The processor can further be operable to execute the instructions to: automatically process the output of the analytical report with respect to the trigger condition; automatically identify the indication of the machine status based at least in part on automatically processing the output of the analytical report with respect to the trigger condition; and perform at least one resulting action in response to automatically identifying the indication of the machine status.
According to yet another embodiment, there is provided a system for analyzing reporting data. The system can include: at least one communication interface; at least one memory operable to store instructions; and at least one processor in communication with the communication interface and the memory. The processor can be operable to execute the instructions to: extract historical data associated with the operation of at least one machine; generate an output of an analytical report based on the historical data; automatically identify an indication of at least one machine status by processing the output of the analytical report with respect to at least one trigger condition associated with the indication of the machine status; and generate an alarm in response to automatically identifying the indication of the machine status.
Other embodiments, aspects, and features will become apparent to those skilled in the art from the following detailed description, the accompanying drawings, and the appended claims.
Reference will now be made to the accompanying drawings, which are not necessarily drawn to scale, and wherein:
Illustrative embodiments of the invention now will be described more fully hereinafter with reference to the accompanying drawings, in which some, but not all embodiments of the invention are shown. Indeed, the invention may be embodied in many different forms and should not be construed as limited to the embodiments set forth herein; rather, these embodiments are provided so that this disclosure will satisfy applicable legal requirements. Like numbers refer to like elements throughout.
Disclosed are systems and methods for analyzing reporting data, which may be performed in association with machine operation reports, such as with turbine operation reports or in other plant reporting environments. Turbine operation is described in detail herein as an example operating environment within which various embodiments described herein can be applied. However, it is appreciated that these embodiments can be applied to any other machine or system that generate data for analysis, which may include, but is not limited to: at least one wind turbine; at least one wind turbine farm; at least one fleet of wind turbines; a plurality of wind turbines associated with at least one area; at least one hydroelectric turbine; at least one generator; at least one motor; or at least one solar panel. Accordingly, a turbine is described herein as an example application only, and the features of these various embodiments can be applied to any machine, plant, or other system.
According to various embodiments, methods and systems are provided that can automatically analyze reporting data by automatically processing reporting data, or a report output, to identify whether or not a condition exists. The condition may indicate a turbine operating status to be monitored. Upon automatically identifying the presence of a condition in the reporting data, a resulting action can be performed, such as an alarm to an individual, a control action to a turbine controller, storing data in memory, and/or generating additional reports or monitoring events. It is appreciated that any number and or any type of reports serving any purpose can be analyzed according to various embodiments described herein. Moreover, it is further appreciated that the conditions for which the reporting data are analyzed can vary, depending upon the turbine status or other operation or performance factors to be identified, and that the automatic analysis of the reporting data can be customized and/or altered over time, based on the needs existing at the time.
Previously, reporting data, whether run or gathered automatically, had to be reviewed manually. Even though the majority of interest is in an abnormal operation of the turbine or indications that may indicate or predict poor operation or component failure, manual review requires each report to be reviewed, resulting in an overwhelming amount of unnecessary review time to detect the few instances of interest. The number of satisfactory results, which would not cause any alarm or indicate any suspect condition, far outweighs the number of undesired results that would necessitate follow-up by the reviewer. Therefore, the systems and methods described herein permit the automatic review of reporting data, which will minimize the amount of effort and involvement required by a human operator (if at all) by generating an alarm or other resulting action only when a suspect condition is identified in the reports. Effectively, only those reports that have data of interest would be reviewed or otherwise acted upon manually, and those reports that do not indicate any suspect condition can effectively be ignored.
As compared to real-time monitoring, such as condition based monitoring (CBM) or component monitoring, analyzing reports based on historical data provides an ability to perform more complex analysis, having historical data available, such as, but not limited to, analyzing trends, performing statistical analysis, adjusting condition triggers or other indications based on historical trends or other changes in turbine operation, etc. In contrast, real-time monitoring typically involves monitoring signals as they are measured from, or otherwise associated with, turbine components based on thresholds or other algorithms. Real-time monitoring, thus, can indicate when a threshold or other algorithm is exceed or not satisfied at any given time, but in many circumstances cannot provide the more insightful analyses capable when analyzing historical reporting data.
With reference to
The one or more turbines 108 may be one or more wind farms having multiple wind turbines operable to supply electrical power to a utility, according to one embodiment. It is appreciated, however, that the one or more turbines 108 may instead represent a single turbine, a fleet of multiple turbines and/or wind farms, or one or more geographically defined areas containing multiple turbines, such that the controller 102 can receive data and analyze reports at the turbine level, the farm level, the fleet level, and/or the area level. Moreover, it is appreciated that, while the example embodiments described herein generally refer to wind turbines, any other turbines or other equipment may be provided instead of wind turbines, such that reports for any other turbines or equipment can be analyzed in the same or similar manners as described herein by example.
According to one embodiment, the controller 102 can be operable to monitor and/or receive measured and/or modeled signals relating to turbine 108 operation. The controller 102 can be in electrical communication with one or more sensors or other monitoring devices associated with the respective turbines 108, and can receive data signals representing measured conditions of the turbines 108. For example, according to one embodiment, the controller 102 may include supervisory command and data acquisition (SCADA) architecture together with databases 106 (local and/or distributed) to provide functionality for monitoring and control, as well as user visualization, historical data archiving and reporting, configuration management, secondary data processing, fault logging, alarming, and/or remote user access. The controller 102, and/or another controller (not pictured), may also be operable to facilitate control of the turbines 108, as is known. It is appreciated that as used herein, the controller 102 may, but is not required to, facilitate control of the turbines 108, and that the term “controller” is used herein to generally refer to the system component or components operable to process reporting data according to the methods described herein, such as with reference to
The controller 102 may also include a report analyzer module 104, which may include software, hardware, or any combination thereof, with computer-executable instructions operable for performing various operations described with reference to the example flowcharts of
The controller 102 and associated report analyzer module 106 may further include one or more user interface means, such that a system operator 110 can interface with the controller 102. For example, a system operator 110 may interface with the controller 102 to define and/or alter report configurations, to define and/or adjust trigger conditions that may give an indication of a given turbine status in reporting data, to review report output, and to receive and analyze alarms 120 or other actions resulting from analyzing reporting data. Moreover, a system operator 110 may interface with the controller to facilitate turbine 108 operation.
In one embodiment, the controller 102 may also be in communication with other data sources 109 that are operable to provide data to the controller 102 for analysis and reporting, and/or to facilitate control of turbine 108 operation. In one embodiment, an additional data source 109 may include a meteorological service, operable to provide meteorological data to the controller 102. It is appreciated, however, that any other data source 109 may also be included, according to various embodiments.
The example power generation system 100 illustrated in
The method 200 can begin at block 205, in which data is gathered for storage and subsequent reporting analysis. The data may be gathered from turbine sensors or other turbine components, and/or from other data sources. According to one embodiment, the data can be transmitted electronically in real-time or near real-time for storage in a database, such as the database 106. According to another embodiment, the data can be transmitted electronically in a batch mode or other asynchronous processing, such as if turbine data is collected and stored locally (e.g., at a local turbine database or at a farm database) and subsequently synchronized with a database associated with the controller, similar to database 106. According to yet another embodiment, as described above, the data may be gathered locally and analyzed locally, such as by a local controller similar to 102 and database similar to 106.
As used herein, the data gathered at block may be any data associated with turbine operations and/or surrounding conditions, for which analytical reports may be run to indicate turbine performance or conditions. Example data includes, but is not limited to, real power production; reactive power production; wind speed; energy subtotal; total energy gathered; generator rotational speed; generator temperature; gearbox temperature; ambient temperature; wind direction; power factor phase voltage and phase current for each phase; production time; vertical wind speed; horizontal wind speed; wind direction; wind temperature; air pressure; data quality indication; data coverage indication; turbine state indication; turbine component state indication; fault; or user action. It is appreciated, however, that any other data may be gathered at block 205, and that the data gathered may vary and may be configurable by an operator.
According to one embodiment, data may be captured at predefined intervals, such that what is gathered is effectively a sample of the turbine operating conditions at predefined intervals. The predefined intervals may vary, such that the shorter the interval, the more comprehensive the data capture is, but the larger the quantity of data becomes. Thus, if the predefined intervals are greater, then the quantity of data can be reduced. It is appreciated that, according to one embodiment, the interval of data capture can vary, and may be adjustable by an operator. Moreover, the data capture requirements may also differ for each analytical report being run. At block 210 the data gathered at block 205 is stored in one or more databases.
Following block 210 is block 215, in which the controller may execute one or more reports on the historical data to generate report output for each report. The reports may be executed at any time and may be representative of historical data over any period of time. According to one example embodiment, the reports may be scheduled for periodic execution at predetermined times (e.g., daily at one hour after midnight local time, etc.), such as at times that minimize the system impact that may result from increased processing overhead associated with executing the reports. According to another embodiment, however, the reports may be event-driven, such that they are executed upon the occurrence of a predetermined event (e.g., turbine shut-down or start-up, turbine cycling, or any other turbine operating condition or other event). For example, turbine systems that perform condition based monitoring (CBM) may use various output of the CBM to initiate execution of related reports. This may be useful to execute reports only upon the identification of a predetermined event. However, event-driven report execution may be somewhat unpredictable and managing the associated processing overhead may require additional system planning. It is also appreciated that reports can be defined on and initially executed by a first system (e.g., a turbine reporting system) and transmitted to a second system including the controller 102 and the report analyzer module 104. As such, the data gathering and report execution operations at blocks 205 and 210 may optionally be performed on a different system than that which performs the subsequent operations described below.
The controller 102 can execute any number and/or any type of reports that may facilitate turbine monitoring and analysis. Example reports include, but are not limited to, power curve reports; data coverage reports; fault reports; data quality reports; counter quality reports; or parameter reports.
A power curve report indicates the amount of power a wind turbine can produce at a given wind speed. A condition may be identified if the power at a given speed is outside of an expected range.
A data coverage report may indicate how many samples have been collected over a set time period, to determine if the expected number of samples has been collected by the system (e.g., based on a given sampling rate, the expected number of samples over a period of time would be the period of time divided by the sample rate). For example, if 10 minute samples are gathered by the system, then 144 samples are expected in a 24 hour period. If a threshold (e.g., 137 or 95%) is not satisfied, then a data quality condition may be indicated.
A fault report may indicate any fault or predefined faults when occurred. The report may include a Pareto chart or Pareto diagram and/or a list of specific faults identified associated with a specific turbine, turbine component, time, etc. A condition may be identified if a threshold minimum number of faults over a predefined time occurs.
A data quality report can indicate when sensors or other turbine components may have a defect because the data generated by the component may be an unexpected value. For example, certain sensors may be expected to report data within a certain range (e.g., temperature sensors between −50° C. and 60° C.), and data returned outside of the expected range may generate a fault or condition to indicate a potential data quality issue.
It is appreciated, however, that any other report may be executed at block 215 to generate report output for subsequent processing by the report analyzer module 104.
Following block 215 is block 220, in which the report analyzer module 104 (or any other programming instructions) automatically processes the report output generated at block 215 to determine whether any suspect conditions (also referred to herein as a “trigger condition”) are indicated by the report output. As described in more detail with reference to
A trigger condition may be any value, parameter, or other data that can be represented by a report output or otherwise discernable from the report output. Thus, a trigger condition may have multiple parameters, algorithms, thresholds, statistical models, mathematical operations, and the like, which are used to process report output. As one example, upon generating a report output at block 215, the report analyzer module 104 may apply the trigger conditions to the report output to determine whether one or more parameters exist or whether one or more thresholds are met or otherwise violated. As another example, the report analyzer module 104 may apply the trigger conditions to the report output by performing additional data processing on the report output data, such as applying algorithms, performing statistical or mathematical operations, or any other operation identified by the trigger condition, to determine whether the report data indicates the turbine condition or status for which the trigger condition is defined to facilitate identifying.
According to one embodiment, the report output from block 215 can be monitored at block 220 either simultaneous to its generation or at some point after executing the underlying report and generating the output. For example, as part of generating the report output, the report analyzer module 104 may process the output with respect to the trigger conditions to identify an indication of a turbine status in the report output. Though, in another embodiment, the report analyzer module 104 may process the report output after the report has been generated, whereby the report analyzer module 104 retrieves the report output (which may be in underlying data, processed data, and/or a graphical representation of the underlying data) that has been previously stored after generation at block 215, and performs the subsequent processing with respect to the trigger condition. Much like executing the reports, the report processing with respect to the trigger conditions at block 220 can be scheduled for periodic execution at predetermined times and/or can be event-driven.
As described, the trigger conditions will vary, depending upon the report type being processed and the turbine status being monitored. Example trigger conditions include, but are not limited to, threshold values for data coverage (i.e., samples collected over a given period of time); predefined faults; data outside of expected ranges or above/below predefined thresholds; counter resets; variables (e.g., power, rotor speed, wind speed, temperatures, etc.) outside of expected ranges or above/below predefined thresholds; or unexpected parameter settings (e.g., outside of expected ranges or above/below predefined thresholds). It is appreciated, however, that any other trigger conditions may be defined and applied when processing report output at block 220, and that the trigger conditions and/or report output processing may be configurable by an operator.
Following block 220 is decision block 225, in which it is determined whether a given turbine status is indicated by the results of processing the report output with respect to the trigger condition(s) at block 220. If the processing indicates that the turbine status does not exist (i.e., there are no reporting anomalies), then processing may end. Alternatively, according to one embodiment, processing may continue to block 205, illustrating that the cycle can be repeated upon the collection of new data and execution of new reports based on the new data.
However, if the processing indicates a certain turbine status may exist, then block 230 follows, in which one or more resulting actions are performed upon identifying the possibility of a monitored status. A resulting action may be any action desired to be performed, which may vary depending upon the turbine status indicated, when the report was executed, the turbine with which the status is associated, etc. Example resulting actions include, but are not limited to, an alarm (e.g., audible, displayed, transmitted, logged, etc.); a control action to a turbine control system (e.g., to alter control of one or more turbines based on the status identified, etc.); storing data associated with the status indicated (e.g., storing into a log in memory or in a database, etc.); or generating at least one additional report or perform additional monitoring based at least in part on the status indicated (e.g., indication of one turbine status may suggest performing additional monitoring of involved turbine components or conditions, or perform additional analysis of related turbine data).
For example, according to one embodiment, an alarm may be generated and transmitted to a system operator. Upon receiving the alarm, the operator may then react accordingly. Because an alarm is generated based on the automatic processing of existing report output, an operator may then choose to manually review the corresponding report output (which may also be transmitted to the operator) to determine if an issue does in fact exist or if additional investigation is necessary. Thus, there is benefit in generating report output, automatically processing that report output to identify if a potential issue exists, then permitting manual review of the underlying report output.
In another example, according to one embodiment, the controller may cause the execution of additional turbine monitoring or measurement upon the indication of a given turbine status in the processed report output. For example, upon identifying a given turbine status, specific CBM may be initiated. Additional monitoring may be used to further identify whether an issue actually exists, further pinpoint the problem, or determine the severity of the issue.
After block 230, or block 225, the method 200 may end, having automatically processed report output based on predetermined trigger conditions to determine whether one or more turbine status being monitored may exist.
The method 300 can begin at block 305, in which one or more reports are defined and stored in association with the controller 102. As previously described, any number of reports may be defined for use in representing any number of turbine operation behavior. Reports may be created using third party reporting tools and/or may be customized reports specifically defined for a given system or task. According to one embodiment, the reports can be stored in one or more databases associated with the controller 102, or with any other system component. It is appreciated that the reports are not required to be defined on, stored by, and/or executed by the same system that operates the report analyzer module 104, as described in more detail with reference to
Following block 305 is block 310, in which trigger conditions may be defined and stored in a database, such as the database 106 associated with, or otherwise accessible by, the controller 102. As previously described, the trigger conditions will likely vary by report and/or by the turbine status to be detected. Each report may have any number of trigger conditions defined and associated therewith for subsequent processing. Moreover, one trigger condition may be defined and associated with any number of reports, such as may be the case if the data analyzed by the trigger conditions are present or can be obtained via multiple reports. As previously described, trigger conditions may be defined to include any value, parameter, or other data that can be represented by a report output or otherwise discernable from the report output, such as, but not limited to, data values, parameters, algorithms, thresholds, statistical models, mathematical operations, and the like, which are used to process report output. Upon defining the trigger conditions, they may be associated with the respective report and stored in a database for subsequent retrieval by the report analyzer module 104.
Following block 310 is block 315, in which one or more resulting actions are defined and stored in association with each triggered condition. Each triggered condition may be configured to invoke the same or different resulting actions, which may likely depend upon the turbine status that the triggered condition is defined to identify. In addition to defining the type or types of resulting actions to perform, parameters, data, or other information can also be defined for the trigger condition. For example, if an alarm is defined as associated with one trigger condition, the alarm type, content, and associated data or other action can be defined for the alarm resulting action. In one example, the resulting action may be defined to cause the report analyzer module 104 to extract additional information during processing for inclusion with the alarm, so as to provide more details to an operator as to the potential problem or other turbine status indicated. Similarly, if a control action causing a turbine adjustment is to be performed, the specific parameters of the turbine adjustment can also be defined. As another example, if additional monitoring or analysis is to be performed, the resulting action may include data used to invoke the additional monitoring (e.g., which type of CBM and associated parameters) or execute the additional analysis (e.g., which reports, what data, etc.). Moreover, as previously described, multiple resulting actions may be performed, and thus the timing and/or sequence of performing the multiple actions may also be defined at block 315.
Finally, following block 315 is block 320, in which any other configurable parameters for executing the reports and/or for performing the automatic processing of report output data can be defined and stored. Various configurable parameters can include, but are not limited to, report execution schedule, automatic report processing schedule, data gathering parameters (e.g., sample rate, data elements, etc.), which turbines/farms/fleets/areas, resulting actions, alarm recipients, and the like. It is appreciated that any aspect of reporting and/or automatic report output processing can be configurable by an operator. Thus, upon storing the configuration parameters, an operator can access and alter the parameters prior or during report execution or subsequent report output processing, such as via a user interface of the controller 102 or any other system.
The method 300 may end after block 320, having defined reports, trigger conditions, resulting actions, and any associated parameters that can be configurable by a user.
The following example, using one example report and associated trigger condition, is illustrative of an example for carrying out the methods described herein. In this example, a report may be a data quality report, which indicates the number of data samples gathered and stored in data over a predetermined period of time. Thus, the report may be relied upon to indicate whether the data gathering techniques are performing as expected, or whether data is missing, and thus may be discounted as less reliable. As a simplistic example, assume that data is gathered from a single turbine, and averaged together every ten minutes, storing ten minute averages in a historical database. Thus, perfect data collection would expect 144 entries in the historical database. A trigger condition may be defined to indicate that anything below a predefined threshold (e.g., 137 entries=95%) would generate an alarm to an operator that indicates a potential data quality issue. Thus, in operation, every twenty-four hours, the data quality report is run to provide the number of data entries over the last twenty-four hours. The report output may simply provide a count of the number of data entries, or may provide a graph of the entry and associated storage time. Either while executing the report, or after the report output is generated, the report analyzer module 104 can process the report output data against the defined trigger condition. If the predefined threshold is not satisfied (e.g., less than 137 entries), then an alarm can be generated to an operator that informs the operator of the potential data quality issue. In one example, the report output (e.g., the graph indicating where missing entries may have occurred) can also be transmitted to the operator for the operator's manual analysis. In another example, the alarm may include more detailed information regarding the potential failure (e.g., include times of day missing data, etc.).
It is appreciated that the aforementioned examples are provided for illustrative purposes only, and that any number of reports and trigger conditions can analyzed according to the methods described herein.
Accordingly, by performing automatic processing of report output data, these systems and methods have the technical effect of greatly reducing the amount of manual effort required to monitor turbine operating status. Without these systems and methods, all report output data would have to be manually monitored, the overwhelming majority of which will likely not indicate any problem. Thus, a human operator may be not be as attentive, due to the unlikely possibility of an error, and miss a critical status change. A further technical effect of automatically processing report output and generating an alarm or any other resulting action enables manual intervention or other system changes only when problems are identified as a result of processing the report output against the trigger conditions. Thus, as a result of these systems and methods, more effective, efficient, and safer turbine monitoring is provided.
The application references block diagrams of systems, methods, apparatuses, and computer program products according to at least one embodiment described herein. It will be understood that at least some of the blocks of the block diagrams, and combinations of blocks in the block diagrams, respectively, may be implemented at least partially by computer program instructions. These computer program instructions may be loaded onto a general purpose computer, special purpose computer, special purpose hardware-based computer, or other programmable data processing apparatus to produce a machine, such that the instructions which execute on the computer or other programmable data processing apparatus create means for implementing the functionality of at least some of the blocks of the block diagrams, or combinations of blocks in the block diagrams discussed in detail in the descriptions below.
These computer program instructions may also be stored in a computer-readable memory that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory produce an article of manufacture including instruction means that implement the function specified in the block or blocks. The computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions that execute on the computer or other programmable apparatus provide steps for implementing the functions specified in the block or blocks.
One or more components of the systems and one or more elements of the methods described herein may be implemented through an application program running on an operating system of a computer. They also may be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor based, or programmable consumer electronics, mini-computers, mainframe computers, etc.
Application programs that are components of the systems and methods described herein may include routines, programs, components, data structures, etc. that implement certain abstract data types and perform certain tasks or actions. In a distributed computing environment, the application program (in whole or in part) may be located in local memory, or in other storage. In addition, or in the alternative, the application program (in whole or in part) may be located in remote memory or in storage to allow for circumstances where tasks are performed by remote processing devices linked through a communications network.
Many modifications and other embodiments of the exemplary descriptions set forth herein to which these descriptions pertain will come to mind having the benefit of the teachings presented in the foregoing descriptions and the associated drawings. Thus, it will be appreciated the invention may be embodied in many forms and should not be limited to the exemplary embodiments described above. Therefore, it is to be understood that the invention is not to be limited to the specific embodiments disclosed and that the modification and other embodiments are intended to be included within the scope of the appended claims. Although specific terms are employed herein, they are used in a generic and descriptive sense only and not for purposes of limitation.