The embodiments described below relate to systems for statistical emulations, the embodiments further relate to systems for statistical emulations for simulation models.
Statistical emulators represent a general type of statistical model used in the context of making the maximum use of the outputs of complicated computer-based simulation models. Reservoir simulators are slow when compared with emulators and require considerably more computer resources than emulators. Emulators provide a fast approximation of the simulation model and are used when each evaluation of the simulation model is computationally expensive. Normally, the inputs to the simulation model are fixed, chosen, values and the output is expected to be deterministic. In this setting, emulators have proven to be useful tools used to accelerate both history matching and optimization of oil & gas reservoir models.
In some reservoir simulation applications, inputs to the simulation model are random variables whose values are defined as probability distributions. The most common example of this is found in an optimization under uncertainty workflow. In these workflows geological inputs are random variables of known distribution whilst the control inputs being optimized are defined values. The uncertain inputs must be sampled to be able to run the simulation model. This results in the output of the simulation model having a degree of randomness and, in effect, the model with control inputs becomes a stochastic simulation model.
Stochastic emulators have been developed that can approximate stochastic simulation models. Such emulators typically require many simulation evaluations (‘runs’) to accurately capture the randomness in the simulation model. These emulators have been used to accelerate workflows where the model is stochastic owing to the presence of uncertain inputs. However, the large number of runs required can make analyzing these models difficult even when using emulation techniques.
Closed loop reservoir management using simulation models is an important method used to determine the most beneficial way to develop oil & gas fields. It is a combination of model-based optimization and data assimilation. In a closed loop system production measurements and geological measurements are used with data assimilation algorithms to update geological parameters in reservoir simulation models. Once the model parameters are updated the reservoir model can be used to optimize production controls, such as well trajectories and bottom hole pressures. The optimized production controls are used to define the field development plan and applied to the real reservoir. As new measurements become available, the process is repeated.
After the measurements are assimilated into the reservoir model, the estimated parameters will still have a degree of uncertainty associated with them. Few optimization methods allow uncertainties in the model to be accounted for and the utility of any field development decision is greatly affected by uncertainties. Thus, a method for constructing stochastic emulators may be required that can produce high quality emulators for fewer runs than is currently possible. The stochastic emulators may be used in a Bayesian optimization workflow to allow optimization of reservoir control parameters under geological uncertainty.
Existing methods for generating stochastic emulation models are inefficient and ineffective, typically failing to accurately emulate the simulation models the emulation models are supposed to represent. In part, this is due to each design point being treated independently and failing to capitalize on relationships between the various design points.
Accordingly, there is a need for improving the efficiency of methods that allow for optimization of reservoir models under uncertainty.
A method for generating a stochastic emulation model is disclosed. In an embodiment, the method uses a computer (100) having a processor (110) configured to execute commands stored on a non-transitory memory element (120), the non-transitory memory element (120) having an emulation module (124). The method includes generating, by the emulation module (124), a stochastic emulation model (β) from the output of a deterministic emulation model (η).
A computer system (100) for generating a stochastic emulation model is disclosed. In an embodiment, the computer system (100) has a processor (110) configured to execute commands stored on a non-transitory memory element (120), the non-transitory memory element (120) having an emulation module (124). The emulation module is configured to generate a stochastic emulation model (β) from the output of a deterministic emulation model (η).
According to an aspect, a method for generating a stochastic emulation model, using a computer (100) having a processor (110) configured to execute commands stored on a non-transitory memory element (120), the non-transitory memory element (120) having an emulation module (124) is disclosed. The method includes generating, by the emulation module (124), a stochastic emulation model (β) from the output of a deterministic emulation model (η).
Preferably, the generating a stochastic emulation model (β) from the output of a deterministic emulation model (η) includes determining, by the emulation module (124), a partial output (γi).
Preferably, the generating a stochastic emulation model (β) from the output of a deterministic emulation model (η) further includes determining, by the emulation module (124), at least one building function (γ) based on one or more of sample outputs of the deterministic emulation model (η) and the partial output (γi).
Preferably, the determining a partial output (γi) includes determining the partial output (γi) by aggregating all outputs of the deterministic emulation model (η) from inputs of a single control design point (xi) and all geologic random points of all geologic random variables (Y) used in the stochastic emulation model (β), wherein the generating, by the emulation module (124), a stochastic emulation model (β) from the output of a deterministic emulation model (η) comprises using, by the emulation module (124), the partial output (γi) to generate the stochastic emulation model (β).
Preferably, the generating a stochastic emulation model (β) from the output of a deterministic emulation model (η), further includes, determining, by the emulation module (124), a trend of the partial output (γi), wherein the generating, by the emulation module (124), a stochastic emulation model (β) from the output of a deterministic emulation model (η) includes using, by the emulation module (124), the trend of the partial output (γi) to generate the stochastic emulation model (β).
Preferably, the trend of the partial output (γi) is one or more of an average of the partial output (
Preferably, the determining, by the emulation module (124), at least one building function (γ), further includes accounting for the trend of the partial output (γi).
Preferably, the generating a stochastic emulation model (β) from the output of a deterministic emulation model (η) further includes accounting for a trend in building function (γ) when determining, by the stochastic emulation module (124), the stochastic emulation model (β) based on the building function (γ).
Preferably, the method for generating a stochastic emulation model (β) further includes generating, by a simulation module (122), a deterministic simulation model (f(x,y)) from a stochastic simulation model (f(x,Y)) by providing fixed samples, y, for the random variables Y to the stochastic simulation module (f(x,Y)).
Preferably, the method for generating a stochastic emulation model further includes generating, by the emulation module (124), the deterministic emulation model (η) from the deterministic simulation model (f(x,y)).
Preferably, the method further includes determining or receiving, by the emulation module (124), data representing at least one control design point (x) and data representing at least one geologic random point (y) and selecting, by the emulation module (124), from the at least one geologic random point (y), at least one sample geologic random point (ysample), wherein the output of the deterministic emulation model (η) is at least one output from inputs of the at least one control design point (x) and the at least one sample geologic random point (ysample).
Preferably, the at least one geologic random point (y) is a set of points representing a random distribution.
Preferably, the at least one geologic random point (y) represents a parameter in a model that is difficult to measure or determine, the random distribution representing known, measured or estimated variation in the parameter.
Preferably, the method further includes updating, by the emulation module (124), the stochastic emulation model (β), using emulation update techniques, to generate an updated stochastic emulation model (βnew), wherein the emulation update techniques account for the stochastic emulation model (β).
Preferably, the updating, by the emulation module (124), the stochastic emulation model (β) further includes determining, by the emulation module (124), a new building function (γnew) based on a new deterministic emulation model (ηnew), determining, by the emulation module (124), new partial outputs (γnew,i) from the new building function (γnew), wherein the stochastic emulation model (β) is updated based on the partial outputs (γnew,i).
Preferably, the method further includes determining, by the emulation module (124), another partial output (γs) of the building function (γ), wherein the determining, by the emulation module (124), a partial output (γi) of the building function (γ), further comprises transmitting, by the emulation module (124), data representing the building function (γ) and data representing input variables for generating the partial output (γi) to a processing element of a parallel processing system, and wherein the determining, by the emulation module (124), another partial output (γs) of the building function (γ) further comprises transmitting, by the emulation module (124), data representing the building function (γ) and data representing different input variables for generating the another partial output (γs) to another processing element of a parallel processing system.
Preferably, the stochastic emulation model and the deterministic emulation model are models of a simulation model of a reservoir.
Preferably, the method further includes determining, by the emulation module (124), a new deterministic emulation model (ηnew), by determining, by the simulation module (122), a new deterministic simulation model (f(x,y,)new) from the stochastic simulation model (f(x,Y)), and determining, using the emulation module (124) a new deterministic emulation model (ηnew) from the new deterministic simulation model (f(x,y,)new).
Preferably, the method further includes generating, by the emulation module (124) an updated stochastic emulation model (βnew), based on the new deterministic emulation model (ηnew) and a prior stochastic emulation model (β).
Preferably the generating, by the emulation module (124) an updated stochastic emulation model (βnew), based on the new deterministic emulation model (ηnew), further includes determining one or more of a new or updated building function (γnew) and a new or updated partial output (γnew,i).
According to an aspect, a computer system (100) for generating a stochastic emulation model, having a processor (110) configured to execute commands stored on a non-transitory memory element (120), the non-transitory memory element (120) having an emulation module (124) is disclosed. The emulation module (124) is configured to generate a stochastic emulation model (β) from the output of a deterministic emulation model (η).
Preferably, the emulation module (124) is further configured to determine a partial output (γi).
Preferably, the emulation module (124) is further configured to determine at least one building function (γ) based on one or more of sample outputs of the deterministic emulation model (η) and the partial output (γ).
Preferably, the emulation module (124) is further configured to generate the partial output (γi) by aggregating all outputs of the deterministic emulation model (η) from inputs of a single control design point (xi) and all geologic random points of all geologic random variables (y) used in the stochastic emulation model (|), and generate the stochastic emulation model (β) based on the partial output (γ).
Preferably, the emulation module (124) is further configured to determine, by the emulation module (124), a trend of the partial output (γi), and generate the stochastic emulation model (β) based on the trend of the partial output (γi).
Preferably, the trend of the partial output (γi) is one or more of an average of the partial output (
Preferably, the emulation module (124) is further configured to determine at least one building function (γ) based on the trend of the partial output (γi).
Preferably, the emulation module (124) is further configured to determine the stochastic emulation model (β) based on one or more of the building function (γ) and a trend in the building function (γ).
Preferably, the computer system (100) further including a simulation module (122), the simulation module (122) configured to generate a deterministic simulation model (f(x,y)) from a stochastic simulation model (f(x,Y)) by providing fixed samples, y, for the random variables Y to the stochastic simulation module (f(x,Y)).
Preferably, the emulation module (124) is further configured to generate the deterministic emulation model (η) from the deterministic simulation model (f(x,y)).
Preferably, the emulation module (124) is further configured to determine data representing at least one control design point (x) and data representing at least one geologic random point (y) and select from the at least one geologic random point (y), at least one sample geologic random point (ysample), wherein the output of the deterministic emulation model (η) is at least one output from inputs of the at least one control design point (x) and the at least one sample geologic random point (ysample).
Preferably, the at least one geologic random point (y) is a set of points representing a random distribution.
Preferably, the at least one geologic random point (y) represents a parameter in a model that is difficult to measure or determine, the random distribution representing known, measured or estimated variation in the parameter.
Preferably, the emulation module (124) is further configured to update the stochastic emulation model (β), using emulation update techniques, to generate an updated stochastic emulation model (βnew), wherein the emulation update techniques account for the stochastic emulation model (β).
Preferably, the emulation module (124) is further configured to update the stochastic emulation model (β) by being configured to determine a new building function (γnew) based on a new deterministic emulation model (ηnew), and determine new partial outputs (γnew,i) from the new building function (γnew), wherein the emulation update is based on partial outputs (γnew,i).
Preferably, the emulation module (124) is further configured to determine another partial output (γs) of the building function (γ), transmit data representing input variables for generating the partial output (γi) to a processing element of a parallel processing system, and transmit data representing different input variables for generating the another partial output (γs) to another processing element of a parallel processing system.
Preferably, the stochastic emulation model and the deterministic emulation model are models of a simulation model of a reservoir.
Preferably, the computer system (100) is further configured to determine a new deterministic emulation model (ηnew), by determining, by the simulation module (122), a new deterministic simulation model (f(x,y,)new) from the stochastic simulation model (f(x,Y)), and determining, using the emulation module (124), a new deterministic emulation model (ηnew) from the new deterministic simulation model (f(x,y,)new).
Preferably, the emulation module (124) is further configured to generate an updated stochastic emulation model (βnew), based on the new deterministic emulation model (ηnew) and a prior stochastic emulation model (β).
Preferably, the emulation module (124) is further configured to determine one or more of a new or updated building function (γnew) and a new or updated partial output (γnew,i).
The same reference number represents the same element on all drawings. It should be understood that the drawings are not necessarily to scale.
The techniques proposed here may provide methods to build a statistical emulator for the production controls incorporating the uncertainty from the geological parameters. This may allow optimization of the controls under the geological uncertainty. Variations on the typical closed loop system include ‘little loop’ and ‘big loop’. In a little loop system, the reservoir model is a simulation model with a fixed geological grid and comparatively few, low dimensional, geological uncertainty parameters. In a big loop system, the reservoir model is a simulation model coupled to a detailed geological modelling package. In big loop there can be many more, high dimensional, geological uncertainty parameters. Statistical emulators of the kind described here can often struggle to represent many high dimensional parameters. The inventive method may employ effective parameter limiting techniques as well as other techniques to reduce the complexity of the problem, and the same principles may be extended to big loop applications.
Optimization under uncertainty either may require an optimizer capable of optimizing stochastic models or may either additionally or separately require the combination of regular deterministic optimization techniques with an auxiliary method of modelling the uncertainty. Different approaches can be taken to model uncertainty in an optimization framework. A simple approach is to use Monte Carlo simulation, in which lots of samples of the random inputs are generated and the simulation model run for each sample. This results in a set of simulation model outputs that can be interpreted using statistical techniques. This approach is straightforward to implement but may require many simulation runs to obtain accurate results. Monte Carlo simulation has been shown to be impractical in large scale reservoir simulation applications.
Bayesian optimization techniques in which an optimizer is combined with a statistical emulator, are commonly used to optimize controls for reservoir simulation models. In the Bayesian optimization setting a stochastic statistical emulator can be used to model the uncertainty. Statistical emulators are analytical functions that can approximate the response of the reservoir simulation model. This may facilitate fast evaluation of the response for large numbers of input parameters. Emulators may be built in conjunction with experimental design techniques such as Latin hypercube sampling. Experimental design techniques specify a set of inputs, referred to as design points, to the simulation model. This set of inputs may be chosen to explore the input parameter space efficiently. This can allow accurate emulators to be created with smaller numbers of runs as input. Once an emulator has been set up and verified for a given reservoir simulation model it may be used in place of the simulation model. Fast evaluation of the emulator may lead to improved efficiency when performing history matching or when optimizing model outputs.
Emulation techniques may be extended to allow approximation of stochastic simulation models. Creating stochastic emulators may require an estimate of the mean and variance of the stochastic simulation model at each experimental design input point. Methods may make use of simple random sampling, or repetition runs, to estimate the mean and variance e.g. running the simulation model repeatedly with the same inputs. However, such simple random sampling, which is effectively a form of Monte Carlo simulation, requires a large number of samples to obtain accurate estimates of the mean and variance. This can lead to a prohibitive number of simulation runs being required when creating a stochastic emulator for a stochastic simulation model.
The methods disclosed may provide a system for constructing emulators of a stochastic reservoir simulation model where the distributions of any random variables in the model are known or can be estimated. The method may initially treat the stochastic reservoir model as a deterministic reservoir model, perhaps by including the random variables that are responsible for the stochastic nature of the model as inputs. Emulator construction techniques may be used to build an emulator for the deterministic version of the reservoir model. Samples from this first emulator may be used as inputs to build a second, stochastic, emulator for the stochastic version of the reservoir model. This emulator may show higher accuracy for the corresponding number of simulator runs than a stochastic emulator created using other techniques.
These emulators may have many and varied usages. For instance, the emulators may be used to determine the best locations on a map, representing a physical site, in which certain operations should be conducted. The operations may include, for instance, drilling to establish a well at a site, moving a well from one site to another site, determine where the faults are, determine where to inject fluids to compel underground fluids to move from the subsurface. The emulators may also provide insight into certain operating parameters, for instance, well injector pressures, producing well pressures, injector fluid flowrates, gas and oil output flowrates, and/or the like. The emulator may be used to determine parameters for maximizing certain outcomes, for instance, the amount of oil and gas produced. The emulator may be used to determine parameters for minimizing certain outcomes, such as the amount of wastewater produced.
This invention exploits the source of randomness in this case and streamlines the creation of emulators for simulation models with uncertain inputs. This results in far fewer runs being required to produce an accurate emulator. This allows the acceleration of optimization workflows for reservoir simulation models with uncertain inputs.
The computer system 100 may execute a two-stage method for generating a stochastic emulation model (β) that emulates the simulation model f(x,Y). In a first stage, a deterministic emulation model (η) may be constructed for the simulation model f(x,Y) by treating the random variables in the simulation model f(x,Y) as known quantities. The deterministic emulation model (η) may be used to generate at least one building function (γ). In a second stage, stochastic emulation model (β) may be generated for the control inputs to the simulation model using at least one building function (γ).
In various embodiments the computer system 100 may be comprised of application specific integrated circuits or may have a discrete processor and memory elements, the processor elements for processing commands from and storing data on the memory elements. The computer system 100 may be configured to store data representing parameters received from other systems representing geologic models and representative variable values.
The computer system 100 may have a processor 110, a memory 120, and an input/output 130. The memory 120 may store and/or may have integrated circuits representing, for instance, a simulation module 122 and/or an emulation module 124. In various embodiments, the computer system 100 may have other computer elements integrated into the stated elements or in addition to or in communication with the stated computer elements, for instance, buses, other communication protocols, and the like.
The processor 110 is a data processing element. The processor 110 may be any element used for processing such as a central processing unit, application specific integrated circuit, other integrated circuit, an analog controller, graphics processing unit, field programmable gate array, any combination of these or other common processing elements and/or the like. The processor 110 may have separate cores in order to facilitate parallel processing, perhaps of multiple variables simultaneously or multiple steps of the methods or module steps described in this specification.
The memory 120 is a device for electronic storage. The memory 120 may be any non-transitory storage medium and may include one, some, or all of a hard drive, solid state drive, volatile memory, integrated circuits, a field programmable gate array, random access memory, read-only memory, dynamic random-access memory, erasable programmable read-only memory, electrically erasable programmable read-only memory, and/or the like. The processor 110 may execute commands from and utilize data stored in the memory 120.
In an embodiment, the computer system 100 may be a standalone computing device, a virtual machine, and/or a cloud computing element. The computer system 100 may also communicate with a cloud computing environment. For instance, for compute intensive operations or highly parallelizable computations, the computer system 100 may communicate with external compute resources to conduct some of the methods, individual steps of the methods, routines within the steps of methods, or any combination thereof in this specification, the compute resources being, for instance, a cloud computing element, a server, other multiple processing devices, and/or external devices with graphics processor units.
The computer system 100 may be configured to store any data that will be used by the simulation module 122 and/or the emulation module 124 and may store prior iterations of simulation models or various outputs for the emulation models with respect to specific control design point and/or random geologic point values. The computer system 100 may also store any data that represents emulation instances, and sub-step emulation intermediates. While the simulation module 122 and emulation module 124 are represented as separate and discrete modules in this specification, it can be appreciated that all of the methods in this specification can be accomplished by any number of modules, including one or more discrete modules working in isolation or in concert.
For the purposes of this specification, two sets of variables may be considered. A first set of variables are control design variables (also referred to as “x”), having particular values called control design points or design values (for example, “xi”). Control design variables represent quantities that can be definitively controlled and/or can be optimized. Control design variables, therefore, are not random variables in simulation modeling. For instance, in an oil and/or gas context, these variables may include, for instance variables representing a location and trajectory of a well, flowrate of water injected into an injector well, pump pressures, a pressure at the top of a producer well, flowrates, depth of a well, location of a top of a reservoir, location of a bottom of a reservoir, size of well perforations, locations of well perforations, and/or the like. In the context of shale oil production, the control design variables may include location and size of well fracture stages as well as pressure and composition of injected well fracking fluid. In an embodiment, the control design variables may be multi-dimensional, such that each value of x is a tensor of values representing measurable and/or controllable non-random conditions (e.g. in an embodiment, a single xi could have one value for each of well location, drill depth, and well pressure). The control design variables may be determined by the simulation module 122, the emulation module 124, and/or may be specified by a user. Also, although the term control design variables are used to refer to the class of variables, the specific values of those control design variables used for input may vary in individual steps. For instance, the simulation may be built using different control design values from ones used in emulation. Further, within emulation, different control design values may be used for each emulation step. In alternative embodiments, the same control design values may be used for some of the steps and different control design values may be used for some of the steps.
For the purposes of explanation, x may be characterized as having index values of 1 to N, represented by the following:
X=(xi;i=1, . . . ,N),
with x representing an individual control variable for the models.
Also, for purposes of explanation, a subset of x values may be used as sample control design variables, hereinafter, xsample:
x
sample
⊂X
x
sample=(xsample,f;f=1, . . . ,K)
A second set of variables are geologic random variables (from a distribution “Y” ˜P, with specific subsets referred to as “y”), having particular values called geologic random points or values (for example, “yj”). The geologic random variables are random values. For each yj, there may be a number of parameters each having a single value (e.g. in an embodiment, each yj is a tensor having a rock porosity value, a fault location value, and rock permeability value). The geological random variables may represent quantities that have uncertain values. These are quantities that are difficult to measure or cannot be measured directly, such as subsurface parameters. Subsurface parameters may include, for instance, rock permeability, rock porosity, fault locations, facies locations, water saturation, and/or the like. The geologic random variables may be well-represented by types of random distributions, for instance, a Gaussian distribution, a Beta distribution, Triangle distribution, and Uniform distribution. The geologic random variables may be better represented by simple ranges with no specific weighting given to any particular range within the simple range, for instance, representative of a Uniform distribution. The geologic random variables may be assigned assumed values or may be based on a random distribution. Random distributions may be established by the computer system 100 based on raw data or may be received from another computer source or modules outside of those described in this specification. For example, the distribution may be defined and approximated by a large number of samples generated by a statistical method such as Markov Chain Monte Carlo or other computer source or modules outside of this specification. The ranges or distributions of the geologic random variables may be informed by realistic values typical of the conditions in the field. For instance, samples may have been taken or seismic readings may indicate particular ranges and/or distributions of values for geologic random variables. Also, although the term, geologic random variables, is used to refer to the class of variables, the specific values of those control design variables used for input may vary in individual method steps. For instance, the simulation may be built using different geologic random values from ones used in emulation. Further, within emulation, different geologic random values may be used for each emulation step. In alternative embodiments, the same geologic random values may be used for some of the steps and different geologic random values may be used for some of the steps.
For the purposes of explanation, Y is a random variable having a probability distribution, P, and y is a realization, or sample, of the random variable, Y, their relationship characterized by:
Y˜P
{y=Y}
y=(yj;j=1, . . . ,M)
Also, for purposes of explanation, a subset of the y values may be used as sample geologic random variables, hereinafter, ysample:
y
sample
⊂y
y
sample=(ysample,f;f=1, . . . ,K)
All combinations of embodiments with certain values of control design variables and geologic random variables are contemplated. For instance, a simulation and emulation may be conducted with the same y values but different x values, a simulation and emulation may be conducted with the same y values and same x values, the simulation and emulation may be conducted with the same y values with the emulation being conducted with individual steps having different x values, and/or the emulation may be conducted with y values being different from those of the simulation but the x values of one of the individual steps may be the same as the x values used in the simulation, and the like. These are merely exemplary, and all combinations, including all combinations of sequential differences in values are contemplated. In an embodiment, particular x values for particular x variables may be used only once with a given y value for a particular y variable.
The simulation module 122 is a module that creates a simulation model, perhaps of an oil & gas reservoir. The simulation model may be constructed by combining simulated physics with measured or sampled geophysical data. This data may include, for instance, seismic, gravimetric and other geologic spatial measured data, as well as sample porosity, permeability, water saturation and/or other geophysical data determined, perhaps, by taking well log and well core samples.
The simulation module 122 may create a simulation model of a reservoir. In an embodiment, the simulation module 122 may identify, determine, and/or receive inputs, representing control design points and geologic random points. The inputs may be determined in advance and received by the simulation module 122 or the emulation module 124, the inputs may be determined by the simulation module 122 or the emulation module 124, or the inputs may be chosen randomly by the simulation module 122 or the emulation module 124 from a variety of pre-specified likely values, for instance, a range or probability distribution. The simulation module 122 and/or the emulation module 124 may determine a number of control design points or may receive from a user or other program a specified number of control design points. In another embodiment the emulation module 124, not the simulation module 122, generates the geologic random points and control design points. The simulation module 122 and/or the emulation module 124 may use experimental design techniques, for instance, Latin hyper cube sampling, to decide where to sample the control design points and/or the geologic random points for generating a deterministic simulation model (f(x,y)), from a stochastic simulation (f(x,Y)).
In an embodiment, the simulation module 122 may output a deterministic simulation model (f(x,y)) from values of geologic random variables and control design variables. For instance, the simulation module can generate a stochastic simulation model (f(x,Y)) which takes as inputs the distribution of Y˜P. Using some sample subset of geologic random variables, ysample, the simulation module 122 can use (f(x,Y)) to generate a deterministic simulation model, f(x,ysample) (hereinafter referred to as “f(x,y)”) accounting for the randomness reflected in the sample, itself.
The emulation module 124 is a module that generates emulation models. The emulation module 124 may output a deterministic emulation model (η) representing a deterministic simulation model (f(x,y)). The emulation module 124 may receive or determine a deterministic simulation model (f(x,y)), for instance, a reservoir simulation model. The emulation module 124 may use stochastic input values obtained from the deterministic emulation model (η) to build a stochastic emulation model (β). The stochastic emulation model (β) emulates the stochastic simulation model (f(x,Y)). The stochastic emulation model (β) may account for the variability in parameters represented by the geologic random variables that cannot readily be measured or are measured with accompanying uncertainty.
In order to generate the stochastic emulation model (β), the emulation module 124 may initially generate or receive a deterministic emulation model (η) based on a deterministic simulation model (f(x,y)) that is received by the emulation module 124. The emulation module 124 may determine control design points and geologic random points for generating the initially generated deterministic emulation model (η) using a design technique, for instance, Latin hypercube sampling. Geologic random points may be chosen by choosing values within the random distribution of each geologic random variable considered or the emulation module 124 may use all of the values of the geologic random variables considered by the model. In an embodiment, the simulation module 122 and/or the emulation module 124 may use stratified sampling to determine samples. For instance, the choice of the random variables to sample may be random or may be chosen to best represent the distribution, perhaps by selecting the geologic random values at uniform intervals within the distribution. The simulation module 122 may run the simulation model (f(x,y)) at every combination of chosen control design point and chosen geologic random variable point or range of geologic random points. A trend fitting technique may be used by the emulation module 124 to generate the deterministic emulation model (η) from the response data from the simulation model (f(x,y)), the responses being the outputs of the simulation model (f(x,y)) corresponding to the control design points and the geologic random points. The curve fitting technique to generate the deterministic emulation model (η) may be, for instance, Bayes linear emulation methodology, Polynomial Chaos Expansion, Gaussian process regression (also known as “Kriging”), and/or techniques commonly used in the art. Other curve fitting techniques to establish emulators are well-known in the art. The deterministic emulation model may be a function of x and y (e.g. may be η(x,y)). Because the determinations of outputs of the simulation model are relatively independent of one another, the simulation module may parallelize these determinations using, for instance, any parallel processing cores, perhaps transmitting the source data to multiple cores with shared local memory. Similarly, the emulation module 124 may parallelize the determinations of the emulation from any partial outputs.
In order to generate the stochastic emulation model (β) from the deterministic emulation module (η), the emulation module 124 may strategically or randomly select certain geologic random points for each geologic random variable considered in order to make a sample set, ysample. Geologic random points may be chosen by choosing values within the random distribution of each geologic random variable considered. These values may be representative of the random distribution, P. The choice of the random variables to sample may be random with or may be chosen to best represent the distributions for each random variable, P, perhaps by selecting the geologic random values at uniform intervals (e.g. y=5, y=10, y=15 . . . ) or uniform discrete sequential steps (e.g. y5, y10, y15 . . . ) between values within the distribution. The emulation module 124 may use a subset or all of the control design points, xsample. In an embodiment, xsample is just x, representing that all values of x are sampled. The emulation module 124 may use the same or different control design values as were used in the creation of the deterministic emulation model (η). The emulation module 124 may take, as input to the deterministic emulation model (η), the sample control design values, xsample, and the sample geologic random values, ysample, and generate output from the deterministic emulation model (η). The emulation module 124 may determine which control design points to compare with which geologic random points using an experimental design technique, for instance, Latin Hypercube sampling. A curve fitting technique may then be used to generate building functions (γ) that represent the relationship between the outputs of the deterministic emulation model (η), the sample control design values (xsample) and the sample geologic random values (ysample), the building functions (γ) perhaps being continuous functions. For purposes of demonstration, if the emulation module 124 were to generate the building functions (γ) from a single geologic random variable and a single control design variable (see e.g.
The emulation module 124 may use the building functions (γ) to determine the stochastic nature of an outputted stochastic emulation model (β). For each design control point, the emulation module 124 may generate a partial building function (hereinafter, “γi”) for each design control point value with respect to all of the geologic random values. To be clear, all of the geologic random values may include all of the values of y, not merely the y values in the set of ysample. For instance, with each specified combination of control design variables, xi, all relevant values of geologic random variables are inputted to generate outputs γi. These outputs may yield a specific range of output values, representing the partial output, γi, for each value of xi (xi representing a single combination of control design values of a single control design point) with respect to all specified y values. The y values chosen, again, may be the entire set of y values, perhaps representing a probability distribution.
This partial emulation function may be characterized by:
γi comprises the entire set of γ(xi, yi) for all j=1 to M.
The emulation module 124 may determine a trend for each range of partial output values (γi) associated with each of the xi values in relation to all of the y values. These trends may include establishing a distribution for all values in γi. For instance, for each xi, a partial output γi range of values may be characterized as having an average partial output value (average γi) or may be characterized as having a standard deviation of a partial output value (standard deviation of γi) with respect to all compared values of the geologic random points.
The average of a partial output value can be characterized by:
The variance of a partial output value can be characterized by:
Other potentially useful trends include, for instance, the minimum or maximum of the partial outputs (min(γi) and/or max(γi)), and the standard deviation of the partial outputs (SD(γi)).
In embodiments where the building function (γ) is used alternatively or additionally to the partial outputs (γi) to generate the stochastic emulation model (β), similar trends may be determined for building function (γ) (e.g.
When all of the xi values are assessed against all of the y values, a series of partial output values (γi) with associated trends and/or distributions may be generated (e.g. average of γi and/or standard deviation of γi). The emulation module 124 may generate a single stochastic emulation model from the collection of partial output values (γi) using existing emulation techniques (e.g. the Stochastic Bayes Linear Emulator, Stochastic Kriging/Gaussian process regression). The emulation module 124 may also combine partial outputs (γi) with associated distributions to form a single stochastic emulation model (β) using existing emulation techniques. The stochastic emulation model (β) may represent the stochastic behavior of the geologic random variables and the effects of this variability on the output. In some embodiments, the emulation module 124 may determine the stochastic emulation model (β) directly from the partial outputs (γi) without any consideration of trends of the partial outputs (γ). In embodiments where the emulation module 124 uses the building function (γ), alternatively or in addition to, the partial outputs, the emulation module 124 may use trends of the building function (γ) or may not utilize trends of the building function (γ).
Because the partial outputs may be calculated relatively independently of one another, the emulation module 124 may assign each determination of a partial output (γi) to a different processing element or set of different processing elements. For instance, the emulation module 124 may transmit a determination of a first partial output to a specific processing core or segment of parallel processing cores with shared local memory, and the emulation module 124 may transmit a determination of a second partial output to a different specific processing core or different segment of parallel processing cores with different shared local memory, potentially to hasten the determinations of the partial outputs.
In another embodiment, the emulation module 124, may generate the stochastic emulation model (β) from the building function (γ) overall, instead of or in addition to from partial outputs (γi) of the building function (γ). In this regard, all of the sampled geologic random variable values may be assessed against all of the control design points in the deterministic emulation model (η) to output a single building function (γ), accounting for all relationships between the control design points and the geologic random points.
In various embodiments, the emulation module 124 may take further responsive action, for instance, determining pump pressures and/or transmitting commands to pumps to alter applied pressures.
In various embodiments, the simulation module 122 and/or the emulation module 124 may be incorporated into a software package for modeling reservoir behavior.
In an embodiment, the emulation module 124 may use an existing stochastic emulation model (β), the existing stochastic emulation model (β) generated by the emulation module 124, as input to create a new or updated stochastic emulation model (βnew) from a new or updated deterministic simulation model (f(x,y)new). The simulation module 122 may receive or determine new control design points, perhaps chosen by methods already specified for choosing control design points. The simulation module 122 may receive or determine geologic random points, these perhaps the same as before or chosen again using methods described in this specification. The simulation module 122 may run the simulation with the new design points and the new geologic random points chosen. The simulation module 122 may output a new and/or updated deterministic simulation model (f(x,y)new) function based on the new points from the stochastic simulation model (f(x,Y)). The emulation module 124 may receive the new or updated deterministic simulation model function (f(x,y)new) and update or replace the existing deterministic emulation model (η), perhaps using sequential emulation techniques to form a new or updated deterministic emulation model (ηnew). These sequential emulation techniques may use prior iteration(s) of emulation models to generate the next iteration of emulation models. The emulation module 124 may receive or determine either new or existing design control points and geologic random points (perhaps in the manners already disclosed). The emulation module 124 may input those new or existing design control points and geologic random points into the updated or new deterministic emulation model (ηnew). The emulation module 124 may use test control design points and test geologic random points, perhaps the same ones or different ones, as it did in the example of generating the original building functions (γ), perhaps varying some of the elements in the manner disclosed with respect to the building functions (γ). The emulation module 124 may determine updated or new partial outputs (γnew,i) using methods that were used to determine γi and/or new or updated trends representing the partial outputs and/or overall building function (e.g.
In another embodiment, the emulation module 124 may update the existing stochastic emulation model (β) from a new and/or updated building function (γnew) overall, instead of or in addition to from the new and/or updated partial outputs (γnew,i) of the new and/or updated building function (γnew). In this regard, all of the sampled geologic random variable values may be assessed against all of the control design points in the new and/or updated deterministic emulation model (ηnew) to output a single new and/or updated building function (γnew), accounting for all relationships between the control design points and the geologic random points. This new and/or updated building function (γnew) can be used to generate a new and/or updated stochastic emulation model (βnew) in isolation or in concert with any, some combination, or all of the new and/or updated partial outputs (γnew,i), trends in either or both of the new and/or updated building function (γnew) and the new and/or updated partial outputs (γnew,i), and/or a prior stochastic emulation model (β).
The input/output 130 is a device used to communicatively couple the data computer system 100 to external compute elements. The input/output 130 is capable of connecting the computer system 100 to external elements, using known technologies, the external elements including, for instance, universal serial bus, Prolink, serial communication, serial advanced technology attachments, HPC type connections, Gigabit Ethernet, infiniband, and/or the like. The input/output 130 may have a communicative coupler 140. The communicative coupler 140 is used to couple the computer system 100 with components external of the computer system 100, for instance, with external compute devices used in mining or oil and gas applications for drilling, mapping, or determining well locations.
Step 202 is generate, by the simulation module 122, a deterministic simulation model (f(x,y)). The simulation module 122 may determine the deterministic simulation model (f(x,y)) by providing sample values for Y to the stochastic simulation model (f(x,Y)), in order to deterministically characterize the stochastic simulation model (f(x,Y)). The simulation module 122 may use any, some or all of the methods presented with respect to the capabilities of the simulation module 122 in order to generate the deterministic simulation model (f(x,y)).
Step 204 is generate, by the emulation module 124, a deterministic emulation model (η) based on the deterministic simulation model (f(x,y)). The emulation module 124 may use any, some or all of the methods presented with respect to the capabilities of the emulation module 124 in order to generate the deterministic emulation model (η) from the deterministic simulation model (f(x,y)).
Step 206 is generate, by the emulation module 124, a stochastic emulation model (β), based on the deterministic emulation model (η). The emulation module 124 may use any, some or all of the methods presented with respect to the capabilities of the emulation module 124 in order to generate the stochastic emulation model (β) from the deterministic emulation model (η).
In an embodiment, each of the steps of the method shown in
Step 302 is receive or generate, by the emulation module 124, a deterministic emulation model (η). The emulation module 124 may use any, some or all of the methods presented with respect to the capabilities of the emulation module 124 in order to generate the deterministic emulation model (η) from the simulation model (f(x,y)) or may simply receive the deterministic emulation model (η) already determined from another source.
Step 304 is determine, by emulation module 124, at least one partial output of a building function (γ). The emulation module 124 may use any, some or all of the methods presented with respect to the capabilities of the emulation module 124 in order to determine the at least one partial output of a building function (γi). Step 306 may be conducted in addition to step 304 or step 306 and 304 may be performed in the alternative.
Step 306 is optionally, determine, by the emulation module 124, at least one trend of the at least one partial output of the building function (γ). These trends may represent the nature and effect of the underlying random distribution of the geologic random variables. The emulation module 124 may use any, some or all of the methods presented with respect to the capabilities of the emulation module 124 in order to determine the at least one trend of the at least one partial output of the building function (γi). In various embodiments, these trends can represent any number of relationships. Embodiments of the at least one trend of the at least one partial output of a deterministic emulation model (γi) may include, for instance, a minimum partial output (min(γi)), a maximum partial output (max(γi)), an average partial output (
Step 308 is optionally, determine, by the emulation module 124, at least one building function (γ) from the deterministic emulation model (η). The emulation module 124 may use any, some or all of the methods presented with respect to the capabilities of the emulation module 124 in order to determine the at least one building function (γ) from the deterministic emulation model (η). In an embodiment, the at least one building function (γ) may be determined from one or more of the at least one partial output (γi) that is determined in step 304 and the at least one trend of the at least one partial output (γi) that is determined in step 306.
Step 310 is generate, by the emulation module 124, a stochastic emulation model (β) using the at least one partial output of a building function (γ). The emulation module 124 may alternatively or additionally generate the stochastic emulation model (β) from the building function (γ), itself, instead of or in addition to the partial outputs (γi). The emulation module 124 may use any, some or all of the methods presented with respect to the capabilities of the emulation module 124 in order to generate the stochastic emulation model (β). For instance, in an embodiment, the emulation module 124 may also account for the at least one trend of the at least one partial output of a building function (γi) and/or the at least one trend of a building function (γ), in generating the stochastic emulation model (β), as disclosed with respect to the capabilities of the emulation module 124.
In an embodiment, each of the steps of the method shown in
Step 402 is generate, by the simulation module 122, a new or updated deterministic simulation model (f(x,y)new). This new or updated deterministic simulation model (f(x,y)new) may be determined, by the simulation module 122, from sampling the existing stochastic simulation model, f(x,Y). The simulation module 122 may use any, some or all of the methods presented with respect to the capabilities of the simulation module 122 in order to generate the new or updated deterministic simulation model (f(x,y)new).
Step 404 is update or generate, by the emulation module 124, a new or updated deterministic emulation model (ηnew) based on the new or updated deterministic simulation model (f(x,y)new). The emulation module 124 may use any, some or all of the methods presented with respect to the capabilities of the emulation module 124 in order to generate the new or updated deterministic emulation model (ηnew) from the new or updated simulation model (f(x,y)new).
Step 406 is generate, by the emulation module 124, a new or updated stochastic emulation model (βnew), based on the new or updated deterministic emulation model (ηnew). The emulation module 124 may use any, some or all of the methods presented with respect to the capabilities of the emulation module 124 in order to generate the new or updated stochastic emulation model (βnew) from the new or updated deterministic emulation model (ηnew).
In an embodiment, each of the steps of the method shown in
Step 502 is receive or generate, by the emulation module 124, a new or updated deterministic emulation model (ηnew). The emulation module 124 may use any, some or all of the methods presented with respect to the capabilities of the emulation module 124 in order to generate the new or updated deterministic emulation model (ηnew) from the simulation model (f(x,y)) or may simply receive the new or updated deterministic emulation model (ηnew) already determined from another source.
Step 504 is determine, by emulation module 124, at least one new or updated partial output of a building function (γnew,i). The emulation module 124 may use any, some or all of the methods presented with respect to the capabilities of the emulation module 124 in order to determine the at least one new or updated partial output of a building function (γnew,i). Step 506 may be conducted in addition to step 504 or step 506 and 504 may be performed in the alternative. Also, in various embodiments, the emulation module may determine the new and/or updated building function (γnew) alternatively or in addition to the partial outputs (γnew,i) in order to generate the new and/or updated stochastic emulation model (βnew).
Step 506 is optionally, determine, by the emulation module 124, at least one new or updated trend of the at least one new or updated partial output of the building function (γnew,i) and/or a trend of the new building function (γnew). The emulation module 124 may use any, some or all of the methods presented with respect to the capabilities of the emulation module 124 in order to determine the at least one new or updated trend of the at least one new or updated partial output of the building function (γnew,i) and/or the trend of the new building function (γnew). In various embodiments, these trends can represent any number of relationships, including those specified trends in other embodiments disclosed in this specification. Embodiments of the trend may include any of the trends mentioned in this specification and/or any other trends known in the art.
Step 508 is optionally, determine, by the emulation module 124, at least one new or updated building function (γnew) from the new or updated deterministic emulation model (ηnew). The emulation module 124 may use any, some or all of the methods presented with respect to the capabilities of the emulation module 124 in order to determine the at least one new or updated building function (γnew) from the new or updated deterministic emulation model (ηnew). In an embodiment, the at least one new or updated building function (γnew) may be determined from one or more of the at least one partial output (γ) that is determined in step 504 and the at least one trend of the at least one partial output (γ) that is determined in step 506.
Step 510 is generate, by the emulation module 124, a new or updated stochastic emulation model (βnew) using the at least one new and/or updated partial output of a building function (γnew,i) or the new and/or updated building function (γnew), itself. The emulation module 124 may use any, some or all of the methods presented with respect to the capabilities of the emulation module 124 in order to generate the new or updated stochastic emulation model (βnew). For instance, in an embodiment, the emulation module 124 may additionally or as an alternative to the least one new and/or updated partial output of a building function (γnew,i) account for the at least one new or updated trend of the at least one new or updated partial output of a building function (γnew,i) and/or the new or updated building function (γnew) in generating the new or updated stochastic emulation module (βnew), as disclosed with respect to the capabilities of the emulation module 124.
In an embodiment, each of the steps of the method shown in
The comparison 600 has a first row 601 representing a one-stage method for generating a stochastic simulation, the first row having images 601A, 601B, and 601C. The second row 602 represents the two-stage method presented in the specification, the second row 602 having images 602A, 602B, and 602C. It should be noted that the comparison 600 deals only with a single dimension of each of a control design variable and a geologic random variable.
In the images, the respective models have abscissa 606 and 610, representing the values of the control design variables and ordinates 608 and 612 representing the values of geologic random variables. In image 602B, the ordinate is the deterministic emulator response. The surface is the output of the first (deterministic) emulator. The highlighted squares show the partial response or partial output (γi) at a single control design point.
In 601A, the single stage method is shown, where points are chosen randomly and are not representative of the span of geologic random variable values and control design values. It can be seen in 602A, that an experimental design method, in this instance, Latin hypercube sampling, allows for a more representative series of outputs to be generated.
In 601A, it can be seen that the trends are determined based on averaging values of the independent control design point values of only the random samples. This fails to account for relationships between the control design points, effectively treating the control design points as unrelated. The stochastic relationships derived also demonstrate independence from one another and are less representative of a real system. In 602B, it can be seen that the building function (the surface generated from the output points) may provide a relationship between the outputs of different control design point inputs. In doing so, the stochastic relationships are more representative of the simulation model the stochastic emulation model is intended to mimic. Image 602B may be an embodiment of the graph in
601C and 602C show a true function mean of the simulation model 616, an emulator predicted function mean 618, uncertainty in emulator mean 620, a plurality of output points 622, and an emulator uncertainty for overall stochastic function 624. It can be seen in the image 602C, representing the results of the two-stage method, and the image 601C, representing the one-stage method, that the two-stage method may be superior to the one-stage method in terms of limiting uncertainty in the results and tracking the simulation model results.
Mean implausibility may represent a measurement of emulator prediction accuracy. For the purposes of this figure, the mean implausibility is determined by a relationship characterized by:
In this relationship
The comparison 800 has an abscissa 802 representing a number of input design points, an ordinate 804 representing a mean implausibility, a two-stage method line 806, and a one-stage method line 808. It can be seen that the implausibility reduces very quickly for a two-stage model when compared with a one-stage model. Also, the two-stage method may plateau at a level of error that may be representative of numerical precision errors in the emulation module used, so the error shown may not be an inherent flaw of the method itself.
The detailed descriptions of the above embodiments are not exhaustive descriptions of all embodiments contemplated by the inventors to be within the scope of the present description. Indeed, persons skilled in the art will recognize that certain elements of the above-described embodiments may variously be combined or eliminated to create further embodiments, and such further embodiments fall within the scope and teachings of the present description. It will also be apparent to those of ordinary skill in the art that the above-described embodiments may be combined in whole or in part to create additional embodiments within the scope and teachings of the present description. When specific numbers representing parameter values are specified, the ranges between all of those numbers as well as ranges above and ranges below those numbers are contemplated and disclosed.
Thus, although specific embodiments are described herein for illustrative purposes, various equivalent modifications are possible within the scope of the present description, as those skilled in the relevant art will recognize. The teachings provided herein can be applied to other methods and apparatuses for determining reservoir models, and not just to the embodiments described above and shown in the accompanying figures. Accordingly, the scope of the embodiments described above should be determined from the following claims.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/EP2019/069577 | 7/19/2019 | WO | 00 |