A method to reduce the rejection rate in Monte Carlo Markov Chains
Abstract
We present a method for Monte Carlo sampling on systems with discrete variables (focusing in the Ising case), introducing a prior on the candidate moves in a MetropolisHastings scheme which can significantly reduce the rejection rate, called the reducedrejectionrate (RRR) method. The method employs same probability distribution for the choice of the moves as rejectionfree schemes such as the method proposed by Bortz, Kalos and Lebowitz (BKL) bortz_new_1975 (); however, it uses it as a prior in an otherwise standard Metropolis scheme: it is thus not fully rejectionfree, but in a wide range of scenarios it is nearly so. This allows to extend the method to cases for which rejectionfree schemes become inefficient, in particular when the graph connectivity is not sparse, but the energy can nevertheless be expressed as a sum of two components, one of which is computed on a sparse graph and dominates the measure. As examples of such instances, we demonstrate that the method yields excellent results when performing Monte Carlo simulations of quantum spin models in presence of a transverse field in the SuzukiTrotter formalism, and when exploring the socalled robust ensemble which was recently introduced in baldassi2016_unreasonable (). Our code for the Ising case is publicly available RRRcode (), and extensible to userdefined models: it provides efficient implementations of standard Metropolis, the RRR method, the BKL method (extended to the case of continuous energy specra), and the waiting time method dall_faster_2001 ().
I Introduction
Monte Carlo methods play a central role in the simulation and study of a variety of physical and mathematical problems. In particular, Monte Carlo Markov Chains (MCMC) are a class of very powerful and general algorithms to sample from arbitrary probability distributions krauth_statistical_2006 (); furthermore, they are at the basis of some general optimization techniques such as simulated annealing kirkpatrick1983optimization () and quantum annealing santoro2002theory (). Arguably, the most popular general MCMC scheme is based on the MetropolisHastings rule. Concrete implementations of the rule can however suffer, particularly in frustrated systems, from the problem of having a very slow dynamics; one typical manifestation of this is a very high rejection rate of the proposed moves. Indeed, a wealth of different techniques have been proposed in order to overcome this problem and improve the sampling efficiency for specific classes of systems, such as Kinetic Monte Carlo voter2007introduction (), Cluster Monte Carlo wang1990cluster (); wolff1989collective (), parallel tempering earl2005parallel (), and many others (see e.g. landau_guide_2009 ()).
In this paper, we propose yet another such variant, which we call “reducedrejectionrate Monte Carlo”, RRR for short, with a publicly available generic implementation RRRcode (), and present some exploratory numerical results that demonstrate its advantages. The method as described here is applicable to the case of Ising spin systems but could be generalized to Pottslike models, and consists in introducing a prior on the choice of the candidate moves in an otherwise standard MetropolisHastings scheme, with the aim – as the name suggests – of reducing the rejection rate.
Consider a system of interacting Ising spins subject to some Hamiltonian . For simplicity, in the following we will consider Hamiltonians restricted to at most pairwise interactions between the spins, but the treatment is general. Let us then call the set of interacting pairs, and write:
(1) 
We want to sample from the Boltzmann probability distribution at inverse temperature :
(2) 
In the usual MCMC scheme, using the MetropolisHastings rule, one starts from a configuration , proposes a candidate move with some prior probability distribution , and accepts the move with some acceptance rate . Therefore, we write the transition probability of going from configuration to a different configuration in the Markov Chain as:
(3) 
Of course, .
The rejection rate is determined by enforcing the detailed balance condition :
(4) 
which can be accomplished by the usual formula:
(5) 
In a straightforward implementation, the proposed moves consist in choosing one spin uniformly at random and flipping it. Then, the terms in the above equation simplify and one is left with the simple rule:
(6) 
Throughout the paper, we refer to this choice as a “standard Metropolis scheme”. In this work, we will instead focus on choosing the prior in such a way to reduce the rejection rate, while still keeping its computation efficient. The rejection rate minimization is achieved, informally speaking, by making the quantity
(7) 
as close as possible to . We will still only consider single flips as the candidate moves.
The basis of our method is (a generalization of) the rejectionfree algorithm by Bortz, Kalos and Lebowitz bortz_new_1975 (), which we refer to as BKL throughout this paper (it is also known as “the nfold way”). The BKL method goes under the general category of “Kinetic Monte Carlo”, or “fasterthantheclock” (FTTC) schemes, see e.g. krauth_statistical_2006 (). The general FTTC technique is to precompute the probability distribution of the number of consecutive rejections before a move would be accepted, extract a number of MCMC iterations to skip from that distribution (thus “advancing the clock”), then choose a move without rejections. The resulting MCMC has the same statistics as a standard Metropolis scheme, but skipping the rejections may be computationally convenient, especially at low temperatures when the rejection rate is high. Of course, the additional computations involved only lead to an advantage in some cases. In particular, the BKL method was introduced as an efficient method for the case of Ising spin systems with small connectivity, and in which the energy shift induced by a spin flip can only belong to a small set of values. As an example of such system, consider an EdwardsAnderson model, i.e. a dimensional lattice with nearest neighbor interactions and periodic boundary conditions, with and , in which case there are only possible values of : . As it turns out, the requirement of small connectivity is the only crucial one in order to achieve an efficient implementation, while the requirement that the energy shifts are discrete is useful for further optimizing the method: for general energy shifts, an efficient rejectionfree method exists, the waiting time method (WTM for short) dall_faster_2001 (), but we will show that the BKL can also be extended rather straightforwardly and achieve comparable performances to WTM. We will shortly review the BKL method in section II, and show how to modify it in the case of general heterogeneous energy shifts.
The core of our RRR method is to use the same probability distribution for the choice of the move as in the BKL method, but this time as the prior , without the initial skipping of the rejected moves; this leaves a residual rejection rate, given by eq. (5). Although this may appear to be a net loss, this is often not the case, and may even be slightly advantageous in a number of situations, as shown in section V.1. The main advantage of the RRR method however is that it is more easily generalizable. Consider the case in which the energy can be written as the sum of two components:
(8) 
where describes a model with low connectivity, while is a residual part of the energy for which the BKL or WTM methods are not convenient. With our approach, since – as we shall show – we can achieve
(9) 
we are then only left with the acceptance rate relative to the nonsparse part of the system:
(10) 
Then, with the RRR method, we can almost completely absorb the effect of the interaction by including it in the prior. This basic idea was used, with the method we propose here in embryonic form, when studying the socalled robust ensemble (RE) introduced in ref. baldassi2016_unreasonable (); the RRR method is a generalization and an improvement of what was used in that paper. This case is discussed in section V.3. An important case that also falls in this category is the simulation of quantum spin systems via the SuzukiTrotter transformation suzuki1976relationship (), in which case can be identified with the interactions between the replicated SuzukiTrotter spins. This case is discussed in section V.2, where indeed we will show that RRR is able to equilibrate much faster than the standard Metropolis scheme.
Ii The BKL Method
In this section, we briefly review the BKL method. In its original formulation, the authors called the method “the nfold way”, since they were considering the case in which the energy shifts arising from a spin flip could only take a value in a small discrete set. Here, however, we will start with the more general case, and recover the original formulation as a specialized case. We will thus introduce some definitions and notations which we will used for RRR as well.
Let us indicate by a configuration of the spins obtained from another configuration by flipping the spin :
(11) 
We denote the effect of such a spin flip on the energy as:
(12) 
Then, for a given configuration and all possible spin flips, we define the following quantities:
(13)  
(14) 
With these, the probability of rejecting a move in a standard Metropolis scheme (eq. (6)) is , while is the probability of transitioning to the new configuration . The BKL procedure at each step is then as follows:

