科研绘图(八)线性热图

线性热图(Linear Heat Map)是一种数据可视化技术,用于展示数值在一维线性空间上的分布情况。它通常用于展示沿着一条线(例如时间线或任何一维序列)的数据密度或强度变化。线性热图与传统的二维热图不同,后者通常展示在二维平面上的数据分布。在线性热图中,线条的颜色或强度通常表示数据的强度或密度,颜色的变化可以揭示数据的模式或趋势。例如,在时间序列分析中,线性热图可以用来显示某个指标随时间的变化情况。

优点

1. 清晰展示趋势和模式:线性热图能有效地展现数据随时间或其他一维序列变化的趋势和模式。

2. 高效的空间利用:由于其一维性质,线性热图在显示长时间序列或大量数据点时可以节省空间。

3. 直观的颜色编码:通过颜色的变化,用户可以快速理解数据强度或密度的变化。

4. 易于集成:线性热图易于嵌入到表格、图表或地图中,作为辅助的视觉元素。

缺点

1. 数据维度有限:线性热图只能有效地展示一维数据,对于多维数据的展现能力有限。

2. 颜色使用的限制:颜色选择和对比度对于数据的可读性至关重要,不当的颜色选择可能导致误解。

3. 对比困难:如果需要对比多个不同序列的数据,单一的线性热图可能不够有效。

4. 过度简化数据:在某些情况下,为了适应线性格式,可能需要过度简化数据,这可能导致信息的丢失或误解。

总的来说,线性热图是一个强大的工具,特别适合于展示随时间变化的数据趋势。然而,它们最适合一维数据,且在设计时需要特别注意颜色的选择和对比度。在选择使用线性热图时,应考虑数据的性质和观众的需求。

 

下面这段代码首先导入了matplotlib.pyplot和numpy库。然后,它创建了三组数据:两组随机数据和一组基于余弦函数的数据。接着,代码使用matplotlib的子图功能(subplots)来创建三个水平排列的线性热图,每个图代表一组数据。每个数据点的颜色映射(cmap='hot')表示了其值的大小,而所有的Y轴都被隐藏了,因为这些图是一维的。最后,代码显示了这个组合图表。 

import matplotlib.pyplot as plt
import numpy as np# 创建示例数据
np.random.seed(0)
data1 = np.random.rand(100)
data2 = np.random.rand(100) * 0.5
data3 = np.abs(np.cos(np.linspace(0, 3.14, 100)))  # 确保数据在0-1之间
times = np.linspace(0, 1, 100)# 创建图表
fig, axs = plt.subplots(3, 1, figsize=(10, 6), sharex=True)# 第一组数据
axs[0].scatter(times, [1] * 100, c=data1, cmap='hot', s=100)
axs[0].set_title('Data Set 1')
axs[0].set_yticks([])# 第二组数据
axs[1].scatter(times, [1] * 100, c=data2, cmap='hot', s=100)
axs[1].set_title('Data Set 2')
axs[1].set_yticks([])# 第三组数据
axs[2].scatter(times, [1] * 100, c=data3, cmap='hot', s=100)
axs[2].set_title('Data Set 3')
axs[2].set_yticks([])plt.xlabel('Time')
plt.tight_layout()
plt.show()

我们对线性热图的可视化效果进行了一些美化:改变了配色方案:使用了viridis配色方案,这是一个现代且视觉上吸引人的颜色映射。为每个图添加了颜色条:每个子图都有自己的水平颜色条(colorbar),这有助于用户更好地理解每个图中颜色与强度之间的关系。清晰的标题和标签:每个子图都有标题,说明了它所代表的数据集。同时,时间轴(X轴)标签和颜色条标签也增加了图表的可读性。

具体可视化结果如下所示

 

 以下是,matlab可视化以及代码的展示

 

