24小时热门版块排行榜    

查看: 2029  |  回复: 11

chj787

金虫 (小有名气)

[求助] matlab拟合求助

用matlab拟合一个方程:
    y=(a+bx+cx^2+dx^3)exp(-bx)
x=[0.8,0.85,0.9,0.94,1,1.1,1.14,1.144,1.146,1.148,1.149,1.15,1.151,1.152,1.153,1.157,1.25,1.3,1.35,1.4,1.45,1.5,1.55,1.6,1.65,1.7,1.75,1.8,1.85,1.9,1.95,2,2.05,2.1,2.15,2.2,2.25,2.3,2.35,2.4];
y=[129698.6607,81517.14907,48462.38869,30160.54842,12625.39888,830.7904906,0,2.343989057,8.695584894,18.42928479,24.54823752,31.4946096,39.26181681,47.84108015,57.22581538,102.7141275,687.9234793,3872.493796,7589.20011,11578.99871,15654.88623,19681.73873,23751.25051,27388.0944,30756.13673,33816.1486,36542.19252,38921.37873,40955.22819,42660.53072,44067.23581,45213.10408,46138.07991,46880.36067,47474.18002,47948.97387,48329.25318,48634.92208,48881.88591,49082.65691];

变量:x,y
拟合常数: a,b,c,d
求高手帮助!给出matlab拟合程序。

[ Last edited by chj787 on 2012-5-20 at 16:29 ]
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
回帖支持 ( 显示支持度最高的前 50 名 )

cactus586

金虫 (著名写手)

流浪过的人总是想再次踏上旅途

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
xzhdty: 金币+1, 欢迎常来程序语言看看 2012-05-21 05:57:43
chj787: 金币+30, 有帮助, 1 2012-05-24 21:55:56
昨天看到一个用MatLab演奏卡侬的 可以站短问问他
http://muchong.com/bbs/viewthread.php?tid=4519096
静水流深
2楼2012-05-20 16:40:48
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通回帖

chj787

金虫 (小有名气)

引用回帖:
2楼: Originally posted by cactus586 at 2012-05-20 16:40:48:
昨天看到一个用MatLab演奏卡侬的 可以站短问问他
http://muchong.com/bbs/viewthread.php?tid=4519096

谢谢!
3楼2012-05-20 17:59:36
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lijie169

铜虫 (著名写手)

【答案】应助回帖

