Added functions Re(z) and Im(z)

This commit is contained in:
bakk 2021-05-25 22:12:26 +02:00
parent a42bb5d002
commit b6412aca1e

View File

@ -92,10 +92,12 @@ lazy_static! {
m.insert("exp", (UnaryFuncInfo(exp, Other), "")); m.insert("exp", (UnaryFuncInfo(exp, Other), ""));
m.insert("floor", (UnaryFuncInfo(floor, Other), "")); m.insert("floor", (UnaryFuncInfo(floor, Other), ""));
m.insert("frac", (UnaryFuncInfo(frac, Other), "")); m.insert("frac", (UnaryFuncInfo(frac, Other), ""));
m.insert("Im", (UnaryFuncInfo(im, Other), ""));
m.insert("gamma", (UnaryFuncInfo(gamma, Other), "")); m.insert("gamma", (UnaryFuncInfo(gamma, Other), ""));
m.insert("Γ", (UnaryFuncInfo(gamma, Other), "")); m.insert("Γ", (UnaryFuncInfo(gamma, Other), ""));
m.insert("log", (UnaryFuncInfo(log, Other), "")); m.insert("log", (UnaryFuncInfo(log, Other), ""));
m.insert("ln", (UnaryFuncInfo(ln, Other), "")); m.insert("ln", (UnaryFuncInfo(ln, Other), ""));
m.insert("Re", (UnaryFuncInfo(re, Other), ""));
m.insert("round", (UnaryFuncInfo(round, Other), "")); m.insert("round", (UnaryFuncInfo(round, Other), ""));
m.insert("sqrt", (UnaryFuncInfo(sqrt, Other), "")); m.insert("sqrt", (UnaryFuncInfo(sqrt, Other), ""));
m.insert("", (UnaryFuncInfo(sqrt, Other), "")); m.insert("", (UnaryFuncInfo(sqrt, Other), ""));
@ -500,6 +502,10 @@ pub mod funcs {
KalkNum::new_with_imaginary(x.value.fract(), &x.unit, x.imaginary_value.fract()) KalkNum::new_with_imaginary(x.value.fract(), &x.unit, x.imaginary_value.fract())
} }
pub fn im(x: KalkNum) -> KalkNum {
KalkNum::new_with_imaginary(x.value, "", KalkNum::default().value)
}
pub fn log(x: KalkNum) -> KalkNum { pub fn log(x: KalkNum) -> KalkNum {
if x.has_imaginary() || x.value < 0f64 { if x.has_imaginary() || x.value < 0f64 {
// ln(z) / ln(10) // ln(z) / ln(10)
@ -532,6 +538,10 @@ pub mod funcs {
x.pow_without_unit(KalkNum::from(1f64).div_without_unit(n)) x.pow_without_unit(KalkNum::from(1f64).div_without_unit(n))
} }
pub fn re(x: KalkNum) -> KalkNum {
KalkNum::new_with_imaginary(KalkNum::default().value, "", x.imaginary_value)
}
pub fn round(x: KalkNum) -> KalkNum { pub fn round(x: KalkNum) -> KalkNum {
KalkNum::new_with_imaginary(x.value.round(), &x.unit, x.imaginary_value.round()) KalkNum::new_with_imaginary(x.value.round(), &x.unit, x.imaginary_value.round())
} }