📄 cost.cpp
字号:
/*
This file is part of Orange.
Orange is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
Orange is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Orange; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Authors: Janez Demsar, Blaz Zupan, 1996--2002
Contact: janez.demsar@fri.uni-lj.si
*/
#include "cost.ppp"
void TCostMatrix::init(const float &inside)
{
if (costs)
delete costs;
const int size = dimension * dimension;
costs = new float[dimension * dimension];
float *ci, *ce;
for(ci = costs, ce = costs + size; ci != ce; *ci++ = inside);
int dim = dimension;
for(ci = costs; dim--; *ci = 0, ci += dimension+1);
}
TCostMatrix::TCostMatrix(const int &dim, const float &inside)
: dimension(dim),
costs(NULL)
{
if (dimension <= 0)
raiseError("invalid dimension (%i)", dimension);
init(inside);
}
TCostMatrix::TCostMatrix(PVariable acv, const float &inside)
: classVar(acv),
dimension(0),
costs(NULL)
{
TEnumVariable *dcv = classVar.AS(TEnumVariable);
if (!dcv)
raiseError("attribute '%s' is not discrete", classVar->name.c_str());
dimension = dcv->noOfValues();
if (!dimension)
raiseError("attribute '%s' has no values", classVar->name.c_str());
init(inside);
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -