1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
id: variable_polar_encoder_systematic_def
label: systematic POLAR Encoder Definition
parameters:
- id: ndim
label: Parallelism
dtype: enum
default: '0'
options: ['0', '1', '2']
- id: dim1
label: Dimension 1
dtype: int
default: '1'
hide: ${ ('none' if (int(ndim) >= 1) else 'all') }
- id: dim2
label: Dimension 2
dtype: int
default: '4'
hide: ${ ('none' if (int(ndim) >= 2) else 'all') }
- id: block_size
label: Block size (N)
dtype: int
- id: num_info_bits
label: '#Info Bits (K)'
dtype: int
- id: frozen_bit_positions
label: Frozen Bit Positions
dtype: int_vector
value: ${ fec.polar_encoder_systematic.make(block_size, num_info_bits, frozen_bit_positions)
}
templates:
imports: from gnuradio import fec
var_make: "% if int(ndim)==0 #:\nself.${id} = ${id} = fec.polar_encoder_systematic.make(${block_size},\
\ ${num_info_bits}, ${frozen_bit_positions}) \n% elif int(ndim)==1 #:\nself.${id}\
\ = ${id} = map((lambda a: fec.polar_encoder_systematic.make(${block_size},\
\ ${num_info_bits}, ${frozen_bit_positions})), range(0, ${dim1})) \n% else:\n\
self.${id} = ${id} = map((lambda b: map((lambda a: fec.polar_encoder_systematic.make(${block_size},\
\ ${num_info_bits}, ${frozen_bit_positions})), range(0, ${dim2}))), range(0,\
\ ${dim1})) \n% endif"
file_format: 1
|