24小时热门版块排行榜    

查看: 1895  |  回复: 10

刘小嵩321

银虫 (著名写手)

[求助] 用matlab对矩阵做一个e指数的拟合程序 已有3人参与

有一个383*2048的矩阵,要求对这个矩阵的所有元素进行e指数拟合,e指数拟合的公式类型为:y=a-bcX,其中X是c的指数,b与c是相乘。给出程序
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

独孤神宇

版主 (知名作家)

【答案】应助回帖

感谢参与,应助指数 +1
用cftool工具箱 拟合就是了 界面操作 简单快捷
数值计算
2楼2015-07-15 19:48:46
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

刘小嵩321

银虫 (著名写手)

引用回帖:
2楼: Originally posted by 独孤神宇 at 2015-07-15 19:48:46
用cftool工具箱 拟合就是了 界面操作 简单快捷

工具箱只能拟合单条线的,我要的是全部的数据都进行拟合。
3楼2015-07-16 08:15:01
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dingd

铁杆木虫 (职业作家)

【答案】应助回帖

感谢参与,应助指数 +1
考虑试试1stOpt,可以批量处理数据,关键是不需要初值,省事不少。
4楼2015-07-16 09:30:25
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

刘小嵩321

银虫 (著名写手)

引用回帖:
4楼: Originally posted by dingd at 2015-07-16 09:30:25
考虑试试1stOpt,可以批量处理数据,关键是不需要初值,省事不少。

matlab里面没有1stOpt
5楼2015-07-16 09:47:40
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

guo_zy_123

木虫 (正式写手)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
刘小嵩321: 金币+10, ★★★★★最佳答案, 万分感谢 2015-07-16 15:48:42
CODE:
function [fitresult, gof] = createFit(x, y)

[xData, yData] = prepareCurveData( x, y );

% Set up fittype and options.
ft = fittype( 'a-b*exp(x)', 'independent', 'x', 'dependent', 'y' );
opts = fitoptions( 'Method', 'NonlinearLeastSquares' );
opts.Display = 'off';
% opts.StartPoint = [0.867276403277854 0.0574539084707549];

% Fit model to data.
[fitresult, gof] = fit( xData, yData, ft, opts );

% Create a figure for the plots.
figure( 'Name', 'untitled fit 1' );

% Plot fit with data.
subplot( 2, 1, 1 );
h = plot( fitresult, xData, yData );
legend( h, 'y vs. x', 'untitled fit 1', 'Location', 'NorthEast' );
% Label axes
xlabel x
ylabel y
grid on

% Plot residuals.
subplot( 2, 1, 2 );
h = plot( fitresult, xData, yData, 'residuals' );
legend( h, 'untitled fit 1 - residuals', 'Zero Line', 'Location', 'NorthEast' );
% Label axes
xlabel x
ylabel y
grid on

1你自己改下吧,不知道你哪个是行是x还是列是x
2此代码直接就是x向量和y向量
你自己先用某一行测试下
3然后你要做的就是注释掉画图
用for循环调用数据就是了
老古董
6楼2015-07-16 10:40:33
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

guo_zy_123

木虫 (正式写手)

引用回帖:
6楼: Originally posted by guo_zy_123 at 2015-07-16 10:40:33
function  = createFit(x, y)

= prepareCurveData( x, y );

