1 Introduction
(…) A special feature of our approach is a general calculus of relations presented in part two. This calculus offers another, often more amenable framework for concepts and methods discussed in part one.
— Freyd & Ščedrov, Categories, Allegories, 1990.
Functions are mathematical objects, and functional programming (FP) has benefitted much from its strong mathematical foundations over the years. This began with LISP, a programming language born in the late 1950s that implemented Church’s
${\lambda }$
-calculus and included higher-order functions, that is, functions that manipulate other functions. This soon proved to be a strong competitive advantage.
Another significant advantage, originally also identified by Church, is parametric polymorphism, a powerful device of great practical and theoretical relevance (Damas & Milner, Reference Damas and Milner1982). Pragmatically, it leads to a programming style in which programs are generic and can be better statically checked, adding to programming productivity since one writes less and better code — “programs for cheap!” in the words of Hackett & Hutton (Reference Hackett and Hutton2015). This comes hand in hand with another advantage, evident when one needs to reason about programs: parametricity theory ensures structural properties of functional code that need not be proved case by case — cf. the “theorem for free” motto coined by Wadler (Reference Wadler1989). Thus correctness-proving becomes more productive as well.
Curiously enough, parametricity theory found an effective formulation in terms of relations and not just functions (Reynolds, Reference Reynolds1983).As Janis Voigtländer (Reference Voigtländer2019) puts it, the key to deriving free theorems is to interpret types as relations. Indeed, it often happens in mathematics that, to better address a concept, it is convenient to invest into another one of wider scope. For example, the laws of basic trigonometry are best formulated if the domain of discourse is extended from real to complex numbers — recall Euler’s formula
$e^{ix} = \cos x + i\sin x$
and all that follows from it. The same happens between functions and relations, the latter extending the former. The quote by Freyd & Scedrov (Reference Freyd and Scedrov1990) that opens this paper reveals exactly this, at the categorial level.
Building on this perspective, Bird & de Moor (Reference Bird and de Moor1997) developed an algebra of programming in which specifications (relations) lead to implementations (functions) by calculation. However, the application of relational techniques to FP is actually wider, see e.g. the work by Backhouse & Backhouse (Reference Backhouse and Backhouse2004) among much other research reported in the literature. This paper will follow the same path of using relations to reason about functional programs, taking a rather pragmatic view inspired by experience in the classroom.
Teaching FP is not an easy task, all the more so when it comes late in the syllabus, after imperative and object-oriented programming. FP calls for a plan of the overall architecture before starting writing code, with particular emphasis on designing a suitable information flow.Footnote 1 It is therefore important to help programmers in identifying “big picture” design patterns.
It can be claimed that the higher-order combinators so much used in FP enable design patterns for free by inter-combination — see e.g. map-filter, MapReduce (Lämmel, Reference Lämmel2008) and so on. In this paper we propose what we call “magic squares” (MS) to expand that view by expressing and composing quite common relational (and functional) patterns that arise in problem analysis and modeling.
Among several examples given in the paper, free-theorem MS prove to be elegant and productive. As observed by Voigtländer (Reference Voigtländer, Shao and Pierce2009), free theorems promise a lot but deriving them is not immediate. It is error-prone and can be tedious and result in intricate logical formulæ hard to simplify into something short and effective, even when using a mechanised generator. We claim that relational reasoning can be of great help in this respect. In this paper, free theorems are expressed in terms of magic squares, whose graphical nature makes it easier to perceive what is going on in the reasoning.
As an example of application, a generic, induction-free theory for
${\mathsf{foldr}{}{}}$
and
${\mathsf{foldl}{}{}}$
is given — understood in a class wider than just finite listsFootnote
2
— showing in particular that
${\mathsf{foldl} \, {{s}}{}\mathrel{=}\mathsf{foldr}{({flip }\unicode{x005F}{s})}{}}$
holds under conditions milder than usually advocated.
2 “Magic” squares
Experience in teaching FP using a relational approach has led the author to a graphical style of expression and reasoning in which a very simple, geometric construct shines: the (semi) commutative square.
In the classroom this is termed the “magic square” (MS), because much of what we do in logic, FP, database modeling, formal semantics, etc fits in some MS geometry. Each magic square has four sides, say R, P, S, Q, which are binary relations, and each square is a comparison between two paths, of two relations each:
data:image/s3,"s3://crabby-images/07398/07398d6cc6e34f0bbf974d4c108b7e2d38e4672a" alt=""
In more detail, each side is an arrow, say , declaring a binary relation R that relates objects of types A and B. Its meaning is as usual: given objects
${{a}\;\mathbin\in \;{A}}$
and
${{b}\;\mathbin\in \;{B}}$
, the proposition
${{a}\;{R}\;{b}}$
tells whether or not a and b are related by R. Take for instance relation
. Clearly,
${\mathrm{0}\leq \mathrm{1}}$
holds (it is a true proposition) while
${\mathrm{1}\leq \mathrm{0}}$
does not.
Next, we need to say what a path means, say
${{P} \cdot {R}}$
in (2.1): given some
${{c}\;\mathbin\in \;{C}}$
and some
${{b}\;\mathbin\in \;{B}}$
,
${{c}\;({P} \cdot {R})\;{b}}$
holds whenever there is some mediator
${{a}\;\mathbin\in \;{A}}$
such that both
${{c}\;{P}\;{a}}$
and
${{a}\;{R}\;{b}}$
hold. We say that relation
${{P} \cdot {R}}$
is the composition of relations
${{P}}$
and
${{R}}$
. Relational composition is associative.
Finally, let us say what the comparison
${{R}\; \subseteq \;{S}}$
of two relations
means, in general. (
${{R}\; \subseteq \;{S}}$
should be read: “
${{R}}$
is at most
${{S}}$
” or “
${{R}}$
is included in
${{S}}$
”.) It means that, for all
${{b}\;\mathbin\in \;{B}}$
and
${{a}\;\mathbin\in \;{A}}$
, if
${{b}\;{R}\;{a}}$
holds then
${{b}\;{S}\;{a}}$
holds too. In summary, relation inclusion “hides” a universal quantifier, while relation composition hides an existential quantifier. In symbols, the logic interpretation of (2.1) is:
data:image/s3,"s3://crabby-images/788f2/788f215d60e03d5dc905656addec8552f4ea922f" alt=""
The following version of (2.2) makes its connection with (2.1) more explicit:
data:image/s3,"s3://crabby-images/73d49/73d49ccc89e202911244c19d90f333873a083d0f" alt=""
Comparisons
${{R}\; \subseteq \;{S}}$
form a partial order, and therefore are reflexive, transitive, and antisymmetric.
As will be shown shortly, one can express “a lot” using the “magic” square pattern (2.1), rendered pointwise in (2.2). Some terminology before giving examples: we shall refer to
${{R}\; \subseteq \;{S}}$
as a relational inequality in which
${{R}}$
is the pre (or lower) side and
${{S}}$
is the post (or upper) side. In a composition
${{R} \cdot {S}}$
, relation
${{S}}$
(resp.
${{R}}$
) will be referred to as the producer (resp. consumer) relation. This terminology bears some relationship to the way information flows in a magic square, cf.
data:image/s3,"s3://crabby-images/32ec1/32ec1c043bd0fb55a1507cdc76e1392c24c93090" alt=""
Magic squares compose, not only horizontally
data:image/s3,"s3://crabby-images/a47d4/a47d4f8a5d83ccc4b4efae2e7fca4b8a7fbf649a" alt=""
but also vertically:
data:image/s3,"s3://crabby-images/554b5/554b55e19b6bb0464c9af070ecc7abde278d2c0f" alt=""
Every type
${{X}}$
has its own identity relation
, which is such that
${{x'}\;{id}\;{x}~\Leftrightarrow~{x'}\mathrel{=}~{x}}$
. Therefore,
${{R} \cdot {id}\mathrel{=}{R}\mathrel{=}{id} \cdot {R}}$
holds for any R and thus squares involving id degenerate into triangles or even “sides”. So, squares in which both pre-consumer and post-producer are identities behave like units of square composition, cf.:
data:image/s3,"s3://crabby-images/104b1/104b1b73f7bdb5b0169fb27340850b20429c922c" alt=""
3 Functions
Statements like John loves Mary can be written as Mary is loved by John without changing meaning. The latter version is known as the passive voice of the former. Generalizing, any proposition
${{b}\;{R}\;{a}}$
can be converted to passive voice, written
${{a}\;{{R}}^\circ\;{b}}$
. (In the example,
${{{loves}}^\circ\mathrel{=}{is}\;{loved}\;{by}}$
.) The
${{(_{\unicode{x2014}})}}^\circ$
operator, known as relational converse, will play a major role in our setting.
Converse is involutive (
${{({{R}^\circ})^\circ}\mathrel{=}{R}}$
) and contravariant:
${{({R} \cdot {S})^\circ}\mathrel{=}{{S}}^\circ \cdot {{R}}}^\circ$
. So one can take the converse of a square, obtaining an equivalent square where producer and consumer relations swap roles, once conversed:
data:image/s3,"s3://crabby-images/fed70/fed70dcc75d6fa0eba638efdac0254420d8e7c96" alt=""
Some relations, termed functions and denoted in lowercase — see e.g. f in (3.1) below — are special in the sense of fitting in two particular squares involving them and their converses:
data:image/s3,"s3://crabby-images/05f8c/05f8c9b1c80b3e54104cbe7420601e06dad3e41d" alt=""
By (2.2), the square on the left (
${{id}\; \subseteq \;{{f}}^\circ \cdot {f}}$
) converts to:
data:image/s3,"s3://crabby-images/0479c/0479c526dad55d82fd732e9f6a59734018769ea2" alt=""
In words,
${{f}}$
reacts to every possible input (it is “total”). Similarly, the square on the right (
${{f} \cdot {{f}}^\circ\; \subseteq \;{id}}$
) converts to:
data:image/s3,"s3://crabby-images/df500/df500cef435252f3f6e3c509a80099c2793e60c9" alt=""
In words:
${{f}}$
is univocal. Because
${{f}}$
in (3.1) always yields some output for any possible input, and such an output is unique, one can interpret the proposition
${{b}\;{f}\;{a}}$
as
${{b}\mathrel{=}{f}\;{a}}$
, that is,
${{b}}$
is unequivocally the output of
${{f}}$
once
${{a}}$
is passed as input. This saves one from the two existential quantifiers of a very frequent and useful pattern involving functions and function converses:Footnote
3
data:image/s3,"s3://crabby-images/6a723/6a723345163fa3874bc5536a7498ad0f799f75ea" alt=""
We shall refer to (3.2) as the “nice” rule, where
${{f}}$
and
${{g}}$
are functions and
${{R}}$
is not constrained.Footnote
4
It can be shown that functions — i.e. relations
${{f}}$
fitting in (3.1) — are precisely those that satisfy the following square equivalences,
data:image/s3,"s3://crabby-images/f641c/f641c868294cfda50ffe9f0b5e3e24d3fab242d8" alt=""
data:image/s3,"s3://crabby-images/48dab/48dabad255930b024aa4ead8d88baffbc56669f2" alt=""
cf.
data:image/s3,"s3://crabby-images/2caef/2caef2ba62a49c6621ebf9e30387ad1330ddf07d" alt=""
— similarly for (3.4). These equivalences, known as “shunting rules,” are very useful for reasoning about functions. One particular follow-up is that comparing functions amounts to equating them,
data:image/s3,"s3://crabby-images/1921e/1921eae918fc87c51c5a913a24af9140fb52ebf7" alt=""
as can be easily shown:
data:image/s3,"s3://crabby-images/e9e0c/e9e0cc19cde3ebb473673410335b345cdb3552e9" alt=""
4 Reynolds squares
In the sequel, we shall be particularly interested in squares (2.1) in which both pre-consumers and post-producers are functions, say
${{f}}$
and
${{g}}$
in (4.1) given next:
data:image/s3,"s3://crabby-images/4c792/4c7929e4afbdb89c7ad170ccb94c7d75db9abf32" alt=""
By (3.3) followed by the “nice rule” (3.2), square (4.1) captures the situation in which, for
${{R}}$
-related inputs, the two functions
${{f}}$
and
${{g}}$
always yield
${{S}}$
-related outputs: if
${{a}\;{R}\;{b}}$
holds then
${({f}\;{a})\;{S}\;({g}\;{b})}$
holds, for any
${{a}}$
and
${{b}}$
.
We shall refer to squares of pattern (4.1) as Reynolds squares because of the role they will play in expressing free theorems of parametric polymorphic functions, due to John Reynolds (Reference Reynolds1983) and made popular by Philip Wadler (Reference Wadler1989). Note however that pattern (4.1) can be found in far more mundane settings, for instance relational database modeling.
Take for instance the very simple data model below of a small grocery in which customers can use coupons to obtain discounts when purchasing goods:
data:image/s3,"s3://crabby-images/69e41/69e41fb51d674cd97fb47adad228eac769b7dfae" alt=""
The “polygons” of the data model can be regarded as “opportunities” to dig up business rules, i.e. data invariants. Indeed, the triangle on the right can be oriented as the square
data:image/s3,"s3://crabby-images/a4b54/a4b54f05f08a746177a05a9985ff42b429a2198e" alt=""
which is indeed meaningful: coupons cannot be used beyond their expiry date. And the lefthand triangle can be oriented as
data:image/s3,"s3://crabby-images/4b747/4b7474d07143ac5630b960573f1814c2495eaa3e" alt=""
bearing in it another relevant business rule: coupons can only be used by the customers who own them. Footnote 5
Squares in general (2.1) arise naturally in formal modeling in various guises, involving data relations (e.g. key-value maps), object attributes etc, and capturing not only domain-specific invariants such as those illustrated above but also structural ones. Particularly frequent squares are those that capture referential integrity,
data:image/s3,"s3://crabby-images/84eea/84eea1bcd478ae46339f716a07ecefe345c96391" alt=""
where
${\top }$
is the largest relation of its type, that is,
for all
${{b}}$
and
${{k}}$
. Think of
${{R}}$
and
${{S}}$
as key-value stores with keys
${{K}}$
and
${{K'}}$
, respectively, the latter playing the role of foreign key referred to by attribute
${{f}}$
of
${{A}}$
(a function).Footnote
6
Reynolds arrow Back to the genericity of Reynolds squares, fix the pre-producer
${{R}}$
and the post-consumer
${{S}}$
of (4.1). Then (4.1) expresses a (higher-order) relation on functions
${{f}\;({R}\to {S})\;{g}}$
defined by:
data:image/s3,"s3://crabby-images/7fec7/7fec787eff839dc0a89c2082cdd9dfacc3e53639" alt=""
Usinghe exponential notation
${{{Y}}^{{X}}}$
to denote the type of all functions from type
${{X}}$
to type
${{Y}}$
, and extending it to relations,
${{{S}}^{{R}}\mathrel{=}({R}\to {S})}$
, one has:
data:image/s3,"s3://crabby-images/95ac9/95ac9ce6f85b1177534fa6e3ae65f33c64e4670b" alt=""
Thus we obtain the Reynolds arrow, a higher-order relational operator that builds, from relations
${{R}}$
and
${{S}}$
, the (higher-order) relation
${{{S}}^{{R}}}$
on functions identified by Backhouse (Reference Backhouse1990) and defined above by (4.5). We will use the notations
${{{S}}^{{R}}}$
,
${{R}\to {S}}$
and
${{S}\leftarrow {R}}$
interchangeably, depending on how convenient they are. (E.g. we avoid
${{({{S}}^{{R}})}^{{Q}}}$
and write
${{Q}\to {{S}}^{\textit{R}}}$
^R instead.)
For instance, the
${{Used}\to (\leq )}$
higher-order relation relates attributes
${{date}}$
and
${{expiry}}$
in (4.2), expressing the semantic constraint that the use of a coupon can only occur on a date prior (
${\leq }$
) to its expiry date.
Reynolds arrows are central to the inference of free theorems, as will be shown later, in particular in the following situation, in which
${{R}}$
is the converse of a function (
${R}\mathbin{:=}{{h}}^\circ$
) and
${{S}}$
is a function (
${{S}\mathbin{:=}{k}}$
):
data:image/s3,"s3://crabby-images/77de4/77de407583d1637ef23f8e3be1332d31406bdc6e" alt=""
By shunting
${{{h}}}^\circ$
in (4.6) via (3.4),
${{{h}}^\circ\to {k}}$
becomes the higher-order function
data:image/s3,"s3://crabby-images/42ff6/42ff633b512e4b408381f861bd33b7e19a624164" alt=""
as can be easily checked:
data:image/s3,"s3://crabby-images/a144c/a144c779562c364536cde8222fb29af465403a0c" alt=""
The special cases of (4.7),
data:image/s3,"s3://crabby-images/15849/15849267d8ef3ca85a5b40ac5e7d8815a2d0fc89" alt=""
(for A=B) and
data:image/s3,"s3://crabby-images/1fe83/1fe83e4cf6dc03980fb4f26589114240a7665d59" alt=""
(for
${{C}\mathrel{=}{D}}$
) capture post-and pre-composition, that is:
data:image/s3,"s3://crabby-images/a91d3/a91d32f2dfb975aba3dc5e6113f44d1b8003d911" alt=""
data:image/s3,"s3://crabby-images/70bae/70bae5a4a527788e69ecfd86b1c82522412577c5" alt=""
By taking converses of both sides of (4.5) and swapping
${{f}}$
and
${{g}}$
via shunting rules (3.3, 3.4), one gets
data:image/s3,"s3://crabby-images/56102/561025ac3db949e661fa3b8321425c66909ab1a1" alt=""
Thus:
data:image/s3,"s3://crabby-images/810dc/810dc7ac14bbe37c552f57a4f3c703c89ffee329" alt=""
data:image/s3,"s3://crabby-images/23fe6/23fe67abf9ce363bbebb1367d8a78bb226119d36" alt=""
Higher-order Reynolds squares Exponential relations
${{{S}}^{{R}}}$
can involve other exponentials, for instance
${{({{S}}^{{Q}})}^{{R}}}$
i.e.
${{R}\to {{S}}^Q}$
. This happens frequently with functional programmers, who tend to use functions curried rather than uncurried. Such is the case in
data:image/s3,"s3://crabby-images/309ab/309ab306b353476ec8b493d6be117bf9509fb95d" alt=""
Let us unfold this, assuming all fresh variables universally quantified:
data:image/s3,"s3://crabby-images/0bd3a/0bd3a704f02f26ec482838d748483c22d427862b" alt=""
data:image/s3,"s3://crabby-images/cc417/cc4172624d527ff254a15fc9f34386dfbe3fb811" alt=""
Perfect squares Allelations in square (4.6) but the pre-producer are functions. Suppose now that all relations are functions in a magic square (2.1). Then, by (3.5) path comparison becomes path equality and producer/consumer paths become interchangeable. In this case, we drop the
${ \subseteq }$
symbol from the square:
data:image/s3,"s3://crabby-images/cd970/cd9705d10189c001ac8ea6e57f25b2394c05671b" alt=""
Clearly:
data:image/s3,"s3://crabby-images/18295/18295945f4ced8a5e913ab7c4b05f0571b373641" alt=""
5 More on Reynolds square expressiveness
Let the pre-producer
${{R}}$
of a Reynolds square (4.1) be the identity:
data:image/s3,"s3://crabby-images/6eb20/6eb20d31962e86a8ccc9ccad3829fc3feaad837c" alt=""
In this case,
${{f}}$
and
${{g}}$
have the same input type and are said to be pointwise
${{S}}$
-related. Using the dotted notation
${\stackrel.{{S}}}$
for
${{{S}}^{{id}}}$
, one may write
${{f}\;\stackrel.{{S}}\;{g}}$
to mean square (5.1), that is:
. Thus, the following (useful) “lifting” rule:
data:image/s3,"s3://crabby-images/632c4/632c4a3c0715d7edcccb0486bb8d0096f82350d4" alt=""
A typical situation arises in (5.1) when the post-consumer
${{S}}$
is an ordering
${(\leq )}$
.
Then
${{f}\;\stackrel.{\leq }\;{g}}$
(i.e.
${{{f}}\subseteq{(\leq ) \cdot {g}}}$
) means that
${{f}\;{a}\leq {g}\;{a}}$
for every input
${{a}}$
, i.e.
${{f}}$
is pointwise-smaller than
${{g}}$
with respect to
${(\leq )}$
.
Relational types. The intersection of
${{{S}}^{{R}}}$
and (higher-order) id captures all Reynolds squares (4.1) in which
${{f}\mathrel{=}{g}}$
:
data:image/s3,"s3://crabby-images/b9bca/b9bca184f261119d4d29b6e029d63b5f2d6c183e" alt=""
In this case, we often abbreviate
${{f}\;({R}\to {S})\;{f}}$
to
${{f}\mathbin{:}{R}\to {S}}$
, meaning that
${{f}}$
has relational type
${{R}\to {S}}$
.Footnote
7
As seen before, this means that
${{f}}$
maps
${{R}}$
-related inputs to
${{S}}$
-related outputs.
We can also write to express (5.3), stressing the fact that
${{f}}$
can be regarded as a morphism of a category in which relations are the objects, mapped by functions that preserve them in the sense of (5.3). Indeed, by vertical composition (2.4) such morphisms compose and composition has identities (2.5).Footnote
8
For
${{R}}$
and
${{S}}$
instantiated to preorders, say
${{R},{S}\mathbin{:=}(\sqsubseteq ),(\leq )}$
, the square
${{f}\mathbin{:}(\sqsubseteq )\to (\leq )}$
is a concise way of saying that
${{f}}$
is a monotonic function:
.
Predicates as types A special case of square (5.3) pops up wherever
${{R}}$
and
${{S}}$
are partial identities, also called coreflexive relations (
${{R}\; \subseteq \;{id}}$
and
${{S}\; \subseteq \;{id}}$
). These relations are one-to-one correspondent to predicates: given a predicate
, its associated coreflexive is the relation
${{{p}}?\mathbin{:}{A}\to {A}}$
defined by
data:image/s3,"s3://crabby-images/e2a59/e2a59a86efee4faceb2379d8348e987ac026400f" alt=""
Let
${{f}}$
have relational type
${{{p}}?\to {{q}}?}$
, as shown next:
data:image/s3,"s3://crabby-images/cf4cf/cf4cf46b049ace5d255451178548169f7de6dfd6" alt=""
It is easy to see that (5.4) converts to the pointwise , meaning that
${{p}}$
is a sufficient condition on the input of
${{f}}$
(pre-condition) for
${{q}}$
to hold on the output (post-condition). By a not so dangerous abuse of notation one might abbreviate
${{f}\mathbin{:}{{p}}?\to {{q}}?}$
to
${{f}\mathbin{:}{p}\to {q}}$
and regard predicates
${{p}}$
and
${{q}}$
as types.Footnote
9
Another perspective is to look at (5.4) as a Hoare-triple
${{p}\;\{\mskip1.5mu {f}\mskip1.5mu\}\;{q}}$
where
${{f}}$
is a functional program that satisfies such pre/post conditions.Footnote
10
Algebraic squares A quite interesting situation arises in a Reynolds square (4.1) when
${{f},{g}\mathbin{:=}\alpha ,\beta }$
, where
${\alpha }$
and
${\beta }$
are algebras of a relator
:Footnote
11
data:image/s3,"s3://crabby-images/4d1a3/4d1a314567a70c327c8141a8e7b48d04ffb36cd1" alt=""
The pointwise equivalent of (5.5) is , for all
${{x}}$
and
${{y}}$
. For
${\alpha \mathrel{=}\beta }$
and endo-relation
${{R}}$
,
says that
${{R}}$
is compatible with algebra
${\alpha }$
. For
${{R}}$
an equivalence relation, it further says that
${{R}}$
is a congruence relation with respect to
${\alpha }$
.Footnote
12
In case
${{R}}$
is a function, say
${{R}\mathbin{:=}{h}}$
in (5.5), the square becomes perfect
data:image/s3,"s3://crabby-images/5c3cf/5c3cff7fba56de6f29fc872dee13ee8e2a14a0c9" alt=""
meaning that
${{h}}$
is an
-homomorphism (Bird & de Moor, Reference Bird and de Moor1997).
Coalgebraic squares Let
${{f},{g}\mathbin{:=}\gamma ,\phi }$
in a Reynolds square, where
${\gamma }$
and
${\phi }$
are
-coalgebras:
data:image/s3,"s3://crabby-images/77587/7758769da74fbc3b5d05332caf152c690b2a9194" alt=""
Then
${{R}}$
is said to be a bisimulation (Sangiorgi, Reference Sangiorgi2004) between the two coalgebras, meaning:
data:image/s3,"s3://crabby-images/246b3/246b31135018294f57173eaef68ca5029e312d21" alt=""
In case
${{R}}$
is coreflexive, it is known as a coalgebraic invariant (Barbosa et al., Reference Barbosa, Oliveira and Silva2008). Squares (5.5) and (5.6) show that, in a sense, a bisimulation is a kind of co-logical-relation.
Galois connections. To complete this review of concepts that magic squares are able to easily capture, let
${{R}}$
and
${{S}}$
in (4.1) be two preorders,
${(\sqsubseteq )}$
and
${(\leq )}$
respectively. Moreover, reverse the direction of
${{f}}$
and let the square be perfect:
data:image/s3,"s3://crabby-images/2b7c0/2b7c0ba195a4d666237a46ca82b5a3025d516be3" alt=""
This very special kind of square is known as a Galois connection (GC) between two so-called adjoint functions,
${{f}}$
(the lower or left adjoint) and
${{g}}$
(the upper or right adjoint). Going pointwise in (5.7) via (2.2, 3.2) etc one gets:
data:image/s3,"s3://crabby-images/39e93/39e93c9ae66e6ada283f248729fb0231f7aac9b8" alt=""
Two cancellation laws are easily obtained from (5.8):
data:image/s3,"s3://crabby-images/32771/327717f6b4e0c8dd5cc78f991d5718562b5a6da2" alt=""
These inequalities tell that f and g are inverses of each other in an imperfect way: the round-trip
${{f} \cdot {g}}$
loses information while
${{g} \cdot {f}}$
yields an over-approximation of its input. This is captured by the diagram
data:image/s3,"s3://crabby-images/3feff/3feff8b454e4642f0741f5f78bbc748b81546da8" alt=""
and often abbreviated by simply writing
${{f}\mathbin\dashv {g}}$
.
Examples of the usefulness of GCs in both mathematics and computing are abundant, see e.g. von Karger (Reference von Karger1998), Backhouse & Backhouse (Reference Backhouse and Backhouse2004), Mu & Oliveira (Reference Mu and Oliveira2011). The following GC between multiplication and whole division in the natural numbers
data:image/s3,"s3://crabby-images/c3e32/c3e321571e98b2d3a3cfaf2b74727bcf6e057279" alt=""
—
${( \times {y})\mathbin\dashv (\div {y})}$
in short, for
${{y}\not=\mathrm{0}}$
— will be of interest in the sequel.
6 Free theorem squares
In his landmark paper Theorems for free!, Philip Wadler (Reference Wadler1989) wrote: “From the type of a polymorphic function we can derive a theorem that it satisfies. (…) How useful are the theorems so generated? Only time and experience will tell (…)”. Under this “theorems for free” catchy phrase, Wadler made popular an important result on parametric polymorphism due to John Reynolds (Reference Reynolds1983). Four decades later there is ample evidence that such free theorems are indeed very useful, see for instance the work by Backhouse & Backhouse (Reference Backhouse and Backhouse2004), Voigtländer (Reference Voigtländer, Shao and Pierce2009) and Hackett & Hutton (Reference Hackett and Hutton2015).
The rest of this paper will be devoted to one particular application of such free theorems. Before that, the question arises: what is a free theorem and how does one derive it (for free)? It turns out that free theorems are magic squares. To put it simply, let a parametric function be given. Then its free theorem states that
${{f}}$
has relational type
data:image/s3,"s3://crabby-images/2fcff/2fcff4c0f944460f2bb16dde7b5dba981ad4006b" alt=""
for any
${{R}}$
relating its parameters, as shown in the corresponding square:
data:image/s3,"s3://crabby-images/c7e82/c7e8297af022bf11255751bb76517fba5420f0df" alt=""
This extends to multiparametric functions, as shown next with a simple example: consider the Haskell constant function
${\mathsf{const}\mathbin{:}{a}\to {b}\to {a}}$
. In exponential notation (and following our uppercase notation for type parameters), we may write
${\mathsf{const}\mathbin{:}{A}\to {{A}}^{{B}}}$
. Then, by (6.1),
${\mathsf{const}}$
has relational type
${{R}\to {{R}}^{\textit{S}}}$
, that is,
data:image/s3,"s3://crabby-images/c4c30/c4c301041089a448ea16261b69f88926da2ce128" alt=""
holds, cf.
data:image/s3,"s3://crabby-images/4a6e4/4a6e41db51ed1baa25b75545dfc0db3b8bd1ece8" alt=""
As already mentioned, this square is the free theorem of
${\mathsf{const}}$
. Recalling (4.15, 4.16), its pointwise version is, for all
${{a}}$
,
${{b}}$
,
${{c}}$
,
${{d}}$
:
data:image/s3,"s3://crabby-images/0aa6e/0aa6e9b929d058bee22820bcb5d2ab61c724e03c" alt=""
As a foretaste of what is to come, let us see how productive (6.2) is. Select, for instance,
${{R},{S}\mathbin{:=}{id},{k}}$
. Then (6.2) becomes
${\mathsf{const}\; \subseteq \;{{id}}^{{k}} \cdot \mathsf{const}}$
that, by (4.13,3.3) and (3.5) becomes
${( \cdot {k}) \cdot \mathsf{const}\mathrel{=}\mathsf{const}}$
, which is equivalent to
${\mathsf{const}\;{a} \cdot {k}\mathrel{=}\mathsf{const}\;{a}}$
— a well-known fusion law for constant functions. Swapping the roles of
${{R}}$
and
${{S}}$
to
${{R},{S}\mathbin{:=}{k},{id}}$
, one gets
${\mathsf{const} \cdot {k}\; \subseteq \;{{k}}^{{id}} \cdot \mathsf{const}}$
which, by (4.8) etc, rewrites to
${\mathsf{const} \cdot {k}\mathrel{=}({k} \cdot ) \cdot \mathsf{const}}$
yielding another well-known law:
${{k} \cdot \mathsf{const}\;{a}\mathrel{=}\mathsf{const}\;({k}\;{a})}$
.
Flipping. As another example, consider the well-known function in Haskell that swaps the arguments of a curried function:
data:image/s3,"s3://crabby-images/7df5b/7df5b607871ed12c252c7c763de8e30bc07543e7" alt=""
Its free theorem states that has relational type
${{{{Q}}^{{S}}}^{{R}}\to {{{Q}}^{{R}}}^{{S}}}$
meaning
data:image/s3,"s3://crabby-images/6e0cd/6e0cdf15a32e8d1ab035d3bd2303b5cf4b0001db" alt=""
that is,
data:image/s3,"s3://crabby-images/47148/471487e5862a27729f595362855034279b38c64f" alt=""
where (as in the sequel) we use the tilde notation to abbreviate
, as in the right hand square above. For
${{Q}\mathbin{:=}{id},{S}\mathbin{:=}{id}\;{and}\;{R}\mathbin{:=}{r}}$
(a function), one gets:
data:image/s3,"s3://crabby-images/ede9b/ede9bbf6c7f089b68d69835992199854614865d3" alt=""
This is known as the fusion-law of flipping (Oliveira, Reference Oliveira2020).
Flipping will be relevant in the rest of the paper, in which we shall investigate the theory that stems from the free theorems of two very popular functional programming combinators,
${\mathsf{foldl}{}{}}$
and
${\mathsf{foldr}{}{}}$
, heading toward discussing under what conditions they have the same behaviour.
7 foldl and foldr
In Haskell, there is a class
${{Foldable}}$
that, according to the standard documentation, “represents data structures that can be reduced to a summary value one element at a time”.Footnote
13
The class offers, in particular, two standard ways of accessing foldable data structures:
data:image/s3,"s3://crabby-images/d2944/d2944b9205aa9a7c869d4ee2286c527398bc827f" alt=""
Lists are a prominent instance of the class — and, indeed, its main inspiration — whose standard definitions are:
data:image/s3,"s3://crabby-images/26c25/26c25d589bf22561596d28db134e35040e9c7bce" alt=""
The free theorems of
${\mathsf{foldl}{}{}}$
and
${\mathsf{foldr}{}{}}$
— valid for any instance
of class
${{Foldable}}$
— can be written in the form of relational types:Footnote
14
data:image/s3,"s3://crabby-images/6f059/6f059ea601d1190ca1b67afaaa07d22c8010b5c1" alt=""
data:image/s3,"s3://crabby-images/ce742/ce74204b169cf799d71c5bd541719ef51b00fa7d" alt=""
There are two squares involved in each type. The one on the left will play the role of a side-condition for the one on the right to hold.
Foldl. Let us see (7.2) first:
data:image/s3,"s3://crabby-images/2b32d/2b32d71465d508c657d807df23894e9fdcc2820f" alt=""
For
${{R},{S}\mathbin{:=}{id},{h}}$
(hence
${{A}\mathbin{:=}{X}}$
), both
and
${{{S}}^{{R}}}$
reduce to
${({h} \cdot )}$
by
Footnote
15
and (4.8). So the squares become perfect and one has:
data:image/s3,"s3://crabby-images/82277/8227714503f0283f8b500a396049da58e96ad2b7" alt=""
Going pointwise via the usual laws, from (7.5) one gets:
data:image/s3,"s3://crabby-images/4e451/4e45115ef78e57499c4436221d15669e1d9194f4" alt=""
This is the fusion law of
${\mathsf{foldl}{}{}}$
given by Bird & Gibbons (Reference Bird and Gibbons2020), who prove it (for lists) by finite-list induction. Note however that, as a corollary of a free theorem, it needs no dedicated proof and it holds for all instances of class
${{Foldable}}$
, not just for lists. Moreover, the scope of (7.4) is far wider than perfect squares involving only functions, as shown next.
To give a simple example, let
${{S}}$
be an ordering
${(\leq )}$
and keep
${{R}\mathbin{:=}{id}}$
. Since
both squares will feature the relational type
${(\leq )\to {(\leq )}^{{id}}}$
. Then, if the left square holds, i.e. for all
${{b}}$
,
${{y}}$
data:image/s3,"s3://crabby-images/3b4ec/3b4ecd68727a1003d765e74a4370e7451acef9a8" alt=""
then the right square
data:image/s3,"s3://crabby-images/cf681/cf681499a028dca8898d8f6c571e7726ec5d5884" alt=""
will hold too.
Perhaps more interesting is to observe that, if types a and b are replaced by predicates p and q, under the interpretation given by (5.4), then
data:image/s3,"s3://crabby-images/21209/21209dc51ccd57e00eff91b25ae65085f295ca1d" alt=""
is a corollary of the free theorem, saying:
data:image/s3,"s3://crabby-images/8d91f/8d91fecebbceb77ebd2e0772d4775681ffcde7b1" alt=""
NB:
${\mathsf{all}\;{p}}$
, available for all instances of class
${{Foldable}}$
, is the predicate associated to the coreflexive
that relates a
-structure to itself if and only if all data in it satisfy predicate
${{p}}$
.
Foldr. Repeating the above exercise for (7.3), on the right we get the same square as in (7.4), but the side condition on the left is different:
data:image/s3,"s3://crabby-images/c16cd/c16cd8eaee108cd2b0e99fa2a35d57d8962ab5c7" alt=""
For
${{R},{S}\mathbin{:=}{id},{h}}$
, such a side-condition square unfolds to:
data:image/s3,"s3://crabby-images/5f281/5f28137df41bfaa64997b48d75ea43507e5cd421" alt=""
Altogether, one gets:
data:image/s3,"s3://crabby-images/f7ad0/f7ad0b0d51b1f60dc3be73fb9041b59356594098" alt=""
Going fully pointwise,
data:image/s3,"s3://crabby-images/23bde/23bde5bd796eed62cf6c32c010dcb2d0d2e0f13f" alt=""
one obtains the fusion law of
${\mathsf{foldr}{}{}}$
proved for finite lists (by induction) by Bird & Gibbons (Reference Bird and Gibbons2020). Again we stress that (7.7) is a corollary of a free theorem and needs no proof, holding for all instances of class
${{Foldable}}$
.
Furthermore, by swapping the roles of
${{R}}$
and
${{S}}$
and making
${{S},{R}\mathbin{:=}{id},{h}}$
, the side-condition square of (7.6) becomes
${{g}\;({{id}}^{{h}})\;{f}}$
which, by (4.17) is
${{f}\mathrel{=}{g} \cdot {h}}$
. Replacing
${{f}}$
in the right square we get
data:image/s3,"s3://crabby-images/74595/74595cafb6dd6b6cad64e412764b17cdf03eaac1" alt=""
Law (7.9) is often referred to as the absorption law of “fmap” () by
${\mathsf{foldr}{}{}}$
. It is another corollary of free theorem (7.6) and therefore none of its instances in the
${{Foldable}}$
class needs a proof. The default implementation of
${{foldMap}}$
in Data.Foldable arises from (7.9).
Maybe Just to give an example of (7.8) holding for instances of class
${{Foldable}}$
other than lists, let us check the
${{Maybe}}$
instance defined in
${{{Data}.Foldable}}$
, with respect to (7.7):
data:image/s3,"s3://crabby-images/57679/5767938482ed93b98eb5d82856d45667d801f932" alt=""
We have two cases: for
${{xs}\mathbin{:=}\mathsf{Nothing}}$
, the right square trivially reduces to
${{h}\;{e}\mathrel{=}{h}\;{e}}$
and we are done. In the case
${{xs}\mathbin{:=}\mathsf{Just}\;{x}}$
, we have
${\mathsf{foldr}{{f}}{{e}}}$
${(\mathsf{Just}\;{x})} = {{f}\;{x}\;{e}}$
in (7.8) and
${\mathsf{foldr}{{g}}{({h}\;{e})}\;(\mathsf{Just}\;{x})\mathrel{=}{g}\;{x}\;({h}\;{e})}$
. Then:
${{g}\;{x}\;({h}\;{y})\mathrel{=}{h}\;({f}\;{x}\;{y})}$
${\Rightarrow }$
${{h}\;({f}\;{x}\;{e})\mathrel{=}{g}\;{x}\;({h}\;{e})}$
trivially holds too.
Permutativity Let
${{f}}$
and g be the same function in (7.7), say s, and
${{h}\mathbin{:=}{s}\;{a}}$
:
data:image/s3,"s3://crabby-images/eca86/eca86e24e2ec6a5b8b8ab9f960b23dc5b3458dad" alt=""
Property
${({s}\;{x}) \cdot ({s}\;{a})\mathrel{=}({s}\;{a}) \cdot ({s}\;{x})}$
— i.e. the fully pointwise
${{s}\;{x}\;({s}\;{a}\;{y})\mathrel{=}{s}\;{a}\;({s}\;{x}\;{y})}$
— is called (left) permutativity by Danvy (Reference Danvy2023).Footnote
16
It can be easily shown that if s is associative and commutative then it is permutative:
data:image/s3,"s3://crabby-images/d946c/d946c89e3ab72e53f3f71f156e9d1a10a0555fca" alt=""
That is:
data:image/s3,"s3://crabby-images/39031/390316b46e6339c22f29af2801b092f4ee186be0" alt=""
On the other hand, if s is permutative and has unit e, then s is commutative:
${{s}\;{x}\;({s}\;{a}\;{e})\mathrel{=}{s}\;{a}\;({s}\;{x}\;{e})}$
and thus
${{s}\;{x}\;{a}\mathrel{=}{s}\;{a}\;{x}}$
.
8 Universal properties
Suppose a particular instance of
${{Foldable}}$
such that
data:image/s3,"s3://crabby-images/97b1f/97b1f83bc20fa590f115ad951c6f072d899c5a80" alt=""
holds, for some
${\alpha }$
and
${\gamma }$
. By (7.6) the types are
and
. That is,
${\alpha }$
and
${\gamma }$
are constructors of type
. Such is the case of lists, in which
${\mathsf{foldr}{(\mathbin{:})}{[\mskip1.5mu \mskip1.5mu]}\mathrel{=}{id}}$
, that is,
${\alpha \mathrel{=}(\mathbin{:})}$
and
${\gamma \mathrel{=}[\mskip1.5mu \mskip1.5mu]}$
in (8.1). Then one has the following corollary of (7.8):
data:image/s3,"s3://crabby-images/1625d/1625dd968c69bf910d3583d4e7458a7c5bed0a56" alt=""
which, by introducing
${{z}\mathrel{=}{h}\;\gamma }$
and dropping
${{xs}}$
, becomes:
data:image/s3,"s3://crabby-images/aa89c/aa89cb4c8b1e265c67a4c93e005b0aa8be53c726" alt=""
Thiseans that, if
${\gamma }$
and
${\alpha }$
exist such that (8.1) holds, by the free-theorem of
${\mathsf{foldr}{}{}}$
the system of equations (in
${{h}}$
)
data:image/s3,"s3://crabby-images/0d360/0d360ff684aca18d45a49363be960702184dba8e" alt=""
has a unique solution,
${{h}\mathrel{=}\mathsf{foldr}{{g}}{{z}}}$
. Since
${\mathsf{foldr}{{g}}{{z}}}$
satisfies the equations for which it is a solution, then
data:image/s3,"s3://crabby-images/7f988/7f98849b14e87b602d8befadf69c35c815ed1726" alt=""
hold, unveiling the definition of
${\mathsf{foldr}{}{}}$
itself. Moreover, this definition is mathematically equivalent to (just replace h by
${\mathsf{foldr}{{g}}{{z}}}$
and simplify):
data:image/s3,"s3://crabby-images/d8d89/d8d892edcd3ce3a393aea6d27f9c7b9a6e7ecc73" alt=""
Putting (8.2,8.4) together, we get the universal property of
${\mathsf{foldr}{}{}}$
,
data:image/s3,"s3://crabby-images/79907/79907a51320719a0bfd48a3aff1582e972d9828e" alt=""
which, for lists, is
data:image/s3,"s3://crabby-images/41b76/41b76e3f33e183950885881b0d6fa783bc309a6f" alt=""
cf. e.g. Hutton (Reference Hutton1999).
9 Is foldl equal to foldr?
Looking at (7.1), the type-wise distance between
${\mathsf{foldr}{}{}}$
and
${\mathsf{foldl}{}{}}$
is the flip (6.3) of the first parameter.Footnote
17
So the “best fit” one can aim at here is
data:image/s3,"s3://crabby-images/9ac14/9ac14cdcc5a7047ed9321d717bcdb51d57c11754" alt=""
possibly valid for (as wide as possible) a class of functions f and instances of class
${{Foldable}}$
.
Our first step is to conjecture a definition for
${\mathsf{foldl}{}{}}$
that is type-wise consistent (over the
${{Foldable}}$
class) with (8.3) which — recall — was derived from the free-theorem of
${\mathsf{foldr}{}{}}$
. A possibility is to involve
${\mathsf{foldr}{}{}}$
itself in the definition. Looking at the flipped
${{f}}$
in (9.1), which is of type
${{A}\to {{B}}^{\textit{B}}}$
, one can think of expressing
by a higher-order fold:
data:image/s3,"s3://crabby-images/83e86/83e8619da548b011c576e0420814035a2032dde4" alt=""
Note the type
${\theta\;{f}\mathbin{:}{A}\to {({{B}}^{{B}})}^{({{B}}^{{B}})}}$
for
${{f}\mathbin{:}{B}\to {{B}}^{{A}}}$
.
Next, we unfold (9.2) via universal property (8.5). For easier reference, we instantiate (with no loss of generality)
${\gamma }$
and
${\alpha }$
for lists, as these are very well known to functional programmers:
data:image/s3,"s3://crabby-images/34e50/34e503b221a3fdbe4a0dc874e423bdcb8aba5a73" alt=""
This confirms the standard definition of
${\mathsf{foldl}{}{}}$
for lists.
Universal-
${\mathsf{foldl}{}{}}$
An advantage of defining
${\mathsf{foldl}{}{}}$
“as a
${\mathsf{foldr}{}{}}$
” (9.2) is that the universal property of the latter induces the universal property of the former:Footnote
18
data:image/s3,"s3://crabby-images/323e6/323e66a3b79fd83b0f60697b3f436f97b9f68d5d" alt=""
Thus we get the universal-property of
${\mathsf{foldl}{}{}}$
:
data:image/s3,"s3://crabby-images/455e2/455e20e36aa319a3fd68d4e32eed25db874a3091" alt=""
Equating
${\mathsf{foldl}{}{}}$
and
${\mathsf{foldr}{}{}}$
Next we address the question (9.1) that opened this section: under what conditions does
hold? We can use
${\mathsf{foldl}{}{}}$
-universal (9.3) to find an answer:
data:image/s3,"s3://crabby-images/6c137/6c1374dd2e398ba2e7d7646f5e05842677c06393" alt=""
We conclude that holds for the instances of class
${{Foldable}}$
such that (8.1) holds, provided that
is a permutative operation (recall Section 7).
The usual assumption that
${\mathsf{foldl}{{f}}{{e}}}$
and
are the same for
${{f}}$
associative and
${{e}}$
its unitFootnote
19
is therefore too strong. By (7.11) we know that associativity and commutativity ensure permutativity.Footnote
20
However, the converse implication does not hold, take e.g.
${{f}\mathrel{=}(\div )}$
(5.9) as counter-example: neither
${(\div }$
) nor
are associative or commutative, and yet
is permutative. Why? Let us check it by indirect equality (Dijkstra, Reference Dijkstra2001):
data:image/s3,"s3://crabby-images/a7481/a7481c4d792917797eb5ad62e51c5dd33f368f10" alt=""
Also to be noted, the second parameter e remains unconstrained in both folds. For example:
data:image/s3,"s3://crabby-images/b29df/b29df30ec08b30fb7f1049ad6e1765b1983a5535" alt=""
Of course, the previous calculation can generalize to any Galois connection
${{f}\mathbin\dashv {g}}$
.
Altogether, we have that is granted for those g that, being neither associative nor commutative, participate in an adjunction
${{f}\mathbin\dashv {g}}$
whose other adjoint is so.
10 Summary and discussion
This article addresses the use of relational, pointfree techniques in reasoning about functional programs. In particular, it shows the role of relational semi-commutative squares (suggestively referred to as “magic” squares) in expressing (and reasoning about) formal concepts relevant to computing and, in particular, to FP. By switching to relational types one gets a quite rich setting in which programming and expressing properties of programs blend naturally.Footnote
21
The calculation of “theorems-for-free” is given as an application of this, in particular used to infer conditions for the combinators
${\mathsf{foldl}{{f}}{{e}}}$
and
to compute the same output for any
${{e}}$
.
This research shares much with the work of Backhouse & Backhouse (Reference Backhouse and Backhouse2004), who give perhaps the most impressive account of the power of free-theorems of all literature on the subject, contributing with sharp results on the role of Galois connections in (higher-order) abstract interpretation. Such a paper is, however, not an easy read for the average functional programmer. The (less ambitious) approach proposed in the current paper bears in mind the need to make such fantastic results more and more accessible to the programming community.
There is a sharp contrast between the effectiveness of relational reasoning in the style of e.g. Bird & de Moor (Reference Bird and de Moor1997) and Backhouse & Backhouse (Reference Backhouse and Backhouse2004) and the low popularity of the methodology. This is rather unfortunate. Having decided to teach such relational methods to computer science students two decades ago, the author has invested into widening scope and applying such a reasoning style to areas such as database programming, formal modeling and, of course, functional programming (Oliveira, Reference Oliveira2024). In this process, diagrams have proved very effective as a device enhancing the perception of the information flow and of how the overall reasoning is conducted. Thus magic squares (MS) emerged as a simple, yet very powerful design unit of a pointfree, relational approach to formal reasoning.
Relational exponentiation
${{{S}}^{{R}}}$
plays a major role in the way higher-order functions are handled. By MS vertical composition (2.4), one immediately infers that, as expected, it is monotone on the base and anti-monotonic on the exponent:
data:image/s3,"s3://crabby-images/e5c6e/e5c6e70d081260c3e966a5286a897c1eb2dec06c" alt=""
We also know that
${{{id}}^{{id}}\mathrel{=}{id}}$
(4.14). By horizontal composition (2.3), we get
data:image/s3,"s3://crabby-images/3bb84/3bb84d53c747bb005f925d0d8063c0360c508a77" alt=""
However, the converse inclusion does not hold and so relational exponentiation is not in general a (bi)relator.Footnote 22 Backhouse & Backhouse (Reference Backhouse and Backhouse2004) give conditions for strengthening (10.1) to an equality that include the cases involving functions and converses of functions used in this paper.
Functional programmers have realized that many abstract concepts they love have a categorical nature. This has led to a strong focus on explaining the whole paradigm in categorial terms, see e.g. Hinze et al. (Reference Hinze, Wu and Gibbons2015) — a trend that of course includes the today so important concept of a monad (Wadler, Reference Wadler1990; Moggi, Reference Moggi1991; Gibbons & Hinze, Reference Gibbons and Hinze2011). It all happened as if, in a sense, FP eventually came to rescue category theory from being considered by the programming community as mere abstract nonsense, with no practical application. In this setting, theorems-for-free have been formalized via (lax) dinatural transformations (Hackett &Hutton, Reference Hackett and Hutton2015; Voigtländer, Reference Voigtländer2019) in order-enriched categories. We believe that the category of relations, which is “naturally” ordered by relation inclusion, provides an overall simpler approach, much in the spirit of the quote by Freyd & Scedrov (Reference Freyd and Scedrov1990) that opens this paper.
Framed in this trend, the
${\mathsf{foldl}{}{}\mathbin{/}\mathsf{foldr}{}{}}$
case study could have been given as a pointfree calculation carried out via the adjoint-fold theorem (Hinze, Reference Hinze2013; Oliveira, Reference Oliveira, Madeira and Martins2023) and enabled by the self-adjunction witnessed by
${{flip}}$
Footnote
23
— as in a similar calculation concerning left and right-iteration (Oliveira, Reference Oliveira2020). It should be noted that knowing that permutativity is enough for foldr/foldl “equality” is not new — see e.g. Danvy (Reference Danvy2023). Danvy’s reasoning is, however, quite different: he postulates permutativity as a side condition and then proves it in Coq by induction on lists. In this paper, permutativity arises by free-theorem calculation. Moreover, it shows that Danvy’s result can be extended via Galois connections.Footnote
24
The generic approach to this case study given in the current paper throws attention to the
${{Foldable}}$
class of the Haskell standard library system. The permutativity of
${{f}}$
that grants the
outcome “for-free” is not alone: a reflection constraint (8.1) is also needed. This constraint is quite strong in the sense of identifying the type constructors
${\gamma }$
and
${\alpha }$
of the particular
${{Foldable}}$
instance in hands. The types of
${\alpha }$
and
${\gamma }$
in (8.1) clearly point to lists as being the prototypical instance of the class.
It is not difficult to find instances of class
${{Foldable}}$
that do not meet reflection constraint (8.1) and for which the
${\mathsf{foldl}{}{}\mathbin{/}\mathsf{foldr}{}{}}$
result cannot be obtained as in the current paper. Interestingly enough,
seems to be granted across the class as an axiom, that is,
is the default definition of
${\mathsf{foldl}{}{}}$
, assuming
${\mathsf{foldr}{}{}}$
defined. Studying this better and applying the same kind of reasoning to other classes of the Haskell standard libraries is a topic for future research.
Acknowledgments
This work was supported by National Funds through the FCT – Fundação para a Ciência e a Tecnologia, I.P. (Portuguese Foundation for Science and Technology) within the IBEX project, with reference PTDC/CCI-COM/4280/2021.
Competing interests
The author reports no conflict of interest.
Discussions
No Discussions have been published for this article.