File: HashKey.hh

package info (click to toggle)
topcom 1.1.2%2Bds-1.1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 31,788 kB
  • sloc: cpp: 37,616; sh: 4,262; makefile: 497; ansic: 49
file content (105 lines) | stat: -rw-r--r-- 2,617 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
////////////////////////////////////////////////////////////////////////////////
// 
// HashKey.hh
//    produced: 01/09/97 jr
// last change: 24/01/99 jr
//
////////////////////////////////////////////////////////////////////////////////
#ifndef HASHKEY_HH
#define HASHKEY_HH

#include "Global.hh"
#include "Field.hh"

namespace topcom {

  template<class Key>
  class HashKeySize {
  public:
    inline size_type operator()(const Key& key) const { return key.keysize(); }
  };

  template<class Key>
  class HashKey {
  public:
    inline size_type operator()(const Key& key, const size_type n) const { return key.key(n); }
  };

  // for the use in STL vectors/unordered sets/maps:
  template<class Key>
  class Hash {
  private:
    static const size_type _init_constant  = sizeof(size_type) >= 8 ? 525201411107845655ull : 3323198485ul;
    static const size_type _mult_constant  = sizeof(size_type) >= 8 ? 0x5bd1e9955bd1e995    : 0x5bd1e995 ; 
    static const int       _shift_constant = sizeof(size_type) >= 8 ? 47ul                  : 15; 
  public:
    inline size_type operator()(const Key& key) const {
      // use single-byte MurmurHash:
      size_type result(_init_constant);
      const size_type keysize = key.keysize();
      for (size_type i = 0; i < keysize; ++i) {
	// result = (result << 5) - result;
	// result += key.key(i);
	result ^= key.key(i);
	result *= _mult_constant;
	result ^= (result >> _shift_constant);
      }
      return result;
    }
  };

  template<>
  class Hash<size_type> {
  public:
    inline size_type operator()(const size_type key) const {
      return key;
    }
  };

  template<>
  class Hash<int> {
  public:
    inline size_type operator()(const int key) const {
      return key;
    }
  };

  //////////////////////////////////////////////////////////////////////////////
  // some specializations:
  //////////////////////////////////////////////////////////////////////////////

  // size_type:

  template<>
  class HashKeySize<size_type> {
  public:
    size_type operator()(const size_type& key) const { return 1; }
  };

  template<>
  class HashKey<size_type> {
  public:
    size_type operator()(const size_type& key, const size_type n) const { return key; }
  };

  template<>
  class HashKeySize<Field> {
  public:
    inline size_type operator()(const Field& key) const { return 1; }
  };

  // Field:
  
  template<>
  class HashKey<Field> {
  public:
    inline size_type operator()(const Field& key, const size_type n) const { 
      hash<Field> hash_obj;
      return hash_obj(key); 
    }
  };

}; // namespace topcom

#endif
// eof HashKey.hh