-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmain_container.py
29 lines (21 loc) · 1000 Bytes
/
main_container.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
from csp.problem import *
from csp.backtracking import *
problem = Containers()
initial_state = {}
search = BackTracking(problem=problem,
var_criterion=random_variable,
value_criterion=random_assignment)
print(f'{search}, Random strategies')
print(search.run(initial_state))
search = BackTracking(problem=problem,
var_criterion=minimum_remaining_values,
value_criterion=least_constraining_value)
print(f'{search}, Minimum Remaining Values, Least Constraining Value')
print(search.run(initial_state))
search = BackTracking(problem=problem,
var_criterion=degree_heuristic,
value_criterion=least_constraining_value)
print(f'{search},Degree Heuristic, Least Constraining Value')
print(search.run(initial_state))
print(f'{search},Forward Checking, Degree Heuristic, Least Constraining Value')
print(search.run_with_forward_checking(initial_state, problem.domains))