co_sort

Sort multiple arrays given a permutation.

LICENSE LICENSE

The simplest way to use this crate is the co_sort! macro, it will sort the first array and swap elements of the others in order to mimic the changes in the first array. \ Usefull when you have multiple slices with an implicit relation. ```rust

[macrouse] extern crate cosort;

use cosort::*; let mut names = ["Diego", "Maia", "Luciana", "Bruno", "Astrid", "Thierry"]; let mut ages = [ 73, 88, 21, 47, 4, 62 ]; // We want to sort the names but keep the ages synced cosort![names, ages]; asserteq!(names, ["Astrid", "Bruno", "Diego", "Luciana", "Maia", "Thierry"]); asserteq!(ages, [ 4, 47, 73, 21, 88, 62 ]); If you want more control you can use the functions co_sort and co_sort_stable, the macro uses co_sort internally. \ co_sort_stable allocates O(n) memory and requires the types to implement Clone while co_sort is in place and doesn't require any trait. \ Performance wise co_sort scale well with the number of arrays but not with their size and co_sort_stable is the opposite. rust

use co_sort::*;

let mut names = ["Diego", "Maia", "Luciana", "Bruno", "Astrid", "Thierry"]; let mut ages = [ 73, 88, 21, 47, 4, 62 ]; let permutation = Permutation::from(names.asref()); permutation.cosort((names.asmut(), ages.asmut())); // or permutation.cosortstable((names.asmut(), ages.asmut())); asserteq!(names, ["Astrid", "Bruno", "Diego", "Luciana", "Maia", "Thierry"]); asserteq!(ages, [ 4, 47, 73, 21, 88, 62 ]); ```

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.