[R] 'par mfrow' and not filling horizontally
(Ted Harding)
Ted.Harding at manchester.ac.uk
Wed Sep 8 22:39:56 CEST 2010
On 08-Sep-10 19:16:15, Bert Gunter wrote:
> Ted:
> ?layout
>
> Is this close to what you want?
>
> layout(matrix(1:2, nrow=2),wid=1,heigh=c(1,1), resp= TRUE)
> set.seed(54321)
> X0 <- rnorm(50) ; Y0 <- rnorm(50)
> plot(X0,Y0,pch="+",col="blue",xlim=c(-3,3),ylim=c(-3,3),
> xlab="X",ylab="Y",main="My Plot",asp=1)
> plot(X0,Y0,pch="+",col="blue",xlim=c(-3,3),ylim=c(-3,3),
> xlab="X",ylab="Y",main="My Plot",asp=1)
Thanks Greg, William, Marc & Bert for the suggestions. It seems
that Bert's suggestion of 'layout' may work best for my real example
(the one I posted was a simple one). It is also necessary to add
par(pty="s").
Greg: I must study squishplot() -- it looks useful.
William, Marc: I had tried pty="s" in my real example (I inadvertently
omitted it from the dummy example I posted), but it still did not
work -- see Case B of the real example below.
Anyway, here is an instance of the real problem. DISCLAIMER: This
is being done as an "exploration of concept" and does not necessarily
represent my true state of mind ...
## Code common to all approaches (Alterbative continuations A and B):
library(MASS)
M <- 10 ; N <- 2 ; plur <- "'s"
set.seed(54321)
mu <- (-3)+6*(0:(M-1))/(M-1)
mu <- rep(mu, N) ## M evenly spaced on (-3,3)
Y <- matrix(rnorm(M*N,mean=mu),ncol=N) ## N Y's for each mu
KDE <- kde2d(x=mu, y=Y, h=2.5, n=100, lims=c(-5,5,-5,5,-5.0,5.0))
S.x <- KDE$x ; S.y <- KDE$y ; S.z <- KDE$z
## For each value of Y in the KDE grid, find the mu with max KDE:
Mxs <- numeric(100)
for(j in (1:100)){ Mxs[j] <- S.x[which(S.z[,j]==max(S.z[,j]))] }
## A: Using Bert's 'layout' approach with pty="s" as well:
layout(matrix(1:2, nrow=2),wid=1,height=c(1,1), resp=TRUE)
par(cex=0.5,pty="s")
plot(mu,Y,pch="+",col="blue",asp=1,xlim=c(-5,5),ylim=c(-5,5),
xlab="True mu", ylab="Sampled Y's",
main=paste("KDE for (mu,Y) ",
M," mu's, ",N," Y",plur," per mu",sep=""))
contour(S.x, S.y, S.z, nlevels=7, drawlabels=FALSE, add=TRUE)
lines(S.x,S.y,col="green")
for(j in (1:100)){ Mxs[j] <- S.x[which(S.z[,j]==max(S.z[,j]))] }
lines(Mxs,S.x,col="red")
plot(S.x[1:100],Mxs[1:100],asp=1,pch="+",col="red",
xlim=c(-5,5),ylim=c(-5,5),
xlab="Future Observed Y",ylab="MLE of mu by KDE",
main="MLE of mu by KDE for this Sim vs Future Y")
lines(c(-3,3),c(-3,3),col="green")
lines(c(-3,-3),c(-3,3)) ; lines(c( 3, 3),c(-3,3))
text(0,3.5,"<-- Range of True mu used -->")
##C: Using par(pty="s") with par(mfrow) leaving out 'layout':
plot.new()
par(mfrow=c(2,1),mfg=c(1,1),cex=0.5,pty="s")
plot(mu,Y,pch="+",col="blue",asp=1,xlim=c(-5,5),ylim=c(-5,5),
xlab="True mu", ylab="Sampled Y's",pty="s",
main=paste("KDE for (mu,Y) ",
M," mu's, ",N," Y",plur," per mu",sep=""))
contour(S.x, S.y, S.z, nlevels=7, drawlabels=FALSE, add=TRUE)
lines(S.x,S.y,col="green")
for(j in (1:100)){ Mxs[j] <- S.x[which(S.z[,j]==max(S.z[,j]))] }
lines(Mxs,S.x,col="red")
par(mfg=c(2,1))
plot(S.x[1:100],Mxs[1:100],asp=1,pch="+",col="red",
xlim=c(-5,5),ylim=c(-5,5),
xlab="Future Observed Y",ylab="MLE of mu by KDE",
main="MLE of mu by KDE for this Sim vs Future Y")
lines(c(-3,3),c(-3,3),col="green")
lines(c(-3,-3),c(-3,3)) ; lines(c( 3, 3),c(-3,3))
text(0,3.5,"<-- Range of True mu used -->")
#################################################
Anyway, thanks! It has helped.
Ted.
--------------------------------------------------------------------
E-Mail: (Ted Harding) <Ted.Harding at manchester.ac.uk>
Fax-to-email: +44 (0)870 094 0861
Date: 08-Sep-10 Time: 21:39:53
------------------------------ XFMail ------------------------------
More information about the R-help
mailing list