Extract a number of iterations to skip as , where is a random number extracted uniformly in , and “advance the clock” accordingly.

Extract a spin with probability and flip it, thereby changing the configuration to .

Compute the new values for all and the new .
As mentioned above, by this procedure one realizes the same MCMC transition matrix of standard Metropolis, but can save computational time by skipping the rejected iterations entirely (step 1), at the cost of requiring a specialized sampling procedure (step 2) and some additional bookkeeping (step 3). Note that in step 3 only the flipped spin and its neighbors may change their values of , therefore the bookkeeping operations can be relatively inexpensive for diluted graphs (the details on how to achieve this are given in section IV), which explains the reason for the requirement given in the introduction.
When expressed in this general form, the BKL method is almost equivalent to another closely related rejectionfree method, the waiting time method (WTM) dall_faster_2001 (). However, in the special case in which the set has a small cardinality for all and all (e.g. in the case of a regular lattice with couplings mentioned in the introduction), a further optimization can provide additional computational advantages. In that case, which is the one originally considered by the authors in bortz_new_1975 (), the procedure is as follows: for a given configuration , we divide all the spins into classes, based on the energy shift induced by flipping them:
(15) 
All the spins in the same class will thus have the same associated probability (eq. (13)), thus we only need to keep track of one probability for each class, and of the class sizes. Let us then define:
(16)  
(17) 
With these, we can also express (eq. (14)) as:
(18) 
In this specialized case, the step 2 of the BKL scheme above is performed in two separate steps:


