死磕带通滤波器

死磕带通滤波器带通滤波器的作用与陷波器类似,带通滤波器在数字电源控制领域有重要作用。比如在三相LCL逆变器的谐振抑制控制方面,通过带通滤波器可以提取谐振点附近的频谱做进一步的控制策略。在有源电力滤波器利用带通滤波器可以提取电网信号的基波频率从而做进一步的控制。带通滤波器传递函数带通滤波器的传递函数是:h(s)=AwoBss2+Bs+wo2h(s)=\frac{Aw_oBs}{s^2+Bs+w_o^2}h(s)=s2+Bs+wo2​Awo​Bs​其中,wow_owo​是带通的“中心频率”,也就是想要通过频率

大家好,又见面了,我是你们的朋友全栈君。

带通滤波器的作用

与陷波器类似,带通滤波器在数字电源控制领域有重要作用。比如在三相LCL逆变器的谐振抑制控制方面,通过带通滤波器可以提取谐振点附近的频谱做进一步的控制策略。在有源电力滤波器利用带通滤波器可以提取电网信号的基波频率从而做进一步的控制。

带通滤波器传递函数

带通滤波器的传递函数是:
h ( s ) = A w o B s s 2 + B s + w o 2 h(s)=\frac{Aw_oBs}{s^2+Bs+w_o^2} h(s)=s2+Bs+wo2AwoBs
其中, w o w_o wo 是带通的“中心频率”,也就是想要通过频率的中心点频率。 B B B是带通的频宽比,注意此处频宽比是一个相对于中心频率的比例,比如:
w o = 50 ∗ 2 ∗ p i w_o=50*2*pi wo=502pi
B = 0.2 B=0.2 B=0.2
表达的意义是设定中心频率为50Hz,带通的带宽为50*0.2=10Hz。

带通滤波器的伯德图

设定“中心频率”为50Hz,频宽比为0.4。用matlab绘制伯德图,如下:
带通滤波器的幅频特性
可见,仅仅在50Hz附近有大于0的增益,其他频率点都被抑制了。于是就有了“带通”的效果。

离散化

上述都是在连续域中分析的,但是对于数字控制应用,它是无法落地实现的,所以我们需要对连续域模型进行离散化分析。

Z变换

利用Z变换可以离散化。也可以利用matlab对S函数进行Z变换,选定离散时间Ts=0.0002,则其Z变换如下:
F ( z ) = 0.0012557 z − 0.0012557 z 2 − 1.996 z + 0.999920 F(z)=\frac{0.0012557z-0.0012557}{z^2-1.996z+0.999920} F(z)=z21.996z+0.9999200.0012557z0.0012557

差分方程

z变换后很自然能得到差分方程,只需要对分子分母除以 z z z的最高次幂:
Y X = 0.0012557 X k − 1 − 0.0012557 X k − 2 1 − 1.996 X k − 1 + 0.999920 X k − 2 \frac{Y}{X}=\frac{0.0012557X_{k-1}-0.0012557X_{k-2}}{1-1.996X_{k-1}+0.999920X_{k-2}} XY=11.996Xk1+0.999920Xk20.0012557Xk10.0012557Xk2
有了差分方程,程序的实现可以落到实地。在Matlab的m文件中编写matlab function为例说明:

function Y = BandFilter(X)
%#codegen
%% 中间变量定义及初始化
Num0 = 0;
Num1 = 0.0012557;
Num2 = -0.0012557;

Den0 = 1;
Den1 = -1.996;
Den2 = 0.999920;

persistent Xk_1; %1次的输入
persistent Xk_2; %2次的输入

persistent Yk_1; %1次的输出
persistent Yk_2; %2次的输出

if isempty(Xk_1)   Xk_1 = 0;
end
if isempty(Xk_2)   Xk_2 = 0;
end
if isempty(Yk_1)   Yk_1 = 0;
end
if isempty(Yk_2)   Yk_2 = 0;
end
%% 执行计算
Temp = Num0*X + Num1*Xk_1 + Num2*Xk_2 - (Den1*Yk_1 + Den2*Yk_2);
Y = Temp/Den0;
Xk_2 = Xk_1;
Xk_1 = X;
Yk_2 = Yk_1;
Yk_1 = Y;

Simulink仿真

利用Sum模块将50Hz、1Hz、500Hz正弦信号,以及直线信号、随机信号,这5个信号相加,得到一组带有谐波的信号注入到带通滤波器,结构图如下所示:
带通滤波器的Simulink仿真
从仿真结果可以看到:滤波后,除了50Hz的波形被保留下来,其他波形都被滤除了。可见,带通滤波器在杂波信号中获取指定次的谐波有较好的效果。
在这里插入图片描述

参考文献

二阶滤波器的标准传递函数

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/133885.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • android 常用加密,分享一下Android各种类型的加密

    android 常用加密,分享一下Android各种类型的加密以下内容仅供参考具体情况以实际为准360加固assets/.appkeyassets/libjiagu.so爱加密lib/armeabi/libexecmain.soassets/ijiami.ajmassets/af.binassets/signed.binassets/ijm_lib/armeabi/libexec.soassets/ijm_lib/X86/libexec.so几维安全asse…

    2022年5月16日
    46
  • IntelliJ IDEA 创建Java项目[通俗易懂]

    IntelliJ IDEA 创建Java项目[通俗易懂]Java模块让你可以开发JavaSE和JavaEE应用程序。由Java模块提供的核心功能可通过加入各种技术和框架支持进行扩展。当您创建好一个项目后,您可以创建一个Java模块。您还可以添加一个Java模块到现有项目。注意:这里说的Java模块实际是一个Java项目,而IDEA的项目(Project)则相当于Eclipse的工作空间(workspace)的概念,相当于VS的解决方案(soluti

    2022年9月29日
    0
  • decimal 整数 mysql_MySQL decimal类型

    decimal 整数 mysql_MySQL decimal类型在本教程中,我们将向您介绍MySQLDECIMAL数据类型以及如何在数据库表中有效地使用它。MySQLDECIMAL数据类型简介MySQLDECIMAL数据类型用于在数据库中存储精确的数值。我们经常将DECIMAL数据类型用于保留准确精确度的列,例如会计系统中的货币数据。要定义数据类型为DECIMAL的列,请使用以下语法:column_nameDECIMAL(P,D);在上面的语法中:P…

    2022年7月17日
    13
  • git 回滚到指定版本_git回滚多了怎么办

    git 回滚到指定版本_git回滚多了怎么办我们在GIT操作项目时,往往会遇到很多需要回滚的代码。我们可以回滚到任意之前的版本,case如下:1.首先找到你需要回滚的版本号,可以通过日志查看命令行:gitlog-32.选择上图红色箭头执行的commit版本号,第一个时最后提交的,我们回滚到第二个commit:f3eb8f9df34dc6ba47e477e05c8772a62d653fbb命令行:gitr

    2022年10月25日
    0
  • python fabric实现远程操作和部署

    python fabric实现远程操作和部署

    2021年12月6日
    33
  • 史上最简单MySQL教程详解(基础篇)之多表联合查询

    史上最简单MySQL教程详解(基础篇)之多表联合查询常用术语表连接的方式数据准备student表college表内连接外连接左外连接右外连接注意事项:自连接子查询在上篇文章史上最简单MySQL教程详解(基础篇)之数据库设计范式及应用举例我们介绍过,在关系型数据库中,我们通常为了减少数据的冗余量将对数据表进行规范,将数据分割到不同的表中。当我们需要将这些数据重新合成一条时,就需要用到我们介绍来将…

    2022年5月23日
    44

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号