Matlab进阶绘图第30期—冲击图

冲击图是一种特殊的堆叠柱状图

与堆叠柱状图相比,冲击图添加了相邻柱子中相同组分之间的连线,可以更加清晰地表达各组分占比情况

由于Matlab中未收录冲击图的绘制函数,因此需要大家自行解决。

本文使用自制的Fbarstacked小工具进行冲击图的绘制,先来看一下成品效果:

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


1. 数据准备

此部分主要是读取原始数据并初始化绘图参数

复制代码
% 读取数据load data.mat% 初始化绘图参数y = A(:,1:6);

2. 颜色定义

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

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

这里直接使用TheColor配色工具中的SCI权威配色库

复制代码
%% 颜色定义map = TheColor('sci',2064,'map',10);map = flipud(map);C = map([1 2 3 6],1:3);

3. 冲击图绘制

调用'Fbarstacked'命令,绘制初始冲击图

复制代码
GO = Fbarstacked(y,0.4,C,0.7);hTitle = title('Filled stacked bar chart');hXLabel = xlabel('Samples');hYLabel = ylabel('RMSE (m)');

4. 细节优化

为了插图的美观,将初始冲击图坐标区基本参数进行调整

复制代码
% 坐标区基本属性调整set(gca, 'Box', 'off', ...                                         % 边框         'LineWidth', 1, ...                                       % 线宽         'XGrid', 'off', 'YGrid', 'on', ...                        % 网格         'TickDir', 'out', 'TickLength', [.01 .01], ...            % 刻度         'XMinorTick', 'off', 'YMinorTick', 'off', ...             % 小刻度         'XColor', [.1 .1 .1],  'YColor', [.1 .1 .1])              % 坐标轴颜色% 坐标轴刻度调整set(gca, 'YTick', 0:0.3:1.5,...         'Ylim' , [0 1.5], ...         'Xlim' , [0.5 6.5], ...         'XTick', 1:7,...         'Xticklabel',{1:7},...         'Yticklabel',{0:0.3:1.5})% legendhLegend = legend([GO(1),GO(2),GO(3),GO(4)],...         {'A', 'B', 'C', 'D'});% 字体和字号set(gca, 'FontName', 'Arial', 'FontSize', 10)set([hLegend, hXLabel, hYLabel], 'FontName', 'Arial', 'FontSize', 11)set(hTitle, 'FontSize', 12, 'FontWeight' , 'bold')% 背景颜色set(gcf,'Color',[1 1 1])

然后,以期刊所需分辨率、格式输出图片。

复制代码
%% 图片输出exportgraphics(gca,'test.png','Resolution',300)

以上。

相关推荐
码农小韩2 分钟前
基于Linux的C++学习——动态数组容器vector
linux·c语言·开发语言·数据结构·c++·单片机·学习
木风小助理3 分钟前
`mapfile`命令详解:Bash中高效的文本至数组转换工具
开发语言·chrome·bash
yyy(十一月限定版)12 分钟前
初始matlab
开发语言·matlab
LawrenceLan13 分钟前
Flutter 零基础入门(九):构造函数、命名构造函数与 this 关键字
开发语言·flutter·dart
listhi52013 分钟前
基于MATLAB的支持向量机(SVM)医学图像分割方法
开发语言·matlab
hui函数18 分钟前
如何解决 pip install 编译报错 g++: command not found(缺少 C++ 编译器)问题
开发语言·c++·pip
Tisfy27 分钟前
网站访问耗时优化 - 从数十秒到几百毫秒的“零成本”优化过程
服务器·开发语言·性能优化·php·网站·建站
济61734 分钟前
嵌入式C语言(第一期)
c语言·开发语言
XiaoHu020735 分钟前
Linux多线程(详细全解)
linux·运维·服务器·开发语言·c++·git
苏宸啊1 小时前
C++(二)类和对象上篇
开发语言·c++