【AI原理解析】—支持向量机原理

目录

[1. 支持向量机(SVM)概述](#1. 支持向量机(SVM)概述)

[2. 超平面与支持向量](#2. 超平面与支持向量)

[3. 间隔最大化](#3. 间隔最大化)

[4. 优化问题](#4. 优化问题)

[5. 核函数](#5. 核函数)

[6. 总结](#6. 总结)


1. 支持向量机(SVM)概述

  • 定义:支持向量机是一种监督学习模型,主要用于数据分类问题。其基本思想是通过一个超平面来分割数据点,使得不同类别的数据点位于超平面的两侧。
  • 分类:支持向量机主要分为三类:线性可分支持向量机、线性支持向量机和非线性支持向量机。

2. 超平面与支持向量

  • 超平面:在n维空间中,超平面是一个n-1维的子空间。在二维空间中,它是一个直线;在三维空间中,它是一个平面。超平面可以表示为 w^T * x + b = 0,其中w是法向量,b是截距,x是样本点。
  • 支持向量:距离超平面最近的样本点称为支持向量。这些点对确定超平面的位置起着决定性作用。

3. 间隔最大化

  • 函数间隔:对于给定的训练集和超平面,样本点 (x_i, y_i) 到超平面的函数间隔为 r_i = y_i(wT * x_i + b)。但是,当w和b成比例变化时,函数间隔也会成比例变化。
  • 几何间隔:为了消除这种影响,引入了几何间隔。样本点 (x_i, y_i) 到超平面的几何间隔为 γ_i = y_i((w / ||w||) * x_i + b / ||w||)。其中 ||w|| 是w的范数。
  • 目标:SVM的目标是找到一个超平面,使得训练集上所有样本点的几何间隔最大。这可以转化为一个优化问题,即最大化几何间隔。

4. 优化问题

  • 优化目标:最小化 ||w||2 / 2,同时满足约束条件 y_i(wT * x_i + b) ≥ 1(对于所有样本点)。这是一个凸二次规划问题。
  • 求解:通过拉格朗日乘子法将原始问题转化为对偶问题,并利用SMO算法求解。最终得到的是w和b的最优解,从而确定最优超平面。

5. 核函数

  • 非线性分类:对于非线性可分的数据,SVM通过引入核函数将数据映射到高维空间,使得数据在高维空间中线性可分。
  • 常用核函数:包括线性核、多项式核、高斯核等。选择合适的核函数对于SVM的性能至关重要。

6. 总结

  • 支持向量机通过找到一个最优超平面来实现对数据的分类。该超平面由支持向量确定,并且使得训练集上所有样本点的几何间隔最大。
  • 对于非线性可分的数据,SVM通过引入核函数将数据映射到高维空间,实现非线性分类。
  • SVM具有泛化能力强、对高维数据有效等优点,在许多领域都有广泛的应用。
相关推荐
冬奇Lab18 小时前
OpenClaw 源码精读(2):Channel & Routing——一条消息如何找到它的 Agent?
人工智能·开源·源码阅读
冬奇Lab18 小时前
一天一个开源项目(第38篇):Claude Code Telegram - 用 Telegram 远程用 Claude Code,随时随地聊项目
人工智能·开源·资讯
格砸20 小时前
从入门到辞职|从ChatGPT到OpenClaw,跟上智能时代的进化
前端·人工智能·后端
可观测性用观测云20 小时前
可观测性 4.0:教系统如何思考
人工智能
sunny86520 小时前
Claude Code 跨会话上下文恢复:从 8 次纠正到 0 次的工程实践
人工智能·开源·github
小笼包包仔21 小时前
OpenClaw 多Agent软件开发最佳实践指南
人工智能
smallyoung21 小时前
AgenticRAG:智能体驱动的检索增强生成
人工智能
_skyming_21 小时前
OpenCode 如何做到结果不做自动质量评估,为什么结果还不错?
人工智能
HXhlx21 小时前
CART决策树基本原理
算法·机器学习
南山安21 小时前
手写 Cursor 核心原理:从 Node.js 进程到智能 Agent
人工智能·agent·设计