/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * */ #pragma once #include namespace sc::op { /** * Performs one step of the Neumanier sum between doubles * Overwrites the summand and error * @parma sum * @param err * @param value */ inline void sumNeumanierNormal(double& sum, double& err, const double& value) { double t = sum + value; if (fabs(sum) >= fabs(value)) err += (sum - t) + value; else err += (value - t) + sum; sum = t; } } // end namespace sc::op /* vim:set shiftwidth=4 softtabstop=4 expandtab: */