from rsf.proj import *
par = {
'before':dict(n1=327,n2=468 ,o1=557.815,o2=5107.985,d1=0.030030675,d2=0.029978587,scale=''),
'after': dict(n1=979,n2=1400,o1=557.805,o2=5107.965,d1=0.010030675,d2=0.010035740,
scale='| scale dscale=0.3048'),
}
def grey(title,color='gist_earth'):
return '''
grey mean=y color=%s title="%s" scalebar=y transp=n yreverse=n
''' % (color,title)
for case in ('before','after'):
txt = 'st-helens_%s.txt' % case
Fetch(txt,'data',
server='https://raw.githubusercontent.com',
top='agile-geoscience/notebooks/master')
asc = case+'.asc'
Flow(asc,txt,'/usr/bin/tail -n +6')
Flow(case,asc,
'''
echo in=$SOURCE data_format=ascii_float
label=Elevation unit=m
n1=%(n1)d o1=%(o1)g d1=%(d1)g label1=X
n2=%(n2)d o2=%(o2)g d2=%(d2)g label2=Y |
dd form=native %(scale)s
''' % par[case],stdin=0)
Result(case,'clip2 lower=0 | ' + grey(case.capitalize()))
fill = case+'-fill'
Flow(fill,case,'clip2 lower=0 | lapfill grad=y niter=200 verb=y')
Result(fill,grey(case.capitalize()))
Flow('after-int','after-fill',
'''
remap1 n1=%(n1)d o1=%(o1)g d1=%(d1)g | transp |
remap1 n1=%(n2)d o1=%(o2)g d1=%(d2)g | transp
''' % par['before'])
Result('after-int',grey('After'))
def plsurf(title):
return '''
window j1=2 j2=2 | plsurf title="%s" color=gist_earth
''' % title
Result('before3','before-fill',plsurf('Before'))
Result('after3','after-int',plsurf('After'))
Flow('diff','before-fill after-int','add scale=1,-1 ${SOURCES[1]}')
Result('diff',grey('Difference') + ' allpos=y minval=0')
Result('diff3','diff',plsurf('Difference'))
End() |