graphiti: Temporal Knowledge Graphs for Agentic Apps

graphiti builds dynamic, temporally aware knowledge graphs that represent complex, evolving relationships between entities over time.

graphiti: Temporal Knowledge Graphs for Agentic Apps

We’ve just open sourced graphiti, a new open-source library for building and querying dynamic, time-aware knowledge graphs.

What's graphiti?

In essence, graphiti is a tool for modeling and analyzing complex, evolving relationships between entities over time. It ingests both unstructured and structured data, creating a graph that can be queried using a combination of temporal, full-text, semantic, and graph algorithm approaches.

What can you build with it?

graphiti is designed with agentic applications in mind, particularly those requiring temporal reasoning and dynamic data handling. Some potential use cases include:

  1. Assistants that evolve with user interactions, merging personal knowledge with real-time data from various business systems.
  2. Agents capable of executing complex tasks autonomously, processing state changes from diverse dynamic sources - think anything from traffic conditions to live voice transcriptions.

How is graphiti different to GraphRAG and others?

We built graphiti specifically for dynamic data and agent-based applications. Here's what sets it apart:

  1. Smart Graph Updates: It automatically evaluates new entities against the existing graph, updating both to reflect the latest context.
  2. Rich Edge Semantics: During graph construction, it generates human-readable, semantic, and full-text searchable representations for edges. This enhances both search capabilities and interpretability.
  3. Temporal Awareness: It extracts and updates time-based edge metadata from input data, enabling reasoning over changing relationships.
  4. Hybrid Search: Offers semantic, BM25, and graph-based search with result fusion capabilities.
  5. Performance: Search results typically come in under 100ms, with latency mainly determined by the third-party embedding API call.
  6. Schema Consistency: Maintains a coherent graph structure by reusing existing schema, preventing unnecessary proliferation of node and edge types.

Why did we build it?

graphiti was initially developed to power Zep Memory, our long-term memory layer for building personalized and accurate LLM applications. However, we realized its potential extends beyond just memory applications, hence the decision to open-source it.

Where can you find it?

We're keen to see what the community builds with graphiti. Whether you have feedback, want to contribute, or just want to share what you've built, we'd love to hear from you!