From de8cd76e8c9f0cb19a3bcf74d8877944fe6a6c24 Mon Sep 17 00:00:00 2001 From: Paul Buerkner Date: Thu, 11 Jun 2020 21:06:53 +0200 Subject: [PATCH 1/2] try to fix issue #75 --- R/as_draws_array.R | 2 +- R/weight_draws.R | 2 +- man/weight_draws.Rd | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/R/as_draws_array.R b/R/as_draws_array.R index eb4092b4..a88088bf 100644 --- a/R/as_draws_array.R +++ b/R/as_draws_array.R @@ -126,7 +126,7 @@ draws_array <- function(..., .nchains = 1) { variables <- names(out) out <- unlist(out) out <- array(out, dim = c(niterations, .nchains, length(variables))) - dimnames(out)[[3]] <- variables + dimnames(out) <- list(NULL, NULL, variables) as_draws_array(out) } diff --git a/R/weight_draws.R b/R/weight_draws.R index 47591b4b..59892a09 100644 --- a/R/weight_draws.R +++ b/R/weight_draws.R @@ -33,8 +33,8 @@ #' #' # add weights which are already on the log scale #' log_weights <- log(weights) +#' x <- weight_draws(x, weights = log_weights, log = TRUE) #' # extract weights -#' x <- weight_draws(x, weights = weights, log = TRUE) #' head(weights(x)) #' #' @export diff --git a/man/weight_draws.Rd b/man/weight_draws.Rd index 3de60e9c..316f46c1 100644 --- a/man/weight_draws.Rd +++ b/man/weight_draws.Rd @@ -56,8 +56,8 @@ head(weights(x)) # add weights which are already on the log scale log_weights <- log(weights) +x <- weight_draws(x, weights = log_weights, log = TRUE) # extract weights -x <- weight_draws(x, weights = weights, log = TRUE) head(weights(x)) } From 8df28a46c70e19e6e44238cea7743a3a69d084f0 Mon Sep 17 00:00:00 2001 From: jgabry Date: Thu, 11 Jun 2020 15:26:17 -0400 Subject: [PATCH 2/2] update weight_draws doc --- R/weight_draws.R | 34 +++++++++++++--------------------- man/weight_draws.Rd | 17 ++++++++++++----- man/weights.draws.Rd | 23 +++++++++++++++-------- 3 files changed, 40 insertions(+), 34 deletions(-) diff --git a/R/weight_draws.R b/R/weight_draws.R index 59892a09..495710ba 100644 --- a/R/weight_draws.R +++ b/R/weight_draws.R @@ -24,18 +24,25 @@ #' x <- example_draws() #' #' # sample some random weights for illustration -#' weights <- rexp(ndraws(x)) +#' wts <- rexp(ndraws(x)) +#' head(wts) #' #' # add weights -#' x <- weight_draws(x, weights = weights) +#' x <- weight_draws(x, weights = wts) +#' #' # extract weights -#' head(weights(x)) +#' head(weights(x)) # defaults to normalized weights +#' head(weights(x, normalize=FALSE)) # recover original weights +#' head(weights(x, log=TRUE)) # get normalized log-weights #' #' # add weights which are already on the log scale -#' log_weights <- log(weights) -#' x <- weight_draws(x, weights = log_weights, log = TRUE) +#' log_wts <- log(wts) +#' head(log_wts) +#' +#' x <- weight_draws(x, weights = log_wts, log = TRUE) #' # extract weights #' head(weights(x)) +#' head(weights(x, log=TRUE, normalize = FALSE)) # recover original log_wts #' #' @export weight_draws <- function(x, weights, ...) { @@ -112,22 +119,7 @@ weight_draws.draws_list <- function(x, weights, log = FALSE, ...) { #' #' @seealso [`weight_draws`], [`resample_draws`] #' -#' @examples -#' x <- example_draws() -#' -#' # sample some random weights for illustration -#' weights <- rexp(ndraws(x)) -#' -#' # add weights -#' x <- weight_draws(x, weights = weights) -#' -#' # return normalized weights -#' weights <- weights(x) -#' head(weights) -#' -#' # return normalized log weights -#' log_weights <- weights(x, log = TRUE) -#' head(log_weights) +#' @inherit weight_draws examples #' #' @export weights.draws <- function(object, log = FALSE, normalize = TRUE, ...) { diff --git a/man/weight_draws.Rd b/man/weight_draws.Rd index 316f46c1..40421a23 100644 --- a/man/weight_draws.Rd +++ b/man/weight_draws.Rd @@ -47,18 +47,25 @@ from \code{draws} objects. x <- example_draws() # sample some random weights for illustration -weights <- rexp(ndraws(x)) +wts <- rexp(ndraws(x)) +head(wts) # add weights -x <- weight_draws(x, weights = weights) +x <- weight_draws(x, weights = wts) + # extract weights -head(weights(x)) +head(weights(x)) # defaults to normalized weights +head(weights(x, normalize=FALSE)) # recover original weights +head(weights(x, log=TRUE)) # get normalized log-weights # add weights which are already on the log scale -log_weights <- log(weights) -x <- weight_draws(x, weights = log_weights, log = TRUE) +log_wts <- log(wts) +head(log_wts) + +x <- weight_draws(x, weights = log_wts, log = TRUE) # extract weights head(weights(x)) +head(weights(x, log=TRUE, normalize = FALSE)) # recover original log_wts } \seealso{ diff --git a/man/weights.draws.Rd b/man/weights.draws.Rd index 1756a033..184dacac 100644 --- a/man/weights.draws.Rd +++ b/man/weights.draws.Rd @@ -28,18 +28,25 @@ See \code{\link{weight_draws}} for details how to add weights to \code{\link{dra x <- example_draws() # sample some random weights for illustration -weights <- rexp(ndraws(x)) +wts <- rexp(ndraws(x)) +head(wts) # add weights -x <- weight_draws(x, weights = weights) +x <- weight_draws(x, weights = wts) -# return normalized weights -weights <- weights(x) -head(weights) +# extract weights +head(weights(x)) # defaults to normalized weights +head(weights(x, normalize=FALSE)) # recover original weights +head(weights(x, log=TRUE)) # get normalized log-weights -# return normalized log weights -log_weights <- weights(x, log = TRUE) -head(log_weights) +# add weights which are already on the log scale +log_wts <- log(wts) +head(log_wts) + +x <- weight_draws(x, weights = log_wts, log = TRUE) +# extract weights +head(weights(x)) +head(weights(x, log=TRUE, normalize = FALSE)) # recover original log_wts } \seealso{