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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
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,
NotStandardShape {
obj: &'static str,
rows: i32,
cols: i32,
},
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::NotStandardShape { obj, rows, cols } => write!(
f,
"{} cannot be made from a ({}, {}) matrix",
obj, rows, cols
),
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)
}
}