Reorder README
[purplehaze.git] / src / hashtable.h
blob8556a8b2ffcbcb443161477e1334141a8c989dc8
1 /* Copyright (C) 2007-2012 Vincent Ollivier
3 * Purple Haze is free software: you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License as published by
5 * the Free Software Foundation, either version 3 of the License, or
6 * (at your option) any later version.
8 * Purple Haze is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
13 * You should have received a copy of the GNU General Public License
14 * along with this program. If not, see <http://www.gnu.org/licenses/>.
17 #ifndef HASH_TABLE_H
18 #define HASH_TABLE_H
20 #include "common.h"
21 #include "zobrist.h"
23 template <class T>
24 class HashTable
26 protected:
27 long hits;
28 long collisions;
29 long misses;
30 const int SIZE;
31 struct Entry {
32 Hash hash;
33 T value;
35 Entry() : hash(0), value() {}
37 Entry* entries;
39 public:
40 HashTable(int used_space = MT_SIZE) :
41 hits(0),
42 collisions(0),
43 misses(0),
44 SIZE(used_space / sizeof(Entry)),
45 entries(new Entry[SIZE])
47 ~HashTable() {
48 delete [] entries;
49 entries = NULL;
51 T lookup(Hash h, bool* is_empty);
52 void save(Hash h, T v) {
53 entries[h & (SIZE - 1)].hash = h;
54 entries[h & (SIZE - 1)].value = v;
56 void clear();
58 // Used to print stats
59 int size() const {
60 return SIZE;
63 T value_at(int i) const {
64 return entries[i].value;
66 Hash hash_at(int i) const {
67 return entries[i].hash;
70 int usage() const;
71 long nb_lookups() const {
72 return hits + misses;
74 long nb_hits() const {
75 return hits;
77 long nb_collisions() const {
78 return collisions;
80 long nb_misses() const {
81 return misses;
85 #endif /* !HASH_TABLE_H */