ytkoa commited on
Commit
7ae350f
·
verified ·
1 Parent(s): 910f284

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +71 -71
app.py CHANGED
@@ -1,71 +1,71 @@
1
- import gradio as gr
2
- import QuckDrawGAN as qd
3
- import numpy as np
4
- from PIL import Image
5
-
6
- # Загрузим модель
7
- generator_file = r'pretrained_output/models/generator.pt'
8
- discriminator_file = r'pretrained_output/models/discriminator_fine_tuned.pt'
9
-
10
- # Создаем объект модели
11
- model = qd.Model(generator_file, discriminator_file)
12
-
13
- # Функция для генерации изображения с учетом сида, нормализацией и изменением размера
14
- def generate_image(n_images=16, seed=""):
15
- # Если сид не задан, не передаем его в модель
16
- if seed == "":
17
- seed = None
18
- best_image = model.generate(n_images, seed) # Генерация с учетом сида
19
-
20
- # Нормализация: находим минимум и максимум в изображении
21
- best_image_min = np.min(best_image)
22
- best_image_max = np.max(best_image)
23
-
24
- # Нормализуем изображение, чтобы значения были в диапазоне от 0 до 255
25
- normalized_image = 255 * (best_image - best_image_min) / (best_image_max - best_image_min)
26
-
27
- # Преобразуем изображение в формат, подходящий для отображения
28
- pil_image = Image.fromarray(normalized_image.astype(np.uint8)) # Преобразуем в uint8 для отображения
29
- pil_image = pil_image.resize((256, 256), Image.Resampling.LANCZOS) # Ресайз изображения до 256x256
30
-
31
- return pil_image
32
-
33
- # Создаем интерфейс Gradio с помощью Blocks (для большей гибкости)
34
- with gr.Blocks() as interface:
35
- gr.Markdown("# Генератор изображений с использованием QuckDrawGAN")
36
- gr.Markdown("Этот интерфейс позволяет генерировать изображения с помощью модели QuckDrawGAN. Настройте количество генерируемых изображений и задайте сид для повторяемости.")
37
-
38
- with gr.Row():
39
- # Блок для изображения сверху
40
- generated_image = gr.Image(type="pil", label="Сгенерированное изображение", elem_id="generated_image", scale=2) # Увеличиваем масштаб изображения
41
-
42
- with gr.Row():
43
- # Блок параметров и кнопки
44
- with gr.Column():
45
- seed_input = gr.Textbox(value="", label="Сид (опционально)", interactive=True)
46
- num_images = gr.Slider(minimum=1, maximum=1024, value=16, label="Количество изображений для генерации", interactive=True, step=1)
47
-
48
- # Кнопка генерации изображения справа
49
- generate_button = gr.Button("Сгенерировать")
50
-
51
- # Логика для автогенерации при изменении параметров
52
- seed_input.change(generate_image, inputs=[num_images, seed_input], outputs=generated_image)
53
- num_images.change(generate_image, inputs=[num_images, seed_input], outputs=generated_image)
54
-
55
- # Логика для кнопки генерации
56
- generate_button.click(generate_image, inputs=[num_images, seed_input], outputs=generated_image)
57
-
58
- # Автогенерация при старте
59
- interface.load(generate_image, inputs=[num_images, seed_input], outputs=generated_image)
60
-
61
- # Стилизация блока изображения (увеличение размера блока)
62
- interface.css = """
63
- #generated_image {
64
- width: 400px;
65
- height: 400px;
66
- margin-top: 20px;
67
- }
68
- """
69
-
70
- # Запуск интерфейса
71
- interface.launch()
 
1
+ import gradio as gr
2
+ import QuckDrawGAN as qd
3
+ import numpy as np
4
+ from PIL import Image
5
+
6
+ # Загрузим модель
7
+ generator_file = r'pretrained_output/models/generator.pt'
8
+ discriminator_file = r'pretrained_output/models/discriminator_fine_tuned.pt'
9
+
10
+ # Создаем объект модели
11
+ model = qd.Model(generator_file, discriminator_file)
12
+
13
+ # Функция для генерации изображения с учетом сида, нормализацией и изменением размера
14
+ def generate_image(n_images=16, seed=""):
15
+ # Если сид не задан, не передаем его в модель
16
+ if seed == "":
17
+ seed = None
18
+ best_image = model.generate(n_images, seed) # Генерация с учетом сида
19
+
20
+ # Нормализация: находим минимум и максимум в изображении
21
+ best_image_min = np.min(best_image)
22
+ best_image_max = np.max(best_image)
23
+
24
+ # Нормализуем изображение, чтобы значения были в диапазоне от 0 до 255
25
+ normalized_image = 255 * (best_image - best_image_min) / (best_image_max - best_image_min)
26
+
27
+ # Преобразуем изображение в формат, подходящий для отображения
28
+ pil_image = Image.fromarray(normalized_image.astype(np.uint8)) # Преобразуем в uint8 для отображения
29
+ pil_image = pil_image.resize((256, 256), Image.Resampling.LANCZOS) # Ресайз изображения до 256x256
30
+
31
+ return pil_image
32
+
33
+ # Создаем интерфейс Gradio с помощью Blocks (для большей гибкости)
34
+ with gr.Blocks() as interface:
35
+ gr.Markdown("# Генератор изображений с использованием предобученной модели QuckDrawGAN (Duck)")
36
+ gr.Markdown("Этот интерфейс позволяет генерировать изображения с помощью модели QuckDrawGAN. Настройте количество генерируемых изображений и задайте сид для повторяемости.")
37
+
38
+ with gr.Row():
39
+ # Блок для изображения сверху
40
+ generated_image = gr.Image(type="pil", label="Сгенерированное изображение", elem_id="generated_image", scale=2) # Увеличиваем масштаб изображения
41
+
42
+ with gr.Row():
43
+ # Блок параметров и кнопки
44
+ with gr.Column():
45
+ seed_input = gr.Textbox(value="", label="Сид (опционально)", interactive=True)
46
+ num_images = gr.Slider(minimum=1, maximum=1024, value=16, label="Количество изображений для генерации", interactive=True, step=1)
47
+
48
+ # Кнопка генерации изображения справа
49
+ generate_button = gr.Button("Сгенерировать")
50
+
51
+ # Логика для автогенерации при изменении параметров
52
+ seed_input.change(generate_image, inputs=[num_images, seed_input], outputs=generated_image)
53
+ num_images.change(generate_image, inputs=[num_images, seed_input], outputs=generated_image)
54
+
55
+ # Логика для кнопки генерации
56
+ generate_button.click(generate_image, inputs=[num_images, seed_input], outputs=generated_image)
57
+
58
+ # Автогенерация при старте
59
+ interface.load(generate_image, inputs=[num_images, seed_input], outputs=generated_image)
60
+
61
+ # Стилизация блока изображения (увеличение размера блока)
62
+ interface.css = """
63
+ #generated_image {
64
+ width: 400px;
65
+ height: 400px;
66
+ margin-top: 20px;
67
+ }
68
+ """
69
+
70
+ # Запуск интерфейса
71
+ interface.launch()