具有二进制条目的函数的全局最小值

问题描述

我需要找到函数F(x_1,x_2,...)的全局最小值,该函数的条目只能采用两个可能的值0和1。我试图使用 scipy.optimize.shgo 这样

optimize.shgo(F,bounds,args = args,constraints = cons)

但是我不知道如何通过 shgo 中的两个可能值限制。

谢谢!

解决方法

您不能。简单同源全局优化是为连续函数优化而设计的,不适合您的离散情况。通常,科学优化不支持离散变量,甚至不支持退火。从理论上讲,使用非凸约束可以限制离散值,但在实践中效果不佳。

根据您的函数类型,您可能希望通过https://pypi.org/project/Pyomo/接口来寻找bonmin或cbc求解器或对https://pypi.org/project/simanneal/进行退火,或者应该有大量的遗传优化实现。

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...