equalizer: add lookahead estimation

This commit is contained in:
Roman Zeyde
2014-08-28 13:46:54 +03:00
parent 550b337c05
commit 5735533a3b
2 changed files with 12 additions and 9 deletions

View File

@@ -34,7 +34,7 @@ def demodulator(signal, size):
return np.array(list(itertools.islice(symbols, size)))
def equalize(signal, symbols, order):
def equalize(signal, symbols, order, lookahead=0):
Nsym = config.Nsym
Nfreq = config.Nfreq
carriers = modem.carriers
@@ -44,18 +44,19 @@ def equalize(signal, symbols, order):
matched = np.array(carriers) / (0.5*Nsym)
matched = matched[:, ::-1].transpose().conj()
signal = np.concatenate([signal, np.zeros(lookahead)])
y = dsp.lfilter(x=signal, b=matched, a=[1])
A = np.zeros([symbols.size, order], dtype=np.complex128)
b = np.zeros([symbols.size], dtype=np.complex128)
A = []
b = []
index = 0
for j in range(Nfreq):
for i in range(length):
offset = (i+1)*Nsym
row = y[offset-order:offset, j]
A[index, :] = row
b[index] = symbols[i, j]
row = y[offset-order:offset+lookahead, j]
A.append(row)
b.append(symbols[i, j])
index += 1
A = np.array(A)

View File

@@ -53,9 +53,11 @@ def test_isi():
num = np.array([0.5])
y = dsp.lfilter(x=x, b=num, a=den)
h = equalizer.equalize(y, symbols, order=len(den))
assert_approx(h, den / num)
lookahead = 2
h = equalizer.equalize(y, symbols, order=len(den), lookahead=lookahead)
assert norm(h[:lookahead]) < 1e-12
assert_approx(h[lookahead:], den / num)
y = dsp.lfilter(x=y, b=h, a=[1])
y = dsp.lfilter(x=y, b=h[lookahead:], a=[1])
z = equalizer.demodulator(y, size=length)
assert_approx(z, symbols)