Matlab论文插图绘制模板第69期—带误差棒的折线图(Errorbar)

在之前的文章中,分享了一系列Matlab折线图的绘制模板:

这一次,再来分享一种特殊的折线图:带误差棒的折线图

先来看一下成品效果:

特别提示:Matlab论文插图绘制模板系列,旨在降低大家使用Matlab进行科研绘图的门槛,只需按照模板格式添加相应内容,即可得到满足大部分期刊以及学位论文格式要求的数据插图。如果觉得有用可以分享给你的朋友


模板中最关键的部分内容

1. 数据准备

此部分主要是读取原始数据,定义自变量和因变量

% 读取数据% 自变量x = 0:10:50;% 因变量y = [0 08 15 25 30 32     0 01 03 05 12 25     0 15 22 36 38 42];err = [0.1 1.7 2.6 3.2 2.5 3.2       0.2 1.8 3.0 2.5 3.5 2.2       0.1 2.0 2.5 2.2 2.8 2.2];

2. 颜色定义

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

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

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

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

3. 带误差棒的折线图绘制

使用‘errorbar’命令,绘制未经美化的带误差棒的折线图

E1 = errorbar(x,y(1,:),err(1,:));E2 = errorbar(x,y(2,:),err(2,:));E3 = errorbar(x,y(3,:),err(3,:));hTitle = title('Errorbar Plot');hXLabel = xlabel('XAxis');hYLabel = ylabel('YAxis');

4. 细节优化

为了插图的美观,将误差棒图赋上之前选择的颜色并进一步调整线属性细节

% 线属性调整set(E1,  'LineStyle', '-', 'Color', C1,...         'LineWidth', 3, 'Marker', 'o', 'MarkerSize', 8, ...         'MarkerEdgeColor', [.2 .2 .2], 'MarkerFaceColor' , C1)set(E2,  'LineStyle', '-', 'Color', C2,...         'LineWidth', 3, 'Marker', 'o', 'MarkerSize', 8, ...         'MarkerEdgeColor', [.2 .2 .2], 'MarkerFaceColor' , C2)set(E3,  'LineStyle', '-', 'Color', C3,...         'LineWidth', 3, 'Marker', 'o', 'MarkerSize', 8, ...         'MarkerEdgeColor', [.2 .2 .2], 'MarkerFaceColor' , C3)

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

% 坐标轴美化set(gca, 'Box', 'off', ...                                 % 边框         'LineWidth',1,...                                 % 线宽         'XGrid', 'off', 'YGrid', 'on', ...                % 网格         'TickDir', 'out', 'TickLength', [.015 .015], ...  % 刻度         'XMinorTick', 'off', 'YMinorTick', 'off', ...     % 小刻度         'XColor', [.1 .1 .1],  'YColor', [.1 .1 .1],...   % 坐标轴颜色         'XTick', 0:10:50,...                              % 坐标轴刻度         'XLim', [-2 52],...         'YTick', 0:10:70,...         'YLim', [-5 50])% 添加上、右框线XL = get(gca,'xlim'); XR = XL(2);YL = get(gca,'ylim'); YT = YL(2);xc = get(gca,'XColor');yc = get(gca,'YColor');plot(XL,YT*ones(size(XL)),'color', xc,'linewidth',1)plot(XR*ones(size(YL)),YL,'color', yc,'linewidth',1)% 添加图例hLegend = legend([E1,E2,E3], ...                 'Samp1', 'Samp2','Samp3', ...                 'Location', 'northwest');P = hLegend.Position;hLegend.Position = P + [0.015 -0.05 0 0.05];% 字体和字号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])

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

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

以上。

完整代码:

Matlab带误差棒的折线图

  • 5
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值