我在使用 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
不起作用。