kadirnar commited on
Commit
69acc93
·
verified ·
1 Parent(s): ca7ce2f

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +121 -69
app.py CHANGED
@@ -1,71 +1,123 @@
1
- from typing import List
2
- from setuptools import find_packages, setup
3
  import subprocess
 
 
 
 
4
 
5
- def fetch_requirements(path) -> List[str]:
6
- """
7
- This function reads the requirements file.
8
-
9
- Args:
10
- path (str): the path to the requirements file.
11
-
12
- Returns:
13
- The lines in the requirements file.
14
- """
15
- with open(path, "r") as fd:
16
- return [r.strip() for r in fd.readlines()]
17
-
18
- def fetch_readme() -> str:
19
- """
20
- This function reads the README.md file in the current directory.
21
-
22
- Returns:
23
- The lines in the README file.
24
- """
25
- with open("README.md", encoding="utf-8") as f:
26
- return f.read()
27
-
28
- setup(
29
- name="opensora",
30
- version="1.0.0",
31
- packages=find_packages(
32
- exclude=(
33
- "assets",
34
- "configs",
35
- "docs",
36
- "outputs",
37
- "pretrained_models",
38
- "scripts",
39
- "tests",
40
- "tools",
41
- "*.egg-info",
42
- )
43
- ),
44
- description="Democratizing Efficient Video Production for All",
45
- long_description=fetch_readme(),
46
- long_description_content_type="text/markdown",
47
- license="Apache Software License 2.0",
48
- install_requires=fetch_requirements("requirements.txt"),
49
- python_requires=">=3.6",
50
- classifiers=[
51
- "Programming Language :: Python :: 3",
52
- "License :: OSI Approved :: Apache Software License",
53
- "Environment :: GPU :: NVIDIA CUDA",
54
- "Topic :: Scientific/Engineering :: Artificial Intelligence",
55
- "Topic :: System :: Distributed Computing",
56
- ],
57
- )
58
-
59
- install_options = [
60
- "--disable-pip-version-check",
61
- "--no-cache-dir",
62
- "--no-build-isolation",
63
- "--config-settings", "--build-option=--cpp_ext",
64
- "--config-settings", "--build-option=--cuda_ext"
65
- ]
66
-
67
- subprocess.run(
68
- ["pip", "install", "-v"] + install_options + ["git+https://github.com/kadirnar/apex.git"],
69
- check=True,
70
- capture_output=True
71
- )
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import gradio as gr
2
+ from huggingface_hub import hf_hub_download
3
  import subprocess
4
+ import tempfile
5
+ import shutil
6
+ import os
7
+ import spaces
8
 
