spla
Loading...
Searching...
No Matches
pair_hash.hpp
Go to the documentation of this file.
1/**********************************************************************************/
2/* This file is part of spla project */
3/* https://github.com/SparseLinearAlgebra/spla */
4/**********************************************************************************/
5/* MIT License */
6/* */
7/* Copyright (c) 2023 SparseLinearAlgebra */
8/* */
9/* Permission is hereby granted, free of charge, to any person obtaining a copy */
10/* of this software and associated documentation files (the "Software"), to deal */
11/* in the Software without restriction, including without limitation the rights */
12/* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell */
13/* copies of the Software, and to permit persons to whom the Software is */
14/* furnished to do so, subject to the following conditions: */
15/* */
16/* The above copyright notice and this permission notice shall be included in all */
17/* copies or substantial portions of the Software. */
18/* */
19/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR */
20/* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, */
21/* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE */
22/* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER */
23/* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, */
24/* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE */
25/* SOFTWARE. */
26/**********************************************************************************/
27
28#ifndef SPLA_PAIR_HASH_HPP
29#define SPLA_PAIR_HASH_HPP
30
31#include <utility>
32
33namespace spla {
34
40 template<class T>
41 inline void hash_combine(std::size_t& seed, const T& v) {
42 std::hash<T> hasher;
43 seed ^= hasher(v) + 0x9e3779b9 + (seed << 6) + (seed >> 2);
44 }
45
46 struct pair_hash {
47 public:
48 template<typename T, typename U>
49 std::size_t operator()(const std::pair<T, U>& x) const {
50 std::size_t seed = 0;
51 hash_combine(seed, x.first);
52 hash_combine(seed, x.second);
53 return seed;
54 }
55 };
56
61}// namespace spla
62
63#endif//SPLA_PAIR_HASH_HPP
void hash_combine(std::size_t &seed, const T &v)
Definition pair_hash.hpp:41
Definition algorithm.hpp:37
Definition pair_hash.hpp:46
std::size_t operator()(const std::pair< T, U > &x) const
Definition pair_hash.hpp:49