Spaces:
Runtime error
Runtime error
Chao Xu
commited on
Commit
β’
f79ddf6
1
Parent(s):
3c4eaa2
Update README and release inference code
Browse files- README.md +23 -4
- app.py +8 -10
- pre-requirements.txt +0 -67
- requirements.txt +62 -1
README.md
CHANGED
@@ -4,7 +4,7 @@ emoji: πΈππ
|
|
4 |
colorFrom: red
|
5 |
colorTo: yellow
|
6 |
sdk: gradio
|
7 |
-
sdk_version: 3.40.
|
8 |
app_file: app.py
|
9 |
pinned: true
|
10 |
license: mit
|
@@ -12,10 +12,29 @@ license: mit
|
|
12 |
|
13 |
# One-2-3-45: Any Single Image to 3D Mesh in 45 Seconds without Per-Shape Optimization
|
14 |
|
15 |
-
|
16 |
-
|
|
|
|
|
|
|
17 |
|
18 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
19 |
|
20 |
```bibtex
|
21 |
@misc{liu2023one2345,
|
|
|
4 |
colorFrom: red
|
5 |
colorTo: yellow
|
6 |
sdk: gradio
|
7 |
+
sdk_version: 3.40.1
|
8 |
app_file: app.py
|
9 |
pinned: true
|
10 |
license: mit
|
|
|
12 |
|
13 |
# One-2-3-45: Any Single Image to 3D Mesh in 45 Seconds without Per-Shape Optimization
|
14 |
|
15 |
+
<div>
|
16 |
+
<a style="display:inline-block" href="http://one-2-3-45.com"><img src="https://img.shields.io/badge/Project_Homepage-f9f7f7?logo="></a>
|
17 |
+
<a style="display:inline-block; margin-left: .5em" href="https://arxiv.org/abs/2306.16928"><img src="https://img.shields.io/badge/2306.16928-f9f7f7?logo="></a>
|
18 |
+
<a style="display:inline-block; margin-left: .5em" href='https://github.com/One-2-3-45/One-2-3-45'><img src='https://img.shields.io/github/stars/One-2-3-45/One-2-3-45?style=social' /></a>
|
19 |
+
</div>
|
20 |
|
21 |
+
|
22 |
+
This space hosts the demo for [One-2-3-45](http://One-2-3-45.com), powered by the [inference model](https://huggingface.co/One-2-3-45/code).
|
23 |
+
|
24 |
+
Please refer to our [GitHub repo](https://github.com/One-2-3-45/One-2-3-45) for full code release.
|
25 |
+
|
26 |
+
## Local Deployment of the Demo
|
27 |
+
```bash
|
28 |
+
# Minimum GPU: NVIDIA A10 or RTX 3090
|
29 |
+
# 1. Install the requirements
|
30 |
+
sudo apt-get install libsparsehash-dev
|
31 |
+
pip install -r requirements.txt
|
32 |
+
|
33 |
+
# 2. Run the demo
|
34 |
+
python app.py
|
35 |
+
```
|
36 |
+
|
37 |
+
## Citation
|
38 |
|
39 |
```bibtex
|
40 |
@misc{liu2023one2345,
|
app.py
CHANGED
@@ -3,26 +3,25 @@ from huggingface_hub import snapshot_download
|
|
3 |
|
4 |
is_local_run = False
|
5 |
|
6 |
-
code_dir = snapshot_download("One-2-3-45/code"
|
7 |
|
8 |
sys.path.append(code_dir)
|
9 |
|
10 |
-
elev_est_dir = os.path.join(code_dir, "one2345_elev_est
|
11 |
sys.path.append(elev_est_dir)
|
12 |
|
13 |
if not is_local_run:
|
14 |
-
import
|
15 |
-
|
16 |
# export TORCH_CUDA_ARCH_LIST="7.0;7.2;8.0;8.6"
|
17 |
# export IABN_FORCE_CUDA=1
|
18 |
os.environ["TORCH_CUDA_ARCH_LIST"] = "8.0;8.6"
|
19 |
os.environ["IABN_FORCE_CUDA"] = "1"
|
20 |
os.environ["FORCE_CUDA"] = "1"
|
21 |
-
|
22 |
# FORCE_CUDA=1 pip install --no-cache-dir git+https://github.com/mit-han-lab/torchsparse.git@v1.4.0
|
23 |
-
|
24 |
|
25 |
-
import inspect
|
26 |
import shutil
|
27 |
import torch
|
28 |
import fire
|
@@ -61,7 +60,7 @@ _BBOX_2 = "Bounding box adjusted. Continue adjusting or **Run Generation**."
|
|
61 |
_BBOX_3 = "Bounding box predicted. Adjust it using sliders or **Run Generation**."
|
62 |
_SAM = "Preprocessing the input image... (safety check, SAM segmentation, *etc*.)"
|
63 |
_GEN_1 = "Predicting multi-view images... (may take \~13 seconds) <br> Images will be shown in the bottom right blocks."
|
64 |
-
_GEN_2 = "Predicting nearby views and generating mesh... (may take \~
|
65 |
_DONE = "Done! Mesh is shown on the right. <br> If it is not satisfactory, please select **Retry view** checkboxes for inaccurate views and click **Regenerate selected view(s)** at the bottom."
|
66 |
_REGEN_1 = "Selected view(s) are regenerated. You can click **Regenerate nearby views and mesh**. <br> Alternatively, if the regenerated view(s) are still not satisfactory, you can repeat the previous step (select the view and regenerate)."
|
67 |
_REGEN_2 = "Regeneration done. Mesh is shown on the right."
|
@@ -361,8 +360,7 @@ def stage2_run(models, device, tmp_dir,
|
|
361 |
zero123_infer(model, tmp_dir, indices=rerun_all, device=device, ddim_steps=stage2_steps, scale=scale)
|
362 |
|
363 |
dataset = tmp_dir
|
364 |
-
main_dir_path = os.path.dirname(
|
365 |
-
inspect.getfile(inspect.currentframe())))
|
366 |
torch.cuda.empty_cache()
|
367 |
os.chdir(os.path.join(code_dir, 'SparseNeuS_demo_v1/'))
|
368 |
|
|
|
3 |
|
4 |
is_local_run = False
|
5 |
|
6 |
+
code_dir = snapshot_download("One-2-3-45/code") if not is_local_run else "../code" # , token=os.environ['TOKEN']
|
7 |
|
8 |
sys.path.append(code_dir)
|
9 |
|
10 |
+
elev_est_dir = os.path.abspath(os.path.join(code_dir, "one2345_elev_est"))
|
11 |
sys.path.append(elev_est_dir)
|
12 |
|
13 |
if not is_local_run:
|
14 |
+
import pip
|
15 |
+
pip.main(['install', elev_est_dir])
|
16 |
# export TORCH_CUDA_ARCH_LIST="7.0;7.2;8.0;8.6"
|
17 |
# export IABN_FORCE_CUDA=1
|
18 |
os.environ["TORCH_CUDA_ARCH_LIST"] = "8.0;8.6"
|
19 |
os.environ["IABN_FORCE_CUDA"] = "1"
|
20 |
os.environ["FORCE_CUDA"] = "1"
|
21 |
+
pip.main(["install", "inplace_abn"])
|
22 |
# FORCE_CUDA=1 pip install --no-cache-dir git+https://github.com/mit-han-lab/torchsparse.git@v1.4.0
|
23 |
+
pip.main(["install", "--no-cache-dir", "git+https://github.com/mit-han-lab/torchsparse.git@v1.4.0"])
|
24 |
|
|
|
25 |
import shutil
|
26 |
import torch
|
27 |
import fire
|
|
|
60 |
_BBOX_3 = "Bounding box predicted. Adjust it using sliders or **Run Generation**."
|
61 |
_SAM = "Preprocessing the input image... (safety check, SAM segmentation, *etc*.)"
|
62 |
_GEN_1 = "Predicting multi-view images... (may take \~13 seconds) <br> Images will be shown in the bottom right blocks."
|
63 |
+
_GEN_2 = "Predicting nearby views and generating mesh... (may take \~33 seconds) <br> Mesh will be shown on the right."
|
64 |
_DONE = "Done! Mesh is shown on the right. <br> If it is not satisfactory, please select **Retry view** checkboxes for inaccurate views and click **Regenerate selected view(s)** at the bottom."
|
65 |
_REGEN_1 = "Selected view(s) are regenerated. You can click **Regenerate nearby views and mesh**. <br> Alternatively, if the regenerated view(s) are still not satisfactory, you can repeat the previous step (select the view and regenerate)."
|
66 |
_REGEN_2 = "Regeneration done. Mesh is shown on the right."
|
|
|
360 |
zero123_infer(model, tmp_dir, indices=rerun_all, device=device, ddim_steps=stage2_steps, scale=scale)
|
361 |
|
362 |
dataset = tmp_dir
|
363 |
+
main_dir_path = os.path.dirname(__file__)
|
|
|
364 |
torch.cuda.empty_cache()
|
365 |
os.chdir(os.path.join(code_dir, 'SparseNeuS_demo_v1/'))
|
366 |
|
pre-requirements.txt
DELETED
@@ -1,67 +0,0 @@
|
|
1 |
-
--extra-index-url https://download.pytorch.org/whl/cu118
|
2 |
-
torch>=2.0.0
|
3 |
-
torchvision>=0.13.1
|
4 |
-
albumentations>=0.4.3
|
5 |
-
opencv-python>=4.5.5.64
|
6 |
-
pudb>=2019.2
|
7 |
-
imageio>=2.9.0
|
8 |
-
imageio-ffmpeg>=0.4.2
|
9 |
-
pytorch-lightning>=1.4.2
|
10 |
-
omegaconf>=2.1.1
|
11 |
-
test-tube>=0.7.5
|
12 |
-
streamlit>=0.73.1
|
13 |
-
einops>=0.3.0
|
14 |
-
torch-fidelity>=0.3.0
|
15 |
-
transformers>=4.22.2
|
16 |
-
kornia>=0.6
|
17 |
-
webdataset>=0.2.5
|
18 |
-
torchmetrics>=0.6.0
|
19 |
-
fire>=0.4.0
|
20 |
-
gradio>=3.21.0
|
21 |
-
diffusers>=0.12.1
|
22 |
-
datasets[vision]>=2.4.0
|
23 |
-
carvekit-colab>=4.1.0
|
24 |
-
rich>=13.3.2
|
25 |
-
plotly>=5.13.1
|
26 |
-
-e git+https://github.com/CompVis/taming-transformers.git#egg=taming-transformers
|
27 |
-
# elev est
|
28 |
-
dl_ext
|
29 |
-
easydict
|
30 |
-
glumpy
|
31 |
-
gym
|
32 |
-
h5py
|
33 |
-
loguru
|
34 |
-
matplotlib
|
35 |
-
# mplib
|
36 |
-
multipledispatch
|
37 |
-
open3d
|
38 |
-
packaging
|
39 |
-
Pillow
|
40 |
-
pycocotools
|
41 |
-
motion-planning
|
42 |
-
pyrender
|
43 |
-
PyYAML
|
44 |
-
scikit_image
|
45 |
-
scikit_learn
|
46 |
-
scipy
|
47 |
-
screeninfo
|
48 |
-
setuptools
|
49 |
-
tensorboardX
|
50 |
-
termcolor
|
51 |
-
tqdm
|
52 |
-
transforms3d
|
53 |
-
trimesh
|
54 |
-
yacs
|
55 |
-
# zarr
|
56 |
-
# sapien
|
57 |
-
pyglet==1.5.27
|
58 |
-
# wis3d
|
59 |
-
gdown
|
60 |
-
git+https://github.com/NVlabs/nvdiffrast.git
|
61 |
-
git+https://github.com/openai/CLIP.git
|
62 |
-
# segment anything
|
63 |
-
onnxruntime
|
64 |
-
onnx
|
65 |
-
git+https://github.com/facebookresearch/segment-anything.git
|
66 |
-
# rembg
|
67 |
-
rembg
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
requirements.txt
CHANGED
@@ -1,6 +1,67 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
# sparseneus
|
2 |
# -e git+https://github.com/mit-han-lab/torchsparse.git@v1.4.0#egg=torchsparse
|
3 |
-
numpy
|
4 |
pyhocon
|
5 |
icecream
|
6 |
PyMCubes
|
|
|
1 |
+
--extra-index-url https://download.pytorch.org/whl/cu118
|
2 |
+
numpy
|
3 |
+
torch>=2.0.0
|
4 |
+
torchvision
|
5 |
+
albumentations>=0.4.3
|
6 |
+
opencv-python>=4.5.5.64
|
7 |
+
pudb>=2019.2
|
8 |
+
imageio>=2.9.0
|
9 |
+
imageio-ffmpeg>=0.4.2
|
10 |
+
pytorch-lightning>=1.4.2
|
11 |
+
omegaconf>=2.1.1
|
12 |
+
test-tube>=0.7.5
|
13 |
+
streamlit>=0.73.1
|
14 |
+
einops>=0.3.0
|
15 |
+
torch-fidelity>=0.3.0
|
16 |
+
transformers>=4.22.2
|
17 |
+
kornia>=0.6
|
18 |
+
webdataset>=0.2.5
|
19 |
+
torchmetrics>=0.6.0
|
20 |
+
fire>=0.4.0
|
21 |
+
gradio>=3.40.1
|
22 |
+
diffusers>=0.12.1
|
23 |
+
datasets[vision]>=2.4.0
|
24 |
+
carvekit-colab>=4.1.0
|
25 |
+
rich>=13.3.2
|
26 |
+
plotly>=5.13.1
|
27 |
+
-e git+https://github.com/CompVis/taming-transformers.git#egg=taming-transformers
|
28 |
+
# elev est
|
29 |
+
dl_ext
|
30 |
+
easydict
|
31 |
+
glumpy
|
32 |
+
gym
|
33 |
+
h5py
|
34 |
+
loguru
|
35 |
+
matplotlib
|
36 |
+
# mplib
|
37 |
+
multipledispatch
|
38 |
+
packaging
|
39 |
+
Pillow
|
40 |
+
pycocotools
|
41 |
+
motion-planning
|
42 |
+
pyrender
|
43 |
+
PyYAML
|
44 |
+
scikit_image
|
45 |
+
scikit_learn
|
46 |
+
scipy
|
47 |
+
screeninfo
|
48 |
+
setuptools
|
49 |
+
tensorboardX
|
50 |
+
tqdm
|
51 |
+
transforms3d
|
52 |
+
trimesh
|
53 |
+
yacs
|
54 |
+
gdown
|
55 |
+
git+https://github.com/NVlabs/nvdiffrast.git
|
56 |
+
git+https://github.com/openai/CLIP.git
|
57 |
+
# segment anything
|
58 |
+
onnxruntime
|
59 |
+
onnx
|
60 |
+
git+https://github.com/facebookresearch/segment-anything.git
|
61 |
+
# rembg
|
62 |
+
rembg
|
63 |
# sparseneus
|
64 |
# -e git+https://github.com/mit-han-lab/torchsparse.git@v1.4.0#egg=torchsparse
|
|
|
65 |
pyhocon
|
66 |
icecream
|
67 |
PyMCubes
|