Currying (från engelska currying , ibland - currying ) - omvandlingen av en funktion från många argument till en uppsättning funktioner, som var och en är en funktion av ett argument. Möjligheten till en sådan transformation noterades först i Gottlob Freges skrifter , systematiskt studerade av Moses Scheinfinkel på 1920-talet och uppkallad efter Haskell Curry , utvecklaren av kombinatorisk logik , där reduktion till funktioner av ett argument är grundläggande.
För en funktion av två argument utför curryoperatorn en konvertering - den tar ett typargument och returnerar en funktion av typ . Intuitivt, genom att currya en funktion kan du fixa några av dess argument samtidigt som funktionen returneras från de återstående argumenten. Alltså är en funktion av typ .
Decurrying ( eng. uncurring ) introduceras som en invers transformation - återställer curry-argumentet: för en funktionden decurry-operatortransformationen; typen av decurryoperatör är.
I praktiken låter currying dig överväga en funktion som inte fick alla de angivna argumenten. Curry-operatorn är inbyggd i vissa programmeringsspråk för att tillåta flerplatsfunktioner att curry, de vanligaste exemplen på sådana språk är ML och Haskell . Alla språk som stöder stängningar låter dig skriva curry-funktioner.
Inom teoretisk datavetenskap ger currying ett sätt att undersöka funktioner hos flera argument inom mycket enkla teoretiska system som lambdakalkylen . I mängdteorin är currying en överensstämmelse mellan set och . I kategoriteorin kommer currying från exponentialets universella egenskap ; i situationen med en kartesisk sluten kategori leder detta till följande korrespondens. Det finns en bijektion mellan uppsättningar av morfismer från en binär produkt och morfismer till en exponentiell som är naturlig med avseende på och med avseende på . Detta påstående är ekvivalent med det faktum att produktfunktioner och Hom-funktioner är samverkande funktioner.
Detta är en nyckelegenskap för en kartesisk sluten kategori , eller, mer allmänt, en sluten monoidal kategori . Den första är helt tillräcklig för klassisk logik, men den andra är en praktisk teoretisk grund för kvantberäkning . Skillnaden är att den kartesiska produkten endast innehåller information om ett par av två objekt, medan tensorprodukten som används i definitionen av en monoidal kategori är lämplig för att beskriva intrasslade tillstånd [1] .
Ur Curry-Howard-korrespondensens synvinkel är förekomsten av curryfunktioner (typ habitability och decurrying (typ habitability ) ekvivalent med ett logiskt påstående ( produkttyp motsvarar konjunktion och funktionell typ till implikation ). Currying och decurrying-funktioner är kontinuerliga enligt Scott .
Currying används ofta i programmeringsspråk , främst de som stöder det funktionella programmeringsparadigmet . På vissa språk är funktioner curry som standard, det vill säga flerplatsfunktioner implementeras som enplatsfunktioner av högre ordning , och appliceringen av argument på dem är en sekvens av partiella applikationer .
Programmeringsspråk med förstklassiga funktioner definierar vanligtvis operationer curry(översätta en vysignaturfunktion A, B -> Ctill en signaturfunktion A -> B -> C) och uncurry(utföra den omvända transformationen - mappa en vysignaturfunktion till en A -> B -> Ctvåställsfunktion av formuläret A, B -> C). I dessa fall är kopplingen till den partiella applikationsoperationen transparent papply: curry papply = curry.