1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
use ndarray::{Ixs, ShapeError};
use std::error;
use std::fmt;
pub type Result<T> = ::std::result::Result<T, LinalgError>;
#[derive(Debug)]
pub enum LinalgError {
NotSquare { rows: i32, cols: i32 },
Lapack { return_code: i32 },
InvalidStride { s0: Ixs, s1: Ixs },
MemoryNotCont,
Shape(ShapeError),
}
impl fmt::Display for LinalgError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
match self {
LinalgError::NotSquare { rows, cols } => write!(f, "Not square: rows({}) != cols({})", rows, cols),
LinalgError::Lapack { return_code } => write!(f, "LAPACK: return_code = {}", return_code),
LinalgError::InvalidStride { s0, s1 } => write!(f, "invalid stride: s0={}, s1={}", s0, s1),
LinalgError::MemoryNotCont => write!(f, "Memory is not contiguous"),
LinalgError::Shape(err) => write!(f, "Shape Error: {}", err),
}
}
}
impl error::Error for LinalgError {
fn source(&self) -> Option<&(dyn error::Error + 'static)> {
match self {
LinalgError::Shape(err) => Some(err),
_ => None,
}
}
}
impl From<ShapeError> for LinalgError {
fn from(error: ShapeError) -> LinalgError {
LinalgError::Shape(error)
}
}