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值指定了更强的正则化。

相关推荐
空白到白10 小时前
决策树-面试题
算法·决策树·机器学习
flashlight_hi10 小时前
LeetCode 分类刷题:2563. 统计公平数对的数目
python·算法·leetcode
java1234_小锋10 小时前
Scikit-learn Python机器学习 - 特征预处理 - 归一化 (Normalization):MinMaxScaler
python·机器学习·scikit-learn
码蛊仙尊10 小时前
2025计算机视觉新技术
人工智能·计算机视觉
西猫雷婶10 小时前
scikit-learn/sklearn学习|广义线性回归损失函数的基本表达式
深度学习·神经网络·学习·机器学习·线性回归·scikit-learn·概率论
星空的资源小屋10 小时前
网易UU远程,免费电脑远程控制软件
人工智能·python·pdf·电脑
前端世界10 小时前
HarmonyOS 数据处理性能优化:算法 + 异步 + 分布式实战
算法·性能优化·harmonyos
楼田莉子10 小时前
C++算法专题学习:栈相关的算法
开发语言·c++·算法·leetcode
IMER SIMPLE10 小时前
人工智能-python-深度学习-神经网络-MobileNet V1&V2
人工智能·python·深度学习
njxiejing10 小时前
Pandas数据结构(DataFrame,字典赋值)
数据结构·人工智能·pandas