#include "../src/NeuralNetwork/FeedForward" #include "../src/NeuralNetwork/Learning/BackPropagation" #include #include class X: public Shin::Problem { public: X(const X& a) :Problem(),q(a.q) {} X(const std::vector &a):q(a) {} std::vector representation() const { return q; } protected: std::vector q; }; int main() { std::vector s; std::vector p; // s.push_back(Shin::Solution(std::vector({0}))); p.push_back(X(std::vector({1,0}))); s.push_back(Shin::Solution(std::vector({0}))); p.push_back(X(std::vector({0,1}))); s.push_back(Shin::Solution(std::vector({0}))); p.push_back(X(std::vector({0,0}))); s.push_back(Shin::Solution(std::vector({1}))); p.push_back(X(std::vector({1,1}))); Shin::NeuralNetwork::FeedForward q({2,4,1}); Shin::NeuralNetwork::Learning::BackPropagation b(q); b.setLearningCoeficient(10); for(int i=0;i<4;i++) { b.teach(p[i%4],s[i%4]); std::cerr << i%4 <<". FOR: [" << p[i%4].representation()[0] << "," <