Persyn makes it easy to integrate many machine learning packages into a single microservices framework. Each project implements a component of a greater personality (language model, long-term memory, visualizations, logic) that is tied together into an interactive group chat interface.
The resulting gestalt can be executed on any combination of local compute resources (CPU + GPU) and third-party APIs (OpenAI, Wikipedia, etc.)
The name "Personality Syndrome" was chosen by the first proto-Persyn instance itself, https://mas.to/@annathebot
Major features:
- Chat with any large language model over Slack, Discord, or Mastodon
- Maintain a consistent and arbitrarily long train of thought
- Short-term and long-term memory
- Knowledge graph generation
- Opinions
- Auto-wikipedia
- Auto-summarization of previous conversations over time or as the prompt size grows too long
- Generate images on demand
- Identify images dropped into the chat with BLIP
- Optional automatic image prompt enhancement with Prompt Parrot
Persyn in intended to run from inside a python virtualenv.
On first launch it will download required models and install necessary packages inside the virtualenv.
$ virtualenv --python=python3.10 env
$ . env/bin/activate
(env) $ pip install --upgrade pip # best practice
(env) $ pip install persyn
The default install only includes chat support. If you'd also like to generate and post images:
(env) $ pip install persyn[all]
Tmux is also highly recommended, and is required for using the bot launcher.
Redis is used for long-term memory and pub/sub. It also requires the following modules:
- RedisSearch
- RedisJSON
https://redis.io/docs/latest/operate/oss_and_stack/install/install-redis/install-redis-on-linux/
The knowledge graph is implemented in Neo4j.
Create a new config file, using config/example.yaml
as a template.
Every bot should have a unique guid. Run uuidgen
and paste it into your config under id > guid.
You will need a language model for prompt completion. OpenAI is currently the most reliable and best tested. Follow one of the URLs in the example to obtain an API key.
At least one chat module (Slack, Discord, or Mastodon) should be enabled so you can interact with the bot.
Image generation requires several additional components mentioned in the example config. Install docs coming soon.
(env) $ launch_bot config/my_config.yaml
(env) $ tmux ls
(env) $ kill_bot mybotsession