Spaces:
Running
Running
import gradio as gr | |
import torch | |
import torchvision.transforms as transforms | |
from pathlib import Path | |
import os | |
# Lấy Hugging Face token từ biến môi trường | |
HF_TOKEN = os.getenv("HF_TOKEN") # Token từ biến môi trường | |
MODEL_REPO = "Arrcttacsrks/FaceStyleGan" | |
TARGET_EPOCH = 47 | |
# Hàm tải mô hình từ thư mục local | |
def load_model(model_name, size): | |
model_directory = Path(f"./models/{model_name}/{size}") | |
if not model_directory.exists(): | |
raise FileNotFoundError(f"Không tìm thấy thư mục mô hình: {model_directory}") | |
# Tải trọng số mô hình | |
mapping_network = torch.load(model_directory / f"mapping_network_{TARGET_EPOCH}.pth", map_location="cpu") | |
generator = torch.load(model_directory / f"generator_{TARGET_EPOCH}.pth", map_location="cpu") | |
return generator, mapping_network | |
# Hàm sinh ảnh | |
def generate_image(model_name, size, alpha=0.5): | |
generator, mapping_network = load_model(model_name, size) | |
# Tạo noise | |
noise = torch.randn(1, 512) # Kích thước noise có thể thay đổi tùy theo mô hình | |
with torch.no_grad(): | |
# Sinh ảnh từ generator và mapping network | |
sample_w = mapping_network(noise) | |
generated_image = generator(sample_w) | |
# Chuyển đổi ảnh về định dạng numpy | |
transform = transforms.ToPILImage() | |
image = transform((generated_image + 1) / 2) # Chuyển đổi ảnh về khoảng [0, 1] | |
return image | |
# Lấy danh sách mô hình và kích thước | |
def get_model_names(): | |
return [folder.name for folder in Path("./models").glob("*") if folder.is_dir()] | |
def get_sizes(model_name): | |
sizes = [folder.name for folder in (Path("./models") / model_name).iterdir() if folder.is_dir()] | |
return sizes | |
# Tạo giao diện Gradio | |
with gr.Blocks() as demo: | |
gr.Markdown("# FaceStyleGan Image Generator") | |
model_name = gr.Dropdown(choices=get_model_names(), label="Chọn model", interactive=True) | |
size = gr.Dropdown(label="Chọn kích thước", interactive=True) | |
model_name.change(fn=get_sizes, inputs=model_name, outputs=size) | |
alpha = gr.Slider(0, 1, 0.5, label="Hệ số điều chỉnh (alpha)") | |
generate_button = gr.Button("Tạo Ảnh") | |
output = gr.Image(label="Ảnh Đã Tạo") | |
generate_button.click( | |
fn=generate_image, | |
inputs=[model_name, size, alpha], | |
outputs=output | |
) | |
demo.launch() | |