24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1527  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 0703化学 +14 妮妮ninicgb 2026-04-04 15/750 2026-04-06 08:32 by zhangdingwa
[考研] 085600,321分求调剂 +11 大馋小子 2026-04-04 12/600 2026-04-06 06:29 by houyaoxu
[考研] 材料调剂 +6 一样YWY 2026-04-05 6/300 2026-04-05 20:30 by 南航~万老师
[考研] 求调剂求调剂 +8 121. 2026-04-02 8/400 2026-04-05 20:15 by lys0704
[考研] 323求调剂(计算机视觉和大模型项目经历) +3 chaoxiicy 2026-03-31 3/150 2026-04-05 10:33 by zhq0425
[考研] 材料调剂 +12 一样YWY 2026-04-04 12/600 2026-04-05 08:24 by 544594351
[考研] 土木304求调剂 +4 兔突突突, 2026-03-31 4/200 2026-04-04 13:34 by 1753564080
[考研] 0856调剂 +8 曲听筠 2026-03-30 8/400 2026-04-04 08:46 by tianyyysss
[考研] 考研调剂 +3 15615482637 2026-04-03 3/150 2026-04-03 22:50 by ms629
[考研] 311求调剂 +20 zchqwer 2026-04-01 22/1100 2026-04-03 22:09 by lglzsd
[考研] 335求调剂 +7 沈清璃 2026-04-03 7/350 2026-04-03 18:55 by lijunpoly
[考研] 学硕机械工程303求调剂 +6 无名所以叫吴明 2026-03-30 7/350 2026-04-03 16:48 by asdfzly
[考研] 机械专硕297 +3 Afksy 2026-04-03 3/150 2026-04-03 14:24 by 1753564080
[考研] 319求调剂 +18 太容易1018 2026-04-01 18/900 2026-04-03 11:18 by linyelide
[考研] 262求调剂 +6 励志一定发文章 2026-04-02 7/350 2026-04-03 09:54 by linyelide
[考研] 一志愿a区211,085601-307分求调剂 +13 党嘉豪 2026-03-31 26/1300 2026-04-03 08:33 by 495374996
[考研] 0856材料与化工调剂,339 +14 10213207 2026-03-31 14/700 2026-04-02 21:01 by 1104338198
[考研] 266求调剂 +4 学员97LZgn 2026-04-02 4/200 2026-04-02 13:03 by yulian1987
[考研] 07生物学求调剂 一志愿同济大学359分 +3 LAMC. 2026-03-30 3/150 2026-04-02 10:26 by 18828373951
[考研] 一志愿 南京航空航天大学 ,080500材料科学与工程学硕 +10 @taotao 2026-03-31 11/550 2026-04-01 09:43 by xiayizhi
信息提示
请填处理意见