Skip to content

Latest commit

 

History

History
52 lines (38 loc) · 1.62 KB

README.md

File metadata and controls

52 lines (38 loc) · 1.62 KB

custom_int

An integer (signed and unsigned) class based on std::bitset

Background

During a project at my work I needed a convenient way to store values taking up the smallest amount of bits necessary, not in memory but later when they're serialized into an array of unsigned short ints. For instance, a value that could be between 0 and 7 was only supposed to be 3 bits long. I ended up developing my own solution based on std::bitset with some additional code in order to make it work with signed values. Another goal was to make it work as close to a regular integer type as possible so I also included arithmetics.

Usage

The idea was to make the usage as close to a regular integral type as possible.

Initialization:

Int<13> value1;
UInt<4> value2 = 2;

For implementations where a certain type is used alot one can make life easier with typedef:

typedef Int<5> Int5;
typedef Int<7> Int7;
typedef UInt<4> Uint4;
typedef UInt<9> Uint9;

Int5 value1;
Int7 value2;
Uint5 value3;
Uint9 value4;

Arithmetics

I've implemented support for just about every kind arithmetic operations including additon, subtraction, division and multiplication. For instantiation with > 64 bits these arithmetics are done bit-by-bit with a quite large performance hit as a result.

Int<5> value1, value2;

value1 = 1;
value2 = value1;

value1++;
value2--;

value1 * value2;

value1 * -2;

etc...

Contribution

I welcome any idea on how to improve this and please let me know if you find anything that isn't working!

Todo

I've not implemented a bit-by-bit implementation of division because I couldn't figure out how to do it.