From dd3613b2144ea796508deec4bad0c6be6010e561 Mon Sep 17 00:00:00 2001 From: Jordan Sherer Date: Thu, 12 Jul 2018 09:54:56 -0400 Subject: [PATCH] Added bit packing to varicode --- varicode.cpp | 73 ++++++++++++++++++++++++++++++++++++++++++++++------ varicode.h | 20 +++++++++++++- 2 files changed, 84 insertions(+), 9 deletions(-) diff --git a/varicode.cpp b/varicode.cpp index 4f32466..baa8f5f 100644 --- a/varicode.cpp +++ b/varicode.cpp @@ -1,24 +1,81 @@ +/** + * (C) 2018 Jordan Sherer - All Rights Reserved + **/ + #include "varicode.h" +const int nalphabet = 41; QString alphabet = {"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ+-./?"}; -qint16 Varicode::unpack16bits(QString const& triple){ - int a = alphabet.indexOf(triple.at(0)); - int b = alphabet.indexOf(triple.at(1)); - int c = alphabet.indexOf(triple.at(2)); - return (41*41) * a + 41*b + c; +QVector Varicode::intToBits(qint64 value, int expected){ + QVector bits; + + while(value){ + bits.prepend((bool) value & 1); + value = value >> 1; + } + + if(expected){ + while(bits.count() < expected){ + bits.prepend((bool) 0); + } + } + + return bits; +} + +qint64 Varicode::bitsToInt(QVector const value){ + qint64 v = 0; + foreach(bool bit, value){ + v = (v << 1) + (int)(bit); + } + return v; +} + +qint8 Varicode::unpack5bits(QString const& value){ + return alphabet.indexOf(value.at(0)); +} + +QString Varicode::pack5bits(qint8 packed){ + return alphabet.at(packed % nalphabet); +} + +qint16 Varicode::unpack16bits(QString const& value){ + int a = alphabet.indexOf(value.at(0)); + int b = alphabet.indexOf(value.at(1)); + int c = alphabet.indexOf(value.at(2)); + return (nalphabet*nalphabet) * a + nalphabet*b + c; } QString Varicode::pack16bits(qint16 packed){ QString out; - qint16 tmp = packed / (41*41); + qint16 tmp = packed / (nalphabet*nalphabet); out.append(alphabet.at(tmp)); - tmp = (packed - (tmp * (41*41))) / 41; + tmp = (packed - (tmp * (nalphabet*nalphabet))) / nalphabet; out.append(alphabet.at(tmp)); - tmp = packed % 41; + tmp = packed % nalphabet; out.append(alphabet.at(tmp)); return out; } + +qint32 Varicode::unpack32bits(QString const& value){ + return unpack16bits(value.left(3)) << 16 | unpack16bits(value.right(3)); +} + +QString Varicode::pack32bits(qint32 packed){ + qint16 a = (packed & 0xFFFF0000) >> 16; + qint16 b = packed & 0xFFFF; + return pack16bits(a) + pack16bits(b); +} + +qint64 Varicode::unpack64bits(QString const& value){ + return unpack16bits(value.left(6)) << 32 | unpack16bits(value.right(6)); +} + +QString Varicode::pack64bits(qint64 packed){ + qint32 a = (packed & 0xFFFFFFFF00000000) >> 32; + qint32 b = packed & 0xFFFFFFFF; +} diff --git a/varicode.h b/varicode.h index b490c4d..fe21cbc 100644 --- a/varicode.h +++ b/varicode.h @@ -1,15 +1,33 @@ #ifndef VARICODE_H #define VARICODE_H +/** + * (C) 2018 Jordan Sherer - All Rights Reserved + **/ + +#include #include +#include class Varicode { public: //Varicode(); - qint16 unpack16bits(QString const& triple); + QVector intToBits(qint64 value, int expected=0); + qint64 bitsToInt(QVector const value); + + qint8 unpack5bits(QString const& value); + QString pack5bits(qint8 packed); + + qint16 unpack16bits(QString const& value); QString pack16bits(qint16 packed); + + qint32 unpack32bits(QString const& value); + QString pack32bits(qint32 packed); + + qint64 unpack64bits(QString const& value); + QString pack64bits(qint64 packed); }; #endif // VARICODE_H