当前位置: 首页 > article >正文

Matplotlib子图标注神器:用transAxes实现跨图统一位置标注(附完整代码)

Matplotlib子图标注神器用transAxes实现跨图统一位置标注附完整代码当我们需要在多个子图中展示不同范围的数据时经常会遇到一个棘手的问题如何在每个子图的相同相对位置添加标注比如在2x3的子图矩阵中每个子图的x轴和y轴范围各不相同但我们希望在每个子图的左上角1/5处添加相同的说明文字。这时候transformax.transAxes参数就是你的救星。1. 为什么需要transAxes在Matplotlib中默认的坐标系统是基于数据范围的。这意味着如果你在(1,1)位置添加文本在不同数据范围的子图中这个文本会出现在完全不同的相对位置。而transAxes转换器允许我们使用相对于子图本身的坐标系统其中(0,0)表示子图的左下角(1,1)表示右上角。传统标注方法的局限性依赖绝对数据坐标在不同范围的子图中位置不一致需要为每个子图单独计算位置# 传统方法 - 依赖数据坐标 ax.text(1.5, 4.5, 标注文本) # 在不同范围的子图中位置会变化2. transAxes的核心原理transAxes是Matplotlib转换系统的一部分它建立了从轴坐标0到1的范围到显示坐标的映射。这种转换独立于数据范围使得标注可以固定在子图的特定相对位置。关键特性对比转换类型坐标范围独立性适用场景data数据范围依赖数据数据点标注axes0-1独立固定位置标注figure0-1独立跨子图标注提示transAxes与transFigure的区别在于参考系不同 - transAxes相对于单个子图而transFigure相对于整个图形。3. 实战多子图统一标注让我们通过一个完整的例子来演示如何使用transAxes实现跨子图的统一标注。假设我们有一个2x3的子图矩阵每个子图展示不同范围的数据。import matplotlib.pyplot as plt import numpy as np # 创建2x3子图 fig, axes plt.subplots(2, 3, figsize(12, 8)) fig.suptitle(跨子图统一标注演示, fontsize16) # 为每个子图设置不同的数据范围 x_ranges [(1,2), (2,3), (3,4), (4,5), (5,6), (6,7)] y_ranges [(4,5), (5,6), (6,7), (1,2), (2,3), (3,4)] # 生成并绘制数据 for i, ax in enumerate(axes.flat): # 设置坐标轴范围 ax.set_xlim(x_ranges[i]) ax.set_ylim(y_ranges[i]) # 生成一些随机数据 x np.linspace(*x_ranges[i], 50) y np.sin(x) * (y_ranges[i][1] - y_ranges[i][0])/2 (y_ranges[i][0] y_ranges[i][1])/2 ax.plot(x, y, b-) # 使用transAxes添加统一位置的标注 ax.text(0.05, 0.95, f子图{i1}, transformax.transAxes, verticalalignmenttop, bboxdict(boxstyleround, facecolorwhite, alpha0.8)) # 在相同相对位置添加数据统计信息 ax.text(0.5, 0.1, f均值: {np.mean(y):.2f}, transformax.transAxes, horizontalalignmentcenter, bboxdict(boxstyleround, facecoloryellow, alpha0.5)) plt.tight_layout() plt.show()代码解析我们创建了2行3列的子图矩阵为每个子图设置了不同的x和y轴范围使用transformax.transAxes参数确保文本标注位于每个子图的相同相对位置第一个标注位于(0.05,0.95) - 靠近左上角第二个标注位于(0.5,0.1) - 底部中央4. 高级应用技巧掌握了基本用法后我们来看几个transAxes的高级应用场景。4.1 组合使用不同转换有时候我们需要在同一个标注中组合使用不同的坐标系统。例如x轴使用数据坐标y轴使用相对坐标from matplotlib.transforms import blended_transform_factory # 创建混合转换 transform blended_transform_factory(ax.transData, ax.transAxes) ax.text(3.5, 0.9, 特定x位置固定y相对位置, transformtransform, hacenter)4.2 创建统一的图例位置当子图数据范围差异很大时传统的图例位置可能不理想。使用transAxes可以确保图例在每个子图的相同相对位置for ax in axes.flat: ax.plot(x, y, label正弦波) ax.legend(locupper right, bbox_to_anchor(0.95, 0.95), transformax.transAxes)4.3 添加跨子图的参考线虽然transAxes主要用于单个子图内但结合transFigure可以实现跨子图的统一元素# 添加贯穿所有子图的水平参考线 for ax in axes.flat: ax.axhline(y0.5, colorgray, linestyle--, transformax.transAxes, alpha0.5)实用技巧列表使用horizontalalignment和verticalalignment参数精确控制文本对齐结合bbox参数为标注添加背景框提升可读性对于复杂布局先用ax.get_position()检查子图实际占用的空间比例调试时设置transformNone可以快速查看数据坐标下的位置5. 常见问题与解决方案在实际使用transAxes时可能会遇到一些典型问题这里提供解决方案。问题1标注出现在预期之外的位置可能原因忘记设置transform参数混淆了transAxes和transData坐标解决方案# 错误忘记transform参数 ax.text(0.1, 0.1, 标注) # 使用数据坐标 # 正确明确指定transform ax.text(0.1, 0.1, 标注, transformax.transAxes)问题2标注在保存图片时位置偏移可能原因图形边缘被裁剪DPI设置影响布局解决方案# 保存时使用bbox_inchestight防止裁剪 plt.savefig(output.png, dpi300, bbox_inchestight)问题3标注在交互式缩放时位置不变期望行为transAxes标注应随子图一起缩放移动如果希望标注保持固定屏幕位置应使用transFigure解决方案# 使用transFigure保持固定屏幕位置 ax.text(0.1, 0.1, 固定位置标注, transformfig.transFigure)6. 性能优化与最佳实践当需要在大量子图中添加标注时遵循这些最佳实践可以提升性能和可维护性。标注样式统一管理# 定义标注样式字典 label_style { transform: ax.transAxes, fontsize: 10, bbox: dict(boxstyleround, facecolorwhite, alpha0.8), verticalalignment: top } # 应用统一样式 ax.text(0.05, 0.95, 统一样式标注, **label_style)批量处理子图标注# 使用函数封装标注逻辑 def add_standard_labels(ax, text, pos(0.05, 0.95)): ax.text(*pos, text, transformax.transAxes, vatop, haleft, fontsize9) # 批量应用 for i, ax in enumerate(axes.flat): add_standard_labels(ax, fPanel {i1})性能对比表格方法执行时间(1000次)内存占用适用场景直接循环添加120ms较低简单标注使用Text对象150ms中等需要后续修改批量工厂方法90ms较低大量相同样式标注# 最高效的批量标注方法 texts [ax.text(0.1, 0.1, str(i), transformax.transAxes) for i, ax in enumerate(axes.flat)]7. 实际案例科研论文多面板图在科研论文中经常需要创建包含多个面板的复合图每个面板展示不同范围的数据但需要统一的标注风格。以下是一个真实案例的实现# 创建4面板科研图 fig, axes plt.subplots(2, 2, figsize(10, 10)) # 面板A: 原始数据 axes[0,0].plot(raw_data_x, raw_data_y) axes[0,0].text(0.05, 0.95, A, transformaxes[0,0].transAxes, fontsize14, weightbold) # 面板B: 拟合结果 axes[0,1].plot(fit_x, fit_y) axes[0,1].text(0.05, 0.95, B, transformaxes[0,1].transAxes, fontsize14, weightbold) # 面板C: 残差分析 axes[1,0].scatter(resid_x, resid_y) axes[1,0].text(0.05, 0.95, C, transformaxes[1,0].transAxes, fontsize14, weightbold) # 面板D: 模型比较 axes[1,1].bar(model_names, model_scores) axes[1,1].text(0.05, 0.95, D, transformaxes[1,1].transAxes, fontsize14, weightbold) # 添加跨面板的共用标签 fig.text(0.5, 0.04, Common X-axis Label, hacenter, vacenter, fontsize12) fig.text(0.04, 0.5, Common Y-axis Label, hacenter, vacenter, rotationvertical, fontsize12) plt.tight_layout()在这个案例中transAxes确保了每个面板的标签A、B、C、D都出现在相同相对位置无论各面板的数据范围如何不同。同时使用fig.text添加了跨面板的共用坐标轴标签。

