Your task is to implement the Insert operation for a Ternary Search Tree (TST) and verify its correctness in Dafny. A TST is a space-efficient alternative to a standard Trie. Instead of allocating a fixed array of 256 children for every node, it dynamically organizes characters using three pointers: left and right (storing alternative characters for the current position in a BST format) and mid (storing the next character in the sequence). This allows the tree to adapt to sparse data without memory waste. The insertion logic combines BST insertion with Trie extension. Given a key and a node: (1) If the current character differs from the node's val, insert a new node into the left or right subtree, maintaining the BST property among siblings. (2) If the character matches, traverse to the mid child and proceed to the next character in the key. (3) If the key extends beyond the existing path, create a new chain of nodes linked via mid pointers. Specifically, you must prove: (1) Set Update: The resulting tree's view is exactly the union of the old view and the new key. (2) Invariant Preservation: The result must satisfy the well_formed invariant, ensuring that for every node, all keys in the left subtree start with a character strictly smaller than the node's val, and all keys in the right subtree start with a character strictly larger. (3) Non-Empty Result: The resulting tree is valid and not "empty."