Currying

Currying

In mathematics and computer science, currying is the technique of transforming a function that takes multiple arguments (or an n-tuple of arguments) in such a way that it can be called as a chain of functions each with a single argument (partial application). It was discovered by Moses Schönfinkel[1] and later re-discovered by Haskell Curry[2][not specific enough to verify]; because of this, some say it would be more correct to name it schönfinkeling.[3][4]

Uncurrying (also known as counter-currying) is the dual transformation to currying, and can be seen as a form of defunctionalization. It takes a function f(x) which returns another function g(y) as a result, and yields a new function f'(x, y) which takes a number of additional parameters and applies them to the function returned by f. The process can be iterated if necessary.

Contents

Motivation

Currying is similar to the process of calculating a function of multiple variables for some given values on paper. For example, given the function \scriptstyle f(x,y) = y / x:

To evaluate \scriptstyle f(2,3), first replace \scriptstyle x with 2.
Since the result is a function of \scriptstyle y, this function \scriptstyle g(y) can be defined as \scriptstyle g(y) = f(2,y) = y/2.
Next, replace the \scriptstyle y argument with 3, producing \scriptstyle g(3) = f(2,3) = 3/2.

On paper, using classical notation, this is usually done all in one step. However, each argument can be replaced sequentially as well. Each replacement results in a function taking exactly one argument. This produces a chain of functions as in lambda calculus, and multi-argument functions are usually represented in curried form.

Some programming languages almost always use curried functions to achieve multiple arguments; notable examples are ML and Haskell, where in both cases all functions have exactly one argument.

This is similar in computer code: If we let f be a function

f(x,y) = y / x

then the function g

g x = \y -> f(x,y)

is a curried version of f. In particular,

g 2 = \y -> f(2,y)

is the curried equivalent of the example above. Though note that currying, while similar, is not the same operation as partial function application.

Definition

Given a function f of type \scriptstyle f \colon (X \times Y) \to Z , currying it makes a function \scriptstyle \text{curry}(f) \colon X \to (Y \to Z) . That is, \scriptstyle \text{curry}(f) takes an argument of type \scriptstyle X and returns a function of type \scriptstyle Y \to Z . Uncurrying is the reverse transformation, and is most easily understood in terms of its right adjoint, apply.

The → operator is often considered right-associative, so the curried function type \scriptstyle X \to (Y \to Z) is often written as \scriptstyle X \to Y \to Z. Conversely, function application is considered to be left-associative, so that \scriptstyle f \; \langle x, y \rangle is equivalent to \scriptstyle\text{curry}(f) \; x \; y.

Curried functions may be used in any language that supports closures; however, uncurried functions are generally preferred for efficiency reasons, since the overhead of partial application and closure creation can then be avoided for most function calls.

Mathematical view

In theoretical computer science, currying provides a way to study functions with multiple arguments in very simple theoretical models such as the lambda calculus in which functions only take a single argument.

In a set-theoretic paradigm, currying is the natural correspondence between the set \scriptstyle A^{B\times C} of functions from \scriptstyle B\times C to A, and the set \scriptstyle\left(A^B\right)^C of functions from \scriptstyle C to the set of functions from \scriptstyle B to \scriptstyle A. In category theory, currying can be found in the universal property of an exponential object, which gives rise to the following adjunction in cartesian closed categories: There is a natural isomorphism between the morphisms from a binary product \scriptstyle f \colon (X \times Y) \to Z and the morphisms to an exponential object \scriptstyle g \colon X \to Z^Y . In other words, currying is the statement that product and Hom are adjoint functors; that is there is a natural transformation:

 \hom(A\times B, C) \cong \hom(A, C^B) .

This is the key property of being a Cartesian closed category.

Under the Curry-Howard correspondence, the existence of currying and uncurrying is equivalent to the logical theorem \scriptstyle (A \and B) \to C \Leftrightarrow A \to (B \to C), as tuples (product type) corresponds to conjunction in logic, and function type corresponds to implication.

Curry is a continuous function in the Scott topology.

Naming

The name "currying", coined by Christopher Strachey in 1967, is a reference to logician Haskell Curry. The alternative name "Schönfinkelisation", has been proposed as a reference to Moses Schönfinkel.[5]

Contrast with partial function application

Currying and partial function application are often conflated.[6] The difference between the two is clearest for functions taking more than two arguments.

Given a function of type \scriptstyle f \colon (X \times Y \times Z) \to N , currying produces \scriptstyle \text{curry}(f) \colon X \to (Y \to (Z \to N)) . That is, while an evaluation of the first function might be represented as \scriptstyle f(1, 2, 3), evaluation of the curried function would be represented as \scriptstyle f_{curried}(1)(2)(3), applying each argument in turn to a single-argument function returned by the previous invocation. Note that after calling \scriptstyle f_{curried}(1), we are left with a function that takes a single argument and returns another function, not a function that takes two arguments.

