GQCP
Loading...
Searching...
No Matches
ERNewtonLocalizer.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
32private:
33 OrbitalSpace orbital_space; // the occupied-virtual orbital space
34
35
36public:
37 // CONSTRUCTORS
38
45 ERNewtonLocalizer(const OrbitalSpace orbital_space, std::shared_ptr<BaseHessianModifier> hessian_modifier, const double convergence_threshold = 1.0e-08, const size_t maximum_number_of_iterations = 128);
46
47
48 // PUBLIC OVERRIDDEN METHODS
49
55 SquareMatrix<double> calculateGradientMatrix(const RSQHamiltonian<double>& sq_hamiltonian) const override;
56
63
72
76 void prepareOrbitalDerivativesCalculation(const RSQHamiltonian<double>& sq_hamiltonian) override {}
77
78
79 // PUBLIC METHODS
80
88 double calculateGradientMatrixElement(const RSQHamiltonian<double>& sq_hamiltonian, const size_t i, const size_t j) const;
89
99 double calculateHessianTensorElement(const RSQHamiltonian<double>& sq_hamiltonian, const size_t i, const size_t j, const size_t k, const size_t l) const;
100};
101
102
103} // namespace GQCP
double convergence_threshold
Definition: BaseOrbitalOptimizer.hpp:35
size_t maximum_number_of_iterations
Definition: BaseOrbitalOptimizer.hpp:36
Definition: ERNewtonLocalizer.hpp:31
ROrbitalRotationGenerators< double > calculateNewFullOrbitalGenerators(const RSQHamiltonian< double > &sq_hamiltonian) const override
Definition: ERNewtonLocalizer.cpp:96
SquareMatrix< double > calculateGradientMatrix(const RSQHamiltonian< double > &sq_hamiltonian) const override
Definition: ERNewtonLocalizer.cpp:48
double calculateHessianTensorElement(const RSQHamiltonian< double > &sq_hamiltonian, const size_t i, const size_t j, const size_t k, const size_t l) const
Definition: ERNewtonLocalizer.cpp:133
SquareRankFourTensor< double > calculateHessianTensor(const RSQHamiltonian< double > &sq_hamiltonian) const override
Definition: ERNewtonLocalizer.cpp:69
void prepareOrbitalDerivativesCalculation(const RSQHamiltonian< double > &sq_hamiltonian) override
Definition: ERNewtonLocalizer.hpp:76
double calculateGradientMatrixElement(const RSQHamiltonian< double > &sq_hamiltonian, const size_t i, const size_t j) const
Definition: ERNewtonLocalizer.cpp:116
Definition: NewtonOrbitalOptimizer.hpp:37
std::shared_ptr< BaseHessianModifier > hessian_modifier
Definition: NewtonOrbitalOptimizer.hpp:39
Definition: OrbitalSpace.hpp:40
Definition: ROrbitalRotationGenerators.hpp:38
Definition: SQHamiltonian.hpp:54
Definition: SquareMatrix.hpp:39
Definition: SquareRankFourTensor.hpp:36
Definition: BaseOneElectronIntegralBuffer.hpp:25