24小时热门版块排行榜    

查看: 1887  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 295材料求调剂,一志愿武汉理工085601专硕 +4 Charlieyq 2026-03-19 4/200 2026-03-20 14:26 by 无懈可击111
[考研] 298-一志愿中国农业大学-求调剂 +9 手机用户 2026-03-17 9/450 2026-03-20 14:24 by 无懈可击111
[考研] 求调剂 +4 Mqqqqqq 2026-03-19 4/200 2026-03-20 14:15 by 星空星月
[考研] 招收调剂硕士 +4 lidianxing 2026-03-19 12/600 2026-03-20 12:25 by lidianxing
[考研] 一志愿苏州大学材料求调剂,总分315(英一) +3 sbdksD 2026-03-19 3/150 2026-03-19 23:21 by fmesaito
[考研] 294求调剂材料与化工专硕 +14 陌の森林 2026-03-18 14/700 2026-03-19 22:38 by 学员8dgXkO
[考研] 288求调剂,一志愿华南理工大学071005 +5 ioodiiij 2026-03-17 5/250 2026-03-19 18:22 by zcl123
[考研] 一志愿天津大学化学工艺专业(081702)315分求调剂 +11 yangfz 2026-03-17 11/550 2026-03-19 15:06 by houyaoxu
[考研] 085600材料与化工求调剂 +6 绪幸与子 2026-03-17 6/300 2026-03-19 13:27 by houyaoxu
[考研] 化学工程321分求调剂 +15 大米饭! 2026-03-15 18/900 2026-03-18 14:52 by haxia
[考研] 311求调剂 +6 26研0 2026-03-15 6/300 2026-03-18 14:43 by haxia
[考研] 299求调剂 +5 △小透明* 2026-03-17 5/250 2026-03-18 11:49 by 尽舜尧1
[考研] 301求调剂 +9 yy要上岸呀 2026-03-17 9/450 2026-03-18 08:58 by 无际的草原
[考研] 考研化学学硕调剂,一志愿985 +4 张vvvv 2026-03-15 6/300 2026-03-17 17:15 by ruiyingmiao
[考研] 材料专硕326求调剂 +6 墨煜姒莘 2026-03-15 7/350 2026-03-17 17:10 by ruiyingmiao
[考研] 有没有道铁/土木的想调剂南林,给自己招师弟中~ +3 TqlXswl 2026-03-16 7/350 2026-03-17 15:23 by TqlXswl
[考研] 材料与化工专硕调剂 +5 heming3743 2026-03-16 5/250 2026-03-17 14:03 by 勇敢太监王公公
[考研] 070305求调剂 +3 mlpqaz03 2026-03-14 4/200 2026-03-15 11:04 by peike
[考研] 招收0805(材料)调剂 +3 18595523086 2026-03-13 3/150 2026-03-14 00:33 by 123%、
[考研] 311求调剂 +3 冬十三 2026-03-13 3/150 2026-03-13 20:41 by JourneyLucky
信息提示
请填处理意见