Skip to content

Latest commit

 

History

History
112 lines (74 loc) · 4.94 KB

README.md

File metadata and controls

112 lines (74 loc) · 4.94 KB

[ECCV 2024] VFusion3D: Learning Scalable 3D Generative Models from Video Diffusion Models

Project page, Paper link, HF Demo

VFusion3D is a large, feed-forward 3D generative model trained with a small amount of 3D data and a large volume of synthetic multi-view data. It is the first work exploring scalable 3D generative/reconstruction models as a step towards a 3D foundation.

VFusion3D: Learning Scalable 3D Generative Models from Video Diffusion Models
Junlin Han, Filippos Kokkinos, Philip Torr
GenAI, Meta and TVG, University of Oxford
European Conference on Computer Vision (ECCV), 2024

News

  • [08.08.2024] HF Demo & HF Model are available, big thanks to Jade Choghari's help for making it possible.
  • [25.07.2024] Release weights and inference code for VFusion3D.

Results and Comparisons

3D Generation Results

User Study Results

Setup

Installation

git clone https://github.com/facebookresearch/vfusion3d
cd vfusion3d

Environment

We provide a simple installation script that, by default, sets up a conda environment with Python 3.8.19, PyTorch 2.3, and CUDA 12.1. Similar package versions should also work.

source install.sh

Quick Start

Pretrained Models

Prepare Images

  • We put some sample inputs under assets/40_prompt_images, which is the 40 MVDream prompt generated images used in the paper. Results of them are also provided under results/40_prompt_images_provided.

Inference

  • Run the inference script to get 3D assets.

  • You may specify which form of output to generate by setting the flags --export_video and --export_mesh.

  • Change --source_path and --dump_path if you want to run it on other image folders.

    # Example usages
    # Render a video
    python -m lrm.inferrer --export_video --resume ./checkpoints/vfusion3dckpt
    
    # Export mesh
    python -m lrm.inferrer --export_mesh --resume ./checkpoints/vfusion3dckpt
    

Local Gradio App

python gradio_app.py 

Hints

  1. Running out of GPU memory when generating videos?

    • Try reducing the --render_size parameter to 256 or even 128. Note that this will degrade performance.
  2. Unsatisfactory results?

    • This inference code works best with front view (or nearly front view) input images. Side views are generally supported, but may result in poorer outcomes. If this is the issue, see below.
  3. Customizing for different viewing angle inputs:

    • Although the model supports input images from any viewing angle, you will need to modify lrm/inferrer.py, which can be a bit complex so it is usually not recommended. Specifically, adjust canonical_camera_extrinsics within _default_source_camera. To find the canonical_camera_extrinsics for the desired input image, follow these steps:
    1. Use a front view image as the input to generate a video result.
    2. Check render_camera_extrinsics inside _default_render_cameras along with the rendered video results.
    3. Identify the view that closely matches the desired input image (in viewing angles).
    4. Replace values of canonical_camera_extrinsics with the corresponding render_camera_extrinsics.
    5. Run the inference code again with your desired input view.

Acknowledgement

  • This inference code of VFusion3D heavily borrows from OpenLRM.

Citation

If you find this work useful, please cite us:

@article{han2024vfusion3d,
  title={VFusion3D: Learning Scalable 3D Generative Models from Video Diffusion Models},
  author={Junlin Han and Filippos Kokkinos and Philip Torr},
  journal={European Conference on Computer Vision (ECCV)},
  year={2024}
}

License

  • The majority of VFusion3D is licensed under CC-BY-NC, however portions of the project are available under separate license terms: OpenLRM as a whole is licensed under the Apache License, Version 2.0, while certain components are covered by NVIDIA's proprietary license.
  • The model weights of VFusion3D are also licensed under CC-BY-NC.