/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4; fill-column: 100 -*- */ /* * 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 #include /** * This class provides LO with Kahan summation algorithm * About this algorithm: https://en.wikipedia.org/wiki/Kahan_summation_algorithm * For general purpose software we assume first order error is enough. * * Additionally queue and remember the last recent non-zero value and add it * similar to approxAdd() when obtaining the final result to further eliminate * accuracy errors. (e.g. for the dreaded 0.1 + 0.2 - 0.3 != 0.0) */ class KahanSum { public: constexpr KahanSum() = default; constexpr KahanSum(double x_0) : m_fSum(x_0) { } constexpr KahanSum(double x_0, double err_0) : m_fSum(x_0) , m_fError(err_0) { } constexpr KahanSum(const KahanSum& fSum) = default; public: /** * Adds a value to the sum using Kahan summation. * @param x_i */ void add(double x_i) { if (x_i == 0.0) return; if (!m_fMem) { m_fMem = x_i; return; } double t = m_fSum + m_fMem; if (std::abs(m_fSum) >= std::abs(m_fMem)) m_fError += (m_fSum - t) + m_fMem; else m_fError += (m_fMem - t) + m_fSum; m_fSum = t; m_fMem = x_i; } /** * Adds a value to the sum using Kahan summation. * @param fSum */ inline void add(const KahanSum& fSum) { add(fSum.m_fSum); add(fSum.m_fError); add(fSum.m_fMem); } /** * Substracts a value to the sum using Kahan summation. * @param fSum */ inline void subtract(const KahanSum& fSum) { add(-fSum.m_fSum); add(-fSum.m_fError); add(-fSum.m_fMem); } public: constexpr KahanSum operator-() const { KahanSum fKahanSum; fKahanSum.m_fSum = -m_fSum; fKahanSum.m_fError = -m_fError; fKahanSum.m_fMem = -m_fMem; return fKahanSum; } constexpr KahanSum& operator=(double fSum) { m_fSum = fSum; m_fError = 0; m_fMem = 0; return *this; } constexpr KahanSum& operator=(const KahanSum& fSum) = default; inline void operator+=(const KahanSum& fSum) { add(fSum); } inline void operator+=(double fSum) { add(fSum); } inline void operator-=(const KahanSum& fSum) { subtract(fSum); } inline void operator-=(double fSum) { add(-fSum); } inline KahanSum operator+(double fSum) const { KahanSum fNSum(*this); fNSum.add(fSum); return fNSum; } inline KahanSum operator+(const KahanSum& fSum) const { KahanSum fNSum(*this); fNSum += fSum; return fNSum; } inline KahanSum operator-(double fSum) const { KahanSum fNSum(*this); fNSum.add(-fSum); return fNSum; } inline KahanSum operator-(const KahanSum& fSum) const { KahanSum fNSum(*this); fNSum -= fSum; return fNSum; } /** * In some parts of the code of interpr_.cxx this may be used for * product instead of sum. This operator shall be used for that task. */ constexpr void operator*=(double fTimes) { if (m_fMem) { m_fSum = get() * fTimes; m_fMem = 0.0; } else { m_fSum = (m_fSum + m_fError) * fTimes; } m_fError = 0.0; } constexpr void operator/=(double fDivides) { if (m_fMem) { m_fSum = get() / fDivides; m_fMem = 0.0; } else { m_fSum = (m_fSum + m_fError) / fDivides; } m_fError = 0.0; } inline KahanSum operator*(const KahanSum& fTimes) const { return get() * fTimes.get(); } inline KahanSum operator*(double fTimes) const { return get() * fTimes; } inline KahanSum operator/(const KahanSum& fDivides) const { return get() / fDivides.get(); } inline KahanSum operator/(double fDivides) const { return get() / fDivides; } inline bool operator<(const KahanSum& fSum) const { return get() < fSum.get(); } inline bool operator<(double fSum) const { return get() < fSum; } inline bool operator>(const KahanSum& fSum) const { return get() > fSum.get(); } inline bool operator>(double fSum) const { return get() > fSum; } inline bool operator<=(const KahanSum& fSum) const { return get() <= fSum.get(); } inline bool operator<=(double fSum) const { return get() <= fSum; } inline bool operator>=(const KahanSum& fSum) const { return get() >= fSum.get(); } inline bool operator>=(double fSum) const { return get() >= fSum; } inline bool operator==(const KahanSum& fSum) const { return get() == fSum.get(); } inline bool operator!=(const KahanSum& fSum) const { return get() != fSum.get(); } public: /** * Returns the final sum. * @return final sum */ double get() const { const double fTotal = m_fSum + m_fError; if (!m_fMem) return fTotal; // Check the same condition as rtl::math::approxAdd() and if true // return 0.0, if false use another Kahan summation adding m_fMem. if (((m_fMem < 0.0 && fTotal > 0.0) || (fTotal < 0.0 && m_fMem > 0.0)) && rtl::math::approxEqual(m_fMem, -fTotal)) { /* TODO: should we reset all values to zero here for further * summation, or is it better to keep them as they are? */ return 0.0; } // The actual argument passed to add() here does not matter as long as // it is not 0, m_fMem is not 0 and will be added anyway, see add(). const_cast(this)->add(m_fMem); const_cast(this)->m_fMem = 0.0; return m_fSum + m_fError; } private: double m_fSum = 0; double m_fError = 0; double m_fMem = 0; }; /* vim:set shiftwidth=4 softtabstop=4 expandtab cinoptions=b1,g0,N-s cinkeys+=0=break: */ ffice-3-5-0'>libreoffice-3-5-0 LibreOffice 界面翻译代码仓库文档基金会
aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndras Timar <atimar@suse.com>2012-11-20 11:00:15 +0100
committerAndras Timar <atimar@suse.com>2012-11-20 11:00:15 +0100
commitb2cf0bf6fb5d098ed7997099349b74de8fb5e1f1 (patch)
treebeb7d143ffddf782f7ad8a9d6833184044e7b3e7 /source/sv/dictionaries/pt_BR.po
parentf044f8923d796ba10814d4bbe8f22c527225e56f (diff)
initial import of LibreOffice 4.0 translations
Change-Id: I577494b6b4189ed19723af4b5e273ea4da85e708
Diffstat (limited to 'source/sv/dictionaries/pt_BR.po')
-rw-r--r--source/sv/dictionaries/pt_BR.po15
1 files changed, 10 insertions, 5 deletions
diff --git a/source/sv/dictionaries/pt_BR.po b/source/sv/dictionaries/pt_BR.po
index 7a55cb8f83c..df9fed42d90 100644
--- a/source/sv/dictionaries/pt_BR.po
+++ b/source/sv/dictionaries/pt_BR.po
@@ -1,9 +1,9 @@
-#. extracted from dictionaries/pt_BR.oo
+#. extracted from dictionaries/pt_BR
msgid ""
msgstr ""
"Project-Id-Version: LibO 350-l10n\n"
-"Report-Msgid-Bugs-To: http://qa.openoffice.org/issues/enter_bug.cgi?comment=&component=l10n&form_name=enter_issue&short_desc=Localization+issue+in+file%3A+dictionaries%2Fpt_BR.oo&subcomponent=ui\n"
-"POT-Creation-Date: 2012-07-04 16:39+0200\n"
+"Report-Msgid-Bugs-To: https://bugs.freedesktop.org/enter_bug.cgi?product=LibreOffice&bug_status=UNCONFIRMED&component=UI\n"
+"POT-Creation-Date: 2012-11-17 19:03+0200\n"
"PO-Revision-Date: 2011-10-07 14:45+0200\n"
"Last-Translator: Automatically generated\n"
"Language-Team: none\n"
@@ -12,9 +12,14 @@ msgstr ""
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
"Plural-Forms: nplurals=2; plural=(n != 1);\n"
-"X-Generator: Translate Toolkit 1.9.0\n"
+"X-Generator: LibreOffice\n"
"X-Accelerator-Marker: ~\n"
-#: description.xml#dispname.dispname.description.text
+#. =qP5
+#: description.xml
+msgctxt ""
+"description.xml\n"
+"dispname\n"
+"description.text"
msgid "Brazilian Portuguese spelling Dictionary (1990 Spelling Agreement), and hyphenation rules"
msgstr "Brasiliansk portugisisk stavningsordlista (1990 överenskommelse om stavning), och böjningsregler"