相关文章:

Matplotlib子图标注神器:用transAxes实现跨图统一位置标注(附完整代码)

Matplotlib子图标注神器:用transAxes实现跨图统一位置标注(附完整代码) 当我们需要在多个子图中展示不同范围的数据时,经常会遇到一个棘手的问题:如何在每个子图的相同相对位置添加标注?比如在2x3的子图矩阵…...

SDXL-Turbo实战案例:插画师用实时反馈优化线稿→上色→特效全流程

SDXL-Turbo实战案例:插画师用实时反馈优化线稿→上色→特效全流程 1. 开篇:重新定义AI绘画工作流 作为一名插画师,你是否曾经遇到过这样的困扰:脑海中有一个绝妙的创意,但在AI绘画工具中输入提示词后,需要…...

DDR5内存调优实战:手把手教你用MRW/MRR命令配置模式寄存器

DDR5内存调优实战:模式寄存器配置与信号完整性优化 当DDR5内存以6400MT/s的速率运行时,每个数据位的传输窗口仅有0.156纳秒。在这个比光传播50厘米所需时间还短的瞬间里,任何信号完整性问题都可能导致灾难性的误码。这就是为什么现代DDR5系统…...

【小白量化智能体】实战:从通达信指标到Python可视化分析的自动化实现

1. 为什么需要量化智能体? 刚接触量化交易的朋友们经常会遇到这样的困扰:看到通达信里各种炫酷的技术指标,想自己动手改一改或者组合创新,但面对复杂的公式语法总是无从下手。好不容易写出来一个指标,想用Python做更深…...

对比评测:BEYOND REALITY Z-Image如何让AI人像拥有摄影级质感?

对比评测:BEYOND REALITY Z-Image如何让AI人像拥有摄影级质感? 1. 评测背景与模型介绍 在AI图像生成领域,写实人像一直是最具挑战性的任务之一。传统模型往往难以平衡生成速度与画面质量,直到BEYOND REALITY Z-Image的出现改变了…...

使用Dify快速搭建DeOldify图像上色AI应用工作流

使用Dify快速搭建DeOldify图像上色AI应用工作流 你是不是也翻出过家里的老照片,看着那些泛黄、褪色的影像,想象着它们原本的色彩?或者,作为一个内容创作者,手头有一些黑白素材,却苦于没有专业工具或技能去…...

从零开始理解IEC104协议:电力系统通信的底层逻辑与报文解析

从零开始理解IEC104协议:电力系统通信的底层逻辑与报文解析 在数字化电力系统的架构中,通信协议如同神经网络般连接着各类自动化设备。当变电站的遥测数据需要实时上传,或调度中心发出远程控制指令时,IEC104协议便是确保这些关键信…...

GitHub中文化插件:打破语言障碍,让全球最大开发者社区说你的母语

GitHub中文化插件:打破语言障碍,让全球最大开发者社区说你的母语 【免费下载链接】github-chinese GitHub 汉化插件,GitHub 中文化界面。 (GitHub Translation To Chinese) 项目地址: https://gitcode.com/gh_mirrors/gi/github-chinese …...

手把手教你用W25Qxx Flash芯片存储数据(附SPI配置避坑指南)

嵌入式开发实战:W25Qxx Flash芯片SPI存储全解析与避坑指南 在嵌入式系统开发中,外部存储扩展是提升设备数据能力的核心环节。W25Qxx系列SPI Flash以其高性价比、低功耗和易用性,成为众多开发者的首选。但初次接触这类存储芯片时,不…...

基于CODESYS平台的S7客户端与西门子PLC通讯源码

基于CODESYS平台的S7客户端与西门子PLC通讯源码工业现场的数据通讯就像车间里的八卦,设备之间总得互相传点悄悄话。今天咱们聊聊CODESYS平台下用C语言搞S7协议通讯的黑科技——别看西门子PLC平时一副高冷样,其实撩拨起来也没那么难。先甩段硬核代码镇楼&…...

