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
|
/*
* DifferentialDecoder.cpp
*
* Created on: 25/01/2017
* Author: Lucas Teske
* Modified by Aang23
*/
#include "nrzs.h"
namespace diff
{
void NRZSDiff::decode(uint8_t *data, int length)
{
uint8_t mask;
for (int i = 0; i < length; i++)
{
mask = ((data[i] >> 1) & 0x7F) | (lastBit << 7);
lastBit = data[i] & 1;
data[i] ^= 0xFF - mask;
}
}
void NRZSDiff::decode_bits(uint8_t *data, int length)
{
uint8_t currentBit = 0;
for (int i = 0; i < length; i++)
{
currentBit = data[i];
data[i] = !(currentBit ^ lastBit);
lastBit = currentBit;
}
}
void nrzs_decode(uint8_t *data, int length)
{
uint8_t mask, lastBit = 0;
for (int i = 0; i < length; i++)
{
mask = ((data[i] >> 1) & 0x7F) | (lastBit << 7);
lastBit = data[i] & 1;
data[i] ^= 0xFF - mask;
}
}
} // namespace diff
|