diff options
Diffstat (limited to 'chilbert')
-rw-r--r-- | chilbert/Hilbert.hpp | 224 | ||||
-rw-r--r-- | chilbert/Hilbert.ipp (renamed from chilbert/Algorithm.hpp) | 19 |
2 files changed, 72 insertions, 171 deletions
diff --git a/chilbert/Hilbert.hpp b/chilbert/Hilbert.hpp index a6b48fb..5b4646d 100644 --- a/chilbert/Hilbert.hpp +++ b/chilbert/Hilbert.hpp @@ -19,172 +19,72 @@ #ifndef CHILBERT_HILBERT_HPP #define CHILBERT_HILBERT_HPP -#include "chilbert/Algorithm.hpp" -#include "chilbert/BigBitVec.hpp" -#include "chilbert/FixBitVec.hpp" - -// Description of parameters: -// -// FOR REGULAR HILBERT INDICES -// -// CFixBitVec/CBigBitVec *p -// Pointer to array of non-negative coordinate values. -// -// int m -// Precision of all coordinate values (number of bits required to -// represent the largest possible coordinate value). -// -// int n -// Number of dimensions (size of the array *p). -// -// CFixBitVec/CBigBitVec &h -// Hilbert index of maximum precision m*n. -// -// int *ms -// Array of precision values, one per dimension. -// -// FOR COMPACT HILBERT INDICES -// -// CFixBitVec/CBigBitVec &hc -// Compact Hilbert index of maximum precision M. -// -// int M -// Net precision value, corresponding to the size of the compact -// Hilbert code. If not provided, defaults to zero and will be calculated -// by the function (sum_i { ms[i] }). -// -// int m -// Largest precision value (max_i { ms[i] }). If not provided, defaults -// to zero and will be calculated by the function, +#include <cstddef> namespace chilbert { -// fix -> fix - -inline void -coordsToIndex(const CFixBitVec* const p, - const size_t m, - const size_t n, - CFixBitVec& h) -{ - coordsToIndex<CFixBitVec, CFixBitVec>(p, m, n, h); -} - -inline void -indexToCoords(CFixBitVec* const p, - const size_t m, - const size_t n, - const CFixBitVec& h) -{ - indexToCoords<CFixBitVec, CFixBitVec>(p, m, n, h); -} - -inline void -coordsToCompactIndex(const CFixBitVec* const p, - const size_t* const ms, - const size_t n, - CFixBitVec& hc, - const size_t M, - const size_t m) -{ - coordsToCompactIndex<CFixBitVec, CFixBitVec>(p, ms, n, hc, M, m); -} - -inline void -compactIndexToCoords(CFixBitVec* const p, - const size_t* const ms, - const size_t n, - const CFixBitVec& hc, - const size_t M, - const size_t m) -{ - compactIndexToCoords<CFixBitVec, CFixBitVec>(p, ms, n, hc, M, m); -} - -// fix -> big - -inline void -coordsToIndex(const CFixBitVec* const p, - const size_t m, - const size_t n, - CBigBitVec& h) -{ - coordsToIndex<CFixBitVec, CBigBitVec>(p, m, n, h); -} - -inline void -indexToCoords(CFixBitVec* const p, - const size_t m, - const size_t n, - const CBigBitVec& h) -{ - indexToCoords<CFixBitVec, CBigBitVec>(p, m, n, h); -} - -inline void -coordsToCompactIndex(const CFixBitVec* const p, - const size_t* const ms, - const size_t n, - CBigBitVec& hc, - const size_t M, - const size_t m) -{ - coordsToCompactIndex<CFixBitVec, CBigBitVec>(p, ms, n, hc, M, m); -} - -inline void -compactIndexToCoords(CFixBitVec* const p, - const size_t* const ms, - const size_t n, - const CBigBitVec& hc, - const size_t M, - const size_t m) -{ - compactIndexToCoords<CFixBitVec, CBigBitVec>(p, ms, n, hc, M, m); -} - -// big -> big - -inline void -coordsToIndex(const CBigBitVec* p, - const size_t m, - const size_t n, - CBigBitVec& h) -{ - coordsToIndex<CBigBitVec, CBigBitVec>(p, m, n, h); -} - -inline void -indexToCoords(CBigBitVec* const p, - const size_t m, - const size_t n, - const CBigBitVec& h) -{ - indexToCoords<CBigBitVec, CBigBitVec>(p, m, n, h); -} - -inline void -coordsToCompactIndex(const CBigBitVec* const p, - const size_t* const ms, - const size_t n, - CBigBitVec& hc, - const size_t M, - const size_t m) -{ - coordsToCompactIndex<CBigBitVec, CBigBitVec>(p, ms, n, hc, M, m); -} - -inline void -compactIndexToCoords(CBigBitVec* const p, - const size_t* const ms, - const size_t n, - const CBigBitVec& hc, - const size_t M, - const size_t m) -{ - compactIndexToCoords<CBigBitVec, CBigBitVec>(p, ms, n, hc, M, m); -} +/** Map the point `p` to a Hilbert Index. + * + * @param p Point with `n` dimensions. + * @param m Precision of each dimension in bits. + * @param n Number of dimensions. + * @param[out] h Hilbert Index. + */ +template <class P, class H> +inline void coordsToIndex(const P* const p, + const size_t m, + const size_t n, + H& h); + +/** Map the Hilbert Index `p` to a point. + * + * @param[out] p Point with `n` dimensions. + * @param m Precision of each dimension in bits. + * @param n Number of dimensions. + * @param h Hilbert Index. + */ +template <class P, class H> +inline void indexToCoords(P* const p, + const size_t m, + const size_t n, + const H& h); + +/** Map the point `p` to a Compact Hilbert Index. + * + * @param p Point with `n` dimensions. + * @param ms Array of `n` precision values for each dimension in bits. + * @param n Number of dimensions. + * @param[out] hc Compact Hilbert Index. + * @param M Optional net precision (sum of `ms`), the size of `hc` in bits. + * @param m Optional largest precision in `m`. + */ +template <class P, class H> +inline void coordsToCompactIndex(const P* const p, + const size_t* const ms, + const size_t n, + H& hc, + const size_t M = 0, + const size_t m = 0); + +/** Map the Compact Hilbert Index `hc` to a point. + * + * @param[out] p Point with `n` dimensions. + * @param ms Array of `n` precision values for each dimension in bits. + * @param n Number of dimensions. + * @param hc Compact Hilbert Index. + * @param M Optional net precision (sum of `ms`), the size of `hc` in bits. + * @param m Optional largest precision in `m`. + */ +template <class P, class H> +inline void compactIndexToCoords(P* const p, + const size_t* const ms, + const size_t n, + const H& hc, + const size_t M = 0, + const size_t m = 0); } // namespace chilbert +#include "chilbert/Hilbert.ipp" + #endif diff --git a/chilbert/Algorithm.hpp b/chilbert/Hilbert.ipp index e5072b0..b4f2b63 100644 --- a/chilbert/Algorithm.hpp +++ b/chilbert/Hilbert.ipp @@ -24,6 +24,7 @@ #include "chilbert/GetBits.hpp" #include "chilbert/GetLocation.hpp" #include "chilbert/GrayCodeRank.hpp" +#include "chilbert/Hilbert.hpp" #include "chilbert/SetBits.hpp" #include "chilbert/SetLocation.hpp" @@ -121,7 +122,7 @@ _coordsToIndex(const P* const p, H& h, I&& scratch, size_t* const ds = nullptr // #HACK - ) +) { I e{std::move(scratch)}; I l{e}; @@ -178,7 +179,7 @@ coordsToIndex(const P* const p, // [in ] point const size_t m, // [in ] precision of each dimension in bits const size_t n, // [in ] number of dimensions H& h // [out] Hilbert index - ) +) { if (n <= FBV_BITS) { // Intermediate variables will fit in fixed width @@ -244,7 +245,7 @@ indexToCoords(P* const p, // [out] point const size_t m, // [in ] precision of each dimension in bits const size_t n, // [in ] number of dimensions const H& h // [out] Hilbert index - ) +) { if (n <= FBV_BITS) { // Intermediate variables will fit in fixed width @@ -309,8 +310,8 @@ coordsToCompactIndex( const size_t* const ms, // [in ] precision of each dimension in bits size_t n, // [in ] number of dimensions HC& hc, // [out] Hilbert index - const size_t M = 0, - const size_t m = 0) + const size_t M, + const size_t m) { if (n <= FBV_BITS) { // Intermediate variables will fit in fixed width? @@ -330,8 +331,8 @@ _compactIndexToCoords(P* const p, const size_t n, const HC& hc, I&& scratch, - size_t M = 0, - size_t m = 0) + size_t M, + size_t m) { I e{std::move(scratch)}; I l{e}; @@ -407,8 +408,8 @@ compactIndexToCoords( const size_t* ms, // [in ] precision of each dimension in bits const size_t n, // [in ] number of dimensions const HC& hc, // [out] Hilbert index - const size_t M = 0, - const size_t m = 0) + const size_t M, + const size_t m) { if (n <= FBV_BITS) { // Intermediate variables will fit in fixed width |