Your task is to implement the Euclidean Algorithm to compute the Greatest Common Divisor (GCD) of two integers and verify its correctness in Dafny. Preconditions: The inputs a and b are u64. Requirements: Implement the function compute_gcd which returns a u64. (1) Algorithm: Use the classic Euclidean algorithm: repeatedly replace (a, b) with (b, a % b) until b becomes 0. The result is a. (2) Functional Correctness: You must verify that your implementation returns exactly the value defined by the specification spec_gcd. Verification Challenges: (1) Termination: This is the primary challenge. You must prove that the loop terminates. This requires proving that the modulo operation a % b strictly decreases the second argument b in every step (i.e., a % b < b). (2) Correctness Invariant: You must verify that the GCD is preserved throughout the transformation. The invariant spec_gcd(current_a, current_b) == spec_gcd(initial_a, initial_b) must hold at every iteration. This relies on the mathematical property that $GCD(a, b) = GCD(b, a \pmod b)$.