Aspects of the disclosure are related to industrial automation systems, and more particularly, to data analytics systems that interact with industrial automation systems and devices.
Industrial controllers and their associated input/output (I/O) devices are central to the operation of modern automation systems. These controllers interact with field devices on the plant floor to control automated processes relating to such objectives as product manufacture, material handling, batch processing, supervisory control, and other such applications. Industrial controllers store and execute user-defined control programs to effect decision-making in connection with the controlled process. Such programs can include, but are not limited to, ladder logic, sequential function charts, function block diagrams, structured text, or other such programming structures.
Because of the large number of system variables that must be monitored and controlled in near real-time, industrial automation systems often generate vast amounts of near real-time data. In addition to production statistics, data relating to machine health, alarm statuses, operator feedback (e.g., manually entered reason codes associated with a downtime condition), electrical or mechanical load over time, and the like are often monitored, and in some cases recorded, on a continuous basis. This data is generated by the many industrial devices that can make up a given automation system, including the industrial controller and its associated I/O, telemetry devices for near real-time metering, motion control devices (e.g., drives for controlling the motors that make up a motion system), visualization applications, lot traceability systems (e.g., barcode tracking), etc. Moreover, since many industrial facilities operate on a 24-hour basis, their associated automation systems can generate a vast amount of potentially useful data at high rates. For an enterprise with multiple plant facilities, the amount of generated automation data further increases.
The large quantity of data generated by modern automation systems makes it possible to apply a broad range of plant analytics to the automation systems and processes that make up an industrial enterprise or business. Reports, charts, and other human-readable formats are often available or may be created for plant personnel and others wishing to monitor and review the generated data in either a real-time mode or at a later time after the data has been stored.
For example, data producers, data consumers, machine builders, original equipment manufacturers (OEMs) supplying equipment to a factory, plant operators, machine operators, and other stakeholders may want to review and analyze data collected by facility equipment in order to troubleshoot, perform maintenance, and improve equipment performance in existing or future models. OEMs and other producers and consumers of data, however, are challenged by how to manage the vast amounts of data collected and how to discover early insights from it. For example, to access the generated data, an operational engineer, information technology technician, or other professional having technical knowledge of the facility's systems is typically required.
The above-described deficiencies of today's industrial control and business systems are merely intended to provide an overview of some of the problems of conventional systems and are not intended to be exhaustive. Other problems with conventional systems and corresponding benefits of the various non-limiting embodiments described herein may become further apparent upon review of the following description.
Technology is disclosed herein for enhancing data analytics in an industrial automation environment. In an implementation, a data analytics service receives a request to connect to a source of data or streaming device for an industrial automation operation. Subsequent to receiving the request, the data analytics service connects with and interrogates the data source for a sample data set comprising, for example, time series and transactional information. Prior to saving the sample data set, the data analytics service analyzes the sample data set for one or more categories and initiates presentation of an inventory of the one or more categories. The data analytics service may receive a request to tailor the inventory of the one or more categories. Subsequent to receiving the request, the data analytics service may filter the sample data set in accordance with the request to tailor the inventory. In another implementation, the data analytics service, subsequent to receiving the request to tailor the inventory, may request from the data source a filtered version of the data set.
Subsequent to receiving the request to tailor the inventory of the one or more categories, the analytics service may add additional context by annotating the inventory of the one or more categories in accordance with the request to tailor the inventory. The analytics service may initiate presentation of the tailored inventory. Subsequent to receiving user input accepting the tailored inventory, the analytics service may store and analyze data associated with the tailored inventory. The analytics service then initiates presentation of a storyboard comprising the analyzed data set. The storyboard remains available, on demand, to present real-time, analyzed and updated data.
This Overview is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. It should be understood that this Overview is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
Many aspects of the disclosure can be better understood with reference to the following drawings. The components in the drawings are not necessarily to scale, emphasis instead being placed upon clearly illustrating the principles of the present disclosure. Moreover, in the drawings, like references numerals designate corresponding parts throughout the several views. While several implementations are described in connection with these drawings, the disclosure is not limited to the implementations disclosed herein. On the contrary, the intent is to cover all alternatives, modifications, and equivalents.
Technology is disclosed herein that improves data analysis techniques by tailoring gathered data from disparate sources to meet specific business requirements. In particular, processes employed by a data analytics service are disclosed that allow the data analytics service to optimize how data is retrieved and displayed from disparate sources. Operational data is generated by the many industrial devices that can make up a given automation system, including an industrial controller and its associated I/O devices, telemetry devices for near real-time metering, motion control devices (e.g., drives for controlling the motors that make up a motion system), visualization applications, lot traceability systems (e.g., barcode tracking), sensors, etc. The generated data may be accessed in real-time (e.g., streaming data from components and applications) or from historical data sources like, for example, spreadsheets and databases. The generated data may also be stored locally or on remote servers using a multitude of labels and categories.
In an implementation, a data analytics service connects to one or more data sources and interrogates the one or more data sources to obtain a sample data set of the data comprised therein. Data sources may comprise industrial automation machines, machine systems, databases, documents, applications, etc. From the sample data set, the data analytics service determines an inventory of available categories and presents the inventory in a user interface.
In an embodiment, the data analytics service may receive a request to apply one or more filters to the inventory prior to storing data from the one or more data sources. In an implementation of said embodiment, the data analytics service applies the filter request to the sample data set and loads the information in accordance with the filter request. In another implementation of said embodiment, the data analytics service requests a non-sample data set from the data source that comprises only the data that corresponds with the filter request. The non-sample data set is then loaded by the service. In some embodiments, the loaded data may be saved and analyzed by the data analytics service, which may then present the analyzed data in a generated storyboard.
In another embodiment, the data analytics service may receive a request to annotate the inventory prior to saving data from the one or more data sources. In an implementation of said embodiment, the data analytics service applies the annotation request to the sample data set. In another implementation, the data analytics service requests a non-sample data set from the data source and applies the annotation request to the non-sample data set. To apply the annotation request, the data analytics service may generate and insert into the data set a new field that corresponds with the requested annotation. The annotated data may be saved and analyzed by the data analytics service, which may then present the annotated data in a generated storyboard.
Turning now to
Data center 101 comprises data analytics service 102. Data analytics service 102 is implemented on one or more computing systems in data center 101, of which computing system 1002 in
To facilitate delivery of analytics information to data producers, data consumers, machine builders, OEMs, plant operators, and other stakeholders, data analytics service 102 is configured to employ storyboard process 200B or variations thereof to connect to one or more data sources and receive data gathered from the one or more sources, for example, from databases, documents, computing devices, applications, gateways, machines, and/or machine systems of plants. Data analytics service 102 also employs storyboard process 200B or variations thereof to process, analyze, and present the gathered data to the various stakeholders. In one embodiment, data analytics service 102 is a cloud-based system accessible via the Internet or similar communication protocols; however, other types of systems are also contemplated herein.
Data analytics service 102 comprises a storyboard system comprising one or more graphical dashboards configured to present contextual data. The storyboard system may be accessible to various stakeholders using, for example, tools such as FACTORYTALK® Analytics software provided by Rockwell Automation, Inc. Through the storyboard system, data analytics service 102 may initiate presentation of storyboards in user interface 116 of computing system 114. Stakeholders may interact with data analytics service 102 via user interface 116 to generate data filters, apply data annotations, and perform other methods to facilitate orchestration of the gathered data prior to its presentation in a storyboard.
Industrial automation environment 104 comprises machine(s) 106, controller(s) 108, and gateway(s) 110. Industrial automation environment 124 comprises machine(s) 126, controller(s) 128, and gateway(s) 120. Industrial automation environment 104 and industrial automation environment 124 are separate entities and may comprise an automobile manufacturing factory, food processing plant, oil drilling operation, microprocessor fabrication facility, or some other type of industrial enterprise. Note that there would typically be many more machine systems in most industrial automation environments, but the number of machine systems shown in
Machine(s) 106, 126 may comprise a sensor, drive, pump, filter, drill, motor, robot, fabrication machinery, mill, printer, or any other industrial automation equipment or element thereof, including associated control systems. Controller(s) 108, 128 may include automation controllers, programmable logic controllers (PLCs), programmable automation controllers (PACs), or any other controllers used in automation control.
Each controller(s) 108, 128 is configured to generate a predefined data structure populated with specific data. The format and configuration of the respective data structures may be the same, but the data contained therein is respective to each machine(s) 106, 126. The specific data, in embodiments of the invention, includes the following operational data: identifying information, machine state information, actual part production or count information, ideal part production or count information, machine event information, and specific machine variable information. The identifying information may identify the maker or builder of the machine, the owner of the machine, the supervisor of an operation(s), the machine operator, the shift date and time, machine location, etc. and allows the data analytics service 102 to group or categorize the data for a single entity or identifying feature.
In some embodiments, the machine state information includes data identifying a history of the operating states of the machine and the times in which each of the operating states was encountered. The actual part count information includes data indicating how many parts the particular machine has made over a period or periods of time. The part count information may include both the number of good parts produced as well as the number of bad parts produced. The ideal part count information includes the number of good parts that the machine should have produced during productive states such as, for example, when the machine was in one or more operational states and with adequate supplies to produce parts. The ideal part production or count information may be calculated based on a comparison of the duration of productive machine states with the ideal time it takes to produce a good part in a productive machine state.
The machine event information includes information related to logged events in the machine. Events such as low or inadequate supplies, faults, operation starts and stops, and other flagged and stored events. The specific machine variable information may include the data values for specific variables that are important or of interest to the various stakeholders and that may be included in at least one of the storyboards.
A user may engage with data analytics service 102 to select one or more data sources from which to further select one or more data objects (e.g., tables, queries, views, etc.). For example, data analytics service 102 may obtain operational data comprising the selected one or more data objects or other information from machine(s) 106, 126 by connecting with or linking to gateway(s) 110, 120. Operational data from machine(s) 106, 126 may be transmitted to the data analytics service 102 via gateway(s) 110, 120. To accomplish this, gateway(s) 110, 120 include the protocols needed to communicate with controller(s) 108, 128 and data analytics service 102 including security protocols, handshaking protocols, and the like. In some embodiments, data analytics service 102 may comprise the protocols needed to communicate with gateway(s) 110, 120. Note that though
Data analytics service 102 may also obtain operational data and/or other information (i.e., gathered data) from database 130. Database 130 may comprise a disk, tape, integrated circuit, server, or some other memory device. Database 130 may reside in a single device or may be distributed among multiple memory devices. Database 130 comprises data 134, which may include structured data (e.g., tabular data, data that is in rows and columns, data that is well defined, etc.), unstructured data (e.g., raw data sets, text, pictures, videos, audio, directories, etc.), and semi-structured data (e.g., document-oriented databases, etc.). Database 130 may be connected to data analytics service 102 via a local network or a remote network.
In another embodiment, data analytics service 102 may obtain gathered data from document 132. Document 132 may comprise one or more of the following: a word processing document, a PDF, a spreadsheet workbook, a presentation document, a digital notebook, a diagram file, an image, a video, an audio file, or some other file type. Document 132 comprises data 136, which may include structured data or unstructured data. Document 132 may be connected to data analytics service 102 via a local network or a remote network.
Computing system 114 comprises user interface 116 and application 118. Computing system 114 is representative of any computing apparatus, system, or systems on which application 118 or variations thereof may be suitably implemented. Application 118 runs locally with respect to a user and is implemented by computing system 114, of which computing system 1002 of
Computing system 114 provides an example of a computing system that could be used as either a server or a client device in some implementations, although such devices could have alternative configurations. Examples of computing system 114 include mobile computing devices, such as cell phones, tablet computers, laptop computers, notebook computers, and gaming devices, as well as any other type of mobile computing devices and any combination or variation thereof. Examples of computing system 114 also include desktop computers, server computers, and virtual machines, as well as any other type of computing system, variation, or combination thereof. In some implementations, computing system 114 could comprise a mobile device capable of operating in a server-like fashion which, among other uses, could be utilized in a wireless mesh network. Computing system 114 may reside in a single device or may be distributed across multiple devices.
To begin, application 118 sends a request to data analytics service 102 to connect to controller(s) 108. In response to receiving the request, data analytics service 102 connects to controller(s) 108. Subsequent to forming a connection with controller(s) 108, data analytics service 102 interrogates controller(s) 108 for data gathered by machine(s) 106. The gathered data may comprise operational data, time series data, transactional data, or any other information stored by machine(s) 106.
Subsequent to receiving the request, controller(s) 108 sends a sample data set to data analytics service 102. Data analytics service 102 analyzes the sample data set to determine which categories of data are available and generates an inventory of available categories of data. Data analytics service 102 transmits the inventory of available categories of data to application 118.
Application 118 displays the inventory of available categories in a user interface (e.g., user interface 116). Application 118 receives a selection to tailor the inventory of categories and sends to data analytics service 102 a request to tailor the inventory of available categories in accordance with the received selection. For example, application 118 may generate the request to tailor the inventory based on the received selection to tailor the inventory. The request to tailor the inventory may comprise a request to filter the inventory (e.g., exclude data corresponding to selected categories, include only data corresponding to selected categories, etc.) and/or to annotate the inventory (e.g., add a field not present in the original data set).
In an embodiment and in response to receiving a request to filter the inventory, data analytics service 102 transmits a request to controller(s) 108 for data from machine(s) 106 that comports with the inclusion or exclusion of data as defined in the request to tailor the inventory. Controller(s) 108 responds to the request by providing the filtered data set to data analytics service 102. Subsequent to receiving the filtered data set, data analytics service 102 loads the filtered data set.
In another embodiment and in response to receiving a request to filter the inventory, data analytics service 102 loads data from the sample data in accordance with the request to tailor the inventory (e.g., by including or excluding data from the sample data set).
The request to tailor the inventory may comprise a request to annotate the data set. In response to receiving a request to annotate the data set, data analytics service 102 may generate a new field in accordance with the request to annotate and incorporate the new field into the received data set.
Data analytics service 102 then generates a preview of the tailored data set (i.e., the filtered and/or annotated data set) and sends the preview to application 118, which displays the preview in a user interface. Application 118 may receive an indication that the tailored inventory is accepted, and in response, may generate and send a notification of the acceptance to data analytics service 102.
Data analytics service 102 saves the loaded data corresponding to the tailored inventory subsequent to receiving the notification of acceptance. Data analytics service 102 analyzes the saved data to discover and record relationships, both explicit and inferred, between the saved data points (i.e., determines a context for the data points). A search index may be employed by data analytics service 102 to facilitate the contextual analysis (e.g., data analytics service 102 loads data points into the search index). Data analytics service 102 then generates a storyboard comprising the contextual analysis and transmits the storyboard to application 118.
Next, application 118 sends a request to data analytics service 102 to connect to controller(s) 128. In response to receiving the request, data analytics service 102 connects to controller(s) 128. Subsequent to forming a connection with controller(s) 128, data analytics service 102 interrogates controller(s) 128 for data gathered by machine(s) 126. The gathered data may comprise operational data, time series data, transaction al data, or any other information stored by machine(s) 126.
Subsequent to receiving the request, controller(s) 128 sends a sample data set to data analytics service 102. Data analytics service 102 analyzes the sample data set to determine which categories of data are available and generates an inventory of available categories of data. Data analytics service 102 transmits the inventory of available categories of data to application 118.
Application 118 displays the inventory of available categories in a user interface (e.g., user interface 116). Application 118 receives a selection to tailor the inventory of categories and sends to data analytics service 102 a request to tailor the inventory of available categories in accordance with the received selection. For example, application 118 may generate the request to tailor the inventory based on the received selection to tailor the inventory. The request to tailor the inventory may comprise a request to filter the inventory (e.g., exclude data corresponding to selected categories, include only data corresponding to selected categories, etc.) and/or to annotate the inventory (e.g., add a field not present in the original data set).
In an embodiment and in response to receiving a request to filter the inventory, data analytics service 102 transmits a request to controller(s) 128 for data from machine(s) 126 that comports with the inclusion or exclusion of data as defined in the request to tailor the inventory. Controller(s) 128 responds to the request by providing the filtered data set to data analytics service 102. Subsequent to receiving the filtered data set, data analytics service 102 loads the filtered data set.
In another embodiment and in response to receiving a request to filter the inventory, data analytics service 102 loads data from the sample data in accordance with the request to tailor the inventory (e.g., by including or excluding data from the sample data set).
The request to tailor the inventory may comprise a request to annotate the data set. In response to receiving a request to annotate the data set, data analytics service 102 may generate a new field in accordance with the request to annotate and incorporate the new field into the received data set.
Data analytics service 102 then generates a preview of the tailored data set (i.e., the filtered and/or annotated data set) and sends the preview to application 118, which displays the preview in a user interface. Application 118 may receive an indication that the tailored inventory is accepted, and in response, may generate and send a notification of the acceptance to data analytics service 102.
Data analytics service 102 saves the loaded data corresponding to the tailored inventory subsequent to receiving the notification of acceptance. Data analytics service 102 analyzes the saved data to discover and record relationships, both explicit and inferred, between the saved data points (i.e., determines a context for the data points). A search index may be employed by data analytics service 102 to facilitate the contextual analysis (e.g., data analytics service 102 loads data points into the search index). Data analytics service 102 then generates a storyboard comprising the contextual analysis and transmits the storyboard to application 118.
Next, application 118 sends a request to data analytics service 102 to connect to database 130. In response to receiving the request, data analytics service 102 connects to database 130. Subsequent to forming a connection with database 130, data analytics service 102 interrogates database 130 for data gathered by database 130. The gathered data may comprise operational data for an industrial automation operation, time series data, transactional data, or any other information stored by database 130.
Subsequent to receiving the request, database 130 sends a sample data set to data analytics service 102. Data analytics service 102 analyzes the sample data set to determine which categories of data are available and generates an inventory of available categories of data. Data analytics service 102 transmits the inventory of available categories of data to application 118.
Application 118 displays the inventory of available categories in a user interface (e.g., user interface 116). Application 118 receives a selection to tailor the inventory of categories and sends to data analytics service 102 a request to tailor the inventory of available categories in accordance with the received selection. For example, application 118 may generate the request to tailor the inventory based on the received selection to tailor the inventory. The request to tailor the inventory may comprise a request to filter the inventory (e.g., exclude data corresponding to selected categories, include only data corresponding to selected categories, etc.) and/or to annotate the inventory (e.g., add a field not present in the original data set).
In an embodiment and in response to receiving a request to filter the inventory, data analytics service 102 transmits a request to database 130 for data that comports with the inclusion or exclusion of data as defined in the request to tailor the inventory. Database 130 responds to the request by providing the filtered data set to data analytics service 102. Subsequent to receiving the filtered data set, data analytics service 102 loads the filtered data set.
In another embodiment and in response to receiving a request to filter the inventory, data analytics service 102 loads data from the sample data in accordance with the request to tailor the inventory (e.g., by including or excluding data from the sample data set).
The request to tailor the inventory may comprise a request to annotate the data set. In response to receiving a request to annotate the data set, data analytics service 102 may generate a new field in accordance with the request to annotate and incorporate the new field into the received data set.
Data analytics service 102 then generates a preview of the tailored data set (i.e., the filtered and/or annotated data set) and sends the preview to application 118, which displays the preview in a user interface. Application 118 may receive an indication that the tailored inventory is accepted, and in response, may generate and send a notification of the acceptance to data analytics service 102.
Data analytics service 102 saves the loaded data corresponding to the tailored inventory subsequent to receiving the notification of acceptance. Data analytics service 102 analyzes the saved data to discover and record relationships, both explicit and inferred, between the saved data points (i.e., determines a context for the data points). A search index may be employed by data analytics service 102 to facilitate the contextual analysis (e.g., data analytics service 102 loads data points into the search index). Data analytics service 102 then generates a storyboard comprising the contextual analysis and transmits the storyboard to application 118.
Finally, application 118 sends a request to data analytics service 102 to connect to document 132. In response to receiving the request, data analytics service 102 connects to document 132. Subsequent to forming a connection with document 132, data analytics service 102 interrogates document 132 for data gathered by document 132. The gathered data may comprise operational data for an industrial automation operation, time series data, transactional data, or any other information stored by document 132.
Subsequent to receiving the request, document 132 sends a sample data set to data analytics service 102. Data analytics service 102 analyzes the sample data set to determine which categories of data are available and generates an inventory of available categories of data. Data analytics service 102 transmits the inventory of available categories of data to application 118.
Application 118 displays the inventory of available categories in a user interface (e.g., user interface 116). Application 118 receives a selection to tailor the inventory of categories and sends to data analytics service 102 a request to tailor the inventory of available categories in accordance with the received selection. For example, application 118 may generate the request to tailor the inventory based on the received selection to tailor the inventory. The request to tailor the inventory may comprise a request to filter the inventory (e.g., exclude data corresponding to selected categories, include only data corresponding to selected categories, etc.) and/or to annotate the inventory (e.g., add a field not present in the original data set).
In an embodiment and in response to receiving a request to filter the inventory, data analytics service 102 transmits a request to document 132 for data that comports with the inclusion or exclusion of data as defined in the request to tailor the inventory. Document 132 responds to the request by providing the filtered data set to data analytics service 102. Subsequent to receiving the filtered data set, data analytics service 102 loads the filtered data set.
In another embodiment and in response to receiving a request to filter the inventory, data analytics service 102 loads data from the sample data in accordance with the request to tailor the inventory (e.g., by including or excluding data from the sample data set).
The request to tailor the inventory may comprise a request to annotate the data set. In response to receiving a request to annotate the data set, data analytics service 102 may generate a new field in accordance with the request to annotate and incorporate the new field into the received data set.
Data analytics service 102 then generates a preview of the tailored data set (i.e., the filtered and/or annotated data set) and sends the preview to application 118, which displays the preview in a user interface. Application 118 may receive an indication that the tailored inventory is accepted, and in response, may generate and send a notification of the acceptance to data analytics service 102.
Data analytics service 102 saves the loaded data corresponding to the tailored inventory subsequent to receiving the notification of acceptance. Data analytics service 102 analyzes the saved data to discover and record relationships, both explicit and inferred, between the saved data points (i.e., determines a context for the data points). A search index may be employed by data analytics service 102 to facilitate the contextual analysis (e.g., data analytics service 102 loads data points into the search index). Data analytics service 102 then generates a storyboard comprising the contextual analysis and transmits the storyboard to application 118.
Referring to
Subsequent to obtaining an inventory of available categories of data, the computing system displays the inventory of available categories at step 205. The inventory of available categories may be displayed in user interface 116. One or more options to tailor the inventory of available categories (e.g., an option to filter, an option to annotate, etc.) may also be displayed in the user interface. A selection of the one or more options to tailor the inventory may cause a filter dialogue box to be displayed, the filter dialogue box comprising additional options to include or exclude one or more of the available categories. A selection of the one or more options to tailor the inventory may also cause an annotation dialogue box to be displayed, the annotation dialogue box comprising additional options to create a new field and apply the new field to the inventory of categories.
The computing system receives a selection to tailor the inventory of categories at step 207. Subsequent to receiving the selection, the computing system may generate and send a notification of the selection to a data analytics service. Also, subsequent to receiving the selection, the computing system may obtain a tailored inventory of categories (step 209). To obtain the tailored inventory of categories, the computing system may receive the tailored inventory from the data analytics service or other source. Additionally, to obtain the tailored inventory of categories, the computing system may generate the tailored inventory.
The computing system may display a preview of the tailored inventory of categories along with data points that correspond with their respective categories (step 211). Via a user interface, the computing system may receive user input indicating an acceptance of the tailored inventory (step 213). Subsequent to receiving the user input accepting the tailored inventory, the computing system may generate and send a notification of the user acceptance of the tailored inventory to a data analytics service. Subsequent to receiving the user input accepting the tailored inventory, the computing system may obtain a storyboard comprising one or more reports that detail an analysis of the data correlating with the tailored inventory of categories. The computing system may display the storyboard in a user interface (step 215).
Subsequent to linking to the data source, the data analytics service interrogates the data source (step 202). By way of example, a data source may be interrogated when it receives a request for all, or part of the data contained therein. For example, a machine may be interrogated when an industrial controller receives a request from a data analytics service for operational data pertaining to the machine. In another example, a gateway device, in response to a request from the service, receives the requested data from another point of data streaming in an industrial automation environment such as a database storage system, application integration platform, or the like. In an exemplary implementation, the data analytics service may interrogate a database by querying the database directly and obtaining the requested information therefrom. In another exemplary implementation, the data analytics service may query a document directly and obtain the requested information therefrom. In some embodiments, the service may request only a portion of an available data set.
In response to obtaining the requested data from one or more data sources, the service may determine a data structure for the requested data. The data structure comprises details for data points gathered in each of the categories of information available in the data set. For example, data analytics service may determine which categories are available by reviewing one or more data structures and/or by evaluating one or more data types for the gathered data. The service may also determine a format and/or configuration of the requested information. The data analytics service may then generate an inventory of available categories based on the determined data structure and initiate presentation of an inventory of available categories (step 206).
As noted above, the service may not require a complete data set to perform its analysis. For example, in one embodiment the data analytics service receives a portion (e.g., less than the whole) of an available data set for an industrial controller. From said portion, the service determines which categories of information are available by examining the data structure of the gathered data comprised in said portion. The data analytics service may present the data structures, data types, formats, configurations, and various other categories of information to a user (e.g., a stakeholder, an application, etc.) prior to loading and/or saving the set of gathered data.
In an exemplary implementation, the service presents a user with one or more options to filter a complete gathered data set prior to loading and/or saving all of the data points included in the gathered data set. The user may engage with the service to indicate which categories of data should be included in or excluded from a tailored inventory. In response to receiving from the user an indication that the data set should be filtered (step 208), the service may proceed to retrieve only the data that corresponds to the desired categories of information and refrains from obtaining the undesired categories of information (step 210).
In another exemplary embodiment, the service may present the user with one or more options to annotate the data set prior to loading and/or saving all of the data included in the data set. Annotation features may allow users to add computing derived fields to storyboards and reports using a built-in expression language and a set of pre-defined functions before creating a new, or updating an existing, storyboard. An annotation feature may, by way of example, provide a means for a user to create a custom field in which to present the operational data. The data may be annotated according to the user defined request before or after applying any filters received in step 208 (step 212). Data annotation is enabled for all data source connectors.
Subsequent to obtaining the filtered data set and/or applying any user defined annotations, the data analytics service may store the tailored data locally or remotely (step 214). Enabling a data set to be filtered prior to loading or saving the entirety of the data set has the technical effect of reducing the quantity of information stored on computer resources and increases computational efficiencies by, for example, reducing the time it takes to perform computational analysis which in turn reduces overall energy requirements because, in part, the system has less data to orchestrate. Existing solutions fail to provide these benefits in part because they require an entire data set to be loaded and/or saved prior to commencing analysis of the data set.
In an embodiment, a data analytics service identifies one or more relationships and/or one or more contexts in the tailored data set. The service may perform additional analytic methodologies to the tailored data set (step 216). The service may further orchestrate and organize the tailored data set to present the analyzed data in a visual storyboard (e.g., dashboard) that comprises multiple reports (Step 218). Each report may provide a visualization for one or more aspects of an industrial operation.
Turning to
In this embodiment, table name 302 comprises the name of the data source from which the operational data or other information is obtained (e.g., FTA_SYSTEM_INFO). Column name 304 comprises the name of the column in the data source from which the data was retrieved (e.g., bom_id). Column display name 306 comprises the label that may be applied to a column of data when the data is presented in a preview or an axis label when the data is presented in a report (e.g., bom_id), and data type 308 indicates the data type for the displayed information (e.g., string).
User interface 300 may provide options to edit labels for some or all of the information presented in table 301. In this embodiment, the labels presented under table name 302 and column name 304 are not editable via user interface 300. A user may, however, employ user interface 300 to edit the labels and/or information displayed in column display name 306 and data type 308. For example, in the present embodiment, each label under column display name 306 initially matched the labels for their respective column names. It can be inferred that subsequent to initiating display of table 301, a user engaged user interface 300 to edit the column display name labels that correspond to column names “component_item1,” “component_item2,” and “component_item3.” As a result, when the user previews the available data, the column display name for the edited labels recites “component_1,” “component_2,” and “component_3,” respectively. A user may similarly edit the data type labels listed under data type 308 to reflect a different type of data.
A user may also engage with user interface 300 to add rules to a data set. For example, a user may apply a visibility rule to indicate which data should be visible in a report or preview. In this exemplary implementation, the user engages with one or more radial options available under visible rule 310 to indicate which data to display in a preview or report. Specifically, the user may indicate, by selecting a radial option or leaving the radial option selected, that all or portions of the available data pertaining to a specific column name should be made visible. In the present embodiment, all of the data available for every column name should be made visible (i.e., the radial buttons corresponding to the column names have been selected) except for the data that corresponds to column name “record_date.” The data corresponding to column name “record_date” should not be displayed in a preview or a report because its corresponding radial button is not selected. Visibility rules may be changed by selecting and deselecting the radial options presented under visible rule 310.
A user may also set a rule to indicate which portion of the data set should be set as a default. For example, a user may engage with one or more radial options available under unique_id rule 312 to select which data to appoint as a default. In this exemplary implementation, only data corresponding to column name “component_item1” should be set as the default because it is the only portion of the data set that has a selected radial option under unique_id rule 312. Default appointments may be changed by selecting and deselecting the radial options available under unique_id rule 312.
User interface 300 also comprises filter option 314. When a user selects filter option 314, the data analytics service may present a dialogue box, or other user interface object, in which to receive an indication that the data set should be filtered and how the data set is to be filtered. In the present embodiment, when a user selects filter option 314, the user interface may present “component_item1” as the default category to which to apply the generated filter because component_item1 has its corresponding radial option selected under unique_id rule 312. Filter option 314 is discussed in more detail with regard to
User interface 300 also comprises annotation option 316. When a user selects annotation option 316, the data analytics service may present a dialogue box, or other user interface object, in which to receive an indication that the data set should be annotated and how the data set is to be annotated. Annotation option 316 is discussed in more detail with regard to
In table 402, labels for column display name 306 that have a corresponding radial option selected under visible rule 310 are displayed. For example, in
Data row 406 comprises data points that correlate with the data points available for each of the respective categories listed in column display name row 404. In the present embodiment, there are six data points presented under each category listed in column display name row 404. The data points may be unique to every other data point in a respective category (e.g., the data presented for bom_id is unique to each data point in bom_id), or the data points may contain the same value as one or more other data points in the category (e.g., “component_item1” comprises three data points with a value of “1,” two data points with a value of “2,” and one data point with a value of “3”).
The information presented in data row 406 has a specific data type that correlates to the data type label presented under data type 308 of
Table 402 is illustrative of a data analytics service applying only rules to an obtained data set (e.g., visibility rule 310). No filters or annotations are applied to the data presented in table 402. Therefore, in the present embodiment, all of the data points retrieved for the categories of user interface 300 having a corresponding radial option selected under visible rule 310 are displayed in table 402.
Dialogue box 500 comprises option 502, filter generator 504, and filter list 512. Option 502 may be selected to create a new filter. Filters may be applied to a data set to include or exclude information in accordance with the respective filter. Filters may limit what data is stored by a data analytics service, which may further limit the data that is ultimately loaded into a storyboard. The filter may stipulate that selected data categories should be included or excluded from a filter inventory.
Filter generator 504 comprises field values 506, 508, and 510. Field value 506 comprises at least one category derived from the data set, field value 508 comprises at least one equation operator, and field value 510 comprises at least one available data value for the gathered data that correlates to field value 506. Field values 506, 508, and 510 may comprise a dropdown menu, or any other graphical control element, that presents available input values for the respective field. For example, field value 506 may comprise a dropdown menu (or other graphical control element) with all or some of the available column names, field value 508 may comprise a dropdown menu (or other graphical control element) with all or some of the available operators, and field value 510 may comprise a dropdown menu (or other graphical control element) with all or some of the data values existing for a particular column name. Example operators include, but are not limited to, an “equal” to operator, a “greater than” operator, a “less than” operator, or any combination thereof. In the present embodiment, a user has entered into field value 506 the column name “component_item1,” into field value 508 the operator “Equal” to, and into field value 510 the data point having a value of “1.”
Filter list 512 comprises a list of all filters currently applied to the obtained data set. It can be inferred that upon presenting dialogue box 500 in the user interface, filter list 512 was empty because no filters had yet been added to the data set. Subsequent to adding the filter generated in filter generator 504, the data analytics service updates filter list 512 to include filter 514. Dialogue box 500 may comprise options to edit and/or delete the filters that are listed in filter list 512.
In the present embodiment, table 602 illustrates the application of rules and filters to a previewed data set. Specifically, in addition to visible rule 310 of
The information presented in data 606 has a specific data type that correlates to data type 308 of
Referring back to
Referring to
A user may also be prompted to supply a formula describing how the data should be annotated for the custom field. The data analysis service may provide display table 708 to offer suggested formulas to input into formula editor 704. For example, in the present embodiment, the user indicated that the custom field will have a string data type by entering “string” into formula hint 706. In response, display table 708 provides a list of suggested formulas for fields having a “string” data type. Though a string data type is used in the present example, any data type may be entered into formula hint 706.
In this embodiment, one filter and one annotation have been applied to the gathered data set. Filter option 814 may indicate the number of filters currently applied to the data set. In the present example, filter option 814 displays a “1” to indicate that one filter is applied to the data set.
The one annotation added to table 801 was generated using dialogue box 700 of
No table name is provided for the custom field “bom_desc_uppercase” under table name 802 in part because the custom field was not retrieved from a gathered data set.
In the present embodiment, table 902 illustrates the application of rules, filters, and data annotation to a previewed data set. Specifically, in addition to visible rule 310 of
Computing system 1002 may be implemented as a single apparatus, system, or device or may be implemented in a distributed manner as multiple apparatuses, systems, or devices. Computing system 1002 includes, but is not limited to, processing system 1012, storage system 1004, software 1006, communication interface system 1010, and user interface system 1014. User interface system 1014 is optional in some implementations. Processing system 1012 is operatively coupled with storage system 1004, communication interface system 1010, and user interface system 1014.
Processing system 1012 loads and executes software 1006 from storage system 1004. Software 1006 includes and implements storyboard process 1008, which is representative of the storyboard processes discussed with respect to the preceding Figures. Software 1006 directs processing system 1012 to operate as described herein for at least the various processes, operational scenarios, and sequences discussed in the foregoing implementations. Computing system 1002 may optionally include additional devices, features, or functionality not discussed for purposes of brevity.
Referring still to
Storage system 1004 may comprise any computer readable storage media readable by processing system 1012 and capable of storing software 1006. Storage system 1004 may include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, program modules, or other data. Examples of storage media include random access memory, read only memory, magnetic disks, optical disks, flash memory, virtual memory and non-virtual memory, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other suitable storage media. In no case is the computer readable storage media a propagated signal.
In addition to computer readable storage media, in some implementations storage system 1004 may also include computer readable communication media over which at least some of software 1006 may be communicated internally or externally. Storage system 1004 may be implemented as a single storage device but may also be implemented across multiple storage devices or sub-systems co-located or distributed relative to each other. Storage system 1004 may comprise additional elements, such as a controller, capable of communicating with Processing system 1012 or possibly other systems.
Software 1006 (including storyboard process 1008) may be implemented in program instructions and among other functions may, when executed by processing system 1012, direct processing system 1012 to operate as described with respect to the various operational scenarios, sequences, and processes illustrated herein. For example, software 1006 may include program instructions for implementing a formula process as described herein.
In particular, the program instructions may include various components or modules that cooperate or otherwise interact to carry out the various processes and operational scenarios described herein. The various components or modules may be embodied in compiled or interpreted instructions, or in some other variation or combination of instructions. The various components or modules may be executed in a synchronous or asynchronous manner, serially or in parallel, in a single threaded environment or multi-threaded, or in accordance with any other suitable execution paradigm, variation, or combination thereof. Software 1006 may include additional processes, programs, or components, such as operating system software, virtualization software, or other application software. Software 1006 may also comprise firmware or some other form of machine-readable processing instructions executable by processing system 1012.
In general, software 1006 may, when loaded into processing system 1012 and executed, transform a suitable apparatus, system, or device (of which computing system 1002 is representative) overall from a general-purpose computing system into a special-purpose computing system customized to provide enhanced formula interactions. Indeed, encoding software 1006 on storage system 1004 may transform the physical structure of storage system 1004. The specific transformation of the physical structure may depend on various factors in different implementations of this description. Examples of such factors may include, but are not limited to, the technology used to implement the storage media of storage system 1004 and whether the computer-storage media are characterized as primary or secondary storage, as well as other factors.
For example, if the computer readable storage media are implemented as semiconductor-based memory, software 1006 may transform the physical state of the semiconductor memory when the program instructions are encoded therein, such as by transforming the state of transistors, capacitors, or other discrete circuit elements constituting the semiconductor memory. A similar transformation may occur with respect to magnetic or optical media. Other transformations of physical media are possible without departing from the scope of the present description, with the foregoing examples provided only to facilitate the present discussion.
Communication interface system 1010 may include communication connections and devices that allow for communication with other computing systems (not shown) over communication networks (not shown). Examples of connections and devices that together allow for inter-system communication may include network interface cards, antennas, power amplifiers, RF circuitry, transceivers, and other communication circuitry. The connections and devices may communicate over communication media to exchange communications with other computing systems or networks of systems, such as metal, glass, air, or any other suitable communication media. The aforementioned media, connections, and devices are well known and need not be discussed at length here.
Communication between computing system 1002 and other computing systems (not shown), may occur over a communication network or networks and in accordance with various communication protocols, combinations of protocols, or variations thereof. Examples include intranets, internets, the Internet, local area networks, wide area networks, wireless networks, wired networks, virtual networks, software defined networks, data center buses and backplanes, or any other type of network, combination of network, or variation thereof. The aforementioned communication networks and protocols are well known and need not be discussed at length here.
The functional block diagrams, operational sequences, and flow diagrams provided in the figures are representative of exemplary architectures, environments, and methodologies for performing novel aspects of the disclosure. While, for purposes of simplicity of explanation, the methodologies included herein may be in the form of a functional diagram, operational sequence, or flow diagram, and may be described as a series of acts, it is to be understood and appreciated that the methodologies are not limited by the order of acts, as some acts may, in accordance therewith, occur in a different order and/or concurrently with other acts from that shown and described herein. For example, those skilled in the art will understand and appreciate that a methodology could alternatively be represented as a series of interrelated states or events, such as in a state diagram. Moreover, not all acts illustrated in a methodology may be required for a novel implementation.
Also, it is to be understood that the phraseology and terminology used herein is for the purpose of description and should not be regarded as limiting. The use of “including,” “comprising” or “having” and variations thereof herein is meant to encompass the items listed thereafter and equivalents thereof as well as additional items. The terms “connected” and “coupled” are used broadly and encompass both direct and indirect mounting, connecting, and coupling. Further, “connected” and “coupled” are not restricted to physical or mechanical connections or couplings, and may include electrical connections or couplings, whether direct or indirect. Also, electronic communications and notifications may be performed using any known means including direct or indirect wired connections, wireless connections, and combinations thereof. Also, functionality described as being performed by one device may be distributed among a plurality of devices.
It should also be noted that a plurality of hardware and software based devices, as well as a plurality of different structural components may be used to implement the embodiments set forth herein. In addition, it should be understood that embodiments may include hardware, software, and electronic components that, for purposes of discussion, may be illustrated and described as if the majority of the components were implemented solely in hardware. However, one of ordinary skill in the art, and based on a reading of this detailed description, would recognize that, in at least one embodiment, the electronic-based aspects of the embodiments may be implemented in software (e.g., stored on non-transitory computer-readable medium) executable by one or more electronic processors.
The included description and associated figures teach the best mode of the invention. For the purpose of teaching inventive principles, some conventional aspects of the best mode may be simplified or omitted. The following claims specify the scope of the invention. Note that some aspects of the best mode may not fall within the scope of the invention as specified by the claims. Thus, those skilled in the art will appreciate variations from the best mode that fall within the scope of the invention. Those skilled in the art will appreciate that the features described below can be combined in various ways to form multiple variations of the invention. As a result, the invention is not limited to the specific examples described below, but only by the claims and their equivalents.