It has been a long day and you are making your way through a paper related to your work. You suddenly come across the following remark: “…since $x

Anatomy of a Formal Proof

submited by
Style Pass
2025-01-24 18:30:21

It has been a long day and you are making your way through a paper related to your work. You suddenly come across the following remark: “…since $x$ and $y$ are eigenvectors of $f$ with distinct eigenvalues, they are linearly independent.” Wait—how does the proof go? You should really know this. Here $x$ and $y$ are nonzero elements of a vector space $V$ and $f : V \to V$ is a linear map. You force yourself to pick up a pen and write down the following argument:

Let $f(x) = \mu x$ and $f(y) = \nu y$ with $\mu \ne \nu$ . Suppose $a x + b y = 0$ . Applying $f$ and using linearity, we have $\mu a x + \nu b y = 0$ . Multiplying the original equation by $\nu$ , we have $\nu a x + \nu b y = 0$ . Subtracting the two yields $(\mu - \nu ) a x = 0$ and since $\mu - \nu$ and $x$ are nonzero, we have $a = 0$ . The corresponding argument with $x$ and $y$ swapped yields $b = 0$ , so the only linear combination of $x$ and $y$ that yields $0$ is the trivial one.

Your colleagues have all gone home and there is nobody around to discuss this with. So, instead, you turn to your computer and start up Lean, the proof assistant you happen to use. Can you prove the claim formally? As you type, the information window in your editor complains about every misstep—the syntax is fiddly, and you have to get the notation and the instructions just right—but that’s okay, because working through the proof is relaxing and kind of fun. Lean often makes you spell out arguments that are painfully obvious, but you have found that if you set things up just right, it will cheerfully fill in some of the details. After a short while, you have success! Lean signs off on the proof, confirming you have managed to construct a formal derivation in the system’s axiomatic foundation.

Leave a Comment