% Set up fittype and options.
ft = fittype( 'a-b*exp(x)', 'independent', 'x', 'dependent', 'y' );
opts = fitoptions( 'Method', 'Nonlin ...

忘了说了,公式写成了a-b*exp(x)
老古董
7楼2015-07-16 10:43:51
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

刘小嵩321

银虫 (著名写手)

引用回帖:
7楼: Originally posted by guo_zy_123 at 2015-07-16 10:43:51
忘了说了,公式写成了a-b*exp(x)...

我想把数据load(‘NM.dat')进去,然后把这个load的数据的第一列作为x轴,第一行作为y轴,应该如何做
8楼2015-07-16 11:29:42
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dingd

铁杆木虫 (职业作家)

引用回帖:
5楼: Originally posted by 刘小嵩321 at 2015-07-16 09:47:40
matlab里面没有1stOpt...

百度下,与Matlab无关。
9楼2015-07-16 11:48:02
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

guo_zy_123

木虫 (正式写手)

引用回帖:
8楼: Originally posted by 刘小嵩321 at 2015-07-16 11:29:42
我想把数据load(‘NM.dat')进去,然后把这个load的数据的第一列作为x轴,第一行作为y轴,应该如何做...

如果你所有的数据都load到1个数据的话,假定这个名字叫做data是个383*2048的数据
代码这么写
x = data(:,1);          %first col to be x
[n_row,n_col] = size(data);         %data size
fit_out = [];                       %output data
gof_out = [];                       %output data
for i_fit = 2:1:n_col               %我觉得你是不是搞错了,应该是每列都是y吧,
    y = data(:,i_fit);
    [a, b] = creatFit(x,y);        %要不然你这是一个z = f(x,y)的函数,也就是拟合一个曲面
fit_out = [fit_out;a];
gof_out = [gof_out;b];             %put fit data in outouts
end
老古董
10楼2015-07-16 14:58:03
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 刘小嵩321 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 304求调剂 +7 司空. 2026-03-18 7/350 2026-03-20 23:08 by JourneyLucky
[考研] 324求调剂 +5 lucky呀呀呀鸭 2026-03-20 5/250 2026-03-20 22:30 by 促天成
[考研] 086500 325 求调剂 +3 领带小熊 2026-03-19 3/150 2026-03-20 18:38 by 尽舜尧1
[考研] 0703化学调剂 +10 妮妮ninicgb 2026-03-15 14/700 2026-03-19 22:59 by 学员8dgXkO
[考研] 0703化学调剂 +4 18889395102 2026-03-18 4/200 2026-03-19 16:13 by 30660438
[考研] 085601材料工程专硕求调剂 +10 慕寒mio 2026-03-16 10/500 2026-03-19 15:26 by 丁丁*
[考研] 346求调剂[0856] +3 WayneLim327 2026-03-16 6/300 2026-03-19 11:21 by WayneLim327
[考研] 材料工程专硕调剂 +5 204818@lcx 2026-03-17 6/300 2026-03-18 22:55 by 204818@lcx
[考研] 328求调剂,英语六级551,有科研经历 +3 生物工程调剂 2026-03-17 7/350 2026-03-18 20:41 by Wangjingyue
[考研] 【同济软件】软件(085405)考研求调剂 +3 2026eternal 2026-03-18 3/150 2026-03-18 19:09 by 搏击518
[考研] 化学工程321分求调剂 +15 大米饭! 2026-03-15 18/900 2026-03-18 14:52 by haxia
[考研] 08工科 320总分 求调剂 +5 梨花珞晚风 2026-03-17 5/250 2026-03-18 14:49 by haxia
[基金申请] 被我言中:新模板不强调格式了,假专家开始管格式了 +4 beefly 2026-03-14 4/200 2026-03-17 22:04 by 黄鸟于飞Chao
[考研] 326求调剂 +5 上岸的小葡 2026-03-15 6/300 2026-03-17 17:26 by ruiyingmiao
[硕博家园] 湖北工业大学 生命科学与健康学院-课题组招收2026级食品/生物方向硕士 +3 1喜春8 2026-03-17 5/250 2026-03-17 17:18 by ber川cool子
[论文投稿] 有没有大佬发小论文能带我个二作 +3 增锐漏人 2026-03-17 4/200 2026-03-17 09:26 by xs74101122
[考研] 304求调剂 +5 素年祭语 2026-03-15 5/250 2026-03-16 17:00 by 我的船我的海
[考研] 一志愿211 0703方向310分求调剂 +3 努力奋斗112 2026-03-15 3/150 2026-03-16 16:44 by houyaoxu
[考研] 0856求调剂 +3 刘梦微 2026-03-15 3/150 2026-03-16 10:00 by houyaoxu
[考研] 一志愿哈工大材料324分求调剂 +5 闫旭东 2026-03-14 5/250 2026-03-14 14:53 by 木瓜膏
信息提示
请填处理意见