用python做傅里叶变换和系统辨识

一、原始信号

1、理想数据

(1)系统参数

参数类型数值
J0.5 k g ∗ m 2 kg*m^2 kgm2
K0.2
b5

(2)激励曲线

在这里插入图片描述

import matplotlib.pyplot as plt
import numpy as np# 生成数据
x = np.linspace(0, 10, 1000)  # 生成0到10之间的100个数据点
y = 20*np.sin(x)+15*np.sin(2*x)+10*np.cos(x)  # 计算正弦函数值# 画曲线图
plt.figure()
plt.plot(x, y, label='20sin(x)+15sin(2x)+10cos(x)', color='blue', linestyle='-', linewidth=2)  # 绘制曲线
plt.xlabel('x')  # x轴标签
plt.ylabel('pos')  # y轴标签
plt.title('Excitation Curve')  # 图标题
plt.legend()  # 显示图例
plt.grid(True)  # 显示网格
plt.show()

(3)其他曲线

在这里插入图片描述

import matplotlib.pyplot as plt
import numpy as npJ = 0.5
K = 0.2
b = 51010# 生成数据
x = np.linspace(0, 10, 1000)  # 生成0到10之间的1000个数据点
pos = 20*np.sin(x) + 15*np.sin(2*x) + 10*np.cos(x)  # 第一条曲线数据
spd = 20*np.cos(x) + 30*np.cos(2*x) - 10*np.sin(x)  # 第二条曲线数据
acc = -20*np.sin(x) - 60*np.sin(2*x) - 10*np.cos(x)  # 第三条曲线数据
tor = J*acc + K*spd + np.sign(spd)*b
# 画曲线图
plt.figure()# 创建第一个子图plt.subplot(411)
plt.plot(x, pos, label='pos', color='blue', linestyle='-', linewidth=2)  # 绘制第一条曲线
plt.xlabel('x')
plt.ylabel('pos')
plt.legend()
plt.grid(True)# 创建第二个子图
plt.subplot(412)
plt.plot(x, spd, label='spd', color='red', linestyle='-', linewidth=2)  # 绘制第二条曲线
plt.xlabel('x')
plt.ylabel('spd')
plt.legend()
plt.grid(True)# 创建第三个子图
plt.subplot(413)
plt.plot(x, acc, label='acc', color='green', linestyle='-', linewidth=2)  # 绘制第三条曲线
plt.xlabel('x')
plt.ylabel('acc')
# plt.title('Excitation Curve 3')
plt.legend()
plt.grid(True)plt.subplot(414)
plt.plot(x, tor, label='tor', color='black', linestyle='-', linewidth=2)  # 绘制第三条曲线
plt.xlabel('x')
plt.ylabel('tor')
# plt.title('Excitation Curve 3')
plt.legend()
plt.grid(True)plt.tight_layout()  # 调整子图布局
plt.show()

2、增加噪声

在这里插入图片描述

