US20210259613A1 - Apparatuses for tracking physiological parameters of mother and fetus during pregnancy - Google Patents

Apparatuses for tracking physiological parameters of mother and fetus during pregnancy Download PDF

Info

Publication number
US20210259613A1
US20210259613A1 US17/112,201 US202017112201A US2021259613A1 US 20210259613 A1 US20210259613 A1 US 20210259613A1 US 202017112201 A US202017112201 A US 202017112201A US 2021259613 A1 US2021259613 A1 US 2021259613A1
Authority
US
United States
Prior art keywords
ecg
fetal
filtered
signal
data
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US17/112,201
Inventor
Oren OZ
Nathan Intrator
Muhammad Mhajna
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Nuvo Group Ltd
Original Assignee
Nuvo Group Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Nuvo Group Ltd filed Critical Nuvo Group Ltd
Priority to US17/112,201 priority Critical patent/US20210259613A1/en
Assigned to NUVO GROUP LTD. reassignment NUVO GROUP LTD. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: MHAJNA, MUHAMMAD, OZ, OREN, INTRATOR, NATHAN
Publication of US20210259613A1 publication Critical patent/US20210259613A1/en
Priority to US17/821,562 priority patent/US20220395212A1/en
Assigned to GAINGELS 10X CAPITAL DIVERSITY FUND I, LP reassignment GAINGELS 10X CAPITAL DIVERSITY FUND I, LP SECURITY INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: NUVO GROUP LTD.
Abandoned legal-status Critical Current

Links

Images

Classifications

    • AHUMAN NECESSITIES
    • A61MEDICAL OR VETERINARY SCIENCE; HYGIENE
    • A61BDIAGNOSIS; SURGERY; IDENTIFICATION
    • A61B5/00Measuring for diagnostic purposes; Identification of persons
    • A61B5/68Arrangements of detecting, measuring or recording means, e.g. sensors, in relation to patient
    • A61B5/6801Arrangements of detecting, measuring or recording means, e.g. sensors, in relation to patient specially adapted to be attached to or worn on the body surface
    • A61B5/6813Specially adapted to be attached to a specific body part
    • A61B5/6823Trunk, e.g., chest, back, abdomen, hip
    • AHUMAN NECESSITIES
    • A61MEDICAL OR VETERINARY SCIENCE; HYGIENE
    • A61BDIAGNOSIS; SURGERY; IDENTIFICATION
    • A61B5/00Measuring for diagnostic purposes; Identification of persons
    • A61B5/24Detecting, measuring or recording bioelectric or biomagnetic signals of the body or parts thereof
    • A61B5/316Modalities, i.e. specific diagnostic methods
    • A61B5/318Heart-related electrical modalities, e.g. electrocardiography [ECG]
    • A61B5/346Analysis of electrocardiograms
    • A61B5/349Detecting specific parameters of the electrocardiograph cycle
    • AHUMAN NECESSITIES
    • A61MEDICAL OR VETERINARY SCIENCE; HYGIENE
    • A61BDIAGNOSIS; SURGERY; IDENTIFICATION
    • A61B5/00Measuring for diagnostic purposes; Identification of persons
    • A61B5/02Detecting, measuring or recording pulse, heart rate, blood pressure or blood flow; Combined pulse/heart-rate/blood pressure determination; Evaluating a cardiovascular condition not otherwise provided for, e.g. using combinations of techniques provided for in this group with electrocardiography or electroauscultation; Heart catheters for measuring blood pressure
    • A61B5/024Detecting, measuring or recording pulse rate or heart rate
    • AHUMAN NECESSITIES
    • A61MEDICAL OR VETERINARY SCIENCE; HYGIENE
    • A61BDIAGNOSIS; SURGERY; IDENTIFICATION
    • A61B5/00Measuring for diagnostic purposes; Identification of persons
    • A61B5/02Detecting, measuring or recording pulse, heart rate, blood pressure or blood flow; Combined pulse/heart-rate/blood pressure determination; Evaluating a cardiovascular condition not otherwise provided for, e.g. using combinations of techniques provided for in this group with electrocardiography or electroauscultation; Heart catheters for measuring blood pressure
    • A61B5/024Detecting, measuring or recording pulse rate or heart rate
    • A61B5/02405Determining heart rate variability
    • AHUMAN NECESSITIES
    • A61MEDICAL OR VETERINARY SCIENCE; HYGIENE
    • A61BDIAGNOSIS; SURGERY; IDENTIFICATION
    • A61B5/00Measuring for diagnostic purposes; Identification of persons
    • A61B5/02Detecting, measuring or recording pulse, heart rate, blood pressure or blood flow; Combined pulse/heart-rate/blood pressure determination; Evaluating a cardiovascular condition not otherwise provided for, e.g. using combinations of techniques provided for in this group with electrocardiography or electroauscultation; Heart catheters for measuring blood pressure
    • A61B5/024Detecting, measuring or recording pulse rate or heart rate
    • A61B5/02411Detecting, measuring or recording pulse rate or heart rate of foetuses
    • AHUMAN NECESSITIES
    • A61MEDICAL OR VETERINARY SCIENCE; HYGIENE
    • A61BDIAGNOSIS; SURGERY; IDENTIFICATION
    • A61B5/00Measuring for diagnostic purposes; Identification of persons
    • A61B5/02Detecting, measuring or recording pulse, heart rate, blood pressure or blood flow; Combined pulse/heart-rate/blood pressure determination; Evaluating a cardiovascular condition not otherwise provided for, e.g. using combinations of techniques provided for in this group with electrocardiography or electroauscultation; Heart catheters for measuring blood pressure
    • A61B5/024Detecting, measuring or recording pulse rate or heart rate
    • A61B5/0245Detecting, measuring or recording pulse rate or heart rate by using sensing means generating electric signals, i.e. ECG signals
    • AHUMAN NECESSITIES
    • A61MEDICAL OR VETERINARY SCIENCE; HYGIENE
    • A61BDIAGNOSIS; SURGERY; IDENTIFICATION
    • A61B5/00Measuring for diagnostic purposes; Identification of persons
    • A61B5/24Detecting, measuring or recording bioelectric or biomagnetic signals of the body or parts thereof
    • A61B5/316Modalities, i.e. specific diagnostic methods
    • AHUMAN NECESSITIES
    • A61MEDICAL OR VETERINARY SCIENCE; HYGIENE
    • A61BDIAGNOSIS; SURGERY; IDENTIFICATION
    • A61B5/00Measuring for diagnostic purposes; Identification of persons
    • A61B5/24Detecting, measuring or recording bioelectric or biomagnetic signals of the body or parts thereof
    • A61B5/316Modalities, i.e. specific diagnostic methods
    • A61B5/318Heart-related electrical modalities, e.g. electrocardiography [ECG]
    • A61B5/344Foetal cardiography
    • AHUMAN NECESSITIES
    • A61MEDICAL OR VETERINARY SCIENCE; HYGIENE
    • A61BDIAGNOSIS; SURGERY; IDENTIFICATION
    • A61B5/00Measuring for diagnostic purposes; Identification of persons
    • A61B5/43Detecting, measuring or recording for evaluating the reproductive systems
    • A61B5/4306Detecting, measuring or recording for evaluating the reproductive systems for evaluating the female reproductive systems, e.g. gynaecological evaluations
    • A61B5/4343Pregnancy and labour monitoring, e.g. for labour onset detection
    • A61B5/4362Assessing foetal parameters
    • AHUMAN NECESSITIES
    • A61MEDICAL OR VETERINARY SCIENCE; HYGIENE
    • A61BDIAGNOSIS; SURGERY; IDENTIFICATION
    • A61B5/00Measuring for diagnostic purposes; Identification of persons
    • A61B5/72Signal processing specially adapted for physiological signals or for diagnostic purposes
    • A61B5/7203Signal processing specially adapted for physiological signals or for diagnostic purposes for noise prevention, reduction or removal
    • AHUMAN NECESSITIES
    • A61MEDICAL OR VETERINARY SCIENCE; HYGIENE
    • A61BDIAGNOSIS; SURGERY; IDENTIFICATION
    • A61B5/00Measuring for diagnostic purposes; Identification of persons
    • A61B5/72Signal processing specially adapted for physiological signals or for diagnostic purposes
    • A61B5/7225Details of analog processing, e.g. isolation amplifier, gain or sensitivity adjustment, filtering, baseline or drift compensation
    • AHUMAN NECESSITIES
    • A61MEDICAL OR VETERINARY SCIENCE; HYGIENE
    • A61BDIAGNOSIS; SURGERY; IDENTIFICATION
    • A61B5/00Measuring for diagnostic purposes; Identification of persons
    • A61B5/24Detecting, measuring or recording bioelectric or biomagnetic signals of the body or parts thereof
    • A61B5/316Modalities, i.e. specific diagnostic methods
    • A61B5/318Heart-related electrical modalities, e.g. electrocardiography [ECG]
    • A61B5/346Analysis of electrocardiograms
    • A61B5/349Detecting specific parameters of the electrocardiograph cycle
    • A61B5/35Detecting specific parameters of the electrocardiograph cycle by template matching
    • AHUMAN NECESSITIES
    • A61MEDICAL OR VETERINARY SCIENCE; HYGIENE
    • A61BDIAGNOSIS; SURGERY; IDENTIFICATION
    • A61B5/00Measuring for diagnostic purposes; Identification of persons
    • A61B5/24Detecting, measuring or recording bioelectric or biomagnetic signals of the body or parts thereof
    • A61B5/316Modalities, i.e. specific diagnostic methods
    • A61B5/318Heart-related electrical modalities, e.g. electrocardiography [ECG]
    • A61B5/346Analysis of electrocardiograms
    • A61B5/349Detecting specific parameters of the electrocardiograph cycle
    • A61B5/352Detecting R peaks, e.g. for synchronising diagnostic apparatus; Estimating R-R interval

