二.代码实现
  
  import numpy as np
  
  from sklearn import datasets
  
  from sklearn.model_selection import train_test_split
  
  from sklearn.linear_model import LogisticRegression
  
  import warnings
  
  warnings.filterwarnings('ignore')
  
  data = datasets.load_breast_cancer()
  
  x = data.data;y = data.target
  
  y[y==0] = -1
  
  x_train,x_test,y_train,y_test = train_test_split(x,y,test_size=0.2,random_state=1)
  
  omega = np.zeros(x.shape[1])
  
  b = 0
  
  lr = 0.01
  
  C = 1
  
  maxgen = 500
  
  for L in range(maxgen):
  
      error = 1 - (np.dot(x_train,omega)+b)*y_train
  
      index = np.argmax(error)
  
      if error[index] > 0:
  
          omega = (1-lr)*omega + lr*C*y_train[index]*x_train[index,:]
  
          b = b + lr*C*y_train[index]
  
      else:
  
          break
  
  predict_train = np.sign(np.dot(x_train,omega)+b)
  
  train_acc = len(np.where(predict_train==y_train)[0])/len(y_train)
  
  predict_test = np.sign(np.dot(x_test,omega)+b)
  
  test_acc = len(np.where(predict_test==y_test)[0])/len(y_test)
  
  print('Train acc = ',round(train_acc,4),' Test acc = ',round(test_acc,4))
  
  三.SMO算法实现
  
  import numpy as np
  
  from sklearn import datasets
  
  from sklearn import preprocessing
  
  from sklearn.model_selection import train_test_split
  
  from sklearn.svm import SVC
  
  import warnings
  
  warnings.filterwarnings('ignore')
  
  data = datasets.load_breast_cancer()
  
  x = data.data;x = preprocessing.MinMaxScaler().fit_transform(x)
  
  y = data.target;y[y==0] = -1
  
  x_train,x_test,y_train,y_test = train_test_split(x,y,test_size=0.2,random_state=1)
  
  alpha = np.zeros(x_train.shape[0])
  
  b = 0
  
  C = 1
  
  p = np.zeros(x_train.shape[0])
  
  maxgen = 100
  
  def gramMat(x):
  
      v = []
  
      for i in x:
  
          for j in x:
  
              k = np.dot(i,j.T)
  
              v.append(k)
  
      gram = np.array(v).reshape(len(x),len(x))
  
      return gram
  
  K = gramMat(x_train)
  
  def selectFirstSample(K,y,p,alpha,b,C):
  
      threshold = 0.001
  
      c = y*p-1
  
      c1 = c.copy();c2=c.copy();c3=c.copy()
  
      c1[(alpha > 0) & (c >= 0)] = 0
  
      c2[((alpha==0) | (alpha==C)) & (c==0)] = 0
  
      c3[(alpha < 0) & (c www.tiaotiaoylzc.com/ <= 0)] = 0
  
      error = c1**2+c2**2+c3**2
  
      index = np.argmax(error)
  
      if error[index] >= threshold:
  
          return index
  
      else:
  
          return None
  
  def selectSecondSample(id1,y_train):
  
      id2 = np.random.randint(www.ysyl157.com len(y_train))
  
      while id1 == id2:
  
          id2 = np.random.randint(len(y_train))
  
      return id2
  
  def boundary(y,id1,id2,C):
  
      if y[id1] =www.xgll521.com= y[id2]:
  
          lb = max(0,alpha[id1]+alpha[id2]-C)
  
          ub = min(C,alpha[id1]+alpha[id2])
  
      else:
  
          lb = max(0,alpha[id2]-alpha[id1])
  
          ub = min(C,C+alpha[id2]-alpha[id1])
  
      return lb,ub
  
  def updateAlpha(K,y,p,id1,id2,lb,ub,C):
  
      old_alpha1 = alpha[id1];old_alpha2 = alpha[id2]
  
      p1 = p[id1];p2 = p[id2]
  
      y1 = y[id1];y2 = y[id2]
  
      E1 = p1 - y1;E2 = p2 - y2
  
      beta = 2*K[id1,id2] - K[id1,id1] - K[id2,id2]
  
      new_alpha2 = old_alpha2 - y2*(E1-E2)/beta
  
      if new_alpha2 > ub:
  
          new_alpha2 = ub
  
      if new_alpha2 < lb:
  
          new_alpha2 www.taohuaqing178.com= lb
  
      alpha[id2] = new_alpha2
  
      new_alpha1 = old_alpha1 - y1*y2*(new_alpha2 - old_alpha2)
  
      alpha[id1] = new_alpha1
  
      deta1 = new_alpha1 - old_alpha1
  
      deta2 = new_alpha2 - old_alpha2
  
      dw = [y1*deta1,y2*deta2]
  
      b1 = -E1 - y1*K[id1,id1]*deta1 - y2*K[id1,id2]*deta2
  
      b2 = -E2 - y1*K[id1,id2]*deta1 - y2*K[id2,id2]*deta2
  
      if new_alpha1 >=0 and new_alpha1 <= C:
  
          db = b1
  
      elif new_alpha2 >www.thd178.com/ =0 and new_alpha2 <= C:
  
          db = b2
  
      else:
  
          db = (b1 + b2)/2
  
      p = p + dw[0]*K[id1,:].T + dw[1]*K[id2,:].T + db
  
      return p
  
  for L in range(maxgen):
  
      id1 = selectFirstSample(K,y_train,p,alpha,b,C)
  
      id2 = selectSecondSample(id1,y_train)
  
      lb,ub = boundary(y_train,id1,id2,C)
  
      p = updateAlpha(K,y,p,id1,id2,lb,ub,C)
  
  index = np.argmax((alpha!=0)&(alpha!=C))
  
  b = y_train[index] - np.sum(alpha*y_train*K[:,index])
  
  predict_train = np.sign(np.sum(alpha*y_train*K,axis=0)+b)
  
  train_acc = len(np.where(predict_train==y_train)[0])/len(y_train)
  
  predict_test = []
  
  for arr in x_test:
  
      v = np.sum(alpha*y_train*np.dot(x_train,arr.T))+b
  
      predict_test.append(np.sign(v))   
  
  test_acc = len(np.where(predict_test==y_test)[0])/len(y_test)
  
  print('self-written ==> Train acc = ',round(train_acc,4),' Test acc = ',round(test_acc,4))
  
  model = SVC()
  
  model.fit(x_train,y_train)
  
  train_acc = model.score(x_train,y_train)
  
  test_acc = model.score(x_test,y_test)
  
  print('sklearn ==> Train acc = ',round(train_acc,4),' Test acc = ',round(test_acc,4))

机器学习模型-支持向量机(SVM)的更多相关文章

  1. 机器学习之支持向量机—SVM原理代码实现

    支持向量机—SVM原理代码实现 本文系作者原创,转载请注明出处:https://www.cnblogs.com/further-further-further/p/9596898.html 1. 解决 ...

  2. 机器学习:支持向量机(SVM)

    SVM,称为支持向量机,曾经一度是应用最广泛的模型,它有很好的数学基础和理论基础,但是它的数学基础却比以前讲过的那些学习模型复杂很多,我一直认为它是最难推导,比神经网络的BP算法还要难懂,要想完全懂这 ...

  3. 机器学习算法 - 支持向量机SVM

    在上两节中,我们讲解了机器学习的决策树和k-近邻算法,本节我们讲解另外一种分类算法:支持向量机SVM. SVM是迄今为止最好使用的分类器之一,它可以不加修改即可直接使用,从而得到低错误率的结果. [案 ...

  4. 【机器学习】支持向量机SVM

    关于支持向量机SVM,这里也只是简单地作个要点梳理,尤其是要注意的是SVM的SMO优化算法.核函数的选择以及参数调整.在此不作过多阐述,单从应用层面来讲,重点在于如何使用libsvm,但对其原理算法要 ...

  5. python机器学习之支持向量机SVM

    支持向量机SVM(Support Vector Machine) 关注公众号"轻松学编程"了解更多. [关键词]支持向量,最大几何间隔,拉格朗日乘子法 一.支持向量机的原理 Sup ...

  6. 机器学习(十一) 支持向量机 SVM(上)

    一.什么是支撑向量机SVM (Support Vector Machine) SVM(Support Vector Machine)指的是支持向量机,是常见的一种判别方法.在机器学习领域,是一个有监督 ...

  7. 机器学习-5 支持向量机SVM

    一.概念和背景 SVM:Support Vector Machine 支持向量机. 最早是由Vladimir N. Vapnik和Alexey Ya. Chervonenkis在1963年提出的. 目 ...

  8. 机器学习(十一) 支持向量机 SVM(下)

    支持向量机通过某非线性变换 φ( x) ,将输入空间映射到高维特征空间.特征空间的维数可能非常高.如果支持向量机的求解只用到内积运算,而在低维输入空间又存在某个函数 K(x, x′) ,它恰好等于在高 ...

  9. 吴裕雄--天生自然python机器学习:支持向量机SVM

    基于最大间隔分隔数据 import matplotlib import matplotlib.pyplot as plt from numpy import * xcord0 = [] ycord0 ...

随机推荐

  1. 配置Echarts大全

    由于项目中需要用到Echarts,最近研究了一个星期.网上的教程也挺多的.磕磕碰碰的,难找到合适的例子.都说的马马虎虎.不废话了.开始. 这种上下排列的... 还有这种地图的.(如下) 还有就是配置的 ...

  2. phpredis命令

    <?php //redis //检查一个扩展是否已经加载.大小写不敏感. if (!function_exists('redis')) { echo '不支持 redis'; return ; ...

  3. python字符串编码

    python默认编码 python 2.x默认的字符编码是ASCII,默认的文件编码也是ASCII. python 3.x默认的字符编码是unicode,默认的文件编码是utf-8. 中文乱码问题 无 ...

  4. jmeter 插件安装

    1.下载Plugins Manager插件 打开下载插件地址:https://jmeter-plugins.org/ 2.将下载的plugins-manager.jar包复制到Jmeter安装目录,l ...

  5. latex02-LaTeX源文件的基本结构

    1.一个latex文件有且仅有一个document环境 %后表示注释 2.latex的导言区用于全局设置. 例如:title\author\date 加入空行是结构更加清晰 为了能正确的使用标题信息, ...

  6. 查询各科成绩最高和最低的分:以如下形式显示:课程ID,最高分,最低分

    SELECT L.C# As 课程ID,L.score AS 最高分,R.score AS 最低分 FROM SC L ,SC AS R WHERE L.C# = R.C# and L.score = ...

  7. shell重温---基础篇(参数传递&echo命令)

    经过前两天的学习,关于shell的基础算是知道的一般般啦,最起码不算是小白了(纯属意淫).今天就来点干货哈.   首先是运行shell脚本时的参数传递.脚本内获取参数的格式为$n.n代表了一个数字,例 ...

  8. 笔记-twisted-adbapi-scrapy

    笔记-twisted-adbapi-scrapy-mysql 1.      异步插入mysql 在爬虫中需要insert到mysql,但有一个问题是在爬虫环境中commit的及时性与性能冲突. 一般 ...

  9. VGA 时序标准

    VGA 显示器扫描方式从屏幕左上角一点开始,从左像右逐点扫描,每扫描完一行,电子束回到屏幕的左边下一行的起始位置,在这期间,CRT 对电子束进行消隐,每行结束时,用行同步信号进行同步:当扫描完所有的行 ...

  10. C#操作Excel文件(转)

    摘要:本文介绍了Excel对象.C#中的受管代码和非受管代码,并介绍了COM组件在.net环境中的使用. 关键词:受管代码:非受管代码:Excel对象:动态连接库 引言 Excel是微软公司办公自动化 ...