Ahmed1871992 commited on
Commit
f522e01
·
verified ·
1 Parent(s): 4103376

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +52 -54
app.py CHANGED
@@ -1,25 +1,20 @@
1
  import os
2
  import gradio as gr
3
  import torch
4
- from diffusers import StableDiffusionPipeline, DDPMScheduler, Trainer, TrainingArguments, DiffusionPipeline
 
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
- # قاعدة بيانات للمستخدمين والنماذج المحفوظة (سيتم حفظها في ملف JSON)
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
- for img in images:
52
- img.save(user_image_folder / img.name)
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
- # تجهيز المعلمات لتدريب DreamBooth
59
- accelerator = Accelerator()
 
 
 
 
 
 
 
 
 
60
 
61
- # إعداد DreamBooth باستخدام مكتبة diffusers
62
- model = StableDiffusionPipeline.from_pretrained(MODEL_NAME)
63
- tokenizer = CLIPTokenizer.from_pretrained("openai/clip-vit-base-patch32")
64
 
65
- # تفعيل التدريب باستخدام DreamBooth
66
  trainer = DreamBoothTrainer(
67
- model=model,
68
- args=TrainingArguments(
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
- model = StableDiffusionPipeline.from_pretrained(f"user_models/{user_email}") # تحميل النموذج المدرب للمستخدم
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="🔔 نتيجة التدريب")