Audio Transcription is a Chrome extension that allows users to capture any audio playing on the current tab and transcribe it using OpenAI-whisper in real time. Users will have the option to do voice activity detection as well to not send audio to server when there is no speech.
We use OpenAI-whisper model to process the audio continuously and send the transcription back to the client. We apply a few optimizations on top of OpenAI's implementation to improve performance and run it faster in a real-time manner. To this end, we used faster-whisper which is 4x faster than OpenAI's implementation.
- Open the Google Chrome browser.
- Type chrome://extensions in the address bar and press Enter.
- Enable the Developer mode toggle switch located in the top right corner.
- Clone this repository
- Click the Load unpacked button.
- Browse to the location where you cloned the repository files and select the
Audio Transcription
folder. - The extension should now be loaded and visible on the extensions page.
This Chrome extension allows you to send audio from your browser to a server for transcribing the audio in real time. It can also incorporate voice activity detection on the client side to detect when speech is present, and it continuously receives transcriptions of the spoken content from the server. You can select from the options menu if you want to run the speech recognition.
To capture the audio in the current tab, we used the chrome tabCapture
API to obtain a MediaStream
object of the current tab.
When using the Audio Transcription extension, you have the following options:
- Use Collabora Server: We provide a demo server which runs the whisper small model.
- Language: Select the target language for transcription or translation. You can choose from a variety of languages supported by OpenAI-whisper.
- Task: Choose the specific task to perform on the audio. You can select either "transcribe" for transcription or "translate" to translate the audio to English.
- Model Size: Select the whisper model size to run the server with.
- Make sure the transcription server is running properly. To know more about how to start the server, see the documentation here.
- Just click on the Chrome Extension which should show 2 options
- Start Capture : Starts capturing the audio in the current tab and sends the captured audio to the server for transcription. This also creates an element to show the transcriptions recieved from the server on the current tab.
- Stop Capture - Stops capturing the audio.
This extension requires an internet connection to stream audio and receive transcriptions. The accuracy of the transcriptions may vary depending on the audio quality and the performance of the server-side transcription service. The extension may consume additional system resources while running, especially when streaming audio.
The extension relies on a properly running transcription server with multilingual support. Please follow the server documentation for setup and configuration.