為什么我畫的頻譜圖和audacity、audition不一樣?

文章目錄

  • 系列文章目錄

    目錄

    文章目錄

    前言

    一、問題引入

    二、使用步驟

    三、分析和改進

    總結


前言

我們知道audacity和audition都有頻譜分析這個窗口,一般過程肯定是分幀加窗,fft變換然后呈現,

大體這個過程是沒問題的,但為什么我畫出來的頻譜圖和它們的不一樣?本篇文章就來分析這個


一、問題引入

一個典型的wav(一個底噪)的波形頻譜,在audition里面展示如下:

fft頻譜分析如下:

注意三個要素,window窗長,選取整個wav數據范圍,采用hanning窗

二、使用步驟

根據上面的分析,我們自己寫了一個頻譜分析的spectrum【AI寫的,我哪有那么厲害】

clear all
close all
clc[x,fs] = audioread('4-OK.wav');% 1. 分幀處理(假設信號長度是幀長的整數倍)
N = length(x);
signal = x;
winLen =2048;
numFrames = floor(N/winLen);
frames = reshape(signal(1:numFrames*winLen), winLen, numFrames);% 2. 加Hanning窗
window = hann(winLen);logMagAll = zeros(winLen/2+1, 1);
for i = 1:numFramesframe = frames(:,i) .* window;mag = abs(fft(frame, winLen));logMagAll = logMagAll + 10*log10(mag(1:winLen/2+1).^2 + 1e-16);
endlogMag = logMagAll/numFrames ;% 5. 繪圖
freq = (0:winLen/2)/winLen * fs; % 頻率軸
figure;
semilogx(freq(2:end), logMag(2:end)); % 對數頻率軸,跳過DC
xlabel('Frequency (Hz)');
ylabel('Magnitude (dB)');
title('Power Spectrum (Hanning window)');
grid on;

核心過程就是 分幀,加窗,先求 log對數,然后算完之后求平均

?

頻譜形狀是對的,但發現底噪和整體幅度有差別

底噪是-60,audition顯示底噪是-100多呢,這個地方肯定有問題,但倆形狀相似,很可能是增益導致,差了倍數。

倍數差在邊度呢?

三、分析和改進

audition的源代碼肯定是沒有,人商業軟件,被adobe買了,別想了。我們可以參考audacity 的, 先看看audacity分析的頻譜如何

低頻底噪太低,沒顯示全,但是沒關系,鼠標可以放到低頻,給出信息,大概-100多dB,那和audition的一樣,audacity的源代碼可是有的哦,馬上參考它的代碼;

?經過一系列的分析,我們知道這個函數是畫頻譜的地方【具體怎么分析得到的的可以參考韋神解五次方程的過程,就是題感!

關鍵是這個地方

方框部分,有個時域加權,對窗口系數的加權!

能量譜沒有什么特殊的,就是普通的fft計算?

回到? ?SpectrumAnalyst::Calculate 函數,這個地方 by每幀會 直接求和

也就是 應該先 求能量譜的總和,不著急求 log,

??????

等出每一幀的while循環之后呢

能量譜求 20倍log,幅度譜求10倍log

再乘以scale,scale里面有對每一幀的平均,194行

到這里就明白了,注意要點有兩個

1、注意要乘窗口歸一化權重 wss

2、注意先求 幅度譜加和,再平均,然后上對數,而不是先對數,再加和平均,經常玩log的都知道,說白了其實一個是算術平均,一個是幾何平均

行了,道理都清楚了,代碼的事情讓deepseek 出!嗷嗷的來吧你就

