We propose a joint model named MISCA for multi-intent detection and slot filling. Our MISCA introduces an intent-slot co-attention mechanism and an underlying layer of label attention mechanism. These mechanisms enable MISCA to effectively capture correlations between intents and slot labels, eliminating the need for graph construction. They also facilitate the transfer of correlation information in both directions: from intents to slots and from slots to intents, through multiple levels of label-specific representations, without relying on token-level intent information. Experimental results show that MISCA outperforms previous models, achieving new state-of-the-art overall accuracies of 59.1% on MixATIS and 86.2% on MixSNIPS.
Please CITE our paper whenever our MISCA implementation is used to help produce published results or incorporated into other software.
@inproceedings{MISCA,
title = {{MISCA: A Joint Model for Multiple Intent Detection and Slot Filling with Intent-Slot Co-Attention}},
author = {Thinh Pham and Chi Tran and Dat Quoc Nguyen},
booktitle = {Findings of the Association for Computational Linguistics: EMNLP 2023},
year = {2023},
pages = {12641–-12650}
}
- Python version >= 3.8
- PyTorch version >= 1.8.0
git clone https://github.com/VinAIResearch/MISCA.git
cd MISCA/
pip3 install -r requirements.txt
In our experiments, we train the base model without coattention first and initialize MISCA with this base model. To train the base model, you can run the experiments by the following command.
python main.py --token_level word-level \
--model_type roberta \
--model_dir dir_base \
--task <mixatis or mixsnips> \
--data_dir data \
--attention_mode label \
--do_train \
--do_eval \
--num_train_epochs 100 \
--intent_loss_coef <lambda> \
--learning_rate 1e-5 \
--train_batch_size 32 \
--num_intent_detection \
--use_crf
Then, once we have pre-trained base model, we can train MISCA by the following command:
python main.py --token_level word-level \
--model_type roberta \
--model_dir misca \
--task <mixatis or mixsnips> \
--data_dir data \
--attention_mode label \
--do_train \
--do_eval \
--num_train_epochs 100 \
--intent_loss_coef <lambda> \
--learning_rate 1e-5 \
--num_intent_detection \
--use_crf \
--base_model dir_base \
--intent_slot_attn_type coattention
We also provide model checkpoints of MISCA for MixATIS and MixSNIPS. Please download the checkpoint if you want to make inference without training from scratch.
We provide a script to predict intents and slots from utterances. To run it, please prepare a raw text file with one utterance per line, and run the following command:
python predict.py --token_level word-level \
--model_type roberta \
--model_dir misca \
--task <mixatis or mixsnips> \
--data_dir data \
--attention_mode label \
--num_intent_detection \
--use_crf \
--intent_slot_attn_type coattention \
--input_file input_file.txt \
--output_file output_file.txt
If you have any questions, please issue the project or email me (v.thinhphp1@vinai.io or thinhphp.nlp@gmail.com) and we will reply soon.
Our code is based on the implementation of the JointIDSF paper from https://github.com/VinAIResearch/JointIDSF