私はニューラル ネットワークの背後にあるアイデアを (完全に) 把握しようとしているので、独自の単純なパーセプトロンアルゴリズムを作成することから始めています。
これが私のコードです(JavaScriptで):
var lr = 0.1;//learning rate
//Initiate the weights randomly
function initWeights(weights, trainingSets){
for(var i=0; i<trainingSets[0].in.length; i++){
weights[i] = Math.random()*2 - 1;
}
weights.push(Math.random()*2 - 1); //b
}
//Return the raw activation value for a giving trainingSet
function getSum(weights, trainingSet){
var sum = 0;
for(var i=0; i < trainingSet.in.length; i++){
sum += weights[i]*trainingSet.in[i];
}
sum += 1 * weights[weights.length-1];
return sum;
}
//Activation function
function activate(value){
return (value >= 0)? 1 : 0;
}
function train(weights, trainingSets){
var error = 0;
for(var i=0; i<trainingSets.length; i++){
var currentSet = trainingSets[i];
var activationValue = getSum(weights, currentSet);
var error = currentSet.out - activate(activationValue);
error += error;
for(var j=0; j<weights.length-1; j++){
var deltaW = error * lr * currentSet.in[j];
weights[j] += deltaW;
}
weights[weights.length-1] += error * lr * 1;
}
return error/(weights.length);
}
var inp = [
{in:[1,1], out:1},
{in:[0,0], out:0},
{in:[0,1], out:0},
];
var w = [];
initWeights(w, inp);
//for(var j = 0; j < inp.length; j++){
var error = 1;
while(error >= 0.01){
error = train(w, inp);
}
//}
console.log("===")
var tester = {in:[1,0], out: NaN};
console.log(getSum(w, tester)) //should be negative
console.log("y=("+w[1]+"*x+"+w[2]+")/"+w[1])
結果に一貫性がありません (学習には AND アルゴリズムを使用しています)。
プロットは次のようになります。
しかし、通常は次のようになります。
ここで何か小さなことが欠けていると確信しています
。よろしくお願いします。