8from .kernels
import create_abstract_solver_declarations
9from .kernels
import create_abstract_solver_definitions
10from .kernels
import create_solver_declarations
11from .kernels
import create_solver_definitions
12from .kernels
import create_musclhancock_kernel_definitions
13from .kernels
import create_compute_Riemann_kernel_for_MUSCLHancock_dsl
17from .kernels
import SolverVariant
18from .kernels
import KernelVariant
23 name, patch_size, unknowns, auxiliary_variables, min_volume_h, max_volume_h, time_step_relaxation,
24 flux=PDETerms.User_Defined_Implementation,
25 ncp=PDETerms.None_Implementation,
26 eigenvalues=PDETerms.User_Defined_Implementation,
27 boundary_conditions=PDETerms.User_Defined_Implementation,
28 refinement_criterion=PDETerms.Empty_Implementation,
29 initial_conditions=PDETerms.User_Defined_Implementation,
30 source_term=PDETerms.None_Implementation,
31 plot_grid_properties=False,
32 pde_terms_without_state=False, overlap=2
34 super(GlobalAdaptiveTimeStep,self).
__init__(name,
42 pde_terms_without_state,
43 kernel_namespace=
"musclhancock")
56 eigenvalues=eigenvalues,
57 boundary_conditions=boundary_conditions,
58 refinement_criterion=refinement_criterion,
59 initial_conditions=initial_conditions,
60 source_term=source_term )
66 boundary_conditions=None,refinement_criterion=None,initial_conditions=None,source_term=None,
67 memory_location = None,
68 use_split_loop = False,
69 additional_action_set_includes = "",
70 additional_user_includes = ""
73 If you pass in User_Defined, then the generator will create C++ stubs
74 that you have to befill manually. If you pass in None_Implementation, it
75 will create nop, i.e. no implementation or defaults. Any other string
76 is copied 1:1 into the implementation. If you pass in None, then the
77 set value so far won't be overwritten.
79 Please note that not all options are supported by all solvers.
81 This routine should be the very last invoked by the constructor.
88 create_musclhancock_kernel_definitions()
101 compute_max_eigenvalue_of_next_time_step =
True,
102 solver_variant = SolverVariant.WithVirtualFunctions,
103 kernel_variant = KernelVariant.PatchWiseAoS
110 compute_max_eigenvalue_of_next_time_step =
True,
111 solver_variant = SolverVariant.Stateless,
112 kernel_variant = KernelVariant.PatchWiseAoS
131 super(GlobalAdaptiveTimeStep,self).
set_implementation(boundary_conditions, refinement_criterion, initial_conditions, memory_location, use_split_loop, additional_action_set_includes, additional_user_includes)
136 return super(GlobalAdaptiveTimeStep, self).user_action_set_includes +
"""
137#include "kernels/musclhancock.h"
Code snippet generator for all fixed time stepping solvers.
str _compute_kernel_call_stateless
str _constructor_implementation
str _abstract_solver_user_definitions
str _finish_time_step_implementation
str _solver_user_declarations
str _solver_user_definitions
str _abstract_solver_user_declarations
str _compute_time_step_size
str _start_time_step_implementation
str _compute_new_time_step_size
Probably the simplest solver you could think off.
_source_term_implementation
_eigenvalues_implementation
set_implementation(self, flux=None, ncp=None, eigenvalues=None, boundary_conditions=None, refinement_criterion=None, initial_conditions=None, source_term=None, memory_location=None, use_split_loop=False, additional_action_set_includes="", additional_user_includes="")
If you pass in User_Defined, then the generator will create C++ stubs that you have to befill manuall...
__init__(self, name, patch_size, unknowns, auxiliary_variables, min_volume_h, max_volume_h, time_step_relaxation, flux=PDETerms.User_Defined_Implementation, ncp=PDETerms.None_Implementation, eigenvalues=PDETerms.User_Defined_Implementation, boundary_conditions=PDETerms.User_Defined_Implementation, refinement_criterion=PDETerms.Empty_Implementation, initial_conditions=PDETerms.User_Defined_Implementation, source_term=PDETerms.None_Implementation, plot_grid_properties=False, pde_terms_without_state=False, overlap=2)
user_action_set_includes(self)
Add further includes to this property, if your action sets require some additional routines from othe...