34template <
typename GlobalDimNodalMatrixType>
38 double const& integration_weight_)
44 GlobalDimNodalMatrixType
const dNdx;
51 double porosity = std::numeric_limits<double>::quiet_NaN();
66 std::size_t
const mesh_item_id,
67 std::vector<NumLib::LocalToGlobalIndexMap const*>
const& dof_tables,
68 std::vector<GlobalVector*>
const& x,
double const t)
70 std::vector<double> local_x_vec;
72 auto const n_processes = x.size();
73 for (std::size_t process_id = 0; process_id < n_processes; ++process_id)
77 assert(!indices.empty());
78 auto const local_solution = x[process_id]->get(indices);
79 local_x_vec.insert(std::end(local_x_vec),
80 std::begin(local_solution),
81 std::end(local_solution));
89 std::size_t
const mesh_item_id,
90 std::vector<NumLib::LocalToGlobalIndexMap const*>
const& dof_tables,
91 std::vector<GlobalVector*>
const& x,
double const t,
double const dt)
93 std::vector<double> local_x_vec;
95 auto const n_processes = x.size();
96 for (std::size_t process_id = 0; process_id < n_processes; ++process_id)
100 assert(!indices.empty());
101 auto const local_solution = x[process_id]->get(indices);
102 local_x_vec.insert(std::end(local_x_vec),
103 std::begin(local_solution),
104 std::end(local_solution));
112 std::size_t
const mesh_item_id,
113 std::vector<NumLib::LocalToGlobalIndexMap const*>
const& dof_tables,
114 std::vector<GlobalVector*>
const& x,
double const t,
double const dt,
117 std::vector<double> local_x_vec;
119 auto const n_processes = x.size();
120 for (std::size_t pcs_id = 0; pcs_id < n_processes; ++pcs_id)
124 assert(!indices.empty());
125 auto const local_solution = x[pcs_id]->get(indices);
126 local_x_vec.insert(std::end(local_x_vec),
127 std::begin(local_solution),
128 std::end(local_solution));
134 auto const num_r_c = indices.size();
136 std::vector<double> local_M_data;
137 local_M_data.reserve(num_r_c * num_r_c);
138 std::vector<double> local_K_data;
139 local_K_data.reserve(num_r_c * num_r_c);
140 std::vector<double> local_b_data;
141 local_b_data.reserve(num_r_c);
144 local_K_data, local_b_data,
147 auto const r_c_indices =
149 if (!local_M_data.empty())
153 M.
add(r_c_indices, local_M);
155 if (!local_K_data.empty())
159 K.
add(r_c_indices, local_K);
161 if (!local_b_data.empty())
163 b.
add(indices, local_b_data);
168 double const t,
double const dt) = 0;
171 std::size_t
const ele_id) = 0;
175 std::vector<GlobalVector*>
const& x,
176 std::vector<NumLib::LocalToGlobalIndexMap const*>
const& dof_table,
177 std::vector<double>& cache)
const = 0;
181 std::vector<GlobalVector*>
const& x,
182 std::vector<NumLib::LocalToGlobalIndexMap const*>
const& dof_table,
183 std::vector<double>& cache)
const = 0;
186 const double t, std::vector<GlobalVector*>
const& x,
187 std::vector<NumLib::LocalToGlobalIndexMap const*>
const& dof_table,
188 std::vector<double>& cache,
int const component_id)
const = 0;
192 Eigen::VectorXd
const& ,
double const ) = 0;
199 double const t,
double const dt, Eigen::VectorXd
const& local_x,
200 std::vector<double>& local_M_data, std::vector<double>& local_K_data,
201 std::vector<double>& local_b_data,
int const transport_process_id) = 0;
204template <
typename ShapeFunction,
int GlobalDim>
216 ShapeFunction::NPOINTS;
222 typename ShapeMatricesType::template MatrixType<
pressure_size,
225 typename ShapeMatricesType::template VectorType<pressure_size>;
228 Eigen::Matrix<double, Eigen::Dynamic, Eigen::Dynamic, Eigen::RowMajor>;
242 std::size_t
const local_matrix_size,
244 bool is_axially_symmetric,
246 std::vector<std::reference_wrapper<ProcessVariable>>
const&
247 transport_process_variables)
258 (void)local_matrix_size;
260 unsigned const n_integration_points =
262 _ip_data.reserve(n_integration_points);
267 double const aperture_size =
_process_data.aperture_size(0.0, pos)[0];
269 auto const shape_matrices =
271 GlobalDim>(element, is_axially_symmetric,
275 for (
unsigned ip = 0; ip < n_integration_points; ip++)
278 shape_matrices[ip].dNdx,
280 shape_matrices[ip].integralMeasure *
281 shape_matrices[ip].detJ * aperture_size);
285 .template initialValue<double>(
286 pos, std::numeric_limits<double>::quiet_NaN() );
296 auto& chemical_system_index_map =
297 _process_data.chemical_solver_interface->chemical_system_index_map;
299 unsigned const n_integration_points =
301 for (
unsigned ip = 0; ip < n_integration_points; ip++)
304 chemical_system_index_map.empty()
306 : chemical_system_index_map.back() + 1;
307 chemical_system_index_map.push_back(
313 double const t)
override
325 .NsHigherOrder<
typename ShapeFunction::MeshElement>();
327 unsigned const n_integration_points =
330 for (
unsigned ip = 0; ip < n_integration_points; ip++)
333 auto const& N = Ns[ip];
334 auto const& chemical_system_id = ip_data.chemical_system_id;
344 std::vector<double> C_int_pt(n_component);
345 for (
unsigned component_id = 0; component_id < n_component;
348 auto const concentration_index =
352 local_x.template segment<concentration_size>(
353 concentration_index);
356 C_int_pt[component_id]);
360 ->initializeChemicalSystemConcrete(C_int_pt, chemical_system_id,
366 double const t,
double dt)
override
381 .NsHigherOrder<
typename ShapeFunction::MeshElement>();
383 unsigned const n_integration_points =
386 for (
unsigned ip = 0; ip < n_integration_points; ip++)
389 auto const& N = Ns[ip];
390 auto& porosity = ip_data.porosity;
391 auto const& porosity_prev = ip_data.porosity_prev;
392 auto const& chemical_system_id = ip_data.chemical_system_id;
395 std::vector<double> C_int_pt(n_component);
396 for (
unsigned component_id = 0; component_id < n_component;
399 auto const concentration_index =
403 local_x.template segment<concentration_size>(
404 concentration_index);
407 C_int_pt[component_id]);
419 .template value<double>(vars, vars_prev, pos, t,
425 _process_data.chemical_solver_interface->setChemicalSystemConcrete(
426 C_int_pt, chemical_system_id, medium, vars, pos, t, dt);
431 double const dt)
override
438 auto const& medium = *
_process_data.media_map.getMedium(ele_id);
445 ip_data.porosity = ip_data.porosity_prev;
448 ->updateVolumeFractionPostReaction(ip_data.chemical_system_id,
450 ip_data.porosity, t, dt);
452 _process_data.chemical_solver_interface->updatePorosityPostReaction(
453 ip_data.chemical_system_id, medium, ip_data.porosity);
458 std::vector<double>
const& local_x,
459 std::vector<double>
const& ,
460 std::vector<double>& local_M_data,
461 std::vector<double>& local_K_data,
462 std::vector<double>& local_b_data)
override
464 auto const local_matrix_size = local_x.size();
469 assert(local_matrix_size == ShapeFunction::NPOINTS * num_nodal_dof);
472 local_M_data, local_matrix_size, local_matrix_size);
474 local_K_data, local_matrix_size, local_matrix_size);
476 local_b_data, local_matrix_size);
479 auto Kpp = local_K.template block<pressure_size, pressure_size>(
481 auto Mpp = local_M.template block<pressure_size, pressure_size>(
483 auto Bp = local_b.template segment<pressure_size>(
pressure_index);
485 auto local_p = Eigen::Map<const NodalVectorType>(
490 .projected_specific_body_force_vectors[
_element.getID()];
492 auto const number_of_components = num_nodal_dof - 1;
493 for (
int component_id = 0; component_id < number_of_components;
505 auto concentration_index =
509 local_K.template block<concentration_size, concentration_size>(
510 concentration_index, concentration_index);
512 local_M.template block<concentration_size, concentration_size>(
513 concentration_index, concentration_index);
515 local_M.template block<concentration_size, pressure_size>(
518 local_M.template block<pressure_size, concentration_size>(
521 auto local_C = Eigen::Map<const NodalVectorType>(
525 MCC, MCp, MpC, Kpp, Mpp, Bp);
529 auto const stoichiometric_matrix =
531 ->getStoichiometricMatrix();
533 assert(stoichiometric_matrix);
535 for (Eigen::SparseMatrix<double>::InnerIterator it(
536 *stoichiometric_matrix, component_id);
540 auto const stoichiometric_coefficient = it.value();
541 auto const coupled_component_id = it.row();
542 auto const kinetic_prefactor =
544 ->getKineticPrefactor(coupled_component_id);
546 auto const concentration_index =
548 auto const coupled_concentration_index =
553 concentration_index, coupled_concentration_index);
557 stoichiometric_coefficient,
567 Eigen::Ref<const NodalVectorType>
const& C_nodal_values,
568 Eigen::Ref<const NodalVectorType>
const& p_nodal_values,
569 Eigen::Ref<LocalBlockMatrixType> KCC,
570 Eigen::Ref<LocalBlockMatrixType> MCC,
571 Eigen::Ref<LocalBlockMatrixType> MCp,
572 Eigen::Ref<LocalBlockMatrixType> MpC,
573 Eigen::Ref<LocalBlockMatrixType> Kpp,
574 Eigen::Ref<LocalBlockMatrixType> Mpp,
575 Eigen::Ref<LocalSegmentVectorType> Bp)
577 unsigned const n_integration_points =
589 auto const& phase = medium.phase(
"AqueousLiquid");
594 auto const& component = phase.component(
600 std::vector<GlobalDimVectorType> ip_flux_vector;
601 double average_velocity_norm = 0.0;
604 ip_flux_vector.reserve(n_integration_points);
609 .NsHigherOrder<
typename ShapeFunction::MeshElement>();
611 for (
unsigned ip(0); ip < n_integration_points; ++ip)
614 auto const& dNdx = ip_data.dNdx;
615 auto const& N = Ns[ip];
616 auto const& w = ip_data.integration_weight;
617 auto& porosity = ip_data.porosity;
619 double C_int_pt = 0.0;
620 double p_int_pt = 0.0;
637 .template value<double>(vars, pos, t, dt);
640 auto const& retardation_factor =
642 .template value<double>(vars, pos, t, dt);
644 auto const& solute_dispersivity_transverse = medium.template value<
648 auto const& solute_dispersivity_longitudinal =
649 medium.template value<double>(
651 longitudinal_dispersivity);
658 .template value<double>(vars, pos, t, dt);
660 auto const decay_rate =
662 .template value<double>(vars, pos, t, dt);
664 auto const& pore_diffusion_coefficient =
667 .value(vars, pos, t, dt));
675 .template value<double>(vars, pos, t, dt);
681 .template value<double>(vars, pos, t, dt);
688 (dNdx * p_nodal_values - density * b))
691 const double drho_dp =
693 .template dValue<double>(
698 const double drho_dC =
700 .template dValue<double>(
707 pore_diffusion_coefficient, velocity, porosity,
708 solute_dispersivity_transverse,
709 solute_dispersivity_longitudinal);
711 const double R_times_phi(retardation_factor * porosity);
713 auto const N_t_N = (N.transpose() * N).eval();
717 MCp.noalias() += N_t_N * (C_int_pt * R_times_phi * drho_dp * w);
718 MCC.noalias() += N_t_N * (C_int_pt * R_times_phi * drho_dC * w);
719 KCC.noalias() -= dNdx.transpose() * mass_density_flow * N * w;
723 ip_flux_vector.emplace_back(mass_density_flow);
724 average_velocity_norm += velocity.norm();
726 MCC.noalias() += N_t_N * (R_times_phi * density * w);
727 KCC.noalias() += N_t_N * (decay_rate * R_times_phi * density * w);
728 KCC_Laplacian.noalias() +=
729 dNdx.transpose() * hydrodynamic_dispersion * dNdx * density * w;
731 MpC.noalias() += N_t_N * (porosity * drho_dC * w);
734 if (component_id == 0)
737 N_t_N * (porosity * drho_dp * w + density * storage * w);
739 dNdx.transpose() * K_over_mu * dNdx * (density * w);
743 Bp.noalias() += dNdx.transpose() * K_over_mu * b *
744 (density * density * w);
752 typename ShapeFunction::MeshElement>(
757 average_velocity_norm /
758 static_cast<double>(n_integration_points),
762 KCC.noalias() += KCC_Laplacian;
766 Eigen::Ref<LocalBlockMatrixType> KCmCn,
767 double const stoichiometric_coefficient,
768 double const kinetic_prefactor)
770 unsigned const n_integration_points =
780 auto const& phase = medium.phase(
"AqueousLiquid");
781 auto const& component = phase.component(
786 .NsHigherOrder<
typename ShapeFunction::MeshElement>();
788 for (
unsigned ip(0); ip < n_integration_points; ++ip)
791 auto const& w = ip_data.integration_weight;
792 auto const& N = Ns[ip];
793 auto& porosity = ip_data.porosity;
802 auto const retardation_factor =
804 .template value<double>(vars, pos, t, dt);
807 .template value<double>(vars, pos, t, dt);
811 .template value<double>(vars, pos, t, dt);
813 KCmCn.noalias() -= N.transpose() * N *
814 (stoichiometric_coefficient * kinetic_prefactor *
815 retardation_factor * porosity * density * w);
820 Eigen::VectorXd
const& local_x,
821 Eigen::VectorXd
const& local_x_prev,
822 int const process_id,
823 std::vector<double>& local_M_data,
824 std::vector<double>& local_K_data,
825 std::vector<double>& local_b_data)
override
830 local_M_data, local_K_data, local_b_data);
835 local_M_data, local_K_data,
842 local_M_data, local_K_data,
843 local_b_data, process_id);
849 Eigen::VectorXd
const& local_x,
850 Eigen::VectorXd
const& local_x_prev,
851 std::vector<double>& local_M_data,
852 std::vector<double>& local_K_data,
853 std::vector<double>& local_b_data)
857 auto const local_C = local_x.template segment<concentration_size>(
859 auto const local_C_prev =
871 unsigned const n_integration_points =
879 .projected_specific_body_force_vectors[
_element.getID()];
883 auto const& phase = medium.phase(
"AqueousLiquid");
890 .NsHigherOrder<
typename ShapeFunction::MeshElement>();
892 for (
unsigned ip(0); ip < n_integration_points; ++ip)
895 auto const& dNdx = ip_data.dNdx;
896 auto const& w = ip_data.integration_weight;
897 auto const& N = Ns[ip];
898 auto& porosity = ip_data.porosity;
899 auto const& porosity_prev = ip_data.porosity_prev;
901 double const C_int_pt = N.dot(local_C);
902 double const p_int_pt = N.dot(local_p);
903 double const T_int_pt = N.dot(local_T);
917 .template value<double>(vars, vars_prev, pos, t,
928 .template value<double>(vars, pos, t, dt);
934 .template value<double>(vars, pos, t, dt);
943 .template value<double>(vars, pos, t, dt);
947 const double drho_dp =
949 .template dValue<double>(
953 const double drho_dC =
955 .template dValue<double>(
962 (porosity * drho_dp * w + density * storage * w);
964 w * dNdx.transpose() * density * K_over_mu * dNdx;
969 w * density * density * dNdx.transpose() * K_over_mu * b;
974 double const C_dot = (C_int_pt - N.dot(local_C_prev)) / dt;
977 N.transpose() * (porosity * drho_dC * C_dot * w);
983 Eigen::VectorXd
const& local_x,
984 Eigen::VectorXd
const& ,
985 std::vector<double>& local_M_data,
986 std::vector<double>& local_K_data,
987 std::vector<double>& )
990 assert(local_x.size() ==
1008 auto const& medium =
1009 *process_data.media_map.getMedium(this->
_element.getID());
1010 auto const& liquid_phase = medium.phase(
"AqueousLiquid");
1014 .projected_specific_body_force_vectors[
_element.getID()];
1018 unsigned const n_integration_points =
1021 std::vector<GlobalDimVectorType> ip_flux_vector;
1022 double average_velocity_norm = 0.0;
1023 ip_flux_vector.reserve(n_integration_points);
1027 .NsHigherOrder<
typename ShapeFunction::MeshElement>();
1029 for (
unsigned ip(0); ip < n_integration_points; ip++)
1031 auto const& ip_data = this->
_ip_data[ip];
1032 auto const& dNdx = ip_data.dNdx;
1033 auto const& w = ip_data.integration_weight;
1034 auto const& N = Ns[ip];
1043 double p_at_xi = 0.;
1045 double T_at_xi = 0.;
1053 auto const porosity =
1055 .template value<double>(vars, pos, t, dt);
1059 auto const fluid_density =
1062 .template value<double>(vars, pos, t, dt);
1064 auto const specific_heat_capacity_fluid =
1067 .template value<double>(vars, pos, t, dt);
1070 local_M.noalias() +=
1073 specific_heat_capacity_fluid,
1078 auto const viscosity =
1081 .template value<double>(vars, pos, t, dt);
1083 auto const intrinsic_permeability =
1088 .value(vars, pos, t, dt));
1091 intrinsic_permeability / viscosity;
1093 process_data.has_gravity
1095 (dNdx * local_p - fluid_density * b))
1100 vars, fluid_density, specific_heat_capacity_fluid, velocity,
1103 local_K.noalias() +=
1104 w * dNdx.transpose() * thermal_conductivity_dispersivity * dNdx;
1106 ip_flux_vector.emplace_back(velocity * fluid_density *
1107 specific_heat_capacity_fluid);
1108 average_velocity_norm += velocity.norm();
1112 process_data.stabilizer, this->_ip_data,
1114 average_velocity_norm /
static_cast<double>(n_integration_points),
1119 double const t,
double const dt, Eigen::VectorXd
const& local_x,
1120 Eigen::VectorXd
const& local_x_prev, std::vector<double>& local_M_data,
1121 std::vector<double>& local_K_data,
1122 std::vector<double>& ,
int const transport_process_id)
1124 assert(
static_cast<int>(local_x.size()) ==
1130 auto const local_p =
1135 auto const local_C = local_x.template segment<concentration_size>(
1137 (transport_process_id - (
_process_data.isothermal ? 1 : 2)) *
1139 auto const local_p_prev =
1150 unsigned const n_integration_points =
1153 std::vector<GlobalDimVectorType> ip_flux_vector;
1154 double average_velocity_norm = 0.0;
1157 ip_flux_vector.reserve(n_integration_points);
1165 .projected_specific_body_force_vectors[
_element.getID()];
1170 auto const& medium =
1172 auto const& phase = medium.phase(
"AqueousLiquid");
1173 auto const component_id =
1175 auto const& component = phase.component(
1180 .NsHigherOrder<
typename ShapeFunction::MeshElement>();
1182 for (
unsigned ip(0); ip < n_integration_points; ++ip)
1185 auto const& dNdx = ip_data.dNdx;
1186 auto const& w = ip_data.integration_weight;
1187 auto const& N = Ns[ip];
1188 auto& porosity = ip_data.porosity;
1189 auto const& porosity_prev = ip_data.porosity_prev;
1191 double const C_int_pt = N.dot(local_C);
1192 double const p_int_pt = N.dot(local_p);
1193 double const T_int_pt = N.dot(local_T);
1206 vars_prev.
porosity = porosity_prev;
1212 .template value<double>(vars, vars_prev, pos, t,
1218 auto const& retardation_factor =
1220 .template value<double>(vars, pos, t, dt);
1222 auto const& solute_dispersivity_transverse = medium.template value<
1225 auto const& solute_dispersivity_longitudinal =
1226 medium.template value<double>(
1228 longitudinal_dispersivity);
1231 auto const density =
1233 .template value<double>(vars, pos, t, dt);
1234 auto const decay_rate =
1236 .template value<double>(vars, pos, t, dt);
1238 auto const& pore_diffusion_coefficient =
1241 .value(vars, pos, t, dt));
1248 .template value<double>(vars, pos, t, dt);
1254 (dNdx * local_p - density * b))
1260 pore_diffusion_coefficient, velocity, porosity,
1261 solute_dispersivity_transverse,
1262 solute_dispersivity_longitudinal);
1264 double const R_times_phi = retardation_factor * porosity;
1265 auto const N_t_N = (N.transpose() * N).eval();
1269 const double drho_dC =
1271 .template dValue<double>(
1274 local_M.noalias() +=
1275 N_t_N * (R_times_phi * C_int_pt * drho_dC * w);
1278 local_M.noalias() += N_t_N * (R_times_phi * density * w);
1283 double const p_dot = (p_int_pt - N.dot(local_p_prev)) / dt;
1285 const double drho_dp =
1287 .template dValue<double>(vars,
1289 liquid_phase_pressure,
1292 local_K.noalias() +=
1293 N_t_N * ((R_times_phi * drho_dp * p_dot) * w) -
1294 dNdx.transpose() * velocity * N * (density * w);
1298 ip_flux_vector.emplace_back(velocity * density);
1299 average_velocity_norm += velocity.norm();
1301 local_K.noalias() +=
1302 N_t_N * (decay_rate * R_times_phi * density * w);
1304 KCC_Laplacian.noalias() += dNdx.transpose() *
1305 hydrodynamic_dispersion * dNdx *
1312 typename ShapeFunction::MeshElement>(
1315 average_velocity_norm /
1316 static_cast<double>(n_integration_points),
1319 local_K.noalias() += KCC_Laplacian;
1323 double const t,
double const dt, Eigen::VectorXd
const& local_x,
1324 Eigen::VectorXd
const& local_x_prev,
int const process_id,
1325 std::vector<double>& local_b_data,
1326 std::vector<double>& local_Jac_data)
override
1331 local_b_data, local_Jac_data);
1335 int const component_id = process_id - 1;
1337 t, dt, local_x, local_x_prev, local_b_data, local_Jac_data,
1343 double const t,
double const dt, Eigen::VectorXd
const& local_x,
1344 Eigen::VectorXd
const& local_x_prev, std::vector<double>& local_b_data,
1345 std::vector<double>& local_Jac_data)
1347 auto const p = local_x.template segment<pressure_size>(
pressure_index);
1348 auto const c = local_x.template segment<concentration_size>(
1360 unsigned const n_integration_points =
1367 .projected_specific_body_force_vectors[
_element.getID()];
1369 auto const& medium =
1371 auto const& phase = medium.phase(
"AqueousLiquid");
1378 .NsHigherOrder<
typename ShapeFunction::MeshElement>();
1380 for (
unsigned ip(0); ip < n_integration_points; ++ip)
1383 auto const& dNdx = ip_data.dNdx;
1384 auto const& w = ip_data.integration_weight;
1385 auto const& N = Ns[ip];
1386 auto& phi = ip_data.porosity;
1387 auto const& phi_prev = ip_data.porosity_prev;
1389 double const p_ip = N.dot(p);
1390 double const c_ip = N.dot(c);
1392 double const cdot_ip = (c_ip - N.dot(c_prev)) / dt;
1404 .template value<double>(vars, vars_prev, pos, t,
1411 .template value<double>(vars, pos, t, dt);
1418 .template value<double>(vars, pos, t, dt);
1420 auto const drho_dp =
1422 .template dValue<double>(
1426 auto const drho_dc =
1428 .template dValue<double>(
1433 local_Jac.noalias() +=
1434 N.transpose() * N * (phi * drho_dp / dt * w) +
1435 w * dNdx.transpose() * rho * k / mu * dNdx;
1437 local_rhs.noalias() -=
1438 N.transpose() * (drho_dp * N * p_prev + drho_dc * cdot_ip) *
1440 dNdx.transpose() * k / mu * dNdx * p * (rho * w);
1444 local_rhs.noalias() +=
1445 w * rho * dNdx.transpose() * k / mu * rho * b;
1451 double const t,
double const dt, Eigen::VectorXd
const& local_x,
1452 Eigen::VectorXd
const& local_x_prev, std::vector<double>& local_b_data,
1453 std::vector<double>& local_Jac_data,
int const component_id)
1455 auto const concentration_index =
1458 auto const p = local_x.template segment<pressure_size>(
pressure_index);
1460 local_x.template segment<concentration_size>(concentration_index);
1478 unsigned const n_integration_points =
1481 std::vector<GlobalDimVectorType> ip_flux_vector;
1482 double average_velocity_norm = 0.0;
1483 ip_flux_vector.reserve(n_integration_points);
1490 .projected_specific_body_force_vectors[
_element.getID()];
1495 auto const& medium =
1497 auto const& phase = medium.phase(
"AqueousLiquid");
1498 auto const& component = phase.component(
1503 .NsHigherOrder<
typename ShapeFunction::MeshElement>();
1505 for (
unsigned ip(0); ip < n_integration_points; ++ip)
1508 auto const& dNdx = ip_data.dNdx;
1509 auto const& w = ip_data.integration_weight;
1510 auto const& N = Ns[ip];
1511 auto& phi = ip_data.porosity;
1512 auto const& phi_prev = ip_data.porosity_prev;
1514 double const p_ip = N.dot(p);
1515 double const c_ip = N.dot(c);
1532 .template value<double>(vars, vars_prev, pos, t,
1540 .template value<double>(vars, pos, t, dt);
1542 auto const alpha_T = medium.template value<double>(
1544 auto const alpha_L = medium.template value<double>(
1548 .template value<double>(vars, pos, t, dt);
1552 .template value<double>(vars, pos, t, dt);
1556 .value(vars, pos, t, dt));
1562 .template value<double>(vars, pos, t, dt);
1574 local_Jac.noalias() +=
1575 N.transpose() * N * (rho * phi * R * (alpha + 1 / dt) * w);
1577 KCC_Laplacian.noalias() += w * rho * dNdx.transpose() * D * dNdx;
1579 auto const cdot = (c - c_prev) / dt;
1580 local_rhs.noalias() -=
1581 N.transpose() * N * (cdot + alpha * c) * (rho * phi * R * w);
1583 ip_flux_vector.emplace_back(q * rho);
1584 average_velocity_norm += q.norm();
1590 average_velocity_norm /
static_cast<double>(n_integration_points),
1593 local_rhs.noalias() -= KCC_Laplacian * c;
1595 local_Jac.noalias() += KCC_Laplacian;
1599 double const t,
double const dt, Eigen::VectorXd
const& local_x,
1600 std::vector<double>& local_M_data, std::vector<double>& local_K_data,
1601 std::vector<double>& local_b_data,
1602 int const transport_process_id)
override
1604 auto const local_C = local_x.template segment<concentration_size>(
1615 unsigned const n_integration_points =
1624 auto const& medium =
1626 auto const component_id = transport_process_id - 1;
1630 .NsHigherOrder<
typename ShapeFunction::MeshElement>();
1632 for (
unsigned ip(0); ip < n_integration_points; ++ip)
1635 auto const w = ip_data.integration_weight;
1636 auto const& N = Ns[ip];
1637 auto& porosity = ip_data.porosity;
1638 auto const& porosity_prev = ip_data.porosity_prev;
1639 auto const chemical_system_id = ip_data.chemical_system_id;
1641 double C_int_pt = 0.0;
1646 auto const porosity_dot = (porosity - porosity_prev) / dt;
1650 vars_prev.
porosity = porosity_prev;
1656 .template value<double>(vars, vars_prev, pos, t,
1660 local_M.noalias() += w * N.transpose() * porosity * N;
1662 local_K.noalias() += w * N.transpose() * porosity_dot * N;
1664 if (chemical_system_id == -1)
1669 auto const C_post_int_pt =
1671 component_id, chemical_system_id);
1673 local_b.noalias() += N.transpose() * ((C_post_int_pt - C_int_pt) /
1680 std::vector<GlobalVector*>
const& x,
1681 std::vector<NumLib::LocalToGlobalIndexMap const*>
const& dof_table,
1682 std::vector<double>& cache)
const override
1684 assert(x.size() == dof_table.size());
1686 auto const n_processes = x.size();
1687 std::vector<std::vector<double>> local_x;
1688 local_x.reserve(n_processes);
1690 for (std::size_t process_id = 0; process_id < n_processes; ++process_id)
1692 auto const indices =
1694 assert(!indices.empty());
1695 local_x.push_back(x[process_id]->get(indices));
1699 if (n_processes == 1)
1701 auto const local_p = Eigen::Map<const NodalVectorType>(
1703 auto const local_C = Eigen::Map<const NodalVectorType>(
1706 local_T.setConstant(ShapeFunction::NPOINTS,
1707 std::numeric_limits<double>::quiet_NaN());
1712 local_T = Eigen::Map<const NodalVectorType>(
1721 constexpr int pressure_process_id = 0;
1722 int concentration_process_id = 1;
1725 int temperature_process_id = -1;
1731 temperature_process_id = 1;
1733 concentration_process_id = 2;
1736 auto const local_p = Eigen::Map<const NodalVectorType>(
1738 auto const local_C = Eigen::Map<const NodalVectorType>(
1741 local_T.setConstant(ShapeFunction::NPOINTS,
1742 std::numeric_limits<double>::quiet_NaN());
1743 if (temperature_process_id != -1)
1745 local_T = Eigen::Map<const NodalVectorType>(
1755 Eigen::Ref<const NodalVectorType>
const& p_nodal_values,
1756 Eigen::Ref<const NodalVectorType>
const& C_nodal_values,
1757 Eigen::Ref<const NodalVectorType>
const& T_nodal_values,
1758 std::vector<double>& cache)
const
1760 auto const n_integration_points =
1765 cache, n_integration_points);
1772 auto const& medium =
1774 auto const& phase = medium.phase(
"AqueousLiquid");
1778 .NsHigherOrder<
typename ShapeFunction::MeshElement>();
1780 for (
unsigned ip = 0; ip < n_integration_points; ++ip)
1782 auto const& N = Ns[ip];
1784 double C_int_pt = 0.0;
1785 double p_int_pt = 0.0;
1786 double T_int_pt = 0.0;
1798 double const dt = std::numeric_limits<double>::quiet_NaN();
1801 .template value<double>(vars, pos, t, dt);
1802 cache_vec[ip] = rho_w;
1810 std::vector<GlobalVector*>
const& x,
1811 std::vector<NumLib::LocalToGlobalIndexMap const*>
const& dof_table,
1812 std::vector<double>& cache)
const override
1814 assert(x.size() == dof_table.size());
1816 auto const n_processes = x.size();
1817 std::vector<std::vector<double>> local_x;
1818 local_x.reserve(n_processes);
1820 for (std::size_t process_id = 0; process_id < n_processes; ++process_id)
1822 auto const indices =
1824 assert(!indices.empty());
1825 local_x.push_back(x[process_id]->get(indices));
1829 if (n_processes == 1)
1831 auto const local_p = Eigen::Map<const NodalVectorType>(
1833 auto const local_C = Eigen::Map<const NodalVectorType>(
1836 local_T.setConstant(ShapeFunction::NPOINTS,
1837 std::numeric_limits<double>::quiet_NaN());
1842 local_T = Eigen::Map<const NodalVectorType>(
1851 constexpr int pressure_process_id = 0;
1852 int concentration_process_id = 1;
1855 int temperature_process_id = -1;
1861 temperature_process_id = 1;
1863 concentration_process_id = 2;
1866 auto const local_p = Eigen::Map<const NodalVectorType>(
1868 auto const local_C = Eigen::Map<const NodalVectorType>(
1871 local_T.setConstant(ShapeFunction::NPOINTS,
1872 std::numeric_limits<double>::quiet_NaN());
1873 if (temperature_process_id != -1)
1875 local_T = Eigen::Map<const NodalVectorType>(
1885 Eigen::Ref<const NodalVectorType>
const& p_nodal_values,
1886 Eigen::Ref<const NodalVectorType>
const& C_nodal_values,
1887 Eigen::Ref<const NodalVectorType>
const& T_nodal_values,
1888 std::vector<double>& cache)
const
1890 auto const n_integration_points =
1895 Eigen::Matrix<double, GlobalDim, Eigen::Dynamic, Eigen::RowMajor>>(
1896 cache, GlobalDim, n_integration_points);
1903 .projected_specific_body_force_vectors[
_element.getID()];
1907 auto const& medium =
1909 auto const& phase = medium.phase(
"AqueousLiquid");
1913 .NsHigherOrder<
typename ShapeFunction::MeshElement>();
1915 for (
unsigned ip = 0; ip < n_integration_points; ++ip)
1917 auto const& ip_data =
_ip_data[ip];
1918 auto const& dNdx = ip_data.dNdx;
1919 auto const& N = Ns[ip];
1920 auto const& porosity = ip_data.porosity;
1922 double C_int_pt = 0.0;
1923 double p_int_pt = 0.0;
1924 double T_int_pt = 0.0;
1937 double const dt = std::numeric_limits<double>::quiet_NaN();
1942 .template value<double>(vars, pos, t, dt);
1945 cache_mat.col(ip).noalias() = -K_over_mu * dNdx * p_nodal_values;
1950 .template value<double>(vars, pos, t, dt);
1952 cache_mat.col(ip).noalias() += K_over_mu * rho_w * b;
1960 const unsigned integration_point)
const override
1962 auto const& N =
_process_data.shape_matrix_cache.NsHigherOrder<
1963 typename ShapeFunction::MeshElement>()[integration_point];
1966 return Eigen::Map<const Eigen::RowVectorXd>(N.data(), N.size());
1971 std::vector<double>
const& local_x)
const override
1973 auto const local_p = Eigen::Map<const NodalVectorType>(
1975 auto const local_C = Eigen::Map<const NodalVectorType>(
1981 auto const shape_matrices =
1985 std::array{pnt_local_coords})[0];
1991 .projected_specific_body_force_vectors[
_element.getID()];
1995 auto const& medium =
1997 auto const& phase = medium.phase(
"AqueousLiquid");
2010 double const dt = std::numeric_limits<double>::quiet_NaN();
2016 .template value<double>(vars, pos, t, dt);
2021 .template value<double>(vars, pos, t, dt);
2024 q += K_over_mu * rho_w * b;
2026 Eigen::Vector3d flux(0.0, 0.0, 0.0);
2027 flux.head<GlobalDim>() = rho_w * q;
2034 Eigen::VectorXd
const& local_x,
2035 Eigen::VectorXd
const& )
override
2037 auto const local_p =
2039 auto const local_C = local_x.template segment<concentration_size>(
2043 std::vector<double> ele_velocity;
2046 auto const n_integration_points =
2048 auto const ele_velocity_mat =
2051 auto const ele_id =
_element.getID();
2052 Eigen::Map<LocalVectorType>(
2055 ele_velocity_mat.rowwise().sum() / n_integration_points;
2059 std::size_t
const ele_id)
override
2061 auto const n_integration_points =
2066 auto const& medium = *
_process_data.media_map.getMedium(ele_id);
2070 ip_data.porosity = ip_data.porosity_prev;
2073 ->updatePorosityPostReaction(ip_data.chemical_system_id,
2074 medium, ip_data.porosity);
2079 [](
double const s,
auto const& ip)
2080 { return s + ip.porosity; }) /
2081 n_integration_points;
2084 std::vector<GlobalIndexType> chemical_system_indices;
2085 chemical_system_indices.reserve(n_integration_points);
2087 std::back_inserter(chemical_system_indices),
2088 [](
auto const& ip_data)
2089 { return ip_data.chemical_system_id; });
2091 _process_data.chemical_solver_interface->computeSecondaryVariable(
2092 ele_id, chemical_system_indices);
2096 const double t, std::vector<GlobalVector*>
const& x,
2097 std::vector<NumLib::LocalToGlobalIndexMap const*>
const& dof_tables,
2098 std::vector<double>& cache,
int const component_id)
const override
2100 std::vector<double> local_x_vec;
2102 auto const n_processes = x.size();
2103 for (std::size_t process_id = 0; process_id < n_processes; ++process_id)
2105 auto const indices =
2107 assert(!indices.empty());
2108 auto const local_solution = x[process_id]->get(indices);
2109 local_x_vec.insert(std::end(local_x_vec),
2110 std::begin(local_solution),
2111 std::end(local_solution));
2115 auto const p = local_x.template segment<pressure_size>(
pressure_index);
2116 auto const c = local_x.template segment<concentration_size>(
2119 auto const n_integration_points =
2124 Eigen::Matrix<double, GlobalDim, Eigen::Dynamic, Eigen::RowMajor>>(
2125 cache, GlobalDim, n_integration_points);
2132 .projected_specific_body_force_vectors[
_element.getID()];
2136 auto const& medium =
2138 auto const& phase = medium.phase(
"AqueousLiquid");
2140 auto const& component = phase.component(
2145 .NsHigherOrder<
typename ShapeFunction::MeshElement>();
2147 for (
unsigned ip = 0; ip < n_integration_points; ++ip)
2149 auto const& ip_data =
_ip_data[ip];
2150 auto const& dNdx = ip_data.dNdx;
2151 auto const& N = Ns[ip];
2152 auto const& phi = ip_data.porosity;
2154 double const p_ip = N.dot(p);
2155 double const c_ip = N.dot(c);
2161 double const dt = std::numeric_limits<double>::quiet_NaN();
2167 .template value<double>(vars, pos, t, dt);
2169 .template value<double>(vars, pos, t, dt);
2177 auto const alpha_T = medium.template value<double>(
2179 auto const alpha_L = medium.template value<double>(
2183 .value(vars, pos, t, dt));
2190 cache_mat.col(ip).noalias() = q * c_ip - D * dNdx * c;
2197 Eigen::VectorXd
const& ,
2198 double const ,
double const ,
2199 int const )
override
2201 unsigned const n_integration_points =
2204 for (
unsigned ip = 0; ip < n_integration_points; ip++)
2215 std::vector<std::reference_wrapper<ProcessVariable>>
const
2218 std::vector<IntegrationPointData<GlobalDimNodalMatrixType>>
_ip_data;
2222 const double fluid_density,
const double specific_heat_capacity_fluid,
2226 auto const& medium =
2228 auto const& solid_phase = medium.phase(
"Solid");
2230 auto const specific_heat_capacity_solid =
2234 .template value<double>(vars, pos, t, dt);
2236 auto const solid_density =
2238 .template value<double>(vars, pos, t, dt);
2240 return solid_density * specific_heat_capacity_solid * (1 - porosity) +
2241 fluid_density * specific_heat_capacity_fluid * porosity;
2246 const double fluid_density,
const double specific_heat_capacity_fluid,
2251 auto const& medium =
2254 auto thermal_conductivity =
2259 .value(vars, pos, t, dt));
2261 auto const thermal_dispersivity_transversal =
2264 thermal_transversal_dispersivity)
2265 .template value<double>();
2267 auto const thermal_dispersivity_longitudinal =
2270 thermal_longitudinal_dispersivity)
2271 .template value<double>();
2276 return thermal_conductivity +
2277 fluid_density * specific_heat_capacity_fluid *
2280 GlobalDimMatrixType::Zero(GlobalDim, GlobalDim),
2281 velocity, 0 , thermal_dispersivity_transversal,
2282 thermal_dispersivity_longitudinal);
2286 Eigen::VectorXd
const& local_x)
const
2293 local_T =
_process_data.temperature->getNodalValuesOnElement(
Interface for coupling OpenGeoSys with an external geochemical solver.
MathLib::EigenMatrix GlobalMatrix
MathLib::EigenVector GlobalVector
GlobalMatrix::IndexType GlobalIndexType
EigenFixedShapeMatrixPolicy< ShapeFunction, GlobalDim > ShapeMatrixPolicyType
double liquid_phase_pressure
int add(IndexType row, IndexType col, double val)
void add(IndexType rowId, double v)
add entry
std::size_t getID() const
Returns the ID of the element.
MathLib::RowColumnIndices< GlobalIndexType > RowColumnIndices
void setCoordinates(MathLib::Point3d const &coordinates)
void setElementID(std::size_t element_id)
virtual std::vector< double > const & getIntPtLiquidDensity(const double t, std::vector< GlobalVector * > const &x, std::vector< NumLib::LocalToGlobalIndexMap const * > const &dof_table, std::vector< double > &cache) const =0
virtual std::vector< double > const & getIntPtDarcyVelocity(const double t, std::vector< GlobalVector * > const &x, std::vector< NumLib::LocalToGlobalIndexMap const * > const &dof_table, std::vector< double > &cache) const =0
virtual void setChemicalSystemConcrete(Eigen::VectorXd const &, double const, double const)=0
virtual void postSpeciationCalculation(std::size_t const ele_id, double const t, double const dt)=0
virtual void computeReactionRelatedSecondaryVariable(std::size_t const ele_id)=0
virtual void setChemicalSystemID(std::size_t const)=0
void initializeChemicalSystem(std::size_t const mesh_item_id, std::vector< NumLib::LocalToGlobalIndexMap const * > const &dof_tables, std::vector< GlobalVector * > const &x, double const t)
void setChemicalSystem(std::size_t const mesh_item_id, std::vector< NumLib::LocalToGlobalIndexMap const * > const &dof_tables, std::vector< GlobalVector * > const &x, double const t, double const dt)
virtual void assembleReactionEquationConcrete(double const t, double const dt, Eigen::VectorXd const &local_x, std::vector< double > &local_M_data, std::vector< double > &local_K_data, std::vector< double > &local_b_data, int const transport_process_id)=0
void assembleReactionEquation(std::size_t const mesh_item_id, std::vector< NumLib::LocalToGlobalIndexMap const * > const &dof_tables, std::vector< GlobalVector * > const &x, double const t, double const dt, GlobalMatrix &M, GlobalMatrix &K, GlobalVector &b, int const process_id)
virtual void initializeChemicalSystemConcrete(Eigen::VectorXd const &, double const)=0
virtual std::vector< double > const & getIntPtMolarFlux(const double t, std::vector< GlobalVector * > const &x, std::vector< NumLib::LocalToGlobalIndexMap const * > const &dof_table, std::vector< double > &cache, int const component_id) const =0
ComponentTransportLocalAssemblerInterface()=default
NodalVectorType getLocalTemperature(double const t, Eigen::VectorXd const &local_x) const
typename ShapeMatricesType::GlobalDimVectorType GlobalDimVectorType
void assembleForStaggeredScheme(double const t, double const dt, Eigen::VectorXd const &local_x, Eigen::VectorXd const &local_x_prev, int const process_id, std::vector< double > &local_M_data, std::vector< double > &local_K_data, std::vector< double > &local_b_data) override
typename ShapeMatricesType::ShapeMatrices ShapeMatrices
MeshLib::Element const & _element
std::vector< double > const & getIntPtLiquidDensity(const double t, std::vector< GlobalVector * > const &x, std::vector< NumLib::LocalToGlobalIndexMap const * > const &dof_table, std::vector< double > &cache) const override
void assembleWithJacobianHydraulicEquation(double const t, double const dt, Eigen::VectorXd const &local_x, Eigen::VectorXd const &local_x_prev, std::vector< double > &local_b_data, std::vector< double > &local_Jac_data)
const int first_concentration_index
void assembleHeatTransportEquation(double const t, double const dt, Eigen::VectorXd const &local_x, Eigen::VectorXd const &, std::vector< double > &local_M_data, std::vector< double > &local_K_data, std::vector< double > &)
Eigen::Matrix< double, Eigen::Dynamic, Eigen::Dynamic, Eigen::RowMajor > LocalMatrixType
void postTimestepConcrete(Eigen::VectorXd const &, Eigen::VectorXd const &, double const, double const, int const) override
std::vector< double > const & getIntPtMolarFlux(const double t, std::vector< GlobalVector * > const &x, std::vector< NumLib::LocalToGlobalIndexMap const * > const &dof_tables, std::vector< double > &cache, int const component_id) const override
void postSpeciationCalculation(std::size_t const ele_id, double const t, double const dt) override
NumLib::GenericIntegrationMethod const & _integration_method
std::vector< double > const & calculateIntPtDarcyVelocity(const double t, Eigen::Ref< const NodalVectorType > const &p_nodal_values, Eigen::Ref< const NodalVectorType > const &C_nodal_values, Eigen::Ref< const NodalVectorType > const &T_nodal_values, std::vector< double > &cache) const
void initializeChemicalSystemConcrete(Eigen::VectorXd const &local_x, double const t) override
void computeReactionRelatedSecondaryVariable(std::size_t const ele_id) override
void assembleBlockMatrices(GlobalDimVectorType const &b, int const component_id, double const t, double const dt, Eigen::Ref< const NodalVectorType > const &C_nodal_values, Eigen::Ref< const NodalVectorType > const &p_nodal_values, Eigen::Ref< LocalBlockMatrixType > KCC, Eigen::Ref< LocalBlockMatrixType > MCC, Eigen::Ref< LocalBlockMatrixType > MCp, Eigen::Ref< LocalBlockMatrixType > MpC, Eigen::Ref< LocalBlockMatrixType > Kpp, Eigen::Ref< LocalBlockMatrixType > Mpp, Eigen::Ref< LocalSegmentVectorType > Bp)
typename ShapeMatricesType::template MatrixType< pressure_size, pressure_size > LocalBlockMatrixType
typename ShapeMatricesType::GlobalDimMatrixType GlobalDimMatrixType
void assembleWithJacobianForStaggeredScheme(double const t, double const dt, Eigen::VectorXd const &local_x, Eigen::VectorXd const &local_x_prev, int const process_id, std::vector< double > &local_b_data, std::vector< double > &local_Jac_data) override
static const int temperature_size
std::vector< IntegrationPointData< GlobalDimNodalMatrixType > > _ip_data
ComponentTransportProcessData const & _process_data
Eigen::Map< const Eigen::RowVectorXd > getShapeMatrix(const unsigned integration_point) const override
Provides the shape matrix at the given integration point.
ShapeMatrixPolicyType< ShapeFunction, GlobalDim > ShapeMatricesType
void computeSecondaryVariableConcrete(double const t, double const, Eigen::VectorXd const &local_x, Eigen::VectorXd const &) override
std::vector< std::reference_wrapper< ProcessVariable > > const _transport_process_variables
void assembleHydraulicEquation(double const t, double const dt, Eigen::VectorXd const &local_x, Eigen::VectorXd const &local_x_prev, std::vector< double > &local_M_data, std::vector< double > &local_K_data, std::vector< double > &local_b_data)
typename ShapeMatricesType::GlobalDimNodalMatrixType GlobalDimNodalMatrixType
typename ShapeMatricesType::NodalRowVectorType NodalRowVectorType
std::vector< double > const & getIntPtDarcyVelocity(const double t, std::vector< GlobalVector * > const &x, std::vector< NumLib::LocalToGlobalIndexMap const * > const &dof_table, std::vector< double > &cache) const override
const int temperature_index
static const int concentration_size
void assembleComponentTransportEquation(double const t, double const dt, Eigen::VectorXd const &local_x, Eigen::VectorXd const &local_x_prev, std::vector< double > &local_M_data, std::vector< double > &local_K_data, std::vector< double > &, int const transport_process_id)
std::vector< double > const & calculateIntPtLiquidDensity(const double t, Eigen::Ref< const NodalVectorType > const &p_nodal_values, Eigen::Ref< const NodalVectorType > const &C_nodal_values, Eigen::Ref< const NodalVectorType > const &T_nodal_values, std::vector< double > &cache) const
Eigen::Vector3d getFlux(MathLib::Point3d const &pnt_local_coords, double const t, std::vector< double > const &local_x) const override
GlobalDimMatrixType getThermalConductivityDispersivity(MaterialPropertyLib::VariableArray const &vars, const double fluid_density, const double specific_heat_capacity_fluid, const GlobalDimVectorType &velocity, ParameterLib::SpatialPosition const &pos, double const t, double const dt)
void assemble(double const t, double const dt, std::vector< double > const &local_x, std::vector< double > const &, std::vector< double > &local_M_data, std::vector< double > &local_K_data, std::vector< double > &local_b_data) override
void assembleWithJacobianComponentTransportEquation(double const t, double const dt, Eigen::VectorXd const &local_x, Eigen::VectorXd const &local_x_prev, std::vector< double > &local_b_data, std::vector< double > &local_Jac_data, int const component_id)
Eigen::Matrix< double, Eigen::Dynamic, 1 > LocalVectorType
static const int pressure_size
double getHeatEnergyCoefficient(MaterialPropertyLib::VariableArray const &vars, const double porosity, const double fluid_density, const double specific_heat_capacity_fluid, ParameterLib::SpatialPosition const &pos, double const t, double const dt)
void assembleReactionEquationConcrete(double const t, double const dt, Eigen::VectorXd const &local_x, std::vector< double > &local_M_data, std::vector< double > &local_K_data, std::vector< double > &local_b_data, int const transport_process_id) override
LocalAssemblerData(MeshLib::Element const &element, std::size_t const local_matrix_size, NumLib::GenericIntegrationMethod const &integration_method, bool is_axially_symmetric, ComponentTransportProcessData const &process_data, std::vector< std::reference_wrapper< ProcessVariable > > const &transport_process_variables)
typename ShapeMatricesType::template VectorType< pressure_size > LocalSegmentVectorType
void assembleKCmCn(int const component_id, double const t, double const dt, Eigen::Ref< LocalBlockMatrixType > KCmCn, double const stoichiometric_coefficient, double const kinetic_prefactor)
static const int pressure_index
void setChemicalSystemConcrete(Eigen::VectorXd const &local_x, double const t, double dt) override
void setChemicalSystemID(std::size_t const) override
typename ShapeMatricesType::NodalVectorType NodalVectorType
constexpr Eigen::Matrix< double, GlobalDim, GlobalDim > formEigenTensor(MaterialPropertyLib::PropertyDataType const &values)
@ longitudinal_dispersivity
used to compute the hydrodynamic dispersion tensor.
@ transversal_dispersivity
used to compute the hydrodynamic dispersion tensor.
@ retardation_factor
specify retardation factor used in component transport process.
Eigen::Map< Vector > createZeroedVector(std::vector< double > &data, Eigen::VectorXd::Index size)
Eigen::Map< const Vector > toVector(std::vector< double > const &data, Eigen::VectorXd::Index size)
Creates an Eigen mapped vector from the given data vector.
Eigen::Map< Matrix > createZeroedMatrix(std::vector< double > &data, Eigen::MatrixXd::Index rows, Eigen::MatrixXd::Index cols)
Eigen::Map< const Matrix > toMatrix(std::vector< double > const &data, Eigen::MatrixXd::Index rows, Eigen::MatrixXd::Index cols)
void shapeFunctionInterpolate(const NodalValues &, const ShapeMatrix &)
void assembleAdvectionMatrix(IPData const &ip_data_vector, NumLib::ShapeMatrixCache const &shape_matrix_cache, std::vector< FluxVectorType > const &ip_flux_vector, Eigen::MatrixBase< Derived > &laplacian_matrix)
std::vector< GlobalIndexType > getIndices(std::size_t const mesh_item_id, NumLib::LocalToGlobalIndexMap const &dof_table)
std::vector< typename ShapeMatricesType::ShapeMatrices, Eigen::aligned_allocator< typename ShapeMatricesType::ShapeMatrices > > initShapeMatrices(MeshLib::Element const &e, bool const is_axially_symmetric, IntegrationMethod const &integration_method)
std::vector< typename ShapeMatricesType::ShapeMatrices, Eigen::aligned_allocator< typename ShapeMatricesType::ShapeMatrices > > computeShapeMatrices(MeshLib::Element const &e, bool const is_axially_symmetric, PointContainer const &points)
Eigen::MatrixXd computeHydrodynamicDispersion(NumericalStabilization const &stabilizer, std::size_t const element_id, Eigen::MatrixXd const &pore_diffusion_coefficient, Eigen::VectorXd const &velocity, double const porosity, double const solute_dispersivity_transverse, double const solute_dispersivity_longitudinal)
std::array< double, 3 > interpolateCoordinates(MeshLib::Element const &e, typename ShapeMatricesType::ShapeMatrices::ShapeType const &N)
NumLib::ShapeMatrices< NodalRowVectorType, DimNodalMatrixType, DimMatrixType, GlobalDimNodalMatrixType > ShapeMatrices
MatrixType< GlobalDim, ShapeFunction::NPOINTS > GlobalDimNodalMatrixType
MatrixType< GlobalDim, GlobalDim > GlobalDimMatrixType
VectorType< GlobalDim > GlobalDimVectorType
VectorType< ShapeFunction::NPOINTS > NodalVectorType
RowVectorType< ShapeFunction::NPOINTS > NodalRowVectorType
GlobalIndexType chemical_system_id
EIGEN_MAKE_ALIGNED_OPERATOR_NEW
GlobalDimNodalMatrixType const dNdx
IntegrationPointData(GlobalDimNodalMatrixType const &dNdx_, double const &integration_weight_)
double const integration_weight