Fast Walsh–Hadamard transform explained

In computational mathematics, the Hadamard ordered fast Walsh–Hadamard transform (FWHTh) is an efficient algorithm to compute the Walsh–Hadamard transform (WHT). A naive implementation of the WHT of order

n=2m

would have a computational complexity of O(

n2

)
. The FWHTh requires only

nlogn

additions or subtractions.

The FWHTh is a divide-and-conquer algorithm that recursively breaks down a WHT of size

n

into two smaller WHTs of size

n/2

. [1] This implementation follows the recursive definition of the

2m x 2m

Hadamard matrix

Hm

:

Hm=

1
\sqrt2

\begin{pmatrix}Hm-1&Hm-1\Hm-1&-Hm-1\end{pmatrix}.

The

1/\sqrt2

normalization factors for each stage may be grouped together or even omitted.

The sequency-ordered, also known as Walsh-ordered, fast Walsh–Hadamard transform, FWHTw, is obtained by computing the FWHTh as above, and then rearranging the outputs.

A simple fast nonrecursive implementation of the Walsh–Hadamard transform follows from decomposition of the Hadamard transform matrix as

Hm=Am

, where A is m-th root of

Hm

. [2]

Python example code

def fwht(a) -> None: """In-place Fast Walsh–Hadamard Transform of array a.""" h = 1 while h < len(a): # perform FWHT for i in range(0, len(a), h * 2): for j in range(i, i + h): x = a[j % len(a)] y = a[(j + h) % len(a)] a[j % len(a)] = x + y a[(j + h) % len(a)] = x - y # normalize and increment a /= math.sqrt(2) h *= 2

See also

External links

Notes and References

  1. Fino . B. J. . Algazi . V. R. . 1976 . Unified Matrix Treatment of the Fast Walsh–Hadamard Transform . IEEE Transactions on Computers . 25 . 11 . 1142–1146 . 10.1109/TC.1976.1674569 . 13252360 .
  2. Yarlagadda and Hershey, "Hadamard Matrix Analysis and Synthesis", 1997 (Springer)