在格子中添加重复的xyplot

时间:2013-05-14 20:48:44

标签: r lattice

这是我的第一篇文章,所以我不确定我是否已经正确地完成了这项工作。我想在plot1中添加第二个xyplot,以便它表示与气泡图相同的数据(百分比〜距离并按Forest_type分组),但没有基于dat $ Pixels的气泡大小。 IE:泡沫中的一个点。所有的点都应该是黑色的,非常小。我尝试使用LatticeExtra作为aslayer,但无法使用我有限的面板和功能体验。我从更有经验的人那里获得了这个原始代码,并且只能稍微修改它。 感谢您的任何建议。

library(lattice)

mykey <- list(x = .7, y = .7, corner = c(0,1), text = list(lab = c("D", "C", "M")),
points = list(col = c(2,3,4), pch = 1) )

fontsize <- trellis.par.get("par.main.text")
fontsize$font <- 1
trellis.par.set("par.main.text", fontsize)
trellis.par.get()


plot1<-xyplot(Percent ~ Distance, key = mykey, cex = dat$Pixels / 15000000, 
       col = dat$Forest_type+1,
       xlab="Distance", ylab="Percent of pixels",
       data = dat, panel = function(...){
       panel.xyplot(...)
       }) 

print(plot1, position=c(0, .5, 1, 1))

要复制/使用的数据如下:

