我知道有很多与我相似的职位,但我真的无法将它们应用于我的情况,因此请寻求您的帮助。基本上,我的代码如下:

def Black_min(f, k, ann, vol, ex, cp):
    d1=(math.log(f/k)+0.5*vol**2*ex)/math.sqrt(vol**2*ex)
    d2=(math.log(f/k)-0.5*vol**2*ex)/math.sqrt(vol**2*ex)
    Price=cp*(f*norm.cdf(cp*d1)-k*norm.cdf(cp*d2))*ann*20000
    return Price

banana = lambda x: (Price_Cube[0][4]-Black_min(F[0], K[0][4], Annuity[0], x, Expiry[0], CP[4]))**2
xopt, fopt = scipy.optimize.fmin(func=banana, x0=[Vol_Cube[0][0]],  disp=False)


Price_Cube,K是内部带有数字的列表的列表,年金,到期日和CP只是列表。当我运行代码时,我得到了这一点。

    xopt, fopt = scipy.optimize.fmin(func=banana, x0=[Vol_Cube[0][0]],  disp=False)

ValueError: need more than 1 value to unpack


我知道这是一个愚蠢的错误,但我确实没有看到。任何帮助表示赞赏,在此先感谢。

最佳答案

问题是您尝试将fmin的返回值分配给两个变量xoptfopt,但是默认情况下fmin仅返回xopt。你应该试试

xopt = scipy.optimize.fmin(func=banana, x0=[Vol_Cube[0][0]])


如果您还希望函数值最小,则必须将full_output设置为True,然后还会获得更多诊断信息:

xopt, fopt, iter, funccalls, warnflags = scipy.optimize.fmin(func=banana, x0=[Vol_Cube[0][0]], full_output=True)

08-24 14:26