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)

以上。

相关推荐
大尚来也8 分钟前
深入HashMap底层:从JDK1.7到1.8的架构演进与性能突围
开发语言
森林里的程序猿猿1 小时前
并发设计模式
java·开发语言·jvm
222you1 小时前
四个主要的函数式接口
java·开发语言
smchaopiao2 小时前
Python中字典与列表合并的问题与解决方法
开发语言·python
敲代码的瓦龙2 小时前
Java?面向对象三大特性!!!
java·开发语言
2501_921649492 小时前
期货 Tick 级数据与基金净值历史数据 API 接口详解
开发语言·后端·python·websocket·金融·区块链
野犬寒鸦3 小时前
Redis复习记录day1
服务器·开发语言·数据库·redis·缓存
小菜鸡桃蛋狗3 小时前
C++——类和对象(下)
开发语言·c++
骑龙赶鸭3 小时前
java开发项目中遇到的难点,面试!
java·开发语言·面试