MATLAB实时脚本分析系统的类冲激响应,并绘制伯德图

2023-11-01 12:51

本文主要是介绍MATLAB实时脚本分析系统的类冲激响应,并绘制伯德图,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目的

这里使用自动驾驶车的转向角度作为输入模拟冲激信号
输出分别为:横向加速度,yaw rate和推定的侧滑角
通过对输入和输出进行傅里叶变换,求出频域的比例关系后绘制伯德图。以观察车辆的传递特性
*由于包含数据的机密性分析结果就不放实际数据图片了,只是作为学习笔记分享一下代码的思路

1. 导入数据

使用CAN信号的记录文件并转换为.mat数据文件后进行分析,每一个数据对应了一个采样时间文件,其中的数据是一一对应的。

close all
clear variables%选择信号文件
filename = 'ImpulseSignal.mat';
load(filename);%测试用信号 V = 0.7*sin(2*pi*50*t) + sin(2*pi*120*t);
S = VehicleSpeed_t1;            %车速(测试用)
StAngle = SteerAngle_t2;        %前轮方向转角(输入)
lAcc = Acc_t3;                  %横向加速度(输出)
Yaw = YawRate_t4;               %yaw rate(输出)
SlAngle = SlipAngle_t5;         %推定侧滑角度(输出)

1.1 参数设定

  • 有效信号的分割点信息
  • 我这里使用的是等间距的冲激信号作为输入,如下图所示,需要将每一个独立的信号分割后进行傅里叶分析
    在这里插入图片描述
%有效信号的分割点信息
Seginfo_test = [350 240 3];               %[有效信号的起始点,冲激信号间隔,冲激信号总数]
Seginfo_1 = [];
seginfo = Seginfo_test;                   
n = seginfo(3);

读取数据部分和相应的时间戳部分,如果输入和输出的采样时间不一致需要将高频数据降采样处理。这里我的转向角输入t2和侧滑角输出t5的采样时间是其他信号的两倍,所以降采样使其保持一致。
为了生成预备数据,代码从这里开始执行到第二章FFT,直到最后全部数据生成后再向后执行。

Y_data = 'SlAngle'
if strcmp(Y_data,'StAngle')Y = downsample(StAngle,2);T = downsample(t2,2);dataid = 1;elseif strcmp(Y_data,'lAcc')Y = lAcc;T = t3;dataid = 2;elseif strcmp(Y_data,'Yaw')Y = Yaw;T = t4;dataid = 3;elseif strcmp(Y_data,'SlAngle')Y = downsample(SlAngle,2);T = downsample(t5,2);dataid = 4;
elseY = S;T = t2;dataid = 0;
endt_sample = mean(diff(T))    % Sampling perios/time
Fs = round(1/t_sample)      % Sampling frequency                    
L = size(Y,1)               % Length of signal          

1.2 初始信号

plot(T(1:L),Y(1:L))         %绘制初始信号图
title("转向角")
xlabel("t (seconds)")
ylabel("S(t)")

在这里插入图片描述

1.3 分割信号

%按照分割点的信息自动求出时间切片和对应的index
start_id=round(seginfo(1)/(t_sample/0.01));
interval=round(seginfo(2)/(t_sample/0.01));
for ii=1:nr=start_id+(ii-1)*interval:start_id+ii*interval-1;time_slice{ii}=T(r);time_index{ii}=(r)';
end
1.3a 有效信号部分样本

impulse_id=1;                                                   %选定N个有效冲激信号中的第impulse_id个绘制图形
%Y_m = mean(Y(time_index{impulse_id}))                          %信号取平均的两种方法
%Y_d = detrend(Y(time_index{impulse_id}), 0);
figure(1);
clf;
plot(time_slice{impulse_id},Y(time_index{impulse_id}),'--')     %绘制初始信号
hold on
plot(time_slice{impulse_id},Y(time_index{impulse_id})-Y_m)      %绘制取平均后的信号title(['handle angle ID:',num2str(impulse_id)])
xlabel("t (seconds)")
ylabel(['S',num2str(impulse_id),'(t)'])

在这里插入图片描述

1.3b 生成全部的冲激信号切片,并按顺序保存
for ii=1:n%Ym = mean(Y(time_index{ii}));    %这里我不取平均了,因为对傅里叶分析的结果没有影响S_x{ii} = time_slice{ii};%S_y{ii} = Y(time_index{ii}-Y_m);S_y{ii} = Y(time_index{ii}); 
end

1.4 快速傅里叶变换(FFT, Fast Fourier Transform)

Sf=fft(S_y{impulse_id});              %FFT
Li = size(S_y{impulse_id},1)          %信号长度
P2 = Sf/Li;
P_Sf = P2(1:Li/2);
P_Sf(2:end-1) = 2*P_Sf(2:end-1);      %取前半部分数据

作图

figure(2);
clf;Px = (Fs*(0:(Li/2)-1)/Li)';             %根据奈奎斯特频率取(Fs/2)
plot(Px,P_Sf)
%xlim([0 Fs/2]);                       
%plot(Fs*(0:(Li/2))/Li,P1) 
title("Fast Fourier Transform of S(f)")
xlabel("f (Hz)")
ylabel(['FFT[S',num2str(impulse_id),'(t)]=S',num2str(impulse_id),'(f)'])

在这里插入图片描述

2.FFT数据生成

