Sundials Solver Options¶
Selecting Precision¶
Sundials can be built with different precisions (currently ‘single’ which maps to C ‘float’; ‘double’ (the default) which maps to C ‘double’; and ‘extended’ which maps to C ‘long double’), and scikits-odes-sundials supports using whichever precision Sundials is built with. To take advantage of this, you must first have sundials built and installed with the desired precision setting.
Once you have done this, build scikits-odes-sundials against this particular
version of sundials (see the main documentation for how to do this).
scikits-odes-sundials will automatically detect the precision, and store this in
a variable called
DTYPE
. DTYPE
should be accessed from
scikits_odes_sundials
(other modules may have DTYPE
defined, but scikits_odes_sundials
should be preferred). Additionally
scikits_odes_sundials.precision
contains the precision setting found
by scikits-odes.
To use DTYPE
, treat it as a numpy dtype; use it whenever you need to
create an array:
np.array([1,2,3], dtype=DTYPE)
or when using scalars:
DTYPE(0.1) * DTYPE(0.1)