# iv
[data:image/s3,"s3://crabby-images/caca7/caca7a77974fd0e567e98dfcce39211e0d7ef2af" alt="Package Version"](https://hex.pm/packages/rrb_array)
[data:image/s3,"s3://crabby-images/7c557/7c557a32f08e49c79944cb17a8d1b101a5ccade0" alt="Hex Docs"](https://hexdocs.pm/rrb_array/)
`iv` is a fast, general-purpose, persistent array structure for Gleam.
You can use it like you would use an array in other programming languages and
expect comparable or better runtime characteristics. It is roughly 5-100 times
faster than Erlangs' `array` module, depending on the workload. It also offers
_O(log n)_ or effectively constant runtime on all main operations, including
`concat` and `split`, making it an excellent choice when parallelising workloads.
### Benchmarks
`iv` does not try to be the fastest at anything, but offer consistent, high
performance across all types of workloads.
You can find benchmarks [here](./benchmarks.html).
### Installation
```sh
gleam add iv@1
```
### Example: Bubble-Sort
```gleam
import iv
import gleam/int
import gleam/result
// bubble sort, in my gleam?
pub fn main() {
// make an array of 10 random integers
let array = iv.initialise(10, fn(_) { int.random(100) })
let sorted = bubble_sort(array)
use item <- iv.each(sorted)
io.println(int.to_string(item))
}
fn bubble_sort(array) {
bubble_sort_loop(array, 1, iv.length(array))
}
fn bubble_sort_loop(array, index, max_index) {
case iv.get(array, index - 1), iv.get(array, index) {
// found 2 elements in the wrong order, swap them, then continue
Ok(prev), Ok(curr) if prev > curr -> {
case
array
|> iv.set(index, prev)
|> result.then(iv.set(_, index - 1, curr))
{
Ok(array) -> bubble_sort_loop(array, index + 1, max_index)
Error(_) -> array
}
}
// found 2 elements in the correct order, we can skip them!
Ok(_), Ok(_) -> bubble_sort_loop(array, index + 1, max_index)
// reached the end, decrease max_index then try again!
_, _ if max_index > 2 -> bubble_sort_loop(array, 1, max_index - 1)
// reached the end and no more elements to swap, we are done.
_, _ -> array
}
}
```
Further documentation can be found at <https://hexdocs.pm/iv>.
### Development
```sh
gleam run # Run the project
gleam test # Run the tests
gleam run -m benchmark # Run the benchmarks
```
### Implementation
`iv` is based on the _RRB-Vector_, an advanced immutable data structure based
on Closures persistent vectors developed by Bagwwell and Rompf. If you're
interested in that sort of thing, I highly recommend also checking out L'oranges
masters thesis, which is a very rigorous presentation of the algorithms and
mathementics behind them. The blog post by Horne-Khan implements the main ideas,
but is easier to digest without a strong computer science background.
`iv` improves on the data structure as presented by offering fast appends,
prepends and inserts for arbitrary numbers of elements and improving general
node reconstruction time.
- L’orange, J. N. (2014). Improving RRB-Tree Performance through Transience \
Available: <https://hypirion.com/thesis.pdf>
- Stucki, N., Rompf, T., Ureche, V., & Bagwell, P. (2015). RRB Vector: a practical general purpose immutable sequence. In Proceedings of the 20th ACM SIGPLAN International Conference on Functional Programming (pp. 342-354). \
Available: <https://www.cs.purdue.edu/homes/rompf/papers/stucki-icfp15.pdf>
- Bagwell, P., Rompf, T. (2011). RRB-Trees: efficient immutable vectors. \
Available: <http://infoscience.epfl.ch/record/169879/files/RMTrees.pdf>
- Horne-Khan, P. (2024). Relaxed Radix Balanced Trees. \
Available: <https://peter.horne-khan.com/relaxed-radix-balanced-trees/>
- konsumlamm (2021). rrb-vector: Efficient RRB-Vectors. \
Available: <https://github.com/konsumlamm/rrb-vector>
- Hansen, R. H. (2017). Elm array exploration. \
Available: <https://github.com/robinheghan/elm-array-exploration>