Skip to content

Latest commit

 

History

History
159 lines (122 loc) · 11.4 KB

README.md

File metadata and controls

159 lines (122 loc) · 11.4 KB

[ICRA2024] Reg-NF: Efficient Registration of Implicit Surfaces within Neural Fields

[Project Page] | [Paper] | [Data]

This repository contains the code implementation used in the paper Reg-NF: Efficient Registration of Implicit Surfaces within Neural Fields published within proceedings of the International Conference of Robotics and Automation (ICRA) 2024.

Abstract

Neural fields, coordinate-based neural networks, have recently gained popularity for implicitly representing a scene. In contrast to classical methods that are based on explicit representations such as point clouds, neural fields provide a continuous scene representation able to represent 3D geometry and appearance in a way which is compact and ideal for robotics applications. However, limited prior methods have investigated registering multiple neural fields by directly utilising these continuous implicit representations. In this paper, we present Reg-NF, a neural fields-based registration that optimises for the relative 6-DoF transformation between two arbitrary neural fields, even if those two fields have different scale factors. Key components of Reg-NF include a bidirectional registration loss, multi-view surface sampling, and utilisation of volumetric signed distance functions (SDFs). We showcase our approach on a new neural field dataset for evaluating registration problems. We provide an exhaustive set of experiments and ablation studies to identify the performance of our approach, while also discussing limitations to provide future direction to the research community on open challenges in utilizing neural fields in unconstrained environments.

Install

The code here is designed to work within a pre-existing sdfstudio repository. Please see the sdfstudio repository to install sdfstudio.

Once sdfstudio is installed, simply copy the relevant contents of this repo into sdfstudio, install remainging dependancies and update the package.

git clone https://github.com/csiro-robotics/Reg-NF.git
cp Reg-NF/scripts <path/to/sdfstudio>/
cp Reg-NF/configs <path/to/sdfstudio>/
cd <path/to/sdfstudio>
pip install visdom git+https://github.com/jonbarron/robust_loss_pytorch
pip install -e .

Now you should be ready to use RegNF

Using RegNF

RegNF can be broken up into 3 steps with three scripts. Training SDF models, registration through reg-nf, and rendering/evaluating results.

Training SDF models

SDF models are trained using existing sdfstudio procedures with some notable assumptions being made for interaction with the rest of the code base.

  1. Training is done using the neus-facto model
  2. Naming convention for experiments is neus-facto-<name>-<suffix>-<img_size> where <name> is the name of the object/scene being described, <suffixes> are any suffixes listed in the rest of the codebase (e.g. "short" for short trajectories in scenes) and <img_size> is a single integer indicating the size of the image used in training.
  3. Data used for training is in the same format as the ONR dataset (containing model GT names and poses for evaluation). For more info see ReadMe in the link above.

Example object training (w. depth data)

ns-train neus-facto \
    --pipeline.model.sdf-field.inside-outside False \
    --pipeline.model.sdf-field.geometric-init True \
    --pipeline.model.sdf-field.bias 0.5 \
    --pipeline.model.near-plane 0.05 \
    --pipeline.model.far-plane 2.5 \
    --pipeline.model.overwrite-near-far-plane True \
    --pipeline.model.background-model none \
    --pipeline.model.background-color white \
    --pipeline.model.sensor-depth-l1-loss-mult 0.1 \
    --pipeline.model.sensor-depth-sdf-loss-mult 6000 \
    --pipeline.model.sensor-depth-freespace-loss-mult 10.0 \
    --pipeline.model.sensor-depth-truncation 0.0248 \
    --trainer.steps-per-eval-image 1000 \
    --trainer.steps-per-eval-batch 1000 \
    --trainer.steps-per-save 1000 \
    --trainer.max-num-iterations 30001 \
    --experiment-name neus-facto-fc \
    sdfstudio-data \
    --data data/omniverse/objects/fancy_chair_512_rtxi/ \
    --include-sensor-depth True

Once you have at least one scene model and one object model, you are ready to perform RegNF

RegNF Registration

Once you have a scene and an object SDF model as outlined above, you are ready to use RegNF to perform registration.

You do this for a single object with it's matching object within a scene without any visualisations using regnf.py as follows:

python scripts/regnf.py --scene-sdf-path <path/to/scene.yml> --object-sdf-path <path/to/object.yml> --transform-savepath <path/to/transform.npy> sdfstudio-data --data <path/to/scene/data>

Options exist to perform visualisations with visdom or open3d, saving open3d visualisations of each step of optimization, saving the initialisation, FGR or each step transformation matrices, as well as to enable the provided object to be tested against every object within the scene. For further details run python scripts/regnf.py -h.

Note the savepath provided in --transform-savepath will have an additional suffix added to the end of it, indicating which object within the scene the provided object was matched with (useful for when testing against all objects within the scene)

WARNING To save different transform outputs and use these results in later evaluation scripts, we assume the following naming conventions

  1. "transforms" should be included as a folder along the savepath
  2. Final file follows the format <scene_model>-2-<object_model>.npy where both <scene_model> and object_model are short names included both in the PRIM_TO_OBJECT_SHORT and OBJECT_FULLNAMES dictionaries found in regnf.py

Evaluating RegNF Results

If transform matrices and scene and object model files have been set up according to the naming conventions outlined above, the transformation numpy file will be all that is needed to perform evaluation as follows:

python scripts/evaluate_transforms.py --tmat_file <path/to/transform.npy> --result_csv <path/to/csv>

Where the csv file provided will have the latest evaluation results appended to it.

Note there is also the option to add a --run_id to this script to indicate multiple runs of the same experiment setup. Used primarily in conjunction with permute scripts.

RegNF Scene Editing Rendering with RegNF Results

As shown in the paper, RegNF results can enable library substitution or object instance replacement within the scene. In our code base, this is all performed through the render_multiple_sdfs.py script. Relevant flags are

--scene-sdf-path -> Path to the main scene sdf YAML (required)
--object-sdf-paths -> Paths to object sdf YAMLs (can be multiple if whishing to perform multiple substitutions/replacements)
--object-transform-paths -> Paths to object transforms for the scene NPY format (can be multiple but assumes same order as object_sdf_paths)
--replace-sdf-paths -> Paths to object sdf YAMLS that will replace those originally used in the transform (can be multiple but assumes same order as object_sdf_paths).
--scene-remove-ids -> Instance IDs to be removed from the scene if rendering in "replace" mode. Note this assumes the same order as object_sdf_paths and any extra ids will simply be removed from the scene with no replacement. Recommended for replace mode rendering. Consult scene data meta_data.json for instance IDs.
--object-colours -> what colours to render objects as (useful visualisation for library substitution)
--render-mode -> mode to use for rendering. Options replace (remove old objects from scene and render new ones on top) and blend (overlay scene and object SDFs together).
--sampler -> Sampler to use for rendering. Options original or uniform. Recommend uniform for replace mode as smart sampler used in neus-facto can produce odd looking artefacts.
--output-path -> Name of output folder (default: renders)

To perform substitution, simply don't provide any paths for --replace-sdf-paths and the library objects will be placed into the scene according to the transformation file provided.

To perform instance replacements, simply provide paths for --replace-sdf-paths to object model YAML files that match the class of object being replaced. Note that you should also use replace mode and provide --scene-remove-ids for the original to avoid any clipping effects with the original scene objects.

Set up multiple tests

To speed up running experiments en masse, we provide two scripts that can generate single bash scripts for some subset of experiments.

The permute_regnf_multi.py script enables you to set up which scenes and objects you want to permute over, set up multiple iteractions of the same test, options for saving different intermittent transforms,etc. For full details run python scripts/permute_regnf_multi.py -h. The output will be a bash script that, when run, will run regnf multiple times across all permutations you had predefined.

The permute_eval.py script enables you to perform the evaluate_transforms.py script across all transforms found in a central transforms folder location and store the results in a given results file. It is assumed all transforms of interest are directly within the given transforms_folder input unless --multiple_runs flag is provided in which case the transformed are nexted under individual run folders.

Update RegNF parameters

Many RegNF hyperparameters can be manually adjusted through a regnf config file. By default we use the parameters found in configs/default_regnf.yaml which were found to be effective on the ONR dataset. These can be changed as desired for future experiments.

Set up ONR dataset

This code is designed to work with the scenes and objects from the Object Neural field Registration (ONR) dataset. You can find the dataset and details for downloading it here. Full details on the dataset can be found in the dataset ReadME. Once downloaded, simply ensure that you either copy or link the raw image data to your sdfstudio data folder and the trained models to the outputs folder. The dataset itself should have already split the data into such folders. Make sure to maintain folder data structure.

Known issues

We have found there are some issues using the pre-trained models in the ONR dataset with different versions of sdfstudio as they had been trained on different versions.

Working with latest sdfstudio

  • chair
  • dining_chair
  • matrix_chair

working on older sdfstudio

  • fancy_chair
  • fancy_chair_no_pillow
  • end_table
  • table
  • willow_table

To use the older models run pip install torchmetrics==0.11.4 lpips. To revert back run pip install torchmetrics==1.4.0. For simplicity we recommend training new models from scratch with the raw image data provided.

Citation

If you find this work useful, please consider citing:

@inproceedings{hausler2024regnf,
	title = {Reg-{NF}: {Efficient} {Registration} of {Implicit} {Surfaces} within {Neural} {Fields}},
	shorttitle = {Reg-{NF}},
	doi = {10.1109/ICRA57147.2024.10610982},
	booktitle = {2024 {IEEE} {International} {Conference} on {Robotics} and {Automation} ({ICRA})},
	author = {Hausler, Stephen and Hall, David and Mahendren, Sutharsan and Moghadam, Peyman},
	month = may,
	year = {2024},
	pages = {15409--15415},
}