Solver Options class

The Solver Options class, daecpp::SolverOptions, allows the user to redefine and fine-tune the DAE solver options. To do so, the user should create an object of the Solver Options class, update parameters of interest by accessing public variables (see example below), and then provide the updated object to the solver function solve.

The table below contains a complete list of all options accessible via the Solver Options class.

Solver options

Option Type Default Description
verbosity int verbosity::off Verbosity level. Can be verbosity::off (no output), verbosity::normal (prints basic information), or verbosity::extra (full output).
dt_init double 0.01 Initial time step. Should be relatively small because the first time step is always of first order.
dt_min double 1e-10 Minimum time step. If the solver has to reduce the time step below dt_min but still fails to converge, the simulation will stop.
dt_max double 1e10 Maximum time step. The solver will not increase the time step above dt_max.
atol double 1e-6 Absolute tolerance for the Newton algorithm
rtol double 1e-6 Relative tolerance for the Newton algorithm
max_err_abs double 1e100 Maximum absolute error. If the absolute error estimation exceeds max_err_abs, the Newton iterations will be considered as diverged.
BDF_order unsigned 4 Order of the BDF implicit numerical integration method: 1 - first order BDF, 2 - BDF-2, 3 - BDF-3, 4 - BDF-4
Newton_scheme unsigned 1 Non-linear solver algorithm:
0 - Classic Newton method (usually the most stable but the slowest),
1 (default) - Quasi-Newton method I (balanced with focus on stability, updates Jacobian and performs factorization every 2nd iteration),
2 - Quasi-Newton method II (balanced with focus on speed, updates Jacobian and performs factorization every 3rd iteration),
3 - Quasi-Newton method III (can be the fastest but less stable, may require tweaking the time step increase/decrease thresholds, updates Jacobian and performs factorization every 4th iteration).
is_mass_matrix_static bool false If true, the mass matrix will be updated only once (at the beginning of computation). Setting this option as true slightly speeds up the computation, but the mass matrix must be static (i.e., it must be independent on time).
max_Jacobian_updates int 8 Maximum number of the Jacobian matrix updates and factorizations per time step. If the algorithm fails to converge after max_Jacobian_updates Jacobian matrix updates and factorizations per time step, the Newton iterations will be considered as diverged. The solver will try to roll back and decrease the time step.
max_Newton_failed_attempts unsigned 3 If the Newton method fails to converge max_Newton_failed_attempts times in a row, the solver will try to update Jacobian matrix every single iteration next time step (for Quasi-Newton methods).
recover_from_linsolver_failure bool true If true, the solver will try to recover from the linear solver failure (e.g., on the matrix decomposition step) by rolling back and decreasing the time step.
dt_increase_threshold_delta int 0 Time step amplification threshold delta. Can be negative or positive integer number. The solver increases the time step if the number of successful Newton iterations per time step is less than the threshold.
Example: If the solver increases the time step too often, decrease the time step amplification threshold by setting dt_increase_threshold_delta to -1.
dt_decrease_threshold_delta int 0 Time step reduction threshold delta. Can be negative or positive integer number. The solver decreases the time step if the number of successful Newton iterations per time step is greater than the threshold.
Example: If the solver struggles to converge but keeps doing many Newton iterations without reducing the time step, decrease the time step reduction threshold by setting dt_decrease_threshold_delta to -1 (or -2 and less).
solution_variability_control bool true Turns ON/OFF solution variability control. Solution variability control tightens up the adaptive time stepping algorithm, and it is ON by default. Switching it OFF can lead to a significant speed boost for big systems, but it can also lead to instability.
variability_tolerance double 1e-4 Solution variability tolerance. Solution variability is the maximum relative change in the solution every time step. If the absolute value of the solution is very close to zero, the relative change can be very high, leading to unnecessary small time steps. To prevent this, the solver will ignore the values below the solution variability tolerance. Consider increasing variability tolerance if the solver reduces the time step too much.
variability_threshold_low double 0.15 Solution variability lower threshold. The higher the value, the more likely the time step can be increased. If the maximum relative change in the solution is above the lower threshold, the time step will not be increased.
variability_threshold_high double 0.5 Solution variability higher threshold. The higher the value, the less likely the time step will be reduced. If the maximum relative change in the solution is above the higher threshold, the time step will be reduced.
dt_increase_factor double 2.0 Time step amplification factor. If the solution is stable enough, the solver will increase the time step by a factor of dt_increase_factor.
dt_decrease_factor double 2.0 Time step reduction factor. If the solution is not stable enough, the solver will decrease the time step by a factor of dt_decrease_factor.
num_threads unsigned 1 Number of threads (not used yet)

In order to check the correctness of the user-defined solver options, the user can explicitly call the void check() const method from the daecpp::SolverOptions class. However, this function will be called automatically by the solver anyway. If one or more of the options are invalid, the check() method can throw an error or print a warning.

Example

By default, the solver does not print any information on the screen during the computation. Let’s increase the solver’s verbosity level and, for example, restrict the maximum time step to 10.0:

daecpp::SolverOptions opt; // Solver Options object with default options

opt.verbosity = daecpp::verbosity::extra; // To print computation time and other info
opt.dt_max = 10.0;                        // To restrict the maximum time step

Object opt is now ready to be passed to the solver.

daecpp::System class contains built-in daecpp::SolverOptions object. See Solving DAE system page for more information.