Matlab进阶绘图第69期—同步坐标图

同步坐标是指将同一figure上的两个或两个以上的子图,用相同的X轴、Y轴或XY轴表示,以方便同步分析。

话不多说,先来看一下同步坐标图的成品效果:

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


1. 数据准备

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

复制代码
% 读取数据load data.mat

2. 颜色定义

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

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

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

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

3. 同步坐标图绘制

调用'tiledlayout'命令,绘制多个子图

复制代码
%% 同步坐标图绘制t = tiledlayout(2,1);​%% 上图绘制ax1 = nexttile;p = plot(x,dataLine);hYLabel1 = ylabel(ax1,'E (m)');% 细节调整MarkerL = {'v','o','^','s'};for i = 1:4    set(p(i),'LineStyle','-','Marker',MarkerL{i},'LineWidth',2.5,'Color',C(i,1:3))endset(gca,'box','on', ...        'xtick',1:8, ...        'ytick',10:20:60)legend(p,{'S1','S2','S3','S4'}, ...       'Location','southeastoutside');​%% 下图绘制ax2 = nexttile;GO = bar(ax2,x,dataBar,0.6,'stacked','EdgeColor','k');% 细节调整for i = 1:4    GO(i).FaceColor = C(i,1:3);endhYLabel2 = ylabel(ax2,'RMSE (m)');set(gca,'box','on', ...        'xtick',1:8, ...        'ytick',0:0.4:1.2,...        'ylim',[0 1.5])legend(GO,{'S1','S2','S3','S4'}, ...       'Location','southeastoutside');

然后进行坐标同步:

复制代码
%% 同步坐标linkaxes([ax1,ax2],'x');t.TileSpacing = 'none';hTitle = title(t,'Axes Link chart');hXLabel = xlabel(t,'Samples');

4. 细节优化

为了插图的美观,对坐标轴细节等进行美化:

复制代码
% 字体和字号set([ax1,ax2], 'FontName', 'Arial', 'FontSize', 10)set([hXLabel, hYLabel1, hYLabel2], 'FontName', 'Arial', 'FontSize', 11)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');

以上。

相关推荐
想回家的一天2 小时前
ECONNREFUSED ::1:8000 前端代理问题
开发语言
cike_y2 小时前
Mybatis之解析配置优化
java·开发语言·tomcat·mybatis·安全开发
Jay_Franklin3 小时前
SRIM通过python计算dap
开发语言·python
Slow菜鸟3 小时前
Java基础架构设计(三)| 通用响应与异常处理(分布式应用通用方案)
java·开发语言
消失的旧时光-19434 小时前
401 自动刷新 Token 的完整架构设计(Dio 实战版)
开发语言·前端·javascript
wadesir4 小时前
Rust中的条件变量详解(使用Condvar的wait方法实现线程同步)
开发语言·算法·rust
tap.AI4 小时前
RAG系列(二)数据准备与向量索引
开发语言·人工智能
阿蒙Amon4 小时前
C#每日面试题-重写和重载的区别
开发语言·c#
是一个Bug4 小时前
Java基础20道经典面试题(二)
java·开发语言
yugi9878384 小时前
基于MATLAB实现协同过滤电影推荐系统
算法·matlab