This patent application claims priority from Italian patent application no. 102022000004628 filed on Mar. 10, 2022, the entire disclosure of which is incorporated herein by reference.
The present invention relates to a method for generating an activation map of a patient's heart. Moreover, it relates to a respective computer program product, to a control unit configured to implement said method and to a device comprising said control unit. In particular, the method can be based on a generative adversarial network (GAN), it can implement a fully connected neural network as surrogate model for replacing the calculation of a forward model and it can include a reconstruction neural network to prevent mode collapse of the GAN.
As known, efficiently and easily recovering the cardiac ventricular activation sequence from ECG signals is crucial for performing several medical procedures and thus improving the patients' healthcare.
In particular, the ECG (electrocardiogram) signals acquired from a patient correspond to electric potentials measured on the patient's skin (e.g., on the skin of the torso of the patient); such electric potentials vary due to depolarization and repolarization of the heart and thus are indicative of the electrical activity of the cardiac muscle at each cardiac cycle (heartbeat). Recovering the cardiac ventricular activity from the ECG signals allows, for example, to perform more efficiently cardiac catheterization of the patient since the physician performing this procedure can be aware in advance of the specific conditions of the patient's heart and thus is able to place the catheter in the most appropriate regions of the heart (analogously, another application is the placing of pacemaker electrodes).
In the past, known solutions for obtaining an activation map (indicative of time propagation of an action potential wavefront in the myocardium) involved using invasive mapping techniques that are not based on acquisition of ECG signals but directly measure the electrical activity of the heart through electrodes placed in the heart or on its external surface. Nonetheless, this approach requires invasive access to the heart and has several serious limitations (e.g., high risk of local infection or thrombosis of the access site vessel) and risks for the patient's health that prevent it to be suitable for use in routine clinical practice.
Other known solutions involve non-invasive approaches based on acquisition of the ECG signals and calculation of activation map through mathematical models. In particular, these approaches exploit the solution of a so-called reverse problem, i.e. of a system of mathematical equations which starting from the ECG signals allows to obtain the activation map. Nonetheless, these approaches have several limitations. The main limitation is that the reverse problem is an ill-posed one that thus has several possible solutions, i.e. the accuracy of the method is not guaranteed. The number of possible solutions can be lowered by increasing the number of acquired electric signals; however, this requires using a large number of electrodes placed on the skin (e.g., hundreds of electrodes) and thus its use is impractical in routine clinical practice. Moreover, the accuracy of this approach is still very low and, for example, the error in identification of the heart regions that are electrically active continues to range from about 15 mm to about 30 mm. Furthermore, solving a reverse problem is extremely time consuming and has a high computational cost.
The aim of the present invention is to provide a method for generating an activation map of a patient's heart, a respective computer program product, a control unit configured to implement said method and a device comprising said control unit that overcome the issues mentioned above.
According to the present invention, a method for generating an activation map of a patient's heart, a respective computer program product, a control unit configured to implement said method and a device comprising said control unit are provided, as defined in the annexed claims.
For a better understanding of the present invention, preferred embodiments thereof are now described, purely by way of non-limiting example and with reference to the attached drawings, wherein:
In particular, the figures are shown with reference to a triaxial Cartesian reference system defined by an X axis, a Y axis and a Z axis, orthogonal to each other.
In the following, elements common to the different embodiments have been indicated with the same reference numbers.
The activation map 40 is indicative of the time propagation of an action potential wavefront in the heart 12 (e.g., in the myocardium). In details, during its functioning, the heart 12 contracts and expands itself based on action potential signals (i.e., electric potentials, also called action potential wavefronts) induced by the nervous system of the patient; these contractions and expansions of the heart 12 are due to mechanical deformations (e.g., contractions and extensions) of cardiac muscle fibers of the myocardium, each of them being electrically controlled through these action potential signals. The activation of the cardiac muscle fibers is not simultaneous for all the cardiac muscle fibers: when an action potential signals is induced in a certain area of the heart 12, it spreads across the heart 12 by travelling across the cardiac muscle fibers (thus inducing their deformation). In other words, each action potential signal is transmitted through the heart 12 according to a time propagation that depends upon several factors (e.g., orientation of the cardiac muscle fibers, electrical conductivity of each region of the heart 12, pathologies of the heart 12, etc.). The time propagation of an action potential signal travelling through the heart 12 is described through said activation map 40.
For illustration purposes, an example of an activation map 40 is shown in
In particular, the activation map 40 is a map (e.g., a 3D map) in the form of a matrix (e.g., a 3D matrix) where each one of its cells is associated to a specific and respective portion of the heart 12 and has a value that is indicative of the local activation time of such respective portion of the heart 12.
Moreover, the action potential signals travelling through the heart 12 induce, due to known electrostatic effects, variations of an electrical potential measured on the skin 20 of the patient (in the following called skin potential). In particular, measured ECG signals indicative of the skin potential are acquired according to per se known ECG techniques and are dependent on the action potential signals according to per se known mathematical relationships (e.g., according to a so-called forward problem, better discussed in the following).
In the embodiment of
In particular, the sensing module 14 comprises a plurality of ECG electrodes 18 that, during use, are attached in a removable way to the skin 20 of the patient to acquire the measured ECG signals. In details, the sensing module 14 comprises twelve ECG electrodes 18 placed on the skin 20 of the torso 22 of the patient and optionally on the skin of patient's limbs, in predefined positions that are well known in the electrocardiography field. Therefore, the physiological data of the patient at least comprise the measured ECG signals that are indicative of the skin potential variations caused by the action potential signals.
Optionally, the sensing module 14 further comprises other sensing elements to measure additional physiological data. For example, the sensing module 14 can further comprise medical imaging apparatuses for acquiring medical images of the patient or medical data obtained through medical imaging techniques, such as per se known patient's tetrahedral torso mesh (including labeled regions of the heart and lungs), myocardial fiber direction matrix, AHA (“American Heart Association”) sectorization markers, universal ventricular coordinates (further details can be found for example in the prior art document https://www.sciencedirect.com/science/article/pii/S1361841518300203), myocardial fiber direction field and myocardial tissue conductivity.
According to an exemplary and non-limiting embodiment, the control unit 16 comprises a processing unit 16a (such as a CPU, a microprocessor, an AP or a dedicated computing unit) for processing the physiological data and generating the activation map 40, and a data storage unit 16b (such as a memory, e.g. non-volatile) for storing data, coupled together. Optionally, the control unit 16 further comprises an interface unit 16c of a known type, coupled to the sensing module 14, to the processing unit 16a and to the data storage unit 16b and configured to pre-process the physiological data and/or electric signals acquired from the sensing module 14. For example, the interface unit 16c includes amplifier circuits and/or analog-to-digital converters (ADC) and/or serial communication modules (e.g., UART, SPI, I2C, etc.), not shown.
According to an embodiment described with reference to
In use, the device 10 implements the activation map generation method 30 for generating the activation map 40. The activation map generation method 30 is in particular performed by the control unit 16 and is described in the following with respect to
At a step S03 of the activation map generation method 30, the physiological data of the patient are acquired by the control unit 16 through the sensing module 14. In particular, in the following it is exemplarily considered the case in which the measured ECG signal is used in the activation map generation method 30; nevertheless, the activation map generation method 30 can analogously be executed by using more general ECG parameters indicative of the measured ECG signal (e.g., statistical parameters of the measured ECG signal such as variance, QRS duration of the ECG measured signal or parameters describing the ECG data, as disclosed for example in document Kuznetsov V V, Moskalenko V A, Gribanov D V and Zolotykh N Y (2021) “Interpretable Feature Generation in ECG Using a Variational Autoencoder”. Front. Genet. 12:638191. doi: 10.3389/fgene.2021.638191). Therefore, in the considered case at step S03 the control unit 16 acquires the measured ECG signal through the ECG electrodes 18 (i.e., acquires the ECG signal generated by combination of the electric signals measured by the ECG electrodes 18 acting as ECG derivations). More in particular, the control unit 16 acquires a distribution of measured ECG signals, having an average correspondent to the measured ECG signal (actually measured by the ECG electrodes 18) and a variance related to the measurement noise.
At a step S05 of the activation map generation method 30, the generator module 32 of the control unit 16 generates, starting from white noise, a distribution of sets of identification parameters. Each set of identification parameters comprises a plurality of identification parameters and is correlated to a respective ECG signal (in the following named random ECG signal and better discussed in the following) and to a respective activation map (in the following named random activation map and better discussed in the following) through per se known mathematical relationships (in details, through a so-called forward problem better discussed in the following). In other words, a respective ECG signal and a respective activation map can be associated to each set of identification parameters through the forward problem.
According to an embodiment, the identification parameters comprise an activation source location F, an activation time to and a conductivity parameter D. The activation source location F is a vector in universal ventricular coordinates that is indicative of the location of the activation source in the heart 12 of a considered action potential signal (i.e., is indicative of the starting region of the heart 12); the activation time to is a scalar coefficient in milliseconds that is indicative of the activation time at which the considered action potential signal is received by the activation source location in the heart 12; and the conductivity parameter D is a symmetric positive definite 3×3 tensor which is dependent on the myocardial fiber direction field and the myocardial tissue conductivity. As a non-limiting example, the activation source location F ranges from (0.2, −2) to (0.8, −1) and is for example equal to about (0.3, −1.5) the activation time to ranges from 0 ms to 20 ms and is for example equal to about 0.5 ms and the conductivity parameter D ranges from 0.05 to 1.5 and is for example equal to about 0.8 (unitless values, corresponding to respective physiological values of conduction velocity ranging from 1 cm/s to 150 cm/s and being for example equal to about 60 cm/s).
The distribution of sets of identification parameters is generated randomly starting from white noise, either according to per se known techniques or by means of machine learning techniques. In particular, according to an embodiment, the generator module 32 implements a machine learning algorithm trained to associate identification parameters to white noise. In details, the generator module 32 implements a generator (or generative network) of a generative adversarial network (GAN). GANs are well known supervised neural networks comprising a generator and a discriminator, as better discussed in the following. In particular, the generator module 32 implements a conditional GAN (cGAN; an example of which can be found in the document Mehdi Mirza, Simon Osindero, “Conditional Generative Adversarial Nets”, 6 Nov. 2014, arXiv:1411.1784 [cs.LG]); nevertheless, other GANs can analogously be used (examples can be found at link https://github.com/hindupuravinash/the-gan-zoo).
At a step S07 of the activation map generation method 30, consecutive to step S05, the forward problem module 34 of the control unit 16 acquires the distribution of sets of identification parameters and, based on them, generates a corresponding distribution of random ECG signals. In details, a respective random ECG signal is generated based on each set of identification parameters. Each random ECG signal is a signal, analogous to an ECG signal, which is not actually measured from the patient but is fictitiously generated as a function of randomly determined identification parameters.
Optionally, during generation of the random ECG signal, also a random activation map can be generated, depending on the used model or approach. The random activation map is an activation map, analogous to the activation map 40, which is not actually acquired from the patient through measurements or analysis but is fictitiously generated as a function of randomly determined identification parameters.
Optionally, the forward problem module 34 further receives as inputs additional data indicative of the patient's health and/or of patient's body structural features (e.g., the patient's torso mesh, the AHA sectorization markers, universal ventricular coordinates, health data of the patient such as age, sex, pathologies, etc.), for example acquired through the sensing module 14 or loaded in the control unit 16 either automatically or by medical staff. These additional data can be used by the forward problem module 34, in a per se known way, to improve the accuracy and patient specificity of the distribution of random ECG signals.
According to an embodiment, each random ECG signal is determined, based on the respective set of identification parameters, by solving a bidomain model of a per se known type (further details can be found for example in the document Muriel Boulakia, Serge Cazeau, Miguel Angel Fernandez, Jean-Frederic Gerbeau, Nejib Zemzemi. Mathematical Modeling of Electrocardiograms: A Numerical Study. Annals of Biomedical Engineering, Springer Verlag, 2010, 38 (3), pp. 1071-1097. ff10.1007/s10439-009-9873-Off. ffinria-00400490v2f). In details, the bidomain equations of the bidomain model allow to obtain both an ECG signal (i.e., the random ECG signal) and a corresponding activation map (i.e., the random activation map) for each set of identification parameters set as input.
According to a different embodiment, each random ECG signal is determined, based on the respective set of identification parameters, by solving both a monodomain model and a pseudo-bidomain model of per se known types (further details about the monodomain model can be found for example in the document Keener, J. P. An eikonal-curvature equation for action potential propagation in myocardium. J. Math. Biol. 29, 629-651 (1991). https://doi.org/10.1007/BF00163916, while further details about the pseudo-bidomain model can be found for example in the document Muriel Boulakia, Serge Cazeau, Miguel Angel Fernandez, Jean-Frederic Gerbeau, Nejib Zemzemi. Mathematical Modeling of Electrocardiograms: A Numerical Study. Annals of Biomedical Engineering, Springer Verlag, 2010, 38 (3), pp. 1071-1097. ff10.1007/s10439-009-9873-Off. ffinria-00400490v2f. In details, the monodomain model allows to obtain a respective activation map (i.e., the random activation map) from each set of identification parameters and, subsequently, the pseudo-bidomain model allows to obtain a respective ECG signal (i.e., the random ECG signal) from this random activation map.
According to a further embodiment, each random ECG signal is determined, based on the respective set of identification parameters, by solving a respective forward problem through solution of an Eikonal model of a per se known type (further details about the Eikonal model can be found for example in the document Pezzuto S, Kal'ayský P, Potse M, Prinzen F W, Auricchio A and Krause R (2017) Evaluation of a Rapid Anisotropic Model for ECG Simulation. Front. Physiol. 8:265. doi: 10.3389/fphys.2017.00265 and of a pseudo-bidomain model (e.g., the same as previously discussed). In details, the Eikonal model allows to obtain a respective activation map (i.e., the random activation map) from each set of identification parameters and, subsequently, the pseudo-bidomain model allows to obtain a respective ECG signal (i.e., the random ECG signal) from this random activation map.
In details, the Eikonal model relies on an Eikonal equation to find the wavefront motion of an electrical wave during heart excitation (i.e., to find the propagation of the action potential signal and, thus, the activation map). In the Eikonal model, arrival times of an action potential wave front ta in a myocardial area Ω of the heart 12 define said activation map and are dependent both on a spatially inhomogeneous orthotropic velocity function indicative of the electrical conductivity in the myocardial area Ω (i.e., are dependent on the conductivity parameter D=D(x)) and on the activation source location F at the activation time to. More in details, the Eikonal equation has the form:
√{square root over (∇taD∇ta)}=1 in Ω
t
a
=t
0 in Γ
where ta is a positive function describing the wavefront arrival time at each location of the myocardial area Ω (i.e., is the random activation map).
Moreover, the pseudo-bidomain model relies on a lead-field approach of per se known type to calculate each random ECG signal according to the following mathematical relationship:
V(t)=∫Ω∇Z(x)·Gi∇Vm(x,t)dx
where V(t) is the random ECG signal, Gi is a predefined parameter indicative of the electrical conductivity of anatomical parts of the patient (other than the heart 12 and, for example, of the lungs, rib cage etc., where each anatomical part is indicated with a respective value of the index i, e.g. i=1,2,3 . . . ), Vm(x,t) is a map of electric potentials in the myocardial area Ω in time and space (i.e., Vm(x,t) is dependent on the arrival times of an action potential wave front ta in a myocardial area Ω) and Z(x) is a lead field that is specific for each ECG electrode 18. More in details, the lead field Z(x) is the potential field created by a unit current applied to the ECG electrode 18 at location xj of the skin 20 and is obtained through the following mathematical relationship:
∇·(Gi∇Z(x))=Σcjδ(x−xj)
where cj are weight coefficients indicative of the reciprocal electrical contributions between the ECG electrodes 18 and δ is Dirac's delta function. This equation can be solved on the full torso mesh of the patient obtained from the sensing module 14. For example, to obtain cardiac potentials from the myocardial area Ω, fixed potentials from a TNNP'06 cardiomyocyte model can be used.
According to a further embodiment, each random ECG signal is obtained, starting from the respective set of identification parameters, by means of a surrogate model based on machine learning techniques. In particular, the surrogate model is a mathematical method to replace complex mathematical calculations, by approximating a simpler model. More in details, the surrogate model is a machine learning algorithm that solves a regression problem to find random ECG signals corresponding to the input identification parameters. The surrogate model is a fully connected neural network trained on data that are generated when solving the forward problem by means of the bidomain model, or of the monodomain model and the pseudo-bidomain model, or of the Eikonal model and the pseudo-bidomain model. The loss function for the surrogate model can be the mean absolute error. Nonetheless, the fully connected neural network operating as surrogate model can be replaced with other machine learning techniques that solve the same regression problem (e.g., Gaussian process regression, Random Forest regression, polynomial regression etc.). Optionally, the surrogate model further receives as inputs the additional data indicative of the patient's health and/or of the patient's body structural features (e.g., the patient's torso mesh, the AHA sectorization markers, universal ventricular coordinates, health data of the patient such as age, sex, pathologies, etc.), as additional input features on which the surrogate model in trained and that the latter can use to further improve the regression accuracy.
At a step S09 of the activation map generation method 30, consecutive to step S07, the discriminator module 36 of the control unit 16 compares the distribution of measured ECG signals and the distribution of random ECG signals to verify if there is correspondence between them (e.g., if they coincide or if the discriminator does not distinguish between random ECG signals and measured ECG signals).
If there is correspondence, the activation map generation method 30 proceeds to a step S11, better discussed in the following.
On the other hand, if there is not correspondence, the activation map generation method 30 goes back to step S05 to repeat the steps S05-S09, thus verifying the correspondence between the measured ECG signals and further random ECG signals.
According to an embodiment, at the step S09 the discriminator module 36 compares the distribution of measured ECG signals and the distribution of random ECG signals according to per se known statistical techniques. For example, the discriminator module 36 calculates a cross-entropy between the distribution of measured ECG signals and of the distribution of random ECG signals and determines the correspondence between the distributions.
According to a different embodiment, at the step S09 the discriminator module 36 compares the distribution of measured ECG signals and the distribution of random ECG signals by means of machine learning techniques. In particular, the discriminator module 36 implements a machine learning algorithm trained to identify correspondence (i.e., a match) between the distribution of measured ECG signals and the distribution of random ECG signals. In details, the discriminator module 36 implements a discriminator (or discriminative network) of the GAN. For example, the discriminator receives as inputs the distribution of measured ECG signals and the distribution of random ECG signals and generates as output a probability value indicative of the probability that the two distributions correspond (e.g., coincide).
If there is correspondence between the distribution of measured ECG signals and the distribution of random ECG signals, the activation map 40 is generated by the control unit 16 at step S11.
According to an embodiment in which the forward problem module 34 generates at step S07 the distribution of random activation maps according to the distribution of sets of identification parameters provided by the generator module 32, the control unit 16 determines at step S11 the activation map 40 based on this distribution of random activation maps (i.e., based on the distribution of random activation maps related to the distribution of random ECG signals corresponding to the distribution of measured ECG signals). In details, the activation map 40 is calculated as a function of an average of these random activation maps (e.g., is equal to or proportional to said average), with a standard deviation that is the standard deviation of the distribution of random activation maps.
According to a different embodiment in which no distribution of random activation maps is generated at step S07 (e.g., in the case of the surrogate model), the control unit 16 generates at step S11 the activation map 40 based on the distribution of sets of identification parameters associated to the distribution of random ECG signals corresponding to the distribution of measured ECG signals. In details, the control unit 16 implements either the bidomain model, or the monodomain model and the pseudo-bidomain model, or the Eikonal model and the pseudo-bidomain model, using this distribution of sets of identification parameters to calculate a respective distribution of random activation maps (as previously described and thus not discussed again here); then, the activation map 40 is calculated as a function of an average of these random activation maps (e.g., is equal to or proportional to said average), with a standard deviation that is the standard deviation of the distribution of random activation maps.
Concerning the surrogate model and the GAN (of per se known type), formed by the generator implemented by the generator module 32 and by the discriminator implemented by the discriminator module 36, details about their trainings are now provided.
In particular, the surrogate model is firstly trained according to supervised techniques performed on a surrogate training dataset comprising a multiplicity of training sets of identification parameters (e.g., 10000 sets of parameters). For example, the training sets of identification parameters are generated by varying the activation source location F, the activation time to and the conductivity parameter D in their ranges of variation through a Quasi-Monte Carlo Halton sampling of a per se known type, to create an evenly filled parametric space. Then, a respective multiplicity of forward problems are solved in order to determine a respective training random ECG signal for each training set of identification parameters (e.g., through the bidomain model, or the monodomain model and the pseudo-bidomain model, or the Eikonal model and the pseudo-bidomain model). The surrogate model is then trained according to per se known techniques based on the training sets of identification parameters and the training random ECG signals, so as to associate to each set of identification parameters the respective training random ECG signal. For example, the surrogate model is trained through the mean absolute error loss function to achieve a regression accuracy higher than about 95%.
Following to the training of the surrogate model (if present), the GAN is trained according to supervised techniques (e.g., for each patient). In details, the generator and the discriminator are trained simultaneously based on a GAN training dataset comprising a multiplicity of training white noise signals and training sets of identification parameters (e.g. 10000 sets) and a distribution of measured ECG signals (e.g., also comprising mean and variance of measured ECG signals). For example, the training white noise signals are generated randomly and are associated to respective training sets of identification parameters, while the distribution of measured ECG signals are acquired from measurements on the patient. In Nash equilibrium between the generator and the discriminator, the generator finds a patient-specific set of identification parameters of an electrophysiological model that allows to generate a respective activation map of this specific patient. In other words, the output of the discriminator (i.e., the correspondence or not between the random ECG signals and the measured ECG signals) is used as a feedback for the quality estimation of the training the GAN. More in details, white noise is associated with a respective set of identification parameters, which is associated with a respective random ECG signal. Thus, if the discriminator decides that the random ECG signals correspond with the measured ECG signals with some probability, it passes this probability to the generator. The generator updates its weights on the network to generate more realistic parameters, which can lead to more realistic random ECG signals. The discriminator, in turn, learns at each iteration to determine the probability that the incoming distribution matches the measured one, using the cross-entropy loss function.
For example, the generator is trained through the following loss function:
L
G
=E
Z˜P
log[D(G(z))]−EZ˜P
where G is the generator, z is the input white noise, LG is the loss of the generator, Kmc is a collapse mode coefficient better discussed in the following and generally equal to zero, Ez is the expected value over all the random inputs provided to the generator, Pz is the distribution of the white noise, G(z) is the generator output when the white noise z is provided in input, D(G(z)) is the discriminator's estimate probability that the generated ECG signal corresponds to the measured ECG signal. Moreover, the discriminator is trained through the following loss function:
L
D
=E
Z˜P
log[D(x)]+EZ˜P
where D is the discriminator, LD is the loss of the discriminator, x is a sample of the measured ECG signals, Pd is the distribution of measured ECG signals and D(x) is the discriminator's estimate probability that the generated ECG signal corresponds to the measured ECG signal.
For example, an Adam optimizer is used with step size of 0.0001 for G and with step size of 0.00004 for D; the β1 and β2 parameters of the Adam optimizer can be set to default values of about 0.9 and about 0.999 respectively.
Furthermore, training parameters of these neural network loss functions can be different, as described for example in the following prior art document: Sebastian Nowozin, Botond Cseke, Ryota Tomioka, “f-GAN: Training Generative Neural Samplers using Variational Divergence Minimization”, 30th Conference on Neural Information Processing Systems (NIPS 2016), Barcelona, Spain.
Moreover, further details about methods and algorithms for calculating or pre-processing input data (e.g. muscle fibers, segmented heart, data about lungs, torso, other organs, forward models, cellular models) are described in these prior art documents: Lopez-Perez, A., Sebastian, R. & Ferrero, J. M. Three-dimensional cardiac computational modelling: methods, features and applications. BioMed Eng OnLine 14, 35 (2015). https://doi.org/10.1186/s12938-015-0033-5; Muriel Boulakia, Serge Cazeau, Miguel Angel Fernández, Jean-Frédéric Gerbeau, Nejib Zemzemi. Mathematical Modeling of Electrocardiograms: A Numerical Study. Annals of Biomedical Engineering, Springer Verlag, 2010, 38 (3), pp. 1071-1097. ff10.1007/s10439-009-9873-Off. ffinria-00400490v2; Pathmanathan P and Gray R A (2018) Validation and Trustworthiness of Multiscale Models of Cardiac Electrophysiology. Front. Physiol. 9:106. doi: 10.3389/fphys.2018.00106.
Moreover, optionally, the collapse mode module 38 can be present in the control unit 16 during training of the GAN. The collapse mode module 38 receives as inputs both the white noise input to the generator and the corresponding sets of identification parameters generated by the generator based on said white noise, and it implements machine learning techniques to prevent collapse mode of the generator during training. As known, collapse mode is a condition where GAN generators return only a small subset of all possible solutions (i.e., always return a same sample subgroup, smaller than the whole possible sample group). In details, the collapse mode module 38 implements a reconstruction neural network of a per se known type for avoiding the generator collapse mode. In particular, the reconstruction neural network acquires the sets of identification parameters generated by the generator, determines, based on the sets of identification parameters, if the generator of the GAN is in a condition indicative of mode collapse risk and, if the generator of the GAN is in said condition indicative of mode collapse risk, a setting of the generator of the GAN is modified to avoid mode collapse. In further details, the reconstruction neural network is trained to reconstruct white noise starting from the sets of identification parameters generated by the generator and to compare the reconstructed white noise with the original white noise set as input to the generator to generate these sets of identification parameters: if they correspond (e.g., coincide) there is no collapse mode risk, while if they do not correspond (e.g., they do not coincide) collapse mode risk is determined. In case collapse mode risk is determined, an additional term (the collapse mode coefficient Kmc, i.e. said modifiable setting of the generator of the GAN) is used to prevent collapse mode of the generator. In details, the collapse mode coefficient Kmc is null when there is no collapse mode risk (i.e., the more the reconstructed white noise and the original white noise correspond between each other) and it is increased as the collapse mode risk is determined (i.e., said condition indicative of mode collapse risk is determined) and increases (in details, it increases the more as more the reconstructed white noise and the original white noise differ between each other). For example, the collapse mode coefficient Kmc can vary between 0 and about 100. In fact, by having the collapse mode coefficient Kmc dependent on the collapse mode risk, the occurrence of collapse mode in the generator is avoided due to the use of this loss function dependent on the collapse mode coefficient Kmc. For example, the reconstruction neural network uses a squared loss that is indicative of the collapse mode risk and is calculated according to the following mathematical relationship:
L
R
=E
Z˜P
∥z−R(G(Z))˜2
where R is the reconstruction neural network, LR is the squared loss of the reconstruction neural network and Pg is the distribution of the generated identification parameters and R(G(z)) is a reconstructed noise from the generated identification parameters. Usually Kmc is equal to LR, but in some cases a multiplier can be used to reduce the probability of collapse.
Other optional improvements to avoid collapse mode can also be implemented and are for example described in prior art document Akash Srivastava, Lazar Valkov, Chris Russell, Michael U. Gutmann, Charles Sutton, “VEEGAN: Reducing Collapse mode in GANs using Implicit Variational Learning”, Published as a conference paper at NIPS, 2017, arXiv:1705.07761 and in prior art document Luke Metz, Ben Poole, David Pfau, Jascha Sohl-Dickstein, “Unrolled Generative Adversarial Networks”, arXiv:1611.02163.
From what has been described and illustrated previously, the advantages of the present invention are evident.
The activation map generation method 30 allows to obtain the activation map 40 of the heart 12 of a patient (i.e., the time propagation of action potentials in the heart 12) starting from measured ECG signals and without the need to solve reverse problems that are highly time and power consuming.
On the other hand, the activation map generation method 30 allows to compare the measured ECG signals with random ECG signals fictitiously generated in a random way (through the solution of forward problems, which are less time and power consuming than the reverse problems) and, when correspondence is obtained, retrieve the activation maps associated to these random ECG signals to determine the activation map 40.
In other words, no reverse problems must be solved to determine the activation map 40 and no great amount of ECG electrodes are necessary, contrary to the known solutions.
Moreover, the GAN implemented in the activation map generation method 30 is robust against mode collapse due to the presence of the reconstruction neural network in the mode collapse module 38.
Therefore, the activation map generation method 30 is easy to be implemented, shows high classification accuracy and requires low computational costs and time.
Finally, it is clear that modifications and variations may be made to what has been described and illustrated herein, without thereby departing from the scope of the present invention, as defined in the annexed claims. For example, the different embodiments described can be combined with each other to provide further solutions.
Moreover, the sensing module 14 can be absent from the device 10. In this case, the control unit 16 receives the physiological data of the patient from external apparatuses or from configuration executed by medical staff (e.g., from external servers or through manual configuration by a physician) and processes them to generate the activation map 40.
The activation map generation method 30 has been described with reference to a distribution of sets of identification parameters, a distribution of random ECG signals, a distribution of measured ECG signals and a distribution of random activation maps. Nevertheless, the activation map generation method 30 can analogously be simplified to use (at each iteration of steps S05-S09) only one set of identification parameters, one random ECG signal, one measured ECG signal and one random activation map. In this case, the activation map 40 coincides with the random activation map corresponding to the set of identification parameters leading to the random ECG signal in correspondence with the measured ECG signal.
Moreover, the activation map generation method 30 has been described with reference to random ECG signals and measured ECG signals (e.g., input to the discriminator module 36). Nonetheless, the random ECG signals and measured ECG signals can be analogously replaced as inputs to the discriminator module 36 with more general random ECG parameters and, respectively, measured ECG parameters that are indicative of the random ECG signals and, respectively, of the measured ECG signals. For example, the random ECG parameters and the measured ECG parameters can be statistical parameters of the random ECG signals and, respectively, of the measured ECG signals, such as variance and/or peak-to-peak and/or QRS duration and/or parameters describing ECG data, further detail can be found in Kuznetsov V V, Moskalenko V A, Gribanov D V and Zolotykh N Y (2021) Interpretable Feature Generation in ECG Using a Variational Autoencoder. Front. Genet. 12:638191. doi: 10.3389/fgene.2021.638191). For example, the random ECG parameters are calculated based on the random ECG signals and the measured ECG parameters are calculated based on the measured ECG signals and then the random ECG parameters and the measured ECG parameters are compared between each other by the discriminator module 36; otherwise, the forward problem module can directly output the random ECG parameters and the measured ECG parameters can be directly acquired by the control unit 16 instead of the measured ECG signals, so that the discriminator module 36 can compare the random ECG parameters and the measured ECG parameters. More in general, the activation map generation method 30 receives as inputs measured ECG data (either the measured ECG parameters, or the measured ECG signal or the distribution of measured ECG signals) that are compared by the discriminator module 36 with random ECG data (either the random ECG parameters, or the random ECG signal or the distribution of random ECG signals), received from the forward problem module 34, to verify correspondence.
Moreover, according to a different embodiment, the identification parameters can comprise the conductivity parameter D, a set of activation source locations F and a respective set of activation times to. Each activation source location F and respective activation time to are relative to a respective action potential wavefront provided to a respective starting region of the heart 12.
Number | Date | Country | Kind |
---|---|---|---|
102022000004628 | Mar 2022 | IT | national |