summaryrefslogtreecommitdiff
path: root/candle-core/src/quantized
diff options
context:
space:
mode:
authorLaurent Mazare <laurent.mazare@gmail.com>2024-12-22 09:18:13 +0100
committerGitHub <noreply@github.com>2024-12-22 09:18:13 +0100
commit62ced44ea94da7062430ed6c21ff17b36f41737d (patch)
treeffcb633955da0d743b013266de9b8b45bd59a1f0 /candle-core/src/quantized
parent5c2f893e5aa21c9f7c82a00407edb6d76db1d06c (diff)
downloadcandle-62ced44ea94da7062430ed6c21ff17b36f41737d.tar.gz
candle-62ced44ea94da7062430ed6c21ff17b36f41737d.tar.bz2
candle-62ced44ea94da7062430ed6c21ff17b36f41737d.zip
Add a Context trait similar to anyhow::Context. (#2676)
* Add a Context trait similar to anyhow::Context. * Switch two unwrap to context.
Diffstat (limited to 'candle-core/src/quantized')
-rw-r--r--candle-core/src/quantized/gguf_file.rs4
-rw-r--r--candle-core/src/quantized/mod.rs4
2 files changed, 4 insertions, 4 deletions
diff --git a/candle-core/src/quantized/gguf_file.rs b/candle-core/src/quantized/gguf_file.rs
index ccbd59eb..2ea6c7a3 100644
--- a/candle-core/src/quantized/gguf_file.rs
+++ b/candle-core/src/quantized/gguf_file.rs
@@ -2,7 +2,7 @@
//!
use super::{GgmlDType, QTensor};
-use crate::{Device, Result};
+use crate::{Context, Device, Result};
use byteorder::{LittleEndian, ReadBytesExt, WriteBytesExt};
use std::collections::HashMap;
@@ -338,7 +338,7 @@ impl Value {
if value_type.len() != 1 {
crate::bail!("multiple value-types in the same array {value_type:?}")
}
- value_type.into_iter().next().unwrap()
+ value_type.into_iter().next().context("empty value_type")?
};
w.write_u32::<LittleEndian>(value_type.to_u32())?;
w.write_u64::<LittleEndian>(v.len() as u64)?;
diff --git a/candle-core/src/quantized/mod.rs b/candle-core/src/quantized/mod.rs
index 236f5a98..802c5691 100644
--- a/candle-core/src/quantized/mod.rs
+++ b/candle-core/src/quantized/mod.rs
@@ -1,5 +1,5 @@
//! Code for GGML and GGUF files
-use crate::{CpuStorage, DType, Device, Result, Shape, Storage, Tensor};
+use crate::{Context, CpuStorage, DType, Device, Result, Shape, Storage, Tensor};
use k_quants::*;
use std::borrow::Cow;
@@ -481,7 +481,7 @@ impl crate::CustomOp1 for QTensor {
crate::bail!("input tensor has only one dimension {layout:?}")
}
let mut dst_shape = src_shape.dims().to_vec();
- let last_k = dst_shape.pop().unwrap();
+ let last_k = dst_shape.pop().context("empty dst_shape")?;
if last_k != k {
crate::bail!("input tensor {layout:?} incompatible with {:?}", self.shape)
}