24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 2217  |  回复: 1

杨小胖

金虫 (正式写手)

[求助] matlab曲线拟合 basic fitting 与polyfit

想请高手帮忙改个代码。
其实基本实现了,但怎么越改越乱。
问题
<1>我不知道怎么在图中把拟合的公式显示出来。
<2>当我只用一组数据时直接在命令窗口输入,那如果我有很多组这样的数据,那要怎么改呢?
x=[ 10.5  13  13.8  16  18  19 20.8];
y=[1190  1040 1000 800 600 430 200];
<3>为什么这样拟合出来的结果是曲线,但如果通过普通的polyfit拟合,出来是折线?


想要实现的是设置不一样的拟合次数,将拟合的系数都显示出来,并在每一个拟合系数求出来以后把表达式显示出来。

这是我从matlab宝典一书中找到的代码。
CODE:
function [th,err,yi]=polyfits(x,y,N,xi,r)
%x,y  :数据点系列
%N    :多项式拟合的系统
%r    :加权系数的逆矩阵

M=length(x);
x=x(:);
y=y(:);

%判断调用函数的格式,考虑权阵
if nargin==4
%当用户调用函数格式为(x,y,N,r)
    if length(xi)==M
        r=xi;
        xi=x;
%当用户调用函数格式为(x,y,N, xi),权阵为1
    else r=1;
    end
%当用户调用函数格式为(x,y,N),不考虑权阵
elseif nargin==3
    xi=x;
    r=1;
end
%求解系数矩阵
A(:,N+1)=ones(M,1);
for n=N:-1:1
    A(:,n)=A(:,n+1).*x;
end

if length(r)==M
    for m=1:M
        A(m,:)=A(m,:)/r(m);
        y(m)=y(m)/r(m);
    end
end

%计算拟合系数
th=(A\y)';
ye=polyval(th,x);
err=norm(y-ye)/norm(y);
yi=polyval(th,xi);

CODE:
clear;
clf;
x=input('请输入x值:');
y=input('请输入y值:');
% x=[ 10.5  13  13.8  16  18  19 20.8];
% y=[1190  1040 1000 800 600 430 200];
% eb=[0.2*ones(5,1);ones(5,1)];
[x,i]=sort(x);
y=y(i);
xi=min(x)+[0:100]/100*(max(x)-min(x));
for i=1:4
N=2*i-1;
[th,err1,yi]=polyfits(x,y,N,xi);
  subplot(220+i);
plot(x,y,'k*')
hold on
plot(xi,yi,'g:','LineWidth',1.5)
title(['The ',num2str(N),'th Polynomial Curve Fitting'])
grid on
end

用的是这组数据
x=[ 10.5  13  13.8  16  18  19 20.8];
y=[1190  1040 1000 800 600 430 200];

运行结果


[ Last edited by 杨小胖 on 2011-6-15 at 16:26 ]
回复此楼

» 猜你喜欢

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

人生中最辉煌的不是功成名就的时候,而是在失败和挫折中看到希望并为之奋斗的日子
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

杨小胖

金虫 (正式写手)

人生中最辉煌的不是功成名就的时候,而是在失败和挫折中看到希望并为之奋斗的日子
2楼2011-06-15 19:06:31
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 杨小胖 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 070300化学354求调剂 +6 101次希望 2026-03-28 6/300 2026-03-29 12:57 by 无际的草原
[考研] 求调剂,一志愿 南京航空航天大学 ,080500材料科学与工程学硕,总分289分 +7 @taotao 2026-03-29 7/350 2026-03-29 12:03 by longlotian
[考研] 一志愿北化求调剂 +4 Jsman 2026-03-22 4/200 2026-03-29 10:50 by 唐沐儿
[考研] 085600,专业课化工原理,321分求调剂 +5 大馋小子 2026-03-28 5/250 2026-03-29 08:56 by qingfeng258
[考研] 调剂考研 +3 王杰一 2026-03-29 3/150 2026-03-29 08:09 by fmesaito
[考研] 一志愿北化085600材料专硕275|有文章专利|求调剂 +7 Micky11223 2026-03-25 7/350 2026-03-28 18:34 by 无际的草原
[考研] 一志愿华北电力大学能动专硕,293,求调剂 +3 15537177284 2026-03-23 5/250 2026-03-28 16:11 by xxxsssccc
[考研] 277跪求调剂 +5 1915668 2026-03-27 9/450 2026-03-28 09:58 by zhshch
[考研] 085601 材料工程 313分 求调剂 +5 Ong3 2026-03-27 5/250 2026-03-27 12:24 by goldfish51
[考研] 求调剂 +3 刘柯@ 2026-03-24 4/200 2026-03-27 11:28 by shangxh
[考研] 考研调剂 +9 小蜡新笔 2026-03-26 9/450 2026-03-27 11:10 by 不吃魚的貓
[考研] 求调剂 一志愿 本科 北科大 化学 343 +6 13831862839 2026-03-24 7/350 2026-03-26 22:57 by 不吃魚的貓
[考研] 一志愿上海交大生物与医药专硕324分,求调剂 +6 jiajunX 2026-03-22 6/300 2026-03-25 23:05 by licg0208
[考研] 一志愿哈工大,085400,320,求调剂 +4 gdlf9999 2026-03-24 4/200 2026-03-25 23:01 by boxking200
[考研] 【2026考研调剂】制药工程 284分 求相关专业调剂名额 +4 袁奂奂 2026-03-25 8/400 2026-03-25 14:32 by lbsjt
[考研] 各位老师您好:本人初试372分 +5 jj涌77 2026-03-25 6/300 2026-03-25 14:15 by mapenggao
[考研] 一志愿北化315 求调剂 +3 akrrain 2026-03-24 3/150 2026-03-24 19:35 by 了了了了。。
[考研] 一志愿吉大化学322求调剂 +4 17501029541 2026-03-23 6/300 2026-03-24 10:21 by 戴围脖的小蚊子
[考研] 333求调剂 +3 ALULU4408 2026-03-23 3/150 2026-03-23 19:04 by macy2011
[考研] 328求调剂 +4 LHHL66 2026-03-23 4/200 2026-03-23 14:55 by lbsjt
信息提示
请填处理意见