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("Invalid input: {0}")]
26 InvalidInput(String),
27
28 #[error("IO error: {0}")]
30 IoError(#[from] std::io::Error),
31
32 #[error("ONNX Runtime error: {0}")]
34 OrtError(String),
35
36 #[error("HuggingFace Hub error: {0}")]
38 HubError(String),
39
40 #[error("Extraction failed: {0}")]
42 ExtractionFailed(String),
43
44 #[error("Cross-encoder reranker at capacity ({active}/{max} active)")]
51 Overloaded { active: usize, max: usize },
52
53 #[error("Candle error: {0}")]
55 CandleError(String),
56
57 #[error("GGUF error: {0}")]
59 GgufError(String),
60
61 #[error("Binary quantization error: {0}")]
63 BinaryQuantError(String),
64}
65
66impl From<ort::Error> for InferenceError {
67 fn from(err: ort::Error) -> Self {
68 InferenceError::OrtError(err.to_string())
69 }
70}
71
72impl From<tokenizers::Error> for InferenceError {
73 fn from(err: tokenizers::Error) -> Self {
74 InferenceError::TokenizationError(err.to_string())
75 }
76}
77
78pub type Result<T> = std::result::Result<T, InferenceError>;