27 lines
827 B
C++
27 lines
827 B
C++
|
#ifndef SPACEFILLING_H
|
||
|
#define SPACEFILLING_H
|
||
|
|
||
|
#include <cstdint>
|
||
|
|
||
|
// http://and-what-happened.blogspot.com/2011/08/fast-2d-and-3d-hilbert-curves-and.html
|
||
|
namespace SpaceFilling
|
||
|
{
|
||
|
uint32_t MortonToHilbert3D(const uint32_t morton, const uint32_t bits);
|
||
|
|
||
|
uint32_t HilbertToMorton3D(const uint32_t hilbert, const uint32_t bits);
|
||
|
|
||
|
uint32_t Morton_3D_Encode_5bit(uint32_t index1, uint32_t index2, uint32_t index3);
|
||
|
|
||
|
void Morton_3D_Decode_5bit(const uint32_t morton,
|
||
|
uint32_t &index1, uint32_t &index2, uint32_t &index3);
|
||
|
|
||
|
uint32_t Morton_3D_Encode_10bit(uint32_t index1, uint32_t index2, uint32_t index3);
|
||
|
|
||
|
void Morton_3D_Decode_10bit(const uint32_t morton,
|
||
|
uint32_t &index1, uint32_t &index2, uint32_t &index3);
|
||
|
|
||
|
void initLUT();
|
||
|
};
|
||
|
|
||
|
#endif
|