gpt4 book ai didi

scipy-optimize-minimize - scipy.optimize.minimize 和 Minuit 返回初始猜测值

转载 作者:行者123 更新时间:2023-12-04 10:31:29 38 4
gpt4 key购买 nike

我在使用 scipy.minimize.optimize 时遇到问题。这是我的代码。

from time import process_time 
import numpy as np
from scipy.optimize import minimize
class NMin(object):
def __init__(self, error):
self.error=error

def func(self, N):
i = np.arange(1, N+1)
f = np.abs(np.sum(4/(N*(1+((i - 0.5)/N)**2))) - np.pi)-self.error
return(f)

def nMin(self):
x0 = 1
nMin = minimize(self.func, x0)
return(nMin.x)


def main():
t1_start = process_time()
error=10**(-6)
nMin = NMin(error).nMin()
print("the minimum value of N is: " + str(nMin))
t1_stop = process_time()
print("Elapsed time during the whole program in seconds:",
t1_stop-t1_start)

main ()

我正在尝试最小化函数 func(x)关于 N 找到 N 最小值,但 NMin(error).nMin()好像回来了 x0 = 1而不是 N 最小值。这是我的输出。
the minimum value of N is: [1.]
Elapsed time during the whole program in seconds: 0.015625

我真的为此感到困扰,因为我似乎找不到问题所在,而且我不明白为什么 scipy.optimize不管用。

最佳答案

scipy.optimize.minimize主要用于连续可微函数。在 func 中使用 arange 会产生一个离散的问题。由于这些不连续性,这会导致梯度大幅跳跃(见下图)。

我添加了一些调试打印:

from time import process_time
import numpy as np
from scipy.optimize import minimize
class NMin(object):
def __init__(self, error):
self.error=error

def func(self, N):
print("func called N = {}".format(N))
i = np.arange(1, N+1)
print("i = {}".format(i))
f = np.abs(np.sum(4/(N*(1+((i - 0.5)/N)**2))) - np.pi)-self.error
print("f = {}".format(f))
return(f)

def nMin(self):
x0 = 1
nMin = minimize(self.func, x0)
return(nMin.x)


def main():
t1_start = process_time()
error=10**(-6)
nMin = NMin(error).nMin()
print("the minimum value of N is: " + str(nMin))
t1_stop = process_time()
print("Elapsed time during the whole program in seconds:",
t1_stop-t1_start)

main()

这导致:
func called N = [1.]
i = [1.]
f = 0.05840634641020706
func called N = [1.00000001]
i = [1. 2.]
f = 1.289175555623012

也许您想使用更适合离散问题的不同求解器或更改目标以满足基于梯度的优化连续性的先决条件。

enter image description here

关于scipy-optimize-minimize - scipy.optimize.minimize 和 Minuit 返回初始猜测值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60405042/

38 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com