segue-w2v2-base / README.md
soujanyaporia's picture
Update README.md
08a0f6d
metadata
datasets:
  - librispeech_asr
  - declare-lab/MELD
  - PolyAI/minds14
  - google/fleurs
language:
  - en
metrics:
  - accuracy
  - f1
  - mae
  - pearsonr
  - exact_match
tags:
  - audio
  - speech
  - pre-training
  - spoken language understanding
  - music
license: apache-2.0

Repository: https://github.com/declare-lab/segue

Paper: https://arxiv.org/abs/2305.12301

SEGUE is a pre-training approach for sequence-level spoken language understanding (SLU) tasks. We use knowledge distillation on a parallel speech-text corpus (e.g. an ASR corpus) to distil language understanding knowledge from a textual sentence embedder to a pre-trained speech encoder. SEGUE applied to Wav2Vec 2.0 improves performance for many SLU tasks, including intent classification / slot-filling, spoken sentiment analysis, and spoken emotion classification. These improvements were observed in both fine-tuned and non-fine-tuned settings, as well as few-shot settings.

How to Get Started with the Model

To use this model checkpoint, you need to use the model classes on our GitHub repository.

from segue.modeling_segue import SegueModel
import soundfile

# assuming this is 16kHz mono audio
raw_audio_array, sampling_rate = soundfile.read('example.wav')

model = SegueModel.from_pretrained('declare-lab/segue-w2v2-base')
inputs = model.processor(audio = raw_audio_array, sampling_rate = sampling_rate)
outputs = model(**inputs)

You do not need to create the Processor yourself, it is already available as model.processor.

SegueForRegression and SegueForClassification are also available. For classification, the number of classes can be specified through the n_classes field in model config, e.g. SegueForClassification.from_pretrained('declare-lab/segue-w2v2-base', n_classes=7). Multi-label classification is also supported, e.g. n_classes=[3, 7] for two labels with 3 and 7 classes respectively.

Pre-training and downstream task training scripts are available on our GitHub repository.

Results

We show only simplified MInDS-14 and MELD results for brevity. Please refer to the paper for full results.

MInDS-14 (intent classification)

Note: we used only the en-US subset of MInDS-14.

Fine-tuning

Model Accuracy
w2v 2.0 89.4±2.3
SEGUE 97.6±0.5

Note: Wav2Vec 2.0 fine-tuning was unstable. Only 3 out of 6 runs converged, the result shown were taken from converged runs only.

Frozen encoder

Model Accuracy
w2v 2.0 54.0
SEGUE 77.9

MELD (sentiment and emotion classification)

Fine-tuning

Model Sentiment F1 Emotion F1
w2v 2.0 47.3 39.3
SEGUE 53.2 41.1
SEGUE (higher LR) 54.1 47.2

Note: Wav2Vec 2.0 fine-tuning was unstable at the higher LR.

Frozen encoder

Model Sentiment F1 Emotion F1
w2v 2.0 45.0±0.7 34.3±1.2
SEGUE 45.8±0.1 35.7±0.3

Limitations

In the paper, we hypothesized that SEGUE may perform worse on tasks that rely less on understanding and more on word detection. This may explain why SEGUE did not manage to improve upon Wav2Vec 2.0 on the Fluent Speech Commands (FSC) task. We also experimented with an ASR task (FLEURS), which heavily relies on word detection, to further demonstrate this.

However, this is does not mean that SEGUE performs worse on intent classification tasks in general. MInDS-14, was able to benifit greatly from SEGUE despite also being an intent classification task, as it has more free-form utterances that may benefit more from understanding.

Citation

@inproceedings{segue2023,
  title={Sentence Embedder Guided Utterance Encoder (SEGUE) for Spoken Language Understanding},
  author={Tan, Yi Xuan and Majumder, Navonil and Poria, Soujanya},
  booktitle={Interspeech},
  year={2023}
}