Video_generator / app.py
Leo8613's picture
Update app.py
ce67fb9 verified
raw
history blame
3.36 kB
import tensorflow as tf
import numpy as np
import cv2
import gradio as gr
import os
# Fonction pour chercher le modèle dans tout le système de fichiers
def find_model_file(filename="generator.h5"):
# Parcourir tous les répertoires du serveur pour trouver le fichier
for root, dirs, files in os.walk("/"):
if filename in files:
model_path = os.path.join(root, filename)
print(f"Modèle trouvé à : {model_path}")
return model_path
return None
# Fonction pour charger le modèle en toute sécurité
def load_model_safe(model_path):
try:
# Charger le modèle sans compilation pour éviter des erreurs liées au batch_shape
model = tf.keras.models.load_model(model_path, compile=False)
return model
except ValueError as e:
print(f"Erreur lors du chargement du modèle: {e}")
return None
# Chercher le modèle 'generator.h5' dans le système
model_path = find_model_file("generator.h5")
# Vérifier si le modèle est trouvé et charger
if model_path is not None:
generator = load_model_safe(model_path)
print(f"Modèle chargé depuis : {model_path}")
else:
print("Le modèle 'generator.h5' n'a pas été trouvé sur le serveur.")
generator = None
# Fonction pour générer une vidéo à partir du générateur
def generate_video():
if generator is None:
return "Le modèle n'a pas pu être chargé."
# Générer un bruit aléatoire (entrée pour le générateur)
noise = np.random.normal(0, 1, (1, 16, 64, 64, 3)) # Exemple de bruit pour 16 frames de 64x64x3
generated_video = generator.predict(noise) # Générer la vidéo
# Vérifier la forme des données générées
print(f"Shape of generated video: {generated_video.shape}")
# Normaliser les données générées
video = (generated_video[0] * 255).astype(np.uint8) # Convertir en entier 8 bits
# Vérifier si la vidéo générée a la bonne forme
if len(video.shape) != 4 or video.shape[0] != 16:
return "Erreur dans les dimensions de la vidéo générée."
# Créer le répertoire pour la vidéo
output_dir = "/content/generated_videos"
os.makedirs(output_dir, exist_ok=True)
filename = os.path.join(output_dir, "generated_video.mp4")
# Enregistrer la vidéo avec OpenCV
fourcc = cv2.VideoWriter_fourcc(*'mp4v') # Codec vidéo
height, width, _ = video[0].shape
out = cv2.VideoWriter(filename, fourcc, 15, (width, height)) # 15 FPS
# Ajouter les frames dans le fichier vidéo
for frame in video:
out.write(frame)
out.release()
# Retourner le chemin de la vidéo générée
return filename
# Interface Gradio
def interface_function():
# Appeler la fonction de génération et retourner la vidéo générée
video_file = generate_video()
return video_file
# Définir l'interface avec Gradio
gr.Interface(
fn=interface_function, # Fonction à exécuter
inputs=[], # Pas d'entrée utilisateur
outputs=gr.Video(label="Vidéo générée", type="file"), # Vidéo en sortie avec type 'file' pour le téléchargement
title="Générateur de Vidéos avec IA",
description="Cliquez sur le bouton ci-dessous pour générer une vidéo aléatoire avec l'IA."
).launch(server_name="0.0.0.0", server_port=7860)