Linea di delay digitale

Una linea di delay digitale, (o semplicemente delay line, chiamata anche delay filter) è un filtro digitale che ritarda un segnale di un certo numero di campioni. Se tale ritardo è di un numero non intero di campioni minore di uno, si parla specificatamente di una delay line frazionaria (anche chiamata interpolated delay line o fractional delay filter). Nel digital signal processing, è comune modellizzare un ritardo arbitrario di campioni come la serie di una delay line a ritardo intero e un fractional delay filter[2].

Rappresentazione diagrammatica a blocchi standard di una delay line a ritardo intero M.[1]

Le digital delay lines sono blocchi funzionali diffusi nella modellizzazione e simulazione acustica degli ambienti, strumenti musicali ed effetti digitali. Un'applicazione comune delle delay lines sono le digital waveguide synthesis, che possono essere usate come strumento di sintesi musicale per diversi tipi di strumenti, quali strumenti a corda o a fiato. Per implementare effetti digitali è standard d'industria usare uno schema di Dattorro, che fa uso di fractional delay lines[3].

Teoria modifica

La delay line standard con ritardo intero è derivata dalla trasformata   di un segnale a tempo discreto   ritardato di   campioni[4]:

     

In questo caso,   è la delay line intera con le seguenti caratteristiche:   La corrispondente risposta impulsiva nel dominio discreto nel tempo non è altro che la trasformata   inversa di  , la quale è un semplice impulso traslato di   campioni[5]:

 

Nel caso di ritardo frazionario, il discorso diventa più complicato. Nella sua forma teorica più generica, una delay line con ritardo frazionario è definita come una delay line standard con ritardo  , modellato come la somma di una componente intera   e di una componente frazionaria   minore di un campione:

 

Questa è la rappresentazione in dominio   di un problema di filter design non banale: la soluzione è una qualsiasi risposta all'impulso che rappresenti o approssimi la trasformata   inversa di  [2].

Soluzione (Design di filtri) modifica

Soluzione ingenua modifica

La soluzione concettualmente più semplice si ottiene campionando la soluzione continua, banale per ogni valore di ritardo anche frazionario. Dato un segnale continuo   ritardato di   campioni, o   secondi[6]:

     

In questo caso,   è il filtro a ritardo frazionario nel dominio continuo del tempo con:  La soluzione ingenua per il filtro campionato   è semplicamente la trasformata inversa di   campionata, che produce un filtro IIR non-causale a forma di Seno Cardinale   traslato di  [6].

 

Il   continuo è traslato del ritardo frazionario, mentre viene campionato dentro la griglia del piano cartesiano. Di conseguenza:

  • quando il ritardo è un numero intero di campioni,  , il   traslato e campionato degenera a un semplice impulso traslato, come da soluzione teorica.
  • quando il ritardo è un numero frazionario di campioni,  , il   traslato e campionato produce un filtro IIR non-causale, che non è implementabile nella pratica.
 
La delay line frazionaria ideale si ottiene dal campionamento della trasformata inversa di Fourier continua del filtro a ritardo frazionario. Per valori interi di ritardo la soluzione degenera in semplici impulsi traslati. Ritardare un segnale campionato equivale concettualmente a ricampionare il suo corrispettivo continuo con lo stesso periodo di campionamento ma un diverso allineamento di campioni, traslato di  . L'immagine mostra solo alcuni campioni attorno a zero, ma il filtro non-causale IIR è definito per un numero infinito di campioni in entrambe le direzioni dell'asse.

FIR causale troncato modifica

La soluzione realizzabile concettualmente più semplice si ottiene semplicemente troncando la soluzione ingenua sopra[7].

 

Troncare la risposta all'impulso potrebbe causare instabilità, per mitigare la quale si possono usare una serie di tecniche:

  • Filtrare la risposta all'impulso troncata con una finestra, con l'obiettivo di "ammorbidirla". In questo caso dobbiamo aggiungere un ulteriore traslazione   per allineare la finestra e il  , così da filtrare simmetricamente[7][8].

     

  • Metodo General Least Square (GLS)[2] → adatta iterativamente la risposta in frequenza filtrando un design Least Square Integral Error, minimizzando lo LSIE tra la risposta in fraquenza ideale e quella troncata. È definito come:

 

  • Interpolatore di Lagrange (Maximally Flat Fractional Delay Filter)[9] → aggiunge vincoli di "appiattimento" per le prime N derivate del Least Square Integral Error. Questo metodo è di particolare interesse in quanto la letteratura fornisce una soluzione in formula chiusa:
 
Una rappresentazione diagrammatica della formula di interpolazione di Lagrange.[10]

 

Segue una tabella dell'espansione della formula per filtri di ordine fino a  :

Espansione della formula di interpolazione di Lagrange[7]
       
N = 1     - -
N = 2       -
N = 3        

