https://github.com/emcie-co/parlant
  
  
    Control GenAI interactions with power, precision, and consistency using Conversation Modeling paradigms 
    https://github.com/emcie-co/parlant
  
ai-agents ai-alignment customer-service customer-success gemini genai llama3 llm openai python
        Last synced: 5 months ago 
        JSON representation
    
Control GenAI interactions with power, precision, and consistency using Conversation Modeling paradigms
- Host: GitHub
- URL: https://github.com/emcie-co/parlant
- Owner: emcie-co
- License: apache-2.0
- Created: 2024-02-15T20:16:15.000Z (over 1 year ago)
- Default Branch: develop
- Last Pushed: 2025-04-28T11:49:15.000Z (6 months ago)
- Last Synced: 2025-04-28T12:14:02.304Z (6 months ago)
- Topics: ai-agents, ai-alignment, customer-service, customer-success, gemini, genai, llama3, llm, openai, python
- Language: Python
- Homepage: https://www.parlant.io
- Size: 52.8 MB
- Stars: 2,370
- Watchers: 25
- Forks: 227
- Open Issues: 16
- 
            Metadata Files:
            - Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
 
Awesome Lists containing this project
- StarryDivineSky - emcie-co/parlant
- awesome-ccamel - emcie-co/parlant - LLM agents built for control. Designed for real-world use. Deployed in minutes. (Python)
- awesome-ChatGPT-repositories - parlant - The heavy-duty guidance framework for customer-facing LLM agents (NLP)
- awesome-hacking-lists - emcie-co/parlant - Control GenAI interactions with power, precision, and consistency using LLM-native Conversation Design paradigms (Python)
- AiTreasureBox - emcie-co/parlant - 10-21_13813_12](https://img.shields.io/github/stars/emcie-co/parlant.svg)|The behavior guidance framework for customer-facing LLM agents| (Repos)
README
          
   
  
Hello, Conversation Modeling!
Parlant is the open-source engine for controlled, compliant, and purposeful generative AI conversations. It gives you the power of LLMs without the unpredictability.
  
    Website —
    Introduction —
    Tutorial —
    About —
    Reddit
  
  
  
## Introduction Video
[](https://www.youtube.com/watch?v=_39ERIb0100)
1. Install
```bash
pip install parlant
```
2. Start the server and start interact with the default agent
```bash
parlant-server run
# Now visit http://localhost:8800
```
3. Add behavioral guidelines and let Parlant do the rest
```bash
parlant guideline create \
    --condition "the user greets you" \
    --action "thank them for checking out Parlant"
# Now start a new conversation and greet the agent
```
## Quick Demo

## What is Conversation Modeling?
You've built an AI agent—that's great! However, when you actually test it, you see it's not handling many customer interactions properly, and your business experts are displeased with it. What do you do?
Enter Conversation Modeling (CM): a new powerful and reliable approach to controlling how your agents interact with your users.
A conversation model is a structured, domain-specific set of principles, actions, objectives, and terms that an agent applies to a given conversation.
### Why Conversation Modeling?
The problem of getting your AI agent to say what _you_ want it to say is a hard one, experienced by virtually anyone building customer-facing agents. Here's how Conversation Modeling compares to other approaches to solving this problem.
- **Flow engines** _force_ the user to interact according to predefined flows. In contrast, a **CM engine** dynamically _adapts_ to a user's natural interaction patterns while conforming to your rules.
- **Free-form prompt engineering** leads to _inconsistency_, frequently failing to uphold requirements. Conversely, a **CM engine** leverages structure to _enforce_ conformance to a Conversation Model.
## Who uses Parlant?
Parlant is used to deliver complex conversational agents that reliably follow your business protocols in use cases such as:
- 🏦 Regulated financial services
- 🏥 Healthcare communications
- 📜 Legal assistance
- 🛡️ Compliance-focused use cases
- 🎯 Brand-sensitive customer service
- 🤝 Personal advocacy and representation
## How is Parlant used?
Developers and data-scientists are using Parlant to:
- 🤖 Create custom-tailored conversational agents quickly and easily
- 👣 Define behavioral guidelines for agents to follow (Parlant ensures they are followed reliably)
- 🛠️ Attach tools with specific guidance on how to properly use them in different contexts
- 📖 Manage their agents’ glossary to ensure strict interpretation of terms in a conversational context
- 👤 Add customer-specific information to deliver personalized interactions
#### How does Parlant work?
```mermaid
graph TD
    API(Parlant REST API) -->|React to Session Trigger| Engine[AI Response Engine]
    Engine -->|Load Domain Terminology| GlossaryStore
    Engine -->|Match Guidelines| GuidelineMatcher
    Engine -->|Infer & Call Tools| ToolCaller
    Engine -->|Tailor Guided Message| MessageComposer
```
When an agent needs to respond to a customer, Parlant's engine evaluates the situation, checks relevant guidelines, gathers necessary information through your tools, and continuously re-evaluates its approach based on your guidelines as new information emerges. When it's time to generate a message, Parlant implements self-critique mechanisms to ensure that the agent's responses precisely align with your intended behavior as given by the contextually-matched guidelines.
***📚 More technical docs on the architecture and API are available under [docs/](./docs)***.
## 📦 Quickstart
Parlant comes pre-built with responsive session (conversation) management, a detection mechanism for incoherence and contradictions in guidelines, content-filtering, jailbreak protection, an integrated sandbox UI for behavioral testing, native API clients in Python and TypeScript, and other goodies.
```bash
$ pip install parlant
$ parlant-server run
$ # Open the sandbox UI at http://localhost:8800 and play
```
## 🙋♂️🙋♀️ Who Is Parlant For?
Parlant is the right tool for the job if you're building an LLM-based chat agent, and:
1. 🎯 Your use case places a **high importance on behavioral precision and consistency**, particularly in customer-facing scenarios
1. 🔄 Your agent is expected to undergo **continuous behavioral refinements and changes**, and you need a way to implement those changes efficiently and confidently
1. 📈 You're expected to maintain a **growing set of behavioral guidelines**, and you need to maintain them coherently and with version-tracking
1. 💬 Conversational UX and user-engagmeent is an important concern for your use case, and you want to easily **control the flow and tone of conversations**
## ⭐ Star Us: Your Support Goes a Long Way!
[](https://star-history.com/#emcie-co/parlant&Date)
## 🤔 What Makes Parlant Different?
In a word: **_Guidance._** 🧭🚦🤝
Parlant's engine revolves around solving one key problem: How can we _reliably guide_ customer-facing agents to behave in alignment with our needs and intentions?
Hence Parlant's fundamentally different approach to agent building: [Managed Guidelines](https://www.parlant.io/docs/concepts/customization/guidelines):
```bash
parlant guideline create \
  --condition "the customer wants to return an item" \
  --action "get the order number and item name and then help them return it"
```
By giving structure to behavioral guidelines, and _granularizing_ guidelines (i.e. making each behavioral guideline a first-class entity in the engine), Parlant's engine is able to offer unprecedented control, quality, and efficiency in building LLM-based agents:
1. 🛡️ **Reliability:** Running focused self-critique in real-time, per guideline, to ensure it is actually followed
1. 💡 **Explainability:** Providing feedback around its interpretation of guidelines in each real-life context, which helps in troubleshooting and improvement
1. 🔧 **Maintainability:** Helping you maintain a coherent set of guidelines by detecting and alerting you to possible contradictions (gross or subtle) in your instructions
## 🤖 Works with all major LLM providers
- [OpenAI](https://platform.openai.com/docs/overview) (also via [Azure](https://learn.microsoft.com/en-us/azure/ai-services/openai/))
- [Gemini](https://ai.google.dev/)
- [Meta Llama 3](https://www.llama.com/) (via [Together AI](https://www.together.ai/) or [Cerebras](https://cerebras.ai/))
- [Anthropic](https://www.anthropic.com/api) (also via [AWS Bedrock](https://aws.amazon.com/bedrock/))
- And more are added regularly
## 📚 Learning Parlant
To start learning and building with Parlant, visit our [documentation portal](https://parlant.io/docs/quickstart/introduction).
Need help? Ask us anything on [Discord](https://discord.gg/duxWqxKk6J). We're happy to answer questions and help you get up and running!
## 💻 Usage Example
Adding a guideline for an agent—for example, to ask a counter-question to get more info when a customer asks a question:
```bash
parlant guideline create \
    --condition "a free-tier customer is asking how to use our product" \
    --action "first seek to understand what they're trying to achieve"
```
## 👋 Contributing
We use the Linux-standard Developer Certificate of Origin ([DCO.md](DCO.md)), so that, by contributing, you confirm that you have the rights to submit your contribution under the Apache 2.0 license (i.e., that the code you're contributing is truly yours to share with the project).
Please consult [CONTRIBUTING.md](CONTRIBUTING.md) for more details.
Can't wait to get involved? Join us on [Discord](https://discord.gg/duxWqxKk6J) and let's discuss how you can help shape Parlant. We're excited to work with contributors directly while we set up our formal processes!
Otherwise, feel free to start a discussion or open an issue here on GitHub—freestyle 😎.