Spaces:
Running
Running
MilesCranmer
commited on
Commit
·
b18ab5a
1
Parent(s):
b15eaa4
Add functions to set constants
Browse files- eureqa.jl +39 -0
- paralleleureqa.jl +4 -3
eureqa.jl
CHANGED
@@ -471,3 +471,42 @@ function run(
|
|
471 |
end
|
472 |
return pop
|
473 |
end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
471 |
end
|
472 |
return pop
|
473 |
end
|
474 |
+
|
475 |
+
# Get all the constants from a tree
|
476 |
+
function getConstants(tree::Node)::Array{Float32, 1}
|
477 |
+
if tree.degree == 0
|
478 |
+
if tree.constant
|
479 |
+
return [tree.val]
|
480 |
+
else
|
481 |
+
return Float32[]
|
482 |
+
end
|
483 |
+
elseif tree.degree == 1
|
484 |
+
return getConstants(tree.l)
|
485 |
+
else
|
486 |
+
both = [getConstants(tree.l), getConstants(tree.r)]
|
487 |
+
return [constant for subtree in both for constant in subtree]
|
488 |
+
end
|
489 |
+
end
|
490 |
+
|
491 |
+
# Set all the constants inside a tree
|
492 |
+
function setConstants(tree::Node, constants::Array{Float32, 1})
|
493 |
+
if tree.degree == 0
|
494 |
+
if tree.constant
|
495 |
+
tree.val = constants[1]
|
496 |
+
end
|
497 |
+
elseif tree.degree == 1
|
498 |
+
setConstants(tree.l, constants)
|
499 |
+
else
|
500 |
+
numberLeft = countConstants(tree.l)
|
501 |
+
setConstants(tree.l, constants)
|
502 |
+
setConstants(tree.r, constants[numberLeft+1:end])
|
503 |
+
end
|
504 |
+
end
|
505 |
+
|
506 |
+
# Does nothing currently
|
507 |
+
function optimizeConstants(member::PopMember)::PopMember
|
508 |
+
x0 = getConstants(member.tree)
|
509 |
+
return member
|
510 |
+
end
|
511 |
+
|
512 |
+
|
paralleleureqa.jl
CHANGED
@@ -5,10 +5,11 @@ const nthreads = Threads.nthreads()
|
|
5 |
# List of the best members seen all time
|
6 |
mutable struct HallOfFame
|
7 |
members::Array{PopMember, 1}
|
8 |
-
exists::Array{Bool, 1}
|
|
|
9 |
|
10 |
# Arranged by complexity - store one at each.
|
11 |
-
HallOfFame() = new([PopMember(Node(1f0), 1f9) for i=1:actualMaxsize], [false for i=1:actualMaxsize])
|
12 |
end
|
13 |
|
14 |
|
@@ -56,6 +57,7 @@ function fullRun(niterations::Integer;
|
|
56 |
betterThanAllSmaller = (numberSmallerAndBetter == 0)
|
57 |
if betterThanAllSmaller
|
58 |
debug(verbosity, "$size \t $(member.score-parsimony*size) \t $(stringTree(member.tree))")
|
|
|
59 |
push!(dominating, member)
|
60 |
end
|
61 |
end
|
@@ -81,6 +83,5 @@ function fullRun(niterations::Integer;
|
|
81 |
end
|
82 |
end
|
83 |
end
|
84 |
-
|
85 |
end
|
86 |
end
|
|
|
5 |
# List of the best members seen all time
|
6 |
mutable struct HallOfFame
|
7 |
members::Array{PopMember, 1}
|
8 |
+
exists::Array{Bool, 1} #Whether it has been set
|
9 |
+
optimized::Array{Bool, 1} #Whether the constants have been optimized
|
10 |
|
11 |
# Arranged by complexity - store one at each.
|
12 |
+
HallOfFame() = new([PopMember(Node(1f0), 1f9) for i=1:actualMaxsize], [false for i=1:actualMaxsize], [false for i=1:actualMaxsize])
|
13 |
end
|
14 |
|
15 |
|
|
|
57 |
betterThanAllSmaller = (numberSmallerAndBetter == 0)
|
58 |
if betterThanAllSmaller
|
59 |
debug(verbosity, "$size \t $(member.score-parsimony*size) \t $(stringTree(member.tree))")
|
60 |
+
member = optimizeConstants(member)
|
61 |
push!(dominating, member)
|
62 |
end
|
63 |
end
|
|
|
83 |
end
|
84 |
end
|
85 |
end
|
|
|
86 |
end
|
87 |
end
|