forked from morxa/genfond
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcheck_solvable.py
36 lines (30 loc) · 1.08 KB
/
check_solvable.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
from genfond.state_space_generator import StateSpaceGraph
import argparse
import pddl
import sys
import tqdm
import logging
log = logging.getLogger(__name__)
def main():
logging.basicConfig(level=logging.INFO)
parser = argparse.ArgumentParser(description='Check if the given problems are solvable')
parser.add_argument('domain_file')
parser.add_argument('problem_file', nargs='*')
args = parser.parse_args()
domain = pddl.parse_domain(args.domain_file)
log.info('Parsing problems ...')
problems = []
for f in tqdm.tqdm(args.problem_file, disable=None):
problems.append(pddl.parse_problem(f))
problems.sort(key=lambda p: len(p.objects))
solvable = True
for i, problem in enumerate(problems):
try:
log.info(f'Checking {i}/{len(problems)} problem {problem.name} ...')
_ = StateSpaceGraph(domain, problem)
except AssertionError:
log.warning('Problem {} is not solvable'.format(problem.name))
solvable = False
sys.exit(0 if solvable else 1)
if __name__ == '__main__':
main()