clear all
close all
clc[x,fs] = audioread('4-OK.wav');% 1. 分幀處理(假設信號長度是幀長的整數倍)
N = length(x);
signal = x;
winLen =2048;
numFrames = floor(N/winLen);
frames = reshape(signal(1:numFrames*winLen), winLen, numFrames);% 2. 加Hanning窗
window = hann(winLen);
wss = sum(window); % 窗譜和
if wss > 0wss = 4.0 / (wss^2); % 窗譜平方和歸一化因子
elsewss = 1.0;
end% 3. 計算每幀幅度譜平方和
MagAll = zeros(winLen/2+1, 1);
for i = 1:numFramesframe = frames(:,i) .* window;mag = abs(fft(frame, winLen));MagAll = MagAll + mag(1:winLen/2+1).^2;
end% 4. 計算對數幅度譜
scale = wss / numFrames;
logMag = 10 * log10(MagAll * scale);% 5. 繪圖
freq = (0:winLen/2)/winLen * fs; % 頻率軸
figure;
semilogx(freq(2:end), logMag(2:end)); % 對數頻率軸,跳過DC
xlabel('Frequency (Hz)');
ylabel('Magnitude (dB)');
title('Power Spectrum (Hanning window)');
grid on;

再看頻譜圖

行了,應該對上了,齊刷的!


總結

1、要會發現問題,別總以為自己的代碼最牛逼,實際根本不符合規律,-30dB底噪那么大,可能么?

2、要利用互聯網資源,能開源的為毛不用,deepseek自己寫也不一定你給正確代碼,還得靠自己分析

3、要會用deepseek,巧用ai,不受制于ai,才不會被ai卷死

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/89463.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/89463.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/89463.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

責任鏈模式 Go 語言實戰

責任鏈模式(Chain of Responsibility) 責任鏈模式是一種行為設計模式,它允許將請求沿著處理者鏈進行傳遞,直到有一個處理者能夠處理它。這個模式的主要目的是解耦請求的發送者和接收者,使得多個對象都有機會處理這個請…

使用開源項目youlai_boot 導入到ecplise 中出現很多錯誤

我是使用ecplise 導入得youlai_boot 這個項目,但是導入到ecplise 中一直出現報錯,然后各種maven clean 和maven install 以及update Maven 都沒有效果不知道怎么辦才好,怎么樣解決這個問題,原來是我本地的環境中沒有安裝 lombok.…

06_Americanas精益管理項目_數據分析

文章目錄 Americanas精益管理項目_數據分析(一)思維方法1、數據分析思維2、零售行業-萬能「人貨場」分析框架(二)商品分析1、品類銷量分析2、銷量趨勢分析3、帕累托法則分析4、商品TopN分析(三)用戶分析(四)場景分析Americanas精益管理項目_數據分析 數據分析與數據開…

ES6從入門到精通:類與繼承

ES6 類的基本概念 ES6 引入了基于類的面向對象編程語法,通過 class 關鍵字定義類。類可以包含構造函數、方法和屬性。 class Person {constructor(name) {this.name name;}greet() {console.log(Hello, ${this.name}!);} }const person new Person(Alice); pers…

【經驗】新版Chrome中Proxy SwitchyOmega2已實效,改為ZeroOmega

1、問題描述 手欠更新了 Chrome 導致無法“上網”,原因是 Proxy SwitchyOmega2 已實效。 2、解決方法 2.1 下載 新版Chrome中Proxy SwitchyOmega2已實效,改為ZeroOmega; 想方設法去下載 ZeroOmega 的crx包,最新的為&#xff1…

在windows上設置python的環境

安裝好了python,再具體說下python語言的相關環境。 #01 關于Python Python 是一個高級別的、邊運行邊解釋的、動態類型的編程語言,以簡潔的語法、強大的功能和豐富的資源庫而聞名。廣泛應用于 Web 開發、數據分析、人工智能、自動化腳本等多個領域。 目前 Python 語言有兩…

3D 建模與點云建模:從虛擬構建到實景復刻的數字孿生雙引擎

在數字化浪潮席卷全球的當下,3D 建模與點云建模如同數字世界的左膀右臂,一個以抽象化的創意構建虛擬藍圖,一個以高精度的實景數據復刻現實世界。它們不僅深刻重塑了影視娛樂、工業制造、建筑設計等傳統領域,更成為數字孿生技術蓬勃…

智能檢測原理和架構

