https://github.com/ElsevierSoftwareX/SOFTX_2019_219
Tip revision: 8449484d61814fb6b89eccbdcc29c5d51481966e authored by Konrad Werys on 07 December 2018, 11:08:10 UTC
travis works again
travis works again
Tip revision: 8449484
OxFunctionsT1AdapterVnlCost.h
/*!
* \file OxFunctionsT1AdapterVnlCost.h
* \author Konrad Werys
* \date 2018/07/30
*/
#ifndef Tomato_OXFUNCTIONST1ADAPTERVNLCOST_H
#define Tomato_OXFUNCTIONST1ADAPTERVNLCOST_H
#include <vnl/vnl_cost_function.h>
#include "OxFunctionsT1.h"
namespace Ox {
class FunctionsT1AdapterVnlCost : public vnl_cost_function {
public:
// cost function problem formulation
double f(vnl_vector<double> const& params){ // override
//_FunctionsT1->copyToParameters(params.data_block());
return _FunctionsT1->calcCostValue(params.data_block());
}
// cost function gradient
void gradf (vnl_vector< double > const ¶ms, vnl_vector< double > &gradient){ // override
//_FunctionsT1->copyToParameters(params.data_block());
_FunctionsT1->calcCostDerivative(params.data_block(), gradient.data_block());
}
void setFunctionsT1(FunctionsT1<double>* _FunctionsT1){
this->_FunctionsT1 = _FunctionsT1;
};
// getters
FunctionsT1<double>* getFunctionsT1(){
return _FunctionsT1;
};
/**
* constructor
*/
FunctionsT1AdapterVnlCost(int nDims) : vnl_cost_function(nDims){
_FunctionsT1 = 0; // nullpointer
};
/**
* copy constructor
* @param old
*/
FunctionsT1AdapterVnlCost(const FunctionsT1AdapterVnlCost &old){
_FunctionsT1 = old._FunctionsT1;
}
private:
FunctionsT1<double>* _FunctionsT1;
};
} // namespace Ox
#endif //Tomato_OXFUNCTIONST1ADAPTERVNLCOST_H