import copy import os import random os.system('pip install dashscope') import gradio as gr import dashscope from dashscope import VideoSynthesis from examples import t2v_examples, i2v_examples import time DASHSCOPE_API_KEY = os.getenv('DASHSCOPE_API_KEY') dashscope.api_key = DASHSCOPE_API_KEY KEEP_SUCCESS_TASK = 3600 * 10 KEEP_RUNING_TASK = 3600 * 1 # the total running task number in 1800 seconds LIMIT_RUNING_TASK = 2 LIMIT_HISTORY_RUNING_TASK = 4 FRESH_TIME = None task_status = {} total_task_info = { "total_process_cost": 0, "total_complete_task": 0, "total_submit": 0, "latest_1h_submit_status": { } } def get_submit_code(): submit_code = random.randint(0, 2147483647) # for sub_c, sub_info in copy.deepcopy(total_task_info["latest_1h_submit_status"]).items(): if time.time() - sub_info > 3600: total_task_info["latest_1h_submit_status"].pop(sub_c) return submit_code def t2v_generation(prompt, resolution, watermark_wan, seed=-1): seed = seed if seed >= 0 else random.randint(0, 2147483647) total_task_info["latest_1h_submit_status"][get_submit_code()] = time.time() total_task_info["total_submit"] += 1 if not allow_task_num(): gr.Info(f"Warning: The number of running tasks is too large, the estimate waiting time is {get_waiting_time('-1')} s.") return None, gr.Button(visible=True) try: rsp = VideoSynthesis.call(model="wanx2.1-t2v-plus", prompt=prompt, seed=seed, watermark_wanx=watermark_wan, size=resolution) video_url = rsp.output.video_url return video_url, gr.Button(visible=True) except Exception as e: gr.Warning(f"Warning: {e}") return None, gr.Button(visible=True) def t2v_generation_async(prompt, size, watermark_wan, seed=-1): print(seed) seed = seed if seed >= 0 else random.randint(0, 2147483647) total_task_info["latest_1h_submit_status"][get_submit_code()] = time.time() total_task_info["total_submit"] += 1 print(seed) if not allow_task_num(): gr.Info(f"Warning: The number of running tasks is too large, the estimate waiting time is {get_waiting_time('-1')} s.") return None, False, gr.Button(visible=True), gr.Button(visible=False), gr.Slider(), gr.Slider() try: rsp = VideoSynthesis.async_call(model="wanx2.1-t2v-plus", prompt=prompt, size=size, seed=seed, watermark_wanx=watermark_wan) task_id = rsp.output.task_id status = False return task_id, status, gr.Button(visible=False), gr.Button(visible=True), get_cost_time(task_id), get_waiting_time(task_id) except Exception as e: gr.Warning(f"Warning: {e}") return None, True, gr.Button(), gr.Button(), gr.Slider(), gr.Slider() def i2v_generation(prompt, image, watermark_wan, seed=-1): seed = seed if seed >= 0 else random.randint(0, 2147483647) video_url = None try: rsp = VideoSynthesis.call(model="wanx2.1-i2v-plus", prompt=prompt, img_url=image, seed=seed, watermark_wanx=watermark_wan ) video_url = rsp.output.video_url except Exception as e: gr.Warning(f"Warning: {e}") return video_url def i2v_generation_async(prompt, image, watermark_wan, seed=-1): seed = seed if seed >= 0 else random.randint(0, 2147483647) total_task_info["latest_1h_submit_status"][get_submit_code()] = time.time() total_task_info["total_submit"] += 1 if not allow_task_num(): gr.Info(f"Warning: The number of running tasks is too large, the estimate waiting time is {get_waiting_time('-1')} s.") return "", None, gr.Button(visible=True), gr.Button(visible=False), gr.Slider(), gr.Slider() try: rsp = VideoSynthesis.async_call(model="wanx2.1-i2v-plus", prompt=prompt, seed=seed, img_url=image, watermark_wanx=watermark_wan) print(rsp) task_id = rsp.output.task_id status = False return task_id, status, gr.Button(visible=False), gr.Button(visible=True), get_cost_time(task_id), get_waiting_time(task_id) except Exception as e: gr.Warning(f"Warning: {e}") return "", None, gr.Button(), gr.Button(), gr.Slider(), gr.Slider() def get_result_with_task_id(task_id): if task_id == "": return True, None try: rsp = VideoSynthesis.fetch(task=task_id) print(rsp) if rsp.output.task_status == "FAILED": gr.Info(f"Warning: task running {rsp.output.task_status}") status = True video_url = None else: video_url = rsp.output.video_url video_url = video_url if video_url != "" else None status = video_url is not None if status: total_task_info["total_complete_task"] += 1 total_task_info["total_process_cost"] += time.time() - task_status[task_id]["time"] print(total_task_info["total_complete_task"], total_task_info["total_process_cost"]) except: video_url = None status = False return status, None if video_url == "" else video_url # return True, "https://dashscope-result-wlcb.oss-cn-wulanchabu.aliyuncs.com/1d/f8/20250220/e7d3f375/ccc590a2-7e90-4d92-84bc-22668db42979.mp4?Expires=1740137152&OSSAccessKeyId=LTAI5tQZd8AEcZX6KZV4G8qL&Signature=i3S3jA5FY6XYfvzZNHnvQiPzZSw%3D" def allow_task_num(): num = 0 total_num = 0 for task_id in task_status: if not task_status[task_id]["status"] and task_status[task_id]["time"] + 1800 > time.time(): num += 1 if not task_status[task_id]["status"]: total_num += 1 return num < LIMIT_RUNING_TASK or total_num < LIMIT_HISTORY_RUNING_TASK def get_waiting_time(task_id): # if the num of running task < Limit # waiting time = num * 480s # task_id not in task_status, return a large number # prediction the waiting time # avg_cost * latest submit time num = 0 for task_id in task_status: if not task_status[task_id]["status"]: num += 1 latest_submit_tasks = len(total_task_info["latest_1h_submit_status"]) print("latest submit tasks", latest_submit_tasks) if task_id in task_status: return int(640 - (time.time() - task_status[task_id]["time"])) else: return int(latest_submit_tasks * (total_task_info["total_process_cost"]/(total_task_info["total_complete_task"]+1))) def online_get_waiting_time(task, t2v_task_id, i2v_task_id): task_id = t2v_task_id if task == "t2v" else i2v_task_id return get_waiting_time(task_id) def clean_task_status(): # clean the task over 1800 seconds for task_id in copy.deepcopy(task_status): if task_id == "": continue # finished task, keep 3600 seconds if task_status[task_id]["status"]: if task_status[task_id]["time"] + KEEP_SUCCESS_TASK < time.time(): task_status.pop(task_id) else: # clean the task over 3600 * 2 seconds if task_status[task_id]["time"] + KEEP_RUNING_TASK < time.time(): task_status.pop(task_id) def get_cost_time(task_id): if task_id in task_status and not task_status[task_id]["status"]: et = int(time.time() - task_status[task_id]["time"]) return f"{et:.2f}" else: return gr.Textbox() def online_get_cost_time(task, t2v_task_id, i2v_task_id): task_id = t2v_task_id if task == "t2v" else i2v_task_id return get_cost_time(task_id) def get_process_bar(task, t2v_task_id, i2v_task_id, status): task_id = t2v_task_id if task == "t2v" else i2v_task_id clean_task_status() if task_id not in task_status: task_status[task_id] = { "value": 0 if not task_id == "" else 100, "status": status if not task_id == "" else True, "time": time.time(), "url": None } if not task_status[task_id]["status"]: # only when > 50% do check status if task_status[task_id]["value"] >= 5 and task_status[task_id]["value"] % 5 == 0: status, video_url = get_result_with_task_id(task_id) else: status, video_url = False, None task_status[task_id]["status"] = status task_status[task_id]["url"] = video_url if task_status[task_id]["status"]: task_status[task_id]["value"] = 100 else: task_status[task_id]["value"] += 5 if task_status[task_id]["value"] >= 100 and not task_status[task_id]["status"]: task_status[task_id]["value"] = 95 # print(task_id, task_status[task_id], task_status) value = task_status[task_id]["value"] return gr.Slider(label=f"({value}%)Generating" if value % 2 == 1 else f"({value}%)Generating.....", value=value) with gr.Blocks() as demo: gr.HTML("""