Skip to content

Instantly share code, notes, and snippets.

@MostAwesomeDude
Last active January 22, 2024 19:24
Show Gist options
  • Star 3 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save MostAwesomeDude/6dad2c19850b5d53826a4210604a2e9e to your computer and use it in GitHub Desktop.
Save MostAwesomeDude/6dad2c19850b5d53826a4210604a2e9e to your computer and use it in GitHub Desktop.
The relational interpretation of Lojban (la brismu)

0: Introduction

This pamphlet is addressed at folks who know Lojban. They've read not just a tutorial like la karda, the Crash Course, or the Wave Lessons, but also CLL and the BPFK Sections, and some of the various notes from many community members.

I am not aiming to teach the syntax of Lojban, but to radically and fundamentally approach the logical foundations of the semantics of Lojban. We will not start with pronouns, but with relations, and we will always keep the mathematics in mind as we progress.

A common theme in the Lojban community is an uncertainty about what words mean. Since words are treacherous and don't have ultimate meaning, and many Lojbanists are philosophers, it is predictably common for such uncertainty to evolve into passionate discussion featuring these themes:

  • "Lojban is not a relex": Aside from Lojban itself being forked from Loglan, Lojban is not merely a borrowing of semantics precisely established and defined in some natural language.
  • Limited words can still blanket semantic space by being vague. We can use tanru to carefully describe observed objects in only certain ways, without committing to imprecision or incorrectness.
  • The grue/bleen problem prevents us from fixing any absolute meaning to any word over time.

So, rather than give each word a meaning on its own, I will use categorical logic and reasoning to build up structural meanings for Lojban. The resulting interpretation will have the structure of an allegory, indeed a bicategory of relations, but do not let these currently-unfamiliar mathematical terms worry you, as they are both just ways to talk about what relations are.

1: What is a relation?

First, mathematically, a binary relation R : X -> Y between two collections of objects X and Y is a collection of pairs of objects (x, y) in (X, Y).

Immediately, the most important feature is the reversibility of the relation; for every R : X -> Y there is an R† : Y -> X, called the dagger of R, which is the same relation but backwards. Another important feature is that we can ask whether a given pair (x, y) is in R, and this leads to the characteristic function for R, which returns the Boolean truth value, true or false, indicating whether the pair is in the relation. We'll write this characteristic as R(x, y). We can also ask about how many pairs are in R, and we'll write this as |R| and call it the cardinality). We'll say that R is satisfiable when it has nonzero cardinality.

While binary relations are the most common kind, relations can come in any arity, and we might see unary relations (which are just subsets) or ternary relations or any arity.

Now, Lojbanically, a selbri has an underlying relation, and its sumti have underlying sets. When we write {da broda de}, we are indicating that (da, de) is within some collection referenced by broda : abu -> ebu. The intermediate Lojbanist will immediately recognize that {de se broda da} is the same utterance, but rearranged; {se} acts as a dagger operator. Similarly, the selbri {jei da broda de} is syntax for the characteristic function; we are applying the selbri {broda} onto the pair (da, de) and seeing whether it is present in the relation. The selbri {ka ce'u broda ce'u} allows us to capture the selbri {broda} itself and plug many different pairs of values in to see whether they are present.

While I will try to keep this terminology straight, I may occasionally abuse words to say that some sumti are in a selbri, by which I mean that the referent objects of each sumti, taken as a tuple, belong to the relation referred to by the selbri.

Size issues

What are our collections? In mathematics, we usually build relations and pairs from sets. However, when sets contain other sets, then we have problems about infinite sets which contain other infinite sets, popularly known as Russell's paradoxes, or affectionately known to mathematicians as "size issues". To avoid size issues, we have to say that there are only some certain ways to form infinite sets. In particular, the only infinite set we'll directly build is the set of natural numbers.

2: Definitions and Proofs

Let's define some valsi, just like any good Lojban tutorial. Since I assume that the reader has already consumed an introductory tutorial and a grammar reference, I will attempt to focus on the formal side of our budding correspondence between Lojban and categorical logic.

Identity: {du}

The first selbri we'll define is {du}. With {du}, we can relate any object to itself. How do we talk about this property formally? We'll use natural deduction, which is a common style of formal proof. The idea is to start from some assumptions, and apply some rules, coming to some conclusions.

