-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmodel_parameters.py
170 lines (170 loc) · 5.29 KB
/
model_parameters.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
#
# Model Parmeters
#
# Peter Turney, February 17, 2020
#
# Set various parameters for running experiments
#
#
#
# Type of experiment:
#
# 1 = uniform asexual = asexual with bit-flip mutation but no seed size change
# 2 = variable asexual = asexual with bit-flip mutation and seed size change
# 3 = sexual = bit-flip mutation, seed size change, and crossover
# 4 = symbiotic = mutation, size change, crossover, fission, and fusion
#
experiment_type_num = 4
#
if (experiment_type_num == 1):
experiment_type_name = "uniform asexual"
elif (experiment_type_num == 2):
experiment_type_name = "variable asexual"
elif (experiment_type_num == 3):
experiment_type_name = "sexual"
else:
assert experiment_type_num == 4
experiment_type_name = "symbiotic"
#
# Set the random number generator seed here. If random_seed is negative,
# then Python will automatically set a random number seed. Note that, if
# random_seed is negative, then the experiment cannot be exactly repeated.
#
random_seed = -1
#
# Directory for log files.
#
log_directory = "../New Paper/Section 4.4/Layer 4/run12"
#
# Fixed population size. Steady-state model for evolution. For every
# birth, there is one death.
#
pop_size = 200
#
# The number of trials for a given pair of seeds. Each pair of seeds
# competes several times, with different rotations and different
# locations in Golly space. The final result for the pair is the
# average of the trials.
#
num_trials = 2
#
# run_length: the number of children born in one run. Each child that
# is born will replace an existing member of the population, so the
# size of the population is constant.
#
# num_generations: one generation is when pop_size children are born.
#
# We want run_length to be evenly divisible by pop_size, because we
# take samples of the population at the end of each generation.
#
num_generations = 100
#
run_length = num_generations * pop_size
#
# Minimum seed sizes.
#
min_s_xspan = 5
min_s_yspan = 5
#
# Initial seed sizes.
#
s_xspan = 5
s_yspan = 5
#
assert s_xspan >= min_s_xspan
assert s_yspan >= min_s_yspan
#
# Maximum seed area: The maximum seed area increases linearly with
# each new child born. Here we set the desired maximum seed area
# for the first child and the last child. The motivation for this
# linear limit to the seed area is to prevent an explosive increase
# in seed area, which causes the simulation to run extremely
# slowly. This limit is due to a lack of patience on my part; it
# is not intended to model a natural phenomenon.
#
max_area_first = 120
max_area_last = 170
#
# Probability of state 1 for random initialization of a new seed.
# For the initial random seeds, use a random density of 37.5%. See:
#
# http://www.njohnston.ca/2009/06/longest-lived-soup-density-in-conways-game-of-life/
# http://www.njohnston.ca/2009/07/the-maximal-lifespan-of-patterns-in-conways-game-of-life/
#
seed_density = 0.375
#
# Multiply the sizes of the seeds by this factor to get the size
# of the toroid. Thus the toroid expands as the seeds get larger.
# The width is greater than the height because the two seeds are
# positioned side-by-side horizontally.
#
width_factor = 6.0
height_factor = 3.0
#
# Multiply the sizes of the toroid by this factor to get the
# number of generations for a run. Thus the running time
# increases as the toroid expands.
#
time_factor = 6.0
#
# The size of the random sample for a tournament. The most fit
# member of the tournament sample will be allowed to reproduce.
#
tournament_size = 2
#
# Probability for mutation in uniform asexual experiments
# (type 1; see above).
#
mutation_rate = 0.01
#
# Probabilities for the three kinds of mutation in variable
# asexual experiments (type 2; see above).
#
# prob_grow = probability of invoking grow()
# prob_flip = probability of invoking flip_bits()
# prob_shrink = probability of invoking shrink()
#
# Constraints:
#
# - all parameters must lie in the range from 0.0 to 1.0
# - the parameters must sum to 1.0
#
prob_grow = 0.2
prob_flip = 0.6
prob_shrink = 0.2
#
assert prob_grow + prob_flip + prob_shrink == 1.0
#
# Elite size: size of the sample that will be used to evaluate
# whether the best seeds (the elite) are getting better.
#
elite_size = 50
#
# Two seeds are allowed to mate (that is, they are considered as
# member of the same species) when they are highly similar but
# not identical. The following parameters define the desired
# region of similarity for mating.
#
min_similarity = 0.80
max_similarity = 0.99
#
# For symbiosis, set the probabilities of fission and fusion.
# Because fusion can result in large seeds, which will slow down
# the simulation, the probability of fusion should be relatively
# low.
#
prob_fission = 0.01
prob_fusion = 0.005
#
assert prob_fission + prob_fusion <= 1.0
#
# Fusion test flag: If this flag is 0, then everything proceeds
# as usual. If this flag is 1, then fusion is modified by
# shuffling one of the two seeds that are about to be fused.
# The purpose of shuffling is to demonstrate that the structure
# of the seeds is important for fitness with fusion. That is,
# shuffling is expected to reduce fitness with fusion. In most
# cases, this test flag should be set to 0.
#
fusion_test_flag = 0
#