This file is indexed.

/usr/include/chemps2/TensorT.h is in libchemps2-dev 1.8.5-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
/*
   CheMPS2: a spin-adapted implementation of DMRG for ab initio quantum chemistry
   Copyright (C) 2013-2018 Sebastian Wouters

   This program is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; either version 2 of the License, or
   (at your option) any later version.

   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.

   You should have received a copy of the GNU General Public License along
   with this program; if not, write to the Free Software Foundation, Inc.,
   51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/

#ifndef TENSORT_CHEMPS2_H
#define TENSORT_CHEMPS2_H

#include "Tensor.h"
#include "SyBookkeeper.h"

namespace CheMPS2{
/** TensorT class.
    \author Sebastian Wouters <sebastianwouters@gmail.com>
    \date February 18, 2013

    The TensorT class is a storage and gauge transformation class for MPS tensors. */
   class TensorT : public Tensor{

      public:

         //! Constructor
         /** \param site_index The site index
             \param denBK The symmetry bookkeeper of the MPS */
         TensorT( const int site_index, const SyBookkeeper * denBK );

         //! Destructor
         virtual ~TensorT();

         //! Get the number of symmetry blocks
         /** \return The number of symmetry blocks */
         int gNKappa() const;

         //! Get the pointer to the storage
         /** return pointer to the storage */
         double * gStorage();

         //! Get the index corresponding to a certain tensor block
         /** \param N1 The left particle number sector
             \param TwoS1 The left spin symmetry sector
             \param I1 The left irrep sector
             \param N2 The right particle number sector
             \param TwoS2 The right spin symmetry sector
             \param I2 The right irrep sector
             \return The kappa corresponding to the input parameters; -1 means no such block */
         int gKappa( const int N1, const int TwoS1, const int I1, const int N2, const int TwoS2, const int I2 ) const;

         //! Get the storage jump corresponding to a certain tensor block
         /** \param kappa The symmetry block
             \return kappa2index[ kappa ], the memory jumper to a certain block */
         int gKappa2index( const int kappa ) const;

         //! Get the pointer to the storage of a certain tensor block
         /** \param N1 The left particle number sector
             \param TwoS1 The left spin symmetry sector
             \param I1 The left irrep sector
             \param N2 The right particle number sector
             \param TwoS2 The right spin symmetry sector
             \param I2 The right irrep sector
             \return Pointer to the storage of the specified tensor block; NULL means no such block */
         double * gStorage( const int N1, const int TwoS1, const int I1, const int N2, const int TwoS2, const int I2 );

         //! Get the location index
         /** \return the index */
         int gIndex() const;

         //! Get the pointer to the symmetry bookkeeper
         /** \return the pointer to the symmetry bookkeeper */
         const SyBookkeeper * gBK() const;

         //! Set the pointer to the symmetry bookkeeper
         /** \param newBK The pointer to the symmetry bookkeeper */
         void sBK( const SyBookkeeper * newBK );

         //! Fill storage with random numbers 0 < val < 1.
         void random();

         //! Apply alpha * ( number operator ) + beta to the MPS tensor
         /** \param alpha Prefactor of the number operator
             \param beta  Constant to be multiplied with the MPS tensor */
         void number_operator( const double alpha, const double beta );

         //! Left-normalization
         /** \param Rstorage Where the R-part of the QR-decomposition can be stored (diagonal TensorOperator). */
         void QR( Tensor * Rstorage );

         //! Right-normalization
         /** \param Lstorage Where the L-part of the LQ-decomposition can be stored (diagonal TensorOperator). */
         void LQ( Tensor * Lstorage );

         //! Multiply at the left with a diagonal TensorOperator
         /** \param Mx The diagonal TensorOperator with which the current TensorT should be multiplied at the left */
         void LeftMultiply( Tensor * Mx );

         //! Multiply at the right with a diagonal TensorOperator
         /** \param Mx The diagonal TensorOperator with which the current TensorT should be multiplied at the right */
         void RightMultiply( Tensor * Mx );

         //! Reset the TensorT (if virtual dimensions are changed)
         void Reset();

         //! Check whether the TensorT is left-normal
         /** \return Whether TensorT is left-normal */
         bool CheckLeftNormal() const;

         //! Check whether the TensorT is right-normal
         /** \return Whether TensorT is right-normal */
         bool CheckRightNormal() const;

      private:

         //! The MPS bookkeeper
         const SyBookkeeper * denBK;

         //! The left particle number sector
         int * sectorNL;

         //! The right particle number sector
         int * sectorNR;

         //! The left spin sector
         int * sectorTwoSL;

         //! The right spin sector
         int * sectorTwoSR;

         //! The left irrep sector
         int * sectorIL;

         //! The right irrep sector
         int * sectorIR;

         //! Delete all arrays
         void DeleteAllArrays();

         //! Allocate all arrays
         void AllocateAllArrays();

   };
}

#endif