Skip to content

lyfkyle/robotics_algorithms

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

robotics_algorithms

logo

This repository contains pure-python implementation for essential robotics algorithms.

The main benefits are:

  1. Have a single source of truth of various algorithms with clear explanation.
  2. Implemented with clear separation between dynamics, environment and algorithm, emphasizing that a lot of algorithms, e.g planing under uncertainties, optimal control, share the same underlying problem formulation,eg. MDP.

Scope

It should include popular and representative algorithms from robot dynamics, state estimation, planning, control and learning.

Requirement

python 3.10

How to use

  • Run pip install -e .
  • Run various scripts inside examples folder.

For example, to run a* to find the shortest path between start and goal in a grid world

python examples/planning/test_a_star.py

Status

This repository is undergoing significant development. Here is the status checklist.

  • Robot Dynamics
    • Differential drive
    • Cartpole
    • Double Integrator
    • Arm
    • Car
    • Quadrotor
    • Quadruped
  • State Estimation
    • Discrete bayes filter
    • Kalman filter
    • Extended Kalman filter
    • Particle filter
  • Planing
    • Discrete Planning
      • Dijkstra
      • A-star
    • Motion Planning
      • RRT / RRT-Connect / RRT*
      • PRM
      • BIT*
    • MDP
      • Value iteration
      • policy iteration
      • Policy tree search
      • MCTS
    • POMDP
      • Belief tree search
      • SARSOP
      • DESPOT
  • Control
    • Classical control (PID)
    • LQR
    • MPPI
    • CEM-MPC
  • Imitation learning
  • Reinforcement learning
    • Tabular
      • On-policy MC
      • Off-policy MC
      • On-policy TD (SARSA)
      • Off-policy TD (Q-learning)
    • Function approximation
  • Environments
    • Frozen lake (MDP)
    • Cliff walking (MDP)
    • Windy gridworld (MDP)
    • 1D navigation with double integrator
      • Deterministic and fully-observable
      • Stochastic and partially-observable
    • 2D navigation with omni-directional robot
      • Deterministic and fully-observable
    • 2D navigation with differential drive
      • Deterministic and fully-observable
      • Stochastic and partially-observable
    • 2D localization
    • 2D SLAM
    • Multi-arm bandits (POMDP)
    • Tiger (POMDP)

About

A collection of algorithms related to robotics.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages