2018-08-26 09:55:12 +00:00
|
|
|
/*
|
|
|
|
* Mr. 4th Dimention - Allen Webster
|
|
|
|
*
|
|
|
|
* 26.08.2018
|
|
|
|
*
|
|
|
|
* Generic hash functions
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
// TOP
|
|
|
|
|
2019-04-01 06:14:31 +00:00
|
|
|
#if !defined(FCODER_HASH_FUNCTIONS_CPP)
|
|
|
|
#define FCODER_HASH_FUNCTIONS_CPP
|
|
|
|
|
|
|
|
static u64
|
2019-07-13 00:43:17 +00:00
|
|
|
table_hash_u8(u8 *v, umem size){
|
2018-08-26 09:55:12 +00:00
|
|
|
u64 hash = 0;
|
|
|
|
for (u8 *p = v, *e = v + size; p < e; p += 1){
|
|
|
|
u8 k = *p;
|
|
|
|
k *= 81;
|
|
|
|
k = ((u8)(k << 4)) | ((u8)(k >> 4));
|
|
|
|
hash ^= k;
|
|
|
|
hash *= 11;
|
|
|
|
hash += 237;
|
|
|
|
}
|
|
|
|
return(hash);
|
|
|
|
}
|
2019-04-01 06:14:31 +00:00
|
|
|
static u64
|
2019-07-13 00:43:17 +00:00
|
|
|
table_hash_u16(u16 *v, umem size){
|
2018-08-26 09:55:12 +00:00
|
|
|
u64 hash = 0;
|
|
|
|
for (u16 *p = v, *e = v + size; p < e; p += 1){
|
|
|
|
u16 k = *p;
|
|
|
|
k *= 11601;
|
|
|
|
k = ((u16)(k << 8)) | ((u16)(k >> 8));
|
|
|
|
hash ^= k;
|
|
|
|
hash *= 11;
|
|
|
|
hash += 12525;
|
|
|
|
}
|
|
|
|
return(hash);
|
|
|
|
}
|
2019-04-01 06:14:31 +00:00
|
|
|
static u64
|
2019-07-13 00:43:17 +00:00
|
|
|
table_hash_u32(u32 *v, umem size){
|
2018-08-26 09:55:12 +00:00
|
|
|
u64 hash = 0;
|
|
|
|
for (u32 *p = v, *e = v + size; p < e; p += 1){
|
|
|
|
u32 k = *p;
|
2018-10-06 19:04:45 +00:00
|
|
|
k *= 3432918353U;
|
2018-08-26 09:55:12 +00:00
|
|
|
k = ((u32)(k << 16)) | ((u32)(k >> 16));
|
|
|
|
hash ^= k;
|
|
|
|
hash *= 11;
|
2018-10-06 19:04:45 +00:00
|
|
|
hash += 2041000173U;
|
2018-08-26 09:55:12 +00:00
|
|
|
}
|
|
|
|
return(hash);
|
|
|
|
}
|
2019-04-01 06:14:31 +00:00
|
|
|
static u64
|
2019-07-13 00:43:17 +00:00
|
|
|
table_hash_u64(u64 *v, umem size){
|
2018-08-26 09:55:12 +00:00
|
|
|
u64 hash = 0;
|
|
|
|
for (u64 *p = v, *e = v + size; p < e; p += 1){
|
|
|
|
u64 k = *p;
|
2018-10-06 15:49:13 +00:00
|
|
|
k *= 14744272059406101841ULL;
|
2018-08-26 09:55:12 +00:00
|
|
|
k = ((u64)(k << 32)) | ((u64)(k >> 32));
|
|
|
|
hash ^= k;
|
|
|
|
hash *= 11;
|
2018-10-06 19:04:45 +00:00
|
|
|
hash += 8766028991911375085ULL;
|
2018-08-26 09:55:12 +00:00
|
|
|
}
|
|
|
|
return(hash);
|
|
|
|
}
|
2019-04-01 06:14:31 +00:00
|
|
|
static u64
|
2019-07-13 00:43:17 +00:00
|
|
|
table_hash(void *v, i32 it_size, umem size){
|
2018-08-26 09:55:12 +00:00
|
|
|
u64 hash = 0;
|
|
|
|
switch (it_size){
|
|
|
|
case 1:
|
|
|
|
{
|
|
|
|
hash = table_hash_u8((u8*)v, size);
|
|
|
|
}break;
|
|
|
|
case 2:
|
|
|
|
{
|
|
|
|
hash = table_hash_u16((u16*)v, size);
|
|
|
|
}break;
|
|
|
|
case 4:
|
|
|
|
{
|
|
|
|
hash = table_hash_u32((u32*)v, size);
|
|
|
|
}break;
|
|
|
|
case 8:
|
|
|
|
{
|
|
|
|
hash = table_hash_u64((u64*)v, size);
|
|
|
|
}break;
|
|
|
|
default:
|
|
|
|
{
|
|
|
|
hash = table_hash_u8((u8*)v, it_size*size);
|
|
|
|
}break;
|
|
|
|
}
|
|
|
|
return(hash);
|
|
|
|
}
|
|
|
|
|
2019-04-01 06:14:31 +00:00
|
|
|
#endif
|
2018-08-26 09:55:12 +00:00
|
|
|
|
2019-04-01 06:14:31 +00:00
|
|
|
// BOTTOM
|
2018-08-26 09:55:12 +00:00
|
|
|
|