LIBINT 2.9.0
twoprep_11_11.h
1/*
2 * Copyright (C) 2004-2024 Edward F. Valeev
3 *
4 * This file is part of Libint compiler.
5 *
6 * Libint compiler is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 *
11 * Libint compiler is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with Libint compiler. If not, see <http://www.gnu.org/licenses/>.
18 *
19 */
20
21#ifndef _libint2_src_bin_libint_twoprep1111_h_
22#define _libint2_src_bin_libint_twoprep1111_h_
23
24#include <integral.h>
25#include <integral_11_11.h>
26
27namespace libint2 {
28
36namespace detail {
37template <typename Bra>
38bool is_nonderiv_ss_product(Bra&& bra) {
39 return bra.member(0, 0).zero() && bra.member(1, 0).zero() &&
40 !bra.member(0, 0).contracted() && !bra.member(1, 0).contracted() &&
41 bra.member(0, 0).deriv().zero() && bra.member(1, 0).deriv().zero();
42};
43} // namespace detail
45template <>
46inline bool GenIntegralSet_11_11<CGF, TwoPRep, mType>::this_precomputed()
47 const {
48 if (detail::is_nonderiv_ss_product(parent_type::bra_) &&
49 detail::is_nonderiv_ss_product(parent_type::ket_))
50 return true;
51 else
52 return false;
53}
54
56template <>
58 if (detail::is_nonderiv_ss_product(parent_type::bra_) &&
59 detail::is_nonderiv_ss_product(parent_type::ket_))
60 return true;
61 else
62 return false;
63}
64
65}; // namespace libint2
66
67#endif
bool auto_unroll() const
Implements GenIntegralSet::auto_unroll()
Definition integral_11_11.impl.h:32
Defaults definitions for various parameters assumed by Libint.
Definition algebra.cc:24