Pack K Bits: Difference between revisions

From GNU Radio
Jump to navigation Jump to search
No edit summary
No edit summary
Line 1: Line 1:
[[Category:Block Docs]]
[[Category:Block Docs]]
Converts a stream of bytes with 1 bit in the LSB to a byte with K relevant bits.
Converts a stream of bytes with 1 bit in the LSB to a byte with K relevant bits. It's the opposite of [[Unpack K Bits]]


In other words, it packs K unpacked bits (one bit per byte, since the byte is the smallest item size in GNU Radio) into a single packed byte containing K bits and 8 - K zeros.
In other words, it packs K unpacked bits (one bit per byte, since the byte is the smallest item size in GNU Radio) into a single packed byte containing K bits and 8 - K zeros.

Revision as of 23:23, 3 May 2019

Converts a stream of bytes with 1 bit in the LSB to a byte with K relevant bits. It's the opposite of Unpack K Bits

In other words, it packs K unpacked bits (one bit per byte, since the byte is the smallest item size in GNU Radio) into a single packed byte containing K bits and 8 - K zeros.

This block takes in K bytes at a time, and uses the least significant bit to form a new byte.

Example:

K = 4

in = [0, 1, 0, 1, 0x81, 0x00, 0x00, 0x00]

out = [0x05, 0x08]

The first four bytes coming in get combined to form binary 0101 which is 0x05

The next four bytes get combined to form binary 1000 which is 0x08. Note that even though one of the input bytes was 0x81, all that mattered was the least significant bit, which was a 1, the rest of the bits in that byte got discarded.