GQCP
Loading...
Searching...
No Matches
AP1roGJacobiOrbitalOptimizer.hpp
Go to the documentation of this file.
1// This file is part of GQCG-GQCP.
2//
3// Copyright (C) 2017-2020 the GQCG developers
4//
5// GQCG-GQCP is free software: you can redistribute it and/or modify
6// it under the terms of the GNU Lesser General Public License as published by
7// the Free Software Foundation, either version 3 of the License, or
8// (at your option) any later version.
9//
10// GQCG-GQCP is distributed in the hope that it will be useful,
11// but WITHOUT ANY WARRANTY; without even the implied warranty of
12// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13// GNU Lesser General Public License for more details.
14//
15// You should have received a copy of the GNU Lesser General Public License
16// along with GQCG-GQCP. If not, see <http://www.gnu.org/licenses/>.
17
18#pragma once
19
20
23
24
25namespace GQCP {
26
27
34private:
35 size_t N_P; // the number of electron pairs
36
37 double A1 = 0.0, B1 = 0.0, C1 = 0.0; // coefficients for occupied-occupied rotations
38 double A2 = 0.0, B2 = 0.0, C2 = 0.0, D2 = 0.0, E2 = 0.0; // coefficients for occupied-virtual rotations
39 double A3 = 0.0, B3 = 0.0, C3 = 0.0; // coefficients for virtual-virtual rotations
40
41 double E; // the electronic energy
42 AP1roGGeminalCoefficients G; // the current geminal coefficients
43
44
45public:
46 // CONSTRUCTORS
47
56 AP1roGJacobiOrbitalOptimizer(const size_t N_P, const size_t K, const double convergence_threshold = 1.0e-08, const size_t maximum_number_of_iterations = 128);
57
64
65
66 // PUBLIC OVERRIDDEN METHODS
67
74 void calculateJacobiCoefficients(const RSQHamiltonian<double>& sq_hamiltonian, const size_t p, const size_t q) override;
75
83 double calculateOptimalRotationAngle(const RSQHamiltonian<double>& sq_hamiltonian, const size_t p, const size_t q) const override;
84
91 double calculateScalarFunctionChange(const RSQHamiltonian<double>& sq_hamiltonian, const JacobiRotation& jacobi_rotation) const override;
92
98 void prepareJacobiSpecificConvergenceChecking(const RSQHamiltonian<double>& sq_hamiltonian) override;
99
100
101 // PUBLIC METHODS
102
106 double electronicEnergy() const { return this->E; }
107};
108
109
110} // namespace GQCP
Definition: AP1roGGeminalCoefficients.hpp:34
Definition: AP1roGJacobiOrbitalOptimizer.hpp:33
double calculateScalarFunctionChange(const RSQHamiltonian< double > &sq_hamiltonian, const JacobiRotation &jacobi_rotation) const override
Definition: AP1roGJacobiOrbitalOptimizer.cpp:253
double electronicEnergy() const
Definition: AP1roGJacobiOrbitalOptimizer.hpp:106
void calculateJacobiCoefficients(const RSQHamiltonian< double > &sq_hamiltonian, const size_t p, const size_t q) override
Definition: AP1roGJacobiOrbitalOptimizer.cpp:74
void prepareJacobiSpecificConvergenceChecking(const RSQHamiltonian< double > &sq_hamiltonian) override
Definition: AP1roGJacobiOrbitalOptimizer.cpp:297
double calculateOptimalRotationAngle(const RSQHamiltonian< double > &sq_hamiltonian, const size_t p, const size_t q) const override
Definition: AP1roGJacobiOrbitalOptimizer.cpp:163
double convergence_threshold
Definition: BaseOrbitalOptimizer.hpp:35
size_t maximum_number_of_iterations
Definition: BaseOrbitalOptimizer.hpp:36
Definition: JacobiOrbitalOptimizer.hpp:31
Definition: JacobiRotation.hpp:33
Definition: SQHamiltonian.hpp:54
Definition: BaseOneElectronIntegralBuffer.hpp:25