View source: R/map_to_state_space.R
map_to_state_space | R Documentation |
Given a list of states (e.g., for each tip in a tree), map the unique states to integers 1,..,Nstates, where Nstates is the number of possible states. This function can be used to translate states that are originally represented by characters or factors, into integer states as required by ancestral state reconstruction and hidden state prediction functions in this package.
map_to_state_space(raw_states, fill_gaps=FALSE,
sort_order="natural")
raw_states |
A vector of values (states), each of which can be converted to a character. This vector can include the same value multiple times, for example if values represent the trait's states for tips in a tree. The vector may also include |
fill_gaps |
Logical. If |
sort_order |
Character, specifying the order in which raw_states should be mapped to ascending integers. Either "natural" or "alphabetical". If "natural", numerical parts of characters are sorted numerically, e.g. as in "3"<"a2"<"a12"<"b1". |
Several ancestral state reconstruction and hidden state prediction algorithms in the castor
package (e.g., asr_max_parsimony
) require that the focal trait's states are represented by integer indices within 1,..,Nstates. These indices are then associated, afor example, with column and row indices in the transition cost matrix (in the case of maximum parsimony reconstruction) or with column indices in the returned matrix containing marginal ancestral state probabilities (e.g., in asr_mk_model
). The function map_to_state_space
can be used to conveniently convert a set of discrete states into integers, for use with the aforementioned algorithms.
A list with the following elements:
Nstates |
Integer. Number of possible states for the trait, based on the unique values encountered in |
state_names |
Character vector of size Nstates, storing the original name (character version) of each unique state. For example, if |
state_values |
A numeric vector of size |
mapped_states |
Integer vector of size equal to |
name2index |
An integer vector of size Nstates, with |
Stilianos Louca
# generate a sequence of random states
unique_states = c("b","c","a")
raw_states = unique_states[sample.int(3,size=10,replace=TRUE)]
# map to integer state space
mapping = map_to_state_space(raw_states)
cat(sprintf("Checking that original unique states is the same as the one inferred:\n"))
print(unique_states)
print(mapping$state_names)
cat(sprintf("Checking reversibility of mapping:\n"))
print(raw_states)
print(mapping$state_names[mapping$mapped_states])
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.