Matlab在一张图上绘制多条拟合曲线,曲线颜色自定,显示指定图例

clear all;clc;
x1 = [2,1,2.3,2.2,1.2,2.4];
x2 = [6,7.6,8.6,7.8,6.6,8];
y1 = [10,11.2,13.2,13,12.4,12.7];
y2 = [6.5,6.7,7.8,6.6,8,9];
cftool

调用打开cftool工具箱

(有cftool的代码好像不能设置断点,直接用ctrl+R把后面的代码先注释掉,不然在cftool工具箱里会不显示x1,x2,y1,y2这些数据?)

在X data里面选择要拟合数据的横坐标值,在Y data里面选择要拟合数据的纵坐标值,在右边选择拟合方式。

在文件-Generate Code-导出生成此拟合曲线的函数文件。

function [fitresult, gof,h] = createFit(x1, y1)
%% Fit: 'untitled fit 1'.
[xData, yData] = prepareCurveData( x1, y1 );

% Set up fittype and options.
ft = 'pchipinterp';  %选择拟合方式

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

% Plot fit with data.
h = plot( fitresult,'b-', xData, yData );  %设置曲线颜色等属性

grid on

上面是导出的代码,直接在plot函数绘制拟合曲线时设置曲线的颜色类型等属性,方便区分。

figure
[fitresult1, gof1,h1] = createFit(x1,y1);
hold on
[fitresult2, gof2,h2] = createFit1(x2,y2);
legend([h1([2]),h2([2])],'风速1.2m/s','风速2.3m/s');  %设置图例,对拟合曲线进行注释
xlabel('入射角');
ylabel('后向散射系数');
axis([0 10 0 15]);     %设置坐标范围

调用函数,在设置图例时,通过对hx的指定对拟合曲线进行注释。

(有2个数据,一个是数据点,一个是拟合曲线,所以选择hx[1]是对原始数据点进行注释,选择hx[2]是对拟合曲线进行注释。)

坑点:在cftool生成的函数里,如果去掉这里的xData,yData,即只显示拟合曲线,那么多条曲线绘制在一张图上,坐标会不在输入数值范围内。

h = plot( fitresult, xData, yData );

譬如现在输入x1范围是[1,3],x2范围是[6,9],但是绘制出来的图,横坐标范围是[1,2.4],只是把拟合出来的函数在某段(怎么确定不知)横坐标范围内表示出来,而不是在我们的数据段内的拟合曲线。建议还是把xData,yData加上,然后再通过axis函数设定坐标轴范围,这样出来的曲线更符合要求和期待。

 在一张图上绘制多条拟合曲线参考:如何使用MATLAB在一个图中创建多条拟合曲线的方法_慕亦星河的博客-CSDN博客_matlab多组数据拟合一条曲线

 用legend函数设置指定拟合曲线的图例参考:

matlab画图显示部分曲线显示legend_奔流聚海-CSDN博客_matlab只显示部分图例

  • 7
    点赞
  • 61
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值