将一个.csv文件有多组多维数据,利用SVM进行分类的机器学习代码,最后可视化展现分类效果
时间: 2024-02-11 22:09:36 浏览: 91
好的,以下是一个简单的Python代码示例,使用SVM对多组多维数据进行分类,并使用matplotlib库可视化分类效果:
``` python
import pandas as pd
import numpy as np
from sklearn import svm
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D
# 加载数据
data = pd.read_csv('data.csv')
x = data.iloc[:, 0:-1].values
y = data.iloc[:, -1].values
# 训练SVM模型
clf = svm.SVC(kernel='linear', C=1)
clf.fit(x, y)
# 预测分类结果
y_pred = clf.predict(x)
# 可视化分类结果
fig = plt.figure()
if x.shape[1] == 2:
# 二维平面展示
plt.scatter(x[:, 0], x[:, 1], c=y_pred)
plt.xlabel('Feature 1')
plt.ylabel('Feature 2')
else:
# 三维空间展示
ax = fig.add_subplot(111, projection='3d')
ax.scatter(x[:, 0], x[:, 1], x[:, 2], c=y_pred)
ax.set_xlabel('Feature 1')
ax.set_ylabel('Feature 2')
ax.set_zlabel('Feature 3')
plt.show()
```
上述代码中,我们首先使用pandas库加载名为"data.csv"的.csv文件,然后将数据集分为特征数据和标签数据。接下来,我们使用SVM训练模型,并使用训练好的模型对特征数据进行分类预测。最后,我们使用matplotlib库将分类结果可视化展示。如果特征数据为二维数据,则在图表中展示二维平面,否则在三维空间中展示。
阅读全文