/myprosody

A Python library for measuring the acoustic features of speech (simultaneous speech, high entropy) compared to ones of native speech.

Primary LanguagePythonMIT LicenseMIT

myprosody

*** Version-10 release: two new functions were added ***

NEW VERSION: the prosodic features of speech (simultaneous speech) compared to the features of native speech ***spoken language proficiency level estimator

A Python library for measuring the acoustic features of speech (simultaneous speech, high entropy) compared to ones of native speech.

Prosody is the study of the tune and rhythm of speech and how these features contribute to meaning. Prosody is the study of those aspects of speech that typically apply to a level above that of the individual phoneme and very often to sequences of words (in prosodic phrases). Features above the level of the phoneme (or "segment") are referred to as suprasegmentals. A phonetic study of prosody is a study of the suprasegmental features of speech. At the phonetic level, prosody is characterised by:

  1. vocal pitch (fundamental frequency)
  2. acoustic intensity
  3. rhythm (phoneme and syllable duration)

MyProsody is a Python library for measuring these acoustic features of speech (simultaneous speech, high entropy) compared to ones of native speech. The acoustic features of native speech patterns have been observed and established by employing Machine Learning algorithms. An acoustic model (algorithm) breaks recorded utterances (48 kHz & 32 bit sampling rate and bit depth respectively) and detects syllable boundaries, fundamental frequency contours, and formants. Its built-in functions recognize/measures:

                     o	Average_syll_pause_duration 
                     o	No._long_pause /o	Speaking-time 
                     o	No._of_words_in_minutes
                     o	Articulation_rate
                     o	No._words_in_minutes
                     o	formants_index
                     o	f0_index ((f0 is for fundamental frequency)
                     o	f0_quantile_25_index 
                     o	f0_quantile_50_index 
                     o	f0_quantile_75_index 
                     o	f0_std 
                     o	f0_max 
                     o	f0_min 
                     o	No._detected_vowel 
                     o	perc%._correct_vowel
                     o	(f2/f1)_mean (1st and 2nd formant frequencies)
                     o	(f2/f1)_std
                     o	no._of_words
                     o	no._of_pauses
                     o	intonation_index 
                     o	(voiced_syll_count)/(no_of_pause)
                     o	TOEFL_Scale_Score 
                     o	Score_Shannon_index
                     o	speaking_rate
                     o	gender recognition
                     o	speech mood (semantic analysis)
                     o	pronunciation posterior score
                     o	articulation-rate 
                     o	speech rate 
                     o	filler words
                     o	f0 statistics
                     -------------
                     NEW
                     --------------
                     o level (CEFR level)
                     o prosody-aspects (comparison, native level)

The library was developed based upon the idea introduced by Klaus Zechner et al “Automatic scoring of non-native spontaneous speech in tests of spoken English” Speech Communicaion vol 51-2009, Nivja DeJong and Ton Wempe [1], Paul Boersma and David Weenink [2], Carlo Gussenhoven [3], S.M Witt and S.J. Young [4] , and Yannick Jadoul [5].

Peaks in intensity (dB) that are preceded and followed by dips in intensity are considered as potential syllable cores. MyProsody is unique in its aim to provide a complete quantitative and analytical way to study acoustic features of a speech. Moreover, those features could be analysed further by employing Python's functionality to provide more fascinating insights into speech patterns.

This library is for Linguists, scientists, developers, speech and language therapy clinics and researchers.

Please note that MyProsody Analysis is currently in initial state though in active development. While the amount of functionality that is currently present is not huge, more will be added over the next few months.

Installation

Myprosody can be installed like any other Python library, using (a recent version of) the Python package manager pip, on Linux, macOS, and Windows:

                                    pip install myprosody

or, to update your installed version to the latest release:

                                    pip install -u myprosody

NOTE:

After installing Myprosody, download the folder called:

                                  myprosody

from

https://github.com/Shahabks/myprosody

and save on your computer. The folder includes the audio files folder where you will save your audio files for analysis.

Audio files must be in *.wav format, recorded at 48 kHz sample frame and 24-32 bits of resolution.

To check how the myprosody functions behave, please check

                                EXAMPLES.pdf

on

https://github.com/Shahabks/myprosody

Development

Myprosody was developed by MYOLUTIONS Lab in Japan. It is part of New Generation of Voice Recognition and Acoustic & Language modelling Project in MYSOLUTIONS Lab. That is planned to enrich the functionality of Myprosody by adding more advanced functions.

References and Acknowledgements

  1. DeJong N.H, and Ton Wempe [2009]; “Praat script to detect syllable nuclei and measure speech rate automatically”; Behavior Research Methods, 41(2).385-390.

  2. Paul Boersma and David Weenink; http://www.fon.hum.uva.nl/praat/

  3. Gussenhoven C. [2002]; “ Intonation and Interpretation: Phonetics and Phonology”; Centre for Language Studies, Univerity of Nijmegen, The Netherlands.

  4. Witt S.M and Young S.J [2000]; “Phone-level pronunciation scoring and assessment or interactive language learning”; Speech Communication, 30 (2000) 95-108.

  5. Jadoul Y. https://parselmouth.readthedocs.io/en/latest/installation.html