#ifndef CSTAT_HPP #define CSTAT_HPP #include #include using std::cout;using std::endl; namespace opt_utilities { template class cstat :public statistic { private: bool verb; int n; public: cstat() :verb(true) {} void verbose(bool v) { verb=v; } public: statistic* do_clone()const { // return const_cast*>(this); return new cstat(*this); } Ts do_eval(const Tp& p) { Ts result(0); for(int i=(this->get_data_set()).size()-1;i>=0;--i) { Ty model_y=eval_model(this->get_data_set().get_data(i).get_x(),p); result-=this->get_data_set().get_data(i).get_y()*std::log(model_y); } if(verb) { n++; if(n%10==0) { cout<<"a:"<