本文整理汇总了C++中ModelList::getModel方法的典型用法代码示例。如果您正苦于以下问题:C++ ModelList::getModel方法的具体用法?C++ ModelList::getModel怎么用?C++ ModelList::getModel使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类ModelList
的用法示例。
在下文中一共展示了ModelList::getModel方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: CanonicalStateMap
AbstractWordSubstitutionModel::AbstractWordSubstitutionModel(
ModelList& modelList,
const std::string& prefix) :
AbstractParameterAliasable(prefix),
AbstractSubstitutionModel(
modelList.getWordAlphabet(),
new CanonicalStateMap(modelList.getWordAlphabet(), false),
prefix),
new_alphabet_ (true),
VSubMod_ (),
VnestedPrefix_(),
Vrate_ (modelList.size())
{
enableEigenDecomposition(false);
size_t i, j;
size_t n = modelList.size();
// test whether two models are identical
bool flag = 0;
i = 0;
j = 1;
while (!flag && i < (n - 1))
{
if (modelList.getModel(i) == modelList.getModel(j))
flag = 1;
else
{
j++;
if (j == n)
{
i++;
j = i + 1;
}
}
}
if (!flag)
{
for (i = 0; i < n; i++)
{
VSubMod_.push_back(modelList.getModel(i));
VnestedPrefix_.push_back(modelList.getModel(i)->getNamespace());
VSubMod_[i]->setNamespace(prefix + TextTools::toString(i + 1) + "_" + VnestedPrefix_[i]);
addParameters_(VSubMod_[i]->getParameters());
}
}
else
{
string t = "";
for (i = 0; i < n; i++)
{
VSubMod_.push_back(modelList.getModel(0));
VnestedPrefix_.push_back(modelList.getModel(0)->getNamespace());
t += TextTools::toString(i + 1);
}
VSubMod_[0]->setNamespace(prefix + t + "_" + VnestedPrefix_[0]);
addParameters_(VSubMod_[0]->getParameters());
}
for (i = 0; i < n; i++)
{
Vrate_[i] = 1.0 / static_cast<double>(n);
}
}