"Levity Polymorphism" by Richard A. Eisenberg and Simon Peyton Jones
 

Document Type

Conference Proceeding

Publication Title

Proceedings of the SIGPLAN Conference on Programming Language Design and Implementation

Version

Author's Final Manuscript

Publication Date

6-2017

Abstract

Parametric polymorphism is one of the linchpins of modern typed programming, but it comes with a real performance penalty. We describe this penalty; offer a principled way to reason about it (kinds as calling conventions); and propose levity polymorphism. This new form of polymorphism allows abstractions over calling conventions; we detail and verify restrictions that are necessary in order to compile levity-polymorphic functions. Levity polymorphism has created new opportunities in Haskell, including the ability to generalize nearly half of the type classes in GHC's standard library.

DOI

http://doi.org/10.1145/3062341.3062357

Plum Print visual indicator of research metrics
PlumX Metrics
  • Citations
    • Citation Indexes: 6
  • Usage
    • Downloads: 557
    • Abstract Views: 143
  • Captures
    • Readers: 17
see details

Share

COinS