Shadowrun: Awakened 29 September 2011 - Build 871
MurmurHash2.hpp
Go to the documentation of this file.
00001 /*
00002     Copyright (c) 2009-2010 Christopher A. Taylor.  All rights reserved.
00003 
00004     Redistribution and use in source and binary forms, with or without
00005     modification, are permitted provided that the following conditions are met:
00006 
00007     * Redistributions of source code must retain the above copyright notice,
00008       this list of conditions and the following disclaimer.
00009     * Redistributions in binary form must reproduce the above copyright notice,
00010       this list of conditions and the following disclaimer in the documentation
00011       and/or other materials provided with the distribution.
00012     * Neither the name of LibCat nor the names of its contributors may be used
00013       to endorse or promote products derived from this software without
00014       specific prior written permission.
00015 
00016     THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00017     AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00018     IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00019     ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
00020     LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
00021     CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
00022     SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
00023     INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
00024     CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
00025     ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00026     POSSIBILITY OF SUCH DAMAGE.
00027 */
00028 
00029 /*
00030     MurmurHash2 is a very fast noncryptographic 32/64-bit hash
00031 
00032     Algorithm by Austin Appleby <aappleby@gmail.com>
00033     http://murmurhash.googlepages.com/
00034 */
00035 
00036 #ifndef CAT_MURMUR_HASH_2_HPP
00037 #define CAT_MURMUR_HASH_2_HPP
00038 
00039 #include <cat/Platform.hpp>
00040 
00041 namespace cat {
00042 
00043 
00044 // NOTE: Result is NOT endian-neutral.  Use getLE().
00045 u32 MurmurHash32(const void *key, int bytes, u32 seed);
00046 u64 MurmurHash64(const void *key, int bytes, u64 seed);
00047 
00048 
00049 class IncrementalMurmurHash32
00050 {
00051     u32 _hash, _tail, _count, _size;
00052 
00053     static const u32 M = 0x5bd1e995;
00054     static const u32 R = 24;
00055 
00056 public:
00057     void Begin(u32 seed = 0);
00058     void Add(const void *data, int bytes);
00059     u32 End();
00060 };
00061 
00062 
00063 class IncrementalMurmurHash64
00064 {
00065     u32 _count;
00066     u64 _hash, _tail, _size;
00067 
00068     static const u64 M = 0xc6a4a7935bd1e995ULL;
00069     static const u64 R = 47;
00070 
00071 public:
00072     void Begin(u64 seed = 0);
00073     void Add(const void *data, int bytes);
00074     u64 End();
00075 };
00076 
00077 
00078 } // namespace cat
00079 
00080 #endif // CAT_MURMUR_HASH_2_HPP

Copyright © 2007-2010 by The Shadowrun: Awakened Team. This work is licensed under the GNU Lesser General Public License 3.

GNU Lesser General Public License 3 Sourceforge.net