[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.10, <3.12" 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.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 = [ # Core generation dependencies, pinned for reproducible builds. "accelerate==0.27.2", "clip_anytorch==2.5.2", # replacing "clip @ https://github.com/openai/CLIP/archive/eaa22acb90a5876642d0507623e859909230a52d.zip", "compel==2.0.2", "controlnet-aux==0.0.7", "diffusers[torch]==0.26.3", "invisible-watermark==0.2.0", # needed to install SDXL base and refiner using their repo_ids "mediapipe==0.10.7", # needed for "mediapipeface" controlnet model "numpy==1.26.4", # >1.24.0 is needed to use the 'strict' argument to np.testing.assert_array_equal() "onnx==1.15.0", "onnxruntime==1.16.3", "opencv-python==4.9.0.80", "pytorch-lightning==2.1.3", "safetensors==0.4.2", "timm==0.6.13", # needed to override timm latest in controlnet_aux, see https://github.com/isl-org/ZoeDepth/issues/26 "torch==2.1.2", "torchmetrics==0.11.4", "torchsde==0.2.6", "torchvision==0.16.2", "transformers==4.37.2", # Core application dependencies, pinned for reproducible builds. "fastapi-events==0.10.1", "fastapi==0.109.2", "huggingface-hub==0.20.3", "pydantic-settings==2.1.0", "pydantic==2.6.1", "python-socketio==5.11.1", "uvicorn[standard]==0.27.1", # Auxiliary dependencies, pinned only if necessary. "albumentations", "click", "datasets", "dnspython~=2.4.0", "dynamicprompts", "easing-functions", "einops", "facexlib", "imohash", "matplotlib", # needed for plotting of Penner easing functions "npyscreen", "omegaconf", "picklescan", "pillow", "prompt-toolkit", "pympler~=1.0.1", "pypatchmatch", 'pyperclip', "pyreadline3", "python-multipart", "requests~=2.28.2", "rich~=13.3", "scikit-image~=0.21.0", "semver~=3.0.1", "send2trash", "test-tube~=0.7.5", "windows-curses; sys_platform=='win32'", ] [project.optional-dependencies] "xformers" = [ # Core generation dependencies, pinned for reproducible builds. "xformers==0.0.23.post1; sys_platform!='darwin'", # Auxiliary dependencies, pinned only if necessary. "triton; sys_platform=='linux'", ] "onnx" = ["onnxruntime"] "onnx-cuda" = ["onnxruntime-gpu"] "onnx-directml" = ["onnxruntime-directml"] "dist" = ["pip-tools", "pipdeptree", "twine"] "docs" = [ "mkdocs-material<9.0", "mkdocs-git-revision-date-localized-plugin", "mkdocs-redirects==1.2.0", ] "dev" = ["jurigged", "pudb", "snakeviz", "gprof2dot"] "test" = [ "ruff==0.2.1", "ruff-lsp", "mypy", "pre-commit", "pytest>6.0.0", "pytest-cov", "pytest-datadir", "requests_testadapter", ] [project.scripts] # legacy entrypoints; provided for backwards compatibility "configure_invokeai.py" = "invokeai.frontend.install.invokeai_configure:invokeai_configure" "textual_inversion.py" = "invokeai.frontend.training:invokeai_textual_inversion" # shortcut commands to start web ui # "invokeai --web" will launch the web interface # "invokeai" = "invokeai.frontend.legacy_launch_invokeai:main" # new shortcut to launch web interface "invokeai-web" = "invokeai.app.api_app:invoke_api" # full commands "invokeai-configure" = "invokeai.frontend.install.invokeai_configure:invokeai_configure" "invokeai-merge" = "invokeai.frontend.merge:invokeai_merge_diffusers" "invokeai-merge2" = "invokeai.frontend.merge.merge_diffusers2:main" "invokeai-ti" = "invokeai.frontend.training:invokeai_textual_inversion" "invokeai-model-install" = "invokeai.frontend.install.model_install:main" "invokeai-model-install2" = "invokeai.frontend.install.model_install2:main" # will eventually be renamed to invokeai-model-install "invokeai-migrate3" = "invokeai.backend.install.migrate_to_3:main" "invokeai-update" = "invokeai.frontend.install.invokeai_update:main" "invokeai-metadata" = "invokeai.backend.image_util.invoke_metadata:main" "invokeai-node-web" = "invokeai.app.api_app:invoke_api" "invokeai-import-images" = "invokeai.frontend.install.import_images:main" "invokeai-db-maintenance" = "invokeai.backend.util.db_maintenance: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 = "invokeai.version.__version__" } [tool.setuptools.packages.find] "where" = ["."] "include" = [ "invokeai.assets.fonts*", "invokeai.version*", "invokeai.generator*", "invokeai.backend*", "invokeai.frontend*", "invokeai.frontend.web.dist*", "invokeai.frontend.web.static*", "invokeai.configs*", "invokeai.app*", ] [tool.setuptools.package-data] "invokeai.app.assets" = ["**/*.png"] "invokeai.app.services.workflow_records.default_workflows" = ["*.json"] "invokeai.assets.fonts" = ["**/*.ttf"] "invokeai.backend" = ["**.png"] "invokeai.configs" = ["*.example", "**/*.yaml", "*.txt"] "invokeai.frontend.web.dist" = ["**"] "invokeai.frontend.web.static" = ["**"] "invokeai.app.invocations" = ["**"] #=== Begin: PyTest and Coverage [tool.pytest.ini_options] addopts = "--cov-report term --cov-report html --cov-report xml --strict-markers -m \"not slow\"" markers = [ "slow: Marks tests as slow. Disabled by default. To run all tests, use -m \"\". To run only slow tests, use -m \"slow\".", ] [tool.coverage.run] branch = true source = ["invokeai"] omit = ["*tests*", "*migrations*", ".venv/*", "*.env"] [tool.coverage.report] show_missing = true fail_under = 85 # let's set something sensible on Day 1 ... [tool.coverage.json] output = "coverage/coverage.json" pretty_print = true [tool.coverage.html] directory = "coverage/html" [tool.coverage.xml] output = "coverage/index.xml" #=== End: PyTest and Coverage #=== Begin: Ruff [tool.ruff] line-length = 120 exclude = [ ".git", "__pycache__", "build", "dist", "invokeai/frontend/web/node_modules/", ".venv*", ] [tool.ruff.lint] ignore = [ "E501", # https://docs.astral.sh/ruff/rules/line-too-long/ "C901", # https://docs.astral.sh/ruff/rules/complex-structure/ "B008", # https://docs.astral.sh/ruff/rules/function-call-in-default-argument/ "B904", # https://docs.astral.sh/ruff/rules/raise-without-from-inside-except/ ] select = ["B", "C", "E", "F", "W", "I"] #=== End: Ruff #=== Begin: MyPy # global mypy config [tool.mypy] ignore_missing_imports = true # ignores missing types in third-party libraries strict = true plugins = "pydantic.mypy" exclude = ["tests/*"] # overrides for specific modules [[tool.mypy.overrides]] follow_imports = "skip" # skips type checking of the modules listed below module = [ "invokeai.app.api.routers.models", "invokeai.app.invocations.compel", "invokeai.app.invocations.latent", "invokeai.app.services.invocation_stats.invocation_stats_default", "invokeai.app.services.model_manager.model_manager_base", "invokeai.app.services.model_manager.model_manager_default", "invokeai.app.services.model_records.model_records_sql", "invokeai.app.util.controlnet_utils", "invokeai.backend.image_util.txt2mask", "invokeai.backend.image_util.safety_checker", "invokeai.backend.image_util.patchmatch", "invokeai.backend.image_util.invisible_watermark", "invokeai.backend.install.model_install_backend", "invokeai.backend.ip_adapter.ip_adapter", "invokeai.backend.ip_adapter.resampler", "invokeai.backend.ip_adapter.unet_patcher", "invokeai.backend.model_management.convert_ckpt_to_diffusers", "invokeai.backend.model_management.lora", "invokeai.backend.model_management.model_cache", "invokeai.backend.model_management.model_manager", "invokeai.backend.model_management.model_merge", "invokeai.backend.model_management.model_probe", "invokeai.backend.model_management.model_search", "invokeai.backend.model_management.models.*", # this is needed to ignore the module's `__init__.py` "invokeai.backend.model_management.models.base", "invokeai.backend.model_management.models.controlnet", "invokeai.backend.model_management.models.ip_adapter", "invokeai.backend.model_management.models.lora", "invokeai.backend.model_management.models.sdxl", "invokeai.backend.model_management.models.stable_diffusion", "invokeai.backend.model_management.models.vae", "invokeai.backend.model_management.seamless", "invokeai.backend.model_management.util", "invokeai.backend.stable_diffusion.diffusers_pipeline", "invokeai.backend.stable_diffusion.diffusion.cross_attention_control", "invokeai.backend.stable_diffusion.diffusion.shared_invokeai_diffusion", "invokeai.backend.util.hotfixes", "invokeai.backend.util.mps_fixes", "invokeai.backend.util.util", "invokeai.frontend.install.model_install", ] #=== End: MyPy