forked from computationalgeography/pycatch
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain_seconds.py
71 lines (56 loc) · 2.2 KB
/
main_seconds.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
# general
import datetime
import glob
import sys
import os
# add path to modules required
sys.path.append("./pcrasterModules/")
import configuration_seconds as cfg
# PCRaster itself
import pcraster as pcr
import pcraster.framework as pcrfw
# from pcrasterModules
import generalfunctions
import rainfallperiodconstant
import runoffkinematic
# from this folder
import exchangevariables
class CatchmentModel(pcrfw.DynamicModel, pcrfw.MonteCarloModel):
def __init__(self):
pcrfw.DynamicModel.__init__(self)
pcrfw.MonteCarloModel.__init__(self)
pcr.setclone(cfg.cloneString)
def premcloop(self):
self.clone = pcr.boolean(cfg.cloneString)
self.dem = pcr.scalar(cfg.dem)
def initial(self):
# time step duration in hours
self.timeStepDuration = cfg.timeStepDurationHoursFloatingPointValue
self.createInstancesInitial()
def dynamic(self):
rainfallFlux = self.d_rainfall.update(self.currentTimeStep())
self.report(rainfallFlux, 'p')
# discharge calculated with kinematic
actualAbstractionFromSurfaceWaterFlux, Q = self.d_runoffKinematic.update(rainfallFlux,0.0)
# discharge in cubic metres per second
self.report(Q,'q')
# discharge calculated with accuthreshold
QAccu = ((pcr.accuthresholdflux(cfg.lddMap, rainfallFlux,0.0) * pcr.cellarea()) * self.timeStepDuration ) / (self.timeStepDuration * 3600.0)
# discharge in cubic metres per second
self.report(QAccu,'qa')
def postmcloop(self):
print("no postmcloop functons")
def createInstancesInitial(self):
self.startRainStorm=0.1
self.endRainStorm=0.5
self.d_rainfall=rainfallperiodconstant.RainfallPeriodConstant(0.04, self.startRainStorm,
self.endRainStorm,self.timeStepDuration)
self.d_runoffKinematic=runoffkinematic.RunoffKinematic(
cfg.lddMap, cfg.dem, pcr.celllength(),
pcr.scalar(0.02), pcr.scalar(0.6), pcr.scalar(0.00000001),
pcr.scalar(0.000000001), self.timeStepDuration)
myModel = CatchmentModel()
dynamicModel = pcrfw.DynamicFramework(myModel, cfg.numberOfTimeSteps)
mcModel = pcrfw.MonteCarloFramework(dynamicModel, cfg.nrOfSamples)
mcModel.setForkSamples(True, 10)
mcModel.run()