Skip to main content

anomalib - Anomaly Detection Library

Project description

Anomalib Logo - A deep learning library for anomaly detection

A library for benchmarking, developing and deploying deep learning anomaly detection algorithms


Key FeaturesDocsNotebooksLicense

python pytorch lightning openvino

Pre-Merge Checks codecov Downloads snyk OpenSSF Best Practices

ReadTheDocs Anomalib - Gurubase docs

open-edge-platform%2Fanomalib | Trendshift


🌟 Announcing v2.3.3 Patch Release! 🌟

This patch release changes data and model download locations, adds pandas 3.0 compatibility fixes, and includes security-focused dependency updates.

What's changed

  • Moved pre-trained model downloads to platform-specific cache directories.
  • Added deprecation warnings for legacy local ./datasets/<dataset> roots ahead of the v2.6.0 cache-directory migration.
  • Updated security-sensitive dependencies including mlflow.

Bug fixes

  • Fixed enum-based DataFrame comparisons for pandas >= 3.0 compatibility.

We value your input! Please share feedback via GitHub Issues or our Discussions

👋 Introduction

Anomalib is a deep learning library that aims to collect state-of-the-art anomaly detection algorithms for benchmarking on both public and private datasets. Anomalib provides several ready-to-use implementations of anomaly detection algorithms described in the recent literature, as well as a set of tools that facilitate the development and implementation of custom models. The library has a strong focus on visual anomaly detection, where the goal of the algorithm is to detect and/or localize anomalies within images or videos in a dataset. Anomalib is constantly updated with new algorithms and training/inference extensions, so keep checking!

A prediction made by anomalib

Key features

  • Simple and modular API and CLI for training, inference, benchmarking, and hyperparameter optimization.
  • The largest public collection of ready-to-use deep learning anomaly detection algorithms and benchmark datasets.
  • Lightning based model implementations to reduce boilerplate code and limit the implementation efforts to the bare essentials.
  • The majority of models can be exported to OpenVINO Intermediate Representation (IR) for accelerated inference on Intel hardware.
  • A set of inference tools for quick and easy deployment of the standard or custom anomaly detection models.

📦 Installation

Anomalib can be installed from PyPI. We recommend using a virtual environment and a modern package installer like uv or pip.

🚀 Quick Install

For a standard installation, you can use uv or pip. This will install the latest version of Anomalib with its core dependencies. PyTorch will be installed based on its default behavior, which usually works for CPU and standard CUDA setups.

# With uv
uv pip install anomalib

# Or with pip
pip install anomalib

For more control over the installation, such as specifying the PyTorch backend (e.g., XPU, CUDA and ROCm) or installing extra dependencies for specific models, see the advanced options below.

💡 Advanced Installation: Specify Hardware Backend

To ensure compatibility with your hardware, you can specify a backend during installation. This is the recommended approach for production environments and for hardware other than CPU or standard CUDA.

Using uv:

# CPU support (default, works on all platforms)
uv pip install "anomalib[cpu]"

# CUDA 12.6 support (Linux/Windows with NVIDIA GPU)
uv pip install "anomalib[cu126]"

# CUDA 13.0 support (Linux/Windows with NVIDIA GPU)
uv pip install "anomalib[cu130]"

# CUDA 11.8 support (Linux/Windows with NVIDIA GPU)
uv pip install "anomalib[cu118]"

# ROCm support (Linux with AMD GPU)
uv pip install "anomalib[rocm]"

# Intel XPU support (Linux with Intel GPU)
uv pip install "anomalib[xpu]"

Using pip: The same extras can be used with pip:

pip install "anomalib[cu130]"
🧩 Advanced Installation: Additional Dependencies

Anomalib includes most dependencies by default. For specialized features, you may need additional optional dependencies. Remember to include your hardware-specific extra.

# Example: Install with OpenVINO support and CUDA 13.0
uv pip install "anomalib[openvino,cu130]"

