This document is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
The copyright holder grants you permission to redistribute this
document freely as a verbatim copy. Furthermore, the copyright
holder permits you to develop any derived work from this document
provided that the following conditions are met.
a) The derived work acknowledges the fact that it is derived from
this document, and maintains a prominent reference in the
work to the original source.
b) The fact that the derived work is not the original OpenMath
document is stated prominently in the derived work. Moreover if
both this document and the derived work are Content Dictionaries
then the derived work must include a different CDName element,
chosen so that it cannot be confused with any works adopted by
the OpenMath Society. In particular, if there is a Content
Dictionary Group whose name is, for example, `math' containing
Content Dictionaries named `math1', `math2' etc., then you should
not name a derived Content Dictionary `mathN' where N is an integer.
However you are free to name it `private_mathN' or some such. This
is because the names `mathN' may be used by the OpenMath Society
for future extensions.
c) The derived work is distributed under terms that allow the
compilation of derived works, but keep paragraphs a) and b)
intact. The simplest way to do this is to distribute the derived
work under the OpenMath license, but this is not a requirement.
If you have questions about this license please contact the OpenMath
society at http://www.openmath.org.
ecc
http://www.openmath.org/cd
http://http://www.openmath.org/cd/ecc.ocd
2006-03-30
experimental
2004-03-30
2
0
Extended Calculus of Constructions Primitives
Initial version: O. Caprotti (July 1, 1999)
Revised: O. Caprotti (September 8, 1999)
type
semantic-attribution
Attribution tag to denote type-judgement
typecoerce
semantic-attribution
Attribution tag to denote type-judgement with coercion
SigmaType
binder
The binder symbol used to construct the
type of Cartesian products. The (either plain or attributed)
variables might occur in the body \OM\ object.
Pair
application
The pairing constructor. It takes two
OpenMath objects as first element and second
element of the pair, and a third optional
OpenMath object that represents the type of
the pair.
0
1
PairProj1
application
The first projection function that extracts the first
component of a Pair. It satisfies the sigma-reduction rule.
0
1
0
PairProj2
application
The second projection function that extracts the second
component of a Pair. It satisfies sigma-reduction rule.
0
1
1
Tuple
application
The n-ary tupling constructor when n>2. The
arguments are the element of the tuple. Tuple objects can also
be constructed by successive nesting of Pair.
0
1
2
0
1
2