Relations between and equivalence of weak sequences #
This file defines a relation between weak sequences as a relation between their some
elements,
ignoring computation time (none
elements). Equivalence is then defined in the obvious way.
Main definitions #
Stream'.WSeq.LiftRelO
: Lift a relation to a relation over weak sequences.Stream'.WSeq.LiftRel
: Two sequences areLiftRel R
-related if their correspondingsome
elements areR
-related.Stream'.WSeq.Equiv
: Two sequences are equivalent if they areLiftRel (· = ·)
-related.
Two weak sequences are LiftRel R
related if they are either both empty,
or they are both nonempty and the heads are R
related and the tails are
LiftRel R
related. (This is a coinductive definition.)
Equations
- One or more equations did not get rendered due to their size.
Instances For
If two sequences are equivalent, then they have the same values and
the same computational behavior (i.e. if one loops forever then so does
the other), although they may differ in the number of think
s needed to
arrive at the answer.
Equations
- Stream'.WSeq.Equiv = Stream'.WSeq.LiftRel fun (x1 x2 : α) => x1 = x2
Instances For
If two sequences are equivalent, then they have the same values and
the same computational behavior (i.e. if one loops forever then so does
the other), although they may differ in the number of think
s needed to
arrive at the answer.
Equations
- Stream'.WSeq.«term_~ʷ_» = Lean.ParserDescr.trailingNode `Stream'.WSeq.«term_~ʷ_» 50 50 (Lean.ParserDescr.binary `andthen (Lean.ParserDescr.symbol " ~ʷ ") (Lean.ParserDescr.cat `term 51))