-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcla4.cpp
121 lines (97 loc) · 2.73 KB
/
cla4.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
114
115
116
117
118
119
120
#include <iostream>
#include <fstream>
#include <vector>
#include <math.h>
#define INPUTS 2
#define OUTPUTS 1
#define BITS 4
// Convert int to bit array
// in = original integer
// bits = how many bits to convert to
// *out = pointer to bool array;
void intToBits(int in, int bits, bool *out)
{
for (int j = 0; j < bits; ++j)
{
out[bits-j-1] = (in >> j) & 1;
}
}
// Vice-versa
int bitsToInt(bool *in, int bits)
{
int result = 0;
for (int i = 0; i < bits; ++i)
{
if (in[bits-i-1])
{
result += pow(2, i);
}
}
return result;
}
int main()
{
std::ofstream file;
file.open("example.tv", std::ios::trunc);
// Ex: 2 inputs, 4 bits is 2^(2*4) = 256 lines
int totalLines = pow(2, INPUTS*BITS);
// Inputs and Ouputs as one big bit array
// Will be broken apart into separate ints
bool inputBitArray[totalLines][INPUTS*BITS];
bool outputBitArray[BITS];
// Inputs and outputs as ints
unsigned int input[totalLines][INPUTS];
unsigned int output[totalLines][OUTPUTS];
bool cin[totalLines], cout[totalLines];
// Loop through all the lines
// In this case we're doing totalLines*2
// (one with cin = 0, another with cin = 1)
for (int ii = 0; ii < (totalLines*2); ++ii)
{
int i = (ii % totalLines);
cin[i] = (ii >= totalLines);
// Write out input as bits
intToBits(i, INPUTS*BITS, &inputBitArray[i][0]);
for (int j = 0; j < INPUTS*BITS; ++j)
{
file << inputBitArray[i][j];
std::cout << inputBitArray[i][j];
}
// Write out cin after input
file << cin[i];
std::cout << cin[i];
// Separate input from output
file << "_";
std::cout << "_";
// For each one of the inputs
for (int j = 0; j < INPUTS; ++j)
{
// Convert it into an int
input[i][j] = bitsToInt(&inputBitArray[i][j*BITS], BITS);
}
// For each one of the outputs
for (int j = 0; j < OUTPUTS; ++j)
{
int result = 0;
/// Process logic
result = input[i][0] + input[i][1] + cin[i];
output[i][j] = result;
// Convert output to bits
intToBits(output[i][j], BITS, &outputBitArray[0]);
// Print the output bits
for (int k = 0; k < BITS; ++k)
{
file << outputBitArray[k];
std::cout << outputBitArray[k];
}
// Print the cout
cout[i] = (result > 15);
file << cout[i];
std::cout << cout[i];
}
file << std::endl;
std::cout << std::endl;
}
file.close();
return 0;
}