Soluzione passa-tutto IIR a fase approssimata modifica

Un altro approccio consiste nel design di un filtro IIR di ordine   con una struttura in trasformata   che lo forza a essere passa-tutto, approssimando un ritardo frazionario  [7]:

 

I poli e zeri di   rispettivamente sono strutturalmente reciproci, e hanno l'effetto di appiattire la risposta in frequenza |  , mentre la fase è calcolata in funzione della fase di  . Di conseguenza, il problema si semplifica nel design di un filtro FIR  , ossia trovare i suoi coefficienti   come funzioni di D (ricordare che   sempre), tali che la fase approssimi il valore obiettivo di  [7].

Il problema si può risolvere nel seguente modo:

  • Minimizzazione iterative del Least Square Phase Error[2], definito come:

 

  • Minimizzazione iterativa del of Least Square Phase Delay Error[2], definito come:

 

  • Filtro Passa-Basso Tutti-Polei di Thiran con Group Delay Massimamente Piatto[11] → offre una formula chiusa per trovare i coefficienti   per ritardi positivi  :

 

Segue una tabella dell'espansione della formula sopra calcolata per filtri di ordine fino a  :

Thiran All-Pole Low-Pass Filter Coefficients Formula Expansion[7]
       
N = 1 1   - -
N = 2 1     -
N = 3 1      

Storia commerciale modifica

Le prime digital delay lines vennero usate nel 1973 al Summer Jam at Watkins Glen di New York, per compensare il ritardo di propagazione del suono nell'aria proveniente dalle torri di diffusione, in quel caso molto distanti tra loro nella vasta area dedicata al pubblico, almeno 600,000 persone. La società del New Jersey Eventide fornì delle delay lines capaci di 200 millisecondi di ritardo, adatte a ritardare le quattro torri di diffusione dei 175 millisecondi necessari a compensare il ritardo del suono nei 60 metri che le distanziavano dal palco. Altre dieci torri di diffusione, sei a 120 metri e quattro a 180 metri furono ritardate con la stessa tecnica di 350 e 525 millisecondi rispettivamente. Ogni modulo Eventide DDL 1745 conteneva parecchi circuiti integrati di registri a scorrimento a 1000-bit e costava l'equivalente di un'auto nuova.[12]

Note modifica

  1. ^ The M-Sample Delay Line, su ccrma.stanford.edu. URL consultato il 6 luglio 2023.
  2. ^ a b c d e Timo I. Laakso, Vesa Välimäki, Matti A. Karjalainen e Unto K. Laine, Splitting the unit delay [FIR/all pass filters design], in IEEE Signal Processing Magazine, vol. 13, n. 1, gennaio 1996, pp. 30–60, DOI:10.1109/79.482137.
  3. ^ Julius O. Smith e Nelson Lee, Computational Acoustic Modeling with Digital Delay, su Center for Computer Research in Music and Acoustics, 5 giugno 2008. URL consultato il 21 agosto 2007.
  4. ^ Delay Lines, su ccrma.stanford.edu. URL consultato il 6 luglio 2023.
  5. ^ INTRODUCTION TO DIGITAL FILTERS WITH AUDIO APPLICATIONS, su ccrma.stanford.edu. URL consultato il 6 luglio 2023.
  6. ^ a b Ideal Bandlimited (Sinc) Interpolation, su ccrma.stanford.edu. URL consultato il 6 luglio 2023.
  7. ^ a b c d e f Vesa Välimäki, Discrete Time Modeling of Acoustic Tubes Using Fractional Delay Filters, su users.spa.aalto.fi, 1998.
  8. ^ F.J. Harris, On the use of windows for harmonic analysis with the discrete Fourier transform, in Proceedings of the IEEE, vol. 66, n. 1, 1978, pp. 51–83, DOI:10.1109/proc.1978.10837, ISSN 0018-9219 (WC · ACNP).
  9. ^ (EN) E. Hermanowicz, Explicity formulas for weighting coefficients of maximally flat tunable FIR delays, in Electronics Letters, vol. 28, n. 20, 1992, pp. 1936, DOI:10.1049/el:19921239.
  10. ^ Julius Smith, Explicit Formula for Lagrange Interpolation Coefficients, su ccrma, 5 settembre 2022.
  11. ^ J.-P. Thiran, Recursive digital filters with maximally flat group delay, in IEEE Transactions on Circuit Theory, vol. 18, n. 6, 1971-11, pp. 659–664, DOI:10.1109/TCT.1971.1083363. URL consultato il 7 luglio 2023.
  12. ^ Nalia Sanchez, Remembering the Watkins Glen Festival, su Eventide Audio, 29 luglio 2016. URL consultato il 20 febbraio 2020.

Bibliografia modifica

Voci correlate modifica

Collegamenti esterni modifica