A subsurface formation may be determined using various measurements obtained through logging tools. For example, these measurements may be used to calculate porosity, permeability, and other properties of a reservoir formation. However, in many situations, logging tool measurements may be unavailable at various wells for specific log types or interwell locations outside the vicinity of the drilled wells.
This summary is provided to introduce a selection of further described concepts in the detailed description. This summary is not intended to identify key or essential features of the claimed subject matter, nor is it intended to be used as an aid in limiting the scope of the claimed subject matter.
In general, in one aspect, embodiments relate to a method that includes obtaining, by a computer processor, well log data for various wells regarding a geological region of interest. The well log data corresponds to various well logs with different logging types. The method further includes assigning, by the computer processor and using a grouping algorithm, subsets of the well log data to various groups based on one or more geological attributes. The method further includes determining, by the computer processor and using the groups and a machine-learning algorithm, various well zones for different portions of a respective well among the wells. The method further includes determining, by the computer processor, interpolated log data using the well log data, the well zones, and an intrawell interpolation process. The method further includes generating, by the computer processor, a formation property volume based on the interpolated log data and the well log data.
In general, in one aspect, embodiments relate to a method that includes obtaining, by a computer processor, well log data for various wells regarding a geological region of interest. The well log data corresponds to various well logs with different logging types. The method further includes assigning, by the computer processor and using a grouping algorithm, subsets of the well log data to various groups based on one or more geological attributes. The method further includes determining, by the computer processor and using the groups and a machine-learning algorithm, various well zones for different portions of a respective well among the wells. The method further includes determining, by the computer processor, extrapolated log data using the well log data, the well zones, and an interwell interpolation process. The method further includes generating, by the computer processor, a formation property volume based on the interpolated log data and the well log data.
In general, in one aspect, embodiments relate to a system that includes a logging system coupled to a logging tool. The system further includes a well system coupled to the logging system and a wellbore. The system further includes a reservoir simulator that includes a computer processor. The reservoir simulator is coupled to the logging system and the well system. The reservoir simulator obtains, using the logging tool, first well log data that is a portion of a second well log data for various wells regarding a geological region of interest. The second well log data corresponds to various well logs with different logging types. The reservoir simulator assigns, using a grouping algorithm, subsets of the second well log data to various groups based on one or more geological attributes. The reservoir simulator determines, using the groups and a machine-learning algorithm, various well zones for different portions of a respective well among the wells. The reservoir simulator determines interpolated log data using the well log data, the well zones, and an intrawell interpolation process. The reservoir simulator generates a formation property volume based on the interpolated log data and the second well log data.
In general, in one aspect, embodiments relate to a non-transitory computer readable medium storing instructions executable by a computer processor. The instructions obtain well log data for various wells regarding a geological region of interest. The well log data corresponds to various well logs with different logging types. The instructions assign, using a grouping algorithm, subsets of the well log data to various groups based on one or more geological attributes. The instructions determine, using the groups and a machine-learning algorithm, various well zones for different portions of a respective well among the wells. The instructions determine interpolated log data using the well log data, the well zones, and an intrawell interpolation process. The instructions generate a formation property volume based on the interpolated log data and the well log data.
The claimed subject matter's other aspects and advantages will be apparent from the following description and the appended claims.
Specific embodiments of the disclosed technology will now be described in detail regarding the accompanying figures. Like elements in the various figures are denoted by like reference numerals for consistency.
In the following detailed description of embodiments of the disclosure, numerous specific details are outlined to provide a more thorough understanding of the disclosure. However, it will be apparent to one of ordinary skill in the art that the disclosure may be practiced without these specific details. In other instances, well-known features have not been described in detail to avoid unnecessarily complicating the description.
Throughout the application, ordinal numbers (e.g., first, second, third, etc.) may be used as an adjective for an element (i.e., any noun in the application). The use of ordinal numbers is not to imply or create any particular ordering of the elements nor to limit any element to being only a single element unless expressly disclosed, such as using the terms “before,” “after,” “single,” and other such terminology. Instead, the use of ordinal numbers is to distinguish between the elements. By way of an example, a first element is distinct from a second element, and the first element may encompass more than one element and succeed (or precede) the second element in an ordering of elements.
In general, embodiments of the disclosure include systems and methods for generating and using a formation property volume based on acquired well log data, predicted log data, interpolated log data, and/or extrapolated log data. A hierarchical multi-stage machine-learning framework is used to obtain formation property values in a 2D or 3D geological region in some embodiments. For example, well logs may be obtained from many wells in single or multiple fields. After this well log consolidation, samples of well logs may be grouped into subsets of well log data according to various geological attributes and grouping algorithms (e.g., the grouping may be performed based on geological time periods using a clustering algorithm). After grouping, well zones may be determined that identify depth boundaries for well log data with common geological attributes, such as facies types, stratigraphic horizons, and geological time periods. Likewise, the group results and the well zones may be used in a training regime for one or more machine learning models. Thus, machine-learning models and machine-learning algorithms may be used in the following situations: (1) predictions for a different type of well log data from available well log data; (2) predictions for missing well log data for a well within an intrawell interpolation process; and (3) predictions for missing well log data in interwell regions between different wells using an interwell extrapolation process.
Furthermore, “intrawell interpolation” and “interwell extrapolation” may refer to multiple types of well log analyses and machine-learning techniques. In particular, both terms may include interpolation, extrapolation, and/or intrapolation of data. For illustration, where well log data is predicted in a three-dimensional volume, there may not be a clear distinction between a process that qualifies as an interpolation or an extrapolation. Accordingly, “intrawell interpolation” is intended to refer to any data prediction process that determines well log data within or proximate a single well (e.g., by predicting a missing type of well log data from available log data or predicting well log data beyond the furthest extent of a logging tool's depth range). Likewise, “interwell extrapolation” is intended to refer to any data prediction process that determines well log data between two or more wells.
Moreover, “interpolated log data” may refer to an output of an intrawell interpolation process, while “extrapolated log data” may refer to a result of an interwell extrapolation process.
Keeping with
Turning to the reservoir simulator (160), a reservoir simulator (160) may include hardware and/or software with functionality for storing and analyzing well logs (140), core sample data (150), seismic data, and/or other types of data to generate and/or update one or more formation property volumes (175). A formation property volume may describe well log data at one or more wells throughout a geological region of interest, such as gamma-ray data for an entire rock volume or reservoir volume. For example, a formation property volume may describe well log data in two-dimensions or three-dimensions. Thus, the formation property volume may include interpolated data from an intrawell interpolation process and/or extrapolated data from an interwell extrapolation process. For more information on intrawell interpolation processes and/or interwell extrapolation processes, see Blocks 240 and 250 in
While the reservoir simulator (160) is shown at a well site, the reservoir simulator (160) may be remote from a well site in some embodiments. In some embodiments, the reservoir simulator (160) is implemented as part of a software platform for the control system (114). The software platform may obtain data acquired by the drilling system (110) and logging system (112) as inputs, including multiple data types from various sources. The software platform may aggregate the data from these systems (110, 112) in real-time for rapid analysis. In some embodiments, the control system (114), the logging system (112), the reservoir simulator (160), and/or a user device coupled to one of these systems may include a computer system that is similar to the computer system (902) described below with regard to
The logging system (112) may include one or more logging tools (113) for use in generating well logs of the formation (106). For example, a logging tool may be lowered into the wellbore (104) to acquire measurements as the tool traverses a depth interval (130) (e.g., a targeted reservoir section) of the wellbore (104). The plot of the logging measurements versus depth may be referred to as a “log” or “well log”. Well logs (140) may provide depth measurements of the well (104) that describe such reservoir characteristics as formation porosity, formation permeability, resistivity, water saturation, and the like. The resulting logging measurements may be stored and/or processed, for example, by the control system (114), to generate corresponding well logs for the well (102). A well log (140) may include, for example, a plot of a logging response time versus true vertical depth (TVD) across the depth interval (130) of the wellbore (104).
Turning to examples of logging techniques, multiple types of logging techniques are available for determining various reservoir characteristics. Gamma-ray logging is used to measure naturally occurring gamma radiation to characterize rock or sediment regions within a wellbore in some embodiments. In particular, different types of rock may emit different amounts and different spectra of natural gamma radiation. For example, gamma-ray logs may distinguish between shales and sandstones/carbonate rocks because radioactive potassium may be common in shales. Likewise, the cation exchange capacity of clay within shales may also result in higher absorption of uranium and thorium, further increasing the amount of gamma radiation produced by shales.
Turning to nuclear magnetic resonance (NMR) logging, an NMR logging tool may measure the induced magnetic moment of hydrogen nuclei (i.e., protons) contained within the fluid-filled pore space of porous media (e.g., reservoir rocks). Thus, NMR logs may measure the magnetic response of fluids present in the pore spaces of the reservoir rocks. In so doing, NMR logs may measure both porosity and permeability and the types of fluids present in the pore spaces. Thus, NMR logging may be a subcategory of electromagnetic logging that responds to the presence of hydrogen protons rather than a rock matrix. Because hydrogen protons may occur primarily in pore fluids, NMR logging may directly or indirectly measure the volume, composition, viscosity, and distribution of pore fluids.
Keeping with NMR logging, NMR logging techniques may determine multiple signals for analyzing a geological region. First, NMR logging may determine spin-lattice relaxation values or a T1 signal amplitude measured from the buildup of magnetization along a static applied magnetic field. For example, T1 signal values may be mainly related to pore size and viscosity. NMR logging may also determine transverse relaxation values or a T2 signal amplitude that describes the decay of an excited magnetization perpendicular to an applied magnetic field. More specifically, a T2 signal may refer to the decaying time for hydrogen protons to complete dephasing. Likewise, NMR logging measurements may be illustrated as a T2 signal amplitude versus time and determine a distribution of porosity components (i.e., a T2 distribution) as a function of their T2 times. Thus, a T2 signal amplitude may be proportional to hydrogen content within a geological region and therefore may determine porosity independent of the rock matrix. Both relaxation times may provide information for determining pore-size information and pore-fluid properties, especially viscosity.
Turning to spontaneous potential (SP) logging, SP logging may determine the permeabilities of rocks in the formation (106) by measuring the amount of electrical current generated between drilling fluid produced by the drilling system (110) and formation water that is held in pore spaces of the reservoir rock. Porous sandstones with high permeabilities may generate more electricity than impermeable shales. Thus, SP logs may be used to identify sandstones from shales.
Another type of electrical logging technique is resistivity logging. Resistivity logging may measure the electrical resistivity of rock or sediment in and around the wellbore (104). In particular, resistivity measurements may determine what types of fluids are present in the formation (106) by measuring how effective these rocks are at conducting electricity. Because fresh water and oil are poor conductors of electricity, they have high resistivities. As such, resistivity measurements obtained via such logging can be used to determine corresponding reservoir water saturation (Sw).
Another electrical logging technique is dielectric logging. For example, dielectric permittivity may be defined as a physical quantity that describes the propagation of an electromagnetic field through a dielectric medium. As such, dielectric permittivity may describe a physical medium's ability to polarize in response to an electromagnetic field and thus reduce the total electric field inside the physical medium. In a portion of reservoir rock, water may have a large dielectric permittivity higher than any associated rock or hydrocarbon fluids within the portion. In particular, water permittivity may depend on a frequency of an electromagnetic wave, water pressure, water temperature, and salinity of the reservoir rock mixture. Likewise, a multi-frequency dielectric logging tool may determine the value of the water-filled porosity in the reservoir rock.
Keeping with dielectric logging, a dielectric logging tool may determine a dielectric constant (i.e., relative-permittivity) measurement. For example, the dielectric logging tool may include an antenna that detects relative dielectric constants between different fluids at a fluid interface. As such, a dielectric logging tool may generate a dielectric log of the high-frequency dielectric properties of a formation. In particular, a dielectric log may include two curves, where one curve may describe the relative dielectric permittivity of the analyzed rock. The other curve may describe the resistivity of the analyzed rock. Relative dielectric permittivity may be used to distinguish hydrocarbons from the water of differing salinities. However, the effect of salinity may be more important than the salinity effect with a high-frequency dielectric log (also called an “electromagnetic propagation log”).
Furthermore, dielectric logging tools may include low-frequency tools and high-frequency tools. A low-frequency dielectric logging tool may use coils on a mandrel and operate at tens of megahertz. For a high-frequency dielectric logging tool called an electromagnetic propagation tool (EPT), the dielectric logging tool may use a microwave antennae on a pad contact device. For example, the high-frequency dielectric logging tool may measure the propagation time and attenuation of an electromagnetic wave as the electromagnetic wave passes through a specific interval of formation. As such, electromagnetic waves may be sent sequentially by two transmitters in the dielectric logging tool, where receivers may measure the amplitude and phase shift of the transmitted electromagnetic waves.
Turning to caliper logging, one or more logging tools (113) may include a caliper logging tool. For example, a caliper logging tool may include hardware to determine a diameter of a borehole along with its depth. In particular, a caliper logging tool may measure variation in borehole diameters as the logging tool is withdrawn from the bottom of a borehole, using two or more articulated arms that push against the borehole wall. An articulated arm may be connected to a potentiometer that causes resistance to change as the diameter of the borehole changes, resulting in varying electrical signals that correspond to changes to diameter. After calibration, the caliper logging tool may generate a caliper log printed as a continuous series of hole diameter values or radius values with respect to depth.
Moreover, some caliper logging tools may use electromagnetic techniques or acoustic techniques to determine diameter sizes. For electromagnetic sensing techniques, a caliper logging tool may include a coil centered inside a tubular that generates an alternating magnetic field and another coil farther up the logging tool that measures phase shift introduced by the tubular. A caliper logging tool may include a transducer that detects a high-frequency pulse reflected from a tubular or a borehole wall back to the transducer for acoustic sensing techniques. As such, a diameter measurement may be determined from the time of flight of this reflected wave and a fluid's acoustic velocity. In some embodiments, a caliper logging tool is a multi-finger caliper. For an irregularly shaped wellbore, a multi-finger caliper may simultaneously determine diameters at several different locations. Within casing pipe and using a large number of arms (also called “fingers”), the caliper logging tool may detect small changes in the wall of the pipe. For illustration purposes, a multi-finger caliper may have between 20 and 80 fingers (compared to caliper logging tools with 2 or 4 fingers), where such larger numbers of fingers may be used in larger pipes. Thus, a caliper logging tool may detect deformations, scale buildup, and/or metal loss due to corrosion.
Keeping with
Turning to sonic logging or acoustic logging, the logging system (112) may measure the speed that acoustic waves travel through rocks in the formation (106) to determine porosity in the formation (106). This type of logging may generate borehole compensated (BHC) logs, which are also called sonic logs. In general, sound waves may travel faster through high-density shales than through lower-density sandstones.
Other types of logging include density logging and neutron logging. Density logging may determine porosity measurements by directly measuring the density of the rocks in the formation (106). Furthermore, neutron logging may determine porosity measurements by assuming that the reservoir pore spaces within the formation (106) are filled with either water or oil and then measuring the amount of hydrogen atoms (i.e., neutrons) in the pores. Other types of logging are also contemplated, such as resistivity logging and dielectric logging.
Turning to coring, reservoir characteristics may be determined using core sample data (e.g., core sample data (150)) acquired from a well site. For example, specific reservoir characteristics can be determined via coring (e.g., physical extraction of rock specimens) to produce core specimens and/or logging operations (e.g., wireline logging, logging-while-drilling (LWD), and measurement-while-drilling (MWD)). Coring operations may include physically extracting a rock specimen from a region of interest within the wellbore (104) for detailed laboratory analysis. For example, when drilling an oil or gas well, a coring bit may cut core plugs (or “cores” or “core specimens”) from the formation (106) and bring the core plugs to the surface. These core specimens may be analyzed at the surface (e.g., in a lab) to determine various formation characteristics (106) at the location where the specimen was obtained.
Turning to various coring technique examples, conventional coring may include collecting a cylindrical specimen of rock from the wellbore (104) using a core bit, a core barrel, and a core catcher. The core bit may have a hole in its center that allows the core bit to drill around a central cylinder of rock. Subsequently, the resulting core specimen may be acquired by the core bit and disposed of inside the core barrel. More specifically, the core barrel may include a special storage chamber within a coring tool for holding the core specimen. Furthermore, the core catcher may provide a grip to the bottom of a core, and, as tension is applied to the drill string, the rock under the core breaks away from the undrilled formation below coring tool. Thus, the core catcher may retain the core specimen to avoid the core specimen falling through the bottom of the drill string.
Keeping with
Returning to a reservoir simulator (160), a reservoir simulator (160) may include hardware and/or software with functionality for generating one or more machine-learning models (170) for use in analyzing the formation (106). For example, the reservoir simulator (160) may store well logs (140) and data regarding core samples (150), and further analyze the well log data, the core sample data, seismic data, and/or other types of data to generate and/or update one or more machine-learning models (170) and/or one or more formation property volumes (175). Thus, different types of machine-learning models may be trained, such as convolutional neural networks, deep neural networks, recurrent neural networks, support vector machines, decision trees, inductive learning models, deductive learning models, supervised learning models, unsupervised learning models, reinforcement learning models, etc. In some embodiments, two or more different types of machine-learning models are integrated into a single machine-learning architecture, e.g., a machine-learning model may include decision trees and neural networks. In some embodiments, the reservoir simulator (160) may generate augmented or synthetic data to produce a large amount of interpreted data for training a particular model.
With respect to neural networks, for example, a neural network may include one or more hidden layers, where a hidden layer includes one or more neurons. A neuron may be a modelling node or object that is loosely patterned on a neuron of the human brain. In particular, a neuron may combine data inputs with a set of coefficients, i.e., a set of network weights for adjusting the data inputs. These network weights may amplify or reduce the value of particular data input, thereby assigning significance to various data inputs for a task being modeled. A neural network may determine which data inputs should receive greater priority in determining one or more specified outputs of the neural network through machine learning. Likewise, these weighted data inputs may be summed such that this sum is communicated through a neuron's activation function to other hidden layers within the neural network. The activation function may determine whether and to what extent an output of a neuron progresses to other neurons where the output may be weighted again for use as an input to the next hidden layer.
In some embodiments, for example, a machine-learning algorithm is a grouping algorithm. A grouping algorithm may describe an unsupervised algorithm with a vector quantization method that uses data analysis, such as cluster analysis, to identify groups and label data points (e.g., wells or well log data portions) within the group. A group may correspond to a collection of data points aggregated together due to similarities among the data points. One example of a grouping algorithm is the k-means clustering algorithm. A target number k is determined, wherein k refers to many centroids in datasets and means refers to averaging the datasets. By reducing the in-cluster sum of squares, a k-means algorithm may identify a k number of centroids and then allocates data points to a particular cluster. For example, a vulnerability manager may use the k-means algorithm to data-mine by starting with an initial group of randomly selected centroids for every cluster. After determining an initial group, the vulnerability manager may iteratively optimize the positions of the centroids. Other types of grouping algorithms include hierarchical grouping, connectivity-based clustering, distribution-based grouping, density-based clustering, fuzzy clustering, and supervised grouping algorithms (e.g., using various constraints).
While
Turning to
In Block 200, well log data are obtained for various wells regarding a geological region of interest in accordance with one or more embodiments. In particular, the well log data may be acquired using one or more logging tools similar to various logging tools described above in
Furthermore, well log data may provide high-resolution measurements for exploration, development, reservoir characterization, and well management. Thus, logging tools may be employed in various fields, yielding large quantities of a large diverse and multimodal logging dataset. This aggregated well log data may be nonuniformly sampled within the geological region of interest due to irregular well spacing, different logging depth ranges, and limited availability of certain well log types of data at various well locations. While some wells may have a comprehensive set of well log data, many wells may have only basic well log types. Thus, the well log data may only cover limited depth ranges or certain depth segments of well log data may be missing. In other cases, particular types of well log measurements may have been acquired at very poor quality.
In Block 210, various subsets of well log data are assigned to various groups based on one or more geological attributes and using a grouping algorithm in accordance with one or more embodiments. In some embodiments, the grouping algorithm is an unsupervised machine-learning algorithm, such as k-means clustering, a weakly supervised machine-learning algorithm, or a supervised learning method, such as an eXtreme Gradient Boosting (XGBoost) algorithm. Likewise, the grouping algorithm may be implemented within an algorithmic model, such as a convolutional neural network (CNN) or a long short-term memory (LSTM). As such, well log data from different wells may be grouped based on one or more geological attributes, such as facies types, stratigraphy horizon correlations, and geological time periods of a respective formation.
Turning to
Returning to
A well zone is determined using a machine-learning algorithm in some embodiments, such as vertical smoothing (i.e., smoothing along a vertical direction) and/or horizontal smoothing (i.e., smoothing along a horizontal direction). For example, smoothing may be performed using one or more smoothing functions that determine a local domain or global domain for one or more geological attributes for a particular well zone. The smoothing functions may thus generate smoothed well log data for a respective well zone. An estimation of the underlying well log data associated with a geological attribute may be called a smooth. Examples of smoothing techniques may include regular bin smoothing or bin smoothing with a simple moving average (e.g., a variable bin-width with a fixed number of observations). Likewise, smoothing techniques may include a running line smoother, a kernel density smoother, and/or a locally estimated scatterplot smoother. Smoothing techniques may be based on well position information, such as northing and easting coordinates.
In some embodiments, one or more well zones are determined using a majority voting algorithm. For example, a majority voting algorithm may be a machine-learning algorithm that includes a voting ensemble (also called a “majority voting ensemble”) that may be an ensemble machine-learning model that combines the predictions from multiple other machine-learning models. Thus, a majority voting algorithm may determine well zones based on geological attributes with more accuracy than when using a single machine-learning model.
Turning to
Returning to
Furthermore, cross-modal prediction may be performed for a well of interest or adjacent wells. In a cross-modal prediction techniques, existing well log data in individual wells may be predicted for missing well log data using one or more deep learning techniques based on grouping results from one or more geological attributes. Moreover, a machine-learning model may be initially trained on well log samples from similar grouped well zones and then the trained model may be applied to wells with missing logs for prediction.
Turning to
Turning to
Returning to
In Block 250, extrapolated log data are determined using well log data, various well zones, and an interwell extrapolation process in accordance with one or more embodiments. For example, an interwell extrapolation process may determine log data at a predetermined location outside a logging depth range from adjacent well data Thus, an interwell extrapolation process may provide pseudo well log data at locations in-between actual logged wells for interwell regions.
In some embodiments, an interwell extrapolation process is based on seismic data. For example, seismic data may provide geological information regarding one or more interwell regions that are outside a logging tool's range. Thus, seismic data may provide an additional input to a machine-learning model or a machine-learning algorithm. However, in the absence of seismic data, the interwell extrapolation process may be based on well log data alone, such as spatial zoning and smoothing operations.
In Block 260, well log data, predicted log data, interpolated well log data, and/or extrapolated well log data are validated in accordance with one or more embodiments. In some embodiments, low-quality well log data is detected for various wells based on deviations from predicted log data. Once detected, the well log data may be corrected accordingly. Likewise, interpolated data and/or extrapolated data from an intrawell interpolation process and/or interwell extrapolation process, respectively, may be validated using predicted log data from one or more machine-learning models. For example, if the interpolated data or extrapolated data is within a predetermined degree of accuracy of the predicted log data, such data is validated for usage in one or more applications or inclusion in a formation property volume.
Turning to
Keeping with
Returning to
Turning to
Embodiments may be implemented on a computer system.
The computer (902) can serve in a role as a client, network component, a server, a database or other persistency, or any other component (or a combination of roles) of a computer system for performing the subject matter described in the instant disclosure. The illustrated computer (902) is communicably coupled with a network (930). In some implementations, one or more components of the computer (902) may be configured to operate within environments, including cloud-computing-based, local, global, or other environment (or a combination of environments).
At a high level, the computer (902) is an electronic computing device operable to receive, transmit, process, store, or manage data and information associated with the described subject matter. According to some implementations, the computer (902) may also include or be communicably coupled with an application server, e-mail server, web server, caching server, streaming data server, business intelligence (BI) server, or another server (or a combination of servers).
The computer (902) can receive requests over a network (930) from a client application (for example, executing on another computer (902)) and responding to the received requests by processing the said requests in an appropriate software application. In addition, requests may also be sent to the computer (902) from internal users (for example, from a command console or by other appropriate access method), external or third-parties, other automated applications, as well as any other relevant entities, individuals, systems, or computers.
Each of the computer components can communicate using a system bus (903). In some implementations, any or all of the components of the computer (902), both hardware or software (or a combination of hardware and software), may interface with each other or the interface (904) (or a combination of both) over the system bus (903) using an application programming interface (API) (912) or a service layer (913) (or a combination of the API (912) and service layer (913). The API (912) may include specifications for routines, data structures, and object classes. The API (912) may be either computer language independent or dependent and refer to a complete interface, a single function, or even a set of APIs. The service layer (913) provides software services to the computer (902) or other components (whether or not illustrated) that are communicably coupled to the computer (902). The functionality of the computer (902) may be accessible for all service consumers using this service layer. Software services, such as those provided by the service layer (913), provide reusable, defined business functionalities through a defined interface. For example, the interface may be software written in JAVA, C++, or other suitable language providing data in extensible markup language (XML) format or another proper format. While illustrated as an integrated component of the computer (902), alternative implementations may illustrate the API (912) or the service layer (913) as stand-alone components in relation to other components of the computer (902) or other components (whether or not illustrated) that are communicably coupled to the computer (902). Moreover, any or all parts of the API (912) or the service layer (913) may be implemented as child or sub-modules of another software module, enterprise application, or hardware module without departing from the scope of this disclosure.
The computer (902) includes an interface (904). Although illustrated as a single interface (904) in
The computer (902) includes at least one computer processor (905). Although illustrated as a single computer processor (905) in
The computer (902) also includes a memory (906) that holds data for the computer (902) or other components (or a combination of both) that can be connected to the network (930). For example, memory (906) can be a database storing data consistent with this disclosure. Although illustrated as a single memory (906) in
The application (907) is an algorithmic software engine providing functionality according to particular needs, desires, or particular implementations of the computer (902), particularly with respect to the functionality described in this disclosure. For example, application (907) can serve as one or more components, modules, applications, etc. Further, although illustrated as a single application (907), the application (907) may be implemented as multiple applications (907) on the computer (902). In addition, although illustrated as integral to the computer (902), in alternative implementations, the application (907) can be external to the computer (902).
There may be any number of computers (902) associated with, or external to, a computer system containing a computer (902), each computer (902) communicating over a network (930). Further, the term “client,” “user,” and other appropriate terminology may be used interchangeably as appropriate without departing from the scope of this disclosure. Moreover, this disclosure contemplates that many users may use one computer (902) or that one user may use multiple computers (902).
In some embodiments, the computer (902) is implemented as part of a cloud computing system. For example, a cloud computing system may include one or more remote servers and various other cloud components, such as cloud storage units and edge servers. In particular, a cloud computing system may perform one or more computing operations without direct active management by a user device or local computer system. As such, a cloud computing system may have different functions distributed over multiple locations from a central server, which may be performed using one or more Internet connections. More specifically, cloud computing system may operate according to one or more service models, such as infrastructure as a service (IaaS), platform as a service (PaaS), software as a service (SaaS), mobile “backend” as a service (MBaaS), serverless computing, artificial intelligence (AI) as a service (AIaaS), and/or function as a service (FaaS).
Although only a few example embodiments have been described in detail above, those skilled in the art will readily appreciate that many modifications are possible in the example embodiments without materially departing from this invention. Accordingly, all such modifications are intended to be included within the scope of this disclosure as defined in the following claims. In the claims, any means-plus-function clauses are intended to cover the structures described herein as performing the recited function(s) and equivalents of those structures. Similarly, any step-plus-function clauses in the claims are intended to cover the acts described here as performing the recited function(s) and equivalents of those acts. It is the express intention of the applicant not to invoke 35 U.S.C. § 112(f) for any limitations of any of the claims herein, except for those in which the claim expressly uses the words “means for” or “step for” together with an associated function.