python3实现线性单元

理论知识见https://www.zybuluo.com/hanbingtao/note/448086直接上python3的代码#coding utf-8import matplotlib.pyplot as pltfrom functools import reduceclass perceptron(object): #初始化,输入训练数目,激活函数 def __ini...
摘要由CSDN通过智能技术生成

理论知识见https://www.zybuluo.com/hanbingtao/note/448086

直接上python3的代码

#coding utf-8
import matplotlib.pyplot as plt
from functools import reduce

class perceptron(object):
    #初始化,输入训练数目,激活函数
    def __init__(self,input_num,activator):#activator为激活函数
        self.activator=activator
        self.weights=[0.0 for _ in range(input_num)]#权重初始化为0
        self.bias=0.0#偏置初始化为0.0
    #运算
    def operation(self,input_vec):
        #对激活函数中的参数做运算,x[0]代表input_vec,x[1]代表weights
        return self.activator(reduce(lambda a,b:a+b,map(lambda x:x[0]*x[1],zip(input_vec,self.weights)),0.0)+self.bias)#0.0为reduce的初始计算值
    #权值更新
    def updata(self,input_vec,output,label,rate):
        delta=label-output
        self.weights=list(map(lambda x:x[1]+rate*delta*x[0],zip(input_vec,self.weights)))#加上list跟python2有区别
        self.bias+=rate*delta
    #训练,输入数据及对应标签,迭代次数,学习率
    def t
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值