Driving Dynamic Multi-Participant Chat Interactions for AI and Human Discourse
Project description
ChatFlock
📦 Installation
pip install -U chat-flock
or install with Poetry
poetry add chat-flock
🤔 What is this?
ChatFlock is a Python library that revolutionizes the way multi-participant chats are conducted by integrating Large Language Models (LLMs) at its core. Born from first principles design, it not only simplifies orchestrating complex chat scenarios but also introduces an innovative structure that mirrors organizational communication.
At the heart of ChatFlock is the Conductor, a novel entity that determines the speaking order, enabling seamless coordination among AI and human participants. This orchestration allows for nuanced conversations and decision-making processes that go beyond traditional chat systems.
NOTE: We are still in a very early and experimental stage of development, so the library might be unstable and the API might change relatively frequently. As soon as we reach a stable version, everything will get properly tested and documented.
📝 Usage Examples
1-Participant Chat
2-Participant Chat
- Basic ChatGPT Clone
- Basic ChatGPT Clone with Tools
- Basic ChatGPT Clone with LangChain Memory
- Basic ChatGPT Clone with LangChain-Based Retrieval
AI-Directed Multi-Participant Chat
- AI-Directed Multi-Participant Chat (Manual Composition)
- AI-Directed Multi-Participant Chat (Automated Composition)
- AI-Directed Multi-Participant Hierarchical Chat (Manual Composition)
End-to-End Examples
- BSHR (Brainstorm-Search-Hypothesize-Refine) Loop - Based on David Shapiro's idea.
🚀 Features
- Multi-Participant LLM-Based Chats: Enable rich, collaborative conversations with AI and human participants.
- Conductor Orchestration: A unique system that manages turn-taking and dialogue flow, ensuring smooth chat progression.
- Composition Generators: Smart modules that configure AI participants to achieve specific conversational goals.
- Group-Based Participants (Hierarchical Chats): Implement sub-chats that handle complex queries internally before delivering concise responses. Enables hierarchical chat structures which can mimic human-like organizational communication.
- Extensive LLM Toolkit Support: Fully compatible with existing LLM ecosystems like LangChain, enhancing their features for a robust chat experience.
- Web Research Module: A sophisticated tool that conducts automated web research, leveraging selenium to analyze top search results.
- BSHR (Brainstorm-Search-Hypothesize-Refine) Loop: An integrated module that employs the automated research tool in a loop using information literacy techniques for superior research outcomes (based on how humans do research). Credit: David Shapiro
- Code Execution Tools: Facilitate the execution of direct code snippets within the chat, with support for both local and Docker environments.
🌟 What's Next?
- Asynchronous Chat Support: enable non-real-time conversations, allowing for more flexible interaction timelines.
- Automated AI Hierarchical Composition: Automatically configure AI participants in a complex company-like hierarchy to achieve specific conversational goals.
- OpenAI Assistant Integration: Compatibility with OpenAI's latest features, expanding the library's AI capabilities.
- Enhanced Code Execution: Advanced code execution features, including support for writing to files and more comprehensive execution environments.
💁 Contributing
As an open-source project in a rapidly developing field, we are extremely open to contributions, whether it be in the form of a new feature, improved infrastructure, or better documentation.
For detailed information on how to contribute, see here.
📈 Releases
You can see the list of available releases on the GitHub Releases page.
We follow Semantic Versions specification.
We use Release Drafter
. As pull requests are merged, a draft release is kept up-to-date listing the changes, ready to publish when you’re ready. With the categories option, you can categorize pull requests in release notes using labels.
List of labels and corresponding titles
Label | Title in Releases |
---|---|
enhancement , feature |
🚀 Features |
bug , refactoring , bugfix , fix |
🔧 Fixes & Refactoring |
build , ci , testing |
📦 Build System & CI/CD |
breaking |
💥 Breaking Changes |
documentation |
📝 Documentation |
dependencies |
⬆️ Dependencies updates |
GitHub creates the bug
, enhancement
, and documentation
labels for you. Dependabot creates the dependencies
label. Create the remaining labels on the Issues tab of your GitHub repository, when you need them.
Building and releasing the package
Building a new version of the application contains steps:
- Bump the version of the package
poetry version <version>
. You can pass the new version explicitly, or a rule such asmajor
,minor
, orpatch
. For more details, refer to the Semantic Versions standard. - Make a commit to
GitHub
. - Create a
GitHub release
. - And... publish 🙂
poetry publish --build
🛡 License
This project is licensed under the terms of the MIT
license. See LICENSE for more details.
📃 Citation
@misc{chat-flock,
author = {doodledood},
title = {Driving Dynamic Multi-Participant Chat Interactions for AI and Human Discourse},
year = {2023},
publisher = {GitHub},
journal = {GitHub repository},
howpublished = {\url{https://github.com/doodledood/chat-flock}}
}
❤️ Package Template Credits
This project was generated with python-package-template
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file chat_flock-0.1.2.tar.gz
.
File metadata
- Download URL: chat_flock-0.1.2.tar.gz
- Upload date:
- Size: 41.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.7.0 CPython/3.11.0 Windows/10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6a474fbfe1cc65d2471c0907779fdb2600d1458c38c149201bbf10ec2e077be3 |
|
MD5 | 147b45e34c9f2639ce975f16b099b4e1 |
|
BLAKE2b-256 | b7c092d7c1c330887023e29401cf74b4fc1c2b4d64ac0b49a193b63bfa2537bb |
File details
Details for the file chat_flock-0.1.2-py3-none-any.whl
.
File metadata
- Download URL: chat_flock-0.1.2-py3-none-any.whl
- Upload date:
- Size: 56.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.7.0 CPython/3.11.0 Windows/10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 164452863edfa422c4fdaa9a23e9982d1c6229e45966d057b78ab6279f362206 |
|
MD5 | 8c625baa46e6f413236bc2ee015336d7 |
|
BLAKE2b-256 | ccaa42bc21e331773fb619f37ac0185fdf80a84d7d9d107ad5747897f49633d1 |