Package org.neuroph.contrib.matrixmlp

Source Code of org.neuroph.contrib.matrixmlp.MatrixMultiLayerPerceptron

package org.neuroph.contrib.matrixmlp;

import org.neuroph.core.Layer;
import org.neuroph.core.NeuralNetwork;
import org.neuroph.core.transfer.Tanh;
import org.neuroph.nnet.MultiLayerPerceptron;

/**
* Matrix based implementation of Multi LAyer Perceptron
* @author Zoran Sevarac
*/
public class MatrixMultiLayerPerceptron extends NeuralNetwork {

    MultiLayerPerceptron sourceNetwork;
    MatrixLayer[] matrixLayers;

    public MatrixMultiLayerPerceptron(MultiLayerPerceptron sourceNetwork) {
        this.sourceNetwork = sourceNetwork;
        // copy layers, input and output neurons

        createMatrixLayers();
        this.setLearningRule(new MatrixMomentumBackpropagation());
    }

    public MatrixLayer[] getMatrixLayers() {
        return matrixLayers;
    }



    private void createMatrixLayers() {
        matrixLayers = new MatrixLayer[sourceNetwork.getLayersCount()];
        matrixLayers[0] = new MatrixInputLayer(sourceNetwork.getLayers().get(0).getNeuronsCount());

        MatrixLayer prevLayer = matrixLayers[0];
       
         for(int i =1; i < sourceNetwork.getLayersCount(); i++  ) {
            Layer layer = sourceNetwork.getLayerAt(i);
            MatrixMlpLayer newBpLayer = new MatrixMlpLayer(layer, prevLayer, new Tanh());
            matrixLayers[i] = newBpLayer;
            prevLayer = newBpLayer;
        }
    }

        @Override
         public void calculate() {
             for(int i = 1; i < matrixLayers.length; i++) {
                 matrixLayers[i].calculate();                
             }
         }

         @Override
         public void setInput(double ... inputs) {
             matrixLayers[0].setInputs(inputs);
         }

         @Override
         public double[] getOutput() {
            return  matrixLayers[matrixLayers.length-1].getOutputs();
         }

         @Override
         public int getLayersCount() {
             return matrixLayers.length;
         }


}


TOP

Related Classes of org.neuroph.contrib.matrixmlp.MatrixMultiLayerPerceptron

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.