|
Arduino PulseWire Transceiver Library
|
NRZ (Non-Return-to-Zero) codec for serial-like encoding/decoding with start/stop bit framing. More...
#include <NRZCodec.h>


Public Member Functions | |
| NRZCodec (uint8_t stopBits=1) | |
| NRZCodec (Preamble &preambleDetector, uint8_t stopBits=1) | |
| CodecEnum | getCodecType () const override |
| instance. | |
| bool | getIdleLevel () |
| void | setStopBits (uint8_t stopBits) |
| uint8_t | getStopBits () const |
| bool | begin (uint16_t bitFrequencyHz) override |
| initialization method for codecs that require setup before use (e.g., loading PIO programs, configuring state machines). | |
| size_t | encode (uint8_t byte, Vector< OutputEdge > &output) override |
| Fill output vector with protocol-specific OutputSpec(s) for a byte. | |
| bool | decodeEdge (uint32_t durationUs, bool level, uint8_t &result) override |
| Edge-based decoding for protocol-agnostic RX drivers. | |
| bool | decodeByte (Vector< OutputEdge > &edges, uint8_t &result) override |
| Decode edges into a byte. | |
| size_t | getEdgeCount () const override |
| Get the number of protocol symbols (bits, pulses, etc.) per encoded byte. | |
| int | getEndOfFrameDelayUs () override |
| Provide the end of frame delay in microseconds for this protocol, used by RX driver to. | |
| virtual void | init (Preamble &detector, uint32_t shortPulseUs=600, uint32_t longPulseUs=1200, uint32_t toleranceUs=200) |
| virtual void | reset () |
| Preamble & | getPreamble () |
| Get the preamble detector associated with this codec. | |
| void | setPreamble (Preamble &preamble) |
| Set the Preamble Detector object. | |
| size_t | encodePreamble (Vector< OutputEdge > &output) |
| void | setFrameSize (uint16_t size) |
| virtual size_t | encodeBit (bool bit, Vector< OutputEdge > &output) |
| Fill output vector with protocol-specific OutputSpec(s) for a bit. | |
| virtual void | encodeByte (uint8_t byte, std::vector< bool > &bits) const |
| Encode a byte to protocol bitstream. Default implementation encodes to raw bits (MSB first), but can be overridden by protocols that require different bit formatting (e.g., Manchester). The output bits are stored in. | |
| virtual bool | getIdleLevel () const |
| Provides the initial ldle state (low or hith) | |
| const char * | name () const |
| Get the name of the codec type as a string (e.g., "PulseDistance", "Manchester"). | |
Protected Member Functions | |
| bool | bitMatch (uint32_t duration, bool bit) const |
Protected Attributes | |
| uint8_t | _stopBits |
| CustomPreambleUs | _defaultPreamble |
| Preamble * | _preamble = &_defaultPreamble |
| uint16_t | _bitFrequencyHz = 0 |
| uint32_t | _bitPeriodUs = 0 |
| Vector< OutputEdge > | _decodeEdgeStream |
| volatile bool | _inFrame = false |
NRZ (Non-Return-to-Zero) codec for serial-like encoding/decoding with start/stop bit framing.
Definition at line 10 of file NRZCodec.h.
|
inline |
Definition at line 12 of file NRZCodec.h.
Definition at line 14 of file NRZCodec.h.
initialization method for codecs that require setup before use (e.g., loading PIO programs, configuring state machines).
Reimplemented from pulsewire::Codec.
Definition at line 25 of file NRZCodec.h.
Definition at line 118 of file NRZCodec.h.
|
inlineoverridevirtual |
|
inlineoverridevirtual |
Edge-based decoding for protocol-agnostic RX drivers.
Called on each signal edge (duration since last edge, new level, minUs, maxUs). The codec maintains its own state and assembles frames internally.
| durationUs | Time in microseconds since last edge. |
| level | New logic level after the edge (true = HIGH, false = LOW). |
| frameBuffer | Output buffer for decoded frame (if available). |
| frameBufferSize | Size of frameBuffer (bytes). |
| frameLen | Set to decoded frame length if a frame is available. |
Reimplemented from pulsewire::Codec.
Definition at line 69 of file NRZCodec.h.
|
inlineoverridevirtual |
Fill output vector with protocol-specific OutputSpec(s) for a byte.
Encodes the byte to protocol bits and appends OutputSpec(s) for each bit.
| byte | The byte to encode. |
| output | Vector to append OutputSpec(s). |
Reimplemented from pulsewire::Codec.
Definition at line 38 of file NRZCodec.h.
|
inlinevirtualinherited |
Fill output vector with protocol-specific OutputSpec(s) for a bit.
| bit | The bit to encode (true/false). |
| output | Vector to append OutputSpec(s). |
Reimplemented in pulsewire::RecorderCodec, pulsewire::DifferentialManchesterCodec, pulsewire::ManchesterCodec, pulsewire::PulseDistanceCodec, and pulsewire::PulseWidthCodec.
|
inlinevirtualinherited |
Encode a byte to protocol bitstream. Default implementation encodes to raw bits (MSB first), but can be overridden by protocols that require different bit formatting (e.g., Manchester). The output bits are stored in.
| byte | The input byte to encode. |
| bits | Output buffer for encoded bits (protocol-specific format). |
Reimplemented in pulsewire::RecorderCodec.
|
inlineinherited |
|
inlineoverridevirtual |
instance.
Get the codec type (e.g., PulseDistance, Manchester) for this Codec
Implements pulsewire::Codec.
Definition at line 17 of file NRZCodec.h.
|
inlineoverridevirtual |
Get the number of protocol symbols (bits, pulses, etc.) per encoded byte.
Implements pulsewire::Codec.
Definition at line 110 of file NRZCodec.h.
|
inlineoverridevirtual |
Provide the end of frame delay in microseconds for this protocol, used by RX driver to.
Implements pulsewire::Codec.
Definition at line 112 of file NRZCodec.h.
|
inline |
Definition at line 19 of file NRZCodec.h.
Provides the initial ldle state (low or hith)
Reimplemented in pulsewire::DifferentialManchesterCodec.
|
inlineinherited |
|
inline |
Definition at line 23 of file NRZCodec.h.
|
inlinevirtualinherited |
Used by IRTransceiver to initialize codec with protocol-specific parameters
Reimplemented in pulsewire::PulseWidthCodec, pulsewire::PulseDistanceCodec, and pulsewire::RecorderCodec.
Definition at line 21 of file NRZCodec.h.
|
protectedinherited |
|
protectedinherited |
|
protectedinherited |
|
protectedinherited |
|
protectedinherited |
|
protected |
Definition at line 115 of file NRZCodec.h.