mirror of
https://github.com/huggingface/candle.git
synced 2025-06-16 10:38:54 +00:00
57 lines
1.7 KiB
Rust
57 lines
1.7 KiB
Rust
use candle::{Device, Result, Tensor};
|
|
use candle_transformers::generation::LogitsProcessor;
|
|
|
|
#[test]
|
|
fn sample_with_zero_temperature() -> Result<()> {
|
|
let mut logits_process = LogitsProcessor::new(1337, None, None);
|
|
let logits = Tensor::new(&[0.1, 0.2, 0.3, 0.4], &Device::Cpu)?;
|
|
let token = logits_process.sample(&logits)?;
|
|
assert_eq!(token, 3);
|
|
Ok(())
|
|
}
|
|
|
|
#[test]
|
|
fn sample_with_temperature() -> Result<()> {
|
|
let mut logits_process = LogitsProcessor::new(42, Some(0.9), None);
|
|
let logits = Tensor::new(&[0.1, 0.2, 0.3, 0.4], &Device::Cpu)?;
|
|
let token = logits_process.sample(&logits)?;
|
|
assert_eq!(token, 0);
|
|
Ok(())
|
|
}
|
|
|
|
#[test]
|
|
fn sample_with_top_p() -> Result<()> {
|
|
let mut logits_process = LogitsProcessor::new(42, Some(1.0), Some(0.5));
|
|
let logits = Tensor::new(&[0.1, 0.2, 0.3, 0.4], &Device::Cpu)?;
|
|
let token = logits_process.sample(&logits)?;
|
|
assert_eq!(token, 2);
|
|
Ok(())
|
|
}
|
|
|
|
#[test]
|
|
fn sample_with_top_k() -> Result<()> {
|
|
let mut logits_process = LogitsProcessor::from_sampling(
|
|
42,
|
|
candle_transformers::generation::Sampling::TopK {
|
|
k: 1,
|
|
temperature: 1.0,
|
|
},
|
|
);
|
|
let logits = Tensor::new(&[0.1, 0.2, 0.3, 0.4], &Device::Cpu)?;
|
|
let token = logits_process.sample(&logits)?;
|
|
assert_eq!(token, 3);
|
|
let mut logits_process = LogitsProcessor::from_sampling(
|
|
42,
|
|
candle_transformers::generation::Sampling::TopK {
|
|
k: 2,
|
|
temperature: 1.0,
|
|
},
|
|
);
|
|
let logits = Tensor::new(&[0.1, 0.2, 0.3, 0.4], &Device::Cpu)?;
|
|
let token = logits_process.sample(&logits)?;
|
|
assert_eq!(token, 3);
|
|
let token = logits_process.sample(&logits)?;
|
|
assert_eq!(token, 2);
|
|
Ok(())
|
|
}
|