Your task is to implement the Lower Bound Binary Search algorithm and verify its correctness in Lean. Given a sorted array of integers and a target value, find the first index i such that arr[i] >= target. If no such element exists, return arr.size. Postconditions: Result index 'res' satisfies: (1) res <= arr.size, (2) all elements before 'res' are strictly less than target, and (3) all elements at or after 'res' are greater than or equal to target. Preconditions: Input array is sorted. Array size fits in signed 32-bit integer. Implementation should be iterative or recursive O(log N).
