1 // Copyright (C) 2011-2018 Free Software Foundation, Inc.
3 // This file is part of the GNU ISO C++ Library. This library is free
4 // software; you can redistribute it and/or modify it under the
5 // terms of the GNU General Public License as published by the
6 // Free Software Foundation; either version 3, or (at your option)
9 // This library is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License along
15 // with this library; see the file COPYING3. If not see
16 // <http://www.gnu.org/licenses/>.
21 class NaturalParameters
29 std::vector
<double>::const_iterator
31 { return m_data
.begin(); }
33 std::vector
<double>::const_iterator
35 { return m_data
.begin(); }
38 operator+=(const NaturalParameters
&)
42 std::vector
<double> m_data
;
47 operator+(const NaturalParameters
& a
, const NaturalParameters
& b
)
49 NaturalParameters tmp
= a
;
56 // Used to fail in parallel-mode with a segfault.
57 for (std::size_t i
= 0; i
< 1000; ++i
)
59 std::vector
<NaturalParameters
> ChildrenNP(1000);
60 NaturalParameters init
;
61 NaturalParameters NP
= std::accumulate(ChildrenNP
.begin(),
62 ChildrenNP
.end(), init
);