Title: | Probabilistic Suffix Trees and Variable Length Markov Chains |
---|---|
Description: | Provides a framework for analysing state sequences with probabilistic suffix trees (PST), the construction that stores variable length Markov chains (VLMC). Besides functions for learning and optimizing VLMC models, the PST library includes many additional tools to analyse sequence data with these models: visualization tools, functions for sequence prediction and artificial sequences generation, as well as for context and pattern mining. The package is specifically adapted to the field of social sciences by allowing to learn VLMC models from sets of individual sequences possibly containing missing values, and by accounting for case weights. The library also allows to compute probabilistic divergence between two models, and to fit segmented VLMC, where sub-models fitted to distinct strata of the learning sample are stored in a single PST. This software results from research work executed within the framework of the Swiss National Centre of Competence in Research LIVES, which is financed by the Swiss National Science Foundation. The authors are grateful to the Swiss National Science Foundation for its financial support. |
Authors: | Alexis Gabadinho [aut, cre, cph] |
Maintainer: | Alexis Gabadinho <alexis.gabadinho@wanadoo.fr> |
License: | GPL (>= 2) |
Version: | 0.95 |
Built: | 2024-12-29 02:48:20 UTC |
Source: | https://github.com/r-forge/pst |
Extracting contexts in a PST satisfying user defined criterion
## S4 method for signature 'PSTf' cmine(object, l, pmin, pmax, state, as.tree=FALSE, delete=TRUE)
## S4 method for signature 'PSTf' cmine(object, l, pmin, pmax, state, as.tree=FALSE, delete=TRUE)
object |
A probabilistic suffix tree, i.e., an object of class |
l |
length of the context to search for. |
pmin |
numeric. Minimal probability for selecting the (sub)sequence. |
pmax |
numeric. Maximal probability for selecting the (sub)sequence. |
state |
character. One or several states of the alphabet for which the (cumulated) probability is greater than |
as.tree |
logical. If |
delete |
Logical. If |
If as.tree=TRUE
a PST, that is an object of class PSTf
which can be printed and plotted; if as.tree=FALSE
a list of contexts with their associated next symbol probability distribution, that is an object of class cprobd.list
for which a plot
method is available. Subscripts can be used to select subsets of the contexts, see examples.
The cmine
function searches in the tree for nodes fulfilling certain characteristics, for example contexts that are highly likely to be followed by a given state (see example 1). One can also mine for contexts corresponding to a minimum or maximum probability for several states together (see example 2). For more details, see Gabadinho 2016.
Alexis Gabadinho
Gabadinho, A. & Ritschard, G. (2016). Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 72(3), pp. 1-39.
## Loading the SRH.seq sequence object data(SRH) ## Learning the model SRH.pst <- pstree(SRH.seq, nmin=30, ymin=0.001) ## Example 1: searching for all contexts yielding a probability of the ## state G1 (very good health) of at least pmin=0.5 cm1 <- cmine(SRH.pst, pmin=0.5, state="G1") cm1[1:10] ## Example 2: contexts associated with a high probability of ## medium or lower self rated health cm2 <- cmine(SRH.pst, pmin=0.5, state=c("B1", "B2", "M")) plot(cm2, tlim=0, main="(a) p(B1,B2,M)>0.5")
## Loading the SRH.seq sequence object data(SRH) ## Learning the model SRH.pst <- pstree(SRH.seq, nmin=30, ymin=0.001) ## Example 1: searching for all contexts yielding a probability of the ## state G1 (very good health) of at least pmin=0.5 cm1 <- cmine(SRH.pst, pmin=0.5, state="G1") cm1[1:10] ## Example 2: contexts associated with a high probability of ## medium or lower self rated health cm2 <- cmine(SRH.pst, pmin=0.5, state=c("B1", "B2", "M")) plot(cm2, tlim=0, main="(a) p(B1,B2,M)>0.5")
Plot the next symbol probability distribution associated with a particular node in a PST
## S4 method for signature 'PSTf' cplot(object, context, state, main=NULL, all=FALSE, x.by=1, y.by=0.2, by.state=FALSE, ...)
## S4 method for signature 'PSTf' cplot(object, context, state, main=NULL, all=FALSE, x.by=1, y.by=0.2, by.state=FALSE, ...)
object |
A probabilistic suffix tree, i.e., an object of class |
context |
character. Label of the node to plot, provided as a string where states are separated by '-', see examples. |
state |
logical. Under development. |
main |
character. Main title for the plot. By default, the title is the node label. |
all |
logical. |
x.by |
numeric. Interval for the ticks on the x axis (segments). |
y.by |
numeric. Interval for the ticks on the y axis (probability). |
by.state |
logical. If |
... |
arguments to be passed to the plot function or other graphical parameters. |
The cplot()
function displays a single node labelled with context
of the tree where one or mode barplots (if object
is a segmented PST) represent the probability distribution(s) stored in the node. For more details, see Gabadinho 2016.
Alexis Gabadinho
Gabadinho, A. & Ritschard, G. (2016). Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 72(3), pp. 1-39.
data(s1) s1 <- seqdef(s1) S1 <- pstree(s1, L=3) cplot(S1, "a-b")
data(s1) s1 <- seqdef(s1) S1 <- pstree(s1, L=3) cplot(S1, "a-b")
L
Compute the empirical conditional probability distributions of order L from a set of sequences
## S4 method for signature 'stslist' cprob(object, L, cdata=NULL, context, stationary=TRUE, nmin=1, prob=TRUE, weighted=TRUE, with.missing=FALSE, to.list=FALSE)
## S4 method for signature 'stslist' cprob(object, L, cdata=NULL, context, stationary=TRUE, nmin=1, prob=TRUE, weighted=TRUE, with.missing=FALSE, to.list=FALSE)
object |
a sequence object, that is an object of class stslist as created by TraMineR |
L |
integer. Context length. |
cdata |
under development |
context |
character. An optional subsequence (a character string where symbols are separated by '-') for which the conditional probability distribution is to be computed. |
stationary |
logical. If |
nmin |
integer. Minimal frequency of a context. See details. |
prob |
logical. If |
weighted |
logical. If |
with.missing |
logical. If |
to.list |
logical. If |
The empirical conditional probability of observing a symbol
after the subsequence
of length
is computed as
where
is the number of occurrences of the subsequence in the sequence
and
is the concatenation of the subsequence
and the symbol
.
Considering a - possibly weighted - sample of sequences having weights
, the function
is replaced by
where is the
th sequence in the sample. For more details, see Gabadinho 2016.
If stationary=TRUE
a matrix with one row for each subsequence of length and minimal frequency
appearing in
object
. If stationary=FALSE
a list where each element corresponds to one subsequence and contains a matrix whith the probability distribution at each position where a state is preceded by the subsequence.
Alexis Gabadinho
Gabadinho, A. & Ritschard, G. (2016). Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 72(3), pp. 1-39.
## Example with the single sequence s1 data(s1) s1 <- seqdef(s1) cprob(s1, L=0, prob=FALSE) cprob(s1, L=1, prob=TRUE) ## Preparing a sequence object with the SRH data set data(SRH) state.list <- levels(SRH$p99c01) ## sequential color palette mycol5 <- rev(brewer.pal(5, "RdYlGn")) SRH.seq <- seqdef(SRH, 5:15, alphabet=state.list, states=c("G1", "G2", "M", "B2", "B1"), labels=state.list, weights=SRH$wp09lp1s, right=NA, cpal=mycol5) names(SRH.seq) <- 1999:2009 ## Example 1: 0th order: weighted and unweigthed counts cprob(SRH.seq, L=0, prob=FALSE, weighted=FALSE) cprob(SRH.seq, L=0, prob=FALSE, weighted=TRUE) ## Example 2: 2th order: weighted and unweigthed probability distrib. cprob(SRH.seq, L=2, prob=TRUE, weighted=FALSE) cprob(SRH.seq, L=2, prob=TRUE, weighted=TRUE)
## Example with the single sequence s1 data(s1) s1 <- seqdef(s1) cprob(s1, L=0, prob=FALSE) cprob(s1, L=1, prob=TRUE) ## Preparing a sequence object with the SRH data set data(SRH) state.list <- levels(SRH$p99c01) ## sequential color palette mycol5 <- rev(brewer.pal(5, "RdYlGn")) SRH.seq <- seqdef(SRH, 5:15, alphabet=state.list, states=c("G1", "G2", "M", "B2", "B1"), labels=state.list, weights=SRH$wp09lp1s, right=NA, cpal=mycol5) names(SRH.seq) <- 1999:2009 ## Example 1: 0th order: weighted and unweigthed counts cprob(SRH.seq, L=0, prob=FALSE, weighted=FALSE) cprob(SRH.seq, L=0, prob=FALSE, weighted=TRUE) ## Example 2: 2th order: weighted and unweigthed probability distrib. cprob(SRH.seq, L=2, prob=TRUE, weighted=FALSE) cprob(SRH.seq, L=2, prob=TRUE, weighted=TRUE)
Generate sequences using a probabilistic suffix tree
## S4 method for signature 'PSTf' generate(object, l, n, s1, p1, method, L, cnames)
## S4 method for signature 'PSTf' generate(object, l, n, s1, p1, method, L, cnames)
object |
a probabilistic suffix tree, i.e., an object of class |
l |
integer. Length of the sequence(s) to generate. |
n |
integer. Number of the sequence(s) to generate. |
s1 |
character. The first state in the sequences. The length of the vector should equal |
p1 |
numeric. An optional probability vector for generating the first position state in the sequence(s). If specified, the first state in the sequence(s) is randomly generated using the probability distribution in |
method |
character. If |
L |
integer: Maximal depth used to extract the probability distributions from the PST object. |
cnames |
character: Optional column (position) names for the returned state sequence object. By default, the names of the sequence object to which the model was fitted are used (slot "data" of the PST). |
As a probabilistic suffix tree (PST) represents a generating model, it can be used to generate artificial sequence data sets. Sequences are built by generating the states at each successive position. The process is similar to sequence prediction (see predict
), except that the retrieved conditional probability distributions provided by the PST are used to generate a symbol instead of computing the probability of an existing state. For more details, see Gabadinho 2016.
A state sequence object (an object of class stslist
) containing n
sequences. This object can be passed as argument to all the functions for visualization and analysis provided by the TraMineR
package.
Alexis Gabadinho
Gabadinho, A. & Ritschard, G. (2016). Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 72(3), pp. 1-39.
data(s1) s1.seq <- seqdef(s1) S1 <- pstree(s1.seq, L=3) ## Generating 10 sequences generate(S1, n=10, l=10, method="prob") ## First state is generated with p(a)=0.9 and p(b)=0.1 generate(S1, n=10, l=10, method="prob", p1=c(0.9, 0.1))
data(s1) s1.seq <- seqdef(s1) S1 <- pstree(s1.seq, L=3) ## Generating 10 sequences generate(S1, n=10, l=10, method="prob") ## First state is generated with p(a)=0.9 and p(b)=0.1 generate(S1, n=10, l=10, method="prob", p1=c(0.9, 0.1))
Missing states in a set of sequences are imputed by using the probability distributions stored in a probabilistic suffix tree.
## S4 method for signature 'PSTf,stslist' impute(object, data, method="pmax")
## S4 method for signature 'PSTf,stslist' impute(object, data, method="pmax")
object |
a probabilistic suffix tree, i.e., an object of class |
data |
a sequence object, i.e., an object of class |
method |
character. If |
A probabilistic suffix tree (PST) can be used to impute missing states in sequences built on the same alphabet. When a missing state occurs in a sequence the procedure searches in the PST for the context preceding the missing state and impute the state according to the conditional distribution associated with the context. The imputation can be done either randomly (method="prob") or with the state having the highest probability. However, more sophisticated modelling taking account of the non response mechanism could be required for imputing missing states. For more details, see Gabadinho 2016.
A sequence object (of class stslist
) containing original sequences in data
with missing states imputed.
Alexis Gabadinho
Gabadinho, A. & Ritschard, G. Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 2016, 72(3), 1-39.
## Loading the SRH.seq sequence object data(SRH) ## working with a sub-sample of 500 sequences ## to reduce computing time subs <- sample(nrow(SRH.seq), size=500) SRH.sub.seq <- SRH.seq[subs,] ## Learning the model (missing state is not included) SRH.pst.L10 <- pstree(SRH.sub.seq, nmin=2, ymin=0.001) ## Pruning C99 <- qchisq(0.99,5-1)/2 SRH.pst.L10.C99 <- prune(SRH.pst.L10, gain="G2", C=C99) ## Imputing missing values in the SRH sequences SRH.sub.iseq <- impute(SRH.pst.L10, SRH.sub.seq, method="prob") ## locating sequences having missing values ## in sequence object missing states are identified by '*' have.miss <- which(rowSums(SRH.sub.seq=='*')>0) ## plotting non imputed vs imputed sequence ## (first 10 sequences in the set) par(mfrow=c(1,2)) seqiplot(SRH.sub.seq[have.miss,], withlegend=FALSE) seqiplot(SRH.sub.iseq[have.miss,], withlegend=FALSE)
## Loading the SRH.seq sequence object data(SRH) ## working with a sub-sample of 500 sequences ## to reduce computing time subs <- sample(nrow(SRH.seq), size=500) SRH.sub.seq <- SRH.seq[subs,] ## Learning the model (missing state is not included) SRH.pst.L10 <- pstree(SRH.sub.seq, nmin=2, ymin=0.001) ## Pruning C99 <- qchisq(0.99,5-1)/2 SRH.pst.L10.C99 <- prune(SRH.pst.L10, gain="G2", C=C99) ## Imputing missing values in the SRH sequences SRH.sub.iseq <- impute(SRH.pst.L10, SRH.sub.seq, method="prob") ## locating sequences having missing values ## in sequence object missing states are identified by '*' have.miss <- which(rowSums(SRH.sub.seq=='*')>0) ## plotting non imputed vs imputed sequence ## (first 10 sequences in the set) par(mfrow=c(1,2)) seqiplot(SRH.sub.seq[have.miss,], withlegend=FALSE) seqiplot(SRH.sub.iseq[have.miss,], withlegend=FALSE)
Retrieve the log-likelihood of a fitted VLMC. This is the logLik
method for objects of class PSTf
returned by the pstree
and prune
functions.
## S4 method for signature 'PSTf' logLik(object)
## S4 method for signature 'PSTf' logLik(object)
object |
a probabilistic suffix tree, i.e., an object of class |
The likelihood of a learning sample containing sequences, given a model
fitted to it, is
where is the probability of the
th observed sequence predicted by
.
Note that the log-likelihood of a VLMC model is not used in the estimation of the model's parameters (see
pstree
). It is obtained once the model is estimated by calling the predict
function. The value is stored in the logLik
slot of the probabilistic suffix tree representing the model (a PSTf
object returned by the pstree
or prune
function).
The AIC
and BIC
values can also be obtained with the corresponding generic functions, which call logLik
and use its result. For more details, see Gabadinho 2016.
An object of class logLik
, a negative numeric value with the df
(degrees of freedom) attribute containing the number of free parameters of the model.
Alexis Gabadinho
Gabadinho, A. & Ritschard, G. (2016). Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 72(3), pp. 1-39.
## activity calendar for year 2000 ## from the Swiss Household Panel ## see ?actcal data(actcal) ## selecting individuals aged 20 to 59 actcal <- actcal[actcal$age00>=20 & actcal$age00 <60,] ## defining a sequence object actcal.lab <- c("> 37 hours", "19-36 hours", "1-18 hours", "no work") actcal.seq <- seqdef(actcal,13:24,labels=actcal.lab) ## building a PST actcal.pst <- pstree(actcal.seq, nmin=2, ymin=0.001) logLik(actcal.pst) ## Cut-offs for 5% and 1% (see ?prune) C99 <- qchisq(0.99,4-1)/2 ## pruning actcal.pst.C99 <- prune(actcal.pst, gain="G2", C=C99) ## Comparing AIC AIC(actcal.pst, actcal.pst.C99)
## activity calendar for year 2000 ## from the Swiss Household Panel ## see ?actcal data(actcal) ## selecting individuals aged 20 to 59 actcal <- actcal[actcal$age00>=20 & actcal$age00 <60,] ## defining a sequence object actcal.lab <- c("> 37 hours", "19-36 hours", "1-18 hours", "no work") actcal.seq <- seqdef(actcal,13:24,labels=actcal.lab) ## building a PST actcal.pst <- pstree(actcal.seq, nmin=2, ymin=0.001) logLik(actcal.pst) ## Cut-offs for 5% and 1% (see ?prune) C99 <- qchisq(0.99,4-1)/2 ## pruning actcal.pst.C99 <- prune(actcal.pst, gain="G2", C=C99) ## Comparing AIC AIC(actcal.pst, actcal.pst.C99)
The number of observations to which a VLMC model is fitted is notably used for computing the Bayesian information criterion BIC
or the Akaike information criterion with correction for finite sample sizes AICc
.
## S4 method for signature 'PSTf' nobs(object)
## S4 method for signature 'PSTf' nobs(object)
object |
A PST, that is an object of class |
This is the method for the generic nobs
function provided by the stats4
package. The number of observations to which a VLMC model is fitted is the total number of symbols in the learning sample. If the learning sample contains missing values and the model is learned without including missing values (see pstree
), the total number of symbols is the number of non-missing states in the sequence(s). This information is used to compute the Bayesian information criterion of a fitted VLMC model. The BIC
generic function calls the logLik
and nobs
methods for class PSTf
. For more details, see Gabadinho 2016.
An integer containing the number of symbols in the learning sample.
Alexis Gabadinho
Gabadinho, A. & Ritschard, G. (2016). Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 72(3), pp. 1-39.
data(s1) s1.seq <- seqdef(s1) S1 <- pstree(s1.seq, L=3) nobs(S1) ## Self rated health sequences ## Loading the 'SRH' data frame and 'SRH.seq' sequence object data(SRH) ## model without considering missing states ## model with max. order 2 to reduce computing time ## nobs is the same whatever L and nmin m1 <- pstree(SRH.seq, L=2, nmin=30, ymin=0.001) nobs(m1) ## considering missing states, hence nobs is higher m2 <- pstree(SRH.seq, L=2, nmin=30, ymin=0.001, with.missing=TRUE) nobs(m2)
data(s1) s1.seq <- seqdef(s1) S1 <- pstree(s1.seq, L=3) nobs(S1) ## Self rated health sequences ## Loading the 'SRH' data frame and 'SRH.seq' sequence object data(SRH) ## model without considering missing states ## model with max. order 2 to reduce computing time ## nobs is the same whatever L and nmin m1 <- pstree(SRH.seq, L=2, nmin=30, ymin=0.001) nobs(m1) ## considering missing states, hence nobs is higher m2 <- pstree(SRH.seq, L=2, nmin=30, ymin=0.001, with.missing=TRUE) nobs(m2)
Retrieve the node labels of a PST
## S4 method for signature 'PSTf' nodenames(object, L)
## S4 method for signature 'PSTf' nodenames(object, L)
object |
A PST, that is an object of class |
L |
integer. Depth of the tree for which the node names are retrieved. If missing the names of all the nodes in the tree are returned. |
A vector containing the node labels (i.e. contexts).
Alexis Gabadinho
data(s1) s1 <- seqdef(s1) S1 <- pstree(s1, L=3) nodenames(S1, L=3) nodenames(S1)
data(s1) s1 <- seqdef(s1) S1 <- pstree(s1, L=3) nodenames(S1, L=3) nodenames(S1)
Compute probabilistic divergence between two PST
## S4 method for signature 'PSTf,PSTf' pdist(x,y, method="cp", l, ns=5000, symetric=FALSE, output="all")
## S4 method for signature 'PSTf,PSTf' pdist(x,y, method="cp", l, ns=5000, symetric=FALSE, output="all")
x |
a probabilistic suffix tree, i.e., an object of class |
y |
a probabilistic suffix tree, i.e., an object of class |
method |
character. Method for computing distances. So far only one method is available. |
l |
integer. Length of the sequence(s) to generate. |
ns |
integer. Number sequences to generate. |
symetric |
logical. If |
output |
character. See |
The function computes a probabilistic divergence measure between PST and
based on the measure originally proposed in Juang-1985 and Rabiner-1989 for the comparison of two (hidden) Markov models
and
where is a sequence generated by model
,
is the probability of
given model
and
is the probability of
given model
. The ratio between the two sequence likelihoods measures how many times the sequence
is more likely to have been generated by
than by
.
As the number of generated sequences on which the measure is computed (or the length of a single sequence) approaches infinity, the expected value of
converges to
Falkhausen-1995, He-2000, the Kullback-Leibler (KL) divergence (also called information gain) used in information theory to measure the difference between two probability distributions.
The pdist
function uses the following procedure to compute the divergence between two PST:
generate a ransom sample of sequences (of length
) with model
using the
generate
method
predict the sequences with and with
compute
the expected value
is the divergence between models and
and is estimated as
For more details, see Gabadinho 2016.
If ouput="all"
, a vector containing the divergence value for each generated sequence, if output="mean"
, the mean, i.e. expected value which is the divergence between models.
Alexis gabadinho
Gabadinho, A. & Ritschard, G. (2016). Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 72(3), pp. 1-39.
Juang, B. H. and Rabiner, L. R. (1985). A probabilistic distance measure for hidden Markov models. ATT Technical Journal, 64(2), pp. 391-408.
Rabiner, L. R. (1989). A tutorial on hidden Markov models and selected applications in speech recognition. Proceedings of the IEEE, 77(2), pp. 257-286.
## activity calendar for year 2000 ## from the Swiss Household Panel ## see ?actcal data(actcal) ## selecting individuals aged 20 to 59 actcal <- actcal[actcal$age00>=20 & actcal$age00 <60,] ## defining a sequence object actcal.lab <- c("> 37 hours", "19-36 hours", "1-18 hours", "no work") actcal.seq <- seqdef(actcal,13:24,labels=actcal.lab) ## building a PST segmented by age group gage10 <- cut(actcal$age00, c(20,30,40,50,60), right=FALSE, labels=c("20-29","30-39", "40-49", "50-59")) actcal.pstg <- pstree(actcal.seq, nmin=2, ymin=0.001, group=gage10) ## pruning C99 <- qchisq(0.99,4-1)/2 actcal.pstg.opt <- prune(actcal.pstg, gain="G2", C=C99) ## extracting PST for age group 20-39 and 30-39 g1.pst <- subtree(actcal.pstg.opt, group=1) g2.pst <- subtree(actcal.pstg.opt, group=2) ## generating 5000 sequences with g1.pst ## and computing 5000 distances dist.g1_g2 <- pdist(g1.pst, g2.pst, l=11) hist(dist.g1_g2) ## the probabilistic distance is the mean ## of the 5000 distances mean(dist.g1_g2)
## activity calendar for year 2000 ## from the Swiss Household Panel ## see ?actcal data(actcal) ## selecting individuals aged 20 to 59 actcal <- actcal[actcal$age00>=20 & actcal$age00 <60,] ## defining a sequence object actcal.lab <- c("> 37 hours", "19-36 hours", "1-18 hours", "no work") actcal.seq <- seqdef(actcal,13:24,labels=actcal.lab) ## building a PST segmented by age group gage10 <- cut(actcal$age00, c(20,30,40,50,60), right=FALSE, labels=c("20-29","30-39", "40-49", "50-59")) actcal.pstg <- pstree(actcal.seq, nmin=2, ymin=0.001, group=gage10) ## pruning C99 <- qchisq(0.99,4-1)/2 actcal.pstg.opt <- prune(actcal.pstg, gain="G2", C=C99) ## extracting PST for age group 20-39 and 30-39 g1.pst <- subtree(actcal.pstg.opt, group=1) g2.pst <- subtree(actcal.pstg.opt, group=2) ## generating 5000 sequences with g1.pst ## and computing 5000 distances dist.g1_g2 <- pdist(g1.pst, g2.pst, l=11) hist(dist.g1_g2) ## the probabilistic distance is the mean ## of the 5000 distances mean(dist.g1_g2)
Plot a PST
## S4 method for signature 'PSTf,ANY' plot(x, y=missing, max.level=NULL, nodePar = list(), edgePar = list(), axis=FALSE, xlab = NA, ylab = if (axis) { "L" } else {NA}, horiz = FALSE, xlim, ylim, withlegend=TRUE, ltext=NULL, cex.legend=1, use.layout=withlegend!=FALSE, legend.prop=NA, ...)
## S4 method for signature 'PSTf,ANY' plot(x, y=missing, max.level=NULL, nodePar = list(), edgePar = list(), axis=FALSE, xlab = NA, ylab = if (axis) { "L" } else {NA}, horiz = FALSE, xlim, ylim, withlegend=TRUE, ltext=NULL, cex.legend=1, use.layout=withlegend!=FALSE, legend.prop=NA, ...)
x |
A PST, that is an object of class |
y |
not applicable |
max.level |
integer. The maximal depth for the display of the tree. |
nodePar |
list. A list of parameters for tuning the node representation. Possible parameters are
|
edgePar |
list. A list of parameters for tuning the edges representation. Possible paramters are |
axis |
logical. If TRUE the axes are displayed on the plot. |
xlab |
character. Label for the x axis. |
ylab |
character. Label for the y axis representing the tree depth. |
horiz |
logical. If FALSE, the tree is represented vertically. The root node at depth L=0 is plotted on the top, and the nodes of maximal depth are plotted on the bottom of the plot. If TRUE, the tree is represented horizontally. The root node at depth L=0 is plotted on the right, and the nodes of maximal depth are plotted on the left of the plot. |
xlim |
numeric. Vector of length 2 giving the x limits for the plot. By default the limits are 1 .. number of terminal nodes (at max.level if specified). This may be usefull to facilitate comparison if several trees are plotted on the same figure. |
ylim |
numeric. Vector of length 2 giving the y limits for the plot. By default the limits are 0 .. max. depth of the tree (max.level if specified). This may be usefull to facilitate comparison if several trees are plotted on the same figure. |
withlegend |
defines if and where the legend of the state colors is plotted. The default value |
ltext |
optional description of the states to appear in the legend. Must be a vector of character strings with number of elements equal to the size of the alphabet. If unspecified, the |
cex.legend |
expansion factor for setting the size of the font for the labels in the legend. The default value is 1. Values lesser than 1 will reduce the size of the font, values greater than 1 will increase the size. |
use.layout |
if |
legend.prop |
sets the proportion of the graphic area used for plotting the legend when |
... |
arguments to be passed to the plot function or graphical parameters |
The function for graphical representation of a PST uses is recursive. The main argument of the function is a tree represented as a nested list (an object of class PSTr
). See also Gabadinho 2016.
Alexis Gabadinho, based on code from plot.dendrogram
Gabadinho, A. & Ritschard, G. (2016). Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 72(3), pp. 1-39.
data(s1) s1 <- seqdef(s1) S1 <- pstree(s1, L=3) plot(S1) plot(S1, horiz=TRUE) plot(S1, nodePar=list(node.type="path", lab.type="prob", lab.pos=1, lab.offset=2, lab.cex=0.7), edgePar=list(type="triangle"), withlegend=FALSE)
data(s1) s1 <- seqdef(s1) S1 <- pstree(s1, L=3) plot(S1) plot(S1, horiz=TRUE) plot(S1, nodePar=list(node.type="path", lab.type="prob", lab.pos=1, lab.offset=2, lab.cex=0.7), edgePar=list(type="triangle"), withlegend=FALSE)
Mine for (sub)sequences satisfying user defined criteria in a state sequence object
## S4 method for signature 'PSTf,stslist' pmine(object, data, l, pmin=0, pmax=1, prefix, lag, average=FALSE, output="sequences", with.prefix=TRUE, sorted=TRUE, decreasing=TRUE, score.norm=FALSE)
## S4 method for signature 'PSTf,stslist' pmine(object, data, l, pmin=0, pmax=1, prefix, lag, average=FALSE, output="sequences", with.prefix=TRUE, sorted=TRUE, decreasing=TRUE, score.norm=FALSE)
object |
A fitted PST, that is an object of class PSTf as returned by the |
data |
A sequence object of class 'stslist' as defined with the |
l |
integer. Length of the subsequence to search for. |
pmin |
numeric. (Sub)-sequences having average or per state probability greater or equal than |
pmax |
numeric. (Sub)-sequences having average or per state probability less or equal than |
prefix |
character. Subsequences are searched in sequences starting with |
lag |
integer. The |
average |
logical. If |
output |
character. If |
with.prefix |
logical. If |
sorted |
logical. If |
decreasing |
logical. If |
score.norm |
logical. If |
The likelihood of a whole sequence
is computed from the state probabilities at each position in the sequence. However, the likelihood of the first states is usually lower than at higher position due to a reduced memory available for prediction. A sequence may not appear as very likely if its first state has a low relative frequency, even if the model predicts high probabilities for the states at higher positions.
The pmine
function allows for advanced pattern mining with user defined parameters. It is controlled by the lag
and pmin
arguments. For example, by setting lag=2
and pmin=0.40
(example 1), we select all sequences with average (the geometric mean is used) state probability from position above
pmin
. Instead of considering the average state probability at positions , it is also possible to select frequent patterns that do not contain any state with probability below the threshold. This prevents from selecting sequences having many states with high probability but one ore several states with a low probability.
It is also possible to mine the sequence data for frequent patterns of length , regardless of the position in the sequence where they occur. By using the
output="patterns"
argument, the pmine
function returns the patterns (as a sequence object) instead of the whole set of distinct sequences containing the patterns. Since the probability of a pattern can be different depending on the context (previous states) the returned subsequences also contain the context preceding the pattern. For more details, see Gabadinho 2016.
A state sequence object, that is an object of class stslist
, where weights are the probability score of (sub)sequences.
Alexis Gabadinho
Gabadinho, A. & Ritschard, G. (2016). Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 72(3), pp. 1-39.
cmine
for context mining
## activity calendar for year 2000 ## from the Swiss Household Panel ## see ?actcal data(actcal) ## selecting individuals aged 20 to 59 actcal <- actcal[actcal$age00>=20 & actcal$age00 <60,] ## defining a sequence object actcal.lab <- c("> 37 hours", "19-36 hours", "1-18 hours", "no work") actcal.seq <- seqdef(actcal,13:24,labels=actcal.lab) ## building a PST actcal.pst <- pstree(actcal.seq, nmin=2, ymin=0.001) ## pruning ## Cut-offs for 5% and 1% (see ?prune) C99 <- qchisq(0.99,4-1)/2 actcal.pst.C99 <- prune(actcal.pst, gain="G2", C=C99) ## example 1 pmine(actcal.pst.C99, actcal.seq, pmin=0.4, lag=2) ## example 2: patterns of length 6 having p>=0.6 pmine(actcal.pst.C99, actcal.seq, pmin=0.6, l=6)
## activity calendar for year 2000 ## from the Swiss Household Panel ## see ?actcal data(actcal) ## selecting individuals aged 20 to 59 actcal <- actcal[actcal$age00>=20 & actcal$age00 <60,] ## defining a sequence object actcal.lab <- c("> 37 hours", "19-36 hours", "1-18 hours", "no work") actcal.seq <- seqdef(actcal,13:24,labels=actcal.lab) ## building a PST actcal.pst <- pstree(actcal.seq, nmin=2, ymin=0.001) ## pruning ## Cut-offs for 5% and 1% (see ?prune) C99 <- qchisq(0.99,4-1)/2 actcal.pst.C99 <- prune(actcal.pst, gain="G2", C=C99) ## example 1 pmine(actcal.pst.C99, actcal.seq, pmin=0.4, lag=2) ## example 2: patterns of length 6 having p>=0.6 pmine(actcal.pst.C99, actcal.seq, pmin=0.6, l=6)
The ppplot
function displays the probability distributions of a node and all its parent nodes (suffixes) in the tree. IF the name of a gain function and a vector of pruning cutoffs are provided, the graphic will display the outcomes of the gain function, i.e., whether a node represents an information gain relative to its parent.
## S4 method for signature 'PSTf' ppplot(object, path, gain, C, cex.plot = 1, nsize = 0.3, nlab=TRUE, psize = nsize/2, pruned.col = "red", div.col = "green", ...)
## S4 method for signature 'PSTf' ppplot(object, path, gain, C, cex.plot = 1, nsize = 0.3, nlab=TRUE, psize = nsize/2, pruned.col = "red", div.col = "green", ...)
object |
a probabilistic suffix tree, i.e., an object of class |
path |
character. Either a character string representing the node label (i.e., the context) where symbols are separated by '-', or a vector where each element is a symbol. See example. |
gain |
character or function. Gain function, see |
C |
numeric. Value of the cutoff used by the gain function, see |
cex.plot |
numeric. Expansion factor for setting the size of the font for the axis labels and names. The default value is 1. Values lesser than 1 will reduce the size of the font, values greater than 1 will increase the size. |
nsize |
numeric. Size of the circles representing the nodes. |
nlab |
logical. Should the node label be displayed inside the circle? |
psize |
numeric. Size of the circles representing the outcome of the gain function. |
pruned.col |
character. Color used to represent a terminal node which provides no information gain relative to its parent. |
div.col |
character. Color used to represent an internal node which provides information gain relative to its parent. |
... |
additional parameters to be passed to the |
For more details, see Gabadinho 2016.
Alexis Gabadinho
Gabadinho, A. & Ritschard, G. (2016). Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 72(3), pp. 1-39.
data(s1) s1.seq <- seqdef(s1) S1 <- pstree(s1.seq, L=5, ymin=0.001) ppplot(S1, "a-a-b-b-a", gain="G1", C=c(1.1, 1.2))
data(s1) s1.seq <- seqdef(s1) S1 <- pstree(s1.seq, L=5, ymin=0.001) ppplot(S1, "a-a-b-b-a", gain="G1", C=c(1.1, 1.2))
Plot the predicted probability of each state in a sequence
## S4 method for signature 'PSTf,stslist' pqplot(object, data, cdata, L, stcol, plotseq=FALSE, ptype="b", cex.plot=1, space=0, measure="prob", pqmax, seqscale, ...)
## S4 method for signature 'PSTf,stslist' pqplot(object, data, cdata, L, stcol, plotseq=FALSE, ptype="b", cex.plot=1, space=0, measure="prob", pqmax, seqscale, ...)
object |
a probabilistic suffix tree, i.e., an object of class |
data |
a sequence object, i.e., an object of class |
cdata |
Not implemented yet. |
L |
integer. Maximal context length for sequence prediction. This is the same as pruning the PST by removing all nodes of depth<L before prediction. |
stcol |
character. Color to use to plot the prediction qualities. |
plotseq |
logical. If TRUE, the sequence is displayed separately, and the prediction plot is plotted above. |
ptype |
character. Type of plot, either |
cex.plot |
numeric. Expansion factor for setting the size of the font for the axis labels and names. The default value is 1. Values lesser than 1 will reduce the size of the font, values greater than 1 will increase the size. |
space |
numeric. Space separating each state in the plot. |
measure |
character. Measure used for prediction quality. Either |
pqmax |
numeric. Maximum coordinate for the prediction quality plot, i.e. the max of the y axis. |
seqscale |
numeric. If |
... |
optional graphical parameters to be passed to the plot function. |
The pqplot()
function displays either the predicted probabilities or the log-loss for each position of a single sequence as a series of barplots. For more details, see Gabadinho 2016.
Alexis Gabadinho
Gabadinho, A. & Ritschard, G. (2016) Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 72(3), 1-39.
data(s1) s1 <- seqdef(s1) S1 <- pstree(s1, L=3) z <- seqdef("a-b-a-a-b") pqplot(S1, z) pqplot(S1, z, measure="logloss", plotseq=TRUE)
data(s1) s1 <- seqdef(s1) S1 <- pstree(s1, L=3) z <- seqdef("a-b-a-a-b") pqplot(S1, z) pqplot(S1, z, measure="logloss", plotseq=TRUE)
Compute the probability (likelihood) of categorical sequences using a Probabilistic Suffix Tree
## S4 method for signature 'PSTf' predict(object, data, cdata, group, L=NULL, p1=NULL, output="prob", decomp=FALSE, base=2)
## S4 method for signature 'PSTf' predict(object, data, cdata, group, L=NULL, p1=NULL, output="prob", decomp=FALSE, base=2)
object |
a probabilistic suffix tree, i.e., an object of class |
data |
a sequence object, i.e., an object of class |
cdata |
not implemented yet. |
group |
if |
L |
integer. Maximal context length for sequence prediction. This is the same as pruning the PST by removing all nodes of depth<L before prediction. |
p1 |
vector. A probability distribution for the first position in the sequence that will be used instead of the root node of the tree. |
output |
character. One of |
decomp |
logical. If |
base |
integer. Base for the logarithm if a logarithm is used in the used prediction measure. |
A probabilistic suffix tree (PST) allows to compute the likelihood of any sequence built on the alphabet of the learning sample. This feature is called sequence prediction. The likelihood of the sequence a-b-a-a-b
given a PST S1
fitted to the example sequence s1
(see example) is
The probability of each of the state is retrieved from the PST. To get for example P(a|a-b-a)
, the tree is scanned for the node labelled with the string a-b-a
, and if this node does not exist, it is scanned for the node labelled with the longest suffix of this string, that is b-a
, and so on. The node a-b-a
is not found in the tree (it has been removed during the pruning stage), and the longest suffix of a-b-a
found is b-a
. The probability P(a|b-a)
is then used instead of P(a|a-b-a)
.
The sequence likelihood is returned by the predict
function. By setting decomp=TRUE
the output is a matrix containing the probability of each of the symbol composing the sequence. The score of a sequence
represents the probability that the VLMC model stored by the PST
generates
. It can be turned into a more readable prediction quality measure such as the average log-loss
by using 'output=logloss'
.
The returned value is the average log-loss of each state in the sequence, which allows to compare the prediction for sequences of unequal lengths. The average log-loss can be interpreted as a residual, that is the distance between the prediction of a sequence by a PST and the perfect prediction
yielding
. The lower the value of
the better the sequence is predicted. For more details, see Gabadinho 2016.
Either a vector of sequence probabilities (decomp=FALSE) or a matrix (if decomp=FALSE) containing for each sequence (row) the probability of each state in columns.
Alexis Gabadinho
Gabadinho, A. & Ritschard, G. (2016) Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 72(3), 1-39.
data(s1) s1 <- seqdef(s1) S1 <- pstree(s1, L=3, nmin=2, ymin=0.001) S1 <- prune(S1, gain="G1", C=1.20, delete=FALSE) predict(S1, s1, decomp=TRUE) predict(S1, s1)
data(s1) s1 <- seqdef(s1) S1 <- pstree(s1, L=3, nmin=2, ymin=0.001) S1 <- prune(S1, gain="G1", C=1.20, delete=FALSE) predict(S1, s1, decomp=TRUE) predict(S1, s1)
PSTf
and PSTr
Display a probabilistic suffix tree
## S4 method for signature 'PSTr' print(x, max.level = NULL, digits = 1, give.attr = FALSE, nest.lev = 0, indent.str = "", stem = "--")
## S4 method for signature 'PSTr' print(x, max.level = NULL, digits = 1, give.attr = FALSE, nest.lev = 0, indent.str = "", stem = "--")
x |
A PST, that is an object of class |
max.level |
integer. The maximal depth for the display of the tree. |
digits |
integer specifying the precision for printing. |
give.attr |
logical. If |
nest.lev |
integer. Parameter used internally by the function. |
indent.str |
character. String used to indent each line when displaying the tree. Default to ”. |
stem |
character. String used to display the stems. Default to '–'. |
signature(x = "ANY")
signature(x = "PSTf")
signature(x = "PSTr")
Prune a PST, using either a gain function, a maximal depth or a list of nodes to keep or remove. Optionally, nodes are not removed from the tree but tagged as deleted, helping to visualize the pruning process.
## S4 method for signature 'PSTf' prune(object, nmin, L, gain, C, keep, drop, state, delete = TRUE, lik =TRUE)
## S4 method for signature 'PSTf' prune(object, nmin, L, gain, C, keep, drop, state, delete = TRUE, lik =TRUE)
object |
a probabilistic suffix tree, i.e., an object of class |
nmin |
integer. All strings having counts less than nmin are removed. |
L |
integer. If specified the the tree is cut at depth L., that is all nodes with depth > L are removed. |
gain |
character. Function for measuring information gain. See |
C |
numeric. Cutoff value to use with the gain function |
keep |
character. A vector of character strings containing the names of the nodes to keep in the tree. All nodes that are not a suffix of contexts in keep are removed from the tree. |
drop |
character. A vector of character strings containing the names of the nodes to remove from the tree. All nodes that are a suffix of contexts in drop are removed from the tree as weel. |
state |
character. All nodes corresponding to contexts which include |
delete |
Logical. If FALSE, the pruned nodes are not removed from the tree but tagged as pruned=FALSE, so that when plotting the pruned tree these nodes wil appear surrounded with red (can be set to another color) lines. |
lik |
Logical. If TRUE, the log-likelihood of the pruned model, i.e. the likelihood of the training sequences given the model, is computed and stored in the 'logLik' slot of the PST. Setting to FALSE will spare the time required to compute the likelihood. |
The initial tree returned by the pstree
function may yield an overly complex model containing all contexts of maximal length and frequency
found in the learning sample. The pruning stage potentially reduces the number of nodes in the tree, and thus the model complexity. It compares the conditional probabilities associated to a node labelled by a subsequence
to the conditional probabilities of its parent node labelled by the longest suffix of
,
. The general idea is to remove a node if it does not contribute additional information with respect to its parent in predicting the next symbol, that is if
is not significantly different from
for all
.
The pruning procedure starts from the terminal nodes and is applied recursively until all terminal nodes remaining in the tree represent an information gain relative to their parent.
A gain function, whose outcome will determine the pruning decision, is used to compare the two probability distributions. The gain function is driven by a cut-off, and different values of this parameter will yield more or less complex trees. A method for selecting the pruning cut-off is described in the tune
help page.
A first implemented gain function, which is used by the Learn-PSA algorithm, is based on the ratio between and
for each
. A node represents an information gain if for any symbol
the ratio is greater than the cut-off
or lower than
, that is if
where is a user defined cut-off value. Nodes that do not satisfy the above condition are pruned. For
no node is removed since even a node having a next probability distribution similar to the one of its parent does not satisfy the pruning condition.
The context algorithm uses another gain function, namely
where is the context labelling the terminal node,
is the number of occurrences of
in the data. The cutoff
is specified on the scale of
-quantiles Maechler-2004
where is the quantile function of a
distribution with
degrees of freedom. The cutoff
is a threshold for the difference of deviances between a tree
and its subtree
obtained by pruning the terminal node
. Typical values for
are
and
, yielding
and
respectively. For more details, see Gabadinho 2016.
A probabilistic suffix tree, i.e., an object of class PSTf
.
Alexis Gabadinho
Bejerano, G. & Yona, G. (2001). Variations on probabilistic suffix trees: statistical modeling and prediction of protein families. Bioinformatics, 17, pp. 23-43.
Gabadinho, A. & Ritschard, G. (2016). Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 72(3), pp. 1-39.
Maechler, M. & Buehlmann, P. (2004). Variable Length Markov Chains: Methodology, Computing, and Software Journal of Computational and Graphical Statistics, 13, pp. 435-455.
Ron, D.; Singer, Y. & Tishby, N. (1996). The power of amnesia: Learning probabilistic automata with variable memory length Machine Learning, 25, pp. 117-149.
data(s1) s1.seq <- seqdef(s1) S1 <- pstree(s1.seq, L=3, nmin=2, ymin=0.001) ## -- S1.p1 <- prune(S1, gain="G1", C=1.20, delete=FALSE) summary(S1.p1) plot(S1.p1) ## -- C95 <- qchisq(0.95,1)/2 S1.p2 <- prune(S1, gain="G2", C=C95, delete=FALSE) plot(S1.p2)
data(s1) s1.seq <- seqdef(s1) S1 <- pstree(s1.seq, L=3, nmin=2, ymin=0.001) ## -- S1.p1 <- prune(S1, gain="G1", C=1.20, delete=FALSE) summary(S1.p1) plot(S1.p1) ## -- C95 <- qchisq(0.95,1)/2 S1.p2 <- prune(S1, gain="G2", C=C95, delete=FALSE) plot(S1.p2)
The class "PSTf"
is the flat representation of a probabilistic suffix tree (PST) storing a variable length Markov chain model. The flat representation is a list where each element corresponds to a given depth. It is the prefered representation and is used by all functions for model fitting and sequence analysis with PST. The nested representation "PSTr"
is used only for printing and plotting PSTs.
Objects of class "PSTf"
are returned by the pstree
, prune
and tune
function.
.Data
:Object of class "list"
, a list where each element corresponds to one level of the tree and is itself a list of nodes, i.e., objects of class "PSTr"
.
data
:Object of class "stslist"
. The learning sample to which the PST is fitted, i.e., a sequence object created with the seqdef
function.
cdata
:Object of class "stslist"
alphabet
:Object of class "character"
. Alphabet on which the sequences, and the PST are built.
labels
:Object of class "character"
containing the long state labels.
cpal
:Object of class "character"
. Color palette used to represent each state of the alphabet.
segmented
:Object of class "logical"
indicating whether the tree is segmented. See pstree
.
group
:Object of class "factor"
containing the group membership for each sequence in data
.
call
:Object of class "call"
.
logLik
:Object of class "numeric"
, containing the log-likelihood of the VLMC model represented by the PST.
Class "list"
, from data part.
Class "vector"
, by class "list", distance 2.
signature(object = "PSTf")
: context mining, see cmine,PSTf-method
.
signature(object = "PSTf")
: plot single nodes of a PST, see cplot,PSTf-method
.
signature(object = "PSTf")
: generate artificial sequences, see generate,PSTf-method
.
signature(object = "PSTf", data = "stslist")
: impute missing values in sequence data, seeimpute,PSTf,stslist-method
.
signature(object = "PSTf")
: extract log-likelihood of the VLMC model represented by a PST, see logLik,PSTf-method
.
signature(object = "PSTf")
: number of observations (symbols) in the learning sample to which a VLMC model is fitted, see nobs,PSTf-method
.
signature(object = "PSTf")
: retrieve the node labels of a PST, see see nodenames,PSTf-method
.
signature(x = "PSTf", y = "PSTf")
: compute probabilistic divergence between two PSTs, see pdist,PSTf,PSTf-method
.
signature(x = "PSTf", y = "ANY")
: plot a PST, see plot,PSTf,ANY-method
.
signature(object = "PSTf", data = "stslist")
: pattern mining, see see pmine,PSTf,stslist-method
.
signature(object = "PSTf")
: plotting a branch of a PST, see ppplot,PSTf-method
.
signature(object = "PSTf", data = "stslist")
: plot the predicted probability of each state in a sequence, see pqplot,PSTf,stslist-method
.
signature(object = "PSTf")
: predict the likelihood of sequences, see predict,PSTf-method
.
signature(x = "PSTf")
: print a PST, see print,PSTf-method
.
signature(object = "PSTf")
: prune a PST, see prune,PSTf-method
.
signature(object = "PSTf")
: retrieve counts or next symbol probability distribution from a node in a Probabilistic Suffix Tree, see query,PSTf-method
.
signature(object = "PSTf")
: extract a subtree from a segmented PST, see subtree,PSTf-method
.
signature(object = "PSTf")
: see summary,PSTf-method
.
signature(object = "PSTf")
: AIC, AICc and BIC based model selection, see tune,PSTf-method
.
Alexis Gabadinho
showClass("PSTf")
showClass("PSTf")
An object of class "PSTr"
is a node of a probabilistic suffix tree (PST). The slot prob
contains one or several probability distributions (if the PST is segmented) and the slot counts
contains the empirical - possibly weighted - counts from which the probabilities are computed. The slot leaf
indicates whether the node (segment) is a terminal node (segment).
The 'flat' representation of a PST is an object of class "PSTf"
), that is a list that contains one element for each level of the tree. Each element of the list is itself a list whose elements are nodes, that is objects of class PSTr
.
The 'nested' representation of a probabilistic suffix tree (PST) is a nested list whose elements are children nodes of class "PSTr"
. This representation is used for printing and plotting PST, in which case the flat representation of a PST, i.e., an object of class "PSTf"
is turned into an object of class "PSTr"
by using the as
function.
Objects are created when calling the pstree
function.
.Data
:Object of class "list"
. In the nested representation of a PST, the elements of the list are the children nodes. Otherwise the list is empty.
alphabet
:Object of class "character"
. Alphabet on which the sequences, and the PST are built. This slot is non-empty only for the root node of the nested representation of a PST.
labels
:Object of class "character"
containing the long state labels. This slot is non-empty only for the root node of the nested representation of a PST.
cpal
:Object of class "character"
. Color palette used to represent each state of the alphabet. This slot is non-empty only for the root node of the nested representation of a PST.
index
:Object of class "matrix"
. When the PST is segmented, indicates the id of the segment corresponding to each group.
counts
:Object of class "matrix"
. The counts to which the probability distributions are computed.
n
:Object of class "matrix"
. The number of occurrences of the context in the learning sample, see cprob
.
prob
:Object of class "matrix"
. The probability distributions computed from the counts.
path
:Object of class "character"
. The node label, i.e. the context which is the path from the node to the root node of the tree.
order
:Object of class "integer"
. The depth of the node in the tree, i.e., the order of the probability distribution(s) stored in the node.
leaf
:Object of class "matrix"
. Indicates whether the node (segment) is a terminal node (segment).
pruned
:Object of class "matrix"
. If the PST was pruned with the delete=FALSE
option, indicates whether the node (segment) is actually pruned. See prune
.
Class "list"
, from data part.
Class "vector"
, by class "list", distance 2.
signature(x = "PSTr")
: extract sub-branches of a nested representation of a PST.
signature(x = "PSTr", y = "ANY")
: plot a PST, see plot,PSTr,ANY-method
.
signature(x = "PSTr")
: print a PST, see print,PSTr-method
.
signature(object = "PSTr")
: see summary,PSTr-method
.
Alexis Gabadinho
showClass("PSTr")
showClass("PSTr")
Build a probabilistic suffix tree that stores a variable length Markov chain (VLMC) model
## S4 method for signature 'stslist' pstree(object, group, L, cdata=NULL, stationary=TRUE, nmin = 1, ymin=NULL, weighted = TRUE, with.missing = FALSE, lik = TRUE)
## S4 method for signature 'stslist' pstree(object, group, L, cdata=NULL, stationary=TRUE, nmin = 1, ymin=NULL, weighted = TRUE, with.missing = FALSE, lik = TRUE)
object |
a sequence object, i.e., an object of class |
group |
a vector giving the group membership for each observation in x. If specified, a segmented PST is produced containing one PST for each group. |
cdata |
Not implemented yet. |
stationary |
Not implemented yet. |
L |
Integer. Maximal depth of the PST. Default to maximum length of the sequence(s) in object minus 1. |
nmin |
Integer. Minimum number of occurences of a string to add it in the tree |
ymin |
Numeric. Smoothing parameter for conditional probabilities, assuring that no symbol, and hence no sequence, is predicted to have a null probability. The parameter $ymin$ sets a lower bound for a symbol's probability. |
weighted |
Logical. If TRUE, weights attached to the sequence object are used in the estimation of probabilities. |
with.missing |
Logical. If TRUE, the missing state is added to the alphabet |
lik |
Logical. If TRUE, the log-likelihood of the model, i.e. the likelihood of the training sequences given the model, is computed and stored in the 'logLik' slot of the PST. Setting to FALSE will spare the time required to compute the likelihood. |
A probabilistic suffix tree (PST) is built from a learning sample of sequences by successively adding nodes labelled with subsequences (contexts)
of length
found in the data. When the value
is not defined by the user it is set to its theorectical maximum
where
is the maximum sequence length in the learning sample. The
nmin
argument specifies the minimum frequency of a subsequence required to add it to te tree.
Each node of the tree is labelled with a context and stores the next symbol empirical probability distribution
, where
is an alphabet of finite size. The root node labelled with the empty string
stores the
order probability
of oberving each symbol of the alphabet in the whole learning sample.
The building algorithm calls the cprob
function which returns the empirical next symbol counts observed after each context and computes the corresponding empirical probability distribution. Each node in the tree is connected to its longest suffix, where the longest suffix of a string
of length
is
.
Once an initial PST is built it can be pruned to reduce its complexity by removing nodes that do not provide significant information (see prune
). A model selection procedure based on information criteria is also available (see tune
). For more details, see Gabadinho 2016.
An object of class "PSTf"
.
Alexis Gabadinho
Bejerano, G. & Yona, G. (2001) Variations on probabilistic suffix trees: statistical modeling and prediction of protein families. Bioinformatics 17, 23-43.
Gabadinho, A. & Ritschard, G. (2016) Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software 72(3), 1-39.
Maechler, M. & Buehlmann, P. (2004) Variable Length Markov Chains: Methodology, Computing, and Software. Journal of Computational and Graphical Statistics 13, pp. 435-455.
Ron, D.; Singer, Y. & Tishby, N. (1996) The power of amnesia: Learning probabilistic automata with variable memory length. Machine Learning 25, 117-149.
## Build a PST on one single sequence data(s1) s1.seq <- seqdef(s1) s1.seq S1 <- pstree(s1.seq, L = 3) print(S1, digits = 3) S1
## Build a PST on one single sequence data(s1) s1.seq <- seqdef(s1) s1.seq S1 <- pstree(s1.seq, L = 3) print(S1, digits = 3) S1
Retrieve counts or next symbol probability distribution from a node of a probabilistic suffix tree
## S4 method for signature 'PSTf' query(object, context, state, output = "prob", exact = FALSE)
## S4 method for signature 'PSTf' query(object, context, state, output = "prob", exact = FALSE)
object |
A probabilistic suffix tree, i.e an object of class |
context |
Character. The string labelling the node to retrieve. States must be separated by '-' as for example in 'a-a-b'. If the node labelled with this string does not exist in the tree, the node labelled with the longest suffix is searched for, and so on until an existing node is found. |
state |
character. If specified the probability of the specified state is returned instead of the whole distribution. |
output |
character. If output="prob" the probability distribution (or a single symbol distribution if state is specified) is returned. If output="counts" the counts on which the probability distribution is calculated are returned. If output="all" the node itself is returned, that is an object of class PSTr. |
exact |
logical. If TRUE, the information is returned only if the node labelled with context is present in the tree. That is, the longest suffix of context is not searched for if context is not in the tree. |
The PST is searched for the node labelled with context
. If exact=FALSE
, when the node does not exist the PST is searched for the longest suffix of context
, and so on until a node corresponding to a suffix of context
is found or the root node is reached. For more details, see Gabadinho 2016.
An object of class cprobd
, with available round
method.
Alexis Gabadinho
Gabadinho, A. & Ritschard, G. (2016). Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 72(3), pp. 1-39.
data(s1) s1 <- seqdef(s1) S1 <- pstree(s1, L=3) ## Retrieving from the node labelled 'a-a-a' query(S1, "a-a-a") ## The node 'a-b-b-a' is not presetnin the tree, and the next symbol ## probability is retrieved from the node labelled 'b-b-a' (the longest ## suffix query(S1, "a-b-b-a")
data(s1) s1 <- seqdef(s1) S1 <- pstree(s1, L=3) ## Retrieving from the node labelled 'a-a-a' query(S1, "a-a-a") ## The node 'a-b-b-a' is not presetnin the tree, and the next symbol ## probability is retrieved from the node labelled 'b-b-a' (the longest ## suffix query(S1, "a-b-b-a")
Example data set containing one single sequence
data(s1)
data(s1)
A character string representing a sequence of 27 symbols separated with '-'.
A sequence object can be created with the dedicated TraMineR
seqdef
function. State sequence objects are the main argument for the pstree
method that creates probabilistic suffix trees. See example below.
## Loading the data data(s1) ## Creating a state sequence object s1.seq <- seqdef(s1) ## Building and plotting a PST S1 <- pstree(s1.seq, L = 3) plot(S1)
## Loading the data data(s1) ## Creating a state sequence object s1.seq <- seqdef(s1) ## Building and plotting a PST S1 <- pstree(s1.seq, L = 3) plot(S1)
Longitudinal data on self rated health from waves 1-11 of the Swiss household panel
data(SRH)
data(SRH)
SRH
is a data frame with 2612 observations on the following 15 variables.
idpers
personal identification number
sex
a factor with levels man
woman
birthy
birth year of the respondent
wp09lp1s
longitudinal weight
p99c01
... p09c01
factors with levels: very well; well; so, so (average); not very well; not well at all
SRH.seq
is a TraMineR
sequence object created from the SRH
data frame using the code in example
. States are coded as follows:
G1 |
(very well) |
G2 |
(well) |
M |
(so, so (average)) |
B2 |
(not very well) |
B1 |
(not well at all) |
Respondant's self rated health is collected at each yearly wave of the SHP with the following question: How do you feel right now?. Possible answers are: very well; well; so, so (average), not very well and not well at all. The sequences are made of an individual's responses over 11 yearly waves of the SHP, starting with wave 1 in 1999. Variable p99c01 contains the self rated health at wave 1, p00c01 contains the self rated health at wave 2, etc... Note that sequences may contain missing values due to wave or item non response.
Swiss Household Panel: www.swisspanel.ch
## Preparing a sequence object with the SRH data set data(SRH) ## Long state labels state.list <- levels(SRH$p99c01) ## Sequential color palette mycol5 <- rev(brewer.pal(5, "RdYlGn")) ## Creating the sequence object SRH.seq <- seqdef(SRH, 5:15, alphabet=state.list, states=c("G1", "G2", "M", "B2", "B1"), labels=state.list, weights=SRH$wp09lp1s, right=NA, cpal=mycol5) names(SRH.seq) <- 1999:2009
## Preparing a sequence object with the SRH data set data(SRH) ## Long state labels state.list <- levels(SRH$p99c01) ## Sequential color palette mycol5 <- rev(brewer.pal(5, "RdYlGn")) ## Creating the sequence object SRH.seq <- seqdef(SRH, 5:15, alphabet=state.list, states=c("G1", "G2", "M", "B2", "B1"), labels=state.list, weights=SRH$wp09lp1s, right=NA, cpal=mycol5) names(SRH.seq) <- 1999:2009
Extract a subtree from a segmented PST
## S4 method for signature 'PSTf' subtree(object, group=NULL, position=NULL)
## S4 method for signature 'PSTf' subtree(object, group=NULL, position=NULL)
object |
A segmented probabilistic suffix tree, i.e an object of class |
group |
integer. Segment of the PST |
position |
Not implemented yet. |
See also Gabadinho 2016.
Alexis Gabadinho
Gabadinho, A. & Ritschard, G. (2016). Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 72(3), pp. 1-39.
## activity calendar for year 2000 ## from the Swiss Household Panel ## see ?actcal data(actcal) ## selecting individuals aged 20 to 59 actcal <- actcal[actcal$age00>=20 & actcal$age00 <60,] ## defining a sequence object actcal.lab <- c("> 37 hours", "19-36 hours", "1-18 hours", "no work") actcal.seq <- seqdef(actcal,13:24,labels=actcal.lab) ## building a PST segmented by age group gage10 <- cut(actcal$age00, c(20,30,40,50,60), right=FALSE, labels=c("20-29","30-39", "40-49", "50-59")) actcal.pstg <- pstree(actcal.seq, nmin=2, ymin=0.001, group=gage10) ## pruning C99 <- qchisq(0.99,4-1)/2 actcal.pstg.opt <- prune(actcal.pstg, gain="G2", C=C99) ## extracting PST for age group 20-39 and 30-39 g1.pst <- subtree(actcal.pstg.opt, group=1) g2.pst <- subtree(actcal.pstg.opt, group=2) ## plotting the two PST par(mfrow=c(1,2)) plot(g1.pst, withlegend=FALSE, max.level=4, main="20-29") plot(g2.pst, withlegend=FALSE, max.level=4, main="30-39")
## activity calendar for year 2000 ## from the Swiss Household Panel ## see ?actcal data(actcal) ## selecting individuals aged 20 to 59 actcal <- actcal[actcal$age00>=20 & actcal$age00 <60,] ## defining a sequence object actcal.lab <- c("> 37 hours", "19-36 hours", "1-18 hours", "no work") actcal.seq <- seqdef(actcal,13:24,labels=actcal.lab) ## building a PST segmented by age group gage10 <- cut(actcal$age00, c(20,30,40,50,60), right=FALSE, labels=c("20-29","30-39", "40-49", "50-59")) actcal.pstg <- pstree(actcal.seq, nmin=2, ymin=0.001, group=gage10) ## pruning C99 <- qchisq(0.99,4-1)/2 actcal.pstg.opt <- prune(actcal.pstg, gain="G2", C=C99) ## extracting PST for age group 20-39 and 30-39 g1.pst <- subtree(actcal.pstg.opt, group=1) g2.pst <- subtree(actcal.pstg.opt, group=2) ## plotting the two PST par(mfrow=c(1,2)) plot(g1.pst, withlegend=FALSE, max.level=4, main="20-29") plot(g2.pst, withlegend=FALSE, max.level=4, main="30-39")
Summary of a variable length Markov chain model stored in a probabilistic suffix tree.
## S4 method for signature 'PSTf' summary(object, max.level)
## S4 method for signature 'PSTf' summary(object, max.level)
object |
A PST, that is an object of class |
max.level |
integer. If specified, the summary is computed for the |
An object of class PST.summary
with following attributes:
list of symbols in the alphabet
long labels for symbols in the alphabet
color palette used to represent each state of the alphabet
number of symbols in the data to which the model was fitted
maximum depth (order) of the tree
number of internal nodes in the PST
number of leaves in the PST
number of free parameters in the mode, i.e., (nodes+leaves)*(|A|-1) where |A| is the size of the alphabet
A show
method is available for displaying objects of class PST.summary
.
Alexis Gabadinho
data(s1) s1.seq <- seqdef(s1) S1 <- pstree(s1.seq, L=3) summary(S1) summary(S1, max.level=2)
data(s1) s1.seq <- seqdef(s1) S1 <- pstree(s1.seq, L=3) summary(S1) summary(S1, max.level=2)
Prune a probabilistic suffix tree with a series of cut-offs and select the model having the lowest value of the selected information criterion. Available information criterion are Akaike information criterion (AIC), AIC with a correction for finite sample sizes (AICc) and Bayesian information criterion (BIC).
## S4 method for signature 'PSTf' tune(object, gain="G2", C, criterion = "AIC", output = "PST")
## S4 method for signature 'PSTf' tune(object, gain="G2", C, criterion = "AIC", output = "PST")
object |
a probabilistic suffix tree, i.e., an object of class |
gain |
character. The gain function used for pruning decisions. See |
C |
numeric. A vector of cutoff values. See |
criterion |
The criterion used to select the model, either AIC, AICc or BIC. AICc should be used when the ratio between the number of observations and the number of estimated parameters is low, which is often the case with VLMC models. Burnham et al 2004 suggest to use AICc instead of AIC when the ratio is lower than 40. |
output |
If |
The tune
function selects among a series of PST pruned with different values of the cutoff the model having the lowest
or
value. The function can return either the selected PST or a data frame containing the statistics for each model. For more details, see Gabadinho 2016.
If output="PST"
a PST that is an object of class PSTf
. If output="stats"
a matrix with the results of the tuning procedure.
The selected model is tagged with ***
, while models with are tagged with
**
, and models with are tagged with
**
.
Alexis Gabadinho
Burnham, K. P. & Anderson, D. R. (2004). Multimodel Inference Sociological Methods & Research, 33, pp. 261-304.
Gabadinho, A. & Ritschard, G. (2016). Analyzing State Sequences with Probabilistic Suffix Trees: The PST R Package. Journal of Statistical Software, 72(3), pp. 1-39.
## activity calendar for year 2000 ## from the Swiss Household Panel ## see ?actcal data(actcal) ## selecting individuals aged 20 to 59 actcal <- actcal[actcal$age00>=20 & actcal$age00 <60,] ## defining a sequence object actcal.lab <- c("> 37 hours", "19-36 hours", "1-18 hours", "no work") actcal.seq <- seqdef(actcal,13:24,labels=actcal.lab) ## building a PST actcal.pst <- pstree(actcal.seq, nmin=2, ymin=0.001) ## Cut-offs for 5% and 1% (see ?prune) C95 <- qchisq(0.95,4-1)/2 C99 <- qchisq(0.99,4-1)/2 ## selecting the optimal PST using AIC criterion actcal.pst.opt <- tune(actcal.pst, gain="G2", C=c(C95,C99)) ## plotting the tree plot(actcal.pst.opt)
## activity calendar for year 2000 ## from the Swiss Household Panel ## see ?actcal data(actcal) ## selecting individuals aged 20 to 59 actcal <- actcal[actcal$age00>=20 & actcal$age00 <60,] ## defining a sequence object actcal.lab <- c("> 37 hours", "19-36 hours", "1-18 hours", "no work") actcal.seq <- seqdef(actcal,13:24,labels=actcal.lab) ## building a PST actcal.pst <- pstree(actcal.seq, nmin=2, ymin=0.001) ## Cut-offs for 5% and 1% (see ?prune) C95 <- qchisq(0.95,4-1)/2 C99 <- qchisq(0.99,4-1)/2 ## selecting the optimal PST using AIC criterion actcal.pst.opt <- tune(actcal.pst, gain="G2", C=c(C95,C99)) ## plotting the tree plot(actcal.pst.opt)