import torch import requests import urllib.request import streamlit as st if torch.cuda.is_available(): device = 'cuda' else: device = 'cpu' validT2IModelTypes = ["KandinskyPipeline", "StableDiffusionPipeline", "DiffusionPipeline", "StableDiffusionXLPipeline", "LatentConsistencyModelPipeline","StableDiffusion3Pipeline", "FluxPipeline"] def check_if_model_exists(repoName): modelLoaded = None huggingFaceURL = "https://huggingface.co/" + repoName + "/raw/main/model_index.json" response = requests.get(huggingFaceURL).status_code if response != 200: return None else: # modelLoaded = huggingFaceURL return huggingFaceURL def get_model_info(modelURL): modelType = None try: with urllib.request.urlopen(modelURL) as f: modelType = str(f.read()).split(',\\n')[0].split(':')[1].replace('"', '').strip() except urllib.error.URLError as e: st.write(e.reason) return modelType # Definitely need to work on these functions to consider adaptors # currently only works if there is a model index json file def import_model(modelID, modelType): T2IModel = None if modelType in validT2IModelTypes: if modelType == 'StableDiffusionXLPipeline': from diffusers import StableDiffusionXLPipeline T2IModel = StableDiffusionXLPipeline.from_pretrained(modelID, torch_dtype=torch.float16) T2IModel.to("cuda") elif modelType == 'LatentConsistencyModelPipeline': from diffusers import DiffusionPipeline T2IModel = DiffusionPipeline.from_pretrained(modelID, torch_dtype=torch.float16) T2IModel.to("cuda") elif modelType == 'StableDiffusion3Pipeline': from diffusers import StableDiffusion3Pipeline T2IModel = StableDiffusion3Pipeline.from_pretrained(modelID, torch_dtype=torch.bfloat16) T2IModel.to("cuda") elif modelType == 'FluxPipeline': from diffusers import FluxPipeline T2IModel = FluxPipeline.from_pretrained(modelID, torch_dtype=torch.bfloat16) T2IModel.enable_model_cpu_offload() else: from diffusers import AutoPipelineForText2Image T2IModel = AutoPipelineForText2Image.from_pretrained(modelID, torch_dtype=torch.float16) T2IModel.to("cuda") if 'StableDiffusionXLPipeline' in modelType.split(','): from diffusers import StableDiffusionXLPipeline T2IModel = StableDiffusionXLPipeline.from_pretrained(modelID, torch_dtype=torch.float16) T2IModel.to("cuda") try: T2IModel.safety_checker = None except: pass # if the model does not contain a safety checker no need to remove it return T2IModel