I’m making a bunch of partition and selection functions. In my use case I will always have vectors indexed by one, but given that offsetarray exists I wonder what would be a good signature for a function that takes an array and an index of said array.
I think the partition function in Base.jl takes a lo, hi as well and partitions arr[lo:hi] but I wonder if there’s an abstract type that represents “index i from the beginning of this vector’s linearindex”, or if something like “for i = eachindex(arr)[1:input_index]” would work?
So… after looking into begin I got to look into Base.Iterators and tried to implement the same function with and without iterators. Iterators make handling of indices easier as I need to traverse in both directions. I managed to get something that runs 2x slower than the initial version with while loops and indices (I’m not pasting that version here as it turns out it also has some errors in edge cases that I haven’t debugged yet). I was wondering if someone would have suggestions to improve the performance. For example, I wonder if these iterators are frozen or are recomputed every time I modify the array, and if there’s a way to freeze them (I don’t think so as they’re lazy):