24小时热门版块排行榜    

查看: 1888  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 085600材料与化工 +6 安全上岸! 2026-03-16 6/300 2026-03-20 15:07 by lbsjt
[考研] 295材料求调剂,一志愿武汉理工085601专硕 +4 Charlieyq 2026-03-19 4/200 2026-03-20 14:26 by 无懈可击111
[考研] 一志愿 南京航空航天大学大学 ,080500材料科学与工程学硕 +4 @taotao 2026-03-20 4/200 2026-03-20 10:37 by EBSD
[考研] 求调剂 +3 暗涌afhb 2026-03-16 3/150 2026-03-20 00:28 by 河南大学校友
[论文投稿] 申请回稿延期一个月,编辑同意了。但系统上的时间没变,给编辑又写邮件了,没回复 10+3 wangf9518 2026-03-17 4/200 2026-03-19 23:55 by babero
[考研] 0703化学调剂 ,六级已过,有科研经历 +12 曦熙兮 2026-03-15 12/600 2026-03-19 19:42 by maocaozhuxi
[考博] 东华理工大学化材专业26届硕士博士申请 +8 zlingli 2026-03-13 8/400 2026-03-19 16:32 by 轻松不少随
[考研] 0703化学调剂 +5 pupcoco 2026-03-17 8/400 2026-03-19 13:58 by houyaoxu
[考研] 311求调剂 +4 冬十三 2026-03-18 4/200 2026-03-18 21:47 by 尽舜尧1
[考研] 085601专硕,总分342求调剂,地区不限 +5 share_joy 2026-03-16 5/250 2026-03-18 14:48 by haxia
[考研] 收复试调剂生 +4 雨后秋荷 2026-03-18 4/200 2026-03-18 14:16 by elevennnne
[考研] 070300化学319求调剂 +6 锦鲤0909 2026-03-17 6/300 2026-03-18 13:22 by Iveryant
[考研] 0854,计算机类招收调剂 +3 胡辣汤放糖 2026-03-15 6/300 2026-03-18 12:09 by 上岸上岸……..
[考研] 0703化学调剂 +3 妮妮ninicgb 2026-03-17 3/150 2026-03-18 10:29 by macy2011
[考研] 材料专硕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
[考研] 考研调剂 +3 淇ya_~ 2026-03-17 5/250 2026-03-17 09:25 by Winj1e
[考研] 机械专硕325,寻找调剂院校 +3 y9999 2026-03-15 5/250 2026-03-16 19:58 by y9999
[基金申请] 今年的国基金是打分制吗? 50+3 zhanghaozhu 2026-03-14 3/150 2026-03-16 17:07 by 北京莱茵润色
[考研] 招收0805(材料)调剂 +3 18595523086 2026-03-13 3/150 2026-03-14 00:33 by 123%、
信息提示
请填处理意见