Skip to content

Latest commit

 

History

History
66 lines (51 loc) · 3.93 KB

README.md

File metadata and controls

66 lines (51 loc) · 3.93 KB

DL Axioms to PDDL Planning

  • translates OWL TBox axioms to PDDL derived predicates and inputs them into existing PDDL domain
  • translates OWL ABox axioms to PDDL to assertions and inputs them into existing PDDL problem
  • takes care of introducing new constants and objects, where necessary
  • can introduce comparision between numbers from ontology in planning domain

Build

build project by running

./gradlew shadowJar

Usage

  • you can only modifying the PDDL domain by inserting TBox axioms, only modifying the PDDL problem by inserting ABox axioms or both

  • run insertion of OWL axioms into PDDL with

    ./OWLToPDDL.sh --owl=<inputOWL> --tBox --inDomain=<inputPDDLdomain> --outDomain=<outputPDDLdomain> [OPTIONS]
    
    ./OWLToPDDL.sh --owl=<inputOWL> --aBox --inProblem=<inputPDDLproblem> --outProblem=<outputPDDLproblem> [OPTIONS]
    
    ./OWLToPDDL.sh --owl=<inputOWL> --tBox --inDomain=<inputPDDLdomain> --outDomain=<outputPDDLdomain> --aBox --inProblem=<inputPDDLproblem> --outProblem=<outputPDDLproblem> [OPTIONS]
    

Options

  • run ./OWLToPDDL.sh -h to see all options.
  • use --ignore-data-props to not export data properties to PDDL
  • use --add-num-comparisons to add comparisons between numerical data occuring in the ontology. For numerical data, the special type numerical-object is used to represent it.
  • use --replace-output to replace the PDDL files if they already exists. Per default, the output is not saved if the output file already exists

Planning

Comments on Program File Update

To speed up updating the problem file, i.e. in settings where only the input PDDL problem file has changed but the domain file and the ontology stay the same, one can export the aBox axioms from the ontology that need to be added to the problem file for later usage. This saves time when the problem file needs to be updated, as the ontology does not need to be loaded anymore. Use the following to export the additions to a file you like:

  java -jar build/libs/dlToPlanning-1.0-SNAPSHOT-all.jar --owl=<inputOWL> --export-problem-additions --problem-additions=<exportedAdditions>

Use the following to update the created problem file:

java -jar build/libs/dlToPlanning-1.0-SNAPSHOT-all.jar --aBox --inProblem=<inputPDDLproblem> --outProblem=<outputPDDLproblem> --replace-output --import-problem-additions --problem-additions=<exportedAdditions>

You can also export, while creating the problem and domain file, e.g. the first time the ontology is consulted and to use updates after that:

./OWLToPDDL.sh --owl=<inputOWL> --tBox --inDomain=<inputPDDLdomain> --outDomain=<outputPDDLdomain> --aBox --inProblem=<inputPDDLproblem> --outProblem=<outputPDDLproblem> --export-problem-additions --problem-additions=<exportedAdditions> [OPTIONS]

Effect on Runtime

Using the update has a significant impact on the runtime. E.g. in one of our tests, reading from ontology required 0.73s, reading from exported file required 0.34s (where only loading the classes took already about 0.20s).

ROS

ros2 run owl_to_pddl owl_to_pddl.py --ros-args -p owl_file:=<inputOWL> -p in_domain_file:=<inputPDDLdomain> -p out_domain_file:==<outputPDDLdomain> -p in_problem_file:=<inputPDDLproblem> -p out_problem_file:=<outputPDDLproblem> -p replace_output:=<true|false> -p add_numbers:=<true|false> -p ignore_data_properties:=<true|false>

Example:

ros2 run owl_to_pddl owl_to_pddl.py --ros-args -p owl_file:=examples/suave/suave_with_imports.owl -p in_domain_file:=examples/suave/suave_domain.pddl -p out_domain_file:=examples/suave/suave_domain_created.pddl -p in_problem_file:=examples/suave/suave_problem.pddl -p out_problem_file:=examples/suave/suave_problem_created.pddl