The Community for Technology Leaders
Green Image
Dilated integers form an ordered group of the Cartesian indices into a d\hbox{-}{\rm dimensional} array represented in the Morton order. Efficient implementations of its operations can be found elsewhere. This paper offers efficient casting (type)conversions to and from an ordinary integer representation. As the Morton order representation for 2D and 3D arrays attracts more users because of its excellent block locality, the efficiency of these conversions becomes important. They are essential for programmers who would use Cartesian indexing there. Two algorithms for each casting conversion are presented here, including to-and-from dilated integers for both d = 2 and d = 3. They fall into two families. One family uses newly compact table lookup, so the cache capacity is better preserved. The other generalizes better to all d, using processor-local arithmetic that is newly presented as abstract d\hbox{-}{\rm ary} and (d - 1)\hbox{-}{\rm ary} recurrences. Test results for two and three dimensions generally favor the former.
Data Structures: Arrays, Programming Techniques: General, Memory Structures: Design Styles, Analysis of Algorithms, and Problem Complexity: Numerical algorithms, problems: computations on matrices.
David Stephen Wise, Rajeev Raman, "Converting to and from Dilated Integers", IEEE Transactions on Computers, vol. 57, no. , pp. 567-573, April 2008, doi:10.1109/TC.2007.70814
47 ms
(Ver 3.3 (11022016))