Hidden subgroup problem

From Wikipedia, the free encyclopedia
Jump to navigation Jump to search

The hidden subgroup problem (HSP) is a topic of research in mathematics and theoretical computer science. The framework captures problems such as factoring, discrete logarithm, graph isomorphism, and the shortest vector problem. This makes it especially important in the theory of quantum computing because Shor's algorithms for factoring and finding discrete logarithms in quantum computing are instances of the hidden subgroup problem for finite abelian groups, while the other problems correspond to finite groups that are not abelian.

Problem statement

[edit | edit source]

Given a group G, a subgroup HG, and a set X, we say a function f:GX hides the subgroup H if for all g1,g2G,f(g1)=f(g2) if and only if g1H=g2H. Equivalently, f is constant on each coset of H, while it is different between the different cosets of H.

Hidden subgroup problem: Let G be a group, X a finite set, and f:GX a function that hides a subgroup HG. The function f is given via an oracle, which uses O(log|G|+log|X|) bits. Using information gained from evaluations of f via its oracle, determine a generating set for H.

A special case is when X is a group and f is a group homomorphism in which case H corresponds to the kernel of f.

Motivation

[edit | edit source]

The hidden subgroup problem is especially important in the theory of quantum computing for the following reasons.

Quantum algorithms

[edit | edit source]

There is an efficient quantum algorithm for solving HSP over finite abelian groups in time polynomial in log|G|. For arbitrary groups, it is known that the hidden subgroup problem is solvable using a polynomial number of evaluations of the oracle.[3] However, the circuits that implement this may be exponential in log|G|, making the algorithm not efficient overall; efficient algorithms must be polynomial in the number of oracle evaluations and running time. The existence of such an algorithm for arbitrary groups is open. Quantum polynomial time algorithms exist for certain subclasses of groups, such as semi-direct products of some abelian groups.

Algorithm for abelian groups

[edit | edit source]

The algorithm for abelian groups uses representations, i.e. homomorphisms from G to GLk(), the general linear group over the complex numbers. A representation is irreducible if it cannot be expressed as the direct product of two or more representations of G. For an abelian group, all the irreducible representations are the characters, which are the representations of dimension one; there are no irreducible representations of larger dimension for abelian groups.

Defining the quantum fourier transform

[edit | edit source]

The quantum fourier transform can be defined in terms of ZN, the additive cyclic group of order N. Introducing the characterχj(k)=ωNjk=e2πijkN,the quantum fourier transform has the definition ofFN|j=1Nk=0Nχj(k)|k.Furthermore, we define |χj=FN|j. Any finite abelian group can be written as the direct product of multiple cyclic groups ZN1×ZN2××ZNm. On a quantum computer, this is represented as the tensor product of multiple registers of dimensions N1,N2,,Nm respectively, and the overall quantum fourier transform is FN1FN2FNm.

Procedure

[edit | edit source]

The set of characters of G forms a group G^ called the dual group of G. We also have a subgroup HG^ of size |G|/|H| defined byH={χg:χg(h)=1 for all hH}For each iteration of the algorithm, the quantum circuit outputs an element gG corresponding to a character χgH, and since χg(h)=1 for all hH, it helps to pin down what H is.

The algorithm is as follows:

  1. Start with the state |0|0, where the left register's basis states are each element of G, and the right register's basis states are each element of X.
  2. Create a superposition among the basis states of G in the left register, leaving the state 1|G|gG|g|0.
  3. Query the function f. The state afterwards is 1|G|gG|g|f(g).
  4. Measure the output register. This gives some f(s) for some sG, and collapses the state to 1|H|hH|s+h|f(s) because f has the same value for each element of the coset s+H. We discard the output register to get 1|H|hH|s+h.
  5. Perform the quantum fourier transform, getting the state 1|H|hH|χs+h.
  6. This state is equal to |H||G|χgHχg(s)|g, which can be measured to learn information about H.
  7. Repeat until H (or a generating set for H) is determined.

The state in step 5 is equal to the state in step 6 because of the following:1|H|hH|χs+h=1|H||G|hHgGχs+h(g)|g=1|H||G|gGχs(g)hHχh(g)|g=1|H||G|gGχg(s)(hHχg(h))|g=|H||G|χgHχg(s)|gFor the last equality, we use the following identity:

TheoremhHχg(h)={|H|χgH0χgH

Proof

This can be derived from the orthogonality of characters. The characters of G form an orthonormal basis:1|H|hHχg(h)χg(h)={1g=g0ggWe let χg be the trivial representation, which maps all inputs to 1, to gethHχg(h)={|H|g is trivial0g is not trivialSince the summation is done over H, χg also being trivial only matters for if it is trivial over H; that is, if χgH. Thus, we know that the summation will result in |H| if χgH and will result in 0 if χgH.

Each measurement of the final state will result in some information gained about H since we know that χg(h)=1 for all hH. H, or a generating set for H, will be found after a polynomial number of measurements. The size of a generating set will be logarithmically small compared to the size of G. Let T denote a generating set for H, meaning T=H. The size of the subgroup generated by T will at least be doubled when a new element tT is added to it, because H and t+H are disjoint and because Ht+H{t}T. Therefore, the size of a generating set |T| satisfies|T|log|H|log|G|Thus a generating set for H will be able to be obtained in polynomial time even if G is exponential in size.

Instances

[edit | edit source]

Many algorithms where quantum speedups occur in quantum computing are instances of the hidden subgroup problem. The following list outlines important instances of the HSP, and whether or not they are solvable.

Problem Quantum Algorithm Abelian? Polynomial time solution?
Deutsch's problem Deutsch's algorithm; Deutsch-Jozsa algorithm Yes Yes
Simon's problem Simon's algorithm Yes Yes
Order finding Shor's order finding algorithm Yes Yes
Discrete logarithm Shor's algorithm § Shor's algorithm for discrete logarithms Yes Yes
Period finding Shor's algorithm Yes Yes
Abelian stabilizer Kitaev's algorithm[4] Yes Yes
Graph Isomorphism None No No
Shortest vector problem None No No

See also

[edit | edit source]

References

[edit | edit source]
  1. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
  2. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
  3. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
  4. ^ Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value).
[edit | edit source]