Industrial equipment or assets, generally, are engineered to perform particular tasks as part of a business process. For example, industrial assets can include, among other things and without limitation, manufacturing equipment on a production line, wind turbines that generate electricity on a wind farm, healthcare or imaging devices (e.g., X-ray or MRI systems) for use in patient care facilities, or drilling equipment for use in mining operations. The design and implementation of these assets often takes into account both the physics of the task at hand, as well as the environment in which such assets are configured to operate.
Low-level software and hardware-based controllers have long been used to drive industrial assets. However, the rise of inexpensive cloud computing, increasing sensor capabilities, and decreasing sensor costs, as well as the proliferation of mobile technologies have created opportunities for creating novel industrial assets with improved sensing technology that are capable of transmitting data that can then be transmitted to a network. As a consequence, there are new opportunities to enhance the business value of some industrial assets using novel industrial-focused hardware and software.
One important aspect of the use of data generated by industrial assets and other types of devices is that the data may be distributed to mobile devices (e.g., smartphones, tablet computers) carried by individuals who are “on the go” but need or wish to be kept up to date on the data produced or stored in a network. Previous proposals for distributing data from central data repositories have often assumed that devices intended to receive the data from a central source are connected to the central source by reliable and substantially uninterrupted communication channels. The application programs in the recipient devices and the central data source that engage in data communication, transmission and reception may be designed to operate on the assumption of substantially continuous data communication connectivity between source and recipient devices. However, that assumption may not hold if mobile devices are to be the recipients of the data. Accordingly, it has been proposed to convert existing web and mobile applications so as to function effectively in environments where connectivity between the source and recipient devices may be subject to frequent interruption. Web and mobile applications for such purposes have previously been converted to function off-line (i.e., with interruptible connectivity) by manually coding suitable adapter programs or “splices”. The manual coding employed in these instances is time-consuming and expensive.
While progress with industrial equipment automation has been made over the last several decades, and assets have become ‘smarter,’ the intelligence of any individual asset pales in comparison to intelligence that can be gained when multiple smart devices are connected together. Aggregating data collected from or about multiple assets can enable users to improve business processes, for example by improving effectiveness of asset maintenance or improving operational performance if appropriate industrial-specific data collection and modeling technology is developed and applied.
In an example, an industrial asset can be outfitted with one or more sensors configured to monitor respective ones of an asset's operations or conditions. Data from the one or more sensors can be recorded or transmitted to a cloud-based or other remote computing environment. By bringing such data into a cloud-based computing environment, new software applications informed by industrial process, tools and know-how can be constructed, and new physics-based analytics specific to an industrial environment can be created. Insights gained through analysis of such data can lead to enhanced asset designs, or to enhanced software algorithms for operating the same or similar asset at its edge, that is, at the extremes of its expected or available operating conditions.
The systems and methods for managing industrial assets can include or can be a portion of an Industrial Internet of Things (IIoT). In an example, an IIoT connects industrial assets, such as turbines, jet engines, and locomotives, to the Internet or cloud, or to each other in some meaningful way. The systems and methods described herein can include using a “cloud” or remote or distributed computing resource or service. The cloud can be used to receive, relay, transmit, store, analyze, or otherwise process information for or about one or more industrial assets. In an example, a cloud computing system includes at least one processor circuit, at least one database, and a plurality of users or assets that are in data communication with the cloud computing system. The cloud computing system can further include or can be coupled with one or more other processor circuits or modules configured to perform a specific task, such as to perform tasks related to asset maintenance, analytics, data storage, data exchange, security, or some other function.
However, the integration of industrial assets with the remote computing resources to enable the IIoT often presents technical challenges separate and distinct from the specific industry and from computer networks, generally. A given industrial asset may need to be configured with novel interfaces and communication protocols to send and receive data to and from distributed computing resources. Given industrial assets may have strict requirements for cost, weight, security, performance, signal interference, and the like such that enabling such an interface is rarely as simple as combining the industrial asset with a general purpose computing device.
To address these problems and other problems resulting from the intersection of certain industrial fields and the IIoT, embodiments may enable improved interfaces, techniques, protocols, and algorithms for facilitating communication with and configuration of industrial assets via remote computing platforms and frameworks. Improvements in this regard may relate to both improvements that address particular challenges related to particular industrial assets (e.g., improved aircraft engines, wind turbines, locomotives, medical imaging equipment) that address particular problems related to use of these industrial assets with these remote computing platforms and frameworks, and also improvements that address challenges related to operation of the platform itself to provide improved mechanisms for configuration, analytics, and remote management of industrial assets as well as distribution of resulting data to individuals who work with or need data generated by industrial assets.
The Predix™ platform available from GE is a novel embodiment of such Asset Management Platform (AMP) technology enabled by state of the art cutting edge tools and cloud computing techniques that enable incorporation of a manufacturer's asset knowledge with a set of development tools and best practices that enables asset users to bridge gaps between software and operations to enhance capabilities, foster innovation, and ultimately provide economic value. Through the use of such a system, a manufacturer of industrial assets can be uniquely situated to leverage its understanding of industrial assets themselves, models of such assets, and industrial operations or applications of such assets, to create new value for industrial customers through asset insights.
The first AMP 100 includes a first asset community 102 that is communicatively coupled with the asset cloud computing system 120. In an example, a machine module 110 receives information from, or senses information about, at least one asset member of the first asset community 102, and configures the received information for exchange with the asset cloud computing system 120. In an example, the machine module 110 is coupled to the asset cloud computing system 120 or to an enterprise computing system 130 via a communication gateway 105.
In an example, the communication gateway 105 includes or uses a wired or wireless communication channel that extends at least from the machine module 110 to the asset cloud computing system 120. The asset cloud computing system 120 includes several layers. In an example, the asset cloud computing system 120 includes at least a data infrastructure layer, a cloud foundry layer, and modules for providing various functions. In the example of
An interface device 140 can be configured for data communication with one or more of the machine module 110, the gateway 105, or the asset cloud computing system 120. The interface device 140 can be used to monitor or control one or more assets. In an example, information about the first asset community 102 is presented to an operator at the interface device 140. The information about the first asset community 102 can include information from the machine module 110, or the information can include information from the asset cloud computing system 120. In an example, the information from the asset cloud computing system 120 includes information about the first asset community 102 in the context of multiple other similar or dissimilar assets, and the interface device 140 can include options for optimizing one or more members of the first asset community 102 based on analytics performed at the asset cloud computing system 120.
In an example, an operator selects a parameter update for the first wind turbine 101 using the interface device 140, and the parameter update is pushed to the first wind turbine via one or more of the asset cloud computing system 120, the gateway 105, and the machine module 110. In an example, the interface device 140 is in data communication with the enterprise computing system 130 and the interface device 140 provides an operation with enterprise-wide data about the first asset community 102 in the context of other business or process data. For example, choices with respect to asset optimization can be presented to an operator in the context of available or forecasted raw material supplies or fuel costs. In an example, choices with respect to asset optimization can be presented to an operator in the context of a process flow to identify how efficiency gains or losses at one asset can impact other assets. In an example, one or more choices described herein as being presented to a user or operator can alternatively be made automatically by a processor circuit according to earlier-specified or programmed operational parameters. In an example, the processor circuit can be located at one or more of the interface device 140, the asset cloud computing system 120, the enterprise computing system 130, or elsewhere.
Returning again to the example of
In an example, the multiple turbine members of the asset community 102 include assets from different manufacturers or vintages. The multiple turbine members of the asset community 102 can belong to one or more different asset communities, and the asset communities can be located locally or remotely from one another. For example, the members of the asset community 102 can be colocated on a single wind farm, or the members can be geographically distributed across multiple different farms. In an example, the multiple turbine members of the asset community 102 can be in use (or non-use) under similar or dissimilar environmental conditions, or can have one or more other common or distinguishing characteristics.
In an example, information from an asset, about the asset, or sensed by an asset itself is communicated from the asset to the data acquisition module 124 in the asset cloud computing system 120. In an example, an external sensor can be used to sense information about a function of an asset, or to sense information about an environment condition at or near an asset. The external sensor can be configured for data communication with the device gateway 105 and the data acquisition module 124, and the asset cloud computing system 120 can be configured to use the sensor information in its analysis of one or more assets, such as using the analytics module 122.
In an example, the first AMP 100 can use the asset cloud computing system 120 to retrieve an operational model for the first wind turbine 101, such as using the asset module 121. The model can be stored locally in the asset cloud computing system 120, or the model can be stored at the enterprise computing system 130, or the model can be stored elsewhere. The asset cloud computing system 120 can use the analytics module 122 to apply information received about the first wind turbine 101 or its operating conditions (e.g., received via the device gateway 105) to or with the retrieved operational model. Using a result from the analytics module 122, the operational model can optionally be updated, such as for subsequent use in optimizing the first wind turbine 101 or one or more other assets, such as one or more assets in the same or different asset community. For example, information about the first wind turbine 101 can be analyzed at the asset cloud computing system 120 to inform selection of an operating parameter for a remotely located second wind turbine that belongs to a different second asset community.
The first AMP 100 includes a machine module 110. The machine module 110 includes a software layer configured for communication with one or more industrial assets and the asset cloud computing system 120. In an example, the machine module 110 can be configured to run an application locally at an asset, such as at the first wind turbine 101. The machine module 110 can be configured for use with or installed on gateways, industrial controllers, sensors, and other components. In an example, the machine module 110 includes a hardware circuit with a processor that is configured to execute software instructions to receive information about an asset, optionally process or apply the received information, and then selectively transmit the same or different information to the asset cloud computing system 120.
In an example, the asset cloud computing system 120 can include the operations module 125. The operations module 125 can include services that developers can use to build or test Industrial Internet applications, or the operations module 125 can include services to implement Industrial Internet applications, such as in coordination with one or more other AMP modules. In an example, the operations module 125 includes a microservices marketplace where developers can publish their services and/or retrieve services from third parties. The operations module 125 can include a development framework for communicating with various available services or modules. The development framework can offer developers a consistent look and feel and a contextual user experience in web or mobile applications.
In an example, an AMP can further include a connectivity module. The connectivity module can optionally be used where a direct connection to the cloud is unavailable. For example, a connectivity module can be used to enable data communication between one or more assets and the cloud using a virtual network of wired (e.g., fixed-line electrical, optical, or other) or wireless (e.g., cellular, satellite, or other) communication channels. In an example, a connectivity module forms at least a portion of the gateway 105 between the machine module 110 and the asset cloud computing system 120, and/or between the asset cloud computing system 120 and other components of the AMP 100, including for example mobile devices (as discussed below) and/or fixed-location data-receiving devices.
In an example, an AMP can be configured to aid in optimizing operations or preparing or executing predictive maintenance for industrial assets. An AMP can leverage multiple platform components to predict problem conditions and conduct preventative maintenance, thereby reducing unplanned downtimes. In an example, the machine module 110 is configured to receive or monitor data collected from one or more asset sensors and, using physics-based analytics (e.g., finite element analysis or some other technique selected in accordance with the asset being analyzed), detect error conditions based on a model of the corresponding asset. In an example, a processor circuit applies analytics or algorithms at the machine module 110 or at the asset cloud computing system 120.
In response to the detected error conditions, the AMP can issue various mitigating commands to the asset, such as via the machine module 110, for manual or automatic implementation at the asset. In an example, the AMP can provide a shut-down command to the asset in response to a detected error condition. Shutting down an asset before an error condition becomes fatal can help to mitigate potential losses or to reduce damage to the asset or its surroundings. In addition to such an edge-level application, the machine module 110 can communicate asset information to the asset cloud computing system 120.
In an example, the asset cloud computing system 120 can store or retrieve operational data for multiple similar assets. Over time, data scientists or machine learning can identify patterns and, based on the patterns, can create improved physics-based analytical models for identifying or mitigating issues at a particular asset or asset type. The improved analytics can be pushed back to all or a subset of the assets, such as via multiple respective machine modules 110, to effectively and efficiently improve performance of designated (e.g., similarly-situated) assets.
In an example, the asset cloud computing system 120 includes a Software-Defined Infrastructure (SDI) that serves as an abstraction layer above any specified hardware, such as to enable a data center to evolve over time with minimal disruption to overlying applications. The SDI enables a shared infrastructure with policy-based provisioning to facilitate dynamic automation, and enables SLA (service level agreement) mappings to underlying infrastructure. This configuration can be useful when an application requires an underlying hardware configuration. The provisioning management and pooling of resources can be done at a granular level, thus allowing optimal resource allocation.
In a further example, the asset cloud computing system 120 is based on Cloud Foundry (CF), an open source PaaS (Platform-as-a-Service) that supports multiple developer frameworks and an ecosystem of application services. Cloud Foundry can make it faster and easier for application developers to build, test, deploy, and scale applications. Developers thus gain access to the vibrant CF ecosystem and an ever-growing library of CF services. Additionally, because it is open source, CF can be customized for IIoT workloads.
The asset cloud computing system 120 can include a data services module that can facilitate application development. For example, the data services module can enable developers to bring data into the asset cloud computing system 120 and to make such data available for various applications, such as applications that execute at the cloud, at a machine module, or at an asset or other location (such as a mobile device). In an example, the data services module can be configured to cleanse, merge, or map data before ultimately storing it in an appropriate data store, for example, at the asset cloud computing system 120. A special emphasis has been placed on time series data, as it is the data format that most sensors use.
Security can be a concern for data services that deal in data exchange between the asset cloud computing system 120 and one or more assets or other components. Some options for securing data transmissions include using Virtual Private Networks (VPNs) or an SSL/TLS (secure socket layer/transport layer security) model. In an example, the first AMP 100 can support two-way TLS, such as between a machine module and the security module 124. In an example, two-way TLS may not be supported, and the security module 124 can treat client devices as OAuth users. For example, the security module 124 can allow enrollment of an asset (or other device) as an OAuth client and transparently use OAuth access tokens to send data to protected endpoints.
In some examples, application programs for data distributing devices and/or data receiving devices are automatically converted (or partially converted) to application programs suitable for off-line applications. This may facilitate applications of AMPs in which mobile devices are deployed as data recipients. An output of the application program conversion process may be a mobile application or an application for operation on a device that supplies data to mobile devices. Devices that supply data to mobile devices may generally be referred to herein and in the appended claims as “servers” or “server computers”; the term “server” or “server computer” is to be understood broadly as encompassing asset cloud computing systems, enterprise systems, remotely-located server computers, and centralized computing resources; the terms “server” and “server computer” are applicable to data-supplying devices whether or not a client/server protocol is employed and whether or not the data-supplying device is located in a single location or distributed over multiple locations.
An application program or programs that perform or facilitate automatic conversion of other application programs for use in or with mobile devices may (a) parse a code listing of a program to be converted; (b) characterize segments of the code-listing; (c) generate adapter code lines to replace some of the original code listing segments; (d) determine that other original code listing segments are to be identified/annotated instead of being replaced. Annotations of original code listing segments may indicate (i) that manual coding is needed to convert the original code listing segments; (ii) a result of the characterization of an individual original code listing segment; and/or (iii) a suggestion of a manual coding approach to be used in converting an individual original code listing segment.
Substantially automated conversion of existing recipient or transmitting device application programs to applications suitable for use with mobile devices may reduce the cost of application conversion and thereby facilitate inclusion of mobile devices in AMPs such as that shown in
As seen from
As indicated schematically at 204 in
In an example, all the data provided from the server 202 to the mobile devices 206 may be provided essentially for the purpose of providing an information feed to users (not shown) of the mobile devices. In an example, the mobile device users may be medical personnel who receive from the server 202 feeds of data generated by (or of data generated from analysis of data generated by) medical monitoring devices that sense vital signs and other indicators of the current and changing conditions of hospitalized patients. It will be understood, in connection with this example, that the medical monitoring devices (though not explicitly depicted) are to be considered among the assets of the AMP 100 as presented in
In another example, the data fed from the server 202 to the mobile devices 206 may include operational indicators of assets of the AMP so that the users of the mobile devices 206 may be prompted to perform tasks relative to the assets such as visual inspections, mechanical tests and/or adjustments, setting of local control mechanisms for the assets, emergency shut-down procedures, rebooting of local electronic controllers, etc. The types of assets referred to in the previous sentence may include wind turbines, locomotives, jet engines, large pieces of medical diagnostic equipment, factory production equipment, power generation equipment that consumes fossil fuel to generate electricity, etc.
In an example, the server 202 (e.g., assuming it to include resources of the asset cloud computing system 120) may simultaneously deliver two or more different types of the data feeds referred to above to mobile devices employed by two, three or more different organizations/enterprises. In an example, the server 202 provides respective data feeds to numerous mobile devices 206 simultaneously or virtually simultaneously. In some examples, the same data feed may be provided simultaneously to a group of mobile devices 206 carried by individuals who share a common interest in the particular data feed. Returning, for example, to the medical monitoring example, several doctors or other medical professionals responsible for treating a certain patient may all receive the same feed of medical monitoring data for that patient. That feed may be received at the users' mobile devices interspersed with other data feeds containing medical monitoring data for other patients. The members of the above-mentioned group of medical professionals may receive over-all feeds that reflect the medical monitoring of different respective groups of patients, given that different professionals may be charged with caring for different groups of patients.
It may also be the case, where the data feeds represent asset operational indicators, that there may be groups of individuals who receive duplicate feeds for assets for which they share responsibility. At the same time, as in the medical example, some members of the group may receive data feeds for other assets that only they are responsible for, and the latter feeds may not be provided to members of the group not responsible for the last-mentioned assets.
In an example, as indicated schematically at 208, at least some of the mobile devices 206 may communicate data and/or control signals to assets in one or more asset communities 102. In an example, the communication from the mobile devices 206 may be via one or more machine modules 110 (per the above discussion of
The communication channel(s) between the mobile devices 206 and the asset(s) (which communication channels are not explicitly shown in the drawing) need not be short-range communication channels. The communication channels between the mobile devices 206 and the asset(s) may include, for example, one or more mobile communication networks, as well as other communication networks such as the internet and/or one or more private networks and/or VPNs (virtual private networks).
In cases where the asset has a short-range data communication capability suitable for providing a communication channel to a nearby mobile device 206, the mobile device and the asset's short range communication capability may provide a backup channel in the event that normal communication channels between the asset and the asset cloud computing system 120 suffer an outage.
The mobile device 206 may include a housing 303. In many embodiments, the front of the housing 203 is predominantly constituted by a touchscreen (not separately shown), which is a key element of the user interface 304 of the mobile device 206.
The mobile device 206 further includes a mobile processor/control circuit 306, which is contained within the housing 303. Also included in the mobile device 206 is a storage/memory device or devices (reference numeral 308). The storage/memory devices 308 are in communication with the processor/control circuit 306 and may contain program instructions to control the processor/control circuit 306 to manage and perform various functions of the mobile device 206. In an example the program instructions may, at least in part, contain one or more mobile application programs (“apps”) that are automatically or semi-automatically generated by converting application programs originally written for non-mobile terminals (or mobile terminals operated with continuous communication connectivity) in an APM environment. Manners of generating such apps are described below. (The apps are represented at block 310 in
As is typical for mobile devices, the mobile device 206 may include mobile communications functions as represented by block 312. The mobile communications functions may include voice and data communications via a mobile communication network with which the mobile device 206 is registered or with which it has been associated. Although not expressly indicated in the drawing, it should be noted that the mobile device 206 may also include capabilities for one or more different types of short-range communication (e.g., WiFi).
From the foregoing discussion, it will be appreciated that the blocks depicted in
While the mobile device 206 may be embodied as a smartphone or tablet computer, other hardware and form factor profiles may characterize the mobile device 206. For example, the mobile device may be embodied as a mobile terminal of one of the types issued by enterprises to their traveling technicians, delivery personnel, etc. Such a mobile terminal may feature, for example, a specially configured keypad/touchpad, tailored to suit the mission of the individuals to whom the terminal is issued. In the case of a mobile terminal issued to a technician, the mobile terminal may include relevant test equipment components, etc.
The application program conversion system 400 may include, for example, an application adapter computer system 402, provided according to some embodiments. The application adapter computer system 402 may be of particular relevance to the subject matter described herein and details thereof will be described below. To briefly describe functionality that may be provided by the application adapter computer system 402, it may convert/adapt—to mobile communication environments, such as that shown in
Block 404 in
At 502, the application adapter computer system 402 receives an application program to be converted. The application program may be received by the application adapter computer system 402 in the form of a code listing for the application program.
At 504, the application adapter computer system 402 may parse a code listing it has received at 502. As will be seen, the parsing of the code listing may be segment-by-segment, and may utilize a number of different capabilities of the application adapter computer system 402 to produce or aid in producing an adapted or converted application suitable for use in or with mobile devices operating in an offline environment. Block 506 represents generation by the application adapter computer system 402 of an adapter module code listing which is complete or may be fairly readily completable as an adapted or converted offline application program.
As noted above, the parsing, processing and conversion of the received code listing by the application adapter computer system 402 may proceed via segment-by-segment through the code listing of the received application program. This segment-by-segment nature of the processing is represented at block 602 in
For each segment, and as indicated at 604, the application adapter computer system 402 detects the starting and ending points of the segment. The application adapter computer system 402 may make determinations as to the starting and ending points of the segments based on a number of factors, such as the formatting of the code listing (e.g., including line-breaks and characters/punctuation signifying segment ends) and/or via a syntactic analysis of the contents of the code listing.
At 606, the application adapter computer system 402 reads the code listing segment that it has detected at 604. The application adapter computer system 402 may have been programmed to interpret the computer programming language in which the code listing was written, and to recognize the meanings of at least some of the programming language expressions contained in the code listing. To aid in the reading of the code listing by the application adapter computer system 402, it may have been programmed with a phrase book or dictionary for the programming language expressions that may appear in the code listing. In addition or alternatively, the application adapter computer system 402 may have been programmed/trained to recognize patterns in the code listing.
At 608, and based on its reading of the current code listing segment at 606, the application adapter computer system 402 may provide or produce a characterization and/or classification of the current code segment. Among the possible characterizations of the code listing segment that may be provided by the application adapter computer system 402 are perhaps the following: “does not require conversion”; “requires conversion”; “automatically convertible” (by the application adapter computer system 402); “not automatically convertible” (or “requires manual coding”): “data generation”; “data reading”; “data updating”; “data deleting”; “simple query”; “complex query”; “data transmission”; “data receiving”. In an example, for at least some code listing segments, the application adapter computer system 402 may apply two or more of these characterizations to the code listing segment. In some examples, other or different characterizations or types of characterizations may be programmed into the application adapter computer system 402 for application to code listing segments. The characterization of the code listing segment made by the application adapter computer system 402 may be based on the code listing segment as read by the application adapter computer system 402.
In the process of
If a negative determination is made at decision block 610 (i.e., if the application adapter computer system 402 determines that conversion is not required for the current code listing section), then block 612 may follow decision block 610. At block 610, the application adapter computer system 402 may include the original content of the current code listing segment in the converted/adapted application code listing that is to be the output of the process of
If a positive determination is made at decision block 610 (i.e., if the application adapter computer system 402 determines that conversion of the current code listing section is required), then decision block 614 may follow decision block 610.
At decision block 614, the application adapter computer system 402 may determine whether the current code listing segment is amenable to automatic conversion by the application adapter computer system 402. In an example, the determination made at decision block 614 may be based on a characterization of the current code listing segment that was made at block 608. More specifically, the application adapter computer system 402 may make the determination at block 614 based on an algorithm that assesses the nature of the code within the current code listing segment and compares the nature of the code with the code conversion capabilities of the application adapter computer system 402.
If a positive determination is made at decision block 614 (i.e., if the application adapter computer system 402 determines that the current code listing segment is amenable to automatic conversion), then block 616 may follow decision block 614. At block 616, the application adapter computer system 402 may generate a suitable replacement code listing segment to replace the current code listing segment. In an example, the application adapter computer system 402 may have been programmed to have a translation capability for translating code listing segments suitable only for online environment application programs into code listing segments suitable for performing the same or a similar function in an offline environment. In some situations, the replacement code listing segment may include portions of the original code listing segment but may have portions of program code inserted therein to adapt the code listing segment to the offline environment. For example, if the code listing segment embodies a simple query, the replacement code listing segment may be suitable for causing the simple query to be performed in a manner that is consistent with operation in an offline environment. Similar translations/adaptations may be performed, for example, with respect to code listing segments that embody functions such as data transmission or data reception.
In another example, conversion of an original code listing segment may include augmenting the original code listing segment to perform an additional function or functions such as transforming a data object or resource from one format to another. For example, the additional function may transform a comma delimited file into serialized data and may package the serialized data for transmission in an offline environment.
In another example, conversion of an original code listing segment that contains a query function may result in a replacement code listing segment that provides a function for submitting a query in the form of asking for a service according to a client/server protocol.
In general, for example, where an original code listing segment performs a function in accordance with a standard RESTful Web service approach (where “REST” stands for Representational State Transfer), the application adapter computer system 402 may be capable of readily translating the original code listing—at least in many cases—to a replacement code listing segment that is suitable for performing the function in an offline environment.
Block 618 may follow block 616 in the process of
If a negative determination is made at decision block 614 (i.e., if the application adapter computer system 402 determines that the current code listing segment is not amenable to automatic conversion), then block 620 may follow decision block 614 in the process of
Referring then to
Continuing to refer to
In an example, the process illustrated in
Referring again to
Again, block 708 represents one variety of annotation processing that may be performed at block 620 (
In various examples, any one or more or all of the types of annotations described with reference to
Reference will now be made once again to
A simplified example of code listing conversion according to teachings of this disclosure will now be illustrated and described with reference to
Referring initially to
In
It is further assumed for the purposes of this example that the process of
According to a further assumption for the purposes of this example, the process of
As to the original code listing segment 808, it is again assumed, as was the case with code listing segment 802, that the process of
The ellipsis 910 shown in
Once any required manual coding is accomplished for the original code listing segments that were found to require conversion but which the application adapter computer system 402 was not capable of converting, an adapted/converted application program has been produced. The adapted/converted application program may be suitable for running in a source of data or a mobile device, as the case may be, and may be suitable for use in an offline environment. The conversion of the original application program may have been accomplished with a high degree of automation, thereby lowering the cost and reducing the time required to produce/convert application programs for an offline environment. This may help to spur or expand the deployment of mobile devices in Asset Management Platform systems. This in turn may increase the capabilities and convenience offered in AMP systems.
The following summarizes various capabilities of the application adapter computer system 402, as illustrated above with reference to
The application adapter computer system 402 may be capable of detecting characteristics of various types of code listing segments encountered in the application programs to be processed/converted for use in an offline environment. For code listing segments found to have certain characteristics, the application adapter computer system 402 may generate a replacement code listing segment to take the place of the original code listing segment. The replacement code listing segment may be suitable for an application program to be deployed in an offline environment.
As to code listing segments found to have other characteristics, the application adapter computer system 402 may refrain from generating replacement code listing segments. As to the latter types of original code listing segments, the application adapter computer system 402 may list the original code listing segment for the code listing for the adapted/converted application program, together with an indication that manual coding of the particular original code listing segment is required.
The application adapter computer system 402 may be capable of machine-reading a code listing on a segment-by-segment basis. (The code listing may represent an application program.) The application adapter computer system 402 may determine for each code listing segment whether or not to automatically generate corresponding adapter program code to replace the original code listing segment.
In addition to the above-mentioned machine-reading capability, and while the machine reading is going on, the application adapter computer system 402 may determine, for a given code listing segment, that the segment is of a predetermined type. In response to that determination, the application adapter computer system 402 may automatically append, to a code listing for an adapted/converted program, an indication of a suggested manual coding approach for converting the particular original code listing segment to a converted code listing segment for use in the adapted/converted program code listing. In addition or alternatively, the application adapter computer system 402 may append to the code listing for the adapted/converted program an indication of what is the type of the original code listing segment.
Computer 1000 shown in
Referring to
Data storage device 1030 may include any appropriate persistent (i.e., non-transitory) storage device, including combinations of magnetic storage devices (e.g., magnetic tape, hard disk drives and flash memory), optical storage devices, Read Only Memory (ROM) devices, etc., while memory 1060 may include Random Access Memory (RAM). The data storage device 1030 and the memory 1060 may be in communication with each other and/or with the processor(s) 1010.
Data storage device 1030 may store software programs that include program code executed by processor(s) 1010 to cause computer 1000 to perform any one or more of the processes described herein. Embodiments are not limited to execution of these processes by a single apparatus. For example, the data storage device 1030 may store code segment reading software 1032.
Continuing to refer to
In addition, data storage device 1030 may store a software program 1036, which generates segments of replacement code.
Still further, data storage device 1030 may store a software program 1038 which generates annotations for inclusion in adapter/converted application program code listings.
Also, data storage device 1030 may store a database manager program 1042 and one or more code listing segment databases 1044, which may be processed or stored in the computer 1000. Data storage device 1030 may store other data and other program code for providing additional functionality and/or which are necessary for operation of system computer 1000, such as device drivers, operating system files, etc.
A technical effect is to provide at least partial machine-based analysis and conversion of application programs for deployment in offline environments.
The foregoing diagrams represent logical architectures for describing processes according to some embodiments, and actual implementations may include more or different components arranged in other manners. Other topologies may be used in conjunction with other embodiments. Moreover, each system described herein may be implemented by any number of devices in communication via any number of other public and/or private networks. Two or more of such computing devices may be located remote from one another and may communicate with one another via any known manner of network(s) and/or a dedicated connection. Each device may include any number of hardware and/or software elements suitable to provide the functions described herein as well as any other functions. For example, any computing device used in an implementation of some embodiments may include a processor to execute program code such that the computing device operates as described herein.
All systems and processes discussed herein may be embodied in program code stored on one or more non-transitory computer-readable media. Such media may include, for example, a floppy disk, a CD-ROM, a DVD-ROM, a Flash drive, magnetic tape, and solid state Random Access Memory (RAM) or Read Only Memory (ROM) storage units. Embodiments are therefore not limited to any specific combination of hardware and software.
The flow charts and descriptions thereof herein should not be understood to prescribe a fixed order of performing the method steps described therein. Rather the method steps may be performed in any order that is practicable, including simultaneous performance of steps.
Embodiments described herein are solely for the purpose of illustration. A person of ordinary skill in the relevant art may recognize other embodiments may be practiced with modifications and alterations to that described above.