-
-
Notifications
You must be signed in to change notification settings - Fork 7.3k
/
gray_code.cpp
113 lines (97 loc) · 3.96 KB
/
gray_code.cpp
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/**
* @brief Program to generate n-bit [Gray
* code](https://en.wikipedia.org/wiki/Gray_code)
*
* @details
* Gray code is a binary numeral system
* where consecutive values differ in exactly 1 bit.
* The following code offers one of many possible Gray codes
* given some pre-determined number of bits.
*/
#include <bitset> /// for gray code representation
#include <cassert> /// for assert
#include <iostream> /// for IO operations
#include <vector> /// for vector data structure
/**
* @namespace bit_manipulation
* @brief Bit manipulation algorithms
*/
namespace bit_manipulation {
/**
* @namespace gray_code
* @brief Generate n-bit Gray code
*/
namespace gray_code {
/**
* @brief The main function to generate n-bit Gray code
*
* @param n Number of bits
* @return A vector that stores the n-bit Gray code
*/
std::vector<std::bitset<32>> gray_code_generation(int n) {
std::vector<std::bitset<32>> gray_code = {}; // Initialise empty vector
// No Gray codes for non-positive values of n
if (n <= 0) {
return gray_code;
}
int total_codes = 1 << n; // Number of n-bit gray codes
for (int i = 0; i < total_codes; i++) {
int gray_num = i ^ (i >> 1); // Gray code formula
gray_code.push_back(std::bitset<32>(gray_num)); // Store the value
}
return gray_code;
}
} // namespace gray_code
} // namespace bit_manipulation
/**
* @brief Self-test implementation
*
* @returns void
*/
static void test() {
std::vector<std::bitset<32>> gray_code_negative_1 = {};
std::vector<std::bitset<32>> gray_code_0 = {};
std::vector<std::bitset<32>> gray_code_1 = {
std::bitset<32>(0), std::bitset<32>(1)
};
std::vector<std::bitset<32>> gray_code_2 = {
std::bitset<32>(0), std::bitset<32>(1), std::bitset<32>(3), std::bitset<32>(2)
};
std::vector<std::bitset<32>> gray_code_3 = {
std::bitset<32>(0), std::bitset<32>(1), std::bitset<32>(3), std::bitset<32>(2),
std::bitset<32>(6), std::bitset<32>(7), std::bitset<32>(5), std::bitset<32>(4)
};
std::vector<std::bitset<32>> gray_code_4 = {
std::bitset<32>(0), std::bitset<32>(1), std::bitset<32>(3), std::bitset<32>(2),
std::bitset<32>(6), std::bitset<32>(7), std::bitset<32>(5), std::bitset<32>(4),
std::bitset<32>(12), std::bitset<32>(13), std::bitset<32>(15), std::bitset<32>(14),
std::bitset<32>(10), std::bitset<32>(11), std::bitset<32>(9), std::bitset<32>(8)
};
std::vector<std::bitset<32>> gray_code_5 = {
std::bitset<32>(0), std::bitset<32>(1), std::bitset<32>(3), std::bitset<32>(2),
std::bitset<32>(6), std::bitset<32>(7), std::bitset<32>(5), std::bitset<32>(4),
std::bitset<32>(12), std::bitset<32>(13), std::bitset<32>(15), std::bitset<32>(14),
std::bitset<32>(10), std::bitset<32>(11), std::bitset<32>(9), std::bitset<32>(8),
std::bitset<32>(24), std::bitset<32>(25), std::bitset<32>(27), std::bitset<32>(26),
std::bitset<32>(30), std::bitset<32>(31), std::bitset<32>(29), std::bitset<32>(28),
std::bitset<32>(20), std::bitset<32>(21), std::bitset<32>(23), std::bitset<32>(22),
std::bitset<32>(18), std::bitset<32>(19), std::bitset<32>(17), std::bitset<32>(16)
};
// invalid values for n
assert(bit_manipulation::gray_code::gray_code_generation(-1) == gray_code_negative_1);
assert(bit_manipulation::gray_code::gray_code_generation(0) == gray_code_0);
// valid values for n
assert(bit_manipulation::gray_code::gray_code_generation(1) == gray_code_1);
assert(bit_manipulation::gray_code::gray_code_generation(2) == gray_code_2);
assert(bit_manipulation::gray_code::gray_code_generation(3) == gray_code_3);
assert(bit_manipulation::gray_code::gray_code_generation(4) == gray_code_4);
assert(bit_manipulation::gray_code::gray_code_generation(5) == gray_code_5);
}
/**
* @brief Main function
* @returns 0 on exit
*/
int main() {
test(); //Run self-test implementation
return 0;
}