1use thiserror::Error;
4
5#[derive(Error, Debug)]
7pub enum InferenceError {
8 #[error("Model not found: {0}")]
10 ModelNotFound(String),
11
12 #[error("Failed to load model: {0}")]
14 ModelLoadError(String),
15
16 #[error("Tokenization failed: {0}")]
18 TokenizationError(String),
19
20 #[error("Inference failed: {0}")]
22 InferenceError(String),
23
24 #[error("Device not available: {0}")]
26 DeviceNotAvailable(String),
27
28 #[error("Invalid input: {0}")]
30 InvalidInput(String),
31
32 #[error("IO error: {0}")]
34 IoError(#[from] std::io::Error),
35
36 #[error("Candle error: {0}")]
38 CandleError(String),
39
40 #[error("HuggingFace Hub error: {0}")]
42 HubError(String),
43}
44
45impl From<candle_core::Error> for InferenceError {
46 fn from(err: candle_core::Error) -> Self {
47 InferenceError::CandleError(err.to_string())
48 }
49}
50
51impl From<tokenizers::Error> for InferenceError {
52 fn from(err: tokenizers::Error) -> Self {
53 InferenceError::TokenizationError(err.to_string())
54 }
55}
56
57impl From<hf_hub::api::tokio::ApiError> for InferenceError {
58 fn from(err: hf_hub::api::tokio::ApiError) -> Self {
59 InferenceError::HubError(err.to_string())
60 }
61}
62
63pub type Result<T> = std::result::Result<T, InferenceError>;