LIBSVM学习总结

2024-05-09 00:58
文章标签 学习 总结 libsvm

本文主要是介绍LIBSVM学习总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Support Vector Machines,SVM,支持向量机


各种SVM


C C -Support Vector Classi cation

训练向量 — xiRn,i=1,,l
两个类class
指标向量 — yRl y ∈ R l yi{1,1} y i ∈ { 1 , − 1 }
C C -SVC解决如下原始优化问题:

这里写图片描述

ϕ(xi) xi x i 映射到更高维空间, C>0 C > 0 为正则化参数。

由于向量参数 w w 的可能的高维度,通常我们解决如下对偶问题

这里写图片描述

e=[1,,1]T为全为1的向量
Q Q — 一个l×l的半正定矩阵positive semidefinite matrix
QijyiyjK(xi,xj) Q i j ≡ y i y j K ( x i , x j )
K(xi,xj)ϕ(xi)Tϕ(xj) K ( x i , x j ) ≡ ϕ ( x i ) T ϕ ( x j ) — 核函数

问题(2)解决后,使用 primal-dual relationship 原始-对偶关系,最优的 w w 满足:

这里写图片描述

决策函数为

这里写图片描述

为进行预测,存储如下参数:

yiαi,i
b b
标签名称
其他参数 如 — 核参数


ν-Support Vector Classi cation

引入了新的参数 — ν(0,1] ν ∈ ( 0 , 1 ]

这里写图片描述

对偶问题为

这里写图片描述

当且仅当

这里写图片描述

问题才有意义

决策函数为

这里写图片描述

可用 eTα=ν e T α = ν 替代 eTαν e T α ≥ ν

LIBSVM解决一个缩放版的问题,这是因为 αi1/l α i ≤ 1 / l 可能过小。

这里写图片描述

α α 对于对偶问题(5)是最优的
ρ ρ 对于原始问题(4)是最优的
则, α/ρ α / ρ 是带有 C=1/(ρl) C = 1 / ( ρ l ) C C -SVM的一个最优解,因此,在LIBSVM模型中的输出为(α/ρ,b/ρ)


Distribution Estimation (One-class SVM)

单类别SVM

无类别信息

这里写图片描述

对偶问题为

这里写图片描述

决策函数为

这里写图片描述

缩放版

这里写图片描述


ϵ ϵ -Support Vector Regression ( ϵ ϵ -SVR)

训练点集 — {(x1,z1),,(xl,zl)} { ( x 1 , z 1 ) , … , ( x l , z l ) }
xiRn x i ∈ R n — 特征向量
ziR1 z i ∈ R 1 — 目标输出
给定参数 — C>0 C > 0 ϵ>0 ϵ > 0 ,支持向量回归的标准形式为:

这里写图片描述

对偶问题为

这里写图片描述

在解决问题(9)后,估计函数为

这里写图片描述

输出为 — αα α ∗ − α


ν ν -Support Vector Regression ( ν ν -SVR)

这里写图片描述

对偶问题为

这里写图片描述

估计函数为

这里写图片描述

eT(α+α)Cν e T ( α + α ∗ ) ≤ C ν 可替换为等式

C¯=C/l C ¯ = C / l

这里写图片描述

如下二者有相同解
1. ϵ ϵ -SVR — 参数 (C¯,ϵ) ( C ¯ , ϵ )
2. ν ν -SVR — 参数 (lC¯,ν) ( l C ¯ , ν )


性能度量


分类

这里写图片描述


回归

这里写图片描述


整体组织

这里写图片描述

这篇关于LIBSVM学习总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/971935

相关文章

Python中实现进度条的多种方法总结

《Python中实现进度条的多种方法总结》在Python编程中,进度条是一个非常有用的功能,它能让用户直观地了解任务的进度,提升用户体验,本文将介绍几种在Python中实现进度条的常用方法,并通过代码... 目录一、简单的打印方式二、使用tqdm库三、使用alive-progress库四、使用progres

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

Java向kettle8.0传递参数的方式总结

《Java向kettle8.0传递参数的方式总结》介绍了如何在Kettle中传递参数到转换和作业中,包括设置全局properties、使用TransMeta和JobMeta的parameterValu... 目录1.传递参数到转换中2.传递参数到作业中总结1.传递参数到转换中1.1. 通过设置Trans的

C# Task Cancellation使用总结

《C#TaskCancellation使用总结》本文主要介绍了在使用CancellationTokenSource取消任务时的行为,以及如何使用Task的ContinueWith方法来处理任务的延... 目录C# Task Cancellation总结1、调用cancellationTokenSource.

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss