Coverage for pySDC/projects/Hamiltonian/hamiltonian_and_energy_output.py: 100%
31 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
1from pySDC.core.hooks import Hooks
4class hamiltonian_and_energy_output(Hooks):
5 def __init__(self):
6 """
7 Initialization of particles output
8 """
9 super(hamiltonian_and_energy_output, self).__init__()
10 self.ham_init = None
11 self.energy_init = None
13 def pre_run(self, step, level_number):
14 # some abbreviations
15 L = step.levels[0]
16 P = L.prob
17 super(hamiltonian_and_energy_output, self).pre_run(step, level_number)
18 self.ham_init = P.eval_hamiltonian(L.u[0])
19 self.energy_init = P.eval_mode_energy(L.u[0])
21 def post_iteration(self, step, level_number):
22 """
23 Overwrite standard post iteration hook
25 Args:
26 step (pySDC.Step.step): the current step
27 level_number (int): the current level number
28 """
29 super(hamiltonian_and_energy_output, self).post_iteration(step, level_number)
31 # some abbreviations
32 L = step.levels[0]
33 P = L.prob
35 L.sweep.compute_end_point()
36 H = P.eval_hamiltonian(L.uend)
37 E = P.eval_mode_energy(L.uend)
39 self.add_to_stats(
40 process=step.status.slot,
41 time=L.time,
42 level=-1,
43 iter=step.status.iter,
44 sweep=L.status.sweep,
45 type='hamiltonian',
46 value=H,
47 )
49 self.add_to_stats(
50 process=step.status.slot,
51 time=L.time,
52 level=-1,
53 iter=step.status.iter,
54 sweep=L.status.sweep,
55 type='err_hamiltonian',
56 value=abs(self.ham_init - H),
57 )
59 self.add_to_stats(
60 process=step.status.slot,
61 time=L.time,
62 level=-1,
63 iter=step.status.iter,
64 sweep=L.status.sweep,
65 type='energy_iter',
66 value=E,
67 )
69 return None
71 def post_step(self, step, level_number):
72 """
73 Overwrite standard post iteration hook
75 Args:
76 step (pySDC.Step.step): the current step
77 level_number (int): the current level number
78 """
79 super(hamiltonian_and_energy_output, self).post_step(step, level_number)
81 # some abbreviations
82 L = step.levels[0]
83 P = L.prob
85 E = P.eval_mode_energy(L.uend)
87 self.add_to_stats(
88 process=step.status.slot,
89 time=L.time,
90 level=-1,
91 iter=step.status.iter,
92 sweep=L.status.sweep,
93 type='position',
94 value=L.uend.pos,
95 )
97 self.add_to_stats(
98 process=step.status.slot,
99 time=L.time,
100 level=-1,
101 iter=step.status.iter,
102 sweep=L.status.sweep,
103 type='energy_step',
104 value=E,
105 )
107 return None