From 83497fbdaf6486571ed70b41dae42f3c13432c1c Mon Sep 17 00:00:00 2001 From: andreas128 Date: Mon, 21 Aug 2017 11:43:36 +0200 Subject: Change dpd to real coefficients --- dpd/main.py | 14 +++++++++++++- dpd/src/Adapt.py | 24 +++++++++++++----------- 2 files changed, 26 insertions(+), 12 deletions(-) diff --git a/dpd/main.py b/dpd/main.py index e22743b..560d142 100755 --- a/dpd/main.py +++ b/dpd/main.py @@ -48,9 +48,21 @@ num_req = int(cli_args.samps) samplerate = int(cli_args.samplerate) meas = Measure.Measure(samplerate, port, num_req) + adapt = Adapt.Adapt(port_rc, coef_path) coefs = adapt.get_coefs() -model = Model.Model(coefs) +#model = Model.Model(coefs) +model = Model.Model([0.8, 0, 0, 0, 0]) +adapt.set_txgain(60) + +tx_gain = adapt.get_txgain() +rx_gain = adapt.get_rxgain() +dpd_coefs = adapt.get_coefs() +logging.info( + "TX gain {}, RX gain {}, dpd_coefs {}".format( + tx_gain, rx_gain, dpd_coefs + ) +) for i in range(10): txframe_aligned, tx_ts, rxframe_aligned, rx_ts = meas.get_samples() diff --git a/dpd/src/Adapt.py b/dpd/src/Adapt.py index 2658240..4117856 100644 --- a/dpd/src/Adapt.py +++ b/dpd/src/Adapt.py @@ -112,33 +112,35 @@ class Adapt: def _read_coef_file(self): """Load the coefficients from the file in the format given in the README""" - coefs_complex = [] + coefs_out = [] f = open(self.coef_path, 'r') lines = f.readlines() n_coefs = int(lines[0]) coefs = [float(l) for l in lines[1:]] i = 0 - for r, c in zip(coefs[0::2], coefs[1::2]): + for c in coefs: if i < n_coefs: - coefs_complex.append(np.complex64(r + 1j * c)) + coefs_out.append(c) else: - raise ValueError("Incorrect coef file format: too many coefficients") + raise ValueError( + "Incorrect coef file format: too many coefficients in {}, should be {}, coefs are {}" + .format(self.coef_path, n_coefs, coefs)) i += 1 f.close() - return coefs_complex + return coefs_out def get_coefs(self): return self._read_coef_file() - def _write_coef_file(self, coefs_complex): + def _write_coef_file(self, coefs): f = open(self.coef_path, 'w') - f.write("{}\n".format(len(coefs_complex))) - for coef in coefs_complex: - f.write("{}\n{}\n".format(coef.real, coef.imag)) + f.write("{}\n".format(len(coefs))) + for coef in coefs: + f.write("{}\n".format(coef)) f.close() - def set_coefs(self, coefs_complex): - self._write_coef_file(coefs_complex) + def set_coefs(self, coefs): + self._write_coef_file(coefs) self.send_receive("set memlesspoly coeffile {}".format(self.coef_path)) # The MIT License (MIT) -- cgit v1.2.3