第二章 机器学习分类算法

第二章节 训练简单的机器学习分类算法

##感知器实现

import numpy as np

class Perceptron(object):
    """
    参数:
    1.eta:学习速率
    2.n_iter:训练集上迭代次数
    3.w:权重
    4.errors:每次迭代错误分类数目
    
    """
    def __init__(self,eta=0.01,n_iter=10):
        self.eta=eta
        self.n_iter=n_iter
        
    def fit(self,X,y):
        """拟合训练集
        X;n×m,n个样本,m个特征
        """
        self.w_=np.zeros(1+X.shape[1])
        self.errors_=[]
        
        for _ in range(self.n_iter):
            errors=0
            for xi,target in zip(X,y):
                update=self.eta*(target-self.predict(xi))
                self.w_[1:] += update*xi
                self.w_[0] +=update
                errors += int(update!=0)
                
            self.errors_.append(errors)
        return self
    
    def net_input(self,X):
        "计算输入z"
        return np.dot(X,self.w_[1:])+self.w_[0]
    
    def predict(self,X):
        "返回预测值"
        return np.where(self.net_input(X) >=0, 1,-1)
    
import pandas as pd
df=pd.read_csv('https://archive.ics.uci.edu/ml/'
        'machine-learning-databases/iris/iris.data',header=None)
df.tail()
0 1 2 3 4
145 6.7 3.0 5.2 2.3 Iris-virginica
146 6.3 2.5 5.0 1.9 Iris-virginica
147 6.5 3.0 5.2 2.0 Iris-virginica
148 6.2 3.4 5.4 2.3 Iris-virginica
149 5.9 3.0 5.1 1.8 Iris-virginica
#变色鸢尾花:1
#山鸢尾花:-1
import matplotlib.pyplot as plt
import numpy as np

#将y类别赋予标签
y=df.iloc[0:100,4].values
y=np.where(y=='Iris-setosa',-1,1)

#提取X
X=df.iloc[0:100,[0,2]].values

plt.scatter(X[0:50,0],X[:50,1],color='red',label='setosa',marker='o')
plt.scatter(X[50:100,0],X[50:100,1],color='blue',label='versicolor',marker='o')
plt.xlabel('petal length')
plt.ylabel('sepal length')
plt.legend(loc='best')
plt.show()

在这里插入图片描述

#训练感知器和绘制错误分类数量的迭代图
ppn=Perceptron(eta=0.1,n_iter=20)
ppn.fit(X,y)
plt.plot
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值