diff --git a/ProcessLib/VectorMatrixAssembler.cpp b/ProcessLib/VectorMatrixAssembler.cpp index a5c620aac3e82ba282346b9de68aa5535220515c..22496e33a2ea4b7f87c5d5444d2054d93687442f 100644 --- a/ProcessLib/VectorMatrixAssembler.cpp +++ b/ProcessLib/VectorMatrixAssembler.cpp @@ -96,7 +96,9 @@ void VectorMatrixAssembler::assembleWithJacobian( MathLib::toMatrix(_local_Jac_data, num_r_c, num_r_c); Jac.add(r_c_indices, local_Jac); } else { - OGS_FATAL("No Jacobian has been assembled!"); + OGS_FATAL( + "No Jacobian has been assembled! This might be due to programming " + "errors in the local assembler of the current process."); } } diff --git a/ProcessLib/VectorMatrixAssembler.h b/ProcessLib/VectorMatrixAssembler.h index 702907bcd999708dc5613ab7142f22d5718c6688..4f99a8d1b859b6869f5fcd5fb8632b6c9ee1f5db 100644 --- a/ProcessLib/VectorMatrixAssembler.h +++ b/ProcessLib/VectorMatrixAssembler.h @@ -23,18 +23,26 @@ namespace ProcessLib { class LocalAssemblerInterface; +//! Utility class used to assemble global matrices and vectors. +//! +//! The methods of this class get the global matrices and vectors as input and +//! pass only local data on to the local assemblers. class VectorMatrixAssembler final { public: - VectorMatrixAssembler( + explicit VectorMatrixAssembler( std::unique_ptr<AbstractJacobianAssembler>&& jacobian_assembler); + //! Assembles\c M, \c K, and \c b. + //! \remark Jacobian is not assembled here, see assembleWithJacobian(). void assemble(std::size_t const mesh_item_id, LocalAssemblerInterface& local_assembler, NumLib::LocalToGlobalIndexMap const& dof_table, double const t, GlobalVector const& x, GlobalMatrix& M, GlobalMatrix& K, GlobalVector& b); + //! Assembles \c M, \c K, \c b, and the Jacobian \c Jac of the residual. + //! \note The Jacobian must be assembled. void assembleWithJacobian(std::size_t const mesh_item_id, LocalAssemblerInterface& local_assembler, NumLib::LocalToGlobalIndexMap const& dof_table, @@ -45,11 +53,14 @@ public: GlobalMatrix& Jac); private: + // temporary data only stored here in order to avoid frequent memory + // reallocations. std::vector<double> _local_M_data; std::vector<double> _local_K_data; std::vector<double> _local_b_data; std::vector<double> _local_Jac_data; + //! Used to assemble the Jacobian. std::unique_ptr<AbstractJacobianAssembler> _jacobian_assembler; };