Your task is to implement the Karatsuba Multiplication Algorithm for polynomials and verify its functional correctness in Lean. Given two polynomials A and B represented as coefficient lists, compute their product. Preconditions: 1. Lengths: A and B have equal lengths, which are powers of two (e.g., 2, 4, 8...). 2. Constraints: The sum of lengths is at most 1000. Coefficients are integers between -1,000,000 and 1,000,000. Postconditions: Implement `karatsuba_mul` using the divide-and-conquer approach. (1) Algorithm: - Base Case: Small N (e.g., N=1), use simple multiplication. - Recursive Step: Split A and B into halves (A0, A1, B0, B1). Compute z0 = A0*B0, z2 = A1*B1, and z1 = (A0+A1)*(B0+B1). - Combine: result = z0 + (z1 - z0 - z2)x^m + z2 x^2m. (2) Output: Returns a list of size |A| + |B| - 1. (3) Functional Correctness: Verify that the result matches the standard mathematical convolution of A and B.  Verification Challenges: (1) Algebraic Equivalence: You must prove that the Karatsuba formula mathematically equals the standard polynomial multiplication formula. This typically requires a helper lemma showing (A0+A1)(B0+B1) - A0B0 - A1B1 = A0B1 + A1B0. (2) Termination: Prove that the recursion on list length terminates.