IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 在python中使用SVM -> 正文阅读

[人工智能]在python中使用SVM

三、在python中使用SVM

3.1 scikit-learn库

??Scikit-learn(sklearn)是一个开源项目,可以免费使用和分发,任何人都可以轻松获取其源代码来查看其背后的原理。Scikit-learn项目正在不断地开发和改进中,它的用户社区非常活跃。它包含许多目前最先进的机器学习算法,每个算法都有详细的文档 (http:// scikit-learn.org/stable/documentation
??scikit-learn是一个非常流行的工具,也是最有名的 Python机器学习库。它广泛应用于工业界和学术界,网上有大量的教程和代码片段。

3.2 SVM在scikit-learn库中的使用

3.2.1 svm.SVC

# Create SVM classification object
sklearn.svm.SVC(C=1.0, kernel='rbf', degree=3, gamma='auto', coef0=0.0, shrinking=True, probability=False, tol=0.001, cache_size=200, class_weight=None, verbose=False, max_iter=-1, decision_function_shape=None,random_state=None)

参数:

C

??C-SVC的惩罚参数C,默认值是1.0。即下图中C权重在这里插入图片描述

??C越大,相当于惩罚松弛变量,希望松弛变量接近0,即对误分类的惩罚增大,趋向于对训练集全分对的情况,这样对训练集测试时准确率很高,但泛化能力弱。C值小,对误分类的惩罚减小,允许容错,将他们当成噪声点,泛化能力较强。

kernel

??核函数,默认是rbf,可以是‘linear’, ‘poly’, ‘rbf’, ‘sigmoid’, ‘precomputed’
– 线性:u’v
– 多项式:(gamma*u’v + coef0)^degree
– RBF函数:exp(-gamma|u-v|^2)
– sigmoid:tanh(gammau’*v + coef0)

degree

??多项式poly函数的维度,默认是3,选择其他核函数时会被忽略。

gamma

??‘rbf’,‘poly’ 和‘sigmoid’的核函数参数。默认是’auto’,则会选择1/n_features

coef0

??核函数的常数项。对于‘poly’和 ‘sigmoid’有用。

probability

??是否采用概率估计。默认为False,布尔类型可选。
??决定是否启用概率估计。需要在训练fit()模型时加上这个参数,之后才能用相关的方法:predict_proba和predict_log_proba

shrinking

??是否采用shrinking heuristic方法(启发式收缩),默认为true

tol

??停止训练的误差值大小,默认为1e-3

cache_size

??核函数cache缓存大小,默认为200

class_weigh

??t类别的权重,字典形式传递。设置第几类的参数C为weight*C(C-SVC中的C)

verbose

??允许冗余输出

max_iter

??最大迭代次数。-1为无限制。

decision_function_shape

??‘ovo’, ‘ovr’ or None, default=None3

random_state

??数据洗牌时的种子值,int值

??主要调节的参数有:C、kernel、degree、gamma、coef0

方法:
??fit(X, y):训练模型。
??predict(X):用模型进行预测,返回预测值。
??score(X, y[, sample_weight]):返回在(X, y)上预测的准确率(accuracy)。
??predict_log_proba(X): 返回一个数组,数组的元素依次是X预测为各个类别的概率的对数值。
??predict_proba(X): 返回一个数组,数组的元素依次是X预测为各个类别的概率值。

3.2.2 datasets

??datasets有很多有用的、可以用来训练算法模型的数据库。主要有两种:
1.封装好的经典数据。在代码中以“load”开头。
2.自己设计参数,然后生成的数据。在代码中以“make”开头。
(一) 波士顿房价
??统计了波士顿506处房屋的13种不同特征( 包含城镇犯罪率、一氧化氮浓度、住宅平均房间数、到中心区域的加权距离以及自住房平均房价等 )以及房屋的价格,适用于回归任务。

boston = datasets.load_boston()  # 导入波士顿房价数据

(二) 鸢尾花
??这个数据集包含了150个鸢尾花样本,对应3种鸢尾花,各50个样本,以及它们各自对应的4种关于花外形的数据 ,适用于分类任务。

iris = datasets.load_iris()  # 导入鸢尾花数据

(三) 糖尿病
??主要包括442个实例,每个实例10个属性值,分别是:Age(年龄)、性别(Sex)、Body mass index(体质指数)、Average Blood Pressure(平均血压)、S1~S6一年后疾病级数指标,Target为一年后患疾病的定量指标, 适用于回归任务。

diabetes = datasets.load_diabetes()  # 导入糖尿病数据

(四) 手写数字
??共有1797个样本,每个样本有64个元素,对应到一个8x8像素点组成的矩阵,每一个值是其灰度值, target值是0-9,适用于分类任务。

digits = datasets.load_digits()  # 导入手写数字数据

3.3 不同应用实例

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-03-13 21:47:25  更:2022-03-13 21:51:04 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 15:28:05-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码