Customizing Graph Structure
Zep enables the use of rich, domain-specific data structures in graphs through Entity Types and Edge Types, replacing generic graph nodes and edges with detailed models.
Zep classifies newly created nodes/edges as one of the default or custom types or leaves them unclassified. For example, a node representing a preference is classified as a Preference node, and attributes specific to that type are automatically populated. You may restrict graph queries to nodes/edges of a specific type, such as Preference.
The default entity and edge types are applied to user graphs (not all graphs) by default, but you may define additional custom types as needed.
Each node/edge is classified as a single type only. Multiple classifications are not supported.
Default Entity and Edge Types
Definition
Zep provides default entity and edge types that are automatically applied to user graphs (not all graphs). These types help classify and structure the information extracted from conversations.
You can view the exact definition for the default ontology here.
Default Entity Types
The default entity types are:
- User: A Zep user specified by role in chat messages. There can only be a single User entity.
- Assistant: Represents the AI assistant in the conversation. This entity is a singleton.
- Preference: Entities mentioned in contexts expressing user preferences, choices, opinions, or selections. This classification is prioritized over most other classifications.
- Location: A physical or virtual place where activities occur or entities exist. Use this classification only after checking if the entity fits other more specific types.
- Event: A time-bound activity, occurrence, or experience.
- Object: A physical item, tool, device, or possession. Use this classification only as a last resort after checking other types.
- Topic: A subject of conversation, interest, or knowledge domain. Use this classification only as a last resort after checking other types.
- Organization: A company, institution, group, or formal entity.
- Document: Information content in various forms.
Default Edge Types
The default edge types are:
- LOCATED_AT: Represents that an entity exists or occurs at a specific location. Connects any entity to a Location.
- OCCURRED_AT: Represents that an event happened at a specific time or location. Connects an Event to any entity.
Default entity and edge types apply to user graphs. All nodes and edges in any user graph will be classified into one of these types or none.
Adding Data
When we add data to the graph, default entity and edge types are automatically created:
Searching
When searching nodes in the graph, you may provide a list of types to filter the search by. The provided types are ORed together. Search results will only include nodes that satisfy one of the provided types:
Custom Entity and Edge Types
Start with fewer, more generic custom types with minimal fields and simple definitions, then incrementally add complexity as needed. This functionality requires prompt engineering and iterative optimization of the class and field descriptions, so it’s best to start simple.
Definition
In addition to the default entity and edge types, you may specify your own custom entity and custom edge types. You need to provide a description of the type and a description for each of the fields. The syntax for this is different for each language.
You may not create more than 10 custom entity types and 10 custom edge types per project. The limit of 10 custom entity types does not include the default types. Each model may have up to 10 fields.
When creating custom entity or edge types, you may not use the following attribute names (including in Go struct tags), as they conflict with default node attributes: uuid, name, graph_id, name_embedding, summary, and created_at.
Including attributes on custom entity and edge types is an advanced feature designed for precision context engineering where you only want to utilize specific field values when constructing your context block. See here for an example. Many agent memory use cases can be solved with node summaries and facts alone. Custom attributes should only be added when you need structured field values for precise context retrieval rather than general conversational memory.
Setting Entity and Edge Types
You can set these custom entity and edge types as the graph ontology for your current Zep project. The ontology can be applied either project-wide to all users and graphs, or targeted to specific users and graphs only.
Setting Types Project Wide
When no user IDs or graph IDs are provided, the ontology is set for the entire project. All users and graphs within the project will use this ontology. Note that for custom edge types, you can require the source and destination nodes to be a certain type, or allow them to be any type:
Setting Types For Specific Graphs
You can also set the ontology for specific users and/or graphs by providing user IDs and graph IDs. When these parameters are provided, the ontology will only apply to the specified users and graphs, while other users and graphs in the project will continue using the previously set ontology (whether that was due to a project-wide setting of ontology or due to a graph-specific setting of ontology):
Adding Data
Now, when you add data to the graph, new nodes and edges are classified into exactly one of the overall set of entity or edge types respectively, or no type:
Searching/Retrieving
Now that a graph with custom entity and edge types has been created, you may filter node search results by entity type, or edge search results by edge type.
Below, you can see the examples that were created from our data of each of the entity and edge types that we defined:
Additionally, you can provide multiple types in search filters, and the types will be ORed together:
Important Notes/Tips
Some notes regarding custom entity and edge types:
- The set_ontologymethod overwrites any previously defined custom entity and edge types, so the set of custom entity and edge types is always the list of types provided in the lastset_ontologymethod call
- The overall set of entity and edge types for a project includes both the custom entity and edge types you set and the default entity and edge types
- You can overwrite the default entity and edge types by providing custom types with the same names
- Changing the custom entity or edge types will not update previously created nodes or edges. The classification and attributes of existing nodes and edges will stay the same. The only thing that can change existing classifications or attributes is adding data that provides new information.
- When creating custom entity or edge types, avoid using the following attribute names (including in Go struct tags), as they conflict with default attributes: uuid,name,graph_id,name_embedding,summary, andcreated_at
- Any custom entity or edge is required to have at least one custom property defined
- Tip: Design custom entity types to represent entities/nouns, and design custom edge types to represent relationships/verbs. Otherwise, your type might be represented in the graph as an edge more often than as a node or vice versa.
- Tip: If you have overlapping entity or edge types (e.g. ‘Hobby’ and ‘Hiking’), you can prioritize one type over another by mentioning which to prioritize in the entity or edge type descriptions