21#ifndef _libint2_src_bin_libint_shgshellordering_h_
22#define _libint2_src_bin_libint_shgshellordering_h_
24#include <libint2/config.h>
30enum SHGShellOrdering {
31 SHGShellOrdering_Standard = LIBINT_SHGSHELL_ORDERING_STANDARD,
32 SHGShellOrdering_Gaussian = LIBINT_SHGSHELL_ORDERING_GAUSSIAN,
33 SHGShellOrdering_MOLDEN
48inline int INT_SOLIDHARMINDEX_STANDARD(
int l,
int m) {
return m + l; }
56#define FOR_SOLIDHARM_STANDARD(l, m) for ((m) = -(l); (m) <= (l); ++(m)) {
57#define END_FOR_SOLIDHARM }
65inline int INT_SOLIDHARMINDEX_GAUSSIAN(
int l,
int m) {
66 return 2 * std::abs(m) + (m > 0 ? -1 : 0);
75#define FOR_SOLIDHARM_GAUSSIAN(l, m) \
76 for ((m) = 0; (m) != (l) + 1; (m) = ((m) > 0 ? -(m) : 1 - (m))) {
82inline int INT_SOLIDHARMINDEX_MOLDEN(
int l,
int m) {
83 return INT_SOLIDHARMINDEX_GAUSSIAN(l, m);
87#define FOR_SOLIDHARM_MOLDEN(l, m) FOR_SOLIDHARM_GAUSSIAN(l, m)
88#define END_FOR_SOLIDHARM_MOLDEN END_FOR_SOLIDHARM
93 "libint2::INT_SOLIDHARMINDEX(libint2::solid_harmonics_ordering(), l, m) "
94 "instead. Current function returns the standard or gaussian index based on "
95 "build configuration, not on libint2::set_solid_harmonics_ordering() "
97inline
int INT_SOLIDHARMINDEX(
int l,
int m) {
98#if LIBINT_SHGSHELL_ORDERING == LIBINT_SHGSHELL_ORDERING_STANDARD
99 return libint2::INT_SOLIDHARMINDEX_STANDARD(l, m);
100#elif LIBINT_SHGSHELL_ORDERING == LIBINT_SHGSHELL_ORDERING_GAUSSIAN
101 return libint2::INT_SOLIDHARMINDEX_GAUSSIAN(l, m);
103#error "unknown value of macro LIBINT_SHGSHELL_ORDERING"
107inline int INT_SOLIDHARMINDEX(
int sho,
int l,
int m) {
108 if (sho == LIBINT_SHGSHELL_ORDERING_STANDARD)
109 return libint2::INT_SOLIDHARMINDEX_STANDARD(l, m);
111 return libint2::INT_SOLIDHARMINDEX_GAUSSIAN(l, m);
116#if LIBINT_SHGSHELL_ORDERING == LIBINT_SHGSHELL_ORDERING_STANDARD
117#define FOR_SOLIDHARM FOR_SOLIDHARM_STANDARD
118#elif LIBINT_SHGSHELL_ORDERING == LIBINT_SHGSHELL_ORDERING_GAUSSIAN
119#define FOR_SOLIDHARM FOR_SOLIDHARM_GAUSSIAN
121#error "unknown value of macro LIBINT_SHGSHELL_ORDERING"
Defaults definitions for various parameters assumed by Libint.
Definition algebra.cc:24