import matplotlib.pyplot as plt
import numpy as np
import pandas as pdJ = 0.5
K = 0.2
b = 5# 生成数据
x = np.linspace(0, 10, 1000)  # 生成0到10之间的1000个数据点
pos = 20*np.sin(x) + 15*np.sin(2*x) + 10*np.cos(x) + np.random.normal(0, 5, 1000) # 第一条曲线数据
spd = 20*np.cos(x) + 30*np.cos(2*x) - 10*np.sin(x) + np.random.normal(0, 5, 1000) # 第二条曲线数据
acc = -20*np.sin(x) - 60*np.sin(2*x) - 10*np.cos(x) + np.random.normal(0, 5, 1000) # 第三条曲线数据
tor = J*acc + K*spd + np.sign(spd)*b + np.random.normal(0, 5, 1000)
# 画曲线图
plt.figure()# 创建第一个子图plt.subplot(411)
plt.plot(x, pos, label='pos', color='blue', linestyle='-', linewidth=2)  # 绘制第一条曲线
plt.xlabel('x')
plt.ylabel('pos')
plt.legend()
plt.grid(True)# 创建第二个子图
plt.subplot(412)
plt.plot(x, spd, label='spd', color='red', linestyle='-', linewidth=2)  # 绘制第二条曲线
plt.xlabel('x')
plt.ylabel('spd')
plt.legend()
plt.grid(True)# 创建第三个子图
plt.subplot(413)
plt.plot(x, acc, label='acc', color='green', linestyle='-', linewidth=2)  # 绘制第三条曲线
plt.xlabel('x')
plt.ylabel('acc')
# plt.title('Excitation Curve 3')
plt.legend()
plt.grid(True)plt.subplot(414)
plt.plot(x, tor, label='tor', color='black', linestyle='-', linewidth=2)  # 绘制第三条曲线
plt.xlabel('x')
plt.ylabel('tor')
# plt.title('Excitation Curve 3')
plt.legend()
plt.grid(True)plt.tight_layout()  # 调整子图布局
plt.show()# 创建DataFrame
data = {'x': x, 'pos': pos, 'spd': spd, 'acc': acc, 'tor': tor}
df = pd.DataFrame(data)# 保存数据到CSV文件
df.to_csv('data_with_noise.csv', index=False)

二、数据预处理

1、傅里叶变换画出频谱图在这里插入图片描述

