当前位置:   article > 正文

使用python进行波形及频谱绘制_python波形生成工具

python波形生成工具
  1. # -*- coding: UTF-8 -*-
  2. import wave
  3. import numpy as np
  4. import matplotlib.pyplot as plt
  5. # 打开wav文件 ,open返回一个的是一个Wave_read类的实例,通过调用它的方法读取WAV文件的格式和数据。
  6. f = wave.open(r"D:\project\REC001.wav","rb")
  7. # 读取格式信息
  8. # 一次性返回所有的WAV文件的格式信息,它返回的是一个组元(tuple):声道数, 量化位数(byte单位), 采
  9. # 样频率, 采样点数, 压缩类型, 压缩类型的描述。wave模块只支持非压缩的数据,因此可以忽略最后两个信息
  10. params = f.getparams()
  11. [nchannels, sampwidth, framerate, nframes] = params[:4]
  12. # 读取波形数据
  13. # 读取声音数据,传递一个参数指定需要读取的长度(以取样点为单位)
  14. str_data = f.readframes(nframes)
  15. f.close()
  16. # 将波形数据转换成数组
  17. # 需要根据声道数和量化单位,将读取的二进制数据转换为一个可以计算的数组
  18. wave_data = np.fromstring(str_data,dtype = np.short)
  19. # 将wave_data数组改为2列,行数自动匹配。在修改shape的属性时,需使得数组的总长度不变。
  20. wave_data.shape = -1,2
  21. # 转置数据
  22. wave_data = wave_data.T
  23. # 通过取样点数和取样频率计算出每个取样的时间。
  24. time=np.arange(0,nframes/2)/framerate
  25. # print(params)
  26. plt.figure(1)
  27. # time 也是一个数组,与wave_data[0]或wave_data[1]配对形成系列点坐标
  28. plt.subplot(211)
  29. plt.plot(time,wave_data[0])
  30. plt.xlabel("time/s")
  31. plt.title('Wave')
  32. N=44100
  33. start=0
  34. # 开始采样位置
  35. df = framerate/(N-1)
  36. # 分辨率
  37. freq = [df*n for n in range(0,N)]
  38. # N个元素
  39. wave_data2=wave_data[0][start:start+N]
  40. c=np.fft.fft(wave_data2)*2/N
  41. # 常规显示采样频率一半的频谱
  42. plt.subplot(212)
  43. plt.plot(freq[:round(len(freq)/2)],abs(c[:round(len(c)/2)]),'r')
  44. plt.title('Freq')
  45. plt.xlabel("Freq/Hz")
  46. plt.show()

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/106504
推荐阅读
相关标签
  

闽ICP备14008679号