mirror of
https://github.com/PaddiM8/kalker.git
synced 2025-01-19 03:38:13 +01:00
Added 'diag' function
This commit is contained in:
parent
6212cd6b2d
commit
30eea3464f
@ -103,6 +103,7 @@ lazy_static! {
|
||||
pub static ref VECTOR_FUNCS: HashMap<&'static str, VectorFuncInfo> = {
|
||||
let mut m = HashMap::new();
|
||||
m.insert("average", VectorFuncInfo(average, Other));
|
||||
m.insert("diag", VectorFuncInfo(diag, Other));
|
||||
m.insert("max", VectorFuncInfo(max, Other));
|
||||
m.insert("min", VectorFuncInfo(min, Other));
|
||||
m
|
||||
@ -537,6 +538,19 @@ pub mod funcs {
|
||||
)
|
||||
}
|
||||
|
||||
pub fn diag(x: KalkValue) -> KalkValue {
|
||||
if let KalkValue::Vector(values) = x {
|
||||
let mut result = vec![vec![KalkValue::from(0f64); values.len()]; values.len()];
|
||||
for (i, value) in values.iter().enumerate() {
|
||||
result[i][i] = value.clone();
|
||||
}
|
||||
|
||||
KalkValue::Matrix(result)
|
||||
} else {
|
||||
KalkValue::nan()
|
||||
}
|
||||
}
|
||||
|
||||
pub fn exp(x: KalkValue) -> KalkValue {
|
||||
let has_imaginary = x.has_imaginary();
|
||||
let (real, imaginary, unit) = as_number_or_return!(x);
|
||||
|
Loading…
Reference in New Issue
Block a user