Your task is to implement the Euclidean Algorithm for Greatest Common Divisor (GCD) and verify its functional correctness in Lean. Given two non-negative integers a and b, compute the largest integer that divides both a and b. Preconditions: * Inputs: `a` and `b` are `UInt64`. Postconditions: Implement `compute_gcd` which returns a `UInt64`. (1) Algorithm: Use the standard Euclidean algorithm (recursive or iterative). (2) Functional Correctness: The result must equal `spec_gcd (UInt64.toNat a) (UInt64.toNat b)`, which is defined declaratively using `Classical.choose`. (3) Implied Properties: The result is a common divisor of a and b, and any other common divisor divides the result. Verification Challenges: (1) Termination: Prove that the recursion/loop terminates (requires proving `a % b < b`) (2) Correctness: Prove that your implementation logic is equivalent to the declarative definition `spec_gcd`. This relies on proving the mathematical property that $GCD(a, b) = GCD(b, a \pmod b)$ to link the algorithmic steps to the abstract specification.