Programa para el testeo de las funciones.Para compilar o código example_logisticregression_paris.cpp:
g++ -static -o example_logisticregression_paris example_logisticregression_paris.cpp -lpdsmlmm -lpdsramm -lpdsspmm
Para executar o programa:
./example_logisticregression_paris
Retornando por consola:
Classification - original
Classification - paralelo
Classification - evaluado
Código example_logisticregression_paris.cpp:
#include <iostream>
#include <Pds/Ra>
#include <Pds/Ml>
int main(void)
{
Pds::Ra::Randomize();
Pds::Octave::XLabel="x_1";
Pds::Octave::YLabel="x_2";
Pds::Octave::XLimits=true;
Pds::Octave::YLimits=true;
Pds::Vector W;
Pds::Vector Yp;
unsigned int L=1000;
Pds::Matrix X;
Pds::Vector Y;
W.T().Print("W:\n");
Pds::Octave::Plot::PointsX2DYW(X,Y,W,"testando.m","example_logisticregression_paris_orig.png");
W.T().Print("W:\n");
Pds::Octave::Plot::PointsX2DYW(X,Y,W,"testando.m","example_logisticregression_paris_par.png");
Pds::Octave::Plot::PointsX2DYW(X,Yp,W,"testando.m","example_logisticregression_paris_eval.png");
std::cout<<"Accuracy: "<<Pds::Accuracy(Y,Yp)<<"\n";
return 0;
}
void LoadDataBand(unsigned int L, Pds::Matrix &X, Pds::Vector &Y)
Clasificacion de datos separados por mas de una curva.
Pds::Vector Classify(const Pds::Vector &W, const Pds::Matrix &X)
Calculo del resultado del clasificador.
Pds::Vector GetW0MeanMethod(const Pds::Matrix &X)
Obtiene de forma rapida un vector inicial para usar en regresion logistica.
Pds::Vector FittingParrallelPlaneIS(const Pds::Matrix &X, const Pds::Vector &Y, const Pds::Vector &W0, double *ISmin=NULL, double Delta=0.001)
Calculo de pesos buscando el plano paralelo a W0 que genere la menor suma de informaciones en la part...