AI写算法:支持向量机(SVM)

在Python中,我们可以使用scikit-learn库来实现支持向量机(SVM)。以下是一个简单的示例,演示如何使用scikit-learnSVC类来训练一个SVM分类器,并使用它对一些数据进行预测。

复制代码

python复制代码

|---|----------------------------------------------------------------------------------------------|
| | # 导入必要的库 |
| | from sklearn import datasets |
| | from sklearn.model_selection import train_test_split |
| | from sklearn.preprocessing import StandardScaler |
| | from sklearn.svm import SVC |
| | from sklearn.metrics import classification_report |
| | |
| | # 加载鸢尾花数据集(iris dataset) |
| | iris = datasets.load_iris() |
| | X = iris.data |
| | y = iris.target |
| | |
| | # 将数据集拆分为训练集和测试集 |
| | X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42) |
| | |
| | # 对数据进行标准化处理,因为SVM对数据的尺度很敏感 |
| | scaler = StandardScaler() |
| | X_train = scaler.fit_transform(X_train) |
| | X_test = scaler.transform(X_test) |
| | |
| | # 创建一个SVC对象(支持向量机分类器) |
| | # 这里我们使用了线性核函数('linear'),但你也可以尝试使用其他核函数,如'rbf' |
| | svm_classifier = SVC(kernel='linear', C=1.0, random_state=42) |
| | |
| | # 使用训练数据训练SVM分类器 |
| | svm_classifier.fit(X_train, y_train) |
| | |
| | # 使用测试数据对模型进行预测 |
| | y_pred = svm_classifier.predict(X_test) |
| | |
| | # 打印分类报告,以评估模型性能 |
| | print(classification_report(y_test, y_pred)) |

这段代码首先导入了必要的库和模块,然后加载了鸢尾花数据集。接下来,它将数据集拆分为训练集和测试集,并对数据进行标准化处理。然后,它创建了一个SVC对象(支持向量机分类器),并使用训练数据训练了这个分类器。最后,它使用测试数据对模型进行了预测,并打印了分类报告来评估模型的性能。

注意:SVC类中的kernel参数决定了使用的核函数类型,这会影响模型的复杂性和性能。在这个例子中,我们使用了线性核函数('linear'),但你也可以尝试使用其他核函数,如径向基函数('rbf')或多项式函数('poly')。C参数是一个正则化参数,用于控制模型的复杂度。较小的C值指定了更强的正则化。

相关推荐
笨笨饿4 分钟前
80_聊聊SPI以及它们的变体
linux·c语言·网络·stm32·单片机·算法·个人开发
Ricardo-Yang5 分钟前
使用GEE以及LandSat8植被指数NDVI计算
python·深度学习·神经网络·算法·视觉检测
Derrick__18 分钟前
LangChain基础实战手记:如何给大模型装上“大脑(记忆)”和“双手(工具)”?
人工智能·python·langchain·个人开发
sheeta199810 分钟前
LeetCode 每日一题笔记 日期:2026.05.12 题目:1665. 完成所有任务的最少初始能量
笔记·算法·leetcode
khalil102012 分钟前
代码随想录算法训练营Day-49 图论01 | 图论理论基础、深搜理论基础、98. 所有可达路径、广搜理论基础
c++·算法·leetcode·深度优先·图论
tangjunjun-owen12 分钟前
[特殊字符] Python异步调用本地Ollama大模型实战:从Demo到高并发避坑指南
开发语言·chrome·python
RSTJ_162514 分钟前
PYTHON+AI LLM DAY FOURTY-THREE
开发语言·人工智能·python
Volunteer Technology15 分钟前
SpringAI(二)Models 模型介绍
开发语言·人工智能·python
霸道流氓气质19 分钟前
Spring AI 实战:Ollama 本地模型工具调用与 Prompt 模板全解析
人工智能·spring·prompt
Chase_______21 分钟前
【算法】删除子数组的最大得分 & 最多 K 个重复元素的最长子数组——不定长滑动窗口与哈希频率约束
算法·哈希算法