Python:平滑处理的3种方法

一、数据平滑

  • 数据平滑是一项重要的预处理步骤。平滑处理能够减少数据中的噪声和波动,使数据更加平滑,从而更易于分析和可视化。

3种方法

  • 移动平均法
  • 高斯滤波
  • 样条插值

二、移动平均法

  • 移动平均是一种简单而有效的平滑技术,它通过计算数据点周围窗口内的平均值来减少数据的波动。这种方法对于减少随机噪声特别有效。
import numpy as np
import matplotlib.pyplot as plt

# 示例高程数据(类阶梯数据)
elevation_data = np.array([10, 10, 11, 11, 10, 10, 20, 20, 20, 10, 10, 15, 15, 15, 10, 10])

# 移动平均平滑
def moving_average(data, window_size):
    return np.convolve(data, np.ones(window_size)/window_size, mode='valid')

window_size = 3
smoothed_data = moving_average(elevation_data, window_size)

# 绘制原始数据和平滑数据
plt.figure(figsize=(10, 5))
plt.plot(elevation_data, label='Original Data')
plt.plot(np.arange(window_size//2, len(elevation_data)-window_size//2), smoothed_data, label='Smoothed Data (Moving Average)', color='red')
plt.legend()
plt.xlabel('Index')
plt.ylabel('Elevation')
plt.title('Elevation Profile with Moving Average Smoothing')
plt.show()

运行结果

三、高斯滤波

  • 高斯滤波是一种通过卷积高斯核来平滑数据的方法。这种方法能够根据不同数据点的权重(由高斯函数确定)来平滑数据,从而在保持数据整体趋势的同时减少噪声。
import numpy as np
import matplotlib.pyplot as plt
from scipy.ndimage import gaussian_filter
# 示例高程数据(类阶梯数据)
elevation_data = np.array([10, 10, 11, 11, 10, 10, 20, 20, 20, 10, 10, 15, 15, 15, 10, 10])

# 高斯滤波平滑
sigma = 1  # 标准差
smoothed_data_gaussian = gaussian_filter(elevation_data, sigma=sigma)

# 绘制原始数据和平滑数据
plt.figure(figsize=(10, 5))
plt.plot(elevation_data, label='Original Data')
plt.plot(smoothed_data_gaussian, label='Smoothed Data (Gaussian Filter)', color='green')
plt.legend()
plt.xlabel('Index')
plt.ylabel('Elevation')
plt.title('Elevation Profile with Gaussian Filter Smoothing')
plt.show()

运行结果

四、样条插值

  • 样条插值通过拟合一个平滑的样条函数来平滑数据。这种方法适用于需要高度平滑且保留数据局部特征的情况。
import numpy as np
import matplotlib.pyplot as plt
from scipy.interpolate import UnivariateSpline
# 示例高程数据(类阶梯数据)
elevation_data = np.array([10, 10, 11, 11, 10, 10, 20, 20, 20, 10, 10, 15, 15, 15, 10, 10])

# 样条插值平滑
x = np.arange(len(elevation_data))
spl = UnivariateSpline(x, elevation_data, s=1)
smoothed_data_spline = spl(x)

# 绘制原始数据和平滑数据
plt.figure(figsize=(10, 5))
plt.plot(elevation_data, label='Original Data')
plt.plot(smoothed_data_spline, label='Smoothed Data (Spline)', color='purple')
plt.legend()
plt.xlabel('Index')
plt.ylabel('Elevation')
plt.title('Elevation Profile with Spline Smoothing')
plt.show()

运行结果

五、优缺点

  • 移动平均法:简单快速,但平滑效果有限,容易导致数据丢失。
  • 高斯滤波:提供平滑且可调节的平滑度(通过 sigma 参数),但可能引入偏移。
  • 样条插值:可以精确拟合数据,平滑效果好,但可能会产生过拟合,尤其是在噪声数据较多时。

可根据数据特性和具体需求,选择合适的平滑方法。
可以尝试不同的方法并比较结果,以找到最佳方案。

六、资料

[北海yy]的博客:
https://blog.csdn.net/weixin_44217158/article/details/140947987

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,271评论 5 466
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,725评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,252评论 0 328
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,634评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,549评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,985评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,471评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,128评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,257评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,233评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,235评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,940评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,528评论 3 302
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,623评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,858评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,245评论 2 344
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,790评论 2 339

推荐阅读更多精彩内容