tf.contrib.bayesflow.monte_carlo.expectation_importance_sampler_logspace(log_f, log_p, sampling_dist_q, z=None, n=None, seed=None, name='expectation_importance_sampler_logspace')
Importance sampling with a positive function, in log-space.
With p(z) := exp{log_p(z)}, and f(z) = exp{log_f(z)}, this Op returns
Log[ n^{-1} sum_{i=1}^n [ f(z_i) p(z_i) / q(z_i) ] ], z_i ~ q,
\approx Log[ E_q[ f(Z) p(Z) / q(Z) ] ]
= Log[E_p[f(Z)]]
This integral is done in log-space with max-subtraction to better handle the often extreme values that f(z) p(z) / q(z) can take on.
In contrast to expectation_importance_sampler, this Op returns values in log-space.
User supplies either Tensor of samples z, or number of samples to draw n
Args:
-
log_f: Callable mapping samples fromsampling_dist_qtoTensorswith shape broadcastable toq.batch_shape. For example,log_fworks "just like"sampling_dist_q.log_prob. -
log_p: Callable mapping samples fromsampling_dist_qtoTensorswith shape broadcastable toq.batch_shape. For example,log_pworks "just like"q.log_prob. -
sampling_dist_q: The sampling distribution.tf.contrib.distributions.BaseDistribution.float64dtyperecommended.log_pandqshould be supported on the same set. -
z:Tensorof samples fromq, produced byq.sample_n. -
n: IntegerTensor. Number of samples to generate ifzis not provided. -
seed: Python integer to seed the random number generator. -
name: A name to give thisOp.
Returns:
Logarithm of the importance sampling estimate. Tensor with shape equal to batch shape of q, and dtype = q.dtype.
Please login to continue.