![]() |
Shadowrun: Awakened 29 September 2011 - Build 871
|
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.