cryptol/docs/ProgrammingCryptol/prims/Primitives.tex
Brian Huffman 030349f6de Fix outdated usage of value-level function width in Cryptol book.
It is now called `length` and has a generalized type.

Cf. #549.
2019-06-20 10:47:40 -07:00

148 lines
5.8 KiB
TeX

\chapter{Cryptol prelude functions}
\commentout{
\begin{code}
primsPlaceHolder=1;
\end{code}
}
\paragraph*{Bitwise and logical operations}
\begin{Verbatim}
True, False : Bit
&&, ||, ^ : {a} (Logic a) => a -> a -> a
~ : {a} (Logic a) => a -> a
==>, /\, \/ : Bit -> Bit -> Bit
\end{Verbatim}
\paragraph*{Comparisons}
\begin{Verbatim}
==, != : {a} (Cmp a) => a -> a -> Bit
<, >, <=, >= : {a} (Cmp a) => a -> a -> Bit
<$, >$, <=$, >=$ : {a} (SignedCmp a) => a -> a -> Bit
min, max : {a} (Cmp a) => a -> a -> a
===, !== : {a, b} (Cmp b) => (a -> b) -> (a -> b) -> a -> Bit
\end{Verbatim}
\paragraph*{Arithmetic}
\begin{Verbatim}
+, -, *, /, %, ^^ : {a} (Arith a) => a -> a -> a
negate, lg2 : {a} (Arith a) => a -> a
fromInteger : {a} (Arith a) => Integer -> a
\end{Verbatim}
\paragraph*{Polynomial arithmetic}
\begin{Verbatim}
pdiv : {u, v} (fin u, fin v) => [u] -> [v] -> [u]
pmod : {u, v} (fin u, fin v) => [u] -> [1 + v] -> [v]
pmult : {u, v} (fin u, fin v) => [1 + u] -> [1 + v] -> [1 + u + v]
\end{Verbatim}
\paragraph*{Sequences}
\begin{Verbatim}
take : {front, back, a} (fin front) => [front + back]a -> [front]a
drop : {front, back, a} (fin front) => [front + back]a -> [back]a
# : {front, back, a} (fin front) => [front]a -> [back]a -> [front + back]a
join : {parts, each, a} (fin each) => [parts][each]a -> [parts * each]a
split : {parts, each, a} (fin each) => [parts * each]a -> [parts][each]a
groupBy : {each, parts, a} (fin each) => [parts * each]a -> [parts][each]a
transpose : {rows, cols, a} [rows][cols]a -> [cols][rows]a
reverse : {n, a} (fin n) => [n]a -> [n]a
head : {n, a} [1 + n]a -> a
tail : {n, a} [1 + n]a -> [n]a
last : {n, a} (fin n) => [1 + n]a -> a
\end{Verbatim}
\paragraph*{Indexing, updates}
\begin{Verbatim}
@ : {n, a, ix} (fin ix) => [n]a -> [ix] -> a
! : {n, a, ix} (fin n, fin ix) => [n]a -> [ix] -> a
@@ : {n, k, ix, a} (fin ix) => [n]a -> [k][ix] -> [k]a
!! : {n, k, ix, a} (fin n, fin ix) => [n]a -> [k][ix] -> [k]a
update : {n, a, ix} (fin ix) => [n]a -> [ix] -> a -> [n]a
updateEnd : {n, a, ix} (fin n, fin ix) => [n]a -> [ix] -> a -> [n]a
updates : {n, k, ix, a} (fin ix, fin k) => [n]a -> [k][ix] -> [k]a -> [n]a
updatesEnd : {n, k, ix, a} (fin n, fin ix, fin k) => [n]a -> [k][ix] -> [k]a -> [n]a
\end{Verbatim}
\paragraph*{Shifting, rotating}
\begin{Verbatim}
>>>, <<< : {n, ix, a} (fin n, fin ix) => [n]a -> [ix] -> [n]a
>>, << : {n, ix, a} (fin ix, Zero a) => [n]a -> [ix] -> [n]a
>>$ : {n, ix} (fin n, n >= 1, fin ix) => [n] -> [ix] -> [n]
\end{Verbatim}
\paragraph*{Functional programming}
\begin{Verbatim}
iterate : {a} (a -> a) -> a -> [inf]a
repeat : {n, a} a -> [n]a
map : {n, a, b} (a -> b) -> [n]a -> [n]b
zip : {n, a, b} [n]a -> [n]b -> [n](a, b)
zipWith : {n, a, b, c} (a -> b -> c) -> [n]a -> [n]b -> [n]c
foldl : {n, a, b} (fin n) => (a -> b -> a) -> a -> [n]b -> a
foldr : {n, a, b} (fin n) => (a -> b -> b) -> b -> [n]a -> b
scanl : {n, b, a} (b -> a -> b) -> b -> [n]a -> [1 + n]b
scanr : {n, a, b} (fin n) => (a -> b -> b) -> b -> [n]a -> [1 + n]b
sum : {n, a} (fin n, Arith a) => [n]a -> a
and, or : {n} (fin n) => [n] -> Bit
all, any : {n, a} (fin n) => (a -> Bit) -> [n]a -> Bit
curry : {a, b, c} ((a, b) -> c) -> a -> b -> c
uncurry : {a, b, c} (a -> b -> c) -> (a, b) -> c
\end{Verbatim}
\paragraph*{Miscellaneous}
\begin{Verbatim}
length : {n, a, b} (fin n, Literal n b) => [n]a -> b
zero : {a} (Zero a) => a
\end{Verbatim}
\paragraph*{Representing exceptions}
\begin{Verbatim}
error : {a, len} (fin len) => [len][8] -> a
undefined : {a} a
trace : {n, a, b} [n][8] -> a -> b -> b
traceVal : {n, a} [n][8] -> a -> a
\end{Verbatim}
\todo[inline]{\texttt{error} and \texttt{undefined} are not covered in
the book at the moment.}
\todo[inline]{What is the state of debugging (\texttt{trace},
\texttt{ASSERT}), randomness (\texttt{random}), and pretty-printing
(\texttt{format}) built-ins?}
%\paragraph*{Debugging}
%\begin{Verbatim}
% trace : {a b c} ([a][8],b,c) -> c
% ASSERT : {a b} (Bit,[a][8],b) -> b
%\end{Verbatim}
%\paragraph*{Generating random numbers}
%\begin{Verbatim}
% random : {a b} (32 >= a) => [a] -> b
%\end{Verbatim}
%\paragraph*{Pretty printing}
%\begin{Verbatim}
% format
%\end{Verbatim}
% (%$) : {a} (Arith a) => a -> a -> a
% (/$) : {a} (Arith a) => a -> a -> a
% number : {val, rep} (Literal val rep) => rep
% elem : {n, a} (fin n, Cmp a) => a -> [n]a -> Bit
% fromThenTo :
% {first, next, last, a, len} (fin first, fin next, fin last,
% Literal first a, Literal next a, Literal last a, first != next,
% lengthFromThenTo first next last == len) =>
% [len]a
% fromTo :
% {first, last, a} (fin last, last >= first, Literal last a) =>
% [1 + (last - first)]a
% fromZ : {n} (fin n, n >= 1) => Z n -> Integer
% infFrom : {a} (Arith a) => a -> [inf]a
% infFromThen : {a} (Arith a) => a -> a -> [inf]a
% splitAt :
% {front, back, a} (fin front) =>
% [front + back]a -> ([front]a, [back]a)
% toInteger : {bits} (fin bits) => [bits] -> Integer
% trace : {n, a, b} (fin n) => [n][8] -> a -> b -> b
% traceVal : {n, a} (fin n) => [n][8] -> a -> a
% undefined : {a} a
% zext : {m, n} (fin m, m >= n) => [n] -> [m]
% sext : {m, n} (fin m, m >= n, n >= 1) => [n] -> [m]
% carry : {n} (fin n) => [n] -> [n] -> Bit
% scarry : {n} (fin n, n >= 1) => [n] -> [n] -> Bit
% sborrow : {n} (fin n, n >= 1) => [n] -> [n] -> Bit
%%% Local Variables:
%%% mode: latex
%%% TeX-master: "../main/Cryptol"
%%% End: