24小时热门版块排行榜    

Znn3bq.jpeg
查看: 1546  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 生物学调剂 +10 纸扇zhishan 2026-04-13 10/500 2026-04-18 21:19 by zqndavala
[考研] 收到复试调剂但是去不了 +8 小蜗牛* 2026-04-16 8/400 2026-04-18 11:15 by zixin2025
[考博] 申博/考博 +3 啃面包的小书虫 2026-04-17 4/200 2026-04-17 23:54 by 阳阳阳^_^
[考研] 304求调剂 +7 castLight 2026-04-16 7/350 2026-04-17 20:05 by 关一盏灯cd
[考研] 一志愿中科大材料与化工,353分还有调剂学校吗 +10 否极泰来2026 2026-04-15 12/600 2026-04-17 17:54 by mapenggao
[考研] 295分求调剂 +5 ?要上岸? 2026-04-17 5/250 2026-04-17 16:51 by fenglj492
[考研] 294求调剂 +14 淡然654321 2026-04-15 14/700 2026-04-16 21:01 by lpl364211
[考研] 一志愿沪9,生物学326求调剂 +9 刘墨墨 2026-04-15 9/450 2026-04-16 17:14 by 崔崔崔cccc
[考研] 307中医考研调剂 +6 于以采蘩 2026-04-14 6/300 2026-04-16 16:20 by qingfeng258
[考研] 291求调剂 +11 关忆北. 2026-04-14 11/550 2026-04-16 15:18 by jiahl2024
[考研] 289 分105500药学专硕求调剂(找B区学校) +4 白云123456789 2026-04-13 4/200 2026-04-16 00:18 by 粉沁若尘
[考研] 一志愿A区211,22408 321求调剂 +6 随心所欲☆ 2026-04-15 7/350 2026-04-15 21:45 by lbsjt
[考研] 0854调剂 +13 长弓傲 2026-04-12 16/800 2026-04-15 13:45 by fenglj492
[考研] 085801电气专硕272求调剂 +19 电气李 2026-04-13 21/1050 2026-04-15 13:37 by 黑科技矿业
[考研] 各位老师好,求调剂,本科211,一志愿天津大学生物与医药学硕,差两名录取。 +11 路六六jjj 2026-04-13 11/550 2026-04-14 16:01 by zs92450
[考研] 105500药学求调剂 +4 x_skys 2026-04-12 4/200 2026-04-14 13:37 by rndfc
[考研] 085408光电信息工程专硕355一志愿长春光机所调剂 +6 王ymaa 2026-04-13 13/650 2026-04-14 11:33 by 王ymaa
[考研] 245求调剂 +6 冰糖橘?汽水 2026-04-13 10/500 2026-04-14 10:49 by jyl0317
[考研] 339求调剂 +4 hanwudada 2026-04-12 4/200 2026-04-13 12:03 by 蓝云思雨
[考研] 调剂结束 +6 floriea 2026-04-12 8/400 2026-04-12 18:13 by zhouxiaoyu
信息提示
请填处理意见