In contrast, partial function application refers to the process of fixing a number of arguments to a function, producing another function of smaller arity. Given the definition of \scriptstyle f above, we might fix (or 'bind') the first argument, producing a function of type \scriptstyle\text{partial}(f) \colon (Y \times Z) \to N. Evaluation of this function might be represented as \scriptstyle f_{partial}(2, 3). Note that the result of partial function application in this case is a function that takes two arguments.

Intuitively, partial function application says "if you fix the first arguments of the function, you get a function of the remaining arguments". For example, if function div stands for the division operation x / y, then div with the parameter x fixed at 1 (i.e., div 1) is another function: the same as the function inv that returns the multiplicative inverse of its argument, defined by inv(y) = 1 / y.

The practical motivation for partial application is that very often the functions obtained by supplying some but not all of the arguments to a function are useful; for example, many languages have a function or operator similar to plus_one. Partial application makes it easy to define these functions, for example by creating a function that represents the addition operator with 1 bound as its first argument.

See also

Notes

  1. ^ Strachey, Christopher (2000). "Fundamental Concepts in Programming Languages". Higher-Order and Symbolic Computation 13: 11–49. doi:10.1023/A:1010000313106. "There is a device originated by Schönfinkel, for reducing operators with several operands to the successive application of single operand operators."  (Reprinted lecture notes from 1967.)
  2. ^ (Barendregt 2000, p. 8)
  3. ^ Reynolds, John C. (1998). "Definitional Interpreters for Higher-Order Programming Languages". Higher-Order and Symbolic Computation 11 (4): 374. doi:10.1023/A:1010027404223. "In the last line we have used a trick called Currying (after the logician H. Curry) to solve the problem of introducing a binary operation into a language where all functions must accept a single argument. (The referee comments that although “Currying” is tastier, “Schönfinkeling” might be more accurate.)" 
  4. ^ Kenneth Slonneger and Barry L. Kurtz. Formal Syntax and Semantics of Programming Languages. p. 144.
  5. ^ I. Heim and A. Kratzer (1998). Semantics in Generative Grammar. Blackwell.
  6. ^ Partial Function Application is not Currying

References

  • Schönfinkel, Moses (1924). "Uber die Bausteine der mathematischen Logik". Math. Ann. 92 (3–4): 305–316. doi:10.1007/BF01448013. 
  • Heim, Irene; Kratzer, Angelika (1998). Semantics in a Generative Grammar. Malden: Blackwall Publishers 

External links

Language-specific implementations

Wikimedia Foundation. 2010.

Игры ⚽ Поможем написать курсовую

Look at other dictionaries:

  • Currying — (selten auch: Schönfinkeln) ist die Umwandlung einer Funktion mit mehreren Argumenten in eine Funktion mit einem Argument. Obwohl das Verfahren von Moses Schönfinkel und Gottlob Frege erfunden wurde, ist es nach Haskell Brooks Curry benannt.… …   Deutsch Wikipedia

  • Currying — Curry Cur ry (k?r r?), v. t. [imp. & p. p. {Curried} ( r?d); p. pr. & vb. n. {Currying}.] [OE. curraien, curreien, OF. cunreer, correier, to prepare, arrange, furnish, curry (a horse), F. corroyer to curry (leather) (cf. OF. conrei, conroi, order …   The Collaborative International Dictionary of English

  • currying — noun The technique of transforming a function that takes multiple arguments into a function that takes a single argument (the first of the arguments to the original function) and returns a new function that takes the remainder of the arguments… …   Wiktionary

  • currying — cur·ry || kÊŒrɪ n. curry powder, seasoning which is made from a combination of tumeric and other spices (commonly used in East Indian dishes); food seasoned with curry v. brush down a horse; prepare leather; beat, hit; flavor with curry powder …   English contemporary dictionary

  • currying — currˈying noun • • • Main Entry: ↑curry …   Useful english dictionary

  • vaunt-currying — …   Useful english dictionary

  • Schönfinkeln — Currying (selten auch: Schönfinkeln) ist die Umwandlung einer Funktion mit mehreren Argumenten in mehrere Funktionen mit je einem Argument. Obwohl das Verfahren von Moses Schönfinkel und Gottlob Frege erfunden wurde, ist es ist nach Haskell… …   Deutsch Wikipedia

  • Currificación — Saltar a navegación, búsqueda En la ciencia de la computación, currificar, inventada por Moses Schönfinkel y Gottlob Frege, es la técnica que consiste en transformar una función que utiliza múltiples argumentos (o más específicamente una n tupla… …   Wikipedia Español

  • Anonymous function — In computing, an anonymous function is a function (or a subroutine) defined, and possibly called, without being bound to a name. In lambda calculus, all functions are anonymous. The Y combinator can be utilised in these circumstances to provide… …   Wikipedia

  • Function (mathematics) — f(x) redirects here. For the band, see f(x) (band). Graph of example function, In mathematics, a function associates one quantity, the a …   Wikipedia

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”