% 初始化数据
rng(0); % 设定随机数生成器的种子
data1 = rand(1, 100);
data2 = 0.5 * rand(1, 100);
data3 = abs(cos(linspace(0, 3.14, 100)));
times = linspace(0, 1, 100);% 创建图表
figure;% 第一组数据
subplot(3, 1, 1);
scatter(times, ones(1, 100), 100, data1, 'filled');
title('Data Set 1');
yticks([]);% 第二组数据
subplot(3, 1, 2);
scatter(times, ones(1, 100), 100, data2, 'filled');
title('Data Set 2');
yticks([]);% 第三组数据
subplot(3, 1, 3);
scatter(times, ones(1, 100), 100, data3, 'filled');
title('Data Set 3');
yticks([]);% 设置共享的x轴标签
xlabel('Time');
colormap('hot'); % 设定颜色映射

 

这段MATLAB代码将执行以下操作:

1、初始化数据:使用随机数生成三组数据。

2、创建图表:使用figure和subplot函数来创建一个包含三个子图的图表。

3、绘制散点图:使用scatter函数在每个子图上绘制数据。

4、设置标题和坐标轴:为每个子图添加标题,并设置y轴的刻度为空。

5、设置颜色映射:使用colormap('hot')来设置颜色方案

以下为进一步美化可视化结果

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/626969.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vue query url 传参

//初始化页面完成后mounted() {console.log(mounted...,this.$route.query);}, //组件初始化时判断,再打开其它时,新参数收不到created() { console.log(created...,this.$route.query); },

Vite+Vue3+TS中解决PrismJS显示JSON数据不高亮的问题

ViteVue3TS中解决PrismJS显示JSON数据不高亮的问题 在使用prismjs库高亮代码的时候,HTML、JS和CSS都能正常高亮,但是在现实JSON数据的时候就不高亮,经过一番折腾,最后解决办法如下: 必须导入js高亮组件 没错&#x…

Vue中的v-model

聚沙成塔每天进步一点点 本文内容 ⭐ 专栏简介基本用法文本输入框复选框下拉框 原理解析文本输入框的原理复选框和下拉框的原理 ⭐ 写在最后 ⭐ 专栏简介 Vue学习之旅的奇妙世界 欢迎大家来到 Vue 技能树参考资料专栏!创建这个专栏的初衷是为了帮助大家更好地应对 V…

odoo14 @api.onchange装饰器的返回值使用操作

在Odoo 14 中,api.onchange装饰器的返回值是一个字典,其中可以包含以下键: value: 用于更新字段的新值。这个键对应的值是一个字典,其中包含要更新的字段名及其新的值。这样,当字段的值发生变化时,这些新的…

UE5 UE4 打包报错Failed to compile material 解决

参考:https://forums.unrealengine.com/t/failed-to-compile-material-for-pcd3d_sm5-warning/385087 https://forums.unrealengine.com/t/failed-to-compile-material-for-platform-pcd3d-sm4/436176 报错:Failed to compile Material for platform PC…

运算符重载函数

C为了增强代码的可读性引入了运算符重载,运算符重载是具有特殊函数名的函数,也具有其返回值类型,函数名字以及参数列表,其返回值类型与参数列表与普通的函数类似。 函数名字为:关键字operator后面接需要重载的运算符符…

Day35 贪心算法 part04 860. 柠檬水找零 406. 根据身高重建队列 452. 用最少数量的箭引爆气球

