SMO Algorithm流程

2024-03-23 20:50
文章标签 流程 algorithm smo

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

SMO Algorithm流程


SMO Algorithm

Input: T T = (x1,y1),(x2,y2),...,(xN,yN) ,精度 ϵ ϵ
Output:近似解 y^ y ^
1. 取初值 α(0) α ( 0 ) =0, k=0
2.1: 选取最优变量:对于第一个变量 α(k)1 α 1 ( k ) ,遍历所有 0<αi<C 0 < α i < C 的值,也就是 yig(xi)=1 y i ∗ g ( x i ) = 1 的值,也就是支持向量,检验是否满足KKT条件,也就是,是否满足一下三个条件:
Ni=1αiyi=0 ∑ i = 1 N α i y i = 0
oαiC o ≤ α i ≤ C , i=1,2,...,N i = 1 , 2 , . . . , N
yig(xi)1,for y i ∗ g ( x i ) ≥ 1 , f o r { { xi| x i | αi=0 α i = 0 } }
yig(xi)=1,for y i ∗ g ( x i ) = 1 , f o r { { xi| x i | 0<αi<C 0 < α i < C } }
yig(xi)1,for y i ∗ g ( x i ) ≤ 1 , f o r { { xi| x i | αi=C α i = C } }
其中 g(xi)=Nj=1αjyjK(xj,xi)+b g ( x i ) = ∑ j = 1 N α j y j K ( x j , x i ) + b
若不满足,则选取该点,若支持向量全部满足,则遍历其他非支持向量,直到找到不满足该KKT条件为之
对于第一个变量 α(k)2 α 2 ( k ) ,则采用以下策略:
若对于第一个变量 α(k)1 α 1 ( k ) 对应的 E1>0 E 1 > 0 ,则选取使得 E2 E 2 最小的点 ,
若对于第一个变量 α(k)1 α 1 ( k ) 对应的 E1<0 E 1 < 0 ,则选取使得 E2 E 2 最大的点 ,
其目的,使得 αnew2 α 2 n e w 依赖于 E1E2 E 1 − E 2 , 则去使得 E1E2 E 1 − E 2 最大(加快计算)的点
这里写图片描述
其中 Ei=g(xi)yi={Nj=1αjyjK(xj,xi)+b}yi E i = g ( x i ) − y i = { ∑ j = 1 N α j y j K ( x j , x i ) + b } − y i
2.2 二次规划求解: 对于选取的第一个变量
其中,原始为剪辑的值为,
这里写图片描述
这里写图片描述
剪辑之后得到第一个变量的解:
这里写图片描述
于此同时,由 αold1y1+αold2y2=ε=αnew1y1+αnew,clipped2y2 α 1 o l d ∗ y 1 + α 2 o l d ∗ y 2 = ε = α 1 n e w ∗ y 1 + α 2 n e w , c l i p p e d ∗ y 2
可得到第二个变量的解:
αnew1=αold1+y1y2(αold2αnew,clipped2) α 1 n e w = α 1 o l d + y 1 ∗ y 2 ( α 2 o l d − α 2 n e w , c l i p p e d )
基于以上的算法,可以得到最优解 α(k+1)1 α 1 ( k + 1 ) α(k+1)2 α 2 ( k + 1 )
3. 若在精度范围内所有点都满足KKT条件,则跳转(3),否则转(2)
4. 取 α^=α(k+1) α ^ = α ( k + 1 )

这篇关于SMO Algorithm流程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

Python实现NLP的完整流程介绍

《Python实现NLP的完整流程介绍》这篇文章主要为大家详细介绍了Python实现NLP的完整流程,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 编程安装和导入必要的库2. 文本数据准备3. 文本预处理3.1 小写化3.2 分词(Tokenizatio

SpringBoot使用minio进行文件管理的流程步骤

《SpringBoot使用minio进行文件管理的流程步骤》MinIO是一个高性能的对象存储系统,兼容AmazonS3API,该软件设计用于处理非结构化数据,如图片、视频、日志文件以及备份数据等,本文... 目录一、拉取minio镜像二、创建配置文件和上传文件的目录三、启动容器四、浏览器登录 minio五、

Nginx、Tomcat等项目部署问题以及解决流程

《Nginx、Tomcat等项目部署问题以及解决流程》本文总结了项目部署中常见的four类问题及其解决方法:Nginx未按预期显示结果、端口未开启、日志分析的重要性以及开发环境与生产环境运行结果不一致... 目录前言1. Nginx部署后未按预期显示结果1.1 查看Nginx的启动情况1.2 解决启动失败的

Security OAuth2 单点登录流程

单点登录(英语:Single sign-on,缩写为 SSO),又译为单一签入,一种对于许多相互关连,但是又是各自独立的软件系统,提供访问控制的属性。当拥有这项属性时,当用户登录时,就可以获取所有系统的访问权限,不用对每个单一系统都逐一登录。这项功能通常是以轻型目录访问协议(LDAP)来实现,在服务器上会将用户信息存储到LDAP数据库中。相同的,单一注销(single sign-off)就是指

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

kubelet组件的启动流程源码分析

概述 摘要: 本文将总结kubelet的作用以及原理,在有一定基础认识的前提下,通过阅读kubelet源码,对kubelet组件的启动流程进行分析。 正文 kubelet的作用 这里对kubelet的作用做一个简单总结。 节点管理 节点的注册 节点状态更新 容器管理(pod生命周期管理) 监听apiserver的容器事件 容器的创建、删除(CRI) 容器的网络的创建与删除

火语言RPA流程组件介绍--浏览网页

🚩【组件功能】:浏览器打开指定网址或本地html文件 配置预览 配置说明 网址URL 支持T或# 默认FLOW输入项 输入需要打开的网址URL 超时时间 支持T或# 打开网页超时时间 执行后后等待时间(ms) 支持T或# 当前组件执行完成后继续等待的时间 UserAgent 支持T或# User Agent中文名为用户代理,简称 UA,它是一个特殊字符串头,使得服务器

UMI复现代码运行逻辑全流程(一)——eval_real.py(尚在更新)

一、文件夹功能解析 全文件夹如下 其中,核心文件作用为: diffusion_policy:扩散策略核心文件夹,包含了众多模型及基础库 example:标定及配置文件 scripts/scripts_real:测试脚本文件,区别在于前者倾向于单体运行,后者为整体运行 scripts_slam_pipeline:orb_slam3运行全部文件 umi:核心交互文件夹,作用在于构建真

C++/《C/C++程序编译流程》

程序的基本流程如图:   1.预处理        预处理相当于根据预处理指令组装新的C/C++程序。经过预处理,会产生一个没有宏定义,没有条件编译指令,没有特殊符号的输出文件,这个文件的含义同原本的文件无异,只是内容上有所不同。 读取C/C++源程序,对其中的伪指令(以#开头的指令)进行处理将所有的“#define”删除,并且展开所有的宏定义处理所有的条件编译指令,如:“#if”、“