-
Notifications
You must be signed in to change notification settings - Fork 50
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Inconsistency in two_block_group_algebra_codes (2BGA) for non-abelian groups #405
Labels
bug
Something isn't working
Comments
Fe-r-oz
changed the title
Inconsistency in two_block_group_algebra_codes (2BGA) code for non-abelian groups
Inconsistency in two_block_group_algebra_codes (2BGA) for non-abelian groups
Oct 25, 2024
Fe-r-oz
added a commit
to Fe-r-oz/QuantumClifford.jl
that referenced
this issue
Oct 26, 2024
…-abelian 2BGA, and misc polish
The third method using julia> using QuantumClifford: check_allrowscommute, stab_looks_good; using QuantumClifford.ECC: two_block_group_algebra_codes, code_n, code_k, parity_checks;
julia> import Hecke: gens, quo, group_algebra, GF, one;
julia> using Oscar: small_group_identification, describe, order, semidirect_product, automorphism_group, hom, gen, cyclic_group;
julia> m = 6;
julia> Cₘ = cyclic_group(m);
julia> C₂ = cyclic_group(2);
julia> A = automorphism_group(Cₘ); # Given dihedral group presentation, choose r -> r⁻¹
julia> au = A(hom(Cₘ,Cₘ,[Cₘ[1]],[Cₘ[1]^-1]));
julia> f = hom(C₂,A,[C₂[1]],[au]);
julia> G = semidirect_product(Cₘ,f,C₂);
julia> GA = group_algebra(GF(2), G);
julia> s, r = gens(GA); # first, we show that this set of generators indeed satisfy the standard group presentation: https://en.wikipedia.org/wiki/Dihedral_group#Other_definitions
julia> r^m == s^2 == (s*r)^2 # presentation is satisfied
true
julia> a_elts = [one(r), r^4];
julia> b_elts = [one(r), s*r^4, r^3, r^4, s*r^2, r];
julia> a = sum(GA(x) for x in a_elts);
julia> b = sum(GA(x) for x in b_elts);
julia> c = two_block_group_algebra_codes(a,b);
julia> check_allrowscommute(parity_checks(c)) # inconsistency
false
julia> stab_looks_good(parity_checks(c), remove_redundant_rows = true) # inconsistency
false
julia> order(G) # correct
12
julia> describe(G) # correct
"D12"
julia> code_n(c), code_k(c) # matches with the paper
(24, 8) |
3 tasks
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Describe the bug 🐞
There is an inconsistency in the
two_block_group_algebra_codes
(2BGA) implementation in #356. The current 2BGA code follows the standard definition as outlined in the literature. However, when non-abelian groups are used, the resulting stabilizer matrix becomes non-commutative, causing thecheck_allrowscommute
test withinstab_looks_good
to fail.The group algebra construction,
group_algebra(GF(2), parent(group_elem_array[1,1]))
, permits the use of non-abelian groups as per the standard definition for 2BGA codes. To illustrate this, a dihedral group can be used as an example. We have found that, although the code parameters are correct, the stabilizer matrix fails to be commutative.QuantumClifford.jl/ext/QuantumCliffordHeckeExt/lifted.jl
Line 67 in f3eb7cd
Expected behavior
The expectation is that the stabilizer matrix should be commutative. After all, non-abelian groups satisfy the CSS orthogonality condition, which is verified by the commutativity of the left and right representation matrices in the group algebra of non-abelian groups.
This inconsistency was overlooked because non-abelian groups were not tested during the implementation of the 2BGA.
For more details, https://arxiv.org/pdf/1407.6228, Appendix B of https://arxiv.org/pdf/2111.03654
Minimal Reproducible Example 👇
[[24, 8, 3]] from Table 3, Example 1: of https://arxiv.org/pdf/2306.16400.
Now, let's do the above same example using
Oscar.free_group
, to reproduce the same error:Additional context
The Alternating group 2BGA given in ECC Zoo example fails the
stab_looks_good
andcheck_allrowscommute
test as well: https://errorcorrectionzoo.org/c/2bgaWhen the group is abelian, no errors occur.
I would like to express my sincere gratitude to Tommy for his invaluable guidance.
The text was updated successfully, but these errors were encountered: