일부 라이브러리 내에서 작업해야하는데이 코드에서 다음 오류가 계속 발생합니다. `의 this'argument '로'const를 amko :: 문제 :: 출시 통과Error 'const`를`const double`의`this` 인수로 전달하면 한정자가 없어집니다.
'const를 두 번 amko :: 문제가 시작 :: :: 비율 (더블, 더블)'규정을
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);
}
고맙습니다!
코드를 ** 최소 ** 테스트 케이스로 줄이십시오. –
이런 종류의 "const 문제"질문은 매일 ** 게시됩니다 **. 어서! – mfontanini
@fontanini : 오래된 질문 중 하나에 대한 링크를 남겨두면 중복으로 닫습니다. –