Spaces:
Running
on
Zero
Running
on
Zero
pablovela5620
commited on
Commit
·
9ec56ae
1
Parent(s):
20fff88
update app to use new version of mini-dust3r
Browse files- app.py +25 -16
- requirements.txt +1 -1
app.py
CHANGED
@@ -3,40 +3,49 @@ import spaces
|
|
3 |
import torch
|
4 |
from gradio_rerun import Rerun
|
5 |
import rerun as rr
|
|
|
6 |
from pathlib import Path
|
7 |
-
|
8 |
|
9 |
from mini_dust3r.api import OptimizedResult, inferece_dust3r, log_optimized_result
|
10 |
from mini_dust3r.model import AsymmetricCroCo3DStereo
|
11 |
|
12 |
-
DEVICE =
|
13 |
model = AsymmetricCroCo3DStereo.from_pretrained(
|
14 |
-
|
15 |
-
|
|
|
16 |
|
17 |
@spaces.GPU
|
18 |
-
def predict(
|
19 |
-
|
|
|
|
|
|
|
20 |
optimized_results: OptimizedResult = inferece_dust3r(
|
21 |
-
|
22 |
model=model,
|
23 |
device=DEVICE,
|
24 |
batch_size=1,
|
25 |
)
|
26 |
-
|
27 |
-
|
28 |
-
|
|
|
|
|
29 |
|
30 |
-
|
|
|
|
|
|
|
|
|
31 |
# scene state is save so that you can change conf_thr, cam_size... without rerunning the inference
|
32 |
-
gr.HTML('<h2 style="text-align: center;">DUSt3R Demo</h2>')
|
33 |
with gr.Column():
|
34 |
inputfiles = gr.File(file_count="multiple")
|
35 |
rerun_viewer = Rerun(height=900)
|
36 |
|
37 |
run_btn = gr.Button("Run")
|
38 |
-
run_btn.click(fn=predict,
|
39 |
-
|
40 |
-
outputs=[rerun_viewer])
|
41 |
-
|
42 |
demo.launch()
|
|
|
3 |
import torch
|
4 |
from gradio_rerun import Rerun
|
5 |
import rerun as rr
|
6 |
+
import rerun.blueprint as rrb
|
7 |
from pathlib import Path
|
8 |
+
import uuid
|
9 |
|
10 |
from mini_dust3r.api import OptimizedResult, inferece_dust3r, log_optimized_result
|
11 |
from mini_dust3r.model import AsymmetricCroCo3DStereo
|
12 |
|
13 |
+
DEVICE = "cuda" if torch.cuda.is_available() else "cpu"
|
14 |
model = AsymmetricCroCo3DStereo.from_pretrained(
|
15 |
+
"naver/DUSt3R_ViTLarge_BaseDecoder_512_dpt"
|
16 |
+
).to(DEVICE)
|
17 |
+
|
18 |
|
19 |
@spaces.GPU
|
20 |
+
def predict(image_name_list: list[str]):
|
21 |
+
uuid_str = str(uuid.uuid4())
|
22 |
+
filename = Path(f"/tmp/gradio/{uuid_str}.rrd")
|
23 |
+
rr.init(f"{uuid_str}")
|
24 |
+
log_path = Path("world")
|
25 |
optimized_results: OptimizedResult = inferece_dust3r(
|
26 |
+
image_dir_or_list=image_name_list,
|
27 |
model=model,
|
28 |
device=DEVICE,
|
29 |
batch_size=1,
|
30 |
)
|
31 |
+
rr.set_time_sequence("sequence", 0)
|
32 |
+
log_optimized_result(optimized_results, log_path)
|
33 |
+
# blueprint = rrb.Spatial3DView(origin="cube")
|
34 |
+
rr.save(filename.as_posix())
|
35 |
+
return filename.as_posix()
|
36 |
|
37 |
+
|
38 |
+
with gr.Blocks(
|
39 |
+
css=""".gradio-container {margin: 0 !important; min-width: 100%};""",
|
40 |
+
title="Mini-DUSt3R Demo",
|
41 |
+
) as demo:
|
42 |
# scene state is save so that you can change conf_thr, cam_size... without rerunning the inference
|
43 |
+
gr.HTML('<h2 style="text-align: center;">Mini-DUSt3R Demo</h2>')
|
44 |
with gr.Column():
|
45 |
inputfiles = gr.File(file_count="multiple")
|
46 |
rerun_viewer = Rerun(height=900)
|
47 |
|
48 |
run_btn = gr.Button("Run")
|
49 |
+
run_btn.click(fn=predict, inputs=[inputfiles], outputs=[rerun_viewer])
|
50 |
+
|
|
|
|
|
51 |
demo.launch()
|
requirements.txt
CHANGED
@@ -1 +1 @@
|
|
1 |
-
mini-dust3r==0.1.
|
|
|
1 |
+
mini-dust3r==0.1.1
|