Your task is to implement a deterministic variant of Quick Sort and verify its correctness in Dafny. The pivot must always be chosen as the first element of the slice (or sub-slice) being sorted. You need to implement: (1) partition: Reorders the slice such that all elements less than the pivot come before it, and all elements greater than or equal to the pivot come after it. It returns the final index of the pivot. (2) quick_sort: Recursive calls using the partition index, which is the function to be verified. There are several verification challenges: (1) Partitioning: Proving that the partition function permutes the array such that [< pivot, pivot, >= pivot] holds. (2) Termination: Proving that the recursive calls are strictly smaller. With pivot = first, if you aren't careful, a sorted array might result in a recursive call of size n-1 and 0. You must prove the pivot index is strictly bounded to ensure the recursion measure decreases. 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.