Ошибка передачи `const` как` this` аргумента `const double` отбрасывает квалификаторы - PullRequest
0 голосов
/ 16 марта 2012

Мне нужно работать в некоторых библиотеках, и независимо от того, что я делаю, я получаю следующую ошибку с этим кодом.

, передавая `const amko :: problem :: launch 'как' этот 'аргумент'const double amko :: problem :: launch :: ratio (double, double) 'отбрасывает квалификаторы

namespace amko { namespace problem {
launch::launch():base( 0.0, 20.0, 1 ) {}

base_ptr launch::clone() const
{
return base_ptr(new launch(*this));
}

const double launch::ratio( const double a, const double b)
{
const double area = a*b;
const double circumference = 2*a+2*b;
const double ratio = circumference/area;
return ratio;
}

void launch::objfun_impl(fitness_vector &f, const decision_vector &xv) const
{
amko_assert(f.size() == 1 && xv.size() == get_dimension());
const double x = xv[0];

const double y = launch::ratio(x,5);

f[0] =  y;
}

, в то время как следующий фрагмент кода работал просто отлично.

namespace amko { namespace problem {

initialValueProblem::initialValueProblem():base( 0.0, 20.0, 1 ) {}

base_ptr initialValueProblem::clone() const
{
return base_ptr(new initialValueProblem(*this));
}

Eigen::VectorXd initialValueProblem::computeDerivative( const double time, const Eigen::VectorXd& state )
{
Eigen::VectorXd stateDerivative( 1 );
stateDerivative( 0 ) = state( 0 ) - std::pow( time, 2.0 ) + 1.0;
return stateDerivative;
}

void initialValueProblem::objfun_impl(fitness_vector &f, const decision_vector &xv) const
{
amko_assert(f.size() == 1 && xv.size() == get_dimension());
const double x = xv[0];

double intervalStart = 0.0;
double intervalEnd = 10.0;
double stepSize = 0.1;

Eigen::VectorXd initialState_;
initialState_.setZero( 1 );
initialState_( 0 ) = x;

numerical_integrators::EulerIntegratorXd integrator( boost::bind( &initialValueProblem::computeDerivative,
                                                                   const_cast<initialValueProblem*>( this ), _1, _2 ), intervalStart, initialState_ );
Eigen::VectorXd finalState = integrator.integrateTo( intervalEnd, stepSize );
f[0] =  fabs( finalState( 0 ) - 11009.9937484598 );
}

Спасибо!

Ответы [ 2 ]

2 голосов
/ 16 марта 2012

launch::objfun_impl - это функция-член const, она не может изменять членов или вызывать другие функции, которые это делают.Это означает, что он не может вызывать не const не- static функции-члены, такие как launch::ratio.

Поскольку launch::ratio вообще не имеет доступа к элементам, только его аргументы,самое простое решение - сделать ее функцией-членом static, изменив прототип внутри определения класса:

static /* <- ADDED static HERE */ double launch::ratio(const double a, const double b);
0 голосов
/ 16 марта 2012

Проблема в том, что ваша ratio функция-член не const, даже если вы не модифицируете ни одного члена объекта (почему это вообще функция-член?).Внутри objfun_impl вы звоните ratio.Теперь objfun_impl - это const, и поэтому обещание не изменять объект, но вызов ratio нарушит это обещание.

...