cDMRG enables the application of the Density-Matrix Renormalization Group (DMRG) to continuous quantum systems by spatial partitioning into segments with continuous basis functions. It is based on arXiv:2108.05366 and distinct from cMPS. The code is written for bosons with contact interactions trapped in a box with a sinusoidal potential, divided into segments of equal width.
In order to get this code running on your machine follow these steps.
choco install make
.DIR
in Makefile
such that it points to the ITensor directory.make build
cDMRG
executable that will be used by the front-end Mathematica script,
which are described below.cDMRG consists of two main modules:
The DMRG module consists of the following files:
cDMRG.cc
- main blockcio.h
, cio.cc
- input/outputreadvec.h
, readvec.cc
- reading vectorscSite.h
- site setcDMRGeps.h
- DMRG sweepslocalmpoproj.h
- Hamiltonian MPOsThe DMRG module is called by the Mathematica package cDMRG_input.m
, which generates the necessary
inputs (local basis and operators) for DMRG.
A separate documentation of cDMRG_input.m
is provided in the notebook cDMRG_input_documentation.nb
.
The package can be modified by changing the notebook cDMRG_input.nb
and saving it as a package .m
.
Parameters specifying the local basis, DMRG sweeps, and what results to save are stored in
basistable.m
, epstable.m
, and savetable.m
in the Parameters
directory,
with unique integer pointers that act as IDs.
One can add more entries using a text editor or using the function storenewparam
in cDMRG_inputIDgen.nb
.
Use the notebook cDMRG_inputIDgen.nb
to
(1) specify parameters for the local basis, DMRG parameters, and what results to save,
(2) check if these are already stored as inputs and find their IDs; if not, create new IDs.
Call the program from the command line as
math -noprompt -run '<<cDMRG_input.m' N gamma Nwell V0 M basisid epsid saveid &
where
N
- int
number of particlesgamma
- float
dimensionless interaction strengthNwell
- float
number of potential minimaV0
- float
potential depth in units of recoilM
- int
number of segmentsbasisid
- int
ID for basis parametersepsid
- int
ID for DMRG parameterssaveid
- int
ID for save parametersFor instance a short calculation can be initiated by
math -noprompt -run '<<cDMRG_input.m' 4 10 4 1 8 1 1 1 &
The results are stored in the directory Runs
.
Results from a sample run are stored in the Runs
directory and illustrated with plots in the notebook cDMRG_example_output.nb
.
Codes for splitting a segment at an arbitrary point, and calculating the bipartite entanglement
are provided in the notebook cDMRG_basis_splitting.nb
.
An example is given using the output MPS stored in Runs
.