Newer
Older
//
// Created by martin on 7/15/18.
//
#ifndef INC_4NEURO_ERRORFUNCTION_H
#define INC_4NEURO_ERRORFUNCTION_H
#include "../Network/NeuralNetwork.h"
#include "../DataSet/DataSet.h"
Martin Beseda
committed

Michal Kravcenko
committed
enum ErrorFunctionType{
ErrorFuncMSE
};

Michal Kravcenko
committed
public:
/**
*
* @param weights
* @return
*/
virtual double eval(std::vector<double>* weights = nullptr) = 0;

Michal Kravcenko
committed
virtual size_t get_dimension();
/**
*
* @param params
* @param grad
*/
virtual void calculate_error_gradient(std::vector<double> ¶ms, std::vector<double> &grad, double alpha = 1.0 ) = 0;
/**
*
* @return
*/
virtual std::vector<double>* get_parameters( ) = 0;
/**
* //TODO delete after gradient learning is debugged
* @return
*/
virtual DataSet* get_dataset() = 0;

Michal Kravcenko
committed
/**
*
*/
NeuralNetwork* net = nullptr;
};
class MSE : public ErrorFunction {
public:
/**
* Constructor for single neural network
* @param net
* @param ds
*/

Michal Kravcenko
committed
MSE(NeuralNetwork* net, DataSet* ds);
/**
*
* @param weights
* @return
*/

Michal Kravcenko
committed
double eval(std::vector<double>* weights = nullptr) override;
/**
*
* @param params
* @param grad
*/
void calculate_error_gradient(std::vector<double> ¶ms, std::vector<double> &grad, double alpha = 1.0 ) override;
/**
*
* @return
*/
std::vector<double>* get_parameters( ) override;
DataSet* get_dataset() override {
return this->ds;
};
public:
/**
*
*/

Michal Kravcenko
committed
ErrorSum();
/**
*
*/

Michal Kravcenko
committed
~ErrorSum();
/**
*
* @param weights
* @return
*/

Michal Kravcenko
committed
double eval(std::vector<double>* weights = nullptr) override;
/**
*
* @param F
*/

Michal Kravcenko
committed
void add_error_function( ErrorFunction *F, double alpha = 1.0 );

Michal Kravcenko
committed
size_t get_dimension( ) override;
/**
*
* @param params
* @param grad
*/
void calculate_error_gradient( std::vector<double> ¶ms, std::vector<double> &grad, double alpha = 1.0 ) override;
/**
*
* @return
*/
std::vector<double>* get_parameters( ) override;
DataSet* get_dataset() override {
return this->summand->at( 0 )->get_dataset();
};
private:
std::vector<double> *summand_coefficient;
};
#endif //INC_4NEURO_ERRORFUNCTION_H