NeumaierSum

Struct NeumaierSum 

Source
pub struct NeumaierSum<ScalarType> { /* private fields */ }
Expand description

Neumaier compensated sum of an iterable object of floating-point (real or scalar) numbers.

When summing floating-point values in a vector, the standard method of adding values sequentially can lead to precision loss, especially when there are a large number of elements or a mix of very large and very small values. This happens because floating-point arithmetic is not associative due to rounding errors. The most accurate algorithm to sum floating-point numbers typically avoids these precision problems.

Kahan summation is a popular algorithm that reduces numerical errors when adding a sequence of floating-point numbers. It keeps track of a running compensation for lost low-order bits during summation.

Neumaier summation is a slight modification of Kahan summation that can handle larger errors better. It uses an extra step to correct for the compensation term if the summation results in a larger round-off error than Kahan’s method can correct.

§Example

use num_valid::neumaier_compensated_sum::NeumaierSum;

let mut neumaier = NeumaierSum::<f64>::zero();
neumaier.add(1.0);
neumaier.add(1e100);
neumaier.add(1.0);
neumaier.add(-1e100);

let sum = neumaier.sum();
println!("Sum: {}", sum);
assert_eq!(sum, 2.0);

§References

Implementations§

Source§

impl<ScalarType> NeumaierSum<ScalarType>

Source

pub fn sum_before_compensation(&self) -> &ScalarType

The sum before the compensation term is added.

Source

pub fn compensation(&self) -> &ScalarType

The compensation term. This is the correction term that is added to the sum_before_compensation to correct for the loss of precision.

Source§

impl<ScalarType> NeumaierSum<ScalarType>
where ScalarType: Clone + Zero + for<'a> Add<&'a ScalarType, Output = ScalarType> + NeumaierAddable,

Source

pub fn new(value: ScalarType) -> Self

Creates a new instance of the Neumaier compensated sum, initializing the sum with the provided value.

Source

pub fn zero() -> Self

Creates a new instance of the Neumaier compensated sum, initialized to zero.

Source

pub fn sum(&self) -> ScalarType

Computes and returns the compensated sum.

Source

pub fn reset(&mut self)

Resets the sum to zero.

Source

pub fn add(&mut self, value: ScalarType)

Adds a value to the sum. This method should be called for each value to be summed.

Source

pub fn new_sequential<I>(values: I) -> Self
where I: IntoIterator<Item = ScalarType>,

Creates a new instance of the NeumaierSum object summing the values in the iterable object values (sequential_version).

§Example
use num_valid::neumaier_compensated_sum::NeumaierSum;

let values = vec![1.0, 1.0e100, 1.0, -1.0e100];

let neumaier = NeumaierSum::new_sequential(values);
let sum = neumaier.sum();
println!("Sum: {}", sum);
assert_eq!(sum, 2.0);

Trait Implementations§

Source§

impl<ScalarType: Clone> Clone for NeumaierSum<ScalarType>

Source§

fn clone(&self) -> NeumaierSum<ScalarType>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<ScalarType: Debug> Debug for NeumaierSum<ScalarType>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<ScalarType> Freeze for NeumaierSum<ScalarType>
where ScalarType: Freeze,

§

impl<ScalarType> RefUnwindSafe for NeumaierSum<ScalarType>
where ScalarType: RefUnwindSafe,

§

impl<ScalarType> Send for NeumaierSum<ScalarType>
where ScalarType: Send,

§

impl<ScalarType> Sync for NeumaierSum<ScalarType>
where ScalarType: Sync,

§

impl<ScalarType> Unpin for NeumaierSum<ScalarType>
where ScalarType: Unpin,

§

impl<ScalarType> UnwindSafe for NeumaierSum<ScalarType>
where ScalarType: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Az for T

Source§

fn az<Dst>(self) -> Dst
where T: Cast<Dst>,

Casts the value.
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<Src, Dst> CastFrom<Src> for Dst
where Src: Cast<Dst>,

Source§

fn cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<T> CheckedAs for T

Source§

fn checked_as<Dst>(self) -> Option<Dst>
where T: CheckedCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> CheckedCastFrom<Src> for Dst
where Src: CheckedCast<Dst>,

Source§

fn checked_cast_from(src: Src) -> Option<Dst>

Casts the value.
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> OverflowingAs for T

Source§

fn overflowing_as<Dst>(self) -> (Dst, bool)
where T: OverflowingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> OverflowingCastFrom<Src> for Dst
where Src: OverflowingCast<Dst>,

Source§

fn overflowing_cast_from(src: Src) -> (Dst, bool)

Casts the value.
Source§

impl<T> SaturatingAs for T

Source§

fn saturating_as<Dst>(self) -> Dst
where T: SaturatingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> SaturatingCastFrom<Src> for Dst
where Src: SaturatingCast<Dst>,

Source§

fn saturating_cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> UnwrappedAs for T

Source§

fn unwrapped_as<Dst>(self) -> Dst
where T: UnwrappedCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> UnwrappedCastFrom<Src> for Dst
where Src: UnwrappedCast<Dst>,

Source§

fn unwrapped_cast_from(src: Src) -> Dst

Casts the value.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WrappingAs for T

Source§

fn wrapping_as<Dst>(self) -> Dst
where T: WrappingCast<Dst>,

Casts the value.
Source§

impl<Src, Dst> WrappingCastFrom<Src> for Dst
where Src: WrappingCast<Dst>,

Source§

fn wrapping_cast_from(src: Src) -> Dst

Casts the value.