Coverage for pySDC/projects/FastWaveSlowWave/rungmrescounter_boussinesq.py: 0%
112 statements
« prev ^ index » next coverage.py v7.6.1, created at 2024-09-20 17:10 +0000
« prev ^ index » next coverage.py v7.6.1, created at 2024-09-20 17:10 +0000
1import numpy as np
4from pySDC.implementations.controller_classes.controller_nonMPI import controller_nonMPI
5from pySDC.implementations.problem_classes.Boussinesq_2D_FD_imex import boussinesq_2d_imex
6from pySDC.implementations.problem_classes.boussinesq_helpers.standard_integrators import SplitExplicit, dirk, rk_imex
7from pySDC.implementations.problem_classes.boussinesq_helpers.unflatten import unflatten
8from pySDC.implementations.sweeper_classes.imex_1st_order import imex_1st_order
9from pySDC.projects.FastWaveSlowWave.HookClass_boussinesq import gmres_tolerance
12def main(cwd=''):
13 """
14 Example running/comparing SDC and different standard integrators for the 2D Boussinesq equation
16 Args:
17 cwd (string): current working directory
18 """
20 num_procs = 1
22 # setup parameters "in time"
23 t0 = 0
24 Tend = 3000
25 Nsteps = 100
26 dt = Tend / float(Nsteps)
28 # initialize level parameters
29 level_params = dict()
30 level_params['restol'] = 1e-15
31 level_params['dt'] = dt
33 # initialize step parameters
34 step_params = dict()
35 step_params['maxiter'] = 4
37 # initialize sweeper parameters
38 sweeper_params = dict()
39 sweeper_params['quad_type'] = 'GAUSS'
40 sweeper_params['num_nodes'] = 3
42 # initialize controller parameters
43 controller_params = dict()
44 controller_params['logger_level'] = 20
45 controller_params['hook_class'] = gmres_tolerance
47 # initialize problem parameters
48 problem_params = dict()
49 problem_params['nvars'] = [(4, 300, 30)]
50 problem_params['u_adv'] = 0.02
51 problem_params['c_s'] = 0.3
52 problem_params['Nfreq'] = 0.01
53 problem_params['x_bounds'] = [(-150.0, 150.0)]
54 problem_params['z_bounds'] = [(0.0, 10.0)]
55 problem_params['order'] = [4]
56 problem_params['order_upw'] = [5]
57 problem_params['gmres_maxiter'] = [500]
58 problem_params['gmres_restart'] = [10]
59 problem_params['gmres_tol_limit'] = [1e-05]
60 problem_params['gmres_tol_factor'] = [0.1]
62 # fill description dictionary for easy step instantiation
63 description = dict()
64 description['problem_class'] = boussinesq_2d_imex # pass problem class
65 description['problem_params'] = problem_params # pass problem parameters
66 description['sweeper_class'] = imex_1st_order # pass sweeper (see part B)
67 description['sweeper_params'] = sweeper_params # pass sweeper parameters
68 description['level_params'] = level_params # pass level parameters
69 description['step_params'] = step_params # pass step parameters
71 # ORDER OF DIRK/IMEX EQUAL TO NUMBER OF SDC ITERATIONS AND THUS SDC ORDER
72 dirk_order = step_params['maxiter']
74 controller = controller_nonMPI(num_procs=num_procs, controller_params=controller_params, description=description)
76 # get initial values on finest level
77 P = controller.MS[0].levels[0].prob
78 uinit = P.u_exact(t0)
80 cfl_advection = P.params.u_adv * dt / P.h[0]
81 cfl_acoustic_hor = P.params.c_s * dt / P.h[0]
82 cfl_acoustic_ver = P.params.c_s * dt / P.h[1]
83 print("Horizontal resolution: %4.2f" % P.h[0])
84 print("Vertical resolution: %4.2f" % P.h[1])
85 print("CFL number of advection: %4.2f" % cfl_advection)
86 print("CFL number of acoustics (horizontal): %4.2f" % cfl_acoustic_hor)
87 print("CFL number of acoustics (vertical): %4.2f" % cfl_acoustic_ver)
89 print("Running SplitExplicit ....")
90 method_split = 'MIS4_4'
91 # method_split = 'RK3'
92 splitp = SplitExplicit(P, method_split, problem_params)
93 u0 = uinit.flatten()
94 usplit = np.copy(u0)
95 print(np.linalg.norm(usplit))
96 for _ in range(0, 2 * Nsteps):
97 usplit = splitp.timestep(usplit, dt / 2)
98 print(np.linalg.norm(usplit))
100 print("Running DIRK ....")
101 dirkp = dirk(P, dirk_order)
102 udirk = np.copy(u0)
103 print(np.linalg.norm(udirk))
104 for _ in range(0, Nsteps):
105 udirk = dirkp.timestep(udirk, dt)
106 print(np.linalg.norm(udirk))
108 print("Running RK-IMEX ....")
109 rkimex = rk_imex(P, dirk_order)
110 uimex = np.copy(u0)
111 dt_imex = dt
112 for _ in range(0, Nsteps):
113 uimex = rkimex.timestep(uimex, dt_imex)
114 print(np.linalg.norm(uimex))
116 print("Running SDC...")
117 uend, stats = controller.run(u0=uinit, t0=t0, Tend=Tend)
119 # For reference solution, increase GMRES tolerance
120 P.gmres_tol_limit = 1e-10
121 rkimexref = rk_imex(P, 5)
122 uref = np.copy(u0)
123 dt_ref = dt / 10.0
124 print("Running RK-IMEX reference....")
125 for _ in range(0, 10 * Nsteps):
126 uref = rkimexref.timestep(uref, dt_ref)
128 usplit = unflatten(usplit, 4, P.N[0], P.N[1])
129 udirk = unflatten(udirk, 4, P.N[0], P.N[1])
130 uimex = unflatten(uimex, 4, P.N[0], P.N[1])
131 uref = unflatten(uref, 4, P.N[0], P.N[1])
133 np.save(cwd + 'data/xaxis', P.xx)
134 np.save(cwd + 'data/sdc', uend)
135 np.save(cwd + 'data/dirk', udirk)
136 np.save(cwd + 'data/rkimex', uimex)
137 np.save(cwd + 'data/split', usplit)
138 np.save(cwd + 'data/uref', uref)
140 print("diff split ", np.linalg.norm(uref - usplit))
141 print("diff dirk ", np.linalg.norm(uref - udirk))
142 print("diff rkimex ", np.linalg.norm(uref - uimex))
143 print("diff sdc ", np.linalg.norm(uref - uend))
145 print(" #### Logging report for Split #### ")
146 print("Total number of matrix multiplications: %5i" % splitp.logger.nsmall)
148 print(" #### Logging report for DIRK-%1i #### " % dirkp.order)
149 print("Number of calls to implicit solver: %5i" % dirkp.logger.solver_calls)
150 print("Total number of GMRES iterations: %5i" % dirkp.logger.iterations)
151 print(
152 "Average number of iterations per call: %6.3f"
153 % (float(dirkp.logger.iterations) / float(dirkp.logger.solver_calls))
154 )
155 print(" ")
156 print(" #### Logging report for RK-IMEX-%1i #### " % rkimex.order)
157 print("Number of calls to implicit solver: %5i" % rkimex.logger.solver_calls)
158 print("Total number of GMRES iterations: %5i" % rkimex.logger.iterations)
159 print(
160 "Average number of iterations per call: %6.3f"
161 % (float(rkimex.logger.iterations) / float(rkimex.logger.solver_calls))
162 )
163 print(" ")
164 print(" #### Logging report for SDC-(%1i,%1i) #### " % (sweeper_params['num_nodes'], step_params['maxiter']))
165 print("Number of calls to implicit solver: %5i" % P.gmres_logger.solver_calls)
166 print("Total number of GMRES iterations: %5i" % P.gmres_logger.iterations)
167 print(
168 "Average number of iterations per call: %6.3f"
169 % (float(P.gmres_logger.iterations) / float(P.gmres_logger.solver_calls))
170 )
173if __name__ == "__main__":
174 main()