use crate::traits::ChromosomeT;
use log::{debug, trace};
pub(crate) use rand::Rng;
pub fn swap<U: ChromosomeT>(chromosome: &mut U) {
debug!(target="mutation_events", method="swap"; "Starting the swap mutation");
if chromosome.dna().len() < 2 {
return;
}
let mut rng = crate::rng::make_rng();
let index_1 = rng.random_range(0..chromosome.dna().len());
let index_2 = rng.random_range(0..chromosome.dna().len());
trace!(target="mutation_events", method="swap"; "Mutation index 1: {}, mutation index 2: {}", index_1, index_2);
let gene_1 = chromosome.dna().get(index_1).cloned().unwrap();
let gene_2 = chromosome.dna().get(index_2).cloned().unwrap();
chromosome.set_gene(index_1, gene_2);
chromosome.set_gene(index_2, gene_1);
debug!(target="mutation_events", method="swap"; "Swap mutation finished");
}