Your task is to implement the standard $O(N^2)$ algorithm for multiplying two polynomials and verify its correctness in Verus. Preconditions: Inputs a and b are Vec<i64> representing polynomial coefficients. Size Constraint: The sum of lengths is at most 1000. Value Constraint: Every coefficient is between -1,000,000 and 1,000,000. This ensures that the result fits within i64 without overflow. Requirements: Implement poly_multiply to return the product polynomial. (1) Algorithm: Initialize a result vector of size len(a) + len(b) - 1 with zeros. Use a nested loop: for every i in a and j in b, add a[i] * b[j] to res[i+j]. (2) Functional Correctness: Prove that the final vector matches the convolution specification: res[k] = sum_{p+q=k} a[p] * b[q]. (3) Safety: You must prove that the intermediate additions and multiplications never overflow i64. Verification Challenges: (1) Accumulation Invariant: The naive algorithm updates the same index res[k] multiple times. You need a loop invariant that characterizes the partial sum stored in res at any point in the nested loops. (2) Overflow Proof: You must prove that given the input bounds ($|c| \le 10^6$) and length bound ($N \le 1000$), the maximum possible coefficient ($N \times 10^{12}$) is strictly less than i64::MAX.