Your task is to implement Kruskal's Algorithm to find the Minimum Spanning Tree (MST) of a connected, undirected, weighted graph and verify its functional correctness in Dafny. Preconditions: You can assume the graph is connected. You can assume the graph contains at most 100,000 nodes and edge weights are between -100,000 and 100,000. Crucially, the graph is a Simple Graph (no parallel edges between the same two nodes). Requirements: Implement the function kruskal_mst which returns a seq<(int, int, int)> (representing edges). (1) The function must sort all edges by weight and iterate through them.  (2) It should add an edge to the result only if it connects two previously disconnected components (i.e., does not form a cycle). (3) Global Optimality: You must prove that the resulting edge set has the minimal total weight among all spanning trees. Verification Challenges: (1) Union-Find (Disjoint Set): To efficiently implement Kruskal's, you typically use a Union-Find data structure.  You must verify that your find and union operations correctly track component connectivity. (2) Cycle Prevention: Proving that your check (typically find(u) != find(v)) correctly predicts whether adding edge $(u, v)$ would create a cycle. (3) Forest Invariant: Unlike Prim's (which grows one tree), Kruskal's grows a forest of trees. You must prove the invariant that this forest eventually merges into a single spanning tree and that every edge added is a "safe edge" for some MST.