rfl

rfl は、反射的(reflexive)な関係に対して関係式を示すタクティクです。ここで二項関係 R : α → α → Prop が反射的であるとは、任意の a : α に対して R a a が成り立つことをいいます。

関係 R が反射的であることを rfl に利用させるには、R の反射性を示した定理に @[refl] タグを付けます。

universe u

-- `MyEq` という二項関係を定義する
inductive MyEq {α : Type u} : α → α → Prop where
  | refl (a : α) : MyEq a a

example (n : Nat) : MyEq n n := by
  -- `rfl` で示すことはできない。
  fail_if_success rfl

  apply MyEq.refl

-- `MyEq` が反射的であることを登録する
attribute [refl] MyEq.refl

-- `rfl` で示せるようになる
example (n : Nat) : MyEq n n := by rfl

補足

2項関係 (· ≡ ·) : A → A → Prop の反射性とは、任意の a : A に対して a ≡ a が成り立つという性質です。反射性を使って何かを示すと言っても、a ≡ a という形の命題しか示せないのではないかという気がするかもしれません。しかし実際には rfl は定義に従って項の簡約を行うため、ab が定義上等しいものであれば a ≡ brfl で示すことができます。

-- 簡約すると3になる
/-- info: 3 -/
#guard_msgs in #reduce (2 ^ 30 + 3 ^ 30) % 5

example : (2 ^ 30 + 3 ^ 30) % 5 = 3 := by rfl

もし反射的でない関係について「定義から計算して示す」ことが必要であれば、decide タクティクを使うと良いかもしれません。