我是靠谱客的博主 光亮宝贝,这篇文章主要介绍Tricks(四十)—— 神经网络解决与(或)及异或问题,现在分享给大家,希望可以做个参考。

G(x)=signt=1Tαtsign(wTtx)g(x)

  • AND 与问题

    G(x)=1+g1(x)+g2(x)G(x)=1g0+1g1+1g2

    暗含了 gt(x) 的系数分别为:-1,1,1

  • OR 或问题

    G(x)=1+g1(x)+g2(x)G(x)=1g0+1g1+1g2

    暗含了 gt(x) 的系数分别为:1,1,1

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
inputs = [(1, x, y) for x in (-1, 1) for y in (-1, 1)] # 1:表示常量输出,g_0(x) # x: g_1 的输出 # y: g_2 的输出 # 定义内积运算 def inner_prod(x, y): return reduce(operator.add, map(lambda z: z[0]*z[1], zip(x, y))) def G_AND(gs): return 1 if inner_prod([-1, 1, 1], gs) > 0 else -1 def G_OR(gs): return 1 if inner_prod([1, 1, 1], gs) > 0 else -1 if __main__ == '__name__': print 'or: ', [G_OR(g) for g in s] print 'and: ', [G_AND(g) for g in s]
  • XOR 问题

    单层感知机是无法解决异或问题的,又因为布尔运算中说:异或问题可以转换为基本布尔运算(与,或,非)的叠加,也即:

    复制代码
    1
    Y = (A & !B) | (!A & B)
    复制代码
    1
    2
    3
    4
    def G_XOR(l): l1 = l[0], l[1], -l[2] l2 = l[0], -l[1], l[2] return G_OR([1, G_AND(l1), G_AND(l2)])

最后

以上就是光亮宝贝最近收集整理的关于Tricks(四十)—— 神经网络解决与(或)及异或问题的全部内容,更多相关Tricks(四十)——内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(69)

评论列表共有 0 条评论

立即
投稿
返回
顶部