The present disclosure relates generally to processor control systems and, more particularly, to process control methods and systems to access process control log information associated with process control systems.
Process control systems, like those used in chemical, petroleum or other processes, typically include one or more centralized process controllers communicatively coupled to at least one host or operator workstation and to one or more field devices via analog, digital or combined analog/digital buses. The field devices, which may be, for example, valves, valve positioners, switches and transmitters (e.g., temperature, pressure and flow rate sensors), perform functions within the process such as opening or closing valves and measuring process parameters. The process controller receives signals indicative of process measurements made by the field devices and/or other information pertaining to the field devices, uses this information to implement a control routine, and then generates control signals that are sent over the buses or other communication lines to the field devices to control the operation of the process. Information from the field devices and the controllers may be made available to one or more applications executed by the operator workstation to enable an operator to perform desired functions with respect to the process, such as viewing the current state of the process, modifying the operation of the process, etc.
Process control system applications typically include process control monitoring routines that can be configured to monitor various aspects of a process control system and log information associated with monitoring the process control system. For example, monitoring routines are often used to monitor alarms associated with various field devices, modules, plant areas, etc. and collect detailed information (e.g., instance/condition counts, time of day, acknowledged/unacknowledged status, duration, etc.) associated with the alarms. Monitoring routines may also be used to monitor other aspects of a process control system such as, for example, events, actions, errors, etc. The collected detailed information (i.e., process control log information) is typically stored in a database. As time passes more process control log information is generated and stored, thus, increasing the size of the database.
To analyze the performance or other operational aspects of a process control system, users retrieve the process control log information from the database using, for example, data queries. As the amount of data stored in the database increases, the access times associated with retrieving process control log information also increases. Each access to the database may require several minutes to return the requested process control log information. The long access times associated with retrieving process control log information often decrease productivity and decrease the efficiency of analyzing the process control log information, thus, delaying the successfully identification of potential problems and repairs or upgrades associated with a process control system. In turn, the decreased productivity and the decreased efficiency of performing analyses can increase a company's operational costs and reduce its process yields.
Example methods and systems to access process control log information associated with process control systems are disclosed herein. In accordance with one example, a method of accessing process control log information involves obtaining the process control log information from a database based on a plurality of logging time periods and at least one data query. The process control log information is then categorized based on at least one of a plurality of categories. A plurality of output files are then generated based on the plurality of logging time periods and the categorized process control log information. A portion of the process control log information is then retrieved from one of the plurality of output files based on one of the plurality of logging time periods and is output.
In accordance with an example method of generating web browser session history disclosed herein, a first index value is assigned to a first web page. A request associated with loading a second web page is then obtained and the first index value is incremented. Changed information associated with the first web page is then stored in a table based on the first index value and a second index value is assigned to the second web page.
In accordance with an example method of generating a bookmark for a dynamic web page disclosed herein, a web page displaying first information is identified. Second information provided to a web application via the web page and associated with displaying third information via the web page is then obtained. The second information is then stored in a database.
Although the following discloses example systems including, among other components, software and/or firmware executed on hardware, it should be noted that such systems are merely illustrative and should not be considered as limiting. For example, it is contemplated that any or all of these hardware, software, and firmware components could be embodied exclusively in hardware, exclusively in software, or in any combination of hardware and software. Accordingly, while the following describes example systems, persons of ordinary skill in the art will readily appreciate that the examples provided are not the only way to implement such systems.
In contrast to known systems that require users (e.g., system engineers) to retrieve process control log information using database accesses associated with relatively long access times, the example methods and systems described herein may be used to store process control log information in optimized storage format (OSF) files from which users can access the process control log information in relatively less time than is typically required to retrieve the process control log information from a database. Process control applications typically include monitoring routines configured to monitor various aspects of one or more distributed process control systems such as, for example, alarms, events, actions, etc. The process control log information may include instance or condition counts (e.g., the number of times an alarm/event/action/etc. instance or condition occurred), a time of day for each instance or condition (e.g., timestamps), whether a particular alarm/event was acknowledged or unacknowledged, the duration of an alarm, summary information, or any other type of data associated with the monitored aspects of the process control system(s). An instance or a condition is associated with the occurrence of an error, an alarm, an event, a user action, etc. that may be associated with performance conditions, operations, process areas, etc. of a process control system. Conditions may be described using various condition levels such as, for example, a critical condition level, a warning condition level, or an advisory condition level. The monitoring routines collect the process control log information and store the process control log information in a log database.
An example system described herein can be configured to periodically communicate one or more data queries to a log database to retrieve process control log information and store the retrieved process control log information in an OSF data file. The process control log information may be stored in the OSF data file in extensible markup language (XML) or in any other suitable data language. The one or more data queries used to retrieve the process control log information from the log database may specify the process control log information to be retrieved based on data logging time periods and data types. The data types may be those that users are typically interested in analyzing. In this manner, a base data query string can be generated once and used a plurality of times thereafter to periodically retrieve the process control log information and generate the OSF data files. After the OSF data files are generated, the process control information can be retrieved from the OSF data files in response to user requests without needing to access the log database, thus, decreasing the amount of time required for a user to retrieve process control information.
To further decrease access times associated with retrieving process control log information, the example system may organize the process control log information based on data monitoring time periods (i.e., data logging time periods), data types (e.g., alarms, user actions, system events, module errors, log alarms, log events, etc.), process control system areas, etc. In this manner, the example system may access an OSF data file and/or a portion of an OSF data file associated with the user-requested information and/or data logging time period to retrieve the user-requested process control log information without needing to search through every record of a log database.
The example system described below is configured to generate daily OSF data files and monthly OSF data files. The daily OSF data files include detailed process control log information describing each occurrence of an instance or a condition associated with, for example, an alarm, event, action, error, etc. A monthly OSF data file includes summarized process control log information of instance/condition occurrences logged during a month. For example, the summarized process control log information in a monthly OSF data file may include total counts associated with the number of times that particular instances or conditions associated with each data type occurred in a month. In this manner, a user may view the summary process control log information retrieved from the monthly OSF data files and determine based on the summary information which detailed process control log information warrants further analysis and, thus, should be retrieved from the daily OSF data files.
A user may access the process control log information using a client program application (e.g., a Microsoft Windows® application) or a web-based application (e.g., a server-side web application, active server pages applications, java servlet applications, a hypertext preprocessor (“PHP”) application, etc.). The client program application may be installed on a processor system used to store the OSF data files or on any other processor system that is communicatively coupled via, for example, a network, to a memory on which the OSF data files are stored. A user may use a web-based application via any web browser capable of communicating with a web host associated with the web-based application and capable of accessing the OSF data files. Web pages associated with web-based applications are typically dynamic, which limits web browsing features available for users to navigate through information in the dynamic web pages. For example, bookmarking a dynamic web page (e.g., creating a favorites link to a dynamic web page) and subsequently using the bookmark to access the dynamic web page often results in generating a blank web page or a web page having different information than the information displayed in the web page at the time the bookmark was generated. Example methods described herein may be used to configure web applications (i.e., web-based applications) to provide users with tools such as bookmarking (e.g., creating favorites links) and forward/backward navigation operations that function in connection with dynamic web pages.
Now turning to
The application station 102 may be configured to perform operations associated with one or more information technology applications, user-interactive applications, and/or communication applications. For example, the application station 102 may be configured to perform operations associated with process control-related applications and communication applications that enable the application station 102, the operator stations 104, and the controller 106 to communicate with other devices or systems using any desired communication media (e.g., wireless, hardwired, etc.) and protocols (e.g., HTTP, SOAP, etc.).
The application station 102 may also be configured to perform operations associated with one or more application(s) used to implement the example methods and systems described herein to periodically retrieve process control log information from a log database, generate OSF data files based on the retrieved process control log information, and output at least portions of the process control log information from the OSF data files in response to user requests. The application station 102 and the operator stations 104 may be implemented using one or more workstations or any other suitable computer systems or processing systems (e.g., the processor system 1910 of
The controller 106 may be coupled to a plurality of field devices 112 via a digital data bus 114 and an input/output (I/O) device 116. The field devices 112 may be Fieldbus compliant valves, actuators, sensors, etc., in which case the field devices 112 communicate via the digital data bus 114 using the well-known Fieldbus protocol. Of course, other types of field devices and communication protocols could be used instead. For example, the field devices 112 could instead be Profibus or HART compliant devices that communicate via the data bus 114 using the well-known Profibus and HART communication protocols. Additional I/O devices (similar or identical to the I/O device 116) may be coupled to the controller 106 to enable additional groups of field devices, which may be Fieldbus devices, HART devices, etc., to communicate with the controller 106.
The controller 106 may be, for example, a DeltaV™ controller sold by Fisher-Rosemount Systems, Inc. However, any other controller could be used instead. Further, while only one controller is shown in
As depicted in
The event historian station 120 may be configured to perform operations associated with one or more monitoring routines to monitor various aspects and/or areas associated with one or more distributed process control systems (e.g., the example process control system 110) of the example enterprise 100. The event historian station 120 may acquire or collect process control log information associated with each event, alarm, action, etc. that the event historian station 120 is configured to monitor. The event historian station 120 may store the process control log information in a log database (e.g., the log database 206 of
The example enterprise 100 is provided to illustrate one type of system within which the example systems and methods described in greater detail below may be advantageously employed. However, the example systems and methods described herein may, if desired, be advantageously employed in other systems of greater or less complexity than the example enterprise 100 shown in
The example system 200 includes an OSF data file generator 202 and an OSF data file interface 204. In general, the OSF data file generator 202 is configured to retrieve process control log information from a log database 206 based on data queries and store the process control log information in a plurality of OSF data files 208 (e.g., a plurality of output files) based on data logging time periods and data type categories, and the OSF data file interface 204 is configured to retrieve the process control log information from the OSF data files 208 and filter, organize, and output the process control log information in response to user requests. The OSF data file generator 202 and the OSF data file interface 204 may be implemented using the same or separate software applications installed on any processor system that is used to store the log database 206 or that is otherwise communicatively coupled to the log database 206. For example, the OSF data file generator 202 may be implemented in software installed in the event historian station 120 and the OSF data file interface 204 may be implemented in software installed in the application station 102 of
The OSF data file interface 204 may be configured to communicate with one or more user interfaces. For example, the OSF data file interface 204 may be communicatively coupled with a client application user interface associated with an executable client application (e.g., a Microsoft Windows® application) installed on any processor system that is communicatively coupled to the OSF data file interface 204. Additionally or alternatively, the OSF data file interface 204 may be communicatively coupled with a web-based application user interface. In this case, the web-based application may be configured to exchange information with the OSF data file interface 204 via the web server 122 (
Turning in detail to the OSF data file generator 202, an administrator 210 is communicatively coupled to the OSF data file generator 202 and configured to periodically communicate a data collection request or data collection command to the OSF data file generator 202. For example, the administrator 210 may be configured to communicate the data collection command to the OSF data file generator 202 once per day or a plurality of times per day. The data collection command causes the OSF data file generator 202 to perform a data collection process to retrieve process control log information from the log database 206 and write the process control log information to the OSF data files 208. The administrator 202 may be any application or routine that may be configured to communicate data collection commands to the OSF data file generator 202 based on, for example, a schedule or one or more particular time intervals. The administrator 202 may be communicatively coupled to a user interface (e.g., a web-based user interface) via which a user may define or specify the schedule or time interval(s) associated with communicating data collection commands to the OSF data file generator 202. The user may also specify via the user interface data logging time periods to be communicated to the OSF data file generator 202 via the data collection commands.
As shown, the OSF data file generator 202 includes a time period specifier 212 communicatively coupled to the administrator 210. The time period specifier 212 is configured to receive the data collection command from the administrator 210 and determine a data logging time period (e.g., one or more hours, one or more days, one or more weeks, one or more months, etc.) for which the OSF data file generator 202 should retrieve process control log information from the log database 206. The OSF data file generator 202 may also use data logging time periods to determine the data logging time periods for which to generate the OSF data files 208. For example, if the data logging time period is one day, then the OSF data file generator 202 retrieves process control log information logged during the past twenty-four hours, generates a daily OSF data file, and stores the retrieved process control log information in the daily OSF data file. If the data logging time period is one month, the OSF data file generator 202 retrieves process control log information logged during the past month, generates a monthly OSF data file, and stores the retrieved process control log information in the monthly OSF data file.
Additionally or alternatively, in an example implementation in which the administrator 210 communicates a plurality of data collection commands to the time period specifier 212 in one day, the time period specifier 212 may specify a time offset and a data logging time period. In this case, the time offset defines the hours, minutes, seconds, etc. past, for example, midnight, at which the OSF data file generator 202 previously collected process control log information from the log database 206. The time offset configures or instructs the OSF data file generator 202 to retrieve process control log information from the log database 206 that has been logged since the last received data collection command received from the administrator 210. In this manner, the OSF data file generator 202 retrieves only the process control log information that it has not been previously retrieved. Of course, the time period specifier 212 and/or other structures of the OSF data file generator 202 may be configured to employ other suitable methods to substantially eliminate storing duplicate data in the OSF data files 208 or omitting data from the OSF data files 208. For example, if the time period specifier 212 obtains a plurality of data collection commands from the administrator 210 per day, the time period specifier 212 may specify a data logging time period associated with collecting all of the process control log information logged since 12:00 am of that day. In this manner, process control log information previously retrieved form the log database 206 and stored in one of the OSF data files 208 is replaced or overwritten with the same process control log information and any additional process control log information logged in the log database 206 between the times of receiving a previous data collection command and receiving the most recent data collection command.
The time period specifier 212 may be configured to employ one or more of a plurality of suitable techniques to obtain data logging time periods. For example, if the data logging time period is specified in the data collection command received from the administrator 210, the time period specifier 212 may obtain the data logging time period from the data collection command as described above. In another example implementation, the time period specifier 212 may include one or more registers (not shown) and a clock (not shown) indicating a present time value (e.g., a present date and a time of day) and synchronized with a clock associated with the event historian station 120 (
In yet another implementation, the time period specifier 212 may be communicatively coupled to a user interface via which a user can specify data logging time periods. In this case, a user can provide or specify timestamps indicating a particular range of time for which the time period specifier 212 should collect process control log information from the log database 206. The user may enter the timestamps via a text field or may select the timestamps from a plurality of available timestamps provided by the time period specifier 212 based on times for which process control log information is stored in the log database 206.
The OSF data file generator 202 includes a data queries interface 214 communicatively coupled to the time period specifier 212 and to the log database 206. The data queries interface 214 is configured to communicate data queries to the log database 206 to retrieve process control log information. In the illustrated example, the data queries interface 214 obtains data logging time period values and/or time offset values from the time period specifier 212. The data queries interface 214 can then communicate the data logging time period value or the time offset value via a data query to the log database 206 to retrieve the process control log information logged during the specified data logging time period or after the specified time offset. In the illustrated example, the process control log information retrieved by the data queries interface 214 from the log database 206 is in the form of raw data including detailed information associated with each logged instance or condition (of an event, alarm, action, etc.). For example, the log entries in the log database 206 may include tags (e.g., tags shown if
The data queries interface 214 can generate each data query used to collect process control log information based on a base query string, a data logging time period, and/or a time offset. The base query string may be designed or specified once during, for example, a design time (e.g., the time at which system engineers or application programmers specify parameter values for the OSF data file generator 202), and used by the data queries interface 214 a plurality of times to generate data queries. The base query string may include values or parameters associated with the types of process control information that a system engineer is most likely to request via, for example, the OSF data file interface 204. Alternatively, the data queries interface 214 may generate queries to retrieve all of the process control log information logged in the log database 206 during specified data logging time periods or after specified time offsets.
The OSF data file generator 202 includes a data processor 216 communicatively coupled to the data queries interface 214 and configured to categorize process control information into a plurality of data type categories. For example, the data queries interface 214 communicates the retrieved process control information to the data processor 216, and the data processor 216 categorizes the process control information into a plurality of pre-defined data type categories. The data type categories may include, for example, alarms, user actions, system events, module errors, log alarms, log events, etc. The data processor 216 groups the categorized process control log information into data type category segments 218. The data processor 216 may also be configured to generate summary information associated with the retrieved process control log information and store the summary information in the data type category segments 218. For example, the data processor 216 may determine total counts (e.g., a TotCnt parameter 712 and/or a Cnt1 parameter 714 of
The data processor 216 may also be configured to filter the process control log information received from the data queries interface 214. For example, if the data queries interface 214 generates queries to retrieve all of the process control log information logged in the log database 206 during specified data logging time periods or after specified time offsets, the data processor 216 may filter the process control log information based on predefined data filters. In this case, the data filters may be defined at design time and may include values or parameters associated with the types of process control log information that a system engineer or user is most likely to request.
The OSF data file generator 202 includes an OSF data file formatter 220 communicatively coupled to the time period specifier 212 and the data processor 216, and is configured to generate the OSF data files 208 according to a particular data format or data organization and write process control information to the OSF data files 208. In the illustrated example, the OSF data file formatter 220 may be configured to format the OSF data files 208 based on example OSF data file formats described below in connection with
The OSF data file formatter 220 is configured to obtain data logging time period values from the time period specifier 212 each time the time period specifier 212 obtains a data collection command from, for example, the administrator 210. The OSF data file formatter 220 uses the data logging time period values to determine they type of OSF data file to generate and/or to which OSF data to write the categorized process control log information. For example, if the data logging time period is a 24-hour time period, the OSF data file formatter 220 generates a daily OSF data file and writes the process control log information from the category type segments 218 to that daily OSF data file. If the data logging time period is one month, then the OSF data file formatter 220 generates a monthly OSF data file. The OSF data file formatter 220 also writes summary information from each of the category type segments 218 to the OSF data files.
If a daily OSF data file or a monthly OSF data file already exists for a particular data logging time period (due to a previous data collection specifying the same daily or monthly data logging time period), then the OSF data file formatter 220 writes the process control log information from the category data type segments 218 to the existing OSF data file. In this case, new summary information (e.g., new total counts for recently retrieved process control log information) in the category type segments 218 can be added to the summary information (e.g., existing total counts for previously retrieved process control log information) previously stored in the existing OSF data file.
For any particular process control information, the OSF data file generator 202 need only access the log database 206 one time to retrieve that particular process control log information and write the process control information to the OSF data files 208, thus, enabling a user to retrieve the process control log information from the OSF data files 208 any number of times thereafter. For instance, after the OSF data file generator 202 stores the process control log information in the OSF data files 208, a user may at any time thereafter use the OSF data file interface 204 to retrieve the process control log information from the OSF data files 208 without having to access the log database 206. In this manner, the OSF data file generator 202, the OSF data file interface 204, and the OSF data files 208 enable relatively faster access times associated with retrieving process control log information because the access times associated with retrieving process control log information from the OSF data files 208 are relatively less than the access times associated with retrieving process control log information from the log database 206.
A user may use the OSF data file interface 204 to retrieve process control log information from the OSF data files 208 by submitting a user request 224 to the OSF data file interface 204. In the illustrated example, the user request 224 may indicate daily or monthly data logging time periods and the date (e.g., month/day/year or month/year) associated with the data logging time period. The user request 224 may also indicate the type of process control log information that a user has requested. For example, a user may request a summary overview of the process control log information for a particular data logging time period or may request detailed process control log information associated with, for example, one or more particular instances or conditions (of an alarm, event, action, etc.). Additionally or alternatively, the user request 224 may indicate requested process control log information based on various data descriptions (e.g., the data descriptions shown in
The OSF data file interface 204 includes a time period identifier 226 and a requested information identifier 228, both configured to receive the user request 224. The time period identifier 226 is configured to determine a data logging time period based on the user request 224. The requested information identifier 228 is configured to identify the particular type of process control log information that is requested by a user based on the user request 224.
The OSF data file interface 204 includes a file reader 230 communicatively coupled to the time period identifier 226 and configured to retrieve process control log information from the OSF data files 208 based on the identified data logging time period. For example, if the data logging time period is a daily time period, then the file reader 230 accesses a daily OSF data file associated with a specific date obtained from the user request 224 by the time period identifier 226. The file reader 230 may be configured to retrieve some (e.g., one line of process control log information) or all of the process control log information from one of the OSF data files 208 during one read operation. If the file reader 230 is configured to read one line of process control log information from one of the OSF data files 208 during a read operation, then the file reader 230 may read all of the process control log information from the OSF data file in an iterative manner using a plurality of read operations based on other operations (e.g., filtering operations, analyzing operations, etc.) performed by other portions of the OSF data file interface 204.
The OSF data file interface 204 includes a data filter 232 communicatively coupled to the requested information identifier 228 and the file reader 230, and configured to filter the process control log information based on the user request 224. More specifically, after the file reader 230 reads the process control log information from one of the OSF data files 208, the file reader 230 communicates the process control log information to the data filter 232. The data filter 230 is configured to receive from the requested information identifier 228 one or more values, parameters, or messages indicating the type of process control log information indicated in the user request 224. The data filter 232 can then extract some, none, or all of the process control log information received from the file reader 230 based on the type of information indicated in the user request 224. For example, if the user request 224 indicates a request for summary information, then the data filter 232 can extract a summary information portion from the process control log information. On the other hand, if the user request 224 indicates a request for all of the process control log information collected for a specified date and stored in a particular one of the OSF data files 208, then the data filter 232 can retain all of the process control log information received from the filer reader 230.
In the illustrated example, the data filter 232 may be configured to filter the process control log information based on data type categories (e.g., alarms, user actions, module errors, systems, log alarms, log events, etc.), some of which are shown in
The OSF data file interface 204 includes a data analyzer 234 communicatively coupled to the data filter 232 and configured to analyze the filtered process control log information obtained from the data filter 232. Specifically, the data analyzer 234 may be configured to generate count values, statistical values, interval time values between occurrences of particular instances or conditions, or generate any other type of analytical value associated with the particular process control log information filtered by the data filter 232. For example, if the user request 224 indicates requested process control log information logged within a particular time range, the data analyzer 234 may determine the count values associated with the occurrences of each type of instance or condition associated with that time range. Also, the data analyzer 234 may analyze the process control information to generate statistical values, such as, for example, percentage values or probability values. System engineers may use probability values to make decisions associated with day-to-day process control system operations, maintenance, upgrades, etc.
In an example implementation, the data analyzer 234 may be configured to generate pattern or relationship information associated with patterns or relationships between instances of alarms, events, actions, or any other types of log entries. For example, the data analyzer 234 may be configured to analyze a plurality of log entries read by the file reader 230 from one or more of the OSF data files 208 and find instances or occurrences of a particular type of alarm. For each instance of the particular type of alarm, the data analyzer 234 may analyze other instances of alarms, events, actions, etc. that occurred and were logged within a particular time period relative to that instance of the particular type of alarm. For example, for each instance of the particular alarm, the data analyzer 234 may analyze log entries that were logged within thirty seconds prior to and thirty seconds after that instance of the particular alarm was logged. In this manner, the data analyzer 234 may determine any similarities or patterns between log entries logged within a particular time period relative to each instance of the particular type of alarm and generate pattern or relationship information indicating whether two or more types of log entries may be related.
Example pattern or relationship information may indicate that a pressure alarm associated with a particular holding tank is asserted every time that a particular valve opens (e.g., a particular event occurs). System engineers may use pattern or relationship information to determine whether particular events or actions may be causes of alarms triggering in process control systems and to determine maintenance actions. The particular types of log entries to be analyzed to generate pattern or relationship information may be determined by the requested information identifier 228 based on the user request 224. Additionally or alternatively, the data analyzer 234 may be configured to determine pattern or relationship information in response to determining that a plurality of log entries associated with a particular type of log entry exceeds a threshold (e.g., an instance or occurrence threshold), which may be determined at a design time or provided via the user request 224.
The OSF data file interface 204 includes a pre-processor 236 communicatively coupled to the data analyzer 234 and the file reader 230. The pre-processor 236 is configured to obtain filtered process control log information and analysis values from the data analyzer 234 and organize the filtered process control log information based on, for example, data category, summary information, detailed information, analysis information, etc. to generate a plurality of pre-processed information segments 238. Each pre-processed information segment 238 may include process control information and analysis information associated with, for example, a particular data category, a particular time range, etc. The pre-processor 236 may also be configured to generate instance/condition count values or other statistical values in addition to the count values and statistical values generated by the data analyzer 234. In some cases, the pre-processor 236 may obtain count values (e.g., a TotCnt parameter 712 or a Cnt1 parameter 714 of
In some example implementations, the pre-processor 236 may be configured to generate statistical information based on a portion (e.g., one line) of the process control log information. If the file reader 230 is configured to read the process control log information from one of the OSF data files 208 using a plurality of read operations, in which each read operation retrieves one of a plurality of portions (e.g., one of a plurality of lines) of the process control log information at a time, the pre-processor 236 may be configured to communicate a feedback signal or message to the file reader 230 when the pre-processor 236 is finished processing a previously retrieved portion. In this manner, the file reader 230 may retrieve another portion (e.g., another line) of the process control log information from the OSF data file based on another read operation.
To save storage space, the process control log information stored in the OSF data files 208 is tagged using pre-defined tags (e.g., the tags shown in
To label the process control log information with text, identifiers, or descriptions that can be interpreted by a user, the OSF data file interface 204 includes a post-processor 240 communicatively coupled to the pre-processor 236 and the time period identifier 226. The post-processor 240 is configured to obtain the pre-processed information segments 238 from the pre-processor 236 and produce processed information 242 by organizing the process control information in the pre-processed information segments 238 into a format and/or organization that facilitates interpreting and analyzing the process control information. The post-processor 240 may be provided with tables (e.g., the tables of
The post-processor 240 may also be configured to process (e.g., generate statistical information, perform analyses, generate pattern and/or relationship information, etc.) and organize the process control log information. For example, in implementations in which the pre-processor 236 is configured to process a portion (e.g., a line) of process control log information at a time, the post-processor 240 may be configured to process a plurality of portions or all of the process control log information from one of the OSF data files 208 at a time. The post-processor 240 may then organize the process control log information into tables, columns, rows, or any other type of organization to generate the processed information 242, label the processed information 242 with an associated data logging time period obtained from the time period identifier 226, and output the processed information 242 to a client application, a web-based application, a storage medium, or to any other user-specified destination.
In an example implementation, the post-processor 240 may be configured to provide alarm configuration or alarm setting recommendations based on, for example, statistical information, pattern or relationship information, or any other analysis information. For example, for a particular type of alarm the post-processor 240 may analyze the process control log information obtained from the pre-processed information segments 238 to determine percent occurrence information and operating condition information associated with the instances or occurrences of that type of alarm. For example, the post-processor 240 may determine that relatively more log entries associated with a pressure alarm are associated with a pressure level (e.g., an operating condition) below a particular level. The post-processor 240 may then generate recommendation information indicating that setting the trigger level for that alarm above that particular level can reduce occurrences or instances of that alarm by, for example, a particular percentage.
Although the OSF data file generator 202 is described above as being configured to generate daily and monthly OSF data files, the OSF data file generator 202 may be configured to generate OSF data files associated with any other time period (e.g., one or more hours, one or more days, one or more weeks, one or more months, etc.). Additionally or alternatively, the OSF data file generator 202 may be configured to generate OSF data files associated with one type of data logging time period or a data logging time period of one duration (e.g., a 24-hour time period) and the OSF data file interface 204 may be configured to generate OSF data files associated with other types of data logging time periods (e.g., a week time period, a month time period, an hour time period, etc.). In this case, each of the OSF data files 208 is generated based on the same duration of time (e.g., each of the OSF data files 208 is a daily OSF data file). To generate OSF data files of different data logging time periods based on the OSF data files 208, the user request 224 may specify the other data logging time periods or the administrator 210 may be communicatively coupled to the OSF data file interface 204 an configured to communicate requests to the OSF data file interface 204 specifying the other data logging time periods. In any case, the process information 242 may be one or more OSF data files associated with data logging time periods that are different than the data logging time periods associated with the OSF data files 208.
In an example implementation, the OSF data file generator 202 may be configured to generate comparison information associated with process control log information logged during different time periods. For example, the OSF data file generator 202 may be configured to generate a historical summary associated with a particular data logging time period based on one or more of the OSF data files 208 and compare the historical summary to process control log information logged during a shorter or different data logging time period. In this manner, the OSF data file generator 202 may generate difference information based on the comparison indicating, for example, percentages of more or less occurrences of particular types of log entries, and provide the difference information in the processed information 242. The OSF data file generator 202 may also provide in the processed information 242 different or separate summary information (or detailed information) for different data logging time periods (e.g., first summary information associated with a first data logging time period and second summary information associated with a second data logging time period). In this manner, a user may view the different summary information (or detailed information) in a side-by-side display configuration via a user interface (e.g., an example web-based user interface 900 of
The summary data section 304 includes summary information associated with the process control log information stored in a particular daily OSF data file. In the illustrated example, the summary data section 304 includes a data collection time period and a total instance count and/or condition count. The data collection time period indicates the data logging time period during which the process control log information was acquired and logged by the log database 206. The total instance and/or condition count indicates the number of instances and/or conditions associated with alarms, events, actions, etc. that occurred during the data logging time period and for which process control information is stored in the daily OSF data file. The specific data type summary section 306 includes categorized data type descriptions and counts associated with each data type for which process control information is stored in a daily OSF data file.
The time zone information section 308 includes a time zone setting (e.g., based on Greenwich Mean Time (GMT)) associated with the data logging time period during which the log database 206 acquired and logged the process control information that is stored in a particular daily OSF data file. The detailed raw data section 310 includes detailed data for each instance or condition associated with each data category. The OSF data file formatter 220 uses the detailed raw data section 310 to store the raw data log entries obtained by the data queries interface 214 from the log database 206.
As shown in
The example daily OSF data file 700 of
As shown in the summary data section 704, a TotCnt parameter 712 indicates that 5,419 is the total number of instances/conditions logged for the particular type of data represented in the example daily OSF data file 700 during the particular data logging time period associated with the example daily OSF data file 700. The specific data type summary section 706 includes total counts for various instances or conditions organized by data type category (e.g., an alarm category, a user actions category, a module errors category, a system category, a log alarm category, a log event category, and a remaining category). A Cnt1 parameter 714 in the specific data type summary section 706 indicates that 2,246 instances/conditions were logged under the alarm data type category. Count values associated with count parameters (e.g., the TotCnt parameter 712 and the Cnt1 parameter 712) may be generated by the data processor 216 (
In the specific data type summary section 706 the instances/conditions associated with each data type category can be further categorized based on other criteria. In the illustrated example, the instances/conditions associated with the alarm data type category are further categorized based on action/unacknowledged (“ACT/UNACK”) and action/acknowledge (“ACT/ACK”) criteria. Of course, the instances/conditions can be further categorized based on any other types of criteria as well.
The detailed raw data section 710 includes a plurality of raw data entries associated with each of the data categories summarized in the specific data type summary section 706. The raw data entries stored in the detailed raw data section 710 are retrieved by the data queries interface 214 from the log database 206 as described above in connection with
The raw data entry 716 and the timestamp entry 720 include a plurality of description information parameters (e.g., ‘D’, ‘E’, ‘F’, etc.), each of which is associated with one of the tags 504 of the legend 500 (
The example monthly OSF data file 800 of
The process control log information represented in the example web-based user interface 900 is associated with a monthly OSF data file as indicated by a date header 902. The web-based user interface 900 includes a summary section 904 showing total monthly count information for various areas of a process control system (e.g., the process control system 110 of
Although
In an example implementation associated with the web-based user interface 900 of
In general, the web application 1100 is configured to generate bookmarks by saving re-creation information (e.g., the user-provided or data-resource provided information) submitted via creator web pages. In this manner, any time that a user selects a particular bookmark associated with a dynamic web page, re-creation information can be submitted to the creator web page and the creator web page can dynamically generate the bookmarked dynamic web page to show the same information that was displayed at the time that the bookmark was generated.
To obtain web page information (e.g., process control log information) from the server 1102, the web application 1100 is provided with a data interface 1104. The data interface 1104 communicates the web page information to a web page generator 1106 that is configured to render web pages via a user interface 1108. To generate bookmarks that enable a user to return to dynamic web pages to view the same information that was displayed at the time the bookmarks were generated, the web application 1100 is provided with a bookmark library 1110. The bookmark library 1110 is communicatively coupled to the data interface 1104 and the web page generator 1106. The bookmark library 1110 is also communicatively coupled to a bookmark data table 1112 that is configured to temporarily store re-creation information. Additionally, the bookmark library 1110 is communicatively coupled to a database 1114 to store the bookmarks generated for the dynamically generated web pages.
After the web page generator 1106 obtains all re-creation information required to dynamically generate a web page, the web page generator 1106 in combination with a creator web page may dynamically generate the web page. If a user selects to generate a bookmark for the dynamic web page, the web page generator 1106 may store in the bookmark data table 1112 all of the re-creation information required to dynamically generate the displayed web page. For example, if the dynamic web page is the web-based user interface 900 as shown in
The bookmark library 1110 is configured to then generate a bookmark by converting the information stored in the bookmark data table 1112 into one or more data table strings 1116 and by generating identification and creation information 1118 associated with the data table strings 1116 to identify the bookmark being generated. The identification and creation information 1118 may include a name of the bookmark, the address (e.g., a uniform resource locator (URL) address) of the creator web page, and the date on which the bookmark was generated. The data table strings 1116 and the identification and creation information 1118 may be written and stored in XML format. In the illustrated example, the bookmark library 1110 stores the data table strings 1116 and the identification and creation information 1118 in the database 1114 for subsequent retrieval.
To facilitate user access to the bookmarks stored in the database 1114, the web page generator 1106 may display a listing of the stored bookmarks via a web page based on identification and creation information (e.g., the identification and creation information 1118). For example, the web page generator 1106 may display the stored bookmark listing in response to receiving user input associated with a user selecting, for example, a bookmark control 1120 shown in
The web application 1100 is communicatively coupled to an index table 1210 in which the web application 1100 may store web page histories associated with a plurality of web pages 1212a-c. The web application 1100 tracks or organizes the web page histories stored in the index table 1210 based on index values assigned to web pages as they are generated or loaded by the web application 1100. For example, when the web application 1100 is initially opened, the web application 1100 loads or displays the first web page and assigns the first web page an index value zero (‘0’). When a user provides or submits a request to the web application 1100 via, for example, a hyperlink, to navigate to a new web page the web application 1100 increments the index value of the previous web page (e.g., the initially loaded web page) by one (e.g., index value one (‘1’)) and assigns the index value zero to the most recently newly loaded web page. As the user requests to navigate to other new web pages, the web application 1100 increments the index values of the previously loaded web pages accordingly and assigns the index value zero to the most recently newly loaded web page.
As shown in
When a user uses the forward and/or backward controls 1202 and 1204 to navigate to a previously loaded one of the plurality of web pages 1212a-c, the web application 1100 determines if any changed values are stored in the index table 1210 for the previously loaded one of the plurality of web pages 1212a-c to which the user is navigating. After retrieving any saved values from the index table 1210, the web application 1100 retrieves any unsaved or unchanged values associated with the previously loaded web page from the server 1102. In this manner, the web application 1100 ensures that any values that were changed by the user prior to navigating away from the previously loaded web page are displayed to the user in addition to any unchanged values obtained from the server 1102 when the user navigates back to the previously loaded web page. The web application 1100 is configured to generate web page histories and load previously displayed web pages associated with any index value based on user-input associated with the forward and backward controls 1202 and 1204. In other words, if the web application 1100 displays a web page having an index value of one or greater in response to receiving user-input associated with the backward control 1204, subsequent user-input associated with the forward control 1202 causes the web application 1100 to display a previously loaded web page having an index value less than the currently loaded web page in a manner substantially similar or identical to that used in response to receiving user-input associated with the backward control 1204.
Now turning in detail to the flowchart of
The data queries interface 214 (
The OSF data file formatter 220 (
The requested information identifier 228 then determines the type of process control log information that the user requested (block 1506) based on the user request 224. For example, the requested information identifier 228 may extract, identify, or otherwise obtain from the user request 224 which type of process control log information the user requested via the web-based user interface 900. The file reader 230 (
The data filter 232 then filters the process control log information (block 1512) read from one of the OSF data files 208 at block 1510. For example, the data filter 232 may obtain one or more values, strings, or otherwise messages from the requested information identifier 228 describing the type of process control log information indicated in the user requested 224 and select one or more data filters to use to extract or obtain the requested type of process control log information from the process control log information received from the file reader 230. The data analyzer 234 and the pre-processor 236 of
The post-processor 240 (
The web application 1100 then determines if it should create a bookmark (e.g., a favorites hyperlink) (block 1606). For example, the web application 1100 may determine that it should create a bookmark if it receives user-input from the web-based user interface 900 indicating that a user has requested to create a bookmark. If the web application 1100 determines that it should create a bookmark, then the web application 1100 creates a bookmark (block 1608). An example method that may be used to create a bookmark is described below in connection with
If the web application 1100 determines that it should not navigate to a new web page, then the web application 1100 determines if it has received a request for detailed information (e.g., the instrument alarm information in the detailed information area of 1006 of
If at block 1610 the web application 1100 determines that it should navigate to a new web page, then the web application 1100 increments the index value of the currently loaded web page (block 1616) as described above in connection with
As shown in
The web application 1100 then obtains changed information from the index table 1210 (block 1630) based on the index value of the previous web page obtained at block 1628. The changed information retrieved from the index table 1210 is information previously stored in the index table 1210 by the web application 1100 using, for example, the operation of block 1618. The web application 1100 then retrieves from a server (e.g., the server 1102) any non-changed information associated with the previous web page (block 1632) that is not stored in the index table 1210. For example, after populating data fields of the previous web page with the changed information retrieved from the index table 208, the web application 1100 determines if any remaining data fields of the previous web page have not been populated with data. The web application 1100 then determines that those data fields not yet populated are associated with information that the user did not change when the previous web page was previously loaded or displayed and, thus, retrieves from the server 1102 the information associated with the data fields not yet populated. The web application 1100 then displays the previous web page with the changed and non-changed information (block 1634). The web application 1100 then determines if it should be closed (block 1636) based on, for example, user input or a command indicating that the web application 1100 should be closed. If the web application 1100 has not received user input or a command to close, then control is returned to block 1606. Otherwise, the example method or process of
The web application 1100 then stores the re-creation information in a bookmark data table (e.g., the bookmark data table 1112 of
The web application 1100 then retrieves a user-selected bookmark (block 1806) and retrieves the re-creation information associated with the user-selected bookmark from the database 1114 (block 1808). For example, the web application 1100 may obtain user input indicating which of the bookmarks displayed via the user interface 1108 a user has selected. The web application 1100 may then retrieve one or more data table strings (e.g., the data table strings 1116 of
The web application 1100 then obtains the address (e.g., a URL address) of the creator web page (block 1810) associated with the selected bookmark. For example, the web application 1100 may obtain the address of the creator web page from the identification and creation information 1118. After obtaining the creator web page address, the web application 1100 communicates the re-creation information retrieved at block 1808 to the creator web page (block 1812). In this manner, the creator web page can re-create or dynamically generate the bookmarked web page based on the re-creation information. The web application 1100 then obtains the re-created web page information (block 1814) and displays the re-created web page (block 1816). For example, if the creator web page is hosted by the server 1102 (
The processor 1912 of
The system memory 1924 may include any desired type of volatile and/or non-volatile memory such as, for example, static random access memory (SRAM), dynamic random access memory (DRAM), flash memory, read-only memory (ROM), etc. The mass storage memory 1925 may include any desired type of mass storage device including hard disk drives, optical drives, tape storage devices, etc.
The I/O controller 1922 performs functions that enable the processor 1912 to communicate with peripheral input/output (I/O) devices 1926 and 1928 and a network interface 1930 via an I/O bus 1932. The I/O devices 1926 and 1928 may be any desired type of I/O device such as, for example, a keyboard, a video display or monitor, a mouse, etc. The network interface 1930 may be, for example, an Ethernet device, an asynchronous transfer mode (ATM) device, an 802.11 device, a DSL modem, a cable modem, a cellular modem, etc. that enables the processor system 1910 to communicate with another processor system.
While the memory controller 1920 and the I/O controller 1922 are depicted in
Although certain methods, apparatus, and articles of manufacture have been described herein, the scope of coverage of this patent is not limited thereto. To the contrary, this patent covers all methods, apparatus, and articles of manufacture fairly falling within the scope of the appended claims either literally or under the doctrine of equivalents.