-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathAdder.java
More file actions
86 lines (80 loc) · 2.34 KB
/
Copy pathAdder.java
File metadata and controls
86 lines (80 loc) · 2.34 KB
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
/**
* Class represents whole adder with data and calculations
*/
public class Adder{
private Data data;
private Line[] line;
private CarryDigit carryDigit;
private boolean[] output;
private boolean schemeType;
int[][] scheme;
int linesNumber;
Adder(String firstNumber, String secondNumber, boolean schemeType){
int max;
if (firstNumber.length()>secondNumber.length()){
max = firstNumber.length();
secondNumber = fixLength(secondNumber, max - secondNumber.length());
}
else if (firstNumber.length()<secondNumber.length()){
max = secondNumber.length();
firstNumber = fixLength(firstNumber, max - firstNumber.length());
} else {
max = secondNumber.length();
}
data = new Data(firstNumber, secondNumber);
this.schemeType = schemeType;
if (!this.schemeType)
scheme = data.generateKoggeStone(data.getWidth(), data.getHeight());
else
scheme = data.generateSklansky(data.getWidth(), data.getHeight());
line = new Line[max];
linesNumber = max;
for (int i=0; i<linesNumber; i++){
line[i] = new Line(data, i, scheme);
}
carryDigit = new CarryDigit(data);
this.output = data.getOutput();
}
/**
* Add '0' to a left side of word
* @param word String to be fixed
* @param paddingSize number of '0' to be added
* @return String with added '0'
*/
private String fixLength(String word, int paddingSize){
String w = word;
for (int i=0; i<paddingSize; i++){
w = '0'+w;
}
return w;
}
/**
* Start threads calculating output
*/
public void calculate(){
for (int i=0; i<linesNumber; i++){
line[i].start();
}
carryDigit.start();
}
public String getOutput(){
String str = "";
for (boolean bit: output){
if (bit == false){
str = '0'+str;
} else if (bit == true){
str = '1'+str;
}
}
return str;
}
/**
* Display visualisation of a whole adder
*/
public void showGraph(){
data.showGenerators();
data.showGraph();
data.showOutput();
System.out.println();
}
}