# Example: Install all optional dependencies for a CPU-only setup
uv pip install "anomalib[full,cpu]"

Here is a list of available optional dependency groups:

Extra Description Purpose
[openvino] Intel OpenVINO optimization For accelerated inference on Intel hardware
[clip] Vision-language models winclip
[vlm] Vision-language model backends Advanced VLM features
[loggers] Experiment tracking (wandb, comet, etc.) For experiment management
[notebooks] Jupyter notebook support For running example notebooks
[full] All optional dependencies All optional features
🔧 Advanced Installation: Install from Source

For contributing to anomalib or using a development version, you can install from source.

Using uv: This is the recommended method for developers as it uses the project's lock file for reproducible environments.

git clone https://github.com/open-edge-platform/anomalib.git
cd anomalib

# Create the virtual environment
uv venv

# Sync with the lockfile for a specific backend (e.g., CPU)
uv sync --extra cpu

# Or for a different backend like CUDA 13.0
uv sync --extra cu130

# To set up a full development environment
uv sync --extra dev --extra cpu

Using pip:

git clone https://github.com/open-edge-platform/anomalib.git
cd anomalib

# Install in editable mode with a specific backend
pip install -e ".[cpu]"

# Install with development dependencies
pip install -e ".[dev,cpu]"

🧠 Training

Anomalib supports both API and CLI-based training approaches:

🔌 Python API

from anomalib.data import MVTecAD
from anomalib.models import Patchcore
from anomalib.engine import Engine

# Initialize components
datamodule = MVTecAD()
model = Patchcore()
engine = Engine()

# Train the model
engine.fit(datamodule=datamodule, model=model)

⌨️ Command Line

# Train with default settings
anomalib train --model Patchcore --data anomalib.data.MVTecAD

# Train with custom category
anomalib train --model Patchcore --data anomalib.data.MVTecAD --data.category transistor

# Train with config file
anomalib train --config path/to/config.yaml

🤖 Inference

Anomalib provides multiple inference options including Torch, Lightning, Gradio, and OpenVINO. Here's how to get started:

🔌 Python API

# Load model and make predictions
predictions = engine.predict(
    datamodule=datamodule,
    model=model,
    ckpt_path="path/to/checkpoint.ckpt",
)

⌨️ Command Line

# Basic prediction
anomalib predict --model anomalib.models.Patchcore \
                 --data anomalib.data.MVTecAD \
                 --ckpt_path path/to/model.ckpt

# Prediction with results
anomalib predict --model anomalib.models.Patchcore \
                 --data anomalib.data.MVTecAD \
                 --ckpt_path path/to/model.ckpt \
                 --return_predictions

📘 Note: For advanced inference options including Gradio and OpenVINO, check our Inference Documentation.

Training on Intel GPUs

[!Note] Currently, only single GPU training is supported on Intel GPUs. These commands were tested on Arc 750 and Arc 770.

Ensure that you have PyTorch with XPU support installed. For more information, please refer to the PyTorch XPU documentation

🔌 API

from anomalib.data import MVTecAD
from anomalib.engine import Engine, SingleXPUStrategy, XPUAccelerator
from anomalib.models import Stfpm

engine = Engine(
    strategy=SingleXPUStrategy(),
    accelerator=XPUAccelerator(),
)
engine.train(Stfpm(), datamodule=MVTecAD())

⌨️ CLI

anomalib train --model Padim --data MVTecAD --trainer.accelerator xpu --trainer.strategy xpu_single

⚙️ Hyperparameter Optimization

Anomalib supports hyperparameter optimization (HPO) using Weights & Biases and Comet.ml.

# Run HPO with Weights & Biases
anomalib hpo --backend WANDB --sweep_config tools/hpo/configs/wandb.yaml

📘 Note: For detailed HPO configuration, check our HPO Documentation.

🧪 Experiment Management

