/usr/include/chemps2/TensorS1Bbase.h is in libchemps2-dev 1.6-3.
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 | /*
CheMPS2: a spin-adapted implementation of DMRG for ab initio quantum chemistry
Copyright (C) 2013-2015 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 TENSORS1BBASE_CHEMPS2_H
#define TENSORS1BBASE_CHEMPS2_H
#include "Tensor.h"
#include "TensorT.h"
#include "SyBookkeeper.h"
namespace CheMPS2{
/** TensorS1Bbase class.
\author Sebastian Wouters <sebastianwouters@gmail.com>
\date March 1, 2013
The TensorS1Bbase class is a storage class for TensorS1 and TensorB. It also performs the update of a previous TensorS1Bbase based on movingRight.*/
class TensorS1Bbase : public Tensor{
public:
//! Constructor
/** \param indexIn The boundary index
\param IdiffIn Direct product of irreps of the two 2nd quantized operators; both sandwiched & to sandwich
\param movingRightIn If true: sweep from left to right. If false: sweep from right to left
\param denBKIn The problem to be solved */
TensorS1Bbase(const int indexIn, const int IdiffIn, const bool movingRightIn, const SyBookkeeper * denBKIn);
//! Destructor
virtual ~TensorS1Bbase();
//! 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 up particle number sector
\param TwoS1 The up spin symmetry sector
\param I1 The up irrep sector
\param N2 The down particle number sector
\param TwoS2 The down spin symmetry sector
\param I2 The down 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 up particle number sector
\param TwoS1 The up spin symmetry sector
\param I1 The up irrep sector
\param N2 The down particle number sector
\param TwoS2 The down spin symmetry sector
\param I2 The down 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 boundary index
/** \return the index */
int gIndex() const;
//! Get Idiff
/** \return Idiff */
int gIdiff() const;
//! Clear and update
/** \param S1BbasePrevious TensorS1Bbase needed for the update
\param denT TensorT needed for the update.
\param workmem Work memory */
void update(TensorS1Bbase * S1BbasePrevious, TensorT * denT, double * workmem);
protected:
//! The irrep difference (direct product of the two 2nd quantized operators; both sandwiched & to sandwich)
int Idiff;
//! Whether or not moving right
bool movingRight;
//! The down spin symmetry sector
int * sectorTwoSD;
//! Set all storage variables to 0.0
void Clear();
private:
//update when movingright
void updateMovingRight(TensorS1Bbase * S1BbasePrevious, TensorT * denT, double * workmem);
//update when movingleft
void updateMovingLeft(TensorS1Bbase * S1BbasePrevious, TensorT * denT, double * workmem);
};
}
#endif
|