Skip to content

Commit

Permalink
Add function to combine multiple petro realizations using facies real…
Browse files Browse the repository at this point in the history
…ization

Add function to import and export field parameters to and from ERTBOX grid.
Added documentation for update_petro_real and the export and import functions.
  • Loading branch information
oddvarlia committed Dec 14, 2024
1 parent 21780d4 commit 94d5a93
Show file tree
Hide file tree
Showing 4 changed files with 577 additions and 0 deletions.
110 changes: 110 additions & 0 deletions docs/export_and_import_fields.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,110 @@
rms.export_and_import_field_parameters
=======================================

The export and import scripts desctibed below supports a workflow where
both facies and petrophysical properties are updated as field parameters in ERT.
The implemented functions in the module *fmu.tools.rms.update_petro_real* are::

export_initial_field_parameters
import_updated_field_parameters

Both the export and import function the same set of petrophysical variables in the
same workflow. Therefore, they both read this information from a configuration file
in YAML format that is also shared with the function *generate_petro_jobs*.

Export petrophysical parameters as field parameters to be used in ERT FIELD keyword
-------------------------------------------------------------------------------------

Example of use of the export function

.. code-block:: python
from fmu.tools.rms.update_petro_real import export_initial_field_parameters
from fmu.tools.rms.generate_petro_jobs_for_field_update import read_specification_file
DEBUG_PRINT=True
CONFIG_FILE_NAME_VALYSAR = "../input/config/field_update/generate_petro_jobs_valysar.yml"
CONFIG_FILE_NAME_THERYS = "../input/config/field_update/generate_petro_jobs_therys.yml"
CONFIG_FILE_NAME_VOLON = "../input/config/field_update/generate_petro_jobs_volon.yml"
ERTBOX_GRID = "ERTBOX"
def export_fields():
spec_dict = read_specification_file(CONFIG_FILE_NAME_VALYSAR)
used_petro_dict = spec_dict["used_petro_var"]
export_initial_field_parameters(
project,
used_petro_dict,
grid_model_name=ERTBOX_GRID,
zone_name_for_single_zone_grid="Valysar",
debug_print= DEBUG_PRINT)
spec_dict = read_specification_file(CONFIG_FILE_NAME_THERYS)
used_petro_dict = spec_dict["used_petro_var"]
export_initial_field_parameters(
project,
used_petro_dict,
grid_model_name=ERTBOX_GRID,
zone_name_for_single_zone_grid="Therys",
debug_print= DEBUG_PRINT)
spec_dict = read_specification_file(CONFIG_FILE_NAME_VOLON)
used_petro_dict = spec_dict["used_petro_var"]
export_initial_field_parameters(
project,
used_petro_dict,
grid_model_name=ERTBOX_GRID,
zone_name_for_single_zone_grid="Volon",
debug_print= DEBUG_PRINT)
if __name__ == "__main__":
export_fields()
Import petrophysical parameters used as field parameters to be used in ERT FIELD keyword
------------------------------------------------------------------------------------------

Example of use of the import function

.. code-block:: python
from fmu.tools.rms.update_petro_real import import_updated_field_parameters
from fmu.tools.rms.generate_petro_jobs_for_field_update import read_specification_file
DEBUG_PRINT = False
CONFIG_FILE_NAME_VALYSAR = "../input/config/field_update/generate_petro_jobs_valysar.yml"
CONFIG_FILE_NAME_THERYS = "../input/config/field_update/generate_petro_jobs_therys.yml"
CONFIG_FILE_NAME_VOLON = "../input/config/field_update/generate_petro_jobs_volon.yml"
ERTBOX_GRID = "ERTBOX"
def import_fields():
spec_dict = read_specification_file(CONFIG_FILE_NAME_VALYSAR)
used_petro_dict = spec_dict["used_petro_var"]
import_updated_field_parameters(
project,
used_petro_dict,
grid_model_name=ERTBOX_GRID,
zone_name_for_single_zone_grid="Valysar",
debug_print=DEBUG_PRINT)
spec_dict = read_specification_file(CONFIG_FILE_NAME_THERYS)
used_petro_dict = spec_dict["used_petro_var"]
import_updated_field_parameters(
project,
used_petro_dict,
grid_model_name=ERTBOX_GRID,
zone_name_for_single_zone_grid="Therys",
debug_print=DEBUG_PRINT)
spec_dict = read_specification_file(CONFIG_FILE_NAME_VOLON)
used_petro_dict = spec_dict["used_petro_var"]
import_updated_field_parameters(
project,
used_petro_dict,
grid_model_name=ERTBOX_GRID,
zone_name_for_single_zone_grid="Volon",
debug_print=DEBUG_PRINT)
if __name__ == "__main__":
import_fields()
2 changes: 2 additions & 0 deletions docs/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@ Contents:
create_rft_ertobs
rename_rms_scripts
rms_import_localmodule
update_petro_real
export_and_import_fields
utilities
rmsvolumetrics2csv
ensembles
Expand Down
123 changes: 123 additions & 0 deletions docs/update_petro_real.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,123 @@
rms.update_petro_real
=======================

