pub struct BenchmarkCase {
pub prompt: String,
pub context: Option<String>,
pub reference: Option<String>,
pub tags: Option<Vec<String>>,
}Expand description
A single benchmark case.
The prompt is sent to the subject model. If context is present it is injected
as a system message before the user turn. If reference is present the judge model
uses it to calibrate its score.
§Examples
use zeph_experiments::BenchmarkCase;
let case = BenchmarkCase {
prompt: "Name the first element.".into(),
context: Some("You are a chemistry expert.".into()),
reference: Some("Hydrogen".into()),
tags: Some(vec!["chemistry".into()]),
};
assert!(case.reference.as_deref() == Some("Hydrogen"));Fields§
§prompt: StringThe prompt sent to the subject model.
context: Option<String>Optional system context injected before the user turn.
reference: Option<String>Optional reference answer for the judge to calibrate scoring.
Optional tags for filtering or grouping results.
Trait Implementations§
Source§impl Clone for BenchmarkCase
impl Clone for BenchmarkCase
Source§fn clone(&self) -> BenchmarkCase
fn clone(&self) -> BenchmarkCase
Returns a duplicate of the value. Read more
1.0.0 · 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 BenchmarkCase
impl Debug for BenchmarkCase
Source§impl<'de> Deserialize<'de> for BenchmarkCase
impl<'de> Deserialize<'de> for BenchmarkCase
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Auto Trait Implementations§
impl Freeze for BenchmarkCase
impl RefUnwindSafe for BenchmarkCase
impl Send for BenchmarkCase
impl Sync for BenchmarkCase
impl Unpin for BenchmarkCase
impl UnsafeUnpin for BenchmarkCase
impl UnwindSafe for BenchmarkCase
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<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