pub fn traverse_from_memories(
conn: &Connection,
seed_memory_ids: &[i64],
namespace: &str,
min_weight: f64,
max_hops: u32,
) -> Result<Vec<i64>, AppError>Expand description
Percorre o grafo de entidades por BFS a partir de memórias-semente.
Retorna memory_ids alcançáveis pelo grafo de entidades e relacionamentos,
excluindo as próprias sementes. O algoritmo:
- Coleta entidades associadas às sementes via
memory_entities. - Executa BFS sobre
relationshipsfiltrando porweight >= min_weightenamespace. - Retorna memórias ligadas às entidades descobertas (excluindo soft-deleted).
§Errors
Propaga AppError::Database (exit 10) em falhas de consulta SQLite.
§Examples
use rusqlite::Connection;
use sqlite_graphrag::graph::traverse_from_memories;
// Lista de sementes vazia retorna imediatamente sem consultar o banco.
let conn = Connection::open_in_memory().unwrap();
let ids = traverse_from_memories(&conn, &[], "global", 0.5, 3).unwrap();
assert!(ids.is_empty());use rusqlite::Connection;
use sqlite_graphrag::graph::traverse_from_memories;
// max_hops == 0 retorna imediatamente sem traversal.
let conn = Connection::open_in_memory().unwrap();
let ids = traverse_from_memories(&conn, &[1, 2], "global", 0.5, 0).unwrap();
assert!(ids.is_empty());