Integer Reversal
Digit-reversal permutation, and in particular bit-reversal permutation, is a reordering technique used in some fast Fourier transform algorithms.
Define a function that generates the reversal permutation of degree .
In[1]:=
data:image/s3,"s3://crabby-images/95389/95389526e8a5e48d776733de0b4c00ae419ab01f" alt="Click for copyable input"
reversalperm[k_, b_] := IntegerReverse[Range[0, b^k - 1], b, k] + 1;
Generate the bit-reversal permutation for lists of length .
In[2]:=
data:image/s3,"s3://crabby-images/2c577/2c5774a149b8e723194cac9e2e71327beda502ca" alt="Click for copyable input"
Table[reversalperm[k, 2], {k, 0, 5}]
Out[2]=
data:image/s3,"s3://crabby-images/f2fbe/f2fbe7a0214eb7dd2abbf6afd0b2c487586385ef" alt=""
Generate the base-3 digit-reversal permutation for lists of 9 elements.
In[3]:=
data:image/s3,"s3://crabby-images/cece7/cece74fa345ebfa4cb20932c0009cb27eea75a04" alt="Click for copyable input"
reversalperm[2, 3]
Out[3]=
data:image/s3,"s3://crabby-images/8d2e8/8d2e86eae857c5dc003afe65ad18129a1bc5a9e2" alt=""
Represent those swaps.
In[4]:=
data:image/s3,"s3://crabby-images/a4ec2/a4ec23c6eb73073126529e373e4928b3232708b5" alt="Click for copyable input"
segment[{p1_, p2_}] := {PointSize[Large], Point[{p1, p2}],
Line[{p1, p2}], Text[Last[p1], p1 - {1/2, 0}],
Text[Last[p2], p2 + {1/2, 0}]};
In[5]:=
data:image/s3,"s3://crabby-images/69c49/69c49052a3fe271b9edf92aba9f98165510d653e" alt="Click for copyable input"
With[{k = 2, b = 3}, Graphics[
segment /@
Thread[{Thread[{0, Range[b^k]}], Thread[{b^k, reversalperm[k, b]}]}]
]]
Out[5]=
data:image/s3,"s3://crabby-images/92cdf/92cdf7f685d018781ffe71e2cfb9cc3b911d672f" alt=""