Various embodiments relate to an electrocardiogram signal processing system.
Electrocardiogram (ECG) is the electrical representation of the contractile activity of the heart over time, which can be easily recorded using non-invasive electrodes on the chest or limbs. ECG indicates the overall rhythm of the heart and weaknesses in different parts of the heart muscle, and can measure and diagnose abnormal rhythms of the heart.
An ECG signal can be represented by a cyclic occurrence of patterns with different frequency content (QRS complexes, P and T waves). The different types of noise and interference can also be separated into different frequency bands.
Several well-documented signal processing algorithms exist that can separate an ECG signal into its different frequency bands. An example of a signal processing algorithm is wavelet transformation. Wavelet transform (WT) are mathematical functions that separate a signal into different frequency bands.
It is possible to apply different signal processing on different sub-bands to realize different functions. In known systems, for each of the different functions, a different signal processing algorithm is used to separate the ECG signal into its different frequency bands. This leads to an increase in the system size.
If many types of ECG signal processing can be integrated into one ASIC chip, the chip size can be quite small. There is thus a need to provide a compact ECG signal processing system which would be suitable for long-term monitoring
According to an embodiment, an electrocardiogram signal processing system is provided. The electrocardiogram signal processing system includes: a wavelet transformation unit comprising a plurality of outputs, each output being connected to one of a plurality of scales, wherein the wavelet transformation unit is adapted to transform an input electrocardiogram signal into a set of wavelets, each wavelet being output to one of the scales; a plurality of signal processing blocks, each of the signal processing blocks coupled to some respective outputs of the wavelet transformation unit and configured to receive and process the wavelet from the respective output, wherein the signal processing blocks provide processing functions which differ from one another.
In the context of various embodiments, the term “electrocardiogram signal processing system” may mean an application specific integrated circuitry (ASIC) entirely fabricated on a single chip, in the context of semiconductor technology. The ASIC may have one or more devices that provide processing functions such as AND, NAND, or OR logic using transistors, resistors, capacitors, inductors and the like. Each of the one or more elements may serve any purpose, for example serving to perform wavelet transformation.
In the context of various embodiments, the term “wavelet transformation unit” may mean a device configured to perform wavelet transformation, which are mathematical functions that separate a signal into different frequency bands. In various embodiments, after the wavelet transformation, the signal is decomposed into a set of wavelets, with each wavelet having a respective frequency band.
In the context of various embodiments, the term “scale” may mean a port or signal path reserved to transmit signals of a designated bandwidth. In various embodiments, each scale may have a different bandwidth, wherein the wavelet output to one of the scales is derived from the wavelet output to an earlier scale. There may be at least eight scales, the scales having 3 dB bandwidths of around 250 to 500 Hz; 72 to 234 Hz; 32 to 108 Hz; 16 to 54 Hz; 8 to 26 Hz; 4 to 13 Hz; 2 to 6.5 Hz; and 1 to 3.25 Hz each, when the sampling rate of the input signal is 1 kHz.
In various embodiments, having the signal processing blocks configured to provide processing functions which differ from one another allows the electrocardiogram signal processing system to perform multiple functions on different scales. For instance, for the first to the fourth scales, signal processing blocks, where each provides noise suppression, QRS detection and HBR (heart beat rate) classification may be provided. For the fifth to the six scales, a signal processing block that provides data compression may be provided. For the seventh to the eight scales, signal processing blocks, where each provides data compression and baseline removal may be provided.
In the context of various embodiments, the term “configured” may mean that the signal processing blocks are each provided with electronics that are designed to process the wavelets from the output of the wavelet transformation unit connected thereto.
In various embodiments, the wavelet transformation unit may include a plurality of low pass filters and a plurality of high pass filters. The low pass filter for the first scale may be given by the expression
lD,1(k)=⅛{δ(k+2)+3δ(k+1)+3δ(k)+δ(k−1)}
and the high pass filter for the first scale may be given by the expression
hD,1(k)=2{δ(k+1)−δ(k)},
wherein δ(k) is the Kronecker delta function and for scale numbers n>1, lD,n(k) and hD,n(k) are obtained by inserting 2n−1−1 zeros between each of the non-zero coefficients of lD,1(k) and hD,1(k).
In various embodiments, the low pass filters and the high pass filters have a cascaded arrangement, wherein an output of at least one of the low pass filters is coupled to an input of at least one of the high pass filters.
In various embodiments, the wavelet transformation unit may include a first memory array to achieve delay, the first memory array coupled to the last low pass filter of the cascaded chain of high pass filters and low pass filters.
In various embodiments, the signal processing blocks may include at least one wavelet denoising unit, an electrocardiogram signal reconstruction block, a data compression block, a baseline drift removal unit, a QRS detection unit and a HBR analysis unit. In various embodiments, having each signal processing block coupled to a respective output of the wavelet transformation unit allows each signal processing block to receive output of wavelets having a respective scale.
In various embodiments, the wavelet denoising unit may suppress high frequency noise and may be coupled to one of the respective outputs of the wavelet transforming unit emitting wavelets coupled to the first three scales and wherein the suppressed high frequency noise falls in a range of above 32 Hz.
In various embodiments, the electrocardiogram signal reconstruction block may process wavelets belonging to the first to the eighth scales and may reconstruct an ECG signal from the plurality of wavelets from the first to the eighth scales. Compared to the ECG signal input into the wavelet transformation unit, the reconstructed ECG signal is cleaner in that it has been processed to remove noise and baseline drifting. In various embodiments, the electrocardiogram signal reconstruction block further may include a first reconstruction block for the fifth to the eighth scales; a second reconstruction block for the first to the fourth scales; and a third reconstruction block for the first to the eighth scales.
In one embodiment, the first reconstruction block, the second reconstruction block and the third reconstruction block may include shift registers to achieve delay. In another embodiment, the first reconstruction block, the second reconstruction block and the third reconstruction block may include memory arrays to achieve delay. In a further embodiment, the first reconstruction block, the second reconstruction block and the third reconstruction block may include both shift registers and memory arrays to achieve delay.
In various embodiments, SRAM may be used for the memory arrays.
In various embodiments, the first reconstruction block may output synchronized signals belonging to the high-pass filtered components of the fifth to the eighth scales; the second reconstruction block may output synchronized signals belonging to the high-pass filtered components of the first to the fourth scales; and the third reconstruction block may output signals belonging to the low-pass filtered components of the first to the seventh scales. The output of the first to the third reconstruction blocks may be a reconstructed electrocardiogram signal.
In various embodiments, the second reconstruction block may be coupled to an output of one of the at least one wavelet denoising unit to receive denoised wavelets belonging to the first to the third scales.
In various embodiments, the data compression block may receive wavelets of the fifth to the eighth scales, wherein an output of the data compression block is coupled to the input of the first reconstruction block.
In various embodiments, the data compression block may be realized using finite-impulse-response filters and infinite-impulse-response filters, wherein either filter compensates poles and zeros of the other filter.
In various embodiments, the baseline drift removal unit may be coupled to the respective output of the wavelet transforming unit emitting wavelets belonging to the seventh and the eighth scales.
In various embodiments, the baseline drift removal block may be realized by an adaptive cascaded filter arrangement, the cascaded filter arrangement comprising at least one filter stage. In various embodiments, the adaptive cascaded filter arrangement may automatically switch off filter stages unnecessary for performing baseline drift removal. The unnecessary filter stages may be those larger than a filter stage in which the difference in the output value of the filter stage and an output value of the largest filter stage is smaller than a specified threshold. In various embodiments, the adaptive cascaded filter arrangement may include chebyshev IIR filters.
In various embodiments, the QRS detection unit may be coupled to the output of the at least one wavelet denoising unit and the output of the wavelet transforming unit emitting wavelets belonging to the fourth scale. The QRS detection unit may include a wavelet summation unit to sum the denoised wavelets from the at least one wavelet denoising unit and the wavelets from the wavelet transforming unit, wherein QRS peaks are detected when the summed wavelets exceed an adaptive threshold value.
In various embodiments, the QRS detection unit may be realized using any of a Field Programmable Gate Array (FPGA), Application Specific Integrated Circuits (ASIC) or be implemented by software. In various embodiments, the wavelet summation unit may include an adder; and the QRS peaks may be detected using a subtractor and multiplexer. The adaptive threshold value may be derived from a standard deviation of a number of sampled summed wavelets.
In various embodiments, the HBR analysis unit may be coupled to an output of the QRS detection unit. In various embodiments, the HBR analysis unit may include a counter; two multiplication modules; an adder and a delay block. In various embodiments, the HBR analysis unit may be realized by a Field Programmable Gate Array (FPGA), Application Specific Integrated Circuits (ASIC) or be implemented by software. In various embodiments, the HBR analysis unit may be adapted to predict QRS peak intervals based on a forward prediction algorithm. The forward prediction algorithm may be based on summing previous QRS peak intervals weighted with a forgetting factor, the forgetting factor determining the number of previous QRS peak intervals included for HBR analysis.
In the drawings, like reference characters generally refer to the same parts throughout the different views. The drawings are not necessarily to scale, emphasis instead generally being placed upon illustrating the principles of the invention. In the following description, various embodiments of the invention are described with reference to the following drawings, in which:
The following detailed description refers to the accompanying drawings that show, by way of illustration, specific details and embodiments in which the invention may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the invention. Other embodiments may be utilized and structural, logical, and electrical changes may be made without departing from the scope of the invention. The various embodiments are not necessarily mutually exclusive, as some embodiments can be combined with one or more other embodiments to form new embodiments.
To achieve high power & area efficiency, embodiments of an electrocardiogram signal processing system use wavelet transform (WT) algorithm to integrate multiple functions. Embodiments of the electrocardiogram signal processing system provide a dedicated power & area efficient non-downsampling WT ASIC implementation structure. WT separates incoming noisy ECG signals into different scales with different bandwidth. Consequently, high frequency noise is suppressed by a de-noising block on the outputs of non-downsampling WT decomposition (NDWTD) scales 1 to 3. A real-time adaptive QRS detection block uses the de-noised NDWTD outputs to acquire the QRS peaks. The HBR prediction and classification is performed by a prediction & classification block. The artificial baseline drift is suppressed by a baseline drift removal block on the outputs of NDWTD scales 7 to 8. After removing high-frequency noise components and the low-frequency baseline drift, the clean ECG signal can be reconstructed by a nondownsampling WT reconstruction (NDWTR) block. All blocks may communicate with each other in 1 kHz frequency.
An overview of the electrocardiogram signal processing system 100 is as follows. A signal acquisition front-end circuit provides 9-bits digitalized ECG signals 152 to the electrocardiogram signal processing system 100 with f1=1 kHz sampling rate. The same sampling rate may be maintained in different WT scales S1 to S8 to avoid the issues of time-shifting and the temporal resolution degradation, as reported in J. P. Martìnez, R. Almeida, S. Olmos, A. P. Rocha, and P. Laguna, “A wavelet-based ECG delineator: evaluation on standard databases,” IEEE Trans. Biomedical Engineering, vol. 51, no. 4, pp. 570-581, 2004. However, increasing the number of scales causes huge number of taps of WT low-pass filters (LPFs) and high-pass filters (HPFs). To optimize hardware implementation, a dedicated NDWT ASIC implementation structure is used. For scales 1˜4 of NDWTD, since the total number of filter taps is small, conventional shift registers based FIR filter structure may be used with the operation clock being f1=1 kHz. Subsequently, 4 single-port static random access memories (SRAM1˜4) may be used to realize the huge number of finite impulse response (FIR) filter taps and buffers between decomposition HPFs (DHPFs) and reconstruction HPFs (RHPFs). SRAM 1˜4 are designed for scales 5˜8 DLPFs and DHPFs, scales 1˜4 RHPFs, scales 5˜8 RHPFs, and scales 1˜8 reconstruction LPFs (RLPFs), respectively. The operation of SRAM is time-division multiplexing (TDM), and its operation clock f2 is 32 kHz. During one clock cycle of f1, each SRAM writes and reads with sequential specific address and scale by scale with frequency f2, which is higher than f1. For each SRAM, only one multiplication module is required because of TDM. A control module for the SRAM generates control signals and controls a first multiplexer MUX1 to select signals from different scales and controls a second multiplexer MUX2 to select different multiplication factors for the outputs of different scales. Memory-based structure is used for the non-downsampling WT because of the large number of delays and small number of non-zero filter coefficients. Since memory based WT structure is simpler and smaller in layout, and no buffers need to be inserted for timing routing during place & route, the electrocardiogram signal processing system 100 may result in 55% area reduction over conventional shift register based structure.
The electrocardiogram signal processing system 100 includes: a wavelet transformation unit 102 and a plurality of signal processing blocks 150.
The plurality of signal processing blocks 150 includes a noise suppression block 110 (having at least one wavelet denoising unit), an electrocardiogram signal reconstruction block 116, a data compression block 106, a baseline drift removal unit 108, a QRS detection unit 112 and a HBR (heart beat rate) analysis unit 114. Each signal processing block (110, 116, 106, 108, 112 and 114) is coupled to a respective output of the wavelet transformation unit 102, which allows each signal processing block to receive input of wavelets having a respective scale. Thus, each signal processing block (110, 116, 106, 108, 112 and 114) is configured to receive and process the wavelet from the respective output. Each signal processing block (110, 116, 106, 108, 112 and 114) provides processing functions which differ from one another, allowing the electrocardiogram signal processing system 100 to perform multiple functions on the different scales S1 to S8. For instance, noise suppression, QRS detection and HBR classification may be performed on the first to the fourth scales S1 to S4. For the fifth to the six scales, data compression may be performed. For the seventh to the eight scales, data compression and baseline removal may be provided. By having each signal processing block (110, 116, 106, 108, 112 and 114) provide a different processing function, multiple functions are performable from the same generic output from the wavelet transformation unit 102.
Further detail on the wavelet transformation unit 102 and the plurality of signal processing blocks 150 is provided below.
The wavelet transformation unit 102 decomposes an input signal electrocardiogram signal 152 into different scales with different bandwidth. The quadratic spline wavelet function is normally used for ECG signal analysis.
The wavelet transformation unit 102 includes a plurality of outputs (DHoutS1, DLoutS1; DHoutS2, DLoutS2; DHoutS3, DLoutS3; DHoutS4, DLoutS4; DHoutS5, DLoutS5; DHoutS6, DLoutS6; DHoutS7, DLoutS7; DHoutS8, DLoutS8) of the outputs is connected to a respective one of a plurality of scales, S1 to S8. In the embodiment shown in
The wavelet transformation unit 102 is adapted to transform an input electrocardiogram signal 152 into a set of wavelets (being, in the embodiment shown in
In the embodiment shown in
In the embodiment shown in
I Real-time Wavelet Transformation Unit and Electrocardiogram Signal Reconstruction Block; and Data Compression and Decompression Block
A) Real-time Wavelet Transformation Unit and Electrocardiogram Signal Reconstruction Block
As shown in
respectively, where Yn−1(i) is the output of DLPF from scale n−1, lD,n(k) and hD,n(k) are the coefficients of DLPF and DHPF of scale n, respectively. For the first scale S1, lD,1(k) and hD,1(k) are given by
wherein δ(k) is the Kronecker delta function. For scale n>1, lD,n(k) and hD,n(k) are obtained by inserting 2n−1−1 zeros between each of the non-zero coefficients of lD,1(k) and hD,1(k).
In the electrocardiogram signal reconstruction block 116, an inverse wavelet transform (IWT) can reconstruct the signal from different scales. The reconstruction algorithm can be derived by
where wn(i), lR,n(k) and hR,n(k) are the outputs, coefficients of reconstruction LPF (RLPF) and coefficients of reconstruction HPF (RHPF) at scale n, respectively. For scale 1, lR,1(k) and hR,1(k) are expressed by
respectively. For scales n>1, lR,n(k) and hR,n(k) are obtained by inserting 2n−1−1 zeros between each of the non-zero coefficients of lR,1(k) and hR,1(k). The real-time wavelet transform occurring in various embodiments does not need to consider border problems, since the ECG signal 152 continuously inputs, so that only the initial several reconstructed ECG signal samples suffer distortion.
From equations (3), (4), (6) and (7), it can be observed that, for higher scale WT/IWT, the number of taps of LPFs and HPFs increase. For example when n=8, the number of taps of lD,8(k), hD,8(k), lR,8(k), and hR,8(k) becomes 385, 129, 385, and 641 respectively. Therefore, there will be a huge hardware cost for non-downsampling wavelet transformation low-pass and high-pass filtering.
When decomposing the ECG signal 152, the first scale S1 is first obtained, followed by the second scale S2, until the Nth scale is finally obtained, which in the embodiment shown in
Therefore, for complete real-time wavelet transformation based decomposition and reconstruction, the delay between obtaining output of the first scale S1 from the DHPF before being processed by the RHPF for the first scale 51 for reconstruction is longest. On the other hand, the delay between obtaining output of the eighth scale S8 from the DHPF before being processed by the RHPF for the first scale S8 for reconstruction is shortest. Therefore, there are different processing delays for different scales.
For ASIC implementation of real-time signal processing, delays in a FIR filter may be implemented by shift registers.
For non-downsampling wavelet transformation HPFs and LPFs, the number of delays would be large, especially for higher scales. Further, to synchronize the DHPF outputs at the signal reconstruction block 116 (see
Using Chartered 0.18 μm technology, one register occupies about 60 μm2. On the contrary, the SRAM unit has comparatively simpler structure. To realize the large delay required by embodiments of the present invention, a large number of shift registers are needed, thus using the architecture shown in
In the interest of achieving a more compact device, delay may also be implemented by using static random access memory (SRAM).
Using single-port SRAM with the same technology to build 720×20 units and taking the area of I/O port into consideration, the average area for one unit is only about 8 μm2, which is much smaller than that of the register.
A comparison between using shift registers and SRAM to achieve delay is provided below.
Every clock cycle of f1, data stored in one register (for example 202) will shift to the next register (204), and thus the transition of register input will consume comparatively high power, especially when the chain of shifting registers is long. On the contrary, an SRAM need only write the data into a unit at a specific clock cycle and keep it, and then read the data out at another specific clock cycle. Therefore, power consumption by the SRAM is much lower than the shift registers.
A shift register needs to build clock tree to solve setup and hold time violation, and thus a large number of buffers need to be inserted between shift registers. These buffers result not only in a larger area, but also higher power consumption.
Time has also to be expanded on floorplan and routing when a large number of registers are used. Since, SRAM are already integrated, there is no requirement to consider how to place and perform internal routing. Thus, the SRAM provides a comparatively simpler structure.
According to equations (3), (4), (6) and (7), although the number of taps for HPFs and LPFs are huge, which is larger than 2n−1−1, the number of non-zero coefficient B is invariant for different scales. B=4 for lD,n(k) and lR,n(k), 2 for hD,n(k), and 6 for hR,n(k), which are quite small. It means that for each scale, only a few mathematical operations, including multiplication and addition, need to be executed on the data to be processed. The non-zero coefficients for different scales are the same as shown in equations (3), (4), (6), and (7). Therefore, the non-downsampling WT & IWT filters have “sparse” structures. For the scales S1 to S4 of WT decomposition, the total number of filter taps is not significantly large, therefore the shift register architecture 200 may be used to implement the filter arrangement 164, where the operation clock is the sampling rate of input signal f1.
For the scales S5 to S8 (see
First considering the decomposition of an ECG signal, since the sampling rate of input is f1, the memory array 104 needs to operate at a higher operation frequency f2. During one clock cycle 302 of f1, one data sample 304 (containing data from output DLoutS4 of the last low pass filter 160DLPF_S4 of the filter arrangement 164 [see
For wavelet reconstruction since the input data 354 for RHPF and RLPF are different according to equation (5), two separate SRAM arrays (only one SRAM array 350 is shown in
Instead of using two separate SRAM arrays to realize the DHPF output delay and the delay inside RHPF respectively, a single SRAM array (such as the SRAM array 350 shown in
Returning to wavelet decomposition, to further reduce the number of I/O control part and hardware area, the SRAM array 320 integrates four single port SRAM 316 units together. For the scales S5 to S8 DLPF implementation, for example, adopting four separate single-port SRAM units 316 using Chartered 0.18 μm technology gives an area of about 160750 μm2. However, for the integrated SRAM array 320, the area is only about 105814 μm2, which reduces almost 34% hardware area.
The integrated SRAM array 320 works as follows. Different data sequences need to be written into the SRAM array 320, and the sampling rate for each sequence is f1. Memory units are allocated to the different scales S5 to S8 in a sequential manner. Assuming the number of required units for scales n, n+1, n+2 are Pn, Pn+1, Pn+2, respectively, the memory addresses that allocated to them are 0˜(Pn−1) Pn˜(Pn+Pn+1−1), and (Pn+Pn+1)˜(Pn+Pn+1+Pn+2−1) respectively. The addresses for writing and reading are sequential and scale by scale. For DHPF, for example, the memory operation is writing data of scale n, reading data 1 of scale n, reading data 2 of scale n, writing data of scale n+1, reading data 1 of scale n+1, reading data 2 of scale n+1, . . . , in sequence. In
As multiplication modules are normally complex and occupy large areas, it is an objective of various embodiments to use fewer multiplication modules. According to equations. (3), (4) and (6), it can be observed that the multiplication operation for DLPF, DHPF, and RLPF may be implemented by shifting and adding operations. For RHPF in Eq. (7), multiplication occurs at the higher operation frequency f2. Therefore, only one multiplication module 312 is required for one integrated SRAM array 320 for the different scales S5 to S8. As shown in
Thus, the eight scales WT decomposition separates the incoming ECG signal 152 into eight DHPF outputs from scales S1 to S8 and one DLPF output for scale S8. These nine signal sequences represent different characteristics of ECG signal in different bandwidth.
The above decomposition and reconstruction schemes are based on WT, and are suitable for non-downsampling WT. Non-downsampling WT has a “sparse” FIR structure, with a large number of delays and a small number of non-zero coefficients. The SRAM array 320/350 has an operating frequency f2 which, in one embodiment, may only be 32 times higher than the sampling frequency f1. In contrast, using a normal FIR structure which has a large number of both delays and non-zero coefficients, the operating frequency of the FIR structure would need to be at an impractically (around hundreds of times) larger value than the sampling frequency.
When choosing whether to use a single-port SRAM or a double-port SRAM to realise the memory array 320, the number of scales that the memory array 320 processes is a factor. The number of scales that can be processed by an integrated SRAM is, in turn, limited by the following factors.
The first factor is the number of I/O ports that the memory can provide. A single-port SRAM occupies much smaller area as compared with a dual-port one. However, the dual-port memory can perform reading and writing operation at same time, whereas the single-port one can only perform either reading or writing operation during one clock cycle of f2. Therefore, the maximum number of times for reading and writing during one clock cycle of f1 using single-port SRAM is less than that using dual-port memory, resulting in that the maximum permitted number of scales using single-port SRAM is less than that using dual-port SRAM.
The second factor is the ratio between the highest operation clock frequency f2 that the system can support and the sampling rate of the input data sequence f1. The higher the ratio, the more the reading and writing operation can be performed during one clock cycle of f1, resulting in more scales that can be combined together.
The third factor is the number of non-zero coefficients for FIR filters. Assuming there are M non-zero coefficients for the FIR filter of each scale, the maximum number of scales using single-port SRAM and dual-port SRAM can be calculated by equations (8) and (9), respectively.
where └x┘ is the operation choosing the maximum integer that is not larger than x.
It will be appreciated that shift registers are also usable to realise the decomposition and reconstruction of the ECG signal. However, by using SRAM to facilitate the WT decomposition and reconstruction, area of about 50% can be saved as compared to using conventional shift registers.
Returning to
B) Data Compression and Decompression
As shown in
To minimize the area of storage units, the data compression block 106 utilizes a data compression algorithm, based on the properties of WT decomposition for the WT scales 5˜8 DHPF. In various embodiments, the data compression algorithm is computational efficient.
From
c(i)=d(i)−d(i−1) (10)
where d(i) and c(i) are the data samples before and after compression, respectively. Equation (10) may also be thought of as a first-order differentiator with the transform function
F1(z)=1−z−1 (11)
Considering DHPF output of scales S5 to S8, it can be observed that the passband of scale S8 is the lowest whereas the passband of scale S5 is the highest. Therefore, comparing different scales, the amplitudes of variations in scale S8 are smallest, whereas the variations in scale S5 are largest. As a result, c(i) in Eq. (10) for scales S5 and S6 may be much larger than that for scales S7 and S8. Therefore, the second-order differentiator instead of first-order differentiator can be adopted for scales S5 and S6 to further reduce the amplitude of variations, as given by
and its corresponding z domain transform function is
F2(z)=1+2z−1+z−2 (13)
The frequency response of F1 and F2 is shown in
Returning to
and the reconstruction filter for scales S5 to S6 is
From equations (14) and (15), it can be observed that the reconstruction filters are first-order and second-order integrators. They may be infinite impulse filters (IIR) with poles on the unit circle, resulting in instability. However, cascading and Fi and Gi, i=1, 2, the poles and zeros compensate each other, and thus the complete system is stable. Thus, the data compression block 106 may be realized using finite-impulse-response filters and the data decompression may be realized using infinite-impulse-response filters, wherein either filter compensates poles and zeros of the other filter.
II Baseline Drift Removal Unit
As shown in
Various embodiments, while providing a computational efficient and low cost scheme for hardware implementation, address the problems of using high-pass filters as follows. Similar to the power & area efficient WT decomposition/reconstruction scheme described in the earlier section, various embodiments of the baseline drift removal unit 108 take advantages of the natural properties of WT to remove baseline drift. Various embodiments use an automatic decision scheme to determine whether the WT based scheme has sufficiently removed baseline drift. In circumstances where the WT based scheme can not sufficiently remove baseline drift, additional HPF may be applied. Assuming that a bradycardia of 42 beats per minute is the lowest heart rate to be processed, then the lowest frequency component of the ECG spectrum is 0.7 Hz, and the low cut-off frequency may be as high as the HBR without disturbing the waveform.
Various embodiments use a sampling rate of incoming ECG signal f1 of around 1 kHz to keep high resolution.
It is also observed that almost all the DC components and baseline drifting fall in the DLPF output of scale S8 and DHPF outputs of scale S7 to S8. Various embodiments focus on these three sub-band signals and can be separated into two steps.
In the first step, the DLPF output of scale S8, DLoutS8, is forced to zero as it is dominated by DC components and lowest frequency components. From
On the other hand, if baseline interference is comparatively large, it may be necessary to introduce additional filters to suppress the baseline removal. Two high-pass filters (represented as numeral 166 in
The number of stages, Pi, to meet the requirement value may be calculated by the following formula
where L is the number of output samples taken into account, and Sl,i is the difference between the lth output of stage i and stage 4. i=0 means that no additional filter operates, and the DHPF outputs of scale 7 and 8 are directly used for clean ECG reconstruction. If the output of stage i has enough capability of baseline removal, the stages larger than i are not necessary and their clock source are latched, resulting in total computational complexity and power consumption reducing.
To minimize the computational complexity, the second order statistic in equation (16) may be replaced by the first order statistic, that is
If Ai is smaller than a specified threshold, determined by a comparator circuit 702 of the control module 706, the comparison procedure is finished. The output (indicated as reference numeral 708 in
Thus, the baseline drift removal block 108 may be realized by an adaptive cascaded filter arrangement 704, the cascaded filter arrangement 704 comprising at least one filter stage. The adaptive cascaded filter arrangement 704 may automatically switch off filter stages unnecessary for performing baseline drift removal. The unnecessary filter stages may be those larger than a filter stage in which the difference in the output value of the filter stage and an output value of the largest filter stage is smaller than a specified threshold. The baseline drift removal unit 108 is connected to scales S7 and S8 (WT S7 and WT S8 of
III Noise Suppression Block, Adaptive Threshold Based QRS Detection Unit, and HBR Analysis Unit
A) Noise Suppression Block
As shown in
Various embodiments provide a real time QRS detection ASIC based on sum of denoised outputs of DHPF. The QRS detection unit 112 is coupled to the output of the at least one wavelet denoising unit 110 and the output of the wavelet transforming unit 102 emitting wavelets belonging to the fourth scale. To exploit wavelet inter-scale dependencies, various embodiments multiply adjacent outputs of DHPF to enhance edge structures while weakening noise. Thereafter, a threshold may be calculated and imposed on the products, instead of on the outputs of DHPF, to identify the important features.
To enhance QRS detection, signal preprocessing to reduce noise reduction is preferred.
The algorithm shown in
As shown in
In 902, for QRS detection, the denoised signals {xn(i)}de are fed into a summation system, where the denoised outputs of DHPF are summed point-by-point to emphasize the QRS complex while suppressing the noise. The summation Sp(i) can be defined as
Sp(i)={x2(i)}de+{x3(i)}de+x4(i) (21)
In 904, to make the decision for detecting QRS peaks, an adaptive threshold-based scheme is applied to the feature waveform generated from the summation stage. The thresholding scheme can be formulated as:
where ΦQRS indicates the position of QRS peaks and γQRS denotes the adaptive threshold. The adaptive threshold γQRS can be calculated as follows. The instant standard deviation of Sp(i) is calculated for every window with a specified number of samples, and is denoted by σs(k), where k denotes the kth window. The number of samples per window may be 1024. The standard deviation
where λ is referred to as the “forgetting factor” with 0≦λ≦1. Finally, the adaptive threshold may be given by
γQRS=c·
where c is an adjustable constant. According to equations (23) and (24), it can be seen that each new value of the threshold is determined from the prior and current values of the threshold itself. In 906, A QRS peak is detected if the featured signal (i.e., Sp(i)) exceeds the threshold. The value of the threshold is then updated each time when a new window of ECG signal comes. Thus from 902 to 906, a wavelet summation unit of the QRS detection unit 112 sums denoised wavelets {xn(i)}de from the at least one wavelet denoising unit 110 (see
C) Heart Beat Rate Prediction & Classification
As shown in
The QRS peak is detected by the real-time adaptive QRS peak detection algorithm used by the QRS detection unit 112. The QRS peak directly reflects the heart beat rate (HBR) and thus its change is a good indicator for classifying potential heart diseases. For example, normally HBR larger than 90 bpm or less than 60 bpm may indicate tachycardia or bradycardia, respectively. However, some patients naturally have somewhat faster or slower HBR in normal status, and thus simply setting a hard decision threshold would not be accurate. Various embodiments use a more accurate classification for the individual status of different patients.
The HBR analysis unit 114 includes a heart beat interval counter 1002 coupled to two multiplication modules: a first multiplication module 1004 and a second multiplication module 1008. The first multiplication module 1004 is coupled to a feedback arrangement 1006. The feedback arrangement 1006 includes the second multiplication module 1008, a delay unit 1010 and a summation unit 1012. The HBR analysis unit 114 may be realized by a Field Programmable Gate Array (FPGA), Application Specific Integrated Circuits (ASIC) or be implemented by software.
The HBR analysis unit 114 predicts QRS peak intervals based on a forward prediction algorithm. The forward prediction algorithm may be based on summing previous QRS peak intervals weighted with a forgetting factor, the forgetting factor determining the number of previous QRS peak intervals included for HBR analysis. Further detail on the forward prediction algorithm is as follows.
Assuming the nth detected QRS peak interval is T(n), then the updated prediction of QRS peak interval (i.e. the output of the feedback arrangement 1006) can be obtained as
where M is the order of taps and wk is the tap weights. The prediction algorithm of equation (25) may be implemented by a M-tap FIR filter, as shown in
Te(n)=λTe(n−1)+(1−λ)T(n−1) (26)
where λ is the forgetting factor, which is less than but close to 1. Expanding equation (26), the following is obtained
Assuming Te(0)=0, and defining the tap weights wn=λn−1(1−λ), wn−1=λn−2(1−λ), . . . w1=(1−λ), equation (27)can be represented by
which is exactly the forward prediction in Eq. (25) by setting M=n.
In various embodiments, the value λ dominates the sensitivity of the proposed prediction algorithm, which is a measure of the memory of the previous input data. The larger the forgetting factor λ, the longer the memory of the previous input, resulting in a long-term prediction with slower prediction change. Even when HBR of the patient varies rapidly within a certain time duration, the long-term prediction can still be able to obtain the stable average HBR without large perturbation. The long-term prediction can indicate the average HBR of the patient in a comparatively long observation window, and can reflect the long-term change trend of the average HBR with less effect by instant HBR variation. Therefore, doctors can use this long-term observation as a baseline reference for a patient in a normal status. On the other hand, the smaller the forgetting factor λ, the shorter the memory of the previous input, resulting in a short-term prediction with rapid prediction change. This short-term prediction can be used to track the most recent or rapid change of HBR, indicating whether the patient is undergoing abnormal cardiac status. The long-term and short term prediction can work together. If the two observations are overlapped, the short-term observation will vary around the long-term observation. The long-term observation may be treated as the baseline, indicating the trend of HBR drift under normal status. The upper and lower thresholds may be specified according to this baseline, respectively. If the short-term observation exceeds the specific upper threshold, a tachycardia can be discriminated. If the short-term observation exceeds the specific lower threshold, on the other hand, a bradycardia can be discriminated. Such a classification scheme is more accurate than that using hard decision threshold, because the baseline of individual status for different patients is taken into consideration. In various embodiments, the recursive forward prediction algorithm implemented by the feedback arrangement 1006 and the first multiplication module 1004 may be used to track the trend of HBR change long-term and short-term prediction by setting λ=0.998 and 0.875 respectively. The long-term prediction serves as a baseline reference indicating the long-term change trend of the average HBR. The short-term prediction tracks the rapid change of HBR and filters occasional changes caused by strong emotions or exercise. Setting an appropriate threshold based on long-term prediction and observing the short-term prediction, more accurate arrhythmias classification for the individual status of different patients can be achieved.
The DHPF outputs 1016 for adjacent scales (from scales S1 to S4) are multiplied to obtain Un 1018 to amplify significant features and dilute noise. The threshold of denoising tn is calculated from the standard deviation of Un 1018. The noise-suppressed DHPF outputs 1022 are fed into the electrocardiogram signal reconstruction block 116 for clean ECG reconstruction. The QRS detection unit 112 calculates the summation Sp 1020 of the de-noised DHPF outputs 1024 from scales S2 to S3 and DHPF output DHoutS4 to emphasize the QRS complex while suppressing noise. An adaptive recursive tracking algorithm is applied to update the threshold tp of the adaptive threshold circuit 1026, which is calculated from the standard deviation of Sp 1020. The QRS detection unit 112 may be realized using any of a Field Programmable Gate Array (FPGA), Application Specific Integrated Circuits (ASIC) or be implemented by software. In
IV Electrocardiogram Signal Processing System Using Dyadic Wavelet Transform Multiscale-Product Based QRS Complex Detection Algorithm (DYWT-MP-QRS)
The QRS detection algorithm used by the QRS detection unit 112 is based on wavelet multiscale product and a simple decision algorithm. Since wavelet multiscale product and rescaled power of the wavelet multiscale product are considered to achieve good detection accuracy, a decision algorithm based on an amplitude comparison to a simple threshold may be employed, where no search-back is used. One detection threshold needs only to be calculated, compared to known systems which use four thresholds at scales 1 to 4 to obtain the location set of “modulus maxima” across the scales.
As shown in
where * is the convolution operator and low-pass subband S2jf(n) and W2jf(n) are implemented with FIR filters as follows:
where hi and gi are low-pass and high-pass coefficients, respectively and are deployed from S. Mallat, and S. Zhong, “Characterization of signals from multiscale edges,” IEEE Trans. Pattern Analysis and Machine Intelligence, vol. 14, pp. 710-732, 1992. The wavelet used for DYWT in various embodiments is chosen as the first order derivatives of a smooth function (a cubic spline function, see S. Mallat, and S. Zhong, “Characterization of signals from multiscale edges,” IEEE Trans. Pattern Analysis and Machine Intelligence, vol. 14, pp. 710-732, 1992), the DYWT W2jf(n) can be interpreted as the derivatives of local smooth (average) of ft at scale j (S. Mallat and W. L. Hwang, “Singularity detection and processing with wavelets,” IEEE Trans. Inform. Theory, vol. 38, pp. 617-643, February 1992). Hence, if ft has some singular points, W2jf(n) will appear as modulus maxima at these locations. The amplitude of noise modulus maxima will decrease from small scale to large scales while the amplitude of signal modulus maxima will increase from small scales to large scales in the wavelet domain (S. Mallat, and S. Zhong, “Characterization of signals from multiscale edges,” IEEE Trans. Pattern Analysis and Machine Intelligence, vol. 14, pp. 710-732, 1992), (S. Mallat and W. L. Hwang, “Singularity detection and processing with wavelets,” IEEE Trans. Inform. Theory, vol. 38, pp. 617-643, February 1992). Therefore, multiscale-product sequence ξtK (indicated as reference numeral 1102 in
The power of ξtK is rescaled in step 1104 to that of W2jf(n) by χ and ψ to get a new normalized detection signal ζt and it can be defined as in equation (34)
where
Since the wavelet coefficients corresponding to the signal are enhanced in the new detection signal ζt, the local maxima (minima) in ζt can be accurately identified by applying a simple scheme of thresholding for the decision making stage.
To perform the decision making for detecting QRS complexes, in 1108 an interval-dependent threshold scheme is applied to the new detection signal. Assume a detection threshold is γ and is calculated in each interval between two consecutive QRS intervals and updated once for every interval. To determine γ, the standard deviation of ζt is computed in equation (35):
where N is the number of samples. The standard deviation σw(j) is updated every N=1024 samples and the mean value of ζt is almost zero per every 1024 samples. Therefore, equation (35) can be simplified as:
and setting the detection threshold as
γ=c·[σw(j)] (37)
where constant c is used to adjust the threshold γ imposed on ζt. From comparison in 1106, the threshold scheme can then be formulated in 1110 and 1112 respectively as
Φ is the vector that contains the site of R peak points. The constant c is adjustable to achieve good detection accuracy.
Power is proportional to α·CL·VDD2·f, where α is the switching activity, f is the frequency, CL is the load capacitance, and VDD is the supply voltage. Consequently, low-power digital design focuses on reducing α, CL, VDD, and f. These parameters can be reduced through algorithmic, architectural and circuit techniques.
Various embodiments reduce design complexity related to the effective capacitance (i.e. α·CL).
The electrocardiogram signal processing system 1200 includes a wavelet transformation unit 1202, a delay block 1204, a multiscale product block 1206, a threshold generation block 1208, a rescaling block 1210, a decision logic unit 1212, a RAM block 1214 and an address generator block 1216.
In the embodiment shown in
H1(z)=h0+h1z−1+h2z−2+h3z−3 (39)
G1(z)=g0+g1z−1 (40)
Since the coefficients are symmetric (i.e., h0=h3, h1=h2 and g0=−g1) (as per Y. Xu et. al., “Wavelet transform domain filters: A spatially selective noise filtration technique,” IEEE Trans. Medical Imaging, vol. 22, pp. 323-331, 2003), the number of multipliers may be reduced into half. The transfer functions become:
H1(z)=h0(1+z−1)+h1(z−1+z−2) (41)
G1(z)=g0(1−z−1) (42)
Since the data input to low-pass and high-pass filters are the same at each scale level, the number of delay elements can therefore be shared to minimize the hardware cost. The order increases with scale level increases because (2j−1) zeros coefficients are inserted between two non-zero coefficients. However the numbers of non-zero coefficients remain the same at each level, the required number of multiplications and addition are the same at each level and delay elements are increased by 2 times. With this architecture, DYWT scale level 1 to 4 (labeled as numeral 1218 in
The delay block 1204 may have 11 D flip-flops (i.e., 11 clock cycles) to align three high-pass outputs (i.e. the outputs from the filters G1, G2, G3 of
The threshold generation block 1208 calculates the dynamic threshold γ as in equation (37) by multiplying the standard deviation of ζt and constant c. The procedure of generating the QRS detection threshold γ may be as follows. The 8 bit ζt is squared and accumulated 1024 times, and the summation is stored in a register. The QRS detection threshold γ is generated by dividing the summation by 1024 (right-shift 10 bits), square-rooting to get the dynamic deviation σw(j), then multiplying σw(j) with constant c to get final γ. By monitoring the difference of γ and ζt, the R-peak can be detected.
The architecture 1400 uses a QRS detection algorithm based on wavelet multiscale product and a simple decision algorithm. Since the wavelet multiscale product and rescaled power of the product are considered to achieve good detection accuracy, a decision algorithm based on an amplitude comparison to a simple thresholding method can be employed, wherein no search back is used. With this architecture, only one detection threshold needs to be calculated, while other known systems may use four thresholds at scales 21 to 24 to obtain the location set of “modulus maxima” across the scales. The algorithm may be summarized as follows:
where * is the convolution operator and low-pass subband S2jf(n) and a high-pass subband W2jf(n). The S2jf(n) and W2jf(n) are implemented with linear phase FIR filters since their coefficients are symmetric in nature. The wavelet used for DYWT may be first-order derivatives of a smooth function (a cubic spline function, such as the one in [S. Mallat, and S. Zhong, “Characterization of signals from multiscale edges,” IEEE Trans. Pattern Analysis and Machine Intelligence, vol. 14, pp. 710-732, 1992]), whereby W2jf(n) may appear as modulus maxima at these locations if S20f(n) (i.e., an ECG signal 1402 in this case) has some singular points. The amplitude of noise modulus maxima may decrease from small scale to large scales in the wavelet domain (S. Mallat, and S. Zhong, “Characterization of signals from multiscale edges,” IEEE Trans. Pattern Analysis and Machine Intelligence, vol. 14, pp. 710-732, 1992). Therefore, multiscale-product ξtK sharpens and enhances the modulus maxima dominated by scale edges and at the same time suppresses the modulus maxima dominated by noise. The multiscale product of the first κ scales in wavelet domain at time index t
The power of ξtK is rescaled to that of by χ and γ to obtain a new normalized detection signal ζt defined as:
where
Since the wavelet coefficients corresponding to the signal are enhanced in the new detection signal ζt and the local maxima (minima) in ζt can thus be accurately identified by applying a simple scheme of thresholding for the decision making stage.
To perform decision making for detecting QRS complexes, an interval-dependent threshold scheme may be applied to the new detection signal. Assume a detection threshold is γ and is calculated in each interval between two consecutive QRS and updated once for every interval. To determine γ, the standard deviation of ζt may be computed as:
where N is the number of samples. The standard deviation σ(ζt) may be updated every N=1024 samples and the mean value ζt is almost zero per every 1024 samples. Therefore, the equation (47) may be simplified as:
The detection threshold may be set as
γ=c·[σ(ζt)] (49)
where constant c is used to adjust the threshold γ imposed on ζt and threshold scheme can then be formulated as
Φ is the vector that contains the site of R peak points. The constant c is adjustable to achieve good detection accuracy.
Implementing the algorithm outlined by the equations (43) to (50), involves considering not only issues such as complexity that directly affect power consumption, but also issues such as available concurrency that indirectly affect power by determining how effectively the algorithm can be implemented on a low-power architecture.
The complexity of an algorithm can be measured in several ways. One measure of complexity is the instruction or operation count. One dominate power consumption in digital CMOS circuits is the switching power dissipation which is given by
Pswitchin=α·Cl·VDD2·fclk (51)
The switching power dissipation depends on four parameters. The switching activity factor α, the load capacitance CL, the supply voltage VDD and the clock frequency fclk. To minimize power consumption, known systems use low power techniques at both architecture level and logic level have been applied. Typically, the decisions made at the highest levels (architecture and system) will have a dramatic impact on power than those made at a lower level (e.g. gate or circuit). Specifically, they include sharing hardware resources, and clockless datapath of the functional unit.
Returning to
In
The high-pass coefficients at scale levels 1, 2 and 3 (i.e., W21f(n), W22f(n) and W22f(n)) may be multiplied together to enhance important features while weakening noise. As discussed earlier, the power of ξtK may be rescaled to that of W2jf by χ and ψ to get a new normalized detection signal ζt. The rescaling factor χ and ψ may be updated every 1024 samples so that divider circuitry which has the higher hardware cost can be replaced by simple right-shift 10 bits. Therefore, the new detection signal ζt may be updated every 1024 samples and compared with the threshold generated to identify the location of R-peak.
The threshold generation stage calculates the dynamic threshold γ as in equation (49) by multiplying standard deviation of ζt and constant c. The 8-bit width of ζt is multiplied with each other and accumulated into a special 16-bit register without facing overflow issue. The contents of the special register is divided by 1024 (right-shift 10-bits), square-rooting to get a standard deviation of ζt. The value of ζt is updated at every 1024 samples. The QRS detection threshold γ is evaluated by multiplying constant c. Instead of using a multibit comparator, a subtractor circuit may be used to calculate the difference between ζt and γ and check the MSB of the subtractor output to locate the positions of R peak. Each non-zero pulse indicating the position of the QRS starts when ζt exceeds γ.
V Advantages of Various Embodiments
Various embodiments allow long-term monitoring and analysis of electrocardiogram (ECG) signals, which is useful for patients who suffer cardio-vascular diseases, so that the doctors can continuously monitor their cardio status in real-time. Various embodiments provide a real-time integrated multi-functional digital ECG signal processing ASIC with minimized area and ultra-low power. This chip of various embodiments can analyze a digitalized ECG signal in a sensor node. Combined with a wireless transceiver (not shown), only the necessary and important analyzed cardio information are wirelessly transmit to healthcare equipments, and thus the sensor node can greatly reduce transmission data rate and power consumption.
Multi-functional: Various embodiments provide a real-time integrated ASIC implementation scheme for ECG signal processing and analysis, which can realize multiple functions: 1). Real-time high-frequency noise suppression and adaptive threshold based QRS detection; 2). Adaptive ECG artificial baseline drifting removal; 3). Real-time HBR prediction/classification; 4). Real-time clean ECG reconstruction. All the functions are based on the intrinsic wavelet transform algorithm. Further, various embodiments can process not only ECG signals, but also other bio-medical signals such as electroencephalography (EEG), electromyography (EMG).
Hardware efficient: All the multiple functions of various embodiments take advantage of the properties of WT. Therefore, the hardware implementation of each function can be shared, resulting in hardware efficient. Based on the property of WT, various embodiments provide a hardware efficient WT decomposition and reconstruction ASIC implementation scheme. Various embodiments apply SRAM to realize FIR filtering. Compared with the conventional scheme using the shift registers, various embodiments reduce hardware cost by about 50%.
Power efficient: The ECG signal processing and analysis scheme used by various embodiments is intrinsic integrated and realizes multiple functions based on the generic WT algorithm. This reusable signal processing scheme is power efficient. The proposed SRAM based WT decomposition and reconstruction ASIC implementation can uses less power as compared with the conventional scheme using shift registers. Clock gating also further reduces the power consumption.
Suitable for long-term monitoring: The ASIC implementation scheme provided by various embodiments allow for long-term cardiac monitoring. The hardware size is quite small, and multiple functions can be realized. Therefore, various embodiments provide an electrocardiogram signal processing system that is very convenient and comfortable for patients to use.
Previous known systems realize different functions using different types of signal processing algorithms. However, the electrocardiogram signal processing system of various embodiments use one generic WT signal processing platform to realize multiple functions. Various embodiments provide an area/power efficient non-downsampling WT ASIC structure for performing generic WT signal processing, capable of realising the following multiple functions:
where TP is the number of true positives detections which means correctly detected beats. False positive (FP) is the number of false positives detection and false Negative (FN) is the number of missed (not detected) beats. The sensitivity Se reports the percentage of true beats that were correctly detected by the algorithm used by the chip of
For the chip of
where TP is the number of true positive detections which means correctly detected beats. FP is the number of false positive detection and FN is the number of missed (not detected) beats. The sensitivity Se reports the percentage of true beats that were correctly detected by the algorithm. The positive predictivity +P reports the percentage of beat detections which were in real true beats. The chip can achieve Se=99.54% and +P=99.89%.
While the invention has been particularly shown and described with reference to specific embodiments, it should be understood by those skilled in the art that various changes in form and detail may be made therein without departing from the spirit and scope of the invention as defined by the appended claims. The scope of the invention is thus indicated by the appended claims and all changes which come within the meaning and range of equivalency of the claims are therefore intended to be embraced.
This application claims priority of U.S. Provisional Patent Application No. 61/241,550 filed on Sep. 11, 2009. The disclosure of the foregoing application is hereby incorporated herein by reference in its respective entirety, for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
5778881 | Sun et al. | Jul 1998 | A |
5782888 | Sun et al. | Jul 1998 | A |
6184942 | Patel et al. | Feb 2001 | B1 |
6970737 | Brodnick et al. | Nov 2005 | B1 |
7403808 | Istvan et al. | Jul 2008 | B2 |
20040010203 | Bibian et al. | Jan 2004 | A1 |
20060013473 | Woodfill et al. | Jan 2006 | A1 |
20060200035 | Ricci et al. | Sep 2006 | A1 |
Number | Date | Country |
---|---|---|
0182099 | Nov 2001 | WO |
2004089205 | Oct 2004 | WO |
2004095307 | Nov 2004 | WO |
2007131173 | Nov 2007 | WO |
2008014895 | Feb 2008 | WO |
Entry |
---|
Adnane, M., et al., “Development of QRS Detection Algorithm Designed for Wearable Cardiorespiratory System”, “Computer Methods and Programs in Biomed.”, 2009, pp. 20-31, vol. 93, No. 1. |
Afonso, V.X., et al., “ECG Beat Detection Using Filter Banks”, “IEEE Trans. Biomedical Engineering”, 1999, pp. 192-202, vol. 46, No. 2. |
Bahoura, M., et al., “DSP Implementation of Wavelet Transform for Real Time ECG Wave Forms Detection and Heart Rate Analysis”, “Computers Methods and Programs in Biomedicine”, 1997, pp. 35-44, vol. 52, No. 1. |
Benitez, D.S., et al., “A New QRS Detection Algorithm Based on the Hilbert Transform”, “Computers in Cardiology”, 2000, pp. 379-382, vol. 27. |
Benitez, D., et al., “The Use of the Hilbert Transform in ECG Signal Analysis”, “Computers in Biology and Medicine”, 2001, pp. 399-406, vol. 31, No. 5. |
Crouse, M.S., et al., “Wavelet-Based Statistical Signal Processing Using Hidden Markov Models”, “IEEE Trans. Signal Processing”, 1998, pp. 886-902, vol. 46, No. 4. |
(Author unknown), “ECG Signal Compression Using Analysis by Synthesis Coding”, accessed online at http://researcher.nsc.gov.tw/public/8905780/Attachment/82261685771.pdf (undated). |
Guo, D.G., et al., “A Wearable BSN-based ECG-recording System Using Micromachined Electrode for Continuous Arrhythmia Monitoring”, “IEEE, Proceedings of 5th International Workshop on Wearable and Implantable Body Sensor Networks”, 2008. |
Hoang, T.T., et al., “A Low Complexity, Low Power, Programmable QRS Detector Based on Wavelet Transform for Implantable Pacemaker IC”, IEEE, SOC Conference, 2006, pp. 160-163. |
Kadambe, S., et al., “Wavelet Transform-Based QRS Complex Detector”, “IEEE Trans. Biomedical Engineering”, 1999, pp. 838-848, vol. 46, No. 7. |
Köhler, B.U., et al., “The Principles of Software QRS Detection”, “IEEE Engineering in Medicine and Biology Magazine”, 2002, pp. 42-57, vol. 21, No. 1. |
Kuon, I., et al., “Measuring the Gap between FPGAs and ASICs”, “Int. Symp. on Field Programmable Gate Arrays”, 2006, pp. 21-30. |
Li, C., et al. “Detection of ECG Characteristic Points Using Wavelet Transforms”, “IEEE Trans. Biomedical Engineering”, 1995, pp. 21-28, vol. 42, No. 1. |
Mallat, S., et al., “Characterization of Signals from Multiscale Edges”, “IEEE Transactions on Pattern Analysis and Machine Intelligence”, 1992, pp. 710-732, vol. 14, No. 7. |
Mallat, S., et al., “Singularity Detection and Processing with Wavelets”, “IEEE Trans. Inform. Theory”, 1992, pp. 617-643, vol. 38, No. 2. |
Martinez, J.P., et al., “A Wavelet-Based ECG Delineator: Evaluation on Standard Databases”, “IEEE Trans. Biomed. Eng.”, 2004, pp. 570-581, vol. 51, No. 4. |
Nibouche, M., et al., “FPGA-Based Discrete Wavelet Transforms System”, “Lecture Notes in Computer Science”, 2001, pp. 607-612, vol. 2147. |
Pan, J., et al., “A Real-Time QRS Detection Algorithm”, “IEEE Trans. Biomedical Engineering”, 1985, pp. 230-236, vol. 32, No. 3. |
Poli, R., et al., “Genetic Design of Optimum Linear and Nonlinear QRS Detector”, “IEEE Trans. Biomedical Engineering”, 1995, pp. 1137-1141, vol. 42, No. 11. |
Raj, C.P., “Design and Implementation of Parallel and Pipelinined Distributive Arithmetic Based Discrete Wavelet Transform IP Core”, “Accessed online at http://www.design-reuse.com/articles/17024/design-and-implementation-of-parallel-and-pipelinined-distributive-arithmetic-based-discrete-wavelet-transform-ip-core.html”, 2009. |
Sadler, B.M., et al., “Analysis of Multiscale Products for Step Detection and Estimation”, “IEEE Trans. Information Theory”, 1999, pp. 1043-1051, vol. 45, No. 3. |
German-Sallo, Z., “Applications of Wavelet Analysis in ECG Signal Processing”, “Technical University of Cluj-Napoca; Summary of PhD Thesis”, 2005. |
Suarez K.V., et al., “ECG Beat Detection Using a Geometrical Matching Approach”, “IEEE Trans. Biomedical Engineering”, 2007, pp. 641-650, vol. 54, No. 4. |
Thakor, N.V., et al., “Estimation of QRS Complex Power Spectra for Design of a QRS Filter”, “IEEE Trans. Biomedical Engineering”, 1984, pp. 702-706, vol. 31, No. 11. |
Tseng, P., et al., “Generic RAM-Based Architecture for Two-Dimensional Discrete Wavelet Transform with Line-Based Method”, “IEEE”, 2002, pp. 363-366, vol. 1. |
Vaessen, M.J., “A QRS Detection Method Using Analog Wavelet Transform in ECG Analysis”, “Maastricht University; Bachelors' Thesis”, 2005. |
Xu, Y., et al., “Wavelet Transform Domain Filters: A Spatially Selective Noise Filtration Technique”, “IEEE Trans. Image Processing”, 1994, pp. 747-758, vol. 3, No. 6. |
Xue, Q., et al., “Neural-Network-Based Adaptive Matched Filtering for QRS Detection”, “IEEE Trans. Biomedical Engineering”, 1992, pp. 317-329, vol. 39, No. 4. |
Zheng, Y., et al., “Recursive Adaptive Algorithms for Fast and Rapidly Time-Varying Systems”, “IEEE Trans. Circuits and Systems II: Analog and Digital Signal Processing”, 2003, pp. 602-614, vol. 50, No. 9. |
Number | Date | Country | |
---|---|---|---|
20110077538 A1 | Mar 2011 | US |
Number | Date | Country | |
---|---|---|---|
61241550 | Sep 2009 | US |