-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
30 lines (21 loc) · 1017 Bytes
/
main.py
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
from components import logic_gate
from components import adder
from components import register
import random
def main():
ARCHITECURE = 8 # 8-bit architecture (can be changed to any value (e.g. 4, 16, 32, 64, 128, 256, etc.))
print(f"Example of adding two {ARCHITECURE}-bit numbers (unsigned int range: 0 to {2 ** ARCHITECURE - 1})")
reg1 = register.Register(ARCHITECURE)
reg2 = register.Register(ARCHITECURE)
reg1.set_value(random.randint(0, 2 ** ARCHITECURE - 1))
reg2.set_value(random.randint(0, 2 ** ARCHITECURE - 1))
adder1 = adder.RegisterAdder(ARCHITECURE)
adder1.set_registers(reg1.read_register(), reg2.read_register())
reg3 = register.Register(ARCHITECURE)
reg3.write_register(adder1.get_sum())
print(f"R1: {reg1.read_register()} ({reg1.get_value()})")
print(f"R2: {reg2.read_register()} ({reg2.get_value()})")
print(f"R3: {reg3.read_register()} ({reg3.get_value()})")
#logic_gate.print_all_truth_tables()
if __name__ == "__main__":
main()