diff --git a/.doctrees/environment.pickle b/.doctrees/environment.pickle
index ce6c026342..e39163acfa 100644
Binary files a/.doctrees/environment.pickle and b/.doctrees/environment.pickle differ
diff --git a/.doctrees/projects/Hamiltonian.doctree b/.doctrees/projects/Hamiltonian.doctree
index 3bb59c7c0e..c38fed2850 100644
Binary files a/.doctrees/projects/Hamiltonian.doctree and b/.doctrees/projects/Hamiltonian.doctree differ
diff --git a/.doctrees/projects/doc_fput.doctree b/.doctrees/projects/doc_fput.doctree
index a14264dd3c..03c684229e 100644
Binary files a/.doctrees/projects/doc_fput.doctree and b/.doctrees/projects/doc_fput.doctree differ
diff --git a/.doctrees/projects/parallelSDC_reloaded.doctree b/.doctrees/projects/parallelSDC_reloaded.doctree
index dc6392d06b..c037ebb651 100644
Binary files a/.doctrees/projects/parallelSDC_reloaded.doctree and b/.doctrees/projects/parallelSDC_reloaded.doctree differ
diff --git a/.doctrees/pySDC/helpers.doctree b/.doctrees/pySDC/helpers.doctree
index b28ef8c5d1..5c07d0f468 100644
Binary files a/.doctrees/pySDC/helpers.doctree and b/.doctrees/pySDC/helpers.doctree differ
diff --git a/.doctrees/pySDC/helpers.spectral_helper.doctree b/.doctrees/pySDC/helpers.spectral_helper.doctree
new file mode 100644
index 0000000000..be388f77c4
Binary files /dev/null and b/.doctrees/pySDC/helpers.spectral_helper.doctree differ
diff --git a/.doctrees/pySDC/implementations.problem_classes.Burgers.doctree b/.doctrees/pySDC/implementations.problem_classes.Burgers.doctree
new file mode 100644
index 0000000000..2467577d76
Binary files /dev/null and b/.doctrees/pySDC/implementations.problem_classes.Burgers.doctree differ
diff --git a/.doctrees/pySDC/implementations.problem_classes.HeatEquation_Chebychev.doctree b/.doctrees/pySDC/implementations.problem_classes.HeatEquation_Chebychev.doctree
new file mode 100644
index 0000000000..a6df21a0a6
Binary files /dev/null and b/.doctrees/pySDC/implementations.problem_classes.HeatEquation_Chebychev.doctree differ
diff --git a/.doctrees/pySDC/implementations.problem_classes.RayleighBenard.doctree b/.doctrees/pySDC/implementations.problem_classes.RayleighBenard.doctree
new file mode 100644
index 0000000000..4639efec43
Binary files /dev/null and b/.doctrees/pySDC/implementations.problem_classes.RayleighBenard.doctree differ
diff --git a/.doctrees/pySDC/implementations.problem_classes.doctree b/.doctrees/pySDC/implementations.problem_classes.doctree
index aa28e90506..e1a5dadb85 100644
Binary files a/.doctrees/pySDC/implementations.problem_classes.doctree and b/.doctrees/pySDC/implementations.problem_classes.doctree differ
diff --git a/.doctrees/pySDC/implementations.problem_classes.generic_spectral.doctree b/.doctrees/pySDC/implementations.problem_classes.generic_spectral.doctree
new file mode 100644
index 0000000000..3e3d5d4841
Binary files /dev/null and b/.doctrees/pySDC/implementations.problem_classes.generic_spectral.doctree differ
diff --git a/.doctrees/tutorial/doc_step_2_C.doctree b/.doctrees/tutorial/doc_step_2_C.doctree
index bff1ea6f75..39e321ee71 100644
Binary files a/.doctrees/tutorial/doc_step_2_C.doctree and b/.doctrees/tutorial/doc_step_2_C.doctree differ
diff --git a/.doctrees/tutorial/doc_step_3_B.doctree b/.doctrees/tutorial/doc_step_3_B.doctree
index 38a6ce65f9..ea82e91637 100644
Binary files a/.doctrees/tutorial/doc_step_3_B.doctree and b/.doctrees/tutorial/doc_step_3_B.doctree differ
diff --git a/.doctrees/tutorial/doc_step_4_D.doctree b/.doctrees/tutorial/doc_step_4_D.doctree
index 5044636127..45ee975f15 100644
Binary files a/.doctrees/tutorial/doc_step_4_D.doctree and b/.doctrees/tutorial/doc_step_4_D.doctree differ
diff --git a/.doctrees/tutorial/doc_step_7_A.doctree b/.doctrees/tutorial/doc_step_7_A.doctree
index 51f9032504..eddbe77bc7 100644
Binary files a/.doctrees/tutorial/doc_step_7_A.doctree and b/.doctrees/tutorial/doc_step_7_A.doctree differ
diff --git a/.doctrees/tutorial/doc_step_7_B.doctree b/.doctrees/tutorial/doc_step_7_B.doctree
index 39f329f9e6..af68052b9c 100644
Binary files a/.doctrees/tutorial/doc_step_7_B.doctree and b/.doctrees/tutorial/doc_step_7_B.doctree differ
diff --git a/.doctrees/tutorial/doc_step_7_C.doctree b/.doctrees/tutorial/doc_step_7_C.doctree
index 44521058f3..b8f4ad11f8 100644
Binary files a/.doctrees/tutorial/doc_step_7_C.doctree and b/.doctrees/tutorial/doc_step_7_C.doctree differ
diff --git a/.doctrees/tutorial/doc_step_7_D.doctree b/.doctrees/tutorial/doc_step_7_D.doctree
index 11816a7efa..32f3f68fb2 100644
Binary files a/.doctrees/tutorial/doc_step_7_D.doctree and b/.doctrees/tutorial/doc_step_7_D.doctree differ
diff --git a/.doctrees/tutorial/doc_step_8_C.doctree b/.doctrees/tutorial/doc_step_8_C.doctree
index ce12ed14f0..c8c8603ee5 100644
Binary files a/.doctrees/tutorial/doc_step_8_C.doctree and b/.doctrees/tutorial/doc_step_8_C.doctree differ
diff --git a/.doctrees/tutorial/step_2.doctree b/.doctrees/tutorial/step_2.doctree
index 4fa64e7b0d..a1c572dfe5 100644
Binary files a/.doctrees/tutorial/step_2.doctree and b/.doctrees/tutorial/step_2.doctree differ
diff --git a/.doctrees/tutorial/step_3.doctree b/.doctrees/tutorial/step_3.doctree
index 683c7ce698..41d427aa13 100644
Binary files a/.doctrees/tutorial/step_3.doctree and b/.doctrees/tutorial/step_3.doctree differ
diff --git a/.doctrees/tutorial/step_4.doctree b/.doctrees/tutorial/step_4.doctree
index 810053bab7..0841637a9d 100644
Binary files a/.doctrees/tutorial/step_4.doctree and b/.doctrees/tutorial/step_4.doctree differ
diff --git a/.doctrees/tutorial/step_7.doctree b/.doctrees/tutorial/step_7.doctree
index 8587814f2a..01ccc1f4f0 100644
Binary files a/.doctrees/tutorial/step_7.doctree and b/.doctrees/tutorial/step_7.doctree differ
diff --git a/.doctrees/tutorial/step_8.doctree b/.doctrees/tutorial/step_8.doctree
index 5ed3e570c6..a81dadd110 100644
Binary files a/.doctrees/tutorial/step_8.doctree and b/.doctrees/tutorial/step_8.doctree differ
diff --git a/_images/coverage-badge.svg b/_images/coverage-badge.svg
index 5cb6ec5c45..69273e9c6e 100644
--- a/_images/coverage-badge.svg
+++ b/_images/coverage-badge.svg
@@ -1 +1 @@
-coverage: 78.12% coverage coverage 78.12% 78.12%
\ No newline at end of file
+coverage: 78.61% coverage coverage 78.61% 78.61%
\ No newline at end of file
diff --git a/_images/step_1_accuracy_test_coll.png b/_images/step_1_accuracy_test_coll.png
index 8f118fc936..8adcff1b94 100644
Binary files a/_images/step_1_accuracy_test_coll.png and b/_images/step_1_accuracy_test_coll.png differ
diff --git a/_images/step_1_accuracy_test_space.png b/_images/step_1_accuracy_test_space.png
index bae03de510..f605236af5 100644
Binary files a/_images/step_1_accuracy_test_space.png and b/_images/step_1_accuracy_test_space.png differ
diff --git a/_images/step_8_residuals.png b/_images/step_8_residuals.png
index 987a06ff27..83d660178c 100644
Binary files a/_images/step_8_residuals.png and b/_images/step_8_residuals.png differ
diff --git a/_images/step_8_residuals_mssdc_gs.png b/_images/step_8_residuals_mssdc_gs.png
index 6df97ccbbe..dda914b05c 100644
Binary files a/_images/step_8_residuals_mssdc_gs.png and b/_images/step_8_residuals_mssdc_gs.png differ
diff --git a/_images/step_8_residuals_mssdc_jac.png b/_images/step_8_residuals_mssdc_jac.png
index 6c848f7f91..a75b4d0290 100644
Binary files a/_images/step_8_residuals_mssdc_jac.png and b/_images/step_8_residuals_mssdc_jac.png differ
diff --git a/_images/timings_SDC_variants_Fisher.png b/_images/timings_SDC_variants_Fisher.png
index 95ec13e9ad..25196d2683 100644
Binary files a/_images/timings_SDC_variants_Fisher.png and b/_images/timings_SDC_variants_Fisher.png differ
diff --git a/_images/timings_SDC_variants_GrayScott.png b/_images/timings_SDC_variants_GrayScott.png
index 75e54843ca..4c23b2d382 100644
Binary files a/_images/timings_SDC_variants_GrayScott.png and b/_images/timings_SDC_variants_GrayScott.png differ
diff --git a/_modules/core/controller.html b/_modules/core/controller.html
index 2ac57a03ac..d1d51b5e8b 100644
--- a/_modules/core/controller.html
+++ b/_modules/core/controller.html
@@ -88,7 +88,7 @@
user_hooks = controller_params . get ( 'hook_class' , [])
hook_classes += user_hooks if type ( user_hooks ) == list else [ user_hooks ]
[ self . add_hook ( hook ) for hook in hook_classes ]
- controller_params [ 'hook_class' ] = controller_params . get ( 'hook_class' , hook_classes )
+ controller_params [ 'hook_class' ] = hook_classes
for hook in self . hooks :
hook . pre_setup ( step = None , level_number = None )
diff --git a/_modules/helpers/spectral_helper.html b/_modules/helpers/spectral_helper.html
new file mode 100644
index 0000000000..6a7bacae7f
--- /dev/null
+++ b/_modules/helpers/spectral_helper.html
@@ -0,0 +1,2337 @@
+
+
+
+
+
+
+ helpers.spectral_helper — pySDC 5.5.1 documentation
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Source code for helpers.spectral_helper
+import numpy as np
+import scipy
+from pySDC.implementations.datatype_classes.mesh import mesh
+from scipy.special import factorial
+
+
+
+
[docs]
+
class SpectralHelper1D :
+
"""
+
Abstract base class for 1D spectral discretizations. Defines a common interface with parameters and functions that
+
all bases need to have.
+
+
When implementing new bases, please take care to use the modules that are supplied as class attributes to enable
+
the code for GPUs.
+
+
Attributes:
+
N (int): Resolution
+
x0 (float): Coordinate of left boundary
+
x1 (float): Coordinate of right boundary
+
L (float): Length of the domain
+
useGPU (bool): Whether to use GPUs
+
+
"""
+
+
fft_lib = scipy . fft
+
sparse_lib = scipy . sparse
+
linalg = scipy . sparse . linalg
+
xp = np
+
+
def __init__ ( self , N , x0 = None , x1 = None , useGPU = False ):
+
"""
+
Constructor
+
+
Args:
+
N (int): Resolution
+
x0 (float): Coordinate of left boundary
+
x1 (float): Coordinate of right boundary
+
useGPU (bool): Whether to use GPUs
+
"""
+
self . N = N
+
self . x0 = x0
+
self . x1 = x1
+
self . L = x1 - x0
+
self . useGPU = useGPU
+
+
if useGPU :
+
self . setup_GPU ()
+
+
+
[docs]
+
@classmethod
+
def setup_GPU ( cls ):
+
"""switch to GPU modules"""
+
import cupy as cp
+
import cupyx.scipy.sparse as sparse_lib
+
import cupyx.scipy.sparse.linalg as linalg
+
import cupyx.scipy.fft as fft_lib
+
from pySDC.implementations.datatype_classes.cupy_mesh import cupy_mesh
+
+
cls . xp = cp
+
cls . sparse_lib = sparse_lib
+
cls . linalg = linalg
+
cls . fft_lib = fft_lib
+
+
+
+
[docs]
+
def get_Id ( self ):
+
"""
+
Get identity matrix
+
+
Returns:
+
sparse diagonal identity matrix
+
"""
+
return self . sparse_lib . eye ( self . N )
+
+
+
+
[docs]
+
def get_zero ( self ):
+
"""
+
Get a matrix with all zeros of the correct size.
+
+
Returns:
+
sparse matrix with zeros everywhere
+
"""
+
return 0 * self . get_Id ()
+
+
+
+
[docs]
+
def get_differentiation_matrix ( self ):
+
raise NotImplementedError ()
+
+
+
+
[docs]
+
def get_integration_matrix ( self ):
+
raise NotImplementedError ()
+
+
+
+
[docs]
+
def get_wavenumbers ( self ):
+
"""
+
Get the grid in spectral space
+
"""
+
raise NotImplementedError
+
+
+
+
[docs]
+
def get_empty_operator_matrix ( self , S , O ):
+
"""
+
Return a matrix of operators to be filled with the connections between the solution components.
+
+
Args:
+
S (int): Number of components in the solution
+
O (sparse matrix): Zero matrix used for initialization
+
+
Returns:
+
list of lists containing sparse zeros
+
"""
+
return [[ O for _ in range ( S )] for _ in range ( S )]
+
+
+
+
[docs]
+
def get_basis_change_matrix ( self , * args , ** kwargs ):
+
"""
+
Some spectral discretization change the basis during differentiation. This method can be used to transfer
+
between the various bases.
+
+
This method accepts arbitrary arguments that may not be used in order to provide an easy interface for multi-
+
dimensional bases. For instance, you may combine an FFT discretization with an ultraspherical discretization.
+
The FFT discretization will always be in the same base, but the ultraspherical discretization uses a different
+
base for every derivative. You can then ask all bases for transfer matrices from one ultraspherical derivative
+
base to the next. The FFT discretization will ignore this and return an identity while the ultraspherical
+
discretization will return the desired matrix. After a Kronecker product, you get the 2D version of the matrix
+
you want. This is what the `SpectralHelper` does when you call the method of the same name on it.
+
+
Returns:
+
sparse bases change matrix
+
"""
+
return self . sparse_lib . eye ( self . N )
+
+
+
+
[docs]
+
def get_BC ( self , kind ):
+
"""
+
To facilitate boundary conditions (BCs) we use either a basis where all functions satisfy the BCs automatically,
+
as is the case in FFT basis for periodic BCs, or boundary bordering. In boundary bordering, specific lines in
+
the matrix are replaced by the boundary conditions as obtained by this method.
+
+
Args:
+
kind (str): The type of BC you want to implement please refer to the implementations of this method in the
+
individual 1D bases for what is implemented
+
+
Returns:
+
self.xp.array: Boundary condition
+
"""
+
raise NotImplementedError ( f 'No boundary conditions of { kind =!r} implemented!' )
+
+
+
+
[docs]
+
def get_filter_matrix ( self , kmin = 0 , kmax = None ):
+
"""
+
Get a bandpass filter.
+
+
Args:
+
kmin (int): Lower limit of the bandpass filter
+
kmax (int): Upper limit of the bandpass filter
+
+
Returns:
+
sparse matrix
+
"""
+
+
k = abs ( self . get_wavenumbers ())
+
+
kmax = max ( k ) if kmax is None else kmax
+
+
mask = self . xp . logical_or ( k >= kmax , k < kmin )
+
+
if self . useGPU :
+
Id = self . get_Id () . get ()
+
else :
+
Id = self . get_Id ()
+
F = Id . tolil ()
+
F [:, mask ] = 0
+
return F . tocsc ()
+
+
+
+
[docs]
+
def get_1dgrid ( self ):
+
"""
+
Get the grid in physical space
+
+
Returns:
+
self.xp.array: Grid
+
"""
+
raise NotImplementedError
+
+
+
+
+
+
[docs]
+
class ChebychevHelper ( SpectralHelper1D ):
+
"""
+
The Chebychev base consists of special kinds of polynomials, with the main advantage that you can easily transform
+
between physical and spectral space by discrete cosine transform.
+
The differentiation in the Chebychev T base is dense, but can be preconditioned to yield a differentiation operator
+
that moves to Chebychev U basis during differentiation, which is sparse. When using this technique, problems need to
+
be formulated in first order formulation.
+
+
This implementation is largely based on the Dedalus paper (arXiv:1905.10388).
+
"""
+
+
def __init__ ( self , * args , transform_type = 'fft' , x0 =- 1 , x1 = 1 , ** kwargs ):
+
"""
+
Constructor.
+
Please refer to the parent class for additional arguments. Notably, you have to supply a resolution `N` and you
+
may choose to run on GPUs via the `useGPU` argument.
+
+
Args:
+
transform_type ('fft' or 'dct'): Either use DCT functions directly implemented in the transform library or
+
use the FFT from the library to compute the DCT
+
x0 (float): Coordinate of left boundary. Note that only -1 is currently implented
+
x1 (float): Coordinate of right boundary. Note that only +1 is currently implented
+
"""
+
assert x0 == - 1
+
assert x1 == 1
+
super () . __init__ ( * args , x0 = x0 , x1 = x1 , ** kwargs )
+
self . transform_type = transform_type
+
+
if self . transform_type == 'fft' :
+
self . get_fft_utils ()
+
+
self . cache = {}
+
self . norm = self . get_norm ()
+
+
+
[docs]
+
def get_1dgrid ( self ):
+
'''
+
Generates a 1D grid with Chebychev points. These are clustered at the boundary. You need this kind of grid to
+
use discrete cosine transformation (DCT) to get the Chebychev representation. If you want a different grid, you
+
need to do an affine transformation before any Chebychev business.
+
+
Returns:
+
numpy.ndarray: 1D grid
+
'''
+
return self . xp . cos ( np . pi / self . N * ( self . xp . arange ( self . N ) + 0.5 ))
+
+
+
+
[docs]
+
def get_wavenumbers ( self ):
+
"""Get the domain in spectral space"""
+
return self . xp . arange ( self . N )
+
+
+
+
[docs]
+
def get_conv ( self , name , N = None ):
+
'''
+
Get conversion matrix between different kinds of polynomials. The supported kinds are
+
- T: Chebychev polynomials of first kind
+
- U: Chebychev polynomials of second kind
+
- D: Dirichlet recombination.
+
+
You get the desired matrix by choosing a name as ``A2B``. I.e. ``T2U`` for the conversion matrix from T to U.
+
Once generates matrices are cached. So feel free to call the method as often as you like.
+
+
Args:
+
name (str): Conversion code, e.g. 'T2U'
+
N (int): Size of the matrix (optional)
+
+
Returns:
+
scipy.sparse: Sparse conversion matrix
+
'''
+
if name in self . cache . keys () and not N :
+
return self . cache [ name ]
+
+
N = N if N else self . N
+
sp = self . sparse_lib
+
xp = self . xp
+
+
def get_forward_conv ( name ):
+
if name == 'T2U' :
+
mat = ( sp . eye ( N ) - sp . diags ( xp . ones ( N - 2 ), offsets =+ 2 )) / 2.0
+
mat [:, 0 ] *= 2
+
elif name == 'D2T' :
+
mat = sp . eye ( N ) - sp . diags ( xp . ones ( N - 2 ), offsets =+ 2 )
+
elif name [ 0 ] == name [ - 1 ]:
+
mat = self . sparse_lib . eye ( self . N )
+
else :
+
raise NotImplementedError ( f 'Don \' t have conversion matrix { name !r} ' )
+
return mat
+
+
try :
+
mat = get_forward_conv ( name )
+
except NotImplementedError as E :
+
try :
+
fwd = get_forward_conv ( name [:: - 1 ])
+
import scipy.sparse as sp
+
+
if self . sparse_lib == sp :
+
mat = self . sparse_lib . linalg . inv ( fwd . tocsc ())
+
else :
+
mat = self . sparse_lib . csc_matrix ( sp . linalg . inv ( fwd . tocsc () . get ()))
+
except NotImplementedError :
+
raise NotImplementedError from E
+
+
self . cache [ name ] = mat
+
return mat
+
+
+
+
[docs]
+
def get_basis_change_matrix ( self , conv = 'T2T' , ** kwargs ):
+
"""
+
As the differentiation matrix in Chebychev-T base is dense but is sparse when simultaneously changing base to
+
Chebychev-U, you may need a basis change matrix to transfer the other matrices as well. This function returns a
+
conversion matrix from `ChebychevHelper.get_conv`. Not that `**kwargs` are used to absorb arguments for other
+
bases, see documentation of `SpectralHelper1D.get_basis_change_matrix`.
+
+
Args:
+
conv (str): Conversion code, i.e. T2U
+
+
Returns:
+
Sparse conversion matrix
+
"""
+
return self . get_conv ( conv )
+
+
+
+
[docs]
+
def get_integration_matrix ( self , lbnd = 0 ):
+
"""
+
Get matrix for integration
+
+
Args:
+
lbnd (float): Lower bound for integration, only 0 is currently implemented
+
+
Returns:
+
Sparse integration matrix
+
"""
+
S = self . sparse_lib . diags ( 1 / ( self . xp . arange ( self . N - 1 ) + 1 ), offsets =- 1 ) @ self . get_conv ( 'T2U' )
+
n = self . xp . arange ( self . N )
+
if lbnd == 0 :
+
S = S . tocsc ()
+
S [ 0 , 1 :: 2 ] = (
+
( n / ( 2 * ( self . xp . arange ( self . N ) + 1 )))[ 1 :: 2 ]
+
* ( - 1 ) ** ( self . xp . arange ( self . N // 2 ))
+
/ ( np . append ([ 1 ], self . xp . arange ( self . N // 2 - 1 ) + 1 ))
+
)
+
else :
+
raise NotImplementedError ( f 'This function allows to integrate only from x=0, you attempted from x= { lbnd } .' )
+
return S
+
+
+
+
[docs]
+
def get_differentiation_matrix ( self , p = 1 ):
+
'''
+
Keep in mind that the T2T differentiation matrix is dense.
+
+
Args:
+
p (int): Derivative you want to compute
+
+
Returns:
+
numpy.ndarray: Differentiation matrix
+
'''
+
D = self . xp . zeros (( self . N , self . N ))
+
for j in range ( self . N ):
+
for k in range ( j ):
+
D [ k , j ] = 2 * j * (( j - k ) % 2 )
+
+
D [ 0 , :] /= 2
+
return self . sparse_lib . csc_matrix ( self . xp . linalg . matrix_power ( D , p ))
+
+
+
+
[docs]
+
def get_norm ( self , N = None ):
+
'''
+
Get normalization for converting Chebychev coefficients and DCT
+
+
Args:
+
N (int, optional): Resolution
+
+
Returns:
+
self.xp.array: Normalization
+
'''
+
N = self . N if N is None else N
+
norm = self . xp . ones ( N ) / N
+
norm [ 0 ] /= 2
+
return norm
+
+
+
+
[docs]
+
def get_fft_shuffle ( self , forward , N ):
+
"""
+
In order to more easily parallelize using distributed FFT libraries, we express the DCT via an FFT following
+
doi.org/10.1109/TASSP.1980.1163351. The idea is based on reshuffling the data to be periodic and rotating it
+
in the complex plane. This function returns a mask to do the shuffling.
+
+
Args:
+
forward (bool): Whether you want the shuffle for forward transform or backward transform
+
N (int): size of the grid
+
+
Returns:
+
self.xp.array: Use as mask
+
"""
+
xp = self . xp
+
if forward :
+
return xp . append ( xp . arange (( N + 1 ) // 2 ) * 2 , - xp . arange ( N // 2 ) * 2 - 1 - N % 2 )
+
else :
+
mask = xp . zeros ( N , dtype = int )
+
mask [: N - N % 2 : 2 ] = xp . arange ( N // 2 )
+
mask [ 1 :: 2 ] = N - xp . arange ( N // 2 ) - 1
+
mask [ - 1 ] = N // 2
+
return mask
+
+
+
+
[docs]
+
def get_fft_shift ( self , forward , N ):
+
"""
+
As described in the docstring for `get_fft_shuffle`, we need to rotate in the complex plane in order to use FFT for DCT.
+
+
Args:
+
forward (bool): Whether you want the rotation for forward transform or backward transform
+
N (int): size of the grid
+
+
Returns:
+
self.xp.array: Rotation
+
"""
+
k = self . get_wavenumbers ()
+
norm = self . get_norm ()
+
xp = self . xp
+
if forward :
+
return 2 * xp . exp ( - 1 j * np . pi * k / ( 2 * N ) + 0 j * np . pi / 4 ) * norm
+
else :
+
shift = xp . exp ( 1 j * np . pi * k / ( 2 * N ))
+
shift [ 0 ] = 0.5
+
return shift / norm
+
+
+
+
[docs]
+
def get_fft_utils ( self ):
+
"""
+
Get the required utilities for using FFT to do DCT as described in the docstring for `get_fft_shuffle` and keep
+
them cached.
+
"""
+
self . fft_utils = {
+
'fwd' : {},
+
'bck' : {},
+
}
+
+
# forwards transform
+
self . fft_utils [ 'fwd' ][ 'shuffle' ] = self . get_fft_shuffle ( True , self . N )
+
self . fft_utils [ 'fwd' ][ 'shift' ] = self . get_fft_shift ( True , self . N )
+
+
# backwards transform
+
self . fft_utils [ 'bck' ][ 'shuffle' ] = self . get_fft_shuffle ( False , self . N )
+
self . fft_utils [ 'bck' ][ 'shift' ] = self . get_fft_shift ( False , self . N )
+
+
return self . fft_utils
+
+
+
+
+
+
+
+
+
+
[docs]
+
def get_BC ( self , kind , ** kwargs ):
+
"""
+
Get boundary condition row for boundary bordering. `kwargs` will be passed on to implementations of the BC of
+
the kind you choose. Specifically, `x` for `'dirichlet'` boundary condition, which is the coordinate at which to
+
set the BC.
+
+
Args:
+
kind ('integral' or 'dirichlet'): Kind of boundary condition you want
+
"""
+
if kind . lower () == 'integral' :
+
return self . get_integ_BC_row ( ** kwargs )
+
elif kind . lower () == 'dirichlet' :
+
return self . get_Dirichlet_BC_row ( ** kwargs )
+
else :
+
return super () . get_BC ( kind )
+
+
+
+
[docs]
+
def get_integ_BC_row ( self ):
+
"""
+
Get a row for generating integral BCs with T polynomials.
+
It returns the values of the integrals of T polynomials over the entire interval.
+
+
Returns:
+
self.xp.ndarray: Row to put into a matrix
+
"""
+
n = self . xp . arange ( self . N ) + 1
+
me = self . xp . zeros_like ( n ) . astype ( float )
+
me [ 2 :] = (( - 1 ) ** n [ 1 : - 1 ] + 1 ) / ( 1 - n [ 1 : - 1 ] ** 2 )
+
me [ 0 ] = 2.0
+
return me
+
+
+
+
[docs]
+
def get_Dirichlet_BC_row ( self , x ):
+
"""
+
Get a row for generating Dirichlet BCs at x with T polynomials.
+
It returns the values of the T polynomials at x.
+
+
Args:
+
x (float): Position of the boundary condition
+
+
Returns:
+
self.xp.ndarray: Row to put into a matrix
+
"""
+
if x == - 1 :
+
return ( - 1 ) ** self . xp . arange ( self . N )
+
elif x == 1 :
+
return self . xp . ones ( self . N )
+
elif x == 0 :
+
n = ( 1 + ( - 1 ) ** self . xp . arange ( self . N )) / 2
+
n [ 2 :: 4 ] *= - 1
+
return n
+
else :
+
raise NotImplementedError ( f 'Don \' t know how to generate Dirichlet BC \' s at { x =} !' )
+
+
+
+
[docs]
+
def get_Dirichlet_recombination_matrix ( self ):
+
'''
+
Get matrix for Dirichlet recombination, which changes the basis to have sparse boundary conditions.
+
This makes for a good right preconditioner.
+
+
Returns:
+
scipy.sparse: Sparse conversion matrix
+
'''
+
N = self . N
+
sp = self . sparse_lib
+
xp = self . xp
+
+
return sp . eye ( N ) - sp . diags ( xp . ones ( N - 2 ), offsets =+ 2 )
+
+
+
+
+
+
[docs]
+
class UltrasphericalHelper ( ChebychevHelper ):
+
"""
+
This implementation follows https://doi.org/10.1137/120865458.
+
The ultraspherical method works in Chebychev polynomials as well, but also uses various Gegenbauer polynomials.
+
The idea is that for every derivative of Chebychev T polynomials, there is a basis of Gegenbauer polynomials where the differentiation matrix is a single off-diagonal.
+
There are also conversion operators from one derivative basis to the next that are sparse.
+
+
This basis is used like this: For every equation that you have, look for the highest derivative and bump all matrices to the correct basis. If your highest derivative is 2 and you have an identity, it needs to get bumped from 0 to 1 and from 1 to 2. If you have a first derivative as well, it needs to be bumped from 1 to 2.
+
You don't need the same resulting basis in all equations. You just need to take care that you translate the right hand side to the correct basis as well.
+
"""
+
+
+
[docs]
+
def get_differentiation_matrix ( self , p = 1 ):
+
"""
+
Notice that while sparse, this matrix is not diagonal, which means the inversion cannot be parallelized easily.
+
+
Args:
+
p (int): Order of the derivative
+
+
Returns:
+
sparse differentiation matrix
+
"""
+
sp = self . sparse_lib
+
xp = self . xp
+
N = self . N
+
l = p
+
return 2 ** ( l - 1 ) * factorial ( l - 1 ) * sp . diags ( xp . arange ( N - l ) + l , offsets = l )
+
+
+
+
[docs]
+
def get_S ( self , lmbda ):
+
"""
+
Get matrix for bumping the derivative base by one from lmbda to lmbda + 1. This is the same language as in
+
https://doi.org/10.1137/120865458.
+
+
Args:
+
lmbda (int): Ingoing derivative base
+
+
Returns:
+
sparse matrix: Conversion from derivative base lmbda to lmbda + 1
+
"""
+
N = self . N
+
+
if lmbda == 0 :
+
sp = scipy . sparse
+
mat = (( sp . eye ( N ) - sp . diags ( np . ones ( N - 2 ), offsets =+ 2 )) / 2.0 ) . tolil ()
+
mat [:, 0 ] *= 2
+
else :
+
sp = self . sparse_lib
+
xp = self . xp
+
mat = sp . diags ( lmbda / ( lmbda + xp . arange ( N ))) - sp . diags (
+
lmbda / ( lmbda + 2 + xp . arange ( N - 2 )), offsets =+ 2
+
)
+
+
return self . sparse_lib . csc_matrix ( mat )
+
+
+
+
[docs]
+
def get_basis_change_matrix ( self , p_in = 0 , p_out = 0 , ** kwargs ):
+
"""
+
Get a conversion matrix from derivative base `p_in` to `p_out`.
+
+
Args:
+
p_out (int): Resulting derivative base
+
p_in (int): Ingoing derivative base
+
"""
+
mat_fwd = self . sparse_lib . eye ( self . N )
+
for i in range ( min ([ p_in , p_out ]), max ([ p_in , p_out ])):
+
mat_fwd = self . get_S ( i ) @ mat_fwd
+
+
if p_out > p_in :
+
return mat_fwd
+
+
else :
+
# We have to invert the matrix on CPU because the GPU equivalent is not implemented in CuPy at the time of writing.
+
import scipy.sparse as sp
+
+
if self . useGPU :
+
mat_fwd = mat_fwd . get ()
+
+
mat_bck = sp . linalg . inv ( mat_fwd . tocsc ())
+
+
return self . sparse_lib . csc_matrix ( mat_bck )
+
+
+
+
[docs]
+
def get_integration_matrix ( self ):
+
"""
+
Get an integration matrix. Please use `UltrasphericalHelper.get_integration_constant` afterwards to compute the
+
integration constant such that integration starts from x=-1.
+
+
Example:
+
+
.. code-block:: python
+
+
import numpy as np
+
from pySDC.helpers.spectral_helper import UltrasphericalHelper
+
+
N = 4
+
helper = UltrasphericalHelper(N)
+
coeffs = np.random.random(N)
+
coeffs[-1] = 0
+
+
poly = np.polynomial.Chebyshev(coeffs)
+
+
S = helper.get_integration_matrix()
+
U_hat = S @ coeffs
+
U_hat[0] = helper.get_integration_constant(U_hat, axis=-1)
+
+
assert np.allclose(poly.integ(lbnd=-1).coef[:-1], U_hat)
+
+
Returns:
+
sparse integration matrix
+
"""
+
return self . sparse_lib . diags ( 1 / ( self . xp . arange ( self . N - 1 ) + 1 ), offsets =- 1 ) @ self . get_basis_change_matrix (
+
p_out = 1 , p_in = 0
+
)
+
+
+
+
[docs]
+
def get_integration_constant ( self , u_hat , axis ):
+
"""
+
Get integration constant for lower bound of -1. See documentation of `UltrasphericalHelper.get_integration_matrix` for details.
+
+
Args:
+
u_hat: Solution in spectral space
+
axis: Axis you want to integrate over
+
+
Returns:
+
Integration constant, has one less dimension than `u_hat`
+
"""
+
slices = [
+
None ,
+
] * u_hat . ndim
+
slices [ axis ] = slice ( 1 , u_hat . shape [ axis ])
+
return self . xp . sum ( u_hat [( * slices ,)] * ( - 1 ) ** ( self . xp . arange ( u_hat . shape [ axis ] - 1 )), axis = axis )
+
+
+
+
+
+
[docs]
+
class FFTHelper ( SpectralHelper1D ):
+
def __init__ ( self , * args , x0 = 0 , x1 = 2 * np . pi , ** kwargs ):
+
"""
+
Constructor.
+
Please refer to the parent class for additional arguments. Notably, you have to supply a resolution `N` and you
+
may choose to run on GPUs via the `useGPU` argument.
+
+
Args:
+
transform_type ('fft' or 'dct'): Either use DCT functions directly implemented in the transform library or
+
use the FFT from the library to compute the DCT
+
x0 (float, optional): Coordinate of left boundary
+
x1 (float, optional): Coordinate of right boundary
+
"""
+
super () . __init__ ( * args , x0 = x0 , x1 = x1 , ** kwargs )
+
+
+
[docs]
+
def get_1dgrid ( self ):
+
"""
+
We use equally spaced points including the left boundary and not including the right one, which is the left boundary.
+
"""
+
dx = self . L / self . N
+
return self . xp . arange ( self . N ) * dx + self . x0
+
+
+
+
[docs]
+
def get_wavenumbers ( self ):
+
"""
+
Be careful that this ordering is very unintuitive.
+
"""
+
return self . xp . fft . fftfreq ( self . N , 1.0 / self . N ) * 2 * np . pi / self . L
+
+
+
+
[docs]
+
def get_differentiation_matrix ( self , p = 1 ):
+
"""
+
This matrix is diagonal, allowing to invert concurrently.
+
+
Args:
+
p (int): Order of the derivative
+
+
Returns:
+
sparse differentiation matrix
+
"""
+
k = self . get_wavenumbers ()
+
+
if self . useGPU :
+
# Have to raise the matrix to power p on CPU because the GPU equivalent is not implemented in CuPy at the time of writing.
+
import scipy.sparse as sp
+
+
D = self . sparse_lib . diags ( 1 j * k ) . get ()
+
return self . sparse_lib . csc_matrix ( sp . linalg . matrix_power ( D , p ))
+
else :
+
return self . linalg . matrix_power ( self . sparse_lib . diags ( 1 j * k ), p )
+
+
+
+
[docs]
+
def get_integration_matrix ( self , p = 1 ):
+
"""
+
Get integration matrix to compute `p`-th integral over the entire domain.
+
+
Args:
+
p (int): Order of integral you want to compute
+
+
Returns:
+
sparse integration matrix
+
"""
+
k = self . xp . array ( self . get_wavenumbers (), dtype = 'complex128' )
+
k [ 0 ] = 1 j * self . L
+
return self . linalg . matrix_power ( self . sparse_lib . diags ( 1 / ( 1 j * k )), p )
+
+
+
+
+
+
+
+
+
+
[docs]
+
def get_BC ( self , kind ):
+
"""
+
Get a sort of boundary condition. You can use `kind=integral`, to fix the integral, or you can use `kind=Nyquist`.
+
The latter is not really a boundary condition, but is used to set the Nyquist mode to some value, preferably zero.
+
You should set the Nyquist mode zero when the solution in physical space is real and the resolution is even.
+
+
Args:
+
kind ('integral' or 'nyquist'): Kind of BC
+
+
Returns:
+
self.xp.ndarray: Boundary condition row
+
"""
+
if kind . lower () == 'integral' :
+
return self . get_integ_BC_row ()
+
elif kind . lower () == 'nyquist' :
+
assert (
+
self . N % 2 == 0
+
), f 'Do not eliminate the Nyquist mode with odd resolution as it is fully resolved. You chose { self . N } in this axis'
+
BC = self . xp . zeros ( self . N )
+
BC [ self . get_Nyquist_mode_index ()] = 1
+
return BC
+
else :
+
return super () . get_BC ( kind )
+
+
+
+
[docs]
+
def get_Nyquist_mode_index ( self ):
+
"""
+
Compute the index of the Nyquist mode, i.e. the mode with the lowest wavenumber, which doesn't have a positive
+
counterpart for even resolution. This means real waves of this wave number cannot be properly resolved and you
+
are best advised to set this mode zero if representing real functions on even-resolution grids is what you're
+
after.
+
+
Returns:
+
int: Index of the Nyquist mode
+
"""
+
k = self . get_wavenumbers ()
+
Nyquist_mode = min ( k )
+
return self . xp . where ( k == Nyquist_mode )[ 0 ][ 0 ]
+
+
+
+
[docs]
+
def get_integ_BC_row ( self ):
+
"""
+
Only the 0-mode has non-zero integral with FFT basis in periodic BCs
+
"""
+
me = self . xp . zeros ( self . N )
+
me [ 0 ] = self . L / self . N
+
return me
+
+
+
+
+
+
[docs]
+
class SpectralHelper :
+
"""
+
This class has three functions:
+
- Easily assemble matrices containing multiple equations
+
- Direct product of 1D bases to solve problems in more dimensions
+
- Distribute the FFTs to facilitate concurrency.
+
+
Attributes:
+
comm (mpi4py.Intracomm): MPI communicator
+
debug (bool): Perform additional checks at extra computational cost
+
useGPU (bool): Whether to use GPUs
+
axes (list): List of 1D bases
+
components (list): List of strings of the names of components in the equations
+
full_BCs (list): List of Dictionaries containing all information about the boundary conditions
+
BC_mat (list): List of lists of sparse matrices to put BCs into and eventually assemble the BC matrix from
+
BCs (sparse matrix): Matrix containing only the BCs
+
fft_cache (dict): Cache FFTs of various shapes here to facilitate padding and so on
+
BC_rhs_mask (self.xp.ndarray): Mask values that contain boundary conditions in the right hand side
+
BC_zero_index (self.xp.ndarray): Indeces of rows in the matrix that are replaced by BCs
+
BC_line_zero_matrix (sparse matrix): Matrix that zeros rows where we can then add the BCs in using `BCs`
+
rhs_BCs_hat (self.xp.ndarray): Boundary conditions in spectral space
+
global_shape (tuple): Global shape of the solution as in `mpi4py-fft`
+
local_slice (slice): Local slice of the solution as in `mpi4py-fft`
+
fft_obj: When using distributed FFTs, this will be a parallel transform object from `mpi4py-fft`
+
init (tuple): This is the same `init` that is used throughout the problem classes
+
init_forward (tuple): This is the equivalent of `init` in spectral space
+
"""
+
+
xp = np
+
fft_lib = scipy . fft
+
sparse_lib = scipy . sparse
+
linalg = scipy . sparse . linalg
+
dtype = mesh
+
fft_backend = 'fftw'
+
fft_comm_backend = 'MPI'
+
+
+
[docs]
+
@classmethod
+
def setup_GPU ( cls ):
+
"""switch to GPU modules"""
+
import cupy as cp
+
import cupyx.scipy.sparse as sparse_lib
+
import cupyx.scipy.sparse.linalg as linalg
+
from pySDC.implementations.datatype_classes.cupy_mesh import cupy_mesh
+
+
cls . xp = cp
+
cls . sparse_lib = sparse_lib
+
cls . linalg = linalg
+
+
cls . fft_backend = 'cupy'
+
cls . fft_comm_backend = 'NCCL'
+
+
cls . dtype = cupy_mesh
+
+
+
def __init__ ( self , comm = None , useGPU = False , debug = False ):
+
"""
+
Constructor
+
+
Args:
+
comm (mpi4py.Intracomm): MPI communicator
+
useGPU (bool): Whether to use GPUs
+
debug (bool): Perform additional checks at extra computational cost
+
"""
+
self . comm = comm
+
self . debug = debug
+
self . useGPU = useGPU
+
+
if useGPU :
+
self . setup_GPU ()
+
+
self . axes = []
+
self . components = []
+
+
self . full_BCs = []
+
self . BC_mat = None
+
self . BCs = None
+
+
self . fft_cache = {}
+
+
@property
+
def u_init ( self ):
+
"""
+
Get empty data container in physical space
+
"""
+
return self . dtype ( self . init )
+
+
@property
+
def u_init_forward ( self ):
+
"""
+
Get empty data container in spectral space
+
"""
+
return self . dtype ( self . init_forward )
+
+
@property
+
def shape ( self ):
+
"""
+
Get shape of individual solution component
+
"""
+
return self . init [ 0 ][ 1 :]
+
+
@property
+
def ndim ( self ):
+
return len ( self . axes )
+
+
@property
+
def ncomponents ( self ):
+
return len ( self . components )
+
+
@property
+
def V ( self ):
+
"""
+
Get domain volume
+
"""
+
return np . prod ([ me . L for me in self . axes ])
+
+
+
[docs]
+
def add_axis ( self , base , * args , ** kwargs ):
+
"""
+
Add an axis to the domain by deciding on suitable 1D base.
+
Arguments to the bases are forwarded using `*args` and `**kwargs`. Please refer to the documentation of the 1D
+
bases for possible arguments.
+
+
Args:
+
base (str): 1D spectral method
+
"""
+
kwargs [ 'useGPU' ] = self . useGPU
+
+
if base . lower () in [ 'chebychov' , 'chebychev' , 'cheby' , 'chebychovhelper' ]:
+
kwargs [ 'transform_type' ] = kwargs . get ( 'transform_type' , 'fft' )
+
self . axes . append ( ChebychevHelper ( * args , ** kwargs ))
+
elif base . lower () in [ 'fft' , 'fourier' , 'ffthelper' ]:
+
self . axes . append ( FFTHelper ( * args , ** kwargs ))
+
elif base . lower () in [ 'ultraspherical' , 'gegenbauer' ]:
+
self . axes . append ( UltrasphericalHelper ( * args , ** kwargs ))
+
else :
+
raise NotImplementedError ( f ' { base =!r} is not implemented!' )
+
self . axes [ - 1 ] . xp = self . xp
+
self . axes [ - 1 ] . sparse_lib = self . sparse_lib
+
+
+
+
[docs]
+
def add_component ( self , name ):
+
"""
+
Add solution component(s).
+
+
Args:
+
name (str or list of strings): Name(s) of component(s)
+
"""
+
if type ( name ) in [ list , tuple ]:
+
for me in name :
+
self . add_component ( me )
+
elif type ( name ) in [ str ]:
+
if name in self . components :
+
raise Exception ( f ' { name =!r} is already added to this problem!' )
+
self . components . append ( name )
+
else :
+
raise NotImplementedError
+
+
+
+
[docs]
+
def index ( self , name ):
+
"""
+
Get the index of component `name`.
+
+
Args:
+
name (str or list of strings): Name(s) of component(s)
+
+
Returns:
+
int: Index of the component
+
"""
+
if type ( name ) in [ str , int ]:
+
return self . components . index ( name )
+
elif type ( name ) in [ list , tuple ]:
+
return ( self . index ( me ) for me in name )
+
else :
+
raise NotImplementedError ( f 'Don \' t know how to compute index for { type ( name ) =} ' )
+
+
+
+
[docs]
+
def get_empty_operator_matrix ( self ):
+
"""
+
Return a matrix of operators to be filled with the connections between the solution components.
+
+
Returns:
+
list containing sparse zeros
+
"""
+
S = len ( self . components )
+
O = self . get_Id () * 0
+
return [[ O for _ in range ( S )] for _ in range ( S )]
+
+
+
+
[docs]
+
def get_BC ( self , axis , kind , line =- 1 , scalar = False , ** kwargs ):
+
"""
+
Use this method for boundary bordering. It gets the respective matrix row and embeds it into a matrix.
+
Pay attention that if you have multiple BCs in a single equation, you need to put them in different lines.
+
Typically, the last line that does not contain a BC is the best choice.
+
Forward arguments for the boundary conditions using `kwargs`. Refer to documentation of 1D bases for details.
+
+
Args:
+
axis (int): Axis you want to add the BC to
+
kind (str): kind of BC, e.g. Dirichlet
+
line (int): Line you want the BC to go in
+
scalar (bool): Put the BC in all space positions in the other direction
+
+
Returns:
+
sparse matrix containing the BC
+
"""
+
sp = scipy . sparse
+
+
base = self . axes [ axis ]
+
+
BC = sp . eye ( base . N ) . tolil () * 0
+
if self . useGPU :
+
BC [ line , :] = base . get_BC ( kind = kind , ** kwargs ) . get ()
+
else :
+
BC [ line , :] = base . get_BC ( kind = kind , ** kwargs )
+
+
ndim = len ( self . axes )
+
if ndim == 1 :
+
return self . sparse_lib . csc_matrix ( BC )
+
elif ndim == 2 :
+
axis2 = ( axis + 1 ) % ndim
+
+
if scalar :
+
_Id = self . sparse_lib . diags ( self . xp . append ([ 1 ], self . xp . zeros ( self . axes [ axis2 ] . N - 1 )))
+
else :
+
_Id = self . axes [ axis2 ] . get_Id ()
+
+
Id = self . get_local_slice_of_1D_matrix ( self . axes [ axis2 ] . get_Id () @ _Id , axis = axis2 )
+
+
if self . useGPU :
+
Id = Id . get ()
+
+
mats = [
+
None ,
+
] * ndim
+
mats [ axis ] = self . get_local_slice_of_1D_matrix ( BC , axis = axis )
+
mats [ axis2 ] = Id
+
return self . sparse_lib . csc_matrix ( sp . kron ( * mats ))
+
+
+
+
[docs]
+
def remove_BC ( self , component , equation , axis , kind , line =- 1 , scalar = False , ** kwargs ):
+
"""
+
Remove a BC from the matrix. This is useful e.g. when you add a non-scalar BC and then need to selectively
+
remove single BCs again, as in incompressible Navier-Stokes, for instance.
+
Forward arguments for the boundary conditions using `kwargs`. Refer to documentation of 1D bases for details.
+
+
Args:
+
component (str): Name of the component the BC should act on
+
equation (str): Name of the equation for the component you want to put the BC in
+
axis (int): Axis you want to add the BC to
+
kind (str): kind of BC, e.g. Dirichlet
+
v: Value of the BC
+
line (int): Line you want the BC to go in
+
scalar (bool): Put the BC in all space positions in the other direction
+
"""
+
_BC = self . get_BC ( axis = axis , kind = kind , line = line , scalar = scalar , ** kwargs )
+
self . BC_mat [ self . index ( equation )][ self . index ( component )] -= _BC
+
+
if scalar :
+
slices = [ self . index ( equation )] + [
+
0 ,
+
] * self . ndim
+
slices [ axis + 1 ] = line
+
else :
+
slices = (
+
[ self . index ( equation )]
+
+ [ slice ( 0 , self . init [ 0 ][ i + 1 ]) for i in range ( axis )]
+
+ [ line ]
+
+ [ slice ( 0 , self . init [ 0 ][ i + 1 ]) for i in range ( axis + 1 , len ( self . axes ))]
+
)
+
N = self . axes [ axis ] . N
+
if ( N + line ) % N in self . xp . arange ( N )[ self . local_slice [ axis ]]:
+
self . BC_rhs_mask [( * slices ,)] = False
+
+
+
+
[docs]
+
def add_BC ( self , component , equation , axis , kind , v , line =- 1 , scalar = False , ** kwargs ):
+
"""
+
Add a BC to the matrix. Note that you need to convert the list of lists of BCs that this method generates to a
+
single sparse matrix by calling `setup_BCs` after adding/removing all BCs.
+
Forward arguments for the boundary conditions using `kwargs`. Refer to documentation of 1D bases for details.
+
+
Args:
+
component (str): Name of the component the BC should act on
+
equation (str): Name of the equation for the component you want to put the BC in
+
axis (int): Axis you want to add the BC to
+
kind (str): kind of BC, e.g. Dirichlet
+
v: Value of the BC
+
line (int): Line you want the BC to go in
+
scalar (bool): Put the BC in all space positions in the other direction
+
"""
+
_BC = self . get_BC ( axis = axis , kind = kind , line = line , scalar = scalar , ** kwargs )
+
self . BC_mat [ self . index ( equation )][ self . index ( component )] += _BC
+
self . full_BCs += [
+
{
+
'component' : component ,
+
'equation' : equation ,
+
'axis' : axis ,
+
'kind' : kind ,
+
'v' : v ,
+
'line' : line ,
+
'scalar' : scalar ,
+
** kwargs ,
+
}
+
]
+
+
if scalar :
+
slices = [ self . index ( equation )] + [
+
0 ,
+
] * self . ndim
+
slices [ axis + 1 ] = line
+
if self . comm :
+
if self . comm . rank == 0 :
+
self . BC_rhs_mask [( * slices ,)] = True
+
else :
+
self . BC_rhs_mask [( * slices ,)] = True
+
else :
+
slices = (
+
[ self . index ( equation )]
+
+ [ slice ( 0 , self . init [ 0 ][ i + 1 ]) for i in range ( axis )]
+
+ [ line ]
+
+ [ slice ( 0 , self . init [ 0 ][ i + 1 ]) for i in range ( axis + 1 , len ( self . axes ))]
+
)
+
N = self . axes [ axis ] . N
+
if ( N + line ) % N in self . xp . arange ( N )[ self . local_slice [ axis ]]:
+
slices [ axis + 1 ] -= self . local_slice [ axis ] . start
+
self . BC_rhs_mask [( * slices ,)] = True
+
+
+
+
[docs]
+
def setup_BCs ( self ):
+
"""
+
Convert the list of lists of BCs to the boundary condition operator.
+
Also, boundary bordering requires to zero out all other entries in the matrix in rows containing a boundary
+
condition. This method sets up a suitable sparse matrix to do this.
+
"""
+
sp = self . sparse_lib
+
self . BCs = self . convert_operator_matrix_to_operator ( self . BC_mat )
+
self . BC_zero_index = self . xp . arange ( np . prod ( self . init [ 0 ]))[ self . BC_rhs_mask . flatten ()]
+
+
diags = self . xp . ones ( self . BCs . shape [ 0 ])
+
diags [ self . BC_zero_index ] = 0
+
self . BC_line_zero_matrix = sp . diags ( diags )
+
+
# prepare BCs in spectral space to easily add to the RHS
+
rhs_BCs = self . put_BCs_in_rhs ( self . u_init )
+
self . rhs_BCs_hat = self . transform ( rhs_BCs )
+
+
+
+
[docs]
+
def check_BCs ( self , u ):
+
"""
+
Check that the solution satisfies the boundary conditions
+
+
Args:
+
u: The solution you want to check
+
"""
+
assert self . ndim < 3
+
for axis in range ( self . ndim ):
+
BCs = [ me for me in self . full_BCs if me [ "axis" ] == axis and not me [ "scalar" ]]
+
+
if len ( BCs ) > 0 :
+
u_hat = self . transform ( u , axes = ( axis - self . ndim ,))
+
for BC in BCs :
+
kwargs = {
+
key : value
+
for key , value in BC . items ()
+
if key not in [ 'component' , 'equation' , 'axis' , 'v' , 'line' , 'scalar' ]
+
}
+
+
if axis == 0 :
+
get = self . axes [ axis ] . get_BC ( ** kwargs ) @ u_hat [ self . index ( BC [ 'component' ])]
+
elif axis == 1 :
+
get = u_hat [ self . index ( BC [ 'component' ])] @ self . axes [ axis ] . get_BC ( ** kwargs )
+
want = BC [ 'v' ]
+
assert self . xp . allclose (
+
get , want
+
), f 'Unexpected BC in { BC [ "component" ] } in equation { BC [ "equation" ] } , line { BC [ "line" ] } ! Got { get } , wanted { want } '
+
+
+
+
[docs]
+
def put_BCs_in_matrix ( self , A ):
+
"""
+
Put the boundary conditions in a matrix by replacing rows with BCs.
+
"""
+
return self . BC_line_zero_matrix @ A + self . BCs
+
+
+
+
[docs]
+
def put_BCs_in_rhs_hat ( self , rhs_hat ):
+
"""
+
Put the BCs in the right hand side in spectral space for solving.
+
This function needs no transforms.
+
+
Args:
+
rhs_hat: Right hand side in spectral space
+
+
Returns:
+
rhs in spectral space with BCs
+
"""
+
ndim = self . ndim
+
+
for axis in range ( ndim ):
+
for bc in self . full_BCs :
+
slices = (
+
[ slice ( 0 , self . init [ 0 ][ i + 1 ]) for i in range ( axis )]
+
+ [ bc [ 'line' ]]
+
+ [ slice ( 0 , self . init [ 0 ][ i + 1 ]) for i in range ( axis + 1 , len ( self . axes ))]
+
)
+
if axis == bc [ 'axis' ]:
+
_slice = [ self . index ( bc [ 'equation' ])] + slices
+
N = self . axes [ axis ] . N
+
if ( N + bc [ 'line' ]) % N in self . xp . arange ( N )[ self . local_slice [ axis ]]:
+
_slice [ axis + 1 ] -= self . local_slice [ axis ] . start
+
rhs_hat [( * _slice ,)] = 0
+
+
return rhs_hat + self . rhs_BCs_hat
+
+
+
+
[docs]
+
def put_BCs_in_rhs ( self , rhs ):
+
"""
+
Put the BCs in the right hand side for solving.
+
This function will transform along each axis individually and add all BCs in that axis.
+
Consider `put_BCs_in_rhs_hat` to add BCs with no extra transforms needed.
+
+
Args:
+
rhs: Right hand side in physical space
+
+
Returns:
+
rhs in physical space with BCs
+
"""
+
assert rhs . ndim > 1 , 'rhs must not be flattened here!'
+
+
ndim = self . ndim
+
+
for axis in range ( ndim ):
+
_rhs_hat = self . transform ( rhs , axes = ( axis - ndim ,))
+
+
for bc in self . full_BCs :
+
slices = (
+
[ slice ( 0 , self . init [ 0 ][ i + 1 ]) for i in range ( axis )]
+
+ [ bc [ 'line' ]]
+
+ [ slice ( 0 , self . init [ 0 ][ i + 1 ]) for i in range ( axis + 1 , len ( self . axes ))]
+
)
+
if axis == bc [ 'axis' ]:
+
_slice = [ self . index ( bc [ 'equation' ])] + slices
+
+
N = self . axes [ axis ] . N
+
if ( N + bc [ 'line' ]) % N in self . xp . arange ( N )[ self . local_slice [ axis ]]:
+
_slice [ axis + 1 ] -= self . local_slice [ axis ] . start
+
+
_rhs_hat [( * _slice ,)] = bc [ 'v' ]
+
+
rhs = self . itransform ( _rhs_hat , axes = ( axis - ndim ,))
+
+
return rhs
+
+
+
+
[docs]
+
def add_equation_lhs ( self , A , equation , relations ):
+
"""
+
Add the left hand part (that you want to solve implicitly) of an equation to a list of lists of sparse matrices
+
that you will convert to an operator later.
+
+
Example:
+
Setup linear operator `L` for 1D heat equation using Chebychev method in first order form and T-to-U
+
preconditioning:
+
+
.. code-block:: python
+
helper = SpectralHelper()
+
+
helper.add_axis(base='chebychev', N=8)
+
helper.add_component(['u', 'ux'])
+
helper.setup_fft()
+
+
I = helper.get_Id()
+
Dx = helper.get_differentiation_matrix(axes=(0,))
+
T2U = helper.get_basis_change_matrix('T2U')
+
+
L_lhs = {
+
'ux': {'u': -T2U @ Dx, 'ux': T2U @ I},
+
'u': {'ux': -(T2U @ Dx)},
+
}
+
+
operator = helper.get_empty_operator_matrix()
+
for line, equation in L_lhs.items():
+
helper.add_equation_lhs(operator, line, equation)
+
+
L = helper.convert_operator_matrix_to_operator(operator)
+
+
Args:
+
A (list of lists of sparse matrices): The operator to be
+
equation (str): The equation of the component you want this in
+
relations: (dict): Relations between quantities
+
"""
+
for k , v in relations . items ():
+
A [ self . index ( equation )][ self . index ( k )] = v
+
+
+
+
[docs]
+
def convert_operator_matrix_to_operator ( self , M ):
+
"""
+
Promote the list of lists of sparse matrices to a single sparse matrix that can be used as linear operator.
+
See documentation of `SpectralHelper.add_equation_lhs` for an example.
+
+
Args:
+
M (list of lists of sparse matrices): The operator to be
+
+
Returns:
+
sparse linear operator
+
"""
+
if len ( self . components ) == 1 :
+
return M [ 0 ][ 0 ]
+
else :
+
return self . sparse_lib . bmat ( M , format = 'csc' )
+
+
+
+
[docs]
+
def get_wavenumbers ( self ):
+
"""
+
Get grid in spectral space
+
"""
+
grids = [ self . axes [ i ] . get_wavenumbers ()[ self . local_slice [ i ]] for i in range ( len ( self . axes ))][:: - 1 ]
+
return self . xp . meshgrid ( * grids )
+
+
+
+
[docs]
+
def get_grid ( self ):
+
"""
+
Get grid in physical space
+
"""
+
grids = [ self . axes [ i ] . get_1dgrid ()[ self . local_slice [ i ]] for i in range ( len ( self . axes ))][:: - 1 ]
+
return self . xp . meshgrid ( * grids )
+
+
+
+
[docs]
+
def get_fft ( self , axes = None , direction = 'object' , padding = None , shape = None ):
+
"""
+
When using MPI, we use `PFFT` objects generated by mpi4py-fft
+
+
Args:
+
axes (tuple): Axes you want to transform over
+
direction (str): use "forward" or "backward" to get functions for performing the transforms or "object" to get the PFFT object
+
padding (tuple): Padding for dealiasing
+
shape (tuple): Shape of the transform
+
+
Returns:
+
transform
+
"""
+
axes = tuple ( - i - 1 for i in range ( self . ndim )) if axes is None else axes
+
shape = self . global_shape [ 1 :] if shape is None else shape
+
padding = (
+
[
+
1 ,
+
]
+
* self . ndim
+
if padding is None
+
else padding
+
)
+
key = ( axes , direction , tuple ( padding ), tuple ( shape ))
+
+
if key not in self . fft_cache . keys ():
+
if self . comm is None :
+
assert np . allclose ( padding , 1 ), 'Zero padding is not implemented for non-MPI transforms'
+
+
if direction == 'forward' :
+
self . fft_cache [ key ] = self . xp . fft . fftn
+
elif direction == 'backward' :
+
self . fft_cache [ key ] = self . xp . fft . ifftn
+
elif direction == 'object' :
+
self . fft_cache [ key ] = None
+
else :
+
from mpi4py_fft import PFFT
+
+
_fft = PFFT (
+
comm = self . comm ,
+
shape = shape ,
+
axes = sorted ( axes ),
+
dtype = 'D' ,
+
collapse = False ,
+
backend = self . fft_backend ,
+
comm_backend = self . fft_comm_backend ,
+
padding = padding ,
+
)
+
if direction == 'forward' :
+
self . fft_cache [ key ] = _fft . forward
+
elif direction == 'backward' :
+
self . fft_cache [ key ] = _fft . backward
+
elif direction == 'object' :
+
self . fft_cache [ key ] = _fft
+
+
return self . fft_cache [ key ]
+
+
+
+
[docs]
+
def setup_fft ( self , real_spectral_coefficients = False ):
+
"""
+
This function must be called after all axes have been setup in order to prepare the local shapes of the data.
+
This must also be called before setting up any BCs.
+
+
Args:
+
real_spectral_coefficients (bool): Allow only real coefficients in spectral space
+
"""
+
if len ( self . components ) == 0 :
+
self . add_component ( 'u' )
+
+
self . global_shape = ( len ( self . components ),) + tuple ( me . N for me in self . axes )
+
self . local_slice = [ slice ( 0 , me . N ) for me in self . axes ]
+
+
axes = tuple ( i for i in range ( len ( self . axes )))
+
self . fft_obj = self . get_fft ( axes = axes , direction = 'object' )
+
if self . fft_obj is not None :
+
self . local_slice = self . fft_obj . local_slice ( False )
+
+
self . init = (
+
np . empty ( shape = self . global_shape )[
+
(
+
... ,
+
* self . local_slice ,
+
)
+
] . shape ,
+
self . comm ,
+
np . dtype ( 'float' ),
+
)
+
self . init_forward = (
+
np . empty ( shape = self . global_shape )[
+
(
+
... ,
+
* self . local_slice ,
+
)
+
] . shape ,
+
self . comm ,
+
np . dtype ( 'float' ) if real_spectral_coefficients else np . dtype ( 'complex128' ),
+
)
+
+
self . BC_mat = self . get_empty_operator_matrix ()
+
self . BC_rhs_mask = self . xp . zeros (
+
shape = self . init [ 0 ],
+
dtype = bool ,
+
)
+
+
+
def _transform_fft ( self , u , axes , ** kwargs ):
+
"""
+
FFT along `axes`
+
+
Args:
+
u: The solution
+
axes (tuple): Axes you want to transform over
+
+
Returns:
+
transformed solution
+
"""
+
# TODO: clean up and try putting more of this in the 1D bases
+
fft = self . get_fft ( axes , 'forward' , ** kwargs )
+
return fft ( u , axes = axes )
+
+
def _transform_dct ( self , u , axes , padding = None , ** kwargs ):
+
'''
+
DCT along `axes`.
+
This will only return real values!
+
When padding the solution, we cannot just use the mpi4py-fft implementation, because of the unusual ordering of
+
wavenumbers in FFTs.
+
+
Args:
+
u: The solution
+
axes (tuple): Axes you want to transform over
+
+
Returns:
+
transformed solution
+
'''
+
# TODO: clean up and try putting more of this in the 1D bases
+
if self . debug :
+
assert self . xp . allclose ( u . imag , 0 ), 'This function can only handle real input.'
+
+
if len ( axes ) > 1 :
+
v = self . _transform_dct ( self . _transform_dct ( u , axes [ 1 :], ** kwargs ), ( axes [ 0 ],), ** kwargs )
+
else :
+
v = u . copy () . astype ( complex )
+
axis = axes [ 0 ]
+
base = self . axes [ axis ]
+
+
shuffle = [ slice ( 0 , s , 1 ) for s in u . shape ]
+
shuffle [ axis ] = base . get_fft_shuffle ( True , N = v . shape [ axis ])
+
v = v [( * shuffle ,)]
+
+
if padding is not None :
+
shape = list ( v . shape )
+
if self . comm :
+
shape [ 0 ] = self . comm . allreduce ( v . shape [ 0 ])
+
fft = self . get_fft ( axes , 'forward' , shape = shape )
+
else :
+
fft = self . get_fft ( axes , 'forward' , ** kwargs )
+
+
v = fft ( v , axes = axes )
+
+
expansion = [ np . newaxis for _ in u . shape ]
+
expansion [ axis ] = slice ( 0 , v . shape [ axis ], 1 )
+
+
if padding is not None :
+
shift = base . get_fft_shift ( True , v . shape [ axis ])
+
+
if padding [ axis ] != 1 :
+
N = int ( np . ceil ( v . shape [ axis ] / padding [ axis ]))
+
_expansion = [ slice ( 0 , n ) for n in v . shape ]
+
_expansion [ axis ] = slice ( 0 , N , 1 )
+
v = v [( * _expansion ,)]
+
else :
+
shift = base . fft_utils [ 'fwd' ][ 'shift' ]
+
+
v *= shift [( * expansion ,)]
+
+
return v . real
+
+
+
+
+
+
+
+
def _transform_ifft ( self , u , axes , ** kwargs ):
+
# TODO: clean up and try putting more of this in the 1D bases
+
ifft = self . get_fft ( axes , 'backward' , ** kwargs )
+
return ifft ( u , axes = axes )
+
+
def _transform_idct ( self , u , axes , padding = None , ** kwargs ):
+
'''
+
This will only ever return real values!
+
'''
+
# TODO: clean up and try putting more of this in the 1D bases
+
if self . debug :
+
assert self . xp . allclose ( u . imag , 0 ), 'This function can only handle real input.'
+
+
v = u . copy () . astype ( complex )
+
+
if len ( axes ) > 1 :
+
v = self . _transform_idct ( self . _transform_idct ( u , axes [ 1 :]), ( axes [ 0 ],))
+
else :
+
axis = axes [ 0 ]
+
base = self . axes [ axis ]
+
+
if padding is not None :
+
if padding [ axis ] != 1 :
+
N_pad = int ( np . ceil ( v . shape [ axis ] * padding [ axis ]))
+
_pad = [[ 0 , 0 ] for _ in v . shape ]
+
_pad [ axis ] = [ 0 , N_pad - base . N ]
+
v = self . xp . pad ( v , _pad , 'constant' )
+
+
shift = self . xp . exp ( 1 j * np . pi * self . xp . arange ( N_pad ) / ( 2 * N_pad )) * base . N
+
else :
+
shift = base . fft_utils [ 'bck' ][ 'shift' ]
+
else :
+
shift = base . fft_utils [ 'bck' ][ 'shift' ]
+
+
expansion = [ np . newaxis for _ in u . shape ]
+
expansion [ axis ] = slice ( 0 , v . shape [ axis ], 1 )
+
+
v *= shift [( * expansion ,)]
+
+
if padding is not None :
+
if padding [ axis ] != 1 :
+
shape = list ( v . shape )
+
if self . comm :
+
shape [ 0 ] = self . comm . allreduce ( v . shape [ 0 ])
+
ifft = self . get_fft ( axes , 'backward' , shape = shape )
+
else :
+
ifft = self . get_fft ( axes , 'backward' , padding = padding , ** kwargs )
+
else :
+
ifft = self . get_fft ( axes , 'backward' , padding = padding , ** kwargs )
+
v = ifft ( v , axes = axes )
+
+
shuffle = [ slice ( 0 , s , 1 ) for s in v . shape ]
+
shuffle [ axis ] = base . get_fft_shuffle ( False , N = v . shape [ axis ])
+
v = v [( * shuffle ,)]
+
+
return v . real
+
+
+
+
+
+
[docs]
+
def get_aligned ( self , u , axis_in , axis_out , fft = None , forward = False , ** kwargs ):
+
"""
+
Realign the data along the axis when using distributed FFTs. `kwargs` will be used to get the correct PFFT
+
object from `mpi4py-fft`, which has suitable transfer classes for the shape of data. Hence, they should include
+
shape especially, if applicable.
+
+
Args:
+
u: The solution
+
axis_in (int): Current alignment
+
axis_out (int): New alignment
+
fft (mpi4py_fft.PFFT), optional: parallel FFT object
+
forward (bool): Whether the input is in spectral space or not
+
+
Returns:
+
solution aligned on `axis_in`
+
"""
+
if self . comm is None or axis_in == axis_out :
+
return u . copy ()
+
if self . comm . size == 1 :
+
return u . copy ()
+
+
fft = self . get_fft ( ** kwargs ) if fft is None else fft
+
+
global_fft = self . get_fft ( ** kwargs )
+
axisA = [ me . axisA for me in global_fft . transfer ]
+
axisB = [ me . axisB for me in global_fft . transfer ]
+
+
current_axis = axis_in
+
+
if axis_in in axisA and axis_out in axisB :
+
while current_axis != axis_out :
+
transfer = global_fft . transfer [ axisA . index ( current_axis )]
+
+
arrayB = self . xp . empty ( shape = transfer . subshapeB , dtype = transfer . dtype )
+
arrayA = self . xp . empty ( shape = transfer . subshapeA , dtype = transfer . dtype )
+
arrayA [:] = u [:]
+
+
transfer . forward ( arrayA = arrayA , arrayB = arrayB )
+
+
current_axis = transfer . axisB
+
u = arrayB
+
+
return u
+
elif axis_in in axisB and axis_out in axisA :
+
while current_axis != axis_out :
+
transfer = global_fft . transfer [ axisB . index ( current_axis )]
+
+
arrayB = self . xp . empty ( shape = transfer . subshapeB , dtype = transfer . dtype )
+
arrayA = self . xp . empty ( shape = transfer . subshapeA , dtype = transfer . dtype )
+
arrayB [:] = u [:]
+
+
transfer . backward ( arrayA = arrayA , arrayB = arrayB )
+
+
current_axis = transfer . axisA
+
u = arrayA
+
+
return u
+
else : # go the potentially slower route of not reusing transfer classes
+
from mpi4py_fft import newDistArray
+
+
_in = newDistArray ( fft , forward ) . redistribute ( axis_in )
+
_in [ ... ] = u
+
+
return _in . redistribute ( axis_out )
+
+
+
+
+
+
+
[docs]
+
def get_local_slice_of_1D_matrix ( self , M , axis ):
+
"""
+
Get the local version of a 1D matrix. When using distributed FFTs, each rank will carry only a subset of modes,
+
which you can sort out via the `SpectralHelper.local_slice` attribute. When constructing a 1D matrix, you can
+
use this method to get the part corresponding to the modes carried by this rank.
+
+
Args:
+
M (sparse matrix): Global 1D matrix you want to get the local version of
+
axis (int): Direction in which you want the local version. You will get the global matrix in other directions. This means slab decomposition only.
+
+
Returns:
+
sparse local matrix
+
"""
+
return M . tocsc ()[ self . local_slice [ axis ], self . local_slice [ axis ]]
+
+
+
+
[docs]
+
def get_filter_matrix ( self , axis , ** kwargs ):
+
"""
+
Get bandpass filter along `axis`. See the documentation `get_filter_matrix` in the 1D bases for what kwargs are
+
admissible.
+
+
Returns:
+
sparse bandpass matrix
+
"""
+
if self . ndim == 1 :
+
return self . axes [ 0 ] . get_filter_matrix ( ** kwargs )
+
+
mats = [ base . get_Id () for base in self . axes ]
+
mats [ axis ] = self . axes [ axis ] . get_filter_matrix ( ** kwargs )
+
return self . sparse_lib . kron ( * mats )
+
+
+
+
[docs]
+
def get_differentiation_matrix ( self , axes , ** kwargs ):
+
"""
+
Get differentiation matrix along specified axis. `kwargs` are forwarded to the 1D base implementation.
+
+
Args:
+
axes (tuple): Axes along which to differentiate.
+
+
Returns:
+
sparse differentiation matrix
+
"""
+
sp = self . sparse_lib
+
ndim = self . ndim
+
+
if ndim == 1 :
+
D = self . axes [ 0 ] . get_differentiation_matrix ( ** kwargs )
+
elif ndim == 2 :
+
for axis in axes :
+
axis2 = ( axis + 1 ) % ndim
+
D1D = self . axes [ axis ] . get_differentiation_matrix ( ** kwargs )
+
+
if len ( axes ) > 1 :
+
I1D = sp . eye ( self . axes [ axis2 ] . N )
+
else :
+
I1D = self . axes [ axis2 ] . get_Id ()
+
+
mats = [ None ] * ndim
+
mats [ axis ] = self . get_local_slice_of_1D_matrix ( D1D , axis )
+
mats [ axis2 ] = self . get_local_slice_of_1D_matrix ( I1D , axis2 )
+
+
if axis == axes [ 0 ]:
+
D = sp . kron ( * mats )
+
else :
+
D = D @ sp . kron ( * mats )
+
else :
+
raise NotImplementedError ( f 'Differentiation matrix not implemented for { ndim } dimension!' )
+
+
return D
+
+
+
+
[docs]
+
def get_integration_matrix ( self , axes ):
+
"""
+
Get integration matrix to integrate along specified axis.
+
+
Args:
+
axes (tuple): Axes along which to integrate over.
+
+
Returns:
+
sparse integration matrix
+
"""
+
sp = self . sparse_lib
+
ndim = len ( self . axes )
+
+
if ndim == 1 :
+
S = self . axes [ 0 ] . get_integration_matrix ()
+
elif ndim == 2 :
+
for axis in axes :
+
axis2 = ( axis + 1 ) % ndim
+
S1D = self . axes [ axis ] . get_integration_matrix ()
+
+
if len ( axes ) > 1 :
+
I1D = sp . eye ( self . axes [ axis2 ] . N )
+
else :
+
I1D = self . axes [ axis2 ] . get_Id ()
+
+
mats = [ None ] * ndim
+
mats [ axis ] = self . get_local_slice_of_1D_matrix ( S1D , axis )
+
mats [ axis2 ] = self . get_local_slice_of_1D_matrix ( I1D , axis2 )
+
+
if axis == axes [ 0 ]:
+
S = sp . kron ( * mats )
+
else :
+
S = S @ sp . kron ( * mats )
+
else :
+
raise NotImplementedError ( f 'Integration matrix not implemented for { ndim } dimension!' )
+
+
return S
+
+
+
+
[docs]
+
def get_Id ( self ):
+
"""
+
Get identity matrix
+
+
Returns:
+
sparse identity matrix
+
"""
+
sp = self . sparse_lib
+
ndim = self . ndim
+
I = sp . eye ( np . prod ( self . init [ 0 ][ 1 :]), dtype = complex )
+
+
if ndim == 1 :
+
I = self . axes [ 0 ] . get_Id ()
+
elif ndim == 2 :
+
for axis in range ( ndim ):
+
axis2 = ( axis + 1 ) % ndim
+
I1D = self . axes [ axis ] . get_Id ()
+
+
I1D2 = sp . eye ( self . axes [ axis2 ] . N )
+
+
mats = [ None ] * ndim
+
mats [ axis ] = self . get_local_slice_of_1D_matrix ( I1D , axis )
+
mats [ axis2 ] = self . get_local_slice_of_1D_matrix ( I1D2 , axis2 )
+
+
I = I @ sp . kron ( * mats )
+
else :
+
raise NotImplementedError ( f 'Identity matrix not implemented for { ndim } dimension!' )
+
+
return I
+
+
+
+
[docs]
+
def get_Dirichlet_recombination_matrix ( self , axis =- 1 ):
+
"""
+
Get Dirichlet recombination matrix along axis. Not that it only makes sense in directions discretized with variations of Chebychev bases.
+
+
Args:
+
axis (int): Axis you discretized with Chebychev
+
+
Returns:
+
sparse matrix
+
"""
+
sp = self . sparse_lib
+
ndim = len ( self . axes )
+
+
if ndim == 1 :
+
C = self . axes [ 0 ] . get_Dirichlet_recombination_matrix ()
+
elif ndim == 2 :
+
axis2 = ( axis + 1 ) % ndim
+
C1D = self . axes [ axis ] . get_Dirichlet_recombination_matrix ()
+
+
I1D = self . axes [ axis2 ] . get_Id ()
+
+
mats = [ None ] * ndim
+
mats [ axis ] = self . get_local_slice_of_1D_matrix ( C1D , axis )
+
mats [ axis2 ] = self . get_local_slice_of_1D_matrix ( I1D , axis2 )
+
+
C = sp . kron ( * mats )
+
else :
+
raise NotImplementedError ( f 'Basis change matrix not implemented for { ndim } dimension!' )
+
+
return C
+
+
+
+
[docs]
+
def get_basis_change_matrix ( self , axes = None , ** kwargs ):
+
"""
+
Some spectral bases do a change between bases while differentiating. This method returns matrices that changes the basis to whatever you want.
+
Refer to the methods of the same name of the 1D bases to learn what parameters you need to pass here as `kwargs`.
+
+
Args:
+
axes (tuple): Axes along which to change basis.
+
+
Returns:
+
sparse basis change matrix
+
"""
+
axes = tuple ( - i - 1 for i in range ( self . ndim )) if axes is None else axes
+
+
sp = self . sparse_lib
+
ndim = len ( self . axes )
+
+
if ndim == 1 :
+
C = self . axes [ 0 ] . get_basis_change_matrix ( ** kwargs )
+
elif ndim == 2 :
+
for axis in axes :
+
axis2 = ( axis + 1 ) % ndim
+
C1D = self . axes [ axis ] . get_basis_change_matrix ( ** kwargs )
+
+
if len ( axes ) > 1 :
+
I1D = sp . eye ( self . axes [ axis2 ] . N )
+
else :
+
I1D = self . axes [ axis2 ] . get_Id ()
+
+
mats = [ None ] * ndim
+
mats [ axis ] = self . get_local_slice_of_1D_matrix ( C1D , axis )
+
mats [ axis2 ] = self . get_local_slice_of_1D_matrix ( I1D , axis2 )
+
+
if axis == axes [ 0 ]:
+
C = sp . kron ( * mats )
+
else :
+
C = C @ sp . kron ( * mats )
+
else :
+
raise NotImplementedError ( f 'Basis change matrix not implemented for { ndim } dimension!' )
+
+
return C
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/_modules/implementations/convergence_controller_classes/interpolate_between_restarts.html b/_modules/implementations/convergence_controller_classes/interpolate_between_restarts.html
index 92d1dbdce6..37316d747b 100644
--- a/_modules/implementations/convergence_controller_classes/interpolate_between_restarts.html
+++ b/_modules/implementations/convergence_controller_classes/interpolate_between_restarts.html
@@ -105,7 +105,7 @@ Source code for implementations.convergence_controller_classes.interpolate_b
for m in range ( len ( level . u )):
level . u [ m ][:] = self . status . u_inter [ i ][ m ] . reshape ( level . prob . init [ 0 ])[:]
- level . f [ m ][:] = self . status . f_inter [ i ][ m ] . reshape ( level . prob . init [ 0 ])[:]
+ level . f [ m ][:] = self . status . f_inter [ i ][ m ] . reshape ( level . f [ m ] . shape )[:]
# reset the status variables
self . status . perform_interpolation = False
diff --git a/_modules/implementations/problem_classes/Burgers.html b/_modules/implementations/problem_classes/Burgers.html
new file mode 100644
index 0000000000..fb628c58b1
--- /dev/null
+++ b/_modules/implementations/problem_classes/Burgers.html
@@ -0,0 +1,451 @@
+
+
+
+
+
+
+ implementations.problem_classes.Burgers — pySDC 5.5.1 documentation
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Source code for implementations.problem_classes.Burgers
+import numpy as np
+
+from pySDC.implementations.datatype_classes.mesh import mesh , imex_mesh
+from pySDC.implementations.problem_classes.generic_spectral import GenericSpectralLinear
+
+
+
+
[docs]
+
class Burgers1D ( GenericSpectralLinear ):
+
"""
+
See https://en.wikipedia.org/wiki/Burgers'_equation for the equation that is solved.
+
Discretization is done with a Chebychev method, which requires a first order derivative formulation.
+
Feel free to do a more efficient implementation using an ultraspherical method to avoid the first order business.
+
+
Parameters:
+
N (int): Spatial resolution
+
epsilon (float): viscosity
+
BCl (float): Value at left boundary
+
BCr (float): Value at right boundary
+
f (int): Frequency of the initial conditions
+
mode (str): 'T2U' or 'T2T'. Use 'T2U' to get sparse differentiation matrices
+
"""
+
+
dtype_u = mesh
+
dtype_f = imex_mesh
+
+
def __init__ ( self , N = 64 , epsilon = 0.1 , BCl = 1 , BCr =- 1 , f = 0 , mode = 'T2U' , ** kwargs ):
+
"""
+
Constructor. `kwargs` are forwarded to parent class constructor.
+
+
Args:
+
N (int): Spatial resolution
+
epsilon (float): viscosity
+
BCl (float): Value at left boundary
+
BCr (float): Value at right boundary
+
f (int): Frequency of the initial conditions
+
mode (str): 'T2U' or 'T2T'. Use 'T2U' to get sparse differentiation matrices
+
"""
+
self . _makeAttributeAndRegister ( 'N' , 'epsilon' , 'BCl' , 'BCr' , 'f' , 'mode' , localVars = locals (), readOnly = True )
+
+
bases = [{ 'base' : 'cheby' , 'N' : N }]
+
components = [ 'u' , 'ux' ]
+
+
super () . __init__ ( bases = bases , components = components , spectral_space = False , ** kwargs )
+
+
self . x = self . get_grid ()[ 0 ]
+
+
# prepare matrices
+
Dx = self . get_differentiation_matrix ( axes = ( 0 ,))
+
I = self . get_Id ()
+
+
T2U = self . get_basis_change_matrix ( conv = mode )
+
+
self . Dx = Dx
+
+
# construct linear operator
+
L_lhs = { 'u' : { 'ux' : - epsilon * ( T2U @ Dx )}, 'ux' : { 'u' : - T2U @ Dx , 'ux' : T2U @ I }}
+
self . setup_L ( L_lhs )
+
+
# construct mass matrix
+
M_lhs = { 'u' : { 'u' : T2U @ I }}
+
self . setup_M ( M_lhs )
+
+
# boundary conditions
+
self . add_BC ( component = 'u' , equation = 'u' , axis = 0 , x = 1 , v = BCr , kind = 'Dirichlet' )
+
self . add_BC ( component = 'u' , equation = 'ux' , axis = 0 , x =- 1 , v = BCl , kind = 'Dirichlet' )
+
self . setup_BCs ()
+
+
+
[docs]
+
def u_exact ( self , t = 0 , * args , ** kwargs ):
+
me = self . u_init
+
+
# x = (self.x + 1) / 2
+
# g = 4 * (1 + np.exp(-(4 * x + t)/self.epsilon/32))
+
# g_x = 4 * np.exp(-(4 * x + t)/self.epsilon/32) * (-4/self.epsilon/32)
+
+
# me[0] = 3./4. - 1./g
+
# me[1] = 1/g**2 * g_x
+
+
# return me
+
+
if t == 0 :
+
me [ self . index ( 'u' )][:] = (( self . BCr + self . BCl ) / 2 + ( self . BCr - self . BCl ) / 2 * self . x ) * np . cos (
+
self . x * np . pi * self . f
+
)
+
me [ self . index ( 'ux' )][:] = ( self . BCr - self . BCl ) / 2 * np . cos ( self . x * np . pi * self . f ) + (
+
( self . BCr + self . BCl ) / 2 + ( self . BCr - self . BCl ) / 2 * self . x
+
) * self . f * np . pi * - np . sin ( self . x * np . pi * self . f )
+
elif t == np . inf and self . f == 0 and self . BCl == - self . BCr :
+
me [ 0 ] = ( self . BCl * np . exp (( self . BCr - self . BCl ) / ( 2 * self . epsilon ) * self . x ) + self . BCr ) / (
+
np . exp (( self . BCr - self . BCl ) / ( 2 * self . epsilon ) * self . x ) + 1
+
)
+
else :
+
raise NotImplementedError
+
+
return me
+
+
+
+
[docs]
+
def eval_f ( self , u , * args , ** kwargs ):
+
f = self . f_init
+
iu , iux = self . index ( 'u' ), self . index ( 'ux' )
+
+
u_hat = self . transform ( u )
+
+
Dx_u_hat = self . u_init_forward
+
Dx_u_hat [ iux ] = ( self . Dx @ u_hat [ iux ] . flatten ()) . reshape ( u_hat [ iu ] . shape )
+
+
f . impl [ iu ] = self . epsilon * self . itransform ( Dx_u_hat )[ iux ] . real
+
f . expl [ iu ] = - u [ iu ] * u [ iux ]
+
return f
+
+
+
+
[docs]
+
def get_fig ( self ): # pragma: no cover
+
"""
+
Get a figure suitable to plot the solution of this problem.
+
+
Returns
+
-------
+
self.fig : matplotlib.pyplot.figure.Figure
+
"""
+
import matplotlib.pyplot as plt
+
+
plt . rcParams [ 'figure.constrained_layout.use' ] = True
+
self . fig , axs = plt . subplots ()
+
return self . fig
+
+
+
+
[docs]
+
def plot ( self , u , t = None , fig = None , comp = 'u' ): # pragma: no cover
+
r """
+
Plot the solution.
+
+
Parameters
+
----------
+
u : dtype_u
+
Solution to be plotted
+
t : float
+
Time to display at the top of the figure
+
fig : matplotlib.pyplot.figure.Figure, optional
+
Figure with the same structure as a figure generated by `self.get_fig`. If none is supplied, a new figure will be generated.
+
+
Returns
+
-------
+
None
+
"""
+
fig = self . get_fig () if fig is None else fig
+
ax = fig . axes [ 0 ]
+
+
ax . plot ( self . x , u [ self . index ( comp )])
+
+
if t is not None :
+
fig . suptitle ( f 't = { t : .2e } ' )
+
+
ax . set_xlabel ( r '$x$' )
+
ax . set_ylabel ( r '$u$' )
+
+
+
+
+
+
[docs]
+
class Burgers2D ( GenericSpectralLinear ):
+
"""
+
See https://en.wikipedia.org/wiki/Burgers'_equation for the equation that is solved.
+
This implementation is discretized with FFTs in x and Chebychev in z.
+
+
Parameters:
+
nx (int): Spatial resolution in x direction
+
nz (int): Spatial resolution in z direction
+
epsilon (float): viscosity
+
BCl (float): Value at left boundary
+
BCr (float): Value at right boundary
+
fux (int): Frequency of the initial conditions in x-direction
+
fuz (int): Frequency of the initial conditions in z-direction
+
mode (str): 'T2U' or 'T2T'. Use 'T2U' to get sparse differentiation matrices
+
"""
+
+
dtype_u = mesh
+
dtype_f = imex_mesh
+
+
def __init__ ( self , nx = 64 , nz = 64 , epsilon = 0.1 , fux = 2 , fuz = 1 , mode = 'T2U' , ** kwargs ):
+
"""
+
Constructor. `kwargs` are forwarded to parent class constructor.
+
+
Args:
+
nx (int): Spatial resolution in x direction
+
nz (int): Spatial resolution in z direction
+
epsilon (float): viscosity
+
fux (int): Frequency of the initial conditions in x-direction
+
fuz (int): Frequency of the initial conditions in z-direction
+
mode (str): 'T2U' or 'T2T'. Use 'T2U' to get sparse differentiation matrices
+
"""
+
self . _makeAttributeAndRegister ( 'nx' , 'nz' , 'epsilon' , 'fux' , 'fuz' , 'mode' , localVars = locals (), readOnly = True )
+
+
bases = [
+
{ 'base' : 'fft' , 'N' : nx },
+
{ 'base' : 'cheby' , 'N' : nz },
+
]
+
components = [ 'u' , 'v' , 'ux' , 'uz' , 'vx' , 'vz' ]
+
super () . __init__ ( bases = bases , components = components , spectral_space = False , ** kwargs )
+
+
self . Z , self . X = self . get_grid ()
+
+
# prepare matrices
+
Dx = self . get_differentiation_matrix ( axes = ( 0 ,))
+
Dz = self . get_differentiation_matrix ( axes = ( 1 ,))
+
I = self . get_Id ()
+
+
T2U = self . get_basis_change_matrix ( axes = ( 1 ,), conv = mode )
+
+
self . Dx = Dx
+
self . Dz = Dz
+
+
# construct linear operator
+
L_lhs = {
+
'u' : { 'ux' : - epsilon * T2U @ Dx , 'uz' : - epsilon * T2U @ Dz },
+
'v' : { 'vx' : - epsilon * T2U @ Dx , 'vz' : - epsilon * T2U @ Dz },
+
'ux' : { 'u' : - T2U @ Dx , 'ux' : T2U @ I },
+
'uz' : { 'u' : - T2U @ Dz , 'uz' : T2U @ I },
+
'vx' : { 'v' : - T2U @ Dx , 'vx' : T2U @ I },
+
'vz' : { 'v' : - T2U @ Dz , 'vz' : T2U @ I },
+
}
+
self . setup_L ( L_lhs )
+
+
# construct mass matrix
+
M_lhs = {
+
'u' : { 'u' : T2U @ I },
+
'v' : { 'v' : T2U @ I },
+
}
+
self . setup_M ( M_lhs )
+
+
# boundary conditions
+
self . BCtop = 1
+
self . BCbottom = - self . BCtop
+
self . BCtopu = 0
+
self . add_BC ( component = 'v' , equation = 'v' , axis = 1 , v = self . BCtop , x = 1 , kind = 'Dirichlet' )
+
self . add_BC ( component = 'v' , equation = 'vz' , axis = 1 , v = self . BCbottom , x =- 1 , kind = 'Dirichlet' )
+
self . add_BC ( component = 'u' , equation = 'uz' , axis = 1 , v = self . BCtopu , x = 1 , kind = 'Dirichlet' )
+
self . add_BC ( component = 'u' , equation = 'u' , axis = 1 , v = self . BCtopu , x =- 1 , kind = 'Dirichlet' )
+
self . setup_BCs ()
+
+
+
[docs]
+
def u_exact ( self , t = 0 , * args , noise_level = 0 , ** kwargs ):
+
me = self . u_init
+
+
iu , iv , iux , iuz , ivx , ivz = self . index ( self . components )
+
if t == 0 :
+
me [ iu ] = self . xp . cos ( self . X * self . fux ) * self . xp . sin ( self . Z * np . pi * self . fuz ) + self . BCtopu
+
me [ iux ] = - self . xp . sin ( self . X * self . fux ) * self . fux * self . xp . sin ( self . Z * np . pi * self . fuz )
+
me [ iuz ] = self . xp . cos ( self . X * self . fux ) * self . xp . cos ( self . Z * np . pi * self . fuz ) * np . pi * self . fuz
+
+
me [ iv ] = ( self . BCtop + self . BCbottom ) / 2 + ( self . BCtop - self . BCbottom ) / 2 * self . Z
+
me [ ivz ][:] = ( self . BCtop - self . BCbottom ) / 2
+
+
# add noise
+
rng = self . xp . random . default_rng ( seed = 99 )
+
me [ iv ] . real += rng . normal ( size = me [ iv ] . shape ) * ( self . Z - 1 ) * ( self . Z + 1 ) * noise_level
+
+
else :
+
raise NotImplementedError
+
+
return me
+
+
+
+
[docs]
+
def eval_f ( self , u , * args , ** kwargs ):
+
f = self . f_init
+
iu , iv , iux , iuz , ivx , ivz = self . index ( self . components )
+
+
u_hat = self . transform ( u )
+
f_hat = self . u_init_forward
+
f_hat [ iu ] = self . epsilon * (( self . Dx @ u_hat [ iux ] . flatten () + self . Dz @ u_hat [ iuz ] . flatten ())) . reshape (
+
u_hat [ iux ] . shape
+
)
+
f_hat [ iv ] = self . epsilon * (( self . Dx @ u_hat [ ivx ] . flatten () + self . Dz @ u_hat [ ivz ] . flatten ())) . reshape (
+
u_hat [ iux ] . shape
+
)
+
f . impl [ ... ] = self . itransform ( f_hat ) . real
+
+
f . expl [ iu ] = - ( u [ iu ] * u [ iux ] + u [ iv ] * u [ iuz ])
+
f . expl [ iv ] = - ( u [ iu ] * u [ ivx ] + u [ iv ] * u [ ivz ])
+
return f
+
+
+
+
[docs]
+
def compute_vorticity ( self , u ):
+
me = self . u_init_forward
+
+
u_hat = self . transform ( u )
+
iu , iv = self . index ([ 'u' , 'v' ])
+
+
me [ iu ] = ( self . Dx @ u_hat [ iv ] . flatten () + self . Dz @ u_hat [ iu ] . flatten ()) . reshape ( u [ iu ] . shape )
+
return self . itransform ( me )[ iu ] . real
+
+
+
+
[docs]
+
def get_fig ( self ): # pragma: no cover
+
"""
+
Get a figure suitable to plot the solution of this problem
+
+
Returns
+
-------
+
self.fig : matplotlib.pyplot.figure.Figure
+
"""
+
import matplotlib.pyplot as plt
+
from mpl_toolkits.axes_grid1 import make_axes_locatable
+
+
plt . rcParams [ 'figure.constrained_layout.use' ] = True
+
self . fig , axs = plt . subplots ( 3 , 1 , sharex = True , sharey = True , figsize = (( 8 , 7 )))
+
self . cax = []
+
divider = make_axes_locatable ( axs [ 0 ])
+
self . cax += [ divider . append_axes ( 'right' , size = '3%' , pad = 0.03 )]
+
divider2 = make_axes_locatable ( axs [ 1 ])
+
self . cax += [ divider2 . append_axes ( 'right' , size = '3%' , pad = 0.03 )]
+
divider3 = make_axes_locatable ( axs [ 2 ])
+
self . cax += [ divider3 . append_axes ( 'right' , size = '3%' , pad = 0.03 )]
+
return self . fig
+
+
+
+
[docs]
+
def plot ( self , u , t = None , fig = None , vmin = None , vmax = None ): # pragma: no cover
+
r """
+
Plot the solution. Please supply a figure with the same structure as returned by ``self.get_fig``.
+
+
Parameters
+
----------
+
u : dtype_u
+
Solution to be plotted
+
t : float
+
Time to display at the top of the figure
+
fig : matplotlib.pyplot.figure.Figure
+
Figure with the correct structure
+
+
Returns
+
-------
+
None
+
"""
+
fig = self . get_fig () if fig is None else fig
+
axs = fig . axes
+
+
iu , iv = self . index ([ 'u' , 'v' ])
+
+
imU = axs [ 0 ] . pcolormesh ( self . X , self . Z , u [ iu ] . real , vmin = vmin , vmax = vmax )
+
imV = axs [ 1 ] . pcolormesh ( self . X , self . Z , u [ iv ] . real , vmin = vmin , vmax = vmax )
+
imVort = axs [ 2 ] . pcolormesh ( self . X , self . Z , self . compute_vorticity ( u ) . real )
+
+
for i , label in zip ([ 0 , 1 , 2 ], [ r '$u$' , '$v$' , 'vorticity' ]):
+
axs [ i ] . set_aspect ( 1 )
+
axs [ i ] . set_title ( label )
+
+
if t is not None :
+
fig . suptitle ( f 't = { t : .2e } ' )
+
axs [ - 1 ] . set_xlabel ( r '$x$' )
+
axs [ - 1 ] . set_ylabel ( r '$z$' )
+
fig . colorbar ( imU , self . cax [ 0 ])
+
fig . colorbar ( imV , self . cax [ 1 ])
+
fig . colorbar ( imVort , self . cax [ 2 ])
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/_modules/implementations/problem_classes/HeatEquation_Chebychev.html b/_modules/implementations/problem_classes/HeatEquation_Chebychev.html
new file mode 100644
index 0000000000..848ac69909
--- /dev/null
+++ b/_modules/implementations/problem_classes/HeatEquation_Chebychev.html
@@ -0,0 +1,561 @@
+
+
+
+
+
+
+ implementations.problem_classes.HeatEquation_Chebychev — pySDC 5.5.1 documentation
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Source code for implementations.problem_classes.HeatEquation_Chebychev
+import numpy as np
+from scipy import sparse as sp
+
+from pySDC.core.problem import Problem
+from pySDC.implementations.datatype_classes.mesh import mesh
+from pySDC.implementations.problem_classes.generic_spectral import GenericSpectralLinear
+
+
+
+
[docs]
+
class Heat1DChebychev ( GenericSpectralLinear ):
+
"""
+
1D Heat equation with Dirichlet Boundary conditions discretized on (-1, 1) using a Chebychev spectral method.
+
"""
+
+
dtype_u = mesh
+
dtype_f = mesh
+
+
def __init__ ( self , nvars = 128 , a = 0 , b = 0 , f = 1 , nu = 1.0 , mode = 'T2U' , ** kwargs ):
+
"""
+
Constructor. `kwargs` are forwarded to parent class constructor.
+
+
Args:
+
nvars (int): Resolution
+
a (float): Left BC value
+
b (float): Right BC value
+
f (int): Frequency of the solution
+
nu (float): Diffusion parameter
+
mode ('T2T' or 'T2U'): Mode for Chebychev method.
+
+
"""
+
self . _makeAttributeAndRegister ( 'nvars' , 'a' , 'b' , 'f' , 'nu' , 'mode' , localVars = locals (), readOnly = True )
+
+
bases = [{ 'base' : 'chebychev' , 'N' : nvars }]
+
components = [ 'u' , 'ux' ]
+
+
super () . __init__ ( bases , components , real_spectral_coefficients = True , ** kwargs )
+
+
self . x = self . get_grid ()[ 0 ]
+
+
I = self . get_Id ()
+
Dx = self . get_differentiation_matrix ( axes = ( 0 ,))
+
self . Dx = Dx
+
+
self . T2U = self . get_basis_change_matrix ( conv = mode )
+
+
L_lhs = {
+
'ux' : { 'u' : - self . T2U @ Dx , 'ux' : self . T2U @ I },
+
'u' : { 'ux' : - nu * ( self . T2U @ Dx )},
+
}
+
self . setup_L ( L_lhs )
+
+
M_lhs = { 'u' : { 'u' : self . T2U @ I }}
+
self . setup_M ( M_lhs )
+
+
self . add_BC ( component = 'u' , equation = 'u' , axis = 0 , x =- 1 , v = a , kind = "Dirichlet" )
+
self . add_BC ( component = 'u' , equation = 'ux' , axis = 0 , x = 1 , v = b , kind = "Dirichlet" )
+
self . setup_BCs ()
+
+
+
[docs]
+
def eval_f ( self , u , * args , ** kwargs ):
+
f = self . f_init
+
iu , iux = self . index ( self . components )
+
+
if self . spectral_space :
+
u_hat = u . copy ()
+
else :
+
u_hat = self . transform ( u )
+
+
u_hat [ iu ] = ( self . nu * self . Dx @ u_hat [ iux ] . flatten ()) . reshape ( u_hat [ iu ] . shape )
+
+
if self . spectral_space :
+
me = u_hat
+
else :
+
me = self . itransform ( u_hat ) . real
+
+
f [ iu ] = me [ iu ]
+
return f
+
+
+
+
[docs]
+
def u_exact ( self , t , noise = 0 , seed = 666 ):
+
"""
+
Get exact solution at time `t`
+
+
Args:
+
t (float): When you want the exact solution
+
noise (float): Add noise of this level
+
seed (int): Random seed for the noise
+
+
Returns:
+
Heat1DChebychev.dtype_u: Exact solution
+
"""
+
xp = self . xp
+
iu , iux = self . index ( self . components )
+
u = self . spectral . u_init
+
+
u [ iu ] = (
+
xp . sin ( self . f * np . pi * self . x ) * xp . exp ( - self . nu * ( self . f * np . pi ) ** 2 * t )
+
+ ( self . b - self . a ) / 2 * self . x
+
+ ( self . b + self . a ) / 2
+
)
+
u [ iux ] = (
+
self . f * np . pi * xp . cos ( self . f * np . pi * self . x ) * xp . exp ( - self . nu * ( self . f * np . pi ) ** 2 * t )
+
+ ( self . b - self . a ) / 2
+
)
+
+
if noise > 0 :
+
assert t == 0
+
_noise = self . u_init
+
rng = self . xp . random . default_rng ( seed = seed )
+
_noise [ iu ] = rng . normal ( size = u [ iu ] . shape )
+
noise_hat = self . transform ( _noise )
+
low_pass = self . get_filter_matrix ( axis = 0 , kmax = self . nvars - 2 )
+
noise_hat [ iu ] = ( low_pass @ noise_hat [ iu ] . flatten ()) . reshape ( noise_hat [ iu ] . shape )
+
_noise [:] = self . itransform ( noise_hat )
+
u += _noise * noise * ( self . x - 1 ) * ( self . x + 1 )
+
+
self . check_BCs ( u )
+
+
if self . spectral_space :
+
u_hat = self . u_init
+
u_hat [ ... ] = self . transform ( u )
+
return u_hat
+
else :
+
return u
+
+
+
+
+
+
[docs]
+
class Heat1DUltraspherical ( GenericSpectralLinear ):
+
"""
+
1D Heat equation with Dirichlet Boundary conditions discretized on (-1, 1) using an ultraspherical spectral method.
+
"""
+
+
dtype_u = mesh
+
dtype_f = mesh
+
+
def __init__ ( self , nvars = 128 , a = 0 , b = 0 , f = 1 , nu = 1.0 , ** kwargs ):
+
"""
+
Constructor. `kwargs` are forwarded to parent class constructor.
+
+
Args:
+
nvars (int): Resolution
+
a (float): Left BC value
+
b (float): Right BC value
+
f (int): Frequency of the solution
+
nu (float): Diffusion parameter
+
"""
+
self . _makeAttributeAndRegister ( 'nvars' , 'a' , 'b' , 'f' , 'nu' , localVars = locals (), readOnly = True )
+
+
bases = [{ 'base' : 'ultraspherical' , 'N' : nvars }]
+
components = [ 'u' ]
+
+
GenericSpectralLinear . __init__ ( self , bases , components , real_spectral_coefficients = True , ** kwargs )
+
+
self . x = self . get_grid ()[ 0 ]
+
+
I = self . get_Id ()
+
Dxx = self . get_differentiation_matrix ( axes = ( 0 ,), p = 2 )
+
+
S2 = self . get_basis_change_matrix ( p_in = 2 , p_out = 0 )
+
U2 = self . get_basis_change_matrix ( p_in = 0 , p_out = 2 )
+
+
self . Dxx = S2 @ Dxx
+
+
L_lhs = {
+
'u' : { 'u' : - nu * Dxx },
+
}
+
self . setup_L ( L_lhs )
+
+
M_lhs = { 'u' : { 'u' : U2 @ I }}
+
self . setup_M ( M_lhs )
+
+
self . add_BC ( component = 'u' , equation = 'u' , axis = 0 , x =- 1 , v = a , kind = "Dirichlet" , line =- 1 )
+
self . add_BC ( component = 'u' , equation = 'u' , axis = 0 , x = 1 , v = b , kind = "Dirichlet" , line =- 2 )
+
self . setup_BCs ()
+
+
+
[docs]
+
def eval_f ( self , u , * args , ** kwargs ):
+
f = self . f_init
+
iu = self . index ( 'u' )
+
+
if self . spectral_space :
+
u_hat = u . copy ()
+
else :
+
u_hat = self . transform ( u )
+
+
u_hat [ iu ] = ( self . nu * ( self . Dxx @ u_hat [ iu ] . flatten ())) . reshape ( u_hat [ iu ] . shape )
+
+
if self . spectral_space :
+
me = u_hat
+
else :
+
me = self . itransform ( u_hat ) . real
+
+
f [ iu ][ ... ] = me [ iu ]
+
return f
+
+
+
+
[docs]
+
def u_exact ( self , t , noise = 0 , seed = 666 ):
+
"""
+
Get exact solution at time `t`
+
+
Args:
+
t (float): When you want the exact solution
+
noise (float): Add noise of this level
+
seed (int): Random seed for the noise
+
+
Returns:
+
Heat1DUltraspherical.dtype_u: Exact solution
+
"""
+
xp = self . xp
+
iu = self . index ( 'u' )
+
u = self . spectral . u_init
+
+
u [ iu ] = (
+
xp . sin ( self . f * np . pi * self . x ) * xp . exp ( - self . nu * ( self . f * np . pi ) ** 2 * t )
+
+ ( self . b - self . a ) / 2 * self . x
+
+ ( self . b + self . a ) / 2
+
)
+
+
if noise > 0 :
+
assert t == 0
+
_noise = self . u_init
+
rng = self . xp . random . default_rng ( seed = seed )
+
_noise [ iu ] = rng . normal ( size = u [ iu ] . shape )
+
noise_hat = self . transform ( _noise )
+
low_pass = self . get_filter_matrix ( axis = 0 , kmax = self . nvars - 2 )
+
noise_hat [ iu ] = ( low_pass @ noise_hat [ iu ] . flatten ()) . reshape ( noise_hat [ iu ] . shape )
+
_noise [:] = self . itransform ( noise_hat )
+
u += _noise * noise * ( self . x - 1 ) * ( self . x + 1 )
+
+
self . check_BCs ( u )
+
+
if self . spectral_space :
+
return self . transform ( u )
+
else :
+
return u
+
+
+
+
+
+
[docs]
+
class Heat2DChebychev ( GenericSpectralLinear ):
+
"""
+
2D Heat equation with Dirichlet Boundary conditions discretized on (-1, 1)x(-1,1) using spectral methods based on FFT and Chebychev.
+
"""
+
+
dtype_u = mesh
+
dtype_f = mesh
+
+
def __init__ ( self , nx = 128 , ny = 128 , base_x = 'fft' , base_y = 'chebychev' , a = 0 , b = 0 , c = 0 , fx = 1 , fy = 1 , nu = 1.0 , ** kwargs ):
+
"""
+
Constructor. `kwargs` are forwarded to parent class constructor.
+
+
Args:
+
nx (int): Resolution in x-direction
+
ny (int): Resolution in y-direction
+
base_x (str): Spectral base in x-direction
+
base_y (str): Spectral base in y-direction
+
a (float): BC at y=0 and x=-1
+
b (float): BC at y=0 and x=+1
+
c (float): BC at y=1 and x = -1
+
fx (int): Horizontal frequency of initial conditions
+
fy (int): Vertical frequency of initial conditions
+
nu (float): Diffusion parameter
+
"""
+
assert nx % 2 == 1 or base_x == 'fft'
+
assert ny % 2 == 1 or base_y == 'fft'
+
self . _makeAttributeAndRegister (
+
'nx' , 'ny' , 'base_x' , 'base_y' , 'a' , 'b' , 'c' , 'fx' , 'fy' , 'nu' , localVars = locals (), readOnly = True
+
)
+
+
bases = [{ 'base' : base_x , 'N' : nx }, { 'base' : base_y , 'N' : ny }]
+
components = [ 'u' , 'ux' , 'uy' ]
+
+
super () . __init__ ( bases , components , Dirichlet_recombination = False , spectral_space = False , ** kwargs )
+
+
self . Y , self . X = self . get_grid ()
+
+
I = self . get_Id ()
+
self . Dx = self . get_differentiation_matrix ( axes = ( 0 ,))
+
self . Dy = self . get_differentiation_matrix ( axes = ( 1 ,))
+
+
L_lhs = {
+
'ux' : { 'u' : - self . Dx , 'ux' : I },
+
'uy' : { 'u' : - self . Dy , 'uy' : I },
+
'u' : { 'ux' : - nu * self . Dx , 'uy' : - nu * self . Dy },
+
}
+
self . setup_L ( L_lhs )
+
+
M_lhs = { 'u' : { 'u' : I }}
+
self . setup_M ( M_lhs )
+
+
for base in [ base_x , base_y ]:
+
assert base in [ 'chebychev' , 'fft' ]
+
+
alpha = ( self . b - self . a ) / 2.0
+
beta = ( self . c - self . b ) / 2.0
+
gamma = ( self . c + self . a ) / 2.0
+
+
if base_x == 'chebychev' :
+
y = self . Y [ 0 , :]
+
if self . base_y == 'fft' :
+
self . add_BC ( component = 'u' , equation = 'u' , axis = 0 , x =- 1 , v = beta * y - alpha + gamma , kind = 'Dirichlet' )
+
self . add_BC ( component = 'ux' , equation = 'ux' , axis = 0 , v = 2 * alpha , kind = 'integral' )
+
else :
+
assert a == b , f 'Need periodic boundary conditions in x for { base_x } method!'
+
if base_y == 'chebychev' :
+
x = self . X [:, 0 ]
+
self . add_BC ( component = 'u' , equation = 'u' , axis = 1 , x =- 1 , v = alpha * x - beta + gamma , kind = 'Dirichlet' )
+
self . add_BC ( component = 'uy' , equation = 'uy' , axis = 1 , v = 2 * beta , kind = 'integral' )
+
else :
+
assert c == b , f 'Need periodic boundary conditions in y for { base_y } method!'
+
self . setup_BCs ()
+
+
+
[docs]
+
def eval_f ( self , u , * args , ** kwargs ):
+
f = self . f_init
+
iu , iux , iuy = self . index ( self . components )
+
+
me_hat = self . u_init_forward
+
me_hat [:] = self . transform ( u )
+
me_hat [ iu ] = self . nu * ( self . Dx @ me_hat [ iux ] . flatten () + self . Dy @ me_hat [ iuy ] . flatten ()) . reshape (
+
me_hat [ iu ] . shape
+
)
+
me = self . itransform ( me_hat )
+
+
f [ self . index ( "u" )] = me [ iu ] . real
+
return f
+
+
+
+
[docs]
+
def u_exact ( self , t ):
+
xp = self . xp
+
iu , iux , iuy = self . index ( self . components )
+
u = self . u_init
+
+
fx = self . fx if self . base_x == 'fft' else np . pi * self . fx
+
fy = self . fy if self . base_y == 'fft' else np . pi * self . fy
+
+
time_dep = xp . exp ( - self . nu * ( fx ** 2 + fy ** 2 ) * t )
+
+
alpha = ( self . b - self . a ) / 2.0
+
beta = ( self . c - self . b ) / 2.0
+
gamma = ( self . c + self . a ) / 2.0
+
+
u [ iu ] = xp . sin ( fx * self . X ) * xp . sin ( fy * self . Y ) * time_dep + alpha * self . X + beta * self . Y + gamma
+
u [ iux ] = fx * xp . cos ( fx * self . X ) * xp . sin ( fy * self . Y ) * time_dep + alpha
+
u [ iuy ] = fy * xp . sin ( fx * self . X ) * xp . cos ( fy * self . Y ) * time_dep + beta
+
+
return u
+
+
+
+
+
+
[docs]
+
class Heat2DUltraspherical ( GenericSpectralLinear ):
+
"""
+
2D Heat equation with Dirichlet Boundary conditions discretized on (-1, 1)x(-1,1) using spectral methods based on FFT and Gegenbauer.
+
"""
+
+
dtype_u = mesh
+
dtype_f = mesh
+
+
def __init__ (
+
self , nx = 128 , ny = 128 , base_x = 'fft' , base_y = 'ultraspherical' , a = 0 , b = 0 , c = 0 , fx = 1 , fy = 1 , nu = 1.0 , ** kwargs
+
):
+
"""
+
Constructor. `kwargs` are forwarded to parent class constructor.
+
+
Args:
+
nx (int): Resolution in x-direction
+
ny (int): Resolution in y-direction
+
base_x (str): Spectral base in x-direction
+
base_y (str): Spectral base in y-direction
+
a (float): BC at y=0 and x=-1
+
b (float): BC at y=0 and x=+1
+
c (float): BC at y=1 and x = -1
+
fx (int): Horizontal frequency of initial conditions
+
fy (int): Vertical frequency of initial conditions
+
nu (float): Diffusion parameter
+
"""
+
self . _makeAttributeAndRegister (
+
'nx' , 'ny' , 'base_x' , 'base_y' , 'a' , 'b' , 'c' , 'fx' , 'fy' , 'nu' , localVars = locals (), readOnly = True
+
)
+
+
bases = [{ 'base' : base_x , 'N' : nx }, { 'base' : base_y , 'N' : ny }]
+
components = [ 'u' ]
+
+
super () . __init__ ( bases , components , Dirichlet_recombination = False , spectral_space = False , ** kwargs )
+
+
self . Y , self . X = self . get_grid ()
+
+
self . Dxx = self . get_differentiation_matrix ( axes = ( 0 ,), p = 2 )
+
self . Dyy = self . get_differentiation_matrix ( axes = ( 1 ,), p = 2 )
+
self . S2 = self . get_basis_change_matrix ( p = 2 )
+
I = self . get_Id ()
+
+
L_lhs = {
+
'u' : { 'u' : - nu * self . Dxx - nu * self . Dyy },
+
}
+
self . setup_L ( L_lhs )
+
+
M_lhs = { 'u' : { 'u' : I }}
+
self . setup_M ( M_lhs )
+
+
for base in [ base_x , base_y ]:
+
assert base in [ 'ultraspherical' , 'fft' ]
+
+
alpha = ( self . b - self . a ) / 2.0
+
beta = ( self . c - self . b ) / 2.0
+
gamma = ( self . c + self . a ) / 2.0
+
+
if base_x == 'ultraspherical' :
+
y = self . Y [ 0 , :]
+
if self . base_y == 'fft' :
+
self . add_BC ( component = 'u' , equation = 'u' , axis = 0 , x =- 1 , v = beta * y - alpha + gamma , kind = 'Dirichlet' )
+
self . add_BC ( component = 'u' , equation = 'u' , axis = 0 , v = beta * y + alpha + gamma , x = 1 , line =- 2 , kind = 'Dirichlet' )
+
else :
+
assert a == b , f 'Need periodic boundary conditions in x for { base_x } method!'
+
if base_y == 'ultraspherical' :
+
x = self . X [:, 0 ]
+
self . add_BC (
+
component = 'u' , equation = 'u' , axis = 1 , x =- 1 , v = alpha * x - beta + gamma , kind = 'Dirichlet' , line =- 1
+
)
+
self . add_BC (
+
component = 'u' , equation = 'u' , axis = 1 , x =+ 1 , v = alpha * x + beta + gamma , kind = 'Dirichlet' , line =- 2
+
)
+
else :
+
assert c == b , f 'Need periodic boundary conditions in y for { base_y } method!'
+
self . setup_BCs ()
+
+
+
[docs]
+
def eval_f ( self , u , * args , ** kwargs ):
+
f = self . f_init
+
iu = self . index ( 'u' )
+
+
me_hat = self . u_init_forward
+
me_hat [:] = self . transform ( u )
+
me_hat [ iu ] = self . nu * ( self . S2 @ ( self . Dxx + self . Dyy ) @ me_hat [ iu ] . flatten ()) . reshape ( me_hat [ iu ] . shape )
+
me = self . itransform ( me_hat )
+
+
f [ iu ] = me [ iu ] . real
+
return f
+
+
+
+
[docs]
+
def u_exact ( self , t ):
+
xp = self . xp
+
iu = self . index ( 'u' )
+
u = self . u_init
+
+
fx = self . fx if self . base_x == 'fft' else np . pi * self . fx
+
fy = self . fy if self . base_y == 'fft' else np . pi * self . fy
+
+
time_dep = xp . exp ( - self . nu * ( fx ** 2 + fy ** 2 ) * t )
+
+
alpha = ( self . b - self . a ) / 2.0
+
beta = ( self . c - self . b ) / 2.0
+
gamma = ( self . c + self . a ) / 2.0
+
+
u [ iu ] = xp . sin ( fx * self . X ) * xp . sin ( fy * self . Y ) * time_dep + alpha * self . X + beta * self . Y + gamma
+
+
return u
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/_modules/implementations/problem_classes/RayleighBenard.html b/_modules/implementations/problem_classes/RayleighBenard.html
new file mode 100644
index 0000000000..1d1fd18cd2
--- /dev/null
+++ b/_modules/implementations/problem_classes/RayleighBenard.html
@@ -0,0 +1,698 @@
+
+
+
+
+
+
+ implementations.problem_classes.RayleighBenard — pySDC 5.5.1 documentation
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Source code for implementations.problem_classes.RayleighBenard
+import numpy as np
+from mpi4py import MPI
+
+from pySDC.implementations.problem_classes.generic_spectral import GenericSpectralLinear
+from pySDC.implementations.datatype_classes.mesh import mesh , imex_mesh
+from pySDC.core.convergence_controller import ConvergenceController
+from pySDC.core.hooks import Hooks
+from pySDC.implementations.convergence_controller_classes.check_convergence import CheckConvergence
+
+
+
+
[docs]
+
class RayleighBenard ( GenericSpectralLinear ):
+
"""
+
Rayleigh-Benard Convection is a variation of incompressible Navier-Stokes.
+
+
The equations we solve are
+
+
u_x + v_z = 0
+
T_t - kappa (T_xx + T_zz) = -uT_x - vT_z
+
u_t - nu (u_xx + u_zz) + p_x = -uu_x - vu_z
+
v_t - nu (v_xx + v_zz) + p_z - T = -uv_x - vv_z
+
+
with u the horizontal velocity, v the vertical velocity (in z-direction), T the temperature, p the pressure, indices
+
denoting derivatives, kappa=(Rayleigh * Prandl)**(-1/2) and nu = (Rayleigh / Prandl)**(-1/2). Everything on the left
+
hand side, that is the viscous part, the pressure gradient and the buoyancy due to temperature are treated
+
implicitly, while the non-linear convection part on the right hand side is integrated explicitly.
+
+
The domain, vertical boundary conditions and pressure gauge are
+
+
Omega = [0, 8) x (-1, 1)
+
T(z=+1) = 0
+
T(z=-1) = 2
+
u(z=+-1) = v(z=+-1) = 0
+
integral over p = 0
+
+
The spectral discretization uses FFT horizontally, implying periodic BCs, and an ultraspherical method vertically to
+
facilitate the Dirichlet BCs.
+
+
Parameters:
+
Prandl (float): Prandl number
+
Rayleigh (float): Rayleigh number
+
nx (int): Horizontal resolution
+
nz (int): Vertical resolution
+
BCs (dict): Can specify boundary conditions here
+
dealiasing (float): Dealiasing factor for evaluating the non-linear part
+
comm (mpi4py.Intracomm): Space communicator
+
"""
+
+
dtype_u = mesh
+
dtype_f = imex_mesh
+
+
def __init__ (
+
self ,
+
Prandl = 1 ,
+
Rayleigh = 2e6 ,
+
nx = 256 ,
+
nz = 64 ,
+
BCs = None ,
+
dealiasing = 3 / 2 ,
+
comm = None ,
+
** kwargs ,
+
):
+
"""
+
Constructor. `kwargs` are forwarded to parent class constructor.
+
+
Args:
+
Prandl (float): Prandtl number
+
Rayleigh (float): Rayleigh number
+
nx (int): Resolution in x-direction
+
nz (int): Resolution in z direction
+
BCs (dict): Vertical boundary conditions
+
dealiasing (float): Dealiasing for evaluating the non-linear part in real space
+
comm (mpi4py.Intracomm): Space communicator
+
"""
+
BCs = {} if BCs is None else BCs
+
BCs = {
+
'T_top' : 0 ,
+
'T_bottom' : 2 ,
+
'v_top' : 0 ,
+
'v_bottom' : 0 ,
+
'u_top' : 0 ,
+
'u_bottom' : 0 ,
+
'p_integral' : 0 ,
+
** BCs ,
+
}
+
if comm is None :
+
try :
+
from mpi4py import MPI
+
+
comm = MPI . COMM_WORLD
+
except ModuleNotFoundError :
+
pass
+
self . _makeAttributeAndRegister (
+
'Prandl' ,
+
'Rayleigh' ,
+
'nx' ,
+
'nz' ,
+
'BCs' ,
+
'dealiasing' ,
+
'comm' ,
+
localVars = locals (),
+
readOnly = True ,
+
)
+
+
bases = [{ 'base' : 'fft' , 'N' : nx , 'x0' : 0 , 'x1' : 8 }, { 'base' : 'ultraspherical' , 'N' : nz }]
+
components = [ 'u' , 'v' , 'T' , 'p' ]
+
super () . __init__ ( bases , components , comm = comm , ** kwargs )
+
+
self . Z , self . X = self . get_grid ()
+
self . Kz , self . Kx = self . get_wavenumbers ()
+
+
# construct 2D matrices
+
Dzz = self . get_differentiation_matrix ( axes = ( 1 ,), p = 2 )
+
Dz = self . get_differentiation_matrix ( axes = ( 1 ,))
+
Dx = self . get_differentiation_matrix ( axes = ( 0 ,))
+
Dxx = self . get_differentiation_matrix ( axes = ( 0 ,), p = 2 )
+
Id = self . get_Id ()
+
+
S1 = self . get_basis_change_matrix ( p_out = 0 , p_in = 1 )
+
S2 = self . get_basis_change_matrix ( p_out = 0 , p_in = 2 )
+
+
U01 = self . get_basis_change_matrix ( p_in = 0 , p_out = 1 )
+
U12 = self . get_basis_change_matrix ( p_in = 1 , p_out = 2 )
+
U02 = self . get_basis_change_matrix ( p_in = 0 , p_out = 2 )
+
+
self . Dx = Dx
+
self . Dxx = Dxx
+
self . Dz = S1 @ Dz
+
self . Dzz = S2 @ Dzz
+
+
kappa = ( Rayleigh * Prandl ) ** ( - 1 / 2.0 )
+
nu = ( Rayleigh / Prandl ) ** ( - 1 / 2.0 )
+
+
# construct operators
+
L_lhs = {
+
'p' : { 'u' : U01 @ Dx , 'v' : Dz }, # divergence free constraint
+
'u' : { 'p' : U02 @ Dx , 'u' : - nu * ( U02 @ Dxx + Dzz )},
+
'v' : { 'p' : U12 @ Dz , 'v' : - nu * ( U02 @ Dxx + Dzz ), 'T' : - U02 @ Id },
+
'T' : { 'T' : - kappa * ( U02 @ Dxx + Dzz )},
+
}
+
self . setup_L ( L_lhs )
+
+
# mass matrix
+
M_lhs = { i : { i : U02 @ Id } for i in [ 'u' , 'v' , 'T' ]}
+
self . setup_M ( M_lhs )
+
+
# Prepare going from second (first for divergence free equation) derivative basis back to Chebychov-T
+
self . base_change = self . _setup_operator ({ ** { comp : { comp : S2 } for comp in [ 'u' , 'v' , 'T' ]}, 'p' : { 'p' : S1 }})
+
+
# BCs
+
self . add_BC (
+
component = 'p' , equation = 'p' , axis = 1 , v = self . BCs [ 'p_integral' ], kind = 'integral' , line =- 1 , scalar = True
+
)
+
self . add_BC ( component = 'T' , equation = 'T' , axis = 1 , x =- 1 , v = self . BCs [ 'T_bottom' ], kind = 'Dirichlet' , line =- 1 )
+
self . add_BC ( component = 'T' , equation = 'T' , axis = 1 , x = 1 , v = self . BCs [ 'T_top' ], kind = 'Dirichlet' , line =- 2 )
+
self . add_BC ( component = 'v' , equation = 'v' , axis = 1 , x = 1 , v = self . BCs [ 'v_bottom' ], kind = 'Dirichlet' , line =- 1 )
+
self . add_BC ( component = 'v' , equation = 'v' , axis = 1 , x =- 1 , v = self . BCs [ 'v_bottom' ], kind = 'Dirichlet' , line =- 2 )
+
self . remove_BC ( component = 'v' , equation = 'v' , axis = 1 , x =- 1 , kind = 'Dirichlet' , line =- 2 , scalar = True )
+
self . add_BC ( component = 'u' , equation = 'u' , axis = 1 , v = self . BCs [ 'u_top' ], x = 1 , kind = 'Dirichlet' , line =- 2 )
+
self . add_BC (
+
component = 'u' ,
+
equation = 'u' ,
+
axis = 1 ,
+
v = self . BCs [ 'u_bottom' ],
+
x =- 1 ,
+
kind = 'Dirichlet' ,
+
line =- 1 ,
+
)
+
+
# eliminate Nyquist mode if needed
+
if nx % 2 == 0 :
+
Nyquist_mode_index = self . axes [ 0 ] . get_Nyquist_mode_index ()
+
for component in self . components :
+
self . add_BC (
+
component = component , equation = component , axis = 0 , kind = 'Nyquist' , line = int ( Nyquist_mode_index ), v = 0
+
)
+
self . setup_BCs ()
+
+
+
[docs]
+
def eval_f ( self , u , * args , ** kwargs ):
+
f = self . f_init
+
+
if self . spectral_space :
+
u_hat = u . copy ()
+
else :
+
u_hat = self . transform ( u )
+
+
f_impl_hat = self . u_init_forward
+
+
Dz = self . Dz
+
Dx = self . Dx
+
+
iu , iv , iT , ip = self . index ([ 'u' , 'v' , 'T' , 'p' ])
+
+
# evaluate implicit terms
+
f_impl_hat = - ( self . base_change @ self . L @ u_hat . flatten ()) . reshape ( u_hat . shape )
+
+
if self . spectral_space :
+
f . impl [:] = f_impl_hat
+
else :
+
f . impl [:] = self . itransform ( f_impl_hat ) . real
+
+
# treat convection explicitly with dealiasing
+
Dx_u_hat = self . u_init_forward
+
for i in [ iu , iv , iT ]:
+
Dx_u_hat [ i ][:] = ( Dx @ u_hat [ i ] . flatten ()) . reshape ( Dx_u_hat [ i ] . shape )
+
Dz_u_hat = self . u_init_forward
+
for i in [ iu , iv , iT ]:
+
Dz_u_hat [ i ][:] = ( Dz @ u_hat [ i ] . flatten ()) . reshape ( Dz_u_hat [ i ] . shape )
+
+
padding = [ self . dealiasing , self . dealiasing ]
+
Dx_u_pad = self . itransform ( Dx_u_hat , padding = padding ) . real
+
Dz_u_pad = self . itransform ( Dz_u_hat , padding = padding ) . real
+
u_pad = self . itransform ( u_hat , padding = padding ) . real
+
+
fexpl_pad = self . xp . zeros_like ( u_pad )
+
fexpl_pad [ iu ][:] = - ( u_pad [ iu ] * Dx_u_pad [ iu ] + u_pad [ iv ] * Dz_u_pad [ iu ])
+
fexpl_pad [ iv ][:] = - ( u_pad [ iu ] * Dx_u_pad [ iv ] + u_pad [ iv ] * Dz_u_pad [ iv ])
+
fexpl_pad [ iT ][:] = - ( u_pad [ iu ] * Dx_u_pad [ iT ] + u_pad [ iv ] * Dz_u_pad [ iT ])
+
+
if self . spectral_space :
+
f . expl [:] = self . transform ( fexpl_pad , padding = padding )
+
else :
+
f . expl [:] = self . itransform ( self . transform ( fexpl_pad , padding = padding )) . real
+
+
return f
+
+
+
+
[docs]
+
def u_exact ( self , t = 0 , noise_level = 1e-3 , seed = 99 ):
+
assert t == 0
+
assert (
+
self . BCs [ 'v_top' ] == self . BCs [ 'v_bottom' ]
+
), 'Initial conditions are only implemented for zero velocity gradient'
+
+
me = self . spectral . u_init
+
iu , iv , iT , ip = self . index ([ 'u' , 'v' , 'T' , 'p' ])
+
+
# linear temperature gradient
+
for comp in [ 'T' , 'v' , 'u' ]:
+
a = ( self . BCs [ f ' { comp } _top' ] - self . BCs [ f ' { comp } _bottom' ]) / 2
+
b = ( self . BCs [ f ' { comp } _top' ] + self . BCs [ f ' { comp } _bottom' ]) / 2
+
me [ self . index ( comp )] = a * self . Z + b
+
+
# perturb slightly
+
rng = self . xp . random . default_rng ( seed = seed )
+
+
noise = self . spectral . u_init
+
noise [ iT ] = rng . random ( size = me [ iT ] . shape )
+
+
me [ iT ] += noise [ iT ] . real * noise_level * ( self . Z - 1 ) * ( self . Z + 1 )
+
+
if self . spectral_space :
+
me_hat = self . spectral . u_init_forward
+
me_hat [:] = self . transform ( me )
+
return me_hat
+
else :
+
return me
+
+
+
+
[docs]
+
def get_fig ( self ): # pragma: no cover
+
"""
+
Get a figure suitable to plot the solution of this problem
+
+
Returns
+
-------
+
self.fig : matplotlib.pyplot.figure.Figure
+
"""
+
import matplotlib.pyplot as plt
+
from mpl_toolkits.axes_grid1 import make_axes_locatable
+
+
plt . rcParams [ 'figure.constrained_layout.use' ] = True
+
self . fig , axs = plt . subplots ( 2 , 1 , sharex = True , sharey = True , figsize = (( 10 , 5 )))
+
self . cax = []
+
divider = make_axes_locatable ( axs [ 0 ])
+
self . cax += [ divider . append_axes ( 'right' , size = '3%' , pad = 0.03 )]
+
divider2 = make_axes_locatable ( axs [ 1 ])
+
self . cax += [ divider2 . append_axes ( 'right' , size = '3%' , pad = 0.03 )]
+
return self . fig
+
+
+
+
[docs]
+
def plot ( self , u , t = None , fig = None , quantity = 'T' ): # pragma: no cover
+
r """
+
Plot the solution.
+
+
Parameters
+
----------
+
u : dtype_u
+
Solution to be plotted
+
t : float
+
Time to display at the top of the figure
+
fig : matplotlib.pyplot.figure.Figure
+
Figure with the same structure as a figure generated by `self.get_fig`. If none is supplied, a new figure will be generated.
+
quantity : (str)
+
quantity you want to plot
+
+
Returns
+
-------
+
None
+
"""
+
fig = self . get_fig () if fig is None else fig
+
axs = fig . axes
+
+
imV = axs [ 1 ] . pcolormesh ( self . X , self . Z , self . compute_vorticity ( u ) . real )
+
+
if self . spectral_space :
+
u = self . itransform ( u )
+
+
imT = axs [ 0 ] . pcolormesh ( self . X , self . Z , u [ self . index ( quantity )] . real )
+
+
for i , label in zip ([ 0 , 1 ], [ rf '$ { quantity } $' , 'vorticity' ]):
+
axs [ i ] . set_aspect ( 1 )
+
axs [ i ] . set_title ( label )
+
+
if t is not None :
+
fig . suptitle ( f 't = { t : .2f } ' )
+
axs [ 1 ] . set_xlabel ( r '$x$' )
+
axs [ 1 ] . set_ylabel ( r '$z$' )
+
fig . colorbar ( imT , self . cax [ 0 ])
+
fig . colorbar ( imV , self . cax [ 1 ])
+
+
+
+
[docs]
+
def compute_vorticity ( self , u ):
+
if self . spectral_space :
+
u_hat = u . copy ()
+
else :
+
u_hat = self . transform ( u )
+
Dz = self . Dz
+
Dx = self . Dx
+
iu , iv = self . index ([ 'u' , 'v' ])
+
+
vorticity_hat = self . spectral . u_init_forward
+
vorticity_hat [ 0 ] = ( Dx * u_hat [ iv ] . flatten () + Dz @ u_hat [ iu ] . flatten ()) . reshape ( u [ iu ] . shape )
+
return self . itransform ( vorticity_hat )[ 0 ] . real
+
+
+
+
[docs]
+
def compute_Nusselt_numbers ( self , u ):
+
"""
+
Compute the various versions of the Nusselt number. This reflects the type of heat transport.
+
If the Nusselt number is equal to one, it indicates heat transport due to conduction. If it is larger,
+
advection is present.
+
Computing the Nusselt number at various places can be used to check the code.
+
+
Args:
+
u: The solution you want to compute the Nusselt numbers of
+
+
Returns:
+
dict: Nusselt number averaged over the entire volume and horizontally averaged at the top and bottom.
+
"""
+
iv , iT = self . index ([ 'v' , 'T' ])
+
+
DzT_hat = self . spectral . u_init_forward
+
+
if self . spectral_space :
+
u_hat = u . copy ()
+
else :
+
u_hat = self . transform ( u )
+
+
DzT_hat [ iT ] = ( self . Dz @ u_hat [ iT ] . flatten ()) . reshape ( DzT_hat [ iT ] . shape )
+
+
# compute vT with dealiasing
+
padding = [ self . dealiasing , self . dealiasing ]
+
u_pad = self . itransform ( u_hat , padding = padding ) . real
+
_me = self . xp . zeros_like ( u_pad )
+
_me [ 0 ] = u_pad [ iv ] * u_pad [ iT ]
+
vT_hat = self . transform ( _me , padding = padding )
+
+
nusselt_hat = ( vT_hat [ 0 ] - DzT_hat [ iT ]) / self . nx
+
nusselt_no_v_hat = ( - DzT_hat [ iT ]) / self . nx
+
+
integral_z = self . xp . sum ( nusselt_hat * self . spectral . axes [ 1 ] . get_BC ( kind = 'integral' ), axis =- 1 ) . real
+
integral_V = (
+
integral_z [ 0 ] * self . axes [ 0 ] . L
+
) # only the first Fourier mode has non-zero integral with periodic BCs
+
Nusselt_V = self . comm . bcast ( integral_V / self . spectral . V , root = 0 )
+
+
Nusselt_t = self . comm . bcast (
+
self . xp . sum ( nusselt_hat * self . spectral . axes [ 1 ] . get_BC ( kind = 'Dirichlet' , x = 1 ), axis =- 1 ) . real [ 0 ], root = 0
+
)
+
Nusselt_b = self . comm . bcast (
+
self . xp . sum ( nusselt_hat * self . spectral . axes [ 1 ] . get_BC ( kind = 'Dirichlet' , x =- 1 ), axis =- 1 ) . real [ 0 ], root = 0
+
)
+
Nusselt_no_v_t = self . comm . bcast (
+
self . xp . sum ( nusselt_no_v_hat * self . spectral . axes [ 1 ] . get_BC ( kind = 'Dirichlet' , x = 1 ), axis =- 1 ) . real [ 0 ], root = 0
+
)
+
Nusselt_no_v_b = self . comm . bcast (
+
self . xp . sum ( nusselt_no_v_hat * self . spectral . axes [ 1 ] . get_BC ( kind = 'Dirichlet' , x =- 1 ), axis =- 1 ) . real [ 0 ],
+
root = 0 ,
+
)
+
+
return {
+
'V' : Nusselt_V ,
+
't' : Nusselt_t ,
+
'b' : Nusselt_b ,
+
't_no_v' : Nusselt_no_v_t ,
+
'b_no_v' : Nusselt_no_v_b ,
+
}
+
+
+
+
[docs]
+
def compute_viscous_dissipation ( self , u ):
+
iu , iv = self . index ([ 'u' , 'v' ])
+
+
Lap_u_hat = self . spectral . u_init_forward
+
+
if self . spectral_space :
+
u_hat = u . copy ()
+
else :
+
u_hat = self . transform ( u )
+
Lap_u_hat [ iu ] = (( self . Dzz + self . Dxx ) @ u_hat [ iu ] . flatten ()) . reshape ( u_hat [ iu ] . shape )
+
Lap_u_hat [ iv ] = (( self . Dzz + self . Dxx ) @ u_hat [ iv ] . flatten ()) . reshape ( u_hat [ iu ] . shape )
+
Lap_u = self . itransform ( Lap_u_hat )
+
+
return abs ( u [ iu ] * Lap_u [ iu ] + u [ iv ] * Lap_u [ iv ])
+
+
+
+
[docs]
+
def compute_buoyancy_generation ( self , u ):
+
if self . spectral_space :
+
u = self . itransform ( u )
+
iv , iT = self . index ([ 'v' , 'T' ])
+
return abs ( u [ iv ] * self . Rayleigh * u [ iT ])
+
+
+
+
+
+
[docs]
+
class CFLLimit ( ConvergenceController ):
+
+
+
[docs]
+
def dependencies ( self , controller , * args , ** kwargs ):
+
from pySDC.implementations.hooks.log_step_size import LogStepSize
+
+
controller . add_hook ( LogCFL )
+
controller . add_hook ( LogStepSize )
+
+
+
+
[docs]
+
def setup_status_variables ( self , controller , ** kwargs ):
+
"""
+
Add the embedded error variable to the error function.
+
+
Args:
+
controller (pySDC.Controller): The controller
+
"""
+
self . add_status_variable_to_level ( 'CFL_limit' )
+
+
+
+
[docs]
+
def setup ( self , controller , params , description , ** kwargs ):
+
"""
+
Define default parameters here.
+
+
Default parameters are:
+
- control_order (int): The order relative to other convergence controllers
+
- dt_max (float): maximal step size
+
- dt_min (float): minimal step size
+
+
Args:
+
controller (pySDC.Controller): The controller
+
params (dict): The params passed for this specific convergence controller
+
description (dict): The description object used to instantiate the controller
+
+
Returns:
+
(dict): The updated params dictionary
+
"""
+
defaults = {
+
"control_order" : - 50 ,
+
"dt_max" : np . inf ,
+
"dt_min" : 0 ,
+
"cfl" : 0.4 ,
+
}
+
return { ** defaults , ** super () . setup ( controller , params , description , ** kwargs )}
+
+
+
+
[docs]
+
@staticmethod
+
def compute_max_step_size ( P , u ):
+
grid_spacing_x = P . X [ 1 , 0 ] - P . X [ 0 , 0 ]
+
+
cell_wallz = P . xp . zeros ( P . nz + 1 )
+
cell_wallz [ 0 ] = 1
+
cell_wallz [ - 1 ] = - 1
+
cell_wallz [ 1 : - 1 ] = ( P . Z [ 0 , : - 1 ] + P . Z [ 0 , 1 :]) / 2
+
grid_spacing_z = cell_wallz [: - 1 ] - cell_wallz [ 1 :]
+
+
iu , iv = P . index ([ 'u' , 'v' ])
+
+
if P . spectral_space :
+
u = P . itransform ( u )
+
+
max_step_size_x = P . xp . min ( grid_spacing_x / P . xp . abs ( u [ iu ]))
+
max_step_size_z = P . xp . min ( grid_spacing_z / P . xp . abs ( u [ iv ]))
+
max_step_size = min ([ max_step_size_x , max_step_size_z ])
+
+
if hasattr ( P , 'comm' ):
+
max_step_size = P . comm . allreduce ( max_step_size , op = MPI . MIN )
+
return float ( max_step_size )
+
+
+
+
[docs]
+
def get_new_step_size ( self , controller , step , ** kwargs ):
+
if not CheckConvergence . check_convergence ( step ):
+
return None
+
+
L = step . levels [ 0 ]
+
P = step . levels [ 0 ] . prob
+
+
L . sweep . compute_end_point ()
+
max_step_size = self . compute_max_step_size ( P , L . uend )
+
+
L . status . CFL_limit = self . params . cfl * max_step_size
+
+
dt_new = L . status . dt_new if L . status . dt_new else max ([ self . params . dt_max , L . params . dt ])
+
L . status . dt_new = min ([ dt_new , self . params . cfl * max_step_size ])
+
L . status . dt_new = max ([ self . params . dt_min , L . status . dt_new ])
+
+
self . log ( f 'dt max: { max_step_size : .2e } -> New step size: { L . status . dt_new : .2e } ' , step )
+
+
+
+
+
+
[docs]
+
class LogCFL ( Hooks ):
+
+
+
[docs]
+
def post_step ( self , step , level_number ):
+
"""
+
Record CFL limit.
+
+
Args:
+
step (pySDC.Step.step): the current step
+
level_number (int): the current level number
+
+
Returns:
+
None
+
"""
+
super () . post_step ( step , level_number )
+
+
L = step . levels [ level_number ]
+
+
self . add_to_stats (
+
process = step . status . slot ,
+
time = L . time + L . dt ,
+
level = L . level_index ,
+
iter = step . status . iter ,
+
sweep = L . status . sweep ,
+
type = 'CFL_limit' ,
+
value = L . status . CFL_limit ,
+
)
+
+
+
+
+
+
[docs]
+
class LogAnalysisVariables ( Hooks ):
+
+
+
[docs]
+
def post_step ( self , step , level_number ):
+
"""
+
Record Nusselt numbers.
+
+
Args:
+
step (pySDC.Step.step): the current step
+
level_number (int): the current level number
+
+
Returns:
+
None
+
"""
+
super () . post_step ( step , level_number )
+
+
L = step . levels [ level_number ]
+
P = L . prob
+
+
L . sweep . compute_end_point ()
+
Nusselt = P . compute_Nusselt_numbers ( L . uend )
+
buoyancy_production = P . compute_buoyancy_generation ( L . uend )
+
viscous_dissipation = P . compute_viscous_dissipation ( L . uend )
+
+
for key , value in zip (
+
[ 'Nusselt' , 'buoyancy_production' , 'viscous_dissipation' ],
+
[ Nusselt , buoyancy_production , viscous_dissipation ],
+
):
+
self . add_to_stats (
+
process = step . status . slot ,
+
time = L . time + L . dt ,
+
level = L . level_index ,
+
iter = step . status . iter ,
+
sweep = L . status . sweep ,
+
type = key ,
+
value = value ,
+
)
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/_modules/implementations/problem_classes/generic_spectral.html b/_modules/implementations/problem_classes/generic_spectral.html
new file mode 100644
index 0000000000..c60f6ca076
--- /dev/null
+++ b/_modules/implementations/problem_classes/generic_spectral.html
@@ -0,0 +1,494 @@
+
+
+
+
+
+
+ implementations.problem_classes.generic_spectral — pySDC 5.5.1 documentation
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
Source code for implementations.problem_classes.generic_spectral
+from pySDC.core.problem import Problem , WorkCounter
+from pySDC.helpers.spectral_helper import SpectralHelper
+import numpy as np
+from pySDC.core.errors import ParameterError
+
+
+
+
[docs]
+
class GenericSpectralLinear ( Problem ):
+
"""
+
Generic class to solve problems of the form M u_t + L u = y, with mass matrix M, linear operator L and some right
+
hand side y using spectral methods.
+
L may contain algebraic conditions, as long as (M + dt L) is invertible.
+
+
Note that the `__getattr__` method is overloaded to pass requests on to the spectral helper if they are not
+
attributes of this class itself. For instance, you can add a BC by calling `self.spectral.add_BC` or equivalently
+
`self.add_BC`.
+
+
You can port problems derived from this more or less seamlessly to GPU by using the numerical libraries that are
+
class attributes of the spectral helper. This class will automatically switch the datatype using the `setup_GPU` class method.
+
+
Attributes:
+
spectral (pySDC.helpers.spectral_helper.SpectralHelper): Spectral helper
+
work_counters (dict): Dictionary for counting work
+
cached_factorizations (dict): Dictionary of cached matrix factorizations for solving
+
L (sparse matrix): Linear operator
+
M (sparse matrix): Mass matrix
+
diff_mask (list): Mask for separating differential and algebraic terms
+
Pl (sparse matrix): Left preconditioner
+
Pr (sparse matrix): Right preconditioner
+
"""
+
+
+
[docs]
+
@classmethod
+
def setup_GPU ( cls ):
+
"""switch to GPU modules"""
+
import cupy as cp
+
from pySDC.implementations.datatype_classes.cupy_mesh import cupy_mesh , imex_cupy_mesh
+
from pySDC.implementations.datatype_classes.mesh import mesh , imex_mesh
+
+
cls . dtype_u = cupy_mesh
+
+
GPU_versions = {
+
mesh : cupy_mesh ,
+
imex_mesh : imex_cupy_mesh ,
+
}
+
+
cls . dtype_f = GPU_versions [ cls . dtype_f ]
+
+
+
def __init__ (
+
self ,
+
bases ,
+
components ,
+
comm = None ,
+
Dirichlet_recombination = True ,
+
left_preconditioner = True ,
+
solver_type = 'cached_direct' ,
+
solver_args = None ,
+
useGPU = False ,
+
max_cached_factorizations = 12 ,
+
spectral_space = True ,
+
real_spectral_coefficients = False ,
+
debug = False ,
+
):
+
"""
+
Base class for problems discretized with spectral methods.
+
+
Args:
+
bases (list of dictionaries): 1D Bases
+
components (list of strings): Components of the equations
+
comm (mpi4py.Intracomm or None): MPI communicator
+
Dirichlet_recombination (bool): Use Dirichlet recombination in the last axis as right preconditioner
+
left_preconditioner (bool): Reverse the Kronecker product if yes
+
solver_type (str): Solver for linear systems
+
solver_args (dict): Arguments for linear solver
+
useGPU (bool): Run on GPU or CPU
+
max_cached_factorizations (int): Number of matrix decompositions to cache before starting eviction
+
spectral_space (bool): If yes, the solution will not be transformed back after solving and evaluating the RHS, and is expected as input in spectral space to these functions
+
real_spectral_coefficients (bool): If yes, allow only real values in spectral space, otherwise, allow complex.
+
debug (bool): Make additional tests at extra computational cost
+
"""
+
solver_args = {} if solver_args is None else solver_args
+
self . _makeAttributeAndRegister (
+
'max_cached_factorizations' ,
+
'useGPU' ,
+
'solver_type' ,
+
'solver_args' ,
+
'left_preconditioner' ,
+
'Dirichlet_recombination' ,
+
'comm' ,
+
'spectral_space' ,
+
'real_spectral_coefficients' ,
+
'debug' ,
+
localVars = locals (),
+
)
+
self . spectral = SpectralHelper ( comm = comm , useGPU = useGPU , debug = debug )
+
+
if useGPU :
+
self . setup_GPU ()
+
+
for base in bases :
+
self . spectral . add_axis ( ** base )
+
self . spectral . add_component ( components )
+
+
self . spectral . setup_fft ( real_spectral_coefficients )
+
+
super () . __init__ ( init = self . spectral . init_forward if spectral_space else self . spectral . init )
+
+
self . work_counters [ solver_type ] = WorkCounter ()
+
self . work_counters [ 'factorizations' ] = WorkCounter ()
+
+
self . setup_preconditioner ( Dirichlet_recombination , left_preconditioner )
+
+
self . cached_factorizations = {}
+
+
def __getattr__ ( self , name ):
+
"""
+
Pass requests on to the helper if they are not directly attributes of this class for convenience.
+
+
Args:
+
name (str): Name of the attribute you want
+
+
Returns:
+
request
+
"""
+
return getattr ( self . spectral , name )
+
+
def _setup_operator ( self , LHS ):
+
"""
+
Setup a sparse linear operator by adding relationships. See documentation for ``GenericSpectralLinear.setup_L`` to learn more.
+
+
Args:
+
LHS (dict): Equations to be added to the operator
+
+
Returns:
+
sparse linear operator
+
"""
+
operator = self . spectral . get_empty_operator_matrix ()
+
for line , equation in LHS . items ():
+
self . spectral . add_equation_lhs ( operator , line , equation )
+
return self . spectral . convert_operator_matrix_to_operator ( operator )
+
+
+
[docs]
+
def setup_L ( self , LHS ):
+
"""
+
Setup the left hand side of the linear operator L and store it in ``self.L``.
+
+
The argument is meant to be a dictionary with the line you want to write the equation in as the key and the relationship between components as another dictionary. For instance, you can add an algebraic condition capturing a first derivative relationship between u and ux as follows:
+
+
```
+
Dx = self.get_differentiation_matrix(axes=(0,))
+
I = self.get_Id()
+
LHS = {'ux': {'u': Dx, 'ux': -I}}
+
self.setup_L(LHS)
+
```
+
+
If you put zero as right hand side for the solver in the line for ux, ux will contain the x-derivative of u afterwards.
+
+
Args:
+
LHS (dict): Dictionary containing the equations.
+
"""
+
self . L = self . _setup_operator ( LHS )
+
+
+
+
[docs]
+
def setup_M ( self , LHS ):
+
'''
+
Setup mass matrix, see documentation of ``GenericSpectralLinear.setup_L``.
+
'''
+
diff_index = list ( LHS . keys ())
+
self . diff_mask = [ me in diff_index for me in self . components ]
+
self . M = self . _setup_operator ( LHS )
+
+
+
+
[docs]
+
def setup_preconditioner ( self , Dirichlet_recombination = True , left_preconditioner = True ):
+
"""
+
Get left and right preconditioners.
+
+
Args:
+
Dirichlet_recombination (bool): Basis conversion for right preconditioner. Useful for Chebychev and Ultraspherical methods. 10/10 would recommend.
+
left_preconditioner (bool): If True, it will interleave the variables and reverse the Kronecker product
+
"""
+
sp = self . spectral . sparse_lib
+
N = np . prod ( self . init [ 0 ][ 1 :])
+
+
Id = sp . eye ( N )
+
Pl_lhs = { comp : { comp : Id } for comp in self . components }
+
self . Pl = self . _setup_operator ( Pl_lhs )
+
+
if left_preconditioner :
+
# reverse Kronecker product
+
+
if self . spectral . useGPU :
+
R = self . Pl . get () . tolil () * 0
+
else :
+
R = self . Pl . tolil () * 0
+
+
for j in range ( self . ncomponents ):
+
for i in range ( N ):
+
R [ i * self . ncomponents + j , j * N + i ] = 1.0
+
+
self . Pl = self . spectral . sparse_lib . csc_matrix ( R )
+
+
if Dirichlet_recombination and type ( self . axes [ - 1 ]) . __name__ in [ 'ChebychevHelper, Ultraspherical' ]:
+
_Pr = self . spectral . get_Dirichlet_recombination_matrix ( axis =- 1 )
+
else :
+
_Pr = Id
+
+
Pr_lhs = { comp : { comp : _Pr } for comp in self . components }
+
self . Pr = self . _setup_operator ( Pr_lhs ) @ self . Pl . T
+
+
+
+
[docs]
+
def solve_system ( self , rhs , dt , u0 = None , * args , skip_itransform = False , ** kwargs ):
+
"""
+
Do an implicit Euler step to solve M u_t + Lu = rhs, with M the mass matrix and L the linear operator as setup by
+
``GenericSpectralLinear.setup_L`` and ``GenericSpectralLinear.setup_M``.
+
+
The implicit Euler step is (M - dt L) u = M rhs. Note that M need not be invertible as long as (M + dt*L) is.
+
This means solving with dt=0 to mimic explicit methods does not work for all problems, in particular simple DAEs.
+
+
Note that by putting M rhs on the right hand side, this function can only solve algebraic conditions equal to
+
zero. If you want something else, it should be easy to overload this function.
+
"""
+
+
sp = self . spectral . sparse_lib
+
+
if self . spectral_space :
+
rhs_hat = rhs . copy ()
+
else :
+
rhs_hat = self . spectral . transform ( rhs )
+
+
rhs_hat = ( self . M @ rhs_hat . flatten ()) . reshape ( rhs_hat . shape )
+
rhs_hat = self . spectral . put_BCs_in_rhs_hat ( rhs_hat )
+
rhs_hat = self . Pl @ rhs_hat . flatten ()
+
+
if dt not in self . cached_factorizations . keys ():
+
A = self . M + dt * self . L
+
A = self . Pl @ self . spectral . put_BCs_in_matrix ( A ) @ self . Pr
+
+
# import numpy as np
+
# if A.shape[0] < 200:
+
# import matplotlib.pyplot as plt
+
+
# # M = self.spectral.put_BCs_in_matrix(self.L.copy())
+
# M = A # self.L
+
# im = plt.imshow((M / abs(M)).real)
+
# # im = plt.imshow(np.log10(abs(A.toarray())).real)
+
# # im = plt.imshow(((A.toarray())).real)
+
# plt.colorbar(im)
+
# plt.show()
+
+
if self . solver_type . lower () == 'cached_direct' :
+
if dt not in self . cached_factorizations . keys ():
+
if len ( self . cached_factorizations ) >= self . max_cached_factorizations :
+
self . cached_factorizations . pop ( list ( self . cached_factorizations . keys ())[ 0 ])
+
self . logger . debug ( f 'Evicted matrix factorization for { dt =: .6f } from cache' )
+
self . cached_factorizations [ dt ] = self . spectral . linalg . factorized ( A )
+
self . logger . debug ( f 'Cached matrix factorization for { dt =: .6f } ' )
+
self . work_counters [ 'factorizations' ]()
+
+
_sol_hat = self . cached_factorizations [ dt ]( rhs_hat )
+
self . logger . debug ( f 'Used cached matrix factorization for { dt =: .6f } ' )
+
+
elif self . solver_type . lower () == 'direct' :
+
_sol_hat = sp . linalg . spsolve ( A , rhs_hat )
+
elif self . solver_type . lower () == 'gmres' :
+
_sol_hat , _ = sp . linalg . gmres (
+
A ,
+
rhs_hat ,
+
x0 = u0 . flatten (),
+
** self . solver_args ,
+
callback = self . work_counters [ self . solver_type ],
+
callback_type = 'legacy' ,
+
)
+
elif self . solver_type . lower () == 'cg' :
+
_sol_hat , _ = sp . linalg . cg (
+
A , rhs_hat , x0 = u0 . flatten (), ** self . solver_args , callback = self . work_counters [ self . solver_type ]
+
)
+
else :
+
raise NotImplementedError ( f 'Solver { self . solver_type : ! } not implemented in { type ( self ) . __name__ } !' )
+
+
sol_hat = self . spectral . u_init_forward
+
sol_hat [ ... ] = ( self . Pr @ _sol_hat ) . reshape ( sol_hat . shape )
+
+
if self . spectral_space :
+
return sol_hat
+
else :
+
sol = self . spectral . u_init
+
sol [:] = self . spectral . itransform ( sol_hat ) . real
+
+
if self . spectral . debug :
+
self . spectral . check_BCs ( sol )
+
+
return sol
+
+
+
+
+
+
[docs]
+
def compute_residual_DAE ( self , stage = '' ):
+
"""
+
Computation of the residual that does not add u_0 - u_m in algebraic equations.
+
+
Args:
+
stage (str): The current stage of the step the level belongs to
+
"""
+
+
# get current level and problem description
+
L = self . level
+
+
# Check if we want to skip the residual computation to gain performance
+
# Keep in mind that skipping any residual computation is likely to give incorrect outputs of the residual!
+
if stage in self . params . skip_residual_computation :
+
L . status . residual = 0.0 if L . status . residual is None else L . status . residual
+
return None
+
+
# check if there are new values (e.g. from a sweep)
+
# assert L.status.updated
+
+
# compute the residual for each node
+
+
# build QF(u)
+
res_norm = []
+
res = self . integrate ()
+
mask = L . prob . diff_mask
+
for m in range ( self . coll . num_nodes ):
+
res [ m ][ mask ] += L . u [ 0 ][ mask ] - L . u [ m + 1 ][ mask ]
+
# add tau if associated
+
if L . tau [ m ] is not None :
+
res [ m ] += L . tau [ m ]
+
# use abs function from data type here
+
res_norm . append ( abs ( res [ m ]))
+
# print(m, [abs(me) for me in res[m]], [abs(me) for me in L.u[0] - L.u[m + 1]])
+
+
# find maximal residual over the nodes
+
if L . params . residual_type == 'full_abs' :
+
L . status . residual = max ( res_norm )
+
elif L . params . residual_type == 'last_abs' :
+
L . status . residual = res_norm [ - 1 ]
+
elif L . params . residual_type == 'full_rel' :
+
L . status . residual = max ( res_norm ) / abs ( L . u [ 0 ])
+
elif L . params . residual_type == 'last_rel' :
+
L . status . residual = res_norm [ - 1 ] / abs ( L . u [ 0 ])
+
else :
+
raise ParameterError (
+
f 'residual_type = { L . params . residual_type } not implemented, choose '
+
f 'full_abs, last_abs, full_rel or last_rel instead'
+
)
+
+
# indicate that the residual has seen the new values
+
L . status . updated = False
+
+
return None
+
+
+
+
+
[docs]
+
def compute_residual_DAE_MPI ( self , stage = None ):
+
"""
+
Computation of the residual using the collocation matrix Q
+
+
Args:
+
stage (str): The current stage of the step the level belongs to
+
"""
+
from mpi4py import MPI
+
+
L = self . level
+
+
# Check if we want to skip the residual computation to gain performance
+
# Keep in mind that skipping any residual computation is likely to give incorrect outputs of the residual!
+
if stage in self . params . skip_residual_computation :
+
L . status . residual = 0.0 if L . status . residual is None else L . status . residual
+
return None
+
+
# compute the residual for each node
+
+
# build QF(u)
+
res = self . integrate ( last_only = L . params . residual_type [: 4 ] == 'last' )
+
mask = L . prob . diff_mask
+
res [ mask ] += L . u [ 0 ][ mask ] - L . u [ self . rank + 1 ][ mask ]
+
# add tau if associated
+
if L . tau [ self . rank ] is not None :
+
res += L . tau [ self . rank ]
+
# use abs function from data type here
+
res_norm = abs ( res )
+
+
# find maximal residual over the nodes
+
if L . params . residual_type == 'full_abs' :
+
L . status . residual = self . comm . allreduce ( res_norm , op = MPI . MAX )
+
elif L . params . residual_type == 'last_abs' :
+
L . status . residual = self . comm . bcast ( res_norm , root = self . comm . size - 1 )
+
elif L . params . residual_type == 'full_rel' :
+
L . status . residual = self . comm . allreduce ( res_norm / abs ( L . u [ 0 ]), op = MPI . MAX )
+
elif L . params . residual_type == 'last_rel' :
+
L . status . residual = self . comm . bcast ( res_norm / abs ( L . u [ 0 ]), root = self . comm . size - 1 )
+
else :
+
raise NotImplementedError ( f 'residual type \" { L . params . residual_type } \" not implemented!' )
+
+
# indicate that the residual has seen the new values
+
L . status . updated = False
+
+
return None
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/_modules/index.html b/_modules/index.html
index 71cea0afab..fcee97368a 100644
--- a/_modules/index.html
+++ b/_modules/index.html
@@ -53,6 +53,7 @@ All modules for which code is available
helpers.problem_helper
helpers.pysdc_helper
helpers.setup_helper
+
helpers.spectral_helper
helpers.stats_helper
helpers.testing
helpers.transfer_helper
@@ -95,6 +96,7 @@
All modules for which code is available
implementations.problem_classes.Boussinesq_2D_FD_imex
implementations.problem_classes.Brusselator
implementations.problem_classes.BuckConverter
+
implementations.problem_classes.Burgers
implementations.problem_classes.DiscontinuousTestODE
implementations.problem_classes.FastWaveSlowWave_0D
implementations.problem_classes.FermiPastaUlamTsingou
@@ -107,6 +109,7 @@
All modules for which code is available
implementations.problem_classes.HarmonicOscillator
implementations.problem_classes.HeatEquation_1D_FEniCS_matrix_forced
implementations.problem_classes.HeatEquation_2D_PETSc_forced
+
implementations.problem_classes.HeatEquation_Chebychev
implementations.problem_classes.HeatEquation_ND_FD
implementations.problem_classes.HeatEquation_ND_FD_CuPy
implementations.problem_classes.HenonHeiles
@@ -117,6 +120,7 @@
All modules for which code is available
implementations.problem_classes.PenningTrap_3D
implementations.problem_classes.Piline
implementations.problem_classes.Quench
+
implementations.problem_classes.RayleighBenard
implementations.problem_classes.TestEquation_0D
implementations.problem_classes.Van_der_Pol_implicit
implementations.problem_classes.VorticityVelocity_2D_FEniCS_periodic
@@ -131,6 +135,7 @@
All modules for which code is available
implementations.problem_classes.boussinesq_helpers.unflatten
implementations.problem_classes.generic_MPIFFT_Laplacian
implementations.problem_classes.generic_ND_FD
+
implementations.problem_classes.generic_spectral
implementations.problem_classes.nonlinear_ODE_1
implementations.problem_classes.odeScalar
implementations.problem_classes.odeSystem
diff --git a/_sources/pySDC/helpers.rst.txt b/_sources/pySDC/helpers.rst.txt
index 6cdef6896f..0a0ddd32ac 100644
--- a/_sources/pySDC/helpers.rst.txt
+++ b/_sources/pySDC/helpers.rst.txt
@@ -12,6 +12,7 @@ Submodules
helpers.problem_helper
helpers.pysdc_helper
helpers.setup_helper
+ helpers.spectral_helper
helpers.stats_helper
helpers.testing
helpers.transfer_helper
diff --git a/_sources/pySDC/helpers.spectral_helper.rst.txt b/_sources/pySDC/helpers.spectral_helper.rst.txt
new file mode 100644
index 0000000000..a7976a3ba0
--- /dev/null
+++ b/_sources/pySDC/helpers.spectral_helper.rst.txt
@@ -0,0 +1,7 @@
+helpers.spectral\_helper module
+===============================
+
+.. automodule:: helpers.spectral_helper
+ :members:
+ :undoc-members:
+ :show-inheritance:
diff --git a/_sources/pySDC/implementations.problem_classes.Burgers.rst.txt b/_sources/pySDC/implementations.problem_classes.Burgers.rst.txt
new file mode 100644
index 0000000000..693e9c7190
--- /dev/null
+++ b/_sources/pySDC/implementations.problem_classes.Burgers.rst.txt
@@ -0,0 +1,7 @@
+implementations.problem\_classes.Burgers module
+===============================================
+
+.. automodule:: implementations.problem_classes.Burgers
+ :members:
+ :undoc-members:
+ :show-inheritance:
diff --git a/_sources/pySDC/implementations.problem_classes.HeatEquation_Chebychev.rst.txt b/_sources/pySDC/implementations.problem_classes.HeatEquation_Chebychev.rst.txt
new file mode 100644
index 0000000000..a061a0e2e6
--- /dev/null
+++ b/_sources/pySDC/implementations.problem_classes.HeatEquation_Chebychev.rst.txt
@@ -0,0 +1,7 @@
+implementations.problem\_classes.HeatEquation\_Chebychev module
+===============================================================
+
+.. automodule:: implementations.problem_classes.HeatEquation_Chebychev
+ :members:
+ :undoc-members:
+ :show-inheritance:
diff --git a/_sources/pySDC/implementations.problem_classes.RayleighBenard.rst.txt b/_sources/pySDC/implementations.problem_classes.RayleighBenard.rst.txt
new file mode 100644
index 0000000000..53cf916671
--- /dev/null
+++ b/_sources/pySDC/implementations.problem_classes.RayleighBenard.rst.txt
@@ -0,0 +1,7 @@
+implementations.problem\_classes.RayleighBenard module
+======================================================
+
+.. automodule:: implementations.problem_classes.RayleighBenard
+ :members:
+ :undoc-members:
+ :show-inheritance:
diff --git a/_sources/pySDC/implementations.problem_classes.generic_spectral.rst.txt b/_sources/pySDC/implementations.problem_classes.generic_spectral.rst.txt
new file mode 100644
index 0000000000..539d7101a8
--- /dev/null
+++ b/_sources/pySDC/implementations.problem_classes.generic_spectral.rst.txt
@@ -0,0 +1,7 @@
+implementations.problem\_classes.generic\_spectral module
+=========================================================
+
+.. automodule:: implementations.problem_classes.generic_spectral
+ :members:
+ :undoc-members:
+ :show-inheritance:
diff --git a/_sources/pySDC/implementations.problem_classes.rst.txt b/_sources/pySDC/implementations.problem_classes.rst.txt
index 1e6f102608..534ed27beb 100644
--- a/_sources/pySDC/implementations.problem_classes.rst.txt
+++ b/_sources/pySDC/implementations.problem_classes.rst.txt
@@ -31,6 +31,7 @@ Submodules
implementations.problem_classes.Boussinesq_2D_FD_imex
implementations.problem_classes.Brusselator
implementations.problem_classes.BuckConverter
+ implementations.problem_classes.Burgers
implementations.problem_classes.DiscontinuousTestODE
implementations.problem_classes.FastWaveSlowWave_0D
implementations.problem_classes.FermiPastaUlamTsingou
@@ -43,6 +44,7 @@ Submodules
implementations.problem_classes.HarmonicOscillator
implementations.problem_classes.HeatEquation_1D_FEniCS_matrix_forced
implementations.problem_classes.HeatEquation_2D_PETSc_forced
+ implementations.problem_classes.HeatEquation_Chebychev
implementations.problem_classes.HeatEquation_ND_FD
implementations.problem_classes.HeatEquation_ND_FD_CuPy
implementations.problem_classes.HenonHeiles
@@ -53,11 +55,13 @@ Submodules
implementations.problem_classes.PenningTrap_3D
implementations.problem_classes.Piline
implementations.problem_classes.Quench
+ implementations.problem_classes.RayleighBenard
implementations.problem_classes.TestEquation_0D
implementations.problem_classes.Van_der_Pol_implicit
implementations.problem_classes.VorticityVelocity_2D_FEniCS_periodic
implementations.problem_classes.generic_MPIFFT_Laplacian
implementations.problem_classes.generic_ND_FD
+ implementations.problem_classes.generic_spectral
implementations.problem_classes.nonlinear_ODE_1
implementations.problem_classes.odeScalar
implementations.problem_classes.odeSystem
diff --git a/coverage/class_index.html b/coverage/class_index.html
index d1fb4c18c1..3f05e6480c 100644
--- a/coverage/class_index.html
+++ b/coverage/class_index.html
@@ -11,7 +11,7 @@
Coverage report:
- 78%
+ 79%
@@ -408,6 +408,54 @@
2
100%
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper1D
+ 29
+ 13
+ 6
+ 55%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper
+ 123
+ 3
+ 8
+ 98%
+
+
+ pySDC/helpers/spectral_helper.py
+ UltrasphericalHelper
+ 28
+ 1
+ 0
+ 96%
+
+
+ pySDC/helpers/spectral_helper.py
+ FFTHelper
+ 29
+ 5
+ 2
+ 83%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper
+ 441
+ 40
+ 15
+ 91%
+
+
+ pySDC/helpers/spectral_helper.py
+ (no class)
+ 114
+ 0
+ 0
+ 100%
+
pySDC/helpers/stats_helper.py
(no class)
@@ -940,9 +988,9 @@
pySDC/implementations/datatype_classes/mesh.py
@@ -1600,6 +1648,30 @@
0
100%
+
+ pySDC/implementations/problem_classes/Burgers.py
+ Burgers1D
+ 31
+ 0
+ 39
+ 100%
+
+
+ pySDC/implementations/problem_classes/Burgers.py
+ Burgers2D
+ 49
+ 5
+ 57
+ 90%
+
+
+ pySDC/implementations/problem_classes/Burgers.py
+ (no class)
+ 16
+ 0
+ 4
+ 100%
+
pySDC/implementations/problem_classes/DiscontinuousTestODE.py
DiscontinuousTestODE
@@ -1912,6 +1984,46 @@
0
100%
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ Heat1DChebychev
+ 46
+ 0
+ 2
+ 100%
+
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ Heat1DUltraspherical
+ 44
+ 0
+ 2
+ 100%
+
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ Heat2DChebychev
+ 52
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ Heat2DUltraspherical
+ 49
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ (no class)
+ 29
+ 0
+ 0
+ 100%
+
pySDC/implementations/problem_classes/HeatEquation_ND_FD.py
heatNd_unforced
@@ -2096,6 +2208,46 @@
0
100%
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ RayleighBenard
+ 137
+ 17
+ 57
+ 88%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ CFLLimit
+ 32
+ 18
+ 1
+ 44%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ LogCFL
+ 3
+ 3
+ 0
+ 0%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ LogAnalysisVariables
+ 9
+ 9
+ 0
+ 0%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ (no class)
+ 28
+ 0
+ 2
+ 100%
+
pySDC/implementations/problem_classes/TestEquation_0D.py
testequation0d
@@ -2116,9 +2268,9 @@
pySDC/implementations/problem_classes/Van_der_Pol_implicit.py
@@ -2352,6 +2504,22 @@
0
100%
+
+ pySDC/implementations/problem_classes/generic_spectral.py
+ GenericSpectralLinear
+ 82
+ 17
+ 1
+ 79%
+
+
+ pySDC/implementations/problem_classes/generic_spectral.py
+ (no class)
+ 59
+ 43
+ 3
+ 27%
+
pySDC/implementations/problem_classes/nonlinear_ODE_1.py
nonlinear_ODE_1
@@ -5076,9 +5244,9 @@
pySDC/projects/soft_failure/implicit_sweeper_faults.py
@@ -5092,9 +5260,9 @@
pySDC/projects/soft_failure/implicit_sweeper_faults.py
@@ -5389,10 +5557,10 @@
Total
- 26137
- 5718
- 4998
- 78%
+ 27567
+ 5896
+ 5197
+ 79%
@@ -5405,7 +5573,7 @@
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/coverage-badge.svg b/coverage/coverage-badge.svg
index 5cb6ec5c45..69273e9c6e 100644
--- a/coverage/coverage-badge.svg
+++ b/coverage/coverage-badge.svg
@@ -1 +1 @@
-coverage: 78.12% coverage coverage 78.12% 78.12%
\ No newline at end of file
+coverage: 78.61% coverage coverage 78.61% 78.61%
\ No newline at end of file
diff --git a/coverage/function_index.html b/coverage/function_index.html
index a91686d515..452c1ef1f3 100644
--- a/coverage/function_index.html
+++ b/coverage/function_index.html
@@ -11,7 +11,7 @@
Coverage report:
- 78%
+ 79%
@@ -1256,6 +1256,670 @@
0
100%
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper1D.__init__
+ 7
+ 1
+ 0
+ 86%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper1D.setup_GPU
+ 9
+ 9
+ 0
+ 0%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper1D.get_Id
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper1D.get_zero
+ 1
+ 1
+ 0
+ 0%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper1D.get_empty_operator_matrix
+ 1
+ 1
+ 0
+ 0%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper1D.get_basis_change_matrix
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper1D.get_filter_matrix
+ 9
+ 1
+ 1
+ 89%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.__init__
+ 8
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.get_1dgrid
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.get_wavenumbers
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.get_conv
+ 18
+ 2
+ 1
+ 89%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.get_conv.get_forward_conv
+ 8
+ 0
+ 1
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.get_basis_change_matrix
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.get_integration_matrix
+ 6
+ 0
+ 1
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.get_differentiation_matrix
+ 6
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.get_norm
+ 4
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.get_fft_shuffle
+ 8
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.get_fft_shift
+ 8
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.get_fft_utils
+ 6
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.transform
+ 13
+ 0
+ 2
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.itransform
+ 13
+ 0
+ 1
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.get_BC
+ 5
+ 1
+ 1
+ 80%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.get_integ_BC_row
+ 5
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.get_Dirichlet_BC_row
+ 8
+ 0
+ 1
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ ChebychevHelper.get_Dirichlet_recombination_matrix
+ 4
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ UltrasphericalHelper.get_differentiation_matrix
+ 5
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ UltrasphericalHelper.get_S
+ 9
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ UltrasphericalHelper.get_basis_change_matrix
+ 10
+ 1
+ 0
+ 90%
+
+
+ pySDC/helpers/spectral_helper.py
+ UltrasphericalHelper.get_integration_matrix
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ UltrasphericalHelper.get_integration_constant
+ 3
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ FFTHelper.__init__
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ FFTHelper.get_1dgrid
+ 2
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ FFTHelper.get_wavenumbers
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ FFTHelper.get_differentiation_matrix
+ 6
+ 3
+ 1
+ 50%
+
+
+ pySDC/helpers/spectral_helper.py
+ FFTHelper.get_integration_matrix
+ 3
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ FFTHelper.transform
+ 1
+ 0
+ 1
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ FFTHelper.itransform
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ FFTHelper.get_BC
+ 8
+ 2
+ 0
+ 75%
+
+
+ pySDC/helpers/spectral_helper.py
+ FFTHelper.get_Nyquist_mode_index
+ 3
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ FFTHelper.get_integ_BC_row
+ 3
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.setup_GPU
+ 10
+ 10
+ 0
+ 0%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.__init__
+ 11
+ 1
+ 0
+ 91%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.u_init
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.u_init_forward
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.shape
+ 1
+ 1
+ 0
+ 0%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.ndim
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.ncomponents
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.V
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.add_axis
+ 10
+ 0
+ 1
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.add_component
+ 6
+ 0
+ 2
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.index
+ 4
+ 0
+ 1
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.get_empty_operator_matrix
+ 3
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.get_BC
+ 21
+ 2
+ 0
+ 90%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.remove_BC
+ 9
+ 1
+ 0
+ 89%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.add_BC
+ 15
+ 1
+ 0
+ 93%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.setup_BCs
+ 8
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.check_BCs
+ 13
+ 2
+ 0
+ 85%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.put_BCs_in_matrix
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.put_BCs_in_rhs_hat
+ 11
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.put_BCs_in_rhs
+ 14
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.add_equation_lhs
+ 2
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.convert_operator_matrix_to_operator
+ 3
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.get_wavenumbers
+ 2
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.get_grid
+ 2
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.get_fft
+ 22
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.setup_fft
+ 12
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper._transform_fft
+ 2
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper._transform_dct
+ 27
+ 0
+ 2
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.transform_single_component
+ 30
+ 1
+ 0
+ 97%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.transform
+ 7
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper._transform_ifft
+ 2
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper._transform_idct
+ 30
+ 0
+ 2
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.itransform_single_component
+ 29
+ 1
+ 0
+ 97%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.get_aligned
+ 33
+ 4
+ 0
+ 88%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.itransform
+ 7
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.get_local_slice_of_1D_matrix
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.get_filter_matrix
+ 5
+ 3
+ 1
+ 40%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.get_differentiation_matrix
+ 18
+ 0
+ 1
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.get_integration_matrix
+ 18
+ 0
+ 1
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.get_Id
+ 15
+ 0
+ 1
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.get_Dirichlet_recombination_matrix
+ 13
+ 13
+ 1
+ 0%
+
+
+ pySDC/helpers/spectral_helper.py
+ SpectralHelper.get_basis_change_matrix
+ 19
+ 0
+ 2
+ 100%
+
+
+ pySDC/helpers/spectral_helper.py
+ (no function)
+ 114
+ 0
+ 0
+ 100%
+
pySDC/helpers/stats_helper.py
filter_stats
@@ -3140,9 +3804,9 @@
pySDC/implementations/datatype_classes/mesh.py
@@ -4873,20 +5537,84 @@
100%
- pySDC/implementations/problem_classes/BuckConverter.py
- buck_converter.u_exact
- 6
+ pySDC/implementations/problem_classes/BuckConverter.py
+ buck_converter.u_exact
+ 6
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/BuckConverter.py
+ (no function)
+ 10
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/Burgers.py
+ Burgers1D.__init__
+ 16
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/Burgers.py
+ Burgers1D.u_exact
+ 7
+ 0
+ 1
+ 100%
+
+
+ pySDC/implementations/problem_classes/Burgers.py
+ Burgers1D.eval_f
+ 8
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/Burgers.py
+ Burgers2D.__init__
+ 23
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/Burgers.py
+ Burgers2D.u_exact
+ 11
+ 0
+ 1
+ 100%
+
+
+ pySDC/implementations/problem_classes/Burgers.py
+ Burgers2D.eval_f
+ 10
0
0
- 100%
+ 100%
- pySDC/implementations/problem_classes/BuckConverter.py
- (no function)
- 10
+ pySDC/implementations/problem_classes/Burgers.py
+ Burgers2D.compute_vorticity
+ 5
+ 5
0
+ 0%
+
+
+ pySDC/implementations/problem_classes/Burgers.py
+ (no function)
+ 16
0
- 100%
+ 4
+ 100%
pySDC/implementations/problem_classes/DiscontinuousTestODE.py
@@ -5872,6 +6600,110 @@
0
100%
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ Heat1DChebychev.__init__
+ 16
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ Heat1DChebychev.eval_f
+ 11
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ Heat1DChebychev.u_exact
+ 19
+ 0
+ 2
+ 100%
+
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ Heat1DUltraspherical.__init__
+ 17
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ Heat1DUltraspherical.eval_f
+ 11
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ Heat1DUltraspherical.u_exact
+ 16
+ 0
+ 2
+ 100%
+
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ Heat2DChebychev.__init__
+ 31
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ Heat2DChebychev.eval_f
+ 8
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ Heat2DChebychev.u_exact
+ 13
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ Heat2DUltraspherical.__init__
+ 30
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ Heat2DUltraspherical.eval_f
+ 8
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ Heat2DUltraspherical.u_exact
+ 11
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ (no function)
+ 29
+ 0
+ 0
+ 100%
+
pySDC/implementations/problem_classes/HeatEquation_ND_FD.py
heatNd_unforced.__init__
@@ -6408,6 +7240,126 @@
0
100%
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ RayleighBenard.__init__
+ 47
+ 1
+ 1
+ 98%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ RayleighBenard.eval_f
+ 30
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ RayleighBenard.u_exact
+ 17
+ 1
+ 0
+ 94%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ RayleighBenard.compute_vorticity
+ 9
+ 1
+ 0
+ 89%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ RayleighBenard.compute_Nusselt_numbers
+ 21
+ 1
+ 0
+ 95%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ RayleighBenard.compute_viscous_dissipation
+ 9
+ 9
+ 0
+ 0%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ RayleighBenard.compute_buoyancy_generation
+ 4
+ 4
+ 0
+ 0%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ CFLLimit.dependencies
+ 3
+ 3
+ 0
+ 0%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ CFLLimit.setup_status_variables
+ 1
+ 1
+ 0
+ 0%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ CFLLimit.setup
+ 2
+ 2
+ 1
+ 0%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ CFLLimit.compute_max_step_size
+ 15
+ 1
+ 0
+ 93%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ CFLLimit.get_new_step_size
+ 11
+ 11
+ 0
+ 0%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ LogCFL.post_step
+ 3
+ 3
+ 0
+ 0%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ LogAnalysisVariables.post_step
+ 9
+ 9
+ 0
+ 0%
+
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ (no function)
+ 28
+ 0
+ 2
+ 100%
+
pySDC/implementations/problem_classes/TestEquation_0D.py
testequation0d.setup_GPU
@@ -6492,9 +7444,9 @@
pySDC/implementations/problem_classes/Van_der_Pol_implicit.py
@@ -7376,6 +8328,94 @@
0
100%
+
+ pySDC/implementations/problem_classes/generic_spectral.py
+ GenericSpectralLinear.setup_GPU
+ 6
+ 6
+ 0
+ 0%
+
+
+ pySDC/implementations/problem_classes/generic_spectral.py
+ GenericSpectralLinear.__init__
+ 14
+ 1
+ 0
+ 93%
+
+
+ pySDC/implementations/problem_classes/generic_spectral.py
+ GenericSpectralLinear.__getattr__
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/generic_spectral.py
+ GenericSpectralLinear._setup_operator
+ 4
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/generic_spectral.py
+ GenericSpectralLinear.setup_L
+ 1
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/generic_spectral.py
+ GenericSpectralLinear.setup_M
+ 3
+ 0
+ 0
+ 100%
+
+
+ pySDC/implementations/problem_classes/generic_spectral.py
+ GenericSpectralLinear.setup_preconditioner
+ 18
+ 2
+ 0
+ 89%
+
+
+ pySDC/implementations/problem_classes/generic_spectral.py
+ GenericSpectralLinear.solve_system
+ 35
+ 8
+ 1
+ 77%
+
+
+ pySDC/implementations/problem_classes/generic_spectral.py
+ compute_residual_DAE
+ 22
+ 22
+ 1
+ 0%
+
+
+ pySDC/implementations/problem_classes/generic_spectral.py
+ compute_residual_DAE_MPI
+ 21
+ 21
+ 1
+ 0%
+
+
+ pySDC/implementations/problem_classes/generic_spectral.py
+ (no function)
+ 16
+ 0
+ 1
+ 100%
+
pySDC/implementations/problem_classes/nonlinear_ODE_1.py
nonlinear_ODE_1.__init__
@@ -15820,9 +16860,9 @@
pySDC/projects/soft_failure/generate_statistics.py
@@ -15900,9 +16940,9 @@
pySDC/projects/soft_failure/implicit_sweeper_faults.py
@@ -16661,23 +17701,23 @@
Total
- 26137
- 5718
- 4998
- 78%
+ 27567
+ 5896
+ 5197
+ 79%
No items found using the specified filter.
- 137 empty functions skipped.
+ 148 empty functions skipped.
+
+ pySDC/helpers/spectral_helper.py
+ 764
+ 62
+ 31
+ 92%
+
pySDC/helpers/stats_helper.py
36
@@ -360,9 +367,9 @@
pySDC/implementations/datatype_classes/mesh.py
56
- 1
+ 0
3
- 98%
+ 100%
pySDC/implementations/datatype_classes/particles.py
@@ -539,6 +546,13 @@
1
100%
+
+ pySDC/implementations/problem_classes/Burgers.py
+ 96
+ 5
+ 100
+ 95%
+
pySDC/implementations/problem_classes/DiscontinuousTestODE.py
87
@@ -623,6 +637,13 @@
2
100%
+
+ pySDC/implementations/problem_classes/HeatEquation_Chebychev.py
+ 220
+ 0
+ 4
+ 100%
+
pySDC/implementations/problem_classes/HeatEquation_ND_FD.py
58
@@ -693,6 +714,13 @@
8
77%
+
+ pySDC/implementations/problem_classes/RayleighBenard.py
+ 209
+ 47
+ 60
+ 78%
+
pySDC/implementations/problem_classes/TestEquation_0D.py
53
@@ -703,9 +731,9 @@
pySDC/implementations/problem_classes/Van_der_Pol_implicit.py
57
+ 3
2
- 2
- 96%
+ 95%
pySDC/implementations/problem_classes/VorticityVelocity_2D_FEniCS_periodic.py
@@ -791,6 +819,13 @@
10
94%
+
+ pySDC/implementations/problem_classes/generic_spectral.py
+ 141
+ 60
+ 4
+ 57%
+
pySDC/implementations/problem_classes/nonlinear_ODE_1.py
41
@@ -2173,16 +2208,16 @@
pySDC/projects/soft_failure/generate_statistics.py
199
- 49
+ 50
16
- 75%
+ 75%
pySDC/projects/soft_failure/implicit_sweeper_faults.py
144
- 5
+ 8
0
- 97%
+ 94%
pySDC/projects/soft_failure/visualization_helper.py
@@ -2412,10 +2447,10 @@
Total
- 26137
- 5718
- 5001
- 78%
+ 27567
+ 5896
+ 5200
+ 79%
@@ -2428,7 +2463,7 @@
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/status.json b/coverage/status.json
index f824471ee1..c371dd1af1 100644
--- a/coverage/status.json
+++ b/coverage/status.json
@@ -1 +1 @@
-{"note":"This file is an internal implementation detail to speed up HTML report generation. Its format can change at any time. You might be looking for the JSON report: https://coverage.rtfd.io/cmd.html#cmd-json","format":5,"version":"7.6.1","globals":"89c1de444accc8c03d929ac4a8c1cbbf","files":{"z_8d0d803e4e125e5c_base_transfer_py":{"hash":"605b006ab4e84d626acb1b138a8fdd64","index":{"url":"z_8d0d803e4e125e5c_base_transfer_py.html","file":"pySDC/core/base_transfer.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":103,"n_excluded":5,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_collocation_py":{"hash":"68ca6f34ec12b659d2d150a964054271","index":{"url":"z_8d0d803e4e125e5c_collocation_py.html","file":"pySDC/core/collocation.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":41,"n_excluded":5,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_common_py":{"hash":"ef6b8ac6f425d97969844142332068fb","index":{"url":"z_8d0d803e4e125e5c_common_py.html","file":"pySDC/core/common.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":22,"n_excluded":4,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_controller_py":{"hash":"87df1d0844996abc5531d5442238d272","index":{"url":"z_8d0d803e4e125e5c_controller_py.html","file":"pySDC/core/controller.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":164,"n_excluded":3,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_convergence_controller_py":{"hash":"6e91af5aaa9f9cebf8156cc807722a18","index":{"url":"z_8d0d803e4e125e5c_convergence_controller_py.html","file":"pySDC/core/convergence_controller.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":112,"n_excluded":15,"n_missing":18,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_errors_py":{"hash":"93ec874a431d050bef317af1601fb90c","index":{"url":"z_8d0d803e4e125e5c_errors_py.html","file":"pySDC/core/errors.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":9,"n_excluded":16,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_hooks_py":{"hash":"d6263163218df2f7c83e088c5f7f239f","index":{"url":"z_8d0d803e4e125e5c_hooks_py.html","file":"pySDC/core/hooks.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":54,"n_excluded":0,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_level_py":{"hash":"f8ab015b9bad72a1c3dfc7e583aa7f49","index":{"url":"z_8d0d803e4e125e5c_level_py.html","file":"pySDC/core/level.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":64,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_problem_py":{"hash":"1c08995d8b8a91d4c7b3343bc085e047","index":{"url":"z_8d0d803e4e125e5c_problem_py.html","file":"pySDC/core/problem.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":37,"n_excluded":8,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_space_transfer_py":{"hash":"cc82770927510b4082ce8f96bdcf3378","index":{"url":"z_8d0d803e4e125e5c_space_transfer_py.html","file":"pySDC/core/space_transfer.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":19,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_step_py":{"hash":"7700c52a132a2a495af1b53a51e80227","index":{"url":"z_8d0d803e4e125e5c_step_py.html","file":"pySDC/core/step.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":117,"n_excluded":7,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_sweeper_py":{"hash":"60cf4876334adff6c5d94f36b69b30e1","index":{"url":"z_8d0d803e4e125e5c_sweeper_py.html","file":"pySDC/core/sweeper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":120,"n_excluded":8,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_NCCL_communicator_py":{"hash":"335ea48729c450fa494f83edbf9b5d62","index":{"url":"z_41564483689e14fd_NCCL_communicator_py.html","file":"pySDC/helpers/NCCL_communicator.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":62,"n_excluded":2,"n_missing":62,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_plot_helper_py":{"hash":"3da9f9e456095ff70b322fc592e54f63","index":{"url":"z_41564483689e14fd_plot_helper_py.html","file":"pySDC/helpers/plot_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":33,"n_excluded":38,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_problem_helper_py":{"hash":"947627cdb7d466c11b75654fe0438f81","index":{"url":"z_41564483689e14fd_problem_helper_py.html","file":"pySDC/helpers/problem_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":102,"n_excluded":5,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_pysdc_helper_py":{"hash":"8f7a47bfe79fefa507904d950e14cd7e","index":{"url":"z_41564483689e14fd_pysdc_helper_py.html","file":"pySDC/helpers/pysdc_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":17,"n_excluded":19,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_setup_helper_py":{"hash":"ee3df0592cb85e8a0e11b1e0dc741754","index":{"url":"z_41564483689e14fd_setup_helper_py.html","file":"pySDC/helpers/setup_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":19,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_stats_helper_py":{"hash":"039bcff9fead556e196125a46bea3a64","index":{"url":"z_41564483689e14fd_stats_helper_py.html","file":"pySDC/helpers/stats_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":36,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_testing_py":{"hash":"0eace903ebaa536113cb4bd66275aa38","index":{"url":"z_41564483689e14fd_testing_py.html","file":"pySDC/helpers/testing.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":30,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_transfer_helper_py":{"hash":"442b9493cef86b1f98f4961b8c10fec7","index":{"url":"z_41564483689e14fd_transfer_helper_py.html","file":"pySDC/helpers/transfer_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":142,"n_excluded":0,"n_missing":33,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_visualization_tools_py":{"hash":"e3aaafde8b227afae340d2c4ba27bbfe","index":{"url":"z_41564483689e14fd_visualization_tools_py.html","file":"pySDC/helpers/visualization_tools.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":40,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_d6839539e65473f5_controller_MPI_py":{"hash":"bbb89968fbab081187bbdc807db6c057","index":{"url":"z_d6839539e65473f5_controller_MPI_py.html","file":"pySDC/implementations/controller_classes/controller_MPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":384,"n_excluded":7,"n_missing":130,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_d6839539e65473f5_controller_nonMPI_py":{"hash":"19438d3a4619ebe68bfc4738af0560a5","index":{"url":"z_d6839539e65473f5_controller_nonMPI_py.html","file":"pySDC/implementations/controller_classes/controller_nonMPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":295,"n_excluded":13,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_adaptive_collocation_py":{"hash":"cbd42126f07c6ecabd43a36f1c811d36","index":{"url":"z_c28af68f8f845bbd_adaptive_collocation_py.html","file":"pySDC/implementations/convergence_controller_classes/adaptive_collocation.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":79,"n_excluded":4,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_adaptivity_py":{"hash":"50103e3984dcb8153142a6870a552989","index":{"url":"z_c28af68f8f845bbd_adaptivity_py.html","file":"pySDC/implementations/convergence_controller_classes/adaptivity.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":257,"n_excluded":12,"n_missing":20,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_basic_restarting_py":{"hash":"ee293e53bed358d9d676e35be9e56892","index":{"url":"z_c28af68f8f845bbd_basic_restarting_py.html","file":"pySDC/implementations/convergence_controller_classes/basic_restarting.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":99,"n_excluded":4,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_check_convergence_py":{"hash":"389679abe085491e4bef783205b30945","index":{"url":"z_c28af68f8f845bbd_check_convergence_py.html","file":"pySDC/implementations/convergence_controller_classes/check_convergence.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":57,"n_excluded":1,"n_missing":9,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_check_iteration_estimator_py":{"hash":"c976e9d22da21f766058ceb5d8d78de8","index":{"url":"z_c28af68f8f845bbd_check_iteration_estimator_py.html","file":"pySDC/implementations/convergence_controller_classes/check_iteration_estimator.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":43,"n_excluded":1,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_crash_py":{"hash":"03eab43f23596b458dd29470fc5b5c7c","index":{"url":"z_c28af68f8f845bbd_crash_py.html","file":"pySDC/implementations/convergence_controller_classes/crash.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":44,"n_excluded":4,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_estimate_contraction_factor_py":{"hash":"21663cf0ee8abbd061c87c2f99c634ee","index":{"url":"z_c28af68f8f845bbd_estimate_contraction_factor_py.html","file":"pySDC/implementations/convergence_controller_classes/estimate_contraction_factor.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":23,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_estimate_embedded_error_py":{"hash":"65677296b14900f356aa54b852ff512e","index":{"url":"z_c28af68f8f845bbd_estimate_embedded_error_py.html","file":"pySDC/implementations/convergence_controller_classes/estimate_embedded_error.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":104,"n_excluded":4,"n_missing":22,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_estimate_extrapolation_error_py":{"hash":"f71e02325fb79464459f18e66b29b2cd","index":{"url":"z_c28af68f8f845bbd_estimate_extrapolation_error_py.html","file":"pySDC/implementations/convergence_controller_classes/estimate_extrapolation_error.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":157,"n_excluded":8,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_estimate_polynomial_error_py":{"hash":"e614751d6f3b3ab4164079398d0e9102","index":{"url":"z_c28af68f8f845bbd_estimate_polynomial_error_py.html","file":"pySDC/implementations/convergence_controller_classes/estimate_polynomial_error.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":67,"n_excluded":3,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_hotrod_py":{"hash":"4f05447bdcb4ae274a8ed3d666a2642d","index":{"url":"z_c28af68f8f845bbd_hotrod_py.html","file":"pySDC/implementations/convergence_controller_classes/hotrod.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":38,"n_excluded":3,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_inexactness_py":{"hash":"7f8a5b9848fd8fc717f4acf7d3ab1d28","index":{"url":"z_c28af68f8f845bbd_inexactness_py.html","file":"pySDC/implementations/convergence_controller_classes/inexactness.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":24,"n_excluded":1,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_interpolate_between_restarts_py":{"hash":"ea966dc7124819303899e2f7fbf40863","index":{"url":"z_c28af68f8f845bbd_interpolate_between_restarts_py.html","file":"pySDC/implementations/convergence_controller_classes/interpolate_between_restarts.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":41,"n_excluded":0,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_spread_step_sizes_py":{"hash":"c383a7d0355e7c01aa86cd1549247886","index":{"url":"z_c28af68f8f845bbd_spread_step_sizes_py.html","file":"pySDC/implementations/convergence_controller_classes/spread_step_sizes.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":61,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_step_size_limiter_py":{"hash":"411aeb8dce5a950a2d089292eba2e5c5","index":{"url":"z_c28af68f8f845bbd_step_size_limiter_py.html","file":"pySDC/implementations/convergence_controller_classes/step_size_limiter.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":43,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_store_uold_py":{"hash":"ba17316c825eaf36070e886447cea6d4","index":{"url":"z_c28af68f8f845bbd_store_uold_py.html","file":"pySDC/implementations/convergence_controller_classes/store_uold.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":14,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_3017878c2b4bc866_cupy_mesh_py":{"hash":"85007849f7ed2c9036de3d568494ceab","index":{"url":"z_3017878c2b4bc866_cupy_mesh_py.html","file":"pySDC/implementations/datatype_classes/cupy_mesh.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":57,"n_excluded":3,"n_missing":8,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_3017878c2b4bc866_fenics_mesh_py":{"hash":"16406c73397cbbbad8907d15f38c7662","index":{"url":"z_3017878c2b4bc866_fenics_mesh_py.html","file":"pySDC/implementations/datatype_classes/fenics_mesh.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":55,"n_excluded":8,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_3017878c2b4bc866_mesh_py":{"hash":"68dcdca641c3c51b796436059cba8d7c","index":{"url":"z_3017878c2b4bc866_mesh_py.html","file":"pySDC/implementations/datatype_classes/mesh.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":56,"n_excluded":3,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_3017878c2b4bc866_particles_py":{"hash":"c04c030bbf43aa477695ce1f35a516fd","index":{"url":"z_3017878c2b4bc866_particles_py.html","file":"pySDC/implementations/datatype_classes/particles.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":112,"n_excluded":15,"n_missing":23,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_3017878c2b4bc866_petsc_vec_py":{"hash":"e65b06f531bdc3953dee44ef5fec4a18","index":{"url":"z_3017878c2b4bc866_petsc_vec_py.html","file":"pySDC/implementations/datatype_classes/petsc_vec.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":40,"n_excluded":2,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1f4fced1df9318f0_default_hook_py":{"hash":"8d7dd6e5da45316ea705f0fa307c4481","index":{"url":"z_1f4fced1df9318f0_default_hook_py.html","file":"pySDC/implementations/hooks/default_hook.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":93,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1f4fced1df9318f0_log_embedded_error_estimate_py":{"hash":"23040721ce915f0d5fc2b981bb2b26d1","index":{"url":"z_1f4fced1df9318f0_log_embedded_error_estimate_py.html","file":"pySDC/implementations/hooks/log_embedded_error_estimate.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":20,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1f4fced1df9318f0_log_errors_py":{"hash":"86a2a3a0c6ee42849fdbcf43108f6140","index":{"url":"z_1f4fced1df9318f0_log_errors_py.html","file":"pySDC/implementations/hooks/log_errors.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":50,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1f4fced1df9318f0_log_extrapolated_error_estimate_py":{"hash":"41728fabdb7a6d6c92c3d7b6e129eb7a","index":{"url":"z_1f4fced1df9318f0_log_extrapolated_error_estimate_py.html","file":"pySDC/implementations/hooks/log_extrapolated_error_estimate.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":6,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1f4fced1df9318f0_log_restarts_py":{"hash":"00b6d519dcebe8f75606857db54c8341","index":{"url":"z_1f4fced1df9318f0_log_restarts_py.html","file":"pySDC/implementations/hooks/log_restarts.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":6,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1f4fced1df9318f0_log_solution_py":{"hash":"45883fb93d590056ddaeda845eef50d2","index":{"url":"z_1f4fced1df9318f0_log_solution_py.html","file":"pySDC/implementations/hooks/log_solution.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":72,"n_excluded":3,"n_missing":11,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1f4fced1df9318f0_log_step_size_py":{"hash":"524d1d5cec27ee6f00768652f7109a40","index":{"url":"z_1f4fced1df9318f0_log_step_size_py.html","file":"pySDC/implementations/hooks/log_step_size.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":6,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1f4fced1df9318f0_log_work_py":{"hash":"5541373444fa9b8ecb3a14afa58011d1","index":{"url":"z_1f4fced1df9318f0_log_work_py.html","file":"pySDC/implementations/hooks/log_work.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":18,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AcousticAdvection_1D_FD_imex_py":{"hash":"bbbe9baa53018f5b67320378c09de83a","index":{"url":"z_91faa57f8583c837_AcousticAdvection_1D_FD_imex_py.html","file":"pySDC/implementations/problem_classes/AcousticAdvection_1D_FD_imex.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":52,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AdvectionDiffusionEquation_1D_FFT_py":{"hash":"b6e5a49811526cd55e42e83a760f9e3b","index":{"url":"z_91faa57f8583c837_AdvectionDiffusionEquation_1D_FFT_py.html","file":"pySDC/implementations/problem_classes/AdvectionDiffusionEquation_1D_FFT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":63,"n_excluded":3,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AdvectionEquation_ND_FD_py":{"hash":"7911c5ce117dfcf909e1f242ea282d4f","index":{"url":"z_91faa57f8583c837_AdvectionEquation_ND_FD_py.html","file":"pySDC/implementations/problem_classes/AdvectionEquation_ND_FD.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":24,"n_excluded":2,"n_missing":8,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AllenCahn_1D_FD_py":{"hash":"699a2a074487980651a92605458c5009","index":{"url":"z_91faa57f8583c837_AllenCahn_1D_FD_py.html","file":"pySDC/implementations/problem_classes/AllenCahn_1D_FD.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":225,"n_excluded":9,"n_missing":10,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AllenCahn_2D_FD_py":{"hash":"1da6ae36990fab1d9005c0611e20520b","index":{"url":"z_91faa57f8583c837_AllenCahn_2D_FD_py.html","file":"pySDC/implementations/problem_classes/AllenCahn_2D_FD.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":201,"n_excluded":8,"n_missing":8,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AllenCahn_2D_FD_gpu_py":{"hash":"4d567ffa04d7e90f6d09ae5f2126eb3e","index":{"url":"z_91faa57f8583c837_AllenCahn_2D_FD_gpu_py.html","file":"pySDC/implementations/problem_classes/AllenCahn_2D_FD_gpu.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":130,"n_excluded":240,"n_missing":130,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AllenCahn_2D_FFT_py":{"hash":"6d928ef2ad94a8644d402b073f039160","index":{"url":"z_91faa57f8583c837_AllenCahn_2D_FFT_py.html","file":"pySDC/implementations/problem_classes/AllenCahn_2D_FFT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":70,"n_excluded":5,"n_missing":55,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AllenCahn_2D_FFT_gpu_py":{"hash":"43e708e7782ef9f7f3151282cc7bf27f","index":{"url":"z_91faa57f8583c837_AllenCahn_2D_FFT_gpu_py.html","file":"pySDC/implementations/problem_classes/AllenCahn_2D_FFT_gpu.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":24,"n_excluded":171,"n_missing":24,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AllenCahn_MPIFFT_py":{"hash":"f6750dbb47ae6632161a3512d9bb9153","index":{"url":"z_91faa57f8583c837_AllenCahn_MPIFFT_py.html","file":"pySDC/implementations/problem_classes/AllenCahn_MPIFFT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":92,"n_excluded":2,"n_missing":25,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AllenCahn_Temp_MPIFFT_py":{"hash":"053c0949ae418a61d46c29226d6e1794","index":{"url":"z_91faa57f8583c837_AllenCahn_Temp_MPIFFT_py.html","file":"pySDC/implementations/problem_classes/AllenCahn_Temp_MPIFFT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":123,"n_excluded":3,"n_missing":23,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Auzinger_implicit_py":{"hash":"556c497c2a6fcd0ffd5f959bfeee0316","index":{"url":"z_91faa57f8583c837_Auzinger_implicit_py.html","file":"pySDC/implementations/problem_classes/Auzinger_implicit.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":38,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Battery_py":{"hash":"2f89d86e8e84bb9d2e655e99ef2f1bd3","index":{"url":"z_91faa57f8583c837_Battery_py.html","file":"pySDC/implementations/problem_classes/Battery.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":166,"n_excluded":4,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Boussinesq_2D_FD_imex_py":{"hash":"f079aa19f16ce8028e11e1e7571bfba2","index":{"url":"z_91faa57f8583c837_Boussinesq_2D_FD_imex_py.html","file":"pySDC/implementations/problem_classes/Boussinesq_2D_FD_imex.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":66,"n_excluded":1,"n_missing":66,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Brusselator_py":{"hash":"dc49acd965363b9e035992584f015600","index":{"url":"z_91faa57f8583c837_Brusselator_py.html","file":"pySDC/implementations/problem_classes/Brusselator.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":44,"n_excluded":48,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_BuckConverter_py":{"hash":"2923f920973af5eb0b9b34d2b7f89794","index":{"url":"z_91faa57f8583c837_BuckConverter_py.html","file":"pySDC/implementations/problem_classes/BuckConverter.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":47,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_DiscontinuousTestODE_py":{"hash":"e1db903d325be680aeb93db97507b8e3","index":{"url":"z_91faa57f8583c837_DiscontinuousTestODE_py.html","file":"pySDC/implementations/problem_classes/DiscontinuousTestODE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":87,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_FastWaveSlowWave_0D_py":{"hash":"ff9bc8fb81069aad9df5ace52b3c3125","index":{"url":"z_91faa57f8583c837_FastWaveSlowWave_0D_py.html","file":"pySDC/implementations/problem_classes/FastWaveSlowWave_0D.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":40,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_FermiPastaUlamTsingou_py":{"hash":"8a944ad7718b7b7af8bfa96ff241086b","index":{"url":"z_91faa57f8583c837_FermiPastaUlamTsingou_py.html","file":"pySDC/implementations/problem_classes/FermiPastaUlamTsingou.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":40,"n_excluded":1,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_FullSolarSystem_py":{"hash":"f4e72ed28345ae6af1c0ad0b13307c87","index":{"url":"z_91faa57f8583c837_FullSolarSystem_py.html","file":"pySDC/implementations/problem_classes/FullSolarSystem.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":43,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_GeneralizedFisher_1D_FD_implicit_py":{"hash":"a3f7f05c7b2816a30e0933b0a817c48f","index":{"url":"z_91faa57f8583c837_GeneralizedFisher_1D_FD_implicit_py.html","file":"pySDC/implementations/problem_classes/GeneralizedFisher_1D_FD_implicit.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":57,"n_excluded":3,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_GeneralizedFisher_1D_PETSc_py":{"hash":"bcc2e1ab385b978a7f258c4be3e6320e","index":{"url":"z_91faa57f8583c837_GeneralizedFisher_1D_PETSc_py.html","file":"pySDC/implementations/problem_classes/GeneralizedFisher_1D_PETSc.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":243,"n_excluded":1,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_GrayScott_1D_FEniCS_implicit_py":{"hash":"665107b23ee05a0ead76532051e1641b","index":{"url":"z_91faa57f8583c837_GrayScott_1D_FEniCS_implicit_py.html","file":"pySDC/implementations/problem_classes/GrayScott_1D_FEniCS_implicit.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":85,"n_excluded":2,"n_missing":85,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_GrayScott_2D_PETSc_periodic_py":{"hash":"f1f41a705b01ff7c4e7645384f31aa1f","index":{"url":"z_91faa57f8583c837_GrayScott_2D_PETSc_periodic_py.html","file":"pySDC/implementations/problem_classes/GrayScott_2D_PETSc_periodic.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":305,"n_excluded":1,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_GrayScott_MPIFFT_py":{"hash":"a3c6e420a057a27352221979b3cb095c","index":{"url":"z_91faa57f8583c837_GrayScott_MPIFFT_py.html","file":"pySDC/implementations/problem_classes/GrayScott_MPIFFT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":267,"n_excluded":2,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_HarmonicOscillator_py":{"hash":"fcfa657b01fe4156d053697edcdd23ba","index":{"url":"z_91faa57f8583c837_HarmonicOscillator_py.html","file":"pySDC/implementations/problem_classes/HarmonicOscillator.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":54,"n_excluded":3,"n_missing":17,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_HeatEquation_1D_FEniCS_matrix_forced_py":{"hash":"d0a0d047e966f33e18b5d335ac0115b0","index":{"url":"z_91faa57f8583c837_HeatEquation_1D_FEniCS_matrix_forced_py.html","file":"pySDC/implementations/problem_classes/HeatEquation_1D_FEniCS_matrix_forced.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":112,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_HeatEquation_2D_PETSc_forced_py":{"hash":"74564b7043abbbc9a821bb4a67582f8f","index":{"url":"z_91faa57f8583c837_HeatEquation_2D_PETSc_forced_py.html","file":"pySDC/implementations/problem_classes/HeatEquation_2D_PETSc_forced.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":90,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_HeatEquation_ND_FD_py":{"hash":"f44100dea16d91447113efddd771b8a0","index":{"url":"z_91faa57f8583c837_HeatEquation_ND_FD_py.html","file":"pySDC/implementations/problem_classes/HeatEquation_ND_FD.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":58,"n_excluded":0,"n_missing":20,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_HeatEquation_ND_FD_CuPy_py":{"hash":"97593f8069dae13b1b869ab05aeddb15","index":{"url":"z_91faa57f8583c837_HeatEquation_ND_FD_CuPy_py.html","file":"pySDC/implementations/problem_classes/HeatEquation_ND_FD_CuPy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":26,"n_excluded":265,"n_missing":26,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_HenonHeiles_py":{"hash":"ff8012356307ca35ff55a5100ffb3c39","index":{"url":"z_91faa57f8583c837_HenonHeiles_py.html","file":"pySDC/implementations/problem_classes/HenonHeiles.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":31,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_LogisticEquation_py":{"hash":"bbfc3db757a18e7d01d1d0ae1b7c394b","index":{"url":"z_91faa57f8583c837_LogisticEquation_py.html","file":"pySDC/implementations/problem_classes/LogisticEquation.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":40,"n_excluded":2,"n_missing":20,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Lorenz_py":{"hash":"4bb1c8a07d69fa93c75a4c2ecb1a4fde","index":{"url":"z_91faa57f8583c837_Lorenz_py.html","file":"pySDC/implementations/problem_classes/Lorenz.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":54,"n_excluded":2,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_NonlinearSchroedinger_MPIFFT_py":{"hash":"a0f964649c3a47934d0edac8054fe9ab","index":{"url":"z_91faa57f8583c837_NonlinearSchroedinger_MPIFFT_py.html","file":"pySDC/implementations/problem_classes/NonlinearSchroedinger_MPIFFT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":60,"n_excluded":1,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_OuterSolarSystem_py":{"hash":"0d0baadaf50761f84ca8b5b3afeb5abc","index":{"url":"z_91faa57f8583c837_OuterSolarSystem_py.html","file":"pySDC/implementations/problem_classes/OuterSolarSystem.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":58,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_PenningTrap_3D_py":{"hash":"60b63c0263e9547d36d508b4f9590d04","index":{"url":"z_91faa57f8583c837_PenningTrap_3D_py.html","file":"pySDC/implementations/problem_classes/PenningTrap_3D.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":120,"n_excluded":4,"n_missing":10,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Piline_py":{"hash":"478e30902b983cef5bd346d1da8df93b","index":{"url":"z_91faa57f8583c837_Piline_py.html","file":"pySDC/implementations/problem_classes/Piline.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":44,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Quench_py":{"hash":"9dea18d5504e12d158eadf03080cfba3","index":{"url":"z_91faa57f8583c837_Quench_py.html","file":"pySDC/implementations/problem_classes/Quench.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":152,"n_excluded":8,"n_missing":35,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_TestEquation_0D_py":{"hash":"561b02cb327b970ea8a7fa1d6de9ceee","index":{"url":"z_91faa57f8583c837_TestEquation_0D_py.html","file":"pySDC/implementations/problem_classes/TestEquation_0D.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":53,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Van_der_Pol_implicit_py":{"hash":"b6711789da3cc47f2282432f75c9b718","index":{"url":"z_91faa57f8583c837_Van_der_Pol_implicit_py.html","file":"pySDC/implementations/problem_classes/Van_der_Pol_implicit.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":57,"n_excluded":2,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_VorticityVelocity_2D_FEniCS_periodic_py":{"hash":"20d08dd0944116f3294b821ba1d9cfd8","index":{"url":"z_91faa57f8583c837_VorticityVelocity_2D_FEniCS_periodic_py.html","file":"pySDC/implementations/problem_classes/VorticityVelocity_2D_FEniCS_periodic.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":108,"n_excluded":2,"n_missing":108,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c032a2f084ee6f96_buildFDMatrix_py":{"hash":"de1f0fe64c78df8beb8b053f316c8b77","index":{"url":"z_c032a2f084ee6f96_buildFDMatrix_py.html","file":"pySDC/implementations/problem_classes/acoustic_helpers/buildFDMatrix.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":145,"n_excluded":0,"n_missing":89,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c032a2f084ee6f96_buildWave1DMatrix_py":{"hash":"de100d9a7852319c85b8e55378734edd","index":{"url":"z_c032a2f084ee6f96_buildWave1DMatrix_py.html","file":"pySDC/implementations/problem_classes/acoustic_helpers/buildWave1DMatrix.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":28,"n_excluded":0,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c032a2f084ee6f96_standard_integrators_py":{"hash":"522c0c6ed96650584bf16bea335eb324","index":{"url":"z_c032a2f084ee6f96_standard_integrators_py.html","file":"pySDC/implementations/problem_classes/acoustic_helpers/standard_integrators.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":259,"n_excluded":0,"n_missing":11,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_850829697a149033_build2DFDMatrix_py":{"hash":"13dc630820804abc849ef9ba8ca011bb","index":{"url":"z_850829697a149033_build2DFDMatrix_py.html","file":"pySDC/implementations/problem_classes/boussinesq_helpers/build2DFDMatrix.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":59,"n_excluded":0,"n_missing":59,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_850829697a149033_buildBoussinesq2DMatrix_py":{"hash":"feace82f4a241545b5f95f840b96a6af","index":{"url":"z_850829697a149033_buildBoussinesq2DMatrix_py.html","file":"pySDC/implementations/problem_classes/boussinesq_helpers/buildBoussinesq2DMatrix.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":34,"n_excluded":0,"n_missing":34,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_850829697a149033_buildFDMatrix_py":{"hash":"5d12f9534fad2a03810f31aa06a86d3c","index":{"url":"z_850829697a149033_buildFDMatrix_py.html","file":"pySDC/implementations/problem_classes/boussinesq_helpers/buildFDMatrix.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":129,"n_excluded":2,"n_missing":129,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_850829697a149033_helper_classes_py":{"hash":"ee455db9d3c4698a012d8d9b08585250","index":{"url":"z_850829697a149033_helper_classes_py.html","file":"pySDC/implementations/problem_classes/boussinesq_helpers/helper_classes.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":19,"n_excluded":0,"n_missing":19,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_850829697a149033_standard_integrators_py":{"hash":"49360f471383361790baa15975efe262","index":{"url":"z_850829697a149033_standard_integrators_py.html","file":"pySDC/implementations/problem_classes/boussinesq_helpers/standard_integrators.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":394,"n_excluded":0,"n_missing":394,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_850829697a149033_unflatten_py":{"hash":"40b25aa2d0363ed8d89f6d304d27c1df","index":{"url":"z_850829697a149033_unflatten_py.html","file":"pySDC/implementations/problem_classes/boussinesq_helpers/unflatten.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":7,"n_excluded":0,"n_missing":7,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_generic_MPIFFT_Laplacian_py":{"hash":"8f73b2ed73cc364da98e4eb437a6dc62","index":{"url":"z_91faa57f8583c837_generic_MPIFFT_Laplacian_py.html","file":"pySDC/implementations/problem_classes/generic_MPIFFT_Laplacian.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":86,"n_excluded":2,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_generic_ND_FD_py":{"hash":"cdb94124190081f7792fe3701d659e36","index":{"url":"z_91faa57f8583c837_generic_ND_FD_py.html","file":"pySDC/implementations/problem_classes/generic_ND_FD.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":71,"n_excluded":10,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_nonlinear_ODE_1_py":{"hash":"430269973759a188002a00318831c754","index":{"url":"z_91faa57f8583c837_nonlinear_ODE_1_py.html","file":"pySDC/implementations/problem_classes/nonlinear_ODE_1.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":41,"n_excluded":1,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_odeScalar_py":{"hash":"329b087632d35ed0a02e32a6f786779b","index":{"url":"z_91faa57f8583c837_odeScalar_py.html","file":"pySDC/implementations/problem_classes/odeScalar.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":53,"n_excluded":6,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_odeSystem_py":{"hash":"c098354f2fd749134957ebdbacd0c9de","index":{"url":"z_91faa57f8583c837_odeSystem_py.html","file":"pySDC/implementations/problem_classes/odeSystem.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":187,"n_excluded":18,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_polynomial_test_problem_py":{"hash":"0f9491300369595fd5be02dae2f47145","index":{"url":"z_91faa57f8583c837_polynomial_test_problem_py.html","file":"pySDC/implementations/problem_classes/polynomial_test_problem.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":36,"n_excluded":1,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_Multistep_py":{"hash":"33a45e1beef256e10bb6f8b51607587f","index":{"url":"z_b9c274c7ffe3e178_Multistep_py.html","file":"pySDC/implementations/sweeper_classes/Multistep.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":83,"n_excluded":1,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_Runge_Kutta_py":{"hash":"4b01b6443592b1297a3de48c521a28e5","index":{"url":"z_b9c274c7ffe3e178_Runge_Kutta_py.html","file":"pySDC/implementations/sweeper_classes/Runge_Kutta.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":286,"n_excluded":18,"n_missing":18,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_Runge_Kutta_Nystrom_py":{"hash":"43a18409d1fbd13dc1b8219b36440dbb","index":{"url":"z_b9c274c7ffe3e178_Runge_Kutta_Nystrom_py.html","file":"pySDC/implementations/sweeper_classes/Runge_Kutta_Nystrom.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":89,"n_excluded":2,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_boris_2nd_order_py":{"hash":"add8cfec5f24044f91a3c5addfa67c8f","index":{"url":"z_b9c274c7ffe3e178_boris_2nd_order_py.html","file":"pySDC/implementations/sweeper_classes/boris_2nd_order.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":118,"n_excluded":2,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_explicit_py":{"hash":"757b98e73938924ec95507db3575ff8e","index":{"url":"z_b9c274c7ffe3e178_explicit_py.html","file":"pySDC/implementations/sweeper_classes/explicit.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":46,"n_excluded":0,"n_missing":46,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_generic_implicit_py":{"hash":"42184d1672682b786daaf3e6e3326228","index":{"url":"z_b9c274c7ffe3e178_generic_implicit_py.html","file":"pySDC/implementations/sweeper_classes/generic_implicit.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":51,"n_excluded":0,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_generic_implicit_MPI_py":{"hash":"2c9eaed0f173aaf875e0ac5eaa1ffe9a","index":{"url":"z_b9c274c7ffe3e178_generic_implicit_MPI_py.html","file":"pySDC/implementations/sweeper_classes/generic_implicit_MPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":106,"n_excluded":4,"n_missing":11,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_imex_1st_order_py":{"hash":"2c85911c7f34e207f06cccd86fa7ae8a","index":{"url":"z_b9c274c7ffe3e178_imex_1st_order_py.html","file":"pySDC/implementations/sweeper_classes/imex_1st_order.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":73,"n_excluded":2,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_imex_1st_order_MPI_py":{"hash":"3a34d72bc2278a10d45ee8560612673e","index":{"url":"z_b9c274c7ffe3e178_imex_1st_order_MPI_py.html","file":"pySDC/implementations/sweeper_classes/imex_1st_order_MPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":41,"n_excluded":0,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_imex_1st_order_mass_py":{"hash":"2629bfaa9a3ea075b9675cb59e9f6b4a","index":{"url":"z_b9c274c7ffe3e178_imex_1st_order_mass_py.html","file":"pySDC/implementations/sweeper_classes/imex_1st_order_mass.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":51,"n_excluded":1,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_multi_implicit_py":{"hash":"674b912d62ef1410aba3aa007c9d4b5a","index":{"url":"z_b9c274c7ffe3e178_multi_implicit_py.html","file":"pySDC/implementations/sweeper_classes/multi_implicit.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":59,"n_excluded":0,"n_missing":8,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_verlet_py":{"hash":"4a252f08ac66d25708a6c75791a5638b","index":{"url":"z_b9c274c7ffe3e178_verlet_py.html","file":"pySDC/implementations/sweeper_classes/verlet.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":73,"n_excluded":0,"n_missing":9,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_BaseTransferMPI_py":{"hash":"c3fc42c863e74cfc798c9860879c503f","index":{"url":"z_716c1644203275a5_BaseTransferMPI_py.html","file":"pySDC/implementations/transfer_classes/BaseTransferMPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":74,"n_excluded":6,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_BaseTransfer_mass_py":{"hash":"aa4e141fea6836cee301e1bf83608922","index":{"url":"z_716c1644203275a5_BaseTransfer_mass_py.html","file":"pySDC/implementations/transfer_classes/BaseTransfer_mass.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":84,"n_excluded":5,"n_missing":84,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_TransferFenicsMesh_py":{"hash":"68f1174bf3f1550921b37296fa2b2eab","index":{"url":"z_716c1644203275a5_TransferFenicsMesh_py.html","file":"pySDC/implementations/transfer_classes/TransferFenicsMesh.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":31,"n_excluded":4,"n_missing":11,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_TransferMesh_py":{"hash":"14356db013913f3a3b58f1efe88af456","index":{"url":"z_716c1644203275a5_TransferMesh_py.html","file":"pySDC/implementations/transfer_classes/TransferMesh.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":101,"n_excluded":10,"n_missing":25,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_TransferMesh_FFT_py":{"hash":"ed912095abaa0a5e2214d987b39c7607","index":{"url":"z_716c1644203275a5_TransferMesh_FFT_py.html","file":"pySDC/implementations/transfer_classes/TransferMesh_FFT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":30,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_TransferMesh_FFT2D_py":{"hash":"77a0dc16cdea2cfd6aba915cb09081c7","index":{"url":"z_716c1644203275a5_TransferMesh_FFT2D_py.html","file":"pySDC/implementations/transfer_classes/TransferMesh_FFT2D.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":51,"n_excluded":2,"n_missing":22,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_TransferMesh_MPIFFT_py":{"hash":"3358136a50df3899e33db29fb9103fc7","index":{"url":"z_716c1644203275a5_TransferMesh_MPIFFT_py.html","file":"pySDC/implementations/transfer_classes/TransferMesh_MPIFFT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":70,"n_excluded":4,"n_missing":8,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_TransferMesh_NoCoarse_py":{"hash":"6f1ca1d2287c3378aac12625e1b96b91","index":{"url":"z_716c1644203275a5_TransferMesh_NoCoarse_py.html","file":"pySDC/implementations/transfer_classes/TransferMesh_NoCoarse.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":18,"n_excluded":2,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_TransferPETScDMDA_py":{"hash":"cf96231ee2433e0cd59a117d3dc9a1bd","index":{"url":"z_716c1644203275a5_TransferPETScDMDA_py.html","file":"pySDC/implementations/transfer_classes/TransferPETScDMDA.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":34,"n_excluded":2,"n_missing":16,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_TransferParticles_NoCoarse_py":{"hash":"4d4f58c6dcef175b58676157515f89aa","index":{"url":"z_716c1644203275a5_TransferParticles_NoCoarse_py.html","file":"pySDC/implementations/transfer_classes/TransferParticles_NoCoarse.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":22,"n_excluded":3,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_AllenCahn_dump_py":{"hash":"a165fb727e1378e455b3733399dd4064","index":{"url":"z_0c21c203c9df60ee_AllenCahn_dump_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/AllenCahn_dump.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":91,"n_excluded":0,"n_missing":91,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_AllenCahn_monitor_py":{"hash":"bb7b7ea9ce1b9afc7bddfb8e0591f5ea","index":{"url":"z_0c21c203c9df60ee_AllenCahn_monitor_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/AllenCahn_monitor.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":68,"n_excluded":2,"n_missing":9,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_AllenCahn_monitor_and_dump_py":{"hash":"4f6562d4d265b44325626a4b2b8c6f22","index":{"url":"z_0c21c203c9df60ee_AllenCahn_monitor_and_dump_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/AllenCahn_monitor_and_dump.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":122,"n_excluded":2,"n_missing":122,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_run_simple_forcing_benchmark_py":{"hash":"5c50ae1cae46907b987cf20b13200dff","index":{"url":"z_0c21c203c9df60ee_run_simple_forcing_benchmark_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/run_simple_forcing_benchmark.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":80,"n_excluded":11,"n_missing":80,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_run_simple_forcing_verification_py":{"hash":"31146ffe9918d2596780321ec941b444","index":{"url":"z_0c21c203c9df60ee_run_simple_forcing_verification_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/run_simple_forcing_verification.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":172,"n_excluded":12,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_run_temp_forcing_benchmark_py":{"hash":"39ab8282333dad3bb3f906989cbcda1a","index":{"url":"z_0c21c203c9df60ee_run_temp_forcing_benchmark_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/run_temp_forcing_benchmark.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":78,"n_excluded":10,"n_missing":78,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_run_temp_forcing_realistic_py":{"hash":"1b4545ee017cda0070349b502f606179","index":{"url":"z_0c21c203c9df60ee_run_temp_forcing_realistic_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/run_temp_forcing_realistic.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":74,"n_excluded":9,"n_missing":74,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_run_temp_forcing_reference_py":{"hash":"073fc300c9e19253d5179f116bfa387e","index":{"url":"z_0c21c203c9df60ee_run_temp_forcing_reference_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/run_temp_forcing_reference.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":74,"n_excluded":9,"n_missing":74,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_run_temp_forcing_verification_py":{"hash":"730a3fafa95769ba57af09d4348bec4a","index":{"url":"z_0c21c203c9df60ee_run_temp_forcing_verification_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/run_temp_forcing_verification.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":109,"n_excluded":9,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_visualize_py":{"hash":"c9b6d6b367f458d5f08cab4fc8097f00","index":{"url":"z_0c21c203c9df60ee_visualize_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/visualize.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":22,"n_excluded":3,"n_missing":22,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_visualize_temp_py":{"hash":"af34cb95bef1a12f1258f3fdcd999d1e","index":{"url":"z_0c21c203c9df60ee_visualize_temp_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/visualize_temp.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":62,"n_excluded":9,"n_missing":62,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73a9842ab7402c4a_PFASST_conv_Linf_py":{"hash":"c709c4eb4fd730afe66b3fd174c51783","index":{"url":"z_73a9842ab7402c4a_PFASST_conv_Linf_py.html","file":"pySDC/projects/AsympConv/PFASST_conv_Linf.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":157,"n_excluded":18,"n_missing":7,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73a9842ab7402c4a_PFASST_conv_tests_py":{"hash":"7a7bf76e1107013aa65a9e63eebf4827","index":{"url":"z_73a9842ab7402c4a_PFASST_conv_tests_py.html","file":"pySDC/projects/AsympConv/PFASST_conv_tests.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":156,"n_excluded":18,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73a9842ab7402c4a_conv_test_to0_py":{"hash":"46ca81701f434fa968ee1f5f34df9093","index":{"url":"z_73a9842ab7402c4a_conv_test_to0_py.html","file":"pySDC/projects/AsympConv/conv_test_to0.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":46,"n_excluded":3,"n_missing":46,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73a9842ab7402c4a_conv_test_toinf_py":{"hash":"592b8d77c886686b8d2fd4adc265fc08","index":{"url":"z_73a9842ab7402c4a_conv_test_toinf_py.html","file":"pySDC/projects/AsympConv/conv_test_toinf.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":46,"n_excluded":5,"n_missing":46,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73a9842ab7402c4a_smoother_specrad_heatmap_py":{"hash":"1d28c90a2e15b6028a032baaf49a2198","index":{"url":"z_73a9842ab7402c4a_smoother_specrad_heatmap_py.html","file":"pySDC/projects/AsympConv/smoother_specrad_heatmap.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":82,"n_excluded":4,"n_missing":82,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0a363dd8c140c711_hooksDAE_py":{"hash":"a6c1291020ee5b023a712ed2aa755098","index":{"url":"z_0a363dd8c140c711_hooksDAE_py.html","file":"pySDC/projects/DAE/misc/hooksDAE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":19,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0a363dd8c140c711_meshDAE_py":{"hash":"2e724b6316fc2852ee10adf40b70021c","index":{"url":"z_0a363dd8c140c711_meshDAE_py.html","file":"pySDC/projects/DAE/misc/meshDAE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":3,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0a363dd8c140c711_problemDAE_py":{"hash":"382c854502bf2d4e4e651848e42b1e17","index":{"url":"z_0a363dd8c140c711_problemDAE_py.html","file":"pySDC/projects/DAE/misc/problemDAE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":22,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0eb34c630be51b75_discontinuousTestDAE_py":{"hash":"c1e0c0b20290708fce9f8d07a2b5da01","index":{"url":"z_0eb34c630be51b75_discontinuousTestDAE_py.html","file":"pySDC/projects/DAE/problems/discontinuousTestDAE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":55,"n_excluded":0,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0eb34c630be51b75_pendulum2D_py":{"hash":"33335e975a1d6a5e2946d8109207e89f","index":{"url":"z_0eb34c630be51b75_pendulum2D_py.html","file":"pySDC/projects/DAE/problems/pendulum2D.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":25,"n_excluded":0,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0eb34c630be51b75_problematicF_py":{"hash":"c208f71cd1fc237409a80e78209786a6","index":{"url":"z_0eb34c630be51b75_problematicF_py.html","file":"pySDC/projects/DAE/problems/problematicF.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":22,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0eb34c630be51b75_simpleDAE_py":{"hash":"361d9422538bd87cf3c953c10ffc63a7","index":{"url":"z_0eb34c630be51b75_simpleDAE_py.html","file":"pySDC/projects/DAE/problems/simpleDAE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":22,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0eb34c630be51b75_synchronousMachine_py":{"hash":"38bb2b0798c469ac9800ebcfd1c27a3e","index":{"url":"z_0eb34c630be51b75_synchronousMachine_py.html","file":"pySDC/projects/DAE/problems/synchronousMachine.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":75,"n_excluded":0,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0eb34c630be51b75_transistorAmplifier_py":{"hash":"56ef517eaff53caa5bff9ff9aab21198","index":{"url":"z_0eb34c630be51b75_transistorAmplifier_py.html","file":"pySDC/projects/DAE/problems/transistorAmplifier.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":59,"n_excluded":0,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0eb34c630be51b75_wscc9BusSystem_py":{"hash":"3105c6b590244b3c4f95a867f3bd0490","index":{"url":"z_0eb34c630be51b75_wscc9BusSystem_py.html","file":"pySDC/projects/DAE/problems/wscc9BusSystem.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":214,"n_excluded":2,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_4ef83d310f553371_accuracy_check_MPI_py":{"hash":"1f60aa30e23fbc9b7104e1511cfb816d","index":{"url":"z_4ef83d310f553371_accuracy_check_MPI_py.html","file":"pySDC/projects/DAE/run/accuracy_check_MPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":56,"n_excluded":4,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_4ef83d310f553371_fully_implicit_dae_playground_py":{"hash":"7aaf40f6396c5bdf0c491b80a097f1df","index":{"url":"z_4ef83d310f553371_fully_implicit_dae_playground_py.html","file":"pySDC/projects/DAE/run/fully_implicit_dae_playground.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":49,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_4ef83d310f553371_run_convergence_test_py":{"hash":"36c77f07b17e4a87fc69fa0a66c3bf1d","index":{"url":"z_4ef83d310f553371_run_convergence_test_py.html","file":"pySDC/projects/DAE/run/run_convergence_test.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":60,"n_excluded":6,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_4ef83d310f553371_run_iteration_test_py":{"hash":"1242e21f2048e8303eab390bbef01960","index":{"url":"z_4ef83d310f553371_run_iteration_test_py.html","file":"pySDC/projects/DAE/run/run_iteration_test.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":64,"n_excluded":6,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_4ef83d310f553371_synchronous_machine_playground_py":{"hash":"1bb24ec5ee1c1a431c83eaf436f90d9e","index":{"url":"z_4ef83d310f553371_synchronous_machine_playground_py.html","file":"pySDC/projects/DAE/run/synchronous_machine_playground.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":56,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_15820e38ae7f8080_fullyImplicitDAE_py":{"hash":"ab2fd21e01e77916c913cfdf2a81891f","index":{"url":"z_15820e38ae7f8080_fullyImplicitDAE_py.html","file":"pySDC/projects/DAE/sweepers/fullyImplicitDAE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":77,"n_excluded":6,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_15820e38ae7f8080_fullyImplicitDAEMPI_py":{"hash":"68f89253df95762a8b48ef4181b13425","index":{"url":"z_15820e38ae7f8080_fullyImplicitDAEMPI_py.html","file":"pySDC/projects/DAE/sweepers/fullyImplicitDAEMPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":58,"n_excluded":4,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_15820e38ae7f8080_rungeKuttaDAE_py":{"hash":"a5623e35f0b1e5a602a740b73605c433","index":{"url":"z_15820e38ae7f8080_rungeKuttaDAE_py.html","file":"pySDC/projects/DAE/sweepers/rungeKuttaDAE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":50,"n_excluded":5,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_15820e38ae7f8080_semiImplicitDAE_py":{"hash":"ab06faba30c319416d496621d42a0101","index":{"url":"z_15820e38ae7f8080_semiImplicitDAE_py.html","file":"pySDC/projects/DAE/sweepers/semiImplicitDAE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":52,"n_excluded":2,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_15820e38ae7f8080_semiImplicitDAEMPI_py":{"hash":"7b832b216e1c1d57cf83a9f5c76b833c","index":{"url":"z_15820e38ae7f8080_semiImplicitDAEMPI_py.html","file":"pySDC/projects/DAE/sweepers/semiImplicitDAEMPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":31,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_AcousticAdvection_1D_FD_imex_multiscale_py":{"hash":"8fc11269c623292b5ab975c63cdbb3f1","index":{"url":"z_60ee0c9d7735ef11_AcousticAdvection_1D_FD_imex_multiscale_py.html","file":"pySDC/projects/FastWaveSlowWave/AcousticAdvection_1D_FD_imex_multiscale.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":13,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_HookClass_acoustic_py":{"hash":"60c739f4f66d646569b9e83e1e54ec1b","index":{"url":"z_60ee0c9d7735ef11_HookClass_acoustic_py.html","file":"pySDC/projects/FastWaveSlowWave/HookClass_acoustic.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":12,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_HookClass_boussinesq_py":{"hash":"e9b91415aa7a1b9b7c050f7e952f56fb","index":{"url":"z_60ee0c9d7735ef11_HookClass_boussinesq_py.html","file":"pySDC/projects/FastWaveSlowWave/HookClass_boussinesq.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":11,"n_excluded":0,"n_missing":11,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_plot_dispersion_py":{"hash":"d2e45bae6b27b320d3b4899e15595511","index":{"url":"z_60ee0c9d7735ef11_plot_dispersion_py.html","file":"pySDC/projects/FastWaveSlowWave/plot_dispersion.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":115,"n_excluded":8,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_plot_stab_vs_k_py":{"hash":"dd2d419e94ae9eb068aeeaa064fbce4e","index":{"url":"z_60ee0c9d7735ef11_plot_stab_vs_k_py.html","file":"pySDC/projects/FastWaveSlowWave/plot_stab_vs_k.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":62,"n_excluded":13,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_plot_stability_py":{"hash":"442784cdc96f1c55ac3dd2075875d2ec","index":{"url":"z_60ee0c9d7735ef11_plot_stability_py.html","file":"pySDC/projects/FastWaveSlowWave/plot_stability.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":75,"n_excluded":9,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_plot_stifflimit_specrad_py":{"hash":"4e2fc67f9d003b878394b0d7d2e3aee2","index":{"url":"z_60ee0c9d7735ef11_plot_stifflimit_specrad_py.html","file":"pySDC/projects/FastWaveSlowWave/plot_stifflimit_specrad.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":82,"n_excluded":9,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_plotgmrescounter_boussinesq_py":{"hash":"8ba8ead87180dba257283974497539ed","index":{"url":"z_60ee0c9d7735ef11_plotgmrescounter_boussinesq_py.html","file":"pySDC/projects/FastWaveSlowWave/plotgmrescounter_boussinesq.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":35,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_runconvergence_acoustic_py":{"hash":"60316a3ce3d70848b7a2727383d7f158","index":{"url":"z_60ee0c9d7735ef11_runconvergence_acoustic_py.html","file":"pySDC/projects/FastWaveSlowWave/runconvergence_acoustic.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":115,"n_excluded":3,"n_missing":57,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_rungmrescounter_boussinesq_py":{"hash":"29b6d1c1cef97fabc4a65c803ae98f51","index":{"url":"z_60ee0c9d7735ef11_rungmrescounter_boussinesq_py.html","file":"pySDC/projects/FastWaveSlowWave/rungmrescounter_boussinesq.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":112,"n_excluded":8,"n_missing":112,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_runitererror_acoustic_py":{"hash":"5ff39e1615f0edfb9f292c5d053ccd51","index":{"url":"z_60ee0c9d7735ef11_runitererror_acoustic_py.html","file":"pySDC/projects/FastWaveSlowWave/runitererror_acoustic.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":83,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_runmultiscale_acoustic_py":{"hash":"8a3967ae617d4a6317b7e6bcf3ec5b82","index":{"url":"z_60ee0c9d7735ef11_runmultiscale_acoustic_py.html","file":"pySDC/projects/FastWaveSlowWave/runmultiscale_acoustic.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":97,"n_excluded":2,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_f7d64113b0673500_ac_fft_py":{"hash":"f5dd3744d42cff813ccb3a7307f5d857","index":{"url":"z_f7d64113b0673500_ac_fft_py.html","file":"pySDC/projects/GPU/ac_fft.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":50,"n_excluded":7,"n_missing":50,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_f7d64113b0673500_heat_py":{"hash":"b48c824a0aa1601054dfc3e81e0f099a","index":{"url":"z_f7d64113b0673500_heat_py.html","file":"pySDC/projects/GPU/heat.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":6,"n_excluded":86,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_020efe120a771d8a_fput_py":{"hash":"d07f44de54eff746144b599e3d5d6854","index":{"url":"z_020efe120a771d8a_fput_py.html","file":"pySDC/projects/Hamiltonian/fput.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":134,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_020efe120a771d8a_hamiltonian_and_energy_output_py":{"hash":"785086f432853d38a8f0626f1509846a","index":{"url":"z_020efe120a771d8a_hamiltonian_and_energy_output_py.html","file":"pySDC/projects/Hamiltonian/hamiltonian_and_energy_output.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":31,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_020efe120a771d8a_hamiltonian_output_py":{"hash":"ecff87412424b74a881189ba51ae156b","index":{"url":"z_020efe120a771d8a_hamiltonian_output_py.html","file":"pySDC/projects/Hamiltonian/hamiltonian_output.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":24,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_020efe120a771d8a_harmonic_oscillator_py":{"hash":"fb77d489b282da9131a7837a93c12fb9","index":{"url":"z_020efe120a771d8a_harmonic_oscillator_py.html","file":"pySDC/projects/Hamiltonian/harmonic_oscillator.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":88,"n_excluded":2,"n_missing":88,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_020efe120a771d8a_simple_problems_py":{"hash":"a2cd7ced9c7a16ccd46adc89c57185c0","index":{"url":"z_020efe120a771d8a_simple_problems_py.html","file":"pySDC/projects/Hamiltonian/simple_problems.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":128,"n_excluded":3,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_020efe120a771d8a_solar_system_py":{"hash":"b6f77003f820e96b129dcd0f0ca0ee0b","index":{"url":"z_020efe120a771d8a_solar_system_py.html","file":"pySDC/projects/Hamiltonian/solar_system.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":157,"n_excluded":4,"n_missing":7,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_020efe120a771d8a_stop_at_error_hook_py":{"hash":"5c82130bee0e73df25baab9e22b8f85b","index":{"url":"z_020efe120a771d8a_stop_at_error_hook_py.html","file":"pySDC/projects/Hamiltonian/stop_at_error_hook.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":12,"n_excluded":0,"n_missing":12,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_6211a37896fa1d13_my_mesh_py":{"hash":"04be58dc568aaf86d7fe222530cadc67","index":{"url":"z_6211a37896fa1d13_my_mesh_py.html","file":"pySDC/projects/Monodomain/datatype_classes/my_mesh.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":3,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_21a23c20069de70c_HookClass_pde_py":{"hash":"a86ca6ee468cabb15c3adc33ce5340f6","index":{"url":"z_21a23c20069de70c_HookClass_pde_py.html","file":"pySDC/projects/Monodomain/hooks/HookClass_pde.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":16,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_21a23c20069de70c_HookClass_post_iter_info_py":{"hash":"6bb67802f4e4263e652ed009abc77296","index":{"url":"z_21a23c20069de70c_HookClass_post_iter_info_py.html","file":"pySDC/projects/Monodomain/hooks/HookClass_post_iter_info.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":10,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c11e9d9b9bfcaf22_MonodomainODE_py":{"hash":"813abf9141ed1fd9577ba7d9678e6874","index":{"url":"z_c11e9d9b9bfcaf22_MonodomainODE_py.html","file":"pySDC/projects/Monodomain/problem_classes/MonodomainODE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":186,"n_excluded":2,"n_missing":10,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c11e9d9b9bfcaf22_TestODE_py":{"hash":"b6842898bec34345387508a6ba11363c","index":{"url":"z_c11e9d9b9bfcaf22_TestODE_py.html","file":"pySDC/projects/Monodomain/problem_classes/TestODE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":76,"n_excluded":0,"n_missing":7,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7d0f5cc921d43478___init___py":{"hash":"44b4524894dcdbfc38c06088505fc752","index":{"url":"z_7d0f5cc921d43478___init___py.html","file":"pySDC/projects/Monodomain/problem_classes/ionicmodels/cpp/__init__.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":5,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_4234e39c002aaf5f_Parabolic_DCT_py":{"hash":"253840d628efc82ee4a7d4fa8e57ac87","index":{"url":"z_4234e39c002aaf5f_Parabolic_DCT_py.html","file":"pySDC/projects/Monodomain/problem_classes/space_discretizazions/Parabolic_DCT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":149,"n_excluded":1,"n_missing":27,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5a4fc9be2b02ba20_run_MonodomainODE_py":{"hash":"0e94721489fa0732c833cab47f7843c1","index":{"url":"z_5a4fc9be2b02ba20_run_MonodomainODE_py.html","file":"pySDC/projects/Monodomain/run_scripts/run_MonodomainODE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":205,"n_excluded":3,"n_missing":26,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5a4fc9be2b02ba20_run_MonodomainODE_cli_py":{"hash":"7e7aa9ca300af7b1553c73d236475af6","index":{"url":"z_5a4fc9be2b02ba20_run_MonodomainODE_cli_py.html","file":"pySDC/projects/Monodomain/run_scripts/run_MonodomainODE_cli.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":35,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5a4fc9be2b02ba20_run_TestODE_py":{"hash":"e8f9e2153bd05a907eedbfb802d75181","index":{"url":"z_5a4fc9be2b02ba20_run_TestODE_py.html","file":"pySDC/projects/Monodomain/run_scripts/run_TestODE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":168,"n_excluded":4,"n_missing":16,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ec92d03b7ea04ce_imexexp_1st_order_py":{"hash":"65f9923f031a97c05ef52d3bc6143974","index":{"url":"z_1ec92d03b7ea04ce_imexexp_1st_order_py.html","file":"pySDC/projects/Monodomain/sweeper_classes/exponential_runge_kutta/imexexp_1st_order.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":121,"n_excluded":2,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_44068b31c6dbca40_imexexp_1st_order_py":{"hash":"10951382ce3198d39d07b6c680c466a1","index":{"url":"z_44068b31c6dbca40_imexexp_1st_order_py.html","file":"pySDC/projects/Monodomain/sweeper_classes/runge_kutta/imexexp_1st_order.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":54,"n_excluded":1,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_f092600e49a290b3_TransferVectorOfDCTVectors_py":{"hash":"90248b1b7865ab6680b02b36772db586","index":{"url":"z_f092600e49a290b3_TransferVectorOfDCTVectors_py.html","file":"pySDC/projects/Monodomain/transfer_classes/TransferVectorOfDCTVectors.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":25,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_f092600e49a290b3_Transfer_DCT_Vector_py":{"hash":"635e5fa5978b8f33d9c0592ea6fcb4cc","index":{"url":"z_f092600e49a290b3_Transfer_DCT_Vector_py.html","file":"pySDC/projects/Monodomain/transfer_classes/Transfer_DCT_Vector.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":24,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_04cb75334c2a5eef_data_management_py":{"hash":"870b65e69a48b9266060b9077c008db7","index":{"url":"z_04cb75334c2a5eef_data_management_py.html","file":"pySDC/projects/Monodomain/utils/data_management.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":24,"n_excluded":1,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_74ce84641ea8e5a0_controller_MPI_scorep_py":{"hash":"c8260e78e3d03867c79505c50d3b31fd","index":{"url":"z_74ce84641ea8e5a0_controller_MPI_scorep_py.html","file":"pySDC/projects/Performance/controller_MPI_scorep.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":283,"n_excluded":7,"n_missing":283,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_74ce84641ea8e5a0_run_simple_forcing_benchmark_py":{"hash":"ce8b47cece2bef01d569c30f7a24e51b","index":{"url":"z_74ce84641ea8e5a0_run_simple_forcing_benchmark_py.html","file":"pySDC/projects/Performance/run_simple_forcing_benchmark.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":83,"n_excluded":11,"n_missing":83,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_74ce84641ea8e5a0_visualize_py":{"hash":"519576124b9bdd1cf7a4a3bf5402c59f","index":{"url":"z_74ce84641ea8e5a0_visualize_py.html","file":"pySDC/projects/Performance/visualize.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":41,"n_excluded":3,"n_missing":41,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_66292b4c3b6b9cb6_battery_model_py":{"hash":"1ee265d15d68d7fd3266625fd97de11a","index":{"url":"z_66292b4c3b6b9cb6_battery_model_py.html","file":"pySDC/projects/PinTSimE/battery_model.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":126,"n_excluded":59,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_66292b4c3b6b9cb6_buck_model_py":{"hash":"5ef5e00bab8e30b564310d89b167a8e1","index":{"url":"z_66292b4c3b6b9cb6_buck_model_py.html","file":"pySDC/projects/PinTSimE/buck_model.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":13,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_66292b4c3b6b9cb6_discontinuous_test_ODE_py":{"hash":"e21a9884573da22931e2ae8d2966fbf5","index":{"url":"z_66292b4c3b6b9cb6_discontinuous_test_ODE_py.html","file":"pySDC/projects/PinTSimE/discontinuous_test_ODE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":26,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_66292b4c3b6b9cb6_estimation_check_py":{"hash":"22a48c9670ec478a1c8043c5ba0167e4","index":{"url":"z_66292b4c3b6b9cb6_estimation_check_py.html","file":"pySDC/projects/PinTSimE/estimation_check.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":31,"n_excluded":273,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_66292b4c3b6b9cb6_hardcoded_solutions_py":{"hash":"49ccd434415b17640e3089e343037bef","index":{"url":"z_66292b4c3b6b9cb6_hardcoded_solutions_py.html","file":"pySDC/projects/PinTSimE/hardcoded_solutions.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":133,"n_excluded":1,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a34c610d01aeb704_log_event_py":{"hash":"fb9ae8a84c79649bacb5d72b617c5d9c","index":{"url":"z_a34c610d01aeb704_log_event_py.html","file":"pySDC/projects/PinTSimE/paper_PSCC2024/log_event.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":14,"n_excluded":0,"n_missing":5,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_66292b4c3b6b9cb6_piline_model_py":{"hash":"e928f0e937dde3102a0aa5d4523078ba","index":{"url":"z_66292b4c3b6b9cb6_piline_model_py.html","file":"pySDC/projects/PinTSimE/piline_model.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":13,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_66292b4c3b6b9cb6_switch_estimator_py":{"hash":"bfe2f2042475ffe6ee2084c3eabcb61b","index":{"url":"z_66292b4c3b6b9cb6_switch_estimator_py.html","file":"pySDC/projects/PinTSimE/switch_estimator.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":105,"n_excluded":1,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73bf12c1262fa441_equidistant_RDC_py":{"hash":"2ec1c89ceb126d68ba4cede5a8a487b2","index":{"url":"z_73bf12c1262fa441_equidistant_RDC_py.html","file":"pySDC/projects/RDC/equidistant_RDC.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":81,"n_excluded":8,"n_missing":7,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73bf12c1262fa441_vanderpol_MLSDC_PFASST_test_py":{"hash":"ca250ea5d3e6c5ef3e56954f557c6348","index":{"url":"z_73bf12c1262fa441_vanderpol_MLSDC_PFASST_test_py.html","file":"pySDC/projects/RDC/vanderpol_MLSDC_PFASST_test.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":63,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73bf12c1262fa441_vanderpol_error_test_py":{"hash":"077d3f70e92c74a2c5ce76a9afeb853e","index":{"url":"z_73bf12c1262fa441_vanderpol_error_test_py.html","file":"pySDC/projects/RDC/vanderpol_error_test.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":82,"n_excluded":3,"n_missing":82,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73bf12c1262fa441_vanderpol_reference_py":{"hash":"7809c275880fc741ab90214b655fd4eb","index":{"url":"z_73bf12c1262fa441_vanderpol_reference_py.html","file":"pySDC/projects/RDC/vanderpol_reference.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":35,"n_excluded":2,"n_missing":35,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_AC_py":{"hash":"6dc67adbe42c915742a3d019db72a2fe","index":{"url":"z_5893b65af8042ae2_AC_py.html","file":"pySDC/projects/Resilience/AC.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":162,"n_excluded":71,"n_missing":131,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_FDeigenvalues_py":{"hash":"fc2a809ab4aef727a8a34039b23366be","index":{"url":"z_5893b65af8042ae2_FDeigenvalues_py.html","file":"pySDC/projects/Resilience/FDeigenvalues.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":10,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_Lorenz_py":{"hash":"11339a84ec913edf0b599b78a47a0992","index":{"url":"z_5893b65af8042ae2_Lorenz_py.html","file":"pySDC/projects/Resilience/Lorenz.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":70,"n_excluded":23,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_Schroedinger_py":{"hash":"137c4ddb374e9fa0468fa2b404094f7b","index":{"url":"z_5893b65af8042ae2_Schroedinger_py.html","file":"pySDC/projects/Resilience/Schroedinger.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":82,"n_excluded":44,"n_missing":11,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_accuracy_check_py":{"hash":"3010b9565ad49096be27ae7e27be7d8e","index":{"url":"z_5893b65af8042ae2_accuracy_check_py.html","file":"pySDC/projects/Resilience/accuracy_check.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":142,"n_excluded":7,"n_missing":29,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_advection_py":{"hash":"eace70e3a2b82706909813bcfd6e936e","index":{"url":"z_5893b65af8042ae2_advection_py.html","file":"pySDC/projects/Resilience/advection.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":59,"n_excluded":17,"n_missing":18,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_collocation_adaptivity_py":{"hash":"a0edcabde70222d88c345da9ade87ede","index":{"url":"z_5893b65af8042ae2_collocation_adaptivity_py.html","file":"pySDC/projects/Resilience/collocation_adaptivity.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":132,"n_excluded":3,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_dahlquist_py":{"hash":"6ca916d38ec3c2ee5a7b8e05328a956a","index":{"url":"z_5893b65af8042ae2_dahlquist_py.html","file":"pySDC/projects/Resilience/dahlquist.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":147,"n_excluded":12,"n_missing":147,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_extrapolation_within_Q_py":{"hash":"3a044aafbd04044de6f982663d4c882d","index":{"url":"z_5893b65af8042ae2_extrapolation_within_Q_py.html","file":"pySDC/projects/Resilience/extrapolation_within_Q.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":53,"n_excluded":2,"n_missing":53,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_fault_injection_py":{"hash":"a059c27aba2123484387723d4a6fee1f","index":{"url":"z_5893b65af8042ae2_fault_injection_py.html","file":"pySDC/projects/Resilience/fault_injection.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":184,"n_excluded":9,"n_missing":16,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_fault_stats_py":{"hash":"484b6adc2c6e9fcdc767c6e739fb68f2","index":{"url":"z_5893b65af8042ae2_fault_stats_py.html","file":"pySDC/projects/Resilience/fault_stats.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":437,"n_excluded":656,"n_missing":181,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_heat_py":{"hash":"001ad6ef2ef04f438eb0fb533dc71b85","index":{"url":"z_5893b65af8042ae2_heat_py.html","file":"pySDC/projects/Resilience/heat.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":35,"n_excluded":8,"n_missing":26,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_hook_py":{"hash":"8965023300ba13fb897a19cfe5759e3a","index":{"url":"z_5893b65af8042ae2_hook_py.html","file":"pySDC/projects/Resilience/hook.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":29,"n_excluded":0,"n_missing":9,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_paper_plots_py":{"hash":"2a6ece8cb22ad59c957d8fba2fdd0269","index":{"url":"z_5893b65af8042ae2_paper_plots_py.html","file":"pySDC/projects/Resilience/paper_plots.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":26,"n_excluded":509,"n_missing":26,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_piline_py":{"hash":"4ac8c412e82cd6f3d61f6dcc6f0525cb","index":{"url":"z_5893b65af8042ae2_piline_py.html","file":"pySDC/projects/Resilience/piline.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":141,"n_excluded":8,"n_missing":19,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_quench_py":{"hash":"27920f839e31b3b607f77b47933dce55","index":{"url":"z_5893b65af8042ae2_quench_py.html","file":"pySDC/projects/Resilience/quench.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":217,"n_excluded":128,"n_missing":111,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_strategies_py":{"hash":"bcd488dbbca11f8f60a0c3991f40dee5","index":{"url":"z_5893b65af8042ae2_strategies_py.html","file":"pySDC/projects/Resilience/strategies.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":867,"n_excluded":11,"n_missing":244,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_sweepers_py":{"hash":"493d4891b34946605485b963c9274341","index":{"url":"z_5893b65af8042ae2_sweepers_py.html","file":"pySDC/projects/Resilience/sweepers.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":103,"n_excluded":1,"n_missing":9,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_vdp_py":{"hash":"dbfa62f341e3a4f235536e339dea0d02","index":{"url":"z_5893b65af8042ae2_vdp_py.html","file":"pySDC/projects/Resilience/vdp.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":195,"n_excluded":93,"n_missing":35,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_work_precision_py":{"hash":"0c35152f78ba5b26ae0150b9e2b96689","index":{"url":"z_5893b65af8042ae2_work_precision_py.html","file":"pySDC/projects/Resilience/work_precision.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":348,"n_excluded":464,"n_missing":348,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_327f90590a9d3ec6_SDC_timing_Fisher_py":{"hash":"f05551d98583c46ac59cfea57b7e32f9","index":{"url":"z_327f90590a9d3ec6_SDC_timing_Fisher_py.html","file":"pySDC/projects/SDC_showdown/SDC_timing_Fisher.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":109,"n_excluded":11,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_327f90590a9d3ec6_SDC_timing_GrayScott_py":{"hash":"0ac80078a94070d4b76eb663006193c6","index":{"url":"z_327f90590a9d3ec6_SDC_timing_GrayScott_py.html","file":"pySDC/projects/SDC_showdown/SDC_timing_GrayScott.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":146,"n_excluded":11,"n_missing":30,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_check_data_folder_py":{"hash":"816be2d6d8d4363216c2157a3e2db565","index":{"url":"z_e65ba0b64d945c43_check_data_folder_py.html","file":"pySDC/projects/Second_orderSDC/check_data_folder.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":4,"n_excluded":1,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_harmonic_oscillator_params_py":{"hash":"e1b7b78c9e946b25a44fa72bf44a6e39","index":{"url":"z_e65ba0b64d945c43_harmonic_oscillator_params_py.html","file":"pySDC/projects/Second_orderSDC/harmonic_oscillator_params.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":10,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_harmonic_oscillator_run_points_py":{"hash":"fda4566f65964d06fb45f1d7221880a9","index":{"url":"z_e65ba0b64d945c43_harmonic_oscillator_run_points_py.html","file":"pySDC/projects/Second_orderSDC/harmonic_oscillator_run_points.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":3,"n_excluded":8,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_harmonic_oscillator_run_stab_interval_py":{"hash":"4fc57d018ed3c9ce93d0413be6e00c95","index":{"url":"z_e65ba0b64d945c43_harmonic_oscillator_run_stab_interval_py.html","file":"pySDC/projects/Second_orderSDC/harmonic_oscillator_run_stab_interval.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":3,"n_excluded":8,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_harmonic_oscillator_run_stability_py":{"hash":"5dcfc7e145b22918d52fca6a6fc5ea54","index":{"url":"z_e65ba0b64d945c43_harmonic_oscillator_run_stability_py.html","file":"pySDC/projects/Second_orderSDC/harmonic_oscillator_run_stability.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":2,"n_excluded":10,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_penningtrap_HookClass_py":{"hash":"85eb5580949ae41da88a91a16a23d09e","index":{"url":"z_e65ba0b64d945c43_penningtrap_HookClass_py.html","file":"pySDC/projects/Second_orderSDC/penningtrap_HookClass.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":19,"n_excluded":24,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_penningtrap_Simulation_py":{"hash":"bc110763555f1747871c3c1127cb04ea","index":{"url":"z_e65ba0b64d945c43_penningtrap_Simulation_py.html","file":"pySDC/projects/Second_orderSDC/penningtrap_Simulation.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":133,"n_excluded":5,"n_missing":32,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_penningtrap_params_py":{"hash":"53daf51fc6cd8b10401c92222a97cf79","index":{"url":"z_e65ba0b64d945c43_penningtrap_params_py.html","file":"pySDC/projects/Second_orderSDC/penningtrap_params.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":27,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_penningtrap_run_Hamiltonian_error_py":{"hash":"86c7e7c68d614b7958b6a25c86276e98","index":{"url":"z_e65ba0b64d945c43_penningtrap_run_Hamiltonian_error_py.html","file":"pySDC/projects/Second_orderSDC/penningtrap_run_Hamiltonian_error.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":10,"n_excluded":116,"n_missing":10,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_penningtrap_run_error_py":{"hash":"6f9c0db4e860d420115e6a426976530d","index":{"url":"z_e65ba0b64d945c43_penningtrap_run_error_py.html","file":"pySDC/projects/Second_orderSDC/penningtrap_run_error.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":2,"n_excluded":8,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_penningtrap_run_work_precision_py":{"hash":"9a7107b9c45239a2c0428e6e24b38f53","index":{"url":"z_e65ba0b64d945c43_penningtrap_run_work_precision_py.html","file":"pySDC/projects/Second_orderSDC/penningtrap_run_work_precision.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":3,"n_excluded":8,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_plot_helper_py":{"hash":"ff58236fdf96cad464c7162adc2e98cf","index":{"url":"z_e65ba0b64d945c43_plot_helper_py.html","file":"pySDC/projects/Second_orderSDC/plot_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":4,"n_excluded":392,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_stability_simulation_py":{"hash":"5d27c04a04a94518f351eafd318274e1","index":{"url":"z_e65ba0b64d945c43_stability_simulation_py.html","file":"pySDC/projects/Second_orderSDC/stability_simulation.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":107,"n_excluded":108,"n_missing":11,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_cf9ddae6e6f0d80b_AllenCahn_contracting_circle_py":{"hash":"b03d0f0cc571a7119bedc6290f3143a2","index":{"url":"z_cf9ddae6e6f0d80b_AllenCahn_contracting_circle_py.html","file":"pySDC/projects/TOMS/AllenCahn_contracting_circle.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":184,"n_excluded":9,"n_missing":10,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_cf9ddae6e6f0d80b_AllenCahn_monitor_py":{"hash":"51e8e5ef809c4cebb897e07d305c387a","index":{"url":"z_cf9ddae6e6f0d80b_AllenCahn_monitor_py.html","file":"pySDC/projects/TOMS/AllenCahn_monitor.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":37,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_cf9ddae6e6f0d80b_pySDC_with_PETSc_py":{"hash":"73ea0319549aa6cad39135bd9fc35f98","index":{"url":"z_cf9ddae6e6f0d80b_pySDC_with_PETSc_py.html","file":"pySDC/projects/TOMS/pySDC_with_PETSc.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":83,"n_excluded":11,"n_missing":83,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_cf9ddae6e6f0d80b_visualize_pySDC_with_PETSc_py":{"hash":"b79cceb4a5bc2aefed920d43e71e0e06","index":{"url":"z_cf9ddae6e6f0d80b_visualize_pySDC_with_PETSc_py.html","file":"pySDC/projects/TOMS/visualize_pySDC_with_PETSc.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":93,"n_excluded":4,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_3a331a23ecfeca1c_compression_convergence_controller_py":{"hash":"69c63282a7c0efe0c1aba2d288314e97","index":{"url":"z_3a331a23ecfeca1c_compression_convergence_controller_py.html","file":"pySDC/projects/compression/compression_convergence_controller.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":23,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_3a331a23ecfeca1c_order_py":{"hash":"fa9229a86cbf0f0eb9ce456363ea8ceb","index":{"url":"z_3a331a23ecfeca1c_order_py.html","file":"pySDC/projects/compression/order.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":79,"n_excluded":3,"n_missing":18,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_ecd017d7b94a3306_compare_to_matrixbased_py":{"hash":"9428f9c18bd2e9793af7e4d796979fb8","index":{"url":"z_ecd017d7b94a3306_compare_to_matrixbased_py.html","file":"pySDC/projects/matrixPFASST/compare_to_matrixbased.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":142,"n_excluded":26,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_ecd017d7b94a3306_compare_to_propagator_py":{"hash":"66a73369e354003ea0ea4b3c1da97809","index":{"url":"z_ecd017d7b94a3306_compare_to_propagator_py.html","file":"pySDC/projects/matrixPFASST/compare_to_propagator.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":135,"n_excluded":26,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_ecd017d7b94a3306_controller_matrix_nonMPI_py":{"hash":"0335aefc5e93285a007e879e67c465f8","index":{"url":"z_ecd017d7b94a3306_controller_matrix_nonMPI_py.html","file":"pySDC/projects/matrixPFASST/controller_matrix_nonMPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":183,"n_excluded":0,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_AllenCahn_parallel_py":{"hash":"1d196b715dc0b37f49446c09f952fdee","index":{"url":"z_7b436a2656aaf131_AllenCahn_parallel_py.html","file":"pySDC/projects/parallelSDC/AllenCahn_parallel.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":112,"n_excluded":17,"n_missing":17,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_ErrReductionHook_py":{"hash":"06bc6ca94798b1fe930d36b78a91249d","index":{"url":"z_7b436a2656aaf131_ErrReductionHook_py.html","file":"pySDC/projects/parallelSDC/ErrReductionHook.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":25,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_GeneralizedFisher_1D_FD_implicit_Jac_py":{"hash":"50302119be99baac69371c3ba9859dd5","index":{"url":"z_7b436a2656aaf131_GeneralizedFisher_1D_FD_implicit_Jac_py.html","file":"pySDC/projects/parallelSDC/GeneralizedFisher_1D_FD_implicit_Jac.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":12,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_Van_der_Pol_implicit_Jac_py":{"hash":"7bc6bed68ccc9dbf4f64badd36d885b1","index":{"url":"z_7b436a2656aaf131_Van_der_Pol_implicit_Jac_py.html","file":"pySDC/projects/parallelSDC/Van_der_Pol_implicit_Jac.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":14,"n_excluded":0,"n_missing":14,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_linearized_implicit_fixed_parallel_py":{"hash":"96f0400220ffe4007a8661dd4e85c9c5","index":{"url":"z_7b436a2656aaf131_linearized_implicit_fixed_parallel_py.html","file":"pySDC/projects/parallelSDC/linearized_implicit_fixed_parallel.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":37,"n_excluded":0,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_linearized_implicit_fixed_parallel_prec_py":{"hash":"5c2afeccdc589ed90f17c608f3686ef5","index":{"url":"z_7b436a2656aaf131_linearized_implicit_fixed_parallel_prec_py.html","file":"pySDC/projects/parallelSDC/linearized_implicit_fixed_parallel_prec.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":10,"n_excluded":0,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_linearized_implicit_parallel_py":{"hash":"db223cd3103c835a2372f96df69446df","index":{"url":"z_7b436a2656aaf131_linearized_implicit_parallel_py.html","file":"pySDC/projects/parallelSDC/linearized_implicit_parallel.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":37,"n_excluded":0,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_minimization_py":{"hash":"51e2d9d86cd187aa8f93608ea036e85f","index":{"url":"z_7b436a2656aaf131_minimization_py.html","file":"pySDC/projects/parallelSDC/minimization.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":48,"n_excluded":2,"n_missing":48,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_newton_vs_sdc_py":{"hash":"fc0a8303a4b91bd92e01492f91200126","index":{"url":"z_7b436a2656aaf131_newton_vs_sdc_py.html","file":"pySDC/projects/parallelSDC/newton_vs_sdc.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":97,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_nonlinear_playground_py":{"hash":"1631e836fb8c5db5dee27275234d4201","index":{"url":"z_7b436a2656aaf131_nonlinear_playground_py.html","file":"pySDC/projects/parallelSDC/nonlinear_playground.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":106,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_preconditioner_playground_py":{"hash":"60c6c220de7ca97ceef11c228c6399a6","index":{"url":"z_7b436a2656aaf131_preconditioner_playground_py.html","file":"pySDC/projects/parallelSDC/preconditioner_playground.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":142,"n_excluded":8,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_preconditioner_playground_MPI_py":{"hash":"ee04d73eb0d298120a17c0469ecc7305","index":{"url":"z_7b436a2656aaf131_preconditioner_playground_MPI_py.html","file":"pySDC/projects/parallelSDC/preconditioner_playground_MPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":151,"n_excluded":22,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_allenCahn_accuracy_py":{"hash":"587620b58e9096eb1ed46b32dd1463f9","index":{"url":"z_1ba2acb451842eb0_allenCahn_accuracy_py.html","file":"pySDC/projects/parallelSDC_reloaded/allenCahn_accuracy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":58,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_allenCahn_setup_py":{"hash":"2ab3feb6b90b74fc5f168bcf1d12b9b9","index":{"url":"z_1ba2acb451842eb0_allenCahn_setup_py.html","file":"pySDC/projects/parallelSDC_reloaded/allenCahn_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":26,"n_excluded":7,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_chemicalReaction_accuracy_py":{"hash":"50bc51eeb351348d564ddab29b3cb0f8","index":{"url":"z_1ba2acb451842eb0_chemicalReaction_accuracy_py.html","file":"pySDC/projects/parallelSDC_reloaded/chemicalReaction_accuracy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":54,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_chemicalReaction_setup_py":{"hash":"210a565c4078af2ef2e4e74fcd343e12","index":{"url":"z_1ba2acb451842eb0_chemicalReaction_setup_py.html","file":"pySDC/projects/parallelSDC_reloaded/chemicalReaction_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":24,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_convergence_py":{"hash":"c47c1397d6f6ddfa97b948df74fb6735","index":{"url":"z_1ba2acb451842eb0_convergence_py.html","file":"pySDC/projects/parallelSDC_reloaded/convergence.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":38,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_jacobiElliptic_accuracy_py":{"hash":"4a8318b9645be411bbe990e6c4e84156","index":{"url":"z_1ba2acb451842eb0_jacobiElliptic_accuracy_py.html","file":"pySDC/projects/parallelSDC_reloaded/jacobiElliptic_accuracy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":52,"n_excluded":4,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_jacobiElliptic_setup_py":{"hash":"4e6099892a35510bc3195de80d8b70b6","index":{"url":"z_1ba2acb451842eb0_jacobiElliptic_setup_py.html","file":"pySDC/projects/parallelSDC_reloaded/jacobiElliptic_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":29,"n_excluded":7,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_kaps_accuracy_py":{"hash":"d6e8cfdb828fb3b9f0b4285768015091","index":{"url":"z_1ba2acb451842eb0_kaps_accuracy_py.html","file":"pySDC/projects/parallelSDC_reloaded/kaps_accuracy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":56,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_kaps_setup_py":{"hash":"9288a30ff00b8af2138d8ddd8ca867f5","index":{"url":"z_1ba2acb451842eb0_kaps_setup_py.html","file":"pySDC/projects/parallelSDC_reloaded/kaps_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":23,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_lorenz_accuracy_py":{"hash":"78043b43987dd56c58234b9841b1aa7f","index":{"url":"z_1ba2acb451842eb0_lorenz_accuracy_py.html","file":"pySDC/projects/parallelSDC_reloaded/lorenz_accuracy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":57,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_lorenz_setup_py":{"hash":"97bd5d422d807e99e2466a784cee5360","index":{"url":"z_1ba2acb451842eb0_lorenz_setup_py.html","file":"pySDC/projects/parallelSDC_reloaded/lorenz_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":24,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_nilpotency_py":{"hash":"1307f57cb34058f0d040bf0b115df411","index":{"url":"z_1ba2acb451842eb0_nilpotency_py.html","file":"pySDC/projects/parallelSDC_reloaded/nilpotency.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":46,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_protheroRobinsonAutonomous_accuracy_py":{"hash":"be2260875288245f01c2aeb007fb3ef6","index":{"url":"z_1ba2acb451842eb0_protheroRobinsonAutonomous_accuracy_py.html","file":"pySDC/projects/parallelSDC_reloaded/protheroRobinsonAutonomous_accuracy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":58,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_protheroRobinsonAutonomous_setup_py":{"hash":"3f1b3bfe18b07559e04696f740909566","index":{"url":"z_1ba2acb451842eb0_protheroRobinsonAutonomous_setup_py.html","file":"pySDC/projects/parallelSDC_reloaded/protheroRobinsonAutonomous_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":30,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_protheroRobinson_accuracy_py":{"hash":"9fb7b0dc93a1346f3b551d6e5bc3bb64","index":{"url":"z_1ba2acb451842eb0_protheroRobinson_accuracy_py.html","file":"pySDC/projects/parallelSDC_reloaded/protheroRobinson_accuracy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":58,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_protheroRobinson_setup_py":{"hash":"0f9ba829c234dedf8465971a10ba2179","index":{"url":"z_1ba2acb451842eb0_protheroRobinson_setup_py.html","file":"pySDC/projects/parallelSDC_reloaded/protheroRobinson_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":30,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_52d7e0681901465e_fig01_conv_py":{"hash":"a00b8c1a656f68ea7584ed094d083848","index":{"url":"z_52d7e0681901465e_fig01_conv_py.html","file":"pySDC/projects/parallelSDC_reloaded/scripts/fig01_conv.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":41,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_52d7e0681901465e_fig02_stab_py":{"hash":"2776c8256b01e48aad11801fee7bf136","index":{"url":"z_52d7e0681901465e_fig02_stab_py.html","file":"pySDC/projects/parallelSDC_reloaded/scripts/fig02_stab.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":40,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_52d7e0681901465e_fig03_lorenz_py":{"hash":"a56fb1672ec952b23c9e2c765d0ccfd3","index":{"url":"z_52d7e0681901465e_fig03_lorenz_py.html","file":"pySDC/projects/parallelSDC_reloaded/scripts/fig03_lorenz.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":101,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_52d7e0681901465e_fig04_protheroRobinson_py":{"hash":"b819a887eeb71b8862c8f13ef6f3132d","index":{"url":"z_52d7e0681901465e_fig04_protheroRobinson_py.html","file":"pySDC/projects/parallelSDC_reloaded/scripts/fig04_protheroRobinson.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":61,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_52d7e0681901465e_fig05_allenCahn_py":{"hash":"b350796e31a5791d06d5dc89ec3a795e","index":{"url":"z_52d7e0681901465e_fig05_allenCahn_py.html","file":"pySDC/projects/parallelSDC_reloaded/scripts/fig05_allenCahn.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":75,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_52d7e0681901465e_fig06_allenCahnMPI_py":{"hash":"80dc66efa9a08d00e9059684d8790614","index":{"url":"z_52d7e0681901465e_fig06_allenCahnMPI_py.html","file":"pySDC/projects/parallelSDC_reloaded/scripts/fig06_allenCahnMPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":64,"n_excluded":3,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_52d7e0681901465e_fig06_allenCahnMPI_plot_py":{"hash":"c2cd6eae0903208c6706b025ffa8be4e","index":{"url":"z_52d7e0681901465e_fig06_allenCahnMPI_plot_py.html","file":"pySDC/projects/parallelSDC_reloaded/scripts/fig06_allenCahnMPI_plot.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":55,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_stability_py":{"hash":"e24af3eeb60b3441b4f3d1fab06bcce6","index":{"url":"z_1ba2acb451842eb0_stability_py.html","file":"pySDC/projects/parallelSDC_reloaded/stability.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":35,"n_excluded":4,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_utils_py":{"hash":"ab823a4054eed57d9be1f3e64b702797","index":{"url":"z_1ba2acb451842eb0_utils_py.html","file":"pySDC/projects/parallelSDC_reloaded/utils.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":168,"n_excluded":4,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_vanderpol_accuracy_py":{"hash":"d82b22bf4a2f4f029cc92f071939455a","index":{"url":"z_1ba2acb451842eb0_vanderpol_accuracy_py.html","file":"pySDC/projects/parallelSDC_reloaded/vanderpol_accuracy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":61,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_vanderpol_setup_py":{"hash":"73121c9ab7641c1b6b611fe4d809ffdc","index":{"url":"z_1ba2acb451842eb0_vanderpol_setup_py.html","file":"pySDC/projects/parallelSDC_reloaded/vanderpol_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":36,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_064a9f2a35945611_FaultHooks_py":{"hash":"6c4e0ae7256faeae212f8f6b86e9ac24","index":{"url":"z_064a9f2a35945611_FaultHooks_py.html","file":"pySDC/projects/soft_failure/FaultHooks.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":20,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_064a9f2a35945611_generate_statistics_py":{"hash":"f633ccb0418a99fd7323f4d14b080a56","index":{"url":"z_064a9f2a35945611_generate_statistics_py.html","file":"pySDC/projects/soft_failure/generate_statistics.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":199,"n_excluded":16,"n_missing":49,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_064a9f2a35945611_implicit_sweeper_faults_py":{"hash":"aa57afdfc9ea3e3580a6275a86ae63b9","index":{"url":"z_064a9f2a35945611_implicit_sweeper_faults_py.html","file":"pySDC/projects/soft_failure/implicit_sweeper_faults.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":144,"n_excluded":0,"n_missing":5,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_064a9f2a35945611_visualization_helper_py":{"hash":"42503abb7715e2570dcd624ab1931f83","index":{"url":"z_064a9f2a35945611_visualization_helper_py.html","file":"pySDC/projects/soft_failure/visualization_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":54,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a8a430cd9834ab6a_A_spatial_problem_setup_py":{"hash":"2217665c983f844e6bbbb0e504edd3d8","index":{"url":"z_a8a430cd9834ab6a_A_spatial_problem_setup_py.html","file":"pySDC/tutorial/step_1/A_spatial_problem_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":21,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a8a430cd9834ab6a_B_spatial_accuracy_check_py":{"hash":"7571221d81cec43b1b00c722df579715","index":{"url":"z_a8a430cd9834ab6a_B_spatial_accuracy_check_py.html","file":"pySDC/tutorial/step_1/B_spatial_accuracy_check.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":81,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a8a430cd9834ab6a_C_collocation_problem_setup_py":{"hash":"08be0636af50ac852a0e621a7b5f1197","index":{"url":"z_a8a430cd9834ab6a_C_collocation_problem_setup_py.html","file":"pySDC/tutorial/step_1/C_collocation_problem_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":26,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a8a430cd9834ab6a_D_collocation_accuracy_check_py":{"hash":"2865db91ebe25203ee836b47e78ba5d2","index":{"url":"z_a8a430cd9834ab6a_D_collocation_accuracy_check_py.html","file":"pySDC/tutorial/step_1/D_collocation_accuracy_check.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":85,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ee527a4b5236415_A_step_data_structure_py":{"hash":"3ca3ec60f6232e12fd48ed3e3ac0d7fb","index":{"url":"z_1ee527a4b5236415_A_step_data_structure_py.html","file":"pySDC/tutorial/step_2/A_step_data_structure.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":38,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ee527a4b5236415_B_my_first_sweeper_py":{"hash":"ea2f98464e92671da558a44d2dc97780","index":{"url":"z_1ee527a4b5236415_B_my_first_sweeper_py.html","file":"pySDC/tutorial/step_2/B_my_first_sweeper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":54,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ee527a4b5236415_C_using_pySDCs_frontend_py":{"hash":"0cd282b28784f44dd8eef8be594021c3","index":{"url":"z_1ee527a4b5236415_C_using_pySDCs_frontend_py.html","file":"pySDC/tutorial/step_2/C_using_pySDCs_frontend.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":43,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a25a81841eb75b92_A_getting_statistics_py":{"hash":"786cb24bf8290ae117e295c015b6df41","index":{"url":"z_a25a81841eb75b92_A_getting_statistics_py.html","file":"pySDC/tutorial/step_3/A_getting_statistics.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":54,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a25a81841eb75b92_B_adding_statistics_py":{"hash":"0ffb90cce4d2f4cbec66c5d45d18543f","index":{"url":"z_a25a81841eb75b92_B_adding_statistics_py.html","file":"pySDC/tutorial/step_3/B_adding_statistics.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":55,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a25a81841eb75b92_C_study_collocations_py":{"hash":"455f5871415b87d705da206675a86d8a","index":{"url":"z_a25a81841eb75b92_C_study_collocations_py.html","file":"pySDC/tutorial/step_3/C_study_collocations.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":63,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a25a81841eb75b92_HookClass_Particles_py":{"hash":"8c5a6c79cacfd88fc0672ee33dba96d6","index":{"url":"z_a25a81841eb75b92_HookClass_Particles_py.html","file":"pySDC/tutorial/step_3/HookClass_Particles.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":49,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_99cdae9889c0cdaf_A_spatial_transfer_operators_py":{"hash":"ec8353e9d018a3714741681a5d34d008","index":{"url":"z_99cdae9889c0cdaf_A_spatial_transfer_operators_py.html","file":"pySDC/tutorial/step_4/A_spatial_transfer_operators.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":45,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_99cdae9889c0cdaf_B_multilevel_hierarchy_py":{"hash":"30a0f2259146158b492947e02b8ae263","index":{"url":"z_99cdae9889c0cdaf_B_multilevel_hierarchy_py.html","file":"pySDC/tutorial/step_4/B_multilevel_hierarchy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":43,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_99cdae9889c0cdaf_C_SDC_vs_MLSDC_py":{"hash":"94ed4c49a98fe4931d3cc1b7b2bc2f09","index":{"url":"z_99cdae9889c0cdaf_C_SDC_vs_MLSDC_py.html","file":"pySDC/tutorial/step_4/C_SDC_vs_MLSDC.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":80,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_99cdae9889c0cdaf_D_MLSDC_with_particles_py":{"hash":"2620d957070eb6a00d993f737ab53234","index":{"url":"z_99cdae9889c0cdaf_D_MLSDC_with_particles_py.html","file":"pySDC/tutorial/step_4/D_MLSDC_with_particles.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":78,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_99cdae9889c0cdaf_PenningTrap_3D_coarse_py":{"hash":"233e646e5479526536d221292eaf5f26","index":{"url":"z_99cdae9889c0cdaf_PenningTrap_3D_coarse_py.html","file":"pySDC/tutorial/step_4/PenningTrap_3D_coarse.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":11,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a2aef498bf4ac071_A_multistep_multilevel_hierarchy_py":{"hash":"c904ef1348c3e9f738f9144c72e697fe","index":{"url":"z_a2aef498bf4ac071_A_multistep_multilevel_hierarchy_py.html","file":"pySDC/tutorial/step_5/A_multistep_multilevel_hierarchy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":32,"n_excluded":10,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a2aef498bf4ac071_B_my_first_PFASST_run_py":{"hash":"7d244638d8f2d6bac578b52eb136cfc6","index":{"url":"z_a2aef498bf4ac071_B_my_first_PFASST_run_py.html","file":"pySDC/tutorial/step_5/B_my_first_PFASST_run.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":72,"n_excluded":10,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a2aef498bf4ac071_C_advection_and_PFASST_py":{"hash":"d498abc3a341dc22897dc27133a783aa","index":{"url":"z_a2aef498bf4ac071_C_advection_and_PFASST_py.html","file":"pySDC/tutorial/step_5/C_advection_and_PFASST.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":81,"n_excluded":10,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a1e8f71763f68ddb_A_run_non_MPI_controller_py":{"hash":"530f65c964cb8c54efa1341d5a415a80","index":{"url":"z_a1e8f71763f68ddb_A_run_non_MPI_controller_py.html","file":"pySDC/tutorial/step_6/A_run_non_MPI_controller.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":97,"n_excluded":3,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a1e8f71763f68ddb_B_odd_temporal_distribution_py":{"hash":"2aecdf0552f601d0fe8a10545c5bbf2b","index":{"url":"z_a1e8f71763f68ddb_B_odd_temporal_distribution_py.html","file":"pySDC/tutorial/step_6/B_odd_temporal_distribution.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":3,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a1e8f71763f68ddb_C_MPI_parallelization_py":{"hash":"c3391b8399c83773e5d052740f25f3d3","index":{"url":"z_a1e8f71763f68ddb_C_MPI_parallelization_py.html","file":"pySDC/tutorial/step_6/C_MPI_parallelization.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":30,"n_excluded":3,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a1e8f71763f68ddb_playground_parallelization_py":{"hash":"5592bf23c129e7223ecc5f57034d0315","index":{"url":"z_a1e8f71763f68ddb_playground_parallelization_py.html","file":"pySDC/tutorial/step_6/playground_parallelization.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":6,"n_excluded":36,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_11ffac7f7ab8bb8d_A_pySDC_with_FEniCS_py":{"hash":"a31708964f2320408198b9ef556b05ff","index":{"url":"z_11ffac7f7ab8bb8d_A_pySDC_with_FEniCS_py.html","file":"pySDC/tutorial/step_7/A_pySDC_with_FEniCS.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":105,"n_excluded":3,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_11ffac7f7ab8bb8d_B_pySDC_with_mpi4pyfft_py":{"hash":"ee5fe7368004483e8a7a2bd479f4ee9a","index":{"url":"z_11ffac7f7ab8bb8d_B_pySDC_with_mpi4pyfft_py.html","file":"pySDC/tutorial/step_7/B_pySDC_with_mpi4pyfft.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":88,"n_excluded":6,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_11ffac7f7ab8bb8d_C_pySDC_with_PETSc_py":{"hash":"e629a5808714d659d053b8fe4abb62e2","index":{"url":"z_11ffac7f7ab8bb8d_C_pySDC_with_PETSc_py.html","file":"pySDC/tutorial/step_7/C_pySDC_with_PETSc.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":95,"n_excluded":11,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_11ffac7f7ab8bb8d_D_pySDC_with_PyTorch_py":{"hash":"ad28ad25353a3c6af9cf552f3739045e","index":{"url":"z_11ffac7f7ab8bb8d_D_pySDC_with_PyTorch_py.html","file":"pySDC/tutorial/step_7/D_pySDC_with_PyTorch.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":43,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_37e09edbaf161c0a_A_visualize_residuals_py":{"hash":"4884b82ba292d16f35614c0cbd537738","index":{"url":"z_37e09edbaf161c0a_A_visualize_residuals_py.html","file":"pySDC/tutorial/step_8/A_visualize_residuals.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":32,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_37e09edbaf161c0a_B_multistep_SDC_py":{"hash":"f50a787eea87a839c960630125326fbf","index":{"url":"z_37e09edbaf161c0a_B_multistep_SDC_py.html","file":"pySDC/tutorial/step_8/B_multistep_SDC.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":98,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_37e09edbaf161c0a_C_iteration_estimator_py":{"hash":"ef03afc5c2d573369b81cc4c70067c9e","index":{"url":"z_37e09edbaf161c0a_C_iteration_estimator_py.html","file":"pySDC/tutorial/step_8/C_iteration_estimator.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":179,"n_excluded":21,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_37e09edbaf161c0a_HookClass_error_output_py":{"hash":"183e371329cdb8b07ffdf2a063dba7e6","index":{"url":"z_37e09edbaf161c0a_HookClass_error_output_py.html","file":"pySDC/tutorial/step_8/HookClass_error_output.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":30,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}}}}
\ No newline at end of file
+{"note":"This file is an internal implementation detail to speed up HTML report generation. Its format can change at any time. You might be looking for the JSON report: https://coverage.rtfd.io/cmd.html#cmd-json","format":5,"version":"7.6.1","globals":"89c1de444accc8c03d929ac4a8c1cbbf","files":{"z_8d0d803e4e125e5c_base_transfer_py":{"hash":"605b006ab4e84d626acb1b138a8fdd64","index":{"url":"z_8d0d803e4e125e5c_base_transfer_py.html","file":"pySDC/core/base_transfer.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":103,"n_excluded":5,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_collocation_py":{"hash":"68ca6f34ec12b659d2d150a964054271","index":{"url":"z_8d0d803e4e125e5c_collocation_py.html","file":"pySDC/core/collocation.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":41,"n_excluded":5,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_common_py":{"hash":"ef6b8ac6f425d97969844142332068fb","index":{"url":"z_8d0d803e4e125e5c_common_py.html","file":"pySDC/core/common.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":22,"n_excluded":4,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_controller_py":{"hash":"34ed34cc3139277b45a93ad7ecaad54c","index":{"url":"z_8d0d803e4e125e5c_controller_py.html","file":"pySDC/core/controller.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":164,"n_excluded":3,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_convergence_controller_py":{"hash":"6e91af5aaa9f9cebf8156cc807722a18","index":{"url":"z_8d0d803e4e125e5c_convergence_controller_py.html","file":"pySDC/core/convergence_controller.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":112,"n_excluded":15,"n_missing":18,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_errors_py":{"hash":"93ec874a431d050bef317af1601fb90c","index":{"url":"z_8d0d803e4e125e5c_errors_py.html","file":"pySDC/core/errors.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":9,"n_excluded":16,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_hooks_py":{"hash":"d6263163218df2f7c83e088c5f7f239f","index":{"url":"z_8d0d803e4e125e5c_hooks_py.html","file":"pySDC/core/hooks.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":54,"n_excluded":0,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_level_py":{"hash":"f8ab015b9bad72a1c3dfc7e583aa7f49","index":{"url":"z_8d0d803e4e125e5c_level_py.html","file":"pySDC/core/level.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":64,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_problem_py":{"hash":"1c08995d8b8a91d4c7b3343bc085e047","index":{"url":"z_8d0d803e4e125e5c_problem_py.html","file":"pySDC/core/problem.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":37,"n_excluded":8,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_space_transfer_py":{"hash":"cc82770927510b4082ce8f96bdcf3378","index":{"url":"z_8d0d803e4e125e5c_space_transfer_py.html","file":"pySDC/core/space_transfer.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":19,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_step_py":{"hash":"7700c52a132a2a495af1b53a51e80227","index":{"url":"z_8d0d803e4e125e5c_step_py.html","file":"pySDC/core/step.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":117,"n_excluded":7,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_8d0d803e4e125e5c_sweeper_py":{"hash":"60cf4876334adff6c5d94f36b69b30e1","index":{"url":"z_8d0d803e4e125e5c_sweeper_py.html","file":"pySDC/core/sweeper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":120,"n_excluded":8,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_NCCL_communicator_py":{"hash":"335ea48729c450fa494f83edbf9b5d62","index":{"url":"z_41564483689e14fd_NCCL_communicator_py.html","file":"pySDC/helpers/NCCL_communicator.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":62,"n_excluded":2,"n_missing":62,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_plot_helper_py":{"hash":"3da9f9e456095ff70b322fc592e54f63","index":{"url":"z_41564483689e14fd_plot_helper_py.html","file":"pySDC/helpers/plot_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":33,"n_excluded":38,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_problem_helper_py":{"hash":"947627cdb7d466c11b75654fe0438f81","index":{"url":"z_41564483689e14fd_problem_helper_py.html","file":"pySDC/helpers/problem_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":102,"n_excluded":5,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_pysdc_helper_py":{"hash":"8f7a47bfe79fefa507904d950e14cd7e","index":{"url":"z_41564483689e14fd_pysdc_helper_py.html","file":"pySDC/helpers/pysdc_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":17,"n_excluded":19,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_setup_helper_py":{"hash":"ee3df0592cb85e8a0e11b1e0dc741754","index":{"url":"z_41564483689e14fd_setup_helper_py.html","file":"pySDC/helpers/setup_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":19,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_spectral_helper_py":{"hash":"e994246d6d088454d47d8715f041d632","index":{"url":"z_41564483689e14fd_spectral_helper_py.html","file":"pySDC/helpers/spectral_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":764,"n_excluded":31,"n_missing":62,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_stats_helper_py":{"hash":"039bcff9fead556e196125a46bea3a64","index":{"url":"z_41564483689e14fd_stats_helper_py.html","file":"pySDC/helpers/stats_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":36,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_testing_py":{"hash":"0eace903ebaa536113cb4bd66275aa38","index":{"url":"z_41564483689e14fd_testing_py.html","file":"pySDC/helpers/testing.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":30,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_transfer_helper_py":{"hash":"442b9493cef86b1f98f4961b8c10fec7","index":{"url":"z_41564483689e14fd_transfer_helper_py.html","file":"pySDC/helpers/transfer_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":142,"n_excluded":0,"n_missing":33,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_41564483689e14fd_visualization_tools_py":{"hash":"e3aaafde8b227afae340d2c4ba27bbfe","index":{"url":"z_41564483689e14fd_visualization_tools_py.html","file":"pySDC/helpers/visualization_tools.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":40,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_d6839539e65473f5_controller_MPI_py":{"hash":"bbb89968fbab081187bbdc807db6c057","index":{"url":"z_d6839539e65473f5_controller_MPI_py.html","file":"pySDC/implementations/controller_classes/controller_MPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":384,"n_excluded":7,"n_missing":130,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_d6839539e65473f5_controller_nonMPI_py":{"hash":"19438d3a4619ebe68bfc4738af0560a5","index":{"url":"z_d6839539e65473f5_controller_nonMPI_py.html","file":"pySDC/implementations/controller_classes/controller_nonMPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":295,"n_excluded":13,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_adaptive_collocation_py":{"hash":"cbd42126f07c6ecabd43a36f1c811d36","index":{"url":"z_c28af68f8f845bbd_adaptive_collocation_py.html","file":"pySDC/implementations/convergence_controller_classes/adaptive_collocation.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":79,"n_excluded":4,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_adaptivity_py":{"hash":"50103e3984dcb8153142a6870a552989","index":{"url":"z_c28af68f8f845bbd_adaptivity_py.html","file":"pySDC/implementations/convergence_controller_classes/adaptivity.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":257,"n_excluded":12,"n_missing":20,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_basic_restarting_py":{"hash":"ee293e53bed358d9d676e35be9e56892","index":{"url":"z_c28af68f8f845bbd_basic_restarting_py.html","file":"pySDC/implementations/convergence_controller_classes/basic_restarting.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":99,"n_excluded":4,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_check_convergence_py":{"hash":"389679abe085491e4bef783205b30945","index":{"url":"z_c28af68f8f845bbd_check_convergence_py.html","file":"pySDC/implementations/convergence_controller_classes/check_convergence.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":57,"n_excluded":1,"n_missing":9,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_check_iteration_estimator_py":{"hash":"c976e9d22da21f766058ceb5d8d78de8","index":{"url":"z_c28af68f8f845bbd_check_iteration_estimator_py.html","file":"pySDC/implementations/convergence_controller_classes/check_iteration_estimator.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":43,"n_excluded":1,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_crash_py":{"hash":"03eab43f23596b458dd29470fc5b5c7c","index":{"url":"z_c28af68f8f845bbd_crash_py.html","file":"pySDC/implementations/convergence_controller_classes/crash.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":44,"n_excluded":4,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_estimate_contraction_factor_py":{"hash":"21663cf0ee8abbd061c87c2f99c634ee","index":{"url":"z_c28af68f8f845bbd_estimate_contraction_factor_py.html","file":"pySDC/implementations/convergence_controller_classes/estimate_contraction_factor.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":23,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_estimate_embedded_error_py":{"hash":"65677296b14900f356aa54b852ff512e","index":{"url":"z_c28af68f8f845bbd_estimate_embedded_error_py.html","file":"pySDC/implementations/convergence_controller_classes/estimate_embedded_error.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":104,"n_excluded":4,"n_missing":22,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_estimate_extrapolation_error_py":{"hash":"f71e02325fb79464459f18e66b29b2cd","index":{"url":"z_c28af68f8f845bbd_estimate_extrapolation_error_py.html","file":"pySDC/implementations/convergence_controller_classes/estimate_extrapolation_error.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":157,"n_excluded":8,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_estimate_polynomial_error_py":{"hash":"e614751d6f3b3ab4164079398d0e9102","index":{"url":"z_c28af68f8f845bbd_estimate_polynomial_error_py.html","file":"pySDC/implementations/convergence_controller_classes/estimate_polynomial_error.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":67,"n_excluded":3,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_hotrod_py":{"hash":"4f05447bdcb4ae274a8ed3d666a2642d","index":{"url":"z_c28af68f8f845bbd_hotrod_py.html","file":"pySDC/implementations/convergence_controller_classes/hotrod.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":38,"n_excluded":3,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_inexactness_py":{"hash":"7f8a5b9848fd8fc717f4acf7d3ab1d28","index":{"url":"z_c28af68f8f845bbd_inexactness_py.html","file":"pySDC/implementations/convergence_controller_classes/inexactness.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":24,"n_excluded":1,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_interpolate_between_restarts_py":{"hash":"745550f0d3efa10ae2de11aaa0475e21","index":{"url":"z_c28af68f8f845bbd_interpolate_between_restarts_py.html","file":"pySDC/implementations/convergence_controller_classes/interpolate_between_restarts.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":41,"n_excluded":0,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_spread_step_sizes_py":{"hash":"c383a7d0355e7c01aa86cd1549247886","index":{"url":"z_c28af68f8f845bbd_spread_step_sizes_py.html","file":"pySDC/implementations/convergence_controller_classes/spread_step_sizes.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":61,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_step_size_limiter_py":{"hash":"411aeb8dce5a950a2d089292eba2e5c5","index":{"url":"z_c28af68f8f845bbd_step_size_limiter_py.html","file":"pySDC/implementations/convergence_controller_classes/step_size_limiter.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":43,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c28af68f8f845bbd_store_uold_py":{"hash":"ba17316c825eaf36070e886447cea6d4","index":{"url":"z_c28af68f8f845bbd_store_uold_py.html","file":"pySDC/implementations/convergence_controller_classes/store_uold.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":14,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_3017878c2b4bc866_cupy_mesh_py":{"hash":"85007849f7ed2c9036de3d568494ceab","index":{"url":"z_3017878c2b4bc866_cupy_mesh_py.html","file":"pySDC/implementations/datatype_classes/cupy_mesh.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":57,"n_excluded":3,"n_missing":8,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_3017878c2b4bc866_fenics_mesh_py":{"hash":"16406c73397cbbbad8907d15f38c7662","index":{"url":"z_3017878c2b4bc866_fenics_mesh_py.html","file":"pySDC/implementations/datatype_classes/fenics_mesh.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":55,"n_excluded":8,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_3017878c2b4bc866_mesh_py":{"hash":"7bdb6608a40fb629428608a0bd82bfbc","index":{"url":"z_3017878c2b4bc866_mesh_py.html","file":"pySDC/implementations/datatype_classes/mesh.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":56,"n_excluded":3,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_3017878c2b4bc866_particles_py":{"hash":"c04c030bbf43aa477695ce1f35a516fd","index":{"url":"z_3017878c2b4bc866_particles_py.html","file":"pySDC/implementations/datatype_classes/particles.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":112,"n_excluded":15,"n_missing":23,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_3017878c2b4bc866_petsc_vec_py":{"hash":"e65b06f531bdc3953dee44ef5fec4a18","index":{"url":"z_3017878c2b4bc866_petsc_vec_py.html","file":"pySDC/implementations/datatype_classes/petsc_vec.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":40,"n_excluded":2,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1f4fced1df9318f0_default_hook_py":{"hash":"8d7dd6e5da45316ea705f0fa307c4481","index":{"url":"z_1f4fced1df9318f0_default_hook_py.html","file":"pySDC/implementations/hooks/default_hook.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":93,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1f4fced1df9318f0_log_embedded_error_estimate_py":{"hash":"23040721ce915f0d5fc2b981bb2b26d1","index":{"url":"z_1f4fced1df9318f0_log_embedded_error_estimate_py.html","file":"pySDC/implementations/hooks/log_embedded_error_estimate.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":20,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1f4fced1df9318f0_log_errors_py":{"hash":"86a2a3a0c6ee42849fdbcf43108f6140","index":{"url":"z_1f4fced1df9318f0_log_errors_py.html","file":"pySDC/implementations/hooks/log_errors.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":50,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1f4fced1df9318f0_log_extrapolated_error_estimate_py":{"hash":"41728fabdb7a6d6c92c3d7b6e129eb7a","index":{"url":"z_1f4fced1df9318f0_log_extrapolated_error_estimate_py.html","file":"pySDC/implementations/hooks/log_extrapolated_error_estimate.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":6,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1f4fced1df9318f0_log_restarts_py":{"hash":"00b6d519dcebe8f75606857db54c8341","index":{"url":"z_1f4fced1df9318f0_log_restarts_py.html","file":"pySDC/implementations/hooks/log_restarts.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":6,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1f4fced1df9318f0_log_solution_py":{"hash":"45883fb93d590056ddaeda845eef50d2","index":{"url":"z_1f4fced1df9318f0_log_solution_py.html","file":"pySDC/implementations/hooks/log_solution.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":72,"n_excluded":3,"n_missing":11,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1f4fced1df9318f0_log_step_size_py":{"hash":"524d1d5cec27ee6f00768652f7109a40","index":{"url":"z_1f4fced1df9318f0_log_step_size_py.html","file":"pySDC/implementations/hooks/log_step_size.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":6,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1f4fced1df9318f0_log_work_py":{"hash":"5541373444fa9b8ecb3a14afa58011d1","index":{"url":"z_1f4fced1df9318f0_log_work_py.html","file":"pySDC/implementations/hooks/log_work.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":18,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AcousticAdvection_1D_FD_imex_py":{"hash":"bbbe9baa53018f5b67320378c09de83a","index":{"url":"z_91faa57f8583c837_AcousticAdvection_1D_FD_imex_py.html","file":"pySDC/implementations/problem_classes/AcousticAdvection_1D_FD_imex.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":52,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AdvectionDiffusionEquation_1D_FFT_py":{"hash":"b6e5a49811526cd55e42e83a760f9e3b","index":{"url":"z_91faa57f8583c837_AdvectionDiffusionEquation_1D_FFT_py.html","file":"pySDC/implementations/problem_classes/AdvectionDiffusionEquation_1D_FFT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":63,"n_excluded":3,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AdvectionEquation_ND_FD_py":{"hash":"7911c5ce117dfcf909e1f242ea282d4f","index":{"url":"z_91faa57f8583c837_AdvectionEquation_ND_FD_py.html","file":"pySDC/implementations/problem_classes/AdvectionEquation_ND_FD.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":24,"n_excluded":2,"n_missing":8,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AllenCahn_1D_FD_py":{"hash":"699a2a074487980651a92605458c5009","index":{"url":"z_91faa57f8583c837_AllenCahn_1D_FD_py.html","file":"pySDC/implementations/problem_classes/AllenCahn_1D_FD.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":225,"n_excluded":9,"n_missing":10,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AllenCahn_2D_FD_py":{"hash":"1da6ae36990fab1d9005c0611e20520b","index":{"url":"z_91faa57f8583c837_AllenCahn_2D_FD_py.html","file":"pySDC/implementations/problem_classes/AllenCahn_2D_FD.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":201,"n_excluded":8,"n_missing":8,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AllenCahn_2D_FD_gpu_py":{"hash":"4d567ffa04d7e90f6d09ae5f2126eb3e","index":{"url":"z_91faa57f8583c837_AllenCahn_2D_FD_gpu_py.html","file":"pySDC/implementations/problem_classes/AllenCahn_2D_FD_gpu.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":130,"n_excluded":240,"n_missing":130,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AllenCahn_2D_FFT_py":{"hash":"6d928ef2ad94a8644d402b073f039160","index":{"url":"z_91faa57f8583c837_AllenCahn_2D_FFT_py.html","file":"pySDC/implementations/problem_classes/AllenCahn_2D_FFT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":70,"n_excluded":5,"n_missing":55,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AllenCahn_2D_FFT_gpu_py":{"hash":"43e708e7782ef9f7f3151282cc7bf27f","index":{"url":"z_91faa57f8583c837_AllenCahn_2D_FFT_gpu_py.html","file":"pySDC/implementations/problem_classes/AllenCahn_2D_FFT_gpu.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":24,"n_excluded":171,"n_missing":24,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AllenCahn_MPIFFT_py":{"hash":"f6750dbb47ae6632161a3512d9bb9153","index":{"url":"z_91faa57f8583c837_AllenCahn_MPIFFT_py.html","file":"pySDC/implementations/problem_classes/AllenCahn_MPIFFT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":92,"n_excluded":2,"n_missing":25,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_AllenCahn_Temp_MPIFFT_py":{"hash":"053c0949ae418a61d46c29226d6e1794","index":{"url":"z_91faa57f8583c837_AllenCahn_Temp_MPIFFT_py.html","file":"pySDC/implementations/problem_classes/AllenCahn_Temp_MPIFFT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":123,"n_excluded":3,"n_missing":23,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Auzinger_implicit_py":{"hash":"556c497c2a6fcd0ffd5f959bfeee0316","index":{"url":"z_91faa57f8583c837_Auzinger_implicit_py.html","file":"pySDC/implementations/problem_classes/Auzinger_implicit.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":38,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Battery_py":{"hash":"2f89d86e8e84bb9d2e655e99ef2f1bd3","index":{"url":"z_91faa57f8583c837_Battery_py.html","file":"pySDC/implementations/problem_classes/Battery.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":166,"n_excluded":4,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Boussinesq_2D_FD_imex_py":{"hash":"f079aa19f16ce8028e11e1e7571bfba2","index":{"url":"z_91faa57f8583c837_Boussinesq_2D_FD_imex_py.html","file":"pySDC/implementations/problem_classes/Boussinesq_2D_FD_imex.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":66,"n_excluded":1,"n_missing":66,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Brusselator_py":{"hash":"dc49acd965363b9e035992584f015600","index":{"url":"z_91faa57f8583c837_Brusselator_py.html","file":"pySDC/implementations/problem_classes/Brusselator.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":44,"n_excluded":48,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_BuckConverter_py":{"hash":"2923f920973af5eb0b9b34d2b7f89794","index":{"url":"z_91faa57f8583c837_BuckConverter_py.html","file":"pySDC/implementations/problem_classes/BuckConverter.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":47,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Burgers_py":{"hash":"06fbc51139fcda3ce5bd0a5d2c306f83","index":{"url":"z_91faa57f8583c837_Burgers_py.html","file":"pySDC/implementations/problem_classes/Burgers.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":96,"n_excluded":100,"n_missing":5,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_DiscontinuousTestODE_py":{"hash":"e1db903d325be680aeb93db97507b8e3","index":{"url":"z_91faa57f8583c837_DiscontinuousTestODE_py.html","file":"pySDC/implementations/problem_classes/DiscontinuousTestODE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":87,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_FastWaveSlowWave_0D_py":{"hash":"ff9bc8fb81069aad9df5ace52b3c3125","index":{"url":"z_91faa57f8583c837_FastWaveSlowWave_0D_py.html","file":"pySDC/implementations/problem_classes/FastWaveSlowWave_0D.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":40,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_FermiPastaUlamTsingou_py":{"hash":"8a944ad7718b7b7af8bfa96ff241086b","index":{"url":"z_91faa57f8583c837_FermiPastaUlamTsingou_py.html","file":"pySDC/implementations/problem_classes/FermiPastaUlamTsingou.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":40,"n_excluded":1,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_FullSolarSystem_py":{"hash":"f4e72ed28345ae6af1c0ad0b13307c87","index":{"url":"z_91faa57f8583c837_FullSolarSystem_py.html","file":"pySDC/implementations/problem_classes/FullSolarSystem.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":43,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_GeneralizedFisher_1D_FD_implicit_py":{"hash":"a3f7f05c7b2816a30e0933b0a817c48f","index":{"url":"z_91faa57f8583c837_GeneralizedFisher_1D_FD_implicit_py.html","file":"pySDC/implementations/problem_classes/GeneralizedFisher_1D_FD_implicit.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":57,"n_excluded":3,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_GeneralizedFisher_1D_PETSc_py":{"hash":"bcc2e1ab385b978a7f258c4be3e6320e","index":{"url":"z_91faa57f8583c837_GeneralizedFisher_1D_PETSc_py.html","file":"pySDC/implementations/problem_classes/GeneralizedFisher_1D_PETSc.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":243,"n_excluded":1,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_GrayScott_1D_FEniCS_implicit_py":{"hash":"665107b23ee05a0ead76532051e1641b","index":{"url":"z_91faa57f8583c837_GrayScott_1D_FEniCS_implicit_py.html","file":"pySDC/implementations/problem_classes/GrayScott_1D_FEniCS_implicit.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":85,"n_excluded":2,"n_missing":85,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_GrayScott_2D_PETSc_periodic_py":{"hash":"f1f41a705b01ff7c4e7645384f31aa1f","index":{"url":"z_91faa57f8583c837_GrayScott_2D_PETSc_periodic_py.html","file":"pySDC/implementations/problem_classes/GrayScott_2D_PETSc_periodic.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":305,"n_excluded":1,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_GrayScott_MPIFFT_py":{"hash":"a3c6e420a057a27352221979b3cb095c","index":{"url":"z_91faa57f8583c837_GrayScott_MPIFFT_py.html","file":"pySDC/implementations/problem_classes/GrayScott_MPIFFT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":267,"n_excluded":2,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_HarmonicOscillator_py":{"hash":"fcfa657b01fe4156d053697edcdd23ba","index":{"url":"z_91faa57f8583c837_HarmonicOscillator_py.html","file":"pySDC/implementations/problem_classes/HarmonicOscillator.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":54,"n_excluded":3,"n_missing":17,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_HeatEquation_1D_FEniCS_matrix_forced_py":{"hash":"d0a0d047e966f33e18b5d335ac0115b0","index":{"url":"z_91faa57f8583c837_HeatEquation_1D_FEniCS_matrix_forced_py.html","file":"pySDC/implementations/problem_classes/HeatEquation_1D_FEniCS_matrix_forced.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":112,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_HeatEquation_2D_PETSc_forced_py":{"hash":"74564b7043abbbc9a821bb4a67582f8f","index":{"url":"z_91faa57f8583c837_HeatEquation_2D_PETSc_forced_py.html","file":"pySDC/implementations/problem_classes/HeatEquation_2D_PETSc_forced.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":90,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_HeatEquation_Chebychev_py":{"hash":"902dcbff38e4cb3cae0063149e70daf6","index":{"url":"z_91faa57f8583c837_HeatEquation_Chebychev_py.html","file":"pySDC/implementations/problem_classes/HeatEquation_Chebychev.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":220,"n_excluded":4,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_HeatEquation_ND_FD_py":{"hash":"f44100dea16d91447113efddd771b8a0","index":{"url":"z_91faa57f8583c837_HeatEquation_ND_FD_py.html","file":"pySDC/implementations/problem_classes/HeatEquation_ND_FD.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":58,"n_excluded":0,"n_missing":20,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_HeatEquation_ND_FD_CuPy_py":{"hash":"97593f8069dae13b1b869ab05aeddb15","index":{"url":"z_91faa57f8583c837_HeatEquation_ND_FD_CuPy_py.html","file":"pySDC/implementations/problem_classes/HeatEquation_ND_FD_CuPy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":26,"n_excluded":265,"n_missing":26,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_HenonHeiles_py":{"hash":"ff8012356307ca35ff55a5100ffb3c39","index":{"url":"z_91faa57f8583c837_HenonHeiles_py.html","file":"pySDC/implementations/problem_classes/HenonHeiles.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":31,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_LogisticEquation_py":{"hash":"bbfc3db757a18e7d01d1d0ae1b7c394b","index":{"url":"z_91faa57f8583c837_LogisticEquation_py.html","file":"pySDC/implementations/problem_classes/LogisticEquation.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":40,"n_excluded":2,"n_missing":20,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Lorenz_py":{"hash":"4bb1c8a07d69fa93c75a4c2ecb1a4fde","index":{"url":"z_91faa57f8583c837_Lorenz_py.html","file":"pySDC/implementations/problem_classes/Lorenz.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":54,"n_excluded":2,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_NonlinearSchroedinger_MPIFFT_py":{"hash":"a0f964649c3a47934d0edac8054fe9ab","index":{"url":"z_91faa57f8583c837_NonlinearSchroedinger_MPIFFT_py.html","file":"pySDC/implementations/problem_classes/NonlinearSchroedinger_MPIFFT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":60,"n_excluded":1,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_OuterSolarSystem_py":{"hash":"0d0baadaf50761f84ca8b5b3afeb5abc","index":{"url":"z_91faa57f8583c837_OuterSolarSystem_py.html","file":"pySDC/implementations/problem_classes/OuterSolarSystem.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":58,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_PenningTrap_3D_py":{"hash":"60b63c0263e9547d36d508b4f9590d04","index":{"url":"z_91faa57f8583c837_PenningTrap_3D_py.html","file":"pySDC/implementations/problem_classes/PenningTrap_3D.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":120,"n_excluded":4,"n_missing":10,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Piline_py":{"hash":"478e30902b983cef5bd346d1da8df93b","index":{"url":"z_91faa57f8583c837_Piline_py.html","file":"pySDC/implementations/problem_classes/Piline.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":44,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Quench_py":{"hash":"9dea18d5504e12d158eadf03080cfba3","index":{"url":"z_91faa57f8583c837_Quench_py.html","file":"pySDC/implementations/problem_classes/Quench.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":152,"n_excluded":8,"n_missing":35,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_RayleighBenard_py":{"hash":"839212ba61edcb7af770b196b6fd625a","index":{"url":"z_91faa57f8583c837_RayleighBenard_py.html","file":"pySDC/implementations/problem_classes/RayleighBenard.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":209,"n_excluded":60,"n_missing":47,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_TestEquation_0D_py":{"hash":"561b02cb327b970ea8a7fa1d6de9ceee","index":{"url":"z_91faa57f8583c837_TestEquation_0D_py.html","file":"pySDC/implementations/problem_classes/TestEquation_0D.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":53,"n_excluded":1,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_Van_der_Pol_implicit_py":{"hash":"49cab031c650d4f4aa58bffe4bc0d1f3","index":{"url":"z_91faa57f8583c837_Van_der_Pol_implicit_py.html","file":"pySDC/implementations/problem_classes/Van_der_Pol_implicit.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":57,"n_excluded":2,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_VorticityVelocity_2D_FEniCS_periodic_py":{"hash":"20d08dd0944116f3294b821ba1d9cfd8","index":{"url":"z_91faa57f8583c837_VorticityVelocity_2D_FEniCS_periodic_py.html","file":"pySDC/implementations/problem_classes/VorticityVelocity_2D_FEniCS_periodic.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":108,"n_excluded":2,"n_missing":108,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c032a2f084ee6f96_buildFDMatrix_py":{"hash":"de1f0fe64c78df8beb8b053f316c8b77","index":{"url":"z_c032a2f084ee6f96_buildFDMatrix_py.html","file":"pySDC/implementations/problem_classes/acoustic_helpers/buildFDMatrix.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":145,"n_excluded":0,"n_missing":89,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c032a2f084ee6f96_buildWave1DMatrix_py":{"hash":"de100d9a7852319c85b8e55378734edd","index":{"url":"z_c032a2f084ee6f96_buildWave1DMatrix_py.html","file":"pySDC/implementations/problem_classes/acoustic_helpers/buildWave1DMatrix.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":28,"n_excluded":0,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c032a2f084ee6f96_standard_integrators_py":{"hash":"522c0c6ed96650584bf16bea335eb324","index":{"url":"z_c032a2f084ee6f96_standard_integrators_py.html","file":"pySDC/implementations/problem_classes/acoustic_helpers/standard_integrators.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":259,"n_excluded":0,"n_missing":11,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_850829697a149033_build2DFDMatrix_py":{"hash":"13dc630820804abc849ef9ba8ca011bb","index":{"url":"z_850829697a149033_build2DFDMatrix_py.html","file":"pySDC/implementations/problem_classes/boussinesq_helpers/build2DFDMatrix.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":59,"n_excluded":0,"n_missing":59,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_850829697a149033_buildBoussinesq2DMatrix_py":{"hash":"feace82f4a241545b5f95f840b96a6af","index":{"url":"z_850829697a149033_buildBoussinesq2DMatrix_py.html","file":"pySDC/implementations/problem_classes/boussinesq_helpers/buildBoussinesq2DMatrix.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":34,"n_excluded":0,"n_missing":34,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_850829697a149033_buildFDMatrix_py":{"hash":"5d12f9534fad2a03810f31aa06a86d3c","index":{"url":"z_850829697a149033_buildFDMatrix_py.html","file":"pySDC/implementations/problem_classes/boussinesq_helpers/buildFDMatrix.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":129,"n_excluded":2,"n_missing":129,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_850829697a149033_helper_classes_py":{"hash":"ee455db9d3c4698a012d8d9b08585250","index":{"url":"z_850829697a149033_helper_classes_py.html","file":"pySDC/implementations/problem_classes/boussinesq_helpers/helper_classes.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":19,"n_excluded":0,"n_missing":19,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_850829697a149033_standard_integrators_py":{"hash":"49360f471383361790baa15975efe262","index":{"url":"z_850829697a149033_standard_integrators_py.html","file":"pySDC/implementations/problem_classes/boussinesq_helpers/standard_integrators.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":394,"n_excluded":0,"n_missing":394,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_850829697a149033_unflatten_py":{"hash":"40b25aa2d0363ed8d89f6d304d27c1df","index":{"url":"z_850829697a149033_unflatten_py.html","file":"pySDC/implementations/problem_classes/boussinesq_helpers/unflatten.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":7,"n_excluded":0,"n_missing":7,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_generic_MPIFFT_Laplacian_py":{"hash":"8f73b2ed73cc364da98e4eb437a6dc62","index":{"url":"z_91faa57f8583c837_generic_MPIFFT_Laplacian_py.html","file":"pySDC/implementations/problem_classes/generic_MPIFFT_Laplacian.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":86,"n_excluded":2,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_generic_ND_FD_py":{"hash":"cdb94124190081f7792fe3701d659e36","index":{"url":"z_91faa57f8583c837_generic_ND_FD_py.html","file":"pySDC/implementations/problem_classes/generic_ND_FD.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":71,"n_excluded":10,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_generic_spectral_py":{"hash":"81f17a69d619746c030b6915074c0c99","index":{"url":"z_91faa57f8583c837_generic_spectral_py.html","file":"pySDC/implementations/problem_classes/generic_spectral.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":141,"n_excluded":4,"n_missing":60,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_nonlinear_ODE_1_py":{"hash":"430269973759a188002a00318831c754","index":{"url":"z_91faa57f8583c837_nonlinear_ODE_1_py.html","file":"pySDC/implementations/problem_classes/nonlinear_ODE_1.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":41,"n_excluded":1,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_odeScalar_py":{"hash":"329b087632d35ed0a02e32a6f786779b","index":{"url":"z_91faa57f8583c837_odeScalar_py.html","file":"pySDC/implementations/problem_classes/odeScalar.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":53,"n_excluded":6,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_odeSystem_py":{"hash":"c098354f2fd749134957ebdbacd0c9de","index":{"url":"z_91faa57f8583c837_odeSystem_py.html","file":"pySDC/implementations/problem_classes/odeSystem.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":187,"n_excluded":18,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_91faa57f8583c837_polynomial_test_problem_py":{"hash":"0f9491300369595fd5be02dae2f47145","index":{"url":"z_91faa57f8583c837_polynomial_test_problem_py.html","file":"pySDC/implementations/problem_classes/polynomial_test_problem.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":36,"n_excluded":1,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_Multistep_py":{"hash":"33a45e1beef256e10bb6f8b51607587f","index":{"url":"z_b9c274c7ffe3e178_Multistep_py.html","file":"pySDC/implementations/sweeper_classes/Multistep.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":83,"n_excluded":1,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_Runge_Kutta_py":{"hash":"4b01b6443592b1297a3de48c521a28e5","index":{"url":"z_b9c274c7ffe3e178_Runge_Kutta_py.html","file":"pySDC/implementations/sweeper_classes/Runge_Kutta.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":286,"n_excluded":18,"n_missing":18,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_Runge_Kutta_Nystrom_py":{"hash":"43a18409d1fbd13dc1b8219b36440dbb","index":{"url":"z_b9c274c7ffe3e178_Runge_Kutta_Nystrom_py.html","file":"pySDC/implementations/sweeper_classes/Runge_Kutta_Nystrom.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":89,"n_excluded":2,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_boris_2nd_order_py":{"hash":"add8cfec5f24044f91a3c5addfa67c8f","index":{"url":"z_b9c274c7ffe3e178_boris_2nd_order_py.html","file":"pySDC/implementations/sweeper_classes/boris_2nd_order.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":118,"n_excluded":2,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_explicit_py":{"hash":"757b98e73938924ec95507db3575ff8e","index":{"url":"z_b9c274c7ffe3e178_explicit_py.html","file":"pySDC/implementations/sweeper_classes/explicit.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":46,"n_excluded":0,"n_missing":46,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_generic_implicit_py":{"hash":"42184d1672682b786daaf3e6e3326228","index":{"url":"z_b9c274c7ffe3e178_generic_implicit_py.html","file":"pySDC/implementations/sweeper_classes/generic_implicit.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":51,"n_excluded":0,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_generic_implicit_MPI_py":{"hash":"2c9eaed0f173aaf875e0ac5eaa1ffe9a","index":{"url":"z_b9c274c7ffe3e178_generic_implicit_MPI_py.html","file":"pySDC/implementations/sweeper_classes/generic_implicit_MPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":106,"n_excluded":4,"n_missing":11,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_imex_1st_order_py":{"hash":"2c85911c7f34e207f06cccd86fa7ae8a","index":{"url":"z_b9c274c7ffe3e178_imex_1st_order_py.html","file":"pySDC/implementations/sweeper_classes/imex_1st_order.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":73,"n_excluded":2,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_imex_1st_order_MPI_py":{"hash":"3a34d72bc2278a10d45ee8560612673e","index":{"url":"z_b9c274c7ffe3e178_imex_1st_order_MPI_py.html","file":"pySDC/implementations/sweeper_classes/imex_1st_order_MPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":41,"n_excluded":0,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_imex_1st_order_mass_py":{"hash":"2629bfaa9a3ea075b9675cb59e9f6b4a","index":{"url":"z_b9c274c7ffe3e178_imex_1st_order_mass_py.html","file":"pySDC/implementations/sweeper_classes/imex_1st_order_mass.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":51,"n_excluded":1,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_multi_implicit_py":{"hash":"674b912d62ef1410aba3aa007c9d4b5a","index":{"url":"z_b9c274c7ffe3e178_multi_implicit_py.html","file":"pySDC/implementations/sweeper_classes/multi_implicit.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":59,"n_excluded":0,"n_missing":8,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_b9c274c7ffe3e178_verlet_py":{"hash":"4a252f08ac66d25708a6c75791a5638b","index":{"url":"z_b9c274c7ffe3e178_verlet_py.html","file":"pySDC/implementations/sweeper_classes/verlet.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":73,"n_excluded":0,"n_missing":9,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_BaseTransferMPI_py":{"hash":"c3fc42c863e74cfc798c9860879c503f","index":{"url":"z_716c1644203275a5_BaseTransferMPI_py.html","file":"pySDC/implementations/transfer_classes/BaseTransferMPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":74,"n_excluded":6,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_BaseTransfer_mass_py":{"hash":"aa4e141fea6836cee301e1bf83608922","index":{"url":"z_716c1644203275a5_BaseTransfer_mass_py.html","file":"pySDC/implementations/transfer_classes/BaseTransfer_mass.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":84,"n_excluded":5,"n_missing":84,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_TransferFenicsMesh_py":{"hash":"68f1174bf3f1550921b37296fa2b2eab","index":{"url":"z_716c1644203275a5_TransferFenicsMesh_py.html","file":"pySDC/implementations/transfer_classes/TransferFenicsMesh.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":31,"n_excluded":4,"n_missing":11,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_TransferMesh_py":{"hash":"14356db013913f3a3b58f1efe88af456","index":{"url":"z_716c1644203275a5_TransferMesh_py.html","file":"pySDC/implementations/transfer_classes/TransferMesh.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":101,"n_excluded":10,"n_missing":25,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_TransferMesh_FFT_py":{"hash":"ed912095abaa0a5e2214d987b39c7607","index":{"url":"z_716c1644203275a5_TransferMesh_FFT_py.html","file":"pySDC/implementations/transfer_classes/TransferMesh_FFT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":30,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_TransferMesh_FFT2D_py":{"hash":"77a0dc16cdea2cfd6aba915cb09081c7","index":{"url":"z_716c1644203275a5_TransferMesh_FFT2D_py.html","file":"pySDC/implementations/transfer_classes/TransferMesh_FFT2D.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":51,"n_excluded":2,"n_missing":22,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_TransferMesh_MPIFFT_py":{"hash":"3358136a50df3899e33db29fb9103fc7","index":{"url":"z_716c1644203275a5_TransferMesh_MPIFFT_py.html","file":"pySDC/implementations/transfer_classes/TransferMesh_MPIFFT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":70,"n_excluded":4,"n_missing":8,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_TransferMesh_NoCoarse_py":{"hash":"6f1ca1d2287c3378aac12625e1b96b91","index":{"url":"z_716c1644203275a5_TransferMesh_NoCoarse_py.html","file":"pySDC/implementations/transfer_classes/TransferMesh_NoCoarse.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":18,"n_excluded":2,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_TransferPETScDMDA_py":{"hash":"cf96231ee2433e0cd59a117d3dc9a1bd","index":{"url":"z_716c1644203275a5_TransferPETScDMDA_py.html","file":"pySDC/implementations/transfer_classes/TransferPETScDMDA.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":34,"n_excluded":2,"n_missing":16,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_716c1644203275a5_TransferParticles_NoCoarse_py":{"hash":"4d4f58c6dcef175b58676157515f89aa","index":{"url":"z_716c1644203275a5_TransferParticles_NoCoarse_py.html","file":"pySDC/implementations/transfer_classes/TransferParticles_NoCoarse.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":22,"n_excluded":3,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_AllenCahn_dump_py":{"hash":"a165fb727e1378e455b3733399dd4064","index":{"url":"z_0c21c203c9df60ee_AllenCahn_dump_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/AllenCahn_dump.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":91,"n_excluded":0,"n_missing":91,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_AllenCahn_monitor_py":{"hash":"bb7b7ea9ce1b9afc7bddfb8e0591f5ea","index":{"url":"z_0c21c203c9df60ee_AllenCahn_monitor_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/AllenCahn_monitor.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":68,"n_excluded":2,"n_missing":9,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_AllenCahn_monitor_and_dump_py":{"hash":"4f6562d4d265b44325626a4b2b8c6f22","index":{"url":"z_0c21c203c9df60ee_AllenCahn_monitor_and_dump_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/AllenCahn_monitor_and_dump.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":122,"n_excluded":2,"n_missing":122,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_run_simple_forcing_benchmark_py":{"hash":"5c50ae1cae46907b987cf20b13200dff","index":{"url":"z_0c21c203c9df60ee_run_simple_forcing_benchmark_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/run_simple_forcing_benchmark.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":80,"n_excluded":11,"n_missing":80,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_run_simple_forcing_verification_py":{"hash":"31146ffe9918d2596780321ec941b444","index":{"url":"z_0c21c203c9df60ee_run_simple_forcing_verification_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/run_simple_forcing_verification.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":172,"n_excluded":12,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_run_temp_forcing_benchmark_py":{"hash":"39ab8282333dad3bb3f906989cbcda1a","index":{"url":"z_0c21c203c9df60ee_run_temp_forcing_benchmark_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/run_temp_forcing_benchmark.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":78,"n_excluded":10,"n_missing":78,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_run_temp_forcing_realistic_py":{"hash":"1b4545ee017cda0070349b502f606179","index":{"url":"z_0c21c203c9df60ee_run_temp_forcing_realistic_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/run_temp_forcing_realistic.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":74,"n_excluded":9,"n_missing":74,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_run_temp_forcing_reference_py":{"hash":"073fc300c9e19253d5179f116bfa387e","index":{"url":"z_0c21c203c9df60ee_run_temp_forcing_reference_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/run_temp_forcing_reference.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":74,"n_excluded":9,"n_missing":74,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_run_temp_forcing_verification_py":{"hash":"730a3fafa95769ba57af09d4348bec4a","index":{"url":"z_0c21c203c9df60ee_run_temp_forcing_verification_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/run_temp_forcing_verification.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":109,"n_excluded":9,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_visualize_py":{"hash":"c9b6d6b367f458d5f08cab4fc8097f00","index":{"url":"z_0c21c203c9df60ee_visualize_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/visualize.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":22,"n_excluded":3,"n_missing":22,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0c21c203c9df60ee_visualize_temp_py":{"hash":"af34cb95bef1a12f1258f3fdcd999d1e","index":{"url":"z_0c21c203c9df60ee_visualize_temp_py.html","file":"pySDC/projects/AllenCahn_Bayreuth/visualize_temp.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":62,"n_excluded":9,"n_missing":62,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73a9842ab7402c4a_PFASST_conv_Linf_py":{"hash":"c709c4eb4fd730afe66b3fd174c51783","index":{"url":"z_73a9842ab7402c4a_PFASST_conv_Linf_py.html","file":"pySDC/projects/AsympConv/PFASST_conv_Linf.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":157,"n_excluded":18,"n_missing":7,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73a9842ab7402c4a_PFASST_conv_tests_py":{"hash":"7a7bf76e1107013aa65a9e63eebf4827","index":{"url":"z_73a9842ab7402c4a_PFASST_conv_tests_py.html","file":"pySDC/projects/AsympConv/PFASST_conv_tests.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":156,"n_excluded":18,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73a9842ab7402c4a_conv_test_to0_py":{"hash":"46ca81701f434fa968ee1f5f34df9093","index":{"url":"z_73a9842ab7402c4a_conv_test_to0_py.html","file":"pySDC/projects/AsympConv/conv_test_to0.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":46,"n_excluded":3,"n_missing":46,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73a9842ab7402c4a_conv_test_toinf_py":{"hash":"592b8d77c886686b8d2fd4adc265fc08","index":{"url":"z_73a9842ab7402c4a_conv_test_toinf_py.html","file":"pySDC/projects/AsympConv/conv_test_toinf.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":46,"n_excluded":5,"n_missing":46,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73a9842ab7402c4a_smoother_specrad_heatmap_py":{"hash":"1d28c90a2e15b6028a032baaf49a2198","index":{"url":"z_73a9842ab7402c4a_smoother_specrad_heatmap_py.html","file":"pySDC/projects/AsympConv/smoother_specrad_heatmap.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":82,"n_excluded":4,"n_missing":82,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0a363dd8c140c711_hooksDAE_py":{"hash":"a6c1291020ee5b023a712ed2aa755098","index":{"url":"z_0a363dd8c140c711_hooksDAE_py.html","file":"pySDC/projects/DAE/misc/hooksDAE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":19,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0a363dd8c140c711_meshDAE_py":{"hash":"2e724b6316fc2852ee10adf40b70021c","index":{"url":"z_0a363dd8c140c711_meshDAE_py.html","file":"pySDC/projects/DAE/misc/meshDAE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":3,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0a363dd8c140c711_problemDAE_py":{"hash":"382c854502bf2d4e4e651848e42b1e17","index":{"url":"z_0a363dd8c140c711_problemDAE_py.html","file":"pySDC/projects/DAE/misc/problemDAE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":22,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0eb34c630be51b75_discontinuousTestDAE_py":{"hash":"c1e0c0b20290708fce9f8d07a2b5da01","index":{"url":"z_0eb34c630be51b75_discontinuousTestDAE_py.html","file":"pySDC/projects/DAE/problems/discontinuousTestDAE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":55,"n_excluded":0,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0eb34c630be51b75_pendulum2D_py":{"hash":"33335e975a1d6a5e2946d8109207e89f","index":{"url":"z_0eb34c630be51b75_pendulum2D_py.html","file":"pySDC/projects/DAE/problems/pendulum2D.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":25,"n_excluded":0,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0eb34c630be51b75_problematicF_py":{"hash":"c208f71cd1fc237409a80e78209786a6","index":{"url":"z_0eb34c630be51b75_problematicF_py.html","file":"pySDC/projects/DAE/problems/problematicF.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":22,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0eb34c630be51b75_simpleDAE_py":{"hash":"361d9422538bd87cf3c953c10ffc63a7","index":{"url":"z_0eb34c630be51b75_simpleDAE_py.html","file":"pySDC/projects/DAE/problems/simpleDAE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":22,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0eb34c630be51b75_synchronousMachine_py":{"hash":"38bb2b0798c469ac9800ebcfd1c27a3e","index":{"url":"z_0eb34c630be51b75_synchronousMachine_py.html","file":"pySDC/projects/DAE/problems/synchronousMachine.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":75,"n_excluded":0,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0eb34c630be51b75_transistorAmplifier_py":{"hash":"56ef517eaff53caa5bff9ff9aab21198","index":{"url":"z_0eb34c630be51b75_transistorAmplifier_py.html","file":"pySDC/projects/DAE/problems/transistorAmplifier.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":59,"n_excluded":0,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_0eb34c630be51b75_wscc9BusSystem_py":{"hash":"3105c6b590244b3c4f95a867f3bd0490","index":{"url":"z_0eb34c630be51b75_wscc9BusSystem_py.html","file":"pySDC/projects/DAE/problems/wscc9BusSystem.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":214,"n_excluded":2,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_4ef83d310f553371_accuracy_check_MPI_py":{"hash":"1f60aa30e23fbc9b7104e1511cfb816d","index":{"url":"z_4ef83d310f553371_accuracy_check_MPI_py.html","file":"pySDC/projects/DAE/run/accuracy_check_MPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":56,"n_excluded":4,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_4ef83d310f553371_fully_implicit_dae_playground_py":{"hash":"7aaf40f6396c5bdf0c491b80a097f1df","index":{"url":"z_4ef83d310f553371_fully_implicit_dae_playground_py.html","file":"pySDC/projects/DAE/run/fully_implicit_dae_playground.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":49,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_4ef83d310f553371_run_convergence_test_py":{"hash":"36c77f07b17e4a87fc69fa0a66c3bf1d","index":{"url":"z_4ef83d310f553371_run_convergence_test_py.html","file":"pySDC/projects/DAE/run/run_convergence_test.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":60,"n_excluded":6,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_4ef83d310f553371_run_iteration_test_py":{"hash":"1242e21f2048e8303eab390bbef01960","index":{"url":"z_4ef83d310f553371_run_iteration_test_py.html","file":"pySDC/projects/DAE/run/run_iteration_test.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":64,"n_excluded":6,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_4ef83d310f553371_synchronous_machine_playground_py":{"hash":"1bb24ec5ee1c1a431c83eaf436f90d9e","index":{"url":"z_4ef83d310f553371_synchronous_machine_playground_py.html","file":"pySDC/projects/DAE/run/synchronous_machine_playground.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":56,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_15820e38ae7f8080_fullyImplicitDAE_py":{"hash":"ab2fd21e01e77916c913cfdf2a81891f","index":{"url":"z_15820e38ae7f8080_fullyImplicitDAE_py.html","file":"pySDC/projects/DAE/sweepers/fullyImplicitDAE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":77,"n_excluded":6,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_15820e38ae7f8080_fullyImplicitDAEMPI_py":{"hash":"68f89253df95762a8b48ef4181b13425","index":{"url":"z_15820e38ae7f8080_fullyImplicitDAEMPI_py.html","file":"pySDC/projects/DAE/sweepers/fullyImplicitDAEMPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":58,"n_excluded":4,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_15820e38ae7f8080_rungeKuttaDAE_py":{"hash":"a5623e35f0b1e5a602a740b73605c433","index":{"url":"z_15820e38ae7f8080_rungeKuttaDAE_py.html","file":"pySDC/projects/DAE/sweepers/rungeKuttaDAE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":50,"n_excluded":5,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_15820e38ae7f8080_semiImplicitDAE_py":{"hash":"ab06faba30c319416d496621d42a0101","index":{"url":"z_15820e38ae7f8080_semiImplicitDAE_py.html","file":"pySDC/projects/DAE/sweepers/semiImplicitDAE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":52,"n_excluded":2,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_15820e38ae7f8080_semiImplicitDAEMPI_py":{"hash":"7b832b216e1c1d57cf83a9f5c76b833c","index":{"url":"z_15820e38ae7f8080_semiImplicitDAEMPI_py.html","file":"pySDC/projects/DAE/sweepers/semiImplicitDAEMPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":31,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_AcousticAdvection_1D_FD_imex_multiscale_py":{"hash":"8fc11269c623292b5ab975c63cdbb3f1","index":{"url":"z_60ee0c9d7735ef11_AcousticAdvection_1D_FD_imex_multiscale_py.html","file":"pySDC/projects/FastWaveSlowWave/AcousticAdvection_1D_FD_imex_multiscale.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":13,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_HookClass_acoustic_py":{"hash":"60c739f4f66d646569b9e83e1e54ec1b","index":{"url":"z_60ee0c9d7735ef11_HookClass_acoustic_py.html","file":"pySDC/projects/FastWaveSlowWave/HookClass_acoustic.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":12,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_HookClass_boussinesq_py":{"hash":"e9b91415aa7a1b9b7c050f7e952f56fb","index":{"url":"z_60ee0c9d7735ef11_HookClass_boussinesq_py.html","file":"pySDC/projects/FastWaveSlowWave/HookClass_boussinesq.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":11,"n_excluded":0,"n_missing":11,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_plot_dispersion_py":{"hash":"d2e45bae6b27b320d3b4899e15595511","index":{"url":"z_60ee0c9d7735ef11_plot_dispersion_py.html","file":"pySDC/projects/FastWaveSlowWave/plot_dispersion.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":115,"n_excluded":8,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_plot_stab_vs_k_py":{"hash":"dd2d419e94ae9eb068aeeaa064fbce4e","index":{"url":"z_60ee0c9d7735ef11_plot_stab_vs_k_py.html","file":"pySDC/projects/FastWaveSlowWave/plot_stab_vs_k.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":62,"n_excluded":13,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_plot_stability_py":{"hash":"442784cdc96f1c55ac3dd2075875d2ec","index":{"url":"z_60ee0c9d7735ef11_plot_stability_py.html","file":"pySDC/projects/FastWaveSlowWave/plot_stability.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":75,"n_excluded":9,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_plot_stifflimit_specrad_py":{"hash":"4e2fc67f9d003b878394b0d7d2e3aee2","index":{"url":"z_60ee0c9d7735ef11_plot_stifflimit_specrad_py.html","file":"pySDC/projects/FastWaveSlowWave/plot_stifflimit_specrad.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":82,"n_excluded":9,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_plotgmrescounter_boussinesq_py":{"hash":"8ba8ead87180dba257283974497539ed","index":{"url":"z_60ee0c9d7735ef11_plotgmrescounter_boussinesq_py.html","file":"pySDC/projects/FastWaveSlowWave/plotgmrescounter_boussinesq.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":35,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_runconvergence_acoustic_py":{"hash":"60316a3ce3d70848b7a2727383d7f158","index":{"url":"z_60ee0c9d7735ef11_runconvergence_acoustic_py.html","file":"pySDC/projects/FastWaveSlowWave/runconvergence_acoustic.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":115,"n_excluded":3,"n_missing":57,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_rungmrescounter_boussinesq_py":{"hash":"29b6d1c1cef97fabc4a65c803ae98f51","index":{"url":"z_60ee0c9d7735ef11_rungmrescounter_boussinesq_py.html","file":"pySDC/projects/FastWaveSlowWave/rungmrescounter_boussinesq.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":112,"n_excluded":8,"n_missing":112,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_runitererror_acoustic_py":{"hash":"5ff39e1615f0edfb9f292c5d053ccd51","index":{"url":"z_60ee0c9d7735ef11_runitererror_acoustic_py.html","file":"pySDC/projects/FastWaveSlowWave/runitererror_acoustic.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":83,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_60ee0c9d7735ef11_runmultiscale_acoustic_py":{"hash":"8a3967ae617d4a6317b7e6bcf3ec5b82","index":{"url":"z_60ee0c9d7735ef11_runmultiscale_acoustic_py.html","file":"pySDC/projects/FastWaveSlowWave/runmultiscale_acoustic.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":97,"n_excluded":2,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_f7d64113b0673500_ac_fft_py":{"hash":"f5dd3744d42cff813ccb3a7307f5d857","index":{"url":"z_f7d64113b0673500_ac_fft_py.html","file":"pySDC/projects/GPU/ac_fft.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":50,"n_excluded":7,"n_missing":50,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_f7d64113b0673500_heat_py":{"hash":"b48c824a0aa1601054dfc3e81e0f099a","index":{"url":"z_f7d64113b0673500_heat_py.html","file":"pySDC/projects/GPU/heat.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":6,"n_excluded":86,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_020efe120a771d8a_fput_py":{"hash":"d07f44de54eff746144b599e3d5d6854","index":{"url":"z_020efe120a771d8a_fput_py.html","file":"pySDC/projects/Hamiltonian/fput.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":134,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_020efe120a771d8a_hamiltonian_and_energy_output_py":{"hash":"785086f432853d38a8f0626f1509846a","index":{"url":"z_020efe120a771d8a_hamiltonian_and_energy_output_py.html","file":"pySDC/projects/Hamiltonian/hamiltonian_and_energy_output.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":31,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_020efe120a771d8a_hamiltonian_output_py":{"hash":"ecff87412424b74a881189ba51ae156b","index":{"url":"z_020efe120a771d8a_hamiltonian_output_py.html","file":"pySDC/projects/Hamiltonian/hamiltonian_output.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":24,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_020efe120a771d8a_harmonic_oscillator_py":{"hash":"fb77d489b282da9131a7837a93c12fb9","index":{"url":"z_020efe120a771d8a_harmonic_oscillator_py.html","file":"pySDC/projects/Hamiltonian/harmonic_oscillator.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":88,"n_excluded":2,"n_missing":88,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_020efe120a771d8a_simple_problems_py":{"hash":"a2cd7ced9c7a16ccd46adc89c57185c0","index":{"url":"z_020efe120a771d8a_simple_problems_py.html","file":"pySDC/projects/Hamiltonian/simple_problems.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":128,"n_excluded":3,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_020efe120a771d8a_solar_system_py":{"hash":"b6f77003f820e96b129dcd0f0ca0ee0b","index":{"url":"z_020efe120a771d8a_solar_system_py.html","file":"pySDC/projects/Hamiltonian/solar_system.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":157,"n_excluded":4,"n_missing":7,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_020efe120a771d8a_stop_at_error_hook_py":{"hash":"5c82130bee0e73df25baab9e22b8f85b","index":{"url":"z_020efe120a771d8a_stop_at_error_hook_py.html","file":"pySDC/projects/Hamiltonian/stop_at_error_hook.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":12,"n_excluded":0,"n_missing":12,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_6211a37896fa1d13_my_mesh_py":{"hash":"04be58dc568aaf86d7fe222530cadc67","index":{"url":"z_6211a37896fa1d13_my_mesh_py.html","file":"pySDC/projects/Monodomain/datatype_classes/my_mesh.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":3,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_21a23c20069de70c_HookClass_pde_py":{"hash":"a86ca6ee468cabb15c3adc33ce5340f6","index":{"url":"z_21a23c20069de70c_HookClass_pde_py.html","file":"pySDC/projects/Monodomain/hooks/HookClass_pde.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":16,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_21a23c20069de70c_HookClass_post_iter_info_py":{"hash":"6bb67802f4e4263e652ed009abc77296","index":{"url":"z_21a23c20069de70c_HookClass_post_iter_info_py.html","file":"pySDC/projects/Monodomain/hooks/HookClass_post_iter_info.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":10,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c11e9d9b9bfcaf22_MonodomainODE_py":{"hash":"813abf9141ed1fd9577ba7d9678e6874","index":{"url":"z_c11e9d9b9bfcaf22_MonodomainODE_py.html","file":"pySDC/projects/Monodomain/problem_classes/MonodomainODE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":186,"n_excluded":2,"n_missing":10,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_c11e9d9b9bfcaf22_TestODE_py":{"hash":"b6842898bec34345387508a6ba11363c","index":{"url":"z_c11e9d9b9bfcaf22_TestODE_py.html","file":"pySDC/projects/Monodomain/problem_classes/TestODE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":76,"n_excluded":0,"n_missing":7,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7d0f5cc921d43478___init___py":{"hash":"44b4524894dcdbfc38c06088505fc752","index":{"url":"z_7d0f5cc921d43478___init___py.html","file":"pySDC/projects/Monodomain/problem_classes/ionicmodels/cpp/__init__.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":5,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_4234e39c002aaf5f_Parabolic_DCT_py":{"hash":"253840d628efc82ee4a7d4fa8e57ac87","index":{"url":"z_4234e39c002aaf5f_Parabolic_DCT_py.html","file":"pySDC/projects/Monodomain/problem_classes/space_discretizazions/Parabolic_DCT.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":149,"n_excluded":1,"n_missing":27,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5a4fc9be2b02ba20_run_MonodomainODE_py":{"hash":"0e94721489fa0732c833cab47f7843c1","index":{"url":"z_5a4fc9be2b02ba20_run_MonodomainODE_py.html","file":"pySDC/projects/Monodomain/run_scripts/run_MonodomainODE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":205,"n_excluded":3,"n_missing":26,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5a4fc9be2b02ba20_run_MonodomainODE_cli_py":{"hash":"7e7aa9ca300af7b1553c73d236475af6","index":{"url":"z_5a4fc9be2b02ba20_run_MonodomainODE_cli_py.html","file":"pySDC/projects/Monodomain/run_scripts/run_MonodomainODE_cli.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":35,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5a4fc9be2b02ba20_run_TestODE_py":{"hash":"e8f9e2153bd05a907eedbfb802d75181","index":{"url":"z_5a4fc9be2b02ba20_run_TestODE_py.html","file":"pySDC/projects/Monodomain/run_scripts/run_TestODE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":168,"n_excluded":4,"n_missing":16,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ec92d03b7ea04ce_imexexp_1st_order_py":{"hash":"65f9923f031a97c05ef52d3bc6143974","index":{"url":"z_1ec92d03b7ea04ce_imexexp_1st_order_py.html","file":"pySDC/projects/Monodomain/sweeper_classes/exponential_runge_kutta/imexexp_1st_order.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":121,"n_excluded":2,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_44068b31c6dbca40_imexexp_1st_order_py":{"hash":"10951382ce3198d39d07b6c680c466a1","index":{"url":"z_44068b31c6dbca40_imexexp_1st_order_py.html","file":"pySDC/projects/Monodomain/sweeper_classes/runge_kutta/imexexp_1st_order.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":54,"n_excluded":1,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_f092600e49a290b3_TransferVectorOfDCTVectors_py":{"hash":"90248b1b7865ab6680b02b36772db586","index":{"url":"z_f092600e49a290b3_TransferVectorOfDCTVectors_py.html","file":"pySDC/projects/Monodomain/transfer_classes/TransferVectorOfDCTVectors.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":25,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_f092600e49a290b3_Transfer_DCT_Vector_py":{"hash":"635e5fa5978b8f33d9c0592ea6fcb4cc","index":{"url":"z_f092600e49a290b3_Transfer_DCT_Vector_py.html","file":"pySDC/projects/Monodomain/transfer_classes/Transfer_DCT_Vector.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":24,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_04cb75334c2a5eef_data_management_py":{"hash":"870b65e69a48b9266060b9077c008db7","index":{"url":"z_04cb75334c2a5eef_data_management_py.html","file":"pySDC/projects/Monodomain/utils/data_management.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":24,"n_excluded":1,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_74ce84641ea8e5a0_controller_MPI_scorep_py":{"hash":"c8260e78e3d03867c79505c50d3b31fd","index":{"url":"z_74ce84641ea8e5a0_controller_MPI_scorep_py.html","file":"pySDC/projects/Performance/controller_MPI_scorep.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":283,"n_excluded":7,"n_missing":283,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_74ce84641ea8e5a0_run_simple_forcing_benchmark_py":{"hash":"ce8b47cece2bef01d569c30f7a24e51b","index":{"url":"z_74ce84641ea8e5a0_run_simple_forcing_benchmark_py.html","file":"pySDC/projects/Performance/run_simple_forcing_benchmark.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":83,"n_excluded":11,"n_missing":83,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_74ce84641ea8e5a0_visualize_py":{"hash":"519576124b9bdd1cf7a4a3bf5402c59f","index":{"url":"z_74ce84641ea8e5a0_visualize_py.html","file":"pySDC/projects/Performance/visualize.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":41,"n_excluded":3,"n_missing":41,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_66292b4c3b6b9cb6_battery_model_py":{"hash":"1ee265d15d68d7fd3266625fd97de11a","index":{"url":"z_66292b4c3b6b9cb6_battery_model_py.html","file":"pySDC/projects/PinTSimE/battery_model.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":126,"n_excluded":59,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_66292b4c3b6b9cb6_buck_model_py":{"hash":"5ef5e00bab8e30b564310d89b167a8e1","index":{"url":"z_66292b4c3b6b9cb6_buck_model_py.html","file":"pySDC/projects/PinTSimE/buck_model.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":13,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_66292b4c3b6b9cb6_discontinuous_test_ODE_py":{"hash":"e21a9884573da22931e2ae8d2966fbf5","index":{"url":"z_66292b4c3b6b9cb6_discontinuous_test_ODE_py.html","file":"pySDC/projects/PinTSimE/discontinuous_test_ODE.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":26,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_66292b4c3b6b9cb6_estimation_check_py":{"hash":"22a48c9670ec478a1c8043c5ba0167e4","index":{"url":"z_66292b4c3b6b9cb6_estimation_check_py.html","file":"pySDC/projects/PinTSimE/estimation_check.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":31,"n_excluded":273,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_66292b4c3b6b9cb6_hardcoded_solutions_py":{"hash":"49ccd434415b17640e3089e343037bef","index":{"url":"z_66292b4c3b6b9cb6_hardcoded_solutions_py.html","file":"pySDC/projects/PinTSimE/hardcoded_solutions.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":133,"n_excluded":1,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a34c610d01aeb704_log_event_py":{"hash":"fb9ae8a84c79649bacb5d72b617c5d9c","index":{"url":"z_a34c610d01aeb704_log_event_py.html","file":"pySDC/projects/PinTSimE/paper_PSCC2024/log_event.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":14,"n_excluded":0,"n_missing":5,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_66292b4c3b6b9cb6_piline_model_py":{"hash":"e928f0e937dde3102a0aa5d4523078ba","index":{"url":"z_66292b4c3b6b9cb6_piline_model_py.html","file":"pySDC/projects/PinTSimE/piline_model.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":13,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_66292b4c3b6b9cb6_switch_estimator_py":{"hash":"bfe2f2042475ffe6ee2084c3eabcb61b","index":{"url":"z_66292b4c3b6b9cb6_switch_estimator_py.html","file":"pySDC/projects/PinTSimE/switch_estimator.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":105,"n_excluded":1,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73bf12c1262fa441_equidistant_RDC_py":{"hash":"2ec1c89ceb126d68ba4cede5a8a487b2","index":{"url":"z_73bf12c1262fa441_equidistant_RDC_py.html","file":"pySDC/projects/RDC/equidistant_RDC.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":81,"n_excluded":8,"n_missing":7,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73bf12c1262fa441_vanderpol_MLSDC_PFASST_test_py":{"hash":"ca250ea5d3e6c5ef3e56954f557c6348","index":{"url":"z_73bf12c1262fa441_vanderpol_MLSDC_PFASST_test_py.html","file":"pySDC/projects/RDC/vanderpol_MLSDC_PFASST_test.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":63,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73bf12c1262fa441_vanderpol_error_test_py":{"hash":"077d3f70e92c74a2c5ce76a9afeb853e","index":{"url":"z_73bf12c1262fa441_vanderpol_error_test_py.html","file":"pySDC/projects/RDC/vanderpol_error_test.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":82,"n_excluded":3,"n_missing":82,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_73bf12c1262fa441_vanderpol_reference_py":{"hash":"7809c275880fc741ab90214b655fd4eb","index":{"url":"z_73bf12c1262fa441_vanderpol_reference_py.html","file":"pySDC/projects/RDC/vanderpol_reference.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":35,"n_excluded":2,"n_missing":35,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_AC_py":{"hash":"6dc67adbe42c915742a3d019db72a2fe","index":{"url":"z_5893b65af8042ae2_AC_py.html","file":"pySDC/projects/Resilience/AC.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":162,"n_excluded":71,"n_missing":131,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_FDeigenvalues_py":{"hash":"fc2a809ab4aef727a8a34039b23366be","index":{"url":"z_5893b65af8042ae2_FDeigenvalues_py.html","file":"pySDC/projects/Resilience/FDeigenvalues.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":10,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_Lorenz_py":{"hash":"11339a84ec913edf0b599b78a47a0992","index":{"url":"z_5893b65af8042ae2_Lorenz_py.html","file":"pySDC/projects/Resilience/Lorenz.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":70,"n_excluded":23,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_Schroedinger_py":{"hash":"137c4ddb374e9fa0468fa2b404094f7b","index":{"url":"z_5893b65af8042ae2_Schroedinger_py.html","file":"pySDC/projects/Resilience/Schroedinger.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":82,"n_excluded":44,"n_missing":11,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_accuracy_check_py":{"hash":"3010b9565ad49096be27ae7e27be7d8e","index":{"url":"z_5893b65af8042ae2_accuracy_check_py.html","file":"pySDC/projects/Resilience/accuracy_check.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":142,"n_excluded":7,"n_missing":29,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_advection_py":{"hash":"eace70e3a2b82706909813bcfd6e936e","index":{"url":"z_5893b65af8042ae2_advection_py.html","file":"pySDC/projects/Resilience/advection.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":59,"n_excluded":17,"n_missing":18,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_collocation_adaptivity_py":{"hash":"a0edcabde70222d88c345da9ade87ede","index":{"url":"z_5893b65af8042ae2_collocation_adaptivity_py.html","file":"pySDC/projects/Resilience/collocation_adaptivity.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":132,"n_excluded":3,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_dahlquist_py":{"hash":"6ca916d38ec3c2ee5a7b8e05328a956a","index":{"url":"z_5893b65af8042ae2_dahlquist_py.html","file":"pySDC/projects/Resilience/dahlquist.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":147,"n_excluded":12,"n_missing":147,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_extrapolation_within_Q_py":{"hash":"3a044aafbd04044de6f982663d4c882d","index":{"url":"z_5893b65af8042ae2_extrapolation_within_Q_py.html","file":"pySDC/projects/Resilience/extrapolation_within_Q.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":53,"n_excluded":2,"n_missing":53,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_fault_injection_py":{"hash":"a059c27aba2123484387723d4a6fee1f","index":{"url":"z_5893b65af8042ae2_fault_injection_py.html","file":"pySDC/projects/Resilience/fault_injection.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":184,"n_excluded":9,"n_missing":16,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_fault_stats_py":{"hash":"484b6adc2c6e9fcdc767c6e739fb68f2","index":{"url":"z_5893b65af8042ae2_fault_stats_py.html","file":"pySDC/projects/Resilience/fault_stats.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":437,"n_excluded":656,"n_missing":181,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_heat_py":{"hash":"001ad6ef2ef04f438eb0fb533dc71b85","index":{"url":"z_5893b65af8042ae2_heat_py.html","file":"pySDC/projects/Resilience/heat.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":35,"n_excluded":8,"n_missing":26,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_hook_py":{"hash":"8965023300ba13fb897a19cfe5759e3a","index":{"url":"z_5893b65af8042ae2_hook_py.html","file":"pySDC/projects/Resilience/hook.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":29,"n_excluded":0,"n_missing":9,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_paper_plots_py":{"hash":"2a6ece8cb22ad59c957d8fba2fdd0269","index":{"url":"z_5893b65af8042ae2_paper_plots_py.html","file":"pySDC/projects/Resilience/paper_plots.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":26,"n_excluded":509,"n_missing":26,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_piline_py":{"hash":"4ac8c412e82cd6f3d61f6dcc6f0525cb","index":{"url":"z_5893b65af8042ae2_piline_py.html","file":"pySDC/projects/Resilience/piline.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":141,"n_excluded":8,"n_missing":19,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_quench_py":{"hash":"27920f839e31b3b607f77b47933dce55","index":{"url":"z_5893b65af8042ae2_quench_py.html","file":"pySDC/projects/Resilience/quench.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":217,"n_excluded":128,"n_missing":111,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_strategies_py":{"hash":"bcd488dbbca11f8f60a0c3991f40dee5","index":{"url":"z_5893b65af8042ae2_strategies_py.html","file":"pySDC/projects/Resilience/strategies.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":867,"n_excluded":11,"n_missing":244,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_sweepers_py":{"hash":"493d4891b34946605485b963c9274341","index":{"url":"z_5893b65af8042ae2_sweepers_py.html","file":"pySDC/projects/Resilience/sweepers.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":103,"n_excluded":1,"n_missing":9,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_vdp_py":{"hash":"dbfa62f341e3a4f235536e339dea0d02","index":{"url":"z_5893b65af8042ae2_vdp_py.html","file":"pySDC/projects/Resilience/vdp.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":195,"n_excluded":93,"n_missing":35,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_5893b65af8042ae2_work_precision_py":{"hash":"0c35152f78ba5b26ae0150b9e2b96689","index":{"url":"z_5893b65af8042ae2_work_precision_py.html","file":"pySDC/projects/Resilience/work_precision.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":348,"n_excluded":464,"n_missing":348,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_327f90590a9d3ec6_SDC_timing_Fisher_py":{"hash":"f05551d98583c46ac59cfea57b7e32f9","index":{"url":"z_327f90590a9d3ec6_SDC_timing_Fisher_py.html","file":"pySDC/projects/SDC_showdown/SDC_timing_Fisher.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":109,"n_excluded":11,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_327f90590a9d3ec6_SDC_timing_GrayScott_py":{"hash":"0ac80078a94070d4b76eb663006193c6","index":{"url":"z_327f90590a9d3ec6_SDC_timing_GrayScott_py.html","file":"pySDC/projects/SDC_showdown/SDC_timing_GrayScott.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":146,"n_excluded":11,"n_missing":30,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_check_data_folder_py":{"hash":"816be2d6d8d4363216c2157a3e2db565","index":{"url":"z_e65ba0b64d945c43_check_data_folder_py.html","file":"pySDC/projects/Second_orderSDC/check_data_folder.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":4,"n_excluded":1,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_harmonic_oscillator_params_py":{"hash":"e1b7b78c9e946b25a44fa72bf44a6e39","index":{"url":"z_e65ba0b64d945c43_harmonic_oscillator_params_py.html","file":"pySDC/projects/Second_orderSDC/harmonic_oscillator_params.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":10,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_harmonic_oscillator_run_points_py":{"hash":"fda4566f65964d06fb45f1d7221880a9","index":{"url":"z_e65ba0b64d945c43_harmonic_oscillator_run_points_py.html","file":"pySDC/projects/Second_orderSDC/harmonic_oscillator_run_points.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":3,"n_excluded":8,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_harmonic_oscillator_run_stab_interval_py":{"hash":"4fc57d018ed3c9ce93d0413be6e00c95","index":{"url":"z_e65ba0b64d945c43_harmonic_oscillator_run_stab_interval_py.html","file":"pySDC/projects/Second_orderSDC/harmonic_oscillator_run_stab_interval.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":3,"n_excluded":8,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_harmonic_oscillator_run_stability_py":{"hash":"5dcfc7e145b22918d52fca6a6fc5ea54","index":{"url":"z_e65ba0b64d945c43_harmonic_oscillator_run_stability_py.html","file":"pySDC/projects/Second_orderSDC/harmonic_oscillator_run_stability.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":2,"n_excluded":10,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_penningtrap_HookClass_py":{"hash":"85eb5580949ae41da88a91a16a23d09e","index":{"url":"z_e65ba0b64d945c43_penningtrap_HookClass_py.html","file":"pySDC/projects/Second_orderSDC/penningtrap_HookClass.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":19,"n_excluded":24,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_penningtrap_Simulation_py":{"hash":"bc110763555f1747871c3c1127cb04ea","index":{"url":"z_e65ba0b64d945c43_penningtrap_Simulation_py.html","file":"pySDC/projects/Second_orderSDC/penningtrap_Simulation.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":133,"n_excluded":5,"n_missing":32,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_penningtrap_params_py":{"hash":"53daf51fc6cd8b10401c92222a97cf79","index":{"url":"z_e65ba0b64d945c43_penningtrap_params_py.html","file":"pySDC/projects/Second_orderSDC/penningtrap_params.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":27,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_penningtrap_run_Hamiltonian_error_py":{"hash":"86c7e7c68d614b7958b6a25c86276e98","index":{"url":"z_e65ba0b64d945c43_penningtrap_run_Hamiltonian_error_py.html","file":"pySDC/projects/Second_orderSDC/penningtrap_run_Hamiltonian_error.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":10,"n_excluded":116,"n_missing":10,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_penningtrap_run_error_py":{"hash":"6f9c0db4e860d420115e6a426976530d","index":{"url":"z_e65ba0b64d945c43_penningtrap_run_error_py.html","file":"pySDC/projects/Second_orderSDC/penningtrap_run_error.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":2,"n_excluded":8,"n_missing":2,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_penningtrap_run_work_precision_py":{"hash":"9a7107b9c45239a2c0428e6e24b38f53","index":{"url":"z_e65ba0b64d945c43_penningtrap_run_work_precision_py.html","file":"pySDC/projects/Second_orderSDC/penningtrap_run_work_precision.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":3,"n_excluded":8,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_plot_helper_py":{"hash":"ff58236fdf96cad464c7162adc2e98cf","index":{"url":"z_e65ba0b64d945c43_plot_helper_py.html","file":"pySDC/projects/Second_orderSDC/plot_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":4,"n_excluded":392,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_e65ba0b64d945c43_stability_simulation_py":{"hash":"5d27c04a04a94518f351eafd318274e1","index":{"url":"z_e65ba0b64d945c43_stability_simulation_py.html","file":"pySDC/projects/Second_orderSDC/stability_simulation.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":107,"n_excluded":108,"n_missing":11,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_cf9ddae6e6f0d80b_AllenCahn_contracting_circle_py":{"hash":"b03d0f0cc571a7119bedc6290f3143a2","index":{"url":"z_cf9ddae6e6f0d80b_AllenCahn_contracting_circle_py.html","file":"pySDC/projects/TOMS/AllenCahn_contracting_circle.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":184,"n_excluded":9,"n_missing":10,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_cf9ddae6e6f0d80b_AllenCahn_monitor_py":{"hash":"51e8e5ef809c4cebb897e07d305c387a","index":{"url":"z_cf9ddae6e6f0d80b_AllenCahn_monitor_py.html","file":"pySDC/projects/TOMS/AllenCahn_monitor.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":37,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_cf9ddae6e6f0d80b_pySDC_with_PETSc_py":{"hash":"73ea0319549aa6cad39135bd9fc35f98","index":{"url":"z_cf9ddae6e6f0d80b_pySDC_with_PETSc_py.html","file":"pySDC/projects/TOMS/pySDC_with_PETSc.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":83,"n_excluded":11,"n_missing":83,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_cf9ddae6e6f0d80b_visualize_pySDC_with_PETSc_py":{"hash":"b79cceb4a5bc2aefed920d43e71e0e06","index":{"url":"z_cf9ddae6e6f0d80b_visualize_pySDC_with_PETSc_py.html","file":"pySDC/projects/TOMS/visualize_pySDC_with_PETSc.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":93,"n_excluded":4,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_3a331a23ecfeca1c_compression_convergence_controller_py":{"hash":"69c63282a7c0efe0c1aba2d288314e97","index":{"url":"z_3a331a23ecfeca1c_compression_convergence_controller_py.html","file":"pySDC/projects/compression/compression_convergence_controller.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":23,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_3a331a23ecfeca1c_order_py":{"hash":"fa9229a86cbf0f0eb9ce456363ea8ceb","index":{"url":"z_3a331a23ecfeca1c_order_py.html","file":"pySDC/projects/compression/order.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":79,"n_excluded":3,"n_missing":18,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_ecd017d7b94a3306_compare_to_matrixbased_py":{"hash":"9428f9c18bd2e9793af7e4d796979fb8","index":{"url":"z_ecd017d7b94a3306_compare_to_matrixbased_py.html","file":"pySDC/projects/matrixPFASST/compare_to_matrixbased.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":142,"n_excluded":26,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_ecd017d7b94a3306_compare_to_propagator_py":{"hash":"66a73369e354003ea0ea4b3c1da97809","index":{"url":"z_ecd017d7b94a3306_compare_to_propagator_py.html","file":"pySDC/projects/matrixPFASST/compare_to_propagator.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":135,"n_excluded":26,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_ecd017d7b94a3306_controller_matrix_nonMPI_py":{"hash":"0335aefc5e93285a007e879e67c465f8","index":{"url":"z_ecd017d7b94a3306_controller_matrix_nonMPI_py.html","file":"pySDC/projects/matrixPFASST/controller_matrix_nonMPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":183,"n_excluded":0,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_AllenCahn_parallel_py":{"hash":"1d196b715dc0b37f49446c09f952fdee","index":{"url":"z_7b436a2656aaf131_AllenCahn_parallel_py.html","file":"pySDC/projects/parallelSDC/AllenCahn_parallel.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":112,"n_excluded":17,"n_missing":17,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_ErrReductionHook_py":{"hash":"06bc6ca94798b1fe930d36b78a91249d","index":{"url":"z_7b436a2656aaf131_ErrReductionHook_py.html","file":"pySDC/projects/parallelSDC/ErrReductionHook.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":25,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_GeneralizedFisher_1D_FD_implicit_Jac_py":{"hash":"50302119be99baac69371c3ba9859dd5","index":{"url":"z_7b436a2656aaf131_GeneralizedFisher_1D_FD_implicit_Jac_py.html","file":"pySDC/projects/parallelSDC/GeneralizedFisher_1D_FD_implicit_Jac.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":12,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_Van_der_Pol_implicit_Jac_py":{"hash":"7bc6bed68ccc9dbf4f64badd36d885b1","index":{"url":"z_7b436a2656aaf131_Van_der_Pol_implicit_Jac_py.html","file":"pySDC/projects/parallelSDC/Van_der_Pol_implicit_Jac.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":14,"n_excluded":0,"n_missing":14,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_linearized_implicit_fixed_parallel_py":{"hash":"96f0400220ffe4007a8661dd4e85c9c5","index":{"url":"z_7b436a2656aaf131_linearized_implicit_fixed_parallel_py.html","file":"pySDC/projects/parallelSDC/linearized_implicit_fixed_parallel.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":37,"n_excluded":0,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_linearized_implicit_fixed_parallel_prec_py":{"hash":"5c2afeccdc589ed90f17c608f3686ef5","index":{"url":"z_7b436a2656aaf131_linearized_implicit_fixed_parallel_prec_py.html","file":"pySDC/projects/parallelSDC/linearized_implicit_fixed_parallel_prec.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":10,"n_excluded":0,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_linearized_implicit_parallel_py":{"hash":"db223cd3103c835a2372f96df69446df","index":{"url":"z_7b436a2656aaf131_linearized_implicit_parallel_py.html","file":"pySDC/projects/parallelSDC/linearized_implicit_parallel.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":37,"n_excluded":0,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_minimization_py":{"hash":"51e2d9d86cd187aa8f93608ea036e85f","index":{"url":"z_7b436a2656aaf131_minimization_py.html","file":"pySDC/projects/parallelSDC/minimization.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":48,"n_excluded":2,"n_missing":48,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_newton_vs_sdc_py":{"hash":"fc0a8303a4b91bd92e01492f91200126","index":{"url":"z_7b436a2656aaf131_newton_vs_sdc_py.html","file":"pySDC/projects/parallelSDC/newton_vs_sdc.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":97,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_nonlinear_playground_py":{"hash":"1631e836fb8c5db5dee27275234d4201","index":{"url":"z_7b436a2656aaf131_nonlinear_playground_py.html","file":"pySDC/projects/parallelSDC/nonlinear_playground.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":106,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_preconditioner_playground_py":{"hash":"60c6c220de7ca97ceef11c228c6399a6","index":{"url":"z_7b436a2656aaf131_preconditioner_playground_py.html","file":"pySDC/projects/parallelSDC/preconditioner_playground.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":142,"n_excluded":8,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_7b436a2656aaf131_preconditioner_playground_MPI_py":{"hash":"ee04d73eb0d298120a17c0469ecc7305","index":{"url":"z_7b436a2656aaf131_preconditioner_playground_MPI_py.html","file":"pySDC/projects/parallelSDC/preconditioner_playground_MPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":151,"n_excluded":22,"n_missing":4,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_allenCahn_accuracy_py":{"hash":"587620b58e9096eb1ed46b32dd1463f9","index":{"url":"z_1ba2acb451842eb0_allenCahn_accuracy_py.html","file":"pySDC/projects/parallelSDC_reloaded/allenCahn_accuracy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":58,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_allenCahn_setup_py":{"hash":"2ab3feb6b90b74fc5f168bcf1d12b9b9","index":{"url":"z_1ba2acb451842eb0_allenCahn_setup_py.html","file":"pySDC/projects/parallelSDC_reloaded/allenCahn_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":26,"n_excluded":7,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_chemicalReaction_accuracy_py":{"hash":"50bc51eeb351348d564ddab29b3cb0f8","index":{"url":"z_1ba2acb451842eb0_chemicalReaction_accuracy_py.html","file":"pySDC/projects/parallelSDC_reloaded/chemicalReaction_accuracy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":54,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_chemicalReaction_setup_py":{"hash":"210a565c4078af2ef2e4e74fcd343e12","index":{"url":"z_1ba2acb451842eb0_chemicalReaction_setup_py.html","file":"pySDC/projects/parallelSDC_reloaded/chemicalReaction_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":24,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_convergence_py":{"hash":"c47c1397d6f6ddfa97b948df74fb6735","index":{"url":"z_1ba2acb451842eb0_convergence_py.html","file":"pySDC/projects/parallelSDC_reloaded/convergence.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":38,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_jacobiElliptic_accuracy_py":{"hash":"4a8318b9645be411bbe990e6c4e84156","index":{"url":"z_1ba2acb451842eb0_jacobiElliptic_accuracy_py.html","file":"pySDC/projects/parallelSDC_reloaded/jacobiElliptic_accuracy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":52,"n_excluded":4,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_jacobiElliptic_setup_py":{"hash":"4e6099892a35510bc3195de80d8b70b6","index":{"url":"z_1ba2acb451842eb0_jacobiElliptic_setup_py.html","file":"pySDC/projects/parallelSDC_reloaded/jacobiElliptic_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":29,"n_excluded":7,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_kaps_accuracy_py":{"hash":"d6e8cfdb828fb3b9f0b4285768015091","index":{"url":"z_1ba2acb451842eb0_kaps_accuracy_py.html","file":"pySDC/projects/parallelSDC_reloaded/kaps_accuracy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":56,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_kaps_setup_py":{"hash":"9288a30ff00b8af2138d8ddd8ca867f5","index":{"url":"z_1ba2acb451842eb0_kaps_setup_py.html","file":"pySDC/projects/parallelSDC_reloaded/kaps_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":23,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_lorenz_accuracy_py":{"hash":"78043b43987dd56c58234b9841b1aa7f","index":{"url":"z_1ba2acb451842eb0_lorenz_accuracy_py.html","file":"pySDC/projects/parallelSDC_reloaded/lorenz_accuracy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":57,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_lorenz_setup_py":{"hash":"97bd5d422d807e99e2466a784cee5360","index":{"url":"z_1ba2acb451842eb0_lorenz_setup_py.html","file":"pySDC/projects/parallelSDC_reloaded/lorenz_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":24,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_nilpotency_py":{"hash":"1307f57cb34058f0d040bf0b115df411","index":{"url":"z_1ba2acb451842eb0_nilpotency_py.html","file":"pySDC/projects/parallelSDC_reloaded/nilpotency.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":46,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_protheroRobinsonAutonomous_accuracy_py":{"hash":"be2260875288245f01c2aeb007fb3ef6","index":{"url":"z_1ba2acb451842eb0_protheroRobinsonAutonomous_accuracy_py.html","file":"pySDC/projects/parallelSDC_reloaded/protheroRobinsonAutonomous_accuracy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":58,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_protheroRobinsonAutonomous_setup_py":{"hash":"3f1b3bfe18b07559e04696f740909566","index":{"url":"z_1ba2acb451842eb0_protheroRobinsonAutonomous_setup_py.html","file":"pySDC/projects/parallelSDC_reloaded/protheroRobinsonAutonomous_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":30,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_protheroRobinson_accuracy_py":{"hash":"9fb7b0dc93a1346f3b551d6e5bc3bb64","index":{"url":"z_1ba2acb451842eb0_protheroRobinson_accuracy_py.html","file":"pySDC/projects/parallelSDC_reloaded/protheroRobinson_accuracy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":58,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_protheroRobinson_setup_py":{"hash":"0f9ba829c234dedf8465971a10ba2179","index":{"url":"z_1ba2acb451842eb0_protheroRobinson_setup_py.html","file":"pySDC/projects/parallelSDC_reloaded/protheroRobinson_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":30,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_52d7e0681901465e_fig01_conv_py":{"hash":"a00b8c1a656f68ea7584ed094d083848","index":{"url":"z_52d7e0681901465e_fig01_conv_py.html","file":"pySDC/projects/parallelSDC_reloaded/scripts/fig01_conv.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":41,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_52d7e0681901465e_fig02_stab_py":{"hash":"2776c8256b01e48aad11801fee7bf136","index":{"url":"z_52d7e0681901465e_fig02_stab_py.html","file":"pySDC/projects/parallelSDC_reloaded/scripts/fig02_stab.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":40,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_52d7e0681901465e_fig03_lorenz_py":{"hash":"a56fb1672ec952b23c9e2c765d0ccfd3","index":{"url":"z_52d7e0681901465e_fig03_lorenz_py.html","file":"pySDC/projects/parallelSDC_reloaded/scripts/fig03_lorenz.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":101,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_52d7e0681901465e_fig04_protheroRobinson_py":{"hash":"b819a887eeb71b8862c8f13ef6f3132d","index":{"url":"z_52d7e0681901465e_fig04_protheroRobinson_py.html","file":"pySDC/projects/parallelSDC_reloaded/scripts/fig04_protheroRobinson.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":61,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_52d7e0681901465e_fig05_allenCahn_py":{"hash":"b350796e31a5791d06d5dc89ec3a795e","index":{"url":"z_52d7e0681901465e_fig05_allenCahn_py.html","file":"pySDC/projects/parallelSDC_reloaded/scripts/fig05_allenCahn.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":75,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_52d7e0681901465e_fig06_allenCahnMPI_py":{"hash":"80dc66efa9a08d00e9059684d8790614","index":{"url":"z_52d7e0681901465e_fig06_allenCahnMPI_py.html","file":"pySDC/projects/parallelSDC_reloaded/scripts/fig06_allenCahnMPI.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":64,"n_excluded":3,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_52d7e0681901465e_fig06_allenCahnMPI_plot_py":{"hash":"9f053c6db2611ab4165d330f2ce77f42","index":{"url":"z_52d7e0681901465e_fig06_allenCahnMPI_plot_py.html","file":"pySDC/projects/parallelSDC_reloaded/scripts/fig06_allenCahnMPI_plot.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":55,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_stability_py":{"hash":"e24af3eeb60b3441b4f3d1fab06bcce6","index":{"url":"z_1ba2acb451842eb0_stability_py.html","file":"pySDC/projects/parallelSDC_reloaded/stability.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":35,"n_excluded":4,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_utils_py":{"hash":"ab823a4054eed57d9be1f3e64b702797","index":{"url":"z_1ba2acb451842eb0_utils_py.html","file":"pySDC/projects/parallelSDC_reloaded/utils.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":168,"n_excluded":4,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_vanderpol_accuracy_py":{"hash":"d82b22bf4a2f4f029cc92f071939455a","index":{"url":"z_1ba2acb451842eb0_vanderpol_accuracy_py.html","file":"pySDC/projects/parallelSDC_reloaded/vanderpol_accuracy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":61,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ba2acb451842eb0_vanderpol_setup_py":{"hash":"73121c9ab7641c1b6b611fe4d809ffdc","index":{"url":"z_1ba2acb451842eb0_vanderpol_setup_py.html","file":"pySDC/projects/parallelSDC_reloaded/vanderpol_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":36,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_064a9f2a35945611_FaultHooks_py":{"hash":"6c4e0ae7256faeae212f8f6b86e9ac24","index":{"url":"z_064a9f2a35945611_FaultHooks_py.html","file":"pySDC/projects/soft_failure/FaultHooks.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":20,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_064a9f2a35945611_generate_statistics_py":{"hash":"284803646f07375ad119b5b67938dcf7","index":{"url":"z_064a9f2a35945611_generate_statistics_py.html","file":"pySDC/projects/soft_failure/generate_statistics.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":199,"n_excluded":16,"n_missing":50,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_064a9f2a35945611_implicit_sweeper_faults_py":{"hash":"d66667671de5ed6668fba9c3d8c00e0a","index":{"url":"z_064a9f2a35945611_implicit_sweeper_faults_py.html","file":"pySDC/projects/soft_failure/implicit_sweeper_faults.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":144,"n_excluded":0,"n_missing":8,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_064a9f2a35945611_visualization_helper_py":{"hash":"42503abb7715e2570dcd624ab1931f83","index":{"url":"z_064a9f2a35945611_visualization_helper_py.html","file":"pySDC/projects/soft_failure/visualization_helper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":54,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a8a430cd9834ab6a_A_spatial_problem_setup_py":{"hash":"2217665c983f844e6bbbb0e504edd3d8","index":{"url":"z_a8a430cd9834ab6a_A_spatial_problem_setup_py.html","file":"pySDC/tutorial/step_1/A_spatial_problem_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":21,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a8a430cd9834ab6a_B_spatial_accuracy_check_py":{"hash":"7571221d81cec43b1b00c722df579715","index":{"url":"z_a8a430cd9834ab6a_B_spatial_accuracy_check_py.html","file":"pySDC/tutorial/step_1/B_spatial_accuracy_check.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":81,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a8a430cd9834ab6a_C_collocation_problem_setup_py":{"hash":"08be0636af50ac852a0e621a7b5f1197","index":{"url":"z_a8a430cd9834ab6a_C_collocation_problem_setup_py.html","file":"pySDC/tutorial/step_1/C_collocation_problem_setup.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":26,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a8a430cd9834ab6a_D_collocation_accuracy_check_py":{"hash":"2865db91ebe25203ee836b47e78ba5d2","index":{"url":"z_a8a430cd9834ab6a_D_collocation_accuracy_check_py.html","file":"pySDC/tutorial/step_1/D_collocation_accuracy_check.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":85,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ee527a4b5236415_A_step_data_structure_py":{"hash":"3ca3ec60f6232e12fd48ed3e3ac0d7fb","index":{"url":"z_1ee527a4b5236415_A_step_data_structure_py.html","file":"pySDC/tutorial/step_2/A_step_data_structure.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":38,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ee527a4b5236415_B_my_first_sweeper_py":{"hash":"ea2f98464e92671da558a44d2dc97780","index":{"url":"z_1ee527a4b5236415_B_my_first_sweeper_py.html","file":"pySDC/tutorial/step_2/B_my_first_sweeper.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":54,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_1ee527a4b5236415_C_using_pySDCs_frontend_py":{"hash":"0cd282b28784f44dd8eef8be594021c3","index":{"url":"z_1ee527a4b5236415_C_using_pySDCs_frontend_py.html","file":"pySDC/tutorial/step_2/C_using_pySDCs_frontend.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":43,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a25a81841eb75b92_A_getting_statistics_py":{"hash":"786cb24bf8290ae117e295c015b6df41","index":{"url":"z_a25a81841eb75b92_A_getting_statistics_py.html","file":"pySDC/tutorial/step_3/A_getting_statistics.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":54,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a25a81841eb75b92_B_adding_statistics_py":{"hash":"0ffb90cce4d2f4cbec66c5d45d18543f","index":{"url":"z_a25a81841eb75b92_B_adding_statistics_py.html","file":"pySDC/tutorial/step_3/B_adding_statistics.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":55,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a25a81841eb75b92_C_study_collocations_py":{"hash":"455f5871415b87d705da206675a86d8a","index":{"url":"z_a25a81841eb75b92_C_study_collocations_py.html","file":"pySDC/tutorial/step_3/C_study_collocations.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":63,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a25a81841eb75b92_HookClass_Particles_py":{"hash":"8c5a6c79cacfd88fc0672ee33dba96d6","index":{"url":"z_a25a81841eb75b92_HookClass_Particles_py.html","file":"pySDC/tutorial/step_3/HookClass_Particles.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":49,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_99cdae9889c0cdaf_A_spatial_transfer_operators_py":{"hash":"ec8353e9d018a3714741681a5d34d008","index":{"url":"z_99cdae9889c0cdaf_A_spatial_transfer_operators_py.html","file":"pySDC/tutorial/step_4/A_spatial_transfer_operators.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":45,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_99cdae9889c0cdaf_B_multilevel_hierarchy_py":{"hash":"30a0f2259146158b492947e02b8ae263","index":{"url":"z_99cdae9889c0cdaf_B_multilevel_hierarchy_py.html","file":"pySDC/tutorial/step_4/B_multilevel_hierarchy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":43,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_99cdae9889c0cdaf_C_SDC_vs_MLSDC_py":{"hash":"94ed4c49a98fe4931d3cc1b7b2bc2f09","index":{"url":"z_99cdae9889c0cdaf_C_SDC_vs_MLSDC_py.html","file":"pySDC/tutorial/step_4/C_SDC_vs_MLSDC.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":80,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_99cdae9889c0cdaf_D_MLSDC_with_particles_py":{"hash":"2620d957070eb6a00d993f737ab53234","index":{"url":"z_99cdae9889c0cdaf_D_MLSDC_with_particles_py.html","file":"pySDC/tutorial/step_4/D_MLSDC_with_particles.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":78,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_99cdae9889c0cdaf_PenningTrap_3D_coarse_py":{"hash":"233e646e5479526536d221292eaf5f26","index":{"url":"z_99cdae9889c0cdaf_PenningTrap_3D_coarse_py.html","file":"pySDC/tutorial/step_4/PenningTrap_3D_coarse.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":11,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a2aef498bf4ac071_A_multistep_multilevel_hierarchy_py":{"hash":"c904ef1348c3e9f738f9144c72e697fe","index":{"url":"z_a2aef498bf4ac071_A_multistep_multilevel_hierarchy_py.html","file":"pySDC/tutorial/step_5/A_multistep_multilevel_hierarchy.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":32,"n_excluded":10,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a2aef498bf4ac071_B_my_first_PFASST_run_py":{"hash":"7d244638d8f2d6bac578b52eb136cfc6","index":{"url":"z_a2aef498bf4ac071_B_my_first_PFASST_run_py.html","file":"pySDC/tutorial/step_5/B_my_first_PFASST_run.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":72,"n_excluded":10,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a2aef498bf4ac071_C_advection_and_PFASST_py":{"hash":"d498abc3a341dc22897dc27133a783aa","index":{"url":"z_a2aef498bf4ac071_C_advection_and_PFASST_py.html","file":"pySDC/tutorial/step_5/C_advection_and_PFASST.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":81,"n_excluded":10,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a1e8f71763f68ddb_A_run_non_MPI_controller_py":{"hash":"530f65c964cb8c54efa1341d5a415a80","index":{"url":"z_a1e8f71763f68ddb_A_run_non_MPI_controller_py.html","file":"pySDC/tutorial/step_6/A_run_non_MPI_controller.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":97,"n_excluded":3,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a1e8f71763f68ddb_B_odd_temporal_distribution_py":{"hash":"2aecdf0552f601d0fe8a10545c5bbf2b","index":{"url":"z_a1e8f71763f68ddb_B_odd_temporal_distribution_py.html","file":"pySDC/tutorial/step_6/B_odd_temporal_distribution.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":3,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a1e8f71763f68ddb_C_MPI_parallelization_py":{"hash":"c3391b8399c83773e5d052740f25f3d3","index":{"url":"z_a1e8f71763f68ddb_C_MPI_parallelization_py.html","file":"pySDC/tutorial/step_6/C_MPI_parallelization.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":30,"n_excluded":3,"n_missing":1,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_a1e8f71763f68ddb_playground_parallelization_py":{"hash":"5592bf23c129e7223ecc5f57034d0315","index":{"url":"z_a1e8f71763f68ddb_playground_parallelization_py.html","file":"pySDC/tutorial/step_6/playground_parallelization.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":6,"n_excluded":36,"n_missing":6,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_11ffac7f7ab8bb8d_A_pySDC_with_FEniCS_py":{"hash":"a31708964f2320408198b9ef556b05ff","index":{"url":"z_11ffac7f7ab8bb8d_A_pySDC_with_FEniCS_py.html","file":"pySDC/tutorial/step_7/A_pySDC_with_FEniCS.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":105,"n_excluded":3,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_11ffac7f7ab8bb8d_B_pySDC_with_mpi4pyfft_py":{"hash":"ee5fe7368004483e8a7a2bd479f4ee9a","index":{"url":"z_11ffac7f7ab8bb8d_B_pySDC_with_mpi4pyfft_py.html","file":"pySDC/tutorial/step_7/B_pySDC_with_mpi4pyfft.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":88,"n_excluded":6,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_11ffac7f7ab8bb8d_C_pySDC_with_PETSc_py":{"hash":"e629a5808714d659d053b8fe4abb62e2","index":{"url":"z_11ffac7f7ab8bb8d_C_pySDC_with_PETSc_py.html","file":"pySDC/tutorial/step_7/C_pySDC_with_PETSc.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":95,"n_excluded":11,"n_missing":3,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_11ffac7f7ab8bb8d_D_pySDC_with_PyTorch_py":{"hash":"ad28ad25353a3c6af9cf552f3739045e","index":{"url":"z_11ffac7f7ab8bb8d_D_pySDC_with_PyTorch_py.html","file":"pySDC/tutorial/step_7/D_pySDC_with_PyTorch.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":43,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_37e09edbaf161c0a_A_visualize_residuals_py":{"hash":"4884b82ba292d16f35614c0cbd537738","index":{"url":"z_37e09edbaf161c0a_A_visualize_residuals_py.html","file":"pySDC/tutorial/step_8/A_visualize_residuals.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":32,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_37e09edbaf161c0a_B_multistep_SDC_py":{"hash":"f50a787eea87a839c960630125326fbf","index":{"url":"z_37e09edbaf161c0a_B_multistep_SDC_py.html","file":"pySDC/tutorial/step_8/B_multistep_SDC.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":98,"n_excluded":2,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_37e09edbaf161c0a_C_iteration_estimator_py":{"hash":"ef03afc5c2d573369b81cc4c70067c9e","index":{"url":"z_37e09edbaf161c0a_C_iteration_estimator_py.html","file":"pySDC/tutorial/step_8/C_iteration_estimator.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":179,"n_excluded":21,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}},"z_37e09edbaf161c0a_HookClass_error_output_py":{"hash":"183e371329cdb8b07ffdf2a063dba7e6","index":{"url":"z_37e09edbaf161c0a_HookClass_error_output_py.html","file":"pySDC/tutorial/step_8/HookClass_error_output.py","description":"","nums":{"precision":0,"n_files":1,"n_statements":30,"n_excluded":0,"n_missing":0,"n_branches":0,"n_partial_branches":0,"n_missing_branches":0}}}}}
\ No newline at end of file
diff --git a/coverage/z_020efe120a771d8a_fput_py.html b/coverage/z_020efe120a771d8a_fput_py.html
index cd3dc75787..1dbf5b0e27 100644
--- a/coverage/z_020efe120a771d8a_fput_py.html
+++ b/coverage/z_020efe120a771d8a_fput_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -328,7 +328,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_020efe120a771d8a_hamiltonian_and_energy_output_py.html b/coverage/z_020efe120a771d8a_hamiltonian_and_energy_output_py.html
index 97b9691566..570ecda793 100644
--- a/coverage/z_020efe120a771d8a_hamiltonian_and_energy_output_py.html
+++ b/coverage/z_020efe120a771d8a_hamiltonian_and_energy_output_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -196,7 +196,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_020efe120a771d8a_hamiltonian_output_py.html b/coverage/z_020efe120a771d8a_hamiltonian_output_py.html
index 2c7a57dd9c..113665247f 100644
--- a/coverage/z_020efe120a771d8a_hamiltonian_output_py.html
+++ b/coverage/z_020efe120a771d8a_hamiltonian_output_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -170,7 +170,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_020efe120a771d8a_harmonic_oscillator_py.html b/coverage/z_020efe120a771d8a_harmonic_oscillator_py.html
index 3689432b4c..fee2a3aa22 100644
--- a/coverage/z_020efe120a771d8a_harmonic_oscillator_py.html
+++ b/coverage/z_020efe120a771d8a_harmonic_oscillator_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -254,7 +254,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_020efe120a771d8a_simple_problems_py.html b/coverage/z_020efe120a771d8a_simple_problems_py.html
index df8ee5054e..c096234557 100644
--- a/coverage/z_020efe120a771d8a_simple_problems_py.html
+++ b/coverage/z_020efe120a771d8a_simple_problems_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -323,7 +323,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_020efe120a771d8a_solar_system_py.html b/coverage/z_020efe120a771d8a_solar_system_py.html
index 8cf2d17512..3049fb9b39 100644
--- a/coverage/z_020efe120a771d8a_solar_system_py.html
+++ b/coverage/z_020efe120a771d8a_solar_system_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -365,7 +365,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_020efe120a771d8a_stop_at_error_hook_py.html b/coverage/z_020efe120a771d8a_stop_at_error_hook_py.html
index 0b2469ed04..a977d78d2f 100644
--- a/coverage/z_020efe120a771d8a_stop_at_error_hook_py.html
+++ b/coverage/z_020efe120a771d8a_stop_at_error_hook_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -117,7 +117,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_04cb75334c2a5eef_data_management_py.html b/coverage/z_04cb75334c2a5eef_data_management_py.html
index ab3e668a37..eb14738c8e 100644
--- a/coverage/z_04cb75334c2a5eef_data_management_py.html
+++ b/coverage/z_04cb75334c2a5eef_data_management_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -196,7 +196,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_064a9f2a35945611_FaultHooks_py.html b/coverage/z_064a9f2a35945611_FaultHooks_py.html
index f947d22da1..d645e45bd6 100644
--- a/coverage/z_064a9f2a35945611_FaultHooks_py.html
+++ b/coverage/z_064a9f2a35945611_FaultHooks_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -135,7 +135,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_064a9f2a35945611_generate_statistics_py.html b/coverage/z_064a9f2a35945611_generate_statistics_py.html
index fc861f2ef9..01fda68405 100644
--- a/coverage/z_064a9f2a35945611_generate_statistics_py.html
+++ b/coverage/z_064a9f2a35945611_generate_statistics_py.html
@@ -55,8 +55,8 @@
199 statements
- 150 run
- 49 missing
+ 149 run
+ 50 missing
16 excluded
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -364,7 +364,7 @@
282 # calculate minimal, maximal, mean residual vectors
283 for i in range ( minlen ) :
284 if np . isnan ( residuals [ i ] ) or np . isinf ( residuals [ i ] ) :
- 285 residuals [ i ] = 1000
+ 285 residuals [ i ] = 1000
286 minres [ i ] = min ( minres [ i ] , residuals [ i ] )
287 maxres [ i ] = max ( maxres [ i ] , residuals [ i ] )
288 meanres [ i ] += residuals [ i ]
@@ -485,7 +485,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_064a9f2a35945611_implicit_sweeper_faults_py.html b/coverage/z_064a9f2a35945611_implicit_sweeper_faults_py.html
index bcfe0008df..88293531d1 100644
--- a/coverage/z_064a9f2a35945611_implicit_sweeper_faults_py.html
+++ b/coverage/z_064a9f2a35945611_implicit_sweeper_faults_py.html
@@ -2,7 +2,7 @@
- Coverage for pySDC/projects/soft_failure/implicit_sweeper_faults.py: 97%
+ Coverage for pySDC/projects/soft_failure/implicit_sweeper_faults.py: 94%
@@ -12,7 +12,7 @@
Coverage for pySDC/projects/soft_failure/implicit_sweeper_faults.py :
- 97%
+ 94%
144 statements
- 139 run
- 5 missing
+ 136 run
+ 8 missing
0 excluded
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -280,10 +280,10 @@
198 self . fault_stats . nfaults_detected += 1
199 # no fault injected but fault detected -> meh!
200 elif not self . fault_injected and self . fault_detected :
- 201 self . fault_stats . nfalse_positives += 1
+ 201 self . fault_stats . nfalse_positives += 1
202 # in correction mode and fault detected -> meeeh!
- 203 if self . in_correction :
- 204 self . fault_stats . nfalse_positives_in_correction += 1
+ 203 if self . in_correction :
+ 204 self . fault_stats . nfalse_positives_in_correction += 1
205 # fault injected but no fault detected -> meh!
206 elif self . fault_injected and not self . fault_detected :
207 self . fault_stats . nfaults_missed += 1
@@ -416,7 +416,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_064a9f2a35945611_visualization_helper_py.html b/coverage/z_064a9f2a35945611_visualization_helper_py.html
index c6e892a4b6..82cb0ceb28 100644
--- a/coverage/z_064a9f2a35945611_visualization_helper_py.html
+++ b/coverage/z_064a9f2a35945611_visualization_helper_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -217,7 +217,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0a363dd8c140c711_hooksDAE_py.html b/coverage/z_0a363dd8c140c711_hooksDAE_py.html
index eb275df61e..94f64cd775 100644
--- a/coverage/z_0a363dd8c140c711_hooksDAE_py.html
+++ b/coverage/z_0a363dd8c140c711_hooksDAE_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -171,7 +171,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0a363dd8c140c711_meshDAE_py.html b/coverage/z_0a363dd8c140c711_meshDAE_py.html
index 9123e922c2..ce272865fe 100644
--- a/coverage/z_0a363dd8c140c711_meshDAE_py.html
+++ b/coverage/z_0a363dd8c140c711_meshDAE_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -101,7 +101,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0a363dd8c140c711_problemDAE_py.html b/coverage/z_0a363dd8c140c711_problemDAE_py.html
index 4fa3d1e583..91a4230fd8 100644
--- a/coverage/z_0a363dd8c140c711_problemDAE_py.html
+++ b/coverage/z_0a363dd8c140c711_problemDAE_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -183,7 +183,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0c21c203c9df60ee_AllenCahn_dump_py.html b/coverage/z_0c21c203c9df60ee_AllenCahn_dump_py.html
index d20e67464a..e21593698f 100644
--- a/coverage/z_0c21c203c9df60ee_AllenCahn_dump_py.html
+++ b/coverage/z_0c21c203c9df60ee_AllenCahn_dump_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -237,7 +237,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0c21c203c9df60ee_AllenCahn_monitor_and_dump_py.html b/coverage/z_0c21c203c9df60ee_AllenCahn_monitor_and_dump_py.html
index d47d914823..93f0e6114f 100644
--- a/coverage/z_0c21c203c9df60ee_AllenCahn_monitor_and_dump_py.html
+++ b/coverage/z_0c21c203c9df60ee_AllenCahn_monitor_and_dump_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -350,7 +350,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0c21c203c9df60ee_AllenCahn_monitor_py.html b/coverage/z_0c21c203c9df60ee_AllenCahn_monitor_py.html
index 75ea21607b..08b9256885 100644
--- a/coverage/z_0c21c203c9df60ee_AllenCahn_monitor_py.html
+++ b/coverage/z_0c21c203c9df60ee_AllenCahn_monitor_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -274,7 +274,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0c21c203c9df60ee_run_simple_forcing_benchmark_py.html b/coverage/z_0c21c203c9df60ee_run_simple_forcing_benchmark_py.html
index 8a0331a374..02053fe3d9 100644
--- a/coverage/z_0c21c203c9df60ee_run_simple_forcing_benchmark_py.html
+++ b/coverage/z_0c21c203c9df60ee_run_simple_forcing_benchmark_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -242,7 +242,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0c21c203c9df60ee_run_simple_forcing_verification_py.html b/coverage/z_0c21c203c9df60ee_run_simple_forcing_verification_py.html
index f17dc41ca6..9b418fbd50 100644
--- a/coverage/z_0c21c203c9df60ee_run_simple_forcing_verification_py.html
+++ b/coverage/z_0c21c203c9df60ee_run_simple_forcing_verification_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -390,7 +390,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0c21c203c9df60ee_run_temp_forcing_benchmark_py.html b/coverage/z_0c21c203c9df60ee_run_temp_forcing_benchmark_py.html
index 23703adde2..350f0772be 100644
--- a/coverage/z_0c21c203c9df60ee_run_temp_forcing_benchmark_py.html
+++ b/coverage/z_0c21c203c9df60ee_run_temp_forcing_benchmark_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -226,7 +226,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0c21c203c9df60ee_run_temp_forcing_realistic_py.html b/coverage/z_0c21c203c9df60ee_run_temp_forcing_realistic_py.html
index 96df866981..fe9d7fb8f5 100644
--- a/coverage/z_0c21c203c9df60ee_run_temp_forcing_realistic_py.html
+++ b/coverage/z_0c21c203c9df60ee_run_temp_forcing_realistic_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -233,7 +233,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0c21c203c9df60ee_run_temp_forcing_reference_py.html b/coverage/z_0c21c203c9df60ee_run_temp_forcing_reference_py.html
index 378a75520f..ca1a96e35b 100644
--- a/coverage/z_0c21c203c9df60ee_run_temp_forcing_reference_py.html
+++ b/coverage/z_0c21c203c9df60ee_run_temp_forcing_reference_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -236,7 +236,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0c21c203c9df60ee_run_temp_forcing_verification_py.html b/coverage/z_0c21c203c9df60ee_run_temp_forcing_verification_py.html
index bc6b686d47..9ff69bbaf7 100644
--- a/coverage/z_0c21c203c9df60ee_run_temp_forcing_verification_py.html
+++ b/coverage/z_0c21c203c9df60ee_run_temp_forcing_verification_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -285,7 +285,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0c21c203c9df60ee_visualize_py.html b/coverage/z_0c21c203c9df60ee_visualize_py.html
index 6e31801e90..40fab8fbc1 100644
--- a/coverage/z_0c21c203c9df60ee_visualize_py.html
+++ b/coverage/z_0c21c203c9df60ee_visualize_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -140,7 +140,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0c21c203c9df60ee_visualize_temp_py.html b/coverage/z_0c21c203c9df60ee_visualize_temp_py.html
index ad04b00d1f..b026b56baa 100644
--- a/coverage/z_0c21c203c9df60ee_visualize_temp_py.html
+++ b/coverage/z_0c21c203c9df60ee_visualize_temp_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -238,7 +238,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0eb34c630be51b75_discontinuousTestDAE_py.html b/coverage/z_0eb34c630be51b75_discontinuousTestDAE_py.html
index 40075aa09c..c8bada90ee 100644
--- a/coverage/z_0eb34c630be51b75_discontinuousTestDAE_py.html
+++ b/coverage/z_0eb34c630be51b75_discontinuousTestDAE_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -293,7 +293,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0eb34c630be51b75_pendulum2D_py.html b/coverage/z_0eb34c630be51b75_pendulum2D_py.html
index 987d2a44e9..4845fb79b8 100644
--- a/coverage/z_0eb34c630be51b75_pendulum2D_py.html
+++ b/coverage/z_0eb34c630be51b75_pendulum2D_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -203,7 +203,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0eb34c630be51b75_problematicF_py.html b/coverage/z_0eb34c630be51b75_problematicF_py.html
index f5027a52f6..ddccd0e168 100644
--- a/coverage/z_0eb34c630be51b75_problematicF_py.html
+++ b/coverage/z_0eb34c630be51b75_problematicF_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -196,7 +196,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0eb34c630be51b75_simpleDAE_py.html b/coverage/z_0eb34c630be51b75_simpleDAE_py.html
index 205bdffa19..9321addcd2 100644
--- a/coverage/z_0eb34c630be51b75_simpleDAE_py.html
+++ b/coverage/z_0eb34c630be51b75_simpleDAE_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -204,7 +204,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0eb34c630be51b75_synchronousMachine_py.html b/coverage/z_0eb34c630be51b75_synchronousMachine_py.html
index 071f0a77d8..14406ea1e9 100644
--- a/coverage/z_0eb34c630be51b75_synchronousMachine_py.html
+++ b/coverage/z_0eb34c630be51b75_synchronousMachine_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -566,7 +566,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0eb34c630be51b75_transistorAmplifier_py.html b/coverage/z_0eb34c630be51b75_transistorAmplifier_py.html
index 8ae7806d71..c8a280ae3a 100644
--- a/coverage/z_0eb34c630be51b75_transistorAmplifier_py.html
+++ b/coverage/z_0eb34c630be51b75_transistorAmplifier_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -368,7 +368,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_0eb34c630be51b75_wscc9BusSystem_py.html b/coverage/z_0eb34c630be51b75_wscc9BusSystem_py.html
index b824bc4a60..31265945f7 100644
--- a/coverage/z_0eb34c630be51b75_wscc9BusSystem_py.html
+++ b/coverage/z_0eb34c630be51b75_wscc9BusSystem_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -1322,7 +1322,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_11ffac7f7ab8bb8d_A_pySDC_with_FEniCS_py.html b/coverage/z_11ffac7f7ab8bb8d_A_pySDC_with_FEniCS_py.html
index d5abb0b10f..9b4a307286 100644
--- a/coverage/z_11ffac7f7ab8bb8d_A_pySDC_with_FEniCS_py.html
+++ b/coverage/z_11ffac7f7ab8bb8d_A_pySDC_with_FEniCS_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -276,7 +276,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_11ffac7f7ab8bb8d_B_pySDC_with_mpi4pyfft_py.html b/coverage/z_11ffac7f7ab8bb8d_B_pySDC_with_mpi4pyfft_py.html
index f4366a2920..35604e11ff 100644
--- a/coverage/z_11ffac7f7ab8bb8d_B_pySDC_with_mpi4pyfft_py.html
+++ b/coverage/z_11ffac7f7ab8bb8d_B_pySDC_with_mpi4pyfft_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -243,7 +243,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_11ffac7f7ab8bb8d_C_pySDC_with_PETSc_py.html b/coverage/z_11ffac7f7ab8bb8d_C_pySDC_with_PETSc_py.html
index af08f24711..da555c5b7e 100644
--- a/coverage/z_11ffac7f7ab8bb8d_C_pySDC_with_PETSc_py.html
+++ b/coverage/z_11ffac7f7ab8bb8d_C_pySDC_with_PETSc_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -256,7 +256,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_11ffac7f7ab8bb8d_D_pySDC_with_PyTorch_py.html b/coverage/z_11ffac7f7ab8bb8d_D_pySDC_with_PyTorch_py.html
index 1c3c0a4232..239023e800 100644
--- a/coverage/z_11ffac7f7ab8bb8d_D_pySDC_with_PyTorch_py.html
+++ b/coverage/z_11ffac7f7ab8bb8d_D_pySDC_with_PyTorch_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -178,7 +178,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_15820e38ae7f8080_fullyImplicitDAEMPI_py.html b/coverage/z_15820e38ae7f8080_fullyImplicitDAEMPI_py.html
index 2a0d0848a8..4c38aee554 100644
--- a/coverage/z_15820e38ae7f8080_fullyImplicitDAEMPI_py.html
+++ b/coverage/z_15820e38ae7f8080_fullyImplicitDAEMPI_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -285,7 +285,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_15820e38ae7f8080_fullyImplicitDAE_py.html b/coverage/z_15820e38ae7f8080_fullyImplicitDAE_py.html
index 7e57086c22..2b185fbc21 100644
--- a/coverage/z_15820e38ae7f8080_fullyImplicitDAE_py.html
+++ b/coverage/z_15820e38ae7f8080_fullyImplicitDAE_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -349,7 +349,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_15820e38ae7f8080_rungeKuttaDAE_py.html b/coverage/z_15820e38ae7f8080_rungeKuttaDAE_py.html
index d12276a003..e43cb61a76 100644
--- a/coverage/z_15820e38ae7f8080_rungeKuttaDAE_py.html
+++ b/coverage/z_15820e38ae7f8080_rungeKuttaDAE_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -272,7 +272,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_15820e38ae7f8080_semiImplicitDAEMPI_py.html b/coverage/z_15820e38ae7f8080_semiImplicitDAEMPI_py.html
index c3b4843e7e..ea089e7ff8 100644
--- a/coverage/z_15820e38ae7f8080_semiImplicitDAEMPI_py.html
+++ b/coverage/z_15820e38ae7f8080_semiImplicitDAEMPI_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -187,7 +187,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_15820e38ae7f8080_semiImplicitDAE_py.html b/coverage/z_15820e38ae7f8080_semiImplicitDAE_py.html
index 25afd79c10..2051dec85d 100644
--- a/coverage/z_15820e38ae7f8080_semiImplicitDAE_py.html
+++ b/coverage/z_15820e38ae7f8080_semiImplicitDAE_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -306,7 +306,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_allenCahn_accuracy_py.html b/coverage/z_1ba2acb451842eb0_allenCahn_accuracy_py.html
index 6a1622f38e..3d2ad0472a 100644
--- a/coverage/z_1ba2acb451842eb0_allenCahn_accuracy_py.html
+++ b/coverage/z_1ba2acb451842eb0_allenCahn_accuracy_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -208,7 +208,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_allenCahn_setup_py.html b/coverage/z_1ba2acb451842eb0_allenCahn_setup_py.html
index 9101482b7b..7debf76b04 100644
--- a/coverage/z_1ba2acb451842eb0_allenCahn_setup_py.html
+++ b/coverage/z_1ba2acb451842eb0_allenCahn_setup_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -145,7 +145,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_chemicalReaction_accuracy_py.html b/coverage/z_1ba2acb451842eb0_chemicalReaction_accuracy_py.html
index 24fcb40545..21976b9938 100644
--- a/coverage/z_1ba2acb451842eb0_chemicalReaction_accuracy_py.html
+++ b/coverage/z_1ba2acb451842eb0_chemicalReaction_accuracy_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -201,7 +201,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_chemicalReaction_setup_py.html b/coverage/z_1ba2acb451842eb0_chemicalReaction_setup_py.html
index ea75b0f29e..f72448f29d 100644
--- a/coverage/z_1ba2acb451842eb0_chemicalReaction_setup_py.html
+++ b/coverage/z_1ba2acb451842eb0_chemicalReaction_setup_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -128,7 +128,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_convergence_py.html b/coverage/z_1ba2acb451842eb0_convergence_py.html
index e36627087e..78b3677762 100644
--- a/coverage/z_1ba2acb451842eb0_convergence_py.html
+++ b/coverage/z_1ba2acb451842eb0_convergence_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -165,7 +165,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_jacobiElliptic_accuracy_py.html b/coverage/z_1ba2acb451842eb0_jacobiElliptic_accuracy_py.html
index 9b0c4afc30..29051c07c5 100644
--- a/coverage/z_1ba2acb451842eb0_jacobiElliptic_accuracy_py.html
+++ b/coverage/z_1ba2acb451842eb0_jacobiElliptic_accuracy_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -203,7 +203,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_jacobiElliptic_setup_py.html b/coverage/z_1ba2acb451842eb0_jacobiElliptic_setup_py.html
index 69f33880c6..44ecb143ed 100644
--- a/coverage/z_1ba2acb451842eb0_jacobiElliptic_setup_py.html
+++ b/coverage/z_1ba2acb451842eb0_jacobiElliptic_setup_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -142,7 +142,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_kaps_accuracy_py.html b/coverage/z_1ba2acb451842eb0_kaps_accuracy_py.html
index a1e370ba9c..0b76b26c9c 100644
--- a/coverage/z_1ba2acb451842eb0_kaps_accuracy_py.html
+++ b/coverage/z_1ba2acb451842eb0_kaps_accuracy_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -204,7 +204,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_kaps_setup_py.html b/coverage/z_1ba2acb451842eb0_kaps_setup_py.html
index 9b5dcdd132..33db249964 100644
--- a/coverage/z_1ba2acb451842eb0_kaps_setup_py.html
+++ b/coverage/z_1ba2acb451842eb0_kaps_setup_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -127,7 +127,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_lorenz_accuracy_py.html b/coverage/z_1ba2acb451842eb0_lorenz_accuracy_py.html
index 4c29a07044..2641cbae9f 100644
--- a/coverage/z_1ba2acb451842eb0_lorenz_accuracy_py.html
+++ b/coverage/z_1ba2acb451842eb0_lorenz_accuracy_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -208,7 +208,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_lorenz_setup_py.html b/coverage/z_1ba2acb451842eb0_lorenz_setup_py.html
index 29100b85b1..1929d770da 100644
--- a/coverage/z_1ba2acb451842eb0_lorenz_setup_py.html
+++ b/coverage/z_1ba2acb451842eb0_lorenz_setup_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -131,7 +131,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_nilpotency_py.html b/coverage/z_1ba2acb451842eb0_nilpotency_py.html
index 1826894fe9..2f55728e9c 100644
--- a/coverage/z_1ba2acb451842eb0_nilpotency_py.html
+++ b/coverage/z_1ba2acb451842eb0_nilpotency_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -155,7 +155,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_protheroRobinsonAutonomous_accuracy_py.html b/coverage/z_1ba2acb451842eb0_protheroRobinsonAutonomous_accuracy_py.html
index 3cb171fc96..fcacb20506 100644
--- a/coverage/z_1ba2acb451842eb0_protheroRobinsonAutonomous_accuracy_py.html
+++ b/coverage/z_1ba2acb451842eb0_protheroRobinsonAutonomous_accuracy_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -215,7 +215,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_protheroRobinsonAutonomous_setup_py.html b/coverage/z_1ba2acb451842eb0_protheroRobinsonAutonomous_setup_py.html
index c775b6b184..b5e240d70c 100644
--- a/coverage/z_1ba2acb451842eb0_protheroRobinsonAutonomous_setup_py.html
+++ b/coverage/z_1ba2acb451842eb0_protheroRobinsonAutonomous_setup_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -137,7 +137,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_protheroRobinson_accuracy_py.html b/coverage/z_1ba2acb451842eb0_protheroRobinson_accuracy_py.html
index 5177fb55ab..7177ce83cb 100644
--- a/coverage/z_1ba2acb451842eb0_protheroRobinson_accuracy_py.html
+++ b/coverage/z_1ba2acb451842eb0_protheroRobinson_accuracy_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -215,7 +215,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_protheroRobinson_setup_py.html b/coverage/z_1ba2acb451842eb0_protheroRobinson_setup_py.html
index 9f34a144fe..662125206e 100644
--- a/coverage/z_1ba2acb451842eb0_protheroRobinson_setup_py.html
+++ b/coverage/z_1ba2acb451842eb0_protheroRobinson_setup_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -136,7 +136,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_stability_py.html b/coverage/z_1ba2acb451842eb0_stability_py.html
index 550d4d4636..7ae98dc8eb 100644
--- a/coverage/z_1ba2acb451842eb0_stability_py.html
+++ b/coverage/z_1ba2acb451842eb0_stability_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -167,7 +167,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_utils_py.html b/coverage/z_1ba2acb451842eb0_utils_py.html
index beee1320ce..66fa2e45b5 100644
--- a/coverage/z_1ba2acb451842eb0_utils_py.html
+++ b/coverage/z_1ba2acb451842eb0_utils_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -418,7 +418,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_vanderpol_accuracy_py.html b/coverage/z_1ba2acb451842eb0_vanderpol_accuracy_py.html
index 253d82b4af..55c76ebca3 100644
--- a/coverage/z_1ba2acb451842eb0_vanderpol_accuracy_py.html
+++ b/coverage/z_1ba2acb451842eb0_vanderpol_accuracy_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -207,7 +207,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ba2acb451842eb0_vanderpol_setup_py.html b/coverage/z_1ba2acb451842eb0_vanderpol_setup_py.html
index 5cb60dbfba..12675f5581 100644
--- a/coverage/z_1ba2acb451842eb0_vanderpol_setup_py.html
+++ b/coverage/z_1ba2acb451842eb0_vanderpol_setup_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -146,7 +146,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ec92d03b7ea04ce_imexexp_1st_order_py.html b/coverage/z_1ec92d03b7ea04ce_imexexp_1st_order_py.html
index cd94b0ae64..b6baa49fe0 100644
--- a/coverage/z_1ec92d03b7ea04ce_imexexp_1st_order_py.html
+++ b/coverage/z_1ec92d03b7ea04ce_imexexp_1st_order_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -390,7 +390,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ee527a4b5236415_A_step_data_structure_py.html b/coverage/z_1ee527a4b5236415_A_step_data_structure_py.html
index b6145aeb9b..af8bbab370 100644
--- a/coverage/z_1ee527a4b5236415_A_step_data_structure_py.html
+++ b/coverage/z_1ee527a4b5236415_A_step_data_structure_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -158,7 +158,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ee527a4b5236415_B_my_first_sweeper_py.html b/coverage/z_1ee527a4b5236415_B_my_first_sweeper_py.html
index e289e6574d..5f8c0083e1 100644
--- a/coverage/z_1ee527a4b5236415_B_my_first_sweeper_py.html
+++ b/coverage/z_1ee527a4b5236415_B_my_first_sweeper_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -206,7 +206,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1ee527a4b5236415_C_using_pySDCs_frontend_py.html b/coverage/z_1ee527a4b5236415_C_using_pySDCs_frontend_py.html
index ce0c131782..16ce8784a1 100644
--- a/coverage/z_1ee527a4b5236415_C_using_pySDCs_frontend_py.html
+++ b/coverage/z_1ee527a4b5236415_C_using_pySDCs_frontend_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -167,7 +167,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1f4fced1df9318f0_default_hook_py.html b/coverage/z_1f4fced1df9318f0_default_hook_py.html
index 0dccf9be18..8934ac5504 100644
--- a/coverage/z_1f4fced1df9318f0_default_hook_py.html
+++ b/coverage/z_1f4fced1df9318f0_default_hook_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -451,7 +451,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1f4fced1df9318f0_log_embedded_error_estimate_py.html b/coverage/z_1f4fced1df9318f0_log_embedded_error_estimate_py.html
index 632f0c4916..efaee1e2a0 100644
--- a/coverage/z_1f4fced1df9318f0_log_embedded_error_estimate_py.html
+++ b/coverage/z_1f4fced1df9318f0_log_embedded_error_estimate_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -157,7 +157,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1f4fced1df9318f0_log_errors_py.html b/coverage/z_1f4fced1df9318f0_log_errors_py.html
index 2dee6cf7d9..d4561ff82c 100644
--- a/coverage/z_1f4fced1df9318f0_log_errors_py.html
+++ b/coverage/z_1f4fced1df9318f0_log_errors_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -319,7 +319,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1f4fced1df9318f0_log_extrapolated_error_estimate_py.html b/coverage/z_1f4fced1df9318f0_log_extrapolated_error_estimate_py.html
index aac1607d9e..1cd632985a 100644
--- a/coverage/z_1f4fced1df9318f0_log_extrapolated_error_estimate_py.html
+++ b/coverage/z_1f4fced1df9318f0_log_extrapolated_error_estimate_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -123,7 +123,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1f4fced1df9318f0_log_restarts_py.html b/coverage/z_1f4fced1df9318f0_log_restarts_py.html
index 9e2f8f3f23..00066a9644 100644
--- a/coverage/z_1f4fced1df9318f0_log_restarts_py.html
+++ b/coverage/z_1f4fced1df9318f0_log_restarts_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -119,7 +119,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1f4fced1df9318f0_log_solution_py.html b/coverage/z_1f4fced1df9318f0_log_solution_py.html
index 4d7edb24dc..41891a5f7f 100644
--- a/coverage/z_1f4fced1df9318f0_log_solution_py.html
+++ b/coverage/z_1f4fced1df9318f0_log_solution_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -279,7 +279,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1f4fced1df9318f0_log_step_size_py.html b/coverage/z_1f4fced1df9318f0_log_step_size_py.html
index bd3325829d..5f4c7df9ad 100644
--- a/coverage/z_1f4fced1df9318f0_log_step_size_py.html
+++ b/coverage/z_1f4fced1df9318f0_log_step_size_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -121,7 +121,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_1f4fced1df9318f0_log_work_py.html b/coverage/z_1f4fced1df9318f0_log_work_py.html
index 34c19d86e5..bd1f18a2b5 100644
--- a/coverage/z_1f4fced1df9318f0_log_work_py.html
+++ b/coverage/z_1f4fced1df9318f0_log_work_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -168,7 +168,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_21a23c20069de70c_HookClass_pde_py.html b/coverage/z_21a23c20069de70c_HookClass_pde_py.html
index fb9242fa05..75bc4d61c0 100644
--- a/coverage/z_21a23c20069de70c_HookClass_pde_py.html
+++ b/coverage/z_21a23c20069de70c_HookClass_pde_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -123,7 +123,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_21a23c20069de70c_HookClass_post_iter_info_py.html b/coverage/z_21a23c20069de70c_HookClass_post_iter_info_py.html
index fb1aa45f29..e6b2c1a2e9 100644
--- a/coverage/z_21a23c20069de70c_HookClass_post_iter_info_py.html
+++ b/coverage/z_21a23c20069de70c_HookClass_post_iter_info_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -123,7 +123,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_3017878c2b4bc866_cupy_mesh_py.html b/coverage/z_3017878c2b4bc866_cupy_mesh_py.html
index 4c9417c8e5..1b5aad4d73 100644
--- a/coverage/z_3017878c2b4bc866_cupy_mesh_py.html
+++ b/coverage/z_3017878c2b4bc866_cupy_mesh_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -272,7 +272,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_3017878c2b4bc866_fenics_mesh_py.html b/coverage/z_3017878c2b4bc866_fenics_mesh_py.html
index 7b69b6c7d9..34baa93707 100644
--- a/coverage/z_3017878c2b4bc866_fenics_mesh_py.html
+++ b/coverage/z_3017878c2b4bc866_fenics_mesh_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -296,7 +296,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_3017878c2b4bc866_mesh_py.html b/coverage/z_3017878c2b4bc866_mesh_py.html
index ab411cd41a..2d3f9fdd60 100644
--- a/coverage/z_3017878c2b4bc866_mesh_py.html
+++ b/coverage/z_3017878c2b4bc866_mesh_py.html
@@ -2,7 +2,7 @@
- Coverage for pySDC/implementations/datatype_classes/mesh.py: 98%
+ Coverage for pySDC/implementations/datatype_classes/mesh.py: 100%
@@ -12,7 +12,7 @@
Coverage for pySDC/implementations/datatype_classes/mesh.py :
- 98%
+ 100%
56 statements
- 55 run
- 1 missing
+ 56 run
+ 0 missing
3 excluded
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -156,7 +156,7 @@
74
75 if self . comm is not None :
76 if self . comm . size > 1 :
- 77 global_absval = self . comm . allreduce ( sendobj = local_absval , op = MPI . MAX )
+ 77 global_absval = self . comm . allreduce ( sendobj = local_absval , op = MPI . MAX )
78 else :
79 global_absval = local_absval
80 else :
@@ -279,7 +279,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_3017878c2b4bc866_particles_py.html b/coverage/z_3017878c2b4bc866_particles_py.html
index 0167591edd..ddd92bd74c 100644
--- a/coverage/z_3017878c2b4bc866_particles_py.html
+++ b/coverage/z_3017878c2b4bc866_particles_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -414,7 +414,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_3017878c2b4bc866_petsc_vec_py.html b/coverage/z_3017878c2b4bc866_petsc_vec_py.html
index 75e269cd9d..821cc8a4d9 100644
--- a/coverage/z_3017878c2b4bc866_petsc_vec_py.html
+++ b/coverage/z_3017878c2b4bc866_petsc_vec_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -229,7 +229,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_327f90590a9d3ec6_SDC_timing_Fisher_py.html b/coverage/z_327f90590a9d3ec6_SDC_timing_Fisher_py.html
index 13fc3c9469..0d14652211 100644
--- a/coverage/z_327f90590a9d3ec6_SDC_timing_Fisher_py.html
+++ b/coverage/z_327f90590a9d3ec6_SDC_timing_Fisher_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -321,7 +321,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_327f90590a9d3ec6_SDC_timing_GrayScott_py.html b/coverage/z_327f90590a9d3ec6_SDC_timing_GrayScott_py.html
index 15f6e071a2..ef7b7dc7e9 100644
--- a/coverage/z_327f90590a9d3ec6_SDC_timing_GrayScott_py.html
+++ b/coverage/z_327f90590a9d3ec6_SDC_timing_GrayScott_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -388,7 +388,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
diff --git a/coverage/z_37e09edbaf161c0a_A_visualize_residuals_py.html b/coverage/z_37e09edbaf161c0a_A_visualize_residuals_py.html
index 2870cbcbe4..c57ac78c80 100644
--- a/coverage/z_37e09edbaf161c0a_A_visualize_residuals_py.html
+++ b/coverage/z_37e09edbaf161c0a_A_visualize_residuals_py.html
@@ -65,7 +65,7 @@
» next
coverage.py v7.6.1 ,
- created at 2024-09-19 09:13 +0000
+ created at 2024-09-20 16:55 +0000
@@ -154,7 +154,7 @@