Spaces:
Sleeping
Sleeping
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 | |