From 092021ed75b55e9322115348eef574f406d3055c Mon Sep 17 00:00:00 2001 From: landinjm Date: Sun, 15 Sep 2024 17:56:17 -0400 Subject: [PATCH 1/4] partially switching to unordered maps --- include/variableContainer.h | 27 ++- src/matrixfree/computeLHS.cc | 1 - src/variableContainer/variableContainer.cc | 212 ++++++++------------- 3 files changed, 97 insertions(+), 143 deletions(-) diff --git a/include/variableContainer.h b/include/variableContainer.h index bfc1518f3..a94af7a88 100644 --- a/include/variableContainer.h +++ b/include/variableContainer.h @@ -3,11 +3,14 @@ #ifndef VARIBLECONTAINER_H #define VARIBLECONTAINER_H +#include #include #include #include #include +#include + #include "userInputParameters.h" template @@ -90,11 +93,6 @@ class variableContainer reinit_and_eval_change_in_solution(const vectorType &src, unsigned int cell, unsigned int var_being_solved); - void - reinit_and_eval_LHS(const vectorType &src, - const std::vector solutionSet, - unsigned int cell, - unsigned int var_being_solved); // Only initialize the FEEvaluation object for each variable (used for // post-processing) @@ -117,23 +115,24 @@ class variableContainer get_q_point_location(); private: - // The number of variables - unsigned int num_var; - // Vectors of the actual FEEvaluation objects for each active variable, split // into scalar variables and vector variables for type reasons - std::vector> scalar_vars; - std::vector> vector_vars; + using scalar_FEEval = dealii::FEEvaluation; + using vector_FEEval = dealii::FEEvaluation; - std::vector> - scalar_change_in_vars; - std::vector> - vector_change_in_vars; + boost::unordered_map> scalar_vars_map; + boost::unordered_map> vector_vars_map; + + std::vector scalar_change_in_vars; + std::vector vector_change_in_vars; // Object containing some information about each variable (indices, whether // the val/grad/hess is needed, etc) std::vector varInfoList; std::vector varChangeInfoList; + + // The number of variables + unsigned int num_var; }; #endif diff --git a/src/matrixfree/computeLHS.cc b/src/matrixfree/computeLHS.cc index 806866ddf..2606b1ade 100644 --- a/src/matrixfree/computeLHS.cc +++ b/src/matrixfree/computeLHS.cc @@ -57,7 +57,6 @@ MatrixFreePDE::getLHS( for (unsigned int cell = cell_range.first; cell < cell_range.second; ++cell) { // Initialize, read DOFs, and set evaulation flags for each variable - // variable_list.reinit_and_eval_LHS(src,solutionSet,cell,currentFieldIndex); variable_list.reinit_and_eval(solutionSet, cell); variable_list.reinit_and_eval_change_in_solution(src, cell, currentFieldIndex); diff --git a/src/variableContainer/variableContainer.cc b/src/variableContainer/variableContainer.cc index 491a449d8..84fcce7f0 100644 --- a/src/variableContainer/variableContainer.cc +++ b/src/variableContainer/variableContainer.cc @@ -1,4 +1,3 @@ -// All of the methods for the 'variableContainer' class #include "../../include/variableContainer.h" template @@ -6,38 +5,39 @@ variableContainer::variableContainer( const dealii::MatrixFree &data, std::vector _varInfoList, std::vector _varChangeInfoList) + : varInfoList(std::move(_varInfoList)) + , varChangeInfoList(std::move(_varChangeInfoList)) + , num_var(varInfoList.size()) { - varInfoList = _varInfoList; - varChangeInfoList = _varChangeInfoList; - - num_var = varInfoList.size(); - for (unsigned int i = 0; i < num_var; i++) { - if (varInfoList[i].var_needed) + const auto &var_info = varInfoList[i]; + const auto &var_change_info = varChangeInfoList[i]; + + if (var_info.var_needed) { - if (varInfoList[i].is_scalar) + if (var_info.is_scalar) { - dealii::FEEvaluation var(data, i); - scalar_vars.push_back(var); + scalar_vars_map.emplace(var_info.variable_index, + std::make_unique(data, i)); } else { - dealii::FEEvaluation var(data, i); - vector_vars.push_back(var); + vector_vars_map.emplace(var_info.variable_index, + std::make_unique(data, i)); } } - if (varChangeInfoList[i].var_needed) + if (var_change_info.var_needed) { - if (varChangeInfoList[i].is_scalar) + if (var_change_info.is_scalar) { - dealii::FEEvaluation var(data, i); + scalar_FEEval var(data, i); scalar_change_in_vars.push_back(var); } else { - dealii::FEEvaluation var(data, i); + vector_FEEval var(data, i); vector_change_in_vars.push_back(var); } } @@ -48,24 +48,24 @@ template variableContainer::variableContainer( const dealii::MatrixFree &data, std::vector _varInfoList) + : varInfoList(std::move(_varInfoList)) + , num_var(varInfoList.size()) { - varInfoList = _varInfoList; - - num_var = varInfoList.size(); - for (unsigned int i = 0; i < num_var; i++) { - if (varInfoList[i].var_needed) + const auto &var_info = varInfoList[i]; + + if (var_info.var_needed) { - if (varInfoList[i].is_scalar) + if (var_info.is_scalar) { - dealii::FEEvaluation var(data, i); - scalar_vars.push_back(var); + scalar_vars_map.emplace(var_info.variable_index, + std::make_unique(data, i)); } else { - dealii::FEEvaluation var(data, i); - vector_vars.push_back(var); + vector_vars_map.emplace(var_info.variable_index, + std::make_unique(data, i)); } } } @@ -78,26 +78,24 @@ variableContainer::variableContainer( const dealii::MatrixFree &data, std::vector _varInfoList, unsigned int fixed_index) + : varInfoList(std::move(_varInfoList)) + , num_var(varInfoList.size()) { - varInfoList = _varInfoList; - - num_var = varInfoList.size(); - for (unsigned int i = 0; i < num_var; i++) { - if (varInfoList[i].var_needed) + const auto &var_info = varInfoList[i]; + + if (var_info.var_needed) { - if (varInfoList[i].is_scalar) + if (var_info.is_scalar) { - dealii::FEEvaluation var(data, - fixed_index); - scalar_vars.push_back(var); + scalar_vars_map.emplace(var_info.variable_index, + std::make_unique(data, fixed_index)); } else { - dealii::FEEvaluation var(data, - fixed_index); - vector_vars.push_back(var); + vector_vars_map.emplace(var_info.variable_index, + std::make_unique(data, fixed_index)); } } } @@ -107,13 +105,15 @@ template unsigned int variableContainer::get_num_q_points() { - if (scalar_vars.size() > 0) + if (!scalar_vars_map.empty()) { - return scalar_vars[0].n_q_points; + auto it = scalar_vars_map.begin(); + return it->second->n_q_points; } - else if (vector_vars.size() > 0) + else if (!vector_vars_map.empty()) { - return vector_vars[0].n_q_points; + auto it = vector_vars_map.begin(); + return it->second->n_q_points; } else if (scalar_change_in_vars.size() > 0) { @@ -129,13 +129,15 @@ template dealii::Point variableContainer::get_q_point_location() { - if (scalar_vars.size() > 0) + if (!scalar_vars_map.empty()) { - return scalar_vars[0].quadrature_point(q_point); + auto it = scalar_vars_map.begin(); + return it->second->quadrature_point(q_point); } - else if (vector_vars.size() > 0) + else if (!vector_vars_map.empty()) { - return vector_vars[0].quadrature_point(q_point); + auto it = vector_vars_map.begin(); + return it->second->quadrature_point(q_point); } else if (scalar_change_in_vars.size() > 0) { @@ -156,27 +158,27 @@ variableContainer::reinit_and_eval(const std::vectorreinit(cell); + scalar_vars_map[var_index]->read_dof_values(*src[i]); + scalar_vars_map[var_index]->evaluate(varInfoList[i].evaluation_flags); } else { - vector_vars[varInfoList[i].variable_index].reinit(cell); - vector_vars[varInfoList[i].variable_index].read_dof_values(*src[i]); - vector_vars[varInfoList[i].variable_index].evaluate( - varInfoList[i].evaluation_flags); + vector_vars_map[var_index]->reinit(cell); + vector_vars_map[var_index]->read_dof_values(*src[i]); + vector_vars_map[var_index]->evaluate(varInfoList[i].evaluation_flags); } } } } /** - * This is specialized for the LHS where there will be only one change in the - * solution needed. The RHS method takes the src as a vector of vectorTypes. + * This is specialized for the LHS where a change in solution is needed. The RHS method + * takes the src as a vector of vectorTypes. */ template void @@ -201,52 +203,6 @@ variableContainer::reinit_and_eval_change_in_solution( } } -template -void -variableContainer::reinit_and_eval_LHS( - const vectorType &src, - const std::vector solutionSet, - unsigned int cell, - unsigned int var_being_solved) -{ - for (unsigned int i = 0; i < num_var; i++) - { - if (varInfoList[i].var_needed) - { - if (varInfoList[i].is_scalar) - { - scalar_vars[varInfoList[i].variable_index].reinit(cell); - if (i == var_being_solved) - { - scalar_vars[varInfoList[i].variable_index].read_dof_values(src); - } - else - { - scalar_vars[varInfoList[i].variable_index].read_dof_values( - *solutionSet[i]); - } - scalar_vars[varInfoList[i].variable_index].evaluate( - varInfoList[i].evaluation_flags); - } - else - { - vector_vars[varInfoList[i].variable_index].reinit(cell); - if (i == var_being_solved) - { - vector_vars[varInfoList[i].variable_index].read_dof_values(src); - } - else - { - vector_vars[varInfoList[i].variable_index].read_dof_values( - *solutionSet[i]); - } - vector_vars[varInfoList[i].variable_index].evaluate( - varInfoList[i].evaluation_flags); - } - } - } -} - template void variableContainer::reinit(unsigned int cell) @@ -257,11 +213,11 @@ variableContainer::reinit(unsigned int cell) { if (varInfoList[i].is_scalar) { - scalar_vars[varInfoList[i].variable_index].reinit(cell); + scalar_vars_map[varInfoList[i].variable_index]->reinit(cell); } else { - vector_vars[varInfoList[i].variable_index].reinit(cell); + vector_vars_map[varInfoList[i].variable_index]->reinit(cell); } } } @@ -278,16 +234,16 @@ variableContainer::integrate_and_distribute( { if (varInfoList[i].is_scalar) { - scalar_vars[varInfoList[i].variable_index].integrate( + scalar_vars_map[varInfoList[i].variable_index]->integrate( varInfoList[i].residual_flags); - scalar_vars[varInfoList[i].variable_index].distribute_local_to_global( + scalar_vars_map[varInfoList[i].variable_index]->distribute_local_to_global( *dst[i]); } else { - vector_vars[varInfoList[i].variable_index].integrate( + vector_vars_map[varInfoList[i].variable_index]->integrate( varInfoList[i].residual_flags); - vector_vars[varInfoList[i].variable_index].distribute_local_to_global( + vector_vars_map[varInfoList[i].variable_index]->distribute_local_to_global( *dst[i]); } } @@ -325,8 +281,8 @@ variableContainer::get_scalar_value( if (varInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::values) { - return scalar_vars[varInfoList[global_variable_index].variable_index].get_value( - q_point); + return scalar_vars_map.at(varInfoList[global_variable_index].variable_index) + ->get_value(q_point); } else { @@ -346,8 +302,8 @@ variableContainer::get_scalar_gradient( if (varInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::gradients) { - return scalar_vars[varInfoList[global_variable_index].variable_index].get_gradient( - q_point); + return scalar_vars_map.at(varInfoList[global_variable_index].variable_index) + ->get_gradient(q_point); } else { @@ -367,8 +323,8 @@ variableContainer::get_scalar_hessian( if (varInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::hessians) { - return scalar_vars[varInfoList[global_variable_index].variable_index].get_hessian( - q_point); + return scalar_vars_map.at(varInfoList[global_variable_index].variable_index) + ->get_hessian(q_point); } else { @@ -388,8 +344,8 @@ variableContainer::get_vector_value( if (varInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::values) { - return vector_vars[varInfoList[global_variable_index].variable_index].get_value( - q_point); + return vector_vars_map.at(varInfoList[global_variable_index].variable_index) + ->get_value(q_point); } else { @@ -409,8 +365,8 @@ variableContainer::get_vector_gradient( if (varInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::gradients) { - return vector_vars[varInfoList[global_variable_index].variable_index].get_gradient( - q_point); + return vector_vars_map.at(varInfoList[global_variable_index].variable_index) + ->get_gradient(q_point); } else { @@ -430,8 +386,8 @@ variableContainer::get_vector_hessian( if (varInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::hessians) { - return vector_vars[varInfoList[global_variable_index].variable_index].get_hessian( - q_point); + return vector_vars_map.at(varInfoList[global_variable_index].variable_index) + ->get_hessian(q_point); } else { @@ -584,8 +540,8 @@ variableContainer::set_scalar_value_term_RHS( unsigned int global_variable_index, T val) { - scalar_vars[varInfoList[global_variable_index].variable_index].submit_value(val, - q_point); + scalar_vars_map[varInfoList[global_variable_index].variable_index] + ->submit_value(val, q_point); } template @@ -594,8 +550,8 @@ variableContainer::set_scalar_gradient_term_RHS( unsigned int global_variable_index, dealii::Tensor<1, dim, T> grad) { - scalar_vars[varInfoList[global_variable_index].variable_index].submit_gradient(grad, - q_point); + scalar_vars_map[varInfoList[global_variable_index].variable_index] + ->submit_gradient(grad, q_point); } template @@ -604,8 +560,8 @@ variableContainer::set_vector_value_term_RHS( unsigned int global_variable_index, dealii::Tensor<1, dim, T> val) { - vector_vars[varInfoList[global_variable_index].variable_index].submit_value(val, - q_point); + vector_vars_map[varInfoList[global_variable_index].variable_index] + ->submit_value(val, q_point); } template @@ -614,8 +570,8 @@ variableContainer::set_vector_gradient_term_RHS( unsigned int global_variable_index, dealii::Tensor<2, dim, T> grad) { - vector_vars[varInfoList[global_variable_index].variable_index].submit_gradient(grad, - q_point); + vector_vars_map[varInfoList[global_variable_index].variable_index] + ->submit_gradient(grad, q_point); } template From 550aef698d156c2d15cb79ecf85629aeca660e50 Mon Sep 17 00:00:00 2001 From: landinjm Date: Sun, 15 Sep 2024 18:31:40 -0400 Subject: [PATCH 2/4] minor optimizations --- include/variableContainer.h | 17 +- src/variableContainer/variableContainer.cc | 196 ++++++++++++--------- 2 files changed, 125 insertions(+), 88 deletions(-) diff --git a/include/variableContainer.h b/include/variableContainer.h index a94af7a88..44b65e37c 100644 --- a/include/variableContainer.h +++ b/include/variableContainer.h @@ -22,15 +22,16 @@ class variableContainer // Standard contructor, used for most situations variableContainer(const dealii::MatrixFree &data, - std::vector _varInfoList, - std::vector _varChangeInfoList); + const std::vector &_varInfoList, + const std::vector &_varChangeInfoList); + variableContainer(const dealii::MatrixFree &data, - std::vector _varInfoList); + const std::vector &_varInfoList); // Nonstandard constructor, used when only one index of "data" should be used, // use with care! variableContainer(const dealii::MatrixFree &data, - std::vector _varInfoList, - unsigned int fixed_index); + const std::vector &_varInfoList, + const unsigned int &fixed_index); // Methods to get the value/grad/hess in the residual method (this is how the // user gets these values in equations.h) @@ -109,10 +110,12 @@ class variableContainer // The quadrature point index, a method to get the number of quadrature points // per cell, and a method to get the xyz coordinates for the quadrature point unsigned int q_point; + unsigned int - get_num_q_points(); + get_num_q_points() const; + dealii::Point - get_q_point_location(); + get_q_point_location() const; private: // Vectors of the actual FEEvaluation objects for each active variable, split diff --git a/src/variableContainer/variableContainer.cc b/src/variableContainer/variableContainer.cc index 84fcce7f0..09c8af595 100644 --- a/src/variableContainer/variableContainer.cc +++ b/src/variableContainer/variableContainer.cc @@ -3,8 +3,8 @@ template variableContainer::variableContainer( const dealii::MatrixFree &data, - std::vector _varInfoList, - std::vector _varChangeInfoList) + const std::vector &_varInfoList, + const std::vector &_varChangeInfoList) : varInfoList(std::move(_varInfoList)) , varChangeInfoList(std::move(_varChangeInfoList)) , num_var(varInfoList.size()) @@ -16,14 +16,16 @@ variableContainer::variableContainer( if (var_info.var_needed) { + const unsigned int var_index = var_info.variable_index; + if (var_info.is_scalar) { - scalar_vars_map.emplace(var_info.variable_index, + scalar_vars_map.emplace(var_index, std::make_unique(data, i)); } else { - vector_vars_map.emplace(var_info.variable_index, + vector_vars_map.emplace(var_index, std::make_unique(data, i)); } } @@ -47,7 +49,7 @@ variableContainer::variableContainer( template variableContainer::variableContainer( const dealii::MatrixFree &data, - std::vector _varInfoList) + const std::vector &_varInfoList) : varInfoList(std::move(_varInfoList)) , num_var(varInfoList.size()) { @@ -55,18 +57,20 @@ variableContainer::variableContainer( { const auto &var_info = varInfoList[i]; - if (var_info.var_needed) + if (!var_info.var_needed) { - if (var_info.is_scalar) - { - scalar_vars_map.emplace(var_info.variable_index, - std::make_unique(data, i)); - } - else - { - vector_vars_map.emplace(var_info.variable_index, - std::make_unique(data, i)); - } + continue; + } + + const unsigned int var_index = var_info.variable_index; + + if (var_info.is_scalar) + { + scalar_vars_map.emplace(var_index, std::make_unique(data, i)); + } + else + { + vector_vars_map.emplace(var_index, std::make_unique(data, i)); } } } @@ -76,8 +80,8 @@ variableContainer::variableContainer( template variableContainer::variableContainer( const dealii::MatrixFree &data, - std::vector _varInfoList, - unsigned int fixed_index) + const std::vector &_varInfoList, + const unsigned int &fixed_index) : varInfoList(std::move(_varInfoList)) , num_var(varInfoList.size()) { @@ -85,68 +89,82 @@ variableContainer::variableContainer( { const auto &var_info = varInfoList[i]; - if (var_info.var_needed) + if (!var_info.var_needed) { - if (var_info.is_scalar) - { - scalar_vars_map.emplace(var_info.variable_index, - std::make_unique(data, fixed_index)); - } - else - { - vector_vars_map.emplace(var_info.variable_index, - std::make_unique(data, fixed_index)); - } + continue; + } + + const unsigned int var_index = var_info.variable_index; + + if (var_info.is_scalar) + { + scalar_vars_map.emplace(var_index, + std::make_unique(data, fixed_index)); + } + else + { + vector_vars_map.emplace(var_index, + std::make_unique(data, fixed_index)); } } } template unsigned int -variableContainer::get_num_q_points() +variableContainer::get_num_q_points() const { if (!scalar_vars_map.empty()) { - auto it = scalar_vars_map.begin(); - return it->second->n_q_points; + return scalar_vars_map.begin()->second->n_q_points; } else if (!vector_vars_map.empty()) { - auto it = vector_vars_map.begin(); - return it->second->n_q_points; + return vector_vars_map.begin()->second->n_q_points; } - else if (scalar_change_in_vars.size() > 0) + else if (!scalar_change_in_vars.empty()) { return scalar_change_in_vars[0].n_q_points; } - else + else if (!vector_change_in_vars.empty()) { return vector_change_in_vars[0].n_q_points; } + else + { + AssertThrow(false, + dealii::ExcMessage( + "PRISMS-PF Error: When trying to access the number of quadrature " + "points, all FEEvaluation object containers were empty.")); + } } template dealii::Point -variableContainer::get_q_point_location() +variableContainer::get_q_point_location() const { if (!scalar_vars_map.empty()) { - auto it = scalar_vars_map.begin(); - return it->second->quadrature_point(q_point); + return scalar_vars_map.begin()->second->quadrature_point(q_point); } else if (!vector_vars_map.empty()) { - auto it = vector_vars_map.begin(); - return it->second->quadrature_point(q_point); + return vector_vars_map.begin()->second->quadrature_point(q_point); } - else if (scalar_change_in_vars.size() > 0) + else if (!scalar_change_in_vars.empty()) { return scalar_change_in_vars[0].quadrature_point(q_point); } - else + else if (!vector_change_in_vars.empty()) { return vector_change_in_vars[0].quadrature_point(q_point); } + else + { + AssertThrow(false, + dealii::ExcMessage( + "PRISMS-PF Error: When trying to access the quadrature point " + "location, all FEEvaluation object containers were empty.")); + } } template @@ -156,22 +174,28 @@ variableContainer::reinit_and_eval(const std::vectorreinit(cell); - scalar_vars_map[var_index]->read_dof_values(*src[i]); - scalar_vars_map[var_index]->evaluate(varInfoList[i].evaluation_flags); - } - else - { - vector_vars_map[var_index]->reinit(cell); - vector_vars_map[var_index]->read_dof_values(*src[i]); - vector_vars_map[var_index]->evaluate(varInfoList[i].evaluation_flags); - } + const unsigned int var_index = var_info.variable_index; + + if (var_info.is_scalar) + { + auto *scalar_FEEval_ptr = scalar_vars_map[var_index].get(); + scalar_FEEval_ptr->reinit(cell); + scalar_FEEval_ptr->read_dof_values(*src[i]); + scalar_FEEval_ptr->evaluate(var_info.evaluation_flags); + } + else + { + auto *vector_FEEval_ptr = vector_vars_map[var_index].get(); + vector_FEEval_ptr->reinit(cell); + vector_FEEval_ptr->read_dof_values(*src[i]); + vector_FEEval_ptr->evaluate(var_info.evaluation_flags); } } } @@ -209,16 +233,22 @@ variableContainer::reinit(unsigned int cell) { for (unsigned int i = 0; i < num_var; i++) { - if (varInfoList[i].var_needed) + const auto &var_info = varInfoList[i]; + + if (!var_info.var_needed) { - if (varInfoList[i].is_scalar) - { - scalar_vars_map[varInfoList[i].variable_index]->reinit(cell); - } - else - { - vector_vars_map[varInfoList[i].variable_index]->reinit(cell); - } + continue; + } + + const unsigned int var_index = var_info.variable_index; + + if (var_info.is_scalar) + { + scalar_vars_map[var_index]->reinit(cell); + } + else + { + vector_vars_map[var_index]->reinit(cell); } } } @@ -230,22 +260,26 @@ variableContainer::integrate_and_distribute( { for (unsigned int i = 0; i < num_var; i++) { - if (!(varInfoList[i].residual_flags & dealii::EvaluationFlags::nothing)) + const auto &var_info = varInfoList[i]; + + if (var_info.residual_flags & dealii::EvaluationFlags::nothing) { - if (varInfoList[i].is_scalar) - { - scalar_vars_map[varInfoList[i].variable_index]->integrate( - varInfoList[i].residual_flags); - scalar_vars_map[varInfoList[i].variable_index]->distribute_local_to_global( - *dst[i]); - } - else - { - vector_vars_map[varInfoList[i].variable_index]->integrate( - varInfoList[i].residual_flags); - vector_vars_map[varInfoList[i].variable_index]->distribute_local_to_global( - *dst[i]); - } + continue; + } + + const unsigned int var_index = var_info.variable_index; + + if (var_info.is_scalar) + { + auto *scalar_FEEval_ptr = scalar_vars_map[var_index].get(); + scalar_FEEval_ptr->integrate(var_info.residual_flags); + scalar_FEEval_ptr->distribute_local_to_global(*dst[i]); + } + else + { + auto *vector_FEEval_ptr = vector_vars_map[var_index].get(); + vector_FEEval_ptr->integrate(var_info.residual_flags); + vector_FEEval_ptr->distribute_local_to_global(*dst[i]); } } } From 210e8f32709e6e43b34025b93713355512f8ccdf Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Mon, 16 Sep 2024 13:26:16 -0400 Subject: [PATCH 3/4] finished switching to maps --- include/variableContainer.h | 6 +- src/variableContainer/variableContainer.cc | 90 +++++++++------------- 2 files changed, 42 insertions(+), 54 deletions(-) diff --git a/include/variableContainer.h b/include/variableContainer.h index 44b65e37c..e5a0fb9be 100644 --- a/include/variableContainer.h +++ b/include/variableContainer.h @@ -126,8 +126,10 @@ class variableContainer boost::unordered_map> scalar_vars_map; boost::unordered_map> vector_vars_map; - std::vector scalar_change_in_vars; - std::vector vector_change_in_vars; + boost::unordered_map> + scalar_change_in_vars_map; + boost::unordered_map> + vector_change_in_vars_map; // Object containing some information about each variable (indices, whether // the val/grad/hess is needed, etc) diff --git a/src/variableContainer/variableContainer.cc b/src/variableContainer/variableContainer.cc index 09c8af595..d37ab91f2 100644 --- a/src/variableContainer/variableContainer.cc +++ b/src/variableContainer/variableContainer.cc @@ -32,15 +32,17 @@ variableContainer::variableContainer( if (var_change_info.var_needed) { + const unsigned int var_index = var_change_info.global_var_index; + if (var_change_info.is_scalar) { - scalar_FEEval var(data, i); - scalar_change_in_vars.push_back(var); + scalar_change_in_vars_map.emplace(var_index, + std::make_unique(data, i)); } else { - vector_FEEval var(data, i); - vector_change_in_vars.push_back(var); + vector_change_in_vars_map.emplace(var_index, + std::make_unique(data, i)); } } } @@ -121,13 +123,13 @@ variableContainer::get_num_q_points() const { return vector_vars_map.begin()->second->n_q_points; } - else if (!scalar_change_in_vars.empty()) + else if (!scalar_change_in_vars_map.empty()) { - return scalar_change_in_vars[0].n_q_points; + return scalar_change_in_vars_map.begin()->second->n_q_points; } - else if (!vector_change_in_vars.empty()) + else if (!vector_change_in_vars_map.empty()) { - return vector_change_in_vars[0].n_q_points; + return vector_change_in_vars_map.begin()->second->n_q_points; } else { @@ -150,13 +152,13 @@ variableContainer::get_q_point_location() const { return vector_vars_map.begin()->second->quadrature_point(q_point); } - else if (!scalar_change_in_vars.empty()) + else if (!scalar_change_in_vars_map.empty()) { - return scalar_change_in_vars[0].quadrature_point(q_point); + return scalar_change_in_vars_map.begin()->second->quadrature_point(q_point); } - else if (!vector_change_in_vars.empty()) + else if (!vector_change_in_vars_map.empty()) { - return vector_change_in_vars[0].quadrature_point(q_point); + return vector_change_in_vars_map.begin()->second->quadrature_point(q_point); } else { @@ -213,17 +215,17 @@ variableContainer::reinit_and_eval_change_in_solution( { if (varChangeInfoList[var_being_solved].is_scalar) { - scalar_change_in_vars[0].reinit(cell); - scalar_change_in_vars[0].read_dof_values(src); - scalar_change_in_vars[0].evaluate( - varChangeInfoList[var_being_solved].evaluation_flags); + auto *scalar_FEEval_ptr = scalar_change_in_vars_map[var_being_solved].get(); + scalar_FEEval_ptr->reinit(cell); + scalar_FEEval_ptr->read_dof_values(src); + scalar_FEEval_ptr->evaluate(varChangeInfoList[var_being_solved].evaluation_flags); } else { - vector_change_in_vars[0].reinit(cell); - vector_change_in_vars[0].read_dof_values(src); - vector_change_in_vars[0].evaluate( - varChangeInfoList[var_being_solved].evaluation_flags); + auto *vector_FEEval_ptr = vector_change_in_vars_map[var_being_solved].get(); + vector_FEEval_ptr->reinit(cell); + vector_FEEval_ptr->read_dof_values(src); + vector_FEEval_ptr->evaluate(varChangeInfoList[var_being_solved].evaluation_flags); } } @@ -293,15 +295,15 @@ variableContainer::integrate_and_distribute_change_in_solution_L // integrate if (varChangeInfoList[var_being_solved].is_scalar) { - scalar_change_in_vars[0].integrate( - varChangeInfoList[var_being_solved].residual_flags); - scalar_change_in_vars[0].distribute_local_to_global(dst); + auto *scalar_FEEval_ptr = scalar_change_in_vars_map[var_being_solved].get(); + scalar_FEEval_ptr->integrate(varChangeInfoList[var_being_solved].residual_flags); + scalar_FEEval_ptr->distribute_local_to_global(dst); } else { - vector_change_in_vars[0].integrate( - varChangeInfoList[var_being_solved].residual_flags); - vector_change_in_vars[0].distribute_local_to_global(dst); + auto *vector_FEEval_ptr = vector_change_in_vars_map[var_being_solved].get(); + vector_FEEval_ptr->integrate(varChangeInfoList[var_being_solved].residual_flags); + vector_FEEval_ptr->distribute_local_to_global(dst); } } @@ -443,9 +445,7 @@ variableContainer::get_change_in_scalar_value( if (varChangeInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::values) { - return scalar_change_in_vars[varChangeInfoList[global_variable_index] - .variable_index] - .get_value(q_point); + return scalar_change_in_vars_map.at(global_variable_index)->get_value(q_point); } else { @@ -465,9 +465,7 @@ variableContainer::get_change_in_scalar_gradient( if (varChangeInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::gradients) { - return scalar_change_in_vars[varChangeInfoList[global_variable_index] - .variable_index] - .get_gradient(q_point); + return scalar_change_in_vars_map.at(global_variable_index)->get_gradient(q_point); } else { @@ -487,9 +485,7 @@ variableContainer::get_change_in_scalar_hessian( if (varChangeInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::hessians) { - return scalar_change_in_vars[varChangeInfoList[global_variable_index] - .variable_index] - .get_hessian(q_point); + return scalar_change_in_vars_map.at(global_variable_index)->get_hessian(q_point); } else { @@ -509,9 +505,7 @@ variableContainer::get_change_in_vector_value( if (varChangeInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::values) { - return vector_change_in_vars[varChangeInfoList[global_variable_index] - .variable_index] - .get_value(q_point); + return vector_change_in_vars_map.at(global_variable_index)->get_value(q_point); } else { @@ -531,9 +525,7 @@ variableContainer::get_change_in_vector_gradient( if (varChangeInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::gradients) { - return vector_change_in_vars[varChangeInfoList[global_variable_index] - .variable_index] - .get_gradient(q_point); + return vector_change_in_vars_map.at(global_variable_index)->get_gradient(q_point); } else { @@ -553,9 +545,7 @@ variableContainer::get_change_in_vector_hessian( if (varChangeInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::hessians) { - return vector_change_in_vars[varChangeInfoList[global_variable_index] - .variable_index] - .get_hessian(q_point); + return vector_change_in_vars_map.at(global_variable_index)->get_hessian(q_point); } else { @@ -614,8 +604,7 @@ variableContainer::set_scalar_value_term_LHS( unsigned int global_variable_index, T val) { - scalar_change_in_vars[varChangeInfoList[global_variable_index].variable_index] - .submit_value(val, q_point); + scalar_change_in_vars_map[global_variable_index]->submit_value(val, q_point); } template @@ -624,8 +613,7 @@ variableContainer::set_scalar_gradient_term_LHS( unsigned int global_variable_index, dealii::Tensor<1, dim, T> grad) { - scalar_change_in_vars[varChangeInfoList[global_variable_index].variable_index] - .submit_gradient(grad, q_point); + scalar_change_in_vars_map[global_variable_index]->submit_gradient(grad, q_point); } template @@ -634,8 +622,7 @@ variableContainer::set_vector_value_term_LHS( unsigned int global_variable_index, dealii::Tensor<1, dim, T> val) { - vector_change_in_vars[varChangeInfoList[global_variable_index].variable_index] - .submit_value(val, q_point); + vector_change_in_vars_map[global_variable_index]->submit_value(val, q_point); } template @@ -644,8 +631,7 @@ variableContainer::set_vector_gradient_term_LHS( unsigned int global_variable_index, dealii::Tensor<2, dim, T> grad) { - vector_change_in_vars[varChangeInfoList[global_variable_index].variable_index] - .submit_gradient(grad, q_point); + vector_change_in_vars_map[global_variable_index]->submit_gradient(grad, q_point); } template class variableContainer<2, 1, dealii::VectorizedArray>; From 7f9b2cc70cd61b5b62ad38e00d579a7f428c6dc9 Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Mon, 16 Sep 2024 13:56:06 -0400 Subject: [PATCH 4/4] simplifications to variable_info struct --- include/model_variables.h | 1 - .../loadVariableAttributes.cc | 142 ++---------------- src/variableContainer/variableContainer.cc | 42 ++---- 3 files changed, 29 insertions(+), 156 deletions(-) diff --git a/include/model_variables.h b/include/model_variables.h index 20d9f7e5a..6f3da0c2e 100644 --- a/include/model_variables.h +++ b/include/model_variables.h @@ -34,7 +34,6 @@ class modelResidual struct variable_info { bool is_scalar; - unsigned int variable_index; unsigned int global_var_index; dealii::EvaluationFlags::EvaluationFlags evaluation_flags; dealii::EvaluationFlags::EvaluationFlags residual_flags; diff --git a/src/userInputParameters/loadVariableAttributes.cc b/src/userInputParameters/loadVariableAttributes.cc index 4edb12c7e..942936973 100644 --- a/src/userInputParameters/loadVariableAttributes.cc +++ b/src/userInputParameters/loadVariableAttributes.cc @@ -50,8 +50,6 @@ userInputParameters::loadVariableAttributes( } } varInfoListExplicitRHS.reserve(num_var_explicit_RHS); - unsigned int scalar_var_index = 0; - unsigned int vector_var_index = 0; for (unsigned int i = 0; i < number_of_variables; i++) { variable_info varInfo; @@ -64,28 +62,9 @@ userInputParameters::loadVariableAttributes( varInfo.global_var_index = i; - !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing) - ? varInfo.var_needed = true - : varInfo.var_needed = false; + varInfo.var_needed = !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); - if (var_type[i] == SCALAR) - { - varInfo.is_scalar = true; - if (varInfo.var_needed) - { - varInfo.variable_index = scalar_var_index; - scalar_var_index++; - } - } - else - { - varInfo.is_scalar = false; - if (varInfo.var_needed) - { - varInfo.variable_index = vector_var_index; - vector_var_index++; - } - } + varInfo.is_scalar = var_type[i] == SCALAR; varInfoListExplicitRHS.push_back(varInfo); } @@ -101,8 +80,6 @@ userInputParameters::loadVariableAttributes( } } varInfoListNonexplicitRHS.reserve(num_var_nonexplicit_RHS); - scalar_var_index = 0; - vector_var_index = 0; for (unsigned int i = 0; i < number_of_variables; i++) { variable_info varInfo; @@ -115,28 +92,9 @@ userInputParameters::loadVariableAttributes( varInfo.global_var_index = i; - !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing) - ? varInfo.var_needed = true - : varInfo.var_needed = false; + varInfo.var_needed = !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); - if (var_type[i] == SCALAR) - { - varInfo.is_scalar = true; - if (varInfo.var_needed) - { - varInfo.variable_index = scalar_var_index; - scalar_var_index++; - } - } - else - { - varInfo.is_scalar = false; - if (varInfo.var_needed) - { - varInfo.variable_index = vector_var_index; - vector_var_index++; - } - } + varInfo.is_scalar = var_type[i] == SCALAR; varInfoListNonexplicitRHS.push_back(varInfo); } @@ -153,8 +111,6 @@ userInputParameters::loadVariableAttributes( } varInfoListLHS.reserve(num_var_LHS); - scalar_var_index = 0; - vector_var_index = 0; for (unsigned int i = 0; i < number_of_variables; i++) { variable_info varInfo; @@ -167,35 +123,14 @@ userInputParameters::loadVariableAttributes( varInfo.global_var_index = i; - !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing) - ? varInfo.var_needed = true - : varInfo.var_needed = false; + varInfo.var_needed = !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); - if (var_type[i] == SCALAR) - { - varInfo.is_scalar = true; - if (varInfo.var_needed) - { - varInfo.variable_index = scalar_var_index; - scalar_var_index++; - } - } - else - { - varInfo.is_scalar = false; - if (varInfo.var_needed) - { - varInfo.variable_index = vector_var_index; - vector_var_index++; - } - } + varInfo.is_scalar = var_type[i] == SCALAR; varInfoListLHS.push_back(varInfo); } varChangeInfoListLHS.reserve(num_var_LHS); - scalar_var_index = 0; - vector_var_index = 0; for (unsigned int i = 0; i < number_of_variables; i++) { variable_info varInfo; @@ -209,28 +144,9 @@ userInputParameters::loadVariableAttributes( varInfo.global_var_index = i; - !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing) - ? varInfo.var_needed = true - : varInfo.var_needed = false; + varInfo.var_needed = !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); - if (var_type[i] == SCALAR) - { - varInfo.is_scalar = true; - if (varInfo.var_needed) - { - varInfo.variable_index = scalar_var_index; - scalar_var_index++; - } - } - else - { - varInfo.is_scalar = false; - if (varInfo.var_needed) - { - varInfo.variable_index = vector_var_index; - vector_var_index++; - } - } + varInfo.is_scalar = var_type[i] == SCALAR; varChangeInfoListLHS.push_back(varInfo); } @@ -238,8 +154,6 @@ userInputParameters::loadVariableAttributes( // Load variable information for postprocessing // First, the info list for the base field variables pp_baseVarInfoList.reserve(number_of_variables); - scalar_var_index = 0; - vector_var_index = 0; for (unsigned int i = 0; i < number_of_variables; i++) { variable_info varInfo; @@ -249,28 +163,9 @@ userInputParameters::loadVariableAttributes( varInfo.global_var_index = i; - !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing) - ? varInfo.var_needed = true - : varInfo.var_needed = false; + varInfo.var_needed = !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); - if (var_type[i] == SCALAR) - { - varInfo.is_scalar = true; - if (varInfo.var_needed) - { - varInfo.variable_index = scalar_var_index; - scalar_var_index++; - } - } - else - { - varInfo.is_scalar = false; - if (varInfo.var_needed) - { - varInfo.variable_index = vector_var_index; - vector_var_index++; - } - } + varInfo.is_scalar = var_type[i] == SCALAR; pp_baseVarInfoList.push_back(varInfo); } @@ -292,8 +187,6 @@ userInputParameters::loadVariableAttributes( // The info list for the postprocessing field variables pp_varInfoList.reserve(pp_number_of_variables); - scalar_var_index = 0; - vector_var_index = 0; for (unsigned int i = 0; i < pp_number_of_variables; i++) { variable_info varInfo; @@ -303,18 +196,9 @@ userInputParameters::loadVariableAttributes( variable_attributes.equation_dependency_parser.eval_flags_residual_postprocess[i]; varInfo.global_var_index = i; - if (pp_var_type[i] == SCALAR) - { - varInfo.is_scalar = true; - varInfo.variable_index = scalar_var_index; - scalar_var_index++; - } - else - { - varInfo.is_scalar = false; - varInfo.variable_index = vector_var_index; - vector_var_index++; - } + + varInfo.is_scalar = pp_var_type[i] == SCALAR; + pp_varInfoList.push_back(varInfo); } } diff --git a/src/variableContainer/variableContainer.cc b/src/variableContainer/variableContainer.cc index d37ab91f2..14ac824e8 100644 --- a/src/variableContainer/variableContainer.cc +++ b/src/variableContainer/variableContainer.cc @@ -16,7 +16,7 @@ variableContainer::variableContainer( if (var_info.var_needed) { - const unsigned int var_index = var_info.variable_index; + const unsigned int var_index = var_info.global_var_index; if (var_info.is_scalar) { @@ -64,7 +64,7 @@ variableContainer::variableContainer( continue; } - const unsigned int var_index = var_info.variable_index; + const unsigned int var_index = var_info.global_var_index; if (var_info.is_scalar) { @@ -96,7 +96,7 @@ variableContainer::variableContainer( continue; } - const unsigned int var_index = var_info.variable_index; + const unsigned int var_index = var_info.global_var_index; if (var_info.is_scalar) { @@ -183,7 +183,7 @@ variableContainer::reinit_and_eval(const std::vector::reinit(unsigned int cell) continue; } - const unsigned int var_index = var_info.variable_index; + const unsigned int var_index = var_info.global_var_index; if (var_info.is_scalar) { @@ -269,7 +269,7 @@ variableContainer::integrate_and_distribute( continue; } - const unsigned int var_index = var_info.variable_index; + const unsigned int var_index = var_info.global_var_index; if (var_info.is_scalar) { @@ -317,8 +317,7 @@ variableContainer::get_scalar_value( if (varInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::values) { - return scalar_vars_map.at(varInfoList[global_variable_index].variable_index) - ->get_value(q_point); + return scalar_vars_map.at(global_variable_index)->get_value(q_point); } else { @@ -338,8 +337,7 @@ variableContainer::get_scalar_gradient( if (varInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::gradients) { - return scalar_vars_map.at(varInfoList[global_variable_index].variable_index) - ->get_gradient(q_point); + return scalar_vars_map.at(global_variable_index)->get_gradient(q_point); } else { @@ -359,8 +357,7 @@ variableContainer::get_scalar_hessian( if (varInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::hessians) { - return scalar_vars_map.at(varInfoList[global_variable_index].variable_index) - ->get_hessian(q_point); + return scalar_vars_map.at(global_variable_index)->get_hessian(q_point); } else { @@ -380,8 +377,7 @@ variableContainer::get_vector_value( if (varInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::values) { - return vector_vars_map.at(varInfoList[global_variable_index].variable_index) - ->get_value(q_point); + return vector_vars_map.at(global_variable_index)->get_value(q_point); } else { @@ -401,8 +397,7 @@ variableContainer::get_vector_gradient( if (varInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::gradients) { - return vector_vars_map.at(varInfoList[global_variable_index].variable_index) - ->get_gradient(q_point); + return vector_vars_map.at(global_variable_index)->get_gradient(q_point); } else { @@ -422,8 +417,7 @@ variableContainer::get_vector_hessian( if (varInfoList[global_variable_index].evaluation_flags & dealii::EvaluationFlags::hessians) { - return vector_vars_map.at(varInfoList[global_variable_index].variable_index) - ->get_hessian(q_point); + return vector_vars_map.at(global_variable_index)->get_hessian(q_point); } else { @@ -564,8 +558,7 @@ variableContainer::set_scalar_value_term_RHS( unsigned int global_variable_index, T val) { - scalar_vars_map[varInfoList[global_variable_index].variable_index] - ->submit_value(val, q_point); + scalar_vars_map[global_variable_index]->submit_value(val, q_point); } template @@ -574,8 +567,7 @@ variableContainer::set_scalar_gradient_term_RHS( unsigned int global_variable_index, dealii::Tensor<1, dim, T> grad) { - scalar_vars_map[varInfoList[global_variable_index].variable_index] - ->submit_gradient(grad, q_point); + scalar_vars_map[global_variable_index]->submit_gradient(grad, q_point); } template @@ -584,8 +576,7 @@ variableContainer::set_vector_value_term_RHS( unsigned int global_variable_index, dealii::Tensor<1, dim, T> val) { - vector_vars_map[varInfoList[global_variable_index].variable_index] - ->submit_value(val, q_point); + vector_vars_map[global_variable_index]->submit_value(val, q_point); } template @@ -594,8 +585,7 @@ variableContainer::set_vector_gradient_term_RHS( unsigned int global_variable_index, dealii::Tensor<2, dim, T> grad) { - vector_vars_map[varInfoList[global_variable_index].variable_index] - ->submit_gradient(grad, q_point); + vector_vars_map[global_variable_index]->submit_gradient(grad, q_point); } template