Я експериментую з децимацією сигналу, в даному випадку одиничним імпульсом.
Я використовую Python, з pylab. По-перше, я створюю імпульс одиниці і зменшую його на 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))))
Це призводить до наступних сюжетів
Потім я додаю кілька зразків затримки перед імпульсом, змінюючи x на:
x = r_[zeros(3), 1, zeros(100)]
Це призводить до наступних сюжетів
У другому наборі сюжетів отриманий децимований сигнал вже не є єдиним зразком, а був спотворений.
Якщо я затримаю сигнал із 5 - і будь-яким кратним q-зразками, я знову отримую перший набір сюжетів.
Вихідний код для десяткової функції - 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]
Я використовую фільтр фільтрів низької частоти перед тим, як знизити, імпульсна характеристика фільтра є
Це пояснює, чому імпульс спотворюється, коли виникає затримка, децимація - це вибір частини імпульсної відповіді, коли затримка кратна децимації, вона вибирає лише нулі імпульсної відповіді та один ненульовий зразок при вершина.
Чи існує спосіб зменшення одиничного зразка з довільною затримкою, що призводить до масштабування вибірок одиничної вибірки?