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;
LIB4NEURO_API virtual size_t get_dimension();

Michal Kravcenko
committed
/**
*
* @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
*/
LIB4NEURO_API MSE(NeuralNetwork* net, DataSet* ds);
/**
*
* @param weights
* @return
*/
LIB4NEURO_API double eval(std::vector<double>* weights = nullptr) override;

Michal Kravcenko
committed
/**
*
* @param params
* @param grad
*/
LIB4NEURO_API void calculate_error_gradient(std::vector<double> ¶ms, std::vector<double> &grad, double alpha = 1.0 ) override;

Michal Kravcenko
committed
/**
*
* @return
*/
LIB4NEURO_API std::vector<double>* get_parameters( ) override;

Michal Kravcenko
committed
LIB4NEURO_API DataSet* get_dataset() override {

Michal Kravcenko
committed
return this->ds;
};
public:
/**
*
*/
/**
*
*/
/**
*
* @param weights
* @return
*/
LIB4NEURO_API double eval(std::vector<double>* weights = nullptr) override;
/**
*
* @param F
*/
LIB4NEURO_API void add_error_function( ErrorFunction *F, double alpha = 1.0 );
LIB4NEURO_API size_t get_dimension( ) override;

Michal Kravcenko
committed
/**
*
* @param params
* @param grad
*/
LIB4NEURO_API void calculate_error_gradient( std::vector<double> ¶ms, std::vector<double> &grad, double alpha = 1.0 ) override;

Michal Kravcenko
committed
/**
*
* @return
*/
LIB4NEURO_API std::vector<double>* get_parameters( ) override;

Michal Kravcenko
committed
LIB4NEURO_API DataSet* get_dataset() override {

Michal Kravcenko
committed
return this->summand->at( 0 )->get_dataset();
};
private:
std::vector<double> *summand_coefficient;
};
#endif //INC_4NEURO_ERRORFUNCTION_H