大家讀完覺得有幫助記得關注和點贊!!! 智能檢測系統基于AI和大數據分析技術,通過主動感知、行為建模與實時響應構建動態防御體系。其核心在于將傳統規則匹配升級為**多模態威脅認知**,實現對新型攻擊(如AI…

2025年6月個人工作生活總結

本文為 2025年6月工作生活總結。 研發編碼 某國產操作系統curl下載sftp服務器文件問題記錄 場景: 某國產系統curl版本信息: # curl --version curl 7.71.1 (x86_64-koji-linux-gnu) libcurl/7.71.1 OpenSSL/1.1.1f-fips zlib/1.2.11 brotli/1.0.7 li…

Java 導出PDF 1、內容可以插入自定義表格 2、內容插入圖片

Java PDF導出工具:自定義表格與圖片插入 下面我將實現一個Java PDF導出工具,支持插入自定義表格和圖片的功能。這個解決方案使用iText 7庫,提供了一個直觀的用戶界面,可以預覽生成的PDF內容。 import javax.swing.*; import jav…

sklearn機器學習概述及API詳細使用指南

一、機器學習與sklearn簡介 機器學習是人工智能的一個分支,它通過算法讓計算機從數據中學習規律,并基于這些規律做出預測或決策。scikit-learn(簡稱sklearn)是Python中最流行的機器學習庫之一,它提供了各種監督學習和…

「日拱一碼」015 機器學習常用庫——scikit-learn

目錄 數據預處理 數據標準化(StandardScaler) 數據歸一化(MinMaxScaler) 數據離散化(KBinsDiscretizer) 缺失值處理(SimpleImputer) 特征選擇 基于單變量特征選擇&#xff08…

網絡編程學習路線

C網絡編程從零基礎到精通的學習路線,每一步都和你的項目實際需求緊密結合,幫助你真正做到“學以致用”。 C網絡編程學習路線(結合FileHub項目) 第一階段:網絡編程基礎入門 1. 計算機網絡基礎 理解OSI七層模型、TCP/I…

NLP:文本張量表示方法

本文目錄: 一、one-hot編碼二、word2vec模型(一)概念1.CBOW(Continuous bag of words)模式2.skipgram模式:3.詞向量的檢索獲取 (二)word2vec的訓練和使用1. 獲取訓練數據2.查看原始數據3.原始數據處理,并查…

高階數據結構------并查集

并查集 在一些應用問題中,需要將n個不同的元素劃分成一些不相交的集合。開始時,每個元素自成一個集合,然后按照一定的規律將歸于同一組的元素集合合并。在此過程中要反復用到查詢某一個元素歸屬于哪一個集合的運算。適合于描述這類問題的抽象…

OWASP Top 10 是什么?

OWASP(Open Web Application Security Project,開放Web應用安全項目)是一個致力于提高軟件安全性的國際非營利組織。其發布的 ?OWASP Top 10? 是最具影響力的Web應用安全風險清單,每3-4年更新一次,幫助開發人員、安全…

如何在IIS上部署net系統(安裝iis參考上一篇)

1.對后端項目打包,我使用的時rider 2.打包前端 npm run build 3.在iis上部署 網站-添加網站 4.選擇之前打包的后端文件,設置端口 5.安裝對應net環境插件:主要是runtime和sdk插件以及dotnet-hosting-2.2.0-win,具體版本看自己項…

Docker可視化管理工具Portainer安裝部署

1、安裝Portainer 編寫docker compose文件,使用docker compose文件完成Portainer的安裝,首先需要在服務器上編寫的名為portainer.yaml的文件,內容如下: [rootserver ~]# cat portainer.yaml services: portainer: image:…

ai之RAG本地知識庫--基于OCR和文本解析器的新一代RAG引擎:RAGFlow 認識和源碼剖析

目錄標題 RAG本地知識庫問答——基于OCR和文本解析器的新一代RAG引擎:RAGFlow 認識和源碼剖析RAGflow 主要功能: 一、RAGflow 簡介1.1 允許用戶上傳并管理自己的文檔(文檔類型可以是任意類型)1.2 RAGFlow的4個特色1.2.1 AI 模型的智能文檔處理系統1.2.2 …

[面試] 手寫題-new

function mynew(Func, ...args) {// 1.創建一個空對象const obj {}// 2.新對象隱式原型指向構造函數的顯式原型obj.__proto__ Func.prototype// 3.將構建函數的this指向新對象let result Func.apply(obj, args)// 4.返回objreturn result instanceof Object ? result : obj…