data:image/s3,"s3://crabby-images/5213a/5213adb6da18e256d43d6941370cafeff574bda0" alt="ショコラ"
ショコラ
AI PHPで実装してみます
勉強したことをアウトプットしていきます。
data:image/s3,"s3://crabby-images/2512f/2512fe90da35022677d8d22f56767bdd7b37afc9" alt="もっさん先輩"
もっさん先輩
data:image/s3,"s3://crabby-images/f57fb/f57fb3c7727973bb8ea251b386d19c083deed3be" alt=""
<?php
$input = [1.0,0.5];
$weight = [[0.9,0.2],[0.3,0.8]];
$output = [0,0];
function sigmoid( $x )
{
return 1 / (1 + exp(-1 * $x));
}
// 入力層の値にリンクの重みを掛けて出力層に保存します。
foreach ($input as $i => $in) {
foreach ($weight[$i] as $j => $w) {
$output[$j] += $in * $w;
}
}
// 出力層にシグモイド関数を適用します。
foreach ($output as $i => $o) {
$output[$i] = sigmoid($o);
}
var_dump($output);
data:image/s3,"s3://crabby-images/19fe9/19fe9bff79defcea30e4a17dc978b89a015a4262" alt=""
<?php
$input = [0.9,0.1,0.8];
$weight1 = [[0.9,0.2,0.1],[0.3,0.8,0.5],[0.4,0.2,0.6]];
$hidden = [0,0,0];
$weight2= [[0.3,0.6,0.8],[0.7,0.5,0.1],[0.5,0.2,0.9]];
$output = [0,0,0];
function sigmoid( $x )
{
return 1 / (1 + exp(-1 * $x));
}
// 入力層にリンクの重みを掛けて隠れ層に保存する。
foreach ($input as $i => $in) {
foreach ($weight1 [$i] as $j => $w) {
$hidden[$j] += $in* $w;
}
}
// 隠れ層にシグモイド関数を適用する。
foreach ($hidden as $i => $v) {
$hidden[$i] = sigmoid($v);
}
var_dump($hidden);
// 隠れ層にリンクの重みを掛けて出力層に保存する。
foreach ($hidden as $i => $h) {
foreach ($weight2[$i] as $j => $w) {
$output[$j] += $h * $w;
}
}
// 出力層にシグモイド関数を適用する。
foreach ($output as $i => $o) {
$output[$i] = sigmoid($o);
}
var_dump($output);
data:image/s3,"s3://crabby-images/82fe1/82fe16281b80e4d906a05849f39ef4abe7fb7146" alt=""
<?php
$error = [0.8,0.5];
$weight2 = [[2.0,1.0],[3.0,4.0]];
$hidden = [0,0];
// 誤差を逆伝播する。(出力層→隠れそう)
foreach ($error as $i => $e) { //$e = 0.8
$total = 0;
foreach ($weight2 as $w) {
$total += $w[$i];
}
foreach ($weight2 as $j => $w) {
$hidden[$j] += $e* $w[$i] / $total;
}
}
var_dump($hidden);
data:image/s3,"s3://crabby-images/b1b83/b1b83b652f54b3362cd584daafc121b3ac9b1137" alt=""
<?php
$error = [0.8,0.5];
$weight2 = [[2.0,1.0],[3.0,4.0]];
$weight1 = [[3.0,1.0],[2.0,7.0]];
$hidden = [0,0];
$input = [0,0];
// 誤差を逆伝播する。(出力層→隠れそう)
foreach ($error as $i => $e) { //$e = 0.8
$total = 0;
foreach ($weight2 as $w) {
$total += $w[$i];
}
foreach ($weight2 as $j => $w) {
$hidden[$j] += $e* $w[$i] / $total;
}
}
// 誤差を逆伝播する。(隠れそう→入力層)
foreach ($hidden as $i => $e) { //$e = 0.8
$total = 0;
foreach ($weight1 as $w) {
$total += $w[$i];
}
foreach ($weight1 as $j => $w) {
$input[$j] += $e* $w[$i] / $total;
}
}
var_dump($input);
data:image/s3,"s3://crabby-images/cc170/cc170a27b367888d127aac8d84a80f06f5603fb3" alt=""
data:image/s3,"s3://crabby-images/6c730/6c730e0648b3572c05c70d29974d201f9f2d5417" alt=""
リンクの重みを更新する処理
<?php
$error = [0.8,0.5];
$weight2 = [[2.0,1.0],[3.0,4.0]];
$hidden = [0.4,0.5];
function sigmoid( $x )
{
return 1 / (1 + exp(-1 * $x));
}
foreach ($error as $i => $e)
{
$total = 0;
foreach ($weight2 as $j => $w) {
$total += $w[$i] * $hidden[$j];
}
$sigm = sigmoid($total);
foreach ($weight2 as $j => $w) {
$d = -1 * ($e) * $sigm * (1 - $sigm) * $hidden[$j];
$weight2[$i][$j] += -0.1 * $d;
}
}
data:image/s3,"s3://crabby-images/90194/90194cc1a329c751291ae2fa03bb0ae7f587694a" alt=""
以上