Your task is to implement the Karatsuba algorithm for fast polynomial multiplication and verify its correctness in Verus. Preconditions: Inputs a and b are Vec<i64> representing polynomials. Structure: The length of a and b are equal and must be a power of 2. Size: The total length is at most 1000. Bounds: input coefficients are within $[-1,000,000, 1,000,000]$. Requirements: Implement poly_multiply that returns the product of the two polynomials. (1) Algorithm Logic: + Base Case: If $N$ is small, perform scalar multiplication. + Split: Divide $A(x)$ and $B(x)$ into halves $A_0, A_1$ and $B_0, B_1$. + Recurse: Compute $z_0 = A_0 B_0$, $z_2 = A_1 B_1$, and $z_1 = (A_0+A_1)(B_0+B_1)$. + Combine: Result $= z_0 + (z_1 - z_0 - z_2)x^m + z_2 x^{2m}$. (2) Functional Correctness: Verify that the result mathematically matches the standard convolution definition (same as the Naive version). Verification Challenges: (1) Algebraic Equivalence: You must prove that the Karatsuba formula equals the standard expansion. This requires a ghost proof establishing $(A_0+A_1)(B_0+B_1) - A_0B_0 - A_1B_1 = A_0B_1 + A_1B_0$. (2) Overflow Safety: The Karatsuba algorithm involves adding coefficients before multiplying them (e.g., $A_0+A_1$). You must prove that these intermediate sums and their subsequent products do not overflow i64, given the input bounds. (3) Recursion Termination: Prove that the recursion depth is finite (the input vector size strictly decreases).