#[non_exhaustive]pub enum LlmRoutingStrategy {
None,
Ema,
Thompson,
Cascade,
Triage,
Bandit,
}Expand description
Routing strategy for the [[llm.providers]] pool.
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
None
Single provider or first-in-pool (default).
Ema
Exponential moving average latency-aware ordering.
Thompson
Thompson Sampling with Beta distributions.
Cascade
Cascade: try cheapest provider first, escalate on degenerate output.
Triage
Complexity triage routing: pre-classify each request, delegate to appropriate tier.
Bandit
PILOT: LinUCB contextual bandit with online learning and budget-aware reward.
Trait Implementations§
Source§impl Clone for LlmRoutingStrategy
impl Clone for LlmRoutingStrategy
Source§fn clone(&self) -> LlmRoutingStrategy
fn clone(&self) -> LlmRoutingStrategy
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for LlmRoutingStrategy
impl Debug for LlmRoutingStrategy
Source§impl Default for LlmRoutingStrategy
impl Default for LlmRoutingStrategy
Source§fn default() -> LlmRoutingStrategy
fn default() -> LlmRoutingStrategy
Returns the “default value” for a type. Read more
Source§impl<'de> Deserialize<'de> for LlmRoutingStrategy
impl<'de> Deserialize<'de> for LlmRoutingStrategy
Source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<LlmRoutingStrategy, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<LlmRoutingStrategy, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl PartialEq for LlmRoutingStrategy
impl PartialEq for LlmRoutingStrategy
Source§fn eq(&self, other: &LlmRoutingStrategy) -> bool
fn eq(&self, other: &LlmRoutingStrategy) -> bool
Tests for
self and other values to be equal, and is used by ==.Source§impl Serialize for LlmRoutingStrategy
impl Serialize for LlmRoutingStrategy
Source§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
Serialize this value into the given Serde serializer. Read more
impl Copy for LlmRoutingStrategy
impl Eq for LlmRoutingStrategy
impl StructuralPartialEq for LlmRoutingStrategy
Auto Trait Implementations§
impl Freeze for LlmRoutingStrategy
impl RefUnwindSafe for LlmRoutingStrategy
impl Send for LlmRoutingStrategy
impl Sync for LlmRoutingStrategy
impl Unpin for LlmRoutingStrategy
impl UnsafeUnpin for LlmRoutingStrategy
impl UnwindSafe for LlmRoutingStrategy
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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 moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request