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

核函数支持向量机(Kernel SVM)

核函数支持向量机(Kernel SVM)是一种非常强大的分类器,能够在非线性数据集上实现良好的分类效果。以下是关于核函数支持向量机的详细数学模型理论知识推导、实施步骤与参数解读,以及两个多维数据实例(一个未优化模型,一个优化后的模型)的完整分析。

一、数学模型理论推导

1.1 线性支持向量机

支持向量机的目标是找到一个超平面,以最大化两类数据点之间的间隔。对于线性可分的数据,支持向量机的目标可以用以下优化问题来表示:

97557112f56d4fae8901e76e7622d405.png

1.2 非线性支持向量机

029dde8d27b442f5b21522f73a1115c3.png

11a83a5da5c840cdaa5288fd815017f4.png

二、实施步骤与参数解读

2.1 选择核函数

常用的核函数有:

26b46bb2114a44949ac166b9f725d6f2.png

2.2 参数选择

  • C:控制分类错误与间隔的权衡。值越大,分类错误越少,但间隔越小,容易过拟合。
  • eq?%5Cgamma:控制RBF核的宽度。值越大,高斯分布越窄,模型复杂度越高,容易过拟合。

三、多维数据实例

import numpy as np
import matplotlib.pyplot as plt
from sklearn.svm import SVC
from sklearn.datasets import make_classification
from sklearn.model_selection import train_test_split
from sklearn.metrics import classification_report# 生成数据
X, y = make_classification(n_samples=300, n_features=2, n_informative=2, n_redundant=0, n_clusters_per_class=1, random_state=42)
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3, random_state=42)# 未优化的核函数SVM模型
model = SVC(kernel='rbf', C=1.0, gamma='scale')
model.fit(X_train, y_train)# 预测与结果分析
y_pred = model.predict(X_test)
print("未优化模型分类报告:")
print(classification_report(y_test, y_pred))# 可视化结果
plt.figure(figsize=(10, 6))
plt.scatter(X_test[:, 0], X_test[:, 1], c=y_test, cmap='coolwarm', s=30, edgecolors='k')
plt.title("未优化的核函数SVM分类结果", fontname='KaiTi')
plt.show()
# 优化后的核函数SVM模型
model_optimized = SVC(kernel='rbf', C=10.0, gamma=0.1)
model_optimized.fit(X_train, y_train)# 预测与结果分析
y_pred_optimized = model_optimized.predict(X_test)
print("优化后模型分类报告:")
print(classification_report(y_test, y_pred_optimized))# 可视化结果
plt.figure(figsize=(10, 6))
plt.scatter(X_test[:, 0], X_test[:, 1], c=y_test, cmap='coolwarm', s=30, edgecolors='k')
plt.title("优化后的核函数SVM分类结果", fontname='KaiTi')
plt.show()

c8b6cff8d61e4d429e6b5d4e01ebb838.png

9b04a72b54e241a2a4983fc3b0b6bebb.png

7e9112b974f846c196bf2798503465a0.png

四、结果与结果解释

4.1 未优化模型

  • 分类报告显示了精度、召回率和F1分数等指标。
  • 可视化图展示了未优化模型的分类边界和测试集数据点。

4.2 优化后的模型

  • 优化后模型的分类报告通常会显示更高的精度、召回率和F1分数,表明模型性能提升。
  • 优化后的可视化图展示了改进后的分类边界,更好地分隔了数据点。

 

 

 

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • IDEA中常用的快捷键
  • 【医学影像】RK3588+FPGA:满足远程诊疗系统8K音视频编解码及高效传输需求
  • SpreadsheetLLM:微软对Excel编码的“摊膀伏”
  • LVS+Nginx高可用集群---搭建高可用集群负载均衡
  • 【论文阅读笔记】Hierarchical Neural Coding for Controllable CAD Model Generation
  • .net6 core Worker Service项目,使用Exchange Web Services (EWS) 分页获取电子邮件收件箱列表,邮件信息字段
  • LeetCode 每日一题 2024/7/15-2024/7/21
  • 6 回归集成:xgb、lgb、cat
  • Air780E/Air780EP/Air780EQ/Air201模块遇到死机问题如何分析
  • 最新!CSSCI(2023-2024)期刊目录公布!
  • AndroidStudio与手机进行无线调试
  • SRv6 BE 配置过程(VRF ping通场景)
  • 图——图的应用02最短路径(Dijkstra算法与Floyd算法详解),拓扑排序及关键路径
  • CSS3 教程
  • Flutter 中的基本数据类型:num、int 和 double
  • 《微软的软件测试之道》成书始末、出版宣告、补充致谢名单及相关信息
  • 8年软件测试工程师感悟——写给还在迷茫中的朋友
  • FineReport中如何实现自动滚屏效果
  • Java基本数据类型之Number
  • maven工程打包jar以及java jar命令的classpath使用
  • MQ框架的比较
  • React中的“虫洞”——Context
  • Spring Boot MyBatis配置多种数据库
  • 高性能JavaScript阅读简记(三)
  • 使用Envoy 作Sidecar Proxy的微服务模式-4.Prometheus的指标收集
  • 原生JS动态加载JS、CSS文件及代码脚本
  • 在electron中实现跨域请求,无需更改服务器端设置
  • 这几个编码小技巧将令你 PHP 代码更加简洁
  • 3月27日云栖精选夜读 | 从 “城市大脑”实践,瞭望未来城市源起 ...
  • 树莓派用上kodexplorer也能玩成私有网盘
  • 通过调用文摘列表API获取文摘
  • ​HTTP与HTTPS:网络通信的安全卫士
  • ​Linux·i2c驱动架构​
  • #gStore-weekly | gStore最新版本1.0之三角形计数函数的使用
  • (06)金属布线——为半导体注入生命的连接
  • (4)事件处理——(2)在页面加载的时候执行任务(Performing tasks on page load)...
  • (Charles)如何抓取手机http的报文
  • (C语言)strcpy与strcpy详解,与模拟实现
  • (C语言)编写程序将一个4×4的数组进行顺时针旋转90度后输出。
  • (pytorch进阶之路)CLIP模型 实现图像多模态检索任务
  • (二)linux使用docker容器运行mysql
  • (附源码)spring boot儿童教育管理系统 毕业设计 281442
  • (面试必看!)锁策略
  • (七)Appdesigner-初步入门及常用组件的使用方法说明
  • (五十)第 7 章 图(有向图的十字链表存储)
  • (译)计算距离、方位和更多经纬度之间的点
  • (正则)提取页面里的img标签
  • (轉)JSON.stringify 语法实例讲解
  • .bat批处理(六):替换字符串中匹配的子串
  • .desktop 桌面快捷_Linux桌面环境那么多,这几款优秀的任你选
  • .NET 8 跨平台高性能边缘采集网关
  • .net 获取url的方法
  • .net 中viewstate的原理和使用
  • .NET 自定义中间件 判断是否存在 AllowAnonymousAttribute 特性 来判断是否需要身份验证
  • .NET程序集编辑器/调试器 dnSpy 使用介绍