★ ★ ★ ★ ★
感谢参与,应助指数 +1
xzhdty: 金币+2, 欢迎常来程序语言 2012-05-21 05:58:00
chj787: 金币+3, ★★★很有帮助 2012-05-29 15:30:03
CODE:
function f=fit(x,y)
f=lsqnonlin(@(a)fun(a,x,y),[1,1,1,1]');
function f1=fun(a,x,y)
f1=y-(a(1)+a(2)*x+a(3)*x.^2+a(4)*x.^3).*exp(-a(2)*x);
end
end

x,y就是楼主输入的,a是一个矩阵,对应着abcd
4楼2012-05-20 18:08:21
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lijie169

铜虫 (著名写手)

【答案】应助回帖

额,输入fit(x,y)就可以了
5楼2012-05-20 18:09:06
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

coolxh

木虫 (小有名气)

【答案】应助回帖

★ ★ ★
感谢参与,应助指数 +1
xzhdty: 金币+1, 欢迎常来程序语言看看 2012-05-21 05:58:22
chj787: 金币+2, ★★★很有帮助 2012-05-29 15:29:52
若不想自己写代码,亦可用曲线拟合工具,
cftool(x,y)

然后采用自定义公式,按你想要的公式定义表达式,进行拟合

然后再自动生成拟合代码
6楼2012-05-20 21:43:41
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lgycjpcqu

金虫 (正式写手)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
xzhdty: 金币+1, 谢谢了 2012-05-22 06:01:48
chj787: 金币+15, ★★★★★最佳答案, 非常感谢!评分晚了,万分抱歉~! 2012-05-29 15:29:20
x=[0.8,0.85,0.9,0.94,1,1.1,1.14,1.144,1.146,1.148,1.149,1.15,1.151,1.152,1.153,1.157,1.25,1.3,1.35,1.4,1.45,1.5,1.55,1.6,1.65,1.7,1.75,1.8,1.85,1.9,1.95,2,2.05,2.1,2.15,2.2,2.25,2.3,2.35,2.4];
y=[129698.6607,81517.14907,48462.38869,30160.54842,12625.39888,830.7904906,0,2.343989057,8.695584894,18.42928479,24.54823752,31.4946096,39.26181681,47.84108015,57.22581538,102.7141275,687.9234793,3872.493796,7589.20011,11578.99871,15654.88623,19681.73873,23751.25051,27388.0944,30756.13673,33816.1486,36542.19252,38921.37873,40955.22819,42660.53072,44067.23581,45213.10408,46138.07991,46880.36067,47474.18002,47948.97387,48329.25318,48634.92208,48881.88591,49082.65691];
ybeta=inline('(beta(1)+beta(2)*x+beta(3)*x.^2+beta(4)*x.^3).*exp(-beta(2)*x)','beta','x');
beta=nlinfit(x,y,ybeta,[1e+004,0,-1e+004,1e+004]);
a=beta(1);
b=beta(2);
c=beta(3);
d=beta(4);
yy=(a+b*x+c*x.^2+d*x.^3).*exp(-b*x);
plot(x,yy,x,y,'*')
但是会显示
Warning: The Jacobian at the solution is ill-conditioned, and some
model parameters may not be estimated well (they are not identifiable).
Use caution in making predictions.所以可能还需要进一步手动优化,我做你何时用nlinfit也经常出现这个警告,期待有高手解答。
拟合结果是
3866678.20479525       
2.55862906421524       
-8281766.51676900       
4642226.52606192
希望能帮到你
7楼2012-05-21 10:31:55
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lijie169

铜虫 (著名写手)

引用回帖:
4楼: Originally posted by lijie169 at 2012-05-20 18:08:21
function f=fit(x,y)
f=lsqnonlin(@(a)fun(a,x,y),');
function f1=fun(a,x,y)
f1=y-(a(1)+a(2)*x+a(3)*x.^2+a(4)*x.^3).*exp(-a(2)*x);
end
end

x,y就是楼主输入的,a是一个矩阵,对应着abcd...

很有帮助才给3个金币  

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

8楼2012-05-29 17:14:23
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

chj787

金虫 (小有名气)

送鲜花一朵
引用回帖:
8楼: Originally posted by lijie169 at 2012-05-29 17:14:23
很有帮助才给3个金币  ...

9楼2012-05-30 22:10:20
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lijie169

铜虫 (著名写手)

引用回帖:
9楼: Originally posted by chj787 at 2012-05-30 22:10:20
...

10楼2012-05-31 07:04:05
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 chj787 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 304求调剂 +4 ahbd 2026-03-14 4/200 2026-03-16 16:48 by 我的船我的海
[考研] 318求调剂 +3 Yanyali 2026-03-15 3/150 2026-03-16 16:41 by houyaoxu
[考研] 0703化学调剂 ,六级已过,有科研经历 +7 曦熙兮 2026-03-15 7/350 2026-03-16 16:34 by houyaoxu
[考研] 085600调剂 +5 漾漾123sun 2026-03-12 6/300 2026-03-16 15:58 by 漾漾123sun
[考研] 材料与化工一志愿南昌大学327求调剂推荐 +7 Ncdx123456 2026-03-13 8/400 2026-03-16 12:15 by karry wen
[教师之家] 焦虑 +7 水冰月月野兔 2026-03-13 9/450 2026-03-16 10:00 by Quakerbird
[考研] 材料工程专硕274一志愿211求调剂 +5 薛云鹏 2026-03-15 5/250 2026-03-15 20:38 by Logic2024
[基金申请] 现在如何回避去年的某一个专家,不知道名字 +3 zk200107 2026-03-12 6/300 2026-03-14 17:13 by zk200107
[考研] 266求调剂 +4 学员97LZgn 2026-03-13 4/200 2026-03-14 08:37 by zhukairuo
[基金申请] 有必要更换申报口吗 20+3 fannyamoy 2026-03-11 3/150 2026-03-14 00:52 by zhanghaozhu
[考研] 0856材料与化工309分求调剂 +6 ZyZy…… 2026-03-10 6/300 2026-03-14 00:38 by JourneyLucky
[考研] 求调剂,一志愿江南大学环境工程085701 +3 Djdjj12 2026-03-10 4/200 2026-03-14 00:31 by JourneyLucky
[考研] b区环境工程求调剂 +4 Maps1 2026-03-10 6/300 2026-03-14 00:23 by JourneyLucky
[考研] 332求调剂 +3 Zz版 2026-03-13 3/150 2026-03-13 20:36 by 18595523086
[硕博家园] 085600 260分求调剂 +3 天空还下雨么 2026-03-13 5/250 2026-03-13 18:46 by 天空还下雨么
[考研] 307求调剂 +5 超级伊昂大王 2026-03-12 5/250 2026-03-13 15:56 by 棒棒球手
[考研] 085600材料与化工 309分请求调剂 +7 dtdxzxx 2026-03-12 8/400 2026-03-13 14:43 by jxchenghu
[考研] 308求调剂 +3 是Lupa啊 2026-03-12 3/150 2026-03-13 14:30 by 求调剂zz
[考研] 0856化学工程280分求调剂 +4 shenzxsn 2026-03-11 4/200 2026-03-13 11:55 by ymwdoctor
[考研] 277求调剂 +4 anchor17 2026-03-12 4/200 2026-03-13 11:15 by 白夜悠长
信息提示
请填处理意见