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

如何使用Savitzky-Golay滤波器进行轨迹平滑

一、Savitzky-Golay滤波器介绍

Savitzky-Golay滤波器是一种数字滤波器,用于平滑数据,特别是在信号处理中。它基于最小二乘法的思想,通过拟合数据到一个滑动窗口内的低阶多项式来实现平滑。这种滤波器的优点是它可以保留数据的高频信息(即峰值),这在许多应用中是非常重要的。

滤波器的工作原理

  1. 选择一个窗口大小(通常是奇数),以及要拟合的多项式的阶数。
  2. 对于数据中的每个点,将该点及其窗口内的邻居拟合到一个多项式(例如线性、二次、三次等)。
  3. 使用该多项式在窗口中心的值替换原始数据点的值。
  4. 将窗口向前移动一个数据点,并重复步骤2和3,直到处理完所有的数据点。

Savitzky-Golay滤波器的主要优点

  • 它可以有效地平滑噪声数据,同时保留数据的形状特征,如峰值和宽度。
  • 它是一种线性滤波器,计算效率高。
  • 它的结果可以很好地逼近原始信号的导数,这对于找出数据的最大值和最小值等特征非常有用。

然而,需要注意的是,Savitzky-Golay滤波器对于数据边缘的处理可能会产生不理想的效果,因为在数据边缘,滤波器窗口内可能没有足够的点来拟合多项式。此外,如果数据中有大的突变或异常值,滤波器可能也会受到影响。

二、如何使用Savitzky-Golay滤波器进行轨迹平滑

import numpy as np
from scipy.signal import savgol_filter# 读取轨迹文件
data = np.loadtxt('trajectory.txt', delimiter=',')# 提取index, x, y, theta, default
index = data[:, 0]
x = data[:, 1]
y = data[:, 2]
theta = data[:, 3]
default = data[:, 4]# 定义滤波器窗口大小和多项式阶数
window_size, poly_order = 51, 3# 对x, y, theta进行滤波
x_smooth = savgol_filter(x, window_size, poly_order)
y_smooth = savgol_filter(y, window_size, poly_order)
theta_smooth = savgol_filter(theta, window_size, poly_order)# 输出平滑后的轨迹
smooth_data = np.column_stack((index, x_smooth, y_smooth, theta_smooth, default))
np.savetxt('smooth_trajectory.txt', smooth_data, delimiter=',')

上述代码读取trajectory.txt轨迹文件,然后提取出了每个点的x, y, theta值。然后,它使用Savitzky-Golay滤波器对x, y, theta进行了平滑,并将平滑后的结果保存在smooth_trajectory.txt中。

http://www.lryc.cn/news/160963.html

相关文章:

  • Nomad系列-Nomad网络模式
  • OpenCV项目开发实战--实现面部情绪识别对情绪进行识别和分类及详细讲解及完整代码实现
  • Validate表单组件的封装
  • 企业架构LNMP学习笔记32
  • 基于Jetty9的Geoserver配置https证书
  • 企业互联网暴露面未知资产梳理
  • 【动态规划刷题 12】等差数列划分 最长湍流子数组
  • react-redux 的使用
  • 77 # koa 中间件的应用
  • 【css】z-index与层叠上下文
  • 系统架构设计师(第二版)学习笔记----多媒体技术
  • 【面试经典150 | 数组】合并两个有序数组
  • 系统架构设计专业技能 ·操作系统
  • CSP 202209-1 如此编码
  • windows安装向量数据库milvus
  • Qt中,QScript对JavaScript的内置接口支持情况
  • C语言基础-typedef的用法
  • Linux中安装MySQL5.7.42
  • 网络基础--1.网络纵横
  • Django TypeError: Abstract models cannot be instantiated.错误解决方案
  • vscode使用delve调试golang程序
  • 如何从任何苹果、Windows或安卓设备访问iCloud照片
  • 关于“找不到mfc140u.dll,无法继续执行代码”问题的分析处理方法
  • 用 TripletLoss 优化bert ranking
  • Tomcat安装及使用
  • 法国新法案强迫 Firefox 等浏览器审查网站
  • 开源电商项目 Mall:构建高效电商系统的终极选择
  • QT(9.1)对话框与事件处理
  • C++项目实战——基于多设计模式下的同步异步日志系统-③-前置知识补充-设计模式
  • C++ 新旧版本两种读写锁