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

【matlab|python】矢量棍棒图应用场景和代码

【matlab|python】矢量棍棒图应用场景和代码

在这里插入图片描述

矢量棍棒图的介绍和作用
矢量棍棒图(stick plot)是一种用于可视化 方向性时间序列数据 的图形工具。它常用于大气科学和海洋科学中,以直观地展示 风场、海流 或 其他矢量变量 随时间的变化情况。

  1. 主要特点
    矢量方向表示流场方向:每个棍棒的朝向代表矢量(如风向或流向)的方向。

矢量长度表示流速或风速:棍棒的长度与该时刻的速率成正比。

时间维度通常沿 x 轴:横轴为时间,纵轴上显示一系列棍棒。

  1. 作用
    描述风速风向的时间变化(如台风期间的风场演变)。

分析潮流或海流随时间的变化,尤其适用于某个固定测站的流场观测数据。

对比不同时间或不同地点的流场特征,如 El Niño 期间的赤道流场变化。

在海洋与大气科学中的应用
矢量棍棒图广泛用于以下几种图表中:

风场棍棒图

应用于大气科学,用于表示一段时间内的风速和风向。

例如,某个气象站的 10m 高度风速风向变化。

潮流/海流棍棒图

在海洋科学中,常用于描述海流随时间的变化。

例如,长江口某测点的潮流方向和流速变化。

涡旋或风暴研究

研究台风、风暴潮期间的风速风向变化,结合其他数据(如增水、气压)分析风暴影响。

波浪方向变化分析(较少见)

在波浪传播方向随时间变化较明显的情况下,也可以使用棍棒图。

示例
如果你有一个固定站点的海流数据(U、V 分量随时间变化),可以使用

和其他结合使用:
在这里插入图片描述

图片
图片在这里插入图片描述

python 代码:

import numpy as np
import matplotlib.pyplot as plt# 生成示例数据
time = np.arange(0, 24, 1)  # 24小时
u = np.sin(time / 6 * np.pi)  # 模拟 U 分量
v = np.cos(time / 6 * np.pi)  # 模拟 V 分量fig, ax = plt.subplots(figsize=(10, 4))
ax.quiver(time, np.zeros_like(time), u, v, scale=5, angles='uv')ax.set_xlabel('Time (hours)')
ax.set_ylabel('Flow Direction')
ax.set_title('Stick Plot of Current Velocity')
plt.show()

matlab 代码:

.rtcContent { padding: 30px; } .lineNode {font-size: 12pt; font-family: "Times New Roman", Menlo, Monaco, Consolas, "Courier New", monospace; font-style: normal; font-weight: normal; }
start=[1990 11 1 0 0 0];    %Gregorian start [yyyy mm dd hh mi sc]
stop=[1991 2 1 0 0 0];
jd=julian(start):julian(stop);
u=sin(.1*jd(:));
v=cos(.1*jd(:));
w=u+i*v;
figure('Position',[10 10 1250 850],'color','w')
h=timeplt(jd,w);
% fixpaper2
export_fig('4.jpg','-r600')

reference:

https://github.com/rsignell-usgs/timeplt

可点击阅读原文:

http://www.xdnf.cn/news/724.html

相关文章:

  • Redis——通信协议
  • 第35讲:构建属于自己的遥感大模型平台,并接入地理数据工作流
  • Ubuntu修改Swap交换空间大小
  • 深入浅出 C++ 核心基础:从语法特性到入门体系构建
  • C语言if
  • 大模型之路(day 1)
  • 嵌入式学习——远程终端登录和桌面访问
  • Java Web项目(一)
  • Mysql相关知识2:Mysql隔离级别、MVCC、锁
  • 深度可分离卷积与普通卷积的区别及原理
  • 【C++】继承----上篇
  • mysql
  • QSS【QT】
  • 常见超低噪声 LDO,ADM7150、LP5907、SGN2036、TPL910
  • 力扣刷题 - 203.移除链表元素
  • 4.20刷题记录(单调栈)
  • 基于springboot的商城
  • 积木报表查询出现jdbc.SQLServerException: 对象名 ‘user_tab_comment 的解决方法
  • 力扣算法ing(61 / 100)
  • 5.1 掌握函数定义与参数传递的奥秘
  • 【Qt】信号和槽
  • [安全实战]逆向工程核心名词详解
  • DAY6:从执行计划到索引优化的完整指南
  • React基础知识(补充中)
  • PyTorch基础学习系列一
  • 安卓手机怎样配置数据加速
  • Java File 类详解
  • 从事计算机视觉需要掌握哪些知识
  • 微信小程序通过mqtt控制esp32
  • Map遍历