Python实现正弦信号的时域波形和频谱图示例【基于matplotlib】

作者:落落图灵 时间:2023-03-18 02:18:43 

本文实例讲述了Python实现正弦信号的时域波形和频谱图。分享给大家供大家参考,具体如下:


# -*- coding: utf-8 -*-
# 正弦信号的时域波形与频谱图
import numpy as np
import matplotlib.pyplot as pl
import matplotlib
import math
import random
row = 4
col = 4
N = 500
fs = 5
n = [2*math.pi*fs*t/N for t in range(N)]  # 生成了500个介于0.0-31.35之间的点
# print n
axis_x = np.linspace(0,3,num=N)
#频率为5Hz的正弦信号
x = [math.sin(i) for i in n]
pl.subplot(221)
pl.plot(axis_x,x)
pl.title(u'5Hz的正弦信号',fontproperties='SimHei')
pl.axis('tight')
#频率为5Hz、幅值为3的正弦+噪声
x1 = [random.gauss(0,0.5) for i in range(N)]
xx = []
#有没有直接两个列表对应项相加的方式??
for i in range(len(x)):
 xx.append(x[i]*3 + x1[i])
pl.subplot(222)
pl.plot(axis_x,xx)
pl.title(u'频率为5Hz、幅值为3的正弦+噪声',fontproperties='SimHei')
pl.axis('tight')
#频谱绘制
xf = np.fft.fft(x)
xf_abs = np.fft.fftshift(abs(xf))
axis_xf = np.linspace(-N/2,N/2-1,num=N)
pl.subplot(223)
pl.title(u'频率为5Hz的正弦频谱图',fontproperties='SimHei')
pl.plot(axis_xf,xf_abs)
pl.axis('tight')
#频谱绘制
xf = np.fft.fft(xx)
xf_abs = np.fft.fftshift(abs(xf))
pl.subplot(224)
pl.title(u'频率为5Hz的正弦频谱图',fontproperties='SimHei')
pl.plot(axis_xf,xf_abs)
pl.axis('tight')
pl.show()

运行效果:

Python实现正弦信号的时域波形和频谱图示例【基于matplotlib】

希望本文所述对大家Python程序设计有所帮助。

来源:https://blog.csdn.net/matrix_google/article/details/60964638

标签:Python,正弦,频谱图,matplotlib
0
投稿

猜你喜欢

  • python爬虫(入门教程、视频教程) <font color=red>原创</font>

    2021-10-28 22:04:08
  • MySQL定时任务不能正常执行的原因分析及解决方法

    2024-01-23 16:28:24
  • CentOS 6.6服务器编译安装lnmp(Nginx1.6.2+MySQL5.6.21+PHP5.6.3)

    2023-11-15 06:40:50
  • Python工程师必考的6个经典面试题

    2021-07-01 02:55:32
  • Git Submodule管理项目子模块的使用

    2023-10-06 20:34:57
  • Oracle中判断字段是否为数字

    2024-01-13 13:00:13
  • Python实现将DNA序列存储为tfr文件并读取流程介绍

    2021-08-04 08:02:23
  • Vue3 ref构建响应式变量失效问题及解决

    2023-07-02 16:33:49
  • MySQL查询冗余索引和未使用过的索引操作

    2024-01-22 22:04:23
  • php支持中文字符串分割的函数

    2023-11-18 21:42:04
  • jQuery中each方法的使用详解

    2024-04-09 19:47:22
  • 对python使用http、https代理的实例讲解

    2022-03-13 00:03:08
  • Python表达式的优先级详解

    2021-09-21 14:24:59
  • MySQL下高可用故障转移方案MHA的超级部署教程

    2024-01-27 13:53:23
  • Python 使用指定的网卡发送HTTP请求的实例

    2022-07-05 05:30:00
  • windows系统下Python环境搭建教程

    2021-06-25 11:07:53
  • PyCharm使用教程之搭建Python开发环境

    2021-09-01 15:21:00
  • asp,php 和 jsp 比较 之我见

    2007-08-10 13:35:00
  • 简单谈谈Python中的反转字符串问题

    2022-02-24 11:55:07
  • node.js操作mysql(增删改查)

    2024-01-26 00:02:50
  • asp之家 网络编程 m.aspxhome.com