3D演示帮你一眼看懂线性规划问题,这篇可视化教程火了

行早 发自 凹非寺
量子位 | 公众号 QbitAI

你印象中的线性规划是什么样的?

先在二维平面上画图再找最优解?

但毕竟是学理论嘛,大家或多或少都会觉得枯燥晦涩。

那么为何不试试更加直观、好玩的学习方式呢?例如这样:

05460a3f062a7c34bee6b6aeab91a740.gif

这是一位国外博主发布的机器学习3D教程,用可视化的方法展示如何在线性规划问题中逐步逼近最优解。

这篇帖子仅在一天之内就在Reddit上收获了接近200点的热度:

ba85b33cad81d39e71150b6ed8512b3d.png

还收到了很多网友的好评:

我喜欢对数学问题高度可视化的描述,太棒了!

097c6c80bc3a8c937576713817b2518b.png

是什么内容这么优质?不妨看看他到底做了什么工作。

线性规划也可以一目了然

关于线性规划问题大家应该都不陌生。

在一组线性方程或不等式的约束下,求某一线性目标函数极值的问题就是线性规划问题。

而它的其中一个解法,就是上文中动图展示的单纯形法,还曾被评为20世纪最伟大的算法之一。

在生产计划,日程管理,交通运输,农业等诸多领域都有广泛的应用。

接下来我们以一个生产计划为例子做讲解:

假如你现在是老板,经营一家货运公司,一共有两种货车。

a734334411e17619ebd281de0d04418e.png

第一种货车跑一趟需要两天,烧4桶油,可以创造1000的利润。

第二种跑一趟要15天,烧8桶油,但是可以创造5000的利润。

那如果你手上有500桶油,应该怎么配比两种货车的货运次数才能在一年内获得最大利润呢?

dc8759b6b6db134303ca3a0e46455cfb.png

这就是一个简单的线性规划问题。

这样的约束条件看起来并没有什么感觉,但是放在空间中就不一样了。

类似于许多平面把完整空间分割出一块多面体:

61b39ad02cc96ca7431869dfafe4d351.gif

分割出的多面体(粉色部分)为可行域或者可行多面体。它包含了所有符合约束条件的点。

线性规划的目的,简单来说就是在可行多面体上找到一个点,来满足预期。比如前面例子中的获得最大利润。

那应该怎么找呢?博主对比了两种办法。

第一种是单纯形法。

由于约束函数和目标函数都是线性的,所以最优解必然存在于可行多面体的顶点。

所以寻找最优解的过程就可以描述为:沿着在可行多面体的棱上沿着目标函数值增加的方向搜索顶点。

听起来不明所以吧?

但是用图形解释就清楚多了:

7980b4bd8479e257a962cfd99578b48a.gif

但是这个方法只能用于求解线性规划的问题。对于非线性规划就无能为力了。

而第二种内点法,在更广泛的凸集优化问题中都可以应用。

它和单纯形法不同的地方在于,内点法是通过增加一个惩罚函数P(x)来不断地调整路径:

d4791e4d782db9818e3d173e265795cb.png

在逐渐靠近可行多面体边界时,惩罚函数会取越来越小的值。

内点法直观来看是这样的:

fe8706379b2fea01b943570676d4fa1b.gif

它不再沿着可行多面体的棱进行迭代,而是直接从内部开始,逐渐逼近最优解。

是不是一目了然了?

相比于纯数学或者算法的推演,可视化的形式明显更容易让人印象深刻。

更多的可视化教程

除了这篇3D教程之外,该博主还在另一个介绍凸优化的KKT条件和内点法的视频中,可视化了内点法是如何通过牛顿迭代逐渐得到最优解的:

bd531e3c399c174534ad724d27bc14bc.gif

视频中x(t)每经过一个黄色的圆框代表进行一次牛顿迭代,左下方的图像代表x(t)在不断地迭代下趋近于最优解。

同样,也比视频上方的一长串公式容易理解多了。

用这样的形式去呈现复杂的内容不禁让网友联想到了另一位可视化视频博主:

好内容!还看到了3blue1brown的影子,动画也很清晰。

33737d0ad97430678737e0a2874c6746.png

在博主的回复中,也能看到他受到另一个数学可视化博主3blue1brown的启发。

后者也同样输出了很多数学可视化的相关视频,如果有兴趣可以多多了解。

参考链接:
[1]https://www.reddit.com/r/MachineLearning/comments/qtx8hn/d_back_to_basics_linear_programming/
[2]https://www.youtube.com/watch?v=C0TTxV0n9OA

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值