summaryrefslogtreecommitdiff
path: root/gr-fec/python/fec/qa_polar_encoder.py
diff options
context:
space:
mode:
authorJohannes Demel <ufcsy@student.kit.edu>2015-07-21 15:47:04 +0200
committerJohannes Demel <ufcsy@student.kit.edu>2015-09-21 10:46:54 +0200
commit73d84a231c31bf8312214b5e3a0a97e15c8db98f (patch)
tree3b531fbb2bd00184b29113a3e564fed379bffe62 /gr-fec/python/fec/qa_polar_encoder.py
parent8b486050a7e425e21f069ad6742385d6496c63eb (diff)
polar: VOLK kernel integration
Conflicts: volk
Diffstat (limited to 'gr-fec/python/fec/qa_polar_encoder.py')
-rw-r--r--gr-fec/python/fec/qa_polar_encoder.py73
1 files changed, 42 insertions, 31 deletions
diff --git a/gr-fec/python/fec/qa_polar_encoder.py b/gr-fec/python/fec/qa_polar_encoder.py
index b4f26e4017..90190cd719 100644
--- a/gr-fec/python/fec/qa_polar_encoder.py
+++ b/gr-fec/python/fec/qa_polar_encoder.py
@@ -28,6 +28,10 @@ from extended_encoder import extended_encoder
from polar.encoder import PolarEncoder
import polar.channel_construction as cc
+# import os
+# print('PID:', os.getpid())
+# raw_input('tell me smth')
+
class test_polar_encoder(gr_unittest.TestCase):
@@ -50,54 +54,45 @@ class test_polar_encoder(gr_unittest.TestCase):
self.assertFloatTuplesAlmostEqual((float(num_info_bits) / block_size, ), (polar_encoder.rate(), ))
self.assertFalse(polar_encoder.set_frame_size(10))
- def test_002_work_function(self):
- block_size = 256
- num_info_bits = 128
- num_frozen_bits = block_size - num_info_bits
- frozen_bit_positions = cc.frozen_bit_positions(block_size, num_info_bits, 0.0)
- frozen_bit_values = np.array([0] * num_frozen_bits,)
- python_encoder = PolarEncoder(block_size, num_info_bits, frozen_bit_positions, frozen_bit_values)
-
+ def test_002_work_function_packed(self):
is_packed = True
- polar_encoder = fec.polar_encoder.make(block_size, num_info_bits, frozen_bit_positions, frozen_bit_values, is_packed)
+ block_size = 256
+ num_info_bits = block_size // 2
- data = np.ones(num_info_bits, dtype=int)
+ data, ref, polar_encoder = self.get_test_data(block_size, num_info_bits, 1, is_packed)
src = blocks.vector_source_b(data, False)
enc_block = extended_encoder(polar_encoder, None, '11')
snk = blocks.vector_sink_b(1)
self.tb.connect(src, enc_block, snk)
self.tb.run()
- print(self.tb.edge_list())
res = np.array(snk.data()).astype(dtype=int)
- penc = python_encoder.encode(data)
-
- print(res)
- print(penc)
- self.assertTupleEqual(tuple(res), tuple(penc))
+ self.assertTupleEqual(tuple(res), tuple(ref))
- def test_003_big_input(self):
- is_packed = True
- num_blocks = 30
+ def test_003_work_function_unpacked(self):
+ is_packed = False
block_size = 256
- num_info_bits = 128
- num_frozen_bits = block_size - num_info_bits
- frozen_bit_positions = cc.frozen_bit_positions(block_size, num_info_bits, 0.0)
- frozen_bit_values = np.array([0] * num_frozen_bits,)
- python_encoder = PolarEncoder(block_size, num_info_bits, frozen_bit_positions, frozen_bit_values)
+ num_info_bits = block_size // 2
- polar_encoder = fec.polar_encoder.make(block_size, num_info_bits, frozen_bit_positions, frozen_bit_values, is_packed)
+ data, ref, polar_encoder = self.get_test_data(block_size, num_info_bits, 1, is_packed)
+ src = blocks.vector_source_b(data, False)
+ enc_block = extended_encoder(polar_encoder, None, '11')
+ snk = blocks.vector_sink_b(1)
- data = np.array([], dtype=int)
- ref = np.array([], dtype=int)
+ self.tb.connect(src, enc_block, snk)
+ self.tb.run()
- for i in range(num_blocks):
- d = np.random.randint(2, size=num_info_bits)
- data = np.append(data, d)
- ref = np.append(ref, python_encoder.encode(d))
+ res = np.array(snk.data()).astype(dtype=int)
+ self.assertTupleEqual(tuple(res), tuple(ref))
+ def test_004_big_input(self):
+ is_packed = False
+ num_blocks = 30
+ block_size = 1024
+ num_info_bits = block_size // 8
+ data, ref, polar_encoder = self.get_test_data(block_size, num_info_bits, num_blocks, is_packed)
src = blocks.vector_source_b(data, False)
enc_block = extended_encoder(polar_encoder, None, '11')
snk = blocks.vector_sink_b(1)
@@ -111,6 +106,22 @@ class test_polar_encoder(gr_unittest.TestCase):
print(ref)
self.assertTupleEqual(tuple(res), tuple(ref))
+ def get_test_data(self, block_size, num_info_bits, num_blocks, is_packed):
+ num_frozen_bits = block_size - num_info_bits
+ frozen_bit_positions = cc.frozen_bit_positions(block_size, num_info_bits, 0.0)
+ frozen_bit_values = np.array([0] * num_frozen_bits,)
+ python_encoder = PolarEncoder(block_size, num_info_bits, frozen_bit_positions, frozen_bit_values)
+
+ data = np.array([], dtype=int)
+ ref = np.array([], dtype=int)
+ for i in range(num_blocks):
+ d = np.random.randint(2, size=num_info_bits)
+ data = np.append(data, d)
+ ref = np.append(ref, python_encoder.encode(d))
+ polar_encoder = fec.polar_encoder.make(block_size, num_info_bits, frozen_bit_positions, frozen_bit_values, is_packed)
+ return data, ref, polar_encoder
+
+