pwenker's picture
chore: Minor improvements and fixes
2a67a0f
|
raw
history blame
4.75 kB
metadata
title: Pronunciation Trainer
emoji: πŸ—£οΈ
colorFrom: blue
colorTo: red
sdk: gradio
app_file: src/pronunciation_trainer/app.py

Pronunciation Trainer πŸ—£οΈ

This repository/app showcases how a phoneme-based pronunciation trainer (including personalized LLM-based feedback) overcomes the limitations of a grapheme-based approach

For convenience, you find a feature comparison overview of the two solutions below:

Feature Grapheme-Based Solution Phoneme-Based Solution
Input Type Text transcriptions of speech Audio files and phoneme transcriptions
Feedback Mechanism Comparison of grapheme sequences Comparison of phoneme sequences and advanced LLM-based feedback
Technological Approach Simple text comparison using SequenceMatcher Advanced ASR models like Wav2Vec2 for phoneme recognition
Feedback Detail Basic similarity score and diff Detailed phoneme comparison, LLM-based feedback including motivational and corrective elements
Error Sensitivity Sensitive to homophones and transcription errors More accurate in capturing pronunciation nuances
Suprasegmental Features Does not capture (stress, intonation) Potentially captures through phoneme dynamics and advanced evaluation
Personalization Limited to error feedback based on text similarity Advanced personalization considering learner's native language and target language proficiency
Scalability Easy to scale with basic text processing tools Requires more computational resources for ASR and LLM processing
Cost Lower, primarily involves basic computational resources Higher, due to usage of advanced APIs and model processing
Accuracy Lower, prone to misinterpretations of homophones Higher, better at handling diverse pronunciation patterns (but LLM hallucinations)
Feedback Quality Basic, often not linguistically rich Rich, detailed, personalized, and linguistically informed
Potential for Learning Limited to recognizing text differences High, includes phonetic and prosodic feedback, as well as resource and practice recommendations

Quickstart πŸš€

πŸ‘‰ Click here to try out the app directly:

Pronunciation Trainer App

πŸ” Inspect the code at:

πŸ“š Read about the pronunciation trainer:

  1. Grapheme-based Approach
  2. Phoneme-based Approach

Local Deployment 🏠

Prerequisites πŸ“‹

Rye 🌾

Install Rye

Rye is a comprehensive tool designed for Python developers. It simplifies your workflow by managing Python installations and dependencies. Simply install Rye, and it takes care of the rest.

  • Create a .env file in the pronunciation_trainer folder and add the following variable:

OPENAI API Token πŸ”‘

OPENAI_TOKEN=... # Token for the OpenAI API

Set-Up πŸ› οΈ

Clone the repository:

git clone [repository-url] # Replace [repository-url] with the actual URL of the repository

Navigate to the directory:

cd pronunciation_trainer

Create a virtual environment in .venv and synchronize the repo:

rye sync

For more details, visit: Basics - Rye

Start the App 🌟

Launch the app using:

rye run python src/pronunciation_trainer/app.py

Then, open your browser and visit http://localhost:7860 to start practicing!