Your task is to implement the classic Sieve of Eratosthenes algorithm to find all prime numbers up to a limit $N$ and verify its correctness in Verus. Preconditions: The input n is a usize. You may assume $n \le 100,000$. Requirements: Implement the function sieve_of_eratosthenes which returns a Vec<bool>. Output Format: The returned vector must be of length $n$. For any index $i$, vec[i] should be true if $i$ is prime, and false otherwise. Algorithm: + Initialize a boolean array of size $n$ to true (except 0 and 1).+ Iterate a variable i from 2 up to $\sqrt{n}$. + If i is marked as prime, iterate a variable j starting from i * i up to n with a step size of i (j += i), marking these indices as false (composite). Functional Correctness: You must verify that the final state of the array exactly matches the mathematical definition of primality for every index. Verification Challenges: (1) Array Invariants: Unlike the scalar problems, you must maintain an invariant over the entire array. For example: "For all $k < n$, if arr[k] is true, then $k$ has no prime factors smaller than the current loop index i. (2) "Inner Loop Stride: The inner loop increments by i ( j += i). You must prove that every index j visited by this loop is indeed a multiple of i, and that the loop correctly covers all multiples of i in the range $[i^2, n)$. (3) Optimization Logic ($i^2$): The standard Sieve starts marking multiples from $i^2$, not $2i$. To verify this is safe, you must use (or prove) the mathematical fact that any composite number $x < i^2$ must have a prime factor strictly smaller than $i$, and thus would have already been marked in a previous iteration.