Definitions

  • the invention relates generally to systems and methods for monitoring the wellbeing of a fetus by the non-invasive detection and analysis of fetal cardiac electrical activity data.
  • Monitoring fetal cardiac can be useful to determine of the health of a fetus during pregnancy.
  • the present invention provides a computer-implemented method, comprising: receiving, by at least one computer processor executing specific programmable instructions configured for the method, raw Electrocardiogram (ECG) signals data from at least one pair of ECG sensors; wherein the at least one pair of ECG sensors are positioned in on an abdomen of a woman carrying a fetus; wherein the raw ECG signals data comprise data representative of a N number of raw ECG signals data (raw N-ECG signals data) which are being acquired in real-time from the at least one pair of ECG sensors; digital signal filtering, by the at least one computer processor, the raw N-ECG signals data to form filtered N-ECG signals data having filtered N-ECG signals; detecting, by the at least one computer processor, maternal heart peaks in each filtered ECG signal in the filtered N-ECG signals data; subtracting, by the at least one computer processor, from each of N-ECG signal of the filtered N-ECG signals data, maternal ECG signal, by utilizing at least
  • the digital signal filtering utilizes at least one of: i) a baseline wander filtering, ii) a power line frequency filtering, iii) a high frequency filtering, or iv) a digital adaptive inverse-median filtering.
  • the filtered N-ECG signals data is data which, prior to the detecting the maternal peaks in the filtered N-ECG signals data, has been processed with at least one decomposition technique, wherein the at least one decomposition technique is selected from the group consisting of: a) Singular-Value-Decomposition (SVD), b) Principal-Component-Analysis (PCA), c) Independent-Component-Analysis (ICA), d) Wavelet-Decomposition (CWT), and e) any combination thereof.
  • the at least one decomposition technique is selected from the group consisting of: a) Singular-Value-Decomposition (SVD), b) Principal-Component-Analysis (PCA), c) Independent-Component-Analysis (ICA), d) Wavelet-Decomposition (CWT), and e) any combination thereof.
  • detecting of the maternal heart peaks in each filtered ECG signal in the filtered N-ECG signals data is performed based at least on: i) dividing each filtered ECG signal into a first plurality of ECG signal segments; ii) normalizing a filtered ECG signal in each ECG signal segment; iii) calculating a first derivative of the filtered ECG signal in each ECG signal segment; iv) finding local maternal heart peaks in each ECG signal segment based on determining a zero-crossing of the first derivative; and v) excluding the local maternal heart peaks having at least one of: 1) an absolute value which is less than a pre-determined local peak absolute threshold value; or 2) a distance between the local peaks is less than a pre-determined local peak distance threshold value.
  • the pre-determined similarity value is based on an Euclidian distance, wherein the set of parameters is a local minima solution to a non-linear least squares problem solved by at least one of: 1) minimizing a cost function taken as the Euclidian distance; 2) utilizing a Gauss-Newton algorithm; 3) utilizing a Steepest-Descent (Gradient-Descent) algorithm; or 4) utilizing a Levenberg-Marquardt algorithm.
  • the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio comprises: i) applying a band-pass filter within a range of 15-65 Hz to break the plurality of N-ECG fetal signals in to a plurality of frequency channels, ii) scoring an ECG fetal signal per channel based on a peak-2-mean analysis to identify a plurality of fetal heartbeat channels, wherein each fetal heartbeat channel corresponds to a particular fetal ECG fetal signal; and iii) selecting the identified plurality of fetal heartbeat channels into filtered ECG fetal signals data, comprising a N number of filtered fetal ECG signals (filtered N-ECG fetal signals data).
  • the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio further comprises at least one of: 1) utilizing a Singular-Value-Decomposition (SVD) technique; or 2) utilizing a Wavelet-Denoising (WD) technique.
  • Singular-Value-Decomposition Singular-Value-Decomposition
  • WD Wavelet-Denoising
  • the present invention provides a computer-implemented method, comprising: receiving, by at least one computer processor executing specific programmable instructions configured for the method, raw Electrocardiogram (ECG) signals data from at least one pair of ECG sensors; wherein the at least one pair of ECG sensors are positioned on an abdomen of a woman carrying a fetus; wherein the raw ECG signals data comprise data representative of a N number of raw ECG signals (raw N-ECG signals data) which are being acquired in real-time from the at least one pair of ECG sensors; digital signal filtering, by the at least one computer processor, the raw ECG signals data to form filtered N-ECG signals data having filtered N-ECG signals, wherein the digital signal filtering utilizes at least one of: i) a baseline wander filtering; ii) a power line frequency filtering; iii) a high frequency filtering; or iv) a digital adaptive inverse-median filtering; detecting, by the at least one computer processor, maternal
  • the baseline wander filtering comprises utilizing at least one of: 1) a moving average filter having constant weights, or 2) a moving median filter.
  • the power line frequency filtering comprises utilizing at least one of: 1) a band-stop digital filter; or 2) a digital adaptive filter.
  • the high frequency filtering comprises utilizing at least one of: 1) a digital low pass filter; 2) a cutoff frequency of at least 70 cycles per second; 3) a smoothing filter; 4) or an edge-preserving filter.
  • the edge-preserving filter is one of: a) an adaptive mean filter; or b) an adaptive median filter.
  • the digital adaptive inverse-median filtering comprises utilizing an adaptive median filter, having a length to be: 1) a constant value, or 2) adapted depending on at least one local characteristic of the ECG signals data.
  • the at least one local characteristic is a duration of at least one of: a) a QRS complex; b) a ST segment; or c) a PR interval.
  • the filtered N-ECG signals data is data which, prior to the detecting the maternal peaks in the filtered N-ECG signals data, has been processed with at least one decomposition technique, wherein the at least one decomposition technique is selected from the group consisting of: a) Singular-Value-Decomposition (SVD); b) Principal-Component-Analysis (PCA); c) Independent-Component-Analysis (ICA); d) Wavelet-Decomposition (CWT), and e) any combination thereof.
  • the at least one decomposition technique is selected from the group consisting of: a) Singular-Value-Decomposition (SVD); b) Principal-Component-Analysis (PCA); c) Independent-Component-Analysis (ICA); d) Wavelet-Decomposition (CWT), and e) any combination thereof.
  • the pre-determined similarity value is based on an Euclidian distance, wherein the set of parameters is a local minima solution to a non-linear least squares problem solved by at least one of: 1) minimizing a cost function taken as the Euclidian distance; 2) utilizing a Gauss-Newton algorithm; 3) utilizing a Steepest-Descent (Gradient-Descent) algorithm; or 4) utilizing a Levenberg-Marquardt algorithm.
  • the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio further comprises at least one of: 1) utilizing a Singular-Value-Decomposition (SVD) technique; or 2) utilizing a Wavelet-Denoising (WD) technique.
  • Singular-Value-Decomposition Singular-Value-Decomposition
  • WD Wavelet-Denoising
  • the at least one pair of ECG sensors is selected from the group consisting of: at least one of a wet contact ECG electrode; and at least one dry contact ECG electrode.
  • a number of in-beat segments in the in-beat segmentation is based on utilizing at least one of the following: 1) a Divide and Conquer algorithm; or 2) a digital band pass filter.
  • the number of in-beat segments is three and are defined as follows: 1) a first in-beat segment defined from the onset value of a particular beat interval to an onset of a QRS complex; 2) a second in-beat segment defined to be the QRS complex; and 3) a third in-beat segment defined from an offset of the QRS complex to the offset value of the particular beat interval.
  • the present invention provides a specifically programmed computer system, comprising: at least one specialized computer machine, comprising: a non-transient memory, electronically storing particular computer executable program code; and at least one computer processor which, when executing the particular program code, becomes a specifically programmed computing processor that is configured to at least perform the following operations: receiving raw Electrocardiogram (ECG) signals data from at least one pair of ECG sensors; wherein the at least one pair of ECG sensors is positioned in on an abdomen of a woman carrying a fetus; wherein the raw ECG signals data comprise data representative of a N number of raw ECG signals (raw N-ECG signals data) which are being acquired in real-time from the at least one pair of ECG sensors; digital signal filtering the raw ECG signals data to form filtered N-ECG signals data having filtered N-ECG signals; detecting maternal heart peaks in each of the filtered N-ECG signal in the filtered N-ECG signals data; subtracting, from each of the filtered N-ECG
  • ECG
  • the present invention provides a specifically programmed computer system, comprising: at least one specialized computer machine, comprising: a non-transient memory, electronically storing particular computer executable program code; and at least one computer processor which, when executing the particular program code, becomes a specifically programmed computing processor that is configured to at least perform the following operations: receiving raw Electrocardiogram (ECG) signals data from at least one pair of ECG sensors; wherein the at least one pair of ECG sensors is positioned on an abdomen of a woman carrying a fetus; wherein the raw ECG signals data comprise data representative of a N number of raw ECG signals (raw N-ECG signals data) which are being acquired in real-time from the at least one pair of ECG sensors; digital signal filtering the raw ECG signals data to form filtered N-ECG signals data having filtered N-ECG signals, wherein the digital signal filtering utilizes at least one of: i) a baseline wander filtering; ii) a power line frequency filtering; iii)
  • FIGS. 1A-1B shows the positions of the sensor pairs on the abdomen of a pregnant woman according to some embodiments of the present invention.
  • Panel A) shows a front view.
  • Panel B) shows a side view.
  • FIG. 2 shows a flow chart of an algorithm used to detect and analyze cardiac electrical activity data according to some embodiments of the present invention.
  • FIG. 3 shows an exemplarary recording of cardiac eletrical activity data according to some embodiments of the present invention.
  • FIG. 4 shows a template maternal electrocardiogram according to some embodiments of the present invention.
  • FIG. 5 shows a flow chart of an algorithm used to perform maternal cardiac activity elimination according to some embodiments of the present invention.
  • FIG. 6 shows a flow chart of an algorithm used to perform maternal cardiac activity elimination according to some embodiments of the present invention.
  • FIG. 7 shows an overlay of a template maternal electrocardiogram over a single maternal heart beat according to some embodiments of the present invention.
  • FIG. 8 shows an overlay of a template maternal electrocardiogram over a single maternal heart beat according to some embodiments of the present invention.
  • FIG. 9 shows the result of maternal ECG elimination of according to some embodiments of the present invention.
  • the present invention provides a system for detecting, recording and analyzing cardiac eletrical activity data from a pregnant mother carrying a fetus.
  • a plurality of ECG sensors is used to record the cardiac eletrical activity data.
  • ECG sensors, comprising electrodes that record cardiac eletrical activity data are attached to the abdomen of the pregnant mother.
  • the ECG sensors are directly attached.
  • the ECG sensors are incorporated into an article, such as, for example, a belt, a patch, and the like, and the article is worn by, or placed on, the pregnant mother.
  • ECG sensors are readily determined by one of ordinary skill in the art. Factors influencing sensor choice include, but are not limited to, the sensitivity of the electrodes, the size of the electrodes, the weight of the electrodes, and the like.
  • the ECG sensors are wet-contact electrodes. In some embodiments, the ECG sensors are dry contact electrodes.
  • the arrangement of the ECG sensors provides a system for recording, detecting and analyzing fetal cardiac eletrical activity data regardless of sensor position, fetal orientation, fetal movement, or gestational age.
  • the ECG sensors are attached, or positioned, on the abdomen of the pregnant mother in the configuration shown in FIG. 1 .
  • the ECG sensors are divided into channels comprising a pair of ECG sensors, and cardiac eletrical activity data is recorded simultaneously from the channels.
  • the channels output the acquired signal data, corresponding to the recorded cardiac eletrical activity data.
  • At least one ECG sensor pair is used to obtain the acquired signal data.
  • the number of acquired signal data is referred to as “N”.
  • the ability of the system to detect fetal cardiac eletrical activity data is increased by increasing the value of N.
  • the channels are specified as follows:
  • the signal data corresponding to fetal cardiac eletrical activity data are extracted from the acquired signal data.
  • Fetal cardiac activity elicits a semi-periodic electrical signal, typically from about 0.1 to 100 Hz. Frequently, signals corresponding to fetal cardiac activity are contaminated with other electrical signals, including maternal cardiac eletrical activity.
  • the signal elicited by maternal cardiac activity can be 10-fold greater than the fetal signal corresponding to fetal cardiac activity. See, for example, FIG. 3 , showing an exemplary recording of cardiac eletrical activity data, showing both maternal and fetal electrical activity combined.
  • the fetal cardiac eletrical activity data are extracted from the acquired signal data by a method comprising:
  • transformations refers to linear or non-linear mathematical transformations, which may include, inter alfa, digital filtering, mathematical linear or non-linear decomposition, mathematical optimization.
  • the fetal cardiac eletrical activity data are extracted from the acquired signal data using the algorithm shown in FIG. 2 .
  • the recorded signal data are pre-processed to remove noise (“Clean up signals”), then the peaks of the maternal cardiac electrical activity are detected (Detect Maternal Peaks”), the maternal cardiac activity signal data is removed (“Remove Maternal Signals”), then the resulting data is processed to remove noise (“Clean up signals”), then the peaks of the fetal cardiac electrical activity are detected (Detect Fetal Peaks”), to detect fetal cardiac activity.
  • the detected fetal activity data is then subsequently analyzed to calculate at least one of the parameters selected from the group consisting of: beat-to-beat fetal heart rate, fetal ECG, average fetal heart rate, and the variability of fetal heart rate.
  • the present invention provides a computer-implemented method, comprising: receiving, by at least one computer processor executing specific programmable instructions configured for the method, raw Electrocardiogram (ECG) signals data from at least one pair of ECG sensors; wherein the at least one pair of ECG sensors are positioned in on an abdomen of a woman carrying a fetus; wherein the raw ECG signals data comprise data representative of a N number of raw ECG signals data (raw N-ECG signals data) which are being acquired in real-time from the at least one pair of ECG sensors; digital signal filtering, by the at least one computer processor, the raw N-ECG signals data to form filtered N-ECG signals data having filtered N-ECG signals; detecting, by the at least one computer processor, maternal heart peaks in each filtered ECG signal in the filtered N-ECG signals data; subtracting, by the at least one computer processor, from each of N-ECG signal of the filtered N-ECG signals data, maternal ECG signal, by utilizing at least
  • the raw N-ECG signals data are preprocessed to remove noise, to generate filtered N-ECG signals data.
  • the preprocessing comprises applying a digital signaling filter selected from the group consisting of: a baseline wander filter, a power line frequency filter, and a high frequency filter.
  • the baseline wander filter is intended to remove low frequency compartments of the recorded signals and enhance fast time varying parts of the signal.
  • the baseline wander filter is a moving average filter with constant weights. In some embodiments, the moving average filter with a length of 501 milliseconds is used.
  • the baseline wander filter is a moving median filter.
  • the powerline frequency filter is intended to remove the power line interference that is picked up by the sensor pairs.
  • the cut-off frequency of powerline frequency filter is set to the powerline frequency of the geographical area where the system of the present invention is used. For example, if the system is used in Europe, in some embodiments, the cut-off frequency is 49.5 to 50.5 Hz. If the system is used in the USA, in some embodiments, the cut-off frequency is 59.5 to 60.5 Hz.
  • the cut-off frequency of the powerline frequency filter is ⁇ 10 Hz of the powerline frequency of the geographical area where the system of the present invention is used. In some embodiments, the cut-off frequency of the powerline frequency filter is ⁇ 5 Hz of the powerline frequency of the geographical area where the system of the present invention is used.
  • the high frequency filter is intended to remove very high frequency compartments from the acquired signals.
  • the high frequency filter is a digital low pass filter.
  • the digital low pass filter is used to attenuates the high frequency compartments of the acquired signals.
  • the digital low pass filter is a Chebyshev type I low pass filter.
  • the cutoff frequency of the low pass filter is set to 70 cycles/second.
  • the baseline ripple is 0.12 decibels.
  • the order is 12th order, 6 sections.
  • the high frequency filter is a smoothing filter.
  • the smoothing filter is used to attenuate the high frequency compartments of the raw N-ECG signals data.
  • the high frequency filter is an edge preserving filter.
  • the edge preserving filter is used to remove high frequency noise from the raw N-ECG signals data while preserving valuable information regarding the fetal and maternal ECG signals contained within the raw N-ECG signals data.
  • the edge preserving filter is an adaptive mean filter. In some embodiments, the edge preserving filter is an adaptive median filter.
  • an additional transformation is applied to the filtered N-ECG signals data.
  • a digital adaptive inverse-median filter is applied to the filtered N-ECG signals data to enhance the maternal ECG peaks.
  • FIG. 4 shows a depiction of the electrical activity during a cardiac contraction cycle.
  • the additional transformation comprises applying an adaptive median filter to the N filtered N-ECG signals data, and subtracting the result filtered N-ECG signals data.
  • the length of the adaptive median filter is selected to be constant. In some embodiments, the length is set to 100 samples.
  • the length of the adaptive median filter is adapted depending on the local characteristics of the maternal ECG peaks.
  • the term “local” refers to the signal recorded from a sensor positioned in at a particular location on the abdomen of the pregnant mother.
  • the local characteristics are the duration of the QRS segment of the maternal electrical activity during a cardiac contraction cycle.
  • the local characteristics are the duration of the ST segment of the maternal electrical activity during a cardiac contraction cycle.
  • the local characteristics are the duration of the PR segment of the maternal electrical activity during a cardiac contraction cycle.
  • an additional high pass filter is applied to the decomposed filtered N-ECG signals data.
  • the high pass filter is 5 th order at 1 Hz.
  • the decomposed N filtered signal data is examined by preliminary and simple peak detector. In some embodiments, the relative energy of the peaks is calculated (relative to the overall energy of the signal). In some embodiments, the decomposed filtered N-ECG signals data is given a quality score depending on this measure, decomposed filtered N-ECG signals data with a quality score of less than a threshold are excluded and the signals are examined for missing data and NaNs (characters that are non-numerical).
  • the quality score is assigned by calculating the relation (energy of peaks)/(Total energy of the filtered N-ECG signal). In some embodiments, the energy of the temporary peaks is calculated by calculating the root mean square of the detected peaks. In some embodiments, the energy of the signal is calculated by calculating the root mean square of the filtered N-ECG signals.
  • the threshold is any value from 0.3 to 0.9. In some embodiments, the threshold is 0.8.
  • maternal heart peaks in each filtered N-ECG signal in the filtered N-ECG signals data are detected and subtracted from each of N-ECG signal of the filtered N-ECG signals data, by utilizing at least one non-linear subtraction procedure to obtain corrected N-ECG signals data which comprise data representative of a N number of corrected ECG signals, wherein the at least one non-linear subtraction procedure comprises: iteratively performing: i) automatically dividing each ECG signal of N-ECG signals of the filtered N-ECG signals data into a plurality of ECG signal segments, 1) wherein each ECG signal segment of the plurality of ECG signal segments corresponds to a beat interval of a full heartbeat, and 2) wherein each beat interval is automatically determined based, at least in part on automatically detecting an onset value and an offset value of such beat interval; ii) automatically modifying each of the second plurality of filtered N-ECG signal segments to form a plurality of modified filtered N-ECG signal segments, wherein the
  • detecting of the maternal heart peaks in each filtered ECG signal in the filtered N-ECG signals data is performed based at least on: i) dividing each filtered ECG signal into a first plurality of ECG signal segments; ii) normalizing a filtered ECG signal in each ECG signal segment; iii) calculating a first derivative of the filtered ECG signal in each ECG signal segment; iv) finding local maternal heart peaks in each ECG signal segment based on determining a zero-crossing of the first derivative; and v) excluding the local maternal heart peaks having at least one of: 1) an absolute value which is less than a pre-determined local peak absolute threshold value; or 2) a distance between the local peaks is less than a pre-determined local peak distance threshold value.
  • the pre-determined similarity value is based on an Euclidian distance, wherein the set of parameters is a local minima solution to a non-linear least squares problem solved by at least one of: 1) minimizing a cost function taken as the Euclidian distance; 2) utilizing a Gauss-Newton algorithm; 3) utilizing a Steepest-Descent (Gradient-Descent) algorithm; or 4) utilizing a Levenberg-Marquardt algorithm.
  • the length of each segment is set at 10 seconds.
  • the length of each segment is selected automatically depending on the length of the recording.
  • the signal data in each segment is normalized by the absolute maximum value of the signal data. In some embodiments, the signal data in each segment is normalized by the absolute non-zero minimum value of the signal data.
  • a first order forward derivative is used. In some embodiments, a first order central derivative is used.
  • the threshold is selected to be a constant value of 0.3.
  • the threshold is selected depending on the local characteristics of the signal data.
  • the local characteristic of the signal is the median value of the signal data or any multiplication of this value. In some embodiments, the local characteristic of the signal is the mean value of the signal data or any multiplication of this value.
  • the threshold on the distance is selected to be 100 samples.
  • the local characteristics of the signal can be the maximum predicted RR internal or any multiple of this value.
  • a “peaks array” is generated from the filtered N-ECG signals data.
  • the peak array comprises the number of detected peaks for each of the segments of the filtered N-ECG signals data.
  • clustering is performed on the peaks array.
  • k-means clustering is used to group the peaks into a number of clusters.
  • k-medoids clustering is used to group the peaks into a number of clusters.
  • the number of clusters for the clustering is set to be three. In some embodiments, the number of clusters for the clustering is selected automatically depending on the characteristics of the processed N filtered signal data.
  • the clustering is used to exclude outliers.
  • outliers are peaks that have anomalous characteristics.
  • the characteristic is the distance between a peak and its neighboring peaks. In some embodiments, the characteristic is the amplitude of the peak.
  • a new peak array is constructed after the exclusion of the anomalous peaks.
  • the new peak array is further analyzed and the peaks are scored depending on the signal to noise ratio of the filtered N-ECG signals data.
  • the signal to noise ratio score is calculated by calculating the relative energy of the QRS complexes from the overall energy of the processed N filtered signal data.
  • the detected peaks for each of the filtered N-ECG signals data are fused for a more robust detection. In some embodiments, the fusion of the detected peaks is done using the scores given for each of the peaks of the filtered N-ECG signals data.
  • a global array of peaks is defined using the fused peaks.
  • the peaks of each of the filtered N-ECG signals data is redetected and the positions are refined using the global peaks array.
  • the global peak array is constructed based on the best lead with corrections made using the peaks from the other leads and the global peaks array is examined using physiological measures, such as, for example, RR intervals, HR, HRV).
  • the filtered N-ECG signals data is further transformed to eliminate the signals corresponding to maternal cardiac activity.
  • the transformations/corrections include applying non-linear subtraction to the filtered N-ECG signals data.
  • the remaining data comprises signal data corresponding to fetal cardiac activity and noise.
  • the non-linear subtraction procedure is applied separately for each one of the processed N filtered signal data. In some embodiments, the non-linear subtraction procedure is applied to all of the processed N filtered signal data in series, in any order. In some embodiments, the non-linear subtraction procedure is applied to all of the processed N filtered signal data simultaneously.
  • the non-linear subtraction comprises: dividing the processed N filtered signal data into a large number of segments; modifying each of the segments, separately or jointly, using an inverse optimization scheme; and eliminating the modified segments from the original processed N filtered signal data, thereby obtaining N raw fetal signal data.
  • segmentation refers to the division of the processed N filtered signal data into any given number of segments.
  • the number of segments is set to be a function of the number of the detected maternal peaks.
  • the function is the identity function so that the number of segments equals the number of the detected maternal peaks, in which case, each segment is a full heartbeat.
  • a beat interval is defined.
  • the term ‘beat interval’ used hereinafter refers the time interval of a single maternal heart beat.
  • the beat interval is taken to be constant and is defined as 500 milliseconds before the R-peak position and 500 milliseconds after the R-peak position.
  • the beat interval is detected automatically by detecting the beat onset and beat offset of each beat.
  • the beat interval depends on the local heart rate value and a more accurate segmentation of the ECG signal is achieved.
  • the beat interval onset is defined as the onset (i.e. starting point in time) of the P-wave.
  • the beat interval offset is defined as the offset (i.e. end point in time) of the T wave.
  • the beat interval onset for the current beat is defined as half the way, in time, between the previous beat and the current beat.
  • the beat interval offset for the current beat is defined as half the way, in time, between the current beat and the next beat.
  • a second segmentation step is performed on the result of the previous segmentation.
  • the product of this segmenting step is referred to as ‘in-beat segments’.
  • the number of in-beat segments is selected to be any integer number between one and the number of time samples in the current beat.
  • the number of in-beat segment can be three.
  • an automatic procedure is performed to detect the optimal number of in-beat segments.
  • the automatic procedure comprises using a Divide and Conquer algorithm, wherein each segment is divided into two equal sub-segments. If the energy content of a sub-segment exceeds a pre-defined relative threshold, the sub-segment itself is divided into two sub-segments and so on recursively.
  • the stop criterion can be reaching a minimum length of sub-segment, reaching a maximum number of segments or dividing into sub-segments such that all of them meet the energy threshold criterion.
  • the entropy measure is used to divide the segment into sub-segments. In this case, the entropy of each segment is minimized.
  • the result of the in-beat segmentation is the following seven segments:
  • the onset and offset of the QRS complex, for each of the beats in the ECG signal are automatically detected using a dedicated method comprising: applying a digital band pass filter to the filtered N-ECG signals data; calculating the curve length transform of the filtered N-ECG signals data; selecting the values of the data that are higher than a threshold; calculating the first derivative of the transformed data; finding the positive transitions and negative transitions in the derivative data; finding pairs of the positive-and-negative transition such that the distance between them, in time samples, is higher than a pre-selected threshold; setting the onset of the QRS complex as the position, in time, of the positive transition from the selected pair; and setting the offset of the QRS complex as the position in time of the negative transition from the selected pair.
  • the cutoff frequencies of the band pass filter are set to be 5 and 20 cycles/sec for the lower and upper frequencies respectively.
  • the threshold is set to be a constant value of 0.3. In some embodiments, the threshold value is calculated automatically depending of the local characteristics of the data after the curve length transform. In some embodiments, the local characteristic of the data is the mean value of the transformed data.
  • the segmentation also comprises an additional complementary transformation that comprises changing the sample rate of the signal by an integer value.
  • the additional complementary transformation reduces the variability of the resulting raw N-ECG fetal signals data caused by the fine positions of the onsets and offsets of the selected segments.
  • the sample rate is decreased by a factor of 4 to decrease the calculation time.
  • the sample rate is increased by a factor of 4.
  • increasing the sample rate is done using interpolation. In some embodiments, increasing the sample rate is done by zero padding the data and then applying a set of low pass FIR filters.
  • changing the sample rate of the signals is done before the segmentation procedure. In some embodiments, changing the sample rate is done after the segmentation. In these embodiments, the selected onsets and offsets of the different segments are refined depending on the signals after changing the sample rate.
  • the segmentation is updated depending on the convergence of the iterative methods in the next steps described hereinafter.
  • a “good fit” occurs when the difference between the adapted template and the measured potentials is very small.
  • very small is defined to be 10 ⁇ 5 or smaller.
  • “very small” is defined as 10 ⁇ 6 or smaller or 10 ⁇ 4 or smaller or 10 ⁇ 7 or smaller or other exponents of 10 or other numbers.
  • the values of a predefined set of parameters also include parameters that change the amplitude of a time signal.
  • an iterative scheme is used to determine the values of the set of the parameters, comprising: selecting starting conditions; assigning tentative values to the set of parameters; adapting the templates using the set of parameters; comparing the adapted templates to the measured potentials; checking if a stop criterion is reached; updating the values of the set of parameters if none of the stop criteria are reached, and repeating steps steps (c), (d), (e) and (f). In some embodiments, if a stop criterion is reached, the iterative procedure is terminated and the current set of parameters is deemed the optimal solution of the optimization problem.
  • the starting conditions are set to be the ECG templates.
  • two templates are defined: The first is a global template that is defined for every ECG beat (see, for example, FIG. 7 ), wherein the template is calculated as a weighted average of M beats.
  • M is an integer number between 2 and the total number of beats in the ECG signal.
  • the weights used in the weighted average are equal yielding a normal averaging.
  • the M beats fulfill the condition that the correlation coefficient between each of the beats should be higher than a threshold. In certain embodiments, the threshold is set to be 0.98.
  • the beats before the averaging, are shifted and fine aligned using the exact position of the R-wave, the QRS onset and the QRS offset.
  • the alignment procedure is done using the cross correlation function.
  • the M beats fulfill the condition that relation between the energy of the template, defined as an average of these beats, and the energy of the current ECG beat is bounded close to 1. However, in some embodiments, the relation between the energy of the template and the energy of the current ECG beat is higher than 1 by a small value or lower than 1 by a small value.
  • the second is a local template that is defined for each of the sub-segments in the current beat (see, for example, FIG. 8 ).
  • the template is calculated as the average of the sub-segments in the M-selected peaks.
  • the beats are selected to fulfill the conditions that the local heart rate is similar to the local heart rate for the current beat. By means of a non-limiting example, the heart rate values are close by a factor of 1.5.
  • the tentative values are set to random numbers. In some embodiments, the tentative values are set to be constant numbers; by means of a non-limiting example, they are set to be 1.
  • the tentative values are saved between different executions of the algorithm and used if available.
  • the different templates are adapted separately depending on the appropriate parameters that are assigned to the templates.
  • the templates are scaled by multiplying the templates vectors with the appropriate set of parameters.
  • the templates are shifted in time using the appropriate set of parameters.
  • the Euclidian distance is used to compare the two sets of vectors; the adapted templates and the measured potentials from the processed N filtered signal data.
  • the cost function is defined as the error energy function.
  • the cross correlation function is used to compare the adapted templates and measured potentials.
  • a “good fit” is a correlation of 0.95 or greater.
  • a maximum number of iterations is used as a stop criterion.
  • the threshold is set to be constant. By means of a non-limiting example, it is set to be 10 ⁇ 5 .
  • the threshold is calculated depending on the characteristics of the iterative procedure.
  • the characteristics of the iterative procedure is the maximum number of allowed iterations; in other embodiments, the characteristics of the iterative procedure is the used cost function, for example the Euclidian distance function; and still other embodiments, the characteristics of the iterative procedure is the number of time samples in the templates.
  • an improvement measure is used as a stop criterion.
  • the change in the set of parameters is used as an improvement measure. In some embodiments, if the values of the set of parameters does not change, or change slightly, the stop criterion is fulfilled.
  • the change in the value of the cost function e.g. the error energy function, is used as an improvement measure.
  • an optimization scheme is applied to update the values of the set of parameters.
  • the optimization problem when using the Euclidian distance as a similarity measure, becomes a non-linear least squares problem. In some embodiments, the solution of this problem gives the optimal set of parameters that minimizes the cost function taken as the Euclidian distance.
  • Gauss-Newton algorithm is used to solve the non-linear least squares problem.
  • the Steepest-Descent (Gradient-Descent) method is used to solve the non-linear least squares problem.
  • Gradient-Descent, Gauss-Newton algorithm and Levenberg-Marquardt algorithm are iterative methods that are repeated a number of times, potentially, bringing the Euclidian distance (the error energy function) to a local minima.
  • P k is the set of parameters at the k th iteration
  • ⁇ c (P k ) is the adapted version of the templates for the P k parameters
  • ⁇ i is the damping parameter in the Levenberg-Marquardt algorithm
  • ⁇ m is the measured potentials (measured ECG signals).
  • J k is the Jacobian matrix calculated for the set of parameters P k by altering the values of the parameters
  • eliminating the modified segments from the N raw signal data is achieved by subtracting the adapted templates from the measured potentials. In some embodiments, the subtraction results in N raw fetal signal data. In some embodiments, the N raw fetal signal data comprises noise and fetal cardiac electrical activity data.
  • maternal cardiac activity is eliminated using the algorithm shown in FIG. 5 .
  • maternal cardiac activity is eliminated using the algorithm shown in FIG. 6 .
  • FIG. 9 A representative result of maternal ECG elimination according to some embodiments of the present invention is shown in FIG. 9 .
  • raw fetal ECG signals data is extracted and analyzed by utilizing a Blind-Source-Separation (BSS) algorithm on (1) the filtered N-ECG signals data and (2) the corrected N-ECG signals data, wherein the raw fetal ECG signals data comprises a N number of fetal ECG signals (N-ECG fetal signals); processing, by the at least one computer processor, the raw fetal ECG signals data to improve a signal-to-noise ratio by at least: i) applying a band-pass filter within a range of 15-65 Hz to break the plurality of raw N-ECG fetal signals in to a plurality of frequency channels, ii) scoring an ECG fetal signal per channel based on a peak-2-mean analysis to identify a plurality of fetal heartbeat channels, wherein each fetal heartbeat channel corresponds to a particular fetal ECG fetal signal; and iii) selecting the identified plurality of fetal heartbeat channels into
  • BSS Blind
  • the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio comprises: i) applying a band-pass filter within a range of 15-65 Hz to break the plurality of N-ECG fetal signals in to a plurality of frequency channels, ii) scoring an ECG fetal signal per channel based on a peak-2-mean analysis to identify a plurality of fetal heartbeat channels, wherein each fetal heartbeat channel corresponds to a particular fetal ECG fetal signal; and iii) selecting the identified plurality of fetal heartbeat channels into filtered ECG fetal signals data, comprising a N number of filtered fetal ECG signals (filtered N-ECG fetal signals data).
  • the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio comprises: i) applying a band-pass filter within a range of 1-70 Hz to break the plurality of N-ECG fetal signals in to a plurality of frequency channels, ii) scoring an ECG fetal signal per channel based on a peak-2-mean analysis to identify a plurality of fetal heartbeat channels, wherein each fetal heartbeat channel corresponds to a particular fetal ECG fetal signal; and iii) selecting the identified plurality of fetal heartbeat channels into filtered ECG fetal signals data, comprising a N number of filtered fetal ECG signals (filtered N-ECG fetal signals data).
  • the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio comprises: i) applying a band-pass filter within a range of 5-70 Hz to break the plurality of N-ECG fetal signals in to a plurality of frequency channels, ii) scoring an ECG fetal signal per channel based on a peak-2-mean analysis to identify a plurality of fetal heartbeat channels, wherein each fetal heartbeat channel corresponds to a particular fetal ECG fetal signal; and iii) selecting the identified plurality of fetal heartbeat channels into filtered ECG fetal signals data, comprising a N number of filtered fetal ECG signals (filtered N-ECG fetal signals data).
  • the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio comprises: i) applying a band-pass filter within a range of 10-70 Hz to break the plurality of N-ECG fetal signals in to a plurality of frequency channels, ii) scoring an ECG fetal signal per channel based on a peak-2-mean analysis to identify a plurality of fetal heartbeat channels, wherein each fetal heartbeat channel corresponds to a particular fetal ECG fetal signal; and iii) selecting the identified plurality of fetal heartbeat channels into filtered ECG fetal signals data, comprising a N number of filtered fetal ECG signals (filtered N-ECG fetal signals data).
  • the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio comprises: i) applying a band-pass filter within a range of 1-65 Hz to break the plurality of N-ECG fetal signals in to a plurality of frequency channels, ii) scoring an ECG fetal signal per channel based on a peak-2-mean analysis to identify a plurality of fetal heartbeat channels, wherein each fetal heartbeat channel corresponds to a particular fetal ECG fetal signal; and iii) selecting the identified plurality of fetal heartbeat channels into filtered ECG fetal signals data, comprising a N number of filtered fetal ECG signals (filtered N-ECG fetal signals data).
  • the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio further comprises at least one of: 1) utilizing a Singular-Value-Decomposition (SVD) technique; or 2) utilizing a Wavelet-Denoising (WD) technique.
  • Singular-Value-Decomposition Singular-Value-Decomposition
  • WD Wavelet-Denoising
  • all of the raw N-ECG signals data are used in the BSS procedure so that the BSS procedure is applied to 2N signals. In other embodiments, only part of the raw N-ECG signals data is used in the BSS procedure so that the BSS procedure is applied to between N+1 signals and less than 2N signals.
  • PCA Principal Component Analysis
  • ICA Independent Component Analysis
  • the results of the BSS procedure is further analyzed to improve the signal to noise ratio of the signals.
  • the further analysis includes a band-pass filter in the range of 15-65 cycle/second.
  • the further analysis includes applying Singular-Value-Decomposition (SVD).
  • the further analysis includes applying Wavelet-Denoising.
  • the further analysis includes applying ‘peak-2-mean’ transformation, which in some versions is in a separate software module, that comprises:
  • the above ‘peak-2-mean transformation’ is applied separately to each signal (i.e. each of the 2N signals or each of the between N+1 and less than 2N signals).
  • fetal heart beat detection is performed.
  • the N raw fetal signal data are subjected the fetal peak detection procedure before the further analysis and in other embodiments the results of the further analysis subjected to the fetal peak detection procedure.
  • the analysis comprises: dividing the N filtered fetal signal data into segments; normalizing the signal data in each segment; calculating the first derivative of the normalized signal data; identifying the fetal ECG peaks within the normalized signal data by determining the zero-crossing of the first derivative; excluding peaks whose absolute value is less than a threshold pre-selected by the user; and excluding very close peaks where the distance between them is less than a threshold, thereby obtaining processed N filtered fetal signal data.
  • the length of each segment is set at 10 seconds.
  • the length of each segment is selected automatically depending on the length of the recording.
  • the signal data in each segment is normalized by the absolute maximum value of the signal data. In some embodiments, the signal data in each segment is normalized by the absolute non-zero minimum value of the signal data.
  • a first order forward derivative is used. In some embodiments, a first order central derivative is used.
  • the threshold is selected to be a constant value of 0.3.
  • the threshold is selected depending on the local characteristics of the signal data.
  • the local characteristic of the signal is the median value of the signal data or any multiplication of this value. In some embodiments, the local characteristic of the signal is the mean value of the signal data or any multiplication of this value.
  • the threshold on the distance is selected to be 100 samples.
  • the local characteristics of the signal can be the maximum predicted RR internal or any multiple of this value.
  • a “peaks array” is generated from the filtered N-ECG fetal signals data.
  • the peak array comprises the number of detected peaks for each of the segments of the filtered N-ECG fetal signals data.
  • clustering is performed on the peaks array.
  • k-means clustering is used to group the peaks into a number of clusters.
  • k-medoids clustering is used to group the peaks into a number of clusters.
  • the number of clusters for the clustering is set to be three. In some embodiments, the number of clusters for the clustering is selected automatically depending on the characteristics of the filtered N-ECG fetal signals data.
  • the clustering is used to exclude outliers.
  • outliers are peaks that have anomalous characteristics.
  • the characteristic is the distance between a peak and its neighboring peaks. In some embodiments, the characteristic is the amplitude of the peak.
  • a new peak array is constructed after the exclusion of the anomalous peaks.
  • the new peak array is further analyzed and the peaks are scored depending on the signal to noise ratio of the filtered N-ECG fetal signals data.
  • the signal to noise ratio score is calculated by calculating the relative energy of the QRS complexes from the overall energy of the filtered N-ECG fetal signals data.
  • the detected peaks for each of the filtered N-ECG fetal signals data are fused for a more robust detection.
  • the fusion of the detected peaks is done using the scores given for each of the peaks of filtered N-ECG fetal signals data.
  • a global array of peaks is defined using the fused peaks.
  • the peaks of each of the filtered N-ECG fetal signals data is redetected and the positions are refined using the global peaks array.
  • the global peak array is constructed based on the best lead with corrections made using the peaks from the other leads and the global peaks array is examined using physiological measures, such as, for example, RR intervals, HR, HRV).
  • the beat-to-beat fetal heart rate is extracted from the detected fetal peaks positions. In some embodiments, the fetal heart curve is also extracted from the detected fetal peak positions.
  • the fECG detection algorithm have the following low level design: 5.1.
  • the acquired N-channels signals should be preprocessed: 5.1.1.
  • Signal exclusion Saturated signals are excluded in this version (if the saturated part exceeds 10% of the overall length of the signal). For the next versions, this criterion should be replaced by an online examiner.
  • Baseline removal the baseline of the ECG signal needs to be removed. It can be removed using a number of methods. In the algorithm the baseline is removed using a moving average filter with an order of 501 (milliseconds). 5.1.3. Low pass filtering with an IIR filter (auto designed by Matlab): 5.1.3.1. Type: Chebyshev Type I 5.1.3.2.
  • Peak enhancement The preprocessed ECG data is passed through an additional median filter with an order of 100 samples to enhance the maternal peaks. 5.2.3. Peaks detection: for each signal: 5.2.3.1. Divide the signal into 10 seconds segments, for each segment:
  • step 1 After finishing, perform kmedoids clustering on the amplitudes of the peaks, very low peaks and very high peaks are filtered using this step. 5.2.3.6.
  • step 2 After finishing with the signal, do the following: 5.2.3.6.1. Check that the number of peaks falls into an expected interval (based on the maximum and minimum possible heart rates) 5.2.3.6.2. Is step 1 is passed, check that the relative energy of the QRS complexes is higher than a threshold 5.2.3.6.3. If step 2 is passed, perform peak redetection using the cross correlation method (helps removing false positive and adding false negatives) 5.2.4.
  • Peak re-detection if the previous step is failed to detect the peaks in at least one channel, apply ICA to the data and then repeat step (5.2.3) 5.2.5. Peaks examination: 5.2.5.1. A score is given for each one of the N signals. The best lead is defined as the lead with the biggest score 5.2.5.2. A global peak array is constructed based on the best lead with corrections made using the peaks from the other leads
  • a beat interval the beat interval is defined as, except for the first and last peaks, (1) beat onset: half the distance between the current peak and the previous peak and (2) beat offset: half the distance between the current peak and the next peak. Due to the beat-2-beat changing heart rate, the beat interval should change for each beat 5.3.3.2.
  • a local template a template that depends on the current beat: 5.3.3.2.1.
  • Step 1 Search for at least 10 beats that have a correlation coefficient (obtained from cross correlation) of at least 0.98 This step is usually fast and gives results for not- noisy signals 5.3.3.2.2.
  • Step 2 Step 1 usually fails for noisy signals hence an iterative scheme is used: 5.3.3.2.2.1.
  • the template as the beat itself 5.3.3.2.2.2.
  • An initial correlation coefficient is defined (high value threshold: 0.99) 5.3.3.2.2.3. Search for the beats that are very similar to the current beat (have higher correlation than the threshold) 5.3.3.2.2.4. If none is found, decrease the correlation threshold and repeat
  • This algorithm has the following characteristics: ⁇ It interpolates between Gauss - Newton (GN) method and the Gradient Decent (GD) method taking the good form both ⁇ At first, it convergence very fast due to the fast convergence of GD. When it advances, the steps become smaller, yielding a slow convergence when it is close to the local minimum (Slow yet cautious progress near the minimum);
  • Wavelet denoising is applied to the data 5.5.6.3. Windowed RMS is applied on the data 5.5.6.4. The results are low pass filtered @35 Hz 5.5.6.5. The data is normalized and AGC is applied to the data 5.5.7. Following step (5.5.6), perform fetal peak detection without the correlation part 5.5.8. Following step (5.5.7), if more than one channel is valid, calculate the kurtosis of the distribution of the distances between the peaks. The best lead is defined as the peak with the maximum relative kurtosis 5.5.9. Following step (5.5.8), perform peak redetection using the RR intervals. Also try to build, using a Kalman filter, an array of the positions of the peaks 5.5.10.
  • step (5.5/5.5.9) perform fetal peak examination using the information about the RR intervals 5.5.11.
  • step (5.5.10) build the fetal peaks array: 5.5.11.1.
  • Time varying RR interval is extracted from the results 5.5.11.2.
  • a characteristic region in the previous signal is defined: a region in which the RR interval curve is very smooth (which means that there is minimum falses in this region) - this region is called the seed region 5.5.11.3.

