微实践 - 方波信号的傅里叶正弦展开
创作时间:
作者:
@小白创作中心
微实践 - 方波信号的傅里叶正弦展开
引用
1
来源
1.
http://codelearn.club/2024/03/fourier/
法国数学家傅里叶指出任何周期函数都可以表示为不同频率的正弦函数和(或)余弦函数的和,每个正弦或者余弦函数乘以不同的系数。这一看似简单的数学表达被称为傅里叶级数,它构成了数字信号处理的数学基石。
本文节选自《Python编程基础及应用》,高等教育出版社,作者:陈波,刘慧君
此处我们以数字电路中广泛使用的方波为例,使用不同频率和振幅的正弦波来构造方波。从而帮助读者在高等数学的理论教学之外,体验傅里叶级数的实践价值。
图10-4 方波(-2π至2π)
如图10-4所示的振幅A=1,周期T=2π的标准方波的傅里叶级数展开式为:
以上述公式为基础,下述程序生成了4个不同频率、不同振幅的正弦信号分量,并将这些分量求和,以“求得”方波信号。
#fourier.py
import numpy as np
import matplotlib.pyplot as plt
t = np.linspace(-2*np.pi,2*np.pi,1000)
N = 4
r = np.zeros(1000)
plt.xlim(-2*np.pi,2*np.pi+5)
for n in range(1,N+1):
f = 4/ np.pi * np.sin((2* n -1) * t) / (2* n -1)
r += f
if n<=4:
s = "${4sin(%dt)}/{%d\\pi}$"% (2*n-1,2*n-1)
plt.plot(t, f+2.0*(5-n),label=s)
plt.plot(t, r, label='$r=\sum$')
plt.legend()
plt.title("Fourier Series of a Square Wave")
plt.show()
上述程序的执行结果如图10-5所示。
图10-5 包含4个正弦分量的“方波”
- 第4行:生成从-2π到+2π,包含1000个元素的等差数列t。数组t在本例中对应时间轴(横轴)。
- 第5行:N表示拟参与叠加生成“方波”的正弦分量数。
- 第6行:生成形状为(1000,)的浮点数数组r,用于保存结果“方波”。
- 第8行:设置matplotlib图表的横轴范围。在本例中,时间轴t的取值范围为-2π ~ +2π,请注意本行代码故意给右限值加5,是为了给图10-5右上角的图示框预留空间。
- 第9 ~ 11行:通过循环依次计算各正弦分量,并累加给“方波”r。
- 第10行:按公式计算方波的正弦分量f。根据10.1.4节中的讨论,本行中的np.sin()函数,以及乘、除等四则运算,均为ufunc函数,其作用范围为数组的全部元素。
- 第11行:将正弦分量f累加给“方波”r。
- 第12 ~ 14行:绘制前4个正弦分量曲线。
- 第13行:s对应分量曲线的标签。请注意,该标签字符串以美元符号开始,美元符号结束,这表示该标签字符串为LaTeX格式公式。LaTeX公式是在学术文献写作过程中广泛采用的一种数学公式标记方法,详情可网上查询。由于LaTeX公式采用{}来包裹公式符号,正好与4.1.6节所述的字符串格式化中所用占位符形式冲突。为了处理这种冲突,我们不得不采用%格式的字符串格式化方法,语法细节请见4.1.6节中的扩展阅读。
- 第14行:plt.plot(t, f+2.0*(5-n),…)函数用于绘制折线图,当折线图的构成点足够密集时,看起来就是一条光滑曲线。t对应所有离散点的横轴坐标,f+2.0*(5-n)则对应所有离散点的纵轴坐标,关键字参数label为曲线的标签。为了避免各曲线在图表中重叠显示,这里给正弦分量f加上了2.0*(5-n),有意将相应曲线在纵向上抬高。请读者注意,这里的f上形状为(1000,)的一维数组,而2.0*(5-n)的结果为浮点数,两者之间的加法操作事实上是通过ufunc函数进行的,该加法函数将f中的每个元素都与浮点数相加,生成一个新的一维数组。
- 第16行:以标签“r=∑”显示结果“方波”r。
如图10-5中的结果方波“r=∑”看起来并不标准,因为它只包含了4个不同频率和振幅的正弦分量。按傅里叶级数,参与叠加的正弦分量的数量增多,结果曲线越接近标准方波。图10-6展示了包含20个和1000个正弦分量的方波信号。在程序fourier.py中,修改N值即可调整方波所包含的正弦分量个数。
图10-6 包含20个(上)和1000个(下)正弦分量的方波信号
本文原文来自codelearn.club
热门推荐
如何化解被拉黑的情况,重建友好关系
拉黑一个人,究竟意味着什么?深度剖析背后的心理与社会现象
王昭君:四大美女的和亲传奇
安全生产事故应急预案有哪些要点?
揭秘看守所:你不知道的卫生管理真相
看守所生活揭秘:心理压力有多大?
揭秘看守所健康管理:从健康检查到心理疏导
哈士奇嚎叫太扰民?试试这些小妙招
揭秘哈士奇的嚎叫:狼性基因还是性格使然?
秋田犬的嚎叫之谜:揭秘背后的生物奥秘
哈士奇为啥总爱嚎叫?科学解密来了!
狗狗为啥总乱叫?专家揭秘背后原因
心理韧性:解锁长寿新密码
王昭君:从悲情女子到神女的华丽转身
王昭君出塞:一段改变历史的“跨国婚姻”
鄂东南系列拐卖儿童案:技术进步与社会防范的双重启示
被拐儿童回家后的心理创伤:一个不容忽视的社会课题
水煮虾时,用“开水”还是冷水?原来一直做错了,难怪虾又老又干
秋冬必备止咳神器:马蹄猪肺汤的功效与制作详解
饭桌这五种嘌呤食物,别老吃易结晶沉积!痛风专家周桂兰详解答!
严选最适儿童的健康海鲜
带鱼表面银色需要去掉吗 带鱼怎么吃营养
央视曝光“毒枸杞”!一文教你鉴别常见药材,快收藏
冷宴华教你设置和平精英最稳灵敏度
枸杞子在中医药中的应用及其健康影响
公安部夏季治安整治行动再创佳绩
昂素派出所:多措并举筑牢反诈防线
中医调理晚上睡眠不好的方法
广东茂名:农文旅融合“新业态” 激活乡村振兴新活力
安全隐患排查治理制度有哪些要点