Skip to content

Kaldi-based goodness of pronunciation (GOP)

License

Notifications You must be signed in to change notification settings

jimbozhang/kaldi-gop

Repository files navigation

kaldi-gop

This project computes GMM-based GOP (Goodness of Pronunciation) using Kaldi.

Notes about the DNN-based implementation

This implementation is GMM-based. For DNN-based implementation, please check Kaldi's official repository:

https://github.com/kaldi-asr/kaldi/tree/master/egs/gop_speechocean762

The performance of GOP-DNN should be much better than GOP-GMM.

How to build

./build.sh

Run the example

cd egs/gop-compute
./run.sh

Theory

In the conventional GMM-HMM based system, GOP was first proposed in (Witt et al., 2000). It was defined as the duration normalised log of the posterior:

G O P ( p ) = 1 t e t s + 1 log p ( p | o )

where o is the input observations, p is the canonical phone, t s , t e are the start and end frame indexes.

Assuming p ( q i ) p ( q j ) for any q i , q j , we have:

log p ( p | o ) = p ( o | p ) p ( p ) q Q p ( o | q ) p ( q ) p ( o | p ) q Q p ( o | q )

where Q is the whole phone set.

The numerator of the equation is calculated from forced alignment result and the denominator is calculated from a Viterbi decoding with an unconstrained phone loop.

About

Kaldi-based goodness of pronunciation (GOP)

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published