Use and abuse of instance parameters in the Lean mathematical library

Anne Baanen
DOI: https://doi.org/10.48550/arXiv.2202.01629
2022-02-03
Logic in Computer Science
Abstract:The Lean mathematical library mathlib features extensive use of the typeclass pattern for organising mathematical structures, based on Lean's mechanism of instance parameters. Related mechanisms for typeclasses are available in other provers including Agda, Coq and Isabelle with varying degrees of adoption. This paper analyses representative examples of design patterns involving instance parameters in the current Lean 3 version of mathlib, focussing on complications arising at scale and how the mathlib community deals with them.
What problem does this paper attempt to address?