Landscapes

  • Health & Medical Sciences (AREA)
  • Life Sciences & Earth Sciences (AREA)
  • Cardiology (AREA)
  • Engineering & Computer Science (AREA)
  • General Health & Medical Sciences (AREA)
  • Public Health (AREA)
  • Pathology (AREA)
  • Physics & Mathematics (AREA)
  • Biomedical Technology (AREA)
  • Heart & Thoracic Surgery (AREA)
  • Medical Informatics (AREA)
  • Molecular Biology (AREA)
  • Surgery (AREA)
  • Animal Behavior & Ethology (AREA)
  • Veterinary Medicine (AREA)
  • Biophysics (AREA)
  • Physiology (AREA)
  • Signal Processing (AREA)
  • Pregnancy & Childbirth (AREA)
  • Gynecology & Obstetrics (AREA)
  • Artificial Intelligence (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • Psychiatry (AREA)
  • Pediatric Medicine (AREA)
  • Reproductive Health (AREA)
  • Power Engineering (AREA)
  • Measurement And Recording Of Electrical Phenomena And Electrical Characteristics Of The Living Body (AREA)
  • Measuring Pulse, Heart Rate, Blood Pressure Or Blood Flow (AREA)

Abstract

The invention provides systems and methods for monitoring the wellbeing of a fetus by the non-invasive detection and analysis of fetal cardiac electrical activity data.

Description

  • This application is a continuation of U.S. patent application Ser. No. 15/205,620, filed Jul. 8, 2016, which is a continuation of U.S. patent application Ser. No. 14/921,489, filed Oct. 23, 2015, which claims priority to U.S. Provisional Application No. 62/131,122, filed on Mar. 10, 2015, the entire contents of which is incorporated by reference herein.
  • FIELD OF THE INVENTION
  • The invention relates generally to systems and methods for monitoring the wellbeing of a fetus by the non-invasive detection and analysis of fetal cardiac electrical activity data.
  • BACKGROUND
  • Monitoring fetal cardiac can be useful to determine of the health of a fetus during pregnancy.
  • SUMMARY
  • In some embodiments, the present invention provides a computer-implemented method, comprising: receiving, by at least one computer processor executing specific programmable instructions configured for the method, raw Electrocardiogram (ECG) signals data from at least one pair of ECG sensors; wherein the at least one pair of ECG sensors are positioned in on an abdomen of a woman carrying a fetus; wherein the raw ECG signals data comprise data representative of a N number of raw ECG signals data (raw N-ECG signals data) which are being acquired in real-time from the at least one pair of ECG sensors; digital signal filtering, by the at least one computer processor, the raw N-ECG signals data to form filtered N-ECG signals data having filtered N-ECG signals; detecting, by the at least one computer processor, maternal heart peaks in each filtered ECG signal in the filtered N-ECG signals data; subtracting, by the at least one computer processor, from each of N-ECG signal of the filtered N-ECG signals data, maternal ECG signal, by utilizing at least one non-linear subtraction procedure to obtain corrected ECG signals data which comprise data representative of a N number of corrected ECG signals, wherein the at least one non-linear subtraction procedure comprises: iteratively performing: i) automatically dividing each ECG signal of N-ECG signals of the filtered N-ECG signals data into a plurality of ECG signal segments, 1) wherein each ECG signal segment of the plurality of ECG signal segments corresponds to a beat interval of a full heartbeat, and 2) wherein each beat interval is automatically determined based, at least in part on automatically detecting an onset value and an offset value of such beat interval; ii) automatically modifying each of the second plurality of filtered N-ECG signal segments to form a plurality of modified filtered N-ECG signal segments, wherein the modifying is performed using at least one inverse optimization scheme based on a set of parameters, wherein values of the set of parameters is determined based on: iteratively performing: 1) defining a global template based on a standard heartbeat profile of an adult human being, 2) setting a set of tentative values for a local template for each filtered N-ECG signal segment, 3) utilizing at least one optimization scheme to determine an adaptive template for each filtered N-ECG signal segment based on the local template being matched to the global template within a pre-determined similarity value; and iii) automatically eliminating the modified segments from each of the filtered N-ECG signals, by subtracting the adaptive template from the filtered N-ECG signal thereby generating each corrected ECG signal; extracting, by the at least one computer processor, raw fetal ECG signals data from the filtered N-ECG signals data based on the corrected ECG signals data, wherein the raw fetal ECG signals data comprises a N number of fetal ECG signals (raw N-ECG fetal signals data); processing, by the at least one computer processor, the raw N-ECG fetal signals data to improve a signal-to-noise ratio of the raw N-ECG fetal signals data to form filtered N-ECG fetal signals data; and detecting, by the at least one computer processor, fetal heart peaks in the filtered N-ECG fetal signals data; and calculating, by the at least one computer processor, based on detected fetal heart peaks, at least one of: i) fetal heart rate, ii) fetal heart curve, iii) beat-2-beat fetal heart rate, or iv) fetal heart rate variability; and outputting, by the at least one computer processor, a result of the calculating step.
  • In some embodiments, the digital signal filtering utilizes at least one of: i) a baseline wander filtering, ii) a power line frequency filtering, iii) a high frequency filtering, or iv) a digital adaptive inverse-median filtering.
  • In some embodiments, the filtered N-ECG signals data is data which, prior to the detecting the maternal peaks in the filtered N-ECG signals data, has been processed with at least one decomposition technique, wherein the at least one decomposition technique is selected from the group consisting of: a) Singular-Value-Decomposition (SVD), b) Principal-Component-Analysis (PCA), c) Independent-Component-Analysis (ICA), d) Wavelet-Decomposition (CWT), and e) any combination thereof.
  • In some embodiments, detecting of the maternal heart peaks in each filtered ECG signal in the filtered N-ECG signals data is performed based at least on: i) dividing each filtered ECG signal into a first plurality of ECG signal segments; ii) normalizing a filtered ECG signal in each ECG signal segment; iii) calculating a first derivative of the filtered ECG signal in each ECG signal segment; iv) finding local maternal heart peaks in each ECG signal segment based on determining a zero-crossing of the first derivative; and v) excluding the local maternal heart peaks having at least one of: 1) an absolute value which is less than a pre-determined local peak absolute threshold value; or 2) a distance between the local peaks is less than a pre-determined local peak distance threshold value.
  • In some embodiments, the pre-determined similarity value is based on an Euclidian distance, wherein the set of parameters is a local minima solution to a non-linear least squares problem solved by at least one of: 1) minimizing a cost function taken as the Euclidian distance; 2) utilizing a Gauss-Newton algorithm; 3) utilizing a Steepest-Descent (Gradient-Descent) algorithm; or 4) utilizing a Levenberg-Marquardt algorithm.
  • In some embodiments, the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio comprises: i) applying a band-pass filter within a range of 15-65 Hz to break the plurality of N-ECG fetal signals in to a plurality of frequency channels, ii) scoring an ECG fetal signal per channel based on a peak-2-mean analysis to identify a plurality of fetal heartbeat channels, wherein each fetal heartbeat channel corresponds to a particular fetal ECG fetal signal; and iii) selecting the identified plurality of fetal heartbeat channels into filtered ECG fetal signals data, comprising a N number of filtered fetal ECG signals (filtered N-ECG fetal signals data).
  • In some embodiments, the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio further comprises at least one of: 1) utilizing a Singular-Value-Decomposition (SVD) technique; or 2) utilizing a Wavelet-Denoising (WD) technique.
  • In some embodiments, the present invention provides a computer-implemented method, comprising: receiving, by at least one computer processor executing specific programmable instructions configured for the method, raw Electrocardiogram (ECG) signals data from at least one pair of ECG sensors; wherein the at least one pair of ECG sensors are positioned on an abdomen of a woman carrying a fetus; wherein the raw ECG signals data comprise data representative of a N number of raw ECG signals (raw N-ECG signals data) which are being acquired in real-time from the at least one pair of ECG sensors; digital signal filtering, by the at least one computer processor, the raw ECG signals data to form filtered N-ECG signals data having filtered N-ECG signals, wherein the digital signal filtering utilizes at least one of: i) a baseline wander filtering; ii) a power line frequency filtering; iii) a high frequency filtering; or iv) a digital adaptive inverse-median filtering; detecting, by the at least one computer processor, maternal heart peaks in each filtered N-ECG signals data in the filtered N-ECG signals data, by performing at least: i) dividing each filtered ECG signal into a first plurality of ECG signal segments; ii) normalizing a filtered ECG signal in each ECG signal segment; iii) calculating a first derivative of the filtered ECG signal in each ECG signal segment; iv) finding local maternal heart peaks in each ECG signal segment based on determining a zero-crossing of the first derivative; and v) excluding the local maternal heart peaks having at least one of: 1) an absolute value which is less than a pre-determined local peak absolute threshold value; or 2) a distance between the local peaks is less than a pre-determined local peak distance threshold value; subtracting, by the at least one computer processor, from each of filtered N-ECG signal of the filtered N-ECG signals data, the maternal ECG signal, by utilizing at least one non-linear subtraction procedure to obtain corrected N-ECG signals data which comprise data representative of a N number of corrected ECG signals, wherein the at least one non-linear subtraction procedure comprises: iteratively performing: i) automatically dividing each ECG signal of filtered N-ECG signals data into a second plurality of ECG signal segments, 1) wherein each ECG signal segment of the second plurality of ECG signal segments corresponds to a beat interval of a full heartbeat; 2) wherein each beat interval is automatically determined based, at least in part on automatically detecting an onset value and an offset value of such beat interval, and 3) wherein the automatically detecting of the onset value and the offset value of each beat interval is based, at least in part, on: a) a number of maternal peaks detected in each ECG signal, b) changing a sample rate of each ECG signal by an integer number, c) an onset of each P-wave, d) an offset of each T-wave, and e) in-beat segmentation; ii) automatically modifying each of the second plurality of filtered N-ECG signal segments to form a plurality of modified filtered N-ECG signal segments, wherein the modifying is performed using at least one inverse optimization scheme based on a set of parameters, wherein values of the set of parameters is determined based on: iteratively performing: 1) defining a global template based on a standard heartbeat profile of an adult human being; 2) setting a set of tentative values for a local template for each filtered N-ECG signal segment; and utilizing at least one optimization scheme to determine an adaptive template for each filtered N-ECG signal segment based on the local template being matched to the global template within a pre-determined similarity value; and iii) automatically eliminating the modified segments from each the filtered N-ECG signals, by subtracting the adaptive template from the filtered N-ECG signal thereby generating each corrected ECG signal, thereby generating corrected N-ECG signals data; extracting, by the at least one computer processor, raw fetal ECG signals data, by utilizing a Blind-Source-Separation (BSS) algorithm on (1) the filtered N-ECG signals data and (2) the corrected N-ECG signals data, wherein the raw fetal ECG signals data comprises a N number of fetal ECG signals (N-ECG fetal signals); processing, by the at least one computer processor, the raw fetal ECG signals data to improve a signal-to-noise ratio by at least: i) applying a band-pass filter within a range of 15-65 Hz to break the plurality of raw N-ECG fetal signals in to a plurality of frequency channels, ii) scoring an ECG fetal signal per channel based on a peak-2-mean analysis to identify a plurality of fetal heartbeat channels, wherein each fetal heartbeat channel corresponds to a particular fetal ECG fetal signal; and iii) selecting the identified plurality of fetal heartbeat channels into filtered fetal ECG signals data, comprising a N number of filtered fetal ECG signals (filtered N-ECG fetal signals data); detecting, by the at least one computer processor, fetal heart peaks in the filtered N-ECG fetal signals data, by performing at least: i) dividing each filtered N-ECG fetal signal into a first plurality of fetal ECG signal segments; ii) normalizing a filtered fetal ECG signal in each fetal ECG signal segment; iii) calculating a first derivative of the filtered fetal ECG signal in each fetal ECG signal segment; and iv) finding local fetal heart peaks in each fetal ECG signal segment based on determining a zero-crossing of the first derivative; calculating, by the at least one computer processor, based on detected fetal heart peaks, at least one of: i) fetal heart rate, ii) fetal heart curve, iii) beat-2-beat fetal heart rate, or iv) fetal heart rate variability; and outputting, by the at least one computer processor , a result of the calculating step.
  • In some embodiments, the baseline wander filtering comprises utilizing at least one of: 1) a moving average filter having constant weights, or 2) a moving median filter.
  • In some embodiments, the power line frequency filtering comprises utilizing at least one of: 1) a band-stop digital filter; or 2) a digital adaptive filter.
  • In some embodiments, the high frequency filtering comprises utilizing at least one of: 1) a digital low pass filter; 2) a cutoff frequency of at least 70 cycles per second; 3) a smoothing filter; 4) or an edge-preserving filter.
  • In some embodiments, the edge-preserving filter is one of: a) an adaptive mean filter; or b) an adaptive median filter.
  • In some embodiments, the digital adaptive inverse-median filtering comprises utilizing an adaptive median filter, having a length to be: 1) a constant value, or 2) adapted depending on at least one local characteristic of the ECG signals data.
  • In some embodiments, the at least one local characteristic is a duration of at least one of: a) a QRS complex; b) a ST segment; or c) a PR interval.
  • In some embodiments, the filtered N-ECG signals data is data which, prior to the detecting the maternal peaks in the filtered N-ECG signals data, has been processed with at least one decomposition technique, wherein the at least one decomposition technique is selected from the group consisting of: a) Singular-Value-Decomposition (SVD); b) Principal-Component-Analysis (PCA); c) Independent-Component-Analysis (ICA); d) Wavelet-Decomposition (CWT), and e) any combination thereof.
  • In some embodiments, the pre-determined similarity value is based on an Euclidian distance, wherein the set of parameters is a local minima solution to a non-linear least squares problem solved by at least one of: 1) minimizing a cost function taken as the Euclidian distance; 2) utilizing a Gauss-Newton algorithm; 3) utilizing a Steepest-Descent (Gradient-Descent) algorithm; or 4) utilizing a Levenberg-Marquardt algorithm.
  • In some embodiments, the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio further comprises at least one of: 1) utilizing a Singular-Value-Decomposition (SVD) technique; or 2) utilizing a Wavelet-Denoising (WD) technique.
  • In some embodiments, the at least one pair of ECG sensors is selected from the group consisting of: at least one of a wet contact ECG electrode; and at least one dry contact ECG electrode.
  • In some embodiments, a number of in-beat segments in the in-beat segmentation is based on utilizing at least one of the following: 1) a Divide and Conquer algorithm; or 2) a digital band pass filter.
  • In some embodiments, the number of in-beat segments is three and are defined as follows: 1) a first in-beat segment defined from the onset value of a particular beat interval to an onset of a QRS complex; 2) a second in-beat segment defined to be the QRS complex; and 3) a third in-beat segment defined from an offset of the QRS complex to the offset value of the particular beat interval.
  • In some embodiments, the present invention provides a specifically programmed computer system, comprising: at least one specialized computer machine, comprising: a non-transient memory, electronically storing particular computer executable program code; and at least one computer processor which, when executing the particular program code, becomes a specifically programmed computing processor that is configured to at least perform the following operations: receiving raw Electrocardiogram (ECG) signals data from at least one pair of ECG sensors; wherein the at least one pair of ECG sensors is positioned in on an abdomen of a woman carrying a fetus; wherein the raw ECG signals data comprise data representative of a N number of raw ECG signals (raw N-ECG signals data) which are being acquired in real-time from the at least one pair of ECG sensors; digital signal filtering the raw ECG signals data to form filtered N-ECG signals data having filtered N-ECG signals; detecting maternal heart peaks in each of the filtered N-ECG signal in the filtered N-ECG signals data; subtracting, from each of the filtered N-ECG signal of the filtered N-ECG signals data, the maternal ECG signal, by utilizing at least one non-linear subtraction procedure to obtain corrected ECG signals data which comprise data representative of a N number of corrected ECG signals (corrected N-ECG signals data), wherein the at least one non-linear subtraction procedure comprises: iteratively performing: i) dividing each filtered N-ECG signal of N-ECG signals of the filtered N-ECG signals data into a second plurality of ECG signal segments,) wherein each ECG signal segment of the plurality of ECG signal segments corresponds to a beat interval of a full heartbeat, and 2) wherein each beat interval is automatically determined based, at least in part on automatically detecting an onset value and an offset value of such beat interval; ii) modifying each of the plurality of filtered N-ECG signal segments to form a plurality of modified filtered N-ECG signal segments, wherein the modifying is performed using at least one inverse optimization scheme based on a set of parameters, wherein values of the set of parameters is determined based on: iteratively performing: 1) defining a global template based on a standard heartbeat profile of an adult human being; 2) setting a set of tentative values for a local template for each filtered N-ECG signal segment; and 3) utilizing at least one optimization scheme to determine an adaptive template for each filtered N-ECG signal segment based on the local template being matched to the global template within a pre-determined similarity value; and iii) eliminating the modified segments from each of the filtered N-ECG signals, by subtracting the adaptive template from the filtered N-ECG signal thereby generating each corrected ECG signal; extracting raw fetal ECG signals data from the filtered N-ECG signals data based on the corrected ECG signals data, wherein the raw fetal ECG signals data comprises a N number of fetal ECG signals (raw N-ECG fetal signals data); processing the raw N-ECG fetal signals data to improve a signal-to-noise ratio of the N-ECG fetal signals to form filtered N-ECG fetal signals data; detecting fetal heart peaks in the filtered N-ECG fetal signals data; calculating, based on detected fetal heart peaks, at least one of: i) fetal heart rate, ii) fetal heart curve, iii) beat-2-beat fetal heart rate, or iv) fetal heart rate variability; and outputting a result of the calculating operation.
  • In some embodiments, the present invention provides a specifically programmed computer system, comprising: at least one specialized computer machine, comprising: a non-transient memory, electronically storing particular computer executable program code; and at least one computer processor which, when executing the particular program code, becomes a specifically programmed computing processor that is configured to at least perform the following operations: receiving raw Electrocardiogram (ECG) signals data from at least one pair of ECG sensors; wherein the at least one pair of ECG sensors is positioned on an abdomen of a woman carrying a fetus; wherein the raw ECG signals data comprise data representative of a N number of raw ECG signals (raw N-ECG signals data) which are being acquired in real-time from the at least one pair of ECG sensors; digital signal filtering the raw ECG signals data to form filtered N-ECG signals data having filtered N-ECG signals, wherein the digital signal filtering utilizes at least one of: i) a baseline wander filtering; ii) a power line frequency filtering; iii) a high frequency filtering; or iv) a digital adaptive inverse-median filtering; detecting maternal heart peaks in each filtered N-ECG signal in the filtered N-ECG signals data, by performing at least: i) dividing each filtered N-ECG signal into a first plurality of ECG signal segments; ii) normalizing a filtered ECG signal in each ECG signal segment; iii) calculating a first derivative of the filtered ECG signal in each ECG signal segment; iv) finding local maternal heart peaks in each ECG signal segment based on determining a zero-crossing of the first derivative; and v) excluding the local maternal heart peaks having at least one of: 1) an absolute value which is less than a pre-determined local peak absolute threshold value; or 2) a distance between the local peaks is less than a pre-determined local peak distance threshold value; subtracting, from each of the filtered N-ECG signals of the filtered N-ECG signals data, the maternal ECG signal, by utilizing at least one non-linear subtraction procedure to obtain corrected ECG signals data which comprise data representative of a N number of corrected ECG signals (corrected N-ECG signals data), wherein the at least one non-linear subtraction procedure comprises: iteratively performing: i) dividing each ECG signal of the filtered N-ECG signals of the filtered N-ECG signals data into a second plurality of ECG signal segments; 1) wherein each ECG signal segment of the second plurality of ECG signal segments corresponds to a beat interval of a full heartbeat; 2) wherein each beat interval is automatically determined based, at least in part on automatically detecting an onset value and an offset value of such beat interval; and 3) wherein the automatically detecting of the onset value and the offset value of each beat interval is based, at least in part, on: a) a number of maternal peaks detected in each ECG signal; b) changing a sample rate of each ECG signal by an integer number; c) an onset of each P-wave; d) an offset of each T-wave; or e) in-beat segmentation; ii) modifying each of the second plurality of filtered N-ECG signal segments to form a plurality of modified filtered N-ECG signal segments, wherein the modifying is performed using at least one inverse optimization scheme based on a set of parameters, wherein values of the set of parameters is determined based on: iteratively performing: 1) defining a global template based on a standard heartbeat profile of an adult human being; 2) setting a set of tentative values for a local template for each filtered N-ECG signal segment; and 3) utilizing at least one optimization scheme to determine an adaptive template for each filtered N-ECG signal segment based on the local template being matched to the global template within a pre-determined similarity value; and iii) eliminating the modified segments from each the filtered N-ECG signals, by subtracting the adaptive template from the filtered N-ECG signal thereby generating each corrected ECG signal; extracting raw fetal ECG signals data, by utilizing a Blind-Source-Separation (BSS) algorithm on (1) the filtered N-ECG signals data and (2) the corrected N-ECG signals data, wherein the raw fetal ECG signals data comprises a N number of fetal ECG signals (raw N-ECG fetal signals data); processing the raw N-ECG fetal signals data to improve a signal-to-noise ratio by at least: i) applying a band-pass filter within a range of 15-65 Hz to break the plurality of raw N-ECG fetal signals in to a plurality of frequency channels, ii) scoring an ECG fetal signal per channel based on a peak-2-mean analysis to identify a plurality of fetal heartbeat channels, wherein each fetal heartbeat channel corresponds to a particular fetal ECG fetal signal; and iii) selecting the identified plurality of fetal heartbeat channels into filtered fetal ECG signals data, comprising a N number of filtered fetal ECG signals (filtered N-ECG fetal signals data); detecting fetal heart peaks in the filtered N-ECG fetal signals data, by performing at least: i) dividing each filtered fetal N-ECG signal into a first plurality of fetal ECG signal segments; ii) normalizing a filtered fetal ECG signal in each fetal ECG signal segment; iii) calculating a first derivative of the filtered fetal ECG signal in each fetal ECG signal segment; and iv) finding local fetal heart peaks in each fetal ECG signal segment based on determining a zero-crossing of the first derivative; calculating based on detected fetal heart peaks, at least one of: i) fetal heart rate, ii) fetal heart curve, iii) beat-2-beat fetal heart rate, or iv) fetal heart rate variability; and outputting a result of the calculating operation.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIGS. 1A-1B shows the positions of the sensor pairs on the abdomen of a pregnant woman according to some embodiments of the present invention. Panel A) shows a front view. Panel B) shows a side view.
  • FIG. 2 shows a flow chart of an algorithm used to detect and analyze cardiac electrical activity data according to some embodiments of the present invention.
  • FIG. 3 shows an exemplarary recording of cardiac eletrical activity data according to some embodiments of the present invention.
  • FIG. 4 shows a template maternal electrocardiogram according to some embodiments of the present invention.
  • FIG. 5 shows a flow chart of an algorithm used to perform maternal cardiac activity elimination according to some embodiments of the present invention.
  • FIG. 6 shows a flow chart of an algorithm used to perform maternal cardiac activity elimination according to some embodiments of the present invention.
  • FIG. 7 shows an overlay of a template maternal electrocardiogram over a single maternal heart beat according to some embodiments of the present invention.
  • FIG. 8 shows an overlay of a template maternal electrocardiogram over a single maternal heart beat according to some embodiments of the present invention.
  • FIG. 9 shows the result of maternal ECG elimination of according to some embodiments of the present invention.
  • DETAILED DESCRIPTION
  • For clarity of disclosure, and not by way of limitation, the detailed description of the invention is divided into the following subsections that describe or illustrate certain features, embodiments or applications of the present invention.
  • In some embodiments, the present invention provides a system for detecting, recording and analyzing cardiac eletrical activity data from a pregnant mother carrying a fetus. In some embodiments, a plurality of ECG sensors is used to record the cardiac eletrical activity data. In some embodiments, ECG sensors, comprising electrodes that record cardiac eletrical activity data are attached to the abdomen of the pregnant mother. In some embodiments, the ECG sensors are directly attached. In some embodiments, the ECG sensors are incorporated into an article, such as, for example, a belt, a patch, and the like, and the article is worn by, or placed on, the pregnant mother.
  • The choice of ECG sensors is readily determined by one of ordinary skill in the art. Factors influencing sensor choice include, but are not limited to, the sensitivity of the electrodes, the size of the electrodes, the weight of the electrodes, and the like.
  • In some embodiments, the ECG sensors are wet-contact electrodes. In some embodiments, the ECG sensors are dry contact electrodes.
  • In some embodiments, the arrangement of the ECG sensors provides a system for recording, detecting and analyzing fetal cardiac eletrical activity data regardless of sensor position, fetal orientation, fetal movement, or gestational age. In some embodiments, the ECG sensors are attached, or positioned, on the abdomen of the pregnant mother in the configuration shown in FIG. 1. In some embodiments, the ECG sensors are divided into channels comprising a pair of ECG sensors, and cardiac eletrical activity data is recorded simultaneously from the channels. In some embodiments, the channels output the acquired signal data, corresponding to the recorded cardiac eletrical activity data.
  • In some embodiments, at least one ECG sensor pair is used to obtain the acquired signal data. In some embodiments, the number of acquired signal data is referred to as “N”. In some embodiments, the ability of the system to detect fetal cardiac eletrical activity data is increased by increasing the value of N. For example, by way of a non-limiting illustration, in some embodiments, the channels are specified as follows:
  • 1. B1-B3
  • 2. B1-B2
  • 3. B2-B3
  • 4. A1-A4
  • 5. A2-A3
  • 6. A2-A4
  • In some embodiments, the signal data corresponding to fetal cardiac eletrical activity data are extracted from the acquired signal data.
  • Fetal cardiac activity elicits a semi-periodic electrical signal, typically from about 0.1 to 100 Hz. Frequently, signals corresponding to fetal cardiac activity are contaminated with other electrical signals, including maternal cardiac eletrical activity. The signal elicited by maternal cardiac activity can be 10-fold greater than the fetal signal corresponding to fetal cardiac activity. See, for example, FIG. 3, showing an exemplary recording of cardiac eletrical activity data, showing both maternal and fetal electrical activity combined.
  • In some embodiments, the fetal cardiac eletrical activity data are extracted from the acquired signal data by a method comprising:
      • a. obtaining raw N-ECG signals data by recording electrical activity from the abdomen of a pregnant mother carrying a fetus using at least one ECG sensor pair;
      • b. applying a set of linear and no-linear mathematical transformations to the raw N-ECG signals data, thereby obtaining transformed/corrected N-ECG signals data; and
      • c. finding features in the transformed/corrected N-ECG signals data that correlates to fetal or maternal cardiac electrical activity.
  • The term “transformations” as used herein refers to linear or non-linear mathematical transformations, which may include, inter alfa, digital filtering, mathematical linear or non-linear decomposition, mathematical optimization.
  • In some embodiments, the fetal cardiac eletrical activity data are extracted from the acquired signal data using the algorithm shown in FIG. 2. Using the algorithm shown in FIG. 2, the recorded signal data are pre-processed to remove noise (“Clean up signals”), then the peaks of the maternal cardiac electrical activity are detected (Detect Maternal Peaks”), the maternal cardiac activity signal data is removed (“Remove Maternal Signals”), then the resulting data is processed to remove noise (“Clean up signals”), then the peaks of the fetal cardiac electrical activity are detected (Detect Fetal Peaks”), to detect fetal cardiac activity. The detected fetal activity data is then subsequently analyzed to calculate at least one of the parameters selected from the group consisting of: beat-to-beat fetal heart rate, fetal ECG, average fetal heart rate, and the variability of fetal heart rate.
  • In some embodiments, the present invention provides a computer-implemented method, comprising: receiving, by at least one computer processor executing specific programmable instructions configured for the method, raw Electrocardiogram (ECG) signals data from at least one pair of ECG sensors; wherein the at least one pair of ECG sensors are positioned in on an abdomen of a woman carrying a fetus; wherein the raw ECG signals data comprise data representative of a N number of raw ECG signals data (raw N-ECG signals data) which are being acquired in real-time from the at least one pair of ECG sensors; digital signal filtering, by the at least one computer processor, the raw N-ECG signals data to form filtered N-ECG signals data having filtered N-ECG signals; detecting, by the at least one computer processor, maternal heart peaks in each filtered ECG signal in the filtered N-ECG signals data; subtracting, by the at least one computer processor, from each of N-ECG signal of the filtered N-ECG signals data, maternal ECG signal, by utilizing at least one non-linear subtraction procedure to obtain corrected ECG signals data which comprise data representative of a N number of corrected ECG signals, wherein the at least one non-linear subtraction procedure comprises: iteratively performing: i) automatically dividing each ECG signal of N-ECG signals of the filtered N-ECG signals data into a plurality of ECG signal segments, 1) wherein each ECG signal segment of the plurality of ECG signal segments corresponds to a beat interval of a full heartbeat, and 2) wherein each beat interval is automatically determined based, at least in part on automatically detecting an onset value and an offset value of such beat interval; ii) automatically modifying each of the second plurality of filtered N-ECG signal segments to form a plurality of modified filtered N-ECG signal segments, wherein the modifying is performed using at least one inverse optimization scheme based on a set of parameters, wherein values of the set of parameters is determined based on: iteratively performing: 1) defining a global template based on a standard heartbeat profile of an adult human being, 2) setting a set of tentative values for a local template for each filtered N-ECG signal segment, 3) utilizing at least one optimization scheme to determine an adaptive template for each filtered N-ECG signal segment based on the local template being matched to the global template within a pre-determined similarity value; and iii) automatically eliminating the modified segments from each of the filtered N-ECG signals, by subtracting the adaptive template from the filtered N-ECG signal thereby generating each corrected ECG signal; extracting, by the at least one computer processor, raw fetal ECG signals data from the filtered N-ECG signals data based on the corrected ECG signals data, wherein the raw fetal ECG signals data comprises a N number of fetal ECG signals (raw N-ECG fetal signals data); processing, by the at least one computer processor, the raw N-ECG fetal signals data to improve a signal-to-noise ratio of the raw N-ECG fetal signals data to form filtered N-ECG fetal signals data; and detecting, by the at least one computer processor, fetal heart peaks in the filtered N-ECG fetal signals data; and calculating, by the at least one computer processor, based on detected fetal heart peaks, at least one of: i) fetal heart rate, ii) fetal heart curve, iii) beat-2-beat fetal heart rate, or iv) fetal heart rate variability; and outputting, by the at least one computer processor, a result of the calculating step.
  • Pre-Processing of the Acquired Signal Data
  • In some embodiments, the raw N-ECG signals data are preprocessed to remove noise, to generate filtered N-ECG signals data. In some embodiments, the preprocessing comprises applying a digital signaling filter selected from the group consisting of: a baseline wander filter, a power line frequency filter, and a high frequency filter.
  • In some embodiments, the baseline wander filter is intended to remove low frequency compartments of the recorded signals and enhance fast time varying parts of the signal.
  • In some embodiments, the baseline wander filter is a moving average filter with constant weights. In some embodiments, the moving average filter with a length of 501 milliseconds is used.
  • In some embodiments, the baseline wander filter is a moving median filter.
  • In some embodiments, the powerline frequency filter is intended to remove the power line interference that is picked up by the sensor pairs. In some embodiments, the cut-off frequency of powerline frequency filter is set to the powerline frequency of the geographical area where the system of the present invention is used. For example, if the system is used in Europe, in some embodiments, the cut-off frequency is 49.5 to 50.5 Hz. If the system is used in the USA, in some embodiments, the cut-off frequency is 59.5 to 60.5 Hz.
  • In some embodiments, the cut-off frequency of the powerline frequency filter is ±10 Hz of the powerline frequency of the geographical area where the system of the present invention is used. In some embodiments, the cut-off frequency of the powerline frequency filter is ±5 Hz of the powerline frequency of the geographical area where the system of the present invention is used.
  • In some embodiments, a Butterworth type band-step filter with a cut-off frequency of 49.5 to 50.5 Hz whose order is 10th order, 5 sections is used. In some embodiments, a band-stop digital filter is used to attenuate the frequency components of the power line interference. In some embodiments, a digital adaptive filter is used to automatically determine the exact power line frequency before applying the band-stop filter.
  • In some embodiments, the high frequency filter is intended to remove very high frequency compartments from the acquired signals. In some embodiments, the high frequency filter is a digital low pass filter. In some embodiments, the digital low pass filter is used to attenuates the high frequency compartments of the acquired signals. In some embodiments, the digital low pass filter is a Chebyshev type I low pass filter.
  • In some embodiments, the cutoff frequency of the low pass filter is set to 70 cycles/second. In some embodiments, the baseline ripple is 0.12 decibels. In some embodiments, the order is 12th order, 6 sections.
  • In some embodiments, the high frequency filter is a smoothing filter. In some embodiments, the smoothing filter is used to attenuate the high frequency compartments of the raw N-ECG signals data.
  • In some embodiments, the high frequency filter is an edge preserving filter. In some embodiments, the edge preserving filter is used to remove high frequency noise from the raw N-ECG signals data while preserving valuable information regarding the fetal and maternal ECG signals contained within the raw N-ECG signals data. In some embodiments, the edge preserving filter is an adaptive mean filter. In some embodiments, the edge preserving filter is an adaptive median filter.
  • In some embodiments, an additional transformation is applied to the filtered N-ECG signals data. In some embodiments, a digital adaptive inverse-median filter is applied to the filtered N-ECG signals data to enhance the maternal ECG peaks.
  • The term “maternal ECG peaks” as used herein refers any of the P, Q, R, S or T waves of the electrical activity during a cardiac contraction cycle. FIG. 4 shows a depiction of the electrical activity during a cardiac contraction cycle.
  • In some embodiments, the additional transformation comprises applying an adaptive median filter to the N filtered N-ECG signals data, and subtracting the result filtered N-ECG signals data.
  • In some embodiments, the length of the adaptive median filter is selected to be constant. In some embodiments, the length is set to 100 samples.
  • In some embodiments, the length of the adaptive median filter is adapted depending on the local characteristics of the maternal ECG peaks.
  • As used herein, the term “local” refers to the signal recorded from a sensor positioned in at a particular location on the abdomen of the pregnant mother.
  • In some embodiments, the local characteristics are the duration of the QRS segment of the maternal electrical activity during a cardiac contraction cycle.
  • In some embodiments, the local characteristics are the duration of the ST segment of the maternal electrical activity during a cardiac contraction cycle.
  • In some embodiments, the local characteristics are the duration of the PR segment of the maternal electrical activity during a cardiac contraction cycle.
  • In some embodiments, the additional transformation comprises a decomposition to filtered N-ECG signals data to improve the signal to noise ratio. In some embodiments, the decomposition is a singular value decomposition (SVD). In some embodiments, the decomposition is principle component analysis (PCA). In some embodiments, the decomposition is independent component analysis (ICA). In some embodiments, the decomposition is wavelet decomposition (CWT).
  • In some embodiments, an additional high pass filter is applied to the decomposed filtered N-ECG signals data. In some embodiments, the high pass filter is 5th order at 1 Hz. In some embodiments, the decomposed N filtered signal data is examined by preliminary and simple peak detector. In some embodiments, the relative energy of the peaks is calculated (relative to the overall energy of the signal). In some embodiments, the decomposed filtered N-ECG signals data is given a quality score depending on this measure, decomposed filtered N-ECG signals data with a quality score of less than a threshold are excluded and the signals are examined for missing data and NaNs (characters that are non-numerical).
  • In some embodiments, the quality score is assigned by calculating the relation (energy of peaks)/(Total energy of the filtered N-ECG signal). In some embodiments, the energy of the temporary peaks is calculated by calculating the root mean square of the detected peaks. In some embodiments, the energy of the signal is calculated by calculating the root mean square of the filtered N-ECG signals.
  • In some embodiments, the threshold is any value from 0.3 to 0.9. In some embodiments, the threshold is 0.8.
  • Detection of the Portion of the Acquired Signals Corresponding to Maternal Cardiac Activity from the Filtered N-ECG Signals Data and Elimination of the Signals Corresponding to Maternal Cardiac Activity from the Filtered N-ECG Signals Data
  • In some embodiments, maternal heart peaks in each filtered N-ECG signal in the filtered N-ECG signals data are detected and subtracted from each of N-ECG signal of the filtered N-ECG signals data, by utilizing at least one non-linear subtraction procedure to obtain corrected N-ECG signals data which comprise data representative of a N number of corrected ECG signals, wherein the at least one non-linear subtraction procedure comprises: iteratively performing: i) automatically dividing each ECG signal of N-ECG signals of the filtered N-ECG signals data into a plurality of ECG signal segments, 1) wherein each ECG signal segment of the plurality of ECG signal segments corresponds to a beat interval of a full heartbeat, and 2) wherein each beat interval is automatically determined based, at least in part on automatically detecting an onset value and an offset value of such beat interval; ii) automatically modifying each of the second plurality of filtered N-ECG signal segments to form a plurality of modified filtered N-ECG signal segments, wherein the modifying is performed using at least one inverse optimization scheme based on a set of parameters, wherein values of the set of parameters is determined based on: iteratively performing: 1) defining a global template based on a standard heartbeat profile of an adult human being, 2) setting a set of tentative values for a local template for each filtered N-ECG signal segment, 3) utilizing at least one optimization scheme to determine an adaptive template for each filtered N-ECG signal segment based on the local template being matched to the global template within a pre-determined similarity value; and iii) automatically eliminating the modified segments from each of the filtered N-ECG signals, by subtracting the adaptive template from the filtered N-ECG signal thereby generating each corrected ECG signal.
  • Examples of adaptive templates according to some embodiments of the present invention are shown in FIGS. 4, 7 and 8.
  • In some embodiments, detecting of the maternal heart peaks in each filtered ECG signal in the filtered N-ECG signals data is performed based at least on: i) dividing each filtered ECG signal into a first plurality of ECG signal segments; ii) normalizing a filtered ECG signal in each ECG signal segment; iii) calculating a first derivative of the filtered ECG signal in each ECG signal segment; iv) finding local maternal heart peaks in each ECG signal segment based on determining a zero-crossing of the first derivative; and v) excluding the local maternal heart peaks having at least one of: 1) an absolute value which is less than a pre-determined local peak absolute threshold value; or 2) a distance between the local peaks is less than a pre-determined local peak distance threshold value.
  • In some embodiments, the pre-determined similarity value is based on an Euclidian distance, wherein the set of parameters is a local minima solution to a non-linear least squares problem solved by at least one of: 1) minimizing a cost function taken as the Euclidian distance; 2) utilizing a Gauss-Newton algorithm; 3) utilizing a Steepest-Descent (Gradient-Descent) algorithm; or 4) utilizing a Levenberg-Marquardt algorithm.
  • In some embodiments, the length of each segment is set at 10 seconds.
  • In some embodiments, the length of each segment is selected automatically depending on the length of the recording.
  • In some embodiments, the signal data in each segment is normalized by the absolute maximum value of the signal data. In some embodiments, the signal data in each segment is normalized by the absolute non-zero minimum value of the signal data.
  • In some embodiments, a first order forward derivative is used. In some embodiments, a first order central derivative is used.
  • In some embodiments, the threshold is selected to be a constant value of 0.3.
  • In some embodiments, the threshold is selected depending on the local characteristics of the signal data. In some embodiments, the local characteristic of the signal is the median value of the signal data or any multiplication of this value. In some embodiments, the local characteristic of the signal is the mean value of the signal data or any multiplication of this value.
  • In some embodiments, the threshold on the distance is selected to be 100 samples.
  • In some embodiments, the local characteristics of the signal can be the maximum predicted RR internal or any multiple of this value.
  • In some embodiments, a “peaks array” is generated from the filtered N-ECG signals data. In some embodiments, the peak array comprises the number of detected peaks for each of the segments of the filtered N-ECG signals data.
  • In some embodiments, clustering is performed on the peaks array. In some embodiments, k-means clustering is used to group the peaks into a number of clusters. In some embodiments, k-medoids clustering is used to group the peaks into a number of clusters.
  • In some embodiments, the number of clusters for the clustering is set to be three. In some embodiments, the number of clusters for the clustering is selected automatically depending on the characteristics of the processed N filtered signal data.
  • In some embodiments, the clustering is used to exclude outliers. In some embodiments, outliers are peaks that have anomalous characteristics.
  • In some embodiments, the characteristic is the distance between a peak and its neighboring peaks. In some embodiments, the characteristic is the amplitude of the peak.
  • In some embodiments, a new peak array is constructed after the exclusion of the anomalous peaks.
  • In some embodiments, the new peak array is further analyzed and the peaks are scored depending on the signal to noise ratio of the filtered N-ECG signals data.
  • In some embodiments, the signal to noise ratio score is calculated by calculating the relative energy of the QRS complexes from the overall energy of the processed N filtered signal data.
  • In some embodiments, the detected peaks for each of the filtered N-ECG signals data are fused for a more robust detection. In some embodiments, the fusion of the detected peaks is done using the scores given for each of the peaks of the filtered N-ECG signals data.
  • In some embodiments, a global array of peaks is defined using the fused peaks.
  • In some embodiments, the peaks of each of the filtered N-ECG signals data is redetected and the positions are refined using the global peaks array. In some embodiments, the global peak array is constructed based on the best lead with corrections made using the peaks from the other leads and the global peaks array is examined using physiological measures, such as, for example, RR intervals, HR, HRV).
  • In some embodiments, after the peaks have been defined, the filtered N-ECG signals data is further transformed to eliminate the signals corresponding to maternal cardiac activity. In some embodiments, the transformations/corrections include applying non-linear subtraction to the filtered N-ECG signals data. In some embodiments, the remaining data comprises signal data corresponding to fetal cardiac activity and noise.
  • In some embodiments of the invention, the non-linear subtraction procedure is applied separately for each one of the processed N filtered signal data. In some embodiments, the non-linear subtraction procedure is applied to all of the processed N filtered signal data in series, in any order. In some embodiments, the non-linear subtraction procedure is applied to all of the processed N filtered signal data simultaneously.
  • In some embodiments, the non-linear subtraction comprises: dividing the processed N filtered signal data into a large number of segments; modifying each of the segments, separately or jointly, using an inverse optimization scheme; and eliminating the modified segments from the original processed N filtered signal data, thereby obtaining N raw fetal signal data.
  • The term ‘segmentation’, as used herein, refers to the division of the processed N filtered signal data into any given number of segments.
  • In some embodiments, the number of segments is set to be a function of the number of the detected maternal peaks. In some embodiments, the function is the identity function so that the number of segments equals the number of the detected maternal peaks, in which case, each segment is a full heartbeat.
  • In some embodiments, a beat interval is defined. The term ‘beat interval’ used hereinafter refers the time interval of a single maternal heart beat.
  • In some embodiments, the beat interval is taken to be constant and is defined as 500 milliseconds before the R-peak position and 500 milliseconds after the R-peak position.
  • In some embodiments, the beat interval is detected automatically by detecting the beat onset and beat offset of each beat. Thus, the beat interval depends on the local heart rate value and a more accurate segmentation of the ECG signal is achieved.
  • In some embodiments, the beat interval onset is defined as the onset (i.e. starting point in time) of the P-wave.
  • In some embodiments, the beat interval offset is defined as the offset (i.e. end point in time) of the T wave.
  • In some embodiments, the beat interval onset for the current beat is defined as half the way, in time, between the previous beat and the current beat.
  • In some embodiments, the beat interval offset for the current beat is defined as half the way, in time, between the current beat and the next beat.
  • In some embodiments, a second segmentation step is performed on the result of the previous segmentation. The product of this segmenting step is referred to as ‘in-beat segments’.
  • In some embodiments, the number of in-beat segments is selected to be any integer number between one and the number of time samples in the current beat. By way of non-limiting example, the number of in-beat segment can be three.
  • In some embodiments, an automatic procedure is performed to detect the optimal number of in-beat segments. In some embodiments, the automatic procedure comprises using a Divide and Conquer algorithm, wherein each segment is divided into two equal sub-segments. If the energy content of a sub-segment exceeds a pre-defined relative threshold, the sub-segment itself is divided into two sub-segments and so on recursively. The stop criterion can be reaching a minimum length of sub-segment, reaching a maximum number of segments or dividing into sub-segments such that all of them meet the energy threshold criterion.
  • In certain embodiments, the entropy measure is used to divide the segment into sub-segments. In this case, the entropy of each segment is minimized.
  • In some embodiments, the result of the in-beat segmentation is the following seven segments:
  • 1. The isoelectric line from the beat onset to the onset of the P wave;
  • 2. The P wave;
  • 3. The isoelectric line from offset of the P wave to the onset of the QRS complex;
  • 4. The QRS complex;
  • 5. The isoelectric line from the offset of the QRS complex to the onset of the T wave;
  • 6. The T wave; and
  • 7. The isoelectric line from the offset of the T wave to the beat offset.
  • In some embodiments, the majority of the energy of the filtered N-ECG signals data is in the QRS complex. Thus, in some embodiments, the in-beat segments a the following three in-beat segments:
  • 1. From the beat onset to the onset of the QRS complex;
  • 2. The QRS complex; and
  • 3. From the offset of the QRS complex to the beat offset.
  • In some embodiments, the onset and offset of the QRS complex, for each of the beats in the ECG signal, are automatically detected using a dedicated method comprising: applying a digital band pass filter to the filtered N-ECG signals data; calculating the curve length transform of the filtered N-ECG signals data; selecting the values of the data that are higher than a threshold; calculating the first derivative of the transformed data; finding the positive transitions and negative transitions in the derivative data; finding pairs of the positive-and-negative transition such that the distance between them, in time samples, is higher than a pre-selected threshold; setting the onset of the QRS complex as the position, in time, of the positive transition from the selected pair; and setting the offset of the QRS complex as the position in time of the negative transition from the selected pair.
  • In some embodiments, the cutoff frequencies of the band pass filter are set to be 5 and 20 cycles/sec for the lower and upper frequencies respectively.
  • In some embodiments, the threshold is set to be a constant value of 0.3. In some embodiments, the threshold value is calculated automatically depending of the local characteristics of the data after the curve length transform. In some embodiments, the local characteristic of the data is the mean value of the transformed data.
  • In some embodiments, the segmentation also comprises an additional complementary transformation that comprises changing the sample rate of the signal by an integer value. In some embodiments, the additional complementary transformation reduces the variability of the resulting raw N-ECG fetal signals data caused by the fine positions of the onsets and offsets of the selected segments.
  • In some embodiments the sample rate is decreased by a factor of 4 to decrease the calculation time. Alternatively, in certain embodiments, the sample rate is increased by a factor of 4.
  • In some embodiments, increasing the sample rate is done using interpolation. In some embodiments, increasing the sample rate is done by zero padding the data and then applying a set of low pass FIR filters.
  • In some embodiments, changing the sample rate of the signals is done before the segmentation procedure. In some embodiments, changing the sample rate is done after the segmentation. In these embodiments, the selected onsets and offsets of the different segments are refined depending on the signals after changing the sample rate.
  • In some embodiments, the segmentation is updated depending on the convergence of the iterative methods in the next steps described hereinafter.
  • In some embodiments, the selected segments are modified using a nonlinear parametric transformation in which the values of a predefined set of parameters are changed according to some criterion.
  • In some embodiments, the values of a predefined set of parameters are determined and modified according to a method comprising: defining reference vectors as, for each filtered N-ECG signals data, the ECG signal and its segments (called ‘measured potentials’ hereinafter); and finding the values of the set of parameters that provide a good fit to results of the measured potentials.
  • A “good fit” occurs when the difference between the adapted template and the measured potentials is very small. In one embodiment, very small is defined to be 10−5 or smaller. In other embodiments, “very small” is defined as 10−6 or smaller or 10−4 or smaller or 10−7 or smaller or other exponents of 10 or other numbers.
  • In some embodiments, the difference between the adapted template and the measured potentials is the L2 norm of the element-by-element subtraction between the two vectors.
  • In some embodiments, the values of a predefined set of parameters also include parameters that change the amplitude of a time signal.
  • In some embodiments, an iterative scheme is used to determine the values of the set of the parameters, comprising: selecting starting conditions; assigning tentative values to the set of parameters; adapting the templates using the set of parameters; comparing the adapted templates to the measured potentials; checking if a stop criterion is reached; updating the values of the set of parameters if none of the stop criteria are reached, and repeating steps steps (c), (d), (e) and (f). In some embodiments, if a stop criterion is reached, the iterative procedure is terminated and the current set of parameters is deemed the optimal solution of the optimization problem.
  • In some embodiments, the starting conditions are set to be the ECG templates. In some embodiments, two templates are defined: The first is a global template that is defined for every ECG beat (see, for example, FIG. 7), wherein the template is calculated as a weighted average of M beats. In some embodiments, M is an integer number between 2 and the total number of beats in the ECG signal. In some embodiments, the weights used in the weighted average are equal yielding a normal averaging. In some embodiments, the M beats fulfill the condition that the correlation coefficient between each of the beats should be higher than a threshold. In certain embodiments, the threshold is set to be 0.98. In some embodiments, before the averaging, the beats are shifted and fine aligned using the exact position of the R-wave, the QRS onset and the QRS offset. In some embodiments, the alignment procedure is done using the cross correlation function. In Some embodiments, the M beats fulfill the condition that relation between the energy of the template, defined as an average of these beats, and the energy of the current ECG beat is bounded close to 1. However, in some embodiments, the relation between the energy of the template and the energy of the current ECG beat is higher than 1 by a small value or lower than 1 by a small value.
  • The second is a local template that is defined for each of the sub-segments in the current beat (see, for example, FIG. 8). In some embodiments, the template is calculated as the average of the sub-segments in the M-selected peaks. In some embodiments, the beats are selected to fulfill the conditions that the local heart rate is similar to the local heart rate for the current beat. By means of a non-limiting example, the heart rate values are close by a factor of 1.5.
  • In some embodiments, the tentative values are set to random numbers. In some embodiments, the tentative values are set to be constant numbers; by means of a non-limiting example, they are set to be 1.
  • In some embodiments, the tentative values are saved between different executions of the algorithm and used if available.
  • In some embodiments, the different templates are adapted separately depending on the appropriate parameters that are assigned to the templates. In some embodiments, the templates are scaled by multiplying the templates vectors with the appropriate set of parameters. In some embodiments, the templates are shifted in time using the appropriate set of parameters.
  • In some embodiments, the Euclidian distance is used to compare the two sets of vectors; the adapted templates and the measured potentials from the processed N filtered signal data. In some embodiments, the cost function is defined as the error energy function.
  • In some embodiments, the city-block measure is used to compare the adapted templates to the measured potentials.
  • In some embodiments, the cross correlation function is used to compare the adapted templates and measured potentials. In some embodiments, a “good fit” is a correlation of 0.95 or greater.
  • In some embodiments, a maximum number of iterations is used as a stop criterion.
  • In some embodiments, in the case of using the Euclidian distance as a similarity measure, the value of the error energy function at a specific iteration is used as a stop criterion. In some embodiments, if the error energy becomes lower than a threshold, the stop criterion is reached.
  • In certain embodiments, the threshold is set to be constant. By means of a non-limiting example, it is set to be 10−5.
  • In some embodiments, the threshold is calculated depending on the characteristics of the iterative procedure. For example, in some embodiments, the characteristics of the iterative procedure is the maximum number of allowed iterations; in other embodiments, the characteristics of the iterative procedure is the used cost function, for example the Euclidian distance function; and still other embodiments, the characteristics of the iterative procedure is the number of time samples in the templates.
  • In some embodiments, an improvement measure is used as a stop criterion.
  • In some embodiments, the change in the set of parameters is used as an improvement measure. In some embodiments, if the values of the set of parameters does not change, or change slightly, the stop criterion is fulfilled.
  • In some embodiments, the change in the value of the cost function, e.g. the error energy function, is used as an improvement measure.
  • In some embodiments, if a stop criterion is reached, an optimization scheme is applied to update the values of the set of parameters.
  • In some embodiments, when using the Euclidian distance as a similarity measure, the optimization problem becomes a non-linear least squares problem. In some embodiments, the solution of this problem gives the optimal set of parameters that minimizes the cost function taken as the Euclidian distance.
  • In some embodiments, Gauss-Newton algorithm is used to solve the non-linear least squares problem.
  • In some embodiments, the Steepest-Descent (Gradient-Descent) method is used to solve the non-linear least squares problem.
  • In some embodiments, the Levenberg-Marquardt algorithm is used to solve the non-linear least squares problem. In these embodiments, the problem becomes a damped least squares problem. Levenberg-Marquardt algorithm is a method, which interpolates between the Gradient-Descent and Gauss-Newton algorithm taking advantage of both methods to increase the convergence accuracy and decrease the convergence time.
  • In some embodiments, Gradient-Descent, Gauss-Newton algorithm and Levenberg-Marquardt algorithm, are iterative methods that are repeated a number of times, potentially, bringing the Euclidian distance (the error energy function) to a local minima.
  • In some embodiments, updating the set of parameters is performed using the relation:

  • P k+1 =P k −[J k T J ki·diag(J k T J k)]−1 *J k Tc(P k)−ϕm]
  • Where Pkis the set of parameters at the kth iteration; and
  • ϕc(Pk) is the adapted version of the templates for the Pk parameters; and
  • λi is the damping parameter in the Levenberg-Marquardt algorithm; and
  • ϕm is the measured potentials (measured ECG signals); and
  • Jk is the Jacobian matrix calculated for the set of parameters Pk by altering the values of the parameters; and
  • diag(Jk TJk) is the diagonal of the approximated Hessian matrix.
  • In some embodiments, eliminating the modified segments from the N raw signal data is achieved by subtracting the adapted templates from the measured potentials. In some embodiments, the subtraction results in N raw fetal signal data. In some embodiments, the N raw fetal signal data comprises noise and fetal cardiac electrical activity data.
  • In some embodiments, maternal cardiac activity is eliminated using the algorithm shown in FIG. 5.
  • In some embodiments, maternal cardiac activity is eliminated using the algorithm shown in FIG. 6.
  • A representative result of maternal ECG elimination according to some embodiments of the present invention is shown in FIG. 9.
  • Extraction of the Fetal Cardiac Electrical Activity Data and Detecting Fetal Cardiac Electrical Activity Data
  • In some embodiments, raw fetal ECG signals data is extracted and analyzed by utilizing a Blind-Source-Separation (BSS) algorithm on (1) the filtered N-ECG signals data and (2) the corrected N-ECG signals data, wherein the raw fetal ECG signals data comprises a N number of fetal ECG signals (N-ECG fetal signals); processing, by the at least one computer processor, the raw fetal ECG signals data to improve a signal-to-noise ratio by at least: i) applying a band-pass filter within a range of 15-65 Hz to break the plurality of raw N-ECG fetal signals in to a plurality of frequency channels, ii) scoring an ECG fetal signal per channel based on a peak-2-mean analysis to identify a plurality of fetal heartbeat channels, wherein each fetal heartbeat channel corresponds to a particular fetal ECG fetal signal; and iii) selecting the identified plurality of fetal heartbeat channels into filtered fetal ECG signals data, comprising a N number of filtered fetal ECG signals (filtered N-ECG fetal signals data); detecting, by the at least one computer processor, fetal heart peaks in the filtered N-ECG fetal signals data, by performing at least: i) dividing each filtered N-ECG fetal signal into a first plurality of fetal ECG signal segments; ii) normalizing a filtered fetal ECG signal in each fetal ECG signal segment; iii) calculating a first derivative of the filtered fetal ECG signal in each fetal ECG signal segment; and iv) finding local fetal heart peaks in each fetal ECG signal segment based on determining a zero-crossing of the first derivative; calculating, by the at least one computer processor, based on detected fetal heart peaks, at least one of: i) fetal heart rate, ii) fetal heart curve, iii) beat-2-beat fetal heart rate, or iv) fetal heart rate variability; and outputting, by the at least one computer processor , a result of the calculating step.
  • In some embodiments, the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio comprises: i) applying a band-pass filter within a range of 15-65 Hz to break the plurality of N-ECG fetal signals in to a plurality of frequency channels, ii) scoring an ECG fetal signal per channel based on a peak-2-mean analysis to identify a plurality of fetal heartbeat channels, wherein each fetal heartbeat channel corresponds to a particular fetal ECG fetal signal; and iii) selecting the identified plurality of fetal heartbeat channels into filtered ECG fetal signals data, comprising a N number of filtered fetal ECG signals (filtered N-ECG fetal signals data).
  • In some embodiments, the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio comprises: i) applying a band-pass filter within a range of 1-70 Hz to break the plurality of N-ECG fetal signals in to a plurality of frequency channels, ii) scoring an ECG fetal signal per channel based on a peak-2-mean analysis to identify a plurality of fetal heartbeat channels, wherein each fetal heartbeat channel corresponds to a particular fetal ECG fetal signal; and iii) selecting the identified plurality of fetal heartbeat channels into filtered ECG fetal signals data, comprising a N number of filtered fetal ECG signals (filtered N-ECG fetal signals data).
  • In some embodiments, the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio comprises: i) applying a band-pass filter within a range of 5-70 Hz to break the plurality of N-ECG fetal signals in to a plurality of frequency channels, ii) scoring an ECG fetal signal per channel based on a peak-2-mean analysis to identify a plurality of fetal heartbeat channels, wherein each fetal heartbeat channel corresponds to a particular fetal ECG fetal signal; and iii) selecting the identified plurality of fetal heartbeat channels into filtered ECG fetal signals data, comprising a N number of filtered fetal ECG signals (filtered N-ECG fetal signals data).
  • In some embodiments, the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio comprises: i) applying a band-pass filter within a range of 10-70 Hz to break the plurality of N-ECG fetal signals in to a plurality of frequency channels, ii) scoring an ECG fetal signal per channel based on a peak-2-mean analysis to identify a plurality of fetal heartbeat channels, wherein each fetal heartbeat channel corresponds to a particular fetal ECG fetal signal; and iii) selecting the identified plurality of fetal heartbeat channels into filtered ECG fetal signals data, comprising a N number of filtered fetal ECG signals (filtered N-ECG fetal signals data).
  • In some embodiments, the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio comprises: i) applying a band-pass filter within a range of 1-65 Hz to break the plurality of N-ECG fetal signals in to a plurality of frequency channels, ii) scoring an ECG fetal signal per channel based on a peak-2-mean analysis to identify a plurality of fetal heartbeat channels, wherein each fetal heartbeat channel corresponds to a particular fetal ECG fetal signal; and iii) selecting the identified plurality of fetal heartbeat channels into filtered ECG fetal signals data, comprising a N number of filtered fetal ECG signals (filtered N-ECG fetal signals data).
  • In some embodiments, the processing of the raw N-ECG fetal signals data to improve the signal-to-noise ratio further comprises at least one of: 1) utilizing a Singular-Value-Decomposition (SVD) technique; or 2) utilizing a Wavelet-Denoising (WD) technique.
  • In some embodiments, all of the raw N-ECG signals data are used in the BSS procedure so that the BSS procedure is applied to 2N signals. In other embodiments, only part of the raw N-ECG signals data is used in the BSS procedure so that the BSS procedure is applied to between N+1 signals and less than 2N signals.
  • In some embodiments, Principal Component Analysis (PCA) is used as the BSS method. In some embodiments, Independent Component Analysis (ICA) is used as the BSS method.
  • In some embodiments, the results of the BSS procedure is further analyzed to improve the signal to noise ratio of the signals. In some embodiments, the further analysis includes a band-pass filter in the range of 15-65 cycle/second. In some embodiments, the further analysis includes applying Singular-Value-Decomposition (SVD). In some embodiments, the further analysis includes applying Wavelet-Denoising.
  • In some embodiments, the further analysis includes applying ‘peak-2-mean’ transformation, which in some versions is in a separate software module, that comprises:
      • a. using a moving window (win) to calculate the relation:
  • max ( Signal [ win ] ) mean ( Signal [ win ] ) ;
  • and
      • b. calculating the 1st derivative of the result of step a; and
      • c. finding the zero crossing to find peaks taking the negative part of the derivative; and
      • d. finding the peaks in the previous result and cluster them based on the difference between them. Identify the best group as the group with the maximum score defined as: SCR=n/RMS where n is the number of peaks in each cluster and RMS is the energy of the derivative of the distances between the peaks; and
      • e. performing a prediction for the RR interval for the best group; and
      • f. if the prediction doesn't fit the real physiological model of the fetal RR intervals, the current signal is ignored and one then begins the process at the beginning (i.e. using a moving window to calculate the relation) with the next signal; and
      • g. if the prediction does fit the real physiological model of the fetal RR, calculate the auto correlation function of a windowed RMS of the signal. If the result has a narrow distribution, the current signal is ignored, and if the result does not have a narrow distribution, then proceed as follows:
      • h. applying AGC to the negative derivative signal; and
      • i. normalizing the result.
  • In certain embodiments, the above ‘peak-2-mean transformation’ is applied separately to each signal (i.e. each of the 2N signals or each of the between N+1 and less than 2N signals).
  • In some embodiments, fetal heart beat detection is performed. For example, in some embodiments, the N raw fetal signal data are subjected the fetal peak detection procedure before the further analysis and in other embodiments the results of the further analysis subjected to the fetal peak detection procedure.
  • In some embodiments, the analysis comprises: dividing the N filtered fetal signal data into segments; normalizing the signal data in each segment; calculating the first derivative of the normalized signal data; identifying the fetal ECG peaks within the normalized signal data by determining the zero-crossing of the first derivative; excluding peaks whose absolute value is less than a threshold pre-selected by the user; and excluding very close peaks where the distance between them is less than a threshold, thereby obtaining processed N filtered fetal signal data.
  • In some embodiments, the length of each segment is set at 10 seconds.
  • In some embodiments, the length of each segment is selected automatically depending on the length of the recording.
  • In some embodiments, the signal data in each segment is normalized by the absolute maximum value of the signal data. In some embodiments, the signal data in each segment is normalized by the absolute non-zero minimum value of the signal data.
  • In some embodiments, a first order forward derivative is used. In some embodiments, a first order central derivative is used.
  • In some embodiments, the threshold is selected to be a constant value of 0.3.
  • In some embodiments, the threshold is selected depending on the local characteristics of the signal data. In some embodiments, the local characteristic of the signal is the median value of the signal data or any multiplication of this value. In some embodiments, the local characteristic of the signal is the mean value of the signal data or any multiplication of this value.
  • In some embodiments, the threshold on the distance is selected to be 100 samples.
  • In some embodiments, the local characteristics of the signal can be the maximum predicted RR internal or any multiple of this value.
  • In some embodiments, a “peaks array” is generated from the filtered N-ECG fetal signals data. In some embodiments, the peak array comprises the number of detected peaks for each of the segments of the filtered N-ECG fetal signals data.
  • In some embodiments, clustering is performed on the peaks array. In some embodiments, k-means clustering is used to group the peaks into a number of clusters. In some embodiments, k-medoids clustering is used to group the peaks into a number of clusters.
  • In some embodiments, the number of clusters for the clustering is set to be three. In some embodiments, the number of clusters for the clustering is selected automatically depending on the characteristics of the filtered N-ECG fetal signals data.
  • In some embodiments, the clustering is used to exclude outliers. In some embodiments, outliers are peaks that have anomalous characteristics.
  • In some embodiments, the characteristic is the distance between a peak and its neighboring peaks. In some embodiments, the characteristic is the amplitude of the peak.
  • In some embodiments, a new peak array is constructed after the exclusion of the anomalous peaks.
  • In some embodiments, the new peak array is further analyzed and the peaks are scored depending on the signal to noise ratio of the filtered N-ECG fetal signals data.
  • In some embodiments, the signal to noise ratio score is calculated by calculating the relative energy of the QRS complexes from the overall energy of the filtered N-ECG fetal signals data.
  • In some embodiments, the detected peaks for each of the filtered N-ECG fetal signals data are fused for a more robust detection. In some embodiments, the fusion of the detected peaks is done using the scores given for each of the peaks of filtered N-ECG fetal signals data.
  • In some embodiments, a global array of peaks is defined using the fused peaks.
  • In some embodiments, the peaks of each of the filtered N-ECG fetal signals data is redetected and the positions are refined using the global peaks array. In some embodiments, the global peak array is constructed based on the best lead with corrections made using the peaks from the other leads and the global peaks array is examined using physiological measures, such as, for example, RR intervals, HR, HRV).
  • In some embodiments, the beat-to-beat fetal heart rate is extracted from the detected fetal peaks positions. In some embodiments, the fetal heart curve is also extracted from the detected fetal peak positions.
  • The present invention is further illustrated, but not limited by, the following examples.
  • EXAMPLES Example 1 Algorithm Design According to Some Embodiments of the Present Invention
  • TABLE 1
    5. Low Level Design of the algorithm: The fECG detection algorithm have the following low level design:
    5.1. The acquired N-channels signals should be preprocessed:
    5.1.1. Signal exclusion: Saturated signals are excluded in this version (if the saturated part exceeds 10%
    of the overall length of the signal). For the next versions, this criterion should be replaced by an
    online examiner.
    5.1.2. Baseline removal: the baseline of the ECG signal needs to be removed. It can be removed using a
    number of methods. In the algorithm the baseline is removed using a moving average filter with
    an order of 501 (milliseconds).
    5.1.3. Low pass filtering with an IIR filter (auto designed by Matlab):
    5.1.3.1. Type: Chebyshev Type I
    5.1.3.2. Cutoff freq: 70 Hz
    5.1.3.3. Baseband ripple: 0.12 dB
    5.1.3.4. Order: 12th order, 6 sections
    5.1.4. Power line interference cancelation: to be in the safe side and for simplicity purposes, the
    following filter is used:
    5.1.4.1. Type: Butterworth (band - stop)
    5.1.4.2. Cutoff freq: 49.5-50.5 Hz
    5.1.4.3. Order: 10th order, 5 sections
    5.2. Maternal ECG detection: The following steps are performed:
    5.2.1. Examination: the data is passed through an additional high pass filter (5th order @1 Hz). The
    data is examined by preliminary and simple peak detector. The relative energy of the peaks is
    calculated (relative to the overall energy of the signal). Each signal is given a quality score
    depending on this measure. Signals with a quality score of less than a threshold are excluded. In
    addition, the signals are examined for missing data and NaNs.
    5.2.2. Peak enhancement: The preprocessed ECG data is passed through an additional median filter with
    an order of 100 samples to enhance the maternal peaks.
    5.2.3. Peaks detection: for each signal:
    5.2.3.1. Divide the signal into 10 seconds segments, for each segment:
  • TABLE 2
    5.2.3.2. Normalize the data
    5.2.3.3. Find the local peaks in the segment using derivative, thresholding and minimum
    distances methods
    5.2.3.4. After finishing with all of the segments perform kmedoids clustering on the number of
    peaks in each segments:
    5.2.3.4.1. For segments with very low number of peaks, (apparently there is a
    noise spike) perform AGC on the data and redetect the peaks. If the new number of peaks
    belongs to one of the good clusters, add these peaks. If not, ignore these peaks
    5.2.3.4.2. For segments with very high number of peaks (due to high noise most
    probably), ignore these peaks
    5.2.3.5. After finishing, perform kmedoids clustering on the amplitudes of the peaks, very low
    peaks and very high peaks are filtered using this step.
    5.2.3.6. After finishing with the signal, do the following:
    5.2.3.6.1. Check that the number of peaks falls into an expected interval (based
    on the maximum and minimum possible heart rates)
    5.2.3.6.2. Is step 1 is passed, check that the relative energy of the QRS complexes
    is higher than a threshold
    5.2.3.6.3. If step 2 is passed, perform peak redetection using the cross correlation
    method (helps removing false positive and adding false negatives)
    5.2.4. Peak re-detection: if the previous step is failed to detect the peaks in at least one channel, apply
    ICA to the data and then repeat step (5.2.3)
    5.2.5. Peaks examination:
    5.2.5.1. A score is given for each one of the N signals. The best lead is defined as the lead with
    the biggest score
    5.2.5.2. A global peak array is constructed based on the best lead with corrections made using the
    peaks from the other leads
  • TABLE 3
    5.5.5.3. The global peaks array is examined using physiological measures (RR intervals, HR,
    HRV)
    5.2.6. HRC calculation: the mHRC is calculated using the detected maternal R-waves
    5.3. Maternal ECG Elimination: The purpose of this step is to eliminate the maternal ECG and thereafter stay
    with the fetal ECG signals and some noise according to the model that have been previously developed. The
    following steps are performed for each of the N-channels:
    5.3.1. Resample the signal to match a 4 kSPS sampling frequency
    5.3.2. Find the QRS onset and offset positions using the Curve Length Transform (CLT)
    5.3.3. For each one of the detected maternal peaks:
    5.3.3.1. Define a beat interval: the beat interval is defined as, except for the first and last peaks,
    (1) beat onset: half the distance between the current peak and the previous peak and (2) beat
    offset: half the distance between the current peak and the next peak. Due to the beat-2-beat
    changing heart rate, the beat interval should change for each beat
    5.3.3.2. Define a local template, a template that depends on the current beat:
    5.3.3.2.1. Step 1: Search for at least 10 beats that have a correlation coefficient (obtained
    from cross correlation) of at least 0.98 This step is usually fast and gives results for not-
    noisy signals
    5.3.3.2.2. Step 2: Step 1 usually fails for noisy signals hence an iterative scheme is used:
    5.3.3.2.2.1. Define the template as the beat itself
    5.3.3.2.2.2. An initial correlation coefficient is defined (high value
    threshold: 0.99)
    5.3.3.2.2.3. Search for the beats that are very similar to the current beat
    (have higher correlation than the threshold)
    5.3.3.2.2.4. If none is found, decrease the correlation threshold and repeat
  • TABLE 4
    5.3.3.2.2.5. If some is found, update the template and continue
    5.3.3.2.2.6. The procedure is terminated if: (1) a maximum number of iterations is
    reached, (2) the number of beats to include reached a minimum number or (3) the current
    iteration yields the same results as the previous iteration
    5.3.3.2.3. A byproduct of this process is a score for how noisy each beat is
    5.3.4. Start the adaptation procedure, iterative Levenberg-Marquardt Parametric Optimization (LMPO)
    for solving non-linear damped least squares problems. Divide the beat into 3 parts: (1) P-wave region, (2)
    QRS complex and (3) T-wave region. The iterative procedure:
    5.3.4.1. Initialize the LMA algorithm (Algorithm params)
    5.3.4.2. Perform initial guess for the mECG (first guess is the template, let it be ϕ_c)
    5.3.4.3. Adapt the initial guess
    5.3.4.4. Compare the result to the measured current ECG (current beat with maternal data, fetal
    data and noise, let it be ϕ_m)
    5.3.4.5. Check if a termination criteria is reached, if yes terminate returning the last good result
    5.3.4.6. If not, update the algorithm parameters and repeat steps 3-5.
    5.3.4.7. This algorithm has the following characteristics:
     ▪ It interpolates between Gauss - Newton (GN) method and the Gradient Decent (GD)
    method taking the good form both
     ▪ At first, it convergence very fast due to the fast convergence of GD. When it advances,
    the steps become smaller, yielding a slow convergence when it is close to the local
    minimum (Slow yet cautious progress near the minimum!)
  • TABLE 5
    It operates by the principle of “worst case scenario is to stay the same”
    The only problem with this iterative algorithm is the convergence to local minima. This
    isn't a big issue in our case since we know that the local minima is also, always, the
    global one (due to the educated guess of the start conditions)
    The algorithm minimizes the error energy function defined as the 12 norm of the
    difference between the calculated potentials and the measured potentials:
    E = ∥ϕc − ϕm2
    The final result of the algorithm is a stable, global and reproducible solution due to the
    fact the number of parameters to be reconstructed is way smaller than the number of the
    available observations
    The reconstruction parameters of the algorithm are:
    P region multiplier
    QRS region multiplier
    T region multiplier
    Beat shift
  • TABLE 6
    5.3.5. Construct the maternal ECG (mECG) array (started form the templates for each beat and get close to
    the current channel measured ECG)
    5.3.6. Construct the fetal ECG array, fECG = ECG − mECG
    5.3.7. Downsample the mECG and the fECG signals to match the initial sampling rate
    5.4. Fetal ECG preprocessing: After the elimination (near-perfect elimination) of the mECG, the remaining data
    is processed for fECG enhancement (see the next step for more info). A preliminary prediction of the best fetal
    channel is performed depending on the energy distribution of the auto correlation function of the signal
    5.5. Fetal ECG detection:
    5.5.1. First step is to prepare the data. Usually, the fetal signals do not appear in all of the channels hence
    it is better to decrease the dimension of the data. This is done by:
    5.5.2. Apply Singular Value Decomposition (SVD) keeping only the N-1 singular values and vectors
    5.5.3. Apply fastICA to the resulting data (with ‘tanh’)
    5.5.4. Apply peak-2-mean transformation:
    5.5.4.1. Use a moving window to calculate the relation: max(signal[win])/mean(signal[win])
    (enhances peaks)
    5.5.4.2. Calculate the 1st derivative of the result of step 1
    5.5.4.3. Find the zero crossing to find peaks, take the negative part of the derivative
    5.5.4.4. Find the peaks in the previous result and cluster them based on the difference between
    them. Identity the best group as the group with the maximum score: SCR = n/RMS where n is the
    number of peaks in each cluster and RMS is the energy of the derivative of the distance between
    the peaks
    5.5.4.5. Perform a prediction for the RR interval for the best group
    5.5.4.6. If the prediction doesn't fit the real model, ignore this channel
  • TABLE 7
    5.5.4.7. If so, calculate the auto correlation function of a windowed RMS of the signal, if the
    result have a narrow distribution ignore this channel, else:
    5.5.4.8. Apply AGC to the negative derivative signal
    5.5.4.9. Normalize the result, and flag it as the processing data
    5.5.4.10. Repeat steps 1-10 to the N-channels
    5.5.5. Try to perform fetal peak detection using the same methodology as for the maternal peak detection
    with different parameters
    5.5.6. If the previous step is successful, skip this step. If not, this means that the fetal data is noisy. In
    this case perform the following preprocessing:
    5.5.6.1. The fetal data is band-pass filtered between the range 15-70 Hz
    5.5.6.2. Wavelet denoising is applied to the data
    5.5.6.3. Windowed RMS is applied on the data
    5.5.6.4. The results are low pass filtered @35 Hz
    5.5.6.5. The data is normalized and AGC is applied to the data
    5.5.7. Following step (5.5.6), perform fetal peak detection without the correlation part
    5.5.8. Following step (5.5.7), if more than one channel is valid, calculate the kurtosis of the distribution
    of the distances between the peaks. The best lead is defined as the peak with the maximum relative kurtosis
    5.5.9. Following step (5.5.8), perform peak redetection using the RR intervals. Also try to build, using a
    Kalman filter, an array of the positions of the peaks
    5.5.10. Following step (5.5.5/5.5.9), perform fetal peak examination using the information about
    the RR intervals
    5.5.11. Following step (5.5.10), build the fetal peaks array:
    5.5.11.1. Time varying RR interval is extracted from the results
    5.5.11.2. A characteristic region in the previous signal is defined: a region in which the
    RR interval curve is very smooth (which means that there is minimum falses in this
    region) - this region is called the seed region
    5.5.11.3. Perform region growing staring from the seed points while including only points
    that are close to the local RR interval
  • TABLE 8
    5.5.12. Perform peak examination and correction:
    5.5.12.1. Stage 1: find false negatives and Zigzags (caused by two consecutive, opposite
    misdetections)
    5.5.12.2. Stage 2: Find mis-positioning of the peaks by detecting spikes in the updating
    RR curve
    5.6. HRC calculation: the fHRC is calculated using the detected fetal peaks
  • Publications cited throughout this document are hereby incorporated by reference in their entirety. Although the various aspects of the invention have been illustrated above by reference to examples and preferred embodiments, it will be appreciated that the scope of the invention is defined not by the foregoing description but by the following claims properly construed under principles of patent law.

Claims (1)

What is claimed is:
1. A computer-implemented method, comprising:
receiving, by at least one computer processor, electrocardiogram (ECG) signals data from at least one pair of ECG sensors positioned on an abdomen of a woman carrying a fetus;
filtering, by the at least one computer processor, the ECG signals data to form filtered ECG signals data;
detecting, by the at least one computer processor, maternal heart peaks in the filtered ECG signals data, the maternal heart peaks forming a maternal ECG signal;
subtracting, from the filtered ECG signals data, by the at least one computer processor, the maternal ECG signal by using a non-linear subtraction procedure to form corrected ECG signals data;
extracting, by the at least one computer processor, raw fetal ECG signals data from the filtered N-ECG signals data from the corrected ECG signals data;
processing, by the at least one computer processor, the raw fetal ECG signals data to improve a signal-to-noise ratio of the raw fetal ECG signals data to form filtered fetal ECG signals data;
detecting, by the at least one computer processor, fetal heart peaks in the filtered fetal ECG signals data;
calculating, by the at least one computer processor, based on the detected fetal heart peaks, at least one of:
i) a fetal heart rate,
ii) a fetal heart curve,
iii) a beat-2-beat fetal heart rate, or,
iv) fetal heart rate variability; and
outputting, by the at least one computer processor, a result of the calculating step.
US17/112,201 2015-03-10 2020-12-04 Apparatuses for tracking physiological parameters of mother and fetus during pregnancy Abandoned US20210259613A1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
US17/112,201 US20210259613A1 (en) 2015-03-10 2020-12-04 Apparatuses for tracking physiological parameters of mother and fetus during pregnancy
US17/821,562 US20220395212A1 (en) 2015-03-10 2022-08-23 Methods and systems for tracking physiological parameters of mother and fetus during pregnancy

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US201562131122P 2015-03-10 2015-03-10
US14/921,489 US9392952B1 (en) 2015-03-10 2015-10-23 Systems, apparatus and methods for sensing fetal activity
US15/205,620 US10111600B2 (en) 2015-03-10 2016-07-08 Systems, apparatus and methods for sensing fetal activity
US16/173,852 US20190059767A1 (en) 2015-03-10 2018-10-29 Apparatuses for tracking physiological parameters of mother and fetus during pregnancy
US17/112,201 US20210259613A1 (en) 2015-03-10 2020-12-04 Apparatuses for tracking physiological parameters of mother and fetus during pregnancy

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US16/173,852 Continuation US20190059767A1 (en) 2015-03-10 2018-10-29 Apparatuses for tracking physiological parameters of mother and fetus during pregnancy

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US17/821,562 Continuation US20220395212A1 (en) 2015-03-10 2022-08-23 Methods and systems for tracking physiological parameters of mother and fetus during pregnancy

Publications (1)

Publication Number Publication Date
US20210259613A1 true US20210259613A1 (en) 2021-08-26

Family

ID=56381470

Family Applications (5)

Application Number Title Priority Date Filing Date
US14/921,489 Active US9392952B1 (en) 2015-03-10 2015-10-23 Systems, apparatus and methods for sensing fetal activity
US15/205,620 Active US10111600B2 (en) 2015-03-10 2016-07-08 Systems, apparatus and methods for sensing fetal activity
US16/173,852 Abandoned US20190059767A1 (en) 2015-03-10 2018-10-29 Apparatuses for tracking physiological parameters of mother and fetus during pregnancy
US17/112,201 Abandoned US20210259613A1 (en) 2015-03-10 2020-12-04 Apparatuses for tracking physiological parameters of mother and fetus during pregnancy
US17/821,562 Abandoned US20220395212A1 (en) 2015-03-10 2022-08-23 Methods and systems for tracking physiological parameters of mother and fetus during pregnancy

Family Applications Before (3)

Application Number Title Priority Date Filing Date
US14/921,489 Active US9392952B1 (en) 2015-03-10 2015-10-23 Systems, apparatus and methods for sensing fetal activity
US15/205,620 Active US10111600B2 (en) 2015-03-10 2016-07-08 Systems, apparatus and methods for sensing fetal activity
US16/173,852 Abandoned US20190059767A1 (en) 2015-03-10 2018-10-29 Apparatuses for tracking physiological parameters of mother and fetus during pregnancy