9
+ from transformers import T5ForConditionalGeneration, T5Tokenizer
10
+ import os
11
+
12
+ subprocess.run('pip install flash-attn --no-build-isolation', env={'FLASH_ATTENTION_SKIP_CUDA_BUILD': "TRUE"}, shell=True)
13
+
14
+
15
+ def install_apex():
16
+ # Install Apex in editable mode from the specified GitHub repository
17
+ cmd = [
18
+ 'pip', 'install', '--no-cache-dir', '--no-build-isolation',
19
+ '--config-settings', 'build-option=--cpp_ext', '--config-settings',
20
+ 'build-option=--cuda_ext', '-e', 'git+https://github.com/NVIDIA/apex.git'
21
+ ]
22
+ subprocess.run(cmd, check=True)
23
+
24
+ try:
25
+ import apex
26
+ except ModuleNotFoundError:
27
+ print("Apex not found, installing...")
28
+ install_apex()
29
+ # Try to import Apex again after installation
30
+ import apex
31
+
32
+
33
+ def download_t5_model(model_id, save_directory):
34
+ # Modelin tokenizer'ını ve modeli indir
35
+ model = T5ForConditionalGeneration.from_pretrained(model_id)
36
+ tokenizer = T5Tokenizer.from_pretrained(model_id)
37
+
38
+ # Model ve tokenizer'ı belirtilen dizine kaydet
39
+ if not os.path.exists(save_directory):
40
+ os.makedirs(save_directory)
41
+ model.save_pretrained(save_directory)
42
+ tokenizer.save_pretrained(save_directory)
43
+
44
+ # Model ID ve kaydedilecek dizin
45
+ model_id = "DeepFloyd/t5-v1_1-xxl"
46
+ save_directory = "pretrained_models/t5_ckpts/t5-v1_1-xxl"
47
+
48
+ # Modeli indir
49
+ download_t5_model(model_id, save_directory)
50
+
51
+ def download_model(repo_id, model_name):
52
+ model_path = hf_hub_download(repo_id=repo_id, filename=model_name)
53
+ return model_path
54
+
55
+ import glob
56
+
57
+ @spaces.GPU
58
+ def run_inference(model_name, prompt_text):
59
+ repo_id = "hpcai-tech/Open-Sora"
60
+
61
+ # Map model names to their respective configuration files
62
+ config_mapping = {
63
+ "OpenSora-v1-16x256x256.pth": "configs/opensora/inference/16x256x256.py",
64
+ "OpenSora-v1-HQ-16x256x256.pth": "configs/opensora/inference/16x512x512.py",
65
+ "OpenSora-v1-HQ-16x512x512.pth": "configs/opensora/inference/64x512x512.py"
66
+ }
67
+
68
+ config_path = config_mapping[model_name]
69
+ ckpt_path = download_model(repo_id, model_name)
70
+
71
+ # Save prompt_text to a temporary text file
72
+ prompt_file = tempfile.NamedTemporaryFile(delete=False, suffix=".txt", mode='w')
73
+ prompt_file.write(prompt_text)
74
+ prompt_file.close()
75
+
76
+ with open(config_path, 'r') as file:
77
+ config_content = file.read()
78
+ config_content = config_content.replace('prompt_path = "./assets/texts/t2v_samples.txt"', f'prompt_path = "{prompt_file.name}"')
79
+
80
+ with tempfile.NamedTemporaryFile('w', delete=False, suffix='.py') as temp_file:
81
+ temp_file.write(config_content)
82
+ temp_config_path = temp_file.name
83
+
84
+ cmd = [
85
+ "torchrun", "--standalone", "--nproc_per_node", "1",
86
+ "scripts/inference.py", temp_config_path,
87
+ "--ckpt-path", ckpt_path
88
+ ]
89
+ subprocess.run(cmd)
90
+
91
+ save_dir = "./outputs/samples/" # Örneğin, inference.py tarafından kullanılan kayıt dizini
92
+ list_of_files = glob.glob(f'{save_dir}/*')
93
+ if list_of_files:
94
+ latest_file = max(list_of_files, key=os.path.getctime)
95
+ return latest_file
96
+ else:
97
+ print("No files found in the output directory.")
98
+ return None
99
+
100
+ # Clean up the temporary files
101
+ os.remove(temp_file.name)
102
+ os.remove(prompt_file.name)
103
+
104
+ def main():
105
+ gr.Interface(
106
+ fn=run_inference,
107
+ inputs=[
108
+ gr.Dropdown(choices=[
109
+ "OpenSora-v1-16x256x256.pth",
110
+ "OpenSora-v1-HQ-16x256x256.pth",
111
+ "OpenSora-v1-HQ-16x512x512.pth"
112
+ ],
113
+ value="OpenSora-v1-16x256x256.pth",
114
+ label="Model Selection"),
115
+ gr.Textbox(label="Prompt Text", value="Enter prompt text here")
116
+ ],
117
+ outputs=gr.Video(label="Output Video"),
118
+ title="Open-Sora Inference",
119
+ description="Run Open-Sora Inference with Custom Parameters",
120
+ ).launch()
121
+
122
+ if __name__ == "__main__":
123
+ main()