A recent blog post on William Cook's Fusings mentions:
The key point is that structures in Ensō are viewed holistically as graphs, not as individual values or traditional sums-and-products data structures.
What are the traditional sums-and-products data structures he is referring to?
He is referring to the standard algebraic data types of functional programming languages.
Examples:
If
a
is of typeA
andb
is of typeB
then(a, b)
is of typeA x B
, which is a product type.A list type with values of the form
Nil
orCons x xs
is a sum type.Ensō apparently has a greater emphasis on graphs than these tree-like algebraic types.
From the lecture notes for the Coursera course, "Programming Languages", offered by Univ. of Washington:
"Why product and sum? It is related to the fact that in Boolean algebra where 0 is false and 1 is true, and works like multiply and or works like addition."
In type theory, regular data structures can be described in terms of sums, products and recursive types. This leads to an algebra for describing data structures (and so-called algebraic data types). Such data types are common in statically typed functional languages, such as ML or Haskell.
Products
Products can be thought of as the type-theoretic view of "structs" or "tuples".
Formally, PFPL, Ch 14:
Sums
Sum types express choice between variants of a data structure. Sometimes they are called "union types" (as in C). Many languages have no notion of sum types.
PFPL, ch 15:
Recursive types
Along with products and sums, we can introduce recursion, so a type may be defined (partially) in terms of itself. Nice examples include trees and lists.
Algebra of sums, products and recursion
Give a type, say
Int
, we can start building up a notation for algebraic expressions that describe data structures:A lone variable:
Int
A product of two types (denoting a pair):
Int * Bool
A sum of two types (denoting a choice between two types):
Int + Bool
And some constants:
1 + Int
where
1
is the unit type,()
.Once you can describe types this way, you get some cool power for free. Firstly, a very concise notation for describing data types, secondly, some results transfer from other algebras (e.g. differentiation works on data structures).
Examples
The unit type,
data () = ()
A tuple, the simplest product type:
data (a,b) = (a,b)
A simple sum type,
data Maybe a = Nothing | Just a
and its alternative,
and a recursive type, the type of linked lists:
data [a] = [] | a : [a]
Given these, you can build quite complicated structures by combining sums, products and recursive types. E.g. the simple notation for a list of products of sums of products:
[(Maybe ([Char], Double), Integer)]
gives rise to some quite complicated trees:References
Very detailed answers have already been given, but somehow they don't mention this simple fact.
Sum types are called so because the number of possible values of a sum type is the sum of the number of values of the two underlying types. Similarly for product types, the number of possible values is the product.
This stems from type theory defining a type as a set of values.
Now you will never forget which is which.