Your task is to implement Merge Sort and verify its correctness in Dafny. Merge Sort is a divide-and-conquer algorithm that divides the input array into two halves, calls itself for the two halves, and then merges the two sorted halves. You might implement two functions: (1) merge: Takes two sorted vectors and combines them into one sorted vector. (2) merge_sort: The recursive driver, which is the function to be verified. There are several verification challenges: (1) Proving that merge maintains the permutation property (the sum of counts in inputs equals counts in output). (2) Proving merge produces a sorted output. (3) Proving termination of the recursion (using a decrement on length). Note that you are not allowed to write new axioms (for example, writing seemingly correct property for multisets), and maybe directly using permutation is a better option.