Your task is to implement the "Exponentiation by Squaring" Algorithm and verify its functional correctness in Verus. Unlike the naive approach, this algorithm computes $b^e$ in $O(\log e)$ time using binary decomposition of the exponent. Preconditions: You can assume the input base b and exponent e are u64 integers. To ensure safety, you may assume that the mathematical result $b^e$ fits within the u64 range (i.e., $b^e \le \text{u64::MAX}$). Requirements: Implement the function provided in the skeleton which returns u64. (1) Functional Correctness: You must define a recursive ghost specification spec_pow(b, e) and prove that your implementation returns exactly this value. (2) Safety: You must prove that neither the accumulator updates nor the squaring of the base ever cause a u64 overflow. Verification Challenges: (1) Non-Linear Arithmetic Lemmas: The core logic relies on the algebraic identity $(b^2)^k = b^{2k}$. SMT solvers struggle with non-linear arithmetic. You must explicitly state and verify helper lemmas (using induction) to teach the solver that squaring the base compensates for halving the exponent. (2) Conservation Invariant: You must define and prove a sophisticated loop invariant. Unlike the naive case, the accumulator does not simply equal $b^i$. Instead, you must prove that at every step, $current\_res \times current\_base^{current\_exp} = original\_base^{original\_exp}$. (3) Intermediate Overflow Safety: Proving safety is subtle because the base variable grows rapidly ($b, b^2, b^4...$). You must verify that base is only squared if it is needed for the result, or prove that even if it is squared unnecessarily in the final step, it is still bounded by the logical constraints of the algorithm.