📄 velan
字号:
#! /bin/sh# Velocity analyses for the cmp gathers# Authors: Dave Hale, Jack K. Cohen, with modifications by John Stockwell# NOTE: Comment lines preceeding user input start with ###set -x## Set parametersvelpanel=modeldata # gained and deconvolved seismic data, # sorted in cdp'svpicks=stkvel.p1 # output file of vnmo= and tnmo= valuesnormpow=0 # see selfdoc for suvelanslowness=0 # see selfdoc for suvelancdpfirst=1 # minimum cdp value in datacdplast=3500 # maximum cdp value in datacdpmin=1500 # minimum cdp value used in velocity analysiscdpmax=3500 # maximum cdp value used in velocity analysisdcdp=500 # change in cdp for velocity scansfold=12 # only have 12 shots, otherwise would be # 64/2=32 for dsx=dgx, or maximum number # of traces per cdp gatherdxcdp=50 # distance between successive midpoints # in full datas set## Set velocity sampling and band pass filtersnv=120 # number of velocities in scandv=75.0 # velocity sampling interval in scan fv=4000.0 # first velocity in scannout=501 # ns in data ## Set interpolation type interpolation=akima # choices are linear, spline, akima, mono## set filter valuesf=1,10,80,100 # bandwidth of data to passamps=0,1,1,0 # don't change## number of contours in contour plotnc=35 # this number should be at least 25fc=.05 # This number should be between .05 to .15 for real data ccolor=black,grey,green,black,grey,cyan,black,grey,blue,black,grey,blue,red,red,redperc=97 # clip above perc percential in amplitudexcur=3 # allow xcur trace xcursion######## You shouldn't have to change anything below this line ############average velocityvaverage=3000 # this may be adjusted# binary files outputvrmst=vrmst.bin # VRMS(t) interpolated rms velocitiesvintt=vintt.bin # VINT(t,x) as pickedvinttav=vinttav.bin # average VINT(t) of VINT(t,x)vinttuni=vinttuni.bin # interploated Vint(t,x)vintzx=vintzx.bin # VINT(z,x)interpolated interval velocitiesvintxz=vintxz.bin # VINT(x,z)interpolated interval velocities### Get header infocdpcount=0 # counting variabledxout=0.004 # don't change thisnout=`sugethw ns <$velpanel | sed 1q | sed 's/.*ns=//'`dt=`sugethw dt <$velpanel | sed 1q | sed 's/.*dt=//'`dxout=`bc -l <<END $dt / 1000000END`cdptotal=`bc -l <<END $cdplast - $cdpfirstEND`dtsec=`bc -l <<END $dt / 1000000END`echo "Skip Introduction? (y/n) " | tr -d "\012" >/dev/ttyread responsecase $response inn*) # continue velocity analysis### give instructionsechoechoechoechoecho " Instructions for Velocity Analysis."echoecho " A contour semblance map will appear on the left of your screen."echo " A wiggle trace plot of the cdp panel being analysed will appear"echo " on the right as a aid in picking. Click on the semblance contour"echo " map to make that window active."echoecho " Pick velocities by placing cursor on each peak in the"echo " semblance plot and typing 's'. Type 'q' when last peak is picked."echo " Note, this is 'blind' picking. You will not see any indication"echo " on the contour plot that a point has been picked."echoecho " Note also, that it is best if a value of the velocity is picked "echo " at the beginning of the data (t=0.0 usually). The picks must "echo " be increasing in time. If you feel you have made an incorrect pick"echo " you will be given an opportunity to pick the velocities again. "echopauseechoecho " Finally, a reasonable value at the latest time of the section "echo " should be picked. (Picking reasonable values for the top and bottom"echo " of the section ensures that interpolations of the velocities are"echo " reasonable. You don't want the wavespeed profile to start at zero "echo " velocity."echoecho " For this demo dataset, there will be a maximum of 4 peaks to be"echo " picked, as this is the number of reflectors in the model. However,"echo " for the far-offset CDP gathers, it may be difficult to pick all "echo " 4 peaks."echoecho " A graph of the velocity function will appear, and a prompt to" echo " hit the return key will be seen in this terminal window. You"echo " will then see an nmo corrected version of the cdp gather you that"echo " you are performing velocity analysis on." echoecho " You will be prompted in the terminal window to hit return. Then "echo " you will be will be asked if your picks are ok. This gives you "echo " a chance to re-pick the velocities if you do not like the velocity"echo " function you have obtained."pause;;*y) #continueechoechoecho "Beginning the velocity analysis"echoechoecho;;esac########################### start velocity analysis #####################cdp=$cdpminwhile [ $cdp -le $cdpmax ]do cdpcount=` expr $cdpcount + 1 ` ok=false reusepanel=false # see if panel.$cdp exists if [ -f panel.$cdp ] then echo "panel.$cdp exists. Reuse? (y/n) " | tr -d "\012" >/dev/tty read response case $response in n*) # continue velocity analysis reusepanel=false ;; y*) # no need to get velocity panel reusepanel=true ;; esac fi # see if par.$cdp and $vrmst.$cdp exist if [ -f par.$cdp ] then if [ -f $vrmst.$cdp ] then echo echo " file $vrmst.$cdp already exists" echo " indicating that cdp $cdp has been picked" fi echo echo " file par.$cdp already exists" echo " indicating that cdp $cdp has been picked" echo echo "Redo velocity analysis on cdp $cdp? (y/n) " | tr -d "\012" >/dev/tty read response case $response in n*) # continue velocity analysis with next cdp ok=true ;; y*) # continue with same value of cdp ok=false ;; esac fi # begin velocity analysis while [ $ok = false ] do echo "Starting velocity analysis for cdp $cdp" if [ $reusepanel = false ] then suwind < $velpanel key=cdp min=$cdp max=$cdp \ count=$fold > panel.$cdp reusepanel=true fi suxwigb < panel.$cdp title="CDP gather for cdp=$cdp" \ xbox=50 mpicks=mpicks.$cdp \ perc=$perc xcur=$xcur wbox=300 & sugain tpow=2 < panel.$cdp | sufilter f=$f amps=$amps | suvelan nv=$nv dv=$dv fv=$fv | suxcontour nc=$nc f2=$fv d2=$dv xbox=450 wbox=600 \ units="semblance" fc=$fc ccolor=$ccolor \ label1="Time (sec)" label2="Velocity (m/sec)" \ title="Velocity Scan (semblance plot) for CMP $cdp" \ mpicks=mpicks.$cdp sort <mpicks.$cdp -n | mkparfile string1=tnmo string2=vnmo >par.$cdp # view the picked velocity function echo "Putting up velocity function for cdp $cdp" sed <par.$cdp ' s/tnmo/xin/ s/vnmo/yin/ ' >unisam.p unisam nout=$nout fxout=0.0 dxout=$dxout \ par=unisam.p method=$interpolation | xgraph n=$nout nplot=1 d1=$dxout f1=0.0 width=400 height=700 \ label1="Time (sec)" label2="Velocity (m/sec)" \ title="Stacking Velocity Function: CMP $cdp" \ grid1=solid grid2=solid \ linecolor=2 style=seismic & pause # view an NMO of the panel echo "Hit return after nmo panel comes up" sunmo < panel.$cdp par=par.$cdp | suxwigb title="NMO of cdp=$cdp" wbox=300 xcur=$xcur \ perc=$perc xcur=$xcur & pause # check to see if the picks are ok echo "Picks OK? (y/n) " | tr -d "\012" >/dev/tty read response case $response in n*) ok=false ;; *) ok=true # capture resampled velocity unisam nout=$nout fxout=0.0 dxout=$dxout \ par=unisam.p method=$interpolation > $vrmst.$cdp # clean up the screen zap ximage zap xgraph zap xwigb zap xcontour ;; esac done </dev/tty echo echo echo "Continue with velocity analysis? (y/n) " | tr -d "\012" >/dev/tty read response case $response in n*) # if quitting set cdp to a value large enough to # break out of loop cdp=`expr $cdpmax + 1` ;; y*) # else get the next cdp cdp=`bc -l <<END $cdp + $dcdpEND` ;; esacdoneset +x### Combine the individual picks into a composite sunmo par fileecho "Editing pick files ...">$vpicksecho "cdp=" | tr -d "\012" >>$vpickscdp=$cdpminecho "$cdp" | tr -d "\012" >>$vpickscdp=`bc -l <<END $cdp + $dcdpEND`while [ $cdp -le $cdpmax ]do echo ",$cdp" | tr -d "\012" >>$vpicks cdp=`bc -l <<END $cdp + $dcdpEND`doneecho >>$vpickscdpcount=0rm $vrmstcdp=$cdpminwhile [ $cdp -le $cdpmax ]do cat $vrmst.$cdp >> $vrmst cat par.$cdp >>$vpicks cdp=`bc -l <<END $cdp + $dcdpEND` cdpcount=` expr $cdpcount + 1 `done# build velocity files to be used for later migrationvrmstpar=vrmst.parvinttpar=vintt.parvinttplotpar=vinttplot.parunipar=unisam.par# build par filesecho "n1=$nout n2=$cdpcount f2=$cdpmin d2=$dcdp " > $vrmstparecho "nt=$nout ns=$nout nx=$cdpcount fx=$cdpmin dx=$dcdp " > $vinttparecho "n=$nout nplot=1 d1=$dxout style=seismic width=400 height=700 " > $vinttplotparecho "nx1=$nout nx2=$cdpcount n1=$nout n2=$cdptotal" > $unipar# convert rms velocities to interval velocities velconv intype=vrmst outtype=vintt par=$vinttpar < $vrmst > $vintt# make an average velocity profilesuaddhead < $vintt ns=$nout | sustack | sustrip > $vinttav # build a uniformly sampled v(t,x) velocity profileunisam2 < $vintt par=$unipar | smooth2 r1=5 r2=5 par=$unipar > $vinttuni # get depth sampling intervaldzout=`bc -l <<END ( $vaverage * $dtsec ) / 2.0END` echo $dzout # build v(z,x)velconv intype=vintt outtype=vintz dt=$dtsec \nx=$cdplast nz=$nout dz=$dzout < $vinttuni |smooth2 r1=10 r2=20 n1=$nout n2=$cdplast > $vintzx # build v(x,z)transp < $vintzx n1=$nout > $vintxz# final echosecho "V(t) RMS (stacking) velocity file: $vrmst is ready"echo "V(t,x) Interval velocity file: $vintt is ready"echo "V(z,x) Interval velocity file: $vintzx is ready"echo "sunmo par file: $vpicks is ready"exit 0
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -