有人可以解释这些代码是什么意思吗?

问题描述 投票:0回答:1

我一直试图找到一种方法来制作具有颜色强度的散点图,该散点图指示该区域中绘制的点的密度(这是一个有很多重叠的大数据集)。我发现这些代码行允许我执行此操作,但我想确保自己真正了解每行的实际功能。在此先感谢:)

get_density <- function(x, y, ...){
  dens <- MASS::kde2d(x, y, ...)
  ix <- findInterval(x, dens$x)
  iy <- findInterval(y, dens$y)
  ii <- cbind(ix, iy)
  return(dens$z[ii])
}

set.seed(1)

dat <- data.frame(x = subset2$conservation.phyloP, y = subset2$gene.expression.RPKM)
dat$density <- get_density(dat$x, dat$y, n = 100)  
r scatter kernel-density
1个回答
0
投票

下面是带有一些解释性注释的函数,如果有什么令人困惑的地方,请告诉我:

# The function "get_density" takes two arguments, called x and y
# The "..." allows you to pass other arguments 
get_density <- function(x, y, ...){ 

# The "MASS::" means it comes from the MASS package, but makes it so you don't have to load the whole MASS package and can just pull out this one function to use. 
# This is where the arguments passed as "..." (above) would get passed along to the kde2d function
dens <- MASS::kde2d(x, y, ...)
# These lines use the base R function "findInterval" to get the density values of x and y
ix <- findInterval(x, dens$x)
iy <- findInterval(y, dens$y)
# This command "cbind" pastes the two sets of values together, each as one column
ii <- cbind(ix, iy)
# This line takes a subset of the "density" output, subsetted by the intervals above
return(dens$z[ii])
}  

# The "set.seed()" function makes sure that any randomness used by a function is the same if it is re-run (as long as the same number is used), so it makes code more reproducible
set.seed(1)

dat <- data.frame(x = subset2$conservation.phyloP, y = subset2$gene.expression.RPKM)
dat$density <- get_density(dat$x, dat$y, n = 100)  

如果您的问题是关于MASS::kde2d函数本身的,那么最好重写此StackOverflow问题以反映这一点!

© www.soinside.com 2019 - 2024. All rights reserved.