24小时热门版块排行榜    

CyRhmU.jpeg
查看: 1371  |  回复: 10

hxwgw

铁虫 (初入文坛)

[求助] matlab非线性拟合计算求助

求助高手,我的拟合程序主体如下
16行 fun=inline('b(1)*(x1.^b(2))*(x2.^b(3))*(x3.^b(4))-b(5)*(x1.^b(6))*(x4.^b(7))*(x5.^b(8));','b','x');
17行 [b,r,j]=nlinfit(x,y,fun,b0);
18行 b                                     %最佳参数
19行 R=sum(r.^2)           

但总是出错
??? Error using ==> nlinfit at 114
The inline model function generated the following error:
Error using ==> inlineeval at 15
Error in inline expression ==>
b(1)*(x1.^b(2))*(x2.^b(3))*(x3.^b(4))-b(5)*(x1.^b(6))*(x4.^b(7))*(x5.^b(8));
??? Error using ==> eval
Undefined function or variable 'x1'.

Error in ==> exmp1 at 17
[b,r,j]=nlinfit(x,y,fun,b0);
求高手帮忙看看错在哪里
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hxwgw

铁虫 (初入文坛)

共有5个自变量(每个40个数据),求解8个参数
2楼2012-10-08 10:49:25
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hxwgw

铁虫 (初入文坛)

参数是这么写的
x1=...;x2;x3;x4;x5;
x=[x1' x2' x3' x4' x5'];
y=...;
bo=...;
3楼2012-10-08 10:53:59
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

csgt0

荣誉版主 (著名写手)

彩色挂图

【答案】应助回帖


感谢参与,应助指数 +1
dbb627: 金币+1, 感谢应助 2012-10-10 17:02:45
函数是关于b和x的函数,你用x(:,1)代替x1之类的试试

» 本帖已获得的红花(最新10朵)

showmethemoney
4楼2012-10-08 13:28:17
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hxwgw

铁虫 (初入文坛)

送鲜花一朵
引用回帖:
4楼: Originally posted by csgt0 at 2012-10-08 13:28:17
函数是关于b和x的函数,你用x(:,1)代替x1之类的试试

你好,我改了一下,原来的错误提示没有了。
改后
x(:,1)=[..].;
x(:,2)=...;
x(:,3)= ;
x(:,4)= ;
x(:,5)= ;
x=[x(:,1)' x(:,2)' x(:,3)' x(:,4)' x(:,5)'];
y= ;  
b0=[5.687 2143 0.0970 0.1051 4.585 122.6 0.1140 0.1159]';            %初始参数值
fun=inline('b(1)*(x(:,1).^b(2))*(x(:,2).^b(3))*(x(:,3).^b(4))-b(5)*(x(:,1).^b(6))*(x(:,4).^b(7))*(x(:,5).^b(8))','b','x');
[b,r,j]=nlinfit(x,y,fun,b0);
b                                     %最佳参数
R=sum(r.^2)   
但是还是有别的提示
??? Error using ==> nlinfit at 128
MODELFUN should return a vector of fitted values the same length as Y.

Error in ==> exmp1 at 11
[b,r,j]=nlinfit(x,y,fun,b0);请教一下这是怎么回事
5楼2012-10-09 09:46:17
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hxwgw

铁虫 (初入文坛)

引用回帖:
4楼: Originally posted by csgt0 at 2012-10-08 13:28:17
函数是关于b和x的函数,你用x(:,1)代替x1之类的试试

上面的问题已解决,但是程序提示矩阵维度不匹配
??? Subscripted assignment dimension mismatch.
我的x有32个值,y也有32个值,矩阵计算的时候怎么会不匹配呢
6楼2012-10-09 10:17:34
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

csgt0

荣誉版主 (著名写手)

彩色挂图

【答案】应助回帖

引用回帖:
6楼: Originally posted by hxwgw at 2012-10-09 10:17:34
上面的问题已解决,但是程序提示矩阵维度不匹配
??? Subscripted assignment dimension mismatch.
我的x有32个值,y也有32个值,矩阵计算的时候怎么会不匹配呢...

把公式里的*都改成.*试试。
其实用inline容易写错,不如单独写个子函数
showmethemoney
7楼2012-10-09 10:28:38
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hxwgw

铁虫 (初入文坛)

引用回帖:
7楼: Originally posted by csgt0 at 2012-10-09 10:28:38
把公式里的*都改成.*试试。
其实用inline容易写错,不如单独写个子函数...

改后还是同样的问题
提示:
??? Subscripted assignment dimension mismatch.

Error in ==> exmp1 at 2
这里是第二行,应该是这里出错了:
x(:,1)=[0.999715794 0.999715794 0.999715794 0.999715794 0.999715794
0.999715794 0.999715794 0.999715794 0.999722354 0.999722354
0.999722354 0.999722354 0.999722354 0.999722354 0.999722354
0.999722354
我的参数有32个
这里只显示了16个
我原来用过inline,感觉只会用这个,呵呵
8楼2012-10-09 10:35:50
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

csgt0

荣誉版主 (著名写手)

彩色挂图

【答案】应助回帖


dbb627: 金币+1, 谢谢耐心指导 2012-10-10 17:03:26
哦,你写错了啊
x(:,1)表示的是x的一列,所以右边应该也是一个列向量。
根据你的意思,应该x是32行5列,y是32行一列,每一行x对应一个y。
然后在inline里,应该用x(:,1).*x(:,2)之类的方式表示x的每一列的所有行分别作用,得到相同行数的一列y
showmethemoney
9楼2012-10-09 10:40:49
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hxwgw

铁虫 (初入文坛)

引用回帖:
9楼: Originally posted by csgt0 at 2012-10-09 10:40:49
哦,你写错了啊
x(:,1)表示的是x的一列,所以右边应该也是一个列向量。
根据你的意思,应该x是32行5列,y是32行一列,每一行x对应一个y。
然后在inline里,应该用x(:,1).*x(:,2)之类的方式表示x的每一列的所有行 ...

嗯,我是这样做的
x(:,1)=[32个数];
x(:,2)=[32个数];
x(:,3)=[32个数];
x(:,4)=[32个数];
x(:,5)=[32个数];
x=[x(:,1)' x(:,2)' x(:,3)' x(:,4)' x(:,5)'];
y=[32个数];  
b0=[5.687 2143 0.0970 0.1051 4.585 122.6 0.1140 0.1159]';            %初始参数值
fun=inline('b(1).*(x(:,1).^b(2)).*(x(:,2).^b(3)).*(x(:,3).^b(4))-b(5).*(x(:,1).^b(6)).*(x(:,4).^b(7)).*(x(:,5).^b(8))','b','x');
[b,r,j]=nlinfit(x,y,fun,b0);
b                                     %最佳参数
R=sum(r.^2)   
出现的错误提示还是一样的,麻烦你看看这里还有错误码?
10楼2012-10-09 10:55:54
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 hxwgw 的主题更新
信息提示
请填处理意见