Walsh Hadamard Transform
(set-function/walsh-hadamard-transform.hpp)
Required by
Verified with
Code
#pragma once
template <typename T>
void walsh_hadamard_transform(vector<T>& f, bool inverse = false) {
int n = f.size();
for (int i = 1; i < n; i <<= 1) {
for (int j = 0; j < n; j++) {
if ((j & i) == 0) {
T x = f[j], y = f[j | i];
f[j] = x + y, f[j | i] = x - y;
}
}
}
if (inverse) {
if constexpr (is_integral<T>::value) {
for (auto& x : f) x /= n;
} else {
T invn = T(1) / T(f.size());
for (auto& x : f) x *= invn;
}
}
}
/**
* @brief Walsh Hadamard Transform
*/
#line 2 "set-function/walsh-hadamard-transform.hpp"
template <typename T>
void walsh_hadamard_transform(vector<T>& f, bool inverse = false) {
int n = f.size();
for (int i = 1; i < n; i <<= 1) {
for (int j = 0; j < n; j++) {
if ((j & i) == 0) {
T x = f[j], y = f[j | i];
f[j] = x + y, f[j | i] = x - y;
}
}
}
if (inverse) {
if constexpr (is_integral<T>::value) {
for (auto& x : f) x /= n;
} else {
T invn = T(1) / T(f.size());
for (auto& x : f) x *= invn;
}
}
}
/**
* @brief Walsh Hadamard Transform
*/
Back to top page