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:

dict