Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
pola-rs
GitHub Repository: pola-rs/polars
Path: blob/main/crates/polars-ops/src/series/ops/abs.rs
6939 views
1
use polars_core::prelude::*;
2
3
/// Convert numerical values to their absolute value.
4
pub fn abs(s: &Series) -> PolarsResult<Series> {
5
use DataType::*;
6
let out = match s.dtype() {
7
#[cfg(feature = "dtype-i8")]
8
Int8 => s.i8().unwrap().wrapping_abs().into_series(),
9
#[cfg(feature = "dtype-i16")]
10
Int16 => s.i16().unwrap().wrapping_abs().into_series(),
11
Int32 => s.i32().unwrap().wrapping_abs().into_series(),
12
Int64 => s.i64().unwrap().wrapping_abs().into_series(),
13
#[cfg(feature = "dtype-i128")]
14
Int128 => s.i128().unwrap().wrapping_abs().into_series(),
15
Float32 => s.f32().unwrap().wrapping_abs().into_series(),
16
Float64 => s.f64().unwrap().wrapping_abs().into_series(),
17
#[cfg(feature = "dtype-decimal")]
18
Decimal(_, _) => {
19
let ca = s.decimal().unwrap();
20
let precision = ca.precision();
21
let scale = ca.scale();
22
23
let out = ca.physical().wrapping_abs();
24
out.into_decimal_unchecked(precision, scale).into_series()
25
},
26
#[cfg(feature = "dtype-duration")]
27
Duration(_) => {
28
let physical = s.to_physical_repr();
29
let ca = physical.i64().unwrap();
30
let out = ca.wrapping_abs().into_series();
31
out.cast(s.dtype())?
32
},
33
dt if dt.is_unsigned_integer() => s.clone(),
34
dt => polars_bail!(opq = abs, dt),
35
};
36
Ok(out)
37
}
38
39