Sto sperimentando la decimazione di un segnale, in questo caso un impulso unitario.
Sto usando Python, con pylab. Innanzitutto, creo un impulso unitario e lo decimo di 5.
x = r_[zeros(0), 1, zeros(100)]
N = 2 ** 14
q = 5
y = decimate(x, q, ftype="fir")
subplot(211)
title("Original")
stem(range(len(x)), x)
subplot(212)
title("Decimated - FIR")
stem(range(len(y)), y)
figure()
subplot(211)
semilogx(log(abs(fft(x, N))))
subplot(212)
y = decimate(x, q, ftype="fir")
semilogx(log(abs(fft(y, N))))
Ciò risulta con i seguenti grafici
Aggiungo quindi alcuni esempi di ritardo prima dell'impulso, modificando x in:
x = r_[zeros(3), 1, zeros(100)]
Ciò si traduce nei seguenti grafici
Nella seconda serie di grafici, il segnale decimato risultante non è più un singolo campione, ma è stato distorto.
Se ritardo il segnale con 5 - e qualsiasi multiplo di q - campioni, ottengo nuovamente il primo set di grafici.
Il codice sorgente per la funzione decimale è, https://github.com/scipy/scipy/blob/master/scipy/signal/signaltools.py#L1570
def decimate(x, q, n=None, ftype='iir', axis=-1):
if not isinstance(q, int):
raise TypeError("q must be an integer")
if n is None:
if ftype == 'fir':
n = 30
else:
n = 8
if ftype == 'fir':
b = firwin(n + 1, 1. / q, window='hamming')
a = 1.
else:
b, a = cheby1(n, 0.05, 0.8 / q)
y = lfilter(b, a, x, axis=axis)
sl = [slice(None)] * y.ndim
sl[axis] = slice(None, None, q)
return y[sl]
Sto usando un filtro passa basso abete prima di decimare, la risposta all'impulso del filtro è
Questo spiega perché l'impulso è distorto quando c'è un ritardo, la decimazione sta selezionando parti della risposta all'impulso, quando il ritardo è un multiplo della decimazione, seleziona solo gli zero della risposta all'impulso e un campione diverso da zero a il picco.
C'è un modo per decimare un campione di unità con un ritardo arbitrario, che si traduce in un output di campione di unità in scala?