% cbs-katex.sty
%
\newcommand{\STYLE}[2]{\htmlClass{cbs-#1}{#2}}
\newcommand{\DECL}[3]{\htmlId{#1:#2}{#3}}
\newcommand{\REF}[3]{\href{###1:#2}{#3}}
\newcommand{\HYPER}[5]{\href{#1/#2/index.html###3:#4}{#5}}
% \SHADE{MATH} can be defined to produce a shaded background to highlight
% inline MATH in running text:
\newcommand{\SHADE}[1]{#1}
% \KEY{TEXT}, \STRING{TEXT}, \ATOM{TEXT}, \LEX{TEXT} can be used in math mode:
\newcommand{\KEY}[1]{\textsf{\textit{\STYLE{Key}{#1}}}}
\newcommand{\STRING}[1]{\textsf{``\texttt{#1}''}}
\newcommand{\ATOM}[1]{\textsf{`\texttt{#1}'}}
\newcommand{\LEX}[1]{\textsf{\STYLE{Key}{`}\texttt{#1}\STYLE{Key}{'}}}
% The following commands produce ASCII characters that are treated specially by LaTeX:
\newcommand{\HASH}{\char`\#}
\newcommand{\DOLLAR}{\char`\$}
\newcommand{\PERCENT}{\char`\%}
\newcommand{\AMPERSAND}{\char`\&}
\newcommand{\APOSTROPHE}{\char`\'}
\newcommand{\BACKSLASH}{\char`\\}
\newcommand{\CARET}{\char`\^}
\newcommand{\UNDERSCORE}{\char`\_}
\newcommand{\GRAVE}{\char`\`}
\newcommand{\LEFTBRACE}{\char`\{}
\newcommand{\RIGHTBRACE}{\char`\}}
\newcommand{\TILDE}{\textasciitilde} % {\char`\~}
% \NAME{name} highlights the name;
% \NAMEDECL{name} declares Name.name as the target of links to name;
% \NAMEREF{name} links name to the target Name.name in the current file;
% \NAMEHYPER{url}{file}{name} links name to Name.name at url/file/file.pdf.
% Similarly for \VAR{partvariable}, \SYN{syntaxname}, \SEM{semanticsName},
% and \SECT{sectionnumber}
% The kerns in \SUB and \VAR avoid overlaps with primes:
\newcommand{\SUB}[1]{_{\kern-2mu\STYLE{PartVariable}{\textsf{#1}}}}
% PLAIN
\newcommand{\VAR}[1]{\STYLE{PartVariable}{\textsf{\textit{#1}\kern2mu}}}
\newcommand{\NAME}[1]{\STYLE{Name}{\textsf{#1}}}
\newcommand{\SYN}[1]{\STYLE{SyntaxName}{\textsf{#1}}}
\newcommand{\SEM}[1]{\STYLE{SemanticsName}{\textsf{#1}}}
\newcommand{\SECT}[1]{\STYLE{SectionNumber}{\textsf{#1}}}
% DECL
\newcommand{\VARDECL}[1]{\DECL{PartVariable}{#1}{\VAR{#1}}}
\newcommand{\NAMEDECL}[1]{\DECL{Name}{#1}{\NAME{#1}}}
\newcommand{\SYNDECL}[1]{\DECL{SyntaxName}{#1}{\SYN{#1}}}
\newcommand{\SEMDECL}[1]{\DECL{SemanticsName}{#1}{\SEM{#1}}}
\newcommand{\SECTDECL}[1]{\DECL{SectionNumber}{#1}{\textsf{#1}}}
% REF
\newcommand{\VARREF}[1]{\REF{PartVariable}{#1}{\VAR{#1}}}
\newcommand{\NAMEREF}[1]{\REF{Name}{#1}{\NAME{#1}}}
\newcommand{\SYNREF}[1]{\REF{SyntaxName}{#1}{\SYN{#1}}}
\newcommand{\SEMREF}[1]{\REF{SemanticsName}{#1}{\SEM{#1}}}
\newcommand{\SECTREF}[1]{\REF{SectionNumber}{#1}{\SECT{#1}}}
% HYPER
\newcommand{\VARHYPER}[3]{\HYPER{#1}{#2}{PartVariable}{#3}{\VAR{#3}}}
\newcommand{\NAMEHYPER}[3]{\HYPER{#1}{#2}{Name}{#3}{\NAME{#3}}}
\newcommand{\SYNHYPER}[3]{\HYPER{#1}{#2}{SyntaxName}{#3}{\SYN{#3}}}
\newcommand{\SEMHYPER}[3]{\HYPER{#1}{#2}{SemanticsName}{#3}{\SEM{#3}}}
\newcommand{\SECTHYPER}[3]{\HYPER{#1}{#2}{SectionNumber}{#3}{\SECT{#3}}}
% \LEFTPHRASE MATH \RIGHTPHRASE produces [[ MATH ]] with proper brackets:
\newcommand{\LEFTPHRASE}{\llbracket}
\newcommand{\RIGHTPHRASE}{\rrbracket}
% \LEFTGROUP MATH \RIGHTGROUP produces ( MATH ) where the parentheses are
% highlighted the same as keywords:
\newcommand{\LEFTGROUP}{\STYLE{Key}{(}}
\newcommand{\RIGHTGROUP}{\STYLE{Key}{)}}
% MATH\PLUS produces a superscript +
% MATH\STAR produces a superscript *
% MATH\QUERY produces a superscript ?
\newcommand{\PLUS}{{}^{\texttt{+}}}
\newcommand{\STAR}{{}^{\texttt{*}}}
\newcommand{\QUERY}{{}^{\texttt{?}}}
% \RULE{& PREMISE \\ & ...}{& FORMULA ... \\ & ...} produces an inference rule
% with separately aligned premises and conclusion
% PREMISE
% ...
% -----------
% FORMULA ...
% ...
\newcommand{\RULE}[2]
{\frac{\begin{aligned}#1\end{aligned}}{\begin{aligned}#2\end{aligned}}}
% \AXIOM{& FORMULA ... \\ & ...} produces an aligned formula
%
% FORMULA ...
% ...
\newcommand{\AXIOM}[1]{\begin{aligned}#1\end{aligned}}
% \TO TYPE produces => TYPE
\newcommand{\TO}{\mathop{\Rightarrow}}
% TERM \TRANS TERM produces TERM ---> TERM
\newcommand{\TRANS}{\longrightarrow}
% TERM \xrightarrow{LABEL} TERM puts the label above the long arrow
%
Funcons-beta : Functions.cbs | PLAIN | PDF
Functions
[ Datatype functions Funcon function Funcon apply Funcon supply Funcon compose Funcon uncurry Funcon curry Funcon partial-apply ] \begin{align*}
[ \
\KEY{Datatype} \quad & \NAMEREF{functions} \\
\KEY{Funcon} \quad & \NAMEREF{function} \\
\KEY{Funcon} \quad & \NAMEREF{apply} \\
\KEY{Funcon} \quad & \NAMEREF{supply} \\
\KEY{Funcon} \quad & \NAMEREF{compose} \\
\KEY{Funcon} \quad & \NAMEREF{uncurry} \\
\KEY{Funcon} \quad & \NAMEREF{curry} \\
\KEY{Funcon} \quad & \NAMEREF{partial-apply}
\ ]
\end{align*} [ Datatype Funcon Funcon Funcon Funcon Funcon Funcon Funcon functions function apply supply compose uncurry curry partial-apply ]
Meta-variables T , T ′ , T 1 , T 2 < : values \begin{align*}
\KEY{Meta-variables} \quad
& \VAR{T}, \VAR{T}', \VAR{T}\SUB{1}, \VAR{T}\SUB{2} <: \NAMEHYPER{../..}{Value-Types}{values}
\end{align*} Meta-variables T , T ′ , T 1 , T 2 <: values
Datatype functions ( T , T ′ ) : : = function ( A : abstractions ( T ⇒ T ′ ) ) \begin{align*}
\KEY{Datatype} \quad
\NAMEDECL{functions}(
\VAR{T} , \VAR{T}' )
\ ::= \ & \NAMEDECL{function}(
\VAR{A} : \NAMEHYPER{../.}{Generic}{abstractions}
( \VAR{T} \TO \VAR{T}' ))
\end{align*} Datatype functions ( T , T ′ ) ::= function ( A : abstractions ( T ⇒ T ′ ))
functions ( T , T ′ ) \SHADE{\NAMEREF{functions}
( \VAR{T},
\VAR{T}' )} functions ( T , T ′ ) consists of abstractions whose bodies may depend on
a given value of type T \SHADE{\VAR{T}} T , and whose executions normally compute values
of type T ′ \SHADE{\VAR{T}'} T ′ .
function ( abstraction ( X ) ) \SHADE{\NAMEREF{function}
( \NAMEHYPER{../.}{Generic}{abstraction}
( \VAR{X} ) )} function ( abstraction ( X )) evaluates to a function with dynamic bindings,
function ( closure ( X ) ) \SHADE{\NAMEREF{function}
( \NAMEHYPER{../.}{Generic}{closure}
( \VAR{X} ) )} function ( closure ( X )) computes a function with static bindings.
Funcon apply ( _ : functions ( T , T ′ ) , _ : T ) : ⇒ T ′ \begin{align*}
\KEY{Funcon} \quad
& \NAMEDECL{apply}(
\_ : \NAMEREF{functions}
( \VAR{T},
\VAR{T}' ), \_ : \VAR{T})
: \TO \VAR{T}'
\end{align*} Funcon apply ( _ : functions ( T , T ′ ) , _ : T ) : ⇒ T ′
apply ( F , V ) \SHADE{\NAMEREF{apply}
( \VAR{F},
\VAR{V} )} apply ( F , V ) applies the function F \SHADE{\VAR{F}} F to the argument value V \SHADE{\VAR{V}} V .
This corresponds to call by value; using thunks as argument values
corresponds to call by name. Moreover, using tuples as argument values
corresponds to application to multiple arguments.
Rule apply ( function ( abstraction ( X ) ) , V : T ) ⇝ give ( V , X ) \begin{align*}
\KEY{Rule} \quad
& \NAMEREF{apply}
( \NAMEREF{function}
( \NAMEHYPER{../.}{Generic}{abstraction}
( \VAR{X} ) ),
\VAR{V} : \VAR{T} ) \leadsto
\NAMEHYPER{../../../Computations/Normal}{Giving}{give}
( \VAR{V},
\VAR{X} )
\end{align*} Rule apply ( function ( abstraction ( X )) , V : T ) ⇝ give ( V , X )
Funcon supply ( _ : functions ( T , T ′ ) , _ : T ) : ⇒ thunks ( T ′ ) \begin{align*}
\KEY{Funcon} \quad
& \NAMEDECL{supply}(
\_ : \NAMEREF{functions}
( \VAR{T},
\VAR{T}' ), \_ : \VAR{T})
: \TO \NAMEHYPER{../.}{Thunks}{thunks}
( \VAR{T}' )
\end{align*} Funcon supply ( _ : functions ( T , T ′ ) , _ : T ) : ⇒ thunks ( T ′ )
supply ( F , V ) \SHADE{\NAMEREF{supply}
( \VAR{F},
\VAR{V} )} supply ( F , V ) determines the argument value of a function application,
but returns a thunk that defers executing the body of the function.
Rule supply ( function ( abstraction ( X ) ) , V : T ) ⇝ thunk ( abstraction ( give ( V , X ) ) ) \begin{align*}
\KEY{Rule} \quad
& \NAMEREF{supply}
( \NAMEREF{function}
( \NAMEHYPER{../.}{Generic}{abstraction}
( \VAR{X} ) ),
\VAR{V} : \VAR{T} ) \leadsto
\NAMEHYPER{../.}{Thunks}{thunk}
( \NAMEHYPER{../.}{Generic}{abstraction}
( \NAMEHYPER{../../../Computations/Normal}{Giving}{give}
( \VAR{V},
\VAR{X} ) ) )
\end{align*} Rule supply ( function ( abstraction ( X )) , V : T ) ⇝ thunk ( abstraction ( give ( V , X )))
Funcon compose ( _ : functions ( T 2 , T ′ ) , _ : functions ( T 1 , T 2 ) ) : ⇒ functions ( T 1 , T ′ ) \begin{align*}
\KEY{Funcon} \quad
& \NAMEDECL{compose}(
\_ : \NAMEREF{functions}
( \VAR{T}\SUB{2},
\VAR{T}' ), \_ : \NAMEREF{functions}
( \VAR{T}\SUB{1},
\VAR{T}\SUB{2} ))
: \TO \NAMEREF{functions}
( \VAR{T}\SUB{1},
\VAR{T}' )
\end{align*} Funcon compose ( _ : functions ( T 2 , T ′ ) , _ : functions ( T 1 , T 2 )) : ⇒ functions ( T 1 , T ′ )
compose ( F 2 , F 1 ) \SHADE{\NAMEREF{compose}
( \VAR{F}\SUB{2},
\VAR{F}\SUB{1} )} compose ( F 2 , F 1 ) returns the function that applies F 1 \SHADE{\VAR{F}\SUB{1}} F 1 to its argument,
then applies F 2 \SHADE{\VAR{F}\SUB{2}} F 2 to the result of F 1 \SHADE{\VAR{F}\SUB{1}} F 1 .
Rule compose ( function ( abstraction ( Y ) ) , function ( abstraction ( X ) ) ) ⇝ function ( abstraction ( give ( X , Y ) ) ) \begin{align*}
\KEY{Rule} \quad
& \NAMEREF{compose}
( \NAMEREF{function}
( \NAMEHYPER{../.}{Generic}{abstraction}
( \VAR{Y} ) ),
\NAMEREF{function}
( \NAMEHYPER{../.}{Generic}{abstraction}
( \VAR{X} ) ) ) \leadsto \\&\quad
\NAMEREF{function}
( \NAMEHYPER{../.}{Generic}{abstraction}
( \NAMEHYPER{../../../Computations/Normal}{Giving}{give}
( \VAR{X},
\VAR{Y} ) ) )
\end{align*} Rule compose ( function ( abstraction ( Y )) , function ( abstraction ( X ))) ⇝ function ( abstraction ( give ( X , Y )))
Funcon uncurry ( F : functions ( T 1 , functions ( T 2 , T ′ ) ) ) : ⇒ functions ( tuples ( T 1 , T 2 ) , T ′ ) ⇝ function ( abstraction ( apply ( apply ( F , checked index ( 1 , tuple-elements given ) ) , checked index ( 2 , tuple-elements given ) ) ) ) \begin{align*}
\KEY{Funcon} \quad
& \NAMEDECL{uncurry}(
\VAR{F} : \NAMEREF{functions}
( \VAR{T}\SUB{1},
\NAMEREF{functions}
( \VAR{T}\SUB{2},
\VAR{T}' ) )) \\&\quad
: \TO \NAMEREF{functions}
( \NAMEHYPER{../../Composite}{Tuples}{tuples}
( \VAR{T}\SUB{1},
\VAR{T}\SUB{2} ),
\VAR{T}' ) \\&\quad
\leadsto \NAMEREF{function}
( \\&\quad\quad\quad\quad \NAMEHYPER{../.}{Generic}{abstraction}
( \\&\quad\quad\quad\quad\quad \NAMEREF{apply}
( \\&\quad\quad\quad\quad\quad\quad \NAMEREF{apply}
( \VAR{F},
\NAMEHYPER{../../../Computations/Abnormal}{Failing}{checked} \
\NAMEHYPER{../../Composite}{Sequences}{index}
( 1,
\NAMEHYPER{../../Composite}{Tuples}{tuple-elements} \
\NAMEHYPER{../../../Computations/Normal}{Giving}{given} ) ), \\&\quad\quad\quad\quad\quad\quad
\NAMEHYPER{../../../Computations/Abnormal}{Failing}{checked} \
\NAMEHYPER{../../Composite}{Sequences}{index}
( 2,
\NAMEHYPER{../../Composite}{Tuples}{tuple-elements} \
\NAMEHYPER{../../../Computations/Normal}{Giving}{given} ) ) ) )
\end{align*} Funcon uncurry ( F : functions ( T 1 , functions ( T 2 , T ′ ))) : ⇒ functions ( tuples ( T 1 , T 2 ) , T ′ ) ⇝ function ( abstraction ( apply ( apply ( F , checked index ( 1 , tuple-elements given )) , checked index ( 2 , tuple-elements given ))))
uncurry ( F ) \SHADE{\NAMEREF{uncurry}
( \VAR{F} )} uncurry ( F ) takes a curried function F \SHADE{\VAR{F}} F and returns a function that takes
a pair of arguments..
Funcon curry ( F : functions ( tuples ( T 1 , T 2 ) , T ′ ) ) : ⇒ functions ( T 1 , functions ( T 2 , T ′ ) ) ⇝ function ( abstraction ( partial-apply ( F , given ) ) ) \begin{align*}
\KEY{Funcon} \quad
& \NAMEDECL{curry}(
\VAR{F} : \NAMEREF{functions}
( \NAMEHYPER{../../Composite}{Tuples}{tuples}
( \VAR{T}\SUB{1},
\VAR{T}\SUB{2} ),
\VAR{T}' ))
: \TO \NAMEREF{functions}
( \VAR{T}\SUB{1},
\NAMEREF{functions}
( \VAR{T}\SUB{2},
\VAR{T}' ) ) \\&\quad
\leadsto \NAMEREF{function}
( \NAMEHYPER{../.}{Generic}{abstraction}
( \NAMEREF{partial-apply}
( \VAR{F},
\NAMEHYPER{../../../Computations/Normal}{Giving}{given} ) ) )
\end{align*} Funcon curry ( F : functions ( tuples ( T 1 , T 2 ) , T ′ )) : ⇒ functions ( T 1 , functions ( T 2 , T ′ )) ⇝ function ( abstraction ( partial-apply ( F , given )))
curry ( F ) \SHADE{\NAMEREF{curry}
( \VAR{F} )} curry ( F ) takes a function F \SHADE{\VAR{F}} F that takes a pair of arguments, and returns
the corresponding ‘curried’ function.
Funcon partial-apply ( F : functions ( tuples ( T 1 , T 2 ) , T ′ ) , V : T 1 ) : ⇒ functions ( T 2 , T ′ ) ⇝ function ( abstraction ( apply ( F , tuple ( V , given ) ) ) ) \begin{align*}
\KEY{Funcon} \quad
& \NAMEDECL{partial-apply}(
\VAR{F} : \NAMEREF{functions}
( \NAMEHYPER{../../Composite}{Tuples}{tuples}
( \VAR{T}\SUB{1},
\VAR{T}\SUB{2} ),
\VAR{T}' ), \VAR{V} : \VAR{T}\SUB{1})
: \TO \NAMEREF{functions}
( \VAR{T}\SUB{2},
\VAR{T}' ) \\&\quad
\leadsto \NAMEREF{function}
( \NAMEHYPER{../.}{Generic}{abstraction}
( \NAMEREF{apply}
( \VAR{F},
\NAMEHYPER{../../Composite}{Tuples}{tuple}
( \VAR{V},
\NAMEHYPER{../../../Computations/Normal}{Giving}{given} ) ) ) )
\end{align*} Funcon partial-apply ( F : functions ( tuples ( T 1 , T 2 ) , T ′ ) , V : T 1 ) : ⇒ functions ( T 2 , T ′ ) ⇝ function ( abstraction ( apply ( F , tuple ( V , given ))))
partial-apply ( F , V ) \SHADE{\NAMEREF{partial-apply}
( \VAR{F},
\VAR{V} )} partial-apply ( F , V ) takes a function F \SHADE{\VAR{F}} F that takes a pair of arguments,
and determines the first argument, returning a function of the second
argument.
←
↑
→