From 9cded34b2425d6320988a32e6986d0184e9c7932 Mon Sep 17 00:00:00 2001 From: Andreas Lauser <and@poware.org> Date: Tue, 14 Dec 2010 12:31:21 +0000 Subject: [PATCH] doc/flowchart: remove the gravest errors IMHO it still has some issues with consistency and the level of detail in some places... git-svn-id: svn://svn.iws.uni-stuttgart.de/DUMUX/dumux/trunk@4871 2fb0f335-1f38-0410-981e-8018bf24f1b0 --- doc/handbook/DumuxFlow.tex | 275 ++++++++++++++------------------ doc/handbook/dumux-handbook.tex | 2 +- 2 files changed, 120 insertions(+), 157 deletions(-) diff --git a/doc/handbook/DumuxFlow.tex b/doc/handbook/DumuxFlow.tex index 4d7df5e484..b3047158f0 100644 --- a/doc/handbook/DumuxFlow.tex +++ b/doc/handbook/DumuxFlow.tex @@ -27,27 +27,34 @@ This list shows the algorithmic outline of a typical \Dumux run employing a full \textbf{\numberThis{Element}{calc}} \hspace{0.01\textwidth} \\ \\ initialize \\ -\textbf{foreach} timestep\\ +\textbf{for each} time step\\ -\> prepare update\\ -\> \textbf{foreach} \textsc{Newton} step \\ +\> pre-process solution\\ +\> \textbf{for each} \textsc{Newton} iteration \\ -\> \> \textbf{foreach} element \\ +\> \> \textbf{for each} element \\ -\> \> \> calculate element residual \\ -\> \> \> calculate element \textit{Jacobian}\\ -\> \> \> assemble local resdidual into global residual \\ -\> \> \> assemble local \textit{Jacobian} into global \textit{Jacobian} matrix \\ +\> \> \> calculate element's local residual \\ +\> \> \> calculate element's local \textsc{Jacobian} \\ +\> \> \> add local resdidual to global residual vector \\ +\> \> \> add local \textsc{Jacobian} to global \textsc{Jacobian} matrix \\ -\> \> \textbf{endfor} \\ +\> \> \textbf{end for} \\ -\> \> solve linear system\\ -\> \> update solution\\ -\> \> check for \textsc{Newton} convergence\\ +\> \> solve linear system of equations\\ +\> \> update current iterative solution\\ +\> \> \textbf{if} converged \\ +\> \> \qquad stop \textsc{Newton} iteration\\ +\> \> \textbf{end if} \\ \> \textbf{endfor}\\ -\> adapt timestep, possibly redo with smaller stepsize\\ -\> write result\\ -\textbf{endfor}\\ +\> \textbf{if} converged \\ +\> \qquad post-process solution\\ +\> \qquad write result\\ +\> \qquad adapt timestep size \\ +\> \textbf{else if} not converged \\ +\> \qquad retry with half time step size\\ +\> \textbf{end if} \\ +\textbf{end for}\\ finalize\\ \end{tabbing} @@ -206,7 +213,7 @@ $\overrightarrow{ \begin{array}{l} $\overrightarrow{ \begin{array}{l} \textbf{\textcircled{\ref{prep}}} \rightarrow \textbf{\textcircled{\ref{elem}}}\\ \texttt{while(ctl.newtonProceed())}\\ - \textnormal{init: u} \rightarrow \textnormal{uOld, error} \rightarrow \textnormal{lasterror} + \textnormal{init: uCurrentIter, uLastIter} \leftarrow \textnormal{model.uCur()} \end{array} }$ } @@ -214,9 +221,9 @@ $\overrightarrow{ \begin{array}{l} \hline \textbf{\textcircled{\ref{elem}}}\verb+jacobianAsm.assemble()+ \\ \begin{scriptsize}linearize the problem: \end{scriptsize}\\ - \begin{scriptsize}collect this elements contribution to global jacobian and global residual\end{scriptsize}\\ + \begin{scriptsize}add all element contributions to global \textsc{Jacobian} and global residual\end{scriptsize}\\ \textbf{called by}: newtonmethod.hh\\ - \textbf{implemented in}: pdelabboxassembler.hh\\ + \textbf{implemented in}: boxassembler.hh\\ \hline \end{tabular} \nextline @@ -226,9 +233,9 @@ $\overrightarrow{ \begin{array}{l} \hline \textbf{\textcircled{\ref{elem}}}\verb+resetSystem_()+ \\ \begin{scriptsize}always set r.h.s. (i.e. residual) to 0\end{scriptsize}\\ - \begin{scriptsize}partially set jacbian to zero in case of partial reassembly\end{scriptsize}\\ - \textbf{called by}: pdelabboxassembler.hh\\ - \textbf{implemented in}: pdelabboxassembler.hh\\ + \begin{scriptsize}partially set \textsc{Jacobian} to zero in case of partial reassembly\end{scriptsize}\\ + \textbf{called by}: boxassembler.hh\\ + \textbf{implemented in}: boxassembler.hh\\ \hline \end{tabular} {\scriptsize$\overrightarrow{\begin{array}{l} @@ -239,9 +246,9 @@ $\overrightarrow{ \begin{array}{l} \begin{tabular}{|l|} \hline \textbf{\textcircled{\ref{calc}}}\verb+assembleElement_()+ \\ - \begin{scriptsize}call local jacobian and residual assembling\end{scriptsize}\\ - \textbf{called by}: pdelabboxassembler.hh\\ - \textbf{implemented in}: pdelabboxassembler.hh\\ + \begin{scriptsize}call local \textsc{Jacobian} and residual assembly\end{scriptsize}\\ + \textbf{called by}: boxassembler.hh\\ + \textbf{implemented in}: boxassembler.hh\\ \hline \end{tabular} \nextline @@ -254,10 +261,10 @@ $\overrightarrow{ \begin{array}{l} \hline \textbf{\textcircled{\ref{calc}}}\verb+model_().localJacobian().assemble()+ \\ \begin{scriptsize}set curr. element, update element's fin.vol.geom.\end{scriptsize}\\ - \begin{scriptsize}reset local jacobian to 0\end{scriptsize}\\ + \begin{scriptsize}reset local \textsc{Jacobian} to 0\end{scriptsize}\\ \begin{scriptsize}update types of boundaries on this element\end{scriptsize}\\ - \textbf{called by}: pdelabboxassembler.hh\\ - \textbf{implemented in}: boxjacobianpdelab.hh\\ + \textbf{called by}: boxassembler.hh\\ + \textbf{implemented in}: boxjacobian.hh\\ \hline \end{tabular} $\overrightarrow{ @@ -265,8 +272,8 @@ $\overrightarrow{ \begin{array}{l} \begin{tabular}{|l|} \hline \textbf{\textcircled{\ref{calc}}}\verb+prevVolVars_.update()+ \\ - \begin{scriptsize}calls model specific update of vars defined in the volume:\end{scriptsize}\\ - \begin{scriptsize}vars from \emph{previous timestep!!}\end{scriptsize}\\ + \begin{scriptsize}call model specific update of quantities defined for the volume:\end{scriptsize}\\ + \begin{scriptsize}variables for the \emph{previous timestep!!}\end{scriptsize}\\ \textbf{called by}: boxlocaljacobian.hh\\ \textbf{implemented in}: boxelementvolumevariables.hh\\ \hline @@ -277,7 +284,7 @@ $\overrightarrow{ \begin{array}{l} \begin{tabular}{||l||} \hline\hline \textbf{\textcircled{\ref{calc}}}\verb+update()+ \\ - \begin{scriptsize}updates all the variables defined in the volume\end{scriptsize}\\ + \begin{scriptsize}calculate all two-phase specific quantites defined in the volume\end{scriptsize}\\ \textbf{called by}: boxelementvolumevariables.hh\\ \textbf{implemented in}: 2pvolumevariables.hh\\ \hline\hline @@ -286,8 +293,8 @@ $\overrightarrow{ \begin{array}{l} }$ \begin{tabular}{||l||} \hline\hline - \textbf{\textcircled{\ref{calc}}}\verb+fluidstate_.update()+ \\ - \begin{scriptsize}calculates all secondary variables from the primary variables\end{scriptsize}\\ + \textbf{\textcircled{\ref{calc}}}\verb+fluidState_.update()+ \\ + \begin{scriptsize}calculate all required fluid properties from the primary variables\end{scriptsize}\\ \textbf{called by}: 2pvolumevariables.hh\\ \textbf{implemented in}: 2pfluidstate.hh\\ \hline\hline @@ -299,8 +306,8 @@ $\overrightarrow{ \begin{array}{l} \uwave{\mbox{\phantom{\textbf{\textcircled{\ref{calc}}}+ e.g: density\_ = Fluidsystem::phaseDensity()+ bissl}}} \\ \textbf{\textcircled{\ref{calc}}}\verb+ e.g: density_ = Fluidsystem::phaseDensity()+ \\ - \begin{scriptsize}The fluidsystem deals with all the compositional stuff: \end{scriptsize}\\ - \begin{scriptsize}calculating densities, diffusivities ... \end{scriptsize}\\ + \begin{scriptsize}The fluid system deals does the real work: \end{scriptsize}\\ + \begin{scriptsize}calculates densities, diffusivities ... \end{scriptsize}\\ \textbf{called by}: 2pfluidstate.hh\\ \textbf{implemented in}: 2p\_system.hh\\ \uwave{\mbox{\phantom{\textbf{\textcircled{\ref{calc}}}+ e.g: density\_ = Fluidsystem::phaseDensity()+ bissl}}} @@ -309,77 +316,68 @@ $\overrightarrow{ \begin{array}{l} $\overrightarrow{ }$ \begin{tabular}{|l|} - \hline +\uwave{\mbox{\phantom{\begin{scriptsize}call model specific update of quantities defined for the volume:\end{scriptsize}+ bissl}}} +\\ \textbf{\textcircled{\ref{calc}}}\verb+curVolVars_.update()+ \\ - \begin{scriptsize}calls model specific update of vars defined in the volume:\end{scriptsize}\\ - \begin{scriptsize}vars from \emph{current iteration step!!}\end{scriptsize}\\ + \begin{scriptsize}call model specific update of quantities defined for the volume:\end{scriptsize}\\ + \begin{scriptsize}variables for the \emph{current time step!!}\end{scriptsize}\\ \textbf{called by}: boxlocaljacobian.hh\\ \textbf{implemented in}: boxelementvolumevariables.hh\\ - \hline +\uwave{\mbox{\phantom{\begin{scriptsize}call model specific update of quantities defined for the volume:\end{scriptsize}+ bissl}}} +\\ \end{tabular} \nextline $\overrightarrow{ }$ - \begin{tabular}{||l||} - \hline\hline - \textbf{\textcircled{\ref{calc}}}\verb+update()+ \\ - \begin{scriptsize}updates all the variables defined in the volume\end{scriptsize}\\ - \textbf{called by}: boxelementvolumevariables.hh\\ - \textbf{implemented in}: 2pvolumevariables.hh\\ - \hline\hline - \end{tabular} - $\overrightarrow{ - }$ - \begin{tabular}{||l||} -\hline\hline - \textbf{\textcircled{\ref{calc}}}\verb+fluidstate_.update()+ \\ - \begin{scriptsize}calculates all secondary variables from the primary variables\end{scriptsize}\\ - \textbf{called by}: 2pvolumevariables.hh\\ - \textbf{implemented in}: 2pfluidstate.hh\\ -\hline\hline - \end{tabular} - \nextline - $\overrightarrow{ - }$ - \begin{tabular}{||l||} -\uwave{\mbox{\phantom{\textbf{\textcircled{\ref{calc}}}+ e.g: density\_ = Fluidsystem::phaseDensity()+ bissl}}} -\\ - \textbf{\textcircled{\ref{calc}}}\verb+ e.g: density_ = Fluidsystem::phaseDensity()+ \\ - \begin{scriptsize}The fluidsystem deals with all the compositional stuff: \end{scriptsize}\\ - \begin{scriptsize}calculating densities, diffusivities ... \end{scriptsize}\\ - \textbf{called by}: 2pfluidstate.hh\\ - \textbf{implemented in}: 2p\_system.hh\\ -\uwave{\mbox{\phantom{\textbf{\textcircled{\ref{calc}}}+ e.g: density\_ = Fluidsystem::phaseDensity()+ bissl}}} -\\ - \end{tabular} - $\overrightarrow{ - }$ \begin{tabular}{|l|} \hline \textbf{\textcircled{\ref{calc}}}\verb+localResidual().eval()+ \\ - \begin{scriptsize}the residual is calculated: see the next two stepstones\end{scriptsize}\\ + \begin{scriptsize}the element's local residual is calculated:\end{scriptsize}\\ + \begin{scriptsize}see the next two stepstones\end{scriptsize}\\ \textbf{called by}: boxlocaljacobian.hh\\ \textbf{implemented in}: boxlocalresidual.hh\\ \hline \end{tabular} -\nextline $\overrightarrow{ }$ \begin{tabular}{|l|} \hline \textbf{\textcircled{\ref{calc}}}\verb+asImp_().evalFluxes_()+ \\ - \begin{scriptsize}evaluate the fluxes going in the r.h.s / residual of the \textsc{Newton} scheme\end{scriptsize}\\ + \begin{scriptsize}evaluate the fluxes going into each finite volume\end{scriptsize}\\ \begin{scriptsize}how this is done is \fbox{\fbox{model specific}} (see below)\end{scriptsize}\\ \textbf{called by}: boxlocalresidual.hh\\ \textbf{implemented in}: boxlocalresidual.hh\\ \hline \end{tabular} +{\scriptsize$\overrightarrow{ + \textnormal{calculating the fluxes takes two more steps} +}$} + \begin{tabular}{||l||} + \hline\hline + \textbf{\textcircled{\ref{calc}}}\verb+FluxVariables vars()+ \\ + \begin{scriptsize}this a call to a constructor: \end{scriptsize}\\ + \begin{scriptsize}calculate the gradients and average the K\end{scriptsize}\\ + \textbf{called by}: 2plocalresidual.hh\\ + \textbf{implemented in}: 2pfluxvariables.hh\\ + \hline\hline + \end{tabular} +\nextline + $\overrightarrow{ + }$ + \begin{tabular}{||l||} + \hline\hline + \textbf{\textcircled{\ref{calc}}}\verb+computeAdvectiveFlux()+ (other models: also diffusive)\\ + \scriptsize{-all velocities are calculated}\\ + \textbf{called by}: 2plocalresidual.hh\\ + \textbf{implemented in}: 2plocalresidual.hh\\ + \hline\hline + \end{tabular} $\overrightarrow{ }$ \begin{tabular}{|l|} \hline \textbf{\textcircled{\ref{calc}}}\verb+asImp_().evalVolumeTerms_()+ \\ - \begin{scriptsize}evaluate the sources and storage going in the r.h.s / residual of the \textsc{Newton} scheme\end{scriptsize}\\ + \begin{scriptsize}evaluate the storage and source terms for each finite volume\end{scriptsize}\\ \begin{scriptsize}how this is done is \fbox{\fbox{model specific}} (see below)\end{scriptsize}\\ \textbf{called by}: boxlocalresidual.hh\\ \textbf{implemented in}: boxlocalresidual.hh\\ @@ -391,7 +389,7 @@ $\overrightarrow{ \begin{array}{l} \begin{tabular}{|l|} \hline \textbf{\textcircled{\ref{calc}}}\verb+asImp_().evalBoundary_()+ \\ - \begin{scriptsize}deal with the different boundary conditions\end{scriptsize}\\ + \begin{scriptsize}deal with the boundary conditions\end{scriptsize}\\ \begin{scriptsize}may be \fbox{\fbox{model specific}}\end{scriptsize}\\ \textbf{called by}: boxlocalresidual.hh\\ \textbf{implemented in}: boxlocalresidual.hh (or modelspecific)\\ @@ -402,7 +400,7 @@ $\overrightarrow{ \begin{array}{l} \begin{tabular}{|l|} \hline \textbf{\textcircled{\ref{calc}}}\verb+asImp_().evalPartialDerivative()+ \\ - \begin{scriptsize}actually calculate the (local) Jacobian matrix\end{scriptsize}\\ + \begin{scriptsize}actually calculate the element's (local) \textsc{Jacobian} matrix\end{scriptsize}\\ \begin{scriptsize}a property chooses backward/central/foward differences\end{scriptsize}\\ \begin{scriptsize}here: central differences\end{scriptsize}\\ \textbf{called by}: boxlocaljacobian.hh\\ @@ -412,79 +410,37 @@ $\overrightarrow{ \begin{array}{l} \nextline $\overrightarrow{ }$ - \begin{minipage}{0.47\textwidth} - \begin{scriptsize}\textnormal{calculation of the Jacobian: numerical differentiation}\end{scriptsize}\\ - \begin{scriptsize}\textnormal{adding +/- eps to the old solution, dividing by 2eps}\end{scriptsize}\\ - \begin{scriptsize}\textnormal{the result is the (local) jacobian matrix}\end{scriptsize}\\ -\begin{scriptsize}\textnormal{(implementation-wise the jacobian is calculated recycling the code for the residual)}\end{scriptsize}\\ + \begin{minipage}{0.50\textwidth} + \begin{scriptsize}\textnormal{approximation of partial derivatives: numerical differentiation}\end{scriptsize}\\ + \begin{scriptsize}\textnormal{add $\pm \epsilon$ solution, divide difference of residual by $2\epsilon$}\end{scriptsize}\\ + \begin{scriptsize}\textnormal{all partial derivatives for the element are local \textsc{Jacobian} matrix}\end{scriptsize}\\ $\left \lbrace \begin{tabular}{l}%these question marks are for the \verb, not meant as ``unclear'' \verb?priVars[pvIdx]+=eps?\\ \begin{scriptsize}\textnormal{this is adding eps to the current solution}\end{scriptsize}\\ \verb?curVolVars_[scvIdx].update(+eps)?\\ + \begin{scriptsize}\textnormal{recalculate volume variables, having $\epsilon$ added}\end{scriptsize}\\ \verb?localResidual().eval(+eps)?\\ - \begin{scriptsize}\textnormal{recalculate terms, having eps added}\end{scriptsize}\\ - {\scriptsize $\left. \begin{array}{l} + \begin{scriptsize}\textnormal{calculate local residual for modified solution as before: involves}\end{scriptsize}\\ + {\scriptsize $\begin{array}{l} \textnormal{- \textbf{computeFlux}}\\ \textnormal{- \textbf{computeStorage}}\\ \textnormal{- \textbf{computeSource}} \\ - \end{array}\right\rbrace \overrightarrow{\phantom{a thing latex was not meant for...}} $} \\ + \end{array}$} \\ \verb?store the residual()?\\ - \verb?priVars[pvIdx]-=eps?\\ - \verb?update(-eps)? - \verb?recalc(-eps)? - \verb?construct jacobian from the two residuals: (+eps, -eps) /2 eps done? + \verb?repeat for priVars[pvIdx]-=eps?\\ + \verb?derivative is (residual(+eps) - residual(-eps))/2eps?\\ \end{tabular} \right . $\\ \end{minipage} -% $\overrightarrow{ -% }$ - \begin{minipage}{0.47\textwidth} - \begin{scriptsize}\textnormal{\bf \hspace*{0.042\textwidth}\textbf{Fluids} are actually flowing in here!!}\end{scriptsize}\\ - \begin{scriptsize}\textnormal{\bf \hspace*{0.042\textwidth}seriously: this is where \textbf{flow} is acutally simulated}\end{scriptsize}\\ - $\left\lbrace \left\lbrace - \begin{array}{l} - \textnormal{\textbf{called by}: boxlocaljacobian.hh}\\ - \textnormal{\textbf{implemented in}: 2pboxjacobian.hh} \\ - \textnormal{\textbf{\textcircled{\ref{calc}}}} \verb+computeStorage(dStorage_dt, i, false)+ \\ - \textnormal{\textbf{\textcircled{\ref{calc}}}} \verb+computeStorage(tmp, i, true)+ \\ - \textnormal{\begin{scriptsize}TIME DISCRETIZATION in implicit models: using bool for old or new time step\end{scriptsize}}\\ - \textnormal{\textbf{\textcircled{\ref{calc}}}} \verb+computeSource()+ \\ - \textnormal{\textbf{\textcircled{\ref{calc}}}} \verb+computeFlux()+ - \overrightarrow{\textnormal{\scriptsize{ \phantom{really: why oh why latex?}computing the fluxes is more complicated }}}\\ - \end{array} - \right. \right.$ -\end{minipage} -\nextline -{\scriptsize$\overrightarrow{ - \textnormal{calculating the fluxes takes two more steps} -}$} - \begin{tabular}{||l||} - \hline\hline - \textbf{\textcircled{\ref{calc}}}\verb+FluxVariables vars()+ \\ - \begin{scriptsize}this a call to a constructor: \end{scriptsize}\\ - \begin{scriptsize}calculate the gradients and average the K\end{scriptsize}\\ - \textbf{called by}: 2plocalresidual.hh\\ - \textbf{implemented in}: 2pfluxvariables.hh\\ - \hline\hline - \end{tabular} - $\overrightarrow{ - }$ - \begin{tabular}{||l||} - \hline\hline - \textbf{\textcircled{\ref{calc}}}\verb+computeAdvectiveFlux()+ (other models: also diffusive)\\ - \scriptsize{-all velocities are calculated}\\ - \textbf{called by}: 2plocalresidual.hh\\ - \textbf{implemented in}: 2plocalresidual.hh\\ - \hline\hline - \end{tabular} - \nextline + \hspace{.25\textwidth} + {\scriptsize$\overrightarrow{}$ } $\left| \begin{array}{l} - \textnormal{current solution (of this iteration ) is now}\\ - \textnormal{``numerically differentiated''}\\ - \quad \rightarrow \textnormal{the Jacobian is calculated} + \textnormal{residual of the current solution is now}\\ + \textnormal{``numerically differentiated'', for the element i.e.}\\ + \textnormal{the local \textsc{Jacobian} matrix is calculated} \end{array} \right |$\\ \nextline @@ -494,9 +450,9 @@ $\left \lbrace \textbf{\textcircled{\ref{calc}}}\verb+assembleElement_()+ \\ \begin{scriptsize}The contribution of a single element is done.\end{scriptsize}\\ \begin{scriptsize}Now, it needs to be added to the global quantities:\end{scriptsize}\\ - \begin{scriptsize}Add to global residual and global jacobian.\end{scriptsize}\\ + \begin{scriptsize}Add to global residual and global \textsc{Jacobian}.\end{scriptsize}\\ \textbf{called by}: continuing in the function. \\ - \textbf{implemented in}: pdelabboxassembler.hh\\ + \textbf{implemented in}: boxassembler.hh\\ \hline \end{tabular} {\scriptsize$\overrightarrow{ @@ -510,7 +466,7 @@ $\left \lbrace \verb? model_().globalJacobian().resdidual(i)? \\ \begin{scriptsize}Add to global residual.\end{scriptsize}\\ \textbf{called by}: continuing in the function. \\ - \textbf{implemented in}: pdelabboxassembler.hh\\ + \textbf{implemented in}: boxassembler.hh\\ \hline \end{tabular} \nextline @@ -523,9 +479,9 @@ $\left \lbrace \hline \textbf{\textcircled{\ref{calc}}}\verb?(*matrix_)[globI][globJ] +=? \\ \verb? model_().localJacobian().mat(i,j)? \\ - \begin{scriptsize}Add to global jacobian.\end{scriptsize}\\ + \begin{scriptsize}Add to global \textsc{Jacobian}.\end{scriptsize}\\ \textbf{called by}: continuing in the function. \\ - \textbf{implemented in}: pdelabboxassembler.hh\\ + \textbf{implemented in}: boxassembler.hh\\ \hline \end{tabular} {\scriptsize$\overrightarrow{ @@ -537,9 +493,9 @@ $\left \lbrace \hline \textbf{\textcircled{\ref{elem}}}\verb?assemble()? \\ \begin{scriptsize}Assembling of elements to global quantities is done.\end{scriptsize}\\ - \begin{scriptsize}In case: print partial assembling stuff\end{scriptsize}\\ + %\begin{scriptsize}In case: print partial assembling stuff\end{scriptsize}\\ \textbf{called by}: continuing in the function. \\ - \textbf{implemented in}: pdelabboxassembler.hh\\ + \textbf{implemented in}: boxassembler.hh\\ \hline \end{tabular} \nextline @@ -565,8 +521,8 @@ $\left \lbrace \hline \textbf{\textcircled{\ref{elem}}}\verb?execute_() , newtonSolveLinear() ?\\ \begin{scriptsize}Ask the linear solver to solve the system.\end{scriptsize}\\ - \begin{scriptsize}i.e. : give jacobian(matrix), delta(u), r.h.s.(residual) to solver (well, newtoncontroller)\end{scriptsize}\\ - \begin{scriptsize}tricky: each \textsc{Newton}step has a linear solver step. \end{scriptsize}\\ + \begin{scriptsize}i.e. : give \textsc{Jacobian}(matrix), delta(x), r.h.s.(residual) to linear solver\end{scriptsize}\\ + \begin{scriptsize}tricky: each \textsc{Newton}step solves a linear system of equations. \end{scriptsize}\\ \textbf{called by}: continuing in the function. \\ \textbf{implemented in}: newtonmethod.hh\\ \hline @@ -589,7 +545,7 @@ $\left \lbrace \textbf{\textcircled{\ref{elem}}}\verb+solveLinear_()+\\ \verb+typedef Dune::PDELab::ISTLBackend_SEQ_BCGS_SSOR Solver;+\\ \begin{scriptsize}Selecting Solver (BiCGStab) and preconditioner (SSOR)\end{scriptsize}\\ - \begin{scriptsize}Instantiate solver object (set max \# iterations, verbosity)\end{scriptsize}\\ + \begin{scriptsize}Instantiate linear solver (set max \# iterations, verbosity)\end{scriptsize}\\ \textbf{called by}: newtoncontroller.hh\\ \textbf{implemented in}: newtoncontroller.hh\\ \hline @@ -600,7 +556,7 @@ $\left \lbrace \begin{tabular}{|l|} \hline \textbf{\textcircled{\ref{elem}}}\verb+solver.apply(A, x, bTmp, residReduction)+\\ - \begin{scriptsize}Finally handing Matrix, unknowns and r.h.s. to the solver backend.\end{scriptsize}\\ + \begin{scriptsize}Finally handing matrix, unknowns and r.h.s. to the solver backend.\end{scriptsize}\\ \begin{scriptsize}Preconditioning and solving the system. \end{scriptsize}\\ \textbf{called by}: newtoncontroller.hh\\ \textbf{implemented in}: istlsolverbackend.hh\\ @@ -622,10 +578,10 @@ $\left \lbrace \begin{tabular}{|l|} \hline \textbf{\textcircled{\ref{elem}}}\verb+newtonupdateRelError()+\\ - \begin{scriptsize}Calculate the error, finding out if we converged to a solution:\end{scriptsize}\\ - \begin{scriptsize}find the prim. var. that changed most between \end{scriptsize}\\ - \begin{scriptsize}\quad last(\verb+uOld+) and current (\verb+uNew+) iteration.\end{scriptsize}\\ - \begin{scriptsize}$\rightsquigarrow$Call this error.\end{scriptsize}\\ + \begin{scriptsize}calculate the \emph{relative error} between two iterations\end{scriptsize}\\ + \begin{scriptsize}\quad find the prim. var. that changed most between \end{scriptsize}\\ + \begin{scriptsize}\quad last(\verb+uLastIter+) and current (\verb+uCurrentIter+) \end{scriptsize}\\ + \begin{scriptsize}\quad \textsc{Newton} iteration.\end{scriptsize}\\ \textbf{called by}: newtoncontroller.hh\\ \textbf{implemented in}: newtoncontroller.hh\\ \hline @@ -649,7 +605,7 @@ $\left \lbrace \begin{tabular}{|l|} \hline \textbf{\textcircled{\ref{elem}}}\verb+ctl.newtonEndStep()+\\ - \begin{scriptsize}Increase counter \textsc{Newton} steps. \end{scriptsize}\\ + \begin{scriptsize}Increase counter for number of \textsc{Newton} steps. \end{scriptsize}\\ \begin{scriptsize}Print info. \end{scriptsize}\\ \textbf{called by}: newtonmethod.hh\\ \textbf{implemented in}: newtoncontroller.hh\\ @@ -657,14 +613,15 @@ $\left \lbrace \end{tabular} {\scriptsize$\overrightarrow {\begin{array}{l} - \textnormal{check in (while) whether \textsc{Newton} proceeds:}\\ - \textnormal{that is: check if the error is below tolerance or we had too many steps.}\\ + \textnormal{check in whether to do another \textsc{Newton} iteration:}\\ + \textnormal{that is: check if the error is below tolerance or}\\ + \textnormal{maximum number of iterations was reached.}\\ \end{array}} $} {\scriptsize$\overrightarrow{\begin{array}{l} \textbf{\textcircled{\ref{elem}}}\rightarrow\textbf{\textcircled{\ref{prep}}}\\ \textnormal{\textsc{Newton} done.}\\ - \textnormal{if failed $\rightsquigarrow$ halve timestep size, restart iteration} + \textnormal{if failed $\rightsquigarrow$ halve timestep size, restart loop} \end{array} }$} \nextline @@ -693,7 +650,8 @@ $\left \lbrace \begin{tabular}{|l|} \hline \textbf{\textcircled{\ref{prep}}}\verb+postTimeStep()+ \\ - \begin{scriptsize}Can be filled by the \fbox{\fbox{model}} e.g. calc global storage.\end{scriptsize}\\ + \begin{scriptsize}Give the \fbox{\fbox{problem}} the chance to\end{scriptsize}\\ + \begin{scriptsize}post-process the solution.\end{scriptsize}\\ \textbf{called by}: boxmodel.hh\\ \textbf{implemented in}: newtoncontroller.hh\\ \hline @@ -703,7 +661,7 @@ $\left \lbrace \begin{tabular}{|l|} \hline \textbf{\textcircled{\ref{prep}}}\verb+suggestTimestepSize()+ \\ - \begin{scriptsize}Determine new size of dt from \# \textsc{Newton} steps. \end{scriptsize}\\ + \begin{scriptsize}Determine new time step size from \# \textsc{Newton} steps. \end{scriptsize}\\ \textbf{called by}: timemanager.hh, boxproblem.hh\\ \textbf{implemented in}: newtoncontroller.hh\\ \hline @@ -740,3 +698,8 @@ $\left \lbrace \newpage % Original pagestyle (headings and footer) were switched off, in order to get mroe space for the flowchart. \pagestyle{scrheadings} + +%%% Local Variables: +%%% mode: latex +%%% TeX-master: "dumux-handbook" +%%% End: diff --git a/doc/handbook/dumux-handbook.tex b/doc/handbook/dumux-handbook.tex index 06d466394e..f43e4b41e4 100644 --- a/doc/handbook/dumux-handbook.tex +++ b/doc/handbook/dumux-handbook.tex @@ -21,7 +21,7 @@ \usepackage{rotating} \usepackage{subfig} -\usepackage{ulem} +\usepackage[normalem]{ulem} \usepackage{tabularx} \usepackage{graphics} \usepackage{pstricks} -- GitLab