-
Notifications
You must be signed in to change notification settings - Fork 0
/
neurona_paso6.html
122 lines (88 loc) · 2.61 KB
/
neurona_paso6.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
<html>
<SCRIPT>
// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/every
class CapaNeuronal {
constructor (weights, bias) {
this.weights = weights;
this.bias = bias;
this.neuronas = [bias.lenght];
}
forward (inputs) {
// procesa calculos
// por cada neurona
for(let n=0; n<bias.length; n++){
// init
this.neuronas[n] = 0;
// multiplica todas las entradas con los pesos
for(let i=0; i<inputs.length; i++){
this.neuronas[n] += inputs[i] * this.weights[n][i];
}
// suma bias
this.neuronas[n] += this.bias[n];
}
}
// entrega resultado como salida
get output() {
return this.neuronas;
}
}
// Clase Neurona unica, se inicializa con pesos y bias, se llama con entradas y se retorna la salida
class Neurona {
constructor () {
this.inicializada = False;
this.result = 0;
}
setup (weights, bias) {
this.inicializada = True;
this.weights = weights;
this.bias = bias;
// peso[0] es el bias
//this.weights.unshift(bias);
// this.result = 0;
}
forward (inputs) {
// inputs[0] es 1 para ser neutro en la multiplicacion por el bias
// inputs.unshift(1);
// inicializa
let result = 0;
// multiplica todas las entradas con los pesos (incluido el bias*1)
for(let i=0; i<inputs.length; i++){
result += inputs[i] * this.weights[i];
}
// entrega resultado como salida
this.result = result + this.bias;
}
get output() {
return this.result;
}
}
// 4 entradas, 3 neuronas, tres salidas
// 4 Entradas, opc reemplazar bias como x[0]=1, asi se agrega un peso extra el cual reemplaza el valor del bias
let x = [1.0, 2.0, 3.0, 2.5];
// Pesos que conectan las 4 entradas con las 3 neuronas
let wN1 = [0.2, 0.8, -0.5, 1.0];
let wN2 = [0.5, -0.91, 0.26, -0.5];
let wN3 = [-0.26, -0.27, 0.17, 0.87];
let W = [wN1, wN2, wN3];
// Sesgos de las 3 neuronas
let bias = [2.0, 3.0, 0.5];
// crear instancias capa neuronal con pesos idem cantidad entradas, y bias idem salidas
var layerFC = new CapaNeuronal(W, bias);
// setiar valores de pesos y bias
// layerFC.setup(W, bias);
// paso de variables entrada y Proceso calculo de salida de las 3 neuronas
layerFC.forward(x);
// Salida
console.log(`layerFC : ${layerFC.output}`);
/////////////////////////////////////////////////////
//class Matriz {
// constructor () { }
// multiply() {}
// sum() {}
//}
/*
// https://developer.mozilla.org/es/docs/Web/JavaScript/Reference/Classes
// https://www.freecodecamp.org/espanol/news/arreglos-de-objetos-en-javascript-actualizar/
*/
</SCRIPT>
</html>