Re3Sim: Generating High-Fidelity Simulation Data via 3D-Photorealistic Real-to-Sim for Robotic Manipulation
Bolun Wang β Weinan Zhang β Jiangmiao Pangβ β
^Project leadβ β Corresponding author
Shanghai Jiao Tong University β Shanghai AI Lab βThe University of Hong Kong
We provide a Dockerfile to install the simulator environment. Here is the installation guide:
docker build -t re3sim:1.0.0 .After the installation, you can run the container:
docker run --name re3sim --entrypoint bash -itd --runtime=nvidia --gpus='"device=0"' -e "ACCEPT_EULA=Y" --rm --network=bridge --shm-size="32g" -e "PRIVACY_CONSENT=Y" \
    -v /path/to/resources:/root/resources:rw \
    re3sim:1.0.0Install IsaacLab:v1.1.0
# in docker
cd /root/IsaacLab
./isaaclab.sh --install noneInstall CUDA 11.8 in the Docker container. Then, install diff-gaussian-rasterization and simple-knn:
./cuda_11.8.0_520.61.05_linux.run --silent --toolkit
pip install src/gaussian_splatting/submodules/diff-gaussian-rasterization/
pip install src/gaussian_splatting/submodules/simple-knn/To reconstruct the geometry of the scene, you need to install OpenMVS by following the instructions in the OpenMVS Wiki within the Docker container and add the binary files to the PATH.
After that, we recommend saving the Docker image with docker commit.
The code in the docker may encounter some network issues, you can try to install the environment in the local machine following this instruction or uncomment this line in the yaml files:
franka_usd_path: /path/to/Re3Sim/re3sim/Collected_franka/franka.usd
We offer the necessary resources here. You can download them and place them in the following path:
# in docker
/isaac-sim/
    - src
        - data/
            - align/
            - gs-data/
            - items/
            - urdfs/
            - usd/
- Collect data in simulator
- collect data for pick and place tasks
# in /isaac-sim/src
python standalone/clean_example/pick_into_basket_lmdb.py- Visualize the Data
You can use utils/checker/check_lmdb_data_by_vis.ipynb to visualize the data.
- Prepare the data:
- Place the images in the folder /path/to/input/images.
- Place the image for alignment in /path/to/input/align_image.png.
- Reconstruct the scene:
# in docker
python reconstrct.py -i /path/to/inputThe scene will be reconstructed automatically.
- Calibrate and align the scene:
- Run real-deployment/calibration/hand_in_eye_shooting.ipynb.
python real-deployment/calibration/hand_in_eye_calib.py --data_root /path/to/calibrate_folder
python real-deployment/utils/get_marker2base_aruco.py --data_root /path/to/calibrate_folder- 
The file configs/pick_and_place/example.yamlprovides an example of how to configure the required paths in the configuration file.
- 
Replace the config path in src/standalone/clean_example/pick_into_basket_lmdb.pyto begin collecting data in the simulator:
python src/standalone/clean_example/pick_into_basket_lmdb.pyThe GitHub repository act-plus-plus contains our modified ACT code.
- create conda env in conda_env.yaml
- install torch
- install other modules in requirements.txt
- install detr
cd detr
pip install -e .- Put the data inside data/5_items_lmdband uncompress them. The file structure should look like this:
    βββ data
        βββ 5_items_lmdb 
            βββ random_position_1021_1_eggplant_low_res_continuous_better_controller2_multi_item_filtered_30_lmdb
                βββ ...
            βββ random_position_1021_1_eggplant_low_res_continuous_better_controller2_multi_item_filtered_45_lmdb
                βββ ... 
            βββ ...
- check data and remove broken files (optional)
python ../re3sim/utils/check_lmdb.py  <path to the data> # use --fast flag to enable a partial check.- process data to get act dataset:
# run the command in the act project root dir **/act-plus-plus/
python process_data.py --source-path /path/to/source --output-path /path/to/act_dataset - start training
# Single machine, 8 GPUs
torchrun --nproc_per_node=8 --master_port=12314 imitate_episodes_cosine.py --config-path=conf --config-name=<config name> hydra.job.chdir=True params.num_epochs=24 params.seed=100
# Multi-machine, multi-GPU
# First machine
torchrun --nproc_per_node=8 --node_rank=0 --nnodes=2 --master_addr=<master ip> --master_port=12314 imitate_episodes_cosine.py --config-path=conf --config-name=<config name> hydra.job.chdir=True params.num_epochs=24 params.seed=100
# Second machine
torchrun --nproc_per_node=8 --node_rank=1 --nnodes=2 --master_addr=<master ip> --master_port=12314 imitate_episodes_cosine.py --config-path=conf --config-name=<config name> hydra.job.chdir=True params.num_epochs=24 params.seed=100We provide the data for the pick a bottle task here. And we show how to train the policy with our data. Please download the dataset and place them in policies/act_plus_plus/lmdb_data
# in policies/act_plus_plus
export PYTHONPATH=$PYTHONPATH:$(pwd)
python process_data.py --source-path lmdb_data/pick_one --output-path data/pick_one --file-name _keys.json
# The configs are in `constants.py` and `conf/pick_one_into_basket.yaml`
torchrun --nproc_per_node=8 --master_port=12314 imitate_episodes_cosine.py --config-path=conf --config-name=pick_one_into_basket hydra.job.chdir=True params.num_epochs=24 params.seed=100Note: The data paths are jointly indexed through constants.py and conf/*.yaml. For custom datasets, you need to add a task in constants.py (new element of the SIM_TASK_CONFIGS dictionary) and create a yaml file where the params.task_name matches the key in constants.py.
To evaluate the policy in simulation, please refer to eval.md.
If you find our work helpful, please cite:
@article{han2025re3sim,
  title={Re$^3$Sim: Generating High-Fidelity Simulation Data via 3D-Photorealistic Real-to-Sim for Robotic Manipulation},
  author={Han, Xiaoshen and Liu, Minghuan and Chen, Yilun and Yu, Junqiu and Lyu, Xiaoyang and Tian, Yang and Wang, Bolun and Zhang, Weinan and Pang, Jiangmiao},
  journal={arXiv preprint arXiv:2502.08645},
  year={2025}
}The work is licensed under Creative Commons Attribution-NonCommercial 4.0 International.
- Gaussian-splatting: We use 3D Gaussian splatting as the rendering engine.
- Act-plus-plus: We modify the ACT model based on the code.
- Franka_grasp_baseline. We borrowed the code of the hand-eye calibration implementation from this codebase.
- IsaacLab: We used the script from this library to convert OBJ to USD.