mirror of
https://github.com/easydiffusion/easydiffusion.git
synced 2025-06-23 19:31:38 +02:00
Allow a user to opt-in to the latest sdkit+diffusers version, while keeping existing 2.0.15.x users restricted to diffusers 0.21.4. This avoids a lengthy upgrade for existing users, while allowing users to opt-in to the latest version. More to come.
This commit is contained in:
parent
66d0c4726e
commit
4edeb14e94
@ -22,8 +22,8 @@ modules_to_check = {
|
|||||||
"torch": ("1.11.0", "1.13.1", "2.0.0", "2.0.1"),
|
"torch": ("1.11.0", "1.13.1", "2.0.0", "2.0.1"),
|
||||||
"torchvision": ("0.12.0", "0.14.1", "0.15.1", "0.15.2"),
|
"torchvision": ("0.12.0", "0.14.1", "0.15.1", "0.15.2"),
|
||||||
"setuptools": "69.5.1",
|
"setuptools": "69.5.1",
|
||||||
"sdkit": "2.0.15.6",
|
# "sdkit": "2.0.15.6", # checked later
|
||||||
"diffusers": "0.21.4",
|
# "diffusers": "0.21.4", # checked later
|
||||||
"stable-diffusion-sdkit": "2.1.5",
|
"stable-diffusion-sdkit": "2.1.5",
|
||||||
"rich": "12.6.0",
|
"rich": "12.6.0",
|
||||||
"uvicorn": "0.19.0",
|
"uvicorn": "0.19.0",
|
||||||
@ -124,8 +124,36 @@ def update_modules():
|
|||||||
f"WARNING! Tried to install {module_name}=={latest_version}, but the version is still {version(module_name)}!"
|
f"WARNING! Tried to install {module_name}=={latest_version}, but the version is still {version(module_name)}!"
|
||||||
)
|
)
|
||||||
|
|
||||||
if module_name in modules_to_log:
|
# different sdkit versions, with the corresponding diffusers
|
||||||
print(f"{module_name}: {version(module_name)}")
|
# if sdkit is 2.0.15.x (or lower), then diffusers should be restricted to 0.21.4 (see below for the reason)
|
||||||
|
# otherwise use the current sdkit version (with the corresponding diffusers version)
|
||||||
|
|
||||||
|
expected_sdkit_version_str = "2.0.20.3"
|
||||||
|
expected_diffusers_version_str = "0.28.2"
|
||||||
|
|
||||||
|
legacy_sdkit_version_str = "2.0.15.6"
|
||||||
|
legacy_diffusers_version_str = "0.21.4"
|
||||||
|
|
||||||
|
sdkit_version_str = version("sdkit")
|
||||||
|
if sdkit_version_str is None: # first install
|
||||||
|
_install("sdkit", expected_sdkit_version_str)
|
||||||
|
_install("diffusers", expected_diffusers_version_str)
|
||||||
|
else:
|
||||||
|
sdkit_version = version_str_to_tuple(sdkit_version_str)
|
||||||
|
legacy_sdkit_version = version_str_to_tuple(legacy_sdkit_version_str)
|
||||||
|
# torch_version = version_str_to_tuple(version("torch"))
|
||||||
|
|
||||||
|
if sdkit_version[:3] <= legacy_sdkit_version[:3]: # and torch_version < (0, 13):
|
||||||
|
# stick to diffusers 0.21.4, since it preserves torch 0.11+ compatibility.
|
||||||
|
# upgrading beyond this will result in a 2+ GB download of torch on older installations
|
||||||
|
# and a time-consuming chain of small package updates due to huggingface_hub upgrade.
|
||||||
|
# for now, the user will need to explicitly upgrade to a newer sdkit, to break this ceiling.
|
||||||
|
|
||||||
|
install_pkg_if_necessary("sdkit", legacy_sdkit_version_str)
|
||||||
|
install_pkg_if_necessary("diffusers", legacy_diffusers_version_str)
|
||||||
|
else:
|
||||||
|
install_pkg_if_necessary("sdkit", expected_sdkit_version_str)
|
||||||
|
install_pkg_if_necessary("diffusers", expected_diffusers_version_str)
|
||||||
|
|
||||||
# hotfix accelerate
|
# hotfix accelerate
|
||||||
accelerate_version = version("accelerate")
|
accelerate_version = version("accelerate")
|
||||||
@ -169,6 +197,9 @@ def update_modules():
|
|||||||
if curr_mod_version != mod_force_version:
|
if curr_mod_version != mod_force_version:
|
||||||
_install(mod_name, mod_force_version_str)
|
_install(mod_name, mod_force_version_str)
|
||||||
|
|
||||||
|
for module_name in modules_to_log:
|
||||||
|
print(f"{module_name}: {version(module_name)}")
|
||||||
|
|
||||||
|
|
||||||
def _install(module_name, module_version=None):
|
def _install(module_name, module_version=None):
|
||||||
if module_version is None:
|
if module_version is None:
|
||||||
@ -180,7 +211,14 @@ def _install(module_name, module_version=None):
|
|||||||
os.system(install_cmd)
|
os.system(install_cmd)
|
||||||
|
|
||||||
|
|
||||||
|
def install_pkg_if_necessary(pkg_name, required_version):
|
||||||
|
pkg_version = version(pkg_name)
|
||||||
|
if pkg_version != required_version:
|
||||||
|
_install(pkg_name, required_version)
|
||||||
|
|
||||||
|
|
||||||
def version_str_to_tuple(ver_str):
|
def version_str_to_tuple(ver_str):
|
||||||
|
ver_str = ver_str.split("+")[0]
|
||||||
ver = ver_str.split(".")
|
ver = ver_str.split(".")
|
||||||
return tuple(map(int, ver))
|
return tuple(map(int, ver))
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user