Spaces:
Sleeping
Sleeping
File size: 2,319 Bytes
d41bb77 1fdf512 7cd78a5 d41bb77 1fdf512 7cd78a5 86e75f4 d41bb77 2c72e26 1fdf512 d41bb77 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 |
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)
elif modelType == 'LatentConsistencyModelPipeline':
from diffusers import DiffusionPipeline
T2IModel = DiffusionPipeline.from_pretrained(modelID, torch_dtype=torch.float16)
elif modelType == 'StableDiffusion3Pipeline':
from diffusers import StableDiffusion3Pipeline
T2IModel = StableDiffusion3Pipeline.from_pretrained(modelID, torch_dtype=torch.bfloat16)
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")
return T2IModel
|