Family Applications After (1)

Application Number Title Priority Date Filing Date
US17/821,562 Abandoned US20220395212A1 (en) 2015-03-10 2022-08-23 Methods and systems for tracking physiological parameters of mother and fetus during pregnancy

Country Status (9)

Country Link
US (5) US9392952B1 (en)
EP (1) EP3267884B1 (en)
KR (1) KR101900641B1 (en)
CN (1) CN107405096B (en)
AU (1) AU2016230825B2 (en)
CA (1) CA2979135C (en)
DK (1) DK3267884T3 (en)
ES (1) ES2895642T3 (en)
WO (1) WO2016142780A1 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN116458864A (en) * 2023-06-19 2023-07-21 深圳大学 Intelligent fetal health early warning system

Families Citing this family (29)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10456074B2 (en) 2014-10-29 2019-10-29 Bloom Technologies NV Method and device for contraction monitoring
US11534104B2 (en) 2014-10-29 2022-12-27 Bloom Technologies NV Systems and methods for contraction monitoring and labor detection
US9392952B1 (en) * 2015-03-10 2016-07-19 Nuvo Group Ltd. Systems, apparatus and methods for sensing fetal activity
US10499844B2 (en) 2016-07-01 2019-12-10 Bloom Technologies NV Systems and methods for health monitoring
CN206507866U (en) * 2016-12-06 2017-09-22 台达电子工业股份有限公司 Toilet seat and support device
CN106580309A (en) * 2016-12-09 2017-04-26 北京工业大学 Fetal electrocardiogram circuit system
WO2018109669A1 (en) * 2016-12-13 2018-06-21 King Abdullah University Of Science And Technology System and method for non-invasive extraction of fetal electrocardiogram signals
US11510607B2 (en) 2017-05-15 2022-11-29 Bloom Technologies NV Systems and methods for monitoring fetal wellbeing
WO2019016759A1 (en) 2017-07-19 2019-01-24 Bloom Technologies NV Monitoring uterine activity and assessing pre-term birth risk
JP6938763B2 (en) * 2017-08-23 2021-09-22 コーニンクレッカ フィリップス エヌ ヴェKoninklijke Philips N.V. Fetal movement detection method from Doppler ultrasonic signals
CN108507607B (en) * 2018-02-09 2020-07-03 中国科学院国家空间科学中心 Weak signal detection method based on kernel function
EP3752055B1 (en) * 2018-02-12 2022-09-28 Nuvo Group Ltd. Methods for sensing fetal activity
CN109146006B (en) * 2018-10-23 2021-12-10 上海交通大学 Template library combined nonlinear template matching fetal heart rate extraction method
CN111772617B (en) * 2019-04-04 2023-08-04 成都心吉康科技有限公司 ECG display filtering method, device and storage medium
CN111772627B (en) * 2019-04-04 2023-08-15 中山大学 Online fetal electrocardiosignal extraction device and method
CN110151156B (en) * 2019-04-07 2021-10-29 西安电子科技大学 Fetal heart rate extraction method and system based on in-window automatic weighted average algorithm
EP3955806A4 (en) * 2019-04-16 2023-02-01 GE Precision Healthcare LLC Multi-sensor patch
EP3730058A1 (en) * 2019-04-24 2020-10-28 Koninklijke Philips N.V. Fetal ultrasound processing unit for separating heart rate signals
WO2020242334A1 (en) * 2019-05-24 2020-12-03 Autonomous Non-Profit Organization For Higher Education "Skolkovo Institute Of Science And Technology" System and method of automated electrocardiogram analysis and interpretation
US11826129B2 (en) 2019-10-07 2023-11-28 Owlet Baby Care, Inc. Heart rate prediction from a photoplethysmogram
US20210128007A1 (en) * 2019-10-31 2021-05-06 Tencent America LLC Method and apparatus for filtering electrocardiogram signal
US20210244347A1 (en) * 2020-02-05 2021-08-12 Nuvo Group Ltd. Fusion signal processing for maternal uterine activity detection
US11744501B2 (en) 2020-05-07 2023-09-05 GE Precision Healthcare LLC Multi-sensor patch
TWI742693B (en) * 2020-05-26 2021-10-11 國立中正大學 Sensor placement optimization device and method thereof
CN111938627B (en) * 2020-08-10 2022-04-19 浙江工业大学 Method for filtering magnetocardiogram signal baseline drift
CN112716525B (en) * 2021-04-06 2021-08-10 深圳市理邦精密仪器股份有限公司 Fetal heart rate processing method and device and readable storage medium
CN113303813A (en) * 2021-05-12 2021-08-27 西安电子科技大学 Lightweight electrocardiosignal noise removal and QRS waveform detection method
US20220409143A1 (en) * 2021-06-28 2022-12-29 Pacesetter, Inc. Method and system for optimizing filter settings of an implantable medical device
CN116548928B (en) * 2023-07-11 2023-09-08 西安浩阳志德医疗科技有限公司 Nursing service system based on internet

