- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在使用 scipy.optimize.minimize
来优化一个答案只能是整数的现实问题。我当前的代码如下所示:
from scipy.optimize import minimize
def f(x):
return (481.79/(5+x[0]))+(412.04/(4+x[1]))+(365.54/(3+x[2]))+(375.88/(3+x[3]))+(379.75/(3+x[4]))+(632.92/(5+x[5]))+(127.89/(1+x[6]))+(835.71/(6+x[7]))+(200.21/(1+x[8]))
def con(x):
return sum(x)-7
cons = {'type':'eq', 'fun': con}
print scipy.optimize.minimize(f, [1,1,1,1,1,1,1,0,0], constraints=cons, bounds=([0,7],[0,7],[0,7],[0,7],[0,7],[0,7],[0,7],[0,7],[0,7]))
这产生:
x: array([ 2.91950510e-16, 2.44504019e-01, 9.97850733e-01,
1.05398840e+00, 1.07481251e+00, 2.60570253e-01,
1.36470363e+00, 4.48527831e-02, 1.95871767e+00]
但我希望它使用整数值进行优化(将所有 x
舍入到最接近的整数并不总是给出最小值)。
有没有办法只对整数值使用 scipy.optimize.minimize
?
(我想我可以创建一个数组,其中包含 x
的所有可能排列,并为每个组合计算 f(x),但这似乎不是一个非常优雅或快速的解决方案。)
最佳答案
PuLP 溶液
经过一些研究,我认为您的目标函数不是线性的。我在 Python 中重新创建了问题 pulp库,但 PuLP 不喜欢我们除以 float 和“LpAffineExpression”。 This answer表明线性规划“不理解除法”,但该评论是在添加约束的背景下进行的,而不是目标函数。该评论将我指向“Mixed Integer Linear Fractional Programming (MILFP)”和Wikipedia .
如果它确实有效,您可以在 pulp 中使用以下方法(也许有人能弄清楚原因):
import pulp
data = [(481.79, 5), (412.04, 4), (365.54, 3)] #, (375.88, 3), (379.75, 3), (632.92, 5), (127.89, 1), (835.71, 6), (200.21, 1)]
x = pulp.LpVariable.dicts('x', range(len(data)), lowBound=0, upBound=7, cat=pulp.LpInteger)
numerator = dict((i,tup[0]) for i,tup in enumerate(data))
denom_int = dict((i,tup[1]) for i,tup in enumerate(data))
problem = pulp.LpProblem('Mixed Integer Linear Programming', sense=pulp.LpMinimize)
# objective function (doesn't work)
# TypeError: unsupported operand type(s) for /: 'float' and 'LpAffineExpression'
problem += sum([numerator[i] / (denom_int[i] + x[i]) for i in range(len(data))])
problem.solve()
for v in problem.variables():
print(v.name, "=", v.varValue)
使用 scipy.optimize 的暴力解决方案
您可以对函数中的每个 x
使用 brute
和 slice
范围。如果您的函数中有 3 个 x
,那么您的范围元组中也会有 3 个 slice
。所有这一切的关键是将 1
的 step 大小添加到 slice(start, stop,
step
)
所以 slice(#, #, 1)
。
from scipy.optimize import brute
import itertools
def f(x):
return (481.79/(5+x[0]))+(412.04/(4+x[1]))+(365.54/(3+x[2]))
ranges = (slice(0, 9, 1),) * 3
result = brute(f, ranges, disp=True, finish=None)
print(result)
itertools 解决方案
或者您可以使用 itertools 生成所有组合:
combinations = list(itertools.product(*[[0,1,2,3,4,5,6,7,8]]*3))
values = []
for combination in combinations:
values.append((combination, f(combination)))
best = [c for c,v in values if v == min([v for c,v in values])]
print(best)
注意:出于示例目的,这是原始函数的缩小版本。
关于python - 将 scipy.optimize.minimize 限制为整数值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39236863/
我需要最小化一个函数,比如五个变量(x[0] 到 x[4]) 要最小化的标量函数由X'*H*X给出。目标函数看起来类似于: def objfun(x): H = 0.1*np.ones([5,
我在使用 scipy.minimize.optimize 时遇到问题。这是我的代码。 from time import process_time import numpy as np from sci
我正在创建一个 C# WinForms MDI 应用程序。我有一个主窗体,其中包含 4 个其他窗体。我希望能够将子窗体移出父窗体(它们的 FormBorderStyle 值设置为可调整大小的工具栏,以
在 views app/views/listings/show.haml 中,我有这段代码: - if @listing.price .row .col-12 .listing
我有一个用于构建 .net 解决方案的批处理文件,并试图将详细程度降至最低,它仅显示正在构建的项目以及任何警告和/或错误,但也希望在结尾处查看带有警告数量的摘要和错误加上构建时间。 我已经尝试了详细程
我正在尝试进行一些参数估计,并希望选择最小化预测方程中的平方误差的参数估计 超过大约 30 个变量 .如果方程是线性的,我只需计算 30 个偏导数,将它们全部设置为零,然后使用线性方程求解器。但不幸的
Pyomo 中多目标优化的任何示例吗? 我正在尝试最小化 4 个目标(非线性),并且我想使用 pyomo 和 ipopt。还可以访问古罗比。 我想看一个非常简单的例子,我们尝试优化一系列决策变量(不仅
我正在尝试在我的 java 项目中使用这个库 https://github.com/ralfstx/minimal-json 以下是如何使用它来创建对象和数组。 JsonObject jsonObje
我正在尝试执行以下函数的最小化: def mvqr(P, y, x, c): s = 0 for i in xrange(1, len(y)): summation =
在虚拟机上安装发现默认是命令行界面一路进行下去,最后发现是Minimal的安装,并且网卡也没有默认启动...晕死。网上搜了下才知道原来Centos 6的Minimal下,网卡默认onboot=&qu
我已经开发了VB6应用程序。现在,我想禁用调整窗体的大小。我知道有一个属性Border style,它更改为fixed single,可以完成我的工作。但是我想要最小化按钮到我的形式。最小化按钮仅在“
我的游戏应用程序有问题: 如果将其最小化,则会崩溃...例如如果您按下主屏幕按钮或点击广告。 这是日志: >threadid=19: thread exiting with uncaught exce
我有以下问题:我们正在构建一个相当大的应用程序(win32,Delphi 6 Enterprise)。在应用程序的几个部分中,使用了模态窗口,通常包含主窗口选择的详细信息。 我们对 WM_SYSCOM
我正在开发一个基于 Minim 的音频可视化项目。对于这个项目的一部分,我需要一个频率放大器阵列(我将使用这个阵列来确定监视器条的高度)。我以前从未使用过 Minim,所以我提前为我在这个主题上的有限
scipy.minimize 似乎不遵守约束。这是一个简单的示例,其中约束是为了防止对数中的负参数,但最小化函数不遵守: import math from scipy.optimize import
我是 scipy.optimize 模块的新手,需要帮助尝试在与矩阵一起使用的公式 V 上使用最小化函数,并且有 2 个约束,但我不确定我是否正确处理了函数的形成或其中之一限制条件。 M 是一个 Nx
是否有 Android 标准或编码约定/最佳实践规定当用户“退出”应用时应用是否应退出(不在后台运行)或最小化(在后台运行)? 例如,您在某个应用的主页上。处理背压的最佳做法是什么?显而易见的答案是让
有没有办法在不使用回调和重新执行成本函数的情况下使用 scipy.minimize 在每次迭代的基础上访问成本函数? options.disp 似乎打算这样做,但只会导致优化器打印终止消息。 最好将它
我想在我的主题的答案帖子中自定义问题的外观,该主题基于 Minimal theme .我尝试从我以前的模板中添加内容,该模板已按照我想要的方式设置格式,但没有成功。 这是我添加的: 在 {Questi
我想要一个方法在很多地方创建以下 json 字符串: {"daily_calendar":{"search":{"print_date":"2014-06-30"}}} 我有以下四行代码来制作散列:
我是一名优秀的程序员,十分优秀!