/droidlet

A modular embodied agent architecture and platform for building embodied agents

Primary LanguageJupyter NotebookMIT LicenseMIT

droidlet

This repository, corresponding tutorials and docs are still being refined (and not ready yet).

droidlet helps you rapidly build agents (real or virtual) that perform a wide variety of tasks specified by humans. The agents can use natural language, memory and humans in the loop.

droidlet is an early research project for AI researchers to explore ideas around grounded dialogue, interactive learning and human-computer interfaces.

droidlet is in active development and is fairly unstable in design, API, performance and correctness. It is not meant for any production use.

Getting Started

You want to do one of three things:

  1. Robots: Reproduce and extend the PyRobot based agent on real robots such as LocoBot or photo-realistic simulators such as AIHabitat.
  2. Minecraft: Reproduced and extend the minecraft based game agent
  3. New Agent: write your own agent from scratch, starting from our base_agent abstraction

Robots Minecraft New Agent
1. Clone the source code
git clone --recursive https://github.com/facebookresearch/droidlet.git
cd droidlet
            
2. Check system requirements
- Linux
- Python 3 (Anaconda recommended)
- NVIDIA GPU (8GB+)
- PyRobot-compatible robot or sim
  - Habitat-sim instructions below
        
        
- Linux
- Python 3 (Anaconda recommended)
- NVIDIA GPU (4GB+)
- Minecraft
  - more instructions below
        
        
- Linux
- Python 3 (Anaconda recommended)
        
2. Install dependencies
pip install -r \
    locobot/requirements.txt
        
        
pip install -r \
    craftassist/requirements.txt
        
        
pip install -r requirements.txt
        
3. Instructions for running the Locobot agent 3. Instructions for running the Craftassist agent
4. Tutorials, runnable in Google Colab (more coming soon).

The tutorials introduce the `base_agent` architecture and take you through the 4 components of an Agent

5. API Documentation
6. Agent-specific API Documentation

Locobot agent API

CraftAssist agent API

Not Applicable

Documentation, Tutorials and Papers

Two papers cover the design of droidlet:

  1. droidlet: modular, heterogenous, multi-modal agents covers the overall design of droidlet as an embodied AI platform that is extensible to physical robots and simulators.
  2. CraftAssist: A Framework for Dialogue-enabled Interactive Agents covers the design of the dialogue parser and the task system of an earlier version of droidlet that is specific to the game Minecraft

License

droidlet is MIT licensed.

Other Links

Datasets

Download links to the datasets described in section 6 of Technical Whitepaper are provided here:

In the root of each tarball is a README that details the file structure contained within.