The following code plots the
price of the diamonds as a function of
depth using a 2d binning.
library(ggplot2) data(diamonds) gp <- ggplot(diamonds,aes(x=carat,y=depth,z=price)) gp <- gp +stat_summary_2d() gp
I would now like represent, not just the price, but also another continuous variable, say
x, as a different color channel. So the intensity of blue would give me the
price and the intensity of red would give the
x (and potentially a third variable coded in the green channel).
What is the best way the achieve this? Do I have to manually bin the data, compute the summary and plot the resulting raster, or is there a quicker way?
Or is it possible to do it on three different plots using the
zvalue and then merge them by assigning each of them to a different color channel?
Update For a more explicit example, the following code generates three plots (see below). I would like to merge them into one plot, each one associate with one color channel, so that I would have one red blob, one green blob and one blue blog in a single plot.
library(ggplot2) n <- 10000 cx <- c(-1, 0, 1) cy <- c(0,1,-1) x <- rnorm(n,0,1) y <- rnorm(n,0,1) v <- list() v <- lapply(seq(3),function(i)dnorm(x,cx[i],0.5)*dnorm(y,cy[i],0.5)) data <- data.frame(x,y,v1=v[]/max(v[]),v2=v[/max(v[]), v3=v[]/max(v[])) gp1 <- ggplot(data, aes(x=x,y=y,z=v1)) + stat_summary_2d() + scale_colour_identity() gp2 <- ggplot(data, aes(x=x,y=y,z=v2)) + stat_summary_2d() + scale_colour_identity() gp3 <- ggplot(data, aes(x=x,y=y,z=v3)) + stat_summary_2d()+ scale_colour_identity()