2025-01-12 04:36:52 +08:00

433 lines
13 KiB
R

### R code from vignette source 'gridBase.Rnw'
###################################################
### code chunk number 1: gridBase.Rnw:81-84
###################################################
library(grid)
library(gridBase)
###################################################
### code chunk number 2: basesetup (eval = FALSE)
###################################################
## midpts <- barplot(1:10, axes=FALSE)
## axis(2)
## axis(1, at=midpts, labels=FALSE)
##
###################################################
### code chunk number 3: baseviewport (eval = FALSE)
###################################################
## vps <- baseViewports()
## pushViewport(vps$inner, vps$figure, vps$plot)
##
###################################################
### code chunk number 4: gridtext (eval = FALSE)
###################################################
## grid.text(c("one", "two", "three", "four", "five",
## "six", "seven", "eight", "nine", "ten"),
## x=unit(midpts, "native"), y=unit(-1, "lines"),
## just="right", rot=60)
## popViewport(3)
##
###################################################
### code chunk number 5: gridBase.Rnw:110-114
###################################################
midpts <- barplot(1:10, axes=FALSE)
axis(2)
axis(1, at=midpts, labels=FALSE)
vps <- baseViewports()
pushViewport(vps$inner, vps$figure, vps$plot)
grid.text(c("one", "two", "three", "four", "five",
"six", "seven", "eight", "nine", "ten"),
x=unit(midpts, "native"), y=unit(-1, "lines"),
just="right", rot=60)
popViewport(3)
###################################################
### code chunk number 6: plotsymbol (eval = FALSE)
###################################################
## novelsym <- function(speed, temp,
## width=unit(3, "mm"),
## length=unit(0.5, "inches")) {
## grid.rect(height=length, y=0.5,
## just="top", width=width,
## gp=gpar(fill="white"))
## grid.rect(height=temp*length,
## y=unit(0.5, "npc") - length,
## width=width,
## just="bottom", gp=gpar(fill="grey"))
## grid.lines(x=0.5,
## y=unit.c(unit(0.5, "npc"), unit(0.5, "npc") + speed*length),
## arrow=arrow(length=unit(3, "mm"), type="closed"),
## gp=gpar(fill="black"))
## grid.points(unit(0.5, "npc"), unit(0.5, "npc"), size=unit(2, "mm"),
## pch=16)
## }
##
###################################################
### code chunk number 7: baseplot (eval = FALSE)
###################################################
## chinasea <- read.table(system.file("doc", "chinasea.txt",
## package="gridBase"),
## header=TRUE)
## plot(chinasea$lat, chinasea$long, type="n",
## xlab="latitude", ylab="longitude",
## main="China Sea Wind Speed/Direction and Temperature")
##
###################################################
### code chunk number 8: gridsym (eval = FALSE)
###################################################
## speed <- 0.8*chinasea$speed/14 + 0.2
## temp <- chinasea$temp/40
## vps <- baseViewports()
## pushViewport(vps$inner, vps$figure, vps$plot)
## for (i in 1:25) {
## pushViewport(viewport(x=unit(chinasea$lat[i], "native"),
## y=unit(chinasea$long[i], "native"),
## angle=chinasea$dir[i]))
## novelsym(speed[i], temp[i])
## popViewport()
## }
## popViewport(3)
##
###################################################
### code chunk number 9: gridBase.Rnw:184-188
###################################################
novelsym <- function(speed, temp,
width=unit(3, "mm"),
length=unit(0.5, "inches")) {
grid.rect(height=length, y=0.5,
just="top", width=width,
gp=gpar(fill="white"))
grid.rect(height=temp*length,
y=unit(0.5, "npc") - length,
width=width,
just="bottom", gp=gpar(fill="grey"))
grid.lines(x=0.5,
y=unit.c(unit(0.5, "npc"), unit(0.5, "npc") + speed*length),
arrow=arrow(length=unit(3, "mm"), type="closed"),
gp=gpar(fill="black"))
grid.points(unit(0.5, "npc"), unit(0.5, "npc"), size=unit(2, "mm"),
pch=16)
}
chinasea <- read.table(system.file("doc", "chinasea.txt",
package="gridBase"),
header=TRUE)
plot(chinasea$lat, chinasea$long, type="n",
xlab="latitude", ylab="longitude",
main="China Sea Wind Speed/Direction and Temperature")
speed <- 0.8*chinasea$speed/14 + 0.2
temp <- chinasea$temp/40
vps <- baseViewports()
pushViewport(vps$inner, vps$figure, vps$plot)
for (i in 1:25) {
pushViewport(viewport(x=unit(chinasea$lat[i], "native"),
y=unit(chinasea$long[i], "native"),
angle=chinasea$dir[i]))
novelsym(speed[i], temp[i])
popViewport()
}
popViewport(3)
###################################################
### code chunk number 10: gridBase.Rnw:220-225
###################################################
data(USArrests)
hc <- hclust(dist(USArrests), "ave")
dend1 <- as.dendrogram(hc)
dend2 <- cut(dend1, h=70)
###################################################
### code chunk number 11: gridBase.Rnw:229-233
###################################################
x <- 1:4
y <- 1:4
height <- factor(round(unlist(lapply(dend2$lower, attr, "height"))))
###################################################
### code chunk number 12: gridBase.Rnw:248-260
###################################################
space <- max(unit(rep(1, 50), "strwidth",
as.list(rownames(USArrests))))
dendpanel <- function(x, y, subscripts, ...) {
pushViewport(viewport(y=space, width=0.9,
height=unit(0.9, "npc") - space,
just="bottom"))
grid.rect(gp=gpar(col="grey", lwd=5))
par(plt=gridPLT(), new=TRUE, ps=10)
plot(dend2$lower[[subscripts]], axes=FALSE)
popViewport()
}
###################################################
### code chunk number 13: gridBase.Rnw:266-273
###################################################
library(lattice)
plot.new()
print(xyplot(y ~ x | height, subscripts=TRUE, xlab="", ylab="",
strip=function(...) { strip.default(style=4, ...) },
scales=list(draw=FALSE), panel=dendpanel),
newpage=FALSE)
###################################################
### code chunk number 14: gridBase.Rnw:290-294
###################################################
counts <- c(18,17,15,20,10,20,25,13,12)
outcome <- gl(3,1,9)
treatment <- gl(3,3)
###################################################
### code chunk number 15: gridBase.Rnw:302-304
###################################################
oldpar <- par(no.readonly=TRUE)
###################################################
### code chunk number 16: regions (eval = FALSE)
###################################################
## pushViewport(viewport(layout=grid.layout(1, 3,
## widths=unit(rep(1, 3), c("null", "cm", "null")))))
##
###################################################
### code chunk number 17: lattice (eval = FALSE)
###################################################
## pushViewport(viewport(layout.pos.col=1))
## library(lattice)
## bwplot <- bwplot(counts ~ outcome | treatment)
## print(bwplot, newpage=FALSE)
## popViewport()
##
###################################################
### code chunk number 18: diagnostic (eval = FALSE)
###################################################
## pushViewport(viewport(layout.pos.col=3))
## glm.D93 <- glm(counts ~ outcome + treatment, family=poisson())
## par(omi=gridOMI(), mfrow=c(2, 2), new=TRUE)
## par(cex=0.5, mar=c(5, 4, 1, 2))
## par(mfg=c(1, 1))
## plot(glm.D93, caption="", ask=FALSE)
## popViewport(2)
##
###################################################
### code chunk number 19: multiplot
###################################################
pushViewport(viewport(layout=grid.layout(1, 3,
widths=unit(rep(1, 3), c("null", "cm", "null")))))
pushViewport(viewport(layout.pos.col=1))
library(lattice)
bwplot <- bwplot(counts ~ outcome | treatment)
print(bwplot, newpage=FALSE)
popViewport()
pushViewport(viewport(layout.pos.col=3))
glm.D93 <- glm(counts ~ outcome + treatment, family=poisson())
par(omi=gridOMI(), mfrow=c(2, 2), new=TRUE)
par(cex=0.5, mar=c(5, 4, 1, 2))
par(mfg=c(1, 1))
plot(glm.D93, caption="", ask=FALSE)
popViewport(2)
###################################################
### code chunk number 20: gridBase.Rnw:346-348
###################################################
par(oldpar)
###################################################
### code chunk number 21: gridBase.Rnw:375-379
###################################################
x <- c(0.88, 1.00, 0.67, 0.34)
y <- c(0.87, 0.43, 0.04, 0.94)
z <- matrix(runif(4*2), ncol=2)
###################################################
### code chunk number 22: gridBase.Rnw:386-388
###################################################
oldpar <- par(no.readonly=TRUE)
###################################################
### code chunk number 23: plot1 (eval = FALSE)
###################################################
## plot(x, y, xlim=c(-0.2, 1.2), ylim=c(-0.2, 1.2), type="n")
##
###################################################
### code chunk number 24: plot2 (eval = FALSE)
###################################################
## vps <- baseViewports()
## pushViewport(vps$inner, vps$figure, vps$plot)
## grid.segments(x0=unit(c(rep(0, 4), x),
## rep(c("npc", "native"), each=4)),
## x1=unit(c(x, x), rep("native", 8)),
## y0=unit(c(y, rep(0, 4)),
## rep(c("native", "npc"), each=4)),
## y1=unit(c(y, y), rep("native", 8)),
## gp=gpar(lty="dashed", col="grey"))
##
###################################################
### code chunk number 25: gridBase.Rnw:427-431
###################################################
maxpiesize <- unit(1, "inches")
totals <- apply(z, 1, sum)
sizemult <- totals/max(totals)
###################################################
### code chunk number 26: plot3 (eval = FALSE)
###################################################
## for (i in 1:4) {
## pushViewport(viewport(x=unit(x[i], "native"),
## y=unit(y[i], "native"),
## width=sizemult[i]*maxpiesize,
## height=sizemult[i]*maxpiesize))
## grid.rect(gp=gpar(col="grey", fill="white", lty="dashed"))
## par(plt=gridPLT(), new=TRUE)
## pie(z[i,], radius=1, labels=rep("", 2))
## popViewport()
## }
##
###################################################
### code chunk number 27: plot4 (eval = FALSE)
###################################################
## popViewport(3)
## par(oldpar)
##
###################################################
### code chunk number 28: complex
###################################################
plot(x, y, xlim=c(-0.2, 1.2), ylim=c(-0.2, 1.2), type="n")
vps <- baseViewports()
pushViewport(vps$inner, vps$figure, vps$plot)
grid.segments(x0=unit(c(rep(0, 4), x),
rep(c("npc", "native"), each=4)),
x1=unit(c(x, x), rep("native", 8)),
y0=unit(c(y, rep(0, 4)),
rep(c("native", "npc"), each=4)),
y1=unit(c(y, y), rep("native", 8)),
gp=gpar(lty="dashed", col="grey"))
for (i in 1:4) {
pushViewport(viewport(x=unit(x[i], "native"),
y=unit(y[i], "native"),
width=sizemult[i]*maxpiesize,
height=sizemult[i]*maxpiesize))
grid.rect(gp=gpar(col="grey", fill="white", lty="dashed"))
par(plt=gridPLT(), new=TRUE)
pie(z[i,], radius=1, labels=rep("", 2))
popViewport()
}
popViewport(3)
par(oldpar)
###################################################
### code chunk number 29: gridBase.Rnw:544-549
###################################################
ctl <- c(4.17,5.58,5.18,6.11,4.50,4.61,5.17,4.53,5.33,5.14)
trt <- c(4.81,4.17,4.41,3.59,5.87,3.83,6.03,4.89,4.32,4.69)
group <- gl(2,10,20, labels=c("Ctl","Trt"))
weight <- c(ctl, trt)
###################################################
### code chunk number 30: gridBase.Rnw:557-559
###################################################
oldpar <- par(no.readonly=TRUE)
###################################################
### code chunk number 31: regions (eval = FALSE)
###################################################
## pushViewport(viewport(layout=grid.layout(1, 3,
## widths=unit(rep(1, 3), c("null", "cm", "null")))))
##
###################################################
### code chunk number 32: lattice (eval = FALSE)
###################################################
## pushViewport(viewport(layout.pos.col=1))
## library(lattice)
## bwplot <- bwplot(weight ~ group)
## print(bwplot, newpage=FALSE)
## popViewport()
##
###################################################
### code chunk number 33: diagnostic (eval = FALSE)
###################################################
## pushViewport(viewport(layout.pos.col=3))
## lm.D9 <- lm(weight ~ group)
## par(omi=gridOMI(), mfrow=c(2, 2), new=TRUE)
## par(cex=0.5)
## par(mfg=c(1, 1))
## plot(lm.D9, caption="", ask=FALSE)
## popViewport(2)
##