前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >或许单纯形法也没那么简单?

或许单纯形法也没那么简单?

作者头像
用户7506105
发布2021-08-09 15:10:59
4700
发布2021-08-09 15:10:59
举报
文章被收录于专栏:碎片学习录碎片学习录

众所周转,单纯形法是求解线性规划问题最常用、最有效的算法之一,一些做优化的软件比如lingo都有对应很成熟的实现库,该方法的提出是由Spendley、Hext和Himswor等人在1962年提出的,它虽然是一个代数计算过程,但是本质还是基于几何原理,且它不需要计算目标函数的梯度,也就避免了一系列的求导操作,也是优化领域较为奠基的方法之一。

思想

通过几何思想构建单纯形,找到每次迭代中的最小值顶点,通过比如反射、延伸等操作构建新的单纯形尽可能挖掘出更多的点看是否比当前最小值点小进行迭代,直到算法收敛

一些约定和理论

凸集

  • 核心过程

当初始单纯形构造好后,核心思想其实就是不断改变这个单纯形使其能够朝向函数极小点收敛,所以需要不断地迭代,在迭代过程中都需要根据单纯形的每个点计算目标函数值,因为约定求得是最小值问题,所以此时目标函数值大的点将被另外的目标函数更小的点代替,且在迭代过程中是不断找到比当前最小值点目标函数更小的点,如果不满足条件则继续迭代,直到收敛到极小点

过程详解

过程最全包含反射、延伸、外收缩、内收缩、压缩过程

压缩操作

引入压缩因子

\sigma = \frac{1}{2}

,根据公式

v_i = p_s + \sigma(p_i - p_s)

,产生除最大值以外的各维度的n个新值,即单纯形中其他各点与最大值的距离减半,由此产生新的点,构建新的单纯形

以上通过各种操作不断更新单纯形进行迭代,之所以每次迭代时将最小值排除就是想着在剩下的顶点中看是否能找到新的比当前最小值更小的顶点,如果找到(找的核心方法是反射,其他方法是对它的一些逻辑的处理,之所以和重心值反射是希望可以跳出局部极值,且机会均等)的话那之间的最小值就没有讨论意义故需排除,最终单纯形不断向极小值收敛,每次在反射时迭代都会判断是否达到了先验知识已知的最小值或者迭代次数上限从而决定是否继续用反射值代替最小值进行迭代

细节处理

  • 如果多个点对应的目标函数值相等,则新产生的点赋予更高的权重即大小排序的下标索引(就是如果有相同,则相对新的点是离全局最大值更接近的点)
  • 有的参考书上面用的是所有点的重心,私以为收敛效果或许没有每次排除最小值来的快
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2021-06-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 碎片学习录 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 思想
  • 一些约定和理论
  • 过程详解
    • 压缩操作
    • 细节处理
    相关产品与服务
    文件存储
    文件存储(Cloud File Storage,CFS)为您提供安全可靠、可扩展的共享文件存储服务。文件存储可与腾讯云服务器、容器服务、批量计算等服务搭配使用,为多个计算节点提供容量和性能可弹性扩展的高性能共享存储。腾讯云文件存储的管理界面简单、易使用,可实现对现有应用的无缝集成;按实际用量付费,为您节约成本,简化 IT 运维工作。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档