Konstanta-Q transformace - Constant-Q transform
V matematice a zpracování signálu, transformace konstantní Q transformuje datovou řadu do frekvenční domény. Souvisí to s Fourierova transformace[1] a velmi úzce souvisí s komplexem Morletova vlnka přeměnit.[2]
Transformaci lze považovat za řadu filtrů Fk, logaritmicky rozmístěné podle frekvence, s k-tý filtr s a spektrální šířka δfk rovná násobku šířky předchozího filtru:
kde δfk je šířka pásma k-tý filtr, Fmin je střední frekvence nejnižšího filtru a n je počet filtrů na oktáva.
Výpočet
The krátkodobá Fourierova transformace z X[n] pro snímek posunutý na vzorek m se počítá takto:
Vzhledem k datové řadě vzorkované v Fs = 1/T, T jako perioda vzorkování našich dat můžeme pro každý frekvenční koš definovat následující:
- Šířka filtru, δfk.
- Q„faktor kvality“:
- Níže je uveden celočíselný počet cyklů zpracovaných na střední frekvenci Fk. Jako takový to poněkud definuje časovou složitost transformace.
- Délka okna pro k-th bin:
- Od té doby Fs/Fk je počet vzorků zpracovaných za cyklus při frekvenci Fk, Q je počet celočíselných cyklů zpracovaných na této střední frekvenci.
Ekvivalentní transformační jádro lze nalézt pomocí následujících substitucí:
- Délka okna každého koše je nyní funkcí čísla koše:
- Relativní výkon každého zásobníku se bude snižovat na vyšších frekvencích, protože tyto součty se skládají z méně výrazů. Abychom to vyrovnali, normalizujeme se o N[k].
- Jakákoli funkce okna bude funkcí délky okna a podobně funkcí čísla okna. Například ekvivalent Hammingovo okno bylo by
- Naše digitální frekvence se stává .
Po těchto úpravách nám zbývá
Rychlý výpočet
Přímý výpočet transformace konstantní Q je pomalý ve srovnání s rychlá Fourierova transformace (FFT). Samotný FFT však může být použit ve spojení s použitím a jádro, provést ekvivalentní výpočet, ale mnohem rychleji.[3] Přibližná inverzní situace k takové implementaci byla navržena v roce 2006; funguje návratem k DFT a je vhodný pouze pro nástroje výšky tónu.[4]
Vývoj této metody se zlepšenou invertibilitou zahrnuje provádění CQT (přes FFT) oktávu po oktávě, s použitím filtrování dolní propustí a převzorkování výsledků pro postupně nižší výšky tónu.[5] Mezi implementace této metody patří implementace MATLAB a implementace Pythonu LibROSA.[6] LibROSA kombinuje podvzorkovanou metodu s přímou metodou FFT (kterou nazývá „pseudo-CQT“) tím, že druhá zpracovává vyšší frekvence jako celek.[6]
Tato sekce potřebuje expanzi s: nestacionární rámy Gabor jak je popsáno zde (a jak používá Matlab ). Můžete pomoci přidávat k tomu. (Prosince 2018) |
Srovnání s Fourierovou transformací
Obecně platí, že transformace se dobře hodí k hudebním datům, což lze vidět na některých jejích výhodách ve srovnání s rychlou Fourierovou transformací. Vzhledem k tomu, že výstup transformace je účinně amplituda / fáze proti kmitočtu protokolu, je zapotřebí méně frekvenčních košů, aby bylo možné účinně pokrýt daný rozsah, což se osvědčuje tam, kde frekvence překračují několik oktáv. Protože rozsah lidského sluchu pokrývá přibližně deset oktáv od 20 Hz do přibližně 20 kHz, je toto snížení výstupních dat významné.
Transformace vykazuje snížení frekvenčního rozlišení s vyššími frekvenčními biny, což je žádoucí pro sluchové aplikace. Transformace zrcadlí lidský sluchový systém, přičemž při nižších frekvencích je spektrální rozlišení lepší, zatímco časové rozlišení se zlepšuje při vyšších frekvencích. Ve spodní části stupnice klavíru (přibližně 30 Hz) je rozdíl 1 půltónu rozdílem přibližně 1,5 Hz, zatímco v horní části hudební stupnice (přibližně 5 kHz) je rozdíl 1 půltónu rozdílem přibližně 200 Hz.[7] Pro hudební data je tedy ideální exponenciální frekvenční rozlišení transformace konstantní Q.
Kromě toho harmonické noty tvoří vzor charakteristický pro zabarvení nástroje v této transformaci. Za předpokladu stejné relativní síly každé harmonické, jak se mění základní frekvence, zůstává relativní poloha těchto harmonických konstantní. To může značně usnadnit identifikaci nástrojů. Konstantní Q transformaci lze také použít k automatickému rozpoznávání hudebních kláves na základě nahromaděného obsahu chroma.[8]
V porovnání s Fourierovou transformací je implementace této transformace složitější. To je způsobeno různým počtem vzorků použitých při výpočtu každé frekvenční přihrádky, což také ovlivňuje délku jakékoli implementované funkce okna.[9]
Všimněte si také, že protože frekvenční stupnice je logaritmická, není přítomen žádný skutečný nulový kmitočet / stejnosměrný člen, což může být v některých případech nevýhodou.
Reference
- ^ Judith C. Brown, Výpočet spektrální transformace konstantní Q, J. Acoust. Soc. Dopoledne., 89(1):425–434, 1991.
- ^ Kontinuální vlnková transformace „Když lze mateřskou vlnu interpretovat jako okénkovou sinusoidu (jako je Morletova vlnka), lze vlnkovou transformaci interpretovat jako Fourierovu transformaci s konstantní Q. Před teorií waveletů se Fourierova transformace s konstantní Q (například klasická banka filtrů třetí oktávy) nebylo snadné invertovat, protože základní signály nebyly ortogonální. “
- ^ Judith C. Brown a Miller S. Puckette, Efektivní algoritmus pro výpočet konstantní Q transformace, J. Acoust. Soc. Dopoledne., 92(5):2698–2701, 1992.
- ^ FitzGerald, Derry; Cychowski, Marcin T .; Cranitch, Matt (1. května 2006). „Směrem k inverzní konstantní Q transformaci“. Úmluva o společnosti audio inženýrství. Paris: Audio Engineering Society. 120.
- ^ Schörkhuber, Christian; Klapuri, Anssi (2010). „TRANSFORMOVANÝ NÁSTROJ CONSTANT-Q PRO ZPRACOVÁNÍ HUDBY“. 7. konference o zvuku a hudbě. Barcelona. Citováno 12. prosince 2018. papír
- ^ A b McFee, Brian; Battenberg, Eric; Lostanlen, Vincent; Thomé, Carl (12. prosince 2018). "librosa: core / constantq.py na 8d26423". GitHub. librosa. Citováno 12. prosince 2018.
- ^ http://newt.phys.unsw.edu.au/jw/graphics/notes.GIF
- ^ Hendrik Purwins, Benjamin Blankertz a Klaus Obermayer, Nová metoda pro sledování modulací v tonální hudbě ve formátu zvukových dat, Mezinárodní společná konference o neuronových sítích (IJCNN’00)., 6:270-275, 2000.
- ^ Benjamin Blankertz, Konstantní Q transformace, 1999.