I’m interested in leveraging the ‘checkdone!’ function during sweeps to not only secure a low ground state energy but also ensure accurate eigenstate determination. Specifically, I’m considering tracking the convergence of energy variance as an indicator.
Monitoring variance in checkdone would be rather difficult, and not really the right “level” at which to do it, if you wanted to do it in the most efficient way possible. I could see two options for you:
-
Overloading the
measure!
method to compute the variance of the entire state, but only on certain steps to keep the costs lower. Here you would overloadmeasure!
as outlined in the documentation on the Observer system and check whether you are, say, at the end of a sweep and on the first bond. Then you could run code that would compute the variance of the entire MPS. This might not be as efficient as possible since each variance calculation would itself cost something like an extra sweep of DMRG. But it could be practical if it’s fast enough in practice for what you need. -
Altering the DMRG code itself. Inside ITensor’s DMRG code, we use an object called
ProjMPO
to store the projection of the Hamiltonian MPO into the current MPS basis. Hypothetically this could be expanded or altered to also store the projection of H^2 into the MPS basis, to allow computing the variance at each step of DMRG. However, it’s not totally clear this would be cheaper than the option 1 above if you only needed the variance in between each sweep.
You can also look into [1711.01104] Error estimates for extrapolations with matrix-product states as a cheaper way of approximating the energy variance.