Skip to content

The research project for designing ML model to convert the Nepali speech to Devnagari text

License

Notifications You must be signed in to change notification settings

qzd-1/ASR-Nepali-using-CNN-BiLSTM-ResNet

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

10 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Automatic Speech Recognition for the Nepali Language using CNN, Bidirectional LSTM and, ResNet

Keywords

Speech To Text, Nepali, CNN, ResNet, BiLSTM, CTC

Intorduction

This repo is a part of the research project for designing the automatic speech recogntion(ASR) model for Nepali language using ML techniques. The conference for this paper has been published in 2022 International Conference on Inventive Computation Technologies (2022 ICICT).

Things to consider before

  • You are free to use this research as a reference and make modifications to continue your own research in Nepali ASR.
  • The trainer.py has been implemented to run on the sampled data for now. To replicate the result please replace dataset directory with original OpenSLR dataset.
  • Please remove the (audio, text) pairs that include Devnagari numeric texts like १४२३, ५९२, etc from the dataset because they degrade the performance of dataset.

Our approach

  1. Remove the (audio, text) pairs that include Devnagari numeric transcriptions
  2. Data cleaning (clipping silent gaps from both ends)
  3. MFCC feature extraction from audio data
  4. Design Neural Network (optimal: CNN + ResNet + BiLSTM) model
  5. Calculate CTC loss for applying gradient (training)
  6. Decode the texts by using beam search decoding (infernce)

Architecture

Res_block

Model

Running the project

  1. Initialize the virtual environment by installing packages from requirements.txt.
  2. Run the training pipeline & evaluate authors model, which can be also be used to evaluate your own (audio,text) pairs.
python trainer.py   # For running the training pipeline
python eval.py      # For testing and evaluating the model already trained by the author

Results

Models and Their character error rate (CER) on Test Data (5% of Total Data.)

Model Test Data CER # Params
BiLSTM 19.71% 1.17M
1D-CNN + BiLSTM 24.6% 1.55M
1D-CNN + ResNet + BiGRU 29.6% 1.30M
✓ 1D-CNN + ResNet + BiLSTM ✓ 17.06% ✓ 1.55M
1D-CNN + ResNet + LSTM 30.27% 0.88M

Cite this paper

The bibtex for citing this paper:

@inproceedings{dhakal2022automatic,
  title={Automatic speech recognition for the Nepali language using CNN, bidirectional LSTM and ResNet},
  author={Dhakal, Manish and Chhetri, Arman and Gupta, Aman Kumar and Lamichhane, Prabin and Pandey, Suraj and Shakya, Subarna},
  booktitle={2022 International Conference on Inventive Computation Technologies (ICICT)},
  pages={515--521},
  year={2022},
  organization={IEEE}
}

For any queries email the author here.

About

The research project for designing ML model to convert the Nepali speech to Devnagari text

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%