RNN-T in Automatic Speech Recognition

The article explores the architecture and training processes of the RNN-T model in ASR.

Introduction

In this blog post, we will briefly discuss the popular transducer based model- RNN-T in speech recognition. It does not discuss everything from one particular paper but represents my understanding from multiple sources and Lugosch, 2020’s blog on the same topic. Lately, these models have shown popular interest in the industry due to its natural streaming ability.

Model Components

The RNN-T model comprises three modules: an encoder, a decoder, and a joiner network. Notably, the predictor in RNN-T operates in an autoregressive manner- meaning the previous output generated by the joiner is fed back into the predictor in order to predict the next output.

The joiner network combines the outputs of the encoder and predictor, generating a probability distribution over all labels and a null output (ϕ). Note that the predictor relies only on y (labels from the text transcript) rather than both x and y, unlike attention-based models. This means one can pre-train the predictor model on a large amount of text.

Greedy Search Algorithm

During the inference phase, RNN-T employs a greedy search algorithm. At each time step t, decisions are made by maximizing computed probabilities. If a label is selected, it is appended to the output sequence y; otherwise, if a blank label ϕ is encountered we move to the next time-step, maintaining the sequential prediction process.

Starting with t=1, u=0, and an empty set y=, the initial output (ht,u computed using ft and gt) unfolds with two scenarios:

  1. If argmax(ht,u) corresponds to a label (let’s say [A]), then y=A, and the time step t remains at 1.
  2. If argmax(ht,u) is ϕ (indicating a blank label), the predictor advances to the next time step, making t=2, i.e., t increments by 1.
Illustration of a greedy search algorithm in RNN-T. Reference (Lugosch, 2020)

Training Dynamics

Training RNN-T involves horizontal transitions for blank labels and vertical transitions for actual labels. The forward variable αt,u is computed using a recursive formula:

αt,u=ht,u1[yu1]αt,u1+ht1,u[ϕ]αt1,u

The above equation represents the computation of the forward variable αt,u. Following this computation, we derive the probability p(y|x), indicating the likelihood of a label given acoustic features, expressed as

p(y|x)=αT,UhT,U[ϕ]
Computation of forward variable in RNN-T training. Reference (Lugosch, 2020)

State-of-the-Art: Pruned RNN-T

A noteworthy advancement is introduced in the paper titled ‘‘Pruned RNN-T for fast, memory-efficient ASR training’’ (link). This involves a stateless prediction network, an alternative to the traditional RNN decoder. The predictor, similar to a bi-gram language model, simplifies the architecture by relying solely on the last output symbol, eliminating the need for recurrent layers. Its sole purpose lies in assisting the model to output an actual label or a blank label.

Alignment in RNN-T

The Transducer in RNN-T defines a set of possible monotonic alignments between the input sequence x and the output sequence y. These alignments, illustrated using an example with the word “CAT,” showcase the model’s ability to align labels with input features.

(This example along with the equation has been taken from Lugosch, 2020)

We can calculate the probability of one of these alignments by multiplying together the values of each edge along the path:

z=ϕ,C,A,ϕ,T,ϕ,ϕ p(z|x)=h1,0[ϕ]h2,0[C]h2,1[A]h2,2[ϕ]h3,2[T]h3,3[ϕ]h4,3[ϕ]

Conclusion

As we conclude the post, you now possess at least a basic understanding of RNN-T models and the functional principle behind it in the context of Automatic Speech Recognition (ASR). The way encoder, decoder, and joiner networks work together, along with features like stateless predictions, makes RNN-T easier to train.

Footnotes