支持向量机案例

以下是一个使用支持向量机(SVM)对鸢尾花数据集进行分类的案例:

1. 数据集介绍

鸢尾花数据集是一类多重变量分析的数据集,共有四个属性列和一个品种类别列,用于分类的属性包括花萼长度、花萼宽度、花瓣长度、花瓣宽度,类别包括山鸢尾、变色鸢尾和维吉尼亚鸢尾三类。该数据集通常被用于分类算法的测试和验证。

2. 数据准备

  • 首先导入必要的库,包括用于数据处理的pandas、用于数据分割的train_test_split、支持向量机模型SVC以及用于评估模型的accuracy_score等。

python

复制代码
import pandas as pd
from sklearn.model_selection import train_test_split
from sklearn.svm import SVC
from sklearn.metrics import accuracy_score
  • 然后读取鸢尾花数据集,假设数据集保存在名为iris.csv的文件中。

python

复制代码
data = pd.read_csv('iris.csv')
  • 接着将数据集分为特征(X)和目标(y)。特征是用于分类的属性,目标是鸢尾花的类别。

python

复制代码
X = data.iloc[:, :-1]
y = data.iloc[:, -1]
  • 最后将数据集划分为训练集和测试集,通常将 70% 的数据用于训练,30% 的数据用于测试。

python

复制代码
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3, random_state=42)

3. 模型训练

  • 创建一个支持向量机模型,这里使用线性核函数。

python

复制代码
model = SVC(kernel='linear')
  • 使用训练数据对模型进行训练。

python

复制代码
model.fit(X_train, y_train)

4. 模型评估

  • 使用测试集进行预测。

python

复制代码
y_pred = model.predict(X_test)
  • 计算模型的准确率。

python

复制代码
accuracy = accuracy_score(y_test, y_pred)
print("Accuracy:", accuracy)

5. 结果分析

通过上述步骤,我们可以得到支持向量机模型在鸢尾花数据集上的分类准确率。如果准确率较高,说明模型能够较好地对鸢尾花进行分类。同时,还可以进一步分析模型的混淆矩阵、精确率、召回率等指标,以更全面地评估模型的性能。此外,还可以尝试不同的核函数、调整模型的超参数,如惩罚参数C等,来优化模型的性能。

相关推荐
光羽隹衡几秒前
决策树项目——电信客户流失预测
算法·决策树·机器学习
TL滕几秒前
从0开始学算法——第二十一天(高级链表操作)
笔记·学习·算法
CoovallyAIHub几秒前
无人机低空视觉数据集全景解读:从单机感知到具身智能的跨越
深度学习·算法·计算机视觉
学编程就要猛1 分钟前
算法:1.移动零
java·算法
杜子不疼.1 分钟前
【LeetCode 35 & 69_二分查找】搜索插入位置 & x的平方根
算法·leetcode·职场和发展
YYDS3142 分钟前
次小生成树
c++·算法·深度优先·图论·lca最近公共祖先·次小生成树
黑客思维者3 分钟前
机器学习014:监督学习【分类算法】(逻辑回归)-- 一个“是与非”的智慧分类器
人工智能·学习·机器学习·分类·回归·逻辑回归·监督学习
xu_yule5 分钟前
算法基础(区间DP)
数据结构·c++·算法·动态规划·区间dp
天骄t6 分钟前
信号VS共享内存:进程通信谁更强?
算法
biter down8 分钟前
C++ 交换排序算法:从基础冒泡到高效快排
c++·算法·排序算法