微实践 - 方波信号的傅里叶正弦展开
创作时间:
作者:
@小白创作中心
微实践 - 方波信号的傅里叶正弦展开
引用
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
热门推荐
智利,是一个什么样的国家?智利,为何发展成这样?
科技赋能 加“数”前行 让铁路出行更智慧更安全
推荐三种运动方式:健康生活,从运动开始
400分考生大学选择指南:在务实中创造人生转机
重固段示范区线和北青公路改扩建项目效果图来啦,抢先看→
考研冲刺阶段复习攻略:从计划到资料全方位指导
水煮牛肉的历史渊源与文化意义
揭秘古代女子为何不能轻易露脚:缠足习俗背后的深层原因
文化中国行|老字号同仁堂的“青春密码”
解释:《鬼灭之刃》中无惨拒绝回归人性的原因
厚床垫好还是薄的好?该如何选购呢?
毕业照就这么拍!“保姆级”教程上线!
八达岭夜长城再度开放 将持续至十一假期
探究海蓝宝手镯的价格因素:品质、稀有度与市场行情
财务原始凭证能修改吗?
工地施工中脚手架作业的注意事项
《荣耀新三国》蜀国武将阵容角色榜攻略排名
小岗村变身最佳旅游村:从农村改革第一村到文旅新地标
一天一根胡萝卜,癌症远离我?常吃还能延长寿命、防治心血管疾病
【风压传感器安装位置】安装需要注意什么?
SAP模块功能一览
战场上吃什么最扛饿?中国压缩饼干吃一块顶一天,到底是什么原理
海蓝宝真假辨别,海蓝宝真假辨别方法
原画角色设计思路分享
中国基础科学重大成果!无漏洞验证哈代悖论,量子力学又赢麻了!
齐鲁干烘茶:400年历史的黄茶瑰宝
查骨龄需要挂什么科
CNC加工行业:未来趋势与技术革新深度解析
医生遗嘱:医学智慧与人生感悟的法律体现
铝外壳的清洁方法