-
Notifications
You must be signed in to change notification settings - Fork 43
/
moment_compute.h
49 lines (42 loc) · 1.76 KB
/
moment_compute.h
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
//
// BAGEL - Brilliantly Advanced General Electronic Structure Library
// Filename: moment_compute.h
// Copyright (C) 2014 Quantum Simulation Technologies, Inc.
//
// Author: Ryan D. Reynolds <RyanDReynolds@u.northwestern.edu>
// Maintainer: QSimulate
//
// This file is part of the BAGEL package.
//
// 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 3 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, see <http://www.gnu.org/licenses/>.
//
#ifndef __SRC_MOLECULE_MOMENT_COMPUTE_H
#define __SRC_MOLECULE_MOMENT_COMPUTE_H
#include <array>
#include <src/molecule/shell.h>
#include <src/util/math/matrix.h>
#include <src/util/math/zmatrix.h>
namespace bagel {
struct MomentCompute {
private:
static std::array<std::shared_ptr<const Matrix>,6> mblock(const Shell& shell, const double exponent);
static std::array<std::shared_ptr<const ZMatrix>,9> mblock(const Shell& shell, const double exponent, const std::array<double,3> magnetic_field, const bool london);
public:
// Gaussian orbitals
static std::array<std::shared_ptr<const Matrix>,3> call(const Shell& shell);
// London orbitals (and common origin)
static std::array<std::shared_ptr<const ZMatrix>,3> call(const Shell& shell, const std::array<double,3> magnetic_field, const bool london);
};
}
#endif