数字一阶低通滤波器simulink仿真

原理

程序所用公式

y(n) = q*x(n) + (1-q)*y(n-1)
其中,y(n)表示当前的输出,x(n)表示当前的输入,y(n-1)表示上一次的输出,q为滤波系数。
链接: 参见 数字 一阶低通滤波器 详细分析.

滤波系数计算方法

q < F2π*t
其中,q为滤波系数(通常小于1),F为截止频率,t为计算频率。
链接: 参见 RC一阶低通滤波的软件实现及相关参数计算.

但实际应用时发现该方法计算的q还需更小一些。

仿真

根据公式搭建

主要部分如下,截止频率根据RC电路计算得到:

理想信号为正弦波,幅值10,频率1Hz。噪音为正弦波,幅值1,频率10kHz。如图所示:

延时模块采样频率10kHz,即设为1e-4(对应为10kHz的PWM触发ADC采样)。
模型仿真设置为固定步长1e-6,仿真时长2s。

输出结果如下图:

使用simulink自带模型

主要部分如下:

低通滤波器截止频率1540Hz,具体设置如下:

其它设置同上。

输出结果如下图:

  • 28
    点赞
  • 168
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
低通滤波器截止频率是指在滤波器的输出信号中,高于该频率的信号被衰减到一定程度,以达到滤波的目的。在进行低通滤波器截止频率的仿真时,可以使用一些常见的工具和软件,例如MATLABSimulink、SPICE等。 以下是在MATLAB中进行低通滤波器截止频率仿真的步骤: 1. 定义滤波器类型和截止频率 可以选择不同类型的滤波器,例如Butterworth滤波器、Chebyshev滤波器和Elliptic滤波器等。在此假设采用Butterworth滤波器。 截止频率通常以角频率的形式给出。假设截止频率为100Hz,则其对应的角频率为2π×100=628.32rad/s。 2. 计算滤波器传递函数 使用MATLAB中的butter函数,根据所选滤波器类型和截止频率计算出滤波器的传递函数。 例如,对于一阶Butterworth低通滤波器,可以使用以下代码: ```matlab Wc = 628.32; % 截止频率 n = 1; % 阶数 [b,a] = butter(n,Wc,'s'); ``` 其中,b和a分别为滤波器的分子和分母多项式系数。 3. 绘制滤波器幅频响应曲线 使用MATLAB中的freqs函数,绘制出滤波器的幅频响应曲线。 例如,可以使用以下代码: ```matlab w = logspace(0,4,1000); % 频率范围 h = freqs(b,a,w); semilogx(w,20*log10(abs(h))); % 绘制幅频响应曲线 xlabel('Frequency (rad/s)'); ylabel('Magnitude (dB)'); grid on; ``` 其中,logspace函数用于生成频率范围,semilogx函数用于绘制幅频响应曲线。 绘制出的幅频响应曲线可以用于分析滤波器的性能,例如截止频率的准确性、滤波器的衰减特性等。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值