python 对海洋、气象数据进行滤波--带通滤波处理

简介: 如何使用python对其海洋、气象数据进行带通滤波处理,得到我们想要的信号呢?

如何使用python对其海洋、气象数据进行带通滤波处理,得到我们想要的信号呢?



这里以scipy.signal.butter滤波器为例,如何对于气象海洋数据做带通滤波处理进行简单讲解,库的官方说明文档链接如下:

butter滤波器


主要实现过程如下所示:

b,a=scipy.signal.butter(N, Wn, btype='band', analog=False, output='ba', fs=None)
filter_result=signal.filtfilt(b, a, data)


里面主要需要关注的为:

  • N:滤波器阶数
  • Wn:频率 (这里我理解的就是你要滤出的时间天数)
  • btype:滤波器类型,lowpass,  highpass, bandpass, bandstop分别为高通,低通,带通、带阻,默认为低通


构造滤波器并传入相应参数后,一般会返回两个变量:a(分母系数)、b(分子系数),之后通过函数signal.filtfilt(),传入相应变量、数据,就可以得到滤波后的数据了。


对于阶数N来说,我的理解是一般不用设置太高,太高的话可能会滤掉过多的信号,我这里一般使用阶数:3、4


以上就是关于滤波的实现原理,下面主要讲解一下关于带通滤波的频率的理解,因为发现大部分的教程示例不适用于海洋、气象数据滤波的处理,没那么通俗易懂。


举个带通滤波的例子



假如想要通过滤波得到天气尺度3-10天的信号,这儿肯定需要做带通滤波了,那么如何计算Wn呢?


首先,先明白Wn的计算公式,通过官网说明可以得到:

Wn=2*截止频率/采样频率


频率是什么呢,其实很简单,频率=1/周期,可以理解为就是我们数据周期的倒数。

因为天气尺度的范围为3-10天,我们默认周期的单位为:1天,以下基于周期为1天的前提进行计算:


相对于周期为一天来说,


  • 假如你的数据是daily的,一天就一个,那么你的数据周期就是1,采样频率就等于1/1=1,还是1
  • 假如你的数据是一天四个时次的,那么一个数据的周期就是0.25,那么采样频率就是1/0.25=4


截止频率是什么呢?与上面采样频率道理类似,还是以相对于周期为一天来说:

3天的截止频率就是1/3,10天的截止频率就是1/10

所以对于3-10天的带通滤波,如果数据基于周期为一天的话,Wn=[2/10,2/3]

如果是30-60天的带通滤波,Wn=[2/60,2/30]


注意:对于数字滤波器,如果没有指定 fs,则将 Wn 单位标准化为0到1,所以检验我们算的Wn有没有错误,可以看他的范围是否符合要求。

这样下面的处理就比较简单了,传入需要滤波的数据即可了:


b, a = signal.butter(3, [2/10,2/3], 'bandpass',axis=time那一维)
filter_data = signal.filtfilt(b, a, origin_data)


低通和高通滤波比较简单这里就不再阐述了

以上是对于python对于海洋、气象数据进行带通滤波处理时的一些简单理解,水平有限,欢迎交流!


                      一个努力学习python的海气人
                      水平有限,欢迎指正!!!
                        欢迎评论、收藏、点赞、转发、关注。
                        关注我不后悔,记录学习进步的过程~~


