DFT-EFE
 
Loading...
Searching...
No Matches
MixingScheme.h
Go to the documentation of this file.
1/******************************************************************************
2 * Copyright (c) 2021. *
3 * The Regents of the University of Michigan and DFT-EFE developers. *
4 * *
5 * This file is part of the DFT-EFE code. *
6 * *
7 * DFT-EFE is free software: you can redistribute it and/or modify *
8 * it under the terms of the Lesser GNU General Public License as *
9 * published by the Free Software Foundation, either version 3 of *
10 * the License, or (at your option) any later version. *
11 * *
12 * DFT-EFE is distributed in the hope that it will be useful, but *
13 * WITHOUT ANY WARRANTY; without even the implied warranty *
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. *
15 * See the Lesser GNU General Public License for more details. *
16 * *
17 * You should have received a copy of the GNU Lesser General Public *
18 * License at the top level of DFT-EFE distribution. If not, see *
19 * <https://www.gnu.org/licenses/>. *
20 ******************************************************************************/
21
22/*
23 * @author Avirup Sircar
24 * @adapted from
25 * "https://github.com/dftfeDevelopers/dftfe/blob/publicGithubDevelop/include/MixingScheme.h"
26 */
27
28#ifndef dftefeMixingScheme_h
29#define dftefeMixingScheme_h
30
31#include <deque>
36
37namespace dftefe
38{
39 namespace ksdft
40 {
46 enum class mixingVariable
47 {
48 rho
49 };
50
59 template <typename ValueTypeMixingVariable, typename ValueTypeWeights>
61 {
62 public:
63 using ValueType =
65 ValueTypeMixingVariable>;
66
67 public:
68 MixingScheme(const utils::mpi::MPIComm &mpiComm);
69
70 ~MixingScheme() = default;
71
74
79 void
81 const std::vector<mixingVariable> mixingVariablesList,
83 &linAlgOpContextHost);
84
89 void
91
96 void
97 popOldHistory(size_type mixingHistory);
98
103 void
104 clearHistory();
105
114 void
116 const mixingVariable mixingVariableList,
118 & weightDotProducts,
119 const bool performMPIReduce,
120 const double mixingValue,
121 const bool isAdaptiveMixing);
122
127 template <utils::MemorySpace memorySpace>
128 void
129 addVariableToInHist(const mixingVariable mixingVariableName,
130 const ValueTypeMixingVariable *inputVariableToInHist,
131 const size_type length);
132
137 template <utils::MemorySpace memorySpace>
138 void
140 const mixingVariable mixingVariableName,
141 const ValueTypeMixingVariable *inputVariableToResidualHist,
142 const size_type length);
143
148 template <utils::MemorySpace memorySpace>
149 void
150 mixVariable(const mixingVariable mixingVariableName,
151 ValueTypeMixingVariable *outputVariable,
152 const size_type lenVar);
153
154
155 private:
161 void
163 const std::deque<std::vector<ValueTypeMixingVariable>> &inHist,
164 const std::deque<std::vector<ValueTypeMixingVariable>> &outHist,
166 & weightDotProducts,
167 const bool isPerformMixing,
168 const bool isMPIAllReduce,
169 std::vector<ValueType> &A,
170 std::vector<ValueType> &c);
171
172 std::vector<ValueType> d_A, d_c;
174
175 std::map<mixingVariable, std::deque<std::vector<ValueTypeMixingVariable>>>
177 std::map<mixingVariable,
180 std::map<mixingVariable, bool> d_performMPIReduce;
181
182 const MPI_Comm &d_mpiComm;
183
184 std::map<mixingVariable, double> d_mixingParameter;
185 std::map<mixingVariable, bool> d_isAdaptiveMixing;
191 std::map<mixingVariable, bool> d_performMixing;
193 };
194 } // namespace ksdft
195} // end of namespace dftefe
197#endif // dftefeMixingScheme_h
This class performs the anderson mixing in a variable agnostic way This class takes can take differen...
Definition: MixingScheme.h:61
std::vector< ValueType > d_A
Definition: MixingScheme.h:172
ValueType d_cFinal
Definition: MixingScheme.h:173
void computeAdaptiveAndersonMixingParameter()
Computes the adaptive mixing parameter.
Definition: MixingScheme.t.cpp:251
std::map< mixingVariable, bool > d_performMixing
Definition: MixingScheme.h:191
void addVariableToInHist(const mixingVariable mixingVariableName, const ValueTypeMixingVariable *inputVariableToInHist, const size_type length)
Adds to the input history.
Definition: MixingScheme.t.cpp:315
std::vector< ValueType > d_c
Definition: MixingScheme.h:172
std::map< mixingVariable, utils::MemoryStorage< ValueTypeWeights, utils::MemorySpace::HOST > > d_vectorDotProductWeights
Definition: MixingScheme.h:179
linearAlgebra::blasLapack::scalar_type< ValueTypeWeights, ValueTypeMixingVariable > ValueType
Definition: MixingScheme.h:65
size_type d_mixingHistory
Definition: MixingScheme.h:190
std::map< mixingVariable, bool > d_performMPIReduce
Definition: MixingScheme.h:180
void popOldHistory(size_type mixingHistory)
Deletes the old history if the length exceeds max length of history.
Definition: MixingScheme.t.cpp:426
void mixVariable(const mixingVariable mixingVariableName, ValueTypeMixingVariable *outputVariable, const size_type lenVar)
Computes the input for the next iteration based on the anderson coefficients.
Definition: MixingScheme.t.cpp:363
void clearHistory()
Clears all the the history.
Definition: MixingScheme.t.cpp:410
void computeMixingMatrices(const std::deque< std::vector< ValueTypeMixingVariable > > &inHist, const std::deque< std::vector< ValueTypeMixingVariable > > &outHist, const utils::MemoryStorage< ValueTypeWeights, utils::MemorySpace::HOST > &weightDotProducts, const bool isPerformMixing, const bool isMPIAllReduce, std::vector< ValueType > &A, std::vector< ValueType > &c)
Computes the matrix A and c vector that will be needed for anderson mixing. This function computes th...
Definition: MixingScheme.t.cpp:93
std::map< mixingVariable, double > d_mixingParameter
Definition: MixingScheme.h:184
void addMixingVariable(const mixingVariable mixingVariableList, const utils::MemoryStorage< ValueTypeWeights, utils::MemorySpace::HOST > &weightDotProducts, const bool performMPIReduce, const double mixingValue, const bool isAdaptiveMixing)
This function is used to add the mixing variables and its corresponding JxW values For dependent vari...
Definition: MixingScheme.t.cpp:43
bool d_anyMixingParameterAdaptive
Definition: MixingScheme.h:186
bool d_adaptiveMixingParameterIncAllIterations
Definition: MixingScheme.h:189
const MPI_Comm & d_mpiComm
Definition: MixingScheme.h:182
std::map< mixingVariable, std::deque< std::vector< ValueTypeMixingVariable > > > d_variableHistoryResidual
Definition: MixingScheme.h:176
utils::ConditionalOStream d_rootCout
Definition: MixingScheme.h:192
bool d_adaptiveMixingParameterDecLastIteration
Definition: MixingScheme.h:187
size_type lengthOfHistory()
Definition: MixingScheme.t.cpp:196
void computeAndersonMixingCoeff(const std::vector< mixingVariable > mixingVariablesList, linearAlgebra::LinAlgOpContext< utils::MemorySpace::HOST > &linAlgOpContextHost)
Computes the mixing coefficients.
Definition: MixingScheme.t.cpp:206
void addVariableToResidualHist(const mixingVariable mixingVariableName, const ValueTypeMixingVariable *inputVariableToResidualHist, const size_type length)
Adds to the residual history.
Definition: MixingScheme.t.cpp:338
bool d_adaptiveMixingParameterDecAllIterations
Definition: MixingScheme.h:188
std::map< mixingVariable, std::deque< std::vector< ValueTypeMixingVariable > > > d_variableHistoryIn
Definition: MixingScheme.h:176
std::map< mixingVariable, bool > d_isAdaptiveMixing
Definition: MixingScheme.h:185
Definition: LinAlgOpContext.h:38
Provides an interface to print based on whether a certain condition is met or not....
Definition: ConditionalOStream.h:47
Definition: MemoryStorage.h:38
mixingVariable
Enum class that stores he list of variables that will can be used in the mixing scheme.
Definition: MixingScheme.h:47
blas::scalar_type< ValueType1, ValueType2 > scalar_type
Definition: BlasLapackTypedef.h:70
int MPIComm
Definition: MPITypes.h:83
dealii includes
Definition: AtomFieldDataSpherical.cpp:31
unsigned int size_type
Definition: TypeConfig.h:8