看到this answer后,我在导出网络时遇到了一些问题。这是网络生成代码:
net = buildNetwork(2, 1, 1, bias=False)
sol = net.activate([2,3])
print("solution", sol)
for mod in net.modules:
for conn in net.connections[mod]:
print("connection:",conn)
for cc in range(len(conn.params)):
print(conn.whichBuffers(cc), conn.params[cc])
输出:
solution [ 0.12654066]
connection: <FullConnection 'FullConnection-3': 'hidden0' -> 'out'>
(0, 0) 1.02869832075
connection: <FullConnection 'FullConnection-4': 'in' -> 'hidden0'>
(0, 0) 0.410307885215
(1, 0) -0.928280457049
不应该解决它的解决方案
(0.410307885215*2-0.928280457049*3)*1.02869832075
是-2.0206,而不是0.12654066
答案 0 :(得分:0)
好的,所以我忘记了激活功能。默认的激活函数是sigmoid函数,在python中你可以用
轻松完成from scipy.special import expit
expit((0.410307885215*2-0.928280457049*3))*1.02869832075 = 0.1265406616438563
我的下一个问题是如何添加偏见。在运行sigmoid函数之前添加偏差。所以,如果你这样做:
net = buildNetwork(2, 1, 1, bias=True)
然后它基本上构建:
expit(weight_in1*input1+weight_in2*input2+hidden_bias)*hidden_weight+bias_out
希望对与我有同样问题的人有意义。