Your task is to implement a linear system solver for the field $GF(2)$ (integers modulo 2) and verify its correctness in Dafny.  Preconditions: Inputs: A matrix matrix (size $M \times N$) and a target vector b (size $M$), both represented using seq<int>. Domain: All elements in the input matrix and vector are guaranteed to be either 0 or 1. Dimensions: You may assume the dimensions are small (e.g., $M, N \le 100$) to keep verification tractable, though the logic should be general. Requirements: Implement the method solve_linear_system_gf2 which returns Option<seq<int>>. Goal: Find a vector $x$ (of size $N$) such that $A x \equiv b \pmod 2$. (1) Algorithm: Use standard Gaussian Elimination adapted for binary arithmetic: Field Arithmetic: Addition is equivalent to XOR (^). Multiplication is equivalent to AND (&). Row Operations: To zero out a column below a pivot, you simply XOR the current row with the pivot row (since $1 + 1 = 0$ in $GF(2)$). Pivoting: If the current diagonal element is 0, find a row below it with a 1 in that column and swap. Output: Return Some(x) if a valid solution vector is found. Return None if the system is inconsistent (i.e., row reduction leads to an equation of the form $0 = 1$). Verification Challenges: (1) Solution Set Preservation: You must prove that every elementary row operation (swapping rows, XORing one row into another) preserves the set of solutions. This implies that if $x$ is a solution to the transformed system, it is also a solution to the original system. (2) Completeness (The None Case): The most difficult part is verifying the negative case. If your algorithm returns None, you must prove that no vector $x$ exists that satisfies the original equation. This typically requires showing that the row operations derived a logical contradiction (like $0=1$) implied by the original constraints. (3) Field Axioms: SMT solvers treat integers as standard arithmetic by default. You may need to verify or hint small lemmas about GF(2) properties (e.g., $a + a = 0$ or $(a - b) \equiv (a + b) \pmod 2$) to justify the correctness of your update steps.