This is the implementation of the paper "EEG-Based Emotion Recognition via Prototype-Guided Disambiguation and Noise Augmentation in Partial-Label Learning"

This repository contains the source code of our paper, using three publicly available dataset, The public available datasets (SEED ,SEED-IV and SEED-V) can be downloaded from the https://bcmi.sjtu.edu.cn/home/seed/index.html

## Prerequisites
Please follow the steps below in order to be able to train our models:  


1 - Install Requirements

```
pip3 install -r ./requirements.txt
```

2 - Download the extracted differential entropy features and labels provided by the dataset. e.g. Follow the [SEEDV_data preparation](./SEEDV_data_preparation.py) code while strictly following the official dataset description.  


3 - Usage: In order to have a user-friendly interface, we provide bash files "start.sh", "run.sh" and input files in the "input_SEEDV" folder for runing our method and all the baseline methods under various settings.  For example, run the command to execute the bash file:  
```
nohup bash ./start.sh &
```
Note: This provides the method to start experiments on the SEED-V dataset. If you want to run it on SEED or SEED-IV, modify the second line (emotion category) of the different methods in the input folder to 3 or 4, respectively.

Important parameters are specified in the "input" folder, which is predefined for the input corresponding to `/run.sh`. 
These may include integers, strings, or boolean values. For the method name, choose one of 'PGNA_PL','DNPL', 'PiCO', 'PaPI', 'PRODEN', 'CAVL', 'CR', 'LW'. For label disambiguation, choose 'true' or 'false' to decide whether to use the label disambiguation progress. For partial label type, choose 'Semantic_Distribution' or 'Russel_Distribution'.  
For the PGNA-PL method, choose '2' to be the temperature coefficient in self-distillation. And the last line means the parameter in the Beta Distribution.
For the PiCO method, choose 'true' or 'false' to determine whether contrastive learning should be used, and choose '64' to be the queue size.
For loss name in the LW method, choose 'sigmoid' or 'cross_entropy'. For beta values, choose '0.0', '1.0', or '2.0'. In which 'cross-entropy' and '2.0' were used in the baseline evaluation.  

 ## Script Description  
- `/parsing`: includes argument specifications for all partial label learning methods.  
- `/backbone_model`: includes the backbone model for all the methods. - `/backbone_model`: includes the backbone model for all the methods. Note: We provide the MLP class as the encoder in lines 240-288 to facilitate the reproduction of the experiments in Appendix 8.  
- `/train_func`: includes the training steps for all partial label learning methods, for EEG representation learning in emotion recognition tasks.  
- `/main`: includes implementation of experiments for PGNA-PL and baseline methods.  
- `/utils`: includes model paramter initialization, methods for generating candidate labels based on our Semantic distribution and the Russel distribution settings, a custom PyTorch data loader, as well as some predefined loss functions.  
# Evaluation  
- `/ComputeACC`: The mean of the accuracy under different distribution settings in each method.  
- `/ComputeConfusion`: Calculate the confusion matrix and two F1 scores under the two distribution settings in each method.   
# Figures Generation
- `/ComputeConfusion`：For the generation of Figures about the confusion matrixs.  
- `/visualization`: For the generation of visualization fugures in the text, the data is from prototype data saved at the completion of the best model  
# Embeddings From GloVe
- `/GloVe_Embeddings/seedv_emotions`: The embeddings of adjectives corresponding to the five emotions in the SEED-V dataset are provided based on GloVe.

The sources of randomness are controlled (same as the baseline evaluation), ensuring that all results presented in the paper can be replicated using the codes provided in this repository. 

Acknowledgment:

This project leveraged certain functions from the open-source code provided in [arXiv preprint arXiv:2302.13170, 2023].

We express our gratitude to the authors for making their code available. We refrain from mentioning the authors' names here to comply with the blind review process, but will include the relevant details or project link once the code is officially released.
