【问题标题】:Discrete optimization in pythonpython中的离散优化
【发布时间】:2013-05-26 12:22:45
【问题描述】:

我正在尝试使用scipy.optimize 包来优化离散优化问题(全局优化)。根据文档,scipy.optimize.anneal 中实现的模拟退火应该是一个不错的选择。但我不确定如何强制优化器只搜索搜索空间的整数值。有人可以帮忙吗?

一个说明性的例子:

f(x1,x2) = (1-0.4*x1)^2 + 100*(0.6*x2 -0.4*x1^2)^2

where, $x1, x2 \in I$

【问题讨论】:

    标签: python optimization scipy simulated-annealing


    【解决方案1】:

    我检查了 scipy.optimize.anneal,但看不到使用离散值的方法。自己实现它的方法是创建一个自定义的“移动”函数,但是您必须指定时间表(通过字符串)的方式会阻止您这样做。

    我认为这是一个很大的错误,如果你可以只传递一个自定义调度类作为参数,你可以自定义它以使用离散变量和更多的东西。

    我找到的解决方案是改用这个其他实现: https://github.com/perrygeo/python-simulated-annealing

    因为您必须提供修改状态的函数,所以您可以控制它可以具有哪些值,或者它们是离散的还是连续的。

    【讨论】:

    • 非常感谢.. 超级:我一直在寻找这样的东西。与此同时,我自己实现了 SA 以获得您所说的控制权
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2016-01-12
    • 2022-08-06
    • 1970-01-01
    • 2017-12-26
    • 2022-08-14
    • 2012-07-23
    • 2013-01-29
    相关资源
    最近更新 更多