为了账号安全,请及时绑定邮箱和手机立即绑定

结果不一样

def func(x):
    return (2*x[0]*x[1]+2*x[0]-x[0]**2-2*x[1]**2)
def func_deriv(x):
    dfdx0=(-2*x[0]+2*x[1]+2)
    dfdx1=(2*x[0]-4*x[1])
    return np.array([dfdx0,dfdx1])
cons=({"type":"eq",
       "fun":lambda x:np.array([x[0]**3-x[1]]),
       "jac":lambda x:np.array([3.0*(x[0]**2.0),-1.0])},
      {'type':'ineq',
       'fun':lambda x:np.array([x[1]-1]),
       'jac':lambda x:np.array([0.0,1.0])})
res=minimize(func,[-1.0,1.0],jac=func_deriv,constraints=cons,method='SLSQP',options={'disp':True})
print("RESTRICT",res)


正在回答

1 回答

def func(x):
    return -(2*x[0]*x[1]+2*x[0]-x[0]**2-2*x[1]**2)
def  func_deriv(x):
    dfdx0 = -(-2*x[0] + 2*x[1] + 2)
    dfdx1 = -(2*x[0] - 4*x[1])
    return np.array([dfdx0,dfdx1])
cons = ({"type":"eq","fun":lambda x:np.array([x[0]**3.0-x[1]]),
        "jac":lambda x:np.array([3.0*(x[0]**2.0),-1.0])},
        {"type":"ineq","fun":lambda x:np.array([x[1]-1]),
        "jac":lambda x:np.array([0.0,1.0])})
res=minimize(func,[-1.0,1.0],jac = func_deriv,constraints=cons,
    method='SLSQP',options = {'disp':True})
print("RESTRICT:",res)


3 回复 有任何疑惑可以回复我~
#1

慕设计3172499

你少了几个负号,不同式子算出结果肯定不同
2019-07-25 回复 有任何疑惑可以回复我~
#2

weixin_慕少2362225 回复 慕设计3172499

请问这几个负号加上和不加上的区别在哪里呀
2021-04-25 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消

结果不一样

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信