genetic_algorithm/chromosome/
vector.rsuse crate::allele::Allele;
use crate::fitness::FitnessValue;
use std::collections::hash_map::DefaultHasher;
use std::hash::{Hash, Hasher};
#[derive(Clone, Debug)]
pub struct Vector<T: Allele> {
pub genes: Vec<T>,
pub fitness_score: Option<FitnessValue>,
pub age: usize,
pub reference_id: usize,
}
impl<T: Allele> super::Chromosome for Vector<T> {
fn age(&self) -> usize {
self.age
}
fn reset_age(&mut self) {
self.age = 0;
}
fn increment_age(&mut self) {
self.age += 1
}
fn fitness_score(&self) -> Option<FitnessValue> {
self.fitness_score
}
fn set_fitness_score(&mut self, fitness_score: Option<FitnessValue>) {
self.fitness_score = fitness_score
}
fn taint(&mut self) {
self.age = 0;
self.fitness_score = None;
self.reference_id = usize::MAX;
}
fn copy_fields_from(&mut self, other: &Self) {
self.age = other.age;
self.fitness_score = other.fitness_score;
self.reference_id = other.reference_id;
}
}
impl<T: Allele> super::GenesOwner for Vector<T> {
type Genes = Vec<T>;
fn new(genes: Self::Genes) -> Self {
Self {
genes,
fitness_score: None,
age: 0,
reference_id: usize::MAX,
}
}
fn genes(&self) -> &Vec<T> {
&self.genes
}
}
impl<T: Allele> Vector<T>
where
Vec<T>: Hash,
{
pub fn genes_key(&self) -> super::GenesKey {
let mut s = DefaultHasher::new();
self.genes.hash(&mut s);
s.finish()
}
}