- Fixed retro-compatibility for S3 behaviours (
plot
andsummary
) fordispRity
objects made before1.9
.
- Redesigned
multi.ace
to be more modular and handle both continuous and/or discrete characters. Changes include a change in argument name fromcastor.options
to the genericoptions.args
(the options can be provided the same way as before though); and a change in default arguments formodels
which can now be left missing (previously was"ER"
) and applies"ER"
and"BM"
for respectively discrete and continuous characters by default. - New design when using distance matrices:
dist.helper
now allows to save distance matrices in the cache, saving a lot of RAM and speeding up calculations. You can use the helper usingdispRity(..., dist.helper = my_distance_function)
ordispRity(..., dist.helper = my_distance_matrix)
. - New
dispRity
,custom.subsets
andchrono.subsets
option: these three functions can now usedist.data = TRUE
to specify that the input data is a distance matrix (and handle it accordingly). - New bootstrap options: you can now use
boot.by
to specify whether to bootstrap the rows (previous behaviour), the columns or both (for distance matrices). - New utility function
set.root.time
to add a root time to a tree ("phylo"
), list of trees ("multiPhylo"
) ordispRity
object with trees. - New utility function
remove.dispRity
to cleanly remove specific parts of a"dispRity"
object. - New metric:
count.neighbours
to count the number of neighbours for each elements within a certain radius (thanks to Rob MacDonald for the suggestion).
custom.subsets
can now take a logical vector for thegroup
argument.custom.subsets
now recycles node names when using a tree to create clade groups.plot
functions doing scatter plot now centers them without changing the scale of both axes.- changed default argument for
tree.age
: the number of digits output bytree.age
is now changed from 3 to 4 by default. - the random starting parameters in
reduce.space
are now drawn from the input data distribution which speeds up the function significantly. match.tip.edges
can now just work for colouring edges connecting a vector of tips.- remove deprecated internal requirements in
boot.matrix
. - improved RAM management for
make.metric
(now uses the largest requestable subset rather than the whole data for testing).
scale.dispRity
now correctly ignoresNA
s when scaling.multi.ace
now correctly handles invariant characters when looking for NAs.dispRity
objects with a$covar
component are not interpreted as bootstrapped byboot.matrix
anymore.
- The
dimensions
argument fromboot.matrix
is now removed: it has been redundant with thedimensions
argument in thedispRity
since v0.3!
- Added the dispRity.multi internal architecture now allowing users to work with different matrices and different trees as inputs for
custom.subsets
,chrono.subsets
,boot.matrix
anddispRity
. This change is not affecting the user level appart from now allowing to bypass some error messages (thanks to Mario Corio for that obvious suggestion). - New utility function:
name.subsets
for directly accessing the subsets names of adispRity
object (basically doingnames(my_dispRity$subsets)
). - New utility function:
MCMCglmm.variance
for calculating the variance for specific terms in a"MCMCglmm"
model. - New statistical test:
pgls.dispRity
to run PGLS test on adispRity
object with a level-2 metric and a tree (using the excellentphylolm
algorithm). The new test comes with its own S3 print, summary and plot functions if the inputdispRity
data contains multiple trees or multiple matrices (running and handling the output of multiplephylolm
). - New options to
get.tree
utility function to get the trees in each subsets (thanks to Jack Hatfield for this suggestion and help with implementation). - New vignette compiling resources for developers to help people (and future me) to edit the package.
- New metric:
roundness
to measure the roundness of a variance-covariance matrix.
- CHANGE IN DEFAULT ARGUMENTS for the
custom.subsets
,chrono.subsets
,boot.matrix
anddispRity
functions: thetree
,FADLAD
,prob
anddimensions
arguments is nowNULL
by default (instead of missing). - CHANGE IN DEFAULT ARGUMENTS for the
projections
function. The defaults are nowscale = TRUE
,centre = FALSE
(previouslyTRUE
) andabs = FALSE
(previouslyTRUE
). The default arguments fordispRity.covar.projections
remain unchanged though (scale = TRUE
,centre = TRUE
,abs = TRUE
). randtest.dispRity
function'ssubsets
argument now can take a list of arguments of subsets to compare isdata
is adispRity
object. The call message has also been updated to be much more verbose and clear of what has been tested.- optimised internal logic for all the
projections.*
functions for speed. test.metric
now also adds the slope coefficient if the optionmodel
is used.- the default legends/row names when using
plot
/summary
ontest.metric
results are now more easy to interpret. reduce.space
has now 25 times less chances to be stuck on a local optimum.match.tip.edges
now also works on nodes and on"multiPhylo"
objects and has a added an optionuse.parsimony
(default isTRUE
) to propagate the matching down the tree (i.e. if two nodes have the same unique ancestor and variable value, the ancestor is consider to have that variable value as well).- Improved margins handling in
covar.plot
. - Updated test coverage here and there.
clean.data
can now also handle a list of"phylo"
objects astree
input (i.e. it does not need to be specifically classed as"multiPhylo"
).- Changed dependencies to
spptest
toGET
. space.maker
can now generate specific row names and be replicated to generate a bunch of spaces (via the new optional argumentselements.names
andreplicates
respectively).- The
add.tree
utility function now has an optional argument to override any existing trees (replace = TRUE
) or not (replace = FALSE
; which remains the default previous behaviour). print.dispRity
now recognises and highlights simulated data from thetreats
package.- Improved
NA
management forS3
functions. - Improved automatic centering and scaling for
covar.plot
making the figures more aesthetic. remove.zero.brlen
now also removes negative branch lengths and works on"multiPhylo"
objects (thanks to Thomas Johnson for this suggestion).fill.dispRity
has now an extra argumentcheck
to toggle the data checking on and off (more for developers).multi.ace
is now described in details in the manual.slice.tree
has now akeep.all.ancestors
option to do exactly that.
- The correct types of changes are now plotted in legend when plotting the results of
test.metric
. get.disparity
now correctly concatenates one dimensional results into a"numeric"
(rather than a"matrix"
).make.metric
now internally handlescovar
object correctly (i.e. as distance matrices).- Calculating disparity for multiple matrices and customised subsets now works as expected for all metric levels.
ellipse.volume
has been changed toellipsoid.volume
to more accurately reflect what it is measuring.rescale.dispRity
has been changed toscale.dispRity
and correctly registered as a S3 method.randtest.dist
has been changed todistance.randtest
to avoid conflict with*.dist
S3 methods.
- New data function:
select.axes
for selecting and analysing the number of axes required to contain an arbitrary amount of variance. - New utility function:
randtest.dist
for measuring the distance between the observed statistic and a specific quantile of the simulated statistic (thanks to Frane Babarovic for the inspiration). dispRity
objects can now contain covariance matrices as a$covar
object. Thecovar
part can be directly used for some specific metrics (usuallymy_metric.covar
) and are handled by thedispRity
function (andplot
,summary
, etc...) in a specific way.$covar
contains a list of two elementsVCV
the variance covariance matrix andloc
the coordinates of the centre of theVCV
in space (can be left empty).$covar
matrices are effectively treated as bootstraps.- New function
covar.plot
for plotting thecovar
content ofdispRity
objects (this is separated fromplot.dispRity
because of the many different options). - New function:
MCMCglmm.subsets
is a function that allows to convert aMCMCglmm
object into adispRity
object. - New metric:
projections.between
a between group metric for applying theprojections
metric between the major covariance axis of two matrices. - New metric:
disalignment
: the (dis)alignment of a group compared to another one (i.e. the rejection from group B's centre on the group A's major axis). a between group metric for applying theprojections
metric between the major covariance axis of two matrices. - New
dispRity.fast
function for the fastest disparity calculations at the expanses of pretty much everything this package does. This is a really situational function. - New utility functions for manipulating
MCMCglmm
objects:MCMCglmm.traits
for extracting the number of traits,MCMCglmm.levels
for extracting the level names,MCMCglmm.sample
for sampling posterior IDs andMCMCglmm.covars
for extracting variance-covariance matrices - New utility functions for
dispRity
objects withcovar
matrices:get.covar
to extract the VCV matrices (or a subsample of them);axes.covar
to extract the major axes of the VCV matrices andas.covar
to transformdispRity
metric function to use a covar object. - New utility function
match.tip.edge
for matching tip labels as factors/characters/integer to tree edges. - New wrapper function
dispRity.covar.projections
for covariance projections analyses (with its associated S3 sub-class). - One new demo datasets:
charadriiformes
, adata.frame
and aphylo
object of 359 Charadriiformes species (gulls, plovers and sandpipers) from Cooney et al 2017 along with aMCMCglmm
model with each clade as a random term. - Additional plot arguments
...
in all thedispRity
plotting functions can now be targeted to a specific plotting element. When multiple elements are plot by default (e.g. lines, legend, points, etc...) it is now possible to pass a specific...
argument to the specific plotted element using the syntax<element>.<argument>
(e.g.points.col = "blue"
will only apply the argumentcol = "blue"
to the points).
- Changed default arguments for
projections
andprojections.tree
metrics: the default"position"
output is now scaled, centred and absolute (see?projections
for details). - Formalised the grouping logic for
custom.subsets
andselect.axes
. This can create some minor user level changes namely: warning messages for empty subsets now correctly mentions "subsets" (rather than subsamples); groups with incorrect elements are now always flagged as errors (rather than just ignored). The changes at the developer level is that the logic is now made smoother and exported incustom.subsets_fun.R
. - Added a
function.index.csv
list (and updater) to help developers find internal functions locations easily. - Restricted the type-I error inflation warning message in
test.dispRity
to only occur when using a test of class"htest"
. - Continuous Integration has been moved from Travis-CI to GitHub Actions.
custom.subsets
can now group elements using a"factor"
vector.- Utility functions manuals are now grouped by topic (e.g. utilities related to
MCMCglmm
objects,dispRity
objects in general,dispRity
objects with subsets, ect...). It should now be much easier to find these sometimes overlooked functions. - Many updates and new entries in the
dispRity
manual, including a section oncovar
andbetween.groups
specific analyses. - Improving speed for the
test.metric
(using the new officialdispRity.fast
function). - Most core functions in the package now have a garbage memory cleaning component. This improves the speed and the memory footprint when handling very large datasets.
- Disparity results stored in
data$disparity
now don't have dimension names anymore (significantly reducing the size ofdisparity
objects). However, you can always retrieve the dimensions names usingget.disparity
. - Updated the calculation options for
ellipse.volume
, you can now directly specify one of the following methods:"pca"
to calculate the eigen values from the ordinated matrix;"eigen"
to directly do an eigen decomposition of the matrix (new); or"axes"
to directly measure the axes (new); or directly provide the eigen values. - The interval function
check.subsets
now handles the checking of"dispRity"
objects much faster making most functions relying on it slightly faster (this function is typically not called more than once per function). - Updated
adonis.dispRity
to the newestvegan::adonis2
code (thanks to Jari Oksanen for the notification). - Removed dependency to
geiger
fordtt.dispRity
to avoid package maintenance errors. This leads to no changes at the user level andgeiger::dtt
is still acknowledged in the manual. tree.age
function's manual now makes it clear it does not estimate tree ages.- When using
plot.dispRity(..., type = "preview")
, group's colour attribution and plotting is now made so that the groups larger groups are plotted in the background and the smaller in the foreground. NA
s are now better handled in internal checking functions.
- Removed warning in
dispRity
when selecting a specific number of dimensions (old warning artefact). - Fixed bug in
plot.dispRity
when usingtype = "preview"
on bootstrapped data and fortype = "box"
when the subsets to plot are from different sizes (now plots all the data correctly). - Fixed bug when using
chrono.subsets
with"continuous"
method aFADLAD
data containing only node values (now correctly taken into account; thanks to Peng-Wei Li for noticing it) and when usingchrono.subsets
with"gradual.*"
models on empty subsets. standardGeneric
functions are now correctly interpreted as functions throughout the package.- Fixed bug when plotting level 1 disparity metric results without bootstrapped (
observed = TRUE
is now used as the default). - Fixed bug when plotting
test.metric
plots withsave.steps
options with more than two types of shifts. - Fixed bug with
null.test
which is now correctly managing the number of dimensions inherited fromdispRity
objects (thanks to Alex Slavenko for spotting this one and the two above). - Fixed bug when using level 2 dimension metrics on unidimensional data (the metric is now detected as a level 2 correctly; thanks to Catherine Klein and Rachel Warnock for noticing that one).
- Update internal use of
is(data, c("array", "matrix"))
tois.array(data)
for R 4.1.2.
matrix.dispRity
andextract.dispRity
are now deprecated. You should now use respectivelyget.matrix
andget.disparity
instead (the arguments don't change though).
- New metric:
projections
that allows to measure elements' projection on an arbitrary axis (or their distance from this axis withmeasure = "distance"
). - New metric:
projections.tree
that allows to measure elements' projection on axis between elements of a given tree. - New metric:
edge.length.tree
the edge length from each element given a tree (with the optionto.root = TRUE/FALSE
to measure the edge length from the element to the root of the tree (default = TRUE) or the nearest ancestor (FALSE). - You can now save the shifts results in
test.metric
withsave.steps
and then visualise them withplot.dispRity
along side the disparity metric test results. - New utility function
n.subsets
to directly get the number of subsets in adispRity
object. - New statistical test:
randtest.dispRity
that is a wrapper forade4::randtest
applied todispRity
objects (not dissimilar fromnull.test
). - Six more demo datasets have been added to the package! These datasets are the ones used in Guillerme et al. 2020 and published originally in Beck & Lee 2014 (that one was originally the only demo dataset in the package), Wright 2017, Marcy et al. 2016, Hopkins & Pearson 2016. Thanks to all these authors for their open science work!
dispRity
objects now have a reserved$tree
component that contain any number of trees attached to the data. This allows any function to use the reserved argument nametree
to extract directly the relevant tree from thedispRity
object, for functions likechrono.subsets
or metrics likeancestral.dist
! To help manipulate thetree
component of thedispRity
object, you can now use the new utility functionsadd.tree
,get.tree
andremove.tree
.
- Reverted R version requirement from
4.0
back to3.6
following Joseph Brown's issue and fix. reduce.space
"random"
algorithm now outputs a named logical vector (like the other algorithms!).- remove the
"only"
text when printingdispRity
objects that contains "only" matrices (even though that can be 10k matrices!). - added a dedicated behaviour to
summary.dispRity
for"dispRity"
"randtest"
objects to output "ready-to-publish" result tables. - some error messages have been updated to be slightly more useful.
- added the
estimation.details
argument tomulti.ace
allowing to also return specific arguments from the ancestral states estimation (thanks to Armin Elsler for the suggestion). - Added new option
inc.nodes
toclean.data
whether to check if the nodes in the tree match the labels in the matrix. make.metric
with the optionsilent = TRUE
now outputs a list of info rather than only the level of the metric. You can reproduce the old behaviour usingmake.metric(..., silent = TRUE)$type)
.- Fixed bug in
plot
usingpreview
when the given argumentpch
did not match the number of groups (the differentpch
arguments are now used correctly). - Completely revamped the
ancestral.dist
metric. The function is now much faster and much easier to use (due to the newdispRity
object structure). The optionsnodes.coords
has been removed and the optionfull
is now changed byto.root
. If you still really want to use the older version ofancestral.dist
usingancestral.dist.deprecated
though. - The
dimensions
option throughout the package (e.g. in thedispRity
function) can now also be a vector of dimensions to take into consideration (e.g.c(1,2,5)
).
chrono.subsets
now automatically detects the number of digits to round for the internal time slicing functions (thanks to Mario Corio) for finding this one).- Fixed bug in
test.metric
plots that now display correctly the "top" and "bottom" changes for the "position" shift. - Fixed bug in
test.metric
plots that now display the R^2 values correctly. - Fixed bug in
tree.age
when the tree tips/node labels vector is longer than the actual number of tips/nodes in the tree.
- Removed former version of
ancestral.dist
(see NEW FEATURES above). - Removed
node.coordinates
function (no replacement; you must use a package version prior 1.5.10 to use this function). - Removed
get.ancestors
function (no replacement; you must use a package version prior 1.5.10 to use this function).
- New function:
multi.ace
for performing fast ancestral character estimations on multiple matrices (based oncastor::asr_mk_model
). - New function:
reduce.space
, a function to modify trait spaces imported from themoms
shiny app. This function comes with a new reduction algorithm: the "evenness" algorithm for flattening the curve (thanks to Gavin Thomas) for the suggestion). - New function:
test.metric
(and associatedplot
,print
andsummary
functions), to apply thereduce.space
function on a specific space and metric to test whether a metric is picking up specific changes in trait space. - the
dispRity
function can now use"between.groups"
metrics to calculate disparity between groups rather than within groups. Themake.metric
function is now modified to allow detection of metrics that can be applied between groups. - New metric:
group.dist
, a dimension level 1 metric for between groups that measures the distance between two groups. By default, this is the minimum distance but the function takes theprobs
argument allowing the distance to be between, says, the 95% CI (probs = c(0.025, 0.975))
) or between the centroids (probs = c(0.5)
). - New metric:
point.dist
, a dimension level 2 metric for between groups that measures the distance between the rows inmatrix
to a point inmatrix2
. That point is the centroid by default but thepoint
argument can take any function.
- The
dispRity
package now depends onR (>= 4.0.0)
. - Many updates to the
dispRity
manual. - Many minor speed improvements across the package
- Simplified syntax for the internal
plot.dispRity
S3 methods (for a potentialggpRity
?). These changes should not be apparent at the user level but see the two removed options below: - removed option in
plot.dispRity
: thechrono.subsets
option (TRUE
/FALSE
) has now been removed. The time-slicing-ness is now automatically detected or can be specified by the user normally throughxlab
. - removed option in
plot.dispRity
: theylim
,ylab
,xlab
andcol
options have now been removed. They are now handled through...
as normal genericplot(...)
arguments. - removed option in
plot.dispRity
: theelements.pch
option has now been removed. Thepch
of the plotted elements can now be passed like other options directly to elements (e.g.elements = list(pch = 15)
). - removed option in
plot.dispRity
: thedimensions
,matrix
,nclass
andcoeff
options have now been removed. Any options for dual class plots (randtest
,dtt
,model.test
,type = "preview"
etc...) are now handled through the genericspecific.args
argument. - New option in
dtt.dispRity
:scale.time
allowing to scale the time axis (like ingeiger::dtt
) or not. - when plotting
chrono.subsets
dispRity
objects, the x label ticks are now rounded if possible (for nicer looking plots!). - when using automatic
chrono.subsets
time slices, the name of the time slices (their age) is now rounded for aesthetics.
- Updated all calls to the
Claddis
package to match version 0.6 (thanks to Graeme Lloyd) for fixing this one!) - Updated
Claddis.ordination
function to be compatible with the newape
version5.4
(thanks to Emmanuel Paradis) for the pointing that out). - Fixed a bug in
chrono.subsets
where ladder trees with no tip branch lengths anmethod = "continuous"
option would get stuck in an infinite loop. - Fixed a bug in
chrono.subsets
where the"*.split"
methods would bug if the last slice is through a single edge. - Fixed a bug in
dispRity
where some 1D matrices could loose their class for certain metrics.
- New metric:
angles
, a dimension level 2 metric that measures the angle of the main axis of each dimension in a matrix (in slopes, angles or degrees). - New metric:
deviations
, a dimension level 2 metric that measures the deviation of each element from a hyperplane. - Completely rewritten
char.diff
function. It now uses a way faster bitwise comparison architecture and comes with different distance methods as well as modular optional arguments on how to treat various special tokens ("?"
,"-"
,"&"
, etc.). This also allows many more distance methods (now including"hamming"
,"manhattan"
,"comparable"
,"euclidean"
,"maximum"
and"mord"
). - all
dispRity
functions can now intake a single"matrix"
or a"list"
of matrices with the same row names and dimensions. The disparity is then calculated directly on all the matrices and summarised as before throughsummary.dispRity
. This option can be used to add uncertainty to disparity calculations. For example inchrono.subsets
you can now provide a list of trees and a list of associated ancestral state estimates; or forcustom.subsets
you can provide a list of matrices with different values representing different estimations of the traits.
- update
reduce.matrix
to work withvegan::vegdist
version 2.5-6 (thanks to Jari Oksanen for the fix). - updated class evaluations throughout the package for
R
version4.0.0
:class(.) == *
is nowis(., *)
. - updated
...
argument bug PR#16223. - In
make.metric
the argument...
is now ignored if anynames(...)
is"tree"
or"phy"
. - fixed bug in
neighbours
andspan.tree.length
when feeding "distance" like metrics (thanks to Ashley Reaney for finding that one).
- greatly improved speed of
chrono.subsets
withmethod = "continuous
(now > 1000 times faster!). - minor warning message fix for
plot.dispRity
with time slices. - removed
paleotree
package dependency (though the links to this excellent package are still there!). - increased
R
version requirement to3.5
. ...
insummary.dispRity
are now directly passed tocent.tend
(e.g.na.rm = TRUE
).- added some time improvements in several phylo functions based on the
castor
package. - updated all the package demo data to fit the new
dispRity
object architecture (see above). Note that this might effect the exact results of calculations using these demo datasets. - you can now specify the dimensions of the matrix to make a disparity metric in
make.metric
through thedata.dim
option. - metrics passed in
dispRity
are now tested using the input data dimensions. chrono.subsets
with multiple trees now stretches the root edges length to match the oldest tree.
- New metric:
displacements
, a dimension level 2 metric that measures the position of elements in space (i.e. their distance from the centre relative to their distance to their centroid). - New metric:
neighbours
, a dimension level 2 metric that measures the distance from an element to its neighbour (e.g. the nearest neighbour, the furthest, the median, etc.). - New metric:
quantiles
, a dimension level 2 metric that measures the nth quantile range per axis (a good alternative to theranges
function!). - New metric:
func.eve
, a dimension level 1 metric that measures the functional evenness (i.e. the spread along the minimum spanning tree; from Villéger et al. 2008). - New metric:
func.div
, a dimension level 1 metric that measures the functional divergence (i.e. the ratio of deviation from the centroid; from Villéger et al. 2008). - Updated metric:
span.tree.length
now outputs the length of each edges (c.f. the sum of the length) and becomes a level 2 metric. - The
chrono.subsets
can now takemultiPhylo
objects for slicing through multiple trees at once! - New utility function:
reduce.matrix
for optimising data overlap in a matrix with missing data. - New utility function:
slide.nodes
for sliding specific nodes on a tree. - New utility function:
remove.zero.brlen
for stochastically removing zero branch lengths on a tree (using theslide.nodes
function). - New argument in
plot.dispRity
: thetype
argument can now be"preview"
to have a glimpse at two of the dimensions of the trait-space. - The
Claddis.ordination
can now directly take a matrix's path as input (leaving the function to read and transform the matrix intoCladdis
format. The function can thus now also be used to convert matrices intoCladdis
format. - Added a "Other functionalities" section to the manual describing miscellaneous functions.
centroids
andancestral.dist
functions can now take themethod
option for"euclidean"
or"manhattan"
distances.- All functions methods selection have now been sped up using
switch
. - Error messages in
dispRity
are more verbose when input the wrong metric(s). scree
option inspace.maker
does not require to sum up to one anymore.cor.matrix
option inspace.maker
does not require to have a valid Choleski decomposition (an approximation is used instead).- Updated all tests and functions to be compatible with R 3.6.
- Fixed bug in
clean.data
that did not output dropped tips correctly when applied onmultiPhylo
objects. - Improved error messages in
chrono.subsets
for funky time slices/bins (e.g. with negative values). - Speed improvements for the
time.slice
function. - Better internal handling of distance matrices for the disparity metrics.
- Most functions handles
NA
asna.rm
orna.omit
.
dispRity
objects now contain a metric argument (if a metric was applied). This argument can now be recycled by the appropriate functions (e.g. innull.test
).
plot.dispRity
argumentobserved
can now take a list of arguments to be passedpoints()
.boot.matrix
now makes a error warning message when bootstrapping distance matrices (as suggested by Dave Bapst!).geomorph.ordination
can now be used to simply create coordinates matrices (no ordination!) withordinate = FALSE
argument.- better internal handling of error messages.
faster
eigen value estimations inellipse.volume
when the argument is left missing.- removed internal handling of the
Claddis.ordination
function. This function now uses the brand new version of theCladdis
package on CRAN (0.3).
plot.dispRity
with option"box"
now correctly display plot ranges when disparity is an observed distribution.test.dispRity
handles errors messages more efficiently when disparity is an observed distribution.summary.dispRity
handles non-bootstrapped distributions display properly.geomorph.ordination
now converts"character"
vectors into"factors"
.adonis.dispRity
now properly handles complex formulas (with arithmetic signs)....
are now properly handled by internal metric testing functions for more accurate error messages.char.diff
names are now properly protected in theC
implementation to comply with newrcheck
requirements.
- New functions:
model.test
,model.test.sim
andmodel.test.wrapper
for fitting models of disparity evolution through time (with associated manuals, vignettes andS3
methods! Thanks to Mark Puttick). - New argument in
boot.matrix
:prob
for passing probabilities of sampling for specific elements. - S3
print
method for objects of class"dtt"
and"dispRity"
(fromdtt.dispRity
).
- tydiversed most of the error messages.
dtt.dispRity
now allows to specify the alternative hypothesis (ifnsim > 0
).ellipse.volume
can now take an explicit eigen value vector (the eigen values are still automatically estimated correctly for PCO and MDS).- Improved metric checking messages from
make.metric
when dealing with optional arguments. - Removed cascade of warnings triggered by
plot.dispRity.dtt
.
- Corrected
char.diff
to properly reflect the probability of different splits between characters (thanks to Abigail Pastore).
- CRAN release 1 with the additional
Claddis.ordination
function.
- Added default Cailliez correction to
Claddis.ordination
function (withadd = TRUE
). - Improved test coverage.
- First CRAN release
- Registered
C
symbols properly. - Overall improvement for the
S3
methods. - Changed name:
scale.dispRity
is nowrescale.dispRity
. - Changed name:
merge.subsets
is nowcombine.subsets
. - Changed name:
time.subsets
is nowchrono.subsets
-time.subsets
can still be called as an alias for the same function.
- Minor bug fixes and typos in various error messages and in the manual.
- Removed
Claddis.ordination
function to comply with the CRAN requirement (this function is still live in the GitHub version 1.1).
custom.subset
can now automatically create clade-based groups if aphylo
object is passed togroup
.- New utility function:
extinction.subsets
, to get the list to be passed totest.dispRity
for testing the effect of extinction. - New test function:
dtt.dispRity
, a wrapper forgeiger::dtt
. This version is slower thatgeiger::dtt
but allows any univariate disparity metric! - New test function:
adonis.dispRity
, a wrapper forvegan::adonis
. - New utility function:
crown.stem
for separating a tree into crown and stem groups. - New disparity metric:
span.tree.length
the length of the minimum spanning tree. - New disparity metric:
pairwise.dist
: the element's pairwise distances. - New disparity metric:
radius
: the radius of each dimensions. - New disparity metric:
n.ball.volume
: the n-dimensional sphere or ellipsoid volume. - New argument in
time.subsets
,model = "equal.split"
andmodel = "gradual.split"
that retain the probability of being either the descendant or the ancestor. This probability is passed toboot.matrix
.
- Changed calls to
stats::dist
tovegan::vegdist
to allow more distances to be passed throughmethods
arguments. slice.tree
can now slice through a single edge.- Various minor speed improvements.
- Correct behaviour in
tree.age
to estimate ages for trees with fossils only.
- Change name throughout the package,
subsample
is now replaced bysubset
(e.g.time.subsamples
is now renamedtime.subsets
,data$subsamples
is nowdata$subsets
, etc...). - Changed argument in
time.subsets
,model = "gradual"
is now replaced bymodel = "proximity"
andmodel = "punctuated"
is now replaced bymodel = "random"
.
- New disparity metric:
ancestral.distance
to get the distance from taxa/nodes to their ancestors. - New function:
random.circle
for generating random circle coordinates (see example inspace.maker
for creating doughnut spaces!). - New function:
get.bin.ages
for getting the geological timescale of a tree (based ongeoscale
).
- Added a
t0
argument totime.subsamples
allowing to set the start age of the first subsample. - Allowing subsamples to contain less than three elements (up to 0!).
- Fixed fuzzy match issues in
slice.tree
.
- Entirely rewritten manual (in GitBook)!
- New function:
Claddis.ordination
andgeomorph.ordination
for automatically ordinating data fromCladdis
andgeomorph
packages! - New function:
char.diff
for calculating character differences and associated plot function (plot.char.diff
) - New utility function:
merge.subsamples
for... merging subsamples. - New utility function:
size.subsamples
for getting the size of subsamples in a disparity object. - New wrapping functions:
dispRity.through.time
anddispRity.per.group
now runs easy default disparity analysis.
- Input ordinated matrices do not need to be of maximum size
n*(n-1)
. Bigger matrices now only trigger a warning. - Added
dimensions
optional argument todispRity
to overwrite the number of dimensions generated byboot.matrix
. variances
,ranges
andcentroids
are now simplified for speed. The optional arguments for data cleaning are now passed tomake.metric
.space.maker
now allows to approximate the dimensions variance distribution with thescree
option.
- Removed
hyper.volume
metric for dependencies reasons, - Removed
parallel
option fromboot.matrix
(the new architecture is already super fast: <2sec for 5k taxa and 10k bootstraps!). - Changed name:
series
as a part ofdispRity
objects is now changed tosubsamples
throughout the whole package. - Changed name:
time.series
is now renamedtime.subsamples
, if dates are provided and method isdiscrete
, this function doesn't need a phylogeny any more. - Changed name:
get.subsamples.dispRity
is now renamedget.subsamples
. - Modified function:
cust.series
is now renamedcustom.subsamples
(to avoid confusion withcustard.subsamples
!). Itsfactor
argument as been changed togroups
and can now take a simple list.
- Complete change of the
dispRity
object architecture.
sim.morpho
can now usemodel = "mixed"
for using bothHKY-binary
andMk
in characters simulation.dispRity
object utilities are now all grouped under the?dispRity.utilities
manual with appropriate S3 methods.
- Removed
rm.last.axis
argument inboot.matrix
. It is now replaced bydimensions
. - Changed argument in
plot.dispRity
,type = "lines"
is now replaced bytype = "line"
.
- New utility function:
merge.time.series
for cleaning or merging time series,. - New vignette:
dispRity-simulate_data
on how to simulate morphological characters indispRity
. - New function:
sim.morpho
generates morphological matrices. - New function:
check.morpho
for checking how "realistic" the simulate morphological matrices are. - New utility functions:
get.contrast.matrix
andapply.inapplicable
functions for morphological matrices.
- Minor updates for the graphical functions.
- New utility functions:
pair.plot
,scale.dispRity
andsort.dispRity
. - New function:
space.maker
for creating some multidimensional spaces! - New disparity metrics:
convhull.surface
,convhull.volume
andhyper.volume
. - New disparity test
null.test
. - New
plot.dispRity
arguments:density
for controlling the polygons density andadd
for adding plots.
- Many updates to the functions manual and vignettes.
- Some algorithm are now greatly improved for speed.
- Disparity can now be calculated as a distribution (i.e.
dispRity
,test.dispRity
,plot.dispRity
, andsummary.dispRity
can now intake one or more distribution rather than just one or more single values of disparity; whether the data is bootstrapped or not). dispRity
can now intakedispRity
objects with level 2 disparity metrics.boot.matrix
anddispRity
can now run in parallel.centroids
disparity metric can now use acentroid
argument for fixing the centroid point value.variances
andranges
disparity metrics can now intake ak.root
argument for scaling the results.
- Minor functions corrections for specific optional arguments combinations.
- Removed
type_discrete
argument inplot.dispRity
andtype
argument can now be:continuous
disparity curves.box
for real boxplots.lines
for the distribution vertical lines.polygon
for the distribution boxes.
- New function:
get.dispRity
for subsampling dispRity objects. - New function:
extract.dispRity
for extracting disparity results. - New function:
test.dispRity
for applying tests todispRity
objects. - New function:
make.metric
for helping creating your very own disparity metric. - New metric:
hyper.volume
for measuring the morphospace hyper-ellipsoid volume.
metric
argument fromdispRity
can now intake up two three functions (seedispRity.metric
andmake.metric
).- Many improved functions manuals and examples!
- Improved vignettes:
- dispRity palaeo demo a quick demo aimed more for palaeobiologist.
- dispRity ecology demo a quick demo aimed more for ecologists.
- dispRity manual for people that want to know the package in details.
- dispRity metrics for explaining how the disparity metric implementation works.
plot.dispRity
options improved (rarefaction + default).cust.series
can now intake multiple factors columns.- Added example for ecological data.
boot.matrix
,dispRity
,summary
andplot
now also include observed values.plot
now has anobserved
option to plot the observed disparity.
- Fixed many error/warning messages.
- Changed
taxa
toelements
. plot
optiondiversity
has been renamedelements
.
- First release!