GOOGLE ADS

lunes, 2 de mayo de 2022

Cómo sombrear una región bajo una curva usando ggplot2

He estado tratando de usar ggplot2 para producir una trama similar a este gráfico R:

xv<-seq(0,4,0.01)
yv<-dnorm(xv,2,0.5)
plot(xv,yv,type="l")
polygon(c(xv[xv<=1.5],1.5),c(yv[xv<=1.5],yv[xv==0]),col="grey")

Esto es todo lo que he conseguido con ggplot2:

x<-seq(0.0,0.1699,0.0001) 
ytop<-dnorm(0.12,0.08,0.02)
MyDF<-data.frame(x=x,y=dnorm(x,0.08,0.02))
p<-qplot(x=MyDF$x,y=MyDF$y,geom="line")
p+geom_segment(aes(x=0.12,y=0,xend=0.12,yend=ytop))

Me gustaría sombrear la región de la cola más allá de x=0,12. ¿Cómo haría esto usando ggplot o qplot?

En términos generales, ¿cómo se sombrea cualquier subconjunto debajo de la curva, ya sea una cola o entre dos líneas arbitrarias que dividen la región en áreas distintas?

Gracias por cualquier consejo.


Solución del problema

Crea un polígono con el área que quieres sombrear

#First subst the data and add the coordinates to make it shade to y = 0
shade <- rbind(c(0.12,0), subset(MyDF, x > 0.12), c(MyDF[nrow(MyDF), "X"], 0))
#Then use this new data.frame with geom_polygon
p + geom_segment(aes(x=0.12,y=0,xend=0.12,yend=ytop)) +
geom_polygon(data = shade, aes(x, y))

ingrese la descripción de la imagen aquí

No hay comentarios.:

Publicar un comentario

Flutter: error de rango al acceder a la respuesta JSON

Estoy accediendo a una respuesta JSON con la siguiente estructura. { "fullName": "FirstName LastName", "listings...