小編給大家分享一下怎么使用python進(jìn)行波形及頻譜繪制,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
創(chuàng)新互聯(lián)公司是一家專注于做網(wǎng)站、成都做網(wǎng)站與策劃設(shè)計(jì),鐘祥網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)公司做網(wǎng)站,專注于網(wǎng)站建設(shè)十多年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:鐘祥等地區(qū)。鐘祥做網(wǎng)站價(jià)格咨詢:18982081108python主要應(yīng)用領(lǐng)域有哪些1、云計(jì)算,典型應(yīng)用OpenStack。2、WEB前端開(kāi)發(fā),眾多大型網(wǎng)站均為Python開(kāi)發(fā)。3.人工智能應(yīng)用,基于大數(shù)據(jù)分析和深度學(xué)習(xí)而發(fā)展出來(lái)的人工智能本質(zhì)上已經(jīng)無(wú)法離開(kāi)python。4、系統(tǒng)運(yùn)維工程項(xiàng)目,自動(dòng)化運(yùn)維的標(biāo)配就是python+Django/flask。5、金融理財(cái)分析,量化交易,金融分析。6、大數(shù)據(jù)分析。
如下所示:
# -*- coding: UTF-8 -*- import wave import numpy as np import matplotlib.pyplot as plt # 打開(kāi)wav文件 ,open返回一個(gè)的是一個(gè)Wave_read類的實(shí)例,通過(guò)調(diào)用它的方法讀取WAV文件的格式和數(shù)據(jù)。 f = wave.open(r"D:\project\REC001.wav","rb") # 讀取格式信息 # 一次性返回所有的WAV文件的格式信息,它返回的是一個(gè)組元(tuple):聲道數(shù), 量化位數(shù)(byte單位), 采 # 樣頻率, 采樣點(diǎn)數(shù), 壓縮類型, 壓縮類型的描述。wave模塊只支持非壓縮的數(shù)據(jù),因此可以忽略最后兩個(gè)信息 params = f.getparams() [nchannels, sampwidth, framerate, nframes] = params[:4] # 讀取波形數(shù)據(jù) # 讀取聲音數(shù)據(jù),傳遞一個(gè)參數(shù)指定需要讀取的長(zhǎng)度(以取樣點(diǎn)為單位) str_data = f.readframes(nframes) f.close() # 將波形數(shù)據(jù)轉(zhuǎn)換成數(shù)組 # 需要根據(jù)聲道數(shù)和量化單位,將讀取的二進(jìn)制數(shù)據(jù)轉(zhuǎn)換為一個(gè)可以計(jì)算的數(shù)組 wave_data = np.fromstring(str_data,dtype = np.short) # 將wave_data數(shù)組改為2列,行數(shù)自動(dòng)匹配。在修改shape的屬性時(shí),需使得數(shù)組的總長(zhǎng)度不變。 wave_data.shape = -1,2 # 轉(zhuǎn)置數(shù)據(jù) wave_data = wave_data.T # 通過(guò)取樣點(diǎn)數(shù)和取樣頻率計(jì)算出每個(gè)取樣的時(shí)間。 time=np.arange(0,nframes/2)/framerate # print(params) plt.figure(1) # time 也是一個(gè)數(shù)組,與wave_data[0]或wave_data[1]配對(duì)形成系列點(diǎn)坐標(biāo) plt.subplot(211) plt.plot(time,wave_data[0]) plt.xlabel("time/s") plt.title('Wave') N=44100 start=0 # 開(kāi)始采樣位置 df = framerate/(N-1) # 分辨率 freq = [df*n for n in range(0,N)] # N個(gè)元素 wave_data2=wave_data[0][start:start+N] c=np.fft.fft(wave_data2)*2/N # 常規(guī)顯示采樣頻率一半的頻譜 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()
看完了這篇文章,相信你對(duì)“怎么使用python進(jìn)行波形及頻譜繪制”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!
新聞名稱:怎么使用python進(jìn)行波形及頻譜繪制-創(chuàng)新互聯(lián)
文章出自:http://jinyejixie.com/article38/jjdpp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供手機(jī)網(wǎng)站建設(shè)、App設(shè)計(jì)、網(wǎng)站排名、網(wǎng)站收錄、動(dòng)態(tài)網(wǎng)站、做網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容