Extract a class with probability

Extract a spin uniformly at random from the chosen class, and flip it.

The update step 3 is also simplified, since it can use a more efficient data structure. The details are given in section IV.
Iii The RRR Method
In the RRR method, when applied to sparse models, the proposal simply follows the BKL step 2 of the previous section, without the skipping step 1 and without accepting the move right away, i.e.:
(19) 
With this choice, the expression involved in the acceptance rate , eq. (7), takes the remarkably simple form:
(20) 
where is the same as for the BKL algorithm, eq. (14), and is the same quantity computed for the new candidate configuration . Indeed, this choice significantly reduces – and in many cases nearly eliminates – the rejection rate. The basic reason for this is that, at fixed (nonzero) temperature and in the thermodynamic limit , is an extensive quantity and the perturbation induced by the spin flip is at most of the order of the connectivity , therefore and to the leading order. Only at fixed and very low temperatures the difference becomes more significant (and indeed, in the limit of at fixed the rejection rate must tend to whenever the system is in a local minimum); in practice, though, this regime appears to be rather narrow, while the acceptance rate seems to be very close to up to rather high values of (see the numerical experiments of section V.1). Moreover, consider a system initialized in a random configuration in the initial transient regime, at an energy far above the equilibrium one:^{1}^{1}1And also far above that of any longlived metastable state which may trap the dynamics, should they exists. the proposed move will be more likely associated to a negative energy shift , due to the form of in eq. (13). In that case, the contribution of spin to the normalization term is in and it is in , and thus unless the effect is overcome by the shifts on the neighbors, which means that in the initial stages there is a bias towards , further reducing the rejection rate.
The resulting MCMC transition matrix is thus no longer the same as that of standard Metropolis, and has in general better convergence properties (for very small systems, this can be assessed numerically by computing the eigenvalues of the transition matrices).
When the method is applied to the twolevel systems mentioned in the introduction, i.e. systems such that the energy can be written as with only begin sparse, the RRR algorithm is straightforwardly modified as follows: first, a candidate spin is chosen according to as described above, and is computed from eq. (20); then, the residual energy shift is computed; finally the move is accepted with probability
(21) 
When is typically much larger than , this method can provide very significant improvements. Experiments on this type of systems are shown in sections V.2 and V.3.
In principle, it may also be possible to exploit the fact that discrete energy spectra allow for a specialized version of the algorithm, and apply the RRR method to sparse graphs with continuous spectra by discretizing the interactions and allowing for a small residual rejection rate (e.g. by writing the couplings as with the chosen from a small discrete set and such that is small). In our tests, however, this strategy led at best to the same performances as using the more general versions of BKL/RRR, or WTM, i.e. the slight advantage of the discretization was always at least counterbalanced by the disadvantage of having a slightly increased rejection rate, and we have thus abandoned this line of inquiry.
Iv Implementation details
During each step of the BKL or RRR algorithms, we need to have an efficient way to a) sample from the distribution , and b) update the distribution under the assumption that only a small subset of the will have changed. To achieve this in our implementation, we used a specialized binary tree which keeps “local cumulative distributions” in memory and can be accessed and updated in time wong_efficient_1980 (). More precisely, let us at first assume for simplicity that is a power of , and define the table of arrays , with , of variable length ; in each entry of an array , we store the sum of elements:
(22) 
We also compute and store . To extract a random element with probability , we use this procedure:

