Arifzyn mrfakename commited on
Commit
7656414
·
0 Parent(s):

Duplicate from cvsys/upscale

Browse files

Co-authored-by: mrfakename <mrfakename@users.noreply.huggingface.co>

Files changed (5) hide show
  1. .gitattributes +35 -0
  2. README.md +14 -0
  3. app.py +127 -0
  4. no_vid.mp4 +0 -0
  5. requirements.txt +4 -0
.gitattributes ADDED
@@ -0,0 +1,35 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ *.7z filter=lfs diff=lfs merge=lfs -text
2
+ *.arrow filter=lfs diff=lfs merge=lfs -text
3
+ *.bin filter=lfs diff=lfs merge=lfs -text
4
+ *.bz2 filter=lfs diff=lfs merge=lfs -text
5
+ *.ckpt filter=lfs diff=lfs merge=lfs -text
6
+ *.ftz filter=lfs diff=lfs merge=lfs -text
7
+ *.gz filter=lfs diff=lfs merge=lfs -text
8
+ *.h5 filter=lfs diff=lfs merge=lfs -text
9
+ *.joblib filter=lfs diff=lfs merge=lfs -text
10
+ *.lfs.* filter=lfs diff=lfs merge=lfs -text
11
+ *.mlmodel filter=lfs diff=lfs merge=lfs -text
12
+ *.model filter=lfs diff=lfs merge=lfs -text
13
+ *.msgpack filter=lfs diff=lfs merge=lfs -text
14
+ *.npy filter=lfs diff=lfs merge=lfs -text
15
+ *.npz filter=lfs diff=lfs merge=lfs -text
16
+ *.onnx filter=lfs diff=lfs merge=lfs -text
17
+ *.ot filter=lfs diff=lfs merge=lfs -text
18
+ *.parquet filter=lfs diff=lfs merge=lfs -text
19
+ *.pb filter=lfs diff=lfs merge=lfs -text
20
+ *.pickle filter=lfs diff=lfs merge=lfs -text
21
+ *.pkl filter=lfs diff=lfs merge=lfs -text
22
+ *.pt filter=lfs diff=lfs merge=lfs -text
23
+ *.pth filter=lfs diff=lfs merge=lfs -text
24
+ *.rar filter=lfs diff=lfs merge=lfs -text
25
+ *.safetensors filter=lfs diff=lfs merge=lfs -text
26
+ saved_model/**/* filter=lfs diff=lfs merge=lfs -text
27
+ *.tar.* filter=lfs diff=lfs merge=lfs -text
28
+ *.tar filter=lfs diff=lfs merge=lfs -text
29
+ *.tflite filter=lfs diff=lfs merge=lfs -text
30
+ *.tgz filter=lfs diff=lfs merge=lfs -text
31
+ *.wasm filter=lfs diff=lfs merge=lfs -text
32
+ *.xz filter=lfs diff=lfs merge=lfs -text
33
+ *.zip filter=lfs diff=lfs merge=lfs -text
34
+ *.zst filter=lfs diff=lfs merge=lfs -text
35
+ *tfevents* filter=lfs diff=lfs merge=lfs -text
README.md ADDED
@@ -0,0 +1,14 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ ---
2
+ title: UPSCALE
3
+ emoji: 📷
4
+ colorFrom: blue
5
+ colorTo: pink
6
+ sdk: gradio
7
+ sdk_version: 3.35.2
8
+ app_file: app.py
9
+ pinned: false
10
+ license: apache-2.0
11
+ duplicated_from: cvsys/upscale
12
+ ---
13
+
14
+ Check out the configuration reference at https://huggingface.co/docs/hub/spaces-config-reference
app.py ADDED
@@ -0,0 +1,127 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ from sldl.video import VideoSR
2
+ from sldl.image import ImageSR
3
+
4
+ import gradio as gr
5
+ import tempfile
6
+ import shutil
7
+ import torch
8
+ import ffmpeg
9
+ import time
10
+ from PIL import Image
11
+
12
+ cc = 2
13
+ if torch.backends.mps.is_available():
14
+ device = 'mps'
15
+ cc = 5
16
+ elif torch.cuda.is_available():
17
+ device = 'cuda'
18
+ cc = 10
19
+ else:
20
+ device = 'cpu'
21
+
22
+ vbsrgan = VideoSR('BSRGAN').to(device)
23
+ vresrgan = VideoSR('RealESRGAN').to(device)
24
+ ibsrgan = ImageSR('BSRGAN').to(device)
25
+ iresrgan = ImageSR('RealESRGAN').to(device)
26
+
27
+ def upscale_video(input_video, output_video, progress, mname):
28
+ modelname = mname.lower()
29
+ model = vbsrgan
30
+ if modelname == 'bsrgan (default)':
31
+ # do nothing
32
+ pass
33
+ elif modelname == 'real esrgan':
34
+ model = vresrgan
35
+ model(input_video, output_video, progress.tqdm)
36
+
37
+ def upscale_image(input_image, output_image, mname):
38
+ modelname = mname.lower()
39
+ model = ibsrgan
40
+ if modelname == 'bsrgan (default)':
41
+ # do nothing
42
+ pass
43
+ elif modelname == 'real esrgan':
44
+ model = iresrgan
45
+ shutil.copy(input_image, output_image)
46
+ model(output_image)
47
+
48
+ # Gradio interface
49
+ def video_upscaling_interface(input_text, model_name, progress=gr.Progress()):
50
+ if input_text:
51
+ temp_dir = tempfile.mkdtemp()
52
+ input_video_path = f"{temp_dir}/input_video"
53
+ output_video_path = f"{temp_dir}/output_video.mp4"
54
+ ffmpeg.input(input_text).output(input_video_path + '.mp4').run()
55
+
56
+ # Upscale the video
57
+ upscale_video(input_video_path + '.mp4', output_video_path, progress, model_name)
58
+
59
+ return [output_video_path, output_video_path]
60
+ else:
61
+ return ["no_vid.mp4", "no_vid.mp4"]
62
+
63
+
64
+ def image_upscaling_interface(input_text, model_name):
65
+ if input_text:
66
+ temp_dir = tempfile.mkdtemp()
67
+ input_image_path = f"{temp_dir}/input_image.jpg"
68
+ output_image_path = f"{temp_dir}/output_image.jpg"
69
+ input_text.save(input_image_path)
70
+ upscale_image(input_image_path, output_image_path, model_name)
71
+ return [output_image_path, output_image_path]
72
+ else:
73
+ return ["no_image.jpg", "no_image.jpg"]
74
+
75
+
76
+ css = "footer {display: none !important;} .gradio-container {min-height: 0px !important;}"
77
+
78
+
79
+ with gr.Blocks(css=css) as demo:
80
+ gr.Markdown('''
81
+ # Upscale
82
+ ## A CVSYS Project
83
+
84
+ ### NOTICE: This is running on a free Hugging Face Space, so it will be quite slow. Expect it to take _hours_ to upscale 5 minutes. Please be mindful and _DO NOT_ upscale videos longer than 15 seconds! Thank you!
85
+
86
+ [Check out Upscale on GitHub!](https://github.com/cv-sys/upscale)
87
+
88
+ ## Want Faster Inference?
89
+
90
+ Duplicate this space for faster inference! We recommend using an A10G or A100.
91
+
92
+ <a href="https://huggingface.co/spaces/cvsys/upscale?duplicate=true"><img src="https://img.shields.io/badge/-Duplicate%20Space-blue?labelColor=white&style=flat&logo=&logoWidth=14"></a>
93
+
94
+ Please note that after you upload an image, it may take several minutes before the progress bar appears. This is because we first convert your video to ensure the correct format.
95
+ ''')
96
+ # with gr.Tab("Image"):
97
+ # with gr.Row():
98
+ # with gr.Column():
99
+ # iinp = gr.Image(label="Upload Image", interactive=True, type="pil")
100
+ # imod = gr.Dropdown(
101
+ # ["BSRGAN (Default)", "Real ESRGAN"],
102
+ # value="BSRGAN (Default)",
103
+ # interactive=True,
104
+ # label="Model"
105
+ # )
106
+ # with gr.Column():
107
+ # iout = gr.Image(label="View Image", interactive=False, type="filepath")
108
+ # ifile = gr.File(label="Download Image", interactive=False)
109
+ # ibtn = gr.Button(value="Upscale Image")
110
+ with gr.Tab("Video"):
111
+ with gr.Row():
112
+ with gr.Column():
113
+ vinp = gr.Video(label="Upload Video", interactive=True)
114
+ vmod = gr.Dropdown(
115
+ ["BSRGAN (Default)", "Real ESRGAN"],
116
+ value="BSRGAN (Default)",
117
+ interactive=True,
118
+ label="Model"
119
+ )
120
+ with gr.Column():
121
+ vout = gr.Video(label="Watch Video", interactive=False)
122
+ vfile = gr.File(label="Download Video", interactive=False)
123
+ vbtn = gr.Button(value="Upscale Video")
124
+ # ibtn.click(image_upscaling_interface, [iinp, imod], outputs=[iout, ifile])
125
+ vbtn.click(video_upscaling_interface, [vinp, vmod], outputs=[vout, vfile])
126
+ demo.queue(concurrency_count=cc)
127
+ demo.launch()
no_vid.mp4 ADDED
Binary file (5.33 kB). View file
 
requirements.txt ADDED
@@ -0,0 +1,4 @@
 
 
 
 
 
1
+ gradio
2
+ git+https://github.com/fakerybakery/sldl-gr
3
+ ffmpeg-python
4
+ pillow