Spaces:
Paused
Paused
File size: 1,282 Bytes
ed9eba5 822805e ed9eba5 822805e b179afc | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 | import torch
import gradio as gr
from PIL import Image
from diffusers import WanImageToVideoPipeline
from diffusers.utils import export_to_video
MODEL_ID = "TestOrganizationPleaseIgnore/WAMU-Merge-VisualEffects_WAN2.2_I2V_LIGHTNING"
pipe = None
def generate(image, prompt):
global pipe
if pipe is None:
pipe = WanImageToVideoPipeline.from_pretrained(
MODEL_ID,
torch_dtype=torch.float16
).to("cuda" if torch.cuda.is_available() else "cpu")
result = pipe(
image=image,
prompt=prompt or "",
num_frames=24
)
video_path = export_to_video(result.frames)
# unload model to free VRAM (cost safety)
del pipe
pipe = None
torch.cuda.empty_cache()
return video_path
with gr.Blocks() as demo:
gr.Markdown("# WAN Image → Video (Private Safe Mode)")
img = gr.Image(type="pil")
prompt = gr.Textbox(label="Prompt")
out = gr.Video()
btn = gr.Button("Generate")
btn.click(generate, [img, prompt], out)
import os
USERNAME = os.getenv("GRADIO_USERNAME")
PASSWORD = os.getenv("GRADIO_PASSWORD")
auth = (USERNAME, PASSWORD) if USERNAME and PASSWORD else None
demo.launch(
server_name="0.0.0.0",
server_port=7860,
ssr_mode=False,
auth=auth
) |