To start, let's give an axiom for {du}. An axiom is an assumption that we can always make. I'll put this axiom in a block by itself, but I'm also going to give it a petname in parentheses so that we can refer to it later easily.

da du da (id-refl)

"id" is short for "identity", and that's precisely what {du} does. "refl" is short for "reflexive", which is one of the three properties of equivalence relations. An equivalence relation is a relational way to talk about equality, and {du} definitely should be an equivalence relation, so let's add those other rules. The second property is called "symmetry", and it means that we can swap the sumti without changing the bridi. To show what a swap looks like, we'll introduce rules. A rule has some assumptions on top, and then a bar, and then some conclusions on the bottom.

da du de
======== (id-sym)
de du da

Here I've drawn a double bar to show which part of the rule is which. I will sometimes also draw single bars. The double bar is reversible; it can be turned upside down to gain another rule. For {du} this is unsurprising, but some double bars later on may feel confusing at first. I encourage the reader to take their time and carefully examine the diagrams to make sure that they can read each step in a proof.

In relational logic, many rules are reversible. This is an instance of the microcosm principle, where algebraic structures tend to show up within their own categorified presentations. We will eventually show that rules can be manipulated like sumti.

A rule can have multiple assumptions. Here, I'll use an ampersand to separate multiple assumptions.

da du de & de du di
=================== (id-trans)
     da du di

And in relational logic, rules can have multiple conclusions! This happens if we take a reversible rule like (id-trans) and run it backwards.

Conversion Operators: {se}

{se} is one of what I will call "operators" on selbri; they are cmavo which alter the structure around a selbri without changing the relation itself. {se} also has reversible rules, as one might expect.

 da broda de
============== (se-intel)
de se broda da

"intel" is short for "introduction" and "elimination", which are traditionally two separate rules. With relational logic, it's one reversible rule instead.

We can start to describe a conversion-normal form for selbri by imagining applying (se-intel) backwards whenever possible, eliminating {se}.

Finally, let's finish our tour of natural deduction by building a proof. A proof is a tree of rules, with the conclusions of one rule becoming the assumptions of the next rule. When a proof only assumes axioms, then I will call its conclusions theorems, and consider them as honorary axioms. Here is our first proof; it starts from an axiom and applies a single rule, concluding in our first theorem.

 da du da   (id-refl)
=========== (se-intel)
da se du da

What we have concluded is that, in any context, {da se du da} is a true bridi. We could give this theorem a name and reuse it in the future. Here's another useful theorem.

 da du de
 ========   (id-sym)
 de du da
=========== (se-intel)
da se du de

This theorem states the symmetry of {du} using {se}.