相关文章
|
7天前
|
数据挖掘 Shell 测试技术
怎么用Python解析HTML轻松搞定网页数据
**Python解析HTML摘要** 本文介绍了使用Python处理HTML的常见需求,如数据提取、网络爬虫和分析,并讨论了三种解析方法。正则表达式适用于简单匹配,但对复杂HTML不理想;BeautifulSoup提供简单API,适合多数情况;lxml结合XPath,适合处理大型复杂文档。示例展示了如何用这些方法提取链接。
|
10天前
|
机器学习/深度学习 数据可视化 搜索推荐
Python在社交媒体分析中扮演关键角色,借助Pandas、NumPy、Matplotlib等工具处理、可视化数据及进行机器学习。
【7月更文挑战第5天】Python在社交媒体分析中扮演关键角色,借助Pandas、NumPy、Matplotlib等工具处理、可视化数据及进行机器学习。流程包括数据获取、预处理、探索、模型选择、评估与优化,以及结果可视化。示例展示了用户行为、话题趋势和用户画像分析。Python的丰富生态使得社交媒体洞察变得高效。通过学习和实践,可以提升社交媒体分析能力。
25 1
|
7天前
|
数据采集 自然语言处理 大数据
​「Python大数据」词频数据渲染词云图导出HTML
使用Python,本文展示数据聚类和办公自动化,焦点在于通过jieba分词处理VOC数据,构建词云图并以HTML保存。`wordCloud.py`脚本中,借助pyecharts生成词云,如图所示,关键词如"Python"、"词云"等。示例代码创建了词云图实例,添加词频数据,并输出到"wordCloud.html"。
18 1
​「Python大数据」词频数据渲染词云图导出HTML
|
2天前
|
算法 数据挖掘 数据处理
搜索新境界:Python二分查找变种实战,精准定位数据不是梦!
【7月更文挑战第13天】二分查找算法以O(log n)效率在有序数组中查找数据。基础算法通过不断分割数组对比中间元素。Python实现变种包括:1) 查找目标值的第一个出现位置,找到后向左搜索;2) 查找目标值的最后一个出现位置,找到后向右搜索。这些变种在数据分析和索引构建等场景中极具价值,提升处理效率。
|
3天前
|
存储 算法 搜索推荐
算法进阶之路:Python 归并排序深度剖析,让数据排序变得艺术起来!
【7月更文挑战第12天】归并排序是高效稳定的排序算法,采用分治策略。Python 实现包括递归地分割数组及合并已排序部分。示例代码展示了如何将 `[12, 11, 13, 5, 6]` 分割并归并成有序数组 `[5, 6, 11, 12, 13]`。虽然 $O(n log n)$ 时间复杂度优秀,但需额外空间,适合大规模数据排序。对于小规模数据,可考虑其他算法。**
18 4
|
2天前
|
数据格式 Python
Python代码示例,读取excel表格,将行数据转为列数据。(10)
【7月更文挑战第10天】Python代码示例,读取excel表格,将行数据转为列数据。
17 2
|
5天前
|
算法 Python
深度剖析!Python中图的DFS与BFS遍历,让你的数据搜索快到飞起
【7月更文挑战第10天】在数据结构和算法中,图遍历是核心概念,Python支持DFS和BFS来探索图。DFS递归深入节点,利用栈,先访问深处;BFS使用队列,层次遍历,先访问最近节点。
18 1
|
7天前
|
数据挖掘 Python
利用Python进行数据分析PDF下载经典数据分享推荐
**Python数据分析大师作,Wes McKinney亲著,详述数据操作、清洗与分析。第2版面向Python 3.6,涵盖pandas、NumPy、IPython和Jupyter更新,实战案例丰富;第3版已升级至Python 3.10和pandas 1.4,继续引领数据科学潮流。[PDF下载](https://zhangfeidezhu.com/?p=337)**
15 0
利用Python进行数据分析PDF下载经典数据分享推荐
|
10天前
|
数据采集 机器学习/深度学习 数据可视化
关于Python数据分析项目的简要概述:从CSV加载数据,执行数据预处理,进行数据探索,选择线性回归模型进行训练,评估模型性能并优化,最后结果解释与可视化。
【7月更文挑战第5天】这是一个关于Python数据分析项目的简要概述:从CSV加载数据,执行数据预处理(填充缺失值,处理异常值),进行数据探索(可视化和统计分析),选择线性回归模型进行训练,评估模型性能并优化,最后结果解释与可视化。此案例展示了数据科学的典型流程。
32 2
|
2天前
|
Python
`scipy.signal`模块是SciPy库中的一个子模块,它提供了信号处理、滤波、频谱分析等功能。这个模块包含了许多用于信号处理的函数和类,其中`butter()`和`filtfilt()`是两个常用的函数。
`scipy.signal`模块是SciPy库中的一个子模块,它提供了信号处理、滤波、频谱分析等功能。这个模块包含了许多用于信号处理的函数和类,其中`butter()`和`filtfilt()`是两个常用的函数。
10 0