Top-Fragen
Zeitleiste
Chat
Kontext
Curry (Programmiersprache)
Programmiersprache Aus Wikipedia, der freien Enzyklopädie
Remove ads
Curry[2] ist eine experimentelle funktionallogische Programmiersprache,[3] die auf Haskell basiert. Sie vereint Elemente der funktionalen und logischen Programmierung, insbesondere Constraintprogrammierung.
Remove ads
Sie erweitert Haskell mit Ausnahme des Überladens mittels Typklassen; sie sind lediglich von einigen Implementierungen als Spracherweiterung enthalten, beispielsweise vom Münster Curry Compiler.[4]
Remove ads
Grundlagen
Es gibt keine Seiteneffekte im Gegensatz zu prozeduralen, objektorientierten oder den meisten anderen imperativen Sprachen. Daher spielt die Reihenfolge, in der Teilausdrücke ausgewertet werden, keine Rolle für den Wert des Ergebnisses. Ferner gibt es konzeptionell keine Funktionen mehr, an ihre Stelle treten Relationen mit Funktionscharakter, sog. Korrespondenzen. Im Gegensatz zu Funktionen sind diese nicht notwendig rechtseindeutig, das heißt für eine bestimmte Eingabe müssen sie nicht genau ein Ergebnis haben, insbesondere sind sie von vornherein partiell. Dadurch ist es möglich, nicht nur Konstruktoren, sondern auch Funktionsaufrufe beim Pattern Matching einzusetzen, die die darin vorkommenden Variablen nicht notwendigerweise eindeutig belegen. Das wird durch nicht-deterministische Bedarfsauswertung sinnvoll ergänzt.
Remove ads
Strategien
Da es keine Seiteneffekte gibt, kann in einem funktionallogischen Programm mit beliebigen Strategien ausgewertet werden. Um Ausdrücke auszuwerten, verwenden die meisten Curry-Compiler eine Variante des needed narrowing, das Bedarfsauswertung mit nicht-deterministischen Suchtechniken verbindet. Im Gegensatz zu Prolog, das Rücksetzverfahren auf der Suche nach Lösungen verwendet, beschränkt sich Curry nicht auf eine bestimmte Strategie. Vielmehr gibt es Implementierungen von Curry, wie KiCS2, bei denen der Benutzer auf einfache Weise eine Strategie auswählen kann; unter anderem Tiefensuche, Breitensuche, iteratives Vertiefen oder paralleles Suchen.
Remove ads
Weblinks
- Curry – Die Homepage von Curry (englisch)
- Smap – Eine webbasierte Ausführungsumgebung für Curry und Haskell mit vielen Beispielprogrammen (englisch)
- MCC ( vom 16. Januar 2007 im Internet Archive) – Der Münster Curry Compiler, der C-Code generiert
- PAKCS – Eine größere Curry-Implementierung mit WWW-Interface, das Prolog-Code generiert (englisch)
- KiCS, KiCS2 – Eine Curry-Implementierung, die Haskell-Code generiert (englisch)
- Curry Mailing List (englisch)
- Homepage von Michael Hanus (englisch)
- Purely Functional Lazy Non-deterministic Programming (Fischer, Shan), Transforming Functional Logic Programs into Monadic Functional Programs (Braßel, Fischer, Hanus, Reck, 2010) on modeling lazy non-deterministic (logic) programming (like in Curry) in a purely functional language (Haskell); such approach might give the programmer more flexibility in the control over the strategies that—in the case of Curry—are built-in.
Belege
Wikiwand - on
Seamless Wikipedia browsing. On steroids.
Remove ads