View source on GitHub |
Make the default swap proposal func, with P[swap]
, for replica swap MC.
tfp.mcmc.default_swap_proposal_fn(
prob_swap, name=None
)
With probability prob_swap
, propose combinations of replicas to swap
When exchanging, create combinations of adjacent replicas in
Replica Exchange Monte Carlo. See also review paper [1].
swap_fn = default_swap_proposal_fn(prob_swap=0.5)
swap_fn(num_replica=3)
==> [1, 0, 2] # 1 swap, 0 <--> 1
swap_fn(num_replica=3)
==> [0, 1, 2] # 0 swaps
swap_fn(num_replica=3, batch_shape=[2])
==> [[0, 1],
[2, 0],
[1, 2]]
Args | |
---|---|
prob_swap
|
Scalar Tensor in [0, 1] giving probability that any swaps
will be generated.
|
name
|
Python str name given to ops created by this function.
Default value: 'adjacent_swaps' .
|
References
[1]: David J. Earl, Michael W. Deem Parallel Tempering: Theory, Applications, and New Perspectives https://arxiv.org/abs/physics/0508111