These teachings relate generally to an apparatus and a method for detecting and removing artifacts in optically acquired biological signals. More particularly, these teachings relate generally to an apparatus and a method for detecting and reconstructing motion and noise artifacts (MNA) in photoplethysmography (PPG) signals.
PPG is a non-invasive and low cost device to continuously monitor blood volume changes in peripheral tissues. PPG is a useful technique since it is widely used to monitor heart rate (HR), arterial oxygen saturation (SpO2), and can also be used to measure respiratory rates. However, MNA can distort PPG recordings, causing erroneous estimation of HR and SpO2. There are three distinct sources of MNA artifacts that can distort PPG recordings: (1) environmental, physiological, and experimental artifacts, which can be attributed to power interference surrounding the body; (2) correlated dynamics from other physiological signals; and (3) instrumental noise, respectively. MNA, which are comprised of all of the aforementioned noise sources, are difficult to filter since they do not have a predetermined frequency band and their spectrum often overlaps with that of the desired PPG signal.
MNA in PPG readings are caused by 1) the movement of venous blood as well as other non-pulsatile components along with pulsatile arterial blood and 2) variations in the optical coupling between the sensor and the skin. Various approaches to mitigate motion artifacts by improving sensor attachment have been proposed. However, these design improvements do not provide a significant reduction of motion artifacts. Algorithm-based MNA reduction methods are also proposed. These include time and frequency domain filtering, power spectrum analysis, and blind source separation techniques. However, these have high computational complexity and more importantly, they operate even on clean PPG portions where MNA reduction is not needed. Hence, accurate MNA detection, which identifies clean PPG recordings from corrupted portions, is essential for the subsequent MNA reduction algorithm so that it does not distort the non-corrupted data segments. Moreover, more computationally efficient MNA algorithms can be designed since they can be tailored only to the MNA contaminated data segments.
MNA detection methods are mostly based on a signal quality index (SQI) which quantifies the severity of the artifacts. Some approaches quantify SQI using waveform morphology or filtered output, while others derive SQI with the help of additional hardware such as accelerometer and electrocardiogram sensing. Statistical measures, such as skewness, kurtosis, Shannon entropy, and Renyi's entropy, have been shown to be helpful in determining a SQI. However, these techniques require manual threshold settings for each parameter to classify if the PPG signal is clean or corrupted. Although a support vector machine (SVM)-based classification method addresses the need of threshold setting, this approach considers limited and controlled types of motions.
On the other hand, arterial oxygen saturation reflects the relative amount of oxyhemoglobin in the blood. The most common method to measure it is based on pulse oximetry, whereby oxidized hemoglobin and reduced hemoglobin have significantly different optical spectra. Specifically, at a wavelength of about 660 nm, and a second wavelength between 805 and 960, there is a large difference in light absorbance between reduced and oxidized hemoglobin. A measurement of the percent oxygen saturation of blood is defined as the ratio of oxyhemoglobin to the total concentration of hemoglobin present in the blood. Pulse oximetry assumes that the attenuation of light is due to both the blood and bloodless tissue. Fluctuations of the PPG signal are caused by changes in arterial blood volume associated with each heartbeat, where the magnitude of the fluctuations depends on the amount of blood rushing into the peripheral vascular bed, the optical absorption of the blood, skin, and tissue, and the wavelength used to illuminate the blood.
The pulse oximeter signal contains not only the blood oxygen saturation and heart rate data, but also other vital physiological information. The fluctuations of PPG signals contain the influences of arterial, venous, autonomic and respiratory systems on the peripheral circulation. In the current environment where health care costs are ever increasing, a single sensor that has multiple functions is very attractive from a financial perspective. Moreover, utilizing a pulse oximeter as a multi-purpose vital sign monitor has clinical appeal, since it is familiar to the clinician and comfortable for the patient. Knowledge of respiratory rate and heart rate patterns can provide more useful clinical information in many situations in which pulse oximeter is the sole monitor available.
Although there are many promising and attractive features of using pulse oximeters for vital sign monitoring, currently they are used on stationary patients. This is mainly because MNA result in unreliable heart rate and SpO2 estimation. Clinicians have cited motion artifacts in pulse oximetry as the most common cause of false alarms, loss of signal, and inaccurate readings.
In practice, MNA are difficult to remove because they do not have a predefined narrow frequency band and their spectrum often overlaps that of the desired signal. Consequently, development of algorithms capable of reconstructing the corrupted signal and removing artifacts is challenging.
There are a number of general techniques used for artifact detection and removal. One of the methods used to remove motion artifacts is adaptive filtering. An adaptive filter is easy to implement and it also can be used in real-time applications, though the requirement of additional sensors to provide reference inputs is the major drawback of such methods.
There are many MNA reduction techniques based on the concept of blind source separation (BSS). BSS is attractive and has garnered significant interest since this approach does not require a reference signal. The aim of the BSS is to estimate a set of uncorrupted signals from a set of mixed signals which is assumed to contain both the clean and MNA sources. Some of the popular BSS techniques are independent component analysis (ICA), canonical correlation analysis (CCA), principle component analysis (PCA), and singular spectrum analysis (SSA).
In ICA, the recorded signals are decomposed into their independent components or sources. CCA uses the second order statistics (SOS) to generate components derived from their uncorrelated nature. PCA is another noise reduction technique which aims to separate the clean signal dynamics from the MNA data. A multi-scale PCA has also been proposed to account for time-varying dynamics of the signal and motion artifacts from PPG recordings.
A promising approach that can be applied to signal reconstruction is the singular spectrum analysis (SSA). The SSA is a model-free BSS technique, which decomposes the data into a number of components which may include trends, oscillatory components, and noise (see, for example, B. S. Kim and S. K. Yoo, “Motion artifact reduction in photoplethysmography using independent component analysis,” Biomedical Engineering, IEEE Transactions on, vol. 53, pp. 566-568, 2006, which is incorporated herein by reference in its entirety for all purposes.) The main advantage of SSA over ICA is that SSA does not require user input to choose the appropriate components for reconstruction and MNA removal. Comparing PCA to SSA, SSA can be applied in cases where the number of signal components is more than the rank of the PCA covariance matrix. Applications of the SSA include extraction of the amplitude and low frequency artifacts from single channel EEG recordings, and removing heart sound dynamics from respiratory signals.
Accordingly, there is a need to develop a new apparatus and a new method to distinguish clean from corrupted PPG signals under various types of motions. There is also a need to develop a new apparatus and a new method to remove MNA from corrupted PPG signals and to reconstruct PPG signals from the corrupted PPG signals.
In view of the foregoing, these teachings provide systems and methods that can distinguish clean from corrupted PPG signals under various types of motions and reconstruct the MNA contaminated data segments, such that biological parameters, e.g., heart rates and SpO2 values, can be accurately estimated.
In one embodiment, the system of these teachings includes one or more processors and one or more computer usable media having computer readable code embodied therein, the computer readable code causing the one or more processors to execute the method of these teachings.
In another embodiment, the method of these teachings includes a method for determining MNA are present in a segment of PPG data by determining a plurality of time domain features for each segment from a plurality of test segments of the PPG data, the plurality of test segments including segments without motion and noise artifacts and other segments with motion and noise artifacts, the plurality of time domain features for said each segment from the plurality of test segments constituting a training set, using the training set to train a SVM, training resulting in a trained SVM, determining the plurality of time domain features for the segment, and using the trained SVM to determine whether motion and noise artifacts are present in the segment.
In yet another embodiment, the method of these teachings includes a method for removal of MNA present in a segment of PPG data, by the steps of: (a) for each one segment from a segment of PPG data in which presence of motion and noise artifacts has been previously detected, referred to as a corrupted segment, and a most prior adjacent segment of PPG data in which motion and noise artifacts are not detected, referred to as a clean segment, performing the following: (a1) assemble a data transition matrix, each row of the data transition matrix being a vector of a predetermined length, a number of vectors being equal to a number of samples in a segment for which the data transition matrix is assembled minus the predetermined length and plus one; a starting value of each vector being displaced by one sample from a previous vector, resulting in the data transition matrix having a number of columns equal to the predetermined length and a number of rows equal to the number of vectors; (a2) obtain eigenvectors and eigenvalues for the data transition matrix, resulting in eigenvectors and eigenvalues for the corrupted segment and eigenvectors and eigenvalues for the clean segment; (b) sorting the eigenvalues for the corrupted segment from largest to smallest; and sorting the eigenvalues for the clean segment from largest to smallest; (c) retaining only a top predetermined percentage of the eigenvalues for the corrupted segment and the eigenvalues for the clean segment; (d) replacing the eigenvalues for the corrupted segment with the eigenvalues for the clean segment, where only the top predetermined percentage of the eigenvalues and corresponding eigenvectors have been retained; (e) retaining only eigenvectors for the corrupted segment and eigenvectors for the clean segment that have data in a predetermined frequency range; (f) discarding eigenvectors for the corrupted segment that have different frequencies from the eigenvectors for the clean segment; (g) obtaining the data transition matrix for the corrupted segment from the eigenvalues and eigenvectors of the corrupted segment and the data transition matrix for the clean segment from the eigenvalues and eigenvectors of the clean segment; (h) repeating steps (a2) to (g) until a predetermined convergence criterion is satisfied; and (i) reconstructing, after the predetermined convergence criterion is satisfied, the corrupted segment from the data transition matrix for the corrupted segment using replaced eigenvalues and retained eigenvectors.
In still another embodiment, the system of these teachings includes a system for determining whether MNA are present in a segment of PPG data, having one or more processors and non-transitory computer usable media having computer readable code embodied therein, the computer readable code, when executed by the one or more processors, causes the one or more processors to: determine a plurality of time domain features for each segment from a plurality of test segments of the PPG data, the plurality of test segments including segments without motion and noise artifacts and other segments with motion and noise artifacts, the plurality of time domain features for said each segment from the plurality of test segments constituting a training set; use the training set to train a SVM, training resulting in a trained SVM; determine the plurality of time domain features for the segment; and use the trained SVM to determine whether motion and noise artifacts are present in the segment.
In yet another embodiment, the system of these teachings includes a system for removal of MNA present in a segment of PPG data, having one or more processors and non-transitory computer usable media, having computer readable code embodied therein, the computer readable code, when executed by the one or more processors, causes the one or more processors to: (a) for each one segment from a segment of PPG data in which presence of motion and noise artifacts has been previously detected, referred to as a corrupted segment, and a most prior adjacent segment of PPG data in which motion and noise artifacts are not detected, referred to as a clean segment, performing the following: (a1) assemble a data transition matrix, each row of the data transition matrix being a vector of a predetermined length, a number of vectors being equal to a number of samples in a segment for which the data transition matrix is assembled minus the predetermined length and plus one; a starting value of each vector being displaced by one sample from a previous vector, resulting in the data transition matrix having a number of columns equal to the predetermined length and a number of rows equal to the number of vectors; (a2) obtain eigenvectors and eigenvalues for the data transition matrix, resulting in eigenvectors and eigenvalues for the corrupted segment and eigenvectors and eigenvalues for the clean segment; (b) sorting the eigenvalues for the corrupted segment from largest to smallest; and sorting the eigenvalues for the clean segment from largest to smallest; (c) retaining only a top predetermined percentage of the eigenvalues for the corrupted segment and the eigenvalues for the clean segment; (d) replacing the eigenvalues for the corrupted segment with the eigenvalues for the clean segment, where only the top predetermined percentage of the eigenvalues and corresponding eigenvectors have been retained; (e) retaining only eigenvectors for the corrupted segment and eigenvectors for the clean segment that have data in a predetermined frequency range; (f) discarding eigenvectors for the corrupted segment that have different frequencies from the eigenvectors for the clean segment; (g) obtaining the data transition matrix for the corrupted segment from the eigenvalues and eigenvectors of the corrupted segment and the data transition matrix for the clean segment from the eigenvalues and eigenvectors of the clean segment; (h) repeating steps (a2) to (g) until a predetermined convergence criterion is satisfied; and (i) reconstructing, after the predetermined convergence criterion is satisfied, the corrupted segment from the data transition matrix for the corrupted segment using replaced eigenvalues and retained eigenvectors.
For a better understanding of the present teachings, together with other and further objects thereof, reference is made to the accompanying drawings and detailed description and its scope will be pointed out in the appended claims.
FIG. 16A1-B7. (Left) HR estimated from reconstructed PPG for different additive white noise levels; (Right) SpO2 estimated from reconstructed PPG for different levels of additive white noise
FIG. 17A1-B7. (Left) HR estimated from reconstructed PPG for different additive colored noise levels; (Right) SpO2 estimated from reconstructed PPG for different levels of additive colored noise.
The following detailed description presents the currently contemplated modes of carrying out the invention. The description is not to be taken in a limiting sense, but is made merely for the purpose of illustrating the general principles of the invention, since the scope of the invention is best defined by the appended claims.
As used herein, the singular forms “a,” “an,” and “the” include the plural reference unless the context clearly dictates otherwise.
Except where otherwise indicated, all numbers expressing quantities of ingredients, reaction conditions, and so forth used in the specification and claims are to be understood as being modified in all instances by the term “about.”
Motion and Noise Artifacts Detection
In these teachings, an accurate and comprehensive MNA detection algorithm is provided, which detects MNA in PPG under various types of motion. First, time-domain parameters are introduced to quantify MNA in the recorded PPG signal. Then, the statistical measures of the time-domain parameters are considered as input variables for a machine learning-based MNA detection algorithm. The MNA detection algorithm may be self-trained by the SVM with clean and corrupted PPG data sets, and then the trained SVM can be used to test the unknown PPG data. The efficacy of the MNA detection algorithm is tested on PPG data sets recorded from the finger and forehead pulse oximeters in simulations, laboratory-controlled and walking/stair-climbing experiments, respectively.
Experimental Protocol and Preprocessing
In order to further elucidate the teachings presented hereinbelow, data for exemplary embodiments was collected. PPG signals can be obtained from custom reflectance-mode prototype pulse oximeters. PPG data with laboratory-controlled head and finger movement, daily-activity movement, or simulated movement are collected respectively from healthy subjects recruited from the student community of Worcester Polytechnic Institute (WPI). This study is approved by WPI's IRB and all subjects are given informed consent prior to data recording.
In laboratory-controlled head movement data, motion artifacts are induced by head movements for specific time intervals in both horizontal and vertical directions. In one example, eleven healthy volunteers are asked to wear a forehead reflectance pulse oximeter along with a reference Masimo Radical (Masimo SET®) finger type transmittance pulse oximeter. After baseline recording for 5 minutes without any movement, subjects are instructed to introduce motion artifacts for specific time intervals varying from 10 to 50% within a 1 minute segment. For example, if a subject is instructed to perform left-right movements for 6 seconds, a 1 minute segment of data would contain 10% noise. The right middle finger with the sensor attached to the Masimo pulse oximeter is kept stationary. HR and SpO2 signals are acquired by the Masimo pulse oximeter at 80 Hz and 1 Hz, respectively, and are acquired synchronously with the PPG signals recorded from the forehead sensor.
In laboratory-controlled finger movement data, motion artifacts are induced by left-right movements of the index finger. In one example, nine healthy volunteers are asked to sit and wear two reflection type PPG pulse oximeters (TSD200) on their index and middle fingers, respectively. After baseline recording for 5 minutes without any movement to acquire clean data, motion artifacts are induced by left-right movements of the index finger while the middle finger is kept stationary as a reference. Similar to the head movement data, motion is induced at specific time intervals corresponding to 10-50% duration in a 1 minute segment. Such controlled movement is repeated five times per subject. The pulse oximeters are connected to a biopotential amplifier (PPG100) having a gain of 100 and cut-off frequencies of 0.05-10 Hz. The MP1000 (BIOPAC Systems Inc., CA, USA) is used to acquire finger PPG signals at 100 Hz. The daily-activity movement PPG data are recorded while subjects are walking straight or climbing stairs for 45 min. The nine subjects are asked to walk or climb stairs after wearing a forehead reflectance pulse oximeter along with a Holter electrocardiogram (ECG) monitor (Rozinn RZ153+) at 180 Hz and a Masimo Rad-57 pulse oximeter at 0.5 Hz. The reference ECG is obtained from the Holter ECG monitor while HR and SpO2 readings are measured from the Masimo pulse oximeter connected to the subject's right index finger, which is held against the chest to minimize motion artifacts. Finally, the simulation movement PPG data are generated by the addition of white noise to the clean PPG data.
PPG data are preprocessed by a 6th order infinite impulse response (IIR) band pass filter with cut-off frequencies of 0.5 Hz and 12 Hz. Zero-phase forward and reverse filtering is applied to account for the non-linear phase of the IIR filter. After these preprocessing, the following parameters for classifying clean and corruption are derived.
In one embodiment, the method of these teachings includes a method for determining whether MNA are present in a segment of PPG data by determining a plurality of time domain features for each segment from a plurality of test segments of the PPG data, the plurality of test segments including segments without motion and noise artifacts and other segments with motion and noise artifacts, the plurality of time domain features for said each segment from the plurality of test segments constituting a training set, using the training set to train a SVM, training resulting in a trained SVM, determining the plurality of time domain features for the segment, and using the trained SVM to determine whether motion and noise artifacts are present in the segment. The method also includes band pass before determining the plurality of time domain features, each segment from the plurality of test segments. The method still further includes determining whether motion and noise artifacts are present in segments neighboring the segment, referred to as neighboring segments, neighboring segments being segments surrounding the segment within a predetermined time interval. Finally, the method includes applying a majority vote algorithm to determinations of whether motion and noise artifacts are present in the segment and the neighboring segments. The time domain features include at least one of standard deviation of peak to peak interval within a segment, standard deviation of peak to peak amplitude within a segment, standard deviation of systolic and diastolic ratio within a segment, and mean standard deviation of pulse shape within an interval.
Parameters from PPG Signals
The following four parameters are selected since they represent the variability present in corrupted PPG signals as shown in
1) Standard deviation of peak-to-peak interval (STDHR):
The STDHR,n of the nth segment is defined by:
where Dn,i is peak-to-peak interval at the ith pulse of the nth segment and
2) Standard deviation of peak-to-peak amplitude (STDAMP): The STDAMP,n of the nth segment is defined by:
where An,i is peak amplitude at the ith pulse of the nth segment and
3) Standard deviation of systolic and diastolic ratio (STDSD): The STDSD,n of the nth segment is defined by:
where RSD,n,i is systolic and diastolic time interval ratio at the ith pulse of the nth segment and
R
SD,n,i=(Ttrough,n-1,i−Tpeak,n,i)/(Tpeak,n,i−Ttrough,n-1,i) (4)
where Ttrough,n,i denotes the trough (or lowest point) at the ith pulse of the nth segment.
4) Mean-standard deviation of pulse shape (STDWAV): To derive pulse shape, we take Nsamp sample points of a pulse. The STDWAV,n of the nth segment is derived by taking average of the standard deviation at each sample point as follows:
STDWAV,n=E[STDWAV,n,m] (5)
where STDWAV,n,m is calculated by:
where qn,i(m) is the mth pulse sample at the ith pulse of the nth segment and
Classification by Support Vector Machine (SVM)
SVM can be applied to build a decision boundary classifying motion corruption from clean PPG signals. SVM is widely used in classification and regression due to its accuracy and robustness to noise (see, for example, C.-W. Hsu, C.-C. Chang, and C.-J. Lin, “A Practical Guide to Support Vector Classification,” Department of Computer Science, National Taiwan University 2003, a copy of which is incorporated by reference here in its entirety and for all purposes). The SVM includes training and test phases described further below.
1) Training phase: A flow chart of the training phase in the SVM-based MNA detection algorithm is shown in
where C is regulation parameter, N is the number of vectors, δsv is the slack variable, ws is weight vector and <•,•> is the inner product operation. The Tsv is the svth target variable, ysv is the svth input vector data, and bs is the bias. The SVM decision boundary Fsv is derived as
F
sv
=
w
2
*,y
+b
s*=0 (8)
where ws* and bs* are weight factor and bias, respectively, obtained from Eq. (7) and y is the input point.
By transforming the ysv and y term to ysv→Φ(ysv) and y→Φ(y), the non-linear SVM can be transformed to a linear SVM. For nonlinear SVM, Eq. (7) is modified as
T
sv(ws,Φ(ysv)+bs)≧1 (9)
To facilitate the operation in nonlinear SVM, a kernel function Ks(•,•), which is a dot-product in the transformed feature space as follows, is used,
K
s(ysv,ysv′)=Φ(ysv),Φ(ysv′) (10)
where sv′=1, 2, . . . , N.
2) Test phase:
Enhancement of MNA Detection by Major Votes
To enhance MNA detection performance, the disclosed algorithm incorporates multiple decisions on a set of neighbor segments in deciding whether a “target” segment is clean or corrupted. Neighbor segment is defined as a segment surrounding a target segment within ±Tneighbor seconds. Decision on a neighbor segment is highly likely to be the same as the decision on a target segment since PPG pulses in the neighbor segments are most likely to exhibit similar dynamics to the target segment.
The algorithm gathers the decisions of neighbor segments as well as target segment (see, for example,
RESULTS—In order to further elucidate these teachings, results of exemplary embodiments are presented hereinbelow.
The performance of the MNA detection algorithm can be evaluated for various types (simulated, laboratory controlled, and daily activities) of motion-corrupted PPGs so as to validate the performance in a wide range of scenarios. For all types of motions, the PPG recordings are divided into 7-second segments since this is determined to be the optimal size among the data length tested from 3-11 seconds (see below PERFORMANCE COMPARISON). Results of the disclosed algorithm are compared with four recently published MNA detection algorithms based on kurtosis (K), Shannon entropy (SE), Hjorth 1 (H1), and Hjorth 2 (H2) metrics, respectively. As performance metrics, classification accuracy, sensitivity, and specificity are considered. In addition, mean HR and SpO2 errors are also investigated as well as detection error ratio.
Reference: Clean Vs. Corrupted
The following are criteria which are adopted to reference PPG segments (clean or corrupted) for each experiment. A visual reference is excluded to avoid subjective decisions by visual inspectors; for subtle MNA, there are large disagreements among visual inspectors. Instead, objective decisions are performed based on controlled corruption start (Tcorr,start) and end (Tcorr,end) time points, ECG-derived heart rate (HRECG), PPG-derived heart rate (HRPPG), and SpO2 (SpO2PPG) from PPG signals.
Laboratory controlled data (Forehead and finger):
Daily activity data (Walking and stair-climbing):
Table I below describes the number of clean and corrupted PPG segments for each motion type used in the experiment as determined by the criteria defined above.
Classification Accuracy
A sample forehead PPG signal and its corresponding parameters calculated segment-by-segment are given in
To evaluate the sensitivity of our MNA detection algorithm to noise, Gaussian white noise (GWN) of varying signal-to-noise (SNR) levels is added to a representative non-MNA corrupted PPG signal. For each SNR, 50 independent clean PPG signal. As shown in
Performance Comparison of MNA Detection Algorithms
The disclosed algorithm is compared with other artifact detection methods based on H1, H2, K and SE since these methods have been shown to provide good detection accuracies. The H1 and H2 parameters represent the central frequency and half of bandwidth, respectively, and are defined as follows:
where
For a fair comparison, all detection methods used 7 second data segments.
Hr and SpO2 Estimation
Robust real-time MNA detection algorithms for raw PPG signals have been elusive to date. The disclosed MNA detection algorithm has been designed based on four parameters: (a) standard deviation of peak-to-peak intervals (b) standard deviation of peak-to-peak amplitudes (c) standard deviation of systolic and diastolic time ratios, and (d) mean-standard deviation of pulse shapes. The disclosed MNA algorithm is compared to other well-established MNA detection methods, using the 7-second data segment as this length has been determined to provide the optimal classification accuracy.
The results demonstrate that the disclosed SVM-based MNA detection algorithm has offered higher classification accuracy as well as lower HR and SpO2 errors compared to the conventional detection methods. The paired-t test is performed to determine whether there is a significant difference between classification errors obtained from the disclosed SVM approach compared with other known methods. For the finger recorded PPG segments,
The disclosed MNA detection algorithm coded with Matlab (2012a) takes only 7 ms on an Intel Xeon 3.6 GHz computer for the 7-second data segment. Hence, the disclosed algorithm is real-time realizable especially when it is coded in either C or C++. The disclosed computational MNA detection algorithm has provided high HR and SpO2 estimation accuracy as well as classification accuracy. Moreover, the disclosed algorithm shows significantly better performance than some well-cited methods with good detection accuracy. Another key advantage of the disclosed algorithm is that it is able to detail with a near pinpoint accuracy when MNA starts and ends. The other four methods fare poorly when compared to the disclosed algorithm in detecting the start and end time of the MNA. The potential for the method disclosed in this work to have practical applications is high, and the integration of the algorithm described with a pulse oximeter device may have significant implications for real-time clinical applications and especially for ambulatory monitoring of vital signs.
Part II—Motion and Noise Artifacts Removal
In these teachings, a PPG signal can be reconstructed from those portions of data that have been identified to be corrupted using the algorithm detailed hereinabove. The fidelity of the reconstructed signal is determined by comparing the estimated SpO2 and heart rate (HR) to reference values. In addition, the reconstructed SpO2 and HR values obtained via the ICA are compared to those obtained by the method disclosed herein. The ICA results are chosen as the point of comparison, because ICA has recently been shown to provide accurate reconstruction of corrupted PPG signals.
Experimental Protocol and Preprocessing
In order to further elucidate the teachings presented hereinbelow, data for exemplary embodiments was collected. Three sets of data are collected from healthy subjects recruited from the student community of Worcester Polytechnic Institute (WPI). This study is approved by WPI's institutional review board and all the subjects give informed consent before data recording.
In the first experiment, eleven healthy volunteers are asked to wear a forehead reflectance pulse oximeter developed in the lab along with a reference Masimo Radical (Masimo SET®) finger transmittance pulse oximeter. PPG signals from the forehead sensor and reference (HR) derived from a finger pulse oximeter are acquired simultaneously. The HR and SpO2 signals are acquired at 80 Hz and 1 Hz, respectively. After baseline recording for 5 minutes without any movement (i.e. clean data), motion artifacts are induced in the PPG data by the spontaneous movements in both horizontal and vertical directions of the subject's head while the right middle finger is kept stationary. Subjects are directed to introduce the motions for specific time intervals that determined the percentage of noise within each 1 minute segment, varying from 10 to 50%. For example, if a subject is instructed to make left-right movements for 6 seconds, a 1 minute segment of data would contain 10% noise.
The second dataset includes finger-PPG signals from the same 9 healthy volunteers in an upright sitting posture using an infrared reflection type PPG transducer (TSD200). An MP1000 pulse oximeter (commercially available from BIOPAC Systems Inc., CA, USA) is also used to acquire finger PPG signals at 100 Hz. One pulse oximeter of each model is placed on the same hand's index finger (one model) and middle finger (the other model) simultaneously. After baseline recording for 5 minutes without any movement (i.e. clean data), motion artifacts are induced in the PPG data by the left-right movements of the index finger while the middle finger is kept stationary to provide a reference. Similar to the first dataset, motion is induced at specific time intervals corresponding to 10 to 50% corruption duration in 1 minute segments, i.e. the controlled movement is carried out five times per subject.
The third dataset includes data measurements from 9 subjects with the PPG signal recorded from the subjects' forehead using a custom sensor simultaneously with the reference ECG, HR and SpO2 from a Holter Monitor at 180 Hz and Masimo (Rad-57) pulse oximeter at 0.5 Hz respectively. The reference pulse oximeter provided HR and SpO2 measured from the subject's right index finger, which is held steadily to their chest. The signals are recorded while the subjects are going through sets of walking and climbing up and down flights of stairs for approximately 45 min.
Once data are acquired, PPG signals from all three experiments outlined above are preprocessed offline using, for example, Matlab (MathWorks, R2012a). The PPG signals are filtered using a zero-phase forward-reverse 4th order IIR band-pass filter with cutoff frequency 0.5-12 Hz.
Motion Artifact Removal
To reconstruct the artifact-corrupted portion of the PPG signal that has been detected using the support vector machine approach provided herein, a hybrid procedure is developed, using Iterative Singular Spectrum Analysis (ISSA) and a frequency matching algorithm. Henceforth, the combined procedures is referenced as the iterative motion artifact removal (IMAR) algorithm.
A method of these teachings includes a method for removal of motion and noise artifacts (MNA) present in a segment of PPG data, by the steps of: (a) for each one segment from a segment of PPG data in which presence of motion and noise artifacts has been previously detected, referred to as a corrupted segment, and a most prior adjacent segment of PPG data in which motion and noise artifacts are not detected, referred to as a clean segment, performing the following: (a1) assemble a data transition matrix, each row of the data transition matrix being a vector of a predetermined length, a number of vectors being equal to a number of samples in a segment for which the data transition matrix is assembled minus the predetermined length and plus one; a starting value of each vector being displaced by one sample from a previous vector, resulting in the data transition matrix having a number of columns equal to the predetermined length and a number of rows equal to the number of vectors; (a2) obtain eigenvectors and eigenvalues for the data transition matrix, resulting in eigenvectors and eigenvalues for the corrupted segment and eigenvectors and eigenvalues for the clean segment; (b) sorting the eigenvalues for the corrupted segment from largest to smallest; and sorting the eigenvalues for the clean segment from largest to smallest; (c) retaining only a top predetermined percentage of the eigenvalues for the corrupted segment and the eigenvalues for the clean segment; (d) replacing the eigenvalues for the corrupted segment with the eigenvalues for the clean segment, where only the top predetermined percentage of the eigenvalues and corresponding eigenvectors have been retained; (e) retaining only eigenvectors for the corrupted segment and eigenvectors for the clean segment that have data in a predetermined frequency range; (f) discarding eigenvectors for the corrupted segment that have different frequencies from the eigenvectors for the clean segment; (g) obtaining the data transition matrix for the corrupted segment from the eigenvalues and eigenvectors of the corrupted segment and the data transition matrix for the clean segment from the eigenvalues and eigenvectors of the clean segment; (h) repeating steps (a2) to (g) until a predetermined convergence criterion is satisfied; and (i) reconstructing, after the predetermined convergence criterion is satisfied, the corrupted segment from the data transition matrix for the corrupted segment using replaced eigenvalues and retained eigenvectors. The predetermined length is less than one half of a number of samples in the segment for which the data transition matrix is assembled and is larger than a ratio of a sampling frequency to a lowest frequency in said segment being considered. The predetermined convergence criterion is a difference between a discarding metric for the corrupted segment reconstructed from the data transition matrix using replaced eigenvalues and retained eigenvectors and a discarding metric for the clean segment, the discarding metric being a sum of absolute values of signal components divided by a length metric for the signal components. The predetermined frequency range is a heart rate range of PPG data. The predetermined frequency range includes frequencies greater than 0.66 Hz and less than 3 Hz. The top predetermined percentage is a top 5%. In this method, the presence of motion and noise artifacts had been previously detected using the method previously described.
Singular Spectrum Analysis (SSA)
The SSA is composed of two stages: A) singular decomposition and B) spectral reconstruction. The former is the spectral decomposition or eigen-decomposition of the data matrix whereas the latter is the reconstruction of the signal based on using only the significant eigenvectors and associated eigenvalues. The assumption is that given a relatively high signal-to-noise ratio of data, significant eigenvectors and associated eigenvalues represent the signal dynamics and less significant values represent the MNA components.
The calculation of the singular stage of the SSA includes two steps: i) embedding followed by ii) singular value decomposition (SVD). In essence, these procedures decompose the data into signal dynamics including trends, oscillatory components, and MNA. The spectral stage of the SSA algorithm also includes two steps: i) grouping and ii) diagonal averaging. These two procedures are used to reconstruct the signal dynamics but without the MNA components. In the following section, we detail all four steps in the SSA algorithm.
Singular Decomposition—Embedding
Assume there is a nonzero real-value time series of length N samples, i.e., x=(x1, x2, . . . , xN). In the embedding step, window length fs/f1<L<N/2 is chosen to embed the initial time series, where fs is the sampling frequency and f1 is the lowest frequency in the signal. The time series X is mapped into the L lagged vectors, x=(xi, xi+1, . . . , xi+L-1) for i=1, . . . , K, where K=N−L+1. The result is the trajectory data matrix Tx or vector Xi that is each row of Tx for i=1, . . . , K.
From Eq. 11, it is evident that the trajectory matrix, Tx, is a Hankel matrix.
Singular Decomposition—Singular Value Decomposition
The next step is to apply the SVD to the trajectory matrix Tx which results in eigenvalues and eigenvectors of the matrix TXTxT where Ti for i=1, . . . , L can be defined as T=USVT. Ui for 1<i<L is a K×L orthonormal matrix. Si for 1<i<L is a diagonal matrix and vi for 1<i<L is an square orthonormal matrix, which is considered the principle component. In this step, Tx has L many singular values which are √{square root over (λi)}>√{square root over (λ2)}>, . . . , √{square root over (λL)}. Thus, the ith eigentriple of Ti can be written as Ui×√{square root over (λi)}×ViT for i=1, 2, . . . , d, in which d=max(i: √{square root over (λi)}>0) is the number of nonzero singular values of Tx. Normally, every harmonic component with a different frequency produces two eigentriples with similar singular values. So the trajectory matrix Tx can be denoted as
Projecting the time series onto the direction of each eigenvector yields the corresponding temporal principal component (PC).
Spectral Reconstruction
The reconstruction stage has two steps: i) grouping and ii) diagonal averaging. First, the subgroups of the decomposed trajectory matrices are grouped and then a diagonal averaging step is needed so that a new time series can be formed.
Spectral Reconstruction—Grouping
The grouping step of the reconstruction stage decomposes the L×K matrix Ti into subgroups according to the trend, oscillatory components, and MNA dynamics. The grouping step divides the set of indices {1, 2, . . . , d} into a collection of m disjoint subsets of I={Il, . . . , Im}. Thus, TI corresponds to the group I={Il, . . . , Im}. Tl
Spectral Reconstruction—Diagonal Averaging
In the final step of analysis, each resultant matrix, Tli, in Eq. (13) is transformed into a time series of length N. We obtain the new Hankel matrices {tilde over (X)}(i) by averaging the diagonal elements of the matrix Tl
X={tilde over (X)}
(1)
+{tilde over (X)}
(2)
+ . . . +{tilde over (X)}
(M) (14)
We can assert that {tilde over (X)}(1) is related to the trend of the signal; however, harmonic and noisy components do not necessarily follow the order of √{square root over (λ1)}>√{square root over (λ2)}> . . . >√{square root over (λM)}.
Iterative Motion Artifact Removal Based on SSA
In order to reconstruct the MNA corrupted segment of the signal, an iterative motion artifact removal approach based on SSA is explained in the last section. The ultimate goodness of the reconstructed signal is determined by the accuracy of the estimated SpO2 and HR values. The top and bottom panels of
To overcome the above limitations, the SSA approach is modified. The first step of the modified SSA involves computing singular value decomposition on both a corrupted data segment and its most prior adjacent clean data segment. Under the assumption of a high SNR of the data, the second step is to retain only the top 5% of the eigenvalues and their associated eigenvectors. The third step is to replace the corrupted segment's top 5% eigenvalues with the clean segment's eigenvalues. The fourth step is to further limit the number of eigenvectors by choosing only those eigenvectors that have heart rates between for both the clean and noise corrupted data segments. The two extreme heart rates are chosen so that they account for possible scenarios that one may encounter with low and high heart rates. With the remaining candidate eigenvectors resulting from step four, non-significant eigenvectors are further pruned by performing frequency matching of the noise corrupted eigenvectors to those of the clean data segment's eigenvectors, in the fifth step. Only those eigenvectors' frequencies that match to those of the clean eigenvectors are retained from the pool of eigenvectors remaining from step four. For the remaining eigenvector candidates, iterative SSA is performed to further reduce MNA and match the dynamics of the clean data segments' eigenvectors for the final step. For each iteration, the standard SSA algorithm is performed. Experience shows that convergence is achieved within 4 iterations.
DM=Σ|u|/L(u) (15)
where u is the signal component, and |•|, L(•) are absolute operator and component length, respectively. The entire procedure for the modified SSA algorithm is summarized in TABLE V.
Results—Noise Sensitivity Analysis
To validate the disclosed IMAR procedure, different SNR levels of Gaussian white noise (GWN) and colored noise are added to an experimentally collected clean segment of PPG signal. One purpose of the simulation is to quantitatively determine the level of noise that can be tolerated by the algorithm. Seven different SNR levels ranging from 10 dB to −25 dB are considered. For each SNR level, 50 independent realizations of GWN and colored noise are added separately to a clean PPG signal. The Euler-Maruyama method is used to generate colored noise.
Results—Heart Rate and Estimation from Forehead Sensor
As described above, PPG data are collected under three different experimental settings so that the disclosed approach could be more thoroughly tested and validated. For all three experimental settings, the efficacy of the disclosed IMAR approach for the reconstruction of the MNA-affected portion of the signal is compared with the reference HR and SpO2 values for all experimental datasets.
For the error-free SpO2 estimation, Red and IR PPG signals with clearly separable DC and AC components are required. The pulsatile components of the Red and IR PPG signals are denoted as ACRed and DCRed, respectively, and the “ratio-of-ratio” is estimated as
Accordingly, SpO2 is computed by substituting the R value in an empirical linear approximate relation given by
SpO
2(%)=(110−25R)(%) (17)
After applying the disclosed IMAR procedure to the identified MNA segment of the PPG signal, the SpO2 (using Eqs. 16-17) and HR are estimated and compared to the corresponding reference and MNA contaminated segment values. As is the case with the noise sensitivity analysis section, the performance of the IMAR algorithm is compared to the ICA method. The top panel (
Results—PPG Signal Reconstruction Performance in Finger Experiment
The performance of the signal reconstruction of the disclosed IMAR approach is compared to ICA for the PPG data with an index finger moving left-to-right patterns. The pulse oximeter on the middle finger of the right hand, which is stationary, is used as the reference signal. Since the subjects are directed to produce the motions for 30 seconds within each 1-minute segment, corresponding to 50% corruption by duration, the window length of both clean and corrupted segments are both set as half length of the signal. Table XII compares the HR reconstruction results between the IMAR and ICA methods for all 10 subjects. As shown in Table XII, the IMAR reconstructed HR values are not significantly different from the reference HR in 7 out of 10 subjects. However, the ICA's reconstructed HR is significantly different from the reference HR in 8 out of 10 subjects indicating poor reconstruction fidelity.
Results—PPG Signal Reconstruction Performance for the Walking and Stair Climbing Experimental Data
The signal reconstruction of the MNA identified data segments of the walking and stair climbing experiments using our disclosed IMAR and its comparison to ICA are provided in this section. Detection of the MNA data segments is performed using the algorithm described in Part I of the this disclosure. The reconstructed HR and SpO2 values using our disclosed algorithm and ICA are provided in below Tables XIII and XIV, respectively. For both HR and SpO2 reconstruction, the measurements are carried out using PPG data recorded from the head pulse oximeter. The right hand index finger's PPG data is used as HR and SpO2 references. As shown in Table XIII, 7 out of 9 subjects' reconstructed HR values are found to be not significantly different from the reference HR values using our algorithm. While 2 subjects' reconstructed HR values are found to be significantly different than the reference, the differences in the actual HR values are minimal. For ICA's reconstructed HR values, all values deviate significantly from the reference values.
For the reconstructed SpO2 values, the disclosed algorithm again significantly outperforms ICA. All but one subject are not significantly different than the SpO2 reference values for ICA. For the disclosed IMAR algorithm, only 4 out of 9 subjects do not show significant difference from the reference values. Note the zero standard deviation reference SpO2 values from Massimo's pulse oximeter in 7 out of 9 subjects. This is because Massimo uses a proprietary averaging scheme based on several past values. Hence, it is possible that the significant difference seen with our algorithm in some of the subjects would turn out to be not significant if the averaging scheme are not used. While some of the SpO2 values from our algorithm are significantly different from the reference, the actual deviations are minimal and they are far less than with ICA.
In this disclosure, a novel IMAR method is introduced to reconstruct MNA contaminated segments of PPG data. Detection of MNA using a support vector machine algorithm is introduced in the companion paper. One aim of this disclosure is to reconstruct the MNA corrupted segments as closely as possible to the non-corrupted data so that accurate heart rates and SpO2 values can be derived. The question is how to reconstruct the MNA data segments when there is no reference signal. To address this question, the most adjacent prior clean data segment and its dynamics are used to derive the MNA contaminated segment's heart rates and oxygen saturation values. Hence, the key assumption with the disclosed IMAR technique is that signal's dynamics do not change abruptly between the MNA contaminated segment and its most adjacent prior clean portion of data. Clearly, if this assumption is violated, the IMAR's ability to reconstruct the dynamics of the signal may be compromised. A time-varying IMAR algorithm can address this issue.
There are hosts of algorithms available for MNA elimination and signal reconstruction. Various adaptive filter approaches to remove MNA have been proposed with good results but the test data to fully evaluate the algorithms are either limited or confined to laboratory controlled MNA involving simple finger or arm movements. Moreover, these adaptive filter methods work best when a reference signal is available.
For those methods that do not require a reference signal to remove MNA, there have been many algorithms developed based on variants of the ICA. Most of the ICA-based methods produced reasonably good signal reconstructions of the MNA contaminated data. However, most of these methods are validated on data that are collected using laboratory controlled MNA involving pre-defined simple side-to-side or up-and-down finger and arm movements.
Given that ICA-based methods produced good signal reconstructions of the MNA contaminated data, the disclosed approach is compared to an ICA method using simulated data, laboratory controlled data as well as daily activity data involving both walking and stair climbing movements. Comparison of the performance of the disclosed method to ICA is based on reconstruction of HR and SpO2 values since these measures are currently used by clinicians.
Comparing HR and SpO2 estimations of the reconstructed signal to the reference measurements using both simulation and experimental data have shown that the proposed IMAR method is a promising tool as the reconstructed values are found to be accurate. The simulation results from noise sensitivity analysis showed that SNR level down to −20 dB and −dB from additive white and colored noise, respectively, can be tolerated well by the application of the proposed IMAR procedure, compared to the SNR values of −10 dB and −dB for the ICA method. Application of the proposed IMAR approach and the ICA to three different sets of experimental data have also shown significantly better signal reconstruction performance with our IMAR algorithm.
The use of singular spectrum analysis (SSA) to a single channel EEG recordings to extract high amplitude and low frequency MNA has been performed. The main aim of this work is to remove the artifacts in EEG signals, hence, an iterative approach to reconstruct the main dynamics of the signal is not implemented. The disclosed approach is based on the use of SSA combined with an iterative approach to reconstruct the portion of the MNA contaminated data with the most likely true dynamics (i.e., non-MNA contaminated data) of the pulse oximeter signal. This disclosure applies SSA-based algorithms for MNA reconstruction of pulse oximeter data. In conclusion, a scenario where a reference signal is not available to remove the MNA, the disclosed IMAR algorithm can accurately reconstruct HR and SpO2 values from MNA contaminated data segments.
In one embodiment, the system of these teachings includes one or more processors and one or more computer usable media having computer readable code embodied therein, the computer readable code causing the one or more processors to execute the method of these teachings, shown in
In still another embodiment, the system of these teachings includes a system for determining whether MNA are present in a segment of PPG data, having one or more processors and non-transitory computer usable media having computer readable code embodied therein, the computer readable code, when executed by the one or more processors, causes the one or more processors to: determine a plurality of time domain features for each segment from a plurality of test segments of the PPG data, the plurality of test segments including segments without motion and noise artifacts and other segments with motion and noise artifacts, the plurality of time domain features for said each segment from the plurality of test segments constituting a training set; use the training set to train a SVM, training resulting in a trained SVM; determine the plurality of time domain features for the segment; and use the trained SVM to determine whether motion and noise artifacts are present in the segment. The computer readable code further causes the one or more processors to band pass filter, before determining the plurality of time domain features, each segment from the plurality of test segments. The computer readable code further causes the one or more processors to determine whether motion and noise artifacts are present in segments neighboring the segment, referred to as neighboring segments, neighboring segments being segments surrounding the segment within a predetermined time interval, and apply a majority vote algorithm to determinations of whether motion and noise artifacts are present in the segment and the neighboring segments. The time domain features comprise at least one of standard deviation of peak to peak interval within a segment, standard deviation of peak to peak amplitude within a segment, standard deviation of systolic and diastolic ratio within a segment, and mean standard deviation of pulse shape within an interval.
In yet another embodiment, the system of these teachings includes a system for removal of MNA present in a segment of PPG data, having one or more processors and non-transitory computer usable media, having computer readable code embodied therein, the computer readable code, when executed by the one or more processors, causes the one or more processors to: (a) for each one segment from a segment of PPG data in which presence of motion and noise artifacts has been previously detected, referred to as a corrupted segment, and a most prior adjacent segment of PPG data in which motion and noise artifacts are not detected, referred to as a clean segment, performing the following: (a1) assemble a data transition matrix, each row of the data transition matrix being a vector of a predetermined length, a number of vectors being equal to a number of samples in a segment for which the data transition matrix is assembled minus the predetermined length and plus one; a starting value of each vector being displaced by one sample from a previous vector, resulting in the data transition matrix having a number of columns equal to the predetermined length and a number of rows equal to the number of vectors; (a2) obtain eigenvectors and eigenvalues for the data transition matrix, resulting in eigenvectors and eigenvalues for the corrupted segment and eigenvectors and eigenvalues for the clean segment; (b) sorting the eigenvalues for the corrupted segment from largest to smallest; and sorting the eigenvalues for the clean segment from largest to smallest; (c) retaining only a top predetermined percentage of the eigenvalues for the corrupted segment and the eigenvalues for the clean segment; (d) replacing the eigenvalues for the corrupted segment with the eigenvalues for the clean segment, where only the top predetermined percentage of the eigenvalues and corresponding eigenvectors have been retained; (e) retaining only eigenvectors for the corrupted segment and eigenvectors for the clean segment that have data in a predetermined frequency range; (f) discarding eigenvectors for the corrupted segment that have different frequencies from the eigenvectors for the clean segment; (g) obtaining the data transition matrix for the corrupted segment from the eigenvalues and eigenvectors of the corrupted segment and the data transition matrix for the clean segment from the eigenvalues and eigenvectors of the clean segment; (h) repeating steps (a2) to (g) until a predetermined convergence criterion is satisfied; and (i) reconstructing, after the predetermined convergence criterion is satisfied, the corrupted segment from the data transition matrix for the corrupted segment using replaced eigenvalues and retained eigenvectors. The predetermined length is less than one half of a number of samples in the segment for which the data transition matrix is assembled and is larger than a ratio of a sampling frequency to a lowest frequency in said segment being considered. The predetermined convergence criterion comprises a difference between a discarding metric for the corrupted segment reconstructed from the data transition matrix using replaced eigenvalues and retained eigenvectors and a discarding metric for the clean segment; the discarding metric being a sum of absolute values of signal components divided by a length metric for the signal components. The predetermined frequency range is a heart rate range of PPG data. The predetermined frequency range includes frequencies greater than 0.66 Hz and less than 3 Hz. The top predetermined percentage is a top 5%. In this system, the presence of motion and noise artifacts has been previously detected using the system described above.
Elements and components described herein may be further divided into additional components or joined together to form fewer components for performing the same functions.
The following is a disclosure by way of example of a device configured to execute functions (hereinafter referred to as computing device) which may be used with the presently disclosed subject matter. The description of the various components of a computing device is not intended to represent any particular architecture or manner of interconnecting the components. Other systems that have fewer or more components may also be used with the disclosed subject matter. A communication device may constitute a form of a computing device and may at least include a computing device. The computing device may include an inter-connect (e.g., bus and system core logic), which can interconnect such components of a computing device to a data processing device, such as a processor(s) or microprocessor(s), or other form of partly or completely programmable or pre-programmed device, e.g., hard wired and or application specific integrated circuit (“ASIC”) customized logic circuitry, such as a controller or microcontroller, a digital signal processor, or any other form of device that can fetch instructions, operate on pre-loaded/pre-programmed instructions, and/or followed instructions found in hard-wired or customized circuitry to carry out logic operations that, together, perform steps of and whole processes and functionalities as described in the present disclosure.
Each computer program may be implemented in any programming language, such as assembly language, machine language, a high-level procedural programming language, or an object-oriented programming language. The programming language may be a compiled or interpreted programming language.
Each computer program may be implemented in a computer program product tangibly embodied in a computer-readable storage device for execution by a computer processor. Method steps of the invention may be performed by a computer processor executing a program tangibly embodied on a computer-readable medium to perform functions of the invention by operating on input and generating output.
In this description, various functions, functionalities and/or operations may be described as being performed by or caused by software program code to simplify description. However, those skilled in the art will recognize what is meant by such expressions is that the functions result from execution of the program code/instructions by a computing device as described above, e.g., including a processor, such as a microprocessor, microcontroller, logic circuit or the like. Alternatively, or in combination, the functions and operations can be implemented using special purpose circuitry, with or without software instructions, such as using Application-Specific Integrated Circuit (ASIC) or Field-Programmable Gate Array (FPGA), which may be programmable, partly programmable or hard wired. The application specific integrated circuit (“ASIC”) logic may be such as gate arrays or standard cells, or the like, implementing customized logic by metalization(s) interconnects of the base gate array ASIC architecture or selecting and providing metalization(s) interconnects between standard cell functional blocks included in a manufacturer's library of functional blocks, etc. Embodiments can thus be implemented using hardwired circuitry without program software code/instructions, or in combination with circuitry using programmed software code/instructions.
Thus, the techniques are limited neither to any specific combination of hardware circuitry and software, nor to any particular tangible source for the instructions executed by the data processor(s) within the computing device. While some embodiments can be implemented in fully functioning computers and computer systems, various embodiments are capable of being distributed as a computing device including, e.g., a variety of forms and capable of being applied regardless of the particular type of machine or tangible computer-readable media used to actually effect the performance of the functions and operations and/or the distribution of the performance of the functions, functionalities and/or operations.
The interconnect may connect the data processing device to define logic circuitry including memory. The interconnect may be internal to the data processing device, such as coupling a microprocessor to on-board cache memory or external (to the microprocessor) memory such as main memory, or a disk drive or external to the computing device, such as a remote memory, a disc farm or other mass storage device, etc. Commercially available microprocessors, one or more of which could be a computing device or part of a computing device, include a PA-RISC series microprocessor from Hewlett-Packard Company, an 80x86 or Pentium series microprocessor from Intel Corporation, a PowerPC microprocessor from IBM, a Sparc microprocessor from Sun Microsystems, Inc, or a 68xxx series microprocessor from Motorola Corporation as examples.
The inter-connect in addition to interconnecting such as microprocessor(s) and memory may also interconnect such elements to a display controller and display device, and/or to other peripheral devices such as input/output (I/O) devices, e.g., through an input/output controller(s). Typical I/O devices can include a mouse, a keyboard(s), a modem(s), a network interface(s), printers, scanners, video cameras and other devices which are well known in the art. The inter-connect may include one or more buses connected to one another through various bridges, controllers and/or adapters. In one embodiment the I/O controller includes a USB (Universal Serial Bus) adapter for controlling USB peripherals, and/or an IEEE-1394 bus adapter for controlling IEEE-1394 peripherals.
The memory may include any tangible computer-readable media, which may include but are not limited to recordable and non-recordable type media such as volatile and non-volatile memory devices, such as volatile RAM (Random Access Memory), typically implemented as dynamic RAM (DRAM) which requires power continually in order to refresh or maintain the data in the memory, and non-volatile ROM (Read Only Memory), and other types of non-volatile memory, such as a hard drive, flash memory, detachable memory stick, etc. Non-volatile memory typically may include a magnetic hard drive, a magnetic optical drive, or an optical drive (e.g., a DVD RAM, a CI) ROM, a DVD or a CD), or other type of memory system which maintains data even after power is removed from the system.
For the purposes of describing and defining the present teachings, it is noted that the term “substantially” is utilized herein to represent the inherent degree of uncertainty that may be attributed to any quantitative comparison, value, measurement, or other representation. The term “substantially” is also utilized herein to represent the degree by which a quantitative representation may vary from a stated reference without resulting in a change in the basic function of the subject matter at issue.
Although these teachings have been described with respect to various embodiments, it should be realized these teachings are also capable of a wide variety of further and other embodiments within the spirit and scope of the appended claims.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2015/017746 | 2/26/2015 | WO | 00 |
Number | Date | Country | |
---|---|---|---|
61944726 | Feb 2014 | US |