Estimate the logarithm of the partition function of the Mallows rank model.
Choose between the importance sampling algorithm described in
vitelli2018BayesMallows and the IPFP algorithm for computing
an asymptotic approximation described in
mukherjee2016BayesMallows. Note that exact partition functions
can be computed efficiently for Cayley, Hamming and Kendall distances with
any number of items, for footrule distances with up to 50 items, Spearman
distance with up to 20 items, and Ulam distance with up to 60 items. This
function is thus intended for the complement of these cases. See
get_cardinalities()
and compute_exact_partition_function()
for details.
Usage
estimate_partition_function(
method = c("importance_sampling", "asymptotic"),
alpha_vector,
n_items,
metric,
n_iterations,
K = 20,
cl = NULL
)
Arguments
- method
Character string specifying the method to use in order to estimate the logarithm of the partition function. Available options are
"importance_sampling"
and"asymptotic"
.- alpha_vector
Numeric vector of \(\alpha\) values over which to compute the importance sampling estimate.
- n_items
Integer specifying the number of items.
- metric
Character string specifying the distance measure to use. Available options are
"footrule"
and"spearman"
whenmethod = "asymptotic"
and in addition"cayley"
,"hamming"
,"kendall"
, and"ulam"
whenmethod = "importance_sampling"
.- n_iterations
Integer specifying the number of iterations to use. When
method = "importance_sampling"
, this is the number of Monte Carlo samples to generate. Whenmethod = "asymptotic"
, on the other hand, it represents the number of iterations of the IPFP algorithm.- K
Integer specifying the parameter \(K\) in the asymptotic approximation of the partition function. Only used when
method = "asymptotic"
. Defaults to 20.- cl
Optional computing cluster used for parallelization, returned from
parallel::makeCluster()
. Defaults toNULL
. Only used whenmethod = "importance_sampling"
.
Value
A matrix with two column and number of rows equal the degree of the
fitted polynomial approximating the partition function. The matrix can be
supplied to the pfun_estimate
argument of compute_mallows()
.
See also
Other partition function:
compute_exact_partition_function()
,
get_cardinalities()
Examples
if (FALSE) { # \dontrun{
# IMPORTANCE SAMPLING
# Let us estimate logZ(alpha) for 20 items with Spearman distance
# We create a grid of alpha values from 0 to 10
alpha_vector <- seq(from = 0, to = 10, by = 0.5)
n_items <- 20
metric <- "spearman"
# We start with 1e3 Monte Carlo samples
fit1 <- estimate_partition_function(
method = "importance_sampling", alpha_vector = alpha_vector,
n_items = n_items, metric = metric, n_iterations = 1e3)
# A matrix containing powers of alpha and regression coefficients is returned
fit1
# The approximated partition function can hence be obtained:
estimate1 <-
vapply(alpha_vector, function(a) sum(a^fit1[, 1] * fit1[, 2]), numeric(1))
# Now let us recompute with 2e3 Monte Carlo samples
fit2 <- estimate_partition_function(
method = "importance_sampling", alpha_vector = alpha_vector,
n_items = n_items, metric = metric, n_iterations = 2e3)
estimate2 <-
vapply(alpha_vector, function(a) sum(a^fit2[, 1] * fit2[, 2]), numeric(1))
# ASYMPTOTIC APPROXIMATION
# We can also compute an estimate using the asymptotic approximation
fit3 <- estimate_partition_function(
method = "asymptotic", alpha_vector = alpha_vector,
n_items = n_items, metric = metric, n_iterations = 50)
estimate3 <-
vapply(alpha_vector, function(a) sum(a^fit3[, 1] * fit3[, 2]), numeric(1))
# We can now plot the estimates side-by-side
plot(alpha_vector, estimate1, type = "l", xlab = expression(alpha),
ylab = expression(log(Z(alpha))))
lines(alpha_vector, estimate2, col = 2)
lines(alpha_vector, estimate3, col = 3)
legend(x = 7, y = 40, legend = c("IS,1e3", "IS,2e3", "IPFP"),
col = 1:3, lty = 1)
# We see that the two importance sampling estimates, which are unbiased,
# overlap. The asymptotic approximation seems a bit off. It can be worthwhile
# to try different values of n_iterations and K.
# When we are happy, we can provide the coefficient vector in the
# pfun_estimate argument to compute_mallows
# Say we choose to use the importance sampling estimate with 1e4 Monte Carlo samples:
model_fit <- compute_mallows(
setup_rank_data(potato_visual),
model_options = set_model_options(metric = "spearman"),
compute_options = set_compute_options(nmc = 200),
pfun_estimate = fit2)
} # }