Track your experiments with popular logging platforms through PyTorch Lightning loggers:

  • 📊 Weights & Biases
  • 📈 Comet.ml
  • 📉 TensorBoard

Enable logging in your config file to track:

  • Hyperparameters
  • Metrics
  • Model graphs
  • Test predictions

📘 Note: For logging setup, see our Logging Documentation.

📊 Benchmarking

Evaluate and compare model performance across different datasets:

# Run benchmarking with default configuration
anomalib benchmark --config tools/experimental/benchmarking/sample.yaml

💡 Tip: Check individual model performance in their respective README files:

Anomalib Studio

Anomalib Studio is a low/no-code web application that allows users to train and deploy anomaly detection models. It enables users to leverage Anomalib's features in their operational environment. Users can connect USB and IP cameras, or use a folder of images, as input to the training pipeline. The tool allows direct output to their industrial pipelines through ROS messages, MQTT, etc.

Anomalib Studio

The source code for Anomalib Studio lives in the application folder.

Anomalib Studio is available as two distributions:

  1. As a docker container
  2. As a standalone application

For more information on each, refer to the respective README files.

Get started with development build

Setup Backend Dependencies

[!NOTE] This assumes that you have uv installed. If not, please refer to the installation guide.

cd application/backend
uv sync --extra xpu # or uv sync --extra cu130 for CUDA 13.0, uv sync --extra cpu for CPU

Setup Frontend Dependencies

cd application/ui
npm install

Run the application

[!IMPORTANT] Both backend and frontend dependencies should be installed before running the application.

Run the backend server:

cd application/backend
./run.sh

Run the frontend server:

cd application/ui
npm run start

Navigate to http://localhost:3000 to see the application.

✍️ Reference

If you find Anomalib useful in your research or work, please cite:

@inproceedings{akcay2022anomalib,
  title={Anomalib: A deep learning library for anomaly detection},
  author={Akcay, Samet and Ameln, Dick and Vaidya, Ashwin and Lakshmanan, Barath and Ahuja, Nilesh and Genc, Utku},
  booktitle={2022 IEEE International Conference on Image Processing (ICIP)},
  pages={1706--1710},
  year={2022},
  organization={IEEE}
}

👥 Contributing

We welcome contributions! Check out our Contributing Guide to get started.

Contributors to open-edge-platform/anomalib

Thank you to all our contributors!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

anomalib-2.3.3.tar.gz (620.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

anomalib-2.3.3-py3-none-any.whl (905.4 kB view details)

Uploaded Python 3

File details

Details for the file anomalib-2.3.3.tar.gz.

File metadata

  • Download URL: anomalib-2.3.3.tar.gz
  • Upload date:
  • Size: 620.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for anomalib-2.3.3.tar.gz
Algorithm Hash digest
SHA256 e850084d9854e2f3882b1d591af34120708c8c3c9a3b8b2f5a8595040fc9ff90
MD5 deddbd2f2692dc001240d060f6364422
BLAKE2b-256 90a45ff1b9c4c272c36cbd9f550859e71fe074157fdbd68b909d095c74441dcb

See more details on using hashes here.

Provenance

The following attestation bundles were made for anomalib-2.3.3.tar.gz:

Publisher: release-lib.yaml on open-edge-platform/anomalib

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file anomalib-2.3.3-py3-none-any.whl.

File metadata

  • Download URL: anomalib-2.3.3-py3-none-any.whl
  • Upload date:
  • Size: 905.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for anomalib-2.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 1198c322e4ece8158b3775268f3795be3171e5ea48376578b34092e259af61c6
MD5 dd599d507f930d207a07ca3c8f83d7bc
BLAKE2b-256 5f385ef0eb253c2fa2501a8306fd028f7730af27e04bdf6df7b29f1e6f85e21e

See more details on using hashes here.

Provenance

The following attestation bundles were made for anomalib-2.3.3-py3-none-any.whl:

Publisher: release-lib.yaml on open-edge-platform/anomalib

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page