mirror of
https://github.com/OPM/ResInsight.git
synced 2025-01-21 22:13:25 -06:00
b610133117
p4#: 20260
148 lines
5.8 KiB
Plaintext
148 lines
5.8 KiB
Plaintext
Considerations
|
||
==================================
|
||
|
||
This function interface towards ResInsight is currently a Draft,
|
||
and not addressing some issues. The known issues are :
|
||
|
||
1. How do we address Cases in the future when we have Case Groups ?
|
||
Where do we write/store the generated data ?
|
||
2. Users wants to run octave operations on several cases/groups.
|
||
There are two ways (at least) of doing that. Either from ResInsight:
|
||
1 Command to call a specified Octave Script for each selected Case
|
||
2 Creating Scripts that loops over all selections in ResInsight
|
||
Option 2 is needed if users wants to do cross-case operations
|
||
Option 1 seems intuitive for one case operations
|
||
How does these two relate ?
|
||
|
||
3. Do we need functions to retreive the selected/active cases/groups ?
|
||
4. Do we need functions to retreive info on what Parent cells an LGR occupies ?
|
||
|
||
|
||
Project Information
|
||
==================================
|
||
|
||
Vector[Casenames] riGetCaseNames()
|
||
|
||
Returns a vector of all the case names in the current ResInsight project
|
||
Use this to determine the number of cases as well
|
||
|
||
This probably needs some additions related to Case Groups
|
||
|
||
|
||
Retreiving Grid Metadata
|
||
==================================
|
||
|
||
Matrix[ActiveCells][8] riGetActiveCellInfo( [CaseName/CaseIndex])
|
||
|
||
Returns a two dimensional matrix: [ActiveCells][8]
|
||
|
||
Containing grid and ijk information about the cells from the Eclipse Case defined.
|
||
The columns contain the following information:
|
||
1: GridIndex: The index of the grid the cell resides in. (Main grid has index 0)
|
||
2, 3, 4: I, J, K: 1-based index address of the cell in the grid.
|
||
5: ParentGridIndex. The index to the grid that this cell's grid is residing in.
|
||
6, 7, 8: PI, PJ, PK address of the parent grid cell that this cell is a part of.
|
||
If the Eclipse Case is not defined, the active View in ResInsight is used.
|
||
|
||
|
||
|
||
Matrix[g0I, g0J, g0K; ... ; gnI, gnJ, gnK] riGetGridDimensions ( [CaseName/CaseIndex])
|
||
|
||
Returns a matrix: [NuberOfGrids][3]
|
||
containing the I, J, K dimensions of the main grid and all the LGR's
|
||
|
||
# Unnecessary ? # Vector(3)[ICount, JCount, KCount] riGetMainGridDimensions( [CaseName/CaseIndex])
|
||
# Unnecessary ? #
|
||
# Unnecessary ? # Returns a vector of size 3: [ICount, JCount, KCount]
|
||
# Unnecessary ? # Containing the dimensions of the main grid in the requested case.
|
||
# Unnecessary ? # If the Eclipse Case is not defined, the active View in ResInsight is used."
|
||
# Unnecessary ? #
|
||
# Unnecessary ? # NumberOfGrids riGetNumLGRs([Casename/CaseIndex])
|
||
# Unnecessary ? #
|
||
# Unnecessary ? # Returns an integer telling the number of LGRS in this case
|
||
|
||
|
||
|
||
Vector[Dates] riGetTimestepDates([Casename/CaseIndex])
|
||
|
||
Returns a vector of all the timesteps in a case as dates YYYY.MM.DD
|
||
|
||
|
||
Vector[Days] riGetTimestepDays([Casename/CaseIndex])
|
||
|
||
Returns a vector of all the timesteps in a case as days from start
|
||
|
||
|
||
Retreiving property data
|
||
==================================
|
||
|
||
Matrix[ActiveCells][Timesteps] riGetActiveCellProperty( [CaseName/CaseIndex], PropertyName )
|
||
|
||
Returns a two dimentional matrix: [ActiveCells][Timesteps]
|
||
|
||
Containing the requested property data from the Eclipse Case defined.
|
||
If the Eclipse Case is not defined, the active View in ResInsight is used.
|
||
|
||
|
||
Matrix[numI][numJ][numK][timeSteps] riGetGridProperty( [Casename/CaseIndex], GridIndex , PropertyName )
|
||
Matrix[numI][numJ][numK] riGetGridProperty( [Casename/CaseIndex], GridIndex , PropertyName, TimeStep )
|
||
|
||
Returns a 4D or 3D matrix of the requested property data for all the gridcells in the requested grid.
|
||
Grids are indexed from 0 - main grid to Max num LGR's
|
||
|
||
Writing Back to ResInsight
|
||
==================================
|
||
|
||
riSetActiveCellProperty( Matrix(nActiveCells, nTimesteps), [CaseName/CaseIndex], PropertyName )
|
||
|
||
Interprets the supplied matrix as an eclipse property set, and puts the data into
|
||
ResInsight as a "Generated" property with the name "PropertyName". The property
|
||
is added to the active case if no case specification is given, or to the Eclipse Case
|
||
named "CaseName" or to the case number "CaseIndex". "
|
||
|
||
|
||
riSetGridProperty( Matrix[numI][numJ][numK][timeSteps] , [CaseName/CaseIndex], GridIndex, PropertyName )
|
||
riSetGridProperty( Matrix[numI][numJ][numK], [CaseName/CaseIndex], GridIndex, PropertyName , TimeStep)
|
||
|
||
Interprets the supplied matrix as an eclipse property set defined for all cells in one of the grids in a case,
|
||
and puts the data into ResInsight as a "Generated" property with the name "PropertyName". The property
|
||
is added to the active case if no case specification is given, or to the Eclipse Case
|
||
named "CaseName" or to the case number "CaseIndex". "
|
||
|
||
Cell geometry functions:
|
||
=================================
|
||
|
||
Matrix[numI*Vector(3)][numJ*Vec(3)] [numK*Vec(3)] riGetCellCenters( [Casename/CaseIndex], GridIndex )
|
||
|
||
Returns the UTM coordinates (X, Y, Z) for centerpoint of all cells
|
||
|
||
|
||
Matrix[numI*8*Vector(3)][numJ*8*Vec(3)] [numK*8*Vec(3)] riGetCellCorners( [Casename/CaseIndex], GridIndex )
|
||
|
||
Returns the UTM coordinates of the each cells 8 corners
|
||
|
||
|
||
Well data functions
|
||
=================================
|
||
Vector[WellNames] riGetWellNames([Casename/CaseIndex])
|
||
|
||
Returns the names of all the wells in the case
|
||
|
||
Vector[ I, J, K, GridNr] riGetWellCells([Casename/CaseIndex], WellName/WellIndex, TimeStep, Producing/Injecting/Any)
|
||
|
||
Returns the cells that has the requested production status for the given well and timestep
|
||
|
||
|
||
Comments to remember/consider
|
||
=================================
|
||
<EFBFBD>Execute for all cases within group<75> in script-tree
|
||
|
||
Well trajectories (alternative trajectory like Planned / Drilled /Real Time/ Project ahead?)
|
||
riGetTrajectories(well, case) ? MD, Inc, Az, Norht(X), East(Y), TVD(Z),DLS,BUR,TR,prop/log/connections?
|
||
|
||
Operator to restrict operation to be carried out inside a given polygon object
|
||
riInside(polygon)
|
||
|
||
Set Octave function Case ID as a function parameter (enable for loops)
|
||
Write grid data to file on .grdecl format (and read & append?)
|