• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

使用python进行波形及频谱绘制的方法

python 搞代码 4年前 (2022-01-07) 27次浏览 已收录 0个评论

今天小编就为大家分享一篇使用python进行波形及频谱绘制的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

如下所示:

 # -*- coding: UTF-8 -*- import wave import<b style="color:transparent">来源gao@!dai!ma.com搞$$代^@码!网</b> numpy as np import 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=44100 start=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进行波形及频谱绘制的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持gaodaima搞代码网

以上就是使用python进行波形及频谱绘制的方法的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:使用python进行波形及频谱绘制的方法
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址