Matlab论文插图绘制模板第94期—带置信区间的折线散点图

在之前的文章中,分享了很多Matlab带置信区间的折线图的绘制模板:

进一步,再来分享一下带置信区间的折线散点图的绘制模板。

先来看一下成品效果:

特别提示:本期内容『数据+代码』已上传资源群中,加群的朋友请自行下载。有需要的朋友可以关注同名公号【阿昆的科研日常】,后台回复关键词【绘图桶】查看加入方式


模板中最关键的部分内容

1. 数据准备

此部分主要是读取原始数据

% 读取数据load data.mat

2. 颜色定义

作图不配色就好比做菜不放盐,总让人感觉少些味道。

但颜色搭配比较考验个人审美,需要多加尝试。

这里直接使用TheColor配色工具中的XKCD配色库

%% 颜色定义C = TheColor('xkcd',[426 627]);C1 = C(1,1:3);C2 = C(2,1:3);

3. 带置信区间的折线散点图绘制

使用‘fill’、‘line’和‘scatter’命令,绘制初始带置信区间的折线散点图

P1 = fill([xconfu1,xconfd1],[yconfu1,yconfd1],C1);P2 = fill([xconfu2,xconfd2],[yconfu2,yconfd2],C2);L1 = line(x,y11);L2 = line(x,y22);S1 = scatter(x,y1,40,'filled');S2 = scatter(x,y2,40,'filled');hTitle = title('Line-Scatter Chart with Confidence Interval');hXLabel = xlabel('GlobBiomass AGB');hYLabel = ylabel('AGB');

4. 细节优化

为了插图的美观,将初始带置信区间的折线散点图赋上之前选择的颜色并对一些属性进行调整

% 赋色及属性调整set(P1,'FaceColor',[0.5 0.5 0.5],'FaceAlpha',0.2,'EdgeColor','none')set(P2,'FaceColor',[0.5 0.5 0.5],'FaceAlpha',0.2,'EdgeColor','none')set(L1,'LineStyle','-','LineWidth',3, 'Color',C1)set(L2,'LineStyle','-','LineWidth',3, 'Color',C2)set(S1,'MarkerFaceColor',C1,'MarkerEdgeColor','none')set(S2,'MarkerFaceColor',C2,'MarkerEdgeColor','none')

然后,对坐标轴细节等进行美化:

% 坐标区调整set(gca, 'Box', 'off', ...                                % 边框         'Layer','top',...                                % 图层         'LineWidth',1,...                                % 线宽         'XGrid', 'off', 'YGrid', 'on', ...               % 网格         'TickDir', 'out', 'TickLength', [0.01 0.01], ... % 刻度         'XMinorTick', 'off', 'YMinorTick', 'off', ...    % 小刻度         'XColor', [.1 .1 .1],  'YColor', [.1 .1 .1])     % 坐标轴颜色set(gca, 'XLim',[-0.01 1.01],...         'YLim',[-65 30])% LegendhLegend = legend([S1,S2,L1,L2], ...                 'Data1','Data2','Fit1','Fit2', ...                 'Location', 'southeast',...                 'NumColumns',2);% 字体和字号set(gca, 'FontName', 'Arial', 'FontSize', 10)set([hLegend,hXLabel,hYLabel], 'FontSize', 11, 'FontName', 'Arial')set(hTitle, 'FontSize', 12, 'FontWeight' , 'bold')% 背景颜色set(gcf,'Color',[1 1 1])% 添加上、右框线xc = get(gca,'XColor');yc = get(gca,'YColor');unit = get(gca,'units');ax = axes( 'Units', unit,...           'Position',get(gca,'Position'),...           'XAxisLocation','top',...           'YAxisLocation','right',...           'Color','none',...           'XColor',xc,...           'YColor',yc);set(ax, 'linewidth',1,...        'XTick', [],...        'YTick', []);

设置完毕后,以期刊所需分辨率、格式输出图片。

%% 图片输出figW = figureWidth;figH = figureHeight;set(figureHandle,'PaperUnits',figureUnits);set(figureHandle,'PaperPosition',[0 0 figW figH]);fileout = 'test';print(figureHandle,[fileout,'.png'],'-r300','-dpng');

以上。

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Matlab中,可以使用`fill`、`line`和`scatter`命令来绘制置信区间折线。具体步骤如下: 1. 定义数据,包括x轴和y轴的值,以及置信区间的上下限值。 2. 使用`fill`命令绘制置信区间。例如,对于置信区间1,可以使用以下代码: ```matlab P1 = fill([xconfu1,xconfd1],[yconfu1,yconfd1],C1); ``` 其中,`xconfu1`和`xconfd1`分别表示置信区间1的上下限x值,`yconfu1`和`yconfd1`分别表示置信区间1的上下限y值,`C1`表示置信区间1的颜色。 3. 使用`line`命令绘制折线。例如,对于折线1,可以使用以下代码: ```matlab L1 = line(x,y11); ``` 其中,`x`表示x轴的值,`y11`表示折线1的y轴的值。 4. 使用`scatter`命令绘制点。例如,对于点1,可以使用以下代码: ```matlab S1 = scatter(x,y1,40,'filled'); ``` 其中,`x`表示x轴的值,`y1`表示点1的y轴的值,`40`表示点的大小,`'filled'`表示填充颜色。 5. 添加标题和轴标签。例如,可以使用以下代码添加标题和轴标签: ```matlab hTitle = title('Line-Scatter Chart with Confidence Interval'); hXLabel = xlabel('GlobBiomass AGB'); hYLabel = ylabel('AGB'); ``` 另外,如果只需要绘制置信区间折线,可以使用`fill`和`line`命令。具体步骤如下: 1. 定义数据,包括x轴和y轴的值,以及置信区间的上下限值。 2. 使用`fill`命令绘制置信区间。例如,对于置信区间1,可以使用以下代码: ```matlab P1 = fill(xconf1,yconf1,C1); ``` 其中,`xconf1`和`yconf1`分别表示置信区间1的x轴和y轴的值,`C1`表示置信区间1的颜色。 3. 使用`line`命令绘制折线。例如,对于折线1,可以使用以下代码: ```matlab L1 = line(x1,y1); ``` 其中,`x1`表示x轴的值,`y1`表示折线1的y轴的值。 4. 添加标题和轴标签。例如,可以使用以下代码添加标题和轴标签: ```matlab hTitle=title('LineChartwithConfidence Interval'); hXLabel = xlabel('GlobBiomass AGB'); hYLabel = ylabel('AGB'); ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值