/wrAIter

AI writing assistant with voiced narrator and characters and an illustrator

Primary LanguagePythonMozilla Public License 2.0MPL-2.0

image

wrAIter is a voiced AI that writes stories while letting the user interact and add to the story. You can write a paragraph, let the AI write the next one, you add another, etc. It allows for three input modes: typing text, selecting one of 3 actions, microphone input.

image

The AI writer is powered by any LLM that can be found on Hugging Face, easily swappable through a command line argument. The default model has 2.7 billion parameters and was fine-tuned to write fictional stories.

wrAIter also displays illustrations for your story when you press ctrl+o. The default model Stable Diffusion 1.4 can be switched up in settings.json

Screenshot_20241010_091804

Features

  • Compatible with LLMs from huggingface, fine-tuned for the specific purpose of writing stories,
  • A high quality narrator AI that reads the story out loud (TTS),
  • A stable diffusion illustrator model that shows a picture related to the story by pressing ctrl+o
  • Customizable voice: the narrator will sound like any voice sample of your choice,
  • Multiple speakers: the voice will change between the narrator and different characters, detecting their genders to assign voices,
  • Three modes to build a story: alternating AI-human writing, choosing from AI generated options or microphone input,
  • A conversation mode to chat directly with a fictional character,
  • Save, load, continue and revert functions.

image

Local Installation

  1. Install python 3.10 or greater (tested on 3.12)
  2. Download or clone this repository.
  3. Run install.ps1 (windows powershell) or install.sh (shell script).
  4. Play by running play.ps1 (windows powershell) or play.sh (shell script). You can also launch main.py directly with your own launch options (model selection, gpu/cpu).s
  5. Set up PyTorch with CUDA or ROCm for GPU acceleration, or disable GPU in the settings.json created after the first run.

FAQ

How can I customize the narrator's voice?

Simply drop WAV files into the directories in audio/voices/. Dialogues will alternate between character1 and character2 voices, and everything outside quotes will be read by narrator. The files should be a clean and samples of a single person talking. A male and a female voice samples are already included: "librispeech-f" and "librispeech-m"

What kind of hardware do I need?

You'll need an GPU with at least 8 GB of VRAM, or a lot of patience and 28 GB of RAM (with the --cputext flag). With 10 GB of VRAM (RTX 3080), you can also run TTS faster by removing the --cputts flag. Feel free to try smaller and bigger variants of the OPT model from huggingface.

With 24GB of VRAM, Mistral models now work with enough spare memory for TTS.

AMD is also supported since version 2.2.0.

The --precision also allows you to reduce VRAM usage by reducing float precision to 8 or 4 bits (see --help, NVIDIA only for now).

Can I write in first person like in AIdungeon?

No, AIdungeon converts first person to second person before feeding your input to its model, which was trained for second person narration. Writing in first person on wrAIter will probably result in a first person response.

Does the AI learn from my inputs?

While the AI remembers the last thousand words of the story, it doesn't learn from it. Playing or saving a story won't affect the way it plays another.

Does the AI forget parts of the story?

Yes. Because the model can only take 2048 words in the input (number depends on the model), the oldest events can be dropped to make the story fit. However, the context of the story (first paragraph) is never "forgotten".

Until you hit 2048 words, longer stories get progressively better results.

Can I fine-tune the AI on a corpus of my choice?

I didn't bother with fine-tuning LLMs larger than 355M parameters. The models are just too large to fit into my machine or any free cloud GPU. So you're on your own if you want to try.

Does this thing respect my privacy?

Yes, wrAIter only needs to connect to the internet to download the models and to install python packages. It doesn't upload anything, and only saves stories on your hard drive.

I read an article about AIdungeon and profanity. Doesn't this have the same issues?

No. First, wrAIter doesn't adjust based on your or other players' inputs. The model runs on your machine, so tempering with it would only affect your own experience. Second, a censor is enabled by default, trashing and regenerating entire paragraphs if the model outputs a single banned word. It can be disabled in the launch options, giving you the freedom of choice.

Credits