Kathabhidhana consists of a few Free/Libre and Open Source Software, documentation to learn and use it, and open datasets that you can customize and shape your metadata.
|“||Almost half of the 6909 living languages of the world are dying in a century’s time. In India alone, over 220 Indian languages out of the total of 780 languages have died only in last 50 years. With these languages, there dies a wealth of knowledge forever||”|
Kathabhidhana is an open toolkit to record a large number of words. It consists of a few free/libre and open source software, open datasets, methodologies and documentations. It can be used to record pronunciations of words to make a talking dictionary to record phonemes to create a text-to-speech software.
We truly believe in openness and the FLOSS philosophy. So every single component of this toolkit is open. It also contains other dependency FLOSS tools that are built by many kind people in the open source movement.
- A tool with many faces
Wikipedia has a sister project called Wiktionary, a multilingual dictionary where you can not just find meaning of words from your own language but also equivalent meanings of foreign language words. Unlike many available dictionaries that help learn proununciations, Wiktionary does not have pronunciations of all words in all the languages. Kathabhidhana was originally started by Subhashish Panigrahi to add pronunciations to the Odia-language Wiktionary. It is adopted from a free software created by Shrinivasan T. It works both on Linux and Mac. The iOS version of Kathabhidhana was created by Prateek Pattanaik. You can certainly create pronunciations and add them to Wiktionary. But you can use Kathabhidhana beyond that by making a large library of pronunciations that can be used to build any machine learning or Natural Language Processing (NLP) tool.
What Does this toolkit contain?
- Using a computer?
- Linux or macOS
- Linux running in a virtual machine
- Using an iOS device? (check more here)
- iOS (iPad or iPhone)
- Workflow (app)
How to use it?
- Download and set up Kathabhidhana (see the next section)
- Set up your recording hardware (see mine in the picture above) e.g. microphone (if using an external one), computer settings like level
- Record using Kathabhidhana
- Batch processing using (tutorial coming soon, download Audacity from here)
- Manual clean up of each file (tutorial coming up soon)
- Setting up Pattypan and upload files on Commons (download from here)
The installation can be done using command-line on a Linux or Mac computer, or using any iOS device.
ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" < /dev/null 2> /dev/null
brew install portaudio
brew install vorbis-tools
sudo easy_install pip
sudo pip install pyaudio
Running the tool
1. Go to the file called "file". Replace all words with the words you want to record
2. Run the command below (it will record both as .wav and .ogg)
python voice-record.py 2> err</code)
3. Go to the path by using
cd command in your terminal For instance, in my computer, it is the "Kathabhidhana" folder under "Documents". Then run:
The next steps are quite self-explanatory. You need to choose "Y" for yes and "N" for no in the following options inside your terminal.
To upload all the ogg files to Wikimedia Commons This will record the sounds in .ogg and .wav formats. You can then use a tool like Pattypan to batch-upload either the .WAV or the .ogg files on Wikimedia Commons.
Findings so far
• It takes about 20-25 mins to record 100 words; A batch processing to convert and do overall auto-cleanup using Audacity will take about 5 mins for a 100-word-batch; It takes an average of 30 secs for 1 word to manually clean up, check quality, trim extra portions and other such editing work (meaning it will take about 45 mins to clean up a batch of 100 words) using Audacity; It takes about 5-10 mins for setting up Pattypan to upload the cleaned up words on Wikimedia Commons; On an average one would spend roughly about 1.5 hrs from recording to cleaning up to uploading for a batch of 100 words
How these recordings can be used?
Kathabhidhana helps you create a pronunciation library with a large number of words in any given language. These recordings can be used to better
- and create a library of pronunciation of words by native speaker that can be used to better:
- machine learning tools like speech-to-text and text-to-speech as audio libraries are building blocks of both these kind of software developement
- the available/nonexistent screenreader app in any language that is extremely vital for visually disabled people
- any open source smart home or personal assistant app help people with disability and everyone else
- dictionaries with native pronunciation support
- document the contemporary version of the intonation, accent and speech pattern of a language that can be useful in the future for any linguistic research
- Project led by Subhashish Panigrahi and the iOS tool is led by Prateek Pattanaik. All the media and text content are available under a CC-BY-SA 4.0 license
- All the software component is licensed under GNU General Public License (GPL) version 3 (read the License page for more details)
- This project and part of the documentation are based on the Voice recorder for Tawiktionary project created by Shrinivasan T (please attribute Shrinivasan T if you're making a derivative of the software)
- Panigrahi, Subhashish. "A simple command-line tool for recording audio". Opensource.com (May 12, 2017)
- Ojha, Bikash. Mishra, Chinmayee. Pattanaik, Prateek. Panigrahi, Subhashish. Patnaik, Sailesh. Elsharbaty, Samir. "Community digest: As Odia Wikisource turns two, a project to digitize rare books kicks off; news in brief". Wikimedia Blog (March 30, 2017)
- Rezwan. "A New Audio Uploading Tool for Crowdsourced Wiktionary Project in Odia Language". Global Voices (February 13, 2017)
- "Workshop "Kathabhidhana: Recording words for Wiktionary and preparing for an AI assistant". Wikimania 2017, Montreal, Canada. (Selected for workshop on August 12. Check back in late August for more updates about the workshop)
- "Kathabhidhana, open source toolkit to record pronunciations of any world language". Celtic Knot Conference 2017, University of Edinburgh. (Selected, Workshop on July 6)
- "How to make your language Machine Learning and NLP friendly with an audio documentation toolkit". The Fifth Elephant 2017, Bengaluru, India. (Selected, Talk during July 27–28)