本文整理汇总了C++中Gene::size方法的典型用法代码示例。如果您正苦于以下问题:C++ Gene::size方法的具体用法?C++ Gene::size怎么用?C++ Gene::size使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Gene
的用法示例。
在下文中一共展示了Gene::size方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: randomMillion
std::pair<Chromosome, Breeder::BreedStats> Breeder::breed(const Chromosome& mum, const Chromosome& dad, uint32_t crossOverPerMillion)
{
BreedStats stats;
stats.crossOvers = 0;
std::random_device rd;
std::uniform_int_distribution<> randomMillion(0, 999999);
std::uniform_int_distribution<> mumOrDad(0, 1);
bool startWithMum = mumOrDad(rd) == 0;
const Gene* currentGene = startWithMum ? &mum.gene() : &dad.gene();
const Gene* otherGene = startWithMum ? &dad.gene() : &mum.gene();
Gene resultingGene;
resultingGene.resize(currentGene->size());
for(uint32_t i = 0; i < resultingGene.size(); i++)
{
resultingGene[i] = (*currentGene)[i];
if(crossOverPerMillion > randomMillion(rd))
{
std::swap(currentGene, otherGene);
++stats.crossOvers;
}
}
return {Chromosome(mum.maxCistronIds(), mum.informationDensity(), mum.startSequence(), mum.stopSequence(), resultingGene), stats};
}
示例2: replaceCistronValues
void Chromosome::replaceCistronValues(const std::vector<Cistron>& cistrons)
{
CistronMap cistronMap;
for(const auto& cistron : cistrons)
{
cistronMap.emplace(cistron.id(), cistron);
}
size_t start = 0;
while((start = mGene.find(mStartSequence, start)) != std::string::npos)
{
size_t stop = mGene.find(mStopSequence, start);
if(stop != std::string::npos)
{
size_t cistronStart = start + mStartSequence.size();
Cistron cistron(mGene.substr(cistronStart, stop - cistronStart), mMaxCistronIds, mInformationDensity);
if(cistronMap.count(cistron.id()))
{
Gene toInsert = mStartSequence;
toInsert.append(cistronMap.at(cistron.id()).gene());
toInsert.append(mStopSequence);
mGene.replace(start, toInsert.size(), toInsert);
}
}
start = stop;
}
}