使用matlab辨识工具来估算震动系统的传递函数

Matlab辨识工具箱里面的函数很多,这里用一个简单的例子来展示估算系统传递传递函数的使用方法。

比如我们的任务是,已知系统的输入输出,而系统未知,是个黑盒子,需要我们去估算系统的传递特性

我们的系统输入输出数据如下

67167798d9864c819b616e8065562e9c.png

5da1265cad7742ed80a1504cb643d270.png

 系统未知,我们通过 功率谱估算 来求解系统响应

 Transfer function estimate - MATLAB tfestimate6c049c56e6b442c881d9444ad4ceb57c.png

 互功率谱和自功率谱相除就得到了系统频响

[pxx,f1] = pwelch(x,window,noverlpap,Nfft,fs);

[pyx ,f2]= cpsd(y,x,window,noverlpap,Nfft,fs);

tfunc=pyx./pxx;

我们得到系统频响(幅度和相位)

plot(f,(abs(tfunc)));
title('传输tf幅度 小范围');
xlim([0,20]);
 

plot(f,(angle(tfunc)));
title('传输tf相位 小范围');
xlim([0,20]);
ypf = angle(tfunc);

 这刚好和我们用82fe94af9c9f44c298cf909c7bf86b7f.png得到的 频响是一致的

0da0ed2d125146ef9ab53eb404cfaf2d.png

下面估算系统的传递函数

Create Frequency Response Object

sysfr = idfrd(ResponseData,Frequency,Ts) creates a discrete-time idfrd object that stores the frequency response ResponseData of a linear system at frequency values FrequencyTs is the sample time. For a continuous-time system, set Ts to 0.

sys = arx(data,[na nb nk]) estimates the parameters of an ARX or an AR idpoly model sys using a least-squares method and the polynomial orders specified in [na nb nk]. The model properties include covariances (parameter uncertainties) and goodness of fit between the estimated and measured data.

e87e8e39fc0a43adacfcf391c485ef21.png

 上na nb nk分别是,分母系数个数,分子系数个数和delay

很遗憾,我们也不具体了解这个未知系统的 零极点个数(或者说多项式的阶数)

ypf = abs(tfunc);
xpf = f;

frdobj = idfrd(ypf,xpf,1/fs);

modelobj = arx(frdobj,[4 3 0])

modeltf = tf(modelobj);

b = cell2mat(get(modeltf,'Numerator'));
a = cell2mat(get(modeltf,'Denominator'));

估算的系统响应,已经把两个峰值的特性 仿真出来了

 19e873d18f844bff9bbf3646b42b41d8.png

单位冲击

step(modeltf)

47cec4ce73b1471f8982de34a40f5cf9.png

传递函数

f557454215ce4bf5a0087cbc83838cd5.png

零极点形式

890051e8d93d47a68ae1f7b355cddae1.png

 zplane 零极点图 

 907fc4f1641e4663addbda186bc5a636.png

Matlab传递函数辨识工具箱是用于分析和建模连续或离散系统工具。你可以使用系统辨识工具箱来估计系统传递函数模型,即系统的输入和输出之间的关系。首先,在Matlab命令行窗口输入"systemIdentification"即可打开系统辨识工具箱。然后,你可以使用plot函数来绘制传递函数的幅度和相位曲线。例如,使用plot函数绘制传递函数的幅度曲线可以使用如下命令:plot(f,(abs(tfunc))); title('传输tf幅度 小范围'); xlim([0,20]);。同样地,你还可以使用plot函数绘制传递函数的相位曲线,例如:plot(f,(angle(tfunc))); title('传输tf相位 小范围'); xlim([0,20]); ypf = angle(tfunc);。通过这些方法,你可以对传递函数进行辨识和分析。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [MATLAB如何进行系统辨识传递函数)](https://blog.csdn.net/qq_39010320/article/details/119902951)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [使用matlab辨识工具估算震动系统传递函数](https://blog.csdn.net/book_bbyuan/article/details/126298989)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值