3.11.1. horton.orbital_entanglement.orbital_entanglement
– One- and two-orbital entanglement measures¶
Abbreviations used in this module:
- dm1 = a 1-RDM
- dm2 = a 2-RDM
- dm3 = a 3-RDM
- dm4 = a 4-RDM
- odm1 = one-orbital reduced density matrix
- odm2 = two-orbital reduced density matrix
- soentropy = single-orbital entropy
- toentropy = two-orbital entropy
- mutualinfo = mutual information
-
class
horton.orbital_entanglement.orbital_entanglement.
OrbitalEntanglement
(lf, one_dm, two_dm, three_dm=None, four_dm=None)¶ Bases:
object
Arguments:
- lf
- Instance of
horton.matrix.dense.DenseLinalgFactory
orhorton.matrix.cholesky.CholeskyLinalgFactory
- one_dm
Instance of
horton.matrix.base.OneIndex
A 1-RDM
- two_dm
List of instances of
horton.matrix.base.TwoIndex
List of 2-RDM’s. e.g. [\(\Gamma_{pp}^{qq}\), \(\Gamma_{pq}^{pq}\)]
Optional arguments:
- three_dm
Instance of
horton.matrix.base.ThreeIndex
A 3-RDM.
- four_dm
Instance of
horton.matrix.base.FourIndex
A 4-RDM.
-
append_odm1
(index, matrix)¶ Append index and one-orbital-reduced density matrix of orbital ‘index’ to list.
Arguments:
- index
- Orbital index.
- matrix
- The OneIndex object containing the ODMs.
Optional arguments:
-
append_odm2
(index1, index2, matrix)¶ Append indices and two-orbital-reduced density matrix of orbital pair ‘index1/index2’ to list.
Arguments:
- index1
- First orbital index.
- index2
- Second orbital index.
- matrix
- The OneIndex object containing the ODMs.
Optional arguments:
-
calculate_entropy_term
(val, select='vonNeumann')¶ Calculate entropic term
Arguements
- val
- Used to determine entropy
Optional arguments:
- select
- Select entropy function. Default: von Neumann.
-
clear
()¶ Clear all information
-
clear_dm
()¶ Clear the orbital density matrices
-
compute_mutual_information
()¶ Compute mutual information using the single-orbital entropy and the two-orbital entropy.
Arguments:
- one_entropy
- Single-orbital entropy.
- two_entropy
- Two-orbital entropy.
Optional arguments:
-
compute_odm1
(index1)¶
-
compute_odm2
(index1, index2)¶
-
compute_single_orbital_entropy
(select='vonNeumann')¶ Compute single-orbital entropy for each orbital in the active space. Currently, only the von Neumann entropy is supported.
The 1-ODM is assumed to be diagonalized.
Optional arguments:
- select
- Select entropy function. Default: von Neumann.
-
compute_two_orbital_entropy
(select='vonNeumann')¶ Compute two-orbital entropy for each orbital in the active space. Currently, only the von Neumann entropy is supported.
The 1-ODM and 2-ODM are assumed to be diagonalized.
Optional arguments:
- select
- Select entropy function. Default: von Neumann.
-
diagonalize
(mat)¶ Returns eigenvalues of a TwoIndex instance. Only real eigenvalues are returned, any imaginary part will be ignored
Arguments:
- mat
- An TwoIndex instance to be diagonalized.
-
dump_output
(file1='s1.dat', file2='i12.dat')¶ Dump entanglement output files for postprocessing. Output files can be visualized using the build_orbital_entanglement_diagrams.sh script, which uses gnuplot.
Optional arguments:
- file1
string
Filename for storing single-orbital entropy
Default: s1.dat
Format: First column is orbital index. Second column is single-orbital entropy
- file2
string
Filename for storing orbital-pair mutual information
Default: i12.dat
Format: First two columns are orbital indices. Second column is corresponding orbital-pair mutual information
-
cache
¶ The cache object in which the main attributes are stored
-
dm1
¶ Some input 1-RDM
-
dm2
¶ Some input 2-RDM
-
dm3
¶ Some input 3-RDM
-
dm4
¶ Some input 4-RDM
-
lf
¶ The LinalgFactory.
-
mutual_info
¶ The mutual information
-
nbasis
¶ The number of basis functions.
-
odm1
¶ The 1-ORDM
-
odm2
¶ The 2-ORDM
-
so_entropy
¶ The single-orbital entropy
-
to_entropy
¶ The two-orbital entropy
-
class
horton.orbital_entanglement.orbital_entanglement.
OrbitalEntanglementAp1rog
(lf, one_dm, two_dm, three_dm=None, four_dm=None)¶ Bases:
horton.orbital_entanglement.orbital_entanglement.OrbitalEntanglement
Arguments:
- lf
- Instance of
horton.matrix.dense.DenseLinalgFactory
orhorton.matrix.cholesky.CholeskyLinalgFactory
- one_dm
Instance of
horton.matrix.base.OneIndex
A 1-RDM
- two_dm
List of instances of
horton.matrix.base.TwoIndex
List of 2-RDM’s. e.g. [\(\Gamma_{pp}^{qq}\), \(\Gamma_{pq}^{pq}\)]
Optional arguments:
- three_dm
Instance of
horton.matrix.base.ThreeIndex
A 3-RDM.
- four_dm
Instance of
horton.matrix.base.FourIndex
A 4-RDM.
-
append_odm1
(index, matrix)¶ Append index and one-orbital-reduced density matrix of orbital ‘index’ to list.
Arguments:
- index
- Orbital index.
- matrix
- The OneIndex object containing the ODMs.
Optional arguments:
-
append_odm2
(index1, index2, matrix)¶ Append indices and two-orbital-reduced density matrix of orbital pair ‘index1/index2’ to list.
Arguments:
- index1
- First orbital index.
- index2
- Second orbital index.
- matrix
- The OneIndex object containing the ODMs.
Optional arguments:
-
calculate_entropy_term
(val, select='vonNeumann')¶ Calculate entropic term
Arguements
- val
- Used to determine entropy
Optional arguments:
- select
- Select entropy function. Default: von Neumann.
-
clear
()¶ Clear all information
-
clear_dm
()¶ Clear the orbital density matrices
-
compute_mutual_information
()¶ Compute mutual information using the single-orbital entropy and the two-orbital entropy.
Arguments:
- one_entropy
- Single-orbital entropy.
- two_entropy
- Two-orbital entropy.
Optional arguments:
-
compute_odm1
(index1)¶ Compute ODM for orbital index1.
Arguments:
- index1
- First orbital index.
-
compute_odm2
(index1, index2)¶ Compute 2-ODM for orbital indices ‘index1/index2’.
Arguments:
- index1
- First orbital index.
- index2
- Second orbital index.
-
compute_single_orbital_entropy
(select='vonNeumann')¶ Compute single-orbital entropy for each orbital in the active space. Currently, only the von Neumann entropy is supported.
The 1-ODM is assumed to be diagonalized.
Optional arguments:
- select
- Select entropy function. Default: von Neumann.
-
compute_two_orbital_entropy
(select='vonNeumann')¶ Compute two-orbital entropy for each orbital in the active space. Currently, only the von Neumann entropy is supported.
The 1-ODM and 2-ODM are assumed to be diagonalized.
Optional arguments:
- select
- Select entropy function. Default: von Neumann.
-
diagonalize
(mat)¶ Returns eigenvalues of a TwoIndex instance. Only real eigenvalues are returned, any imaginary part will be ignored
Arguments:
- mat
- An TwoIndex instance to be diagonalized.
-
dump_output
(file1='s1.dat', file2='i12.dat')¶ Dump entanglement output files for postprocessing. Output files can be visualized using the build_orbital_entanglement_diagrams.sh script, which uses gnuplot.
Optional arguments:
- file1
string
Filename for storing single-orbital entropy
Default: s1.dat
Format: First column is orbital index. Second column is single-orbital entropy
- file2
string
Filename for storing orbital-pair mutual information
Default: i12.dat
Format: First two columns are orbital indices. Second column is corresponding orbital-pair mutual information
-
cache
¶ The cache object in which the main attributes are stored
-
dm1
¶ Some input 1-RDM
-
dm2
¶ Some input 2-RDM
-
dm3
¶ Some input 3-RDM
-
dm4
¶ Some input 4-RDM
-
lf
¶ The LinalgFactory.
-
mutual_info
¶ The mutual information
-
nbasis
¶ The number of basis functions.
-
odm1
¶ The 1-ORDM
-
odm2
¶ The 2-ORDM
-
so_entropy
¶ The single-orbital entropy
-
to_entropy
¶ The two-orbital entropy