extract a random number , and initialize ;

looping over each , do:

if , set and

otherwise set ;


return .
This requires elementary operations. Updating the structure when one of the is changed is also since each entry only appears in at most entries in the table, and can be updated with a single operation.^{2}^{2}2Other schemes based on more sophisticated data structures such as matias_dynamic_2003 () can achieve better asymptotic performances, but they involve more complex operations, and also consume more random numbers. We consider it unlikely that they could positively and significantly affect the results which we present here considering the system sizes involved (and in any case this would only affect the comparisons between BKL/RRR and WTM for the continuous cases), and we have thus left their use as a potential future improvement to the code. In the general case in which is not a power of , we simply pad the distribution with zeros. Also note that the WTM has the same complexity, since it uses a binary heap as its underlying data structure for performing the analogous sampling and update operations.
In the specialized case of discrete energy shifts, however, we use basically the same approach and data structures as described in the original BKL paper bortz_new_1975 (): at each time, we keep track of the classes’ compositions by using unsorted lists of variable size, and associated lookup tables to determine the position of each spin in the structure. Updating the position of a spin within the structure is an operation, since the structure is unsorted. For example, removing a spin from a list amounts at doing the following: locate its position using the lookup table, move the last spin of the list in its position, reduce the list size, update the lookup table. This data structure then allows to a) keep track of the values of (eq. (16)) for all classes, b) have an efficient way to choose a spin within a class, and c) determine how the neighbors’ classes are affected by the move and perform the update. Note that when the number of classes is very small, the choice of the class (step 2a at the end of section II) is most efficiently performed by simply extracting a uniform random number in and computing the cumulative distribution on the fly until it exceeds that number, without the need of specialized structures. This is for cache efficiency reasons. When instead the number of classes is not so small that more sophisticated methods are required, the discrete specialization is not particularly convenient over the more general method.
When determining the effect of the move on the energy shifts, a loop over the neighbors of the chosen spin is necessary. This introduces an cost, where is the connectivity, as mentioned above. The difference between BKL and RRR is that, in the latter case, this computation is required before the move is accepted. For RRR, we have thus two possible modes of operation: we can either always accept the change at first and undo it if it happens to be rejected (we call this the undo mode), or we can keep in memory the results of the computation (the potential shifts induced by the move) and apply them later if the move is accepted (we call this the staged mode). Empirically, we found that the undo mode has better performance at high acceptance rate, while the staged mode becomes convenient at lower acceptance rates (the transition between the two regimes happening at about or acceptance rate on the discrete or continuous problems we tested, respectively). Therefore, our code determines which strategy to employ based on an ongoing estimate of the acceptance rate. When the acceptance rate of RRR is high, these additional computations are very rarely wasted with respect to the BKL method – it is rare that a move needs to be undone; on the other hand, the RRR method avoids the computation of the number of steps to skip (point 1 in section II), which, as it turns out, can also be relatively expensive. On balance, RRR may be slightly more convenient than BKL even on diluted models, up to some value of where the acceptance rate of RRR starts decreasing.
Finally, we mention the fact that it is common practice in Monte Carlo simulations to boost performance by keeping some kind of memory cache (e.g. the local fields acting on a spin); the need, at least in the staged mode of operation, to perform tentative spin flips, then roll them back, and finally perhaps accepting them, introduces a slight complication in this regard. This however is solved quite easily by keeping an additional cache level which allows to undo the last performed change: in our tests, this proved to be both computationally cheap and sufficient to keep the advantages of the cache mechanisms. We refer the interested reader to the provided code RRRcode () for concrete examples.
V Numerical experiments
We performed numerical experiments comparing the performance of standard Metropolis, BLK (where applicable), WTM (where applicable) and RRR. All tests were run under identical conditions on a 2.5 GHz Intel i74710HQ CPU with a single thread; the code is written in the Julia programming language and run with Julia version 0.5 on a Linux operating system.^{3}^{3}3For reference, we benchmarked the performance of our generic Julia code against a very efficient specialized C implementation of BKL on a pspin model which was kindly made available to us by G. Parisi, and found them to be identical.
In all tests, we set a hard wallclocktime limit (e.g. seconds), and compared most results (e.g. the energy or the overlaps) as a function of the wallclock time. The results were sampled at regular intervals in the simulated Monte Carlo time: we took one sample for every attempted moves in the RRR case, and we scaled the sampling intervals for the other algorithms in order to make sure that a similar amount of samples was collected for each algorithm. We mostly explored the lowtemperature regime, which is the one where RRR (as well as BKL and WTM) can be expected to offer an advantage over standard Metropolis.
v.1 Tests on sparse models
The first batch of experiments which we present here was performed on random regular graphs (RRG) with connectivity , with random couplings. We tested two cases, binary couplings and continuous normally distributed couplings , extracted uniformly and independently, in both cases with no external fields (, see eq. (1)).^{4}^{4}4Qualitatively similar results as those shown here were obtained with EdwardsAnderson graphs and pspin models with random couplings. For each case, we tested at least different random graphs, and ran independent tests for each algorithm and each setting of the parameters. We performed all experiments at fixed , starting from random initial conditions. By construction, we were not expecting the RRR method to outperform BKL or WTM on this type of graph. Thus, the main purpose of these experiments was to check the behavior of RRR, in particular as compared to BKL and WTM, exploring different values of and . As expected, at large and nottoolarge , RRR has a very high acceptance rate (e.g. larger than for in both models with , see below), and thus it should behave almost identically to BKL. As it turns out, it is even slightly better in some regimes.
Figure 1 shows the energy as a function of time (for models with , with ranging from to ), for seconds of simulations (thus nowhere near equilibrium). Figure 2 shows the overlaps as a function of time (for models with at ) and the RRR acceptance rates at different values of and .
Following bhatt_numerical_1988 (), we computed both the selfoverlaps (the overlaps at different times, within a certain time interval, for the same run) and the crossoverlaps (the overlaps for different runs on the same graph at comparable times), and used their difference as a measure of the distance from equilibrium. In both cases, we divided the time in regular intervals in logarithmic scale (so that for example in figure 2 the points displayed at used all samples collected between and , while the points displayed at used the samples collected between and ). The results make clear that the tests are indeed very far from equilibrium, but they help discriminating better the different algorithms, and are qualitatively consistent with the picture that emerges from comparing the energies.
Figure 3 shows the number of moves performed on average per second for each algorithm, as a function of , again confirming the overall picture.
As mentioned above, since on these models BKL is essentially identical to RRR in the veryhighacceptancerate regime algorithmically, the slight advantage of RRR over BKL in the discrete case at (which, although not clearly visible in figure 1a, is visible in figure 2c and even more clearly in figure 3a) can only be ascribed to the computation of the number of moves to skip (step 1 in section II).
Figures 1 and 3 show that only at in the discrete case RRR performs slightly but measurably worse than BKL, since in that case the RRR acceptance rate dropped to (figure 2e). For the continuous case, instead, even at these low temperatures the acceptance rate is still greater than (figure 2f), and still better than BKL in terms of moves per second: this is due to the fact that a fraction of the variables have nearly energy shift cost and are thus selected with higher probability, while in discrete RRG case no such cases exists since is odd. In general, the bottom panels in figure 2 show that, for any given , the RRR acceptance rate increases monotonically with , as expected from the arguments given in section III.
v.2 Quantum Monte Carlo tests
In the second set of experiments, we used the SuzukiTrotter transformation to study a quantum system of spins in a transverse magnetic field. We will only sketch the method here, see e.g. krzakala_pathintegral_2008 () for a nice and more thorough introduction. Consider the following Hamiltonian operator:
(23) 
where is the spin operator (Pauli matrix) in the longitudinal direction , is the spin operator in the transverse direction , and is a magnetic field. The goal is to study the statistical mechanics properties of the system at inverse temperature , i.e. the partition function and the average value of the observables . The wellknown SuzukiTrotter transformation suzuki1976relationship () allows to address this problem by using an effective classical Hamiltonian of Ising spins, with an additional dimension with periodic boundary conditions. The equivalence is realized when the size of this additional (“imaginary”, or “Trotter”) dimension diverges. The effective classical Hamiltonian is written as:
(24) 
where are classical spins, with , and the periodic condition , and where . Therefore, the transformation consists in replicating times the longitudinal part of the original system (the part of the Hamiltonian which commutes with the ), and adding pairwise nearestneighbor ferromagnetic interactions along the Trotter dimension between the corresponding replicated spins. Hereafter, we refer to the system “slices” at fixed as to the “Trotter replicas”.
If such a system can be sampled efficiently, the average value of the observables can be easily computed. In particular, the average value of the energy density can be computed as:
(25) 
The interactions along the Trotter dimension all have connectivity , and all couplings are equal: therefore, that part of the Hamiltonian describes a part of the model with small connectivity, and we can thus apply the RRR method (and since the energy levels are discrete, we can use the specialized discrete version for this case). It is interesting to notice that, at small values of , the corresponding transverse interactions diverge (as the system becomes classical and the replicas collapse); therefore, in that regime, these interactions dominate, and accounting for them through a prior rather than the rejection rate seems particularly promising. The BKL and WTM methods, on the other hand, would need to take into account all the connections of each spin, which are extensive, and are thus those methods are not efficient in this case (we verified that they are indeed orders of magnitude slower than standard Metropolis in the settings we tested).
This formalism is not only used to study quantum physical systems (see e.g. suzuki1977monte (); nakamura2008spin ()), but it is also at the basis of some quantum annealing optimization techniques, in which the main idea is that the system can be made to escape local minima of the energy landscape via the tunneling effect by introducing a transverse field in an otherwise classical problem, rather than by thermal fluctuations. The general scheme is to simulate a system at low temperature but with an initially strong transverse field , which is gradually lowered to in order to recover the original classical system, hopefully in a lowenergy configuration. The usage of Monte Carlo sampling with the SuzukiTrotter scheme in this context is a wellknown technique, see e.g. santoro2002theory (); martovnak2004quantum (); battaglia2005optimization ().
We tested this approach on a SherringtonKirkpatrick (SK) fullyconnected model with random binary couplings , at fixed and , measuring the value of the “instantaneous Hamiltonian density estimator” (the term between angle brackets in eq. (25)) as a function of time. The results, shown in figure 4, clearly indicate that the RRR method can equilibrate much faster than standard Metropolis, and that the gain increases with larger values of the Trotter dimension . The acceptance rate increases with for RRR because of the scaling factor in the first term of eq. (24), while the second term is accounted for by the prior.
A more thorough exploration of the characteristics of the RRR method on this kind of models, and a comparison with alternative Monte Carlo algorithms specifically designed for this purpose like e.g. nakamura2008efficient (), is reserved for a future work.
v.3 Robust Ensemble tests
In a final set of experiments, we applied the RRR method to the socalled robust ensemble (RE), recently introduced in baldassi2016_unreasonable (). For a given Ising model with energy , its RE Hamiltonian at a given inverse temperature is defined on a set of interacting replicas of the original system:
(26) 
where is a control parameter. This Hamiltonian introduces a measure which, compared to the original Gibbs distribution on , enhances the statistical weight of regions of the configuration space with a large free entropy (i.e., roughly speaking, extensive regions in which an exponential number of configurations have low energy), with the parameter indirectly controlling the scale of the region (larger values bring the focus to narrower regions). One typical use of this measure is to use it within a “scoping” procedure, in which is gradually increased. Therefore, the large regime is of particular interest for this problem. In terms of observables, one of the main quantities of interest is the mean energy density across replicas, defined as:
(27) 
This system is formally similar to the Quantum Monte Carlo of the previous section,^{5}^{5}5This remarkable fact will be the subject of a future separate work. and we can use the RRR method to almost entirely account for the effect of the interaction between replicas (the second term in eq. (26)). Note however that for this model the topology of this interaction is different (it’s fullyconnected rather than a loop), and methods based on flipping entire clusters of spins along a replicated dimensions such as nakamura2008efficient () are not applicable.
As in the previous section, we tested this approach on a replicated SherringtonKirkpatrick fullyconnected model with random binary couplings , using , replicas at fixed and varying . The results are shown in figure 5. As expected, RRR is able to absorb most of the effect of the interaction in the prior, and therefore its acceptance rate is almost constant up to very large values of , while that of standard Metropolis drops dramatically. This is true both in terms of accepted moves per attempted spin flip (figure 5e) and of accepted moves per second (figure 5f). As a result, RRR is clearly advantageous in this large regime.
Vi Conclusions
We have presented a Monte Carlo Markov Chain method, called reducedrejectionrate Monte Carlo (RRR), which extends the realm of applicability of rejectionfree methods: by transforming a kinetic Monte Carlo approach into a choice for a prior, we were able to show that it is possible to improve over the performance of a naïve Metropolis scheme by reducing the rejection rate on a class of models. While rejectionfree methods such as BKL and WTM are effective (at low temperatures) for models with low connectivity, the RRR method can also be applied to models in which only a component of the Hamiltonian has that characteristic. For such models, the RRR method can, in many cases, almost remove the rejection rate associated with that component.
We demonstrated this by numerical experiments on Ising spin models, first by showing that RRR indeed nearly eliminates the rejection rate on sparse models (and is thus almost equivalent to BKL) in a wide range of regimes; then by applying it to two models (quantum models and robustensemble models) in which only a part of the Hamiltonian is sparse, and showing that the reduction of the rejection rates leads to improved dynamics with respect to a naïve Metropolis scheme when the sparse part dominates. The experiments were mostly exploratory and aimed at demonstrating the feasibility of the method, and are by no means exhaustive: further work is needed (and planned) to employ this method in practically relevant applications and as a component within more general algorithmic schemes (e.g. simulated annealing or parallel tempering). Since the code is generic and extensible, and publicly available, it will also easily allow for a more widerange exploration of the effectiveness of the technique to other type of sampling and optimization problems.
The method itself is not restricted to Ising spin models: just like the rejectionfree methods it is derived from, it could be straightforwardly applied to models with multiple states per variable (Pottslike models). Of course, this would come at an additional algorithmic cost. In general, the results presented here suggest that such scheme would certainly be convenient whenever the problem is dominated by a sparse component for which the kinetic Monte Carlo approach is better than standard Metropolis, but is also subject to additional dense interactions.
Acknowledgements.
I am deeply indebted to G. Parisi for some crucial observations on an early draft of this manuscript, to R. Zecchina for suggestions and discussions, and to the anonymous referees that reviewed this work for their precious comments. I also wish to thank M. Zamparo and A. Pagnani for helpful suggestions and discussions.References
 (1) A.B. Bortz, M.H. Kalos, and J.L. Lebowitz. A new algorithm for Monte Carlo simulation of Ising spin systems. Journal of Computational Physics, 17(1):10–18, January 1975. doi:10.1016/00219991(75)900601.
 (2) Carlo Baldassi, Christian Borgs, Jennifer T. Chayes, Alessandro Ingrosso, Carlo Lucibello, Luca Saglietti, and Riccardo Zecchina. Unreasonable effectiveness of learning neural networks: From accessible states and robust ensembles to basic algorithmic schemes. Proceedings of the National Academy of Sciences, 2016. doi:10.1073/pnas.1608103113.
 (3) RRR Monte Carlo code. https://github.com/carlobaldassi/RRRMC.jl.
 (4) Jesper Dall and Paolo Sibani. Faster Monte Carlo simulations at low temperatures. The waiting time method. Computer Physics Communications, 141(2):260–267, November 2001. doi:10.1016/S00104655(01)00412X.
 (5) Werner Krauth. Statistical mechanics: algorithms and computations. Number 13 in Oxford master series in physics Statistical, computational, and theoretical physics. Oxford Univ. Press, Oxford, 2006. OCLC: 254061236.
 (6) S. Kirkpatrick, C. D. Gelatt, and M. P. Vecchi. Optimization by Simulated Annealing. Science, 220(4598):671–680, May 1983. doi:10.1126/science.220.4598.671.
 (7) G. E. Santoro. Theory of Quantum Annealing of an Ising Spin Glass. Science, 295(5564):2427–2430, March 2002. doi:10.1126/science.1068774.
 (8) Arthur F. Voter. INTRODUCTION TO THE KINETIC MONTE CARLO METHOD. In Kurt E. Sickafus, Eugene A. Kotomin, and Blas P. Uberuaga, editors, Radiation Effects in Solids, volume 235, pages 1–23. Springer Netherlands, Dordrecht, 2007. doi:10.1007/9781402052958_1.
 (9) JianSheng Wang and Robert H. Swendsen. Cluster Monte Carlo algorithms. Physica A: Statistical Mechanics and its Applications, 167(3):565–579, September 1990. doi:10.1016/03784371(90)90275W.
 (10) Ulli Wolff. Collective Monte Carlo Updating for Spin Systems. Physical Review Letters, 62(4):361–364, January 1989. doi:10.1103/PhysRevLett.62.361.
 (11) David J. Earl and Michael W. Deem. Parallel tempering: Theory, applications, and new perspectives. Physical Chemistry Chemical Physics, 7(23):3910, 2005. doi:10.1039/b509983h.
 (12) David P. Landau and K. Binder. A guide to Monte Carlo simulations in statistical physics. Cambridge University Press, Cambridge; New York, 3rd ed edition, 2009. OCLC: ocn444371657.
 (13) M. Suzuki. Relationship between dDimensional Quantal Spin Systems and (d+1)Dimensional Ising Systems: Equivalence, Critical Exponents and Systematic Approximants of the Partition Function and Spin Correlations. Progress of Theoretical Physics, 56(5):1454–1469, November 1976. doi:10.1143/PTP.56.1454.
 (14) C. K. Wong and M. C. Easton. An Efficient Method for Weighted Sampling without Replacement. SIAM Journal on Computing, 9(1):111–113, February 1980. doi:10.1137/0209009.
 (15) Yossi Matias, Jeffrey Scott Vitter, and WenChun Ni. Dynamic Generation of Discrete Random Variates. Theory of Computing Systems, 36(4):329–358, August 2003. doi:10.1007/s0022400310786.
 (16) R. N. Bhatt and A. P. Young. Numerical studies of Ising spin glasses in two, three, and four dimensions. Physical Review B, 37(10):5606–5614, April 1988. doi:10.1103/PhysRevB.37.5606.
 (17) Florent Krzakala, Alberto Rosso, Guilhem Semerjian, and Francesco Zamponi. Pathintegral representation for quantum spin models: Application to the quantum cavity method and Monte Carlo simulations. Physical Review B, 78(13), October 2008. doi:10.1103/PhysRevB.78.134428.
 (18) M. Suzuki, S. Miyashita, and A. Kuroda. Monte Carlo Simulation of Quantum Spin Systems. I. Progress of Theoretical Physics, 58(5):1377–1387, November 1977. doi:10.1143/PTP.58.1377.
 (19) Tota Nakamura and Yoichi Nishiwaki. Spinlattice model of magnetoelectric transitions in RbCoBr 3. Physical Review B, 78(10), September 2008. doi:10.1103/PhysRevB.78.104422.
 (20) Roman Martoňák, Giuseppe E. Santoro, and Erio Tosatti. Quantum annealing of the travelingsalesman problem. Physical Review E, 70(5), November 2004. doi:10.1103/PhysRevE.70.057701.
 (21) Demian A. Battaglia, Giuseppe E. Santoro, and Erio Tosatti. Optimization by quantum annealing: Lessons from hard satisfiability problems. Phys. Rev. E, 71:066707, Jun 2005. doi:10.1103/PhysRevE.71.066707.
 (22) Tota Nakamura. Efficient Monte Carlo Algorithm in QuasiOneDimensional Ising Spin Systems. Physical Review Letters, 101(21), November 2008. doi:10.1103/PhysRevLett.101.210602.