Spaces:
Sleeping
Sleeping
Update app.py
Browse files
app.py
CHANGED
@@ -1,25 +1,20 @@
|
|
1 |
import os
|
2 |
import gradio as gr
|
3 |
import torch
|
4 |
-
from diffusers import StableDiffusionPipeline,
|
|
|
5 |
from datasets import load_dataset
|
6 |
-
from transformers import CLIPTextModel, CLIPTokenizer, PreTrainedModel
|
7 |
-
from werkzeug.security import generate_password_hash, check_password_hash
|
8 |
import json
|
9 |
import time
|
10 |
-
from pathlib import Path
|
11 |
-
from PIL import Image
|
12 |
-
from diffusers import DreamBoothTrainer, DreamBoothPipeline
|
13 |
-
from accelerate import Accelerator
|
14 |
|
15 |
-
# تحميل نموذج Stable Diffusion
|
16 |
MODEL_NAME = "runwayml/stable-diffusion-v1-5"
|
17 |
device = "cuda" if torch.cuda.is_available() else "cpu"
|
18 |
|
19 |
pipe = StableDiffusionPipeline.from_pretrained(MODEL_NAME)
|
20 |
pipe.to(device)
|
21 |
|
22 |
-
# قاعدة بيانات للمستخدمين والنماذج المحفوظة
|
23 |
user_data_file = "user_data.json"
|
24 |
|
25 |
# تحميل البيانات من ملف JSON إذا كان موجودًا
|
@@ -31,81 +26,84 @@ else:
|
|
31 |
|
32 |
saved_models = {}
|
33 |
|
34 |
-
#
|
35 |
-
def save_users_data():
|
36 |
-
with open(user_data_file, "w") as f:
|
37 |
-
json.dump(users, f)
|
38 |
-
|
39 |
-
# وظيفة تدريب النموذج على الصور المرفوعة باستخدام DreamBooth أو LoRA
|
40 |
def train_model(user_email, images, progress):
|
41 |
if not user_email:
|
42 |
return "يجب تسجيل الدخول لحفظ النموذج."
|
43 |
|
44 |
user_model_id = f"user_model_{user_email}"
|
45 |
-
|
46 |
-
# إعداد مجلد لحفظ الصور
|
47 |
-
user_image_folder = Path(f"user_images/{user_email}")
|
48 |
-
user_image_folder.mkdir(parents=True, exist_ok=True)
|
49 |
|
50 |
-
#
|
51 |
-
|
52 |
-
|
53 |
-
|
54 |
-
# إعداد بيانات التدريب (يمكنك تخصيص هذه الطريقة لتناسب النموذج الخاص بك)
|
55 |
-
image_paths = [str(user_image_folder / img.name) for img in images]
|
56 |
-
dataset = load_dataset('imagefolder', data_dir=str(user_image_folder))
|
57 |
|
58 |
-
# تجهيز
|
59 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
60 |
|
61 |
-
#
|
62 |
-
|
63 |
-
|
64 |
|
65 |
-
#
|
66 |
trainer = DreamBoothTrainer(
|
67 |
-
model=
|
68 |
-
args=
|
69 |
-
output_dir=f"user_models/{user_email}",
|
70 |
-
per_device_train_batch_size=4,
|
71 |
-
num_train_epochs=1,
|
72 |
-
gradient_accumulation_steps=2,
|
73 |
-
logging_dir='./logs',
|
74 |
-
logging_steps=10,
|
75 |
-
report_to="none"
|
76 |
-
),
|
77 |
train_dataset=dataset["train"],
|
78 |
-
tokenizer=tokenizer
|
|
|
79 |
)
|
80 |
-
|
81 |
-
#
|
82 |
trainer.train()
|
83 |
-
|
84 |
-
# حفظ النموذج المدرب
|
85 |
-
model.save_pretrained(f"user_models/{user_email}")
|
86 |
-
saved_models[user_email] = user_model_id
|
87 |
|
88 |
return f"✅ تم حفظ النموذج بنجاح: {user_model_id}"
|
89 |
|
90 |
-
# وظيفة
|
91 |
def generate_image(prompt, user_email=None):
|
92 |
if user_email and user_email in saved_models:
|
93 |
model_id = saved_models[user_email]
|
94 |
-
|
95 |
-
model.to(device)
|
96 |
-
result = model(prompt).images[0]
|
97 |
else:
|
98 |
result = pipe(prompt).images[0]
|
99 |
|
100 |
return result
|
101 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
102 |
# واجهة Gradio
|
103 |
with gr.Blocks() as demo:
|
104 |
gr.Markdown("# 🖼️ إنشاء صور مخصصة باستخدام الذكاء الاصطناعي")
|
105 |
|
106 |
with gr.Row():
|
107 |
with gr.Column():
|
108 |
-
image_input = gr.Files(label="📤 رفع صورك للتدريب") #
|
109 |
user_email_input = gr.Textbox(label="📧 بريدك الإلكتروني (اختياري لحفظ النموذج)")
|
110 |
train_button = gr.Button("🔧 تدريب النموذج")
|
111 |
train_output = gr.Textbox(label="🔔 نتيجة التدريب")
|
|
|
1 |
import os
|
2 |
import gradio as gr
|
3 |
import torch
|
4 |
+
from diffusers import StableDiffusionPipeline, DreamBoothTrainer, TrainingArguments, Trainer
|
5 |
+
from transformers import CLIPTextModel, CLIPTokenizer
|
6 |
from datasets import load_dataset
|
|
|
|
|
7 |
import json
|
8 |
import time
|
|
|
|
|
|
|
|
|
9 |
|
10 |
+
# تحميل نموذج Stable Diffusion الأساسي
|
11 |
MODEL_NAME = "runwayml/stable-diffusion-v1-5"
|
12 |
device = "cuda" if torch.cuda.is_available() else "cpu"
|
13 |
|
14 |
pipe = StableDiffusionPipeline.from_pretrained(MODEL_NAME)
|
15 |
pipe.to(device)
|
16 |
|
17 |
+
# قاعدة بيانات للمستخدمين والنماذج المحفوظة
|
18 |
user_data_file = "user_data.json"
|
19 |
|
20 |
# تحميل البيانات من ملف JSON إذا كان موجودًا
|
|
|
26 |
|
27 |
saved_models = {}
|
28 |
|
29 |
+
# وظيفة لتدريب النموذج على الصور المرفوعة
|
|
|
|
|
|
|
|
|
|
|
30 |
def train_model(user_email, images, progress):
|
31 |
if not user_email:
|
32 |
return "يجب تسجيل الدخول لحفظ النموذج."
|
33 |
|
34 |
user_model_id = f"user_model_{user_email}"
|
35 |
+
saved_models[user_email] = user_model_id
|
|
|
|
|
|
|
36 |
|
37 |
+
# تأكد من أن الصور مرفوعة
|
38 |
+
if len(images) == 0:
|
39 |
+
return "⚠️ يجب رفع صور للتدريب."
|
|
|
|
|
|
|
|
|
40 |
|
41 |
+
# تجهيز البيانات الخاصة بالتدريب
|
42 |
+
dataset = load_dataset('imagefolder', data_dir=images)
|
43 |
+
|
44 |
+
# إعداد الـ Trainer للتدريب
|
45 |
+
training_args = TrainingArguments(
|
46 |
+
output_dir="./output", # مكان حفظ النموذج المدرب
|
47 |
+
per_device_train_batch_size=1, # حجم الدفعة
|
48 |
+
num_train_epochs=3, # عدد العصور (epochs)
|
49 |
+
logging_dir='./logs', # مكان تسجيل السجلات
|
50 |
+
logging_steps=10,
|
51 |
+
)
|
52 |
|
53 |
+
# تحميل Tokenizer و Model من CLIP لتوليد النصوص
|
54 |
+
tokenizer = CLIPTokenizer.from_pretrained("openai/clip-vit-base-patch16")
|
55 |
+
text_encoder = CLIPTextModel.from_pretrained("openai/clip-vit-base-patch16")
|
56 |
|
57 |
+
# إعداد الـ Trainer باستخدام DreamBooth
|
58 |
trainer = DreamBoothTrainer(
|
59 |
+
model=pipe.unet,
|
60 |
+
args=training_args,
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
61 |
train_dataset=dataset["train"],
|
62 |
+
tokenizer=tokenizer,
|
63 |
+
text_encoder=text_encoder,
|
64 |
)
|
65 |
+
|
66 |
+
# بدء عملية التدريب
|
67 |
trainer.train()
|
|
|
|
|
|
|
|
|
68 |
|
69 |
return f"✅ تم حفظ النموذج بنجاح: {user_model_id}"
|
70 |
|
71 |
+
# وظيفة لإنشاء الصور باستخدام البرومبتات
|
72 |
def generate_image(prompt, user_email=None):
|
73 |
if user_email and user_email in saved_models:
|
74 |
model_id = saved_models[user_email]
|
75 |
+
result = pipe(prompt).images[0]
|
|
|
|
|
76 |
else:
|
77 |
result = pipe(prompt).images[0]
|
78 |
|
79 |
return result
|
80 |
|
81 |
+
# وظيفة لتسجيل المستخدمين
|
82 |
+
def register(email, password):
|
83 |
+
if email in users:
|
84 |
+
return "⚠️ البريد الإلكتروني مسجل بالفعل!"
|
85 |
+
users[email] = {"password": generate_password_hash(password)}
|
86 |
+
save_users_data()
|
87 |
+
return "✅ تم التسجيل بنجاح!"
|
88 |
+
|
89 |
+
# وظيفة لتسجيل الدخول
|
90 |
+
def login(email, password):
|
91 |
+
if email not in users or not check_password_hash(users[email]["password"], password):
|
92 |
+
return "❌ البريد الإلكتروني أو كلمة المرور غير صحيحة!"
|
93 |
+
return f"✅ تم تسجيل الدخول: {email}"
|
94 |
+
|
95 |
+
# حفظ بيانات المستخدمين إلى ملف JSON
|
96 |
+
def save_users_data():
|
97 |
+
with open(user_data_file, "w") as f:
|
98 |
+
json.dump(users, f)
|
99 |
+
|
100 |
# واجهة Gradio
|
101 |
with gr.Blocks() as demo:
|
102 |
gr.Markdown("# 🖼️ إنشاء صور مخصصة باستخدام الذكاء الاصطناعي")
|
103 |
|
104 |
with gr.Row():
|
105 |
with gr.Column():
|
106 |
+
image_input = gr.Files(label="📤 رفع صورك للتدريب") # رفع الصور
|
107 |
user_email_input = gr.Textbox(label="📧 بريدك الإلكتروني (اختياري لحفظ النموذج)")
|
108 |
train_button = gr.Button("🔧 تدريب النموذج")
|
109 |
train_output = gr.Textbox(label="🔔 نتيجة التدريب")
|