haploNet
computes a haplotype network. There is a plot method
and two conversion functions towards other packages.
haploNet(h, d = NULL, getProb = TRUE)
# S3 method for haploNet
print(x, ...)
# S3 method for haploNet
plot(x, size = 1, col = "black", bg = "white",
col.link = "black", lwd = 1, lty = 1, pie = NULL,
labels = TRUE, font = 2, cex = 1, scale.ratio = 1,
asp = 1, legend = FALSE, fast = FALSE, show.mutation = 1,
threshold = c(1, 2), ...)
# S3 method for haploNet
as.network(x, directed = FALSE, altlinks = TRUE, ...)
# S3 method for haploNet
as.igraph(x, directed = FALSE, use.labels = TRUE,
altlinks = TRUE, ...)
an object of class "haplotype"
.
an object giving the distances among haplotypes (see details).
a logical specifying whether to calculate Templeton's probabilities (see details).
an object of class "haploNet"
.
a numeric vector giving the diameter of the circles representing the haplotypes: this is in the same unit than the links and eventually recycled.
a character vector specifying the colours of the circles; eventually recycled.
a character vector specifying either the colours of the
background of the circles (if pie = NULL
), or the colours of
the slices of the pies; eventually recycled.
a character vector specifying the colours of the links; eventually recycled.
a numeric vector giving the width of the links; eventually recycled.
idem for the line types.
a matrix used to draw pie charts for each haplotype; its number of rows must be equal to the number of haplotypes.
a logical specifying whether to identify the haplotypes with their labels (the default).
the font used for these labels (bold by default); must be an integer between 1 and 4.
a numerical specifying the character expansion of the labels.
the ratio of the scale of the links representing the number of steps on the scale of the circles representing the haplotypes. It may be needed to give a value greater than one to avoid overlapping circles.
the aspect ratio of the plot. Do not change the default unless you want to distort your network.
a logical specifying whether to draw the legend, or a
vector of length two giving the coordinates where to draw the
legend; FALSE
by default. If TRUE
, the user is asked
to click where to draw the legend.
a logical specifying whether to optimize the spacing of
the circles; FALSE
by default.
an integer value: if 0, nothing is drawn on the links; if 1, the mutations are shown with small segments on the links; if 2, they are shown with small dots; if 3, the number of mutations are printed on the links.
a numeric vector with two values (or 0) giving the
lower and upper numbers of mutations for alternative links to be
displayed. If threshold = 0
, alternative links are not drawn
at all.
a logical specifying whether the network is directed
(FALSE
by default).
a logical specifying whether to use the original labels in the returned network.
whether to output the alternative links when
converting to another class; TRUE
by default.
further arguments passed to plot
.
haploNet
returns an object of class "haploNet"
which is
a matrix where each row represents a link in the network, the first
and second columns give the numbers of the linked haplotypes, the
third column, named "step"
, gives the number of steps in this
link, and the fourth column, named "Prob"
, gives the
probability of a parsimonious link as given by Templeton et
al. (1992). There are three additional attributes: "freq"
, the
absolute frequencies of each haplotype, "labels"
, their labels,
and "alter.links"
, the alternative links of the network.
as.network
and as.igraph
return objects of the
appropriate class.
By default, the haplotype network is built using an infinite site
model (i.e., uncorrected or Hamming distance) of DNA sequences and
pairwise deletion of missing data (see dist.dna
).
Users may specify their own distance with the argument d
. There
is no check of labels, so the user must make sure that the distances
are ordered in the same way than the haplotypes.
The probabilities calculated with Templeton et al.'s (1992) method may
give non-finite values with very divergent sequences, resulting in an
error from haploNet
. If this happens, it may be better to use
getProb = FALSE
.
Templeton, A. R., Crandall, K. A. and Sing, C. F. (1992) A cladistic analysis of phenotypic association with haplotypes inferred from restriction endonuclease mapping and DNA sequence data. III. Cladogram estimation. Genetics, 132, 619--635.
# NOT RUN {
## generate some artificial data from 'woodmouse':
data(woodmouse)
x <- woodmouse[sample(15, size = 110, replace = TRUE), ]
h <- haplotype(x)
(net <- haploNet(h))
plot(net)
## symbol sizes equal to haplotype sizes:
plot(net, size = attr(net, "freq"), fast = TRUE)
plot(net, size = attr(net, "freq"))
plot(net, size=attr(net, "freq"), scale.ratio = 2, cex = 0.8)
# }
Run the code above in your browser using DataLab