dat <- structure(list(Pixels = c(51442200L, 16201800L, 9679500L, 8954100L, 
4332600L, 4024800L, 2843100L, 2707200L, 2635200L, 1754100L, 1865700L, 
1467000L, 1575900L, 1253700L, 1061100L, 1205100L, 1045800L, 909000L, 
822600L, 732600L, 837900L, 676800L, 600300L, 538200L, 504900L, 
414000L, 316800L, 318600L, 260100L, 261900L, 214200L, 189900L, 
182700L, 178200L, 150300L, 135000L, 117000L, 103500L, 90000L, 
95400L, 68400L, 79200L, 69300L, 54900L, 72000L, 60300L, 55800L, 
41400L, 41400L, 37800L, 24300L, 25200L, 32400L, 36000L, 28800L, 
19800L, 18900L, 16200L, 16200L, 60586200L, 25074900L, 18993600L, 
21714300L, 13090500L, 13913100L, 10777500L, 11007900L, 11732400L, 
8385300L, 9188100L, 7379100L, 8556300L, 7248600L, 6276600L, 7616700L, 
6766200L, 6323400L, 5963400L, 5404500L, 6618600L, 5781600L, 5630400L, 
5091300L, 5515200L, 4810500L, 4392900L, 4674600L, 4113900L, 4517100L, 
3974400L, 3650400L, 3759300L, 3761100L, 3456000L, 3180600L, 2963700L, 
2999700L, 2619000L, 2723400L, 2321100L, 2286000L, 2167200L, 1925100L, 
1906200L, 1649700L, 1658700L, 1561500L, 1567800L, 1494900L, 1378800L, 
1384200L, 1219500L, 1257300L, 1220400L, 1098000L, 1133100L, 959400L, 
1044900L, 3713400L, 1295100L, 827100L, 892800L, 549000L, 561600L, 
440100L, 432900L, 461700L, 319500L, 344700L, 248400L, 277200L, 
221400L, 185400L, 227700L, 222300L, 206100L, 189900L, 177300L, 
209700L, 189900L, 170100L, 156600L, 170100L, 163800L, 153900L, 
169200L, 148500L, 185400L, 162000L, 165600L, 176400L, 149400L, 
128700L, 111600L, 99000L, 83700L, 60300L, 48600L, 32400L, 27000L, 
12600L, 6300L, 5400L, 8100L, 9000L, 11700L, 15300L, 16200L, 11700L, 
10800L, 6300L, 5400L, 6300L, 9900L, 14400L, 15300L, 15300L), 
    Forest_type = c(1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
    1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
    1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
    1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
    1L, 1L, 1L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 
    2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 
    2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 
    2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 2L, 
    2L, 2L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 
    3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 
    3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 
    3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 3L, 
    3L), Distance = c(30L, 60L, 90L, 120L, 150L, 180L, 210L, 
    240L, 270L, 300L, 330L, 360L, 390L, 420L, 450L, 480L, 510L, 
    540L, 570L, 600L, 630L, 660L, 690L, 720L, 750L, 780L, 810L, 
    840L, 870L, 900L, 930L, 960L, 990L, 1020L, 1050L, 1080L, 
    1110L, 1140L, 1170L, 1200L, 1230L, 1260L, 1290L, 1320L, 1350L, 
    1380L, 1410L, 1440L, 1470L, 1500L, 1530L, 1560L, 1590L, 1620L, 
    1650L, 1680L, 1710L, 1740L, 1770L, 30L, 60L, 90L, 120L, 150L, 
    180L, 210L, 240L, 270L, 300L, 330L, 360L, 390L, 420L, 450L, 
    480L, 510L, 540L, 570L, 600L, 630L, 660L, 690L, 720L, 750L, 
    780L, 810L, 840L, 870L, 900L, 930L, 960L, 990L, 1020L, 1050L, 
    1080L, 1110L, 1140L, 1170L, 1200L, 1230L, 1260L, 1290L, 1320L, 
    1350L, 1380L, 1410L, 1440L, 1470L, 1500L, 1530L, 1560L, 1590L, 
    1620L, 1650L, 1680L, 1710L, 1740L, 1770L, 30L, 60L, 90L, 
    120L, 150L, 180L, 210L, 240L, 270L, 300L, 330L, 360L, 390L, 
    420L, 450L, 480L, 510L, 540L, 570L, 600L, 630L, 660L, 690L, 
    720L, 750L, 780L, 810L, 840L, 870L, 900L, 930L, 960L, 990L, 
    1020L, 1050L, 1080L, 1110L, 1140L, 1170L, 1200L, 1230L, 1260L, 
    1290L, 1320L, 1350L, 1380L, 1410L, 1440L, 1470L, 1500L, 1530L, 
    1560L, 1590L, 1620L, 1650L, 1680L, 1710L, 1740L, 1770L), 
    Percent = c(44.44565403, 38.05758742, 32.81164195, 28.37059427, 
    24.10736642, 21.75626368, 20.22018818, 19.13486005, 17.77022516, 
    16.77136219, 16.36794315, 16.1306284, 15.13920111, 14.37119571, 
    14.10455796, 13.31675783, 13.01669094, 12.22020569, 11.79202684, 
    11.60205245, 10.92979573, 10.18004603, 9.378515186, 9.301602115, 
    8.156440826, 7.683313847, 6.51369356, 6.171548117, 5.751243781, 
    5.275562001, 4.923458833, 4.740507751, 4.436188811, 4.358353511, 
    4.024096386, 3.93907563, 3.679592414, 3.24767015, 3.249918752, 
    3.327055869, 2.824228911, 3.31075997, 3.081232493, 2.763932941, 
    3.629764065, 3.509690938, 3.237597911, 2.564102564, 2.548476454, 
    2.440441604, 1.717557252, 1.774397972, 2.575107296, 2.772002772, 
    2.29390681, 1.755786113, 1.62037037, 1.634877384, 1.505016722, 
    52.34599773, 58.90025792, 64.38464824, 68.80061595, 72.83789874, 
    75.20797859, 76.64981118, 77.80534351, 79.11634399, 80.17382325, 
    80.60797473, 81.13805047, 82.1978212, 83.09089033, 83.43103242, 
    84.16708105, 84.21642209, 85.00907441, 85.48574377, 85.59007982, 
    86.33482038, 86.96358468, 87.9640045, 87.99191165, 89.09566735, 
    89.27676633, 90.32198372, 90.55090656, 90.96517413, 90.98984772, 
    91.35291684, 91.12558976, 91.28059441, 91.98767334, 92.53012048, 
    92.80462185, 93.20690631, 94.12595312, 94.57263568, 94.97802888, 
    95.83797845, 95.56057186, 96.35854342, 96.91889443, 96.09800363, 
    96.01885804, 96.24020888, 96.71125975, 96.50969529, 96.51365485, 
    97.45547074, 97.46514575, 96.9241774, 96.81219681, 97.20430108, 
    97.36632083, 97.14506173, 96.82107175, 97.0735786, 3.208348237, 
    3.042154666, 2.803709805, 2.82878978, 3.054734839, 3.035757723, 
    3.13000064, 3.059796438, 3.113430843, 3.05481456, 3.024082116, 
    2.731321128, 2.662977693, 2.537913959, 2.464409618, 2.516161114, 
    2.766886972, 2.770719903, 2.72222939, 2.807867731, 2.735383893, 
    2.856369297, 2.657480315, 2.706486234, 2.747891829, 3.039919826, 
    3.164322724, 3.277545328, 3.28358209, 3.734590283, 3.723624328, 
    4.133902494, 4.283216783, 3.653973145, 3.445783133, 3.256302521, 
    3.113501274, 2.62637673, 2.177445564, 1.694915254, 1.337792642, 
    1.128668172, 0.56022409, 0.317172633, 0.272232305, 0.471451021, 
    0.522193211, 0.724637681, 0.941828255, 1.045903544, 0.82697201, 
    0.760456274, 0.500715308, 0.415800416, 0.501792115, 0.877893057, 
    1.234567901, 1.544050863, 1.421404682), div2erroftot = c(4.966434556, 
    1.564186201, 0.934497422, 0.864464421, 0.418286433, 0.388570197, 
    0.27448418, 0.261363854, 0.254412687, 0.169347789, 0.180122097, 
    0.141630014, 0.152143653, 0.121037184, 0.102442814, 0.116345146, 
    0.100965691, 0.087758475, 0.079417075, 0.070728117, 0.080894198, 
    0.065340963, 0.057955349, 0.051959968, 0.048745054, 0.039969206, 
    0.030585132, 0.030758911, 0.025111088, 0.025284867, 0.02067972, 
    0.018333701, 0.017638585, 0.017204137, 0.01451056, 0.013033437, 
    0.011295645, 0.009992302, 0.008688958, 0.009210295, 0.006603608, 
    0.007646283, 0.006690498, 0.005300264, 0.006951166, 0.005821602, 
    0.005387154, 0.003996921, 0.003996921, 0.003649362, 0.002346019, 
    0.002432908, 0.003128025, 0.003475583, 0.002780467, 0.001911571, 
    0.001824681, 0.001564012, 0.001564012, 5.849232678, 2.42083056, 
    1.833717675, 2.096384872, 1.263808926, 1.343226002, 1.040502708, 
    1.062746441, 1.132692552, 0.809550207, 0.887055712, 0.712407658, 
    0.826059227, 0.699808669, 0.605967924, 0.735346507, 0.653235855, 
    0.610486182, 0.57573035, 0.521771922, 0.638985964, 0.558178655, 
    0.543581206, 0.491534348, 0.53245934, 0.4644248, 0.424108035, 
    0.451304473, 0.397172266, 0.436098797, 0.383704381, 0.352424132, 
    0.362937771, 0.363111551, 0.333655983, 0.307067772, 0.286127384, 
    0.289602967, 0.252848675, 0.262927866, 0.224088224, 0.220699531, 
    0.209230106, 0.185856809, 0.184032128, 0.159268598, 0.160137494, 
    0.15075342, 0.151361647, 0.144323591, 0.133114835, 0.133636172, 
    0.11773538, 0.121384742, 0.117822269, 0.106005286, 0.10939398, 
    0.092624291, 0.100878801, 0.358506403, 0.125034104, 0.079851523, 
    0.086194462, 0.053002643, 0.054219097, 0.042489004, 0.041793887, 
    0.044574354, 0.030845801, 0.033278709, 0.023981524, 0.02676199, 
    0.021374836, 0.017899253, 0.021983063, 0.021461726, 0.019897714, 
    0.018333701, 0.017117247, 0.020245272, 0.018333701, 0.01642213, 
    0.015118787, 0.01642213, 0.015813903, 0.014858118, 0.016335241, 
    0.014336781, 0.017899253, 0.015640124, 0.015987683, 0.017030357, 
    0.01442367, 0.01242521, 0.010774308, 0.009557854, 0.008080731, 
    0.005821602, 0.004692037, 0.003128025, 0.002606687, 0.001216454, 
    0.000608227, 0.000521337, 0.000782006, 0.000868896, 0.001129565, 
    0.001477123, 0.001564012, 0.001129565, 0.001042675, 0.000608227, 
    0.000521337, 0.000608227, 0.000955785, 0.001390233, 0.001477123, 
    0.001477123)), .Names = c("Pixels", "Forest_type", "Distance", 
"Percent", "div2erroftot"), class = "data.frame", row.names = c(NA, 
-177L))

1 个答案:

答案 0 :(得分:1)

如果我理解正确,这很简单,只需稍加修改的面板功能即可处理。

下面的面板功能首先运行panel.xyplot(x,y,...)以获取您已有的绘图,然后使用函数lpoints()向其添加小黑点,这只是晶格基本图形函数points()基于网格的版本。

试试这个:

plot1<-xyplot(Percent ~ Distance, key = mykey, cex = dat$Pixels / 15000000, 
       col = dat$Forest_type+1,
       xlab="Distance", ylab="Percent of pixels",
       data = dat, 
       panel = function(x,y,...){
           panel.xyplot(x,y,...)
           lpoints(x, y, col="black", pch=16, cex=0.01)
      }) 

print(plot1, position=c(0, .5, 1, 1))

enter image description here