Skip to content

Latest commit

 

History

History
75 lines (47 loc) · 2.24 KB

README.md

File metadata and controls

75 lines (47 loc) · 2.24 KB

David Attenborough narrates your life

Credit goes to Charlie Holtz for the idea's inception and initial app work. https://twitter.com/charliebholtz/status/1724815159590293764

Setup

Clone this repo, and setup and activate a virtualenv:

python3 -m pip install virtualenv
python3 -m virtualenv venv
source venv/bin/activate

Then, install the dependencies: pip install -r requirements.txt

Make an OpenAI and ElevenLabs account and set your tokens:

export OPENAI_API_KEY=<token>
export ELEVENLABS_API_KEY=<eleven-token>

Make a new voice in Eleven and get the voice id of that voice using their get voices API, or by clicking the flask icon next to the voice in the VoiceLab tab.

export ELEVENLABS_VOICE_ID=<voice-id>

Note: In order to use David's voice you'll need to train an Eleven Labs voice model. A suitable mp3 file can be found here.

Run it!

In on terminal, run the webcam capture:

python capture.py

In another terminal, run the narrator:

python narrator.py

Options

Setup

Script

Alternative to running the Setup commands above individually, one can use the setup.sh script to facilitate getting the two required shell envs ready to rock.

Note: will have to run source source venv/bin/activate afterwards to activate the virtual env.

Dotenv

One can set the environment variables via the .env file, which is read every time the process starts. It is recommended to copy the .env.example file and rename to .env.

Streaming

If you would like the speech to start quicker via a streaming manner set the environment variable to enable. The concession is that the audio and corresponding image is not saved in the /narration directory.

export ELEVENLABS_STREAMING=true

PhotoBooth

The default behavior of this app will continually analyze images. If you would like to use in a mode more similar to a photo booth, set the environment variable. In this mode, the image will only be analyzed when the spacebar key is pressed.

export PHOTOBOOTH_MODE=true