for x=1:nFFT = fft(S_y{x});L = size(S_y{x},1);FFT = FFT/L;FFT = FFT(1:L/2);FFT(2:end-1) = 2*FFT(2:end-1);if dataid == 1Res_StAngle{x} = FFT;            %转向角(输入)elseif dataid == 2Res_lAcc{x} = FFT;               %横向加速度(输出)elseif dataid == 3Res_Yaw{x} = FFT;                %Yawrate(输出)elseif dataid == 4Res_SlAngle{x} = FFT;            %侧滑角(输出)end
end

3.生成比例数据

  • 输入和输出的比例反映了系统的响应特征,也就是传递函数
  • 我们可以利用得到的特征数据和标准模型进行对比,从而观察出外界因素对系统响应的影响
for x=1:nRes_lAcc_R{x} = Res_lAcc{x}./Res_StAngle{x};Res_Yaw_R{x} = Res_Yaw{x}./Res_StAngle{x};Res_SlAngle_R{x} = Res_SlAngle{x}./Res_StAngle{x};
endRes_lAcc_sum = 0;
Res_Yaw_sum = 0;
Res_SlAngle_sum = 0;for i=1:n   Res_lAcc_sum = Res_lAcc_sum + Res_lAcc_R{i};Res_Yaw_sum = Res_Yaw_sum + Res_Yaw_R{i};Res_SlAngle_sum = Res_SlAngle_sum + Res_SlAngle_R{i};
end%计算所有冲激响应的均值
Res_lAcc_mean = Res_lAcc_sum/n;
Res_Yaw_mean = Res_Yaw_sum/n;
Res_SlAngle_mean = Res_SlAngle_sum/n;

4.結果

4.1 转向角(输入)→横向加速度(输出1)

*由于数据的机密性这里开始就不放图片了

figure(3);
clf;
ax = (Fs*(0:(Li/2)-1)/Li)';subplot(2,1,1);
semilogx(ax,20*log10(abs(Res_lAcc_mean))); grid on;
title("转向角→横向加速度")
%xlabel('f (Hz)')
ylabel('Gain[dB]')subplot(2,1,2);
semilogx(ax, 180/pi*angle(Res_lAcc_mean)); grid on;
xlabel('f (Hz)')
ylabel('相位[deg]')

4.2 转向角→yawrate(输出2)

figure(4);
clf;subplot(2,1,1);
semilogx(ax,20*log10(abs(Res_Yaw_mean))); grid on;
title("转向角→yawrate")
ylabel('Gain[dB]')
subplot(2,1,2);
semilogx(ax,180/pi*angle(Res_Yaw_mean)); grid on;
xlabel('f (Hz)')
ylabel('相位[deg]')

4.3 转向角→侧滑角(输出3)

figure(5);
clf;subplot(2,1,1);
semilogx(ax,20*log10(abs(Res_SlAngle_mean))); grid on;
title("转向角→侧滑角")
ylabel('Gain[dB]')subplot(2,1,2);
semilogx(ax,180/pi*angle(Res_SlAngle_mean)); grid on;
xlabel('f (Hz)')
ylabel('相位[deg]')
  • 20230630完

这篇关于MATLAB实时脚本分析系统的类冲激响应,并绘制伯德图的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/323117

相关文章

Java程序进程起来了但是不打印日志的原因分析

《Java程序进程起来了但是不打印日志的原因分析》:本文主要介绍Java程序进程起来了但是不打印日志的原因分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java程序进程起来了但是不打印日志的原因1、日志配置问题2、日志文件权限问题3、日志文件路径问题4、程序

Java使用ANTLR4对Lua脚本语法校验详解

《Java使用ANTLR4对Lua脚本语法校验详解》ANTLR是一个强大的解析器生成器,用于读取、处理、执行或翻译结构化文本或二进制文件,下面就跟随小编一起看看Java如何使用ANTLR4对Lua脚本... 目录什么是ANTLR?第一个例子ANTLR4 的工作流程Lua脚本语法校验准备一个Lua Gramm

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

Python 迭代器和生成器概念及场景分析

《Python迭代器和生成器概念及场景分析》yield是Python中实现惰性计算和协程的核心工具,结合send()、throw()、close()等方法,能够构建高效、灵活的数据流和控制流模型,这... 目录迭代器的介绍自定义迭代器省略的迭代器生产器的介绍yield的普通用法yield的高级用法yidle

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

C++ Sort函数使用场景分析

《C++Sort函数使用场景分析》sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变,如果某些场景需要保持相同元素间的相对顺序,可使... 目录C++ Sort函数详解一、sort函数调用的两种方式二、sort函数使用场景三、sort函数排序

kotlin中const 和val的区别及使用场景分析

《kotlin中const和val的区别及使用场景分析》在Kotlin中,const和val都是用来声明常量的,但它们的使用场景和功能有所不同,下面给大家介绍kotlin中const和val的区别,... 目录kotlin中const 和val的区别1. val:2. const:二 代码示例1 Java

微信公众号脚本-获取热搜自动新建草稿并发布文章

《微信公众号脚本-获取热搜自动新建草稿并发布文章》本来想写一个自动化发布微信公众号的小绿书的脚本,但是微信公众号官网没有小绿书的接口,那就写一个获取热搜微信普通文章的脚本吧,:本文主要介绍微信公众... 目录介绍思路前期准备环境要求获取接口token获取热搜获取热搜数据下载热搜图片给图片加上标题文字上传图片

Go标准库常见错误分析和解决办法

《Go标准库常见错误分析和解决办法》Go语言的标准库为开发者提供了丰富且高效的工具,涵盖了从网络编程到文件操作等各个方面,然而,标准库虽好,使用不当却可能适得其反,正所谓工欲善其事,必先利其器,本文将... 目录1. 使用了错误的time.Duration2. time.After导致的内存泄漏3. jsO

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整