armour.reachsets.JRSGenerator
- class armour.reachsets.JRSGenerator(robot, taylor_degree: int = 1, add_ultimate_bound: bool = True, traj_type: str = 'piecewise')[source]
Bases:
ReachSetGenerator
JointReachableSetsOnline This does the online computation of joint reachable sets. It then generates a JRSInstance object
- __init__(robot, taylor_degree: int = 1, add_ultimate_bound: bool = True, traj_type: str = 'piecewise')[source]
Methods
__init__
(robot[, taylor_degree, ...])generateReachableSet
(robotState)Obtains the relevant reachable set for the robotstate provided and outputs the singular instance of a reachable set.
getReachableSet
(robotState[, ignore_cache])Get a reachable set instance for the given robot state and passthrough arguments
- generateReachableSet(robotState: EntityState) dict[int, armour.reachsets.JRSInstance.JRSInstance] [source]
Obtains the relevant reachable set for the robotstate provided and outputs the singular instance of a reachable set. Wraps create_jrs_online
- getReachableSet(robotState: EntityState, ignore_cache: bool = False, **options) dict[int, rtd.planner.reachsets.ReachSetInstance.ReachSetInstance]
Get a reachable set instance for the given robot state and passthrough arguments
This function handles how to actually get the reachable set with built in caching of already generated instances. It will call generateReachableSet as needed. This is useful if we need to use one reachable set in another reachable set and we don’t want to regenerate it online. It performs caching based on the id of the provided robotState and and the string cast of any additional arguments. If we don’t want to use the cache on one call, setting ignore_cache to true will bypass caching altogether
- Parameters:
robotState – EntityState: Some state of used for generation / keying
ignore_cache – bool: If set true, the cache is completely ignored
- Returns:
A dict of problem id to ReachSetInstance pairs
- Return type: