Calibration of the monodomain model coupled with the Rogers-McCulloch model for the ionic current: design of a protocol for impulse delivery from an ATP device.
Before running the code contained in this repository, please have a look at WARNING.md.
The framework for this project is the following: the normal diffusion of the potential in the heart is hindered by a re-entry of the signal, possibly caused by scar tissue in specific areas of the heart. This problem leads to some complications, which could be fatal. In order to restore the normal diffusion of the potential through the affected region, an Anti-Tachycardia Pacing (ATP) device is inserted: its purpose is to deliver an impulse at a specific time (from now on called impulse time) and with a specific duration (from now on called impulse duration) to avoid the re-entry. The role of the impulse is to reset the ECG and the device checks the effectiveness of the shock tracking the ECG in a certain time interval after the shock. This period is called tracking window and it lasts from 600 to 800 milliseconds. The impulse timing can be within 450 and 525 milliseconds and there is no bound a priori on the impulse duration.
We are given
- three ECG signal observed for some milliseconds of three different patients;
- a numerical solver to compute an approximation of an ECG to solve the monodomain model, couple with the Rogers-McCulloch model for the ionic current.
We want to:
- calibrate patient-specific parameter
$\nu_2 \in (0.0116, 0.0124)$ ms for the Rogers-McCulloch model; - find the best values for the timing (tbest) and duration (Δtbest) of the impulse delivered by the ATP;
We quantify the effectiveness of pair (tbest, Δtbest) in terms of the ability of the resulting impulse to:
- annihilate the ECG in the tracking window
- preserve the device's battery as long as possible by minimizing the duration of the impulse
Before working on the ATP device, we need to tune hyperparameter
Remarks:
- The ECG provided are noisy: they were first denoised using a low-pass bandpass filter called Butterworth filter. The results are shown in the following plots:
Patient 1 | Patient 2 | Patient 3 |
---|---|---|
- For each iteration, the sampling of
$\nu_2$ is repeated until it falls within its bounds. - The variance of the Gaussian from which we sample
$\nu_2$ decreases according to the number of iterations. - We used 20 iterations: for each iteration we need to compute the solution of the monodomain problem coupled with the model for the ionic current, which is quite costly.
The following plots show the results of the calibration:
Patient Number | ν2 | MSE | Exact ECG (orange) vs Numerical ECG (blue) |
---|---|---|---|
Patient 1 | 0.012113108 | 0.020216 | |
Patient 2 | 0.011852261 | 0.019144 | |
Patient 3 | 0.011748969 | 0.021651 |
In particular, this plot showcases the exploration for paramete
Calibrating t and Δt using grid search or even our own version of a Naive Random Search (which we called Adaptive Random Search) is too costly, since for each possible couple (t, Δt) we would need to solve the monodomain problem for each patient.
To avoid wasting time in useless evaluations, we relied on Bayesian Otimization, in particular on this opensource python library, which needs to be installed to run the code contained in this repository:
pip install bayesian-optimization
The Bayesian Optimization algorithm is specifically designed to minimize the number of evaluations of the objective function, which in our case is the L2 norm of the ECG signal of each patient in the tracking window (600, 800) milliseconds. This approach is particularly useful when the objective function is expensive to be evaluated, as in our case.
Remarks:
- Bayesian Optimization is implemented to solve a maximization problem, so to use this library for our purposes1, we used the opposite of the L2 norm of the numerical ECG, hence the "minus" sign in the objective function.
- To take into account also the battery duration, we decided to add to the loss function a term which is proportional to the square of the duration of the impulse, to try to be more conservative with respect to the battery consumption.
- The ATP device comes into play only after 450 milliseconds, therefore the ECG until the 450-th millisecond is always the same. Still, the numerical solver (which relies on an iterative procedure) needs to compute the solution from the very beginning. To avoid wasting time on simulating the first 450 milliseconds, we computed the ECG once and for all and saved it: at each step of the Bayesian Optimization algorithm, we simply load the numerical ECG until the 450-th millisecond and go on from there using the solver. Please look at WARNING.md for more details.
We used two types of loss function:
$||\hat{u}||_{L^2(600, 800)ms} + \lambda \Delta t$ $||\hat{u}||_{L^2(600, 800)ms} + \lambda (\Delta t)^2$
where
-
$\hat{u}$ is the numerical ECG. -
$\Delta t$ is the ATP impulse duration. -
$\lambda$ is a term which quantifies the fact that higher values of$\Delta t$ should be avoided, since they undemine the device's battery.
Moreover, we noticed that by restricting the bounds for Δt, we were still able to find optimal results. For this reason we restricted the bounds for Δt.
We decided to use:
item | Patient 1 | Patient 2 | Patient 3 |
---|---|---|---|
Loss | |||
1 | 1 | 0.001 | |
(0, 2) ms | (0, 2) ms | (0, 8) ms |
Remarks:
- We needed to tread carefully with parameter
$\lambda$ : if we penalized excessively longer impulse durations, the overall loss function was not able to reset the ECG in the tracking window. This trade-off forced us to cope with higher impulse durations, especially for patient 3. - We realized that it was not necessary to annihilate the ECG in the whole tracking window, hence we tried to restrict the
$L^2$ norm of the ECG in a subset of the tracking window2. - The calibration for the third patient was the one which consistently resulted in higher values for
$\Delta t$ , therefore we decided to focus on finding better values for the impulse duration, rather than exploring the space of possible impusle timings. We therefore set lambda equal to one and restricted the bounds for the impulse timing of patient 3 from (450, 600) ms to (509, 513) ms. The choice for these values was motivated by the following plot:
The following plots showcase the ability of our impulse delivery protocol to reset the ECG in the tracking widow for all three patients:
Patient Number | Impulse delivery timing | Impulse duration | Numerical ECG |
---|---|---|---|
Patient 1 | 484.707 ms | 2.697 ms | |
Patient 2 | 501.435 ms | 2.804 ms | |
Patient 3 | 511.579 ms | 5.038 ms |
Footnotes
-
We want to reset the ECG, therefore we are dealing with a minimization task. ↩
-
Basically this means that, being the tracking window within 600 and 800 milliseconds, with this choice the ECG was not exaclty zero from 600 milliseconds on, but from, from example, 750 milliseconds. This is still condiered an effective impulse. ↩