Trajectory Optimization
The trajectory optimization examples are outdated and currently not available.
Dojo provides dynamics constraints and Jacobians in order to perform trajectory optimization using iterative LQR.
Quadruped
data:image/s3,"s3://crabby-images/0687a/0687ab3c97fe9f7e59eed4c38317c0c04d98c66f" alt=""
A Unitree A1 takes a number of forward steps. There are costs on a kinematic gait and control usage, as well as an augmented Lagrangian (i.e., soft) constraint on the the robot's final pose. The maximal representation is converted to a minimal one for optimization. Additionally, slack controls are utilized early on to aid the optimizer before being driven to zero by a constraint to achieve a dynamically feasible trajectory.
Atlas
data:image/s3,"s3://crabby-images/46e26/46e26b7bc0f97a91c977e255fa8027ef4d22f08f" alt=""
The Atlas v5 humanoid (sans arms) takes a number of forward steps. Similar to the quadruped example, there are costs on control effort and deviations from a kinematic plan, a minimal representation is utilized, and the optimizer is aided by slack controls.
Block
data:image/s3,"s3://crabby-images/2895f/2895fcfe1dd1b7767a21944e64b061c6e474e7f9" alt=""
A block is moved to a goal location by applying forces to its center of mass. The optimizer is initialized with zero control and utilizes smooth gradients from Dojo to find a motion that overcomes friction to slide towards the goal.
Raibert Hopper
data:image/s3,"s3://crabby-images/0307a/0307aa098ff054beef9cc7adfcaee4a13c669330" alt=""
A hopping robot, inspired by the Raibert Hopper, is tasked with moving to a goal location. The optimizer finds a single hop trajectory to reach its goal pose.
Cartpole
data:image/s3,"s3://crabby-images/ea860/ea8606e4b0803e71eb1fc27ac4979a42f12df59a" alt=""
This classic system is tasked with performing a swing-up. Examples are provided performing optimization with both maximal and minimal representations.