Skip to content

Commit

Permalink
Add MurmurHash3 implementation to hash.h/add hash.cpp.
Browse files Browse the repository at this point in the history
  • Loading branch information
TheBlueMatt committed Jan 16, 2013
1 parent 68feac9 commit 7ab026f
Show file tree
Hide file tree
Showing 7 changed files with 66 additions and 0 deletions.
1 change: 1 addition & 0 deletions bitcoin-qt.pro
Expand Up @@ -215,6 +215,7 @@ SOURCES += src/qt/bitcoin.cpp src/qt/bitcoingui.cpp \
src/version.cpp \
src/sync.cpp \
src/util.cpp \
src/hash.cpp \
src/netbase.cpp \
src/key.cpp \
src/script.cpp \
Expand Down
58 changes: 58 additions & 0 deletions src/hash.cpp
@@ -0,0 +1,58 @@
#include "hash.h"

inline uint32_t ROTL32 ( uint32_t x, int8_t r )
{
return (x << r) | (x >> (32 - r));
}

unsigned int MurmurHash3(unsigned int nHashSeed, const std::vector<unsigned char>& vDataToHash)
{
// The following is MurmurHash3 (x86_32), see http://code.google.com/p/smhasher/source/browse/trunk/MurmurHash3.cpp
uint32_t h1 = nHashSeed;
const uint32_t c1 = 0xcc9e2d51;
const uint32_t c2 = 0x1b873593;

const int nblocks = vDataToHash.size() / 4;

//----------
// body
const uint32_t * blocks = (const uint32_t *)(&vDataToHash[0] + nblocks*4);

for(int i = -nblocks; i; i++)
{
uint32_t k1 = blocks[i];

k1 *= c1;
k1 = ROTL32(k1,15);
k1 *= c2;

h1 ^= k1;
h1 = ROTL32(h1,13);
h1 = h1*5+0xe6546b64;
}

//----------
// tail
const uint8_t * tail = (const uint8_t*)(&vDataToHash[0] + nblocks*4);

uint32_t k1 = 0;

switch(vDataToHash.size() & 3)
{
case 3: k1 ^= tail[2] << 16;
case 2: k1 ^= tail[1] << 8;
case 1: k1 ^= tail[0];
k1 *= c1; k1 = ROTL32(k1,15); k1 *= c2; h1 ^= k1;
};

//----------
// finalization
h1 ^= vDataToHash.size();
h1 ^= h1 >> 16;
h1 *= 0x85ebca6b;
h1 ^= h1 >> 13;
h1 *= 0xc2b2ae35;
h1 ^= h1 >> 16;

return h1;
}
3 changes: 3 additions & 0 deletions src/hash.h
Expand Up @@ -10,6 +10,7 @@

#include <openssl/sha.h>
#include <openssl/ripemd.h>
#include <vector>

template<typename T1>
inline uint256 Hash(const T1 pbegin, const T1 pend)
Expand Down Expand Up @@ -113,4 +114,6 @@ inline uint160 Hash160(const std::vector<unsigned char>& vch)
return hash2;
}

unsigned int MurmurHash3(unsigned int nHashSeed, const std::vector<unsigned char>& vDataToHash);

#endif
1 change: 1 addition & 0 deletions src/makefile.linux-mingw
Expand Up @@ -83,6 +83,7 @@ OBJS= \
obj/wallet.o \
obj/walletdb.o \
obj/noui.o \
obj/hash.o \
obj/leveldb.o \
obj/txdb.o

Expand Down
1 change: 1 addition & 0 deletions src/makefile.mingw
Expand Up @@ -78,6 +78,7 @@ OBJS= \
obj/util.o \
obj/wallet.o \
obj/walletdb.o \
obj/hash.o \
obj/noui.o \
obj/leveldb.o \
obj/txdb.o
Expand Down
1 change: 1 addition & 0 deletions src/makefile.osx
Expand Up @@ -96,6 +96,7 @@ OBJS= \
obj/util.o \
obj/wallet.o \
obj/walletdb.o \
obj/hash.o \
obj/noui.o \
obj/leveldb.o \
obj/txdb.o
Expand Down
1 change: 1 addition & 0 deletions src/makefile.unix
Expand Up @@ -127,6 +127,7 @@ OBJS= \
obj/util.o \
obj/wallet.o \
obj/walletdb.o \
obj/hash.o \
obj/noui.o \
obj/leveldb.o \
obj/txdb.o
Expand Down

0 comments on commit 7ab026f

Please sign in to comment.