llama_cpp_2/token/data.rs
1//! Safe wrapper around `llama_token_data`.
2use crate::token::LlamaToken;
3
4/// A transparent wrapper around `llama_token_data`.
5///
6/// Do not rely on `repr(transparent)` for this type. It should be considered an implementation
7/// detail and may change across minor versions.
8#[derive(Clone, Copy, Debug, PartialEq)]
9#[repr(transparent)]
10#[allow(clippy::module_name_repetitions)]
11pub struct LlamaTokenData {
12 data: llama_cpp_sys_2::llama_token_data,
13}
14
15impl LlamaTokenData {
16 /// Create a new token data from a token, logit, and probability.
17 /// ```
18 /// # use llama_cpp_2::token::LlamaToken;
19 /// # use llama_cpp_2::token::data::LlamaTokenData;
20 /// let token = LlamaToken::new(1);
21 /// let token_data = LlamaTokenData::new(token, 1.0, 1.0);
22 #[must_use]
23 pub fn new(LlamaToken(id): LlamaToken, logit: f32, p: f32) -> Self {
24 LlamaTokenData {
25 data: llama_cpp_sys_2::llama_token_data { id, logit, p },
26 }
27 }
28 /// Get the token's id
29 /// ```
30 /// # use llama_cpp_2::token::LlamaToken;
31 /// # use llama_cpp_2::token::data::LlamaTokenData;
32 /// let token = LlamaToken::new(1);
33 /// let token_data = LlamaTokenData::new(token, 1.0, 1.0);
34 /// assert_eq!(token_data.id(), token);
35 /// ```
36 #[must_use]
37 pub fn id(&self) -> LlamaToken {
38 LlamaToken(self.data.id)
39 }
40
41 /// Get the token's logit
42 /// ```
43 /// # use llama_cpp_2::token::LlamaToken;
44 /// # use llama_cpp_2::token::data::LlamaTokenData;
45 /// let token = LlamaToken::new(1);
46 /// let token_data = LlamaTokenData::new(token, 1.0, 1.0);
47 /// assert_eq!(token_data.logit(), 1.0);
48 /// ```
49 #[must_use]
50 pub fn logit(&self) -> f32 {
51 self.data.logit
52 }
53
54 /// Get the token's probability
55 /// ```
56 /// # use llama_cpp_2::token::LlamaToken;
57 /// # use llama_cpp_2::token::data::LlamaTokenData;
58 /// let token = LlamaToken::new(1);
59 /// let token_data = LlamaTokenData::new(token, 1.0, 1.0);
60 /// assert_eq!(token_data.p(), 1.0);
61 /// ```
62 #[must_use]
63 pub fn p(&self) -> f32 {
64 self.data.p
65 }
66
67 /// Set the token's id
68 /// ```
69 /// # use llama_cpp_2::token::LlamaToken;
70 /// # use llama_cpp_2::token::data::LlamaTokenData;
71 /// let token = LlamaToken::new(1);
72 /// let mut token_data = LlamaTokenData::new(token, 1.0, 1.0);
73 /// token_data.set_id(LlamaToken::new(2));
74 /// assert_eq!(token_data.id(), LlamaToken::new(2));
75 /// ```
76 pub fn set_id(&mut self, id: LlamaToken) {
77 self.data.id = id.0;
78 }
79
80 /// Set the token's logit
81 /// ```
82 /// # use llama_cpp_2::token::LlamaToken;
83 /// # use llama_cpp_2::token::data::LlamaTokenData;
84 /// let token = LlamaToken::new(1);
85 /// let mut token_data = LlamaTokenData::new(token, 1.0, 1.0);
86 /// token_data.set_logit(2.0);
87 /// assert_eq!(token_data.logit(), 2.0);
88 /// ```
89 pub fn set_logit(&mut self, logit: f32) {
90 self.data.logit = logit;
91 }
92
93 /// Set the token's probability
94 /// ```
95 /// # use llama_cpp_2::token::LlamaToken;
96 /// # use llama_cpp_2::token::data::LlamaTokenData;
97 /// let token = LlamaToken::new(1);
98 /// let mut token_data = LlamaTokenData::new(token, 1.0, 1.0);
99 /// token_data.set_p(2.0);
100 /// assert_eq!(token_data.p(), 2.0);
101 /// ```
102 pub fn set_p(&mut self, p: f32) {
103 self.data.p = p;
104 }
105}