Automate chatting with AI from command line, store and compose chat history for the next question
Go to file
2023-08-05 12:24:53 +02:00
.vscode Name files with autogenerated numbers 2023-04-07 21:55:47 +02:00
chatmastermind added option '-a' to match all tags when selecting chat history entries 2023-08-05 11:41:36 +02:00
tests Improve handling of printing source code only output. 2023-05-07 16:32:24 +02:00
.flake8 Fix handling of -q and -s, add pre-commit checks. 2023-04-19 15:28:19 +02:00
.gitignore Ignore noweb for now. 2023-05-07 14:02:19 +02:00
.pre-commit-config.yaml Fix handling of -q and -s, add pre-commit checks. 2023-04-19 15:28:19 +02:00
config.yaml Small change 2023-04-07 18:02:36 +02:00
LICENSE Initial commit of the code. 2023-04-07 15:14:34 +02:00
mypy.ini Fix handling of -q and -s, add pre-commit checks. 2023-04-19 15:28:19 +02:00
README.md added option '-a' to match all tags when selecting chat history entries 2023-08-05 11:41:36 +02:00
requirements.txt Initial commit of the code. 2023-04-07 15:14:34 +02:00
setup.py Rename the script to cmm and fix installation 2023-04-07 15:42:24 +02:00

ChatMastermind

ChatMastermind is a Python application that automates conversation with AI, stores question-answer pairs with tags, and composes relevant chat history for the next question.

The project uses the OpenAI API to generate responses and stores the data in YAML files. It also allows you to filter chat history based on tags and supports autocompletion for tags.

Requirements

  • Python 3.6 or higher
  • openai
  • PyYAML
  • argcomplete

You can install these requirements using pip:

pip install -r requirements.txt

Installation

You can install the package with the requirements using pip:

pip install .

Usage

cmm [-h] [-p PRINT | -q QUESTION | -D | -d | -l] [-c CONFIG] [-m MAX_TOKENS] [-T TEMPERATURE] [-M MODEL] [-n NUMBER] [-t [TAGS [TAGS ...]]] [-e [EXTAGS [EXTAGS ...]]] [-o [OTAGS [OTAGS ...]]] [-a] [-w] [-W]

Arguments

  • -p, --print: YAML file to print.
  • -q, --question: Question to ask.
  • -D, --chat-dump: Print chat history as a Python structure.
  • -d, --chat: Print chat history as readable text.
  • -a, --match-all-tags: All given tags must match when selecting chat history entries.
  • -w, --with-tags: Print chat history with tags.
  • -W, --with-tags: Print chat history with filenames.
  • -l, --list-tags: List all tags and their frequency.
  • -c, --config: Config file name (defaults to .config.yaml).
  • -m, --max-tokens: Max tokens to use.
  • -T, --temperature: Temperature to use.
  • -M, --model: Model to use.
  • -n, --number: Number of answers to produce (default is 3).
  • -t, --tags: List of tag names.
  • -e, --extags: List of tag names to exclude.
  • -o, --output-tags: List of output tag names (default is the input tags).

Examples

  1. Print the contents of a YAML file:
cmm -p example.yaml
  1. Ask a question:
cmm -q "What is the meaning of life?" -t philosophy -e religion
  1. Display the chat history as a Python structure:
cmm -D
  1. Display the chat history as readable text:
cmm -d
  1. Filter chat history by tags:
cmm -d -t tag1 tag2
  1. Exclude chat history by tags:
cmm -d -e tag3 tag4

Configuration

The configuration file (.config.yaml) should contain the following fields:

  • openai:
    • api_key: Your OpenAI API key.
    • model: The name of the OpenAI model to use (e.g. "text-davinci-002").
    • temperature: The temperature value for the model.
    • max_tokens: The maximum number of tokens for the model.
    • top_p: The top P value for the model.
    • frequency_penalty: The frequency penalty value.
    • presence_penalty: The presence penalty value.
  • system: The system message used to set the behavior of the AI.
  • db: The directory where the question-answer pairs are stored in YAML files.

Autocompletion

To activate autocompletion for tags, add the following line to your shell's configuration file (e.g., .bashrc, .zshrc, or .profile):

eval "$(register-python-argcomplete cmm)"

After adding this line, restart your shell or run source <your-shell-config-file> to enable autocompletion for the cmm script.

License

This project is licensed under the terms of the WTFPL License.