Abstract interface to define tolerance scheduler for the Newton iteration
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
real(kind=dp), | intent(out) | :: | tol |
Tolerance to be used |
||
real(kind=dp), | intent(in) | :: | target_tol |
Target tolerance |
||
real(kind=dp), | intent(in) | :: | rnorm |
Norm of the residual of the current iterate |
||
integer, | intent(in) | :: | iter |
Newton iteration count |
||
integer, | intent(out) | :: | info |
Information flag |
subroutine dynamic_tol_dp(tol, target_tol, rnorm, iter, info) !! Abstract interface to define tolerance scheduler for the Newton iteration real(dp), intent(out) :: tol !! Tolerance to be used real(dp), intent(in) :: target_tol !! Target tolerance real(dp), intent(in) :: rnorm !! Norm of the residual of the current iterate integer, intent(in) :: iter !! Newton iteration count integer, intent(out) :: info !! Information flag ! internals real(dp) :: tol_old character(len=256) :: msg tol_old = tol tol = max(0.1*rnorm, target_tol) if (tol /= tol_old) then if (tol == target_tol) then write(msg,'(A,E9.2)') 'Solver tolerance set to input target. tol= ', tol else write(msg,'(A,E9.2)') 'Solver tolerance set to tol= ', tol end if call logger%log_information(msg, module=this_module, procedure='dynamic_tol_dp') end if return end subroutine dynamic_tol_dp