Skip to content

janehwu/mcc-ho

Repository files navigation

MCC-HO: Multiview Compressive Coding for Hand-Object 3D Reconstruction

Code repository for the paper: Reconstructing Hand-Held Objects in 3D from Images and Videos

Jane Wu, Georgios Pavlakos, Georgia Gkioxari, Jitendra Malik

arXiv Website shields.io

teaser

Installation

Installation and preparation follow the MAE repo, just like MCC. Please also install PyTorch3D for 3D related funcionality and the following libraries:

pip install omegaconf trimesh

HaMeR Installation

Our demo includes the option to use HaMeR to obtain 3D hands from RGB images. If you would like to use HaMeR, you can initialize the submodule:

git submodule update --init --recursive

Please follow the HaMeR repo for installation instructions. Afer installing HaMeR, you will need to create a symlink to the HaMeR data/checkpoints to be used for our demo:

ln -s [path to HaMeR root]/_DATA .

HaMeR requires ViTPose. You can either install ViTPose in the third-party folder of this repository, or symlink the installation from HaMeR (recommended):

ln -s [path to HaMeR root]/third-party/ViTPose third-party/ViTPose

Data

Please see DATASET.md for information on data preparation.

Demo (with HaMeR)

If you do not have input 3D hands, you can run MCC-HO inference on any input image and use HaMeR to obtain 3D hands. Please use, e.g.,

python demo_with_hamer.py \
    --image demo/drink_v_1F96GArORtg_frame000084.jpg \
    --obj_seg demo/drink_v_1F96GArORtg_frame000084_mask.png \
    --cam demo/camera_intrinsics_hamer.json \
    --checkpoint [path to model checkpoint]

The object segmentation mask (obj_seg) can be obtained using any off-the-shelf segmentation model, e.g. we use SAM 2.

One may use a checkpoint from the training step below or download our pretrained model (trained on DexYCB, MOW, and HOI4D) [here]. One may set the --score_thresholds argument to specify the score thresholds (More points are shown with a lower threshold, but the predictions might be noisier).

The script will generate an html file showing an interactive visualizaion of the MCC-HO output with plotly, as well as the predicted point clouds in the same coordinate system as the preprocessed HaMeR hand (saved at out_demo/input_hand.obj).

Demo (without HaMeR)

To run MCC-HO inference on any input image and input 3D hand, please use, e.g.,

python demo.py \
    --image demo/boardgame_v_W_qdSiPKSdQ_frame000019.jpg \
    --hand demo/boardgame_v_W_qdSiPKSdQ_frame000019_hand.obj \
    --seg demo/boardgame_v_W_qdSiPKSdQ_frame000019_mask.png \
    --cam demo/camera_intrinsics_mow.json \
    --checkpoint [path to model checkpoint]

Note that for your own data, you need to make sure the camera intrinsics correspond to the input 3D hand.

[Same as above] One may use a checkpoint from the training step below or download our pretrained model (trained on DexYCB, MOW, and HOI4D) [here]. One may set the --score_thresholds argument to specify the score thresholds (More points are shown with a lower threshold, but the predictions might be noisier).

The script will generate an html file showing an interactive visualizaion of the MCC-HO output with plotly, as well as the predicted point clouds in the same coordinate system as the input hand.

Training

To train an MCC-HO model, please run

OUTPUT=model_outputs
python main_mccho.py \
    --mccho_path [path to MCC-HO preprocessed data] \
    --dataset_cache [path to dataset cache] \
    --job_dir $OUTPUT \
    --output_dir $OUTPUT/log \
    --shuffle_train
  • Optional: MCC-HO (excluding the segmentation output layers) may be initialized using MCC pre-trained. A pretrained MCC model is available [here].

Acknowledgements

This implementation builds on the MCC codebase, which in turn is based on MAE.

Citing

If you find this code useful for your research, please consider citing the following paper:

@article{wu2024reconstructing,
  title={Reconstructing Hand-Held Objects in 3D},
  author={Wu, Jane and Pavlakos, Georgios and Gkioxari, Georgia and Malik, Jitendra},
  journal={arXiv preprint arXiv:2404.06507,
  year={2024},
}

Releases

No releases published

Packages

No packages published

Languages