Composition: {gi'e}

When a variable shows up in two different bridi, then we might be able to combine them. The underlying relations compose cleanly, so most of the difficulty is in Lojbanic arrangement. We need to use the concept of contravariance, and turn around one of the bridi, in order to apply {gi'e}.

da broda de & da brode di
========================= (gi'e-intel)
da broda de gi'e brode di

Our ampersand happens to commute, so {gi'e} commutes as well. To see this in full, let's do a deduction that can't be done with only two dimensions. The (sr) rule is short for "structural rearrangement"; we are doing bookkeeping that doesn't affect the logical correctness of assumptions and that would be free if we could stand our proof up like a tree in three dimensions. Recall that {gi'e} groups to the left.

da broda da gi'e brode de gi'e brodi di
======================================= (gi'e-intel)
da broda da gi'e brode de & da brodi di
======================================= (gi'e-intel)
da broda da & da brode de & da brodi di
======================================= (sr)
da broda da & da brodi di & da brode de
======================================= (gi'e-intel)
da broda da gi'e brodi di & da brode de
======================================= (gi'e-intel)
da broda da gi'e brodi di gi'e brode de

In the middle, those two triangles of assumptions are each two-dimensional, but stacked on top of each other, giving a three-dimensional structure to the proof.

To get more comfortable with proofs, let's do another one. This proof is closer in phrasing to traditional categorical texts, where given f : X -> Y and g : Y -> Z, one can form f;g : X -> Z. Note that, unlike in traditional notation, we do not forget our intermediate connecting values between relations.

 da broda de & de brode di
============================ (se-intel)
de se broda da & de brode di
============================ (gi'e-intel)
de se broda da gi'e brode di

One more rule connects {gi'e} back to {du} by letting us effectively rewrite across an equality. This is like performing a sort of unification, too.

da broda de & de du di
====================== (du-intel)
     da broda di

We can use both of these new rules to write the more categorically-oriented proof, which says that composition with the identity relation has no effect.

da broda de gi'e du di
====================== (gi'e-intel)
da broda de & de du di
====================== (du-intel)
     da broda di

Along with the other rules introduced, we now have a dagger category on selbri, with {du} as our identity selbri, {gi'e} for composition, and {se} for the dagger.

Scoping

Scoping comes into play at this time. Up until this point, we have not explained the scoping and binding of our {da} variables. However, scoped negation and plural quantifiers do not work with our (se-intel) rule. The fix comes from work done on bicategories of relations and regular logic: All quantifiers must either be lifted to the top level, or be single positive existential quantifiers.

In more words, {da} is fine because it only binds one thing once, it asserts that the bound thing satisfies the bridi it's bound within, and it only claims that there is one satisfying thing at a time rather than all things at once, and it fortunately has all of these properties by default. When we need other quantifiers, we will use a prenex.

Interpreting natural deduction

Each logic in natural deduction can be used to give judgements, like "P is true." Wikipedia lists "P is possibly true," "P is always true," "P is true at a given time," and "P is constructible from the given resources," as other examples in other logics. What does relational logic give us? Relational logic judgements are of the form "P is true multiple times, under each of the given contexts;" we can imagine that a bridi is not just true or false, but true for each of the many possible values that are being related.

3: Categorical Relational Algebra

Let's investigate more properties of the category of sumti and selbri. In this section, we'll think categorically, and look for abstract patterns which show up elsewhere in logic. We'll look at products and coproducts, as well as internal homs. We will be guided by the properties of bicategories of relations.

Products: {gi'onai}

Is there a selbri for categorical products? Let's first write out the categorical universal property that we want to search for. Given two objects X and Y, their product X * Y comes with the ability to combine any two arrows l : I -> X and r : I -> Y into a single compound arrow l*r : I -> X * Y, as well as two arrows p1 : X * Y -> X and p2 : X * Y -> Y. Next, let's write a selbri in English, along the lines of "x1 (set) is the disjoint union of x2 (set) and x3 (set)". We know from the definition of the category of relations, Rel, that the disjoint union of sets is the correct choice for products.

As it happens, the experimental non-logical cmavo {jo'ei} can build disjoint unions, although there is no selbri satisfying {da jo'ei de broda da de} as we might like.

Now, let's state the actual universal property. For products, this means combining our two arrows into one arrow. To achieve a disjoint union, we will select from either the left-hand arrow or the right-hand arrow, but not both at once. This is a job for {onai}.

 da broda de & da brode di
============================ (gi'onai-intel)
da broda de gi'onai brode di

What makes this rule different from (gi'e-intel) is the logical interpretation of results. An {onai} forms a branch, and only variables on one side of the branch will be bound. That is, even when the entire bridi succeeds, some of its variables may not have any values. If we wanted to prevent this situation, then we could produce a fresh variable and adopt the convention that scoped variables aren't visible at the top level, but that requires some extra machinery that we haven't set up yet.

Let's get weird. We haven't properly introduced negation yet, so let's just say that when {onai} chooses one branch, then the other branch is not explored. Negation is like a refusal to bind any values. We will get more precise later, but for now, consider this surprising statement.

 da broda de gi'e brode di
 =========================   (gi'e-intel)
 da broda de & da brode di
============================ (gi'onai-intel)
da brode de gi'onai brode di

Here is part of the strange reality of relational algebra: The number of results is not necessarily zero, neither on the top nor the bottom of this statement! On top, we need both relations to be satisfied simultaneously, so we'll get triples (da, de, di). On bottom, we can have pairs of either (da, de) or (da, di). So, if we go from top to bottom, then each input triple gives two output triples. In the other direction, we are performing a unification that matches up these pairs into spans, which happens to be a common operation in low-level relational algebra.

Coproducts

Relations are extremely symmetrical, and sometimes that is very powerful. Categorical coproducts, also known as sums, are very popular in programming language theory. Coproducts are defined by categorical duality; we take the definition of products, mechanically turn around all of the arrows, and obtain a new universal property. But because relations are so symmetrical, it happens that the disjoint union implements both products and coproducts for relations.

  da broda di      de brode di
 ==============   ============== (se-intel)
 di se broda da & di se brode de
================================== (gi'onai-intel)
di se broda da gi'onai se brode de

One more curious example. Here, we are looking for broda(di, de) pairs where di ≠ di. We are allowed to transition between zero and nonzero numbers of results!

da broda de gi'onai du di
========================= (gi'onai-intel)
 da broda de & da du di
 ======================   (du-intel)
       di broda de

Internal homs: {ka}, {ckaji}, {ckini}

We can now search for the internal hom (WP), the construction which behaves like functions with closure. It turns out that relationally, internal homs are built from Cartesian products. To see this, let's see the universal property: Given a pair (X, Y^X), we can apply the latter to the former, and get a Y. So the universal property comes as a single arrow apply : (X, Y^X) -> Y.

        da broda de
============================ (ckaji-intel)
da ckaji pa ka ce'u broda de

We will use {ka} for selbri which have been closed over, with {ce'u} indicating where holes remain. Arity will matter; {ckaji} can only fill in one hole at a time. Why {pa}? Because there's only one way to perform the closure, up to unique isomorphism, and so the quantifier ought to be "there exists exactly one". This is a common property of universal properties, but it is very different from traditional Lojban quantification, where {lo ka} is used to generically select relations. A notable consequence is that, in rules like (ckaji-intel), we will not bind the {ka} to any name, but we will bind each {de} just the same in both the top and bottom.

So, where were those Cartesian products? One is hidden inside {da broda de}: each solution to this bridi is a pair (da, de) drawn from their Cartesian product! We can make a more explicit coupling with {ckini}, which does for binary {ka} what {ckaji} does for unary {ka}. Note that we use explicit {ce'u} to mark

          da broda de
================================= (ckini-intel)
da ckini de pa ka ce'u broda ce'u

I can think of a few useful lemmas to try out. First, let's see if we can connect {ckaji} and {ckini} without any more rules.

  da ckaji pa ka ce'u broda de
  ============================    (ckaji-intel)
          da broda de
================================= (ckini-intel)
da ckini de pa ka ce'u broda ce'u

Looks reasonable. What about the symmetry within {ckini}? Can we, say, put {se} underneath {ka}? Yes, we can.

 da ckini de pa ka ce'u broda ce'u
 =================================   (ckini-intel)
            da broda de
           ==============            (se-intel)
           de se broda da
==================================== (ckini-intel)
de ckini da pa ka ce'u se broda ce'u

Creation and Deletion: {zi'o}

Relationship diagrams can create and delete data. Note, though, that the underlying relation is not erased. This is important both for preserving the behavior of the remaining data, and also for running in reverse. When we reverse deletion, we get creation of data from within the surrounding bridi.

 da broda de
============= (zi'o-del)
da broda zi'o

We can erase any column of the relation this way.

  da broda de
  ===========    (se-intel)
 de se broda da
================ (zi'o-del)
de se broda zi'o
================ (se-intel)
 zi'o broda de

Monoidal structure: {pamei}, {fa'u}

A monoid is a structure with a unit and a binary operation which associates. Categories are already monoids in one way, with identity arrows for units and composition as the binary operation. However, in a monoidal category, there is another unit and binary operation, and this second monoid gives us the ability to have multiple sumti packed into a single sumti.

First, we'll need our unit object. This object will only have one way to represent and relate data. We'll have this be a one-element set, or singleton set. The bridi {da pamei de} relates this set to its lone element. We would like to be able to say {le pamei}, and maybe we will eventually, but for now we'll have to designate the uniqueness of these sumti in a different way. Note the single-dashed lines in these rules; these are one-way derivations.

da pamei di & de pamei di
------------------------- (pamei-fa)
        da du de

da pamei de & da pamei di
------------------------- (pamei-fe)
        de du di

Monoidal products are designated with {fa'u}, both for sumti and selbri. We have one basic rule introducing and eliminating them, as usual.

      da broda de & di brode daxivo
========================================== (fa'u-intel)
da fa'u di broda fa'u brode de fa'u davixo

We have reached the point where we need at least four distinct sumti, and so we will need {xi} to give us additional names. Note that, as before with {gi'e} and {se}, the symmetry of our proof tree leads to a symmetry underneath {fa'u}.

More importantly, we need rules to let us remove units from monoidal products. If we have a pair of (da, @) where @ is the unique sumti {le se pamei}, then that's just like having a single value. However, once again, we can't just forget the underlying relation which is tied to the sumti, so we'll have to both pattern-match {fa'u} and also deliberately ask for {zi'o} to remove the lone irrelevant value from the other end of the pair.

da fa'u di broda fa'u brode de fa'u zi'o & de pamei di
====================================================== (fa'u-unit)
                     da broda de

That awkward rule is formally known by the awkward name of the "unitor". It has an elegant relative, just called the "unit", which also needs an awkward phrasing with {zi'o}.

zi'o pamei da & de broda zi'o (pamei-unit)

This axiom can be used like a selbri, and lets us start and stop a computation by replacing everything with the single unit value from the singleton set.

We can encode the Booleans as in bicategories of relations. The bridi {du} and {na du} serve as true and false respectively. We will have to soon define {na}, but we can put it off a little longer.

In addition to creation and deletion, there are also copying and merging. A copy of a value is a pair of that value twice; when we reverse copying, we get merging, where pairs are accepted only when they are two copies of the same value.

da du de fa'u de (fa'u-copy)

There are also two rules which relate to internal logic and let us move selbri up and down the monoidal structure. The first says that, if we have a selbri followed by a copy, then we can duplicate the selbri along the copy.

          da broda de & de fa'u de du di
---------------------------------------------------- (selbri-copy)
da broda de & da broda daxivo & de fa'u daxivo du di

The second says that, if we have a selbri followed by a deletion, then we can delete the selbri too. However, we don't need a new rule for this.

 da broda de & zi'o pamei di
============================= (zi'o-del)
da broda zi'o & zi'o pamei di

Curious how everything fits together. To be honest, this probably means that I've made a mistake somewhere.

4: Categorical Set Theory

At this point, we are ready to give the axioms for set theory. We will be using ZF, and the shape of each axiom comes from Rethinking Set Theory.

Composition

Terminal object

Initial object

Products

Internal homs

Pullbacks

Subobject classifier

NNO

Choice

-1: Notes, Uncleaned

We now start inching towards set theory inside Lojban. We begin with an important relation, {cmima}, which corresponds to the notion of membership. First, let us put size issues to rest:

da na cmima da

This doesn't actually do what I had imagined when I wrote it. It's pretty but useless.

A {na} bridi asserts that its tuple of sumti are not related by its selbri; that is, that the tuple doesn't belong to the selbri's relation. And now we can give an equivalent for the axiom of pairing:

da cmima da ce de

{ce} is commutative:

da ce de broda
==============
de ce da broda

We now introduce useful sumti. First, {da} may be restricted with {poi}. A sumti {da poi ke'a broda} carries with it the implicit understanding that {da broda}. {broda} is here captured as a selbri, with {ke'a} for the sumti that {da} will fill in. In terms of set theory, the values that {da} can take on are universal, but the values that {da poi ke'a broda} can take on are limited by {broda}'s relation's cardinality. Therefore we cannot have a reversible rule for introducing and eliminating {poi} restrictions, only a one-way rule:

          da broda
----------------------------
da poi ke'a brode ku'o broda

We may now define {lo broda} as {da poi ke'a broda} and {lo broda be de} as {da poi ke'a broda de}.

We know the natural numbers, {no}, {pa}, {re}, etc. already. We may define {li no} to refer to zero itself as a sumti, and similarly for the rest of the natural numbers.

We may also say {pa broda} as a sumti to indicate {pa da poi ke'a broda}, and {pa da} to indicate that there exists exactly one value which {da} can take on for all satisfying rows. Since this is a confusing concept, it is worth spelling out in more detail. Recall that relations are many-to-many in their operation. A {pa da} in the result is an assertion that, for each of the many distinct rows that satisfy the relation, {da} will be unchanging in the value that is assigned to it. We do have a one-way weakening rule:

pa da broda
-----------
  da broda

There is also a rule for {no da}, which asserts that zero values are taken on by {da}, which means that no rows match, which means that the relation effectively isn't true. This can be inverted, too.

no da broda
===========
da na broda

We may now define {lo'i broda} as {lo se cmima be lo broda}. We can also define {lo'i pa broda} as {lo se cmima be lo pa broda}, and {lo pa broda} as {pa da poi ke'a broda}. In fact, for all natural numbers, we have an axiom. Let P be some natural number, and then:

lo P broda cmima lo'i P broda

Applying definitions:

P da poi ke'a broda ku'o cmima de poi ke'a se cmima P di poi ke'a broda

Or, in plainer language, if we expect {da} to be bound to P distinct values during the course of our query, then it follows that we will explore a set with cardinality P, whose elements each satisfy {da}'s constraints. This may seem trivial, but it is an important sanity check as well as an indication of the strength of our theory: Every defined set has P elements which each satisfy the set's defining property.

As a special case:

                   lo no broda cmima lo'i no broda
=====================================================================
no da poi ke'a broda ku'o cmima de poi ke'a se cmima no di ke'a broda
=====================================================================
no da poi ke'a broda ku'o cmima de poi ke'a na se cmima di ke'a broda
=====================================================================
da poi ke'a broda ku'o na cmima de poi ke'a na se cmima di ke'a broda
=====================================================================
        lo broda ku na cmima de poi ke'a na se cmima lo broda
        =====================================================
           lo broda ku na cmima lo na se cmima be lo broda

This is a nice double-negation theorem.

We can define {kampu} now. {kampu} relates a {ka} to a set, so that every member of the set can be plugged into the {ka}'s subordinate bridi. More formally, {kampu} relates sets to their membership relations. As a result, after defining {kampu} in terms of {ckaji}:

pa ka ce'u broda ku kampu lo'i brode
====================================
 lo broda ku ckaji pa ka ce'u brode

This looks like an adjunction, doesn't it? We can also define that, as an axiom, {kampu} should relate every membership relation to the set of the members:

pa ka ce'u broda ku kampu lo'i broda

Let's continue on to get a classic tautology of informal Lojban:

pa ka ce'u broda ku kampu lo'i broda
=====================================
  lo broda ku ckaji pa ka ce'u broda
  ==================================
         lo broda ku broda

Note the difference between the earlier axiom that {da brode} -> {lo broda ku brode}, and this axiom that {lo broda ku broda}. The earlier axiom is conditional upon already having established {brode} as a main selbri, while this newer theorem allows us to introduce a restricted query upon any {broda} as a starting point.

We have set membership, one of the two important relations of set theory. The other is the subset relation, {steci}.

-2: Ideas not yet fully cooked

{me} has poset structure according to https://mw.lojban.org/papri/gadri:_an_unofficial_commentary_from_a_logical_point_of_view for each of our sumti. Even better, it interoperates with {du}. {jo'u} is used for unions; the experimental {jo'ei} could be used for intersections.

{mei} and {moi} ought to have clean interpretations once we introduce NNO properly.

{fancu} has been a thorn in my mind for how long now? Let's say that fancu4 is {pa ka}. We might, at first blush, require fancu4 to be functional ("single-valued"). But another route is to let fancu4 bind multiple times, ranging over each of the possible legal functional subrelations. Like, for each subrelation, if it's functional, then bind it.

Building on that, {da poi selcmi zo'u fancu da da pa ka ce'u du ce'u} ought to designate the identity function on any particular set {da}. But there may be many functional subrelations on {da} which are too small to be the identity! In this case, though, it is okay because every element of fancu2 must be accounted for, and so all functional subrelations satisfying this condition will be big enough. We know, then, that there's a nice sandwich that lets {pa ka ce'u du ce'u} do what we want here.

{mintu} is like {du} but generalized to take an equivalence relation for mintu3.

{pamei} can justify {le} for its two sumti. So can {nomei} for its fa sumti. Are there others?

If la tsani contributes a third insight, then they may be entitled to co-author credit.

@MostAwesomeDude
Copy link
Author

Hi! These notes eventually became a living book which can be contributed to here or previewed here.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment