kdrag.tactics.lemma

kdrag.tactics.lemma(thm: BoolRef, by: None | list[None] = [], admit=False, timeout=1000, dump=False, solver=None, defns=True, simps={}) None

Prove a theorem using a list of previously proved lemmas.

In essence prove(Implies(by, thm)).

Parameters:
  • thm (smt.BoolRef) – The theorem to prove.

  • thm – The theorem to prove.

  • by (list[Proof]) – A list of previously proved lemmas.

  • admit (bool) – If True, admit the theorem without proof.

Returns:

A proof object of thm

Return type:

Proof

>>> lemma(smt.BoolVal(True))
|- True
>>> lemma(smt.RealVal(1) >= smt.RealVal(0))
|- 1 >= 0