This documentation is automatically generated by online-judge-tools/verification-helper
#include "lib/convolution/set_zeta_mobius_transform.hpp"
#pragma once
/**
* @brief Set Zeta/Mobius Transform
*/
#include <vector>
#include <cassert>
template <typename T>
void superset_zeta_transform(std::vector<T> &f){
const int n = f.size();
assert((n & (n - 1)) == 0);
for(int i = 1; i < n; i <<= 1){
for(int j = 0; j < n; ++j){
if((j & i) == 0){
f[j] += f[j | i];
}
}
}
}
template <typename T>
void superset_mobius_transform(std::vector<T> &f){
const int n = f.size();
assert((n & (n - 1)) == 0);
for(int i = 1; i < n; i <<= 1){
for(int j = 0; j < n; ++j){
if((j & i) == 0){
f[j] -= f[j | i];
}
}
}
}
template <typename T>
void subset_zeta_transform(std::vector<T> &f){
const int n = f.size();
assert((n & (n - 1)) == 0);
for(int i = 1; i < n; i <<= 1){
for(int j = 0; j < n; ++j){
if((j & i) == 0){
f[j | i] += f[j];
}
}
}
}
template <typename T>
void subset_mobius_transform(std::vector<T> &f){
const int n = f.size();
assert((n & (n - 1)) == 0);
for(int i = 1; i < n; i <<= 1){
for(int j = 0; j < n; ++j){
if((j & i) == 0){
f[j | i] -= f[j];
}
}
}
}
#line 2 "lib/convolution/set_zeta_mobius_transform.hpp"
/**
* @brief Set Zeta/Mobius Transform
*/
#include <vector>
#include <cassert>
template <typename T>
void superset_zeta_transform(std::vector<T> &f){
const int n = f.size();
assert((n & (n - 1)) == 0);
for(int i = 1; i < n; i <<= 1){
for(int j = 0; j < n; ++j){
if((j & i) == 0){
f[j] += f[j | i];
}
}
}
}
template <typename T>
void superset_mobius_transform(std::vector<T> &f){
const int n = f.size();
assert((n & (n - 1)) == 0);
for(int i = 1; i < n; i <<= 1){
for(int j = 0; j < n; ++j){
if((j & i) == 0){
f[j] -= f[j | i];
}
}
}
}
template <typename T>
void subset_zeta_transform(std::vector<T> &f){
const int n = f.size();
assert((n & (n - 1)) == 0);
for(int i = 1; i < n; i <<= 1){
for(int j = 0; j < n; ++j){
if((j & i) == 0){
f[j | i] += f[j];
}
}
}
}
template <typename T>
void subset_mobius_transform(std::vector<T> &f){
const int n = f.size();
assert((n & (n - 1)) == 0);
for(int i = 1; i < n; i <<= 1){
for(int j = 0; j < n; ++j){
if((j & i) == 0){
f[j | i] -= f[j];
}
}
}
}