In mathematics, function application is the act of applying a function to an argument from its domain so as to obtain the corresponding value from its range. In this sense, function application can be thought of as the opposite of function abstraction.
Function application is usually depicted by juxtaposing the variable representing the function with its argument encompassed in parentheses. For example, the following expression represents the application of the function ƒ to its argument x.
f(x)
In some instances, a different notation is used where the parentheses aren't required, and function application can be expressed just by juxtaposition. For example, the following expression can be considered the same as the previous one:
f x
The latter notation is especially useful in combination with the currying isomorphism. Given a function
f:(X x Y)\toZ
f(x,y)
f (x,y)
f \langlex,y\rangle
\langlex,y\rangle\inX x Y
f:X\to(Y\toZ)
f x y
f(x)(y)
See main article: Apply.
Function application can be trivially defined as an operator, called apply or
\$
f\$x=f(x)
The operator may also be denoted by a backtick (`).
If the operator is understood to be of low precedence and right-associative, the application operator can be used to cut down on the number of parentheses needed in an expression. For example;
f(g(h(j(x))))
can be rewritten as:
f\$g\$h\$j\$x
However, this is perhaps more clearly expressed by using function composition instead:
(f\circg\circh\circj)(x)
or even:
(f\circg\circh\circj\circx)
if one considers
x
x
Function application in the lambda calculus is expressed by β-reduction.
The Curry–Howard correspondence relates function application to the logical rule of modus ponens.