This is the official codebase for SPAR3D, a state-of-the-art open-source model for fast feedforward 3D mesh reconstruction from a single image using a point cloud conditioning to improve the quality of the reconstruction.
SPAR3D is based on Stable Fast 3D but improves upon the backside of the mesh by conditioning on a point cloud. This point cloud can be generated from an image using our included point cloud denoising model. This point cloud can even be edited easily in external tools or our included gradio demo. With that missing backside details can be fixed. We further improve the prediction quality of materials using novel contributions. We achieve all of this while still maintaining the fast inference speeds.
Ensure your environment is:
- Python >= 3.8 (Depending on PyTorch version >3.9)
- Optional: CUDA has to be available
- Has PyTorch installed according to your platform: https://pytorch.org/get-started/locally/ [Make sure the Pytorch CUDA version matches your system's.]
- Update setuptools by
pip install -U setuptools==69.5.1
- Install wheel by
pip install wheel
Then, install the remaining requirements with pip install -r requirements.txt
.
If remeshing is required, install the additional requirements with pip install -r requirements-remesh.txt
.
For the gradio demo, an additional pip install -r requirements-demo.txt
is required.
Our model is gated at Hugging Face:
- Log in to Hugging Face and request access here.
- Create an access token with read permissions here.
- Run
huggingface-cli login
in the environment and enter the token.
To run SPAR3D with low VRAM mode, set the environment variable SPAR3D_LOW_VRAM=1
. By default, SPAR3D consumes 10.5GB of VRAM. This mode will reduce the VRAM consumption to roughly 7GB but in exchange the model will be slower. The run.py
script also supports the --low-vram-mode
flag.
CPU backend will automatically be used if no GPU is detected in your system. Note that this will be really slow.
If you have a GPU but are facing issues and want to use the CPU backend instead, set the environment variable SPAR3D_USE_CPU=1
to force the CPU backend. The run.py
script also supports the --device=cpu
flag.
python run.py demo_files/examples/fish.png --output-dir output/
This will save the reconstructed 3D model as a GLB file to output/
. You can also specify more than one image path separated by spaces. The default options takes about 6GB VRAM for a single image input.
You may also use --texture-resolution
to specify the resolution in pixels of the output texture and --remesh_option
to specify the remeshing operation (None, Triangle, Quad).
For detailed usage of this script, use python run.py --help
.
python gradio_app.py
Custom nodes and an example workflow are provided for ComfyUI.
To install:
- Clone this repo into
custom_nodes
:
$ cd ComfyUI/custom_nodes
$ git clone https://github.com/Stability-AI/stable-point-aware-3d
- Install dependencies:
$ cd stable-point-aware-3d
$ pip install -r requirements.txt
- Optional for remeshing:
$ pip install -r requirements-remesh.txt
- Restart ComfyUI
-none
: mesh unchanged after generation. No CPU overhead.
-triangle
: verticies and edges are rearranged to form a triangle topography. Implementation is from: "A Remeshing Approach to Multiresolution Modeling" by M. Botsch and L. Kobbelt. CPU overhead expected.
-quad
: verticies and edges are rearanged in quadrilateral topography with a proper quad flow. The quad mesh is split into triangles for export with GLB. Implementation is from "Instant Field-Aligned Meshes" from Jakob et al.. CPU overhead expected.
Additionally the target vertex or face count can be specified. This is not a hard constraint but a rough count the method aims to create. This target is ignored if the remesher is set to none
.
@article{spar3d2024,
title={SPAR3D: Stable Point-Aware Reconstruction of 3D Objects from Single Images},
author={Huang, Zixuan and Boss, Mark and Vasishta, Aaryaman and Rehg, James Matthew and Jampani, Varun},
journal={arXiv preprint},
year={2024}
}