Your task is to implement the Linear Search algorithm to find the lower bound index and verify its correctness in Lean. Given a sequence of integers (not necessarily sorted, though typically used with sorting in mind for lower_bound semantics, the spec here just asks for the partition point if it were sorted or just the first element >= target), find the first index k such that seq[k] >= target. Returns seq.size if no such element is found. Postconditions: (1) result <= seq.size. (2) All elements before 'result' are < target. (3) All elements from 'result' onwards (if sorted) or just the element at 'result' matches the condition? Wait, the Dafny spec says "forall i < result ==> s[i] < target" and "forall i >= result ==> s[i] >= target". This implies the array MUST be sorted for this spec to hold for ALL i >= result. However, the Dafny spec provided does NOT explicitly require `is_sorted` in the precondition for `linear_search` in the file view (wait, let me check the file content again... checked: explicitly requires `is_sorted(s)`). So it is Lower Bound on a sorted array using Linear Search. Implementation should be O(N).
