24小时热门版块排行榜    

查看: 1498  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 化学工程321分求调剂 +9 大米饭! 2026-03-15 12/600 2026-03-16 21:59 by 大米饭!
[考研] 药学383 求调剂 +3 药学chy 2026-03-15 4/200 2026-03-16 20:51 by 元子^0^
[硕博家园] 深圳大学硕士招生(2026秋,传感器方向,仅录取第一志愿) +4 xujiaoszu 2026-03-11 8/400 2026-03-16 09:45 by xujiaoszu
[考研] 中科大材料与化工319求调剂 +3 孟鑫材料 2026-03-14 3/150 2026-03-14 20:10 by ms629
[考研] 学硕285求调剂 +13 Wisjxn 2026-03-12 46/2300 2026-03-14 10:33 by JourneyLucky
[考研] 0856材料与化工309分求调剂 +6 ZyZy…… 2026-03-10 6/300 2026-03-14 00:38 by JourneyLucky
[考研] 321求调剂 +3 CUcat 2026-03-10 3/150 2026-03-14 00:25 by JourneyLucky
[考研] 327求调剂 +4 Ffff03 2026-03-10 4/200 2026-03-14 00:17 by JourneyLucky
[考研] 0805,333求调剂 +3 112253525 2026-03-10 3/150 2026-03-13 23:42 by JourneyLucky
[考研] 材料与化工(0856)304求B区调剂 +6 邱gl 2026-03-12 7/350 2026-03-13 23:24 by 邱gl
[考研] 材料专硕288分求调剂 一志愿211 +4 在家想你 2026-03-11 4/200 2026-03-13 22:49 by JourneyLucky
[考研] 337一志愿华南理工0805材料求调剂 +7 mysdl 2026-03-11 9/450 2026-03-13 22:43 by JourneyLucky
[考研] 一志愿中科院,化学方向,295求调剂 +4 一氧二氮 2026-03-11 4/200 2026-03-13 22:35 by JourneyLucky
[考研] 307求调剂 +5 超级伊昂大王 2026-03-12 5/250 2026-03-13 15:56 by 棒棒球手
[考研] 274求调剂 +3 S.H1 2026-03-12 3/150 2026-03-13 15:15 by JourneyLucky
[考研] 277求调剂 +4 anchor17 2026-03-12 4/200 2026-03-13 11:15 by 白夜悠长
[考研] 296求调剂 +3 大口吃饭 身体健 2026-03-13 3/150 2026-03-13 10:31 by 学员8dgXkO
[考研] 化工学硕306求调剂 +9 42838695 2026-03-12 9/450 2026-03-13 10:16 by houyaoxu
[考研] 工科0856专硕化学工程269能调剂吗 +10 我想读研11 2026-03-10 10/500 2026-03-13 10:14 by Yuyi.
[基金申请] 提交后的基金本子,已让学校撤回了,可否换口子提交 +3 dut_pfx 2026-03-10 3/150 2026-03-11 08:38 by kudofaye
信息提示
请填处理意见