LIBINT 2.7.2
twoprep_11_11.h
1/*
2 * Copyright (C) 2004-2021 Edward F. Valeev
3 *
4 * This file is part of Libint.
5 *
6 * Libint 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 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. 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
36 namespace detail {
37 template <typename Bra>
38 bool 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 }
45 template <>
46 inline bool
47 GenIntegralSet_11_11<CGF,TwoPRep,mType>::this_precomputed() const
48 {
49 if (detail::is_nonderiv_ss_product(parent_type::bra_) && detail::is_nonderiv_ss_product(parent_type::ket_))
50 return true;
51 else
52 return false;
53 }
54
56 template <>
57 inline bool
59 {
60 if (detail::is_nonderiv_ss_product(parent_type::bra_) && detail::is_nonderiv_ss_product(parent_type::ket_))
61 return true;
62 else
63 return false;
64 }
65
66};
67
68#endif
69
bool auto_unroll() const
Implements GenIntegralSet::auto_unroll()
Definition: integral_11_11.impl.h:35
Defaults definitions for various parameters assumed by Libint.
Definition: algebra.cc:24