[build-system] requires = ["setuptools~=65.5", "pip~=22.3", "wheel"] build-backend = "setuptools.build_meta" [project] name = "InvokeAI" description = "An implementation of Stable Diffusion which provides various new features and options to aid the image generation process" requires-python = ">=3.9, <3.11" readme = { content-type = "text/markdown", file = "README.md" } keywords = ["stable-diffusion", "AI"] dynamic = ["version"] license = { file = "LICENSE" } authors = [{ name = "The InvokeAI Project", email = "lincoln.stein@gmail.com" }] classifiers = [ 'Development Status :: 4 - Beta', 'Environment :: GPU', 'Environment :: GPU :: NVIDIA CUDA', 'Environment :: MacOS X', 'Intended Audience :: End Users/Desktop', 'Intended Audience :: Developers', 'License :: OSI Approved :: MIT License', 'Operating System :: POSIX :: Linux', 'Operating System :: MacOS', 'Operating System :: Microsoft :: Windows', 'Programming Language :: Python :: 3 :: Only', 'Programming Language :: Python :: 3.8', 'Programming Language :: Python :: 3.9', 'Programming Language :: Python :: 3.10', 'Topic :: Artistic Software', 'Topic :: Internet :: WWW/HTTP :: WSGI :: Application', 'Topic :: Internet :: WWW/HTTP :: WSGI :: Server', 'Topic :: Multimedia :: Graphics', 'Topic :: Scientific/Engineering :: Artificial Intelligence', 'Topic :: Scientific/Engineering :: Image Processing', ] dependencies = [ "accelerate", "albumentations", "click", "clip_anytorch", # replacing "clip @ https://github.com/openai/CLIP/archive/eaa22acb90a5876642d0507623e859909230a52d.zip", "datasets", "diffusers[torch]~=0.11", "dnspython==2.2.1", "einops", "eventlet", "facexlib", "flask==2.1.3", "flask_cors==3.0.10", "flask_socketio==5.3.0", "flaskwebgui==1.0.3", "getpass_asterisk", "gfpgan==1.3.8", "huggingface-hub>=0.11.1", "imageio", "imageio-ffmpeg", "k-diffusion", # replacing "k-diffusion @ https://github.com/Birch-san/k-diffusion/archive/refs/heads/mps.zip", "kornia", "npyscreen", "numpy<1.24", "omegaconf", "opencv-python", "picklescan", "pillow", "pudb", "prompt-toolkit", "pypatchmatch", "pyreadline3", "pytorch-lightning==1.7.7", "realesrgan", "requests==2.28.2", "safetensors", "scikit-image>=0.19", "send2trash", "streamlit", "taming-transformers-rom1504", "test-tube>=0.7.5", "torch>=1.13.1", "torch-fidelity", "torchvision>=0.14.1", "torchmetrics", "transformers~=4.25", "windows-curses; sys_platform=='win32'", ] [project.optional-dependencies] "dist" = ["pip-tools", "pipdeptree", "twine"] "docs" = [ "mkdocs-material<9.0", "mkdocs-git-revision-date-localized-plugin", "mkdocs-redirects==1.2.0", ] "test" = ["pytest>6.0.0", "pytest-cov"] "xformers" = [ "xformers~=0.0.16; sys_platform!='darwin'", "triton; sys_platform=='linux'", ] [project.scripts] # legacy entrypoints; provided for backwards compatibility "invoke.py" = "ldm.invoke.CLI:main" "configure_invokeai.py" = "ldm.invoke.config.invokeai_configure:main" "textual_inversion.py" = "ldm.invoke.training.textual_inversion:main" "merge_embeddings.py" = "ldm.invoke.merge_diffusers:main" # modern entrypoints "invokeai" = "ldm.invoke.CLI:main" "invokeai-configure" = "ldm.invoke.config.invokeai_configure:main" "invokeai-merge" = "ldm.invoke.merge_diffusers:main" # note name munging "invokeai-ti" = "ldm.invoke.training.textual_inversion:main" "invokeai-update" = "ldm.invoke.config.invokeai_update:main" [project.urls] "Homepage" = "https://invoke-ai.github.io/InvokeAI/" "Documentation" = "https://invoke-ai.github.io/InvokeAI/" "Source" = "https://github.com/invoke-ai/InvokeAI/" "Bug Reports" = "https://github.com/invoke-ai/InvokeAI/issues" "Discord" = "https://discord.gg/ZmtBAhwWhy" [tool.setuptools.dynamic] version = { attr = "ldm.invoke.__version__" } [tool.setuptools.packages.find] "where" = ["."] "include" = ["invokeai.assets.web*", "invokeai.backend*", "invokeai.frontend.dist*", "invokeai.configs*", "ldm*"] [tool.setuptools.package-data] "invokeai.assets.web" = ["**.png"] "invokeai.backend" = ["**.png"] "invokeai.configs" = ["*.example", "**/*.yaml", "*.txt"] "invokeai.frontend.dist" = ["**"] [tool.pytest.ini_options] addopts = "-p pytest_cov --junitxml=junit/test-results.xml --cov-report=term:skip-covered --cov=ldm/invoke --cov=backend --cov-branch"