-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathice_pytough.py
573 lines (519 loc) · 24.5 KB
/
ice_pytough.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
# -*- coding: utf-8 -*-
"""
Created on Tue Jan 13 09:57:38 2015
\n
Module containing fuctions for building and running pytough icey models. \n
Reading results\n
@author: Brioch Hemmings
"""
from t2grids import *
from t2data import * # import classes and routines for creating TOUGH2 files
from t2incons import *
from t2listing import *
import numpy as np
import scipy as spy
import shutil
import time
import os
import pytoughgrav as ptg
import matplotlib.pyplot as plt
def icegeo( modelname, length = 500., depth = 500., width = 1., celldim = 10.,
origin = ([0,0,0]), xcells = None, zcells = None,
surface = None, wells = None, atmos_type=0, min_thick=2.0):
"""
method for defining geometry of ice work.
Initially it is the same as ptg definition so is just passed to that.
"""
geo=ptg.geo2D( modelname, width=width, celldim=celldim, origin=origin,
zcells=zcells, xcells=xcells, surface=surface, atmos_type=atmos_type, min_thick=min_thick)
return geo
def icegrid(geo,dat,rocks,boundcol,eos=3,lpregion=None,hpregion=None,heatsource=None,satelev=0.0,atmosP=1.013e5,pmx_lamda=0.004, glacier_limit=2500., infax=False, topsurf=None,radial=False):
"""
Method for defining ice grid. Varies slightly from ptg method.
"""
grid = t2grid().fromgeo(geo)
atmos=grid.atmosphere_blocks
# loop over list of rocktypes and add to pytough gird object
for rock in rocks:
grid.add_rocktype(rock)
# loop over every element block in the grid
for blk in grid.blocklist[0:]:
blk.hotcell=False
lay=geo.layer[geo.layer_name(str(blk))] # layer containing current block
col=geo.column[geo.column_name(str(blk))] # column containing current block
tlay=geo.column_surface_layer(col)
if topsurf is not None:
ind=topsurf[:,0].tolist().index(col.centre[0])
hmax=topsurf[ind,1]
else: hmax=col.surface
if blk in atmos:
rocktype='top ' # assign rocktype "top "
initP=atmosP*spy.power(1.-(col.surface*2.25577e-5),5.25588) # initial presure condition - MAY NOT BE APPROPRIATE - WHAT IS THE PRESSURE UNDER THICK GLACIER AT 5000 m amsl??
Tmin=2.
#if blk.centre[0] <= 250.:
#initT=50.#Tmin + (hmax-blk.centre[2])*(12.5/100.)
if 350.< blk.centre[0] <= glacier_limit:
initT=Tmin#+(hmax-blk.centre[2])*(12.5/100.) # initial temperature - TOUGH2 doesn't seem to like < 1.0 C
else:
initT = 25.8 - (hmax*(5.4/1000.)) #+ (hmax-blk.centre[2])*(12.5/100.) # 15.+((2000.-blk.centre[2])*(5.4/1000.0))
if initT <= Tmin: initT=Tmin
#initT=25.8 - (hmax*(5.4/1000.)) + (hmax-blk.centre[2]*15./100.) 150.+(-0.0225*blk.centre[0])
if (hpregion is not None and 'hp ' in grid.rocktype.keys()):
for rt,hpr in hpregion.iteritems():
if (blk.centre[2] > hpr[0][2] and
blk.centre[2] <= hpr[1][2] and
blk.centre[0] > hpr[0][0] and
blk.centre[0] <= hpr[1][0]): #if in hp region
rocktype=rt#'hp ' # this allows a different pmx for atmos above highperm
initSG=0.999 # initial gas saturation
infvol=False # already given 1e50 volume
# if topsurf is not None:
# ind=topsurf[:,0].tolist().index(col.centre[0])
# hmax=topsurf[ind,1]
# pmx=pmxcalc(blk,grid,hmax,rocktype,0.004,800.)
# else:
pmx=grid.rocktype[rocktype].permeability[0]
rocktype='top ' # resets to rocktype "top "
else:
rocktype = 'main '
initP=(atmosP*spy.power(1.-(col.surface*2.25577e-5),5.25588))+(997.0479*9.81*abs(col.surface-blk.centre[2]))
if blk.centre[2]<4800:
initSG=0.0
else:
initSG=10.3
if blk.centre[0]<10000:
initT=Tmin + ((np.abs(hmax-blk.centre[2])/100.0)*12.5)
else:
initT=Tmin + 10.0 + ((np.abs(hmax-blk.centre[2])/100.0)*3.0)
if initT > 350.: initT=350.
infvol=False
if lay==geo.layerlist[-1]:
rocktype='sourc'
if (lpregion is not None and 'lp ' in grid.rocktype.keys() and
blk.centre[2] > lpregion[0][2] and
blk.centre[2] <= lpregion[1][2] and
blk.centre[0] > lpregion[0][0] and
blk.centre[0] <= lpregion[1][0]): # if in lp region
rocktype='lp '
if (hpregion is not None and 'hp ' in grid.rocktype.keys()):
for rt,hpr in hpregion.iteritems():
if (blk.centre[2] > hpr[0][2] and
blk.centre[2] <= hpr[1][2] and
blk.centre[0] > hpr[0][0] and
blk.centre[0] <= hpr[1][0]): #if in hp region
rocktype=rt#'hp '
if (heatsource is not None and
blk.centre[2] > heatsource[0][2] and
blk.centre[2] <= heatsource[1][2] and
blk.centre[0] > heatsource[0][0] and
blk.centre[0] <= heatsource[1][0]): # if in heatsource region
rocktype='hotcl'
initT=350
infvol=True
blk.hotcell=True
if infax is True and col is geo.columnlist[5] and lay == tlay:
print "inf vol top axis cell " + blk.name
infvol=True
initSG=10.9999
rocktype='bound'
if not radial and col in boundcol:
print "inf vol boundary cell " + blk.name
infvol=True
initSG=0.0
rocktype='bound'
pmx=pmxcalc(blk,grid,hmax,rocktype,0.004,800.)
ptg.rockandincon(blk,grid,dat,rocktype,initP,initSG,initT,pmx,eos=eos,infvol=infvol)
return grid
def pmxcalc(blk,grid,hmax,rock,Saar_lam=0.004,switch_depth=None):
depth=hmax-blk.centre[2]
if switch_depth is not None:
if depth < switch_depth:
pmx=grid.rocktype[rock].permeability[0]*np.exp(-Saar_lam*depth) # calculating depth dependent permeability modifier
else: pmx=grid.rocktype[rock].permeability[0]*np.exp(-Saar_lam*(switch_depth))*((depth/switch_depth)**-3.2)
else:
pmx=grid.rocktype[rock].permeability[0]*np.exp(-Saar_lam*depth)
return pmx
def heatgen(mod,geo,dat,grid,heat_flux,function=None, inject=None, inject2=None):
f = open(mod+'/Heat_genertot.txt','w')
f.write('Model = '+mod+'\n')
allgens=[]
allinject=[]
cols=[col for col in geo.columnlist]
if function is not None:
func=function['type']
if func=='exp':
p1=function['points'][0]
p2=function['points'][1]
b=spy.log(p1[1]/p2[1])/(p1[0]-p2[0])
a=p1[1]/spy.e**(p1[0]*b)
f.write('exponential spatial generation Q=ae^bx '+str(a)+'e^('+str(b)+'x) J/s/m2\n')
elif func=='log':
p1=np.array(function['points'][0])
p2=np.array(function['points'][1])
a=(p1[1]-p2[1])/(spy.log(p1[0]/p2[0]))
b=spy.e**((p2[1]*spy.log(p1[0])-p1[1]*spy.log(p2[0]))/(p1[1]-p2[1]))
f.write('logarithmic spatial generation Q=a*ln(bx) '+str(a)+'ln('+str(b)+'x) J/s/m2\n')
else:
func='Constant'
f.write('Constant generation ='+str(heat_flux)+' J/s/m2\n')
for col in cols:
lay=geo.layerlist[-1] # bottom layer
blkname=geo.block_name(lay.name,col.name) # get block name for the bottom layer of this column
if grid.block[blkname].hotcell is not True:
if func=='exp':
heat_flux=a*spy.e**(b*grid.block[blkname].centre[0])
elif func=='log':
#if grid.block[blkname].centre[0] < 250:
# heat_flux=p1[1]
#else:
heat_flux=a*spy.log(b*(grid.block[blkname].centre[0]))
#gxa=[0.0]+[col.area*heat_flux]*2
gxa=col.area*heat_flux
#times=[0.]+[1000*365.25*3600*24]+[1.0e6*365.25*3600*24]
#numt=len(times)
gen=t2generator(name=' H'+col.name,block=blkname,type='HEAT',gx=gxa, ex=None,hg=None,fg=None)#, rate=gxa, time=times, ltab=numt) # creat a generater oject with the heat generation rate of tflux - muliplication by column area important.
dat.add_generator(gen) # add generater to TOUGH2 input
allgens.append(gxa)
if inject is not None:
if grid.block[blkname].centre[0] < inject[0]:
ixa=col.area*inject[1]
gen=t2generator(name=' i'+col.name,block=blkname,type='COM1',gx=ixa, ex=inject[2]) # create a generater oject with the heat generation rate of tflux - muliplication by column area important.
dat.add_generator(gen)
allinject.append(ixa)
if inject2 is not None:
lays=[lay for lay in geo.layerlist if inject2[0] < lay.centre < inject2[1]]
for lay in lays:
col=geo.columnlist[0] # first column
blkname=geo.block_name(lay.name,col.name)
ixa=lay.get_thickness()*2*np.pi*col.get_side_lengths()[1]*inject2[2]
gen=t2generator(name='i'+lay.name+'01',block=blkname,type='COM1',gx=ixa, ex=inject2[3]) # create a generater oject with the heat generation rate of tflux - muliplication by column area important.
dat.add_generator(gen)
allinject.append(ixa)
allgens=np.array(allgens)
gensum=np.sum(allgens)
allinject=np.array(allinject)
injectsum=np.sum(allinject)
f.write('Total generation in model = '+str(gensum)+' J/s\n')
f.write('Total generation rate per m2 = '+str(gensum/geo.area)+' J/s/m2\n')
if inject is not None:
f.write('Total injection in model = '+str(injectsum)+' kg/s\n')
f.write('injection rate per m2 = '+str(inject[1])+' kg/s/m2\n')
f.close()
def simple_readres( modelname, savevtk=False, tough2_input=None, geom_data=None, results=None):
"""Easy reading of TOUGH2 results into pyTOUGH. Option to write out vtk results files. Will return pyTOUGH results object if desired.
Usage:
results=simple_readres(modelname, kwargs)
modelname = directory name of model as string, e.g. "20150202_1"
Optional kwargs:
savevtk: flag to save vtk results files [default=False]
tough2_input: provide the name of the tough2 input file [dafault="flow2.inp"]
geom_data: provide name of pyTOUGH geometry data file ["grd.dat"]
results: if results object already exists [None]
"""
mod=modelname # define modelname
current_d=os.getcwd() # find current directory
print os.getcwd()
os.chdir(mod) # change to model directory
print('Reading '+mod+' results from: ') #
print os.getcwd()
## read output file
t0=time.clock()
if tough2_input is None:
dat=t2data('flow2.inp') # tough2 input from input file
else: dat=tough2_input
if geom_data is None:
geo=mulgrid('grd.dat') # geometry from geometry file
else: geo=geom_data
if results is None:
resfile='flow2.out'
# resfile=gzip.open('flow2.out.gz','r').read()
results=t2listing(resfile) # read output file
else:
results=results
grid=dat.grid # define input grid
t1=time.clock()
t=t1-t0
print 'time2read .out=',t
## create directory for results
if not os.path.exists('results'):
os.makedirs('results')
os.chdir('results')
## save vtks...
if savevtk:
t0=time.clock()
results.write_vtk(geo,mod+'_out.vtk',grid=grid,flows=True, time_unit='y')
t1=time.clock()
t=t1-t0
print 'time2writevtks',t
os.chdir(current_d)
return geo,grid,dat,results
def icepost( modelname, save=False, radial=True, savevtk=False, geom_data=None, tough2_input=None, results=None, times={}, fall=None,flows={'FLOH':{},'FLOF':{}}, logt=False):
""" Function to calculated surface heat flow from pytough results
"""
if type(tough2_input) is not t2data and tough2_input is not None:
raise TypeError('data needs to be type t2data. Type ' + str(type(tough2_input)) + ' found. You idiot')
elif tough2_input is None:
raise TypeError('data needs to be type t2data. Currently None found. You idiot')
else: dat=tough2_input
if type(geom_data) is not mulgrid and geom_data is not None:
raise TypeError('data needs to be type mulgrid. Type ' + str(type(geom_data)) + ' found. You idiot')
elif geom_data is None:
raise TypeError('data needs to be type mulgrid. Currently None found. You idiot')
else: geo=geom_data
if type(results) is not t2listing and results is not None:
raise TypeError('results needs to be type t2listing. Type ' + str(type(results)) + ' found. You idiot')
elif results is None:
print('No Results files (flow.out) passed. please read flow2.out')
results=results
width=geo.bounds[1][1]-geo.bounds[0][1]
yrsec=365.25*3600*24
mod=modelname
if radial and not geo.radial:
ptg.makeradial(geo,None,width)
# find atmosphere blocks
grid=dat.grid # define input grid
grid2=t2grid().fromgeo(geo) # grid saved in flow2.inp does not contain atmos information required.
atmos=[]
atmosconn=[]
for flow in flows:
t0=time.clock()
if flows[flow]=={}:
if atmos==[]:
atmos=grid2.atmosphere_blocks
# find atmosphere connections
atmosconn=[cell.connection_name for cell in atmos] # returns a list of sets - !!!! sets are not ordered so cannot be indexed !!!
flows[flow],times = surfaceflow(atmos,atmosconn,results=results,grid=grid2,flow=flow)
tq=times
X=[]
qts=[]
Area=[]
for x,a,q in flows[flow].values():
X.append(x)
qts.append(q)
Area.append(a)
inds=np.array(X).argsort()
X=np.array(X)[inds]
qts=np.array(qts)[inds] # J/s/m2 or kg/s/m2
Area=np.array(Area)[inds]
totq=np.sum(np.multiply(qts.T,Area),axis=1)
if flow=='FLOH' or flow=='FHEAT': # calculate meltrate etc.
unit='W'
meltratematrix= (qts.T/3.335E5) # kg/s/m2
# but negative meltrate cant exist....
# where heatflow is negative and meltrate is negative set meltrate=0
#tempdel=np.array([tstep-meltratematrix[0] for tstep in meltratematrix]) # kg/s/m2 ~ mm/s
meltratematrix[meltratematrix<0]=0 # kg/s/m2
# change in meltrate
deltameltrate=np.array([tstep-meltratematrix[0] for tstep in meltratematrix]) # kg/s/m2 ~ mm/s
#meltrate just within glacier
glacmeltrate=meltratematrix.T[X<2500].T # kg/s/m2 ~ mm/s
print np.max(glacmeltrate)
#change in meltrate within glacier
deltaglacmeltrate=deltameltrate.T[X<2500].T # kg/s/m2 ~ mm/s
i=0
meltrate=np.zeros(len(tq))
for t in tq:
for x,A,r in zip(X,Area,meltratematrix[i]):
if r> 0 and x < 2500:
meltrate[i]= meltrate[i] + (r*A) # kg/s
i=i+1
meltrate_mmpyr= (meltrate*yrsec)/(np.pi*(2500**2)) # kg/yr/m2 ~ mm/yr
else:
unit='kg/s'
# plottings
tscale=tq/yrsec
if logt:
tscale=np.log10(tscale)
## a quick plot of flows into atmosphere at X and time.
plt.figure()
plt.pcolormesh(X,tscale,qts.T, rasterized=True,cmap='rainbow') #W or (ks/s) /m2
cbar=plt.colorbar(format='%.1e')
cbar.set_label(flow + r' out of the model ('+ unit + r'/m$^{2}$)')
#plt.xlim(0,2500)
plt.ylim(tscale.min(),tscale.max())
plt.title('Flow ('+flow+') out of the model')
plt.xlabel('Distance from axial centre (m)')
plt.ylabel('Time (yrs)')
plt.tight_layout()
if save:
plt.savefig('results/'+mod+'_'+flow+'_.pdf',dpi=400)
qout=np.ma.masked_array(qts,[qts<0]) # mask where flow is negative (i.e. in to the model)
qin=np.ma.masked_array(qts,[qts>0]) # mask where flow is positive (i.e. out of the model)
delqout=np.array([tstep-qts.T[0] for tstep in qout.T]) # kg/s/m2 ~ mm/s
delqin=np.array([qts.T[0]-tstep for tstep in qin.T])
plt.figure()
plt.pcolormesh(X,tscale,delqout, rasterized=True,cmap='rainbow') #W or (ks/s) /m2
cbar=plt.colorbar(format='%.1e')
cbar.set_label('Change in '+ flow + r' out of the model ('+ unit + r'/m$^{2}$)')
#plt.xlim(0,2500)
plt.ylim(tscale.min(),tscale.max())
plt.title('Change in flow ('+flow+') out of the model')
plt.xlabel('Distance from centre axis (m)')
plt.ylabel('Time (yrs)')
plt.tight_layout()
if save:
plt.savefig('results/'+mod+'_delout_'+flow+'_.pdf',dpi=400)
plt.figure()
plt.pcolormesh(X,tscale,delqin, rasterized=True,cmap='rainbow') #W or (ks/s) /m2
cbar=plt.colorbar(format='%.1e')
cbar.set_label('Change in '+ flow + r' in to the model ('+ unit + r'/m$^{2}$)')
#plt.xlim(0,2500)
plt.ylim(tscale.min(),tscale.max())
plt.title('Change in flow ('+flow+') in to the model')
plt.xlabel('Distance from centre axis (m)')
plt.ylabel('Time (yrs)')
plt.tight_layout()
if save:
plt.savefig('results/'+mod+'_delin_'+flow+'_.pdf',dpi=400)
# plt.figure()
# plt.plot(tscale,totq)
# #plt.xlim(0, 30000)
# plt.xlabel('Time (years)')
# plt.ylabel('Net flow ('+unit+')')
# plt.title('Net flow in/out of surface')
if save:
if os.path.isfile('results/'+flow+'.pkl'):
print(flow+' flow alreay pickled')
else:
ptg.save_obj(flows[flow],'results/'+flow+'.pkl')
if os.path.isfile('results/time.pkl'):
print('time alreay pickled')
else:
ptg.save_obj(tq,'results/time.pkl')
t1=time.clock()
print 'time for flow=',(t1-t0)
if savevtk and os.path.isfile('results/'+mod+'_output.vtk') is False:
os.chdir('results')
results.write_vtk(geo,mod+'_output.vtk',grid=grid,flows=True)
os.chdir('..')
plt.figure()
plt.pcolormesh(X,tscale,meltratematrix, rasterized=True,cmap='rainbow') # mm/s
cbar=plt.colorbar(format='%.1e')
cbar.set_label(r'Melt rate (kg/s/m$^{2}$)')
#plt.xlim((0,2500))
plt.ylim(tscale.min(),tscale.max())
plt.xlabel('Distance from centre axis (m)')
plt.ylabel('Time (yrs)')
plt.title('Melt rate')
plt.tight_layout()
if save:
plt.savefig('results/'+mod+'_meltrate_.pdf',dpi=400)
plt.figure()
plt.pcolormesh(X[X<2500],tscale,glacmeltrate, rasterized=True,cmap='rainbow')#, vmax=3.2e-4) # mm/s
cbar=plt.colorbar(format='%.1e')
cbar.set_label(r'Glacial melt rate (kg/s/m$^{2}$)')
#plt.xlim((0,250))
plt.ylim(tscale.min(),tscale.max())
plt.xlabel('Distance from centre axis (m)')
plt.ylabel('Time (yrs)')
plt.title('Melt rate')
plt.tight_layout()
if save:
plt.savefig('results/'+mod+'_glac_meltrate_.pdf',dpi=400)
plt.figure()
plt.pcolormesh(X,tscale,deltameltrate, rasterized=True,cmap='rainbow') # mm/s
cbar=plt.colorbar(format='%.1e')
cbar.set_label(r'Change in melt rate (kg/s/m$^{2}$)')
#plt.xlim((0,2500))
plt.ylim(tscale.min(),tscale.max())
plt.xlabel('Distance from centre axis (m)')
plt.ylabel('Time (yrs)')
plt.title('Change in melt rate')
plt.tight_layout()
if save:
plt.savefig('results/'+mod+'_meltrate_delta_.pdf',dpi=400)
plt.figure()
plt.pcolormesh(X[X<2500],tscale,deltaglacmeltrate, rasterized=True,cmap='rainbow') # mm/s
cbar=plt.colorbar(format='%.1e')
cbar.set_label(r'Change in melt rate (kg/s/m$^{2}$)')
plt.xlim((0,2500))
plt.ylim(tscale.min(),tscale.max())
plt.title('Change in glacial melt rate')
plt.tight_layout()
if save:
plt.savefig('results/'+mod+'_glacmeltrate_delta_.pdf',dpi=400)
#############
#np.savetxt("melt_time.txt", np.vstack(([tq], [meltrate],[meltrate_mpyr])).T)
plt.figure()
plt.plot(tscale,meltrate_mmpyr)
#plt.xlim(0, 30000)
plt.xlabel('Time (yrs)')
plt.ylabel('Average melt rate at glacial base (mm/yr)')
plt.title('Average basal meltrate')
plt.tight_layout()
if save:
plt.savefig('results/'+mod+'_basalmelt.pdf')
def surfaceflow(atmoscells,atmosconns,results=None,grid=None,flow='FLOH'):
# totq=glac_toq=np.zeros(results.num_times) # arrays for adding total flows at each timstep
# X=np.array([]).reshape(0,1) # array for storing the x dimension of each connection
# Area=np.array([]).reshape(0,1)
# qts=[] # empty list for storing all flows
flowDict={}
sels=[('c',conn,flow) for atmosset in atmosconns for conn in atmosset]
Q=results.history(sels)
tq=Q[0][0]
for sel,q in zip(sels,Q):
conn=sel[1]
cell1,cell2=conn
# tq is time, q is flow
#(tq,q) = results.history([('c', conn, flow)]) # here just pull out flow of HEAT (could do more)
# flow from cell1 to cell2 is negative we want to make it uniform so that flow into the atmosphere is always negative
if grid.block[cell2] in atmoscells:
q=-q[1]/(grid.connection[conn].area) # divide by conneciton area to get flux in /m2
cen=grid.block[cell1].centre #
elif grid.block[cell1] in atmoscells:
q=q[1]/(grid.connection[conn].area) # if atmos cell is cell1 the sign of the flow needs to be switched
cen=grid.block[cell2].centre
flowDict[conn]=cen[0],grid.connection[conn].area,q # dictionary of flow timseries for each connection
# compile all the flow time series (for each connection)
# if qts == []:
# qts=[q] # the first time through need to initialise our list
# else:
# qts=np.concatenate((qts,[q]),axis=0) # add the current flow time series to our compilations
# X=np.append(X,cen[0]) # also create array of connection distance
# Area= np.append(Area,grid2.connection[conn].area)
# totq=np.add(totq,q) # timeseries of total heat flux into atmos
# # can look at total heat flux that is within a certain X limit (e.g. within the range of a glacier)
# if cen[0] <= 2500.0:
# glac_toq=np.add(glac_toq,q)
#atxs[conn]=cen[0]
return flowDict,tq
def makewt(model,geo=None,grid=None,dat=None,results=None):
t0=tinit=time.clock()
mod=model # define model name
read=True ########### I N P U T #########################
readgeo=True ########### I N P U T #########################
geo_fname='grd.dat'
readdat=True ########### I N P U T #########################
dat_fname='flow2.inp'
readresults=True ########### I N P U T #########################
results_fname='flow2.out'
print 'model=',mod
os.chdir('C:/Users/glbjch/Local Documents/Work/Modelling/Cotapaxi/'+mod)
if read:
if geo is None:
print 'Reading geometry from '+ geo_fname
geo=mulgrid(geo_fname)
geo.radial=False # set flag that geometry is not yet radial.
if dat is None:
print 'Reading input data from '+ dat_fname
dat=t2data(dat_fname)
if results is None:
print 'Reading results from '+ results_fname
results=t2listing(results_fname)
t1=time.clock()
print 'time to read=',(t1-t0)
if grid is None:
grid=dat.grid # define input grid
xz=[]
results.last()
sat=results.element['SL']
for col in geo.columnlist:
colblklist= [block for block in grid.blocklist if block.centre[0]==col.centre[0] and sat[geo.block_name_index[block.name]]==1.0]
wtelev=np.max([geo.block_surface(geo.layer[geo.layer_name(str(blk))],col) for blk in colblklist])
xz.append([col.centre[0], wtelev])
xz.append([xz[-1][0]+xz[0][0],xz[-1][1]])
xz.insert(0,[xz[0][0]-xz[0][0],xz[0][1]])
xz=np.array(xz)
np.savetxt('surface.txt',xz,header='/Distance\tHeight',fmt='%g',delimiter='\t')
os.chdir('..')