ELECTROCARDIOGRAM PROCESSING SYSTEM FOR DETECTING AND/OR PREDICTING CARDIAC EVENTS
20220095982 · 2022-03-31
Assignee
Inventors
- Marie-Albane DE SAINT VICTOR (Paris, FR)
- Helene EVAIN (Maisons-Laffitte, FR)
- Aurelie DELEFORGE (Chaponost, FR)
- Armand FOUCAULT (Paris, FR)
- Wadii HAJJI (Vitry sur Seine, FR)
- Jeremy CALDAS (Asnieres-sur-seine, FR)
- Benjamin Barre (Suresnes, FR)
- Gautier ZIMMERMANN (Paris, FR)
- Yann FLEUREAU (Paris, FR)
- Baptiste Rios CAMPO (Paris, FR)
- Chiara Scabellone (Paris, FR)
- Anastasiya BODROVA (Orsay, FR)
- Johanna LAVERSIN (Montrouge, FR)
Cpc classification
A61B5/6801
HUMAN NECESSITIES
G16H50/20
PHYSICS
A61B5/318
HUMAN NECESSITIES
A61B5/02416
HUMAN NECESSITIES
A61B5/0816
HUMAN NECESSITIES
G16H50/30
PHYSICS
A61B5/349
HUMAN NECESSITIES
A61B5/6846
HUMAN NECESSITIES
International classification
A61B5/00
HUMAN NECESSITIES
A61B5/08
HUMAN NECESSITIES
A61B5/145
HUMAN NECESSITIES
Abstract
Systems and methods are provided for analyzing electrocardiogram (ECG) data of a patient using a substantial amount of ECG data. The systems receive ECG data from a sensing device positioned on a patient such as one or more ECG leads/electrodes that may be integrated in a smart device. The system may include an application that communicates with an ECG platform running on a server(s) that processes and analyzes the ECG data, e.g., using neural networks, to detect and/or predict various abnormalities, conditions and/or descriptors. The system may also determine a confidence score corresponding to the abnormalities, conditions and/or descriptors. The processed ECG data is used to generate a graphic user interface that is communicated from the server(s) to a computer for display in a user-friendly and interactive manner with enhanced accuracy.
Claims
1. A computerized-method for analyzing electrocardiogram (ECG) data of a patient, the computerized method comprising: obtaining, from a first device, a set of patient ECG data corresponding to a patient, the set of patient ECG data generated over a first plurality of time points as sampled by a sensing device; obtaining, from a second device, a set of patient sensor data corresponding to the patient, the set of patient sensor data generated over a second plurality of time points, the second plurality of time points corresponding to the first plurality of time points; processing at least a portion of the set of patient ECG data and at least a portion of the set of sensor data using an algorithm to determine a presence of one or more abnormalities, conditions, or descriptors corresponding to a cardiac event associated with the set of patient ECG data and the set of patient sensor data, the algorithm trained using a plurality of sets of ECG data different from the set of ECG data and a plurality of sets of sensor data different from the set of patient sensor data; generating information, based on the processing, to indicate the presence of the one or more abnormalities, conditions, or descriptors corresponding to a cardiac event associated with the set of patient ECG data and set of patient sensor data; and sending the information corresponding to the presence of the one or more abnormalities, conditions, or descriptors determined for the set of patient ECG data and the set of patient sensor data for display.
2. The computerized-method of claim 1, wherein the second device comprises a photoplethysmogram (PPG) sensor.
3. The computerized-method of claim 1, wherein the patient sensor data comprises one or more of heart rate, SpO2, respiratory rate data.
4. The computerized-method of claim 1, wherein the first device comprises an implantable loop recorder (ILR).
5. The computerized-method of claim 1, further comprising generating a database associating the ECG data with the first device and the patient sensor data with the second device.
6. The computerized-method of claim 1, further comprising obtaining, from the second device, a set of second sensor data corresponding to the patient and different than the set of patient sensor data.
7. The computerized-method of claim 6, wherein the set of second sensor data is generated over a third plurality of time points corresponding to the first plurality of time points.
8. The computerized-method of claim 6, further comprising processing at least a portion of the set of second sensor data using the algorithm, wherein the algorithm is further trained using a plurality of sets of second sensor data different from the set of second sensor data.
9. A computerized-method for analyzing electrocardiogram (ECG) data of a patient, the computerized-method comprising: determining patient ECG data indicative of at least one cardiac event; processing at least a portion of the patient ECG data using an algorithm to determine a presence of one or more descriptors corresponding to the at least one cardiac event associated with the patient ECG data, the algorithm trained using a plurality of sets of ECG data different from the patient ECG data; determining a cardiac event and a descriptor corresponding to the cardiac event; generating an event interface indicating the descriptor and comprising a graphical representation of the cardiac event; and receiving input corresponding to the descriptor.
10. The computerized-method of claim 9, wherein the input reclassifies the cardiac event as a second descriptor.
11. The computerized-method of claim 10, further comprising generating an event interface indicating the second descriptor and comprising a graphical representation of the cardiac event.
12. The computerized-method of claim 10, wherein the second descriptor is used to train the algorithm.
13. The computerized-method of claim 9, wherein the event interface further comprises one or more of heart rate information or event duration information.
14. A computerized-method for analyzing electrocardiogram (ECG) data of a patient, the computerized-method comprising: determining ECG history data, the ECG history data corresponding at least one arrhythmia event and sampled at a variety of time points; processing ECG history data using an algorithm trained to determine a time point corresponding to a risk of an arrhythmia; determining a first time period associated with the risk of an arrhythmia; and sending a request for ECG data corresponding to the time period.
15. The computerized-method of claim 14, wherein the request for ECG data is sent to a user's mobile device.
16. The computerized-method of claim 14, wherein the request for ECG data is sent to a sensor device.
17. The computerized-method of claim 14, wherein the risk of an arrhythmia is a risk of atrial fibrillation.
18. The computerized-method of claim 14, wherein the algorithm is trained to determine a premature atrial contraction (PAC) burden.
19. A computerized-method for analyzing electrocardiogram (ECG) data of a patient, the computerized-method comprising: determining the ECG data indicative of at least one ECG event; processing ECG history data using an algorithm trained to determine at least one of a condition, descriptor or abnormality; determining a plurality of results corresponding to the at least one the condition, descriptor or abnormality; determining an indication associated with the patient; determining a prioritized order of the plurality of results based on the indication; and causing the prioritized order of the plurality of results to be presented on a computing device.
20. The computerized-method of claim 19, further comprising: receiving a request to reprioritize the order of the plurality of results; determining a second prioritized order of the plurality of results based on the request to reprioritize.
21. The computerized-method of claim 19, wherein the plurality of results comprises a first condition, and further comprising: determining an association between the indication and a first condition; and prioritizing the first condition based on the association.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
[0049]
[0050]
[0051]
[0052]
[0053]
[0054]
[0055]
[0056]
[0057]
[0058]
[0059]
[0060]
[0061]
[0062]
[0063]
[0064]
[0065]
[0066]
[0067]
[0068]
[0069]
[0070]
[0071]
[0072]
[0073]
[0074]
[0075]
[0076]
[0077]
[0078]
[0079]
[0080]
[0081]
[0082]
[0083]
[0084] The foregoing and other features of the present invention will become apparent from the following description and appended claims, taken in conjunction with the accompanying drawings. Understanding that these drawings depict only several embodiments in accordance with the disclosure and are, therefore, not to be considered limiting of its scope, the disclosure will be described with additional specificity and detail through use of the accompanying drawings.
DETAILED DESCRIPTION OF THE INVENTION
[0085] The present invention is directed to an electrocardiogram (ECG) processing system having medical grade artificial intelligence involving an ECG application run on a system device and an ECG platform run on a server(s). The ECG application and ECG platform implement the ECG processing system by processing and analyzing the ECG data using machine learning algorithms to detect and/or predict cardiac events such as such as cardiac arrhythmias and/or abnormalities including atrial fibrillation (AFib). The system may achieve delineation of the cardiac signal and classification of various abnormalities, conditions, and descriptors. The server(s) may be located in a different location than the system device(s) and the servers need not be in the same physical location as one another (e.g., the server(s) may be a remote server(s)). Alternatively, the server(s) and the system device(s) may be located in the same general area (e.g., on a local area network (LAN)). The ECG platform may be a cloud-based ECG platform that may implement the ECG processing system by processing and analyzing the ECG data in the cloud.
[0086] To implement the ECG processing system, ECG application running on the system device may receive ECG data (i.e., cardiac signal) from a sensing device and may transmit the ECG data to a ECG platform running on the server. The ECG platform may execute a first and second neural network and may apply the ECG data to the first and second neural network. The first neural network may be a delineation neural network having machine learning functionality. The second neural network may be a classification neural network having machine learning functionality. The output of the first and/or second neural networks may be processed by the ECG platform to achieve delineation and classification of the ECG data. The ECG data and/or data generated by the ECG platform may be communicated from the ECG platform to the ECG application. The ECG application may cause the ECG data and/or data generated by the ECG platform to be displayed in an interactive manner. The ECG platform may generate reports including ECG data and/or data generated by the ECG platform, and may communicate the reports to the ECG application.
[0087] Referring now to
[0088] ECG sensing device 13 is designed to sense the electrical activity of the heart for generating ECG data. For example, sensing device 13 may be one or more electrodes that may be disposed on one or more leads. ECG sensing device 13 may be an ECG-dedicated sensing device such as a conventional 12-lead arrangement or may be a multi-purposes device with sensing hardware for sensing electrical activity of the heart for ECG generation such as the Apple Watch available from Apple, Inc., of Cupertino, Calif. Sensing device 13 may be placed on the surface of the chest of a patient and/or limbs of a patient. Sensing device 13 may be in electrical communication with system device 14 running the ECG application 29 such that the electrical signal sensed by sensing device 13 may be received by the ECG application 29. ECG application 29 may include instructions that cause sensing device 13 to sense or otherwise obtain ECG data.
[0089] System device 14 is preferably one or more computing devices (e.g., laptop, desktop, tablet, smartphone, smartwatch, etc.) having the components described below with reference to
[0090] Server 15 is preferably one or more servers having the components described below with reference to
[0091] Server 15 may optionally communicate with drive 16 which may be one or more drives having memory dedicated to storing digital information unique to a certain patient, professional, facility and/or device. For example, drive 16 may include, but is not limited to, volatile (e.g. random-access memory (RAM)), non-volatile (e.g. read-only memory (ROM)), flash memory, or any combination thereof. Drive 16 may be incorporated into server 15 or may be separate and distinct from server 15 and may communicate with server 15 over any well-known wireless or wired connection.
[0092] Aspects of ECG processing system 10 and/or any other ECG processing systems described throughout this application may be the same or similar to the ECG processing system described in WO2020161605A1, which is the published application of PCT/IB2020/050850, filed on Feb. 3, 2020, (corresponding to U.S. Ser. No. 17/390,714), which claims priority to U.S. Pat. No. 10,959,660 to Li, the entire contents of each of which are incorporated herein by reference. Additional technology that may be utilized is described in commonly-assigned U.S. Ser. No. 17/397,782, the entire contents of which are incorporated herein by reference.
[0093] Referring now to
[0094] Processing unit 31 may be one or more processors configured to run collaboration operating system 28 and ECG application 29 and perform the tasks and operations of system device 14 set forth herein. Memory 22 may include, but is not limited to, volatile (e.g. random-access memory (RAM)), non-volatile (e.g. read-only memory (ROM)), flash memory, or any combination thereof. Communication unit 23 may receive and/or transmit information to and from other components in ECG processing system 10 including, but not limited to, sensing device 13 and server 15. Communication unit 23 may be any well-known communication infrastructure facilitating communication over any well-known wired or wireless connection, including over any well-known standard such as any IEEE 802 standard. Power source 24 may be a battery or may connect system device 14 to a wall outlet or any other external source of power. Storage 27 may include, but is not limited to, removable and/or non-removable storage such as, for example, magnetic disks, optical disks, or tape.
[0095] Input device 25 may be one or more devices coupled to or incorporated into system device 14 for inputting data to system device 14. Input device 25 may further include a keyboard, a mouse, a pen, a sound input device (e.g., microphone), a touch input device (e.g., touch pad or touch screen), a location sensor, and/or a camera, for example. Output device 26 may be any device coupled to or incorporated into system device 14 for outputting or otherwise displaying data and includes at least a display 17. Output device 26, may further include speakers and/or a printer, for example.
[0096] ECG application 29 may be stored in storage 27 and executed on processing unit 21. ECG application 29 may be a software application and/or software modules having one or more sets of instructions suitable for performing the operations of system device 14 set forth herein, including facilitating the exchange of information with sensing device 13 and server 15. For example, ECG application 29 may cause system device 14 to receive ECG data from sensing device 13, to record ECG data from sensing device 13, to communicate ECG data to server 15, to instruct server 15 to process and analyze ECG data, to receive processed and/or analyzed ECG data from server 15, to communicate user input regarding report generation to server, and to generate a graphic user interface suitable for displaying raw, analyzed and/or processed ECG data and data related thereto.
[0097] Operating system 28 may be stored in storage 27 and executed on processing unit 21. Operating system 28 may be suitable for controlling the general operation of system device 14 and may work in concert with ECG application 29 to achieve the functionality of system device 14 described herein. System device 14 may also optionally run a graphics library, other operating systems, and/or any other application programs. It of course is understood that system device 14 may include additional or fewer components than those illustrated in
[0098] Referring now to
[0099] Memory 32 may include, but is not limited to, volatile (e.g. random-access memory (RAM)), non-volatile (e.g. read-only memory (ROM)), flash memory, or any combination thereof. Storage 35 may include, but is not limited to, removable and/or non-removable storage such as, for example, magnetic disks, optical disks, or tape. Communication unit 34 may receive and/or transmit information to and from other components of ECG processing system 10 including, but not limited to, system device 14 and/or drive 16. Communication unit 34 may be any well-known communication infrastructure facilitating communication over any well-known wired or wireless connection. Power source 33 may be a battery or may connect server 15 to a wall outlet or other external source of power.
[0100] Operating system 36 and ECG platform 37 may be stored in storage 35 and executed on processing unit 31. Operating system 36 may be suitable for controlling general operation of server 15. ECG platform 37 may be a software application and/or software modules having one or more sets of instructions. ECG platform 37 may facilitate and oversee the processing and analysis of ECG data received from system device 14, report generation, and otherwise may be suitable for performing the operations of server 15 set forth herein.
[0101] ECG platform 37 may include several sub-modules and/or applications including, but not limited to, pre-processor 38, delineator 39, classifier 41, clusterer 42 which may include embedder 48 and grouper 49, post-processor 43, report generator 44, recomputer 40 and/or sequence analyzed 50. Each sub-module and/or application may be a separate software application and/or module having one or more sets of instructions. Pre-processor 38 may pre-process raw ECG data, delineator 39 may execute a first neural network to achieve delineation, classifier 41 may execute a second neural network to achieve classification, clusterer 42 may identify clusters in data processed by the first neural network, post-processor 43 may post-process data processed by the second neural network, embedder 48 may execute one or more algorithms and/or a third neural network to achieve embedding, grouper 49 may execute one or more algorithms and/or a fourth neural network to generate cluster groups, report generator 44 may generate reports based on raw ECG data and ECG data processed by ECG platform 37, and recomputer 40 may recompute and/or adjust embedder 48 and/or grouper 49 based on user input data. For example, recomputer 40 may recalculate episodes based on corrected wave information. Sequence analyzer 50 may be one or more algorithms and/or a third neural network which may be a recurrent neural network. Sequence analyzer 50 may analyze feature maps to determine one or more sequence labels and thereby achieve sequence identification as explained below. ECG platform 37 may also perform various other functions including, but not limited to, receiving requests from system device 14 to process and/or analyze ECG data, communicating processed and/or analyzed ECG data to system device 14, receiving a request to generate a report, requesting and/or receiving user interaction and/or instructions from system device 14, receiving user input data and/or instruction information from system device 14 regarding report generation, and/or communicating a report to system device 14.
[0102] Server 15 may also optionally run a graphics library, other operating systems, and/or any other application programs. It of course is understood that server 15 may include additional or fewer components than those illustrated in
[0103]
[0104] As is shown in
[0105] Upon receiving raw ECG data 52, ECG application 29 may cause system device 14 to record raw ECG data 52 and may optionally save some or all of raw ECG data 52 to system device 14. As explained above, the signals may correspond to one or more leads. When multiple leads are used, all leads may be processed simultaneously. It is understood that the cardiac signal generated by each lead may have varying lengths. It is further understood that the cardiac signal may be short term (e.g., 10 seconds in standard ECGs) or long term (several days in holters). System device 14 may optionally display raw ECG data 52 or a portion thereof on display 17.
[0106] As is shown in
[0107] Pre-processor 38 may process raw ECG data 52 or a portion thereof by removing the disturbing elements of the cardiac signal, such as noise from the raw ECG data. For noise filtering, a multivariate functional data analysis approach may be used (Pigoli and Sangalli. Computational Statistics and Data Analysis, Vol. 56, 2012, pp 1482-1498). As the signal sensed by sensing device 13 may vary due to a patient's movements, the baseline frequency of raw ECG data 52 may be removed by pre-processor 38 and the cardiac signal may be expressed at a chosen frequency. The frequencies of the signal corresponding to the patient's movements may be removed using median filtering (Kaur et al., Proceedings published by International Journal of Computer Applications, 2011, pp 30-36). Applying raw ECG data 52 to pre-processor 38 generates pre-processed ECG data 55. At this point, ECG platform 37 may cause pre-processed ECG data 55 to optionally be communicated to ECG application 29 running on system device 14 for display on display 17. ECG platform 37 may alternatively, or additionally, cause pre-processed ECG data 55 to be used as an input at classification step 58, discussed in more detail.
[0108] At step 56, ECG platform 37 causes pre-processed ECG data 55 to be applied to delineator 39 for delineation. Delineator 39 applies a first neural network that is a delineation neural network to pre-processed ECG data 55. A neural network refers to a mathematical structure or algorithm that may take an object (e.g., matrix or vector) as input and produce another object as an output though a set of linear and non-linear operations called layers. For example, the input of the first neural network may be one or more multi-lead cardiac signals that are pre-processed to remove noise and/or baseline wandering.
[0109] To apply pre-processed ECG data 55 to the first neural network, delineator 39 may cause some or all of raw ECG data 52 to be expressed as matrix X, which may be a matrix of real numbers. For example, matrix X may be a matrix of size m×n at the frequency used for training the networks, described in more detail below. The constant “m” may be a number of leads in sensing device 13, which is typically 12, though any number of leads may be used. In this example, the number of samples “n” provides the duration of the cardiac signal “n/f” with f being the sampling frequency of the cardiac signal. The sample rate is above a predetermined rate and is preferably relatively high, such as, for example, at least 20, at least 250, at least 500 or at least 1000 samples per second, etc. In one embodiment, all of the sampled ECG data is transferred to the server for input into the processing algorithms without filtering out ECG data. While the ECG data applied to the first neural network is preferably pre-processed ECG data 55, it is understood that a non-preprocessed cardiac signal (i.e., raw ECG data 52, or a portion thereof) may be applied to the first neural network.
[0110] The first neural network may provide as an output, values corresponding to the likelihood of the presence of or one or more waves at a plurality of time points in the cardiac signal. The time points may be dictated by the raw ECG data, may be selected by the user of system device 14, or may be preprogrammed. The first neural network may be a convolutional neural network, and is preferably a fully convolutional neural network. Convolutional neural networks are a particular type of neural network where one or more matrices, which are learned, do not encode a full linear combination of the input elements, but the same local linear combination at all the elements of a structured signal, such as a cardiac signal, through a convolution (Fukushima, Biol. Cybernetics, Vol. 36, 1980, pp 193-202, LeCun et al., Neural Computation, Vol. 1, 1989, pp 541-551). A network which only contains convolutional networks is called a fully convolutional neural network.
[0111] Accordingly, at step 56, delineator 39 causes the first neural network to read each time point of the cardiac signal, spatio-temporally analyze each time point of the cardiac signal, and assign a score at each time point corresponding to one or more types of waves. In this manner, all types of waves in the cardiac signals may analyzed and the likelihood of their presence at each time point, quantified, in a single step. Accordingly, each score generated by delineator 39 is indicative of the likelihood of the presence of a particular wave type at a given time point of the cardiac signal. The wave types may be any well know wave type such as, P-waves, Q-wave, R-wave, S-wave, Q-waves, R-waves, S-waves, QRS complexes, and/or T-waves, for example. In this manner, delineator 39 may process data sampled multiple times per heart beat across a plurality of heart beats.
[0112] The output of the first neural network may be a matrix Y, which may be a matrix of real numbers. For example, matrix Y may be a matrix of the size p×n. Matrix Y may include scores for each type of wave at each time point of the cardiac signal. In matrix Y, “n” is the number of samples, as discussed above with respect to Matrix X, and “p” is the number of wave types plus the number of wave characterizations. As explained in more detail below, wave characterization may correspond to conductivity, prematurity, ectopy, and/or origin of the waves in the cardiac signal, for example. In one example, the wave types include (1) P-waves, (2) QRS complexes, and (3) T-waves, and the wave characterizations include (1) premature waves, (2) paced waves, (3) ventricular QRS complexes, (4) junctional QRS complexes, (5) ectopic P waves, and (6) non-conducted P waves. Accordingly, in this example, p=3+6=9. Each wave type may be expressed according to certain characteristics of that wave, such as start and end points (i.e., onset and offset)).
[0113] Referring now to
[0114] Referring now to
[0115]
[0116] Using the scores assigned to each time point corresponding to each wave type (e.g., P-wave, QRS complex, T-wave, etc.), delineator 39 may post-process the cardiac signal. Post-processing involves, assigning to each time point, none, one, or several waves, calculating the onset and offset of each of the identified waves, and optionally determining the characterization of the waves. Waves may be assigned to each time point by determining that a wave exists at that time point if a certain value is achieved. Computing the “onset” and “offset” of each wave involves computing the time points of the beginning and the end of each wave in the cardiac signal, the beginning referred to as the “onset” and the end referred to as the “offset.” This may involve analyzing the time points corresponding begging and end of the highest values for each wave type. Delineator 39 may characterize the waves by identifying prematurity, conductivity and ectopy. Wave characterization leverages the contextual information between each wave and/or each beat. For example, the premature label may be applied to the wave if a certain threshold value is achieved at a certain time point or an average value over several time points.
[0117] After computing the onset and offset of each wave type in the cardiac signal, delineator 39 may calculate global measurements. Global measurements are derived from the onset and offset of each wave type and may relate to features and characteristics of the cardiac signal such as intervals between waves and wave durations. For example, global measurements may include, but are not limited to, PR interval, P-wave duration, QRS complex duration, QRS axis, QT interval, corrected QT interval (Qtc), T-wave duration, JT interval, corrected JT interval, heart rate, ST elevation, Sokolov index, number of premature ventricular complexes, number of premature atrial complexes (PAC), ratio of non-conducted P waves, and/or ratio of paced waves.
[0118] Delineator 39 may further deduce labels solely from the information generated by delineator 39. For example, the following labels may be deduced by delineator 39: short PR interval (i.e., PR interval<120 ms), first degree AV block (e.g., PR interval>200 ms), axis deviations, long QTc, short QTc, wide complex tachycardia, and/or intraventricular conduction blocks. Labels determined solely from information generated by delineator 39 are referred to as delineation based labels.
[0119] Referring again to
[0120] Referring again to
[0121] The second neural network generates an output having values that correspond to the likelihood of the presence of one or more abnormality, condition and/or descriptor at each time point of the cardiac signal. If a time point or time window is determined to correspond to a certain abnormality, condition, and/or descriptor, a label corresponding to that abnormality, condition, and/or descriptor will be assigned to that time point or window. In one example, one or more labels 59 may be assigned to a time point or time window if a score achieves a predetermined threshold. Accordingly, multi-label localization may be achieved for abnormalities, conditions, and/or descriptors by generating a plurality of values at each time point and assigning one or more labels at each time point.
[0122] Classifier 41 may recover the output of the classification neural network as a vector of size q. The values in the vector correspond to the presence of each label at each time point or each time window. For example, the output of the classification neural network may be the vector [0.98: 0.89; 0.00] with the corresponding labels for each element of the vector: Right Bundle Branch Bloc; Atrial Fibrillation; Normal ECG. The scores may be between 0 and 1. For the vector above, a threshold of 0.5 would result in the labels “Right Bundle Branch Block” and “Atrial Fibrillation” being assigned by classifier 41 to the time point or time window corresponding to the score. It is understood that the threshold may be preprogrammed and/or selected by the user and may be modified to provide varying degrees of sensitivity and specificity. By assigning one or more labels for each time point, onsets and offsets corresponding to each label may be computed to identify durations of episodes (e.g., abnormalities episodes).
[0123] Abnormalities and conditions may include any physiological abnormality or condition which may be identifiable on the cardiac signal. Today about 150 measurable abnormalities may be identified on cardiac signal recordings. Abnormalities and conditions may include but are not limited to, sinoatrial block, paralysis or arrest, atrial fibrillation, atrial flutter, atrial tachycardia, junctional tachycardia, supraventricular tachycardia, sinus tachycardia, ventricular tachycardia, pacemaker, premature ventricular complex, premature atrial complex, first degree atrio-ventricular block (AVB), 2nd degree AVB Mobitz I, 2nd degree AVB Mobitz II, 3rd degree AVB, Wolff-Parkinson-White syndrome, left bundle branch block, right bundle branch block, intraventricular conduction delay, left ventricular hypertrophy, right ventricular hypertrophy, acute myocardial infarction, old myocardial infarction, ischemia, hyperkalemia, hypokalemia, brugada, and/or long QTc. Descriptors may include descriptive qualities of the cardiac signal such as “normal” or “noisy ECG.”
[0124] Upon applying the second neural network at step 58, classifier 41 may read each time point of the cardiac signal as well as each global measurement, analyze each time point of the cardiac signal and each global measurement, compute time windows by aggregating at least two time points, and compute scores for each time window, the scores corresponding to a plurality of non-exclusive labels.
[0125] The classification neural network may be a convolutional neural network or a recurrent neural network. Referring now to
[0126] Referring now to
[0127] As is shown in
[0128] The first neural network (i.e., delineation neural network) and the second neural network (i.e., classification neural network) must be trained to achieve the behavior and functionality described herein. In both the delineation and the classification embodiments, the networks may be expressed using open software such as, for example, Tensorflow, Theano, Caffe or Torch. These tools provide functions for computing the output(s) of the networks and for updating their parameters through gradient descent.
[0129] Training the neural networks involves applying numerous datasets containing cardiac signals and known outputs to the neural networks. A database of the datasets containing cardiac signals collected across a plurality of patients using the systems and methods described herein may be stored on server 15 and/or drive 16 (e.g., in the cloud). The datasets in the database may be used by server 15 to analyze new cardiac signals inputted into the system for processing. In a preferred embodiment, any cardiac signal applied to the trained neural network will have the same sampling rate and/or frequency as the cardiac signals in the datasets used to train the neural network. For example, training of the classification neural network begins with a dataset containing cardiac signals and their known delineation. As explained above, the cardiac signal is expressed as a matrix of size m×n at a predefined frequency. For example, the network may be trained at 250 Hz, 500 Hz or 1000 Hz, though any frequency could be used. The delineation is then expressed in the form of a Matrix Y of size p×n where p is the number of types of waves. Each wave is expressed with their start and end points such as, for example: (P, 1.2 s, 1.3 s), (QRS 1.4 s 1.7 s), (T, 1.7 s, 2.1 s), (P, 2.2 s, 2.3 s). In this example, the first row of Matrix Y corresponds to P-waves, and will have a value of 1 at times 1.2 s and 1.3 s, and as well as 2.2 s and 2.4 s, and 0 otherwise. The second row of Matrix Y corresponds to QRS complexes and will have a value of 1 at times 1.4 s and 1.7 s, and otherwise 0. Finally, the third row of Matrix Y corresponds to T-waves and will have a value of 1 at times 2.2 s and 2.3 s, and otherwise 0. The parameters of the network may then be modified so as to decrease a cost function comparing the known delineation and the output of the network. A cross-entropy error function is used so as to allow for multi-labeling (i.e., allowing for multiple waves at a given instant). This minimization can be done though a gradient step, repeating the foregoing steps at least once for each cardiac signal of the dataset. It is understood that a similar approach may be used to train the delineation neural network (i.e., second neural network).
[0130] It is further understood that ECG platform 37 may cause neural networks described herein to process cardiac signals having a differing number of leads in entry. For example, the neural network may include a sequence of layers at the beginning of the network so as to obtain a network which is independent of the number of input leads and can therefore process cardiac signals with any number of leads m. For example,
[0131] As is shown in
[0132] Referring again to
[0133] Post-processor 43 may also filter the labels to remove redundant labels, assemble labels according to a known hierarchy of labels, or ignore labels that are known to be of lesser importance according to a hierarchy or weighted values. Post-processor 43 may also aggregate the labels through time so as to compute the start (onset) and end (offset) times of each abnormality. It is understood that post-processor 43 may be a standalone component or may be a subcomponent of classifier 41.
[0134] As is shown in
[0135] ECG application 29 may receive data (e.g., raw ECG data, pre-processed ECG data, wave information, labels and any other data generated during steps 54, 56, 58, 61, and/or 63) and cause system device 14 to display as described in U.S. Patent Pub. No. 2020/0022604, the entire contents of which are incorporated herein by reference. Specifically, the '604 publication explains that the ECG signal, features of the ECG signal, and/or descriptors of the ECG signal may be displayed in a multiple field display in an interactive manner.
[0136] Referring now to
[0137] Referring now to
[0138] First graphic window 104 further comprises, parallel to the time axis of the plot 110, temporal bar 115. Temporal bar 115 provides a linear representation of the total ECG acquisition time wherein the time periods associated to episodes or events are represented as colored segments. As is shown in
[0139] Referring again to
[0140] Interactive display 101 further includes graphic window 105 including ECG strip 118 in a second time window starting at the time point selected by the cursor 116. Second graphic window 105 further includes ECG strip 119 in a third time window which is larger than the second time window which is inclusive of the second time window. The third time window includes a shaded portion which corresponds to the second time window.
[0141] Referring now to
[0142] First graphic window 124 is similar to first graphic window 104 except for plot 130. Like first graphic window 104, first graphic window 124 includes multiple label buttons 129 having the same functionality as multiple label buttons 109, secondary labels 132 having the same functionality as secondary labels 112, temporal bar 135 and curser 136 having the same functionality as temporal bar 115 and cursor 116, and second interactive means 137 having the same functionality as second interactive means 117. Unlike plot 110, plot 130 is a heart rate density plot which is the projection onto a bivariate intensity plot of the histogram of the density of heart rates as a function of time.
[0143] Referring now to
[0144] As is shown in
[0145] Referring again to
[0146] Referring again to
[0147] Referring again to
[0148] In a preferred embodiment, the density is calculated as a function of the number of R-waves in the bin divided by the heart rate of the HR bin (e.g. the mean of the minimum and maximum bounds of the time window). This preferred computation of density considers the time spent in a specific bin. For example, in a time bin of 3 minutes, if there occurs 100 beats at a heart rate of 50 bpm (beats per minute) in a first HR bin and 100 beats at 100 bpm in a second HR bin, there will be as many beats in each bin, but 2 minutes will be spent at 50 bpm and only one minute at 100 bpm. Therefore, this bin would have the same density representation if only the number of beats are considered. However, when considering the count of beats divided by the heart rate, the first bin corresponding to the heart rate bin of 50 bpm will be darker than the bin corresponding to the heart rate bin of 100 bpm, as dividing by the heart rate gives higher weight to lower heart rate values. The preferred embodiment therefore captures this temporal information better than only considering the count of beats.
[0149] Referring again to
[0150] It is understood that the bounds of the x-axis of the HR density plot may be the beginning and end of the signal. However, in a preferred embodiment, the bounds of the x-axis may interactively vary with the action of zooming in and out performed by the user. The bounds of the y-axis remain fixed when performing this action. Referring again to
[0151]
[0152] Referring again to
[0153] As explained above, interactive icons in interactive displays may be engaged to incorporate data and images displayed in a report. For example, third interactive icon 108 may be selected by a user using ECG application 29 to include the corresponding episode plot in a report. Accordingly, at step 66, the user may request a report and may select customized features such as certain data to be included in the report (e.g., abnormality data, episode data, episode plots, etc.).
[0154] At step 67, ECG application 29 may transmit the request for a report and selected customizable features (e.g., ECG data to be included in the report) to ECG platform 37 and ECG platform 37 may receive the request and information. ECG platform 37 may log the request and save the information received from ECG application 29. At step 68, ECG platform 37 may cause report generator 44 to generate a report 69 according to the information received from system ECG application 29.
[0155] Referring now to
[0156] Third section 183 may include a plot of the ECG data. In
[0157] Fourth section 184 may include metrics from the cardiac signal recording. For example, fourth section 184 may include the duration of the recording, the maximum, minimum and average heart rate, premature supraventricular complexes and any patient-triggered events, and/or any other metrics concerning the cardiac signal. Fifth section 185 may include information corresponding to any episodes detected. For example, fifth section 185 may include pause information (count and/or longest R-R interval), atrioventricular block information, atrial fibrillation/flutter information, ventricular tachycardia information, other supraventricular tachycardia information, and/or any other information concerning any episodes or abnormalities. Sixth section 186 may include results information such as, for example, a summary of the episodes and/or abnormalities, a diagnosis, and/or any other information analyzed, aggregated, computed, determined, identified, or otherwise detected from the cardiac signal. For example, sixth section 186 may identify a sinus rhythm with paroxysmal atrial fibrillation.
[0158]
[0159] Referring now
[0160] Referring now to
[0161] At block 802, a patient profile may be determined. For example, a user (e.g., physician, healthcare provide, and/or technician) may generate a profile for a particular patient. At block 804, a ILR and/or wearable device of a patient may be connected and/or associated with the patient profile such that data from the ILR and/or wearable device is periodically sent to and/or shared with the platform.
[0162] At block 806, the platform may receive data from the ILR and/or wearable device and may archive the data on a server and associate the data with the patient profile. For example, a server running the platform may receive data from the ILR and/or wearable device and may determine, based on a device identifier or a user identifier that the device is known and associated with a user profile and may archive that data in a manner that associates the data with the user profile.
[0163] At optional block 808 the platform may optionally display a list of the data, alerts and/reports based on the data. The platform may automatically generate alerts after processing the data using the techniques described herein (e.g., using delineation, classification, clustering, etc.). The platform may also automatically and/or at the direction of the user, generate reports corresponding to the data as described herein. At optional block 810, the platform may display an option to edit the patient information and/or any other information in the patient profile. For example, the user may alter the arrangement of the alerts and/or data displayed at optional block 808.
[0164] Referring now to
[0165] At decision 818, if the ECG data is not important, at optional block 820, the platform (e.g., either automatically and/or at the direction of the user) may generate a report to document the important ECG data for EMR purposes. This may include generating a report as described herein. At optional block, the platform may determine to classify parsed and/or prioritized ECG data as closed. At optional block 822, the platform may further determine that the ECG data that was initially categorized as normal is important based on user feedback. For example, a user may view displayed ECG strips classified as normal and may instruct the platform that the ECG is important. At optional block 826, the user may change one or more diagnostics with respect to the ECG data.
[0166] If instead, at decision 818, the ECG data is important, the platform (e.g., either automatically and/or at the direction of the user) may generate a report to document the important ECG data for EMR purposes at optional block 828. This may include generating a report as described herein. At optional block 829, the platform may determine that the ECG data is not important (e.g., based on user feedback). At optional block 830, the platform may further determine to mark the parsed and/or prioritized ECG data and/or an event corresponding thereto as closed. For example, a user may view displayed ECG strips classified as important and may instruct the platform to mark the event and/or data as closed. At optional block 831, the user may change one or more diagnostics with respect to the ECG data.
[0167] Referring now to
[0168] Based on the data received by ECG platform 836, true alarm events 837 and/or false alarm events 838 may be determined. For example ECG platform 836 may employ the techniques described herein (e.g., delineation, classification, clustering, etc.) to analyze wearable device ECG events 831 and/or ILR ECG events 832. True alarm events may correspond to the ECG platform correctly classifying the ECG event and/or data. False alarm events may correspond to the ECG platform incorrectly classifying the ECG event and/or data (e.g., based on user feedback). True alarm events and/or false alarm events may be used by reports module 839 to update EMR 841 and otherwise cause EMR 841 to incorporate this information.
[0169] The true alarm events may be used by the platform to generate item 834, which may include an event report and/or clinical action items. For example, ECG platform 833 may generate a report for important ECG events. The report may include ECG strips. Additionally, or alternatively, ECG platform may determine clinical actionable items and/or recommendations (e.g., in the form of a message and/or alarm). The information in item 834 may be used by and/or incorporated in EMR 835.
[0170] Referring now to
[0171] At block 866, a report generated (e.g., at block 864) may be classified as a high or low priority. The priority designation may be assigned based on the presence of important information. The reports may include billing information and/or requirements, all ECG strips for a given period of time, and/or certain trends (e.g., HR trends). Alternatively, or additionally, a physician may review the report and determine the priority designation (e.g., high or low). At optional block 870, a report may be displayed and the platform may receive instructions to affix a signature to the report. At optional block 872, the platform may determine billing information and/or corresponding EMR information based on the report and/or data in the report. At optional block 874, billing may be performed based on information in the report and/or EMR may be updated such that relevant information from the report is applied to or otherwise incorporated into the EMR.
[0172] Referring now to
[0173] Referring now to
[0174] Referring now to
[0175] Referring now to
[0176] Referring now to
[0177]
[0178] Referring now to
[0179] To initiate the process set forth in
[0180] At step 909, an event interface may be generated indicating (e.g., displaying) the classification and/or cardiac event determined at step 907. For example, the event interface may display “sinus rhythm” and may include a representation of the ECG signal corresponding to the event. At step 911, input regarding the classification may be received. For example, a system device (e.g., healthcare provider device) may present the event interface and the healthcare provider may send the ECG platform a message regarding the classification (e.g., regarding the accuracy of the classification).
[0181] At step 913, the cardiac event may be reclassified based on the input received. For example, the input may indicate that the classification determined at step 907 was not accurate and may even identify a new classification. The new classification may be used to reclassify the event. At optional step 915, an event interface may be generated indicating the reclassification determined at step 913. At optional step 917, the algorithm used to process the ECG data at step 905 may be trained and/or otherwise modified based on the reclassification. Event interfaces and reclassification are described in greater detail below with respect to
[0182] Referring now to
[0183] Referring now to
[0184] Sensing device 930 and sensing device 932 may any type of device for sensing electrical activity of the heart, generating ECG data (e.g., ECG signals), and/or generating any other biometric or physiological data (e.g., heart rate, temperature, motion, oxygen levels (SpO2), respiratory rate, humidity, blood pressure, etc.). Sensing device 930 and sensing device 932 may be the same or different devices. For example, sensing device 930 may be a smart watch worn by user 925 and sensing device 932 may be an implantable ECG recording device (e.g., ILR). While only two sensing devices are illustrated in
[0185] Sensing device 930 and sensing device 932 may generate sensed data (e.g., ECG data and/or other biometric or physiological data) and may send such data to server 922. Sensing device 930 and sensing device 932 may send the data directly to server 922 or may send the data to server 922 via a computing device such as system device 928. Upon receiving the sensed data, server and/or drive 924 may analyze the data using one or more approaches or techniques described herein (e.g., process the sensed data to determine an anomaly, abnormality or condition). System device 928 may be used to analyze and otherwise oversee processing and analyzing the sensed data on server 922.
[0186] As shown in
[0187] Referring now to
[0188] At optional step 941, the ECG data and the sensor data may be catalogued or otherwise saved in an organized fashion (e.g., in a database) such that the ECG data and sensor data may be associated with the device from which it originated, the type of data, a file number, and/or any other information relevant to the ECG and/or sensor data. At step 943, the ECG data and sensor data may be processed using an algorithm to determine the presence of one or more abnormalities, conditions and/or descriptors corresponding to an event (e.g., cardiac event, ECG event, and/or any other type of physiological event). For example, techniques and/or algorithms similar to those described above (e.g., the techniques and/or algorithms described above with respect to
[0189] At step 945, information indicative of the presence of the one or more abnormalities, conditions, or descriptors corresponding to the event may be generated. For example, such information may be used to generate a display on a system device and/or generate a report regarding the one or more abnormalities, conditions, or descriptors. At step 947, the information generated at step 945 may be communicated to a system device for display. For example, the information may be sent or otherwise accessed by a health care provider device for display on the healthcare provider device.
[0190] Referring now to
[0191] The server running the ECG platform may communicate all or a portion of mobile interface 933 to mobile device 930. For example, mobile device 930 may communicate patient information 934, ECG information 936, and/or notification information 938 to mobile device 930, which may be presented by the application running on mobile device 930. Alternatively, and/or additionally, certain information presented on mobile interface 933 may be saved locally on mobile device 930. Patient information 934 may include information about the patient (e.g., date of birth, sex, indication, etc.). ECG information 936 may include ECG representation 936 which may be a representation of the ECG signal, such as portion of the signal at a detected ECG event.
[0192] ECG information 936 may optionally include information about a detected anomaly, descriptor and/or condition. Notification information 938 may include a notice that the user has a notification or message (e.g., from a health care provider and/or from the ECG platform running on the server). In one example, the notification may be a diagnosis or detected abnormality, condition, and/or anomaly determined by the ECG platform and/or the healthcare provider. Alternatively, or additionally, a notification may include a treatment recommendation Information displayed and provided by the ECG platform may have to be reviewed and/or released by a healthcare professional. Alternatively, the ECG platform may permit the mobile device to display such information once it has been reviewed and/or released by the healthcare professional. It is understood that different data and/or information than that illustrated in
[0193] Referring now to
[0194] To initiate the process illustrated in
[0195] At step 944, the system (e.g., ECG platform) may priority certain events, analyses, results, data, or other information determined by the system based on the indication identified at step 942. For example, results, data and/or other information determined by the system by analyzing sensed data (e.g., ECG data) may be prioritized for review by a healthcare professional. The prioritized data, results, and information may be known by the system to be associated or relevant to the indication. The system may include default settings making such associations between the data, results, identified abnormalities, conditions and/or events and/or information and certain indications.
[0196] At decision 946, the system may determine if the events, analyses, data, results, and/or information should be reprioritized. For example, the system may include a reprioritize button on a user interface presenting the events, analyses, data, results and/or information and the healthcare provider may engage the button to indicate that the presentation of the foregoing should be reprioritize or otherwise modified. If the data, results, and/or information should not be reprioritized (e.g., the healthcare provider did not engage the button), then at step 948, the default prioritization should be maintained. Alternatively, input from a user indicating that the data, results, and/or information associated with the indication should be reprioritized (e.g., the button was engaged), then at step 952, the data, results, and/or information prioritized for the indication should be reprioritized. For example, the healthcare provider may manually reprioritize such data, results, and/or information. Prioritization is described further below with respect to
[0197] Referring now to
[0198] To initiate the process set forth in
[0199] At step 966, a message may be sent to a mobile device and/or to a sensing device to cause the sensing device to generate or obtain ECG data and/or other data relevant to the arrhythmia at the time period. For example, the message may be sent to a mobile device and the mobile device may request such data from the sensing device. Alternatively, the request may be sent directly to the sensing device. In yet another example, a user may need to manually cause the sensing device to record ECG data and the message may instruct the user to start recording the ECG at a certain time and/or for a certain duration. At step 968, the system may receive ECG data and/or other data relevant to the arrhythmia and corresponding to the time period. In this manner, the system and/or mobile device may trigger ECG recordings at times when the patient is likely to experience arrhythmias.
[0200] Referring now to
[0201] To initiate the process set forth in
[0202] At step 978, a message may be sent to a mobile device and/or to a sensing device to cause the sensing device to generate or obtain ECG data and/or other data relevant during the time period. For example, the message may be sent to a mobile device and the mobile device may request such data from the sensing device. Alternatively, the request may be sent directly to the sensing device. In yet another example, a user may need to cause the sensing device to record ECG data and the message may instruct the user to start recording the ECG at a certain time. At step 968, the system may receive ECG data and/or other data relevant to the arrhythmia and corresponding to the time period. In this manner, the system and/or mobile device may trigger ECG recordings at times when the patient is likely to experience atrial fibrillation.
[0203] Referring now to
[0204] Referring now to
[0205] Referring now to
[0206] Referring now to
[0207] Referring now to
[0208] Referring now to
[0209] Referring now to
[0210] Referring now to
[0211] Referring now to
[0212] As shown in
[0213] Plot 1052 and/or any other plot in ECG report 1050 may be interactive. For example, plot 1052 may include clickable portion 1054 and/or clickable link 1056, which each may be clicked or otherwise engaged by a user on a computing device. It is understood that clickable link 1056 may be text, an image, an icon, and/or the like. In one example, a physician and/or healthcare provider may receive a digital version of ECG report 1050 and may desire to view more of the signal and/or underlying data in more detail and thus may click clickable portion 1054 of a clickable ECG plot and/or clickable link 1056 using a computing device (e.g., using a touchscreen and/or mouse). Upon clicking clickable portion 1054 and/or clickable link 1056, the user may be redirected to ECG platform 37 and specifically to a viewer version of ECG application 29. For example, the user may be redirected to a viewer application (.eg., the viewer application and interface illustrated in
[0214] Referring now to
[0215] As shown in
[0216] The heart rate density plot in first portion 1062 may be similar to plot 110 of
[0217] Expanded ECG strip 1068 may similarly correspond to a location of the interactive cursor on the on the heart rate density plot and may include an ECG strip having a length of time longer than focused ECG strip 1066 but including the timeframe of the focused ECG strip 1066. Expanded ECG strip 1068 may have a reduced height as compared to focused ECG strip 1066. It is understood that second portion 1064 and first portion 1066 may be linked such that moving the cursor on the heart rate density plot causes the portion of the ECG signal displayed in the focused ECG strip 1066 and the expanded ECG strip 1068 to change based on the location of the cursor on the time axis of the heart rate density plot.
[0218] The selectable ECG strips in third portion 1070 may be organized by identified conditions, events, and/or abnormalities. For example, the selectable ECG strips may be organized by ventricular tachycardia (VT), couplets, bigeminy, or trigeminy, for example. Each selectable ECG strip may be selected using the viewer application to view that portion of the ECG signal correspond to the selected ECG strip on first portion 1062 and the second portion 1064. Specifically, the cursor on the heart rate density plot may move to the portion of the heart rate density plot corresponding to the selected ECG strip. Further, focused ECG strip 1066 and expanded ECG strip 1068 will display the selected ECG strip and an expanded version of the selected ECG strip, respectively. In one example, the ECG strips in third portion 1070 may only be those strips included in the ECG report. Alternatively, all identified ECG strips by ECG system may be included in third portion 1070.
[0219] Viewer interface 1060 may display greater or fewer plots than that shown in
[0220] Referring now to
[0221] At block 1086, the ECG system, in response to the request to access the viewer application, may request and validate user credentials. For example, the healthcare provider may be a registered limited user of the ECG system and may have a limited user profile with corresponding credentials (e.g., username and passcode). In response to receiving the request to access the viewer application, the ECG system may request the credentials from the limited user and may validate those credentials using the user profile.
[0222] At block 1088, the ECG system, via the viewer application, may generate a viewer interface to present ECG plots, ECG data, and/or other data related to the ECG report. For example, the ECG system may generate a viewer interface similar to viewer interface 1062, described above with respect to
[0223] Referring now to
[0224] As shown in
[0225] As shown in
[0226] It should be understood that any of the computer operations described herein above may be implemented at least in part as computer-readable instructions stored on a computer-readable memory. It will of course be understood that the embodiments described herein are illustrative, and components may be arranged, substituted, combined, and designed in a wide variety of different configurations, all of which are contemplated and fall within the scope of this disclosure.
[0227] The foregoing description of illustrative embodiments has been presented for purposes of illustration and of description. It is not intended to be exhaustive or limiting with respect to the precise form disclosed, and modifications and variations are possible in light of the above teachings or may be acquired from practice of the disclosed embodiments. It is intended that the scope of the invention be defined by the claims appended hereto and their equivalents.