Note: These are based on an older version of evoMPS, but the differences are minor. Most importantly, compilation of extension modules is no longer necessary.
evoMPS can find ground states and low-lying excited states of one-dimensional quantum systems (local, translation-invariant Hamiltonians) directly in the thermodynamic limit of infinitely long chains. States are represented as infinite matrix product states (MPS) invariant under translation by L sites (block-translation invariant).
evoMPS finds ground states efficiently, even for critical systems, using the nonlinear conjugate gradient method. It computes dispersion relations using the MPS tangent space as ansatz states for low-lying excitations with well-defined momenta.
evoMPS can also simulate nonuniform dynamics in a finite window of an infinite system.
The above features set evoMPS apart from other MPS and DMRG software, which do not usually work directly in the thermodynamic limit and do not exploit the MPS tangent space as an excitations ansatz. In addition, evoMPS can find ground states and simulate real-time dynamics of finite systems with open boundary conditions.
evoMPS is based on algorithms published by Haegeman et al. [1] and Milsted et al. [2], among others.
See the INSTALL file for installation instructions!
The evoMPS algorithms are presented as python classes to be used in a script. Some example scripts can be found in the "examples" directory. To run an example script without installing the evoMPS modules, copy it to the base directory first e.g. under Windows::
copy examples\transverse_ising_uniform.py .
python transverse_ising_uniform.py
Essentially, the user defines a spin chain Hilbert space and a nearest-neighbour Hamiltonian and then carries out a series of small time steps (numerically integrating the effective Schrödinger equation for the MPS parameters)::
sim = EvoMPS_TDVP_Uniform(bond_dim, local_hilb_dim, my_hamiltonian)
for i in range(max_steps):
sim.update()
my_exp_val = sim.expect_1s(my_op)
sim.take_step_RK4(dtau)
Operators, including the Hamiltonian, are defined as arrays like this::
pauli_z = numpy.array([[1, 0],
[0, -1]])
Calculating expectation values or other quantities can be done after each step as desired.
Switching between imaginary time evolution (for finding the ground state) and real time evolution is as easy as multiplying the time step size by a factor of i!
Please send comments to:
ashmilsted at <google's well-known email service>
To submit ideas or bug reports, please use the GitHub Issues system http://github.com/amilsted/evoMPS/.
evoMPS was originally developed as part of an MSc project by Ashley Milsted, supervised by Tobias Osborne at the Institute for Theoretical Physics of Leibniz Universität Hannover http://www.itp.uni-hannover.de/.