Family Cites Families (32)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4781200A (en) * 1985-10-04 1988-11-01 Baker Donald A Ambulatory non-invasive automatic fetal monitoring system
IL82698A0 (en) * 1987-05-29 1987-11-30 Univ Ramot Method and apparatus for indicating repetition intervals of a specified component of a composite electrical signal,particularly useful for displaying fetal r-waves
US5042499A (en) * 1988-09-30 1991-08-27 Frank Thomas H Noninvasive electrocardiographic method of real time signal processing for obtaining and displaying instantaneous fetal heart rate and fetal heart rate beat-to-beat variability
US6171263B1 (en) * 1994-11-24 2001-01-09 The Institute Of Respiratory Medicine Limited Foetal circulatory impedance monitor
US5666959A (en) * 1995-08-30 1997-09-16 British Technology Group Limited Fetal heart rate monitoring
US5758654A (en) * 1996-08-29 1998-06-02 Harley Street Software Ltd. ECG P QRS T onset and peak detection method
US5749831A (en) * 1997-06-23 1998-05-12 Baker; Donald A. Fetal cardiac monitoring utilizing umbilical blood flow parameters and heartbeat information
GB2342449B (en) * 1998-12-22 2000-09-20 Neoventa Medical Ab Device for reducing signal noise in a fetal ECG signal
US6751498B1 (en) * 1999-03-15 2004-06-15 The Johns Hopkins University Apparatus and method for non-invasive, passive fetal heart monitoring
GB0123772D0 (en) * 2001-10-03 2001-11-21 Qinetiq Ltd Apparatus for monitoring fetal heartbeat
US7333850B2 (en) * 2004-05-28 2008-02-19 University Of Florida Research Foundation, Inc. Maternal-fetal monitoring system
KR100630341B1 (en) * 2004-12-31 2006-09-29 학교법인연세대학교 Separating apparatus and method of fetal ECG from maternal abdomen ECG
JP4590554B2 (en) * 2005-01-31 2010-12-01 国立大学法人東北大学 ECG signal processing method and ECG signal processing apparatus
US7474915B2 (en) * 2005-07-26 2009-01-06 American University Of Sharjah And Arab Science And Technology Foundation Separating mixed signals containing a distorted signal
PL2185068T3 (en) * 2007-07-20 2017-06-30 Stichting Voor De Technische Wetenschappen Fetal monitoring
WO2009110051A1 (en) * 2008-03-03 2009-09-11 株式会社 東北テクノアーチ On-line vital signal processing method effective during fetal movement and its apparatus
EP2276401A4 (en) * 2008-04-15 2014-02-05 Tufts Medical Ct Fetal ecg monitoring
US9414786B1 (en) * 2009-11-03 2016-08-16 Vivaquant Llc ECG sensing with noise filtering
US8632465B1 (en) * 2009-11-03 2014-01-21 Vivaquant Llc Physiological signal denoising
US9408549B2 (en) * 2009-11-03 2016-08-09 Vivaquant Llc Detecting fiducial points in physiological signals
KR101029386B1 (en) 2010-04-16 2011-04-13 계명대학교 산학협력단 Method for qrs detection using real-time ecg monitoring system
US9717412B2 (en) * 2010-11-05 2017-08-01 Gary And Mary West Health Institute Wireless fetal monitoring system
EP2668897B1 (en) * 2011-01-25 2024-03-27 Public University Corporation Nara Medical University Fetal heart potential signal extraction program, fetal heart potential signal-discriminating apparatus and pregnancy monitoring system using same
KR101245445B1 (en) * 2011-04-29 2013-03-19 가톨릭대학교 산학협력단 R-peak detection method in ECG Signal and apparatus thereof
US20140058219A1 (en) * 2012-02-14 2014-02-27 Marianna Kiraly Device for recording ultrasound-induced fetal eeg, and method of use
US9364160B2 (en) * 2012-03-28 2016-06-14 Qualcomm Incorporated Systems and methods for ECG monitoring
CN103222862A (en) * 2013-04-23 2013-07-31 江苏矽望电子科技有限公司 Passive fetal heart monitoring system based on acoustic sensor
EP3003080A4 (en) * 2013-06-01 2017-03-15 Healthwatch Ltd. Wearable fetal monitoring system having textile electrodes
WO2015033244A1 (en) * 2013-09-09 2015-03-12 Koninklijke Philips N.V. Fetal heart rate extraction from maternal abdominal ecg recordings
CN103610460B (en) * 2013-12-11 2015-10-28 哈尔滨工业大学 A kind of Fetal ECG method for extracting signal based on self adaptation FLANN wave filter
US9392952B1 (en) * 2015-03-10 2016-07-19 Nuvo Group Ltd. Systems, apparatus and methods for sensing fetal activity
US9572504B2 (en) * 2015-03-16 2017-02-21 Nuvo Group Ltd. Continuous non-invasive monitoring of a pregnant human subject

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN116458864A (en) * 2023-06-19 2023-07-21 深圳大学 Intelligent fetal health early warning system

