Differences
This shows you the differences between two versions of the page.
| Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
| doc:srdl2_tutorial [2014/11/27 16:33] – [Components and capabilities of a robot] admin | doc:srdl2_tutorial [2014/11/27 17:05] (current) – [Matching requirements to capabilities] admin | ||
|---|---|---|---|
| Line 28: | Line 28: | ||
| $ rosrun rosprolog rosprolog knowrob_srdl | $ rosrun rosprolog rosprolog knowrob_srdl | ||
| - | % Load SRDL model of the PR2 robot | + | % Load SRDL model of the PR2 and Baxter robots |
| ?- owl_parse(' | ?- owl_parse(' | ||
| + | ?- owl_parse(' | ||
| + | % Load an example task description for serving a drink | ||
| + | ?- register_ros_package(knowrob_actions). | ||
| + | ?- owl_parse(' | ||
| </ | </ | ||
| Line 40: | Line 44: | ||
| Sub = pr2: | Sub = pr2: | ||
| Sub = pr2: | Sub = pr2: | ||
| + | [...] | ||
| + | </ | ||
| + | |||
| + | Filter the list of components to only those of a given type, e.g. a //Camera//: | ||
| + | |||
| + | <code prolog> | ||
| + | ?- sub_component(pr2:' | ||
| + | | ||
| + | Sub = pr2: | ||
| + | Sub = pr2: | ||
| + | Sub = pr2: | ||
| + | Sub = pr2: | ||
| + | Sub = pr2: | ||
| + | [...] | ||
| + | </ | ||
| + | |||
| + | Read all properties of a component: | ||
| + | |||
| + | <code prolog> | ||
| + | ?- sub_component(pr2:' | ||
| + | Sub = pr2: | ||
| + | Sub = pr2: | ||
| + | P = srdl2comp: | ||
| + | O = literal(type(' | ||
| + | Sub = pr2: | ||
| + | P = srdl2comp: | ||
| + | O = literal(type(xsd: | ||
| + | Sub = pr2: | ||
| + | P = srdl2comp: | ||
| + | O = literal(type(xsd: | ||
| [...] | [...] | ||
| </ | </ | ||
| Line 55: | Line 89: | ||
| </ | </ | ||
| - | Check which capabilities exists on a robot | + | Check which capabilities exists on a robot: |
| <code prolog> | <code prolog> | ||
| - | | + | ?- cap_available_on_robot(Cap, |
| - | Cap = 'http:// | + | Cap = srdl2cap:'GraspingCapability' ; |
| - | Cap = ' | + | Cap = srdl2cap:'ObjectManipulationCapability' ; |
| - | Cap = 'http:// | + | [...] |
| - | Cap = ' | + | |
| - | ... | + | |
| </ | </ | ||
| ===== Requirements of an action ===== | ===== Requirements of an action ===== | ||
| Capabilities an action depends on: | Capabilities an action depends on: | ||
| - | | + | |
| - | | + | <code prolog> |
| - | | + | ?- required_cap_for_action(serve_drink:'ServeADrink', |
| - | | + | C = srdl2cap:' |
| - | | + | C = srdl2cap:' |
| - | ... | + | C = srdl2cap:'GraspingCapability' ; |
| + | C = srdl2cap:' | ||
| + | [...] | ||
| + | </code> | ||
| Components an action depends on (either directly or via required capabilities that depend on these components) | Components an action depends on (either directly or via required capabilities that depend on these components) | ||
| - | | + | <code prolog> |
| - | | + | ?- required_comp_for_action(serve_drink:'ServeADrink', |
| - | | + | C = srdl2comp:' |
| - | | + | C = srdl2comp:' |
| - | ... | + | C = srdl2comp:' |
| + | C = srdl2comp:' | ||
| + | [...] | ||
| + | </ | ||
| ===== Missing components or capabilities ===== | ===== Missing components or capabilities ===== | ||
| - | | + | <code prolog> |
| - | Cap = ' | + | % No components nor capabilities are missing for the ServeADrink action on the PR2: |
| - | Cap = ' | + | ?- missing_comp_for_action(serve_drink:'ServeADrink', |
| + | false. | ||
| - | | + | ?- missing_cap_for_action(serve_drink:'ServeADrink', |
| - | false. | + | false. |
| - | + | % The Baxter robot, in contrast, cannot perform the task due to lacking navigation abilities: | |
| - | ===== Matching requirements to capabilities | + | ?- missing_cap_for_action(serve_drink:' |
| + | C = srdl2cap:' | ||
| + | </ | ||
| + | ===== Behind the scenes: Implementation of the matching procedures | ||
| The matching can effectively reduced to the following statement: | The matching can effectively reduced to the following statement: | ||
| + | <code prolog> | ||
| missing_cap_for_action(Action, | missing_cap_for_action(Action, | ||
| | | ||
| \+ cap_available_on_robot(Cap, | \+ cap_available_on_robot(Cap, | ||
| - | A missing capability is thus defined as one that is required by an action, but not provided by the robot. Required means that either the action itself or any sub-action has a dependency on this capability: | + | </ |
| + | |||
| + | A missing capability is thus defined as one that is required by an action but not provided by the robot. | ||
| + | <code prolog> | ||
| required_cap_for_action(Action, | required_cap_for_action(Action, | ||
| | | ||
| Line 102: | Line 149: | ||
| | | ||
| | | ||
| + | </ | ||
| - | There are three possibilities to express that a capability is available on a robot: Either it is asserted to be available for the whole class of robots (e.g. every PR2 has a holonomic base), for a specific robot instance, or it can be concluded that the capability should be available because all specified dependencies on components or other capabilities are fulfilled: | ||
| + | There are three possibilities to express that a capability is available on a robot: Either it is asserted to be available for the whole class of robots (e.g. every PR2 has a mobile base), for a specific robot instance, or it can be concluded that the capability should be available because all specified dependencies on components or other capabilities are fulfilled: | ||
| + | <code prolog> | ||
| % capability asserted for robot instance | % capability asserted for robot instance | ||
| cap_available_on_robot(Cap, | cap_available_on_robot(Cap, | ||
| Line 124: | Line 173: | ||
| | | ||
| | | ||
| + | </ | ||
| The matching procedure is equivalent for components. | The matching procedure is equivalent for components. | ||

