This repository serves as a template for building projects or extensions based on Isaac Lab. It allows you to develop in an isolated environment, outside of the core Isaac Lab repository.
Key Features:
- IsolationWork outside the core Isaac Lab repository, ensuring that your development efforts remain self-contained.
- FlexibilityThis template is set up to allow your code to be run as an extension in Omniverse.
Keywords: extension, template, isaaclab
- 
Install Isaac Lab by following the installation guide. We recommend using the conda installation as it simplifies calling Python scripts from the terminal. 
- 
Clone this repository separately from the Isaac Lab installation (i.e. outside the IsaacLabdirectory):
# Option 1: HTTPS
git clone https://github.com/isaac-sim/IsaacLabExtensionTemplate.git
# Option 2: SSH
git clone [email protected]:isaac-sim/IsaacLabExtensionTemplate.git- Throughout the repository, the name ext_templateonly serves as an example and we provide a script to rename all the references to it automatically:
# Enter the repository
cd IsaacLabExtensionTemplate
# Rename all occurrences of ext_template (in files/directories) to your_fancy_extension_name
python scripts/rename_template.py your_fancy_extension_name- Using a python interpreter that has Isaac Lab installed, install the library
python -m pip install -e source/ext_template- Verify that the extension is correctly installed by running the following command:
python scripts/rsl_rl/train.py --task=Template-Isaac-Velocity-Rough-Anymal-D-v0To setup the IDE, please follow these instructions:
- Run VSCode Tasks, by pressing Ctrl+Shift+P, selectingTasks: Run Taskand running thesetup_python_envin the drop down menu. When running this task, you will be prompted to add the absolute path to your Isaac Sim installation.
If everything executes correctly, it should create a file .python.env in the .vscode directory. The file contains the python paths to all the extensions provided by Isaac Sim and Omniverse. This helps in indexing all the python modules for intelligent suggestions while writing code.
We provide an example UI extension that will load upon enabling your extension defined in source/ext_template/ext_template/ui_extension_example.py.
To enable your extension, follow these steps:
- 
Add the search path of your repository to the extension manager: - Navigate to the extension manager using Window->Extensions.
- Click on the Hamburger Icon (☰), then go to Settings.
- In the Extension Search Paths, enter the absolute path toIsaacLabExtensionTemplate/source
- If not already present, in the Extension Search Paths, enter the path that leads to Isaac Lab's extension directory directory (IsaacLab/source)
- Click on the Hamburger Icon (☰), then click Refresh.
 
- Navigate to the extension manager using 
- 
Search and enable your extension: - Find your extension under the Third Partycategory.
- Toggle it to enable your extension.
 
- Find your extension under the 
Currently, we don't have the Docker for Isaac Lab publicly available. Hence, you'd need to build the docker image for Isaac Lab locally by following the steps here.
Once you have built the base Isaac Lab image, you can check it exists by doing:
docker images
# Output should look something like:
#
# REPOSITORY                       TAG       IMAGE ID       CREATED          SIZE
# isaac-lab-base                   latest    28be62af627e   32 minutes ago   18.9GBFollowing above, you can build the docker container for this project. It is called isaac-lab-template. However,
you can modify this name inside the docker/docker-compose.yaml.
cd docker
docker compose --env-file .env.base --file docker-compose.yaml build isaac-lab-templateYou can verify the image is built successfully using the same command as earlier:
docker images
# Output should look something like:
#
# REPOSITORY                       TAG       IMAGE ID       CREATED             SIZE
# isaac-lab-template               latest    00b00b647e1b   2 minutes ago       18.9GB
# isaac-lab-base                   latest    892938acb55c   About an hour ago   18.9GBAfter building, the usual next step is to start the containers associated with your services. You can do this with:
docker compose --env-file .env.base --file docker-compose.yaml upThis will start the services defined in your docker-compose.yaml file, including isaac-lab-template.
If you want to run it in detached mode (in the background), use:
docker compose --env-file .env.base --file docker-compose.yaml up -dIf you want to run commands inside the running container, you can use the exec command:
docker exec --interactive --tty -e DISPLAY=${DISPLAY} isaac-lab-template /bin/bashWhen you are done or want to stop the running containers, you can bring down the services:
docker compose --env-file .env.base --file docker-compose.yaml downThis stops and removes the containers, but keeps the images.
We have a pre-commit template to automatically format your code. To install pre-commit:
pip install pre-commitThen you can run pre-commit with:
pre-commit run --all-filesIn some VsCode versions, the indexing of part of the extensions is missing. In this case, add the path to your extension in .vscode/settings.json under the key "python.analysis.extraPaths".
{
    "python.analysis.extraPaths": [
        "<path-to-ext-repo>/source/ext_template"
    ]
}If you encounter a crash in pylance, it is probable that too many files are indexed and you run out of memory.
A possible solution is to exclude some of omniverse packages that are not used in your project.
To do so, modify .vscode/settings.json and comment out packages under the key "python.analysis.extraPaths"
Some examples of packages that can likely be excluded are:
"<path-to-isaac-sim>/extscache/omni.anim.*"         // Animation packages
"<path-to-isaac-sim>/extscache/omni.kit.*"          // Kit UI tools
"<path-to-isaac-sim>/extscache/omni.graph.*"        // Graph UI tools
"<path-to-isaac-sim>/extscache/omni.services.*"     // Services tools
...