Skip to main content

UsageTracker

Struct UsageTracker 

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

Tracks cumulative token usage across multiple LLM calls.

UsageTracker accumulates Usage records from each request and provides context-awareness features for detecting when the conversation is approaching the model’s context limit.

§Example

use llm_stack::usage::{Usage, UsageTracker};

let mut tracker = UsageTracker::with_context_limit(128_000);

// Record usage from each LLM call
tracker.record(Usage {
    input_tokens: 1000,
    output_tokens: 500,
    ..Default::default()
});

assert_eq!(tracker.total().input_tokens, 1000);
assert!(!tracker.is_near_limit(0.8)); // Not near 80% yet

§Use Cases

  • Billing/cost tracking: Aggregate costs across a session
  • Budget alerts: Warn when approaching token limits
  • Compaction triggers: Signal when context window is nearly full
  • Token debugging: Analyze per-call consumption patterns

Implementations§

Source§

impl UsageTracker

Source

pub fn new() -> Self

Creates a new tracker with no context limit.

Source

pub fn with_context_limit(limit: u64) -> Self

Creates a tracker with a known context window limit.

The limit is used for context_utilization and is_near_limit calculations.

Source

pub fn record(&mut self, usage: Usage)

Records a usage sample from an LLM call.

The usage is added to the running total and stored for per-call analysis.

Source

pub fn total(&self) -> &Usage

Returns the accumulated usage across all recorded calls.

Source

pub fn calls(&self) -> &[Usage]

Returns the usage from each individual call, in order.

Source

pub fn call_count(&self) -> usize

Returns the number of calls recorded.

Source

pub fn context_limit(&self) -> Option<u64>

Returns the context limit, if set.

Source

pub fn set_context_limit(&mut self, limit: u64)

Sets or updates the context limit.

Useful when the model is determined after tracker creation.

Source

pub fn context_utilization(&self) -> Option<f64>

Returns the context utilization as a ratio (0.0 to 1.0+).

Utilization is calculated as total_input_tokens / context_limit. Returns None if no context limit is set.

§Note

The value can exceed 1.0 if the total exceeds the limit (which shouldn’t happen in practice but is not enforced).

Source

pub fn is_near_limit(&self, threshold: f64) -> bool

Checks if the context utilization is at or above the given threshold.

Returns false if no context limit is set.

§Example
use llm_stack::usage::{Usage, UsageTracker};

let mut tracker = UsageTracker::with_context_limit(100_000);
tracker.record(Usage {
    input_tokens: 85_000,
    output_tokens: 1000,
    ..Default::default()
});

assert!(tracker.is_near_limit(0.8));   // 85% >= 80%
assert!(!tracker.is_near_limit(0.9));  // 85% < 90%
Source

pub fn cost(&self, pricing: &ModelPricing) -> Option<Cost>

Computes the cost of all recorded usage given a pricing table.

Uses the pricing rates (per-million tokens) to calculate cost. Returns None if the cost would overflow.

Source

pub fn reset(&mut self)

Resets the tracker, clearing all recorded usage.

Trait Implementations§

Source§

impl Clone for UsageTracker

Source§

fn clone(&self) -> UsageTracker

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for UsageTracker

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for UsageTracker

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> DynClone for T
where T: Clone,

Source§

fn __clone_box(&self, _: Private) -> *mut ()

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> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
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