#!/usr/bin/env python # # Copyright 2012 Free Software Foundation, Inc. # # This file is part of GNU Radio # # SPDX-License-Identifier: GPL-3.0-or-later # # import math import numpy as np from gnuradio import gr, gr_unittest, digital from gnuradio.digital.utils import lfsr_args class test_lfsr(gr_unittest.TestCase): def setUp(self): pass def tearDown(self): pass def test_lfsr_001(self): reglen = 8 l = digital.lfsr(1, 1, reglen) result_data = [] for i in range(4 * (reglen + 1)): result_data.append(l.next_bit()) expected_result = 4 * ([1, ] + reglen * [0, ]) self.assertFloatTuplesAlmostEqual(expected_result, result_data, 5) def test_lfsr_002(self): l = digital.lfsr(*lfsr_args(0b1,5,3,0)) result_data = [l.next_bit() for _ in range(2*(2**5-1))] expected_result = [1, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 1, 0, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 1, 1, 0, 1, 0, 0]*2 self.assertEqual(expected_result, result_data) seq1 = [l.next_bit() for _ in range(2**5-1)] seq2 = [l.next_bit() for _ in range(2**5-1)] self.assertEqual(seq1,seq2) res = (np.convolve(seq1,[1,0,1,0,0,1])%2) self.assertTrue(sum(res[5:-5])==0,"LRS not generated properly") if __name__ == '__main__': gr_unittest.run(test_lfsr)