Nothing
# Dimension p = 1
Sigma1 <- 0.5
Sigma2 <- 1
kl1_12 <- kld(Sigma1, Sigma2, distribution = "mtd", nu1 = 1, nu2 = 1, eps = 1e-16)
kl1_21 <- kld(Sigma2, Sigma1, distribution = "mtd", nu1 = 1, nu2 = 1, eps = 1e-16)
lambda <- 0.5
test_that("kl works (dim 1)", {
expect_equal(
round(as.numeric(kl1_21), 15),
log( (1 + sqrt(lambda))^2 / (4*sqrt(lambda)) )
)
expect_equal(
round(as.numeric(kl1_21), 15),
log( (1 + sqrt(lambda))^2 / (4*sqrt(lambda)) )
)
})
# Dimension p = 1, 2nd example
Sigma1 <- 0.5
nu1 <- 2
Sigma2 <- 1
nu2 <- 1
kl1_2 <- kld(Sigma1, Sigma2, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = .Machine$double.eps)
test_that("kl1_2 works (dim 1, 2nd exple)", {
expect_equal(
attr(kl1_2, "epsilon"), .Machine$double.eps
)
expect_equal(
round(as.numeric(kl1_2), 16), 0.1447298858494002
)
})
# Dimension p = 1, lambda*nu1/nu2 == 1
nu1 <- 2; Sigma1 <- 0.5
nu2 <- 2; Sigma2 <- 0.5
kl1_12_0 <- kld(Sigma1, Sigma2, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = 1e-16)
kl1_21_0 <- kld(Sigma2, Sigma1, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = 1e-16)
test_that("kl works (dim 1, lambda*nu1/nu2 == 1)", {
expect_equal(
as.numeric(kl1_12_0),
0
)
expect_equal(
as.numeric(kl1_21_0),
0
)
})
# Dimension p = 2
Sigma1 <- diag(0.5, nrow = 2)
Sigma2 <- diag(1, nrow = 2)
kl2_12 <- kld(Sigma1, Sigma2, distribution = "mtd", nu1 = 1, nu2 = 1, eps = 1e-16)
kl2_21 <- kld(Sigma2, Sigma1, distribution = "mtd", nu1 = 1, nu2 = 1, eps = 1e-16)
lambda <- as.complex(0.5)
test_that("kl works (dim 2)", {
expect_equal(
round(as.numeric(kl2_12), 15),
Re(-log(lambda) + 3/sqrt(1-1/lambda) * log(sqrt(lambda) + sqrt(lambda-1)) - 3)
)
expect_equal(
round(as.numeric(kl2_21), 15),
Re(log(lambda) + 3/sqrt(1-lambda) * log(sqrt(1/lambda) + sqrt(1/lambda-1)) - 3)
)
})
# Dimension p = 2; 2nd example
Sigma1 <- matrix(c(0.5, 0, 0, 1), nrow = 2)
Sigma2 <- diag(nrow = 2)
lambda <- 0.5
kl2 <- kld(Sigma1, Sigma2, distribution = "mtd", nu1 = 1, nu2 = 1, eps = 1e-16)
test_that("kl works (dim 2, one of the eigenvalues = 1)", {
expect_equal(
round(as.numeric(kl2), 15),
log(lambda) - 3/2 * 1/sqrt(1-lambda) * log((1 - sqrt(1-lambda))/(1 + sqrt(1-lambda))) - 3
)
})
# Dimension p = 2: third example
nu1 <- 2
Sigma1 <- diag(0.5, nrow = 2)
nu2 <- 1
Sigma2 <- diag(1, nrow = 2)
lambda <- 0.5
kl2_3 <- kld(Sigma1, Sigma2, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = .Machine$double.eps)
test_that("kl2_3 works (dim 2, 2nd example)", {
expect_equal(
attr(kl2_3, "epsilon"), .Machine$double.eps
)
expect_equal(
round(as.numeric(kl2_3), 16), 0.1931471805599454
)
})
# Dimension p = 2, lambda*nu1/nu2 == 1
nu1 <- 2; Sigma1 <- diag(0.5, 2)
nu2 <- 2; Sigma2 <- diag(0.5, 2)
kl2_12_0 <- kld(Sigma1, Sigma2, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = 1e-16)
kl2_21_0 <- kld(Sigma2, Sigma1, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = 1e-16)
test_that("kl works (dim 2, lambda*nu1/nu2 == 1)", {
expect_equal(
as.numeric(kl2_12_0),
0
)
expect_equal(
as.numeric(kl2_21_0),
0
)
})
#Dimension p = 3
nu1 <- 2; nu2 <- 4
Sigma1 <- 4*rbind(c(1, 0.6, 0.2), c(0.6, 1, 0.3), c(0.2, 0.3, 1))
Sigma2 <- rbind(c(1, 0.3, 0.1), c(0.3, 1, 0.4), c(0.1, 0.4, 1))
lambda <- 0.5
kl3_12 <- kld(Sigma1, Sigma2, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = 1e-8)
kl3_21 <- kld(Sigma2, Sigma1, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = 5e-5)
test_that("kl works (dim 3)", {
expect_equal(
attr(kl3_12, "epsilon"), 1e-8
)
expect_equal(
round(as.numeric(kl3_12), 16), 0.9297752865860369
)
expect_equal(
attr(kl3_21, "epsilon"), 5e-5
)
expect_equal(
round(as.numeric(kl3_21), 16), 0.4074954441658625
)
})
# Dimension p = 3, 2nd example
nu1 <- 2; nu2 <- 4
Sigma1 <- 2*rbind(c(1, 0.6, 0.2), c(0.6, 1, 0.3), c(0.2, 0.3, 1))
Sigma2 <- rbind(c(1, 0.3, 0.1), c(0.3, 1, 0.4), c(0.1, 0.4, 1))
kl3 <- kld(Sigma1, Sigma2, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = 1e-16)
test_that("kl12 works (dim 3, 2nd)", {
expect_equal(
attr(kl3, "epsilon"), 1e-16
)
expect_equal(
round(as.numeric(kl3), 16), 0.3979439491689158
)
})
# Dimension p = 3, 3rd example
nu1 <- 2; nu2 <- 1
Sigma1 <- diag(0.5, nrow = 3)
Sigma2 <- Sigma2 <- diag(nrow = 3)
kl3_3 <- kld(Sigma1, Sigma2, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = .Machine$double.eps)
test_that("kl3_3 works (dim 3, 3rd)", {
expect_equal(
attr(kl3_3, "epsilon"), .Machine$double.eps
)
expect_equal(
round(as.numeric(kl3_3), 16), 0.2168616606242311
)
})
# Dimension p = 3, lambda*nu1/nu2 == 1
nu1 <- 2; Sigma1 <- diag(0.5, 3)
nu2 <- 2; Sigma2 <- diag(0.5, 3)
kl3_12_0 <- kld(Sigma1, Sigma2, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = 1e-16)
kl3_21_0 <- kld(Sigma2, Sigma1, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = 1e-16)
test_that("kl works (dim 3, lambda*nu1/nu2 == 1)", {
expect_equal(
as.numeric(kl3_12_0),
0
)
expect_equal(
as.numeric(kl3_21_0),
0
)
})
# Dimension p = 4
nu1 <- 2; nu2 <- 4
Sigma1 <- 4*rbind(c(1, 0.6, 0.2, 0),
c(0.6, 1, 0.3, 0),
c(0.2, 0.3, 1, 0),
c(0, 0, 0, 1))
Sigma2 <- rbind(c(1, 0.3, 0.1, 0),
c(0.3, 1, 0.4, 0),
c(0.1, 0.4, 1, 0),
c(0, 0, 0, 1))
kl4_12 <- kld(Sigma1, Sigma2, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = 1e-4)
kl4_21 <- kld(Sigma2, Sigma1, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = 1e-4)
test_that("kl12 works (dim 4)", {
expect_equal(
attr(kl4_12, "epsilon"), 1e-04
)
expect_equal(
round(as.numeric(kl4_12), 16), 1.039921364830607
)
expect_equal(
attr(kl4_21, "epsilon"), 1e-04
)
expect_equal(
round(as.numeric(kl4_21), 16), 0.5360139882566615
)
})
# Dimension p = 4, lambda*nu1/nu2 == 1
nu1 <- 2; Sigma1 <- diag(0.5, 4)
nu2 <- 2; Sigma2 <- diag(0.5, 4)
kl4_12_0 <- kld(Sigma1, Sigma2, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = 1e-16)
kl4_21_0 <- kld(Sigma2, Sigma1, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = 1e-16)
test_that("kl works (dim 3, lambda*nu1/nu2 == 1)", {
expect_equal(
as.numeric(kl4_12_0),
0
)
expect_equal(
as.numeric(kl4_21_0),
0
)
})
# Dimension p = 3: particular case
nu1 <- 1
Sigma1 <- diag(0.5, nrow = 3)
nu2 <- 2
Sigma2 <- diag(1, nrow = 3)
lambda <- 0.5
kl3pc <- kld(Sigma1, Sigma2, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = .Machine$double.eps)
d <- -2*log((nu2 + sqrt(nu2*lambda))/(2*nu2)) + (sqrt(nu2) - sqrt(lambda))/(sqrt(nu2) + sqrt(lambda))
d <- log( (gamma((nu1+3)/2) * gamma(nu2/2) * nu2^1.5) / (gamma((nu2+3)/2) * gamma(nu1/2) * nu1^1.5) ) +
(nu2 - nu1)/2 * ( digamma((nu1+3)/2) - digamma(nu1/2) ) - 0.5*3*(log(lambda)) -
(nu2 + 3)/2 * d
test_that("kl3pc works (dim 3, particular case)", {
expect_equal(
attr(kl3pc, "epsilon"), .Machine$double.eps
)
expect_equal(
round(as.numeric(kl3pc), 16), d
)
})
# Dimension p = 3: particular case
nu1 <- 1
Sigma1 <- diag(0.5, nrow = 3)
nu2 <- 2
Sigma2 <- diag(1, nrow = 3)
lambda <- 0.5
kl3pc <- kld(Sigma1, Sigma2, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = .Machine$double.eps)
d <- -2*log((nu2 + sqrt(nu2*lambda))/(2*nu2)) + (sqrt(nu2) - sqrt(lambda))/(sqrt(nu2) + sqrt(lambda))
d <- log( (gamma((nu1+3)/2) * gamma(nu2/2) * nu2^1.5) / (gamma((nu2+3)/2) * gamma(nu1/2) * nu1^1.5) ) +
(nu2 - nu1)/2 * ( digamma((nu1+3)/2) - digamma(nu1/2) ) - 0.5*3*(log(lambda)) -
(nu2 + 3)/2 * d
test_that("kl3pc works (dim 3, particular case)", {
expect_equal(
attr(kl3pc, "epsilon"), .Machine$double.eps
)
expect_equal(
round(as.numeric(kl3pc), 16), d
)
})
# Dimension p = 4: particular case
p <- 4
nu1 <- 2
Sigma1 <- diag(0.5, nrow = p)
nu2 <- 4
Sigma2 <- diag(1, nrow = p)
lambda <- 0.5
kl4pc <- kld(Sigma1, Sigma2, distribution = "mtd", nu1 = nu1, nu2 = nu2, eps = 1e-6)
d <- nu2/(nu2 - 2*lambda) - log(2*lambda/nu2) + nu2^2*log(2*lambda/nu2) / ((nu2 - 2*lambda)^2) + 0.5
d <- log( (gamma((nu1+p)/2) * gamma(nu2/2) * nu2^(p/2)) / (gamma((nu2+p)/2) * gamma(nu1/2) * nu1^(p/2)) ) +
(nu2 - nu1)/2 * ( digamma((nu1+p)/2) - digamma(nu1/2) ) - 0.5*p*(log(lambda)) -
(nu2 + p)/2 * d
test_that("kl4pc works (dim 4, particular case)", {
expect_equal(
attr(kl4pc, "epsilon"), 1e-6
)
expect_equal(
round(as.numeric(kl4pc), 6), round(d, 6)
)
})
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.