-
Notifications
You must be signed in to change notification settings - Fork 236
Different types of equality in F*
Kenji Maillard edited this page Jul 4, 2017
·
12 revisions
F* has 3 different types of equality:
val (=) : #a:Type{hasEq a} -> a -> a -> Tot bool
val (==) : #a:Type -> a -> a -> Tot Type0
val (===): #a:Type -> #b:Type -> a -> b -> Tot Type0
Here is what each of them means:
-
=
is boolean equality that is automatically generated by F* for many types with decidable equality; such types satisfy thehasEq
predicate. -
==
is homogeneous propositional equality, and is defined for all F* types, even the ones withouthasEq
(==
is defined inprims.fst
as a squashed inductive) -
===
is heterogeneous propositional equality; this more exotic equality is sometimes called "John Major equality" (===
is defined inprims.fst
as a squashed inductive)
Corresponding to the equalities, there are also the corresponding disequalities :
-
x <> y
is equivalent tonot (x = y)
(the decidable boolean valued disequality) -
x =!= y
is equivalent yo~(x == y)
(the logical, homogeneous disequality)