当前位置: 首页 > news >正文

机器学习实验三:支持向量机模型

系列文章目录

  1. 机器学习实验一:线性回归
  2. 机器学习实验二:决策树模型
  3. 机器学习实验三:支持向量机模型
  4. 机器学习实验四:贝叶斯分类器
  5. 机器学习实验五:集成学习
  6. 机器学习实验六:聚类

文章目录

  • 系列文章目录
  • 一、实验目的
  • 二、实验原理
  • 三、实验内容
  • 四、实验步骤
    • 1. 训练集和测试数据集划分
    • 2. 评价分类结果 TP、FN、FP、TN 以及精确率和召回率
    • 3. 加入松弛因子后,与未加松弛因子之前效果做对比。
  • 五、代码参考
  • 总结


一、实验目的

(1)了解支持向量机基本知识;
(2)掌握 SVM 分类器的设计方法;
(3)学会建立 SVM 分类器来实现分类预测,并进行结果分析。

二、实验原理

支持向量机旨在求一个分离超平面。这个超平面使得离它最近的点能够最远。

三、实验内容

使用 Python 读取数据集信息, 使用鸢尾花的花萼(sepal)和花瓣(petal)
的长和宽数据,并利用 sklearn 训练支持向量机模型,随后使用 SVM 实现分类预
测,判断样本属于山鸢尾(Iris Setosa)、变色鸢尾(Iris Versicolor)还是
维吉尼亚鸢尾(Iris Virginica)。评价分类结果 TP、FN、FP、TN 以及精确率和
召回率。
加入松弛因子后,与未加松弛因子之前效果做对比。

四、实验步骤

1. 训练集和测试数据集划分

导入鸢尾花数据集,将数据集按 80%训练集,20%测试集的比例进行分割。

2. 评价分类结果 TP、FN、FP、TN 以及精确率和召回率

FN:被判定为负样本,但事实上是正样本;
FP:被判定为正样本,但事实上是负样本;
TN:被判定为负样本,事实上也是负样本;
TP:被判定为正样本,事实上也是正样本;
精确率 Precision:针对模型判断出的所有正例(即 TP + FP)而言,其中真
正例 TP 占的比例。
Precision = TP /( TP + FP )
召回率 Recall:针对数据集中的所有正例(即 TP + FN)而言,模型正确判
断出的正例 TP 占数据集中所有正例的比例,FN 表示被模型误认为是负例但实
际是正例的数据。
Recall = TP/( TP + FN )

3. 加入松弛因子后,与未加松弛因子之前效果做对比。

假设样本数为 n,原先对样本的分类是yi( 𝑤 ⋅ 𝑥𝑖 + b) ≥ 1 ( i = 1, 2, … ,
n ),则引入松弛因子 ξ ≥ 0后对样本分类的要求变为 yi
( 𝑤 ⋅ 𝑥𝑖 + b) ≥ 1 − 𝜉𝑖 ( i
= 1, 2, …, n ),松弛因子的意义是引入一定的容错性。

五、代码参考

import numpy as np
from sklearn import svm, datasets
from sklearn.model_selection import train_test_split
from sklearn.multiclass import OneVsRestClassifier
from sklearn.preprocessing import label_binarize
iris = datasets.load_iris()
X = iris.data
y = iris.target
random_state = np.random.RandomState(0)
n_samples, n_features = X.shape
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=.2, random_state=66)
# 设定参数
classifier = OneVsRestClassifier(svm.SVC(C=100000, kernel='linear', probability=True, 
random_state=random_state))
classifier.fit(X_train, y_train)
y_pred = classifier.predict(X_test)
def func(precited, expected):res = (precited ^ expected) r = np.bincount(res)tp_list = (precited & expected)fp_list = (precited & (~expected))tp_list = tp_list.tolist()fp_list = fp_list.tolist()TP = tp_list.count(1)FP = fp_list.count(1)TN = r[0] - TPFN = r[1] - FPRecall = TP / (TP + FN)Precesion = TP / (TP + FP)return TP, FP, TN, FN, Recall, Precesion
y_test1 = label_binarize(y_test, classes=[0, 1, 2])
y_pred1 = label_binarize(y_pred, classes=[0, 1, 2])
print(y_pred1[..., 0], y_test1[..., 0])
tp, fp, tn, fn, recall, pre = func(y_pred1[..., 0], y_test1[..., 0])
recall = format(recall, '0.2f')
pre = format(pre, '0.2f')
print(f"type1:recall = {recall} precision ={pre}")
tp, fp, tn, fn, recall, pre = func(y_pred1[..., 1], y_test1[..., 1])
recall = format(recall, '0.2f')
pre = format(pre, '0.2f')
print(f"type2:recall = {recall} precision = {pre}")
tp, fp, tn, fn, recall, pre = func(y_pred1[..., 2], y_test1[..., 2])
recall = format(recall, '0.2f')
pre = format(pre, '0.2f')
print(f"type3:recall = {recall} precision = {pre}")

修改松弛因子
即修改如下语句中的参数 C
classifier = OneVsRestClassifier(svm.SVC(C=100, kernel=‘linear’, probability=True,
random_state=random_state)

总结

以上就是今天要讲的内容,机器学习实验三:支持向量机模型

相关文章:

  • 连锁零售企业如何优化网络性能?
  • 【开源】基于Vue+SpringBoot的教学资源共享平台
  • Redis研学-三种特殊类型的常用命令
  • blender 数字键盘上的快捷键
  • el-tree搜索的使用
  • svn使用步骤
  • Qt开发 之 记一次安装 Qt5.12.12 安卓环境的失败案例
  • IntelliJ插件开发-Code Vision Hints
  • 菜鸟学习日记(python)——循环语句
  • 酶联免疫抗体试剂——博迈伦生物
  • codeblocks代码提示导致延迟的问题
  • OpenGL学习(二)绘制三维图形 固定管线
  • HTML5 基础总结
  • 【Deeplearning4j】小小的了解下深度学习
  • 使用OkHttp上传本地图片及参数
  • angular组件开发
  • CentOS7简单部署NFS
  • EOS是什么
  • isset在php5.6-和php7.0+的一些差异
  • JavaScript实现分页效果
  • Java应用性能调优
  • Magento 1.x 中文订单打印乱码
  • Redash本地开发环境搭建
  • Spring Cloud Alibaba迁移指南(一):一行代码从 Hystrix 迁移到 Sentinel
  • web标准化(下)
  • 利用DataURL技术在网页上显示图片
  • 终端用户监控:真实用户监控还是模拟监控?
  • 小白应该如何快速入门阿里云服务器,新手使用ECS的方法 ...
  • ​渐进式Web应用PWA的未来
  • # linux 中使用 visudo 命令,怎么保存退出?
  • # 再次尝试 连接失败_无线WiFi无法连接到网络怎么办【解决方法】
  • (01)ORB-SLAM2源码无死角解析-(56) 闭环线程→计算Sim3:理论推导(1)求解s,t
  • (JSP)EL——优化登录界面,获取对象,获取数据
  • (Matlab)使用竞争神经网络实现数据聚类
  • (简单有案例)前端实现主题切换、动态换肤的两种简单方式
  • (转)【Hibernate总结系列】使用举例
  • (转)ABI是什么
  • (转)可以带来幸福的一本书
  • (轉貼) 資訊相關科系畢業的學生,未來會是什麼樣子?(Misc)
  • .NET Standard 支持的 .NET Framework 和 .NET Core
  • .NET 应用启用与禁用自动生成绑定重定向 (bindingRedirect),解决不同版本 dll 的依赖问题
  • .Net的C#语言取月份数值对应的MonthName值
  • .net连接MySQL的方法
  • .NET与 java通用的3DES加密解密方法
  • .Net中间语言BeforeFieldInit
  • @NoArgsConstructor和@AllArgsConstructor,@Builder
  • @Tag和@Operation标签失效问题。SpringDoc 2.2.0(OpenApi 3)和Spring Boot 3.1.1集成
  • [Angular] 笔记 21:@ViewChild
  • [CSS]CSS 字体属性
  • [DL]深度学习_Feature Pyramid Network
  • [exgcd] Jzoj P1158 荒岛野人
  • [Leetcode LCR 106.判断二分图]
  • [leetcode]Search a 2D Matrix @ Python
  • [NAND Flash 7.1] 闪存系统性能优化方向集锦?AC timing? Cache? 多路并发?
  • [Python]list.append字典的时候,修改字典会导致list内容变化的问题