GQCP
Loading...
Searching...
No Matches
vAP1roGElectricalResponseSolver.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
22
23
24namespace GQCP {
25
26
31private:
32 QCModel::vAP1roG vap1rog; // the optimal vAP1roG parameters
33
34
35public:
36 // CONSTRUCTORS
37
42
43
44 // PUBLIC OVERRIDDEN METHODS
45
52
59
60
61 // PUBLIC METHODS
62
69
76
83
92
103};
104
105
106} // namespace GQCP
Definition: BaseElectricalResponseSolver.hpp:30
Definition: ImplicitRankFourTensorSlice.hpp:38
Definition: Matrix.hpp:47
Definition: vAP1roG.hpp:36
Definition: RSQOneElectronOperator.hpp:42
Definition: SQHamiltonian.hpp:54
Definition: SquareMatrix.hpp:39
Definition: vAP1roGElectricalResponseSolver.hpp:30
SquareMatrix< double > calculateParameterResponseConstant(const RSQHamiltonian< double > &sq_hamiltonian) const override
Definition: vAP1roGElectricalResponseSolver.cpp:48
Matrix< double, Dynamic, 3 > calculateMultiplierResponse(const RSQHamiltonian< double > &sq_hamiltonian, const VectorRSQOneElectronOperator< double > dipole_op, const Matrix< double, Dynamic, 3 > &x) const
Definition: vAP1roGElectricalResponseSolver.cpp:229
Matrix< double, Dynamic, 3 > calculateParameterResponseForce(const VectorRSQOneElectronOperator< double > &dipole_op) const override
Definition: vAP1roGElectricalResponseSolver.cpp:59
ImplicitRankFourTensorSlice< double > calculateImplicitMultiplierResponseForceConstant(const RSQHamiltonian< double > &sq_hamiltonian) const
Definition: vAP1roGElectricalResponseSolver.cpp:156
Matrix< double, Dynamic, 3 > calculateExplicitMultiplierResponseForce(const VectorRSQOneElectronOperator< double > dipole_op) const
Definition: vAP1roGElectricalResponseSolver.cpp:115
Matrix< double, Dynamic, 3 > calculateMultiplierResponseForce(const RSQHamiltonian< double > &sq_hamiltonian, const VectorRSQOneElectronOperator< double > dipole_op, const Matrix< double, Dynamic, 3 > &x) const
Definition: vAP1roGElectricalResponseSolver.cpp:210
SquareMatrix< double > calculateMultiplierResponseConstant(const RSQHamiltonian< double > &sq_hamiltonian) const
Definition: vAP1roGElectricalResponseSolver.cpp:104
Definition: BaseOneElectronIntegralBuffer.hpp:25
@ x
Definition: CartesianDirection.hpp:28