拉格朗日乘数法 和 KTT条件
预备知识
令 \(X\) 表示一个变量组(向量) \((x_1, x_2, \cdots, x_n)\)
考虑一个处处可导的函数 \(f(X)\), 为了方便描述, 这里以二元函数为例
对于微分, 考虑在初始点处固定x移动y产生的变化量, 是和先将x移动dx,然后固定x移动y产生的变化量是相等的
那么有全微分公式 \(df = \frac{\partial f}{\partial x}dx + \frac{\partial f}{\partial y}dy\)
定义 \(\nabla f(x, y)\) 为点 \((x, y)\) 上的梯度方向向量(平面上的这些向量构成一个向量场)
梯度方向向量指向让\(df\)最大的方向. 也即使 \((\frac{\partial f}{\partial x},\frac{\partial f}{\partial y})\cdot(dx, dy)\) 最大的 \((dx, dy)\)
要投影最长, 同向自然最优, 因此偏导组成的向量\((\frac{\partial f}{\partial x},\frac{\partial f}{\partial y})\)就是梯度方向向量
同理考虑 \(df=0\) 的方向(等高线), 投影为0, 这说明等高线的方向与梯度的方向垂直
高维的情况同理
拉格朗日乘数法
考虑这么一个问题:
\(~~\max f(X)\)
\(s.t.~~g_k(X) = 0, \forall k \in [1,m]\)
考虑 \(f(X)\) 在什么时候取得局部极大值:
考虑往某个方向微移, 若满足这样移动不影响任何一个 \(dg\), 那么必须要有 \(df=0\)
否则如果存在 \(df\neq 0\) , 必然 \(<0, >0\) 都会出现 (考虑反向微移), 就不是局部极值点了
考虑把 \(dx_1, dx_2,\cdots dx_n\) 这种东西看作变量
把 \(\nabla g_1, \nabla g_2, \cdots \nabla g_m\) 以及 \(\nabla f\) 都横着放在矩阵里看作若干个方程
之前的条件就等价于: 前 \(m\) 条方程蕴含了最后一条方程
也即 \(\nabla f\) 可以被 \(\nabla g_1\cdots \nabla g_m\) 线性表示
令\(L(X,\Lambda) = f(X) + \sum_{k=1}^m \lambda_k g_k(X)\)
我们只需求解 \(\nabla L(X,\Lambda) = 0\) 即可
这样我们对 \(n\) 个变量分别求偏导即可得到 \(n\) 个方程
加上 \(g\) 的 \(m\) 个方程 (恰好是对\(\lambda\)分别求偏导)
总共 \(n+m\) 个方程.
KKT条件
考虑这么一个问题:
\(~~\max f(X)\)
\(s.t.~~h_k(X)\ge 0, \forall k \in [1, m]\)
令 \(L(X, \Lambda) = f(x) + \sum_{k=1}^m \lambda_k h_k(X), \lambda_k \ge 0\)
因为\(\lambda\ge 0, h\ge 0\), 所以 \(f(X) = \min_{\Lambda\ge 0} L(X,\Lambda)\)
原问题等价于 \(\max_X \min_{\Lambda\ge 0} L(X,\Lambda)\)
考虑对偶问题 \(\min_{\Lambda\ge 0}\max_X L(X, \Lambda)\)
显然\(L(X, \Lambda)\ge f(X)\), 则有 \(\max_X L(X, \Lambda) \ge \max f(X)\)
对偶问题对所有的这些值取 \(\min\), 仍然是 \(\ge \max f(X)\)
设原问题极值点在 \(X^{*}\), 对偶问题极值点在 \(\Lambda^{*}\)
则有 \(\max_X L(X, \Lambda^{*}) \ge f(X^{*}) + \sum_{k=1}^m \lambda^{*}_k h_k(X) \ge f(X^{*})\)
假设强对偶性满足, 上面的不等号都要变成等号
限制了 : \(\lambda^{*}_k h_k(X) = 0\) 以及 \(\nabla L(X^{*}, \Lambda^{*})=0\)
结论好记: KTT条件只比拉格朗日乘数多了两个限制, \(\lambda_k h_k(X) = 0, \lambda_k\ge 0\)
在哪些问题上满足强对偶性, 详见wiki
自己姿势水平不够, 这个坑可能不那么快能填上了
另外, 考虑如果在原问题加上等式限制, 就再补上拉格朗日乘数即可, 不难发现, 不影响这里的证明
拉格朗日乘数法 和 KTT条件的更多相关文章
- [Math & Algorithm] 拉格朗日乘数法
拉格朗日乘数法(Lagrange Multiplier Method)之前听数学老师授课的时候就是一知半解,现在越发感觉拉格朗日乘数法应用的广泛性,所以特意抽时间学习了麻省理工学院的在线数学课程.新学 ...
- 《University Calculus》-chaper12-多元函数-拉格朗日乘数法
求解条件极值的方法:拉格朗日乘数法 基于对多元函数极值方法的了解,再具体的问题中我们发现这样一个问题,在求解f(x,y,z)的极值的时候,我们需要极值点落在g(x,y,z)上这种对极值点有约束条件,通 ...
- CodeForces - 813C The Tag Game(拉格朗日乘数法,限制条件求最值)
[传送门]http://codeforces.com/problemset/problem/813/C [题意]给定整数a,b,c,s,求使得 xa yb zc值最大的实数 x,y,z , 其中x ...
- bzoj2876 [NOI2012]骑行川藏(拉格朗日乘数法)
题目描述 蛋蛋非常热衷于挑战自我,今年暑假他准备沿川藏线骑着自行车从成都前往拉萨.川藏线的沿途有着非常美丽的风景,但在这一路上也有着很多的艰难险阻,路况变化多端,而蛋蛋的体力十分有限,因此在每天的骑行 ...
- ML(附录4)——拉格朗日乘数法
基本的拉格朗日乘子法(又称为拉格朗日乘数法),就是求函数 f(x1,x2,...) 在 g(x1,x2,...)=C 的约束条件下的极值的方法.其主要思想是引入一个新的参数 λ (即拉格朗日乘子),将 ...
- CodeChef TWOROADS(计算几何+拉格朗日乘数法)
题面 传送门 简要题意:给出\(n\)个点,请求出两条直线,并最小化每个点到离它最近的那条直线的距离的平方和,\(n\leq 100\) orz Shinbokuow 前置芝士 给出\(n\)个点,请 ...
- BZOJ3775: 点和直线(计算几何+拉格朗日乘数法)
题面 传送门 题解 劲啊-- 没有和\(Claris\)一样推,用了类似于\(Shinbokuow\)推已知点求最短直线的方法,结果\(WA\)了好几个小时,拿\(Claris\)代码拍了几个小时都没 ...
- BZOJ2876 [Noi2012]骑行川藏 【拉格朗日乘数法】
题目链接 BZOJ 题解 拉格朗日乘数法 拉格朗日乘数法用以求多元函数在约束下的极值 我们设多元函数\(f(x_1,x_2,x_3,\dots,x_n)\) 以及限制\(g(x_1,x_2,x_3,\ ...
- Wannafly模拟赛2 B river(拉格朗日乘数法)
题目 https://www.nowcoder.com/acm/contest/4/B题意 有n条南北流向的河并列排着,水流速度是v,现在你需要从西岸游到东岸,总共T个时间,你的游泳速度是u,问东岸的 ...
随机推荐
- PIC32MZ 通过U盘在线升级 -- USB Host bootloader
了解bootloader的实现,请加QQ: 1273623966(验证填bootloader); 欢迎咨询或定制bootloader; 我的博客主页 www.cnblogs.com/geekygeek ...
- linux基础重要命令小节
此为L005&&L006课程内容的一个总结. 命令: 基本形式 命令 [参数] [路径或文件] 例:ls -ld /data pwd 目前所在目录 [root@moban /]# pw ...
- lessJs
lessJs下载地址 ======== 简介 lessJs主要提供页面切换,页面管理的一个框架:less-ui.css 和 less-ui.js 是独立于less.js的,他们提供的是一组ui,包括消 ...
- 「Haskell 学习」二 类型和函数(上)
随着学习的深入,笔记会补充和修订.当然,这个补充修订也许会鸽,但我一定会坚持写完. 这个笔记假定你至少学过C/C++及Python,或与这两种语言类型相同的语言. 类型系统概述 “Haskell’s ...
- centos7用yum搭建LAMP环境
用yum快速搭建LAMP平台 实验环境: [root@nmserver- html]# cat /etc/redhat-release CentOS release (AltArch) [root@n ...
- 菜鸟级appium 必看
之所以写这个,因为太多新人,appium环境半天都搭建不好,版本问题,兼容问题等等. 自己的解决方案:1 官网下载nodejs,建议安装长期支持版 2 进入appium官网,点击下载,跳转到githu ...
- LuffyCity-CMDB实战
第1章 章节一 课时01-ITIL介绍 课时02-CMDB介绍 课时03-CMDB需求讨论 课时04-CMDB需求讨论2 课时05-CMDB表结构设计 课时06-CMDB表结构设计2 课时07-CMD ...
- centos7使用Gogs搭建Git服务器
一.初次接触Gogs,记录一下搭建过程 二.平台环境 Linux: CentOS7.5.1804 MySQL: 5.6.35 安装步骤: linux服务器新建git用户: 下载.解压gogs安装包: ...
- Python 3.6 爬取BD电影网
2018-07-10 #coding:utf-8 #coding:utf-8 from lxml import etree import requests import pandas import t ...
- Drools 7.4.1.Final参考手册(六) 用户手册
用户手册 基础 无状态的知识Session Drools规则引擎拥有大量的用例和功能,我们要如何开始?你无须担心,这些复杂性是分层的,你可以用简单的用例来逐步入门. 无状态Session,无须使用推理 ...