# 🐍 DeR-Mamba

This is the official implementation of **DeR-Mamba**.

---

## 📋 1. Requirements

### 🔧 Main Package Requirements

*   **CUDA** == 11.7
*   **Python** == 3.9
*   **PyTorch** == 1.12.1
*   **PyTorch-Geometric** == 2.0.1

### 📦 Installation

To install the complete requiring packages, use the following command at the root directory of the repository:

```bash
pip install -r requirements.txt
```

---

## 🚀 2. Quick Start

### 🏋️ Training

To train **DeR-Mamba**, run the following command in the ROOT directory:

```bash
python main.py --dataset collab --load_best_config
```

Or specify custom hyperparameters:

```bash
python main.py --dataset collab --lr 0.0025 --weight_decay 1e-3 --num_layers 1 --hidden_channels 32 --num_heads 1 --rb_order 1 --rb_trans sigmoid --M 30 --K 10 --use_bn --use_residual --use_gumbel --epochs 2000 --beta1 0.1 --beta2 50.0 --gamma 0.0025 --lamda_1 0.0025 --mu 1.0 --patience 1000
```

You can specify other datasets by changing the `--dataset` argument. (collab\yelp\act)

### 🧪 Evaluation

To evaluate **DeR-Mamba** with trained models, run the following command in the ROOT directory:

```bash
python eval.py --dataset=<dataset_name> --exp_type=<exp_mode> --load_best_config
```

#### 💡 Examples

Evaluation on the Yelp dataset:

```bash
python eval.py --dataset=yelp --exp_type=clean --load_best_config
python eval.py --dataset=yelp --exp_type=structure --load_best_config
```

Other experiment types such as `feature`, `evasive`, `poisoning`, etc., are similar.

---

## 📂 Project Structure

```
DeR-Mamba/
├── 📄 main.py                    # Main script for training the model
├── 📄 eval.py                    # Script for evaluating trained models
├── 📄 REDGSL.py                  # Core implementation of the DeR-Mamba framework
├── 📄 config.py                  # Configuration and hyperparameter management
├── 📁 selective_modeling/        # Mamba-based selective state space models
└── 📁 data/                      # Dataset directory (collab, yelp, act)
```
