Spaces:
Running
Running
MilesCranmer
commited on
Commit
·
08a98f6
1
Parent(s):
2e104cc
Function to return random node AND parent
Browse files
eureqa.jl
CHANGED
@@ -361,6 +361,31 @@ function randomConstantNode()::Node
|
|
361 |
return newnode
|
362 |
end
|
363 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
364 |
# Select a random node, and replace it an the subtree
|
365 |
# with a variable or constant
|
366 |
function deleteRandomOp(tree::Node)::Node
|
|
|
361 |
return newnode
|
362 |
end
|
363 |
|
364 |
+
# Return a random node from the tree with parent
|
365 |
+
function randomNodeAndParent(tree::Node, parent::Union{Node, Nothing})::Tuple{Node, Union{Node, Nothing}}
|
366 |
+
if tree.degree == 0
|
367 |
+
return tree, parent
|
368 |
+
end
|
369 |
+
a = countNodes(tree)
|
370 |
+
b = 0
|
371 |
+
c = 0
|
372 |
+
if tree.degree >= 1
|
373 |
+
b = countNodes(tree.l)
|
374 |
+
end
|
375 |
+
if tree.degree == 2
|
376 |
+
c = countNodes(tree.r)
|
377 |
+
end
|
378 |
+
|
379 |
+
i = rand(1:1+b+c)
|
380 |
+
if i <= b
|
381 |
+
return randomNodeAndParent(tree.l, tree)
|
382 |
+
elseif i == b + 1
|
383 |
+
return tree, parent
|
384 |
+
end
|
385 |
+
|
386 |
+
return randomNodeAndParent(tree.r, tree)
|
387 |
+
end
|
388 |
+
|
389 |
# Select a random node, and replace it an the subtree
|
390 |
# with a variable or constant
|
391 |
function deleteRandomOp(tree::Node)::Node
|