-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsolver.py
executable file
·53 lines (43 loc) · 1.6 KB
/
solver.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
import networkx as nx
from parse import read_input_file, write_output_file
from utils import is_valid_solution, calculate_happiness, calculate_stress_for_room, convert_dictionary
import sys, time
from bruteforce import bruteForce
from estimator import estimate
def solve(G, s):
"""
Args:
G: networkx.Graph
s: stress_budget
Returns:
D: Dictionary mapping for student to breakout room r e.g. {0:2, 1:0, 2:1, 3:2}
k: Number of breakout rooms
"""
#TODO: your code here!
return estimate(G, s)
# Here's an example of how to run your solver.
# Usage: python3 solver.py test.in
if __name__ == '__main__':
assert len(sys.argv) == 2
path = sys.argv[1]
G, s = read_input_file(path)
start = time.time()
D, k = solve(G, s)
end = time.time()
assert is_valid_solution(D, G, s, k)
print("Total Happiness: {}".format(calculate_happiness(D, G)))
print("Solving took {} seconds.".format(end - start))
if path[-3:] == ".in":
write_output_file(D, f'{path[:-3]}.out')
else:
write_output_file(D, f'test/test.out')
# For testing a folder of inputs to create a folder of outputs, you can use glob (need to import it)
# if __name__ == '__main__':
# inputs = glob.glob('file_path/inputs/*')
# for input_path in inputs:
# output_path = 'file_path/outputs/' + basename(normpath(input_path))[:-3] + '.out'
# G, s = read_input_file(input_path, 100)
# D, k = solve(G, s)
# assert is_valid_solution(D, G, s, k)
# cost_t = calculate_happiness(T)
# write_output_file(D, output_path)