私は複数の可変時系列を持っていますが、変数の中にはかなり大きな範囲があります。私は変数のいくつかがlog10のy軸スケーリングを持つように、各変数の複数の積み重ねプロットを含む単一ページのプロットを作成したいと思います。私は格子が比較的新しく、非変形軸とlog10スケーリングをどのように効果的に混合し、出版品質のプロットを得るかを理解することができませんでした。 print.trellisが使用されている場合、プロットは整列せず、パディングにはいくつかの作業が必要です。c.trellisを使用するとレイアウトは良好ですが、1つのプロットからのyスケーリングのみが使用されます。効率的なソリューションの提案です。ここでは、各(元の)オブジェクトに対して異なるy-スケーリングを使用してc.trellisの出力を複製できますか?以下 例:@のjoranのアイデアを使用してlatticeまたはlatticeExtra異なる複数のプロットを組み合わせるyscaling(log10および非変換)
require(lattice)
require(latticeExtra)
# make data.frame
d.date <- as.POSIXct(c("2009-12-15", "2010-01-15", "2010-02-15", "2010-03-15", "2010-04-15"))
CO2dat <- c(100,200,1000,9000,2000)
pHdat <- c(10,9,7,6,7)
tmp <- data.frame(date=d.date ,CO2dat=CO2dat ,pHdat=pHdat)
# make plots
plot1 <- xyplot(pHdat ~ date, data=tmp
, ylim=c(5,11)
, ylab="pHdat"
, xlab="Date"
, origin = 0, border = 0
, scales=list(y=list(alternating=1))
, panel = function(...){
panel.xyarea(...)
panel.xyplot(...)
}
)
# make plot with log y scale
plot2 <- xyplot(CO2dat ~ date, data=tmp
, ylim=c(10,10^4)
, ylab="CO2dat"
, xlab="Date"
, origin = 0, border = 0
, scales=list(y=list(alternating=1,log=10))
, yscale.components = yscale.components.log10ticks
, panel = function(...){
panel.xyarea(...)
panel.xyplot(...)
# plot CO2air uatm
panel.abline(h=log10(390),col="blue",type="l",...)
}
)
# plot individual figures using split
print(plot2, split=c(1,1,1,2), more=TRUE)
print(plot1, split=c(1,2,1,2), more=F)
# combine plots (more convenient)
comb <- c(plot1, plot2, x.same=F, y.same=F, layout = c(1, 2))
# plot combined figure
update(comb, ylab = c("pHdat","log10 CO2dat"))
ます( 'print.trellis'メソッドの)先頭の空白スペースでplot1にy軸の目盛りラベルをパディングみました、またはあなたはそれよりも少ないアドホックソリューションを探していますか? – joran
こんにちは@ジョラン:以下のあなたの考えの私の試みを参照してください。 – Aaron