catlog::dbl

Module theory

Source
Expand description

Double theories.

A double theory specifies a categorical structure, meaning a category (or categories) equipped with extra structure. The spirit of the formalism is that a double theory is “just” a virtual double category, categorifying Lawvere’s idea that a theory is “just” a category. Thus, a double theory is a concept with an attitude. To bring out these intuitions, the interface for double theories, DblTheory, introduces new terminology compared to the references cited below.

§Terminology

A double theory comprises four kinds of things:

  1. Object type, interpreted in models as a set of objects.

  2. Morphism type, having a source and a target object type and interpreted in models as a span of morphisms (or heteromorphisms) between sets of objects.

  3. Object operation, interpreted in models as a function between sets of objects.

  4. Morphism operation, having a source and target object operation and interpreted in models as map between spans of morphisms.

The dictionary between the type-theoretic and double-categorical terminology is summarized by the table:

Associated typeDouble theoryDouble categoryInterpreted as
ObTypeObject typeObjectSet
MorTypeMorphism typeProarrow (loose morphism)Span
ObOpObject operationArrow (tight morphism)Function
MorOpMorphism operationCellMap of spans

Models of a double theory are categorical structures, rather than merely set-theoretical ones, because each object type is assigned not just a set of objects but also a span of morphisms between those objects, constituting a category. The morphisms come from a distinguished “Hom” morphism type for each object type in the double theory. Similarly, each object operation is not just a function but a functor because it comes with an “Hom” operation between the Hom types. Moreover, morphism types can be composed to give new ones, as summarized by the table:

MethodDouble theoryDouble category
hom_typeHom typeIdentity proarrow
hom_opHom operationIdentity cell on arrow
compose_typesCompose morphism typesCompose proarrows

Finally, operations on both objects and morphisms have identities and can be composed:

MethodDouble theoryDouble category
id_ob_opIdentity operation on object typeIdentity arrow
id_mor_opIdentity operation on morphism typeIdentity cell on proarrow
compose_ob_opsCompose object operationsCompose arrows
compose_mor_opsCompose morphism operationsCompose cells

§References

Structs§

Enums§

  • Projection onto morphism type in a discrete tabulator theory.
  • Morphism type in a discrete tabulator theory.
  • Projection onto object type in a discrete tabulator theory.
  • Object type in a discrete tabulator theory.

Traits§

Type Aliases§