Codebase list votca-xtp / upstream/1.6.4 src / libxtp / threecenter_dft.cc
upstream/1.6.4

Tree @upstream/1.6.4 (Download .tar.gz)

threecenter_dft.cc @upstream/1.6.4raw · history · blame

/*
 *            Copyright 2009-2019 The VOTCA Development Team
 *                       (http://www.votca.org)
 *
 *      Licensed under the Apache License, Version 2.0 (the "License")
 *
 * You may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *              http://www.apache.org/licenses/LICENSE-2.0
 *
 *Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 */

#include <votca/xtp/aobasis.h>
#include <votca/xtp/aomatrix.h>
#include <votca/xtp/symmetric_matrix.h>
#include <votca/xtp/threecenter.h>

namespace votca {
namespace xtp {

void TCMatrix_dft::Fill(const AOBasis& auxbasis, const AOBasis& dftbasis) {

  AOCoulomb auxAOcoulomb;
  auxAOcoulomb.Fill(auxbasis);
  _inv_sqrt = auxAOcoulomb.Pseudo_InvSqrt(1e-8);
  _removedfunctions = auxAOcoulomb.Removedfunctions();

  for (Index i = 0; i < auxbasis.AOBasisSize(); i++) {
    try {
      _matrix.push_back(Symmetric_Matrix(dftbasis.AOBasisSize()));
    } catch (std::bad_alloc&) {
      throw std::runtime_error(
          "Basisset/aux basis too large for 3c calculation. Not enough RAM.");
    }
  }
#pragma omp parallel for schedule(dynamic)
  for (Index is = dftbasis.getNumofShells() - 1; is >= 0; is--) {
    const AOShell& dftshell = dftbasis.getShell(is);
    std::vector<Eigen::MatrixXd> block;
    for (Index i = 0; i < dftshell.getNumFunc(); i++) {
      Index size = dftshell.getStartIndex() + i + 1;
      block.push_back(Eigen::MatrixXd::Zero(auxbasis.AOBasisSize(), size));
    }
    FillBlock(block, is, dftbasis, auxbasis);
    Index offset = dftshell.getStartIndex();
    for (Index i = 0; i < Index(block.size()); ++i) {
      Eigen::MatrixXd temp = _inv_sqrt * block[i];
      for (Index mu = 0; mu < temp.rows(); ++mu) {
        for (Index j = 0; j < temp.cols(); ++j) {
          _matrix[mu](i + offset, j) = temp(mu, j);
        }
      }
    }
  }
  return;
}

/*
 * Determines the 3-center integrals for a given shell in the aux basis
 * by calculating the 3-center overlap integral of the functions in the
 * aux shell with ALL functions in the DFT basis set (FillThreeCenterOLBlock)
 */

void TCMatrix_dft::FillBlock(std::vector<Eigen::MatrixXd>& block,
                             Index shellindex, const AOBasis& dftbasis,
                             const AOBasis& auxbasis) {
  const AOShell& left_dftshell = dftbasis.getShell(shellindex);

  Index start = left_dftshell.getStartIndex();
  // alpha-loop over the aux basis function
  for (const AOShell& shell_aux : auxbasis) {
    Index aux_start = shell_aux.getStartIndex();

    for (Index is = 0; is <= shellindex; is++) {

      const AOShell& shell_col = dftbasis.getShell(is);
      Index col_start = shell_col.getStartIndex();
      Eigen::Tensor<double, 3> threec_block(shell_aux.getNumFunc(),
                                            left_dftshell.getNumFunc(),
                                            shell_col.getNumFunc());
      threec_block.setZero();

      bool nonzero = FillThreeCenterRepBlock(threec_block, shell_aux,
                                             left_dftshell, shell_col);
      if (nonzero) {

        for (Index left = 0; left < left_dftshell.getNumFunc(); left++) {
          for (Index aux = 0; aux < shell_aux.getNumFunc(); aux++) {
            for (Index col = 0; col < shell_col.getNumFunc(); col++) {
              // symmetry
              if ((col_start + col) > (start + left)) {
                break;
              }
              block[left](aux_start + aux, col_start + col) =
                  threec_block(aux, left, col);
            }
          }
        }
      }
    }
  }
  return;
}

}  // namespace xtp
}  // namespace votca