When running FMU project where field parameters for both facies and
petrophysical properties are updated in ERT simultaneously,
some adjustments are needed in the RMS project to support this type
of workflow. It is necessary to have one petrosim job per facies.

The module *update_petro_real* will combine values from realization
of a petrophysical property for individual facies into one common
petrophysical realization by using the facies realization as filter.

Example describing the workflow
--------------------------------

The zone Valysar has four different facies::

Floodplain
Channel
Crevasse
Coal

A petrophysical realization is made for PHIT and KLOGH for each of the three
first facies with property names::

Floodplain_PHIT
Floodplain_KLOGH
Channel_PHIT
Channel_KLOGH
Crevasse_PHIT
Crevasse_KLOGH

Neither PHIT nor KLOGH are updated as field parameters for facies
Coal since they have constant (not spatially varying) values and
may even have 0 specified uncertainty.
The variables VSH and VPHYL are chosen not to be used as field parameters
in ERT in assisted histroy matching and therefore not included here,
but still used in the RMS workflow with the prior values.

The original realizations created for PHIT and KLOGH are conditioned
to facies. In a workflow where we want to use both facies by applying
the Adaptive PluriGaussian Simulation method (APS) and PHIT and KLOG
for some selected facies as field parameters to be updated by ERT,
we will need the separate PHIT and KLOGH realizations for the selected
facies.

The steps will be:

* Use original petrophysical job to create initial version of a realization of
PHIT, KLOGH, VSH and VPHYL.
* Use separate petrophysical jobs to create separate version of realizations of
Floodplain_PHIT, Floodplain_KLOGH and so on.
* Use the script *update_petro_real* to copy the values for PHIT and KLOGH from
the individual realizations per facies into the initial version of PHIT and KLOG
by overwriting the values in the original version. In this process,
the facies realization is used as a filter to select which grid cell values
to get from the individual PHIT and KLOGH parameters that belongs to the
various facies.

When running ERT iteration 0 which creates the initial ensemble, this looks a bit unnecessary,
since the initial PHIT and KLOGH already has taken facies into account. But, when running
ERT iteration larger than 0 (after ERT has updated the fields Floodplain_PHIT,
Floodplain_KLOGH and so on), then updated versions of the field parameters are imported
and updated version of facies realization is used to update the PHIT and KLOGH parameters
from the imported field parameters (Floodplain_PHIT, Floodplain_KLOGH ...).

Also for iteration 0, to ensure consistency the same procedure
(copy from the field parameters Floodplain_PHIT, Floodplain_KLOG,..) is applied since this ensure
consistent handling of the realizations.

Example of RMS python job running this module to combine the field parameters
-------------------------------------------------------------------------------

The python job below will call the *update_petro_real* function that does the
combination of the field parameters into one petrophysical realization.
This job depends on a small config file ( the same config file that is used by the
function *generate_petro_jobs* from fmu.tools.rms module). Here the python job gets
the grid name and which of the petrophysical properties for which facies
to be updated as field parameters in ERT. The script also depends on the facies table
(which facies code and name belongs together).
This can be fetched from the *global_variables.yml* file as shown in the example below.

.. code-block:: python
from fmu.tools.rms.update_petro_real import update_petro_real
from fmu.config import utilities as ut
CFG = ut.yaml_load("../../fmuconfig/output/global_variables.yml")["global"]
FACIES_ZONE = CFG["FACIES_ZONE"]
DEBUG_PRINT = False
CONFIG_FILE_VALYSAR = "../input/config/field_update/generate_petro_jobs_valysar.yml"
CONFIG_FILE_THERYS = "../input/config/field_update/generate_petro_jobs_therys.yml"
CONFIG_FILE_VOLON = "../input/config/field_update/generate_petro_jobs_volon.yml"
FACIES_CODE_NAMES_VALYSAR = FACIES_ZONE["Valysar"]
FACIES_CODE_NAMES_THERYS = FACIES_ZONE["Therys"]
FACIES_CODE_NAMES_VOLON = FACIES_ZONE["Volon"]
# Variables not used here, but will be relevant for multi-zone grids
ZONE_PARAM_NAME = "" # Single zone grid does not need to have a zone parameter
ZONE_CODE_NAMES = {} # Only non-empty if grid model is a multi-zone model
if __name__ == "__main__":
# Drogon uses 3 different grids and single zone grids
update_petro_real(
project,
CONFIG_FILE_VALYSAR,
FACIES_CODE_NAMES_VALYSAR,
debug_print=DEBUG_PRINT)
update_petro_real(
project,
CONFIG_FILE_THERYS,
FACIES_CODE_NAMES_THERYS,
debug_print=DEBUG_PRINT)
update_petro_real(
project,
CONFIG_FILE_VOLON,
FACIES_CODE_NAMES_VOLON,
debug_print=DEBUG_PRINT)
Loading

0 comments on commit 94d5a93

Please sign in to comment.