博客
关于我
从算子角度理解优化方法
阅读量:318 次
发布时间:2019-03-04

本文共 1429 字,大约阅读时间需要 4 分钟。

在求解一个优化问题时,我们可以采用不同的优化方法,而这些方法又可以从不同角度去理解。本文将从算子角度出发,讲述如何理解许多已存在的优化方法。

1. 非线性映射的零点问题

我们考虑一个非线性映射的零点问题,即求解一个映射,使得非线性映射满足某一特定条件。这个问题可以从以下三个角度理解:

1. 无约束凸问题

对于无约束凸问题,其最优解等价于求解梯度等于零。这里的梯度即为该优化问题的解。

2. 约束优化问题的对偶问题

对于约束优化问题,我们可以将其转化为一个无约束的对偶问题。这个对偶问题的梯度即为原问题的解。

3. 约束优化问题的KKT系统

对于约束优化问题,我们可以求解其KKT系统。这里的A即为由KKT条件组成的一个非线性方程组。

2. 稳定点迭代

在求解问题(1)时,我们采用稳定点迭代的方法。稳定点迭代的核心是找到一个算子,该算子满足以下条件:

1. Forward operator

Forward operator是一种简单的算子,可以理解为对某一特定条件的转化。例如,在凸问题中,Forward operator可以转化为梯度算法。

2. Backward operator

Backward operator也称为resolvent operator。其用于求解稳定点迭代。通过推导,我们可以得到稳定点迭代的表达式。

3. 临近点迭代

在问题(5)的对偶问题中,Backward operator的稳定点迭代等价于临近点迭代。这种迭代方法被称为增广拉格朗日方法。

3. 临近梯度算法

结合Forward和Backward算子的应用,我们可以得到临近梯度算法。该算法通过对梯度迭代和临近点迭代的结合,显著提高了优化效率。

4. Douglas-Rachford splitting

Douglas-Rachford splitting是一种基于A和B的Backward operator的拆分方法。其核心思想是通过引入新的变量,并结合前面的Backward operator推导,得到ADMM算法。

5. Peaceman-Rachford splitting

Peaceman-Rachford splitting是一种对称的ADMM方法。通过对前面的方法进行对称处理,得到了一种更高效的优化算法。

总结

这些算子的设计原理都是从优化问题的求解出发,通过特定的算子构建,最终得到了一些常见的优化方法。这些方法在实际应用中表现出色,尤其是在处理复杂优化问题时。


下载资源

在「小白学视觉」公众号后台回复以下内容,可以下载相关教程和项目:

  • OpenCV-Contrib扩展模块中文版教程

    • 涵盖扩展模块安装、SFM算法、立体视觉、目标跟踪、生物视觉、超分辨率处理等二十多章内容。
  • Python视觉实战项目52讲

    • 包括图像分割、口罩检测、车道线检测、车辆计数、添加眼线、车牌识别、字符识别、情绪检测、文本内容提取、面部识别等31个视觉实战项目。
  • OpenCV实战项目20讲

    • 基于OpenCV实现20个实战项目,助力OpenCV学习进阶。

  • 欢迎加入「小白学视觉」公众号读者群,参与视觉技术的深度交流。目前有SLAM、三维视觉、传感器、自动驾驶、计算摄影、检测、分割、识别、医学影像、GAN、算法竞赛等多个微信群,扫描下方二维码加群,备注:“昵称+学校/公司+研究方向”,如:“张三 + 上海交大 + 视觉SLAM”。请勿在群内发送广告,否则会被移出群。

    转载地址:http://tsaq.baihongyu.com/

    你可能感兴趣的文章
    OSGi与Maven、Eclipse PlugIn的区别
    查看>>
    Osgi环境配置
    查看>>
    OSG——选取和拖拽
    查看>>
    OSG中找到特定节点的方法(转)
    查看>>
    OSG学习:C#调用非托管C++方法——C++/CLI
    查看>>
    OSG学习:OSG组成(三)——组成模块(续):OSG核心库中的一些类和方法
    查看>>
    OSG学习:OSG组成(二)——渲染状态和纹理映射
    查看>>
    OSG学习:WIN10系统下OSG+VS2017编译及运行
    查看>>
    OSG学习:人机交互——普通键盘事件:着火的飞机
    查看>>
    OSG学习:几何体的操作(一)——交互事件、简化几何体
    查看>>
    OSG学习:几何体的操作(二)——交互事件、Delaunay三角网绘制
    查看>>
    OSG学习:几何对象的绘制(一)——四边形
    查看>>
    OSG学习:几何对象的绘制(三)——几何元素的存储和几何体的绘制方法
    查看>>
    OSG学习:几何对象的绘制(二)——简易房屋
    查看>>
    OSG学习:几何对象的绘制(四)——几何体的更新回调:旋转的线
    查看>>
    OSG学习:场景图形管理(一)——视图与相机
    查看>>
    OSG学习:场景图形管理(三)——多视图相机渲染
    查看>>
    OSG学习:场景图形管理(二)——单窗口多相机渲染
    查看>>
    OSG学习:场景图形管理(四)——多视图多窗口渲染
    查看>>
    OSG学习:新建C++/CLI工程并读取模型(C++/CLI)——根据OSG官方示例代码初步理解其方法
    查看>>