Documentation

Lean.Meta.Tactic.Grind.Util

Throws an exception if target of the given goal contains metavariables.

Equations
  • One or more equations did not get rendered due to their size.
Instances For

    Abstracts metavariables occurring in the target.

    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

        Returns true if declName is the name of a grind helper declaration that should not be unfolded by unfoldReducible.

        Equations
        Instances For
          Equations
          • One or more equations did not get rendered due to their size.
          Instances For

            Auxiliary function for implementing unfoldReducible and unfoldReducibleSimproc. Performs a single step.

            Equations
            • One or more equations did not get rendered due to their size.
            Instances For

              Unfolds all reducible declarations occurring in e.

              Equations
              • One or more equations did not get rendered due to their size.
              Instances For

                Unfolds all reducible declarations occurring in the goal's target.

                Equations
                Instances For

                  Beta-reduces the goal's target.

                  Equations
                  Instances For

                    If the target is not False, applies byContradiction.

                    Equations
                    • One or more equations did not get rendered due to their size.
                    Instances For

                      Clears auxiliary and implementation detail decls used to encode recursive declarations and implementation details.

                      • grind eliminates auxiliary declarations to ensure they are not accidentally used by its proof automation.
                      • grind eliminates implementation detail declarations because they have a support role.
                      Equations
                      • One or more equations did not get rendered due to their size.
                      Instances For

                        In the grind tactic, during Expr internalization, we don't expect to find Expr.mdata. This function ensures Expr.mdata is not found during internalization. Recall that we do not internalize Expr.lam children. Recall that we still have to process Expr.forallE because of ForallProp.lean. Moreover, we may not want to reduce p → q to ¬p ∨ q when (p q : Prop).

                        Equations
                        • One or more equations did not get rendered due to their size.
                        Instances For

                          Converts nested Expr.projs into projection applications if possible.

                          Equations
                          • One or more equations did not get rendered due to their size.
                          Instances For

                            Normalizes universe levels in constants and sorts.

                            Equations
                            • One or more equations did not get rendered due to their size.
                            Instances For
                              @[extern lean_grind_normalize]

                              Normalizes the given expression using the grind simplification theorems and simprocs. This function is used for normalizing E-matching patterns. Note that it does not return a proof.

                              Returns Grind.MatchCond e. We have special support for propagating is truth value. See comment at MatchCond.lean.

                              Equations
                              Instances For
                                Equations
                                Instances For

                                  Returns Grind.PreMatchCond e. Recall that Grind.PreMatchCond is an identity function, but the simproc reducePreMatchCond is used to prevent the term e from being simplified. Grind.PreMatchCond is later converted into Grind.MatchCond. See comment at MatchCond.lean.

                                  Equations
                                  Instances For
                                    Equations
                                    Instances For
                                      Equations
                                      • One or more equations did not get rendered due to their size.
                                      Instances For

                                        Adds reducePreMatchCond to s

                                        Equations
                                        Instances For

                                          Converts Grind.PreMatchCond into Grind.MatchCond. Recall that Grind.PreMatchCond uses default reducibility setting, but Grind.MatchCond does not.

                                          Equations
                                          • One or more equations did not get rendered due to their size.
                                          Instances For