2.4.1 Post-step hook function

Demonstrate the simple hook function in PDE, which is called after each time step and may modify the state and abort the simulation.

post step hook
  0%|          | 0/10000.0 [00:00<?, ?it/s]
Initializing:   0%|          | 0/10000.0 [00:00<?, ?it/s]
  0%|          | 0/10000.0 [00:10<?, ?it/s]
  0%|          | 0.1/10000.0 [00:15<425:58:55, 153.36s/it]
  0%|          | 0.2/10000.0 [00:15<212:59:36, 76.68s/it]
  0%|          | 0.3/10000.0 [00:15<141:59:43, 51.12s/it]
  0%|          | 12.7/10000.0 [00:15<3:21:01,  1.21s/it]
  4%|▎         | 358.7/10000.0 [00:15<06:53, 23.34it/s]
  4%|▎         | 358.7/10000.0 [00:15<06:54, 23.25it/s]
  4%|▎         | 358.7/10000.0 [00:15<06:54, 23.25it/s]

from pde import PDE, ScalarField, UnitGrid


def post_step_hook(state_data, t):
    """Helper function called after every time step."""
    state_data[24:40, 24:40] = 1  # set central region to given value

    if t > 1e3:
        raise StopIteration  # abort simulation at given time


eq = PDE({"c": "laplace(c)"}, post_step_hook=post_step_hook)
state = ScalarField(UnitGrid([64, 64]))
result = eq.solve(state, dt=0.1, t_range=1e4)
result.plot()

Total running time of the script: (0 minutes 15.519 seconds)