forked from Thiemann96/Geosimulation
-
Notifications
You must be signed in to change notification settings - Fork 0
/
main_predatorInf.py
203 lines (164 loc) · 8.78 KB
/
main_predatorInf.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
from pcraster import *
from pcraster.framework import *
import csv
class MyFirstModel(DynamicModel):
def __init__(self):
DynamicModel.__init__(self)
setclone("main.map")
def initial(self):
# Creation if initial predator & prey map
# Prey:
self.prey = uniform(1)
# Set probability for prey to 10 %
self.prey = self.prey<0.3 # to be made random ..
# Save as map
self.report(self.prey,"preyMap")
# Predator:
self.predatormap = uniform(1)
# Set probability for predator to 5 %
self.predator = self.predatormap<0.3
# Save as map
self.report(self.predator,"predatorMap")
# infected Predator:
# Set probability for predator to 5 %
self.infectedPredator = pcrand(self.predatormap>0.3, self.predatormap<0.4)
# Save as map
self.report(self.infectedPredator,"infectedPredatorMap")
# Equilibrium state variables:
self.iter = 0
self.emptymap = scalar((uniform(1)))*0
self.preyDensity = [0]*30
self.predDensity = [0]*30
self.preyInitDensity = areaaverage(scalar(self.prey),nominal(self.emptymap))
self.predInitDensity = areaaverage(scalar(self.predator),nominal(self.emptymap))
self.preyFinalDensityCSV = list()
self.predFinalDensityCSV = list()
self.already = False
print("Finished building maps for prey&predator distribution")
def dynamic(self):
# Determine cells which were occupied by both, prey and predator in last timestep
both = pcrand(self.prey, self.predator)
# Determine cells which are occupied by prey only in last timestep
alivePrey = pcrand(self.prey, pcrnot(self.predator))
# Determine the number of cells with prey only in Von Neumann neighborhood of each cell in last timestep
preyBirth = window4total(scalar(alivePrey))
# Determine whether a cell had any cells with prey only in Von Neumann neighborhood or was prey only in the last timestep
preyBirth = pcror(preyBirth>0.0, alivePrey)
# All of the cells in preyBirth become prey in the current timestep
self.prey = preyBirth
# Determine number of infected predators in neighbourhood
infectedNeighbour = window4total(scalar(self.infectedPredator))
infectedNeighbour = infectedNeighbour>0.0
# Determine cells that do fully reproduce (only have non infected neighbours and can eat)
doIReproduce = pcrand(both, pcrnot(infectedNeighbour))
# Determine the number of cells with both, prey and (sound) predator in Von Neumann neighborhood of each cell in last timestep
birthByNeighbour = window4total(scalar(doIReproduce))
birthByNeighbour = birthByNeighbour>0.0
# Determine whether a cell has any cells with both, prey and predator in Von Neumann neighborhood or is itself both prey and predator in last timestep
predatorBirth = pcror(birthByNeighbour, doIReproduce)
# Determine the cells that become infected
infectedCells = pcrand(infectedNeighbour, both)
self.infectedPredator = infectedCells
# All of the cells in predatorBirth become predator in the current timestep
self.predator = pcrand(predatorBirth, pcrnot(infectedCells))
# Save prey and predator distribution of current timestep each as a map
self.report(self.infectedPredator, 'infPred')
self.report(self.predator,'predator')
self.report(self.prey,"prey")
# <--------------------------------- Equilibrium --------------------------------->
# Find equilibrium state. Assumption: equilibrium = mean density of prey/predator for last 10 iterations is in one standard error deviation from the mean density of the previous 30 iterations
# <------------------------------------ Prey ------------------------------------->
# Create variables
preyMean10 = 0
preyMean30 = 0
preySeries = 0
# Save the density of prey for each of the last 30 iterations
if self.iter<30:
self.preyDensity[self.iter] = areaaverage(scalar(self.prey),nominal(self.emptymap))
else:
for i in range(29):
self.preyDensity[i]=self.preyDensity[i+1]
self.preyDensity[29] = areaaverage(scalar(self.prey),nominal(self.emptymap))
# After the first 30 iterations look for equilibrium
if self.iter>=29:
# Calculate the average number of prey in the last 10 iterations
for i in range(10):
preyMean10 = preyMean10 + self.preyDensity[29-i]
preyMean10 = preyMean10 / 10
# Calculate the average number of prey in the last 30 iterations
for i in range(30):
preyMean30 = preyMean30 + self.preyDensity[i]
preyMean30 = preyMean30 / 30
# Calculate the standard deviation of prey for the last 30 iterations
for i in range(30):
preySeries = preySeries + (self.preyDensity[i] - preyMean30)**2
preySD30 = sqrt(preySeries/30)
# Calculate the standard deviation of prey for the last 10 iterations
for i in range(10):
preySeries = preySeries + (self.preyDensity[29-i] - preyMean10)**2
preySD10 = sqrt(preySeries/10)
# Validate equilibrium:
equlibriumPrey = (preyMean10 > (preyMean30 - preySD30)) & (preyMean10 < (preyMean30 + preySD30))
# Save density of prey in the state of equilibrium
preyFinalDensity = ifthen(equlibriumPrey, areaaverage(scalar(self.prey),nominal(self.emptymap)))
preyFinalDensityCSV = pcraster.cellvalue(preyFinalDensity,1)[0]
preyInitDensity = pcraster.cellvalue(self.preyInitDensity,1)[0]
self.preyFinalDensityCSV.append(preyFinalDensityCSV)
self.report(preyFinalDensity,"preyDens")
# <---------------------------------- Predator ----------------------------------->
# Create variables
predMean10 = 0
predMean30 = 0
predSeries = 0
# Save the density of pred for each of the last 30 iterations
if self.iter<30:
self.predDensity[self.iter] = areaaverage(scalar(self.predator),nominal(self.emptymap))
else:
for i in range(29):
self.predDensity[i]=self.predDensity[i+1]
self.predDensity[29] = areaaverage(scalar(self.predator),nominal(self.emptymap))
# After the first 30 iterations look for equilibrium
if self.iter>=29:
# Calculate the average number of pred in the last 10 iterations
for i in range(10):
predMean10 = predMean10 + self.predDensity[29-i]
predMean10 = predMean10 / 10
# Calculate the average number of pred in the last 30 iterations
for i in range(30):
predMean30 = predMean30 + self.predDensity[i]
predMean30 = predMean30 / 30
# Calculate the standard deviation of pred for the last 30 iterations
for i in range(30):
predSeries = predSeries + (self.predDensity[i] - predMean30)**2
predSD30 = sqrt(predSeries/30)
# Calculate the standard deviation of pred for the last 10 iterations
for i in range(10):
predSeries = predSeries + (self.predDensity[29-i] - predMean10)**2
predSD10 = sqrt(predSeries/10)
# Validate equilibrium:
equlibriumPred = (predMean10 > (predMean30 - predSD30)) & (predMean10 < (predMean30 + predSD30))
# Save density of pred in the state of equilibrium
predFinalDensity = ifthen(equlibriumPred, areaaverage(scalar(self.predator),nominal(self.emptymap)))
predFinalDensityCSV = pcraster.cellvalue(predFinalDensity,1)[0]
predInitDensity = pcraster.cellvalue(self.predInitDensity,1)[0]
self.predFinalDensityCSV.append(predFinalDensityCSV)
self.report(predFinalDensity,"predDens")
# Confirm if equilibrium is validated (map has value true)
if(pcraster.cellvalue(equlibriumPred,1)[0]):
# When an equilibrium has already been found in this execution do nothing
if(not(self.already)):
# When an equilibrium has not been found log the neccessary values to csv
print("Equilibrium found.. writing to csv...")
array = [preyInitDensity,predInitDensity,self.preyFinalDensityCSV[0],self.predFinalDensityCSV[0]]
with open('states.csv','a',newline="\n") as file:
writer = csv.writer(file, delimiter=';',
quotechar='|', quoting=csv.QUOTE_MINIMAL)
writer.writerow([array[0],array[1],array[2],array[3]])
# Set already to true to not calculate any further
self.already = True
self.iter=self.iter+1
# Run the model 100 times
nrOfTimeSteps=100
myModel = MyFirstModel()
dynamicModel = DynamicFramework(myModel,nrOfTimeSteps)
dynamicModel.run()