HomeCompaniesZep AI

The Memory Foundation For Your AI Stack

Build AI assistants that continually learn and delight users with personalized and accurate experiences. ## Memory that learns from your users Zep intelligently learns from user interactions, improving your assistant or agent's knowledge over time. Recall user facts in milliseconds, with Zep adding no latency to your prompt creation. ## Ready for Production and Scale - Granular Memory Controls: Go beyond semantic search with developer-defined rubrics for user fact relevance. - Comprehensive APIs and SDKs: Python, TypeScript, and Go SDKs, with full CRUD control of stored facts. - SOC 2 and tools for Privacy Compliance. ## Build Consistent and Correct LLM Apps Zep's Structured Output and Dialog Classification tools build on Zep's memory enabling you to build more accurate and consistent user experiences. - Extract strongly-typed data from chat history, quickly & accurately: Go beyond your LLM provider's JSON or Structured Output mode with built-in types for datetimes, floats, emails, RegEx patterns, and more. - Instantly classify conversation state: Understand user intent and emotion, segment users, and more.

Jobs at Zep AI

San Francisco, CA, US
$120K - $180K
1.00%
3+ years
Zep AI
Founded:2023
Team Size:5
Location:San Francisco
Group Partner:Garry Tan

Active Founders

Daniel Chalef, Founder

Founder, Zep AI. Engineer turned startup founder (previously KnowledgeTree) and late-stage operator (SparkPost acquired MessageBird), with detours as a Data Science, Marketing, and Corp Dev guy. Still an engineer at heart and have a soft spot for Go.
Daniel Chalef
Daniel Chalef
Zep AI

Company Launches

Hey! We're Paul, Preston, and Daniel from Zep AI. We've just open-sourced Graphiti, a Python library for building temporal Knowledge Graphs using LLMs.

https://youtu.be/sygRBjILDn8

Graphiti helps you create and query graphs that evolve over time. Think of a knowledge graph as a network of interconnected facts, such as “Kendra loves Adidas shoes.” Each fact is a “triplet, represented by two entities, or nodes (”Kendra,” “Adidas shoes”), and their relationship, or edge (”loves”). Knowledge Graphs have been explored extensively for information retrieval. What makes Graphiti unique is its ability to autonomously build a knowledge graph while handling changing relationships and maintaining historical context.

At Zep, we build a memory layer for LLM applications. Developers use Zep to recall relevant user information from past conversations without including the entire chat history in a prompt. Accurate context is crucial for LLM applications. If an AI agent doesn't remember that you've changed jobs or confuses the chronology of events, its responses can be jarring or irrelevant, or worse, inaccurate.

Zep’s Suboptimal Fact Pipeline

Before Graphiti, our approach to storing and retrieving user “memory” was, in effect, a specialized RAG pipeline. An LLM extracted “facts” from a user’s chat history. Semantic search, reranking, and other techniques then surfaced facts relevant to the current conversation back to a developer for inclusion in their prompt.

Unfortunately, this approach became problematic. Reconciling facts from increasingly complex conversations challenged even frontier LLMs such as gpt-4o. We saw incomplete facts, poor recall, and hallucinations. Our RAG search also failed at times to capture the nuanced relationships between facts, leading to irrelevant or contradictory information being retrieved.

We tried fixing these issues with prompt optimization but saw diminishing returns on effort. We realized that a graph would help model a user’s complex world, potentially addressing these challenges.

Building Graphiti

We were intrigued by Microsoft’s GraphRAG, which expanded on RAG text chunking with a graph to better model a document corpus. However, it didn't solve our core problem: GraphRAG is designed for static documents and doesn't natively handle temporality.

So, we built Graphiti, a temporal Knowledge Graph library, which is designed from the ground up to handle constantly changing information, hybrid semantic and graph search, and scale:

  • Temporal Awareness: Tracks changes in facts and relationships over time. Graph edges include temporal metadata to record relationship lifecycles.
  • Episodic Processing: Ingests data as discrete episodes, maintaining data provenance and enabling incremental processing.
  • Hybrid Search: Semantic and BM25 full-text search, with the ability to rerank results by distance from a central node.
  • Scalable: Designed for large datasets, parallelizing LLM calls for batch processing while preserving event chronology.
  • Varied Sources: Ingests both unstructured text and structured data.

Getting Started

Graphiti is open-source and available on GitHub: https://git.new/graphiti

Quick Start: pip install graphiti-core

While we developed Graphiti for our needs at Zep, we believe it could be useful for any application dealing with evolving, interconnected data, such as:

  • Personal AI assistants that need to maintain user context over time
  • Knowledge management systems for rapidly changing domains
  • Social network analysis tools
  • Financial systems tracking changing relationships and transactions

If you try, we'd love to hear your thoughts, questions, and experiences. Please also consider contributing!

Other Company Launches

Zep: Fast, accurate structured data extraction for AI assistant apps

10x faster than GPT-4o, with field format and validity guarantees.
Read Launch ›

Zep - Long-term memory for AI assistants

Build Assistants that know your users.
Read Launch ›