python三维曲面拟合_使用Python做3-d曲面拟合

我可以使用模块(scipy.optimize.least_squares)做1-d曲线拟合(当然,我还可以使用直接curve_fit模块),像这样使用Python做3-d曲面拟合

def f(par,data,obs):

return par[0]*data+par[1]-obs

def get_f(x,a,b):

return x*a+b

data = np.linspace(0, 50, 100)

obs = get_f(data,3.2,2.3)

par = np.array([1.0, 1.0])

res_lsq = least_squares(f, par, args=(data, obs))

print res_lsq.x

我能得到正确的拟合参数(3.2,2.3),但是当我概括这种方法多维度,这样

def f(par,data,obs):

return par[0]*data[0,:]+par[1]*data[1,:]-obs

def get_f(x,a,b):

return x[0]*a+b*x[1]

data = np.asarray((np.linspace(0, 50, 100),(np.linspace(0, 50, 100))))

obs = get_f(data,1.,1.)

par = np.array([3.0, 5.0])

res_lsq = least_squares(f, par, args=(data, obs))

print res_lsq.x

我发现我不能得到正确的答案,即(1,1。 ),我不知道我是否犯了一个错误。

2016-11-08

john

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值