lok - Lookup operation
Name
lok — Lookup operation
Syntax
Single lookup transitions:
lok [xy | xz | yx | yz | zx | zy] ;# Indicates which two coordinate axes to use.
lok value hi workspacename ;# Lookup transition
Lookup handling if input value is outside lookup curve
lok ... nol nolookupvalue | ext ;# setting nolookupvalue or extrapolation
Lookup transitions for active dataset:
lok [xy | xz | yx | yz | zx | zy] hi workspacename ;# Lookup transition
Fast lookup transitions for active dataset:
lok [xy | xz | yx | yz | zx | zy] fast init [resolution_size (default 1000)] ;# The lookup curve is converted to a dense result buffer of resolution_size.
lok hi workspacename fast ;# Fast lookup transition using the input value as entry in the resolution buffer for direct lookup result. No extrapolation is allowed.
Multiple lookup transitions:
lok up | pml | wlc | wel | mlp | mlc ;# See separate documentation
Description
A lookup curve is a way of transforming a point trough a curve. In Geocap all curves have xyz-coordinates. Default lookup is between the y and x coordinates. The functionality of lookup curves are collected under the lok command. The system operates with single and multiple lookup curves.
A lookup curve is a curve in a plane. An input entry on one axes goes parallel with the other axes until it hits the curve. The lookup value is found by going parallel with the first axes down to the second axes.
Arguments single lookup transitions
lok [xy | xz | yx | yz | zx | zy]
Indicates which two coordinate axes to use as entry and exit of the lookup operation.
lok value hi workspacename
The lookup curve is in workspacename. Input value is value. The result is saved in @lookup. To assign it to a variable: set lup [gvar lookup]
Arguments for lookup transitions on active data
lok [xy | xz | yx | yz | zx | zy]
Indicates which two coordinate axes to use as entry and exit of the lookup operation.
lok [xy | xz | yx | yz | zx | zy] hi workspacename [nol no_lookup_value | nol keep | rem | ext] [dlo]
dlo - Display lookup curve.
nol no_lookup_value - Use no_lookup_value outside lookup range.
nol keep - Keep values unchanged outside lookup range.
rem - Remove values outside lookup range.
ext - Extrapolate values outside lookup range.
Fast lookup transitions on active data
lok [xy | xz | yx | yz | zx | zy] fast init [resolution_size]
The lookup curve in active is converted to a set of lookup values placed in a buffer of resolution_size. Default resolution size is 1000 if not entered. Do this initialization first using the fast and init argument as well as specifying the lookup coordinate axes. The lookup curve should also be placed in workspace workspacename .
lok hi workspacename fast
Fast lookup transition on active data using the input value as entry for calculating an index in the result buffer for direct lookup result. No extrapolation argument is allowed. The accuracy of the result depends on the size of the result buffer. The values in the result buffer are calculated through interpolation when they were created, but no further interpolation takes place when a value is returned..
Arguments multiple lookup transitions
A set of lookup curves are spread across a horizon. A grid node can be converted using a blend of lookup curves in the node's neighbourhood.
The multiple lookup feature is used normally in depth conversion of grids in case there are many wells in the area. Each well has a separate lookup curve for time to depth. A node in the grid to be depth converted will be influenced by the surrounding lookup curves and get lookup values for all of them using the node as input. The result is calculated by the preferred interpolator using the distance square to the wells as a blending criteria. Although the algorithm was specified and used for depth conversion it is quite general if one has many lookup curves spread laterally across the grid.
See separate documentation.
Examples
Ex.1: Lookup transitions
# Lookup curves vie def ;# reset viewport ret 10 ;# return start window spe bgc whi ;# specify background color to white sta 0 0 0 ;# stack x y z coordinates sta 20 40 0 ;# stack x y z coordinates sta 100 100 0 ;# stack x y z coordinates rea ter ;# read 3 stacked points cur lin sav nodraw ;# spline curve, save and no draw poi num 0 ;# display point number 0 pot ;# tube the polygon mhi mm ;# move lookup curve high to mm col bla ;# color black dra win ;# draw window frame d2 ;# set in 2d mode axe adhx 15 tic ;# draw axes with tic marks and tune vertical x placement sta 20 60 25 ;# stack x y z coordinates sta 30 40 60 ;# stack x y z coordinates sta 60 80 80 ;# stack x y z coordinates rea ter ;# read 3 stacked points set xx [gvar xwin] ;# set xwin value in tcl syntax set yy [gvar ywin] ;# set ywin value in tcl syntax mhi pp ;# move pointset high to pp swi xzy ;# switch y and z sca x 0 ;# x values are scaled to 0 tra $xx 0 0 ;# shift x values by xx sca z 0 ;# z values are scaled to 0 add 50 ;# add 50 col yel ;# yellow color poi val fol yco ;# display y coordinate values mlo pp ;# move low from pp lok yx hi mm dlo ;# perform lookup transition mhi ll ;# move high the new pointset col red ;# color red mlo ll ;# move low the transformed pointset swi zyx ;# switch x and z sca y 0 ;# y values are scaled to 0 tra 0 $yy 0 ;# shift y values by yy sca z 0 ;# z values are scaled to 0 add 50 ;# add 50 col tur ;# color turqoise poi val fol xco ;# display x coordinate values
The above example produces this image.
Lookup transitions for three points