Warning: this is an htmlized version!
The original is across this link,
and the conversion rules are here.
% (find-angg "LATEX/2008typesystems.tex")
% (find-dn4ex "edrx08.sty")
% (find-angg ".emacs.templates" "s2008a")
% (defun c () (interactive) (find-zsh "cd ~/LATEX/ && ~/dednat4/dednat41 2008typesystems.tex && latex    2008typesystems.tex"))
% (defun c () (interactive) (find-zsh "cd ~/LATEX/ && ~/dednat4/dednat41 2008typesystems.tex && pdflatex 2008typesystems.tex"))
% (eev "cd ~/LATEX/ && Scp 2008typesystems.{dvi,pdf} edrx@angg.twu.net:slow_html/LATEX/")
% (find-dvipage "~/LATEX/2008typesystems.dvi")
% (find-pspage  "~/LATEX/2008typesystems.pdf")
% (find-zsh0 "cd ~/LATEX/ && dvips -D 300 -o 2008typesystems.ps 2008typesystems.dvi")
% (find-pspage  "~/LATEX/2008typesystems.ps")
% (find-zsh0 "cd ~/LATEX/ && dvips -D 300 -o tmp.ps tmp.dvi")
% (find-pspage  "~/LATEX/tmp.ps")

% TODO: borrow more from:
% (find-LATEX    "2002fmcs.tex")
% (find-LATEXdvi "2002fmcs.dvi")


% «.intro-to-bhk»		(to "intro-to-bhk")
% «.witnesses-vs-proofs»	(to "witnesses-vs-proofs")
% «.intro-to-ptss»		(to "intro-to-ptss")
% «.notation-space-of»		(to "notation-space-of")
% «.dependent-types»		(to "dependent-types")
% «.spaces-of-witnesses-set»	(to "spaces-of-witnesses-set")
% «.typing-categories-1»	(to "typing-categories-1")
% «.typing-categories-2»	(to "typing-categories-2")
% «.typing-categories-3»	(to "typing-categories-3")


\documentclass[oneside]{book}
\usepackage[latin1]{inputenc}
\usepackage{edrx08}       % (find-dn4ex "edrx08.sty")
%L process "edrx08.sty"  -- (find-dn4ex "edrx08.sty")
\input edrxheadfoot.tex   % (find-dn4ex "edrxheadfoot.tex")
\begin{document}

\input 2008typesystems.dnt

%*
% (eedn4-51-bounded)

Index of the slides:
\msk
% To update the list of slides uncomment this line:
\makelos{tmp.los}
% then rerun LaTeX on this file, and insert the contents of "tmp.los"
% below, by hand (i.e., with "insert-file"):
% (find-fline "tmp.los")
% (insert-file "tmp.los")
\tocline {Introduction to BHK} {2}
\tocline {Spaces of witnesses as spaces of proofs, collapsed} {3}
\tocline {Pure Type Systems} {4}
\tocline {Notation (temporary) for ``the space of''} {5}
\tocline {Dependent types} {6}
\tocline {Spaces of witnesses in Set} {7}
\tocline {Typing categories (1)} {8}
\tocline {Typing categories (2)} {9}
\tocline {Typing categories (3)} {10}

\setlength{\parindent}{0em}

\newpage
% --------------------
% «intro-to-bhk»  (to ".intro-to-bhk")
% (s "Introduction to BHK" "intro-to-bhk")
\myslide {Introduction to BHK} {intro-to-bhk}

{\myttchars
\footnotesize
\begin{verbatim}
Suppose that for atomic propositions P, Q, R(4,2), etc,
we know how to characterize what constitutes a ``proof''
of P, Q, R(4,2), etc.

Write W[P] for the ``space of proofs of P'',
W[R(4,2)] for the ``space of proofs of R(4,2)'',
and so on.

The BHK (Brouwer-Heyting-Kolmogorov) interpretation
tells us how to build the ``spaces of (constructive)
proofs'' for all (bigger) formulas whose atomic
formulas are just P, Q, R(4,2), etc... the rules are:

  W[P&Q] := W[P]×W[Q]
  W[P⊃Q] := W[P]->W[Q]
  W[P∨Q] := {0}×W[P]  {1}×W[Q]
    W[] := {*}
    W[] := \emptyset
  W[aA.P(a)] := åaA.W[P(a)]
  W[aA.P(a)] := ÆaA.W[P(a)]

Note that this is different from just saying that
``the space of witnesses of P is a singleton when
P is true, and the empty set when P is false'' -
because W[∨] = {(0,*),(1,*)}
and W[n\N.] = {(0,*),(1,*),(2,*),...} -
`∨' and `' take us out of the realm of sets
of size 0/1.
\end{verbatim}
}


\newpage
% --------------------
% «witnesses-vs-proofs»  (to ".witnesses-vs-proofs")
% (s "Spaces of witnesses as spaces of proofs, collapsed" "witnesses-vs-proofs")
\myslide {Spaces of witnesses as spaces of proofs, collapsed} {witnesses-vs-proofs}

{\myttchars
\footnotesize
\begin{verbatim}
Our (archetypical) space of truth-values:
   = {0, 1} = {{}, {*}}
A ``space of witnesses'' for us is a set
that is ``at most a singleton'' (size=0/1).

  a:A:     A is a set, a is an element of A
  P:Ï[P]:  Ï[P] is a space of witnesses,
            P is a witness for the proposition P.

Interpreting BHK categorically is hard, and uncommon
(see Palmgren 2002; it refers to Makkai/Reyes 1977).
Interpreting propositions using this 
(like BHK, but collapsing the spaces of proofs into
sets that are ``at most singletons'') is easy,
and that's what we will do.

In BHK we start from W[P], W[Q], W[R(4,2)], ...
and we build all the spaces of proofs for propostions
whose atomic propositions are just these.

Here we will also start from spaces of witnesses
for the atomic propositions, and build all other
spaces of witnesses from them.

In the archetypical model - Set - these spaces of
witnesses will be exactly what we expect
(classical logic).

In some toposes the logic will be intuitionistic,
not classical - for example, we may have
Ï[P] \subsetneq Ï[P].
\end{verbatim}
}



\newpage
% --------------------
% «intro-to-ptss»  (to ".intro-to-ptss")
% (s "Pure Type Systems" "intro-to-ptss")
\myslide {Pure Type Systems} {intro-to-ptss}

{\myttchars
\footnotesize
\begin{verbatim}
PTSs generalize the type system for -calculus
that we've seen (``1'') and other systems that
we will see.

We have supposed that we knew sets A, B, C
to derive:

    b|->c
  =========
  a,b|->a,c

In a PTS we don't have any constants besides the
``sorts'', that typically are ::ñ, whose intended
semantics are, VERY roughly:

  ñ   (the class of all) classes
     (the class of all) sets
     the set of truth-values
      ( has two elements, ``true'' and ``false'')

Constants - like:

  A,B,C:
  \R:
  +:\R×\R->\R
  assoc:Ï[x,y,z:\R.(x+y)+z=x+(y+z)]:

can be added later, as ``impurities''.

The idea is that Pure Type Systems are flexible enough
to let us declare the constants that we need as
variables in the beginning of a context.

In a PTS we can derive:

  A:,B:,C:,f:(B->C) |- (p:A×B.<p,f('p)>):A×B->A×C

which, in DNC notation, shrinks to:

  A,B,C,(b|->c)|-(a,b|->a,c)
\end{verbatim}
}


\newpage
% --------------------
% «notation-space-of»  (to ".notation-space-of")
% (s "Notation (temporary) for ``the space of''" "notation-space-of")
\myslide {Notation (temporary) for ``the space of''} {notation-space-of}

{\myttchars
\footnotesize
\begin{verbatim}
  {a,b|P(a,b)}          {a,b|P(a,b)}
       v                     v
       |       becomes:      |
       v                     v
      A×B                  {a,b}

We will write ``{a,b}'' for A×B.
``{a,b}'' will stand for ``the set of all
possible values for (a,b)''.

Note that this conflicts with the
set-theoretical usage - ``the set with
two elements, a and b''...

(I used to use \E[a,b] for {a,b}, but
many people felt that that was too weird...)

The same notation - {a,b} - will also work
for ``dependent types'' (next slides), where
a:A,b:B_a, and B_a depends on a...
\end{verbatim}
}


\newpage
% --------------------
% «dependent-types»  (to ".dependent-types")
% (s "Dependent types" "dependent-types")
\myslide {Dependent types} {dependent-types}

{\myttchars
\footnotesize
\begin{verbatim}
Suppose that we have:

  A              a set: the space of `a's
  (B_a)_{a:A}    a family of sets/spaces (of `b's)
  (C_a)_{a:A}    another family of sets
  (D_abc)_{(a,b,c):\{a,b,c\}}  another family

Note that

  {a:A,b:B_a,c:C_a} ----> {a:A,c:C_a}
          |     __|            |
          |                    |
          v                    v
     {a:A,b:B_a} ----------> {a:A}

is a pullback.

Alternative notations:

  {a,b,c} ----> {a,c}     a,b,c |----> a,c
     | __|        |         -  __|      -  
     |            |         |           |  
     v            v         v           v  
   {a,b} ------> {a}       a,b |------> a 

Maps (between ``contexts'') that just drop
the last variable - all but the top one in
the squares above - are called ``one-step
projections''.

What are ``generalized projections''?
We will see that later...
\end{verbatim}
}



\newpage
% --------------------
% «spaces-of-witnesses-set»  (to ".spaces-of-witnesses-set")
% (s "Spaces of witnesses in Set" "spaces-of-witnesses-set")
\myslide {Spaces of witnesses in Set} {spaces-of-witnesses-set}

{\myttchars
\footnotesize
\begin{verbatim}
More families:

  (\P_ab)_{(a,b):\{a,b\}}      a family of spaces of witnesses,
  (\Q_a)_{a:A}                 another,
  (\R_ab)_{(a,b):\{a,b\}}      another.

We can use spaces of witnesses to represent propositions:
a proposition is false when its space of witnesses is empty,
true when it is non-empty.


  {a,b||P(a,b)} |---> {a||b.P(a,b)}
  {a,b||R(a,b)} |---> {a||b.R(a,b)}
\end{verbatim}
}



\newpage
% --------------------
% «typing-categories-1»  (to ".typing-categories-1")
% (s "Typing categories (1)" "typing-categories-1")
\myslide {Typing categories (1)} {typing-categories-1}

{\myttchars
\footnotesize
\begin{verbatim}
A category is a 7-uple,

  (Objs, Hom, id, , idL, idR, assoc)

where the first four components are ``structure''
and the last three are ``properties''.

They can by typed like this:
(this looks indirect, but can be formalized...
note that this is a locally small category -
its hom-sets are sets, not classes)

  |-Objs:ñ
  A:Objs,B:Objs|-Hom(A,B):
  A:Objs|-id_A:Hom(A,A)
  A:Objs,B:Objs,C:Objs,f:Hom(A,B),g:Hom(B,C)
    |-(gf):Hom(A,C)

  A:Objs,B:Objs,f:Hom(A,B)|-idL_f:W[fid_A=f]
  A:Objs,B:Objs,f:Hom(A,B)|-idR_f:W[id_Bf=f]
  A:Objs,B:Objs,C:Objs,D:Objs,
    f:Hom(A,B),g:Hom(B,C),h:Hom(C,D)
    |-assoc(f,g,h):W[h(gf)=(hg)f]

We are using some shorthands...
The constants that we are declaring are actually
Objs,(Hom),(id),(),(idL),(idR),assoc:

  Hom(A,B) := (Hom) A B
  id_A     := (id) A
  (gf)    := () A B C f g
  idL_f    := (idL) A B f
  idR_f    := (idR) A B f
  assoc(f,g,h) := (assoc) A B C D f g h

and we are using ``identity types'':

  X:,x:X,x':X|-W[x=x']:
      W[x=x'] := Eq X x x'

and we should imagine that we also have terms that
assert that this ``equality'' is reflexive, symmetric,
transitive, and stable by substitutions - but these
terms will not be used in the spefication of the
typing of a category.
\end{verbatim}
}


\newpage
% --------------------
% «typing-categories-2»  (to ".typing-categories-2")
% (s "Typing categories (2)" "typing-categories-2")
\myslide {Typing categories (2)} {typing-categories-2}

{\myttchars
\footnotesize
\begin{verbatim}
Let's make this typing less indirect.
Instead of:

  |-Objs:ñ
  A:Objs,B:Objs|-(Hom)AB:
  A:Objs|-(id)A:(Hom)AA
  A:Objs,B:Objs,C:Objs,f:(Hom)AB,g:(Hom)BC
    |-()ABCfg:(Hom)AC

This:

  |-Objs:ñ
  |-(Hom):(åA:Objs.åB:Objs.)
  |-(id):(åA:Objs.(Hom)AA)
  |-():(åA:Objs.åB:Objs.åC:Objs.
         åf:(Hom)AB.åg:(Hom)BC.(Hom)AC)

The exact typing of (Hom), (id), (), etc is immaterial -
for example, (Hom) can be either :(Objs->(Objs->)) or
:(Objs×Objs->), it doesn't matter.

Problems:
(1) The domains of these functions are too big.
(2) We need dependent types. 
Let's examine one particular case: \Set.

  |-:ñ
  |-(A:.B:.A->B):(åA:.åB:.)
  |-(A:.a:A.a):(åA:.(A:.B:.A->B)AA)

rewriting:

  |-:ñ
  |-(A:.B:.A->B):(->(->))
  |-(A:.a:A.a):(åA:.A->A)

Some domains of functions are  - a class, not a set -
and, in (id) - the ``polymorphic identity'' -
the space where a:A.a lives - A->A - depends on A... 
\end{verbatim}
}


\newpage
% --------------------
% «typing-categories-3»  (to ".typing-categories-3")
% (s "Typing categories (3)" "typing-categories-3")
\myslide {Typing categories (3)} {typing-categories-3}

{\myttchars
\footnotesize
\begin{verbatim}
Some of these terms can only be declared after others have
been declared: (Hom) after Objs, (id) and () after Hom...

``Earlier'' terms and variables appear higher at
derivation trees than ``later'' terms and variables...
Here's a diagram showing the dependencies:

        Objs
          |
         Hom   
        /   \
      id     
       |    / \
     idL,idR   assoc

It is possible to build the ``space of all categories'',
but it will depend on the order that we will choose for
the components - and then we would define Objs, Hom, etc,
as certain components of these 7-uples...

  (Objs,Hom,id,,idL,idR,assoc):(Æ_.Æ_.Æ_.Æ_.Æ_.Æ_._)
  (Objs,Hom,,id,assoc,idL,idR):(Æ_.Æ_.Æ_.Æ_.Æ_.Æ_._)

(Actually the first `Æ' - ÆObjs:ñ._ - is problematic, as
it would require a sort above ñ - but this is not
important now)
\end{verbatim}
}




% Add:
% Propositions as dependent types
%   Ï[P].P satisfiable
%   Ï[P].P⊃P tautology
%              (and theorem)
%
% Blob diagram
% (find-es "tex" "ovals")

% Doctrinal diagram
% Smashing operator

% PTSs with minimal contexts

% Category of contexts

% Projections form a preorder
% Products are pullbacks
% What are the conditions on sections?
%   They can only be added after their
%   inverses; they must commute with what?
% An a|->a,b says that a,b has as much information as a.
% Comparison with quotients (on HAs) and equations (a<->a,b)

% Display maps
% Projections, generalized projections, proper projections,
% one step projections; unit types; the formal way to see
% variables

% Diagram for a,b`->a,b,b',(b=b')
% A magic rule says that this is not just a section
% LCCCs

%*

\end{document}

% Local Variables:
% coding:           raw-text-unix
% ee-anchor-format: "«%s»"
% End: