2023-08-15 16:20:26 +02:00
|
|
|
/* SPDX-FileCopyrightText: 2023 Blender Authors
|
2023-05-31 16:19:06 +02:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: GPL-2.0-or-later */
|
2017-04-14 17:13:44 +02:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2019-02-17 22:08:12 +01:00
|
|
|
/** \file
|
|
|
|
* \ingroup bli
|
2017-04-14 17:13:44 +02:00
|
|
|
*/
|
|
|
|
|
2020-05-08 18:16:39 +02:00
|
|
|
#include "BLI_utildefines.h"
|
|
|
|
|
2019-01-31 14:22:46 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2020-12-17 14:43:31 +01:00
|
|
|
/**
|
|
|
|
* Jenkins Lookup3 Hash Functions.
|
|
|
|
* Source: http://burtleburtle.net/bob/c/lookup3.c
|
|
|
|
*/
|
|
|
|
|
2017-04-24 13:58:28 +02:00
|
|
|
#define rot(x, k) (((x) << (k)) | ((x) >> (32 - (k))))
|
2020-12-17 14:43:31 +01:00
|
|
|
#define final(a, b, c) \
|
|
|
|
{ \
|
|
|
|
c ^= b; \
|
|
|
|
c -= rot(b, 14); \
|
|
|
|
a ^= c; \
|
|
|
|
a -= rot(c, 11); \
|
|
|
|
b ^= a; \
|
|
|
|
b -= rot(a, 25); \
|
|
|
|
c ^= b; \
|
|
|
|
c -= rot(b, 16); \
|
|
|
|
a ^= c; \
|
|
|
|
a -= rot(c, 4); \
|
|
|
|
b ^= a; \
|
|
|
|
b -= rot(a, 14); \
|
|
|
|
c ^= b; \
|
|
|
|
c -= rot(b, 24); \
|
|
|
|
} \
|
|
|
|
((void)0)
|
|
|
|
|
|
|
|
BLI_INLINE unsigned int BLI_hash_int_3d(unsigned int kx, unsigned int ky, unsigned int kz)
|
|
|
|
{
|
|
|
|
unsigned int a, b, c;
|
|
|
|
a = b = c = 0xdeadbeef + (3 << 2) + 13;
|
|
|
|
|
|
|
|
c += kz;
|
|
|
|
b += ky;
|
|
|
|
a += kx;
|
|
|
|
final(a, b, c);
|
|
|
|
|
|
|
|
return c;
|
|
|
|
}
|
2017-04-14 17:13:44 +02:00
|
|
|
|
2020-12-17 14:43:31 +01:00
|
|
|
BLI_INLINE unsigned int BLI_hash_int_2d(unsigned int kx, unsigned int ky)
|
|
|
|
{
|
2017-04-14 17:13:44 +02:00
|
|
|
unsigned int a, b, c;
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2017-04-14 17:13:44 +02:00
|
|
|
a = b = c = 0xdeadbeef + (2 << 2) + 13;
|
|
|
|
a += kx;
|
|
|
|
b += ky;
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2020-12-17 14:43:31 +01:00
|
|
|
final(a, b, c);
|
2019-04-17 06:17:24 +02:00
|
|
|
|
2017-04-14 17:13:44 +02:00
|
|
|
return c;
|
2020-12-17 14:43:31 +01:00
|
|
|
}
|
2017-04-14 17:13:44 +02:00
|
|
|
|
2020-12-17 14:43:31 +01:00
|
|
|
#undef final
|
2017-04-14 17:13:44 +02:00
|
|
|
#undef rot
|
|
|
|
|
2017-04-17 12:41:05 +02:00
|
|
|
BLI_INLINE unsigned int BLI_hash_string(const char *str)
|
2017-04-14 17:13:44 +02:00
|
|
|
{
|
|
|
|
unsigned int i = 0, c;
|
|
|
|
|
2017-04-24 13:58:28 +02:00
|
|
|
while ((c = *str++)) {
|
2017-04-14 17:13:44 +02:00
|
|
|
i = i * 37 + c;
|
2017-04-24 13:58:28 +02:00
|
|
|
}
|
2017-04-14 17:13:44 +02:00
|
|
|
return i;
|
|
|
|
}
|
|
|
|
|
2021-02-12 20:25:45 +01:00
|
|
|
BLI_INLINE float BLI_hash_int_2d_to_float(uint32_t kx, uint32_t ky)
|
|
|
|
{
|
|
|
|
return (float)BLI_hash_int_2d(kx, ky) / (float)0xFFFFFFFFu;
|
|
|
|
}
|
|
|
|
|
|
|
|
BLI_INLINE float BLI_hash_int_3d_to_float(uint32_t kx, uint32_t ky, uint32_t kz)
|
|
|
|
{
|
|
|
|
return (float)BLI_hash_int_3d(kx, ky, kz) / (float)0xFFFFFFFFu;
|
|
|
|
}
|
|
|
|
|
2017-04-17 12:41:05 +02:00
|
|
|
BLI_INLINE unsigned int BLI_hash_int(unsigned int k)
|
2017-04-14 17:13:44 +02:00
|
|
|
{
|
|
|
|
return BLI_hash_int_2d(k, 0);
|
|
|
|
}
|
|
|
|
|
2018-02-14 14:32:38 +01:00
|
|
|
BLI_INLINE float BLI_hash_int_01(unsigned int k)
|
|
|
|
{
|
2018-02-15 01:13:54 +01:00
|
|
|
return (float)BLI_hash_int(k) * (1.0f / (float)0xFFFFFFFF);
|
2018-02-14 14:32:38 +01:00
|
|
|
}
|
|
|
|
|
2018-03-16 12:11:55 +01:00
|
|
|
BLI_INLINE void BLI_hash_pointer_to_color(const void *ptr, int *r, int *g, int *b)
|
|
|
|
{
|
|
|
|
size_t val = (size_t)ptr;
|
|
|
|
const size_t hash_a = BLI_hash_int(val & 0x0000ffff);
|
2020-04-17 11:30:14 +02:00
|
|
|
const size_t hash_b = BLI_hash_int((uint)((val & 0xffff0000) >> 16));
|
2018-03-16 12:11:55 +01:00
|
|
|
const size_t hash = hash_a ^ (hash_b + 0x9e3779b9 + (hash_a << 6) + (hash_a >> 2));
|
|
|
|
*r = (hash & 0xff0000) >> 16;
|
|
|
|
*g = (hash & 0x00ff00) >> 8;
|
|
|
|
*b = hash & 0x0000ff;
|
|
|
|
}
|
|
|
|
|
2019-01-31 14:22:46 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|