DeFM: Learning Foundation Representations from Depth for Robotics
Project description
DeFM: Learning Foundation Representations from Depth for Robotics
DeFM (Depth Foundation Model) is a vision backbone trained on 60M depth images via self-distillation. It is engineered for robotic perception, providing metric-aware representations that excel in sim-to-real transfer and cross-sensor generalization.
TL;DR - A DINO-style encoder, but for depth image inputs.
🌟 Key Features
- Large-Scale Pretraining: We pretrain on our curated dataset of 60 M depth images using self-distillation.
- Semantic Awareness: DeFM learns not only robust geometric priors but also semantically rich features from just depth images.
- Metric-Aware Normalization: Our novel three channel input normalization preserves metric depth across multiple scales.
- Compact efficient models: We distill our DeFM-ViT-L into a family of smaller efficient CNNs as small as 3M params for robot policy learning.
- Robotics Proven: Our encoder is proven effective for diverse robotic tasks such as navigation, manipulation and locomotion without task-specific fine-tuning.
🛠️ Installation
To use DeFM as a backbone in your own projects without cloning this repository, ensure you have the following prerequisites installed:
pip install torch torchvision numpy huggingface_hub omegaconf
and directly jump to Quick Start. Otherwise, below you can find instructions to install the DeFM module for using the notebooks or for local development.
Using uv (Fastest)
# Create and activate environment
uv venv --python 3.10
source .venv/bin/activate
# Install dependencies and DeFM in editable mode
uv pip install -e .
Using standard pip
pip install -e .
🚀 Quick Start
1. Loading the Model
Load via TorchHub for easy integration:
import torch
# Load the 307M Parameter Foundation Model
model = torch.hub.load('leggedrobotics/defm:main', 'defm_vit_l14', pretrained=True)
model.eval().to("cuda")
2. Preprocessing
DeFM requires depth maps to be processed into our metric-aware 3-channel format.
from defm import preprocess_depth_image
# Depth needs to be in meters (numpy array, tensor or PIL image)
normalized_depth = preprocess_depth_image(metric_depth, target_size=518, patch_size=14)
3. Inference
with torch.no_grad():
output = model.get_intermediate_layers(
normalized_depth, n=1, reshape=True, return_class_token=True)
spatial_tokens = output[0][0] # (B, C, H', W')
class_token = output[0][1] # (B, C)
📂 Project Structure
defm/: Main package containing model factory, architectures, and utils.notebooks/: Demo notebooks for Semantic PCA Visualization and Inference Scripts for CNNs and ViTs.classification/: Scripts and packages to reproduce the classification results [TODO]segmentation/: Scripts and packages to reproduce the segmentation results [TODO]
📊 Model Zoo
The following table provides a comprehensive overview of the DeFM model family, including architectural parameters, inference latency across training and deployment hardware (224x224), and performance on the ImageNet-1k-Depth benchmark.
| Model | Params (M) | RTX 4090 (ms) | Jetson Orin (ms) | Top-5 KNN (%) | Linear Prob (%) | Checkpoint |
|---|---|---|---|---|---|---|
| DeFM ViT-L/14 | 307.0 | 624.91 | 72.82 | 84.79 | 71.72 | Download |
| DeFM ViT-S/14 | 22.1 | 63.76 | 11.92 | 78.06 | 61.54 | Download |
| DeFM ResNet-50 | 26.2 | 69.39 | 17.79 | 77.63 | 61.54 | Download |
| DeFM ResNet-34 | 21.8 | 33.08 | 13.54 | 72.72 | 54.39 | Download |
| DeFM ResNet-18 | 11.7 | 21.06 | 8.67 | 69.69 | 50.58 | Download |
| DeFM EfficientNet-B6 | 28.98 | 150.98 | 54.11 | 77.81 | 59.23 | Download |
| DeFM EfficientNet-B4 | 14.16 | 86.51 | 39.67 | 74.74 | 54.73 | Download |
| DeFM EfficientNet-B2 | 4.95 | 46.12 | 28.37 | 71.51 | 50.32 | Download |
| DeFM EfficientNet-B0 | 3.01 | 29.39 | 21.04 | 67.98 | 46.17 | Download |
| DeFM RegNetY-1.6GF | 12.4 | 44.25 | 41.82 | 76.21 | 57.28 | Download |
| DeFM RegNetY-800MF | 6.3 | 25.21 | 24.16 | 74.91 | 57.03 | Download |
| DeFM RegNetY-400MF | 4.1 | 17.27 | 25.17 | 72.87 | 50.51 | Download |
📖 Citation
If you find DeFM useful for your research, please cite our paper:
@misc{patel2026defm,
title={DeFM: Learning Foundation Representations from Depth for Robotics},
author={Manthan Patel and Jonas Frey and Mayank Mittal and Fan Yang and Alexander Hansson and Amir Bar and Cesar Cadena and Marco Hutter},
year={2026},
eprint={2601.18923},
archivePrefix={arXiv},
primaryClass={cs.RO},
url={https://arxiv.org/abs/2601.18923},
}
Contribution Guidelines
We use the following tools for maintaining code quality:
- pre-commit: Runs a list of formatters and linters over the codebase.
- ruff: An extremely fast Python linter and code formatter, written in Rust.
Please check here for instructions to set these up. To run over the entire repository, please execute the following command in the terminal:
# for installation (only once)
pre-commit install
# for running
pre-commit run --all-files
Acknowledgement
We would like to thank the researchers and developers of the DINOv2 repository for their excellent open-source work, which served as the foundation for our implementation.
This work was supported as part of the Swiss AI Initiative by a grant from the Swiss National Supercomputing Centre (CSCS) under project ID a144 on Alps. This work was also supported by the Luxembourg National Research Fund (Ref. 18990533), and the Swiss National Science Foundation (SNSF) through projects No. 200021E_229503 and No. 227617.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file defm-1.0.0.tar.gz.
File metadata
- Download URL: defm-1.0.0.tar.gz
- Upload date:
- Size: 34.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.8.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bd5ad07363446cfaaf9bdc3892f826aedd11f87b357ecfd44d356a40f28c5fdb
|
|
| MD5 |
3965e99d7e059321a5c0fc425003da92
|
|
| BLAKE2b-256 |
ea633e7560797932434f6f0b2b545769a99cc15cf6bc9f9b6ec6f7dd15bc8047
|
File details
Details for the file defm-1.0.0-py3-none-any.whl.
File metadata
- Download URL: defm-1.0.0-py3-none-any.whl
- Upload date:
- Size: 42.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.8.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c7b8c9fdc9741e98dd44cd02d880b09e3f6256b85340fbe9dc7ea46e42f657ed
|
|
| MD5 |
f52b27879d981d39f89a007a5945a729
|
|
| BLAKE2b-256 |
7e959fe8946b2349b0d28938f762978a04025e2957163f5313e0ff477cfee77c
|