MilesCranmer commited on
Commit
311797d
·
1 Parent(s): 3336e27

Fix issue with empty hall of fame

Browse files
Files changed (3) hide show
  1. benchmark.jl +7 -3
  2. eureqa.jl +1 -1
  3. paralleleureqa.jl +3 -3
benchmark.jl CHANGED
@@ -6,14 +6,17 @@ fullRun(3,
6
  annealing=true,
7
  ncyclesperiteration=100,
8
  fractionReplaced=0.1f0,
9
- verbosity=0)
 
 
10
 
11
  t = @benchmark(fullRun(3,
12
  npop=100,
13
  annealing=true,
14
  ncyclesperiteration=100,
15
  fractionReplaced=0.1f0,
16
- verbosity=0
 
17
  ), evals=10)
18
 
19
  tnoanneal = @benchmark(fullRun(3,
@@ -21,7 +24,8 @@ tnoanneal = @benchmark(fullRun(3,
21
  annealing=false,
22
  ncyclesperiteration=100,
23
  fractionReplaced=0.1f0,
24
- verbosity=0
 
25
  ), evals=10)
26
 
27
  println("The median time is $(median(t)) with annealing, $(median(tnoanneal)) without")
 
6
  annealing=true,
7
  ncyclesperiteration=100,
8
  fractionReplaced=0.1f0,
9
+ verbosity=0,
10
+ topn=10
11
+ )
12
 
13
  t = @benchmark(fullRun(3,
14
  npop=100,
15
  annealing=true,
16
  ncyclesperiteration=100,
17
  fractionReplaced=0.1f0,
18
+ verbosity=0,
19
+ topn=10
20
  ), evals=10)
21
 
22
  tnoanneal = @benchmark(fullRun(3,
 
24
  annealing=false,
25
  ncyclesperiteration=100,
26
  fractionReplaced=0.1f0,
27
+ verbosity=0,
28
+ topn=10
29
  ), evals=10)
30
 
31
  println("The median time is $(median(t)) with annealing, $(median(tnoanneal)) without")
eureqa.jl CHANGED
@@ -415,7 +415,7 @@ function bestOfSample(pop::Population)::PopMember
415
  end
416
 
417
  # Return best 10 examples
418
- function bestSubPop(pop::Population; topn::Int32=10)::Population
419
  best_idx = sortperm([pop.members[member].score for member=1:pop.n])
420
  return Population(pop.members[best_idx[1:topn]])
421
  end
 
415
  end
416
 
417
  # Return best 10 examples
418
+ function bestSubPop(pop::Population; topn::Integer=10)::Population
419
  best_idx = sortperm([pop.members[member].score for member=1:pop.n])
420
  return Population(pop.members[best_idx[1:topn]])
421
  end
paralleleureqa.jl CHANGED
@@ -19,7 +19,7 @@ function fullRun(niterations::Integer;
19
  ncyclesperiteration::Integer=3000,
20
  fractionReplaced::Float32=0.1f0,
21
  verbosity::Integer=0,
22
- topn::Int32=10
23
  )
24
  debug(verbosity, "Lets try to learn (x2^2 + cos(x3)) using regularized evolution from scratch")
25
  debug(verbosity, "Running with $nthreads threads")
@@ -82,11 +82,11 @@ function fullRun(niterations::Integer;
82
  end
83
 
84
  # Hall of fame migration
85
- if hofMigration
86
  for j=1:nthreads
87
  for k in rand(1:npop, Integer(npop*fractionReplacedHof))
88
  # Copy in case one gets used twice
89
- allPops[j].members[k] = deepcopy(dominating[rand(2:size(dominating)[1])])
90
  end
91
  end
92
  end
 
19
  ncyclesperiteration::Integer=3000,
20
  fractionReplaced::Float32=0.1f0,
21
  verbosity::Integer=0,
22
+ topn::Integer=10
23
  )
24
  debug(verbosity, "Lets try to learn (x2^2 + cos(x3)) using regularized evolution from scratch")
25
  debug(verbosity, "Running with $nthreads threads")
 
82
  end
83
 
84
  # Hall of fame migration
85
+ if hofMigration && size(dominating)[1] > 0
86
  for j=1:nthreads
87
  for k in rand(1:npop, Integer(npop*fractionReplacedHof))
88
  # Copy in case one gets used twice
89
+ allPops[j].members[k] = deepcopy(dominating[rand(1:size(dominating)[1])])
90
  end
91
  end
92
  end