我想使用R从两个伽马分布计算KL距离。



这是我的R代码:

theta1 <- 0.2
theta2 <- 2

f <- function(u)
{
     dgamma(u, shape=1/theta1, scale=theta1) *
      (dgamma(u, shape=1/theta1, scale=theta1, log=TRUE) -
       dgamma(u, shape=1/theta2, scale=theta2, log=TRUE))
}

f <- Vectorize(f)
integrate(f, lower=0, upper=Inf)


您对我的R代码有何评论?您认为这是计算KL距离的好方法吗?

任何建议将不胜感激,

谢谢,
马可

最佳答案

我将定义函数中使用的所有参数。我的意思是:

my.theta1 <- 0.2
my.theta2 <- 2

f <- function(u, theta1, theta2)
{
     dgamma(u, shape=1/theta1, scale=theta1) *
      (dgamma(u, shape=1/theta1, scale=theta1, log=TRUE) -
       dgamma(u, shape=1/theta2, scale=theta2, log=TRUE))
}


f <- Vectorize(f)
integrate(f, lower=0, upper=Inf, theta1 = my.theta1, theta2 = my.theta2)


更明确的表示可以防止“事故”,因为您的函数在更高(全局)的环境中搜索theta1theta2(如果您将此函数深埋在程序中,则可能会变得混乱)。

08-19 19:57