From 6b16713d274fb5f5d0bf994b3b1b7ae3e38736ef Mon Sep 17 00:00:00 2001 From: Matteo Cusini <49037133+CusiniM@users.noreply.github.com> Date: Mon, 26 Aug 2024 17:48:11 -0700 Subject: [PATCH] feat: add log at the end of the timestep with substeps info. (#3303) --- .../physicsSolvers/SolverBase.cpp | 27 +++++++++++++++++++ .../physicsSolvers/SolverBase.hpp | 4 +++ 2 files changed, 31 insertions(+) diff --git a/src/coreComponents/physicsSolvers/SolverBase.cpp b/src/coreComponents/physicsSolvers/SolverBase.cpp index e970c3a76e..1f94367496 100644 --- a/src/coreComponents/physicsSolvers/SolverBase.cpp +++ b/src/coreComponents/physicsSolvers/SolverBase.cpp @@ -21,6 +21,7 @@ #include "mesh/DomainPartition.hpp" #include "math/interpolation/Interpolation.hpp" #include "common/Timer.hpp" +#include "common/Units.hpp" #if defined(GEOS_USE_PYGEOSX) #include "python/PySolverType.hpp" @@ -251,6 +252,10 @@ bool SolverBase::execute( real64 const time_n, integer const maxSubSteps = m_nonlinearSolverParameters.m_maxSubSteps; + // Keep track of substeps. It is useful to output these. + std::vector< real64 > subStepDt( maxSubSteps, 0.0 ); + integer numOfSubSteps = 0; + for( integer subStep = 0; subStep < maxSubSteps && dtRemaining > 0.0; ++subStep ) { // reset number of nonlinear and linear iterations @@ -260,6 +265,8 @@ bool SolverBase::execute( real64 const time_n, nextDt, cycleNumber, domain ); + numOfSubSteps++; + subStepDt[subStep] = dtAccepted; // increment the cumulative number of nonlinear and linear iterations m_solverStatistics.saveTimeStepStatistics(); @@ -304,9 +311,29 @@ bool SolverBase::execute( real64 const time_n, // Decide what to do with the next Dt for the event running the solver. m_nextDt = setNextDt( nextDt, domain ); + logEndOfCycleInformation( cycleNumber, numOfSubSteps, subStepDt ); + return false; } +void SolverBase::logEndOfCycleInformation( integer const cycleNumber, + integer const numOfSubSteps, + std::vector< real64 > const & subStepDt ) const +{ + // The formating here is a work in progress. + GEOS_LOG_RANK_0( "\n------------------------- TIMESTEP END -------------------------" ); + GEOS_LOG_RANK_0( GEOS_FMT( " - Cycle: {}", cycleNumber ) ); + GEOS_LOG_RANK_0( GEOS_FMT( " - N substeps: {}", numOfSubSteps ) ); + std::string logMessage = " - dt:"; + for( integer i = 0; i < numOfSubSteps; ++i ) + { + logMessage += " " + units::TimeFormatInfo::fromSeconds( subStepDt[i] ).toString(); + } + // Log the complete message once + GEOS_LOG_RANK_0( logMessage ); + GEOS_LOG_RANK_0( "------------------------------------------------------------------\n" ); +} + real64 SolverBase::setNextDt( real64 const & currentDt, DomainPartition & domain ) { diff --git a/src/coreComponents/physicsSolvers/SolverBase.hpp b/src/coreComponents/physicsSolvers/SolverBase.hpp index b2f9b45d81..c135f3fda8 100644 --- a/src/coreComponents/physicsSolvers/SolverBase.hpp +++ b/src/coreComponents/physicsSolvers/SolverBase.hpp @@ -845,6 +845,10 @@ class SolverBase : public ExecutableGroup integer const cycleNumber, DomainPartition & domain ); + void logEndOfCycleInformation( integer const cycleNumber, + integer const numOfSubSteps, + std::vector< real64 > const & subStepDt ) const; + }; template< typename CONSTITUTIVE_BASE_TYPE >