Skip to content

Speech Self-Attention Exploratory Visual Environment

License

Notifications You must be signed in to change notification settings

erfanashams/steve

Repository files navigation

STEVE (Speech Transformer Exploratory Visual Environment)

This is a tool for visualising self-attention weights in transformer-based speech recognition models with or without time-aligned annotations.

STEVE screenshot annotated.

Developers/Authors

Erfan A. Shams, Julie Carson-Berndsen

Installation and Usage

Clone the repository using the command below:

git clone https://github.com/erfanashams/steve.git

Navigate to w2v2viz folder and install the requirements:

cd steve
pip install -r requirements.txt

How to use

  1. Extract the self-attention weights in the following format: N×1×M×K×Q, where N is the number of layers, M is the number of self-attention heads, K and Q are the Key and Query dimensions respectively. For example, the code below allows self-attention head extraction from the Whipsr-base model and stores them in the encoder_attn variable with the dimension 6×1×8×1500×1500:

Warning

This method of registering forward hook is tested and works on version 20231117, however, it does not work with version 20240930 (or possibly newer). You may want to use the HuggingFace version for extrcting the self-attention weights or calculate the self-attention weights from the QK vectors as shown in test_whisper_attn.py.

Load Whisper-base model and install forward hooks on self-attention heads:

import torch
import librosa
import whisper
from whisper.tokenizer import get_tokenizer


DEVICE = "cuda" if torch.cuda.is_available() else "cpu"

model_size = "base"
model = whisper.load_model(model_size).to(DEVICE)

# install hooks on the encoder attention layers to retrieve the attention weights
encoder_attn = [None] * model.dims.n_audio_layer
for i, block in enumerate(model.encoder.blocks):
    block.attn.register_forward_hook(
        lambda _, ins, outs, index=i: encoder_attn.__setitem__(index, outs[-1])
    )

# Load Whisper tokenizer
tokenizer = get_tokenizer(model.is_multilingual, language='en')

# ...

Inference steps for whisper are given below:

# ...

file = "path_to_your_wav_file"
speech_, sr_ = librosa.load(path=file, sr=16000)
speech_ = torch.from_numpy(speech_).float()

tokens = torch.tensor(
        [
            *tokenizer.sot_sequence,
            tokenizer.timestamp_begin,
        ]
    ).to(DEVICE)

mel = whisper.log_mel_spectrogram(whisper.pad_or_trim(speech_)).to(DEVICE)

with torch.no_grad():
    logits = model(mel.unsqueeze(0), tokens.unsqueeze(0))

# ...

The audio sample per frame spf is also needed to be calculated or extracted from the model parameters. Refer to the paper for this step. For all whisper models spf is 320, but may need to be calculated for other models such as wav2vec 2.0 (you may also refer tp test_wav2vec2_attn.py).

# ...

spf = 320

# ...
  1. Import and run the visualiser using the required ad optional parameters:
# ...

from steve import STEVE


steve = STEVE()
steve.plot_attentions(file_name=[file], attention=[encoder_attn], spf=[spf],
                      alignments="", tg_phone=None, tg_word=None, tg_text=None,
                      tg_ext="textgrid", debug=False)

Required parameters:

  • file_name: string literal of the wav file or a list of files.
  • attention: the extracted attentions or a list of extracted attentions mentioned above.
  • spf: audio sample per frame of the model.

Optional parameters:

  • alignments: "timit" or "textgrid" if alignments in any of the given formats are available.
  • tg_phone: textgrid phone tier name or TIMIT style phonetic alignment file extension (e.g., "phn").
  • tg_word: textgrid word tier name or TIMIT style word alignment file extension (e.g., "wrd").
  • tg_phone: textgrid text tier name or TIMIT style text file extension (e.g., "txt").
  • tg_ext: extension of the textgrid files (e.g., "TextGrid").
  • debug: display various steps during the visualisation process.

Tip

Complete examples for Whisper (test_whisper_attn.py) and wav2vec 2.0 (test_wav2vec2_attn.py) with annotations are available in the mentioned files. The audio files for TIMIT are taken from the free sample at https://catalog.ldc.upenn.edu/LDC93S1, and the TextGrid sample is taken from L2-ARCTIC at https://psi.engr.tamu.edu/l2-arctic-corpus/.

Important

The wav2vec 2.0 from the transformers module returns self-attention weights after softmax. This behaviour does not allow the visualiser to show the weights without the softmax function applied. A workaround would be to return the non-softmax version by modifying the source code. The patch file in the wav2vec2_patch directory demonstrates which lines need to be modified in the source.

Important

You may need to enable interactive mode for Jupyter notebooks.

Cite as

@InProceedings{10.1007/978-3-031-70566-3_8,
author="Shams, Erfan A.
and Carson-Berndsen, Julie",
editor="N{\"o}th, Elmar
and Hor{\'a}k, Ale{\v{s}}
and Sojka, Petr",
title="Attention to Phonetics: A Visually Informed Explanation of Speech Transformers",
booktitle="Text, Speech, and Dialogue",
year="2024",
publisher="Springer Nature Switzerland",
address="Cham",
pages="81--93",
isbn="978-3-031-70566-3"
}

About

Speech Self-Attention Exploratory Visual Environment

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages