The impact of an organization and associated operations on the environment may be tracked through the use of sustainability footprints, which may include carbon footprints, water footprints, ecological footprints, and/or other footprints. The sustainability footprints may be used to evaluate implications of strategic decisions, track progress toward sustainability goals, and ensure compliance with regulations, among other applications.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary 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.
In summary, the detailed description is directed to various innovative technologies for managing, processing, and generating display information relating to data input into cartesian columns. In some examples, the disclosed technologies can be implemented as a method performed by a computer. Activity data for an organization is received, and emissions factors for the activity data are determined. Absolute and relative sustainability footprints for the organization are calculated based on the activity data and the emissions factors. Average relative sustainability footprints are calculated for the organization over a specified time period based on the absolute and relative sustainability footprints, and an indication of the absolute, relative, and average relative sustainability footprints is generated for display on a graphical user interface.
In some examples, the disclosed technologies can be implemented as computer-readable media storing instructions which, when executed by one or more hardware processors, cause the hardware processors to perform the following actions. A set of emissions factors for one or more products, materials, or suppliers of materials is retrieved. Activity data for an organization is received, the activity data including one or more categories of data relating to operations of the organization. For each category of activity data, the activity data is mapped to a respective relevant emissions factor from the retrieved set of emissions factors to generate enriched or augmented activity data. For a selected product, material, or supplier of materials, a plurality of relative sustainability footprints is calculated for the organization using the enriched or augmented activity data in association with operations of the organization in a targeted period relating to the selected product, material, or supplier of materials. An absolute sustainability footprint is calculated for the selected product, material, or supplier of materials corresponding to a sum of the plurality of relative sustainability footprints for the targeted period. An average relative sustainability footprint is calculated for the organization over a specified time period based on the absolute and relative sustainability footprints. An indication of the calculated relative, absolute, and average relative sustainability footprints is generated for display on one or more views of a graphical user interface.
In some examples, the disclosed technologies can be implemented in a system including one or more hardware processors with coupled memory, and computer-readable media storing instructions executable by the one or more hardware processors. The instructions include first, second, third, fourth, fifth, and sixth instructions. The first instructions, when executed, cause a selection of emissions factors to be used for a sustainability assessment for an organization to be received via a user interface displayed on a client computing device. The second instructions, when executed, cause activity data for the organization in accordance with one or more parameters of the assessment to be received. The third instructions, when executed, cause relative and absolute footprints to be calculated for a first time period for the activity data associated with the first time period using the emissions factors. The fourth instructions, when executed, cause relative and absolute footprints to be calculated for a second time period for the activity data associated with the second time period, where the calculation of the relative and absolute footprints for outflows of the organization use an associated relative or absolute footprint calculated for the first time period. The fifth instructions, when executed, cause an average relative footprint for the organization based on the calculated relative and absolute footprints to be calculated. The sixth instructions, when executed, cause an indication of the calculated average relative footprint for the organization to be output to one or more applications of the system for adjusting operations of the system to reduce an overall footprint associated with the organization.
The foregoing and other objects, features, and advantages of the invention will become more apparent from the following detailed description, which proceeds with reference to the accompanying figures.
Sustainability services may utilize efficient and fast algorithms for sustainability footprint (e.g., a carbon CO2 footprint) calculations. These calculations may be related to individual value chain contributions of upstream processes like raw material processing and inbound transport, own processing like production or assembly of products, and downstream processes like outbound transport, product use, and product end of use. The calculated footprints may be used as a data basis for reducing direct or indirect emissions, and with that to reduce costs like carbon taxes. The scope of such footprint calculations is defined but not limited to the scopes defined by the Greenhouse Gas Protocol (GHG Protocol). These calculation algorithms are configured to cover the complex cases like multiple suppliers in upstream inbound activities, the accumulation of goods in the inventory, the supplier-unaware outbound flows in direct production, the downstream activities etc. The calculations may be based on various types of so-called Business Activity Metrics (BAM) like physical goods movement, extracted from business data sources. This data, being accumulated and aggregated in a defined way, combined with the sustainability reference factors (which are obtained from external and home systems in the form of sustainability impacts for various business activities), form the basis for corporate business activities footprint calculations. These results may then be used as a basis for sustainability scoring and footprint determination in general business processes like purchasing, material sourcing, production planning and optimization, Material Requirements Planning (MRP) and vendor selection, etc. and used for broader analytical reporting, including creation of a respective sustainability factors base.
This disclosure describes a new approach including the application of a calculation algorithm based on periodic averages, which enables fast and efficient calculations of footprints of products. The described approaches may combine related big-data real-time Business Activity Metrics, which are retrieved from Enterprise Resource Planning (ERP) systems (such as S/4HANA ledgers) with sustainability reference factors provided by external parties (such as the supplier, third party, and/or public databases). The described technologies may also define an approach to determine and calculate the error rate and accuracy taken into the account as consequence of working with averages for gaining high calculation performance. The new proposed calculation approaches described herein may be generic and/or agnostic with regards to specific industries or business sectors. In addition to a generic calculation algorithm, a generic business configuration scheme is described herein based on Assessment Templates and Derivation definitions.
The disclosure addresses the problem to make the above-described footprint calculations clear, consistent, logical, memory and time efficient based on a new concept based on periodic averages. It offers reasonable approximations and describes various methods, which make the calculations transparent for users and gives formulas and processes for estimations of calculation method related errors.
In an initial stage, the described approach includes a new journey starting with extracting the data (e.g., business activity data 104 and/or master data 106) out from the ERP system 102 and loading it into a footprint calculation service 108 (e.g., into an extracted ERP data storage 109). However, getting the detailed single-line item data from service-level systems, though accurate, may be a cumbersome process with regard to data volume, network bandwidth and CPU load, which eventually is inefficient and sometimes impossible for long-periodic footprint calculations. Therefore, the disclosed process includes aggregating the detailed business data at a periodic time interval (for example weekly, monthly, yearly, etc.) in a specific way and then use the periodic aggregated data for periodic calculations.
In a second stage, reliable calculations for footprint calculations utilize reliable sustainability reference content, which may include external data, provided by data providers (e.g., external factors providers 110) gathering it from other sources or by business partners like the suppliers into a footprint factors database 112. The sustainability content is industry standard data which gives details of the environmental impact based on different parameters like carbon impact or water impact for a specific material depending on certain factors like for example country of origin. An example is the footprint factor, such as 1.1 kg CO2e for 1 kg sugar. The choice of the content provider depends on the customer and can be decided on variety of parameters like diversity of data, reliability of data, accuracy of data etc. This decision also depends on the sector, industry, or the nature of business that the customer operates in. Supplier's footprint factors may be included by standard formats and APIs. Therefore, in a third stage of operation, the content data (e.g., the extracted ERP data 109 and footprint factors 112) is imported into a calculation agent 114 of the calculation service in a standardized way.
In a fourth operation, the calculation service utilizes the footprint calculation agent 114, which is able to determine the appropriate footprint derivation, which includes the business input data, the selection of the appropriate sustainability reference content (e.g. footprint factors), and the calculation algorithm based on a given business scope. Once this derivation is determined, the calculation can be scheduled as assessment run. In some examples, the calculation may be performed at regular intervals automatically based on a schedule set by a user and/or based on one or more triggering events (e.g., an initiation of a new procurement process). The calculation agent may employ a coded calculation algorithm, which is specified in more detail below.
Once the assessment run has been executed and the footprint calculation algorithm has computed a set of footprints, those footprints are stored into a footprints database 116, which may include a multidimensional data cube in some examples. The footprint sets may have business object types and time as dimensions. Business object types in scope for the implementation but not limited concept-wise are supplier, plant, product (group). An in-memory column data base, such as SAP HANA Cloud, may be used as footprint persistency, however simpler database approaches can be chosen, too, with the drawbacks of lower performance.
After the footprints are calculated, they can be used in applications 118 of the ERP system 102 for optimizing business processes like reducing the footprint of inflow materials (purchasing and sourcing), the production process (manufacturing and maintenance) or transport (logistics).
A simplified calculation example of sustainability footprint determinations is given in this section. It relates to an abstract and simplified material flow with 4 raw material suppliers and 2 plants of an enterprise 200 structured as shown in
Plant 1 and plant 2 produce the same arbitrary end-product for a company. They utilize just one and the same raw material for this product. The raw material is shipped by supplier 1 and 2 to plant 1 and by supplier 3 and 4 to plant 2. Plant 1 and plant 2 exchange this raw material from time-to-time, which introduces a circular delivery situation, which happens in the worst case in the same calculation period. For breaking the circular dependency (which would lead into an endless calculation which might not converge to a target value), the calculation scheme proposes a recursive approach, based on periodic averages, where the outflows (can be raw materials or products) be calculated based on the previous period's relative footprint factor. In the given example, the plant 1 and plant 2 circular shipments may not be consolidated by, for example, a reverse posting. In other examples, the circular shipments are consolidated, and the algorithm works in the same way with the consolidated posting.
In October, plant 1 gets delivered 1000 kg by supplier 1 and 800 kg by supplier 2 with their specific relative footprint factors 0.08 and 0.1688 respectively, which have been exchanged as sustainability content before (e.g., as described above). From plant 2, plant 1 receives 70 kg as reverse inflow with the relative footprint of plant 2 of the previous period (0.035). In the same period October, plant 1 uses 100 kg and ships 100 kg to plant 2, both with the relative footprint plant 1 had calculated for the previous period September (0.07). This is also the relative footprint “given” to plant 2, which breaks the circle of calculation.
For plant 2, the analogues calculation happens: It gets delivered 500 kg by supplier 3 and 300 kg by supplier 4 with the factors 0.16 and 0.45. From plant 1, plant 2 receives 100 kg as inflow with the relative footprint of plant 1 of the previous period (0.07). In the same period October, plant 2 uses 100 kg and ships 70 kg to plant 1, both with the relative footprint plant 2 had calculated for the previous period September (0.035). This is also the relative footprint “given” to plant 1, which breaks the circle of calculation.
At 404, the method includes identifying parameters of the assessment. For example, the BVE may retrieve the assessment definition to identify the period, the business scope (e.g., corresponding to master data and Business Activity Metrics [BAM] data), and/or the footprint categories to be calculated along with the related derivation definitions to be used to calculate footprints.
At 406, the method includes fetching related business activity metrics data based on parameters of the assessment. At 408, the method includes determining emission factors for use in the assessment. For example, a Business Activity Valuation Engine may orchestrate the calls for each period, for each footprint category, for each business activity category combination for absolute and relative footprints calculation by invoking a Derivation Management module. The Derivation Management module may use an orchestrator to fetch the related BAM data based on business scope and period for all the Goods Movement which are received from a supplier. A Business Activity Metrics Data Manager may fetch related BAM data which is enriched or augmented with Master data. For example, the BAM data may be enriched or augmented by providing additional details to the BAM data, such as supplier and/or plant country and/or other information associated with a supplier and/or plant indicated in the BAM data, product details such as gross weight, net weight, volume, density, and/or other attributes for one or more products referenced in the BAM data, etc. The Derivation Management Orchestrator provides the enriched or augmented BAM data to Determination Engine to find most suitable Sustainability Reference Content data using the determination algorithm and the business data.
At 410, the method includes providing the BAM data and the emission factors to a calculation agent, which calculates absolute and relative footprints based on the BAM data and emission factors. The method further includes receiving the calculated footprints at 412. For example, the Derivation Management Orchestrator may provide the BAM data along with determined emission factors to a Calculation Agent, which returns the absolute and relative footprints for the BAM data and these derived footprints are handed over to a Footprint Data Manager, which are then persisted. The Orchestrator then acknowledges back the status of calculation to the Business Valuation Engine.
At 414, the method includes calculating average relative footprints based on the parameters of the assessment. For example, after all the calculations are acknowledged by the Derivation Management to the Business Activity Valuation Engine and on all successful derivations the Business Valuation Engine then triggers the calculation of Average Relative footprints by invoking Footprints Data Management for each period and business scope definition defined in the assessment. The Footprint Data Manager then triggers the calculation of relative, absolute footprints for all inflows which are not supplied by a Supplier and for all the outflows, and additionally the average relative footprints for all inflows and outflows of Goods Movement data, which are also persisted in the Footprint Data Manager and acknowledged back to BVE with relevant status.
BVE then updates the overall status of the assessment execution based on the acknowledgements from the Derivation Management and the Footprint Data Manager. At 416, the method includes outputting the result of the footprint calculations (e.g., the average, relative, absolute, etc. footprints and/or related data). For example, the result may be output to a graphical user interface and/or output to a downstream process or system for controlling operations associated with the organization. As a non-limiting example, the calculated footprint may be provided in in a procurement user interface to inform a user of the footprint associated with one or more options for fulfilling an order for a product, which may allow a user or an associated automated procurement process to select a supplier/vendor or otherwise make purchasing decisions based on an estimated footprint calculated as described herein. In additional or alternative examples, the calculated result may be fed back into the system to be used for future calculations. Still further examples of applications for the calculated footprints includes creating integrated financial and sustainability enterprise reports, which may include product footprint statistics (e.g., footprint per product group, sales region, etc.), communicating the footprint to customers/consumers of delivered products (e.g., to assist in calculating their own footprints), and/or running analytic assessments on product footprint data by using machine learning algorithms to identify trends, outliers, and/or other features of the data.
Lifecycle Assessment (LCA) data providers 510 provide the emission factors data as Sustainability Reference Content for products which are extracted, transformed and persisted in a reference format in a Sustainability Content Manager of Reference data manager 512. Customers of PFM can also bring in the reference emission factors data (Sustainability Reference Content) in a reference format and upload this data via File Ingestor (FI) service 514 of a business technology platform 515. The same mechanism can be applied for the supplier's reference emission factors.
Turning briefly to
Returning to
Calculation Agents 520 are the services which executes the calculation/derivation algorithms on the data provided as input and outputs the relative and total footprints. A Footprint Data Manager (FDM) 522 is the repository for all kinds of footprints calculated by different calculation agents and the footprints can be visualized in a ‘View Product Footprints’ application. An Average Relative Footprint Data Manager service 524 is built for calculating the Average Relative footprints.
A Business Activity Valuation Engine (BVE) 526 is the Orchestrator service which executes an assessment for a period based on business scoping like master data and BAM data, on footprint scope like CO2e to derive relative, total and average relative footprints by derivation management service and average relative footprint data manager services. A Foundation Umbrella service manages database access and the DB artifacts per tenant which is shared by foundation services like Master Data, FDM etc. An application launchpad 527 may be used to launch various application of the business technology platform, such as uploading business data, managing assessments, managing deviations, managing configurations, viewing product footprints, defining business scoping, viewing product footprint analytics, etc.
Turning briefly to
Returning to
Application, Audit, and Business Logging services, which are used to handle the related logging operations for tracing, auditing and business logs. An ERP Cloud may be used as a persistent storage for data and an Object Store service may be used for handling objects like zip files, CSV files, and so on.
Personal Data Manager and Retention Manager, which are used to handle the Data Privacy and Data lifecycle management related features.
Identity Provider Service (e.g., for user and role management), which is used for authentication and authorization.
SaaS Provisioning for tenant provision and deprovision features.
Analytics Cloud 530 is used for analytical reporting for slicing and dicing the footprints data with related business data for insights on footprints An ERP Integration component in an ERP system may act as a cache for footprints which can be accessed via APIs and the related UIs and also enables Line-of-Business (LoB) applications like Purchase Order to integrate footprints data for the products. A Content Network 532 includes a network of companies that can publish/consume the calculated footprints by trusted companies.
This disclosure puts the calculation idea explained with the example above into a set of mathematical formulas, which are implemented as calculation agent in the calculation service. This chapter deducts the formula for the calculation of absolute and relative footprint as well as the related error rate which can happen in a period T due to the periodic averages that are used. It can be shown that the error in total converges to zero over total time.
The following constraints may be observed in some example implementations: 1. The following mathematical formulas are defined for the unit of measure dimension of mass with kg as unit. It can be applied for any dimension and any unit by exchanging the parameters with mass unit by parameters with another unit, e.g., volume. Alternatively, other units are calculated into mass by an appropriate unit of measure conversion, e.g., with density as conversion rate. 2. The following mathematical formulas are defined for a given organizational unit of an enterprise, e.g., a plant or a storage location like a warehouse. An enterprise usually has multiple organizational units for which the calculations may be run separately per each (see also example above).
(1) Cn is the n-th material out of N used in production processes with a constant mass mn across time (t=0 . . . ∞) and supplier (i.e., if mass changes, a new material is created).
(2) Each supplier s out of Lt has for period t the proper sustainability factor ftsn. If the supplier factor is unknown, a factor ftn can be applied (e.g., for initial load/bootstrapping). If the factor for a period t is not known, a general factor fn is the last default. Factors are retrieved from external factor data bases.
(3) utsn is the received quantity of material Cn in the period t from supplier s (also called input or inflow). Suppliers can be external (i.e., vendors) or internal (i.e., own plants or warehouses).
(4a) wtcn is the quantity of material Cn in the period t, which is consumed in a production step or shipped to a consumer c out of Vt (also called output or outflow).
(4b) wt2sn is the consumed or shipped quantity of material Cn from supplier s at the period t2 in a production step or to a consumer. It might be that the consummation wt2sn of the received material utsn happens in the same period (t2=t), in a later period (t2>t), or in partitions across multiple periods utsn=Σtv=tt2wtv sn.
(5a) Absolute quantity of Cn at end of period T≥1 is:
With R0n as quantity at begin (initial load/bootstrapping) point in time.
(5b) To minimize data volume, the quantity is calculated recursively:
This allows to delete all single data points utsn and wtcn after the calculation which reduces allocated volume on DB drastically. The calculation itself is much faster than (5a) since computing sums across all data is avoided.
(6) Absolute quantity in mass of Cn at end of period T is: STn=RTn*mn.
(7a) Absolute footprint of material Cn in the stock is the sum of all individual footprints for periods t:
with I0n=S0n*f0n=R0n*mn*f0n (which is initial load/bootstrapping at T=0). Note that for outflows wt2sn the factors ftsn at the point of inflow is to be taken.
(7b) As in (5a), (7a) includes keeping all historic single data points and their relation in time. Second, run sum operation across all data points is necessary, which is CPU and memory intensive. Therefore, the concept of “periodic averages” is introduced, which defines a relative footprint factor Ftn so that:
As in (5b), such a recursive approach with relative footprint as average factor allows to delete the data points utsn, wt2sn, and ftsn after the calculation, which reduces the allocated DB volume drastically. Again, the calculation itself is much faster than (7a) since computing sums across all data is avoided.
(8) Ftn is the relative footprint of material Cn at the end of period T≥1 with:
From an algorithm perspective, first RTn and ITn are calculated, then FTn, so this relative footprint is used for the calculation of the next period.
A consumer c of an outflow can be supplier s of an inflow in a period T for the same material Cn and for the same organizational unit (e.g., plant1 ships Cn to plant 2 and plant2 retours Cn to plant1 in T). This leads to the circular calculation problem, because FTn of plant1 and plant2 are usually different. Therefore, the calculation of (shipped) outflows in (7b) are done with the relative footprint FT−1n of the previous period. This leads to an approximation error if Ec=1v
(Otherwise it is wT errn=0).
(10) In this case, the quantity wT errn is consumed/shipped with FT−1n though it should be FTn. For the extreme case of (RT−1n=0)∧(FT−1n=0) (i.e., stock is empty at end of T−1), the footprint of the complete outflow is erroneously zero:
(In this case, this should be corrected by fallback to a standard factor (e.g. from an emission data base for the material) FT−1n=f0n).
(11) Therefore, the systematic error of this approach can be quantified with
I
T err
n
=w
T err
n
*m
n*(FTn−FT−1n)
With IT errn being the absolute footprint error for outflows. A sensible error rate is relating the error to the outflows:
(12) Though this systematic error leads to wrong relative footprints (which are factors from consumer point of view) downstream, it averages out in total in the next period, since the absolute footprint remaining is distributed on the remaining quantity:
Delta of absolute footprint, which is erroneously kept in stock is negative or positive depending whether the footprint of received material is greater or smaller than the footprint of material in stock:
FTn>FT−1n→IT errn>0, i.e., the absolute footprint on stock too high by IT errn
FTn<FT−1n→IT errn<0, i.e., the absolute footprint on stock too low by IT errn
(13) This will be corrected by the new calculation of
So that
I
T+1 out
n=Σc=1v
I.e., the error is eliminated from stock by being forwarded in the next period to the outflows.
Though on total average the error is eliminated, it might happen that for certain consumers slightly wrong footprints are forwarded. Therefore, it is possible to calculate and quantify the error rate as defined in (11) so that the accuracy level for the calculation can be quantified.
Accordingly, the algorithms described above may be summarized as a combination of:
1. Recursive calculation of quantities of materials (products) relevant for sustainability footprint calculation (see formula (5b))
2. Introduction of relative footprint factors following the concept of periodic averages as defined in formula (7b)
3. Derivation of a formula and calculation of quantified error values that document the accuracy of the calculation scheme (formula (9) and (11))
4. Proof that the systematic total error of the calculation is eliminate by average across periods (formula (13)).
The solution provided by the technologies described herein is superior in comparison of approaches in the past with regards to at least the following considerations.
1. The mathematical foundation provides a clear, consistent and re producible calculation model with very low adoption efforts and time to value. The solution provides a clear guidance how to map primary and secondary Sustainability Reference Content dataset with customer enterprise business data to derive Footprints.
2. The calculation can be used for all industries and organizations that have inventory management and material flow in place.
3. The technologies described herein enable customers to calculate footprints at scale and periodically using transactional “realtime” (ERP) business data.
4. Because it works with real-time transaction data from ERP systems, the calculation result has the same quality as the related material ledger inside the ERP system. Manual data copying, modifications, manual interactions and alike are avoided.
5. The technologies described here provide flexible derivation definitions to associate reference content automatically and intelligent to the business data.
6. The generic definition of business scope by Assessment Template and selection of derivation variants allow to extract the input data in an aggregated way. With that the resource consumption (e.g., with regard to memory, network bandwidth, CPU load, etc.) is reduced and the performance (e.g., duration of calculation) is increased.
7. The calculation itself can be implemented as stored procedure directly on databases, like SAP HANA Cloud. With that a high-performance calculation is possible.
8. The formula and algorithm allow a quantification of transient error rates, which are inherent for periodic averages. However, as mathematically proven, the total error over total time and supplier, plant, and consumer nodes do converge to zero.
9. The resulting calculated footprint of products can be used further in many applications like sustainability scoring of suppliers for consideration in procurement, selection of low-carbon transport logistics, reduction of costs introduced by carbon taxes and certificates.
With reference to
A computing system 910 can have additional features, such as one or more of storage 940, input devices 950, output devices 960, or communication ports 970. An interconnection mechanism (not shown) such as a bus, controller, or network interconnects the components of the computing environment 910. Typically, operating system software (not shown) provides an operating environment for other software executing in the computing environment 910, and coordinates activities of the components of the computing environment 910.
The tangible storage 940 can be removable or non-removable, and includes magnetic disks, magnetic tapes or cassettes, CD-ROMs, DVDs, or any other medium which can be used to store information in a non-transitory way and which can be accessed within the computing environment 910. The storage 940 stores instructions of the software 980 (including instructions and/or data) implementing one or more innovations described herein.
The input device(s) 950 can be a mechanical, touch-sensing, or proximity-sensing input device such as a keyboard, mouse, pen, touchscreen, trackball, a voice input device, a scanning device, or another device that provides input to the computing environment 910. The output device(s) 960 can be a display, printer, speaker, optical disk writer, or another device that provides output from the computing environment 910.
The communication port(s) 970 enable communication over a communication medium to another computing device. The communication medium conveys information such as computer-executable instructions or other data in a modulated data signal. A modulated data signal is a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media can use an electrical, optical, RF, acoustic, or other carrier.
In some examples, computer system 900 can also include a computing cloud 990 in which instructions implementing all or a portion of the disclosed technology are executed. Any combination of memory 924, storage 940, and computing cloud 990 can be used to store software instructions and data of the disclosed technologies.
The present innovations can be described in the general context of computer-executable instructions, such as those included in program modules, being executed in a computing system on a target real or virtual processor. Generally, program modules or components include routines, programs, libraries, software objects, classes, components, data structures, etc. that perform tasks or implement particular abstract data types. The functionality of the program modules can be combined or split between program modules as desired in various embodiments. Computer-executable instructions for program modules can be executed within a local or distributed computing system.
The terms “system,” “environment,” and “device” are used interchangeably herein. Unless the context clearly indicates otherwise, none of these terms implies any limitation on a type of computing system, computing environment, or computing device. In general, a computing system, computing environment, or computing device can be local or distributed, and can include any combination of special-purpose hardware and/or general-purpose hardware and/or virtualized hardware, together with software implementing the functionality described herein. Virtual processors, virtual hardware, and virtualized devices are ultimately embodied in a hardware processor or another form of physical computer hardware, and thus include both software associated with virtualization and underlying hardware.
The computing cloud 1090 can be operatively connected to various types of computing devices (e.g., client computing devices), such as computing devices 1012, 1014, and 1016, and can provide a range of computing services thereto. One or more of computing devices 1012, 1014, and 1016 can be computers (e.g., servers, virtual machines, embedded systems, desktop, or laptop computers), mobile devices (e.g., tablet computers, smartphones, or wearable appliances), or other types of computing devices. Communication links between computing cloud 1090 and computing devices 1012, 1014, and 1016 can be over wired, wireless, or optical links, or any combination thereof, and can be short-lived or long-lasting. Communication links can be continuous or sporadic. These communication links can be stationary or can move over time, being implemented over varying paths and having varying attachment points at each end. Computing devices 1012, 1014, and 1016 can also be connected to each other.
Computing devices 1012, 1014, and 1016 can utilize the computing cloud 1090 to obtain computing services and perform computing operations (e.g., data processing, data storage, and the like). Particularly, software 1080 for performing the described innovative technologies can be resident or executed in the computing cloud 1090, in computing devices 1012, 1014, and 1016, or in a distributed combination of cloud and computing devices.
As used in this disclosure, the singular forms “a,” “an,” and “the” include the plural forms unless the surrounding language clearly dictates otherwise. Additionally, the terms “includes” and “incorporates” mean “comprises.” Further, the terms “coupled” or “attached” encompass mechanical, electrical, magnetic, optical, as well as other practical ways of coupling items together, and does not exclude the presence of intermediate elements between the coupled items. Furthermore, as used herein, the terms “or” and “and/or” mean any one item or combination of items in the phrase.
For the sake of presentation, the detailed description uses terms like “determine” and “use” to describe computer operations in a computing system. These terms are high-level abstractions for operations performed by a computer, and should not be confused with acts performed by a human being. The actual computer operations corresponding to these terms vary depending on implementation.
Although the operations of some of the disclosed methods are described in a particular, sequential order for convenient presentation, it should be understood that this manner of description encompasses rearrangement, unless a particular ordering is required by specific language set forth below. For example, operations described sequentially may in some cases be rearranged or performed concurrently. Moreover, for the sake of simplicity, the attached figures may not show the various ways in which the disclosed methods can be used in conjunction with other methods.
Any of the disclosed methods can be implemented as computer-executable instructions or a computer program product stored on one or more computer-readable storage media, such as tangible, non-transitory computer-readable storage media, and executed on a computing device (e.g., any available computing device, including tablets, smartphones, or other mobile devices that include computing hardware). Tangible computer-readable storage media are any available tangible media that can be accessed within a computing environment (e.g., one or more optical media discs such as DVD or CD, volatile memory components (such as DRAM or SRAM), or nonvolatile memory components (such as flash memory or hard drives)). By way of example, and with reference to
Any of the computer-executable instructions for implementing the disclosed techniques as well as any data created and used during implementation of the disclosed embodiments can be stored on one or more computer-readable storage media. The computer-executable instructions can be part of, for example, a dedicated software application or a software application that is accessed or downloaded via a web browser or other software application (such as a remote computing application). Such software can be executed, for example, on a single local computer (e.g., any suitable commercially available computer) or in a network environment (e.g., via the Internet, a wide-area network, a local-area network, a client-server network, a cloud computing network, or other such network) using one or more network computers.
For clarity, only certain selected aspects of the software-based implementations are described. Other details that are well known in the art are omitted. For example, it should be understood that the disclosed technology is not limited to any specific computer language or program. For instance, the disclosed technology can be implemented by software written in ABAP, Adobe Flash, Angular, C, C++, C#, Curl, Dart, Fortran, Go, Java, JavaScript, Julia, Lisp, Matlab, Octave, Perl, Python, R, Ruby, SAS, SPSS, WebAssembly, any derivatives thereof, or any other suitable programming language, or, in some examples, markup languages such as HTML or XML, or in any combination of suitable languages, libraries, and packages. Likewise, the disclosed technology is not limited to any particular computer or type of hardware. Certain details of suitable computers and hardware are well known and need not be set forth in detail in this disclosure.
Furthermore, any of the software-based embodiments (comprising, for example, computer-executable instructions for causing a computer to perform any of the disclosed methods) can be uploaded, downloaded, or remotely accessed through a suitable communication means. Such suitable communication means include, for example, the Internet, the World Wide Web, an intranet, software applications, cable (including fiber optic cable), magnetic communications, electromagnetic communications (including RF, microwave, infrared, and optical communications), electronic communications, or other such communication means.
The disclosed methods, apparatus, and systems should not be construed as limiting in any way. Instead, the present disclosure is directed toward all novel and nonobvious features and aspects of the various disclosed embodiments, alone and in various combinations and sub-combinations with one another. The disclosed methods, apparatus, and systems are not limited to any specific aspect or feature or combination thereof, nor do the disclosed embodiments require that any one or more specific advantages be present or problems be solved.
The technologies from any example can be combined with the technologies described in any one or more of the other examples. In view of the many possible embodiments to which the principles of the disclosed invention may be applied, it should be recognized that the illustrated embodiments are only preferred examples of the invention and should not be taken as limiting the scope of the invention. Rather, the scope of the invention is defined by the following claims. We therefore claim as our invention all that comes within the scope and spirit of these claims.