# KANomaly: Fourier-KAN-based Multi-Scale Patch Mixer for Multivariate Time Series Anomaly Detection

This repository includes the source code for our anonymous submission to ICLR 2026, "KANomaly: Fourier-KAN-based Multi-Scale Patch Mixer for Multivariate Time Series Anomaly Detection".


## ⚙️ Requirements
This project was implemented and tested using Python 3.10.13.

The following packages are required to run KANomaly:

```
einops==0.8.0
numpy==1.26.2
pandas==2.2.3
pkbar==0.5
scikit_learn==1.6.0
timm==1.0.15
torch==2.1.2
torchinfo==1.8.0
```

To install all dependencies, run:
```
pip install -r requirements.txt
```

🔍 **Note:** For best compatibility, we recommend using a virtual environment (e.g., `venv` or `conda`).


## 📦 Dataset Preparation
All well pre-processed datasets used in our experiments (MSL, PSM, SMAP, SMD, and SWaT) can be downloaded from the following publicly available repository:

👉 https://github.com/thuml/Time-Series-Library

Please place them under the `dataset/` directory using the structure shown in the [📁 Folder Structure](#📁-folder-structure) section below.


## 📁 Folder Structure
Due to the size limitations of the Supplementary Material, only the MSL dataset is included in the submission. The remaining datasets can be placed by following the directory structure below, where we also provide trained model weights for each dataset under the `checkpoints/` directory.
The full directory structure is illustrated below:
```
KANomaly
├── checkpoints
│   ├── MSL_checkpoint.pth
│   ├── PSM_checkpoint.pth
│   ├── SMAP_checkpoint.pth
│   ├── SMD_checkpoint.pth
│   └── SWaT_checkpoint.pth
├── data_factory
│   ├── __init__.py
│   └── data_loader.py
├── dataset
│   ├── MSL
│   │   ├── MSL_test.npy
│   │   ├── MSL_test_label.npy
│   │   └── MSL_train.npy
│   ├── PSM
│   │   ├── test.csv
│   │   ├── test_label.csv
│   │   └── train.csv
│   ├── SMAP
│   │   ├── SMAP_test.npy
│   │   ├── SMAP_test_label.npy
│   │   └── SMAP_train.npy
│   ├── SMD
│   │   ├── SMD_test.npy
│   │   ├── SMD_test_label.npy
│   │   └── SMD_train.npy
│   └── SWaT
│       ├── swat2.csv
│       └── swat_train2.csv
├── layers
│   └── KANlayers.py
├── models
│   └── KANomaly.py
├── scripts
│   ├── MSL.sh
│   ├── MSL_test.sh
│   ├── PSM.sh
│   ├── PSM_test.sh
│   ├── SMAP.sh
│   ├── SMAP_test.sh
│   ├── SMD.sh
│   ├── SMD_test.sh
│   ├── SWaT.sh
│   └── SWaT_test.sh
├── utils
│   └── utils.py
├── README.md
├── exp_AD.py
├── main.py
└── requirements.txt
```


## 🧩 Code Description
This section briefly describes the key components of the repository:

- `checkpoints/`  
  Contains trained model weights for each dataset (MSL, PSM, SMAP, SMD, and SWaT). These weights can be used to directly evaluate the model’s performance on the corresponding test sets.

- `data_factory/`  
  Includes data loading utilities. The `data_loader.py` file handles dataset preprocessing and segmentation.

- `dataset/`  
  Contains the input datasets. Each subdirectory holds the corresponding well-preprocessed train/test files and labels.

- `layers/`  
  Contains the implementation of Kolmogorov–Arnold Network (KAN) layers in `KANlayers.py`, used in the KANomaly model.

- `models/`  
  Contains the main KANomaly model architecture implemented in `KANomaly.py`.

- `scripts/`  
  Includes shell scripts for training and testing on each dataset.

- `utils/`  
  Utility functions implemented in `utils.py`, such as learning rate adjustment and early stopping.

- `main.py`  
  The entry point of the project. It manages all hyperparameters and parses arguments.

- `exp_AD.py`  
  A Python script that handles anomaly detection experiments using the KANomaly model, including the training, validation, and testing processes.

- `README.md`  
  This file. Provides an overview of the project and instructions for usage.


## 🚀 Get Started
1. **Install the required dependencies.**  
Refer to the [⚙️ Requirements](#⚙️-requirements) section and install the required Python packages. We recommend using a virtual environment for compatibility.

2. **Prepare the datasets.**  
Follow the instructions in the [📦 Dataset Preparation](#📦-dataset-preparation) section to place the datasets under the `dataset/` directory.

3. **Reproduce results using trained model weights.**  
To reproduce the performance reported in the paper, use the pre-trained model weights provided in the `checkpoints/` directory. Run the corresponding shell script to evaluate the model on each dataset:
    ```
    bash ./scripts/MSL_test.sh
    bash ./scripts/PSM_test.sh
    bash ./scripts/SMAP_test.sh
    bash ./scripts/SMD_test.sh
    bash ./scripts/SWaT_test.sh
    ```

4. **Run training and testing scripts.**  
Use the shell scripts provided under the `scripts/` directory to train and test the model on each dataset. You can run them as follows:
    ```
    bash ./scripts/MSL.sh
    bash ./scripts/PSM.sh
    bash ./scripts/SMAP.sh
    bash ./scripts/SMD.sh
    bash ./scripts/SWaT.sh
    ```


## 📄 License
- This project is intended to be released under the MIT License upon acceptance.
- The complete source code and documentation will be made publicly available through a GitHub repository after the peer-review process.