贪心算法 part04 860. 柠檬水找零 406. 根据身高重建队列 452. 用最少数量的箭引爆气球 860. 柠檬水找零 class Solution { public:bool lemonadeChange(vector<int>& bills) {vector<int> count(2,0); //count[0]记录5美元&#xff0c;count[1]记录10美元fo…

Vuex中的dispatch用来触发(派发)action

Vuex 中的 dispatch 方法是用来触发&#xff08;派发&#xff09;action 的。store.dispatch(‘actionName’) 会去调用名为 actionName 的 action。 在 Vuex 中&#xff0c;actions 类似于 mutations&#xff0c;但是可以包含任意异步操作&#xff0c;而且 action 不能直接修…

django rest_framework 部署doc文档

1.背景 在实际开发过程中&#xff0c;前后端分离的项目&#xff0c;是需要将一份完整的接口文档交付给前端开发人员&#xff0c;这样有利于开发速度和开发质量&#xff0c;以及有可能减少协同时间。 2.内容 本项目是以Pythondjangorest_framework作为技术框架&#xff0c;在这…

设计模式之里氏代换原则:打破常规,让代码更灵活

在软件开发的世界中&#xff0c;设计模式是解决常见问题的最佳实践。其中&#xff0c;里氏代换原则&#xff08;Liskov Substitution Principle&#xff0c;LSP&#xff09;是面向对象设计的基本原则之一&#xff0c;它强调了在软件中子类型必须能够替换其基类型&#xff0c;而…

Zabbix监控(2)

目录 一.自动发现 配置自动发现&#xff1a;&#xff08;被动模式&#xff09; 修改三台服务器的hosts文件&#xff1a; 修改agent02的配置文件&#xff1a; 访问页面&#xff0c;删除客服端主机配置&#xff1a; 在配置的自动发现中添加规则&#xff1a; 我们重启的zab…

基于springboot的疫情物资捐赠和分配系统

&#x1f345;点赞收藏关注 → 私信领取本源代码、数据库&#x1f345; 本人在Java毕业设计领域有多年的经验&#xff0c;陆续会更新更多优质的Java实战项目希望你能有所收获&#xff0c;少走一些弯路。&#x1f345;关注我不迷路&#x1f345;一 、设计说明 1.1 课题背景 二…

网站引导页源码带视频背景源码系统:HTML5开发的引导页 附带完整的搭建教程

随着互联网技术的飞速发展&#xff0c;网站引导页作为用户体验的重要环节&#xff0c;越来越受到开发者的关注。传统的静态图片引导页已经无法满足用户对于新鲜感和互动性的需求。小编给大家分享一款基于HTML5的带视频背景的源码系统&#xff0c;旨在为用户提供更加丰富、动态的…

细说JavaScript内置对象(JavaScript内置对象详解)

一、String对象 1、简单上手 2、构造方法 3、其他方法 3.1、charAt() 3.2、indexOf() 3.3、split() 3.4、substring() 3.5、substr() 4、实际操作 二、Math对象 1、简单上手 2、对象属性 3、对象方法 4、实际操作 三、Date对象 1、简单上手 2、构造方法 3、实…

【网络安全】【密码学】【北京航空航天大学】实验四、古典密码(上)【C语言实现】

实验四、古典密码&#xff08;上&#xff09; 一、实验目的 1、 通过本次实验&#xff0c;了解古典加密算法的主要思想&#xff0c;掌握常见的古典密码。 2、 学会应用古典密码&#xff0c;掌握针对部分古典密码的破译方法。 二、原理简介 古典密码的编码方法主要有两种&am…

第一个 OpenGL 程序:旋转的立方体(VS2022 / MFC)

文章目录 OpenGL API开发环境在 MFC 中使用 OpenGL初始化 OpenGL绘制图形重置视口大小 创建 MFC 对话框项目添加 OpenGL 头文件和库文件初始化 OpenGL画一个正方形OpenGL 坐标系改变默认颜色 重置视口大小绘制立方体使用箭头按键旋转立方体深度测试添加纹理应用纹理换一个纹理 …

【电商API接口】挖掘电商数据常用的方法

电子商务模式是一个连接线上用户和线下商家的多边平台商业模式。O2O 商业模式将实体经济与线上资源融合在一起&#xff0c;使网络成为实体经济延伸到虚拟世界的渠道; 线下商业可以到线上挖掘和吸引客源&#xff0c;而消费者可以在线上筛选商品和服务并完成支付&#xff0c;再到…

C++面试实战问题之关键字

1.extern和static的区别&#xff0c;什么情况用前者&#xff0c;什么情况用后者 extern用于声明引用其他文件中定义的全局变量或函数。并不分配内存空间。static用于限定变量、函数或类的作用域&#xff0c;使其仅在当前源文件中可见或保持静态特性。在函数内部&#xff0c;使用…

PB获取随机字符串

// // 函数: randstr() //-------------------------------------------------------------------- // 描述:获取随机字符串 //-------------------------------------------------------------------- // 参数: // value string as_str 一个随机因子字符串 // value intege…

自定义shell工具函数之get_config()

自定义shell工具函数之get_config() function get_config() {key$1default${2-}value$(grep "^${key}" "${CONFIG_FILE}" | awk -F { print $2 } | awk -F { print $1 })if [[ -z "$value" ]];thenvalue"$default"fiecho "${va…