/nNetJs

Neural Networks for javaScript; a self-contained library

Primary LanguageJavaScript

nNetJs

Neural Networks for javaScript; a self-contained library

Written for general use in web-based aplications.

This is the openSource version.

###Example 1

We construct a 5-layers deep neural network, outputing a numeric 3-vector, and train it for a 1000 steps.

//generate Random data for demo
//input -> 5 x 50 matrix, 1x50 is one case
var input=getRandomBatchIn(5,50)
//output -> 5x3 matrix, 1x3 is one case
var output=getRandomBatchOut(5,3,{mean:10,variance:5});
var data={in:input,out:output};
//declare the net
var n=new net();
//specify its' structure
n.add({shape:[1,50],type:"input"});
n.add({shape:[50,10],type:"fc",activation:"sigmoid"});
n.add({shape:[10,10],type:"fc",activation:"reLu"});
n.add({shape:[10,10],type:"fc",activation:"sigmoid"});
n.add({shape:[10,10],type:"fc",activation:"sigmoid"});
n.add({shape:[10,3],type:"fc",activation:"id"});
//initialize neurons (uses variance normalization by layer length)
n.init(gaussian(0, 1));
//train for 1000 steps
for(var k=0;k<1000;k++) n.trainStep({data:data,cost:"meanSquare",stepSize:0.1});
//evaluate on all 5 cases
var prediction=[];
for(k in input){
    prediction[k]=n.eval(input[k]);
    forAll(prediction[k],function(x){return x.toFixed(2)});
}
//display results
console.log("Correct predictions");
console.log(output);
console.log("\nPredictions:");
console.log(prediction);

###Example 2

We construct a 5-layers deep neural network, outputing a 3-class classification probability, and train it for a 1000 steps.

//generate Random data for demo
//input -> 5 x 50 matrix, 1x50 is one case
var input=getRandomBatchIn(5,50)
//output -> 5x3 matrix, 1x3 is one case
var output=getRandomClassBatch(5,3);
var data={in:input,out:output};
//declare the net
var n=new net();
//specify its' structure
n.add({shape:[1,50],type:"input"});
n.add({shape:[50,10],type:"fc",activation:"sigmoid"});
n.add({shape:[10,10],type:"fc",activation:"reLu"});
n.add({shape:[10,10],type:"fc",activation:"sigmoid"});
n.add({shape:[10,10],type:"fc",activation:"reLu"});
n.add({shape:[10,3],type:"fc",activation:"sigmoid"});
//initialize neurons (uses variance normalization by layer length)
n.init(gaussian(0, 1));
//train for 1000 steps
for(var k=0;k<1000;k++) n.trainStep({data:data,cost:"entropyBinary",stepSize:0.1});
//evaluate on all data
var classification=[];
for(k in input){
    classification[k]=n.eval(input[k]);
    forAll(classification[k],function(x){return x.toFixed(2)});
}
//display results
console.log("Correct predictions");
console.log(output);
console.log("\nPredictions:");
console.log(classification);

Creative Commons License
nNetJs by Žiga Sajovic is licensed under a Creative Commons Attribution 4.0 International License.