参考李航《统计学习方法》 一开始的感知机章节,看着不太复杂就实现一下。。。

 """
感知机学习算法的原始形式
例2.1
"""
import numpy as np class Perceptron:
def __init__(self,w,b,alpha):
self.w = w
self.b = b
self.alpha = alpha def loss(self,x,y):
return np.sum( y*(np.dot(x, self.w) + self.b) ) def sgd(self,x,y): # 随机梯度下降函数
self.w += self.alpha * y * x
self.b += self.alpha * y def train(self,X,Y):
while(True):
M = len(X) # 错误分类数
for i in range(len(X)):
if self.loss(X[i],Y[i])<=0:
self.sgd(X[i],Y[i])
print "w:",self.w," b:",self.b
else:
M -= 1
if not M:
print "final optimal:","w:",self.w," b:",self.b
break class Perceptron_dual:
def __init__(self,alpha,b,ita):
self.alpha = alpha
self.b = b
self.ita = ita def gram(self,X):
return np.dot(X,X.T) def train(self,X,Y):
g = self.gram(X) M = len(X) # 错误分类数
while(True):
M = len(X) # 错误分类数
for j in range(len(X)):
if Y[j] * (np.sum(self.alpha * Y * g[j]) + self.b) <= 0:
self.alpha[j] += self.ita
self.b += self.ita * Y[j]
print "a:",self.alpha," b:",self.b
else:
M -= 1
if M == 0:
print "final optimal:","a:",self.alpha," b:",self.b
break if __name__ == "__main__": X = np.array([[3,3],[4,3],[1,1]]) Y = np.array([1,1,-1])
perc_d = Perceptron_dual(np.zeros(Y.shape),0,1)
perc_d.train(X, Y)

感知机学习算法 python实现的更多相关文章

  1. 【机器学习】感知机学习算法(PLA)

    感知机问题学习算法引入:信用卡问题 根据已知数据(不同标准的人的信用评级)训练后得出一个能不能给新客户发放信用卡的评定结果 解决该问题的核心思想扔为之前所讲到的梯度下降算法,对于更多条件的类似问题,首 ...

  2. 感知机学习算法(PLA)

    Perception Learning Algorithm, PLA 1.感知机 感知机是一种线性分类模型,属于判别模型. 感知机模型给出了由输入空间到输出空间的映射: f(X) = sign(WTX ...

  3. 感知机学习算法Java实现

    感知机学习算法Java实现. Perceptron类用于实现感知机, 其中的perceptronOriginal()方法用于实现感知机学习算法的原始形式: perceptronAnother()方法用 ...

  4. 利用Python实现一个感知机学习算法

    本文主要参考英文教材Python Machine Learning第二章.pdf文档下载链接: https://pan.baidu.com/s/1nuS07Qp 密码: gcb9. 本文主要内容包括利 ...

  5. 吴裕雄 python 机器学习——人工神经网络感知机学习算法的应用

    import numpy as np from matplotlib import pyplot as plt from sklearn import neighbors, datasets from ...

  6. 利用python深度学习算法来绘图

    可以画画啊!可以画画啊!可以画画啊! 对,有趣的事情需要讲三遍. 事情是这样的,通过python的深度学习算法包去训练计算机模仿世界名画的风格,然后应用到另一幅画中,不多说直接上图! 这个是世界名画& ...

  7. 【数据结构与算法Python版学习笔记】引言

    学习来源 北京大学-数据结构与算法Python版 目标 了解计算机科学.程序设计和问题解决的基本概念 计算机科学是对问题本身.问题的解决.以及问题求解过程中得出的解决方案的研究.面对一 个特定问题,计 ...

  8. win10+anaconda+cuda配置dlib,使用GPU对dlib的深度学习算法进行加速(以人脸检测为例)

    在计算机视觉和机器学习方向有一个特别好用但是比较低调的库,也就是dlib,与opencv相比其包含了很多最新的算法,尤其是深度学习方面的,因此很有必要学习一下.恰好最近换了一台笔记本,内含一块GTX1 ...

  9. 精选 TOP45 值得学习的Python项目

    精选 TOP45 值得学习的Python项目 [导读]热门资源博客 Mybridge AI 比较了 18000 个关于 Python 的项目,并从中精选出 45 个最具竞争力的项目.我们进行了翻译,在 ...

随机推荐

  1. java面向对象编程——第二章 java基础语法

    第二章 java基础语法 1. java关键字 abstract boolean break byte case catch char class const continue default do ...

  2. The C10K problem

    原文链接:http://www.kegel.com/c10k.html It's time for web servers to handle ten thousand clients simulta ...

  3. 上传项目的更改 info.plist文件

    info.plistOpen AsSource As 添加<key>NSAppTransportSecurity</key>    <dict>        &l ...

  4. POJ 1011 Sticks dfs,剪枝 难度:2

    http://poj.org/problem?id=1011 要把所给的集合分成几个集合,每个集合相加之和ans相等,且ans最小,因为这个和ans只在[1,64*50]内,所以可以用dfs一试 首先 ...

  5. ROS TF——learning tf

    在机器人的控制中,坐标系统是非常重要的,在ROS使用tf软件库进行坐标转换. 相关链接:http://www.ros.org/wiki/tf/Tutorials#Learning_tf 一.tf简介 ...

  6. CoHTMLDocument

    http://blog.csdn.net/dlwxn/article/details/2860329 http://www.itnose.net/detail/120267.html 不知道是 线程内 ...

  7. JDBC 连接池

    数据库连接池(connection pool) JDBC数据库连接池的必要性 在使用开发基于数据库的web程序时,传统的模式基本是按以下步骤: 在主程序(如servlet.beans)中建立数据库连接 ...

  8. HTML参考

    HTML Basic Document <html> <head> <title>Document name goes here</title> < ...

  9. c#读取文本文档实践1-File.ReadAllLines()

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.I ...

  10. Centos 6 安装 epel yum库

    1.获得epel库安装rpm包 wget https://dl.fedoraproject.org/pub/epel/epel-release-latest-6.noarch.rpm 2.安装获得的r ...