VMPS++
|
Clebsch-Gordon coefficients describe the coupling of irreps of a group. For the irreps are labeled by the spin quantum number , for the irreps are labeled by an integer for the amount of particles for example. The CGC depend on three irreps: the two ordered (first and second ) irreps to couple and the total irrep .
(1) |
For , this simply requires . Hence the CGc for are symmetric in and but not for other permutations. For the symmetry relations can be found on wikipedia.
CGC can be multiplied to give recoupling coefficients which are related to Wigner -symbols. The -symbol is related to the recoupling of three irreps:
(2) |
In the first column the CGC share the first irrep and in the second column they share the second irrep. The second and third irrep from the CGC in the first column and first row build the first irrep from the CGC in the second column. The second and thir irreps from the CGC from the first column and second row build the third irreps of the CGC in the second column. It is worthwhile to have this visual structure to identify if the sum over four CGC forms a recoupling coeff or not. The -symbol is the recoupling coeff which is related to the -symbol (curly brackets):
(3) |
The same quantities exist for four irreps. The recoupling coeff is:
(4) |
Notice, that: in the first column the CGC shares the first irrep, in the second column they share the second irrep and in the third column they share the third irrep. Between the first and second column one can draw a cross from and . In the last column the first and second irrep of each CGC comes from the third irrep in the CGC in the same row but from the first or second column respectively. All are summed beside the last one from the CGC in the third column. It is worthwhile to have this visual structure to identify if the sum over six CGC forms a recoupling coeff or not. The -symbol is defined as:
(5) |
For a tensor operator the following holds:
(6) |
This is convention also used by Mc Culloch. The CGC is build so that the first irrep is the ket, the second irrep is the operator irrep and the total irrep is the bra. For this means .
For an operator with (scalar operator), the CGC part is , so that the reduced matrix elements are the same as the normal matrix elements. If the trace however is calculated from the reduced matrix elements, one needs to take into account that copies of the reduced matrix elements appear:
(7) |
This coefficients is called coeff_dot in the implementation. It appears at every situation, where one obtains a scalar quantity. E.g. when contracting the left and right environment to obtain an expectation value.
The product of two operators and gives rise to different irreducible tensor operators by the definition:
(8) |
One can obtain the reduced matrix elements of the product directly from the reduced matrix elements of the individual operators. To see this, one inserts in Eq. (8) the CGC as defined in the Wigner-Eckart theorem for all operators, namely , and . Therefore, one sandwiches the equation with and introduces an identity for the operator product on the right side of Eq. (8). For clearness it is worthwile to omit the reduced matrix elements because they factor out. The CGC part reads then:
(9) |
The CGC at the left side can be brought to the right side by multiplying with and summing over and . This gives for the left side and for right side:
(10) |
This equation does not fit the definition of the recouple coeff in Eq. (2). To reach this, one has to interchange and in the CGC . This leads to a an additional phase factor . Afterwards, one can perform the sum over the quantum numbers to obtain a recouple coeff as in Eq. (2).
(11) |
For the sign, one finds:
(12) |
because , and fulfil the triangle condition. In summary, the coefficient for the product is:
(13) |
The corresponding coefficient is called coeff_prod.
The adjoint of tensor operators can be defined with respect to the metric defined in Eq. (8) when coupling two operators of rank to a singlet operator (). The corresponding CGC is . The adjoint tensor operator is therefore:
(14) |
The Wigner Eckart theorem gives:
(15) |
The reduced matrix elements of the adjoint are related to the original one. The factor is obtained when applying the Wigner Eckart theorem for Eq. (14):
(16) |
Interchanging and at the right side leads to the factor and to the subtitution to and to in the CGC at the right. The sign cancels and after reverting all signs of the CGC at the right, the two CGC are identical. Reverting all signs give another sign so that the corresponding coeff reads:
(17) |
The corresponding coefficient is called coeff_adjoint in the implementation. Notice that .
For an MPS, we choose the following convention for the CGC:
(18) |
This is different from the convention by Mc Culloch. For it corresponds to . is the left index from and the right index.
For an MPO, we choose the following convention for the CGC:
(19) |
For it corresponds to and . is the left index from and the right index. points in the direction of the ket MPS while into the direction of the bra.
For the left environment we have:
(20) |
For it corresponds to . is pointing to the ket layer, is pointing to the bra layer.
For the right environment we have:
(21) |
For it corresponds to . is pointing to the ket layer, is pointing to the bra layer.
] Reshaping is is the combination of two indices into a super index. This is essentially an isometry which maps the basis states from the two indices into one. The reshaping process is not unique and a convention is neccesary. E.g. without any symmetries a isometry could be chosen as if and otherwise. For symmetric tensors, the isometry should map on proper irreps of the syymetry. The combination of two irreps into the tensor product is exactly the definition for the CGC, so that the isometry needs to be proportional to the CGC.
For a right sweep, we want to left-normalize the -tensor. Hence the incoming index get combined with the physical index . The symmetry part of isometry is chosen as . We have since:
(22) |
is a orthonormality condition for the CGC. Furthermore in the calculation , the CGC drop out for the same reason. Hence there is no extra factor for a right sweep step (left-normalization step).
(23) |
There is also no extra factor when checking for the left-nomalize condition.
For a left sweep, we want to right-normalize the -tensor. Hence the outgoing index get combined with the physical index . The symmetry part of isometry is chosen as . We have but:
(24) |
This can be seen when changing the indices and in both CGC which leads to the factor . The phase factor drops out because it appears twice. The CGC after the interchange multiply to one. A proper normalized is in fact an isometry: . When calculating , one encounters the same equation as above so there is a factor for the left sweep:
(25) |
This factor is called coeff_leftSweep in the implementation. Notice that for the inverse reshaping process, one needs the inverse of this factor. This factor has no different name but simply coeff_leftSweep is called with reversed quantum numbers. When checking for the right-normalize condition one encounters also Eq. (24). Hence one has to encounter the factor from the CGC when checking the right-normalize condition:
(26) |
This factor is called coeff_rightOrtho in the implementation.
For updating the left environment, we have the following equation:
(27) |
Inserting all the CGC for the tensors, the CGC part of this equation reads:
(28) |
We can multiply this equation with and sum over and . The left hand side is then and the right side becomes:
(29) |
Which is easily obtained when analysing that the visual structure fits the requirements for the recoupling coeff in Eq. (4). This coeffecient is called coeff_buildL.
The update of the right environment is similar. Collecting all the CGC for the tensors, the CGC part reads:
(30) |
We can multiply this equation with and sum over and . The left hand side is then and the right side becomes:
(31) |
This is not the correct structure for a recoupling coeff. But the following steps will convert this into the form of Eq. (4). Notice, that I will use coordinates to refer to the CGC in this equation where is the row and is the column.
interchange and for . This gives a factor . Furthermore and goes into and .
interchange and for . This gives a factor . Furthermore and goes into and .
interchange and for . This gives a factor . Furthermore and goes into and .
Flip all signs of the quantum numbers for the CGC in , , and . This gives four phase factors: , , and .
The signs , , and gives in total . This can be seen when noting that (because of the corresponding CGC) and for any and which belong together.
All -dependent factors disappear and the sum over the resulting CGC give a recoupling coeff:
(32) |
together with the factor:
(33) |
Convert the recoupling coeff to a -symbol by Eq. (5). Interchange the first and the last column of the -symbol. This gives a phase factor given by the sum af all quantum numbers in the -symbol. Converting back to a recoupl coeff giv the final coefficient used for the update of the right environment:
(34) |
This coefficient is called coeff_buildR in the implementation.
For the effective Hamiltonian the CGC part reads:
(35) |
We can multiply this equation with and sum over and . The left hand side is then and the right side becomes:
(36) |
Which is easily obtained when analysing that the visual structure fits the requirements for the recoupling coeff in Eq. (4). This coeffecient is called coeff_HPsi. It is identical to coeff_buildL.
The product of two MPS is obtained by the product over the auxiliary space and the combination of and to a combined index . The CGC part of this operation reads:
(37) |
Again we bring the CGC from the left side to the right side by using a orthonormality equation for the CGC and obtain:
(38) |
The recoupl coeff is related to the -symbol and this coefficient for the product of two -tensors is called coeff_Apair in the implementation. Notice, that this is different to coeff_prod (Eq. (13)). This is because of our convention for the -tensors.
Multiplying two MPOs means the product in the auxiliary space and the tensor product in the physical space. Since our convention for the auxiliary indices is the same as for the MPS, the coefficient for the product in the auxiliary space is exactly coeff_Apair. The tensor product in the physical space is identical to coeff_tensorProd (which is not included in the doc yet) since the convention for the physical part of the MPO is which is as for normal tensor operators (Eq. (6)). The total coefficient is simply the product of both.
For this operation, the structure is completely identical to the action of the effective Hamiltonian. This is due to our definition of the CGC structure of the environment. The coefficient is therefore identical to coeff_HPsi. In the implementation, it has an extra name: coeff_AW.
Add graphical visualizations of the different contractions.
Describe the local operators and their reduced matrix elements.
Describe the tensor product of tensor operators for the coefficient coeff_tensorProd.
Think about recoupling of five irreps and -symbols. What is problem here?