Your task is to implement a solver for the Discrete Logarithm Problem and verify its correctness in Verus. Preconditions: The inputs g (generator), h (target), and p (modulus) are u64. Assume p > 1. Requirements: Implement the function discrete_log_naive which returns Option<u64>. Goal: Find an integer x such that $g^x \equiv h \pmod p$, where $0 \le x < p$. Algorithm: Use a naive linear search. Iterate x from 0 to p-1. Maintain a running product for $g^x \pmod p$ to avoid recomputing the power from scratch. Minimality: If multiple solutions exist, you must return the smallest x. Unsolvable Case: If no such x exists in the range, return None. Verification Challenges: (1) Incremental Modular Exponentiation: You are not calling a pow function inside the loop; you are updating current_val = (current_val * g) % p. You must prove the invariant that at iteration i, current_val == spec_pow_mod(g, i, p). This requires the modular multiplication lemma. (2) Negative Proof (None): The hardest part is the None case. If the loop finishes without returning, you must prove the universal quantifier: $\forall k \in [0, p), g^k \not\equiv h \pmod p$. (3) Minimality (Some): When you return Some(x), you must prove that no earlier index k < x was a solution. Since your loop searches strictly from 0 upwards, this follows from the control flow, but you must capture it in the loop invariant ("for all checked $k$, $g^k \neq h$").