zoukankan      html  css  js  c++  java
  • 优化问题及KKT条件

    整理自其他优秀博文及自己理解。

    目录

    • 无约束优化
    • 等式约束
    • 不等式约束(KKT条件)

    1、无约束优化

    无约束优化问题即高数下册中的 “多元函数的极值"  部分。

    驻点:所有偏导数皆为0的点;

    极值点:在邻域内最大或最小的点;

    最值点:在定义域内最大或最小的点;

    关系:

    驻点不一定是极值点,极值点一定是驻点;

    极值点不一定是最值点,最值点一定是极值点;

    求解最值:

    求出所有的极值点,将所有的极值点带入函数中,最大或最小的那个就是最值点。

    2、等式约束

    等式约束问题即高数下册中的 “条件极值  拉格朗日乘数法” 部分。

    对于$z=f(x,y)$在$varphi(x,y)=0$的条件下的最值问题:

    构造拉格朗日函数:$L(x,y,lambda)=f(x,y)+lambdavarphi(x,y)$;

    对拉格朗日函数求解,得到的即为在条件$varphi(x,y)=0$下,$z=f(x,y)$所有可能的极值点。再利用问题本身的其他约束条件(如果有的话)筛选极值点,比较之后求得最值点。

    直观的解释:目标函数和约束函数在最优解处的法线共线,即$igtriangledown f(x,y)=lambdaigtriangledown g(x,y)$

    具体证明请查阅高数课本。

    3、不等式约束

     当约束是不等式的时候,可以在不等式约束中加入松弛变量,使其变为等式约束问题,再进行一些分析。

    最后$x^*$是极值点的必要条件(KKT条件)为: 

    $f(x)=left{
    egin{aligned}
    igtriangledown f(x) & = & lambda igtriangledown c_i(x) \
    lambda_ic_i(x) & = & 0\
    lambda_i & geq & 0
    end{aligned}
    ight.$

    不等式约束可以直接利用KKT条件求出可能的极值点。

    具体推导和证明可参见:https://zhuanlan.zhihu.com/p/26514613

    他们之间的关系:(此图来自知乎上链接,入侵可删)

    至此,梳理完毕。

  • 相关阅读:
    Python/WSGI 应用快速入门--转
    汇编题目:数字转字符,并在窗口上显示出来
    汇编题目:在窗口上显示Welcome to masm!
    VBA中的函数Timer用法
    用VBA计算两个日期之间的工作日(去掉周末两天)
    VBA记录当前系统时间并精确到毫秒
    上海房产税免征--积分或居住证
    学习汇编语言
    “Hello World”—— 第一个汇编程序
    汇编程序设计上机步骤
  • 原文地址:https://www.cnblogs.com/echo-coding/p/8638385.html
Copyright © 2011-2022 走看看