lths commited on
Commit
2686577
·
verified ·
1 Parent(s): 7c8937f

Upload app.py

Browse files
Files changed (1) hide show
  1. app.py +18 -25
app.py CHANGED
@@ -1,39 +1,32 @@
1
  # app.py
2
  import os, sys
3
- os.environ.setdefault("HF_HUB_ENABLE_HF_TRANSFER", "1") # 更快的下载
4
  import gradio as gr
5
  import torch
6
 
 
7
  MODEL_REPO = "vibevoice/VibeVoice-1.5B"
8
 
9
- demo = None
10
  model_ready = False
11
 
12
- def ensure_loaded():
13
- global demo, model_ready
14
- if model_ready:
15
- return
16
- # 只有第一次真正用到时才加载(避免冷启动卡住健康检查)
17
- from demo.gradio_demo import VibeVoiceDemo # 延迟导入
18
- device = "cuda" if torch.cuda.is_available() else "cpu"
19
- # 你的 gradio_demo.py 里如何传参就怎么来,这里举例:
20
- demo = VibeVoiceDemo(model_path=MODEL_REPO, device=device) # 内部会 .load_model()
21
- model_ready = True
22
 
23
- def warmup():
24
- ensure_loaded()
25
- return "✅ Model is loaded and ready."
26
 
27
- def ui():
28
- # 你原本的 UI 如果在 gradio_demo.py 里已有 main(),也可以直接 import 后调用。
29
- # 这里放一个简单门面,点击后再加载再转到真正的 demo
30
- with gr.Blocks() as app:
31
- gr.Markdown("## VibeVoice Demo — click below to start (lazy load)")
32
- btn = gr.Button("Start / Load model")
33
- out = gr.Textbox(label="Status")
34
- btn.click(fn=warmup, outputs=out)
35
- return app
36
 
37
  if __name__ == "__main__":
38
- app = ui()
39
  app.queue().launch(server_name="0.0.0.0", server_port=7860)
 
1
  # app.py
2
  import os, sys
 
3
  import gradio as gr
4
  import torch
5
 
6
+ os.environ.setdefault("HF_HUB_ENABLE_HF_TRANSFER", "1")
7
  MODEL_REPO = "vibevoice/VibeVoice-1.5B"
8
 
9
+ demo_app = None
10
  model_ready = False
11
 
12
+ def load_real_demo():
13
+ global demo_app, model_ready
14
+ if not model_ready:
15
+ from demo import gradio_demo
16
+ # 假设 gradio_demo.py 里有 main(return_app=True) 可以返回一个 Blocks
17
+ demo_app = gradio_demo.main(model_path=MODEL_REPO, return_app=True)
18
+ model_ready = True
19
+ return demo_app
 
 
20
 
21
+ def launch_wrapper():
22
+ load_real_demo()
23
+ return demo_app
24
 
25
+ with gr.Blocks() as app:
26
+ gr.Markdown("## 🎙️ VibeVoice Demo (lazy-load)")
27
+ btn = gr.Button("🚀 Load full demo")
28
+ out = gr.HTML()
29
+ btn.click(fn=lambda: "<b>Reload page to see full demo</b>", outputs=out)
 
 
 
 
30
 
31
  if __name__ == "__main__":
 
32
  app.queue().launch(server_name="0.0.0.0", server_port=7860)