# S3Net: Sleep Stage Classification

This repository contains the code for the S3Net model.

## Requirements

- Packages are listed in `requirements.txt`.

## How to Run

### 1. Setup
First, clone the repository and install the necessary dependencies.
```bash
pip install -r requirements.txt
```

### 2. Prepare Data

Downloads full data in https://sleeptight.isr.uc.pt/

**a. Preprocess Raw Data**

Before running, you **must** update the file paths inside `rawdata_preprocess.py`.

```python
# Inside rawdata_preprocess.py
path_Extracted = '/path/to/your/ExtractedChannels/'
path_RawData = '/path/to/your/RawData/'
```
Then, run the script to create a processed data file.
```bash
python rawdata_preprocess.py
```

**b. Generate STFT Features**

Use the file generated above to create STFT features and prepare datasets.
```bash
python SleepDataLoader.py --rawdata ./data/ISRUC_S3.npz --output ./data_s3
```

### 3. Train the Model
Train the model using 10-fold cross-validation. The best model for each fold will be saved in the `./results` directory.
```bash
# Use --device 0 to train on the first GPU
python train.py --device 0
```

### 4. Evaluate the Model
After training, run the evaluation script to see the performance metrics.
```bash
# Evaluate on the first GPU
python evaluate.py --device 0

```
The results, including accuracy and a confusion matrix, will be saved in `./eval_results/results.txt`.