Files
DEC/individual/genome/strategies/InOutBreeding/InOutBreeginGenToPhenStrategy.cpp
2024-10-03 18:43:04 +07:00

101 lines
3.2 KiB
C++

#include "../GenotypeToPhenotypeStrategy.h"
#include "../../../../processor/Settings.h"
#include <cmath>
void InOutBreedingGenotypeToPhenotypeStrategy::calculatePhenotype(Individual* individ){
Genotype* genotype = individ->genotype;
Phenotype* phenotype = individ->phenotype;
InnerSubstratesPool* substrates = individ->substrateCache;
// Chromosome 1
Chromosome chr1F = individ->genotype->getFatherGenome().getChromosome(0);
Chromosome chr1M = individ->genotype->getMotherGenome().getChromosome(0);
const std::vector<Gene>& genesF = chr1F.getGenesAsVector();
const std::vector<Gene>& genesM = chr1M.getGenesAsVector();
// Êîàäàïòèâíûå àëëåëè
float a1 = genesF.at(0).getGeneValueCont();
float a2 = genesM.at(0).getGeneValueCont();
float b1 = genesF.at(1).getGeneValueCont();
float b2 = genesM.at(1).getGeneValueCont();
// (END) Êîàäàïòèâíûå àëëåëè
// Àëëåëè áîëåçíè
std::vector<float> diseaseAllelesF(4);
std::vector<float> diseaseAllelesM(4);
for(unsigned int i = 0; i < diseaseAllelesF.size(); i++){
diseaseAllelesF.at(i) = genesF.at(i+2).getGeneValueCont();
diseaseAllelesM.at(i) = genesM.at(i+2).getGeneValueCont();
}
// (END) Àëëåëè áîëåçíè
// Êîìáèíàòîðèêà
float trait1 = 0, trait2 = 0;
float a, b;
// 1) Êîàäàïòèâíûå ãåíû
if(Settings::CoadaptiveGenesInteraction == "onechromosome"){
// 1.1 Ðàáîòàþò ãåíû ñ îäíîé òîëüêî õðîìîñîìû
a = a1;
b = b1;
}
else if(Settings::CoadaptiveGenesInteraction == "mean"){
// 1.2 Ñðåäíåå ïðîÿâëåíèå ïðèçíàêà
a = 0.5f*(a1+a2);
b = 0.5f*(b1+b2);
}
else{ // Settings::CoadaptiveGenesInteraction == "maxmodule"
// 1.3 Ìàêñèìóì ìîäóëÿ
a = std::fabs(a1) >= std::fabs(a2) ? a1 : a2;
b = std::fabs(b1) >= std::fabs(b2) ? b1 : b2;
}
// Ïðèçíàê 1
trait1 = std::max(a*b - (fabs(a*a*a) + fabs(b*b*b))/20, 0.0f);
//trait1 = std::max(a*b - (a*a*a*a + b*b*b*b)/250, 0.0f);
// 2) Ãåíû áîëåçíè
if(Settings::DiseaseGenesInteraction == "add1"){
// 2.1à Àääèòèâíî
float sum1 = 0.0f, sum2 = 0.0f;
for(unsigned int i = 0; i < diseaseAllelesF.size(); i++){
sum1 += diseaseAllelesF.at(i);
sum2 += diseaseAllelesM.at(i);
}
trait2 = std::max(sum1,sum2);
}
else if(Settings::DiseaseGenesInteraction == "addmax"){
// 2.1á Àääèòèâíî (àëüò)
for(unsigned int i = 0; i < diseaseAllelesF.size(); i++){
trait2 += std::max(diseaseAllelesF.at(i), diseaseAllelesM.at(i));
}
}
else if(Settings::DiseaseGenesInteraction == "mult"){
// 2.2 Ìóëüòèïëèêàòèâíî
for(unsigned int i = 0; i < diseaseAllelesF.size(); i++){
trait2 *= std::max(diseaseAllelesF.at(i), diseaseAllelesM.at(i));
}
}
else if(Settings::DiseaseGenesInteraction == "meanadd"){
// 2.3à Ñðåäíåå çíà÷åíèå (àääèòèâíî)
for(unsigned int i = 0; i < diseaseAllelesF.size(); i++){
trait2 += diseaseAllelesF.at(i) + diseaseAllelesM.at(i);
}
trait2 /= 2.0f;
}
else{// if(Settings::DiseaseGenesInteraction == "meanmult"){
// 2.3á Ñðåäíåå çíà÷åíèå (ìóëüòèïëèêàòèâíî)
for(unsigned int i = 0; i < diseaseAllelesF.size(); i++){
trait2 *= (diseaseAllelesF.at(i) + diseaseAllelesM.at(i))/2;
}
}
// Ïðèçíàêè ïåðåäàþòñÿ â ôåíîòèï
phenotype->traitsMap["coadaptive"].setTraitValue(trait1);
phenotype->traitsMap["disease"].setTraitValue(trait2);
}