<h1 align="center">AnomSeer: Reinforcing Multimodal LLMs for Time-Series Anomaly Detection</h1>




# Overview

**AnomSeer** is a reinforcement learning (RL) enhanced multimodal LLM framework for **time-series anomaly detection**.  
It leverages **TimerPO** reinforcement optimization and multimodal LLMs (e.g., **Qwen2.5-VL**) to improve anomaly reasoning and detection. 

# Installation

## 1. Set Up Conda Environment

```bash
conda create -n anomseer python=3.11 -y
conda activate anomseer

pip3 install torch==2.6.0 --index-url https://download.pytorch.org/whl/cu124
pip3 install flash-attn==2.7.4.post1 --no-build-isolation
pip3 install -e .
pip3 install vllm==0.8.2

pip3 install -r requirements_anomseer.txt
```

## 2. Data Preprocessing

Download the datasets **AnomLLM**, **VisualTimeAnomaly**, and **TSB-UAD**. Each dataset contains training and evaluation splits, as well as a `figs/` directory and a `data.pkl` file. Note that the images contain no annotations or shading. Place all datasets into the `./data/` directory.

Preprocess with:

```bash
python ./multimodal_data_processing/anom.py
```

## 3. Model Preparation

###  Training

Set backbone model:

- **Qwen2.5-VL-3B**

  ```bash
  MODEL_PATH=Qwen/Qwen2.5-VL-3B-Instruct
  ```

- **Qwen2.5-VL-7B**

  ```bash
  MODEL_PATH=Qwen/Qwen2.5-VL-7B-Instruct
  ```

Start training:

```bash
bash example/timerpo_trainer/run_anomseer.sh
```

Model checkpoints will be saved in:

```
./checkpoints/
```

### Evaluation

Enable evaluation mode by setting:

```bash
EVAL=True
```

in `example/timerpo_trainer/run_anomseer.sh`, then run:

```bash
bash example/timerpo_trainer/run_anomseer.sh
```

You can modify `data.val_files` to evaluate on other datasets.

# Usage Tips

- Ensure **CUDA 12.4** or compatible for `torch 2.6.0` and `flash-attn`.
- During evaluation, check the logs for **affinity-based Precision, Recall, and F1 scores** on the benchmark datasets.



# Acknowledgements

We thank the [veRL](https://github.com/volcengine/verl) project for foundational RL infrastructure.