This commit is contained in:
2025-11-04 15:02:02 +03:00
parent 83be98e923
commit 8e8e0abd0d
6 changed files with 657 additions and 1 deletions

View File

@@ -22,11 +22,20 @@ class Chromosome:
"""Вычисляет глубину дерева. Дерево из одного только корня имеет глубину 1."""
return self.root.get_depth() if self.root is not None else 0
def clone(self) -> "Chromosome":
"""Создает копию хромосомы."""
return Chromosome(
self.operations,
self.terminals,
lambda _: self.root.clone(),
)
def eval(self, values: list[float]) -> float:
"""Вычисляет значение хромосомы для заданных значений терминалов."""
if self.root is None:
raise ValueError("Chromosome is not initialized")
# Мне это не нравится, но, возможно, это будет работать
for terminal, value in zip(self.terminals, values):
terminal._value = value
@@ -65,6 +74,12 @@ class Chromosome:
self.value = value
self.children = children
def clone(self) -> "Chromosome.Node":
"""Создает копию поддерева."""
return Chromosome.Node(
self.value, [child.clone() for child in self.children]
)
def get_depth(self) -> int:
"""Вычисляет глубину поддерева."""
return (