我使用了Neataptic库来为XOR进化结构,就像它们在github页面上的说明一样。
实际的结果似乎是正确的--,但是当我可视化节点(大部分时间)时,没有隐藏层--只有2个输入节点和1个输出,因此我假设它不应该工作。你知道怎么回事吗?
var network = new neataptic.Network(2,1);
var trainingSet = [
{ input: [0,0], output: [0] },
{ input: [0,1], output: [1] },
{ input: [1,0], output: [1] },
{ input: [1,1], output: [0] }
];
async function abc() {
await network.evolve(trainingSet, {
equal: true,
error: 0.03
});
document.getElementById("app").innerHTML = "0 ⊕ 0 = " +
network.activate([0,0]) + "<br />0 ⊕ 1 = " +
network.activate([0,1]) + "<br />1 ⊕ 0 = " +
network.activate([1,0]) + "<br />1 ⊕ 1 = " +
network.activate([1,1]);
drawGraph(network.graph(500, 400), '#draw');
}
abc();* {
box-sizing: border-box;
}
body {
margin: 0;
padding: 0;
height: 100vh;
}
#app {
vertical-align: top;
display: inline-block;
padding: 15px;
width: 20%;
height: 100%;
}
#draw {
vertical-align: top;
display: inline-block;
width: 80%;
height: 100%;
}<link rel="stylesheet" type="text/css" href="https://rawgit.com/wagenaartje/neataptic/master/graph/graph.css">
<script src="https://d3js.org/d3.v3.min.js"></script>
<script src="https://marvl.infotech.monash.edu/webcola/cola.v3.min.js"></script>
<script src="https://combinatronics.com/wagenaartje/neataptic/master/graph/graph.js"></script>
<script src="https://wagenaartje.github.io/neataptic/cdn/1.4.7/neataptic.js"></script>
<div id="app">
</div><svg id="draw" width="600px" height="450px" />
发布于 2019-03-25 16:18:36
我已经联系了Neataptic图书馆的创建者,这就是我问题的答案:
..。回想一下,突变也可以改变最终节点的压缩功能。是的,默认的逻辑压缩函数不能处理XOR,但是正弦函数可以!
发布于 2019-02-10 22:52:45
您只定义了两个输入层和一个输出。再读一读文档,看看如何正确地添加隐藏层。使用感知器或lstm
https://stackoverflow.com/questions/54378742
复制相似问题