Your task is to implement Dijkstra's Algorithm for single-source shortest paths and verify its functional correctness in Lean using Mathlib. The input is a WeightedGraph where edge weights are Int. Preconditions: You can assume the graph contains at most 100,000 nodes and edge weights are between -100,000 and 100,000 (inclusive). Crucially, the graph is a Simple Graph (no parallel edges between the same two nodes) and all edge weights are non-negative ($w \ge 0$). Requirements: Implement the function dijkstra_shortest_paths which returns a list of Option Int. If a node v is reachable, the sequence at index v must contain Some(d), where d is the unique minimal path weight from the start node to v. If a node v is unreachable, the sequence must contain None. Verification Challenges: (1) Relaxation Invariant: Proving that when a node u is extracted from the priority queue, its recorded distance is the true shortest path distance. (2) Queue Invariants: Proving that the priority queue correctly maintains the "frontier" of the search. (3) Path Minimality: Proving that no path exists with weight strictly less than the returned distance.