探索Avalonia跨平台UI框架:构建现代化多媒体应用的核心实践

探索Avalonia跨平台UI框架:构建现代化多媒体应用的核心实践 【免费下载链接】Avalonia AvaloniaUI/Avalonia: 是一个用于 .NET 平台的跨平台 UI 框架,支持 Windows、macOS 和 Linux。适合对 .NET 开发、跨平台开发以及想要使用现代的 UI 框架的开发者。 …...

如何按作者检索论文?找领域大佬必会

当你刚进入一个研究领域时,最常见的检索方式往往是从关键词开始。打开数据库,输入研究主题,然后下载几十篇甚至上百篇论文,看起来文献已经积累了不少。但随着阅读逐渐深入,你很快会发现一个现象:有些作者的…...

MATLAB四旋翼无人机自适应控制仿真(Simulink和Simscape,支持SolidWo...

MATLAB四旋翼自适应控制仿真simulink simscape,可更换成自己的无人机solidworks模型 有公式手册需MATLAB2017版本以上刚拆完快递的周末下午最适合折腾无人机仿真了。最近在MATLAB里搞了个四旋翼自适应控制的活儿,用Simscape Multibody把SolidWorks建的模…...

2026 转行网络安全必看!真实网安职场全景解析,小白收藏这篇就够了

26年想转行网络安全?一篇带你了解真实的网安职场! 最近是不是经常刷到网络安全相关的内容?看着别人做渗透测试、参加CTF比赛,觉得这行挺酷,薪资也不错,心里痒痒的想转行?别急,今天咱…...

ai赋能图像处理:基于快马平台调用模型,实现photoshop高级智能抠图功能

作为一名经常和图像处理打交道的开发者,我深知要实现一个像Photoshop那样精准的智能抠图功能有多复杂。它不仅需要对图形学有深入理解,还要处理各种边缘细节和复杂背景。不过,最近我发现了一个新思路:借助AI模型的力量&#xff0c…...

深入解析arping与arp命令:高效检测IP冲突与MAC地址查询实战

1. 网络地址冲突的隐形杀手与排查利器 刚入行做运维那会儿,我遇到过最诡异的网络故障——办公室某台电脑突然无法上网,重启后恢复正常,但过段时间又断线。折腾了半天才发现,原来是行政部新装的打印机偷偷占用了同事电脑的IP地址。…...

如何在Netty客户端实现断线自动重连

channelInactive 由于底层资源没有完全释放,不能立即重新连接,需要等待 closeFuture 完成或延迟后 connect;推荐用 HashedWheelTimer 实现指数退出重连,确保 Bootstrap 配置一致,分类处理异常,心跳保存。ch…...

MATLAB伪彩色增强实战:5分钟搞定医学图像分析(附完整代码)

MATLAB伪彩色增强实战:5分钟搞定医学图像分析(附完整代码) 在医学影像诊断领域,X光片、CT扫描等灰度图像往往包含大量难以肉眼识别的细节差异。传统灰度图像中,不同组织可能仅存在几个灰度级的微小差别,而这…...

OpenFOAM实战:snappyHexMesh网格划分避坑指南(附参数优化技巧)

OpenFOAM实战:snappyHexMesh网格划分避坑指南(附参数优化技巧) 在计算流体力学(CFD)领域,网格质量往往直接决定仿真结果的可靠性和计算效率。对于使用OpenFOAM的工程师来说,snappyHexMesh作为其…...

PAT 乙级 1060

本题要先从大到小排个序。再逐个比较天数和骑行公里数。但有一个坑&#xff0c;如果全部公里数都大于全部天数&#xff0c;那 for 循环不会输出东西。所以要加一步&#xff0c;输出全部天数。#include<bits/stdc.h> using namespace std;bool cmp(int a, int b) {return …...

Evidence企业实践:构建数据驱动智能决策的四象限实施指南

Evidence企业实践&#xff1a;构建数据驱动智能决策的四象限实施指南 【免费下载链接】evidence evidence - 这是一个 Web 归档工具&#xff0c;可以将网页内容转换为结构化数据。适用于 Web 存档、数据挖掘、信息处理等场景。特点包括支持多种格式、自定义处理规则、可扩展性。…...

Qwen3在重装系统后快速恢复AI开发环境的实战教程

Qwen3在重装系统后快速恢复AI开发环境的实战教程 重装系统&#xff0c;对开发者来说&#xff0c;就像一次“数字搬家”。看着空空如也的桌面和命令行&#xff0c;那种熟悉的开发环境、配置好的工具链、调试顺畅的模型服务全都消失不见&#xff0c;要一点点重新搭建&#xff0c…...

NLnet Labs NSD:高性能权威DNS服务器的技术解析与实践指南

NLnet Labs NSD&#xff1a;高性能权威DNS服务器的技术解析与实践指南 【免费下载链接】nsd The NLnet Labs Name Server Daemon (NSD) is an authoritative, RFC compliant DNS nameserver. 项目地址: https://gitcode.com/gh_mirrors/ns/nsd 为何选择NSD&#xff1f;揭…...

Python实战:5分钟搞定TF-IDF文本向量化(附完整代码)

Python实战&#xff1a;5分钟搞定TF-IDF文本向量化&#xff08;附完整代码&#xff09; 在自然语言处理领域&#xff0c;文本向量化是让计算机理解人类语言的关键一步。而TF-IDF算法&#xff0c;作为文本挖掘中最经典的特征提取方法之一&#xff0c;以其简单高效的特点&#xf…...

ngx_shmtx_create

1. 定义 ngx_shmtx_create 函数 定义在 ./nginx-1.24.0/src/core/ngx_shmtx.cngx_int_t ngx_shmtx_create(ngx_shmtx_t *mtx, ngx_shmtx_sh_t *addr, u_char *name) { mtx->lock &addr->lock;if (mtx->spin (ngx_uint_t) -1) {return NGX_OK;}mtx->spin 204…...

Bladed实战:如何用湍流风文件完成动态发电仿真(含样本文件下载)

Bladed高阶实战&#xff1a;湍流风动态发电仿真全流程解析与异常排查指南 当风电工程师完成基础建模后&#xff0c;真正的挑战往往来自动态仿真阶段。去年参与某3MW海上机组认证项目时&#xff0c;我们团队在湍流风发电仿真环节连续三次出现功率输出异常波动&#xff0c;最终发…...

开源项目AGENTS.md开发效率提升指南:多包管理快速上手与避坑指南

开源项目AGENTS.md开发效率提升指南&#xff1a;多包管理快速上手与避坑指南 【免费下载链接】agents.md AGENTS.md — a simple, open format for guiding coding agents 项目地址: https://gitcode.com/GitHub_Trending/ag/agents.md AGENTS.md作为一款被超过60,000个…...

探索xManager:开源音乐管理工具的全新体验

探索xManager&#xff1a;开源音乐管理工具的全新体验 【免费下载链接】xManager Ad-Free, New Features & Freedom 项目地址: https://gitcode.com/GitHub_Trending/xm/xManager 你是否曾在使用音乐应用时被频繁的广告打断沉浸式体验&#xff1f;是否因应用体积臃肿…...

动态顺序表(二)

一、顺序表&#xff1a;检查容量并扩容1. 1头文件&#xff1a;SeqList.h作用&#xff1a;定义结构体和所有函数的“接口”。代码如下&#xff1a;#pragma once #include<stdio.h> #include<stdlib.h> #include<assert.h> typedef int SLDataType; typedef st…...

eNSP无线网络实战:AC/AP二层旁路组网从零搭建与毕业设计应用

1. 初识eNSP无线网络实战环境 第一次接触eNSP模拟器时&#xff0c;我就被它强大的网络仿真能力惊艳到了。作为华为官方推出的企业网络仿真平台&#xff0c;eNSP能完美模拟真实网络设备&#xff0c;特别适合我们这些需要练习AC/AP组网但又没有实体设备的学生党。记得当时为了完成…...