R/uLSIF.R

#' Estimate Density Ratio p(x)/q(x) by uLSIF (unconstrained Least-Square Importance Fitting)
#'
#' @param x1 numeric vector or matrix. Data from a numerator distribution p(x).
#' @param x2 numeric vector or matrix. Data from a denominator distribution q(x).
#' @param sigma positive numeric vector. Search range of Gaussian kernel bandwidth.
#' @param lambda positive numeric vector. Search range of regularization parameter.
#' @param kernel_num positive integer. Number of kernels.
#' @param verbose logical(default TRUE).
#'
#' @return uLSIF object that contains a function to compute estimated density ratio.
#'
#' @export
uLSIF <- function(x1, x2,
                  sigma = 10 ^ seq(-3, 1, length.out = 9),
                  lambda = 10 ^ seq(-3, 1, length.out = 9),
                  kernel_num = 100, verbose = TRUE) {

  params <- alist(x1 = x1, x2 = x2,
                  sigma = sigma, lambda = lambda, alpha = 0,
                  kernel_num = kernel_num, verbose = verbose)
  result <- do.call(RuLSIF, params)
  class(result) <- c("uLSIF", class(result))
  result
}
hoxo-m/densratio documentation built on June 30, 2019, 2:58 p.m.