Function problem

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

In computational complexity theory, a function problem is a computational problem where a single output is expected for every input, but the output is more complex than that of a decision problem. For function problems, the output is not simply 'yes' or 'no'.

Definition

[edit | edit source]

A function problem P is defined by a relation R over strings of an arbitrary alphabet Σ:

RΣ*×Σ*.

Note that R does not have to be a functional binary relation.

An algorithm solves P if for every input x such that there exists a y satisfying (x,y)R, the algorithm produces one such y, and if there are no such y, it rejects.

A promise function problem permits the algorithm to do anything (thus may not terminate) if no such y exists.

Examples

[edit | edit source]

A well-known function problem is given by the functional Boolean satisfiability problem, FSAT for short. The problem, which is closely related to the SAT decision problem, can be formulated as follows:

Given a propositional formula φ with variables x1,,xn, find an assignment xi{TRUE,FALSE} such that φ evaluates to TRUE or decide that no such assignment exists.

In this case the relation R is given by pairs of suitably encoded propositional formulas and satisfying assignments. While a SAT algorithm, fed with a formula φ, only needs to return "unsatisfiable" or "satisfiable", an FSAT algorithm needs to return some satisfying assignment in the latter case.

Other notable examples include the travelling salesman problem, which asks for the route taken by the salesman, and the integer factorization problem, which asks for the list of factors.

Relationship to other complexity classes

[edit | edit source]

Consider an arbitrary decision problem L in the class NP. By the definition of NP, there is a system of certificates such that each problem instance x that is answered 'yes' has a polynomial-size certificate y that serves as a proof for the 'yes' answer (and problem instances answered 'no' have no such certificates). Thus, the set of these pairs (x,y) forms a relation, representing the function problem "given x in L, find a certificate y for x". This function problem is called a function variant of L; it belongs to the class FNP.

Conversely, every problem R in FNP induces a (unique) corresponding decision problem: given x, decide if there exists some y such that R(x,y) holds.

FNP can be thought of as the function class analogue of NP, in that solutions of FNP problems can be efficiently (i.e., in polynomial time in terms of the length of the input) verified, but not necessarily efficiently found. In contrast, the class FP, which can be thought of as the function class analogue of P, consists of function problems for which solutions can be found in polynomial time.

Self-reducibility

[edit | edit source]

Observe that the problem FSAT introduced above can be solved using only polynomially many calls to a subroutine that decides the SAT problem: An algorithm can first ask whether the formula φ is satisfiable. After that the algorithm can fix variable x1 to TRUE and ask again. If the resulting formula is still satisfiable the algorithm keeps x1 fixed to TRUE and continues to fix x2, otherwise it decides that x1 has to be FALSE and continues. Thus, FSAT is solvable in polynomial time using an oracle deciding SAT. In general, a problem in FNP is called self-reducible if it can be solved in polynomial time using an oracle for its induced decision problem. Every function variant of every NP-complete problem is self-reducible. There are several (slightly different) notions of self-reducibility.[1][2][3]

Reductions and complete problems

[edit | edit source]

Function problems can be reduced much like decision problems: Given function problems R and S we say that R reduces to S if there exist polynomially-time computable functions f and g such that for all instances x of R and possible solutions y of S, it holds that

  • If x has an R-solution, then f(x) has an S-solution.
  • (f(x),y)S(x,g(x,y))R.

It is therefore possible to define FNP-hard problems analogous to NP-hard problems:

A problem R is FNP-hard if every problem in FNP can be reduced to R. A problem R is FNP-complete if it is FNP-hard and in FNP. The problem FSAT is an FNP-complete problem, and hence by self-reducibility of FSAT it holds that 𝐏=𝐍𝐏 if and only if 𝐅𝐏=𝐅𝐍𝐏.

Total function problems

[edit | edit source]

The relation R(x,y) used to define function problems has the drawback of being possibly incomplete: Not every input x necessarily has a counterpart y such that (x,y)R. Therefore the question of computability of outputs is not separated from the question of their existence. To overcome this problem it is convenient to consider the restriction of function problems to total relations yielding the class TFNP as a subclass of FNP. This class contains problems such as the computation of pure Nash equilibria in certain strategic games where a solution is guaranteed to exist. In addition, if TFNP contains any FNP-complete problem it follows that 𝐍𝐏=𝐜𝐨-𝐍𝐏.

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).
  • Raymond Greenlaw, H. James Hoover, Fundamentals of the theory of computation: principles and practice, Morgan Kaufmann, 1998, Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value)., p. 45-51
  • Elaine Rich, Automata, computability and complexity: theory and applications, Prentice Hall, 2008, Lua error in Module:Citation/CS1/Configuration at line 2172: attempt to index field '?' (a nil value)., section 28.10 "The problem classes FP and FNP", pp. 689–694