Also Published As

Publication number Publication date
EP3267884B1 (en) 2021-07-28
US20190059767A1 (en) 2019-02-28
AU2016230825B2 (en) 2017-10-19
AU2016230825A1 (en) 2017-09-28
WO2016142780A1 (en) 2016-09-15
CN107405096B (en) 2019-07-12
US20220395212A1 (en) 2022-12-15
DK3267884T3 (en) 2021-10-25
CA2979135C (en) 2018-06-19
EP3267884A4 (en) 2019-04-24
CN107405096A (en) 2017-11-28
US20170007142A1 (en) 2017-01-12
KR101900641B1 (en) 2018-09-19
CA2979135A1 (en) 2016-09-15
KR20170120706A (en) 2017-10-31
ES2895642T3 (en) 2022-02-22
EP3267884A1 (en) 2018-01-17
US10111600B2 (en) 2018-10-30
US9392952B1 (en) 2016-07-19

Similar Documents

Publication Publication Date Title
US20210259613A1 (en) Apparatuses for tracking physiological parameters of mother and fetus during pregnancy
US8954140B2 (en) Method and system for determining QRS complexes in electrocardiogram signals
EP3270774B1 (en) Continuous non-invasive monitoring of a pregnant human subject
WO2012151498A2 (en) Signal averaging
US20230301581A1 (en) Fusion signal processing for maternal uterine activity detection
CN112839584B (en) System and method for maternal uterine activity detection
CN110063726B (en) Electrocardiosignal single-lead f-wave extraction method and device
US20220378364A1 (en) Systems and methods for maternal uterine activity detection
Hamad Discrete Cosine Transform based ECG Signal Analysis and Processing.
Gautam et al. A Critical Review of Various Peak Detection Techniques of ECG Signals

Legal Events

Date Code Title Description
AS Assignment

Owner name: NUVO GROUP LTD., ISRAEL

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:OZ, OREN;INTRATOR, NATHAN;MHAJNA, MUHAMMAD;SIGNING DATES FROM 20151029 TO 20151102;REEL/FRAME:056074/0429

STPP Information on status: patent application and granting procedure in general

Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION

STPP Information on status: patent application and granting procedure in general

Free format text: NON FINAL ACTION MAILED

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION

AS Assignment

Owner name: GAINGELS 10X CAPITAL DIVERSITY FUND I, LP, VERMONT

Free format text: SECURITY INTEREST;ASSIGNOR:NUVO GROUP LTD.;REEL/FRAME:066366/0843

Effective date: 20240116