24小时热门版块排行榜    

查看: 1500  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[基金申请] 国自科面上基金字体 +6 iwuli 2026-03-12 7/350 2026-03-16 21:18 by sculhf
[考研] 药学383 求调剂 +3 药学chy 2026-03-15 4/200 2026-03-16 20:51 by 元子^0^
[考研] 302求调剂 +3 小贾同学123 2026-03-15 5/250 2026-03-16 20:39 by zhq0425
[考研] 0703化学调剂 ,六级已过,有科研经历 +7 曦熙兮 2026-03-15 7/350 2026-03-16 16:34 by houyaoxu
[考研] 309求调剂 +5 花与叶@ 2026-03-10 5/250 2026-03-16 14:13 by 哦哦123
[教师之家] 焦虑 +7 水冰月月野兔 2026-03-13 9/450 2026-03-16 10:00 by Quakerbird
[基金申请] NSFC申报书里申请人简历中代表性论著还需要在申报书最后的附件里面再上传一遍吗 20+5 NSFC2026我来了 2026-03-10 14/700 2026-03-15 23:53 by 不负韶华的虎
[考博] 欢迎申博同学联系 +3 天道酬勤2026686 2026-03-10 7/350 2026-03-15 19:03 by 天道酬勤2026686
[考研] 中科大材料与化工319求调剂 +3 孟鑫材料 2026-03-14 3/150 2026-03-14 20:10 by ms629
[考研] 复试调剂 +4 z1z2z3879 2026-03-14 5/250 2026-03-14 16:30 by JourneyLucky
[考研] 330求调剂 +3 ?酱给调剂跪了 2026-03-13 3/150 2026-03-14 10:13 by JourneyLucky
[考研] 312求调剂 +6 陌宸希 2026-03-10 6/300 2026-03-14 00:40 by JourneyLucky
[考研] 一志愿湖师大化学289求调剂 +6 XMCMM3.14159 2026-03-10 6/300 2026-03-14 00:28 by JourneyLucky
[考研] 304求调剂 +6 Mochaaaa 2026-03-12 7/350 2026-03-13 22:18 by 星空星月
[考研] 求材料调剂 +5 隔壁陈先生 2026-03-12 5/250 2026-03-13 22:03 by 星空星月
[考研] 329求调剂 +3 miaodesi 2026-03-12 4/200 2026-03-13 20:53 by 18595523086
[考研] 材料与化工085600调剂求老师收留 +9 jiaanl 2026-03-11 9/450 2026-03-13 20:22 by JourneyLucky
[考研] 301求调剂 +6 Liyouyumairs 2026-03-11 6/300 2026-03-13 20:11 by JourneyLucky
[考研] 081200-11408-276学硕求调剂 +3 崔wj 2026-03-12 4/200 2026-03-12 19:33 by 求调剂zz
[考研] 085602化工求调剂 +7 董boxing 2026-03-10 7/350 2026-03-10 17:07 by BruceLiu320
信息提示
请填处理意见