Polar Coding

A Python wrapper around the AFF3CT [1] project, transferring the Polar [2] implementations to the Hermes forward error correction pipeline structure.

class PolarSCCoding(self: hermespy.fec.aff3ct.polar.PolarSCCoding, arg0: SupportsInt | SupportsIndex, arg1: SupportsInt | SupportsIndex, arg2: SupportsFloat | SupportsIndex)[source]

Bases: pybind11_object

Parameters:
  • data_block_size (int) – Number of data bits per block to be encoded.

  • code_block_size (int) – Number of code bits per encoded block.

  • ber (float) – Assumed bit error rate.

  • num_paths (int) – Number of decoding paths.

decode(self: hermespy.fec.aff3ct.polar.PolarSCCoding, arg0: Annotated[numpy.typing.ArrayLike, numpy.int32]) numpy.typing.NDArray[numpy.int32][source]

Decode a block of code bits to data bits.

Parameters:

code (numpy.ndarray) – The code bit block to be decoded.

Returns:

The data bit block after decoding.

encode(self: hermespy.fec.aff3ct.polar.PolarSCCoding, arg0: Annotated[numpy.typing.ArrayLike, numpy.int32]) numpy.typing.NDArray[numpy.int32][source]

Encode a block of data bits to code bits.

Parameters:

data (numpy.ndarray) – The data bit block to be encoded.

Returns:

The code bit block after encoding.

property bit_block_size[source]

Number of bits within a data block to be encoded.

property code_block_size[source]

Number of bits within a code block to be decoded.

enabled = True[source]
property rate[source]

Coding rate of the polar code.

class PolarSCLCoding(self: hermespy.fec.aff3ct.polar.PolarSCLCoding, arg0: SupportsInt | SupportsIndex, arg1: SupportsInt | SupportsIndex, arg2: SupportsFloat | SupportsIndex, arg3: SupportsInt | SupportsIndex)[source]

Bases: pybind11_object

Successive Cancellation List Polar Codes. Refer to [3] for further information.

Parameters:
  • data_block_size (int) – Number of data bits per block to be encoded.

  • code_block_size (int) – Number of code bits per encoded block.

  • ber (float) – Assumed bit error rate.

  • num_paths (int) – Number of considered decoding paths.

decode(self: hermespy.fec.aff3ct.polar.PolarSCLCoding, arg0: Annotated[numpy.typing.ArrayLike, numpy.int32]) numpy.typing.NDArray[numpy.int32][source]

Decode a block of code bits to data bits.

Parameters:

code (numpy.ndarray) – The code bit block to be decoded.

Returns:

The data bit block after decoding.

encode(self: hermespy.fec.aff3ct.polar.PolarSCLCoding, arg0: Annotated[numpy.typing.ArrayLike, numpy.int32]) numpy.typing.NDArray[numpy.int32][source]

Encode a block of data bits to code bits.

Parameters:

data (numpy.ndarray) – The data bit block to be encoded.

Returns:

The code bit block after encoding.

property bit_block_size[source]

Number of bits within a data block to be encoded.

property code_block_size[source]

Number of bits within a code block to be decoded.

enabled = True[source]
property rate[source]

Coding rate of the polar code.