dyadic permutations
This commit is contained in:
parent
b04c1508ee
commit
7c3f359c9c
|
@ -137,6 +137,39 @@ public:
|
|||
}
|
||||
|
||||
void permute_rows (const matrix&, matrix&) const;
|
||||
|
||||
//work-alike for dyadic permutations.
|
||||
template<class V> static bool permute_dyadic
|
||||
(uint sig, const V&a, V&r) {
|
||||
|
||||
//check if the thing has size 2^n
|
||||
uint s = a.size();
|
||||
while (s > 1) {
|
||||
if (s & 1) return false;
|
||||
s >>= 1;
|
||||
}
|
||||
|
||||
if (sig >= a.size() ) return false;
|
||||
|
||||
r.resize (a.size() );
|
||||
|
||||
uint i, t, x;
|
||||
for (i = 0; i < a.size(); ++i) {
|
||||
r[sig] = a[i];
|
||||
|
||||
//flip the correct bit in signature
|
||||
t = i + 1;
|
||||
x = 1;
|
||||
while (! (t & 1) ) {
|
||||
t >>= 1;
|
||||
x <<= 1;
|
||||
}
|
||||
sig ^= x;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
/*
|
||||
|
|
Loading…
Reference in a new issue