Reorder input symbols using algebraically derived permutation table
Block sublibrary of Interleaving
The Algebraic Interleaver block rearranges the elements of its input vector using a permutation that is algebraically derived. The Number of elements parameter, N, indicates how many numbers are in the input vector. This block accepts a column vector input signal.
The block accepts the following data types: int8,
uint8, int16,
uint16, int32,
uint32, boolean,
single, double, and
fixed-point. The output signal inherits its data type from the input
signal.
The Type parameter indicates the algebraic method
that the block uses to generate the appropriate permutation table.
Choices are Takeshita-Costello and
Welch-Costas. Each of these
methods has parameters and restrictions that are specific to
it:
If you set Type to
Welch-Costas, then
N + 1 must be prime. The
Primitive element parameter
is an integer, A, between 1 and
N that represents a primitive
element of the finite field GF(N
+ 1). This means that every nonzero
element of GF(N + 1) can be
expressed as A raised to some
integer power.
In a Welch-Costas interleaver, the permutation maps the integer k to mod(Ak,N + 1) - 1.
If you set Type to
Takeshita-Costello,
then N must be
2m
for some integer m. The
Multiplicative factor
parameter, k, must be an odd
integer less than N. The
Cyclic shift parameter,
h, must be a nonnegative
integer less than N.
A Takeshita-Costello interleaver uses a length-N cycle vector whose nth element is
for integers n between 1 and N. The intermediate permutation function is obtained by using the following relationship:
where
The interleaver's actual permutation vector is the result of cyclically shifting the elements of the permutation vector, π, by the Cyclic shift parameter, h.
The type of permutation table that the block uses for interleaving.
The number of elements, N, in the input vector.
The factor used to compute the interleaver's
cycle vector. This field appears only if
Type is set to
Takeshita-Costello.
The amount by which the block shifts indices
when creating the permutation table. This field
appears only if Type is set
to
Takeshita-Costello.
An element of order N in
the finite field GF(N+1). This field appears only
if Type is set to
Welch-Costas.
[1] Heegard, Chris and Stephen B. Wicker. Turbo Coding. Boston: Kluwer Academic Publishers, 1999.
[2] Takeshita, O. Y. and D. J. Costello, Jr. "New Classes Of Algebraic Interleavers for Turbo-Codes." Proc. 1998 IEEE International Symposium on Information Theory, Boston, Aug. 16-21, 1998. 419.