Skip to main content

SemanticQueryCache

Struct SemanticQueryCache 

Source
pub struct SemanticQueryCache { /* private fields */ }
Expand description

Semantic query cache

Implementations§

Source§

impl SemanticQueryCache

Source

pub fn new(threshold: f32) -> Self

Create a new semantic query cache with default max entries

Source

pub fn with_capacity(threshold: f32, max_entries: usize) -> Self

Create a new semantic query cache with specified capacity

Source

pub fn with_config( threshold: f32, max_entries: usize, index_config: SemanticIndexConfig, ) -> Self

Create with custom index config

Source

pub fn lookup(&self, embedding: &[f32]) -> Option<SimilarityResult>

Lookup by semantic similarity

Source

pub fn lookup_with_threshold( &self, embedding: &[f32], threshold: f32, ) -> Option<SimilarityResult>

Lookup with custom threshold

Source

pub fn find_similar(&self, embedding: &[f32], k: usize) -> Vec<SimilarityResult>

Find k most similar queries

Source

pub fn lookup_with_branch( &self, embedding: &[f32], branch: &BranchContext, ) -> Option<SimilarityResult>

Lookup with branch context filtering

Returns cached entry only if it’s compatible with the given branch context. This enables branch-aware caching for time-travel queries.

Source

pub fn lookup_with_session( &self, embedding: &[f32], session: &String, ) -> Option<SimilarityResult>

Lookup with session affinity for agent conversations

Prioritizes entries from the same session for better conversation context.

Source

pub fn lookup_with_context( &self, embedding: &[f32], branch: Option<&BranchContext>, session: Option<&String>, workload: AIWorkloadContext, ) -> Option<SimilarityResult>

Lookup with full AI context (branch + session + workload)

Most comprehensive lookup that considers:

  • Branch context for time-travel
  • Session affinity for agent conversations
  • Workload type for TTL and priority
Source

pub fn find_similar_in_branch( &self, embedding: &[f32], branch: &BranchContext, k: usize, ) -> Vec<SimilarityResult>

Find similar entries within a branch

Source

pub fn invalidate_by_table(&self, table: &str) -> usize

Invalidate entries by table name

Used when WAL invalidation detects changes to a table.

Source

pub fn invalidate_branch(&self, branch: &BranchId) -> usize

Invalidate entries by branch

Source

pub fn insert( &self, query: impl Into<String>, embedding: Embedding, result: Value, ) -> VectorId

Insert a new entry

Source

pub fn insert_with_ttl( &self, query: impl Into<String>, embedding: Embedding, result: Value, ttl: Duration, ) -> VectorId

Insert with TTL

Source

pub fn insert_with_context( &self, query: impl Into<String>, embedding: Embedding, result: Value, branch: Option<BranchContext>, session: Option<String>, workload: AIWorkloadContext, tables: Vec<String>, ) -> VectorId

Insert with full AI context (branch, session, workload, tables)

This is the recommended insertion method for AI/Agent workloads as it enables branch-aware caching, session affinity, and workload-specific TTL management.

Source

pub fn insert_rag_retrieval( &self, query: impl Into<String>, embedding: Embedding, result: Value, tables: Vec<String>, ) -> VectorId

Insert for RAG retrieval workload

Optimized TTL for fast-refresh retrieval phase.

Source

pub fn insert_agent_response( &self, query: impl Into<String>, embedding: Embedding, result: Value, session: String, branch: Option<BranchContext>, ) -> VectorId

Insert for agent conversation

Session-aware with longer TTL for conversation context.

Source

pub fn insert_tool_result( &self, query: impl Into<String>, embedding: Embedding, result: Value, ) -> VectorId

Insert deterministic tool result

Long TTL for deterministic tool calls (e.g., math, date formatting).

Source

pub fn remove(&self, id: VectorId)

Remove an entry

Source

pub fn cleanup_expired(&self)

Remove expired entries

Source

pub fn clear(&self)

Clear all entries

Source

pub fn len(&self) -> usize

Get entry count

Source

pub fn is_empty(&self) -> bool

Check if empty

Source

pub fn stats(&self) -> SemanticCacheStatsSnapshot

Get statistics

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more