This module contains the implementation of the reflection monad, used by all other components of this directory.
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
- Lean.Elab.Tactic.BVDecide.Frontend.instToExprBVExpr.go (Std.Tactic.BVDecide.BVExpr.var idx) = Lean.mkApp2 (Lean.mkConst `Std.Tactic.BVDecide.BVExpr.var) (Lean.toExpr w) (Lean.toExpr idx)
- Lean.Elab.Tactic.BVDecide.Frontend.instToExprBVExpr.go (Std.Tactic.BVDecide.BVExpr.const val) = Lean.mkApp2 (Lean.mkConst `Std.Tactic.BVDecide.BVExpr.const) (Lean.toExpr w) (Lean.toExpr val)
Instances For
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
- Lean.Elab.Tactic.BVDecide.Frontend.instToExprBoolExpr.go (Std.Tactic.BVDecide.BoolExpr.const b) = Lean.mkApp2 (Lean.mkConst `Std.Tactic.BVDecide.BoolExpr.const) (Lean.toTypeExpr α) (Lean.toExpr b)
Instances For
A BitVec
atom.
- width : Nat
The width of the
BitVec
that is being abstracted. - atomNumber : Nat
A unique numeric identifier for the atom.
- synthetic : Bool
Whether the atom is synthetic. The effect of this is that values for this atom are not considered for the counter example deriviation. This is for example useful when we introduce an atom over an expression, together with additional lemmas that fully describe the behavior of the atom.
Instances For
The state of the reflection monad
The atoms encountered so far. Saved as a map from
BitVec
expressions to a (width, atomNumber) pair.- atomsAssignmentCache : Lean.Expr
A cache for
atomsAssignment
.
Instances For
The reflection monad, used to track BitVec
variables that we see as we traverse the context.
Equations
Instances For
A reified version of an Expr
representing a BVExpr
.
- width : Nat
- bvExpr : Std.Tactic.BVDecide.BVExpr self.width
The reified expression.
- evalsAtAtoms : Lean.Elab.Tactic.BVDecide.Frontend.M Lean.Expr
A proof that
bvExpr.eval atomsAssignment = originalBVExpr
. - expr : Lean.Expr
A cache for
toExpr bvExpr
.
Instances For
A reified version of an Expr
representing a BVPred
.
- bvPred : Std.Tactic.BVDecide.BVPred
The reified expression.
- evalsAtAtoms : Lean.Elab.Tactic.BVDecide.Frontend.M Lean.Expr
A proof that
bvPred.eval atomsAssignment = originalBVPredExpr
. - expr : Lean.Expr
A cache for
toExpr bvPred
Instances For
A reified version of an Expr
representing a BVLogicalExpr
.
- bvExpr : Std.Tactic.BVDecide.BVLogicalExpr
The reified expression.
- evalsAtAtoms : Lean.Elab.Tactic.BVDecide.Frontend.M Lean.Expr
A proof that
bvExpr.eval atomsAssignment = originalBVLogicalExpr
. - expr : Lean.Expr
A cache for
toExpr bvExpr
Instances For
A reified version of an Expr
representing a BVLogicalExpr
that we know to be true.
- bvExpr : Std.Tactic.BVDecide.BVLogicalExpr
The reified expression.
- satAtAtoms : Lean.Elab.Tactic.BVDecide.Frontend.M Lean.Expr
A proof that
bvExpr.eval atomsAssignment = true
. - expr : Lean.Expr
A cache for
toExpr bvExpr
Instances For
Run a reflection computation as a MetaM
one.
Equations
- m.run = StateRefT'.run' m { atoms := ∅, atomsAssignmentCache := Lean.mkConst `List.nil [Lean.Level.zero] }
Instances For
Retrieve the atoms as pairs of their width and expression.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Retrieve a BitVec.Assignment
representing the atoms we found so far.
Equations
- Lean.Elab.Tactic.BVDecide.Frontend.M.atomsAssignment = do let __do_lift ← getThe Lean.Elab.Tactic.BVDecide.Frontend.State pure __do_lift.atomsAssignmentCache
Instances For
Look up an expression in the atoms, recording it if it has not previously appeared.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- One or more equations did not get rendered due to their size.
Instances For
The state of the lemma reflection monad.
The list of top level lemmas that got created on the fly during reflection.
Instances For
The lemma reflection monad. It extends the usual reflection monad M
by adding the ability to
add additional top level lemmas on the fly.
Equations
Instances For
Equations
- m.run state = do let __discr ← StateRefT'.run m state match __discr with | (res, state) => pure (res, state.lemmas)
Instances For
Add another top level lemma.
Equations
- Lean.Elab.Tactic.BVDecide.Frontend.LemmaM.addLemma lemma = modify fun (s : Lean.Elab.Tactic.BVDecide.Frontend.LemmaState) => { lemmas := s.lemmas.push lemma }