Hidden subgroup problem: Difference between revisions

From testwiki
Jump to navigation Jump to search
imported>Tito Omburo
Instances: increase section depth
 
(No difference)

Latest revision as of 13:47, 16 January 2025

Template:Short description Template:Use American English 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

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

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

Quantum algorithms

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

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

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

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: Template:Math theoremTemplate:Math proof 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

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 Template:Section link 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

References

Template:Quantum Computing