Difference between revisions of "Research papers/Functional pearls"

From HaskellWiki
Jump to navigation Jump to search
m (Add Finger Trees pearl by Koen Claessen)
m (use open access doi.org links instead of preprints)
 
(3 intermediate revisions by 2 users not shown)
Line 32: Line 32:
   
 
Functional pearls available online.
 
Functional pearls available online.
  +
  +
;2023
  +
* [https://doi.org/10.1145/3607853 More Fixpoints!] - Joachim Breitner.
  +
* [https://doi.org/10.1145/3607849 HasChor: Functional Choreographic Programming for All] - Gan Shen, Shun Kashiwa, Lindsey Kuper.
  +
  +
;2022
  +
* [https://doi.org/10.1145/3547640 'do' Unchained: Embracing Local Imperativity in a Purely Functional Language] - Sebastian Ullrich, Leonardo de Moura.
  +
* [https://doi.org/10.1145/3547624 Monadic Compiler Calculation] - Patrick Bahr, Graham Hutton.
  +
* [https://doi.org/10.1145/3547621 Beyond Relooper: Recursive Translation of Unstructured Control Flow to Structured Control Flow] - Norman Ramsey.
   
 
;2021
 
;2021
 
* [https://www.cs.nott.ac.uk/~pszgmh/123.pdf It’s Easy As 1,2,3] - Graham Hutton.
 
* [https://www.cs.nott.ac.uk/~pszgmh/123.pdf It’s Easy As 1,2,3] - Graham Hutton.
  +
* [https://doi.org/10.1145/3471874.3472984 Design Patterns for Parser Combinators] - Jamie Willis, Nicolas Wu.
   
 
;2020
 
;2020
  +
* [https://dl.acm.org/doi/10.1145/3408974 Achieving high-performance the functional way] - Bastian Hagedorn, Johannes Lenfers, Thomas Kœhler, Xueying Qin, Sergei Gorlatch, Michel Steuwer.
  +
* [https://doi.org/10.1145/3408990 Parsing with zippers] - Pierce Darragh, Michael D. Adams
  +
* [https://doi.org/10.1145/3408998 Separation Logic for Sequential Programs] - Arthur Charguéraud
  +
* [https://doi.org/10.1145/3409004 Strong Functional Pearl: Harper's Regular-Expression Matcher in Cedille] - Aaron Stump, Chris Jenkins, Stephan Spahn, Colin McDonald
  +
* [https://dl.acm.org/doi/10.1145/3409006 The simple essence of algebraic subtyping: principal type inference with subtyping made easy] - Lionel Parreaux
  +
* [https://doi.org/10.1145/3406088.3409024 A Graded Monad for Deadlock-Free Concurrency] - Andrej Ivašković, Alan Mycroft
 
* [https://dl.acm.org/doi/10.1145/3406088.3409026 Finger Trees explained anew, and slightly simplified] - Koen Claessen.
 
* [https://dl.acm.org/doi/10.1145/3406088.3409026 Finger Trees explained anew, and slightly simplified] - Koen Claessen.
  +
* [https://doi.org/10.1145/3406088.3409015 Stitch: The Sound Type-Indexed Type Checker] - Richard A. Eisenberg
 
  +
* [https://doi.org/10.1145/3406088.3409019 Type Your Matrices for Great Good: A Haskell Library of Typed Matrices and Applications] - Armando João Isaías Ferreira dos Santos, Jose Nuno Oliveira
 
;2018
 
;2018
 
* [http://www.cs.ox.ac.uk/jeremy.gibbons/publications/proyo.pdf What You Needa Know about Yoneda: Profunctor Optics and the Yoneda Lemma] - Guillaume Boisseau and Jeremy Gibbons.
 
* [http://www.cs.ox.ac.uk/jeremy.gibbons/publications/proyo.pdf What You Needa Know about Yoneda: Profunctor Optics and the Yoneda Lemma] - Guillaume Boisseau and Jeremy Gibbons.

Latest revision as of 16:50, 6 February 2024

Functional pearls are elegant, instructive examples of functional programming. They are supposed to be fun, and they teach important programming techniques and fundamental design principles. They traditionally appear in The Journal of Functional Programming and and at ICFP and affiliated workshops.

History

The history of functional pearls is covered by:

There have been many functional pearls in JFP and and some others at ICFP and the Haskell Workshop. There is also a collection of them in The Fun of Programming.

The pearls tend to concentrate on:

  • Examples of program calculation and proof
  • Neat presentations of new or old data structures
  • Interesting applications and techniques

Some advice on writing pearls for JFP is available in this editorial.

Online

Functional pearls available online.

2023
2022
2021
2020
2018
2017
2016
2015
2013.
2012
2011
2010
2009
2008
2007
2006
2005
2004
2003
2002
2001
2000
1999
1998
1997
1996
1994
1993
1992
1991
1988

Potential pearls

Unpublished pearls.