24小时热门版块排行榜    

查看: 2212  |  回复: 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的回帖
相关版块跳转 我要订阅楼主 杨小胖 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料专硕326求调剂 +4 墨煜姒莘 2026-03-15 4/200 2026-03-15 11:02 by dyw
[考研] 085601材料工程315分求调剂 +3 yang_0104 2026-03-15 3/150 2026-03-15 10:58 by peike
[考研] 289求调剂 +4 这么名字咋样 2026-03-14 6/300 2026-03-14 18:58 by userper
[考研] 266求调剂 +4 学员97LZgn 2026-03-13 4/200 2026-03-14 08:37 by zhukairuo
[考研] 2026考研调剂+本科延边大学+山东大学+生物化学与分子生物学+有项目经验 +3 ccdsscjy 2026-03-09 6/300 2026-03-14 02:14 by JourneyLucky
[考研] 341求调剂 +4 番茄头--- 2026-03-10 4/200 2026-03-13 23:12 by JourneyLucky
[考研] 材料工程调剂 +9 咪咪空空 2026-03-12 9/450 2026-03-13 22:05 by 星空星月
[考研] 333求调剂 +3 球球古力 2026-03-11 3/150 2026-03-13 21:27 by JourneyLucky
[考研] 301求调剂 +6 Liyouyumairs 2026-03-11 6/300 2026-03-13 20:11 by JourneyLucky
[考研] 求调剂 +7 18880831720 2026-03-11 7/350 2026-03-13 16:10 by JourneyLucky
[考研] 考研调剂 +4 芬达46 2026-03-12 4/200 2026-03-13 16:04 by ruiyingmiao
[考研] 求调剂 +3 程雨杭 2026-03-12 3/150 2026-03-13 15:06 by JourneyLucky
[考研] 304求调剂(085602一志愿985) +12 化工人999 2026-03-09 12/600 2026-03-13 12:02 by JourneyLucky
[考研] 一志愿华中师范071000,325求调剂 +5 RuitingC 2026-03-12 5/250 2026-03-13 10:43 by hyswxzs
[考研] 0856化工原理 +6 z2839474511 2026-03-10 6/300 2026-03-13 10:41 by houyaoxu
[考研] 274求调剂0856材料化工 +12 z2839474511 2026-03-11 13/650 2026-03-13 10:39 by peike
[考研] 求调剂 资源与环境 285 +3 未名考生 2026-03-10 3/150 2026-03-13 10:31 by houyaoxu
[考研] 08食品或轻工求调剂,本科发表3篇sci一区top论文,一志愿南师大食品科学与工程 +3 我是一个兵, 2026-03-10 3/150 2026-03-13 10:21 by Yuyi.
[考研] 大连大学化学专业研究生调剂 +3 琪久. 2026-03-10 8/400 2026-03-11 10:02 by 琪久.
[考研] 298求调剂 +3 Vv呀! 2026-03-10 3/150 2026-03-10 22:40 by 剑诗杜康
信息提示
请填处理意见