Your task is to implement the standard $O(N^2)$ algorithm for multiplying two polynomials and verify its correctness in Dafny.  Preconditions: Inputs a and b are seq<int> 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 a standard 64-bit integer range without overflow. Requirements: Implement poly_multiply to return the product polynomial. (1) Algorithm: Initialize a result sequence of size |a| + |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 sequence 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 exceed the simulated 64-bit bounds. 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 within safe limits.