Швидке перетворення Волша–Адамара

Матеріал з testwiki
Перейти до навігації Перейти до пошуку
Швидке перетворення Волша–Адамара, застосоване до вектора довжини 8
Приклад для вхідного вектора (1, 0, 1, 0, 0, 1, 1, 0)

Швидке перетворення Волша–Адамара (ШПВА) — це ефективний алгоритм для обчислення перетворення Волша–Адамара (ПВА). Наївна реалізація ПВА порядку n=2m матиме обчислювальну складність O(n2) . ШПВА вимагає лише nlogn додавань або віднімань.

ШПВА — це алгоритм типу «розділяй і володарюй», який рекурсивно розбиває ПВА розміру n на два менших ПВА розміром n/2.[1] Ця реалізація відповідає рекурсивному визначенню матриці Адамара Hm розміром 2m×2m:

Hm=12(Hm1Hm1Hm1Hm1).

Коефіцієнти нормалізації 1/2 для кожного етапу можуть бути згруповані разом або навіть пропущені.

Шаблон:Li, також відоме як упорядковане за Волшем ШПВА, отримується шляхом обчислення ШПВА, як зазначено вище, з наступним перегруповуванням виходів.

Проста швидка нерекурсивна реалізація перетворення Волша–Адамара випливає з розкладання матриці перетворення Адамара як Hm=Am, де A — корінь m -го числа Hm.[2]

Приклад коду Python

import math
def fwht(a) -> None:
    """In-place Fast Walsh–Hadamard Transform of array a."""
    assert math.log2(len(a)).is_integer(), "length of a is a power of 2"
    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]
                y = a[j + h]
                a[j] = x + y
                a[j + h] = x - y
        # normalize and increment
        a /= math.sqrt(2)
        h *= 2

Див. також

Примітки

Шаблон:Reflist

Посилання