-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
70 lines (49 loc) · 1.66 KB
/
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
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
import data_provider
import fermat
import os
import miller_rabin
import frobenius
import solovay_strassen
from cpu_and_mem import CPUandMEM_Print
numbers = []
def clean_logs(directory_path):
for file_name in os.listdir(directory_path):
os.remove(directory_path + os.sep + file_name)
def run_testing_function(function):
for number in numbers:
function(number)
def run_fermat(numbers):
print("Starting fermat")
for number in numbers:
fermat.is_probable_prime(number)
def run_miller_rabin(numbers):
print("Starting miller rabin")
for number in numbers:
miller_rabin.is_probable_prime(number)
def run_frobenius(numbers):
print("Starting frobenius")
for number in numbers:
frobenius.is_probable_prime(number)
def run_solovay_strassen(numbers):
print("Starting solovay strassen")
for number in numbers:
solovay_strassen.is_probable_prime(number)
def run_all_tests(numbers):
cpu_and_mem_getter = CPUandMEM_Print(os.getpid(), "logs/cpu_mem_fermat.log")
cpu_and_mem_getter.start()
run_fermat(numbers)
cpu_and_mem_getter.stop()
cpu_and_mem_getter = CPUandMEM_Print(os.getpid(), "logs/cpu_mem_miller_rabin.log")
cpu_and_mem_getter.start()
run_miller_rabin(numbers)
cpu_and_mem_getter.stop()
cpu_and_mem_getter = CPUandMEM_Print(os.getpid(), "logs/cpu_mem_solovay_strassen.log")
cpu_and_mem_getter.start()
run_solovay_strassen(numbers)
cpu_and_mem_getter.stop()
if __name__ == "__main__":
global numbers
file_name = "./data/data_set.p"
numbers = data_provider.get_random_numbers(file_name)
run_all_tests(numbers)
print("Finished!")