pub struct SamplingContext<'a> {
pub step: usize,
pub sampling_params: &'a SamplingParams,
pub logits: &'a mut [f32],
pub previous_tokens: &'a [TokenId],
pub token_frequencies: &'a HashMap<TokenId, usize>,
pub vocab_size: usize,
pub metadata: HashMap<String, f32>,
}Expand description
Sampling context passed to logits processors and samplers
Fields§
§step: usizeCurrent generation step (0-based)
sampling_params: &'a SamplingParamsRequest-specific sampling parameters
logits: &'a mut [f32]Current logits (mutable for processing)
previous_tokens: &'a [TokenId]Previous token IDs in sequence
token_frequencies: &'a HashMap<TokenId, usize>Token frequencies for repetition penalty
vocab_size: usizeVocabulary size
metadata: HashMap<String, f32>Additional metadata
Implementations§
Source§impl<'a> SamplingContext<'a>
impl<'a> SamplingContext<'a>
Sourcepub fn new(
step: usize,
sampling_params: &'a SamplingParams,
logits: &'a mut [f32],
previous_tokens: &'a [TokenId],
token_frequencies: &'a HashMap<TokenId, usize>,
vocab_size: usize,
) -> Self
pub fn new( step: usize, sampling_params: &'a SamplingParams, logits: &'a mut [f32], previous_tokens: &'a [TokenId], token_frequencies: &'a HashMap<TokenId, usize>, vocab_size: usize, ) -> Self
Create new sampling context
Sourcepub fn set_logit(&mut self, token_id: TokenId, value: f32) -> bool
pub fn set_logit(&mut self, token_id: TokenId, value: f32) -> bool
Set logit value for specific token
Sourcepub fn mask_tokens(&mut self, token_ids: &[TokenId])
pub fn mask_tokens(&mut self, token_ids: &[TokenId])
Mask (set to negative infinity) specific tokens
Trait Implementations§
Auto Trait Implementations§
impl<'a> Freeze for SamplingContext<'a>
impl<'a> RefUnwindSafe for SamplingContext<'a>
impl<'a> Send for SamplingContext<'a>
impl<'a> Sync for SamplingContext<'a>
impl<'a> Unpin for SamplingContext<'a>
impl<'a> UnsafeUnpin for SamplingContext<'a>
impl<'a> !UnwindSafe for SamplingContext<'a>
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