# 从CSV文件中读取数据
df = pd.read_csv('data_with_noise.csv')
column_name = 'pos'  # 选择要进行傅里叶变换的列名
data = df[column_name].values# 进行傅里叶变换
fs = 100  # 假设数据是均匀采样的
fft_data = np.fft.fft(data)
freqs = np.fft.fftfreq(len(fft_data), 1/fs)
freqs = freqs[:len(freqs)//2]  # 取一半频谱(对称性)# 绘制频谱图
plt.figure()
plt.plot(freqs, np.abs(fft_data[:len(fft_data)//2]))
plt.xlabel('Frequency (Hz)')
plt.ylabel('Amplitude')
plt.title('Spectrum of the data column')
plt.grid()
plt.show()

2、去除高频噪声并逆傅里叶变换

在这里插入图片描述

# import numpy as np
# import pandas as pd
# import matplotlib.pyplot as plt# # 从CSV文件中读取数据
# df = pd.read_csv('data_with_noise.csv')
# column_name = 'pos'  # 选择要进行傅里叶变换的列名
# data = df[column_name].values# # 进行傅里叶变换
# fs = 100  # 采样频率为100 Hz
# fft_data = np.fft.fft(data)
# freqs = np.fft.fftfreq(len(fft_data), 1/fs)# # 去除大于10Hz的频率成分
# fft_data_filtered = np.copy(fft_data)
# fft_data_filtered[np.where(np.abs(freqs) > 0.5)] = 0# # 进行逆傅里叶变换
# filtered_data = np.fft.ifft(fft_data_filtered)# # # 创建新的DataFrame保存原始数据和滤波后的数据
# # new_df = pd.DataFrame({'Original Data': data, 'Filtered Data': np.real(filtered_data)})# # # 将数据保存到新的CSV文件中
# # new_df.to_csv('filtered_yaw_data.csv', index=False)# # 绘制时域对比图
# plt.figure()
# plt.plot(data, label='Original Data')
# plt.plot(np.real(filtered_data), label='Filtered Data (freq < 10Hz)')
# plt.xlabel('Time')
# plt.ylabel('Amplitude')
# plt.title('Original Data vs Filtered Data')
# plt.legend()
# plt.grid()
# plt.show()import numpy as np
import pandas as pd
import matplotlib.pyplot as plt# 从CSV文件中读取数据
df = pd.read_csv('data_with_noise.csv')
column_name = 'pos'  # 选择要进行傅里叶变换的列名
data = df[column_name].values# 进行傅里叶变换
fs = 100  # 采样频率为100 Hz
fft_data = np.fft.fft(data)       #离散快速傅里叶变换
freqs = np.fft.fftfreq(len(fft_data), 1/fs)freqs = freqs[:len(freqs)]  # 取一半频谱(对称性)正
print(freqs)
# 去除大于10Hz的频率成分
fft_data_filtered = np.copy(fft_data)
fft_data_filtered[np.where(np.abs(freqs) > 0.5)] = 0
print(fft_data_filtered)
# 进行逆傅里叶变换
filtered_data = np.fft.ifft(fft_data_filtered)# 创建新的DataFrame保存原始数据和滤波后的数据
new_df = pd.DataFrame({'Original Data': data, 'Filtered Data': np.real(filtered_data)})
# 将数据保存到新的CSV文件中
new_df.to_csv('filtered_yaw_data.csv', index=False)# 绘制时域对比图
plt.figure()
plt.plot(data, label='Original Data')
plt.plot(np.real(filtered_data), label='Filtered Data (freq < 10Hz)')
plt.xlabel('Time')
plt.ylabel('Amplitude')
plt.title('Original Data vs Filtered Data')
plt.legend()
plt.grid()
plt.show()

三、动力学辨识

1、动力学模型

t o r = J ∗ α + K ∗ s p d + s i g n ( s p d ) ∗ b tor = J*\alpha + K*spd+sign(spd)*b tor=Jα+Kspd+sign(spd)b

  • 摩擦力使用粘滞-库伦模型
  • 单自由度的关节模型

2、最小二乘法

在这里插入图片描述

import numpy as np
import pandas as pd
from scipy.optimize import curve_fit
import matplotlib.pyplot as plt
from mpl_toolkits.mplot3d import Axes3D# 从CSV文件中读取数据
df = pd.read_csv('data_with_noise.csv')
column_name_acc = 'Filtered_acc'  # 第一列数据的列名
column_name_v = 'Filtered_spd'  # 第二列数据的列名
column_name_tor = 'Filtered_tor'  # 第三列数据的列名data_acc = df[column_name_acc].values
data_v = df[column_name_v].values
data_tor = df[column_name_tor].values# 定义拟合函数
def model_func(inputs, a, b, c):acc, v = inputsreturn a * acc + b * v + np.sign(v) * np.abs(c)# 初始参数猜测值
initial_guess = [1, 1, 1]# 使用最小二乘法拟合模型
params, covariance = curve_fit(model_func, (data_acc, data_v), data_tor, initial_guess)# 提取拟合参数
a_fit, b_fit, c_fit = params# 打印拟合参数
print("拟合参数:")
print("a =", a_fit)
print("b =", b_fit)
print("c =", c_fit)# 绘制三维效果图
fig = plt.figure()
ax = fig.add_subplot(111, projection='3d')
ax.scatter(data_acc, data_v, data_tor, color='b', label='Fitted Data')
ax.scatter(data_acc, data_v, model_func((data_acc, data_v), a_fit, b_fit, c_fit), color='r', label='Model Data')
ax.set_xlabel('Filtered Acceleration')
ax.set_ylabel('Filtered Speed')
ax.set_zlabel('Filtered Torque')
ax.set_title('Fitted vs. Actual Data')
plt.legend()
plt.show()

3、结果分析

参数类型数值
J0.50.47
K0.20.275
b5-0.676
  • 转动惯量的部分还是可以的,摩擦力的两个参数就有点离谱了,速度越大摩擦力还小了。这是我觉得辨识方法最尴尬的地方,结果是拟合了,参数没拟合。这还是单自由度的情况下,如果是多自由度的整体辨识,大量参数耦合在一起,就更难说清到底是哪些参数起到了什么样的作用了,这也没比基于神经网络的纯黑盒强多少。

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

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

相关文章

Midjourney与waifu2x双剑合璧:完美打造超高清动漫图像

在追求完美的动漫图像时&#xff0c;质量和分辨率是两个关键因素。Midjourney&#xff08;一个神秘而强大的AI图像生成工具&#xff09;与waifu2x&#xff08;一个专门用于放大动漫风格图像的AI工具&#xff09;的结合使得创造超高清的动漫图像变得触手可及。本文将引导您如何使…

【C++】---STL之vector详解

【C】---STL之vector详解 一、vector的介绍&#xff1a;二、vector的成员函数&#xff1a;1、vector类的构造函数2、vector的元素访问符3、vector的迭代器4、vector的模版5、vector的拷贝构造6、vector的容量&#xff08;1&#xff09;vector的增容机制&#xff08;2&#xff0…

Spring的过滤器、拦截器、切面区别及案例分析

Spring的过滤器、拦截器、切面 三者的区别&#xff0c;以及对应案例分析 一、三者的实现方式 1.1 过滤器 xxxFilter 过滤器的配置比较简单&#xff0c;直接实现Filter接口即可&#xff0c;也可以通过WebFilter注解实现对特定URL的拦截&#xff0c;Filter接口中定义了三个方法…

告别数据丢失,轻松掌握文件自动备份秘籍

在这个数字化高速发展的时代&#xff0c;我们的工作和生活都离不开电脑&#xff0c;而电脑中存储的文件和数据更是至关重要。然而&#xff0c;数据丢失的风险无处不在&#xff0c;可能因为硬件故障、软件崩溃、病毒攻击等原因而导致重要文件丢失。因此&#xff0c;文件自动备份…

Abaqus三维晶体塑性Voronoi泰森多边形晶格建模插件

插件介绍 AbyssFish Voronoi2D&3D 3D V3.0 插件可对Abaqus内已进行网格划分的部件&#xff08;Part&#xff09;生成Voronoi泰森多边形区块。插件可对任意形状的二维或三维部件、任意特征&#xff08;实体或壳&#xff09;、任意单元形状进行指派Voronoi晶格&#xff0c;可…

【STM32F4】按键开关

上一章&#xff0c;我们介绍了STM32F4的IO口作为输出的使用&#xff0c;这一章&#xff0c;将向大家介绍如何使用按键作为输入使用。 &#xff08;一&#xff09;硬件连接 根据正点原子的stm32f4阿波罗开发板&#xff0c;可以看见 按键KEY0连接在PH3上、 KEY1连接在PH2上、 …

SQLite的DBSTAT 虚拟表(三十六)

返回&#xff1a;SQLite—系列文章目录 上一篇:SQLite运行时可加载扩展(三十五&#xff09; 下一篇&#xff1a;SQLite—系列文章目录 1. 概述 DBSTAT 虚拟表是一个只读的同名虚拟表&#xff0c;返回 有关用于存储内容的磁盘空间量的信息 的 SQLite 数据库。 示例用例…

FPGA - ZYNQ 基于Axi_Lite的PS和PL交互

前言 在FPGA - ZYNQ 基于EMIO的PS和PL交互中介绍了ZYNQ 中PS端和PL端交互的开发流程&#xff0c;接下来构建基于基于Axi_Lite的PS和PL交互。 开发流程 Axi_Lite从机 在FPGA - AXI4_Lite&#xff08;实现用户端与axi4_lite之间的交互逻辑&#xff09;中&#xff0c;详解介绍…

性能工具之 JMeter 自定义 Java Sampler 支持国密 SM2 算法

文章目录 一、前言二、加密接口1、什么是SM22、被测接口加密逻辑 三、准备工作四、JMeter 扩展实现步骤1&#xff1a;准备开发环境步骤2&#xff1a;了解实现方法步骤3&#xff1a;runTest 方法步骤4&#xff1a;getDefaultParameters 方法步骤5&#xff1a;setupTest 方法 五、…

HTX迪拜之夜盛大举行:共筑开放、互联的Web3生态系统

4月18日&#xff0c;由HTX、HTX DAO主办&#xff0c;去中心化AI云游戏协议DeepLink赞助的HTX迪拜之夜主题活动“领航者相聚&#xff0c;引领币圈新风向”在迪拜盛大举行。通过在全球第二大加密中心-迪拜的频繁亮相&#xff0c;HTX正积极塑造自己作为行业领导者的形象&#xff0…

Mysql学习一

目录 1.启动数据库&#xff1a; 2.命令行连接到MySQL&#xff08;winr输入cmd&#xff09; 3.MySQL的三重结构&#xff1a; 4.SQL语句分类&#xff1a; 1.启动数据库&#xff1a; winr——输入services.msc进入本地服务 2.命令行连接到MySQL&#xff08;winr输入cmd&#x…

109. Python的turtle库简介

109. Python的turtle库简介 【目录】 文章目录 109. Python的turtle库简介1. 什么是turtle库&#xff1f;2. 用turtle库绘制一个爱心图案3. 库的导入方法3.1 直接导入整个库3.2 从库中导入特定的函数或类3.3 导入库中的所有内容3.4 为导入的库设置别名3.5 为导入的函数或变量设…

阿里巴巴Java开发规范——编程规约(3)

# 阿里巴巴Java开发规范——编程规约&#xff08;3&#xff09; 编程规约 &#xff08;四&#xff09; OOP规约 1.【强制】构造方法里面禁止加入任何业务逻辑&#xff0c;如果有初始化逻辑&#xff0c;请放在 init 方法中 这条编程规范的目的是为了保持代码的清晰性、可读性…

AOP

代理模式 提出问题 现有缺陷 假设我们有一个计算类&#xff0c;里面有加减乘除四个方法&#xff0c;现在我们要为这四个方法添加日志&#xff0c;即在方法执行的前后分别输出一句话&#xff0c;这时我们会发现如下缺陷&#xff1a; 1.对核心业务有干扰。核心业务是加减乘除…

货拉拉0-1数据指标体系构建与应用

目录 一、背景 二、指标体系搭建 2.1 指标设计 2.2 指标体系搭建 2.3 指标维度拆解 三、指标标准化建设 四、指标元数据管理 五、指标应用&未来规划 原文大佬介绍的这篇指标体系构建有借鉴意义&#xff0c;现摘抄下来用作沉淀学习。如有侵权请告知~ 一、背景 指标…

汽车摄像头匿名化处理解决方案,保护信息的安全性和隐私性

随着智能交通和自动驾驶技术的迅猛发展&#xff0c;汽车摄像头已成为现代汽车不可或缺的一部分&#xff0c;摄像头所捕捉的图像信息也引发了日益严峻的信息安全问题。如何在充分利用摄像头功能的同时&#xff0c;保障个人隐私和信息安全&#xff0c;已成为企业亟待解决的问题。…

IP地址定位技术引发的个人隐私保护问题

IP地址定位技术对互联网的影响深远且多面&#xff0c;它不仅改变了网络管理与优化的方式&#xff0c;还极大地推动了在线广告营销、电子商务、地理信息服务等多个领域的发展。然而&#xff0c;与此同时&#xff0c;它也引发了一系列关于个人隐私保护的问题。 首先&#xff0c;I…

vue的学习之用vue写一个hello,vue

根据以下步骤下载vue.js 介绍 — Vue.js 创建一个damo.html &#xff0c;引入vue.js即可 <body><div id"app">{{ message }}</div><!-- Vue --><!-- 开发环境版本&#xff0c;包含了有帮助的命令行警告 --><script src"js/vu…

清华新突破,360°REA重塑多智能体系统:全方位提升复杂任务表现

引言&#xff1a;多智能体系统的新篇章——360REA框架 在多智能体系统的研究领域&#xff0c;最新的进展揭示了一种全新的框架——360REA&#xff08;Reusable Experience Accumulation with 360 Assessment&#xff09;。这一框架的提出&#xff0c;不仅是对现有系统的一次重大…

如何修改WordPress数据库表前缀以提高安全性

WordPress作为世界上最受欢迎的内容管理系统之一&#xff0c;吸引了数以百万计的用户。然而&#xff0c;正因为其广泛的使用&#xff0c;WordPress网站也成为了黑客攻击的目标之一。其中一个最常见的安全漏洞是使用默认的数据库表前缀wp_&#xff0c;使得黑客能够更轻松地进行大…