使用python进行波形及频谱绘制的方法
Python  /  管理员 发布于 7年前   320
如下所示:
# -*- coding: UTF-8 -*-import waveimport numpy as npimport matplotlib.pyplot as plt # 打开wav文件 ,open返回一个的是一个Wave_read类的实例,通过调用它的方法读取WAV文件的格式和数据。f = wave.open(r"D:\project\REC001.wav","rb")# 读取格式信息# 一次性返回所有的WAV文件的格式信息,它返回的是一个组元(tuple):声道数, 量化位数(byte单位), 采# 样频率, 采样点数, 压缩类型, 压缩类型的描述。wave模块只支持非压缩的数据,因此可以忽略最后两个信息params = f.getparams()[nchannels, sampwidth, framerate, nframes] = params[:4]# 读取波形数据# 读取声音数据,传递一个参数指定需要读取的长度(以取样点为单位)str_data = f.readframes(nframes)f.close()# 将波形数据转换成数组# 需要根据声道数和量化单位,将读取的二进制数据转换为一个可以计算的数组wave_data = np.fromstring(str_data,dtype = np.short)# 将wave_data数组改为2列,行数自动匹配。在修改shape的属性时,需使得数组的总长度不变。wave_data.shape = -1,2# 转置数据wave_data = wave_data.T# 通过取样点数和取样频率计算出每个取样的时间。time=np.arange(0,nframes/2)/framerate# print(params)plt.figure(1)# time 也是一个数组,与wave_data[0]或wave_data[1]配对形成系列点坐标plt.subplot(211)plt.plot(time,wave_data[0])plt.xlabel("time/s")plt.title('Wave') N=44100start=0# 开始采样位置df = framerate/(N-1)# 分辨率freq = [df*n for n in range(0,N)]# N个元素wave_data2=wave_data[0][start:start+N]c=np.fft.fft(wave_data2)*2/N# 常规显示采样频率一半的频谱plt.subplot(212)plt.plot(freq[:round(len(freq)/2)],abs(c[:round(len(c)/2)]),'r')plt.title('Freq')plt.xlabel("Freq/Hz")plt.show()
以上这篇使用python进行波形及频谱绘制的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号