LSSTApplications
20.0.0
LSSTDataManagementBasePackage
stack
1a1d771
Linux64
utils
20.0.0
include
lsst
utils
hashCombine.h
Go to the documentation of this file.
1
/*
2
* LSST Data Management System
3
* See COPYRIGHT file at the top of the source tree.
4
*
5
* This product includes software developed by the
6
* LSST Project (http://www.lsst.org/).
7
*
8
* This program is free software: you can redistribute it and/or modify
9
* it under the terms of the GNU General Public License as published by
10
* the Free Software Foundation, either version 3 of the License, or
11
* (at your option) any later version.
12
*
13
* This program is distributed in the hope that it will be useful,
14
* but WITHOUT ANY WARRANTY; without even the implied warranty of
15
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
* GNU General Public License for more details.
17
*
18
* You should have received a copy of the LSST License Statement and
19
* the GNU General Public License along with this program. If not,
20
* see <http://www.lsstcorp.org/LegalNotices/>.
21
*/
22
#ifndef LSST_UTILS_HASH_COMBINE_H
23
#define LSST_UTILS_HASH_COMBINE_H
24
25
#include <functional>
26
27
namespace
lsst
{
28
namespace
utils {
29
35
inline
std::size_t
hashCombine
(
std::size_t
seed) noexcept {
return
seed; }
36
59
// This implementation is provided by Matteo Italia, https://stackoverflow.com/a/38140932/834250
60
// Algorithm described at https://stackoverflow.com/a/27952689
61
// WARNING: should not be inline or constexpr; it can cause instantiation-order problems with std::hash<T>
62
template
<
typename
T,
typename
... Rest>
63
std::size_t
hashCombine
(
std::size_t
seed,
const
T& value, Rest... rest) noexcept {
64
std::hash<T>
hasher;
65
seed ^= hasher(value) + 0x9e3779b9 + (seed << 6) + (seed >> 2);
66
return
hashCombine
(seed, rest...);
67
}
68
90
// Note: not an overload of hashCombine to avoid ambiguity with hashCombine(size_t, T1, T2)
91
// WARNING: should not be inline or constexpr; it can cause instantiation-order problems with std::hash<T>
92
template
<
typename
InputIterator>
93
std::size_t
hashIterable
(
std::size_t
seed, InputIterator begin, InputIterator
end
) noexcept {
94
std::size_t
result
= 0;
95
for
(; begin !=
end
; ++begin) {
96
result
=
hashCombine
(
result
, *begin);
97
}
98
return
result
;
99
}
100
101
}}
// namespace lsst::utils
102
103
#endif
end
int end
Definition:
BoundedField.cc:105
result
py::object result
Definition:
_schema.cc:429
lsst::utils::hashIterable
std::size_t hashIterable(std::size_t seed, InputIterator begin, InputIterator end) noexcept
Combine hashes in an iterable.
Definition:
hashCombine.h:93
lsst
A base class for image defects.
Definition:
imageAlgorithm.dox:1
lsst::utils::hashCombine
std::size_t hashCombine(std::size_t seed) noexcept
Combine hashes.
Definition:
hashCombine.h:35
std::size_t
std::hash
Generated on Wed Jun 24 2020 18:10:12 for LSSTApplications by
1.8.18