2013-01-19 7 views
12

I currrently mieć kod zawarte poniżej narysować to: enter image description hereRysunek przedstawia wokół wielu grup geom_point z ggplot

Co staram się zrobić, to kontur dla każdej z grup, aby śledzić wszystkie punkty w każdej grupie - zamiast pomijać niektóre z nich, tak jak obecnie. Ponadto chciałbym, aby każdy kontur miał półprzezroczyste wypełnienie. Dzięki za pomoc.

library(ggplot2) 
library(reshape) 
library(car) 

G1 <- 1:10 
G2 <- 11:20 
G3 <- 21:30 
G4 <- 31:35 
G5 <- 36:41 

sdata <- read.csv("http://dl.dropbox.com/u/58164604/sdata.csv", stringsAsFactors = FALSE) 
pdata<-melt(sdata, id.vars="Var") 

VarArea <- data.frame(unique(pdata$Var)) 
VarFinalMin <-c() 
for (g in 1:max(VarArea)) 
{ 
VarNum<-pdata[which(pdata$Var==g),1:c(ncol(pdata))] 
VarN <- g 
VarMin <- min(VarNum$value) 
VarMinN <- cbind(VarN, VarMin) 
VarFinalMin <- rbind(VarFinalMin,VarMinN) 
} 
VFinalMin <- data.frame(VarFinalMin) 
colnames(VFinalMin)<-c("Variable", "Value") 

VarFinalMax <-c() 
for (g in 1:max(VarArea)) 
{ 
VarNum<-pdata[which(pdata$Var==g),1:c(ncol(pdata))] 
VarN <- g 
VarMax <- max(VarNum$value) 
VarMaxN <- cbind(VarN, VarMax) 
VarFinalMax <- rbind(VarFinalMax,VarMaxN) 
} 
VFinalMax <- data.frame(VarFinalMax) 
colnames(VFinalMax)<-c("Variable", "Value") 

VFinal<-rbind(VFinalMin, VFinalMax) 
VFinal$Group <- recode(VFinal$Variable, "G1 = 'A'; G2 = 'B'; G3 = 'C'; G4 = 'D'; G5 = 'E'") 

ggplot(VFinal, aes(Variable, Value, colour = Group)) + geom_point() 
find_hull <- function(VFinal) VFinal[chull(VFinal$Variable, VFinal$Value), ] 
hulls <- ddply(VFinal, "Group", find_hull) 
ggplot(VFinal, aes(Variable, Value, colour = Group)) + geom_point() + geom_polygon(data = hulls, fill = NA) 
+2

Zrzut ekranu, w pełni odtwarzalny kod, w tym wezwania do biblioteki - +1 za świetne pytanie. – SlowLearner

Odpowiedz

11

Jeśli uporządkować dna i czubki swoich kształtów odpowiednio wstępujących i zstępujących, można po prostu użyć geom_polygon na oryginalnym data.frame i przejść całą wypukłą rzeczy kadłuba:

VLarge <- VFinal[which(VFinal$Value > 25000),] 
VLarge <- VLarge[order(-VLarge$Variable, VLarge$Group),] 
VSmall <- VFinal[which(VFinal$Value <= 25000),] 
VSmall <- VSmall[order(VSmall$Variable, VSmall$Group),] 
VFinal <- rbind(VSmall, VLarge) 
ggplot(VFinal, aes(Variable, Value, colour = Group)) + geom_point() + 
    geom_polygon(aes(fill = Group), alpha = 0.3) 

enter image description here

+0

Argh, pokonaj mnie ... Nice one – SlowLearner

+1

Półprzezroczyste wypełnienie można uzyskać, modyfikując ostatnią linię kodu @ Noela, aby przeczytać 'geom_polygon (aes (wypełnienie = grupa, alfa = 0.3))' – SlowLearner

+0

HT @SlowLearner. Dodano go do odpowiedzi. – Noah