|
opm-grid
|
Low-level corner-point processing routines and supporting data structures. More...
Go to the source code of this file.
Classes | |
| struct | grdecl |
| Raw corner-point specification of a particular geological model. More... | |
| struct | processed_grid |
| Result structure representing minimal derived topology and geometry of a geological model in corner-point format. More... | |
Enumerations | |
| enum | face_tag { I_FACE , J_FACE , K_FACE , NNC_FACE } |
| Connection taxonomy. More... | |
Functions | |
| int | process_grdecl (int pinchActive, int edge_conformal, double tol, const struct grdecl *g, const int *is_aquifer_cell, struct processed_grid *out) |
| Construct a prototypical grid representation from a corner-point specification. | |
| void | free_processed_grid (struct processed_grid *g) |
| Release memory resources acquired in previous grid processing using function process_grdecl(). | |
| int | add_cell_face_mapping (struct processed_grid *grid) |
| Populate cell-to-face mapping. | |
Low-level corner-point processing routines and supporting data structures.
User code should typically employ higher-level routines such as create_grid_cornerpoint() in order to construct fully formed UnstructuredGrid data structures from a corner-point specification. Incidentally, the routines provided by this module are used to implement function create_grid_cornerpoint().
| enum face_tag |
| int add_cell_face_mapping | ( | struct processed_grid * | grid | ) |
Populate cell-to-face mapping.
| [in,out] | grid | On input, the neighbourship structure from process_grdecl(), with the 'edge_conformal' flag set to true. On output, the same structure, but with added cell-to-face mappings. |
| void free_processed_grid | ( | struct processed_grid * | g | ) |
Release memory resources acquired in previous grid processing using function process_grdecl().
Note: This function releases the resources associated to the individual fields of the processed_grid, but does not free() the structure itself.
| [in,out] | g | Prototypical grid representation obtained in an earlier call to function process_grdecl(). |
| int process_grdecl | ( | int | pinchActive, |
| int | edge_conformal, | ||
| double | tol, | ||
| const struct grdecl * | g, | ||
| const int * | is_aquifer_cell, | ||
| struct processed_grid * | out ) |
Construct a prototypical grid representation from a corner-point specification.
Pinched cells will be removed irrespective of any explicit "active" map in the geological model input specification. On input, the result structure "out" must point to a valid management structure. In other words, the result structure must point to a region of memory that is typically backed by automatic or allocated (dynamic) storage duration.
| [in] | pinchActive | Whether cells with zero volume should be pinched out and neighboring cells should be connected. |
| [in] | edge_conformal | Whether or not to create an edge-conformal grid. This is an experimental feature, aimed at supporting geo-mechanical workflows, that should typically not be used in production runs of traditional reservoir simulations. Non-zero to enable edge-conformal processing, zero to disable this mode. |
| [in] | tol | Absolute tolerance of node-coincidence. |
| [in] | g | Corner-point specification. If "actnum" is NULL, then the specification is interpreted as if all cells are initially active. |
| [in] | is_aquifer_cell | Whether or not an input cell represents a numerical aquifer. Pass NULL if there are no numerical aquifers in the run. Otherwise, the argument is expected to be one integer for each Cartesian input cell with a zero value for cells that are not in numerical aquifers and a non-zero value for cells that are in numerical aquifers. |
| [in,out] | out | Minimal grid representation featuring face-to-cell neighbourship definition, vertex geometry, face's constituent vertices, and local-to-global cell mapping. |