ClangFormat: apply to source, most of intern
[blender.git] / intern / cycles / util / util_hash.h
1 /*
2  * Copyright 2011-2013 Blender Foundation
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 #ifndef __UTIL_HASH_H__
18 #define __UTIL_HASH_H__
19
20 #include "util/util_types.h"
21
22 CCL_NAMESPACE_BEGIN
23
24 ccl_device_inline uint hash_int_2d(uint kx, uint ky)
25 {
26 #define rot(x, k) (((x) << (k)) | ((x) >> (32 - (k))))
27
28   uint a, b, c;
29
30   a = b = c = 0xdeadbeef + (2 << 2) + 13;
31   a += kx;
32   b += ky;
33
34   c ^= b;
35   c -= rot(b, 14);
36   a ^= c;
37   a -= rot(c, 11);
38   b ^= a;
39   b -= rot(a, 25);
40   c ^= b;
41   c -= rot(b, 16);
42   a ^= c;
43   a -= rot(c, 4);
44   b ^= a;
45   b -= rot(a, 14);
46   c ^= b;
47   c -= rot(b, 24);
48
49   return c;
50
51 #undef rot
52 }
53
54 ccl_device_inline uint hash_int(uint k)
55 {
56   return hash_int_2d(k, 0);
57 }
58
59 #ifndef __KERNEL_GPU__
60 static inline uint hash_string(const char *str)
61 {
62   uint i = 0, c;
63
64   while ((c = *str++))
65     i = i * 37 + c;
66
67   return i;
68 }
69 #endif
70
71 ccl_device_inline float hash_int_01(uint k)
72 {
73   return (float)hash_int(k) * (1.0f / (float)0xFFFFFFFF);
74 }
75
76 CCL_NAMESPACE_END
77
78 #endif /* __UTIL_HASH_H__ */