Georgi Gerganov 09d7d2b68e
examples : refactor in order to reuse code and reduce duplication ()
2 years ago
..
.gitignore talk : talk with AI in the terminal 2 years ago
CMakeLists.txt examples : refactor in order to reuse code and reduce duplication () 2 years ago
README.md talk : improve prompting 2 years ago
gpt-2.cpp examples : fix memory leak on failure to load gpt2 model () 2 years ago
gpt-2.h talk : talk with AI in the terminal 2 years ago
speak.sh talk : talk with AI in the terminal 2 years ago
talk.cpp examples : refactor in order to reuse code and reduce duplication () 2 years ago

README.md

talk

Talk with an Artificial Intelligence in your terminal

Demo Talk

Web version: examples/talk.wasm

Building

The talk tool depends on SDL2 library to capture audio from the microphone. You can build it like this:

# Install SDL2 on Linux
sudo apt-get install libsdl2-dev

# Install SDL2 on Mac OS
brew install sdl2

# Build the "talk" executable
make talk

# Run it
./talk -p Santa

GPT-2

To run this, you will need a ggml GPT-2 model: instructions

Alternatively, you can simply download the smallest ggml GPT-2 117M model (240 MB) like this:

wget --quiet --show-progress -O models/ggml-gpt-2-117M.bin https://huggingface.co/datasets/ggerganov/ggml/raw/main/ggml-model-gpt-2-117M.bin

TTS

For best experience, this example needs a TTS tool to convert the generated text responses to voice. You can use any TTS engine that you would like - simply edit the speak.sh script to your needs. By default, it is configured to use espeak, but you can use whatever you wish.