We modified the function dist_make()
to pass along additional arguments to the distance function. This helps with distance functions that take extra parameters. We removed the method
keyword argument from dist_make()
because we found it not to be useful in practice.
We added a new function, dist_multi_centroid()
, to produce a distance matrix between multiple centroid positions.
We fixed an error in dist_groups()
that will pop up in future versions of R. In R 4.0.0, the data.frame()
function will have a new default value, stringsAsFactors = FALSE
. This update caused one column in the output from dist_groups()
to change from a factor to a character vector, which broke one of our tests. We updated the code to deliberately make this column a factor. The function’s behavior will be preserved when R 4.0.0 is released.
We’ve made two major updates for this release.
The centroid functions have gained a keyword argument, squared
. The final step in computing distance to group centroids involves taking a square root. Sometimes, we end up with a negative number inside the square root. Normally, this produces NaN
as a result. However, if squared
is set to TRUE
, we don’t take the square root and the result is always a real number. The default setting is squared = FALSE
, which gives the distance as you’d expect. Thanks to Sam Ross for helpful advice on this topic.
We added a new function, pivot_to_numeric_matrix()
. This function takes a data frame in long format and converts to a matrix suitable for distance calculations. Long-format data frames are commonly used with functions in the tidyverse
, and proper conversion to a matrix requires a few non-obvious steps. The packages dplyr
, tidyr
, and tibble
are needed to run the function, and have been added as suggested packages for usedist
.
During development, we had implemented an additional function to create a distance matrix directly from a data frame in long format. However, we found that it was nearly as convenient to use pivot_to_numeric_matrix()
and dist_make()
together to achieve the same result. We added an example to the README file to illustrate this.
Initial release!
For the first release, we’ve moved over all the distance matrix-related functions from the qiimer
package. Utility functions dist_setNames
and dist_make
were added to the existing functions dist_subset
, dist_get
, and dist_groups
.
The other area of focus for our initial release was a set of distance-to-centroid functions. These functions operate on a set of items that are placed into several groups, and they apply algebraic formulas to find the group centroid distances based on the distance matrix. If you had a set of points in normal Euclidean space, you could easily find the centroid positions and compute the distances from there. The centroid functions included in the package are more useful for non-Euclidean distances, where it is less straightforward to locate the centroids in space. The centroid functions were inspired by work in microbial ecology, where it is typical to work with non-Euclidean distances between samples.