百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

傅里叶级数物理意义的直观理解:利用傅里叶级数逼近方波信号

moboyou 2025-05-14 14:30 32 浏览

上篇文章将向大家介绍频谱的概念,对傅里叶级数、傅里叶积分、傅里叶变换进行了数学的推导,并解释了它们各自的物理意义。推导过程见我的上一篇文章:频谱分析——频谱概念(傅里叶变换、级数、积分及物理意义)

如下图所示的方波表达式为:

傅里叶级数表示为:

其中

首先求傅里叶系数:

因此,得到的傅里叶级数的表达式为:


用MATLAB绘制一下傅里叶级数的曲线

先看看傅里叶级数40次谐波逐次叠加的结果的动态展示(偶次谐波为零,为方便展示,作图时忽略偶次谐波项)

左图是n次谐波的和,右图可以清晰直观地看出各次谐波叠加逼近原始方波的过程

接下来再看看傅里叶级数100次谐波逐次叠加的结果

1000次谐波叠加

10000次谐波叠加

将10000次谐波叠加的方波边缘处放大,发现有依然是有超调现象

这种现象称为吉布斯(Gibbs)现象

在时域描述一个不连续的信号时,要求信号有无穷的频率成分,但实际情况中不可能采样到无穷的频率成分,只能对一定频率范围的信号进行采样。

而对于方波这样具有跳跃间断点的信号,采样将会存在频率截断,频率截断会引起时域信号在不连续处产生“振铃效应”。吉布斯现象的产生有两个条件:(1) 对信号频谱的锐截止;(2) 原信号存在跳变点。

MATLAB代码如下:

clc,clear
f = 2; %输入方波的频率
A = 1; %输入方波的幅值
tw = 1;%持续时间,单位:秒
[t,y] = squareWave(f,A,tw);
%设置傅里叶级数的系数
a0 = A / 2;
n = 100; %谐波次数
sum = zeros(1 , length(t) );
sum = sum + a0;
% figure(2);
% plot(t,y);
% hold on
each_hm = zeros( n + 1 , 40000 );
hm = 0 : n;
for k = 1 : 2 : n
An = -( 2 * A / ( 2 * pi * k) ) * ( cos( k * pi ) - 1 );
y1 = An * sin( 2 * pi * k * t * f );
each_hm( k + 1 , : ) = y1;
sum = sum + y1;
each_hm( 1 , : ) = sum;

figure(2);
plot( t , sum );
title([ 'Sum of the first ', num2str(k) , ' harmonics'])

figure(3)
title([ 'For the first ' , num2str(k) , ' harmonics'])
plot3( t , zeros( 1 , 40000 ) , each_hm( 1 , : ) )
grid on
hold on
plot3( t , k * ones( 1 , 40000 ) , each_hm( k + 1 , : ) )
xlabel('t'); ylabel('Harmonic');

pause(0.5)
end
pause(0.5)
figure(2)
plot(t , y , '--' , 'LineWidth' , 2 );
hold on
plot( t , sum ,'LineWidth',1);
legend('Original Square Wave' , 'Fourier series approximation ')
title(['Sum of the first ' , num2str(k) , ' harmonics'])


%%方波生成代码 squareWave函数
function [t,y] = squareWave(freq,A,waveTime)
tt = waveTime;%sec
f = freq; %hz
tp = 1 / f;
fs = 20000 * f;
n1 = tp*fs;
t= 0 : 1 / fs : ( n1 - 1) / fs;
y1 = zeros(1 , n1);
y1(1 : n1 / 2) = A;
n2 = tt * fs
nw = tt / tp;
t2=0 : 1 / fs : ( n2 - 1 ) / fs;
y2 = zeros(1 , n2);
y2 = repmat(y1 , 1 , nw);
y = y2;
t = t2;
end

制作不易,欢迎关注+点赞+收藏支持作者!!!

相关推荐

原神:“天理”是什么?至今还有很多玩家没搞明白

原神已经更新到层岩巨渊,关于提瓦特的秘密却越来越多。然而,直到今天还有很多玩家不明白天理以及天理维系者的关系。这并不怪大家,因为剧情里根本没提,只能靠玩家去猜。天理是什么?在看完渊下宫的剧情之后,不少...

《原神》爆火3年仍无竞品:它的“致命武器”竟不是开放世界?

#原神的最大特点是什么?#《原神》爆火3年仍无竞品:它的“致命武器”竟不是开放世界?【独家观察】2023年8月,《原神》4.0版本“枫丹”上线首日登顶68国畅销榜,这个现象级产品再次向行业抛出灵魂拷问...

原神:每个人都是氪金大佬?除非在梦里!或许还有一种方法

游戏中的笔杆王者,每日靠玩游戏过日子,玩网游也有20个年头,我有自己独特的见解,作为一个10年不脱坑的老玩家,如果文章写的有什么问题,请重喷!如果大家觉得好,请转发加点赞!非常感谢!原神每个人都是氪金...

原神:丝柯克,又传新消息!入池时间,武器确定!第八元素无了!

原神:丝柯克,又传新消息!入池时间,武器确定!第八元素无了!新角色丝柯克已经确定会在5.7版本入池!作为公子的师傅,早在公子14岁时,丝柯克就已经是一位畅行于深渊的剑客了,如今成为执行官的公子,却只希...

原神服务端架构搭建工具+环境配置资料

我是艾西,今天给大家分享一份详细的原神服务端结构资料教程,从服务端的获取到端口的使用以及安卓和ios的DAIL签名等一文让你明白怎么架设原神服务端,哪些工具资料又代表着什么意思(保姆级教学)Grass...

在原神里钓鱼,有人竟然用上了深度强化学习,还把它开源了

机器之心报道机器之心编辑部还愁在《原神》里钓不到鱼吗?这有一份迟到的提瓦特钓鱼指南。在游戏圈,你可以没有玩过,但一定听过《原神》。虽然这是一款口碑两极分化的游戏,但不得不承认《原神》是当前最为火热的游...

BetterGI:让原神游戏更便捷的自动化工具

技术背景BetterGI是一个基于计算机视觉技术的项目,旨在让原神游戏变得更加便捷。它利用视觉算法和模拟操作,实现了多种游戏内的自动化功能,帮助玩家节省时间和精力。实现步骤系统要求操作系统:Wind...

原神:2.6服务端泄露?9999纠缠之缘秒到账,米哈游跻身全球15强

首先,恭喜米哈游凭借原神跻身全球应用开发商第14名,这个榜单记录了全球开发商在iOS&GooglePlay综合收入前52名的数据,第一腾讯第二网易,字节跳动第7,米哈游则排14名。值得一提的是,这个...

观鸣潮1.3前瞻有感,《原神》是屎山代码?七个问题拷打米哈游!

哈喽大家好啊。前天看完鸣潮1.3直播后,感触良多啊。虽然我对1.3的前瞻内容觉得中规中矩,没有太满意,但是对面策划的态度让我看到了差距。所以今天来拷打一下原神。就是对比隔壁策划面对玩家的反馈,所回答的...

PHP中的九大缓存技术(php中的九大缓存技术是什么)

1、全页面静态化缓存也就是将页面全部生成html静态页面,用户访问时直接访问的静态页面,而不会去走php服务器解析的流程。此种方式,在CMS系统中比较常见,比如dedecms;一种比较常用的实现方式是...

使用PhpStorm将代码同步到开发环境

配置步骤1、选择Tools>Deployment>Configuration:2、选择SFTP:3、输入servername:4、配置SSHconfiguration:5、配置...

PM小技术:使用SAE发布在线Axure文档

俗话说,不会写代码的产品经理不是好的射鸡湿。关于产品经理与技术之间的微妙关系,扯开了讲可是长篇大论,比如知乎上这个问题:IT行业产品经理(尤其是创业的)需要懂技术吗?懂到什么程度?,以及这个:产品经...

PHP新手如何提高代码质量(php代码教程)

1.不要使用相对路径常常会看到:require_once('../../lib/some_>该方法有很多缺点:它首先查找指定的php包含路径,然后查找当前目录.因此会检查过多路径.如果该脚本...

PHP代码中常用的优化策略(php性能优化及安全策略)

1、如果能将类的方法定义成static,就尽量定义成static,它的速度会提升将近4倍。2、$row['id']的速度是$row[id]的7倍。3、echo比print快,并...

PHP 没你想的那么差(php ml)

PHP现在名声很糟糕,因为它曾经是“可怕”的。本文试着回答一些常见的关于PHP的断言,目的是向非技术人员解释,PHP并不像许多人所说的那么糟糕。它是不是鼓励糟糕的实践?不再是了。过去,许多开发者...