summaryrefslogtreecommitdiff
path: root/gr-fec/grc/fec_bercurve_generator.xml
blob: 5dfc7c67140811ca2679355c509129104af3865a (plain)
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
<?xml version="1.0"?>
<!--
###################################################
## BER Curve Generator
###################################################
 -->
<block>
  <name>BER Curve Gen.</name>
  <key>fec_bercurve_generator</key>
  <import>from gnuradio import fec</import>
  <import>import numpy</import>
  <make>fec.bercurve_generator(
	$encoder_list, \#size
	$decoder_list, \#name
	$esno, \#range of esnos
	$samp_rate, \#throttle
        $threadtype, \#threading mode
	$puncpat, \#puncture pattern
        $seed \# noise gen. seed
)
  </make>

  <param>
    <name>Es/N0</name>
    <key>esno</key>
    <value>numpy.arange(0.0, 4.0, .5)</value>
    <type>raw</type>
  </param>

  <param>
    <name>Sample Rate</name>
    <key>samp_rate</key>
    <value>3200000</value>
    <type>float</type>
  </param>

  <param>
    <name>Encoder list</name>
    <key>encoder_list</key>
    <value>0</value>
    <type>raw</type>
  </param>

  <param>
    <name>Decoder list</name>
    <key>decoder_list</key>
    <value>0</value>
    <type>raw</type>
  </param>

  <param>
    <name>Puncture Pat.</name>
    <key>puncpat</key>
    <value>'11'</value>
    <type>string</type>
  </param>

  <param>
    <name>Threading Type</name>
    <key>threadtype</key>
    <type>enum</type>
    <hide>part</hide>
    <option>
      <name>Capillary</name>
      <key>"capillary"</key>
    </option>
    <option>
      <name>Ordinary</name>
      <key>"ordinary"</key>
    </option>
    <option>
      <name>None</name>
      <key>"none"</key>
    </option>
  </param>

  <param>
    <name>Noise Seed</name>
    <key>seed</key>
    <value>0</value>
    <type>int</type>
    <hide>part</hide>
  </param>

  <bus_source>1</bus_source>

  <source>
    <name>out</name>
    <type>byte</type>
    <nports>len($esno)*2</nports>
  </source>

  <doc>
    Note that this block tries to launch many parallel codes to run simultaneously. Thus, it requires that the definitions for each encoder and decoder (specified in the "Encoder list" and "Decoder list") be configured with a parallelism > 0. If the parallelism for one of the encoder or decoder definition blocks is configured to 0, you will likely see an error like:

    generic_decoder=decoder_list[i],
    TypeError: 'generic_decoder_sptr' object does not support indexing

    or

    generic_encoder=encoder_list[i],
    TypeError: 'generic_encoder_sptr' object does not support indexing
  </doc>
</block>