plot.segmented {segmented} | R Documentation |
Plot method for segmented objects
Description
Takes a fitted segmented
object returned by segmented()
and plots (or adds)
the fitted broken-line relationship for the selected segmented term.
Usage
## S3 method for class 'segmented'
plot(x, term, add=FALSE, res=FALSE, conf.level=0, interc=TRUE, link=TRUE,
res.col=grey(.15, alpha = .4), rev.sgn=FALSE, const=NULL, shade=FALSE, rug=!add,
dens.rug=FALSE, dens.col = grey(0.8), transf=I, isV=FALSE, is=FALSE, var.diff=FALSE,
p.df="p", .vcov=NULL, .coef=NULL, prev.trend=FALSE, smoos=NULL, hide.zeros=FALSE,
leg="topleft", psi.lines=FALSE, ...)
Arguments
x |
a fitted |
term |
Numerical or character to indicate the segmented variable having the piece-wise relationship to be plotted. If there is a single segmented variable in the fitted model |
add |
when |
res |
when |
conf.level |
If greater than zero, it means the confidence level at which the pointwise confidence itervals have to be plotted. |
interc |
If |
link |
when |
res.col |
when |
rev.sgn |
when |
const |
constant to add to each fitted segmented relationship (on the scale of the linear predictor) before plotting.
If |
shade |
if |
rug |
when |
dens.rug |
when |
dens.col |
if |
transf |
A possible function to convert the fitted values before plotting. It is only effective
if |
isV |
logical value (to be passed to |
is |
logical value (to be passed to |
var.diff |
logical value to be passed to |
p.df |
degrees of freedom when |
.vcov |
The full covariance matrix of estimates to be used when |
.coef |
The regression parameter estimates. If unspecified (i.e. |
prev.trend |
logical. If |
smoos |
logical, indicating if the residuals (provided that |
hide.zeros |
logical, indicating if the residuals (provided that |
leg |
If the plot refers to segmented relationships in groups, i.e. |
psi.lines |
if |
... |
other graphics parameters to pass to plotting commands: ‘col’, ‘lwd’ and ‘lty’ (that
can be vectors and are recycled if necessary, see the example below) for the fitted piecewise lines; ‘ylab’, ‘xlab’, ‘main’, ‘sub’, ‘cex.axis’, ‘cex.lab’, ‘xlim’ and
‘ylim’ when a new plot is produced (i.e. when |
Details
Produces (or adds to the current device) the fitted segmented relationship between the
response and the selected term
. If the fitted model includes just a single ‘segmented’ variable,
term
may be omitted.
The partial residuals are computed as ‘fitted + residuals’, where ‘fitted’ are the fitted values of the
segmented relationship relevant to the covariate specified in term
.
Notice that for GLMs the residuals are the response residuals if link=FALSE
and
the working residuals if link=TRUE
.
Value
None.
Note
For models with offset, partial residuals on the response scale are not defined. Thus plot.segmented
does not work
when link=FALSE
, res=TRUE
, and the fitted model includes an offset.
When term
is a vector and multiple segmented relationships are being drawn on the same plot, col
and res.col
can be vectors. Also pch
, cex
, lty
, and lwd
can be vectors, if specified.
Author(s)
Vito M. R. Muggeo
See Also
segmented
to fit the model, lines.segmented
to add the estimated breakpoints on the current plot.
points.segmented
to add the joinpoints of the segmented relationship.
predict.segmented
to compute standard errors and confidence intervals for predictions from a
"segmented" fit.
Examples
set.seed(1234)
z<-runif(100)
y<-rpois(100,exp(2+1.8*pmax(z-.6,0)))
o<-glm(y~z,family=poisson)
o.seg<-segmented(o) #single segmented covariate and one breakpoint: 'seg.Z' and 'psi' can be omitted
par(mfrow=c(1,2))
plot(o.seg, conf.level=0.95, shade=TRUE)
points(o.seg, link=TRUE, col=2)
## new plot
plot(z,y)
## add the fitted lines using different colors and styles..
plot(o.seg,add=TRUE,link=FALSE,lwd=2,col=2:3, lty=c(1,3))
lines(o.seg,col=2,pch=19,bottom=FALSE,lwd=2) #for the CI for the breakpoint
points(o.seg,col=4, link=FALSE)
## using the options 'is', 'isV', 'shade' and 'col.shade'.
par(mfrow=c(1,2))
plot(o.seg, conf.level=.9, is=TRUE, isV=TRUE, col=1, shade = TRUE, col.shade=2)
plot(o.seg, conf.level=.9, is=TRUE, isV=FALSE, col=2, shade = TRUE, res=TRUE, res.col=4, pch=3)