本文整理汇总了C++中Gene::pMutate方法的典型用法代码示例。如果您正苦于以下问题:C++ Gene::pMutate方法的具体用法?C++ Gene::pMutate怎么用?C++ Gene::pMutate使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Gene
的用法示例。
在下文中一共展示了Gene::pMutate方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: father
void genetic::Generation::Generate(const genetic::Generation& ancestor)
{
int& nCells = gainput.max_cells;
m_cells = vector<Cell>(nCells, Cell());
int iCell = 0;
// Chose Elites
for(; iCell < gainput.max_elite; ++iCell) m_cells[iCell] = ancestor.m_cells[iCell];
// Selection to Next Generation
while(iCell < nCells)
{
Gene child;
if(drand(1.0) > gainput.thre_cloning)
{
child = ancestor.Select().Gen();
}
else
{
Cell father(ancestor.Select());
Cell mother(ancestor.Select());
// if(father.Fitness() > mother.Fitness())
child = father.Gen() * mother.Gen();
// else
// child = mother.Gen() * father.Gen();
}
// Mutation
if(drand(1.0) < gainput.thre_mutation) child.pMutate();
if(drand(1.0) < gainput.thre_mutation) child.gMutate();
m_cells[iCell++] = Cell(child);
}
ComputeProbability();
}