Blender V2.61 - r43446
|
00001 /* 00002 * Copyright 2011, Blender Foundation. 00003 * 00004 * This program is free software; you can redistribute it and/or 00005 * modify it under the terms of the GNU General Public License 00006 * as published by the Free Software Foundation; either version 2 00007 * of the License, or (at your option) any later version. 00008 * 00009 * This program is distributed in the hope that it will be useful, 00010 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00011 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00012 * GNU General Public License for more details. 00013 * 00014 * You should have received a copy of the GNU General Public License 00015 * along with this program; if not, write to the Free Software Foundation, 00016 * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. 00017 */ 00018 00019 #ifndef __UTIL_HASH_H__ 00020 #define __UTIL_HASH_H__ 00021 00022 CCL_NAMESPACE_BEGIN 00023 00024 static inline unsigned int hash_int_2d(unsigned int kx, unsigned int ky) 00025 { 00026 #define rot(x,k) (((x)<<(k)) | ((x)>>(32-(k)))) 00027 00028 unsigned int a, b, c; 00029 00030 a = b = c = 0xdeadbeef + (2 << 2) + 13; 00031 a += kx; 00032 b += ky; 00033 00034 c ^= b; c -= rot(b,14); 00035 a ^= c; a -= rot(c,11); 00036 b ^= a; b -= rot(a,25); 00037 c ^= b; c -= rot(b,16); 00038 a ^= c; a -= rot(c,4); 00039 b ^= a; b -= rot(a,14); 00040 c ^= b; c -= rot(b,24); 00041 00042 return c; 00043 00044 #undef rot 00045 } 00046 00047 static inline unsigned int hash_int(unsigned int k) 00048 { 00049 return hash_int_2d(k, 0); 00050 } 00051 00052 CCL_NAMESPACE_END 00053 00054 #endif /* __UTIL_HASH_H__ */ 00055