Field of the Invention
The present invention relates generally to apparatus, systems, and methods for noninvasively measuring cardiac output (CO) and left ventricular stroke volume (SV). More specifically, the invention includes systems and methods that measure CO and/or SV using plethysmographic waveform data collected by a pulse oximeter.
Description of Related Art
There has been a long felt need in the medical arts for a noninvasive way to measure left ventricular stroke volume (SV) and cardiac output (CO). SV is the volume of blood pumped by the left ventricle of the heart with a single heart cycle. CO is the product of SV and hear rate (HR). SV and CO are important physiological parameters for a number of medical conditions, including congestive heart failure (CHF).
Patients being treated for heart failure are normally medicated with drugs that regulate diuresis and heart muscle function. An important aim of drug therapy is to maintain a CO that is sufficient to perfuse tissues with oxygenated blood. It is advantageous to use the lowest possible doses of drugs to manage CHF because the drugs used produce unwanted side effects. To optimally manage the dosage and selection of drugs in the treatment of CHF, one must monitor CO to assess the efficacy of the drugs and dosages being administered and/or to monitor patient compliance.
Currently, CO is measured using invasive techniques such as the Fick method, the Thermodilution method, and implantable microelectromechanical devices (MEMs), also called CardioMEMs. The Fick method involves the measurement of oxygen consumption and computing the arteriovenous difference using samples of arterial blood and mixed venous blood from the pulmonary artery. The thermodilution method measures the rate at which cold saline solution is diluted in the blood. Both of these methods are performed in a hospital setting because they require the placement of a catheter in the pulmonary artery. Additionally, the use of a pulmonary artery catheter use may also increase morbidity in critically ill patients. CardioMEMs are surgically implanted into patients in a hospital setting and, once implanted, provide measurements of SV and CO that can be used to monitor patients. The implantation of the cardioMEMs device into the pulmonary artery, however, is expensive and is performed in a hospital setting and involves the risks associated with heart catheterization.
Less invasive techniques for measuring SV and CO include esophageal Doppler and transesophageal echocardiography. Esophageal Doppler measures blood flow velocity in the descending thoracic aorta using a flexible ultrasound probe that is inserted into the esophagus. The blood flow velocity is combined with an estimate of the cross-sectional area of the aorta estimated from the patient's age, height, and weight to calculate SV and CO. This technique requires someone with technical skill to insert an esophageal Doppler monitor, which must be properly aligned with respect to the thoracic aorta to provide accurate measurements. Transesophageal echocardiography involves measuring SV using flow velocity calculated from the area under the measured Doppler velocity waveform at the pulmonary artery, the mitral valve, or the aortic valve. This technique requires a highly trained operator to position and place the esophageal Doppler monitor. These procedures are not truly noninvasive because accessing the esophagus is perceived by patients as invasively uncomfortable.
Truly noninvasive methods, apparatus, and systems are needed that can measure SV and CO, preferably in the homes of patients without the need for skilled caregivers. Pulse oximetry has been investigated for decades as a possible tool for the noninvasive measurement of SV and CO. A pulse oximeter (PO) is a device that obtains photoplethysmography (PPG) data, which measures changes in blood volume within a tissue caused by the pulse of blood pressure through the vasculature in the tissue. The blood volume change is detected by measuring the amount of light transmitted or reflected to a sensor from a light source used to illuminate the skin. The shape of the PPG waveform varies with the location and manner in which the pulse oximeter is contacted with the body. In addition to PPG data, a pulse oximeter measures peripheral oxygen saturation (SpO2). Most often, the device operates in a transmission mode in which two wavelengths of light are passed through a body part to a photodetector. Changes in absorbance at each of the wavelengths are measured, which allow the determination of the absorbance due to pulsing arterial blood, excluding venous blood, skin, bone, muscle, and other tissues. Alternatively, reflectance pulse oximetry can be used. A typical pulse oximeter comprises a data processor and a pair of light-emitting diodes (LEDs) facing a photodiode. One LED produces red light having a wavelength of 660 nm, the other infrared light having a wavelength of 940 nm. Oxygenated hemoglobin absorbs more infrared light and less red light than hemoglobin. The transmission signals fluctuate over time because of changes in the amount of arterial blood present in the tissue caused by the blood pulse associated with each cycle of the heart. The ratio of red light measured to infrared light measured is calculated by the processor and is converted by the processor to SpO2 using a lookup table based on the Beer-Lambert law.
Awad et al. (J. Clinical Monitoring and Computing, 2006, 20:175-184) reports that researchers have been attempting to understand the relationship between central cardiac hemodynamics and the resulting measured peripheral waveforms. Awad et al. studied ear pulse oximeter waveforms in order to understand the underlying physiology reflected in these waveforms and to extract information about cardiac performance. Multi-linear regression analysis of ear plethysmographic waveform components were used to estimate CO from the ear plethysmograph and it was determined that ear plethysmographic width correlates with CO. Awad et al. does not suggest that this correlation allows pulse oximetry or plethysmographic data to be used to calculate SV or CO.
Natalini et al. (Anesth. Analg. 2006, 103:1478-1484) reports the use of pulse oximetry to predict which hypotensive patients are likely to respond positively to increasing blood volume. Arterial blood pressure changes during mechanical ventilation are reported as accurately predicting fluid responsiveness. Photoplethysmographic (PPG) waveform variations measured by pulse oximetry showed a correlation with measured pulse pressure variation values associated with fluid responsiveness but neither SV nor CO were calculated. Natilini does not indicate that SV or CO can be calculated using PPG data.
US 2013/0310669 discloses a method for determining mixed venous oxygen saturation (SvO2) using a photoplethysmography pulse oximeter (PPG PO) device that measures changes in pulmonary circulation using a light source and a light detector applied to the thoracic wall of a patient. The light source and the detector are separated by at least 15-20 mm so that the region of illumination overlaps a portion of the pulmonary microcirculation beneath the PPG device. The contribution of circulation in the thoracic wall to the PPG signal must be assessed using an additional detector and/or light source that is attached to the thoracic wall less than 8 mm apart. The SvO2 value can be used to calculate CO using the Fick method from the values of total oxygen consumption, arterial oxygen content and venous oxygen content. One drawback of this method is that the pulmonary microcirculation is surrounded by bone, muscle, and other tissues that make the contribution of circulation in the thoracic wall to the PPG signal difficult to measure reliably. Another drawback is that the measured values depend on the accurate placement of the light emitters and sensors, which may be difficult to reproduce for each subsequent measurement.
U.S. Pat. No. 9,289,133 discloses a method and apparatus for monitoring proportional changes in CO from a blood pressure signal measurement obtained by fingertip PPG. A time constant of the arterial tree is defined as the product of the total peripheral resistance (TPR) and a constant arterial compliance and is determined by analyzing long time scale variations of more than one cardiac cycle. A value proportional to CO is determined from the ratio of the blood pressure signal to the estimated time constant using Ohm's law. An invasive, absolute CO calibrating measurement is required to derive absolute CO values from the proportional CO change values obtained using PPG. This method and apparatus cannot measure values for SV or CO without an invasive CO measurement and therefore requires a hospital setting and skilled medical personnel.
WO 2010/0274102 A1 discloses a data processing method and associated apparatus and systems that measures SV and CO from pulse oximetry data. The pulse oximeter system comprises a data processor configured to perform a method that combines a probabilistic processor and a physiological model of the cardiovascular system in a Dynamic State-Space Model (DSSM) that can remove contaminating noise and artifacts from the pulse oximeter sensor output and measure blood oxygen saturation, HR, SV, aortic pressure and systemic pressures. This pulse oximeter and associated method provides truly noninvasive measurement of CO and SV suitable for monitoring patients with CHF. The DSSM comprises a mathematical model of the cardiovascular system that models the physiological processes which produce the pulses measured by the pulse oximeter. In one embodiment, the model comprises parameters including aortic pressure, radial pressure, peripheral resistance, aortic impedance, and blood density.
The present invention fills a need in the art for truly noninvasive apparatus and methods for measuring SV and CO by providing a system and method for measuring and reporting SV and/or CO using plethysmographic (PG) waveform data from a photoplethysomgraphic pulse oximeter (PPG PO).
As used herein, “noninvasively” and “noninvasive” are used to indicate that a method, system, or apparatus does not involve an invasive or minimally invasive procedure such as surgery or catheterization. Additionally, “noninvasively” and “noninvasive” are used to indicate that a method, system, or apparatus does not involve endoscopy, phlebotomy, biopsy, or a procedure that requires intubation or artificial respiration.
The data processor shown in
A mathematical model or a computer model, as used herein, involves the use of state parameters and model parameters in a mathematical representation of physiological processes that give rise to a physiological parameter being measured and processes through which sensor data is detected.
A mathematical model may include model and/or state parameters that correspond directly to physiological parameters including vital signs such as oxygen saturation of blood (SpO2), heart rate (HR), respiratory rate (RR), and blood pressure (BP) that can be directly measured; physiological parameters not directly measured such as total blood volume (TBV), left-ventricular stroke volume (SV), vasomotor tone (VT), autonomous nervous system (ANS) tone, and cardiac output (CO); and hemoglobin-bound complexes, concentrations of metabolic intermediates, and concentrations of drugs present in one or more tissues or organs.
While the scope of a mathematical model used in the context of the present invention cannot possibly encompass every single process of human physiology, it should have the capacity to interpret the measured observable(s). For instance, if the intent is to process electrocardiography (ECG) signals, a model describing the generation and propagation of electrical impulses in the heart should be included.
The fusion of two or more biomedical signals follows the same principle. For instance, if the intent is to measure blood pressure waves and electrocardiogram signals simultaneously, the use of a heart model describing both the electrical and mechanical aspects of the organ should be used. Initially, the model may also accept manual data input as a complement to data from sensors. Nonlimiting examples of manually entered data include food consumption over time vital signs, gender, age, weight, and height.
Non-physiological models may be included in and/or coupled to the DSSM in cases where non-biomedical signals are measured. For instance, one may use non-biomedical measurements to enhance or complement biomedical measurements. A non-limiting example is the use of accelerometer data to enhance motion artifact rejection in biomedical measurements. In order to accomplish this, the physiological model is extended to describe both measurements, which may include, in this example, cardiovascular circulation at rest, at different body postures (standing, supine, etc), and in motion.
While the process and observational mathematical models F and H may be conceptualized as separate models, they are normally integrated into a single mathematical model that describes processes that produce a physiological parameter and processes involved in sensing the physiological parameter. That model, in turn, is integrated with a processing engine within an executable program stored in a data processor that is configured to receive digital data from one or more sensors and to output data to a display or other output formats.
The DSSM is integrated in a dual estimation processing engine or a joint estimation processing engine. The most favored embodiment makes use of a DSSM built into a Sigma point Kalman filter (SPKF) or Sequential Monte Carlo (SMC) processing engine. Sigma point Kalman filter (SPKF), as used herein, refers to the collective name used for derivativeless Kalman filters that employ the deterministic sampling based sigma point approach to calculate approximations of the optimal terms of the Gaussian approximate linear Bayesian update rule, including unscented, central difference, square-root unscented, and square-root central difference Kalman filters. SMC and SPKF processing engines operate on a general nonlinear DSSM having the form:
x
k
=f(xk−1,vk−1;W) (1)
y
k
=h(xk,nk;W) (2)
A hidden system state, xk, propagates over time index, k, according to the system model, f. The process noise is vk−1, and W is the vector of model parameters. Observations, yk, about the hidden state are given by the observation model h and nk is the measurement noise. When W is fixed, only state estimation is required and either SMC or SPKF can be used to estimate the hidden states.
Unsupervised machine learning, sometimes referred to as system identification or parameter estimation, involves determining the nonlinear mapping:
y
k
=g(xk;wk) (3)
where xk is the input, yk is the output, and the nonlinear map g(.) is parameterized by the model parameter vector W. The nonlinear map, for example, may be a feed-forward neural network, recurrent neural network, expectation maximization algorithm, or enhanced Kalman filter algorithm. Learning corresponds to estimating W in some optimal fashion. In the preferred embodiment, SPKF or SMC is used for updating parameter estimates. One way to accomplish this is to write a new state-space representation
W
k+1
=w
k
+r
k (4)
d
k
=g(xk;wk)+ek (5)
where wk correspond to a stationary process with identity state transition matrix, driven by process noise rk. The desired output dk corresponds to a nonlinear observation on wk.
The state and parameter estimation steps may be coupled in an iterative dual-estimation mode as shown in
The current estimate of the parameters Wk is used in the state estimator as a given (known) input, and likewise the current estimate of the state xk is used in the parameter estimator. This results in a step-wise stochastic optimization within the combined state-parameter space.
The flow chart shown
The state and parameter estimation steps may also be performed in a simultaneous joint-estimation mode as shown in
where xk are the state parameters and wk the model parameters. The joint state space is used to produce simultaneous estimates of the states and parameters.
The flow chart shown
Compared to dual estimation, both state and model parameters are concatenated into a single vector that is transformed by the DSSM. Hence, no machine learning step is necessary in order to update model parameters. Joint estimation may be performed using a sequential Monte Carlo method or sigma-point Kalman method. These may take the form of unscented, central difference, square-root unscented, and square-root central difference forms. The optimal method will depend on the particular application.
SMC methods estimate the probability distributions of all the model unknowns by propagating a large number of samples called probability particles in accordance with the system models (typically nonlinear, non-Gaussian, non-stationary) and the rules of probability. Artifacts are equivalent to noise with short-lived probability distributions, also called non-stationary distributions. The number of simulated particles scales linearly with computational power, with 100 particles being reasonable for real time processing with presently available processors. The system model describes pertinent physiology and the processor engine uses the system model as a “template” from which to calculate, using Bayesian statistics, posterior probability distribution functions (processed data). From this, the expectation values (e.g. the mean) and confidence intervals can be estimated
SMC process nonlinear and non-Gaussian problems by discretizing the posterior into weighted samples, or probability particles, and evolving them using Monte Carlo simulation. For discretization, Monte Carlo simulation uses weighted particles to map integrals to discrete sums:
where the random samples {x(i); i=1, 2, . . . , N}, are drawn from p(xk|y1:k) and δ(.) is the Dirac delta function. Expectations of the form
E[g(xh)]=∫g(xh)p(xh|y1:k)dxh (8)
can be approximated by the estimate:
if the distribution has finite support. As N approaches infinity, the estimate converges to the true expectation.
The optimal Bayesian solution can be outlined by the following recursive algorithm. Suppose the required PDF a p(xk−1|yt:k−1) at time k−1 is available. In the prediction stage, the prior PDF at time k is obtained using the DSSM via the Chapman-Kolmogorov equation:
p(xk|y1:k−1)=∫p(xh|xk−1)p(xk−1|y1:k−1)dxk−1 (10)
The DSSM model describing the state evolution p(xk|xk−1) is defined by the system equation (1) and the known statistics of vk−1. At time step k a measurement yk becomes available, and this may be used to update the prior (updated stage) via Bayes' rule:
where the normalizing constant
p(yk|y1:k−1)=∫p(yk|xk)p(xk|y1:k−1)dxk (12)
depends on the likelihood function p(yk|xk) defined by the measurement model (equation 2) and the known statistics of nk.
It is not possible to sample directly from the posterior density function so importance sampling from a known proposal distribution π(x0:k|y1:k) is used. One may use sigma-point Kalman filters, for example, to generate the proposal.
The known distribution is introduced into Equation 5 to yield:
where the variables wk(x0:k) are unnormalized importance weights, which are written as wk(x0:k)=wk:
resulting in a weighted expectation:
where {tilde over (w)}h(i) are normalized importance weights:
Importance sampling is made sequential by reiterating the Markov 1st order assumption, resulting in the assumption that the current state is not dependent on future observations:
π(x0:h|y1:h)=π(x0:h-1|y1:k−1)π(xh|x0:h-1,y1:h) (17)
and that observations are conditionally independent given the states:
A recursive estimate for the importance weights is:
which is called Sequential Importance Sampling (SIS). SIS suffers from degeneracy so that, over a few iterations, all but one of the importance weights will be zero, effectively removing a large number of samples. To remedy this, samples with low importance weights may be eliminated while high importance samples may be multiplied. One way to accomplish this is Sampling-Importance Resampling (SIR), which involves mapping the Dirac random measure
{xh(i),{tilde over (w)}h(i);i=1, . . . N} (21)
into a measure with equal weights, 1/N:
A pseudo-code for a generic SMC (also called bootstrap filter or condensation algorithm) can be written as:
1. Importance sampling step. For i=1, . . . , N, do:
x
h
(i)
˜p(xh|xk−1(i)) i)sample
w
h
(i)
˜w
h-1
(i)
p(yh|xh(i)) ii)evaluate
{tilde over (w)}
k
(i)
=w
h
(i)/Σj=1Nwh(i) iii) normalize
2. Importance resampling step
SPKF may be used to approximate probability distributions. Assuming that x has a mean
where h is a scaling parameter. Each sigma-point is propagated through the DSSM to yield the posterior sigma-point set, Yi:
Y
i
=h(f(Xi)),i=0, . . . 2L (24)
From this, the posterior statistics are calculated using a procedure resembling the linear Kalman filter. For instance, for the unscented Kalman filter case, a SPKF variant, the time-update equations are:
and the measurement-update equations are:
where x, v and n superscripts denote the state, process noise and measurement noise dimensions, respectively.
The mathematical structure for sequential Monte Carlo and SPKF represent two examples of a family of probabilistic inference methods exploiting Monte Carlo simulation and the sigma point transform, respectively, in conjunction with a Bayesian statistical process.
SPKF are generally inferior to SMC but are computationally cheaper. Like SMC, SPKF evolve the state using the full nonlinear DSSM, but represent probability distributions using a sigma-point set. This is a deterministic step that replaces the stochastic Monte Carlo step in the SMC. As a result, SPKF lose accuracy when posterior distributions depart heavily from the Gaussian form, such as with bimodal or heavily-tailed distributions, or with strong nonstationary distributions such as those caused by motion artifacts in pulse oximeters. For these cases SMC are more suitable.
SPKF yields higher-order accuracy than the extended Kalman filter (EKF) and its related variants with equal algorithm complexity, O (L2). SPKF returns 2nd order accuracy for nonlinear and non-Gaussian problems, and 3rd order for Gaussian problems. EKF has only 1st order accuracy for nonlinear problems. Both EKF and SPKF approximate state distributions with Gaussian random variables (GRV). However, the EKF propagates the GRV using a single measure (usually the mean) and the 1st order Taylor expansion of the nonlinear system. The SPKF, on the other hand, decomposes the GRV into distribution moments (sigma points) and propagates those using the unmodified nonlinear system. SPKF implementation is simpler than EKF since it is derivativeless. That is, it uses the unmodified DSSM form, and therefore does not require lengthy Jacobian derivations.
The data processing method is also capable of prediction because the method can operate faster than real time measurements. At any given time during data processing, the measurement PDF, obtained either from SPKF or SMC, embodies all available statistical information up to that point in time. It is therefore possible to march the system model forwards in time, for instance, using the same sequential Monte Carlo method, to obtain deterministic or stochastic simulations of future signal trajectories. In this way, the future health status (physiological state) of a patient can be predicted with attached probabilities indicating the confidence of each prediction.
The data processing method may benefit from a noise adaptation method if timed sensor data contains noise and/or artifact that changes its spectral qualities over time. That is, if timed sensor data has a non-stationary probability distribution function. Here, a known algorithm such as the Robins-Monro or Annealing methods may be added to the data processing method in order to adapt the probability distribution functions of noise terms (stochastic terms) in the DSSM according to changing noise and artifact present in sensor data.
In general, the output may include estimates of the true measured signals (i.e. processed data), and estimates of values for one or more physiological parameters measured by one or more sensors from which data was received, and estimates of values for one or more physiological parameters not measured by the sensors from which data was received (data extraction). A state parameter estimate is the processed data from the physiological sensor. Both noise and artifacts can be attenuated or rejected even though they may have very distinct probability distribution functions and may mimic the real signal. A model parameter estimate may be also used to produce a physiological parameter. For example, an estimate of total blood volume may be used to diagnose hemorrhage or hypovolemia. An estimate of tissue oxygen saturation may indicate poor tissue perfusion and/or hypoxia. Estimates of glucose uptake in several tissues may differentiate between diabetes mellitus types and severities; and estimates of carotid artery radius may be indicative of carotid artery stenosis.
Pulse Oximeter with Probabilistic Data Processing
In this example, the DSSM comprises the following function to represent CO:
wherein CO Qco(t), is expressed as a function of HR and SV and where QCO=(HR×SV)/60. The CO function pumps blood into a Windkessel 3-element model of the vascular system including two state parameters: aortic pressure, Pao, and radial (Windkessel) pressure, PW:
RP and ZO are the peripheral resistance and characteristic aortic impedance, respectively. The sum of these two terms is the total peripheral resistance due to viscous (Poiseuille-like) dissipation:
Z
o=√{square root over (ρ/AC1)} (34)
where ρ is blood density. The elastic component due to vessel compliance is a nonlinear function including thoracic aortic cross-sectional area, A:
where Amax, P0 and P1 are fitting constants correlated with age and gender:
A
max=(5.62−1.5(gender))·cm2 (36)
P
0=(76−4(gender)−0.89(age))·mmHg (37)
P
1=(57−0.044(age))·mmHg (38)
The time-varying Windkessel compliance, Cw, and the aortic compliance per unit length, Cl, are:
where l is the aortic effective length. The peripheral resistance is defined as the ratio of average pressure to average flow. A set-point pressure, Pset, and the instantaneous flow:
are used to provide compensation autonomic nervous system responses. The value for Pset is adjusted manually to obtain 120 over 75 mmHg for a healthy individual at rest.
The compliance of blood vessels changes the interactions between light and tissues with pulse. This is accounted for using a homogenous photon diffusion theory for a reflectance or transmittance pulse oximeter configuration. For the reflectance case:
for each wavelength. In this example, the red and infrared bands are centered at ˜660 nm and ˜880 nm. l denotes the detected intensities: total reflected (no subscript), and the pulsating (ac) and background (dc) components. Va is the arterial blood volume, which changes as the cross-sectional area of illuminated blood vessels, ΔAw, changes as:
ΔVa≈r·ΔAw (42)
where r is the source-detector distance. The tissue scattering coefficient, Σs′, is assumed constant but the arterial absorption coefficient, Σaart, depends on blood oxygen saturation, SpO2:
which is the Beer-Lambert absorption coefficient, with hematocrit, H, and red blood cell volume, vi. The optical absorption cross sections for red blood cells containing totally oxygenated (HbO2) and totally deoxygenated (Hb) hemoglobin are σa100% and σa0%, respectively.
The function K(α,d,r) contains, along with the scattering coefficient, the wavelength, sensor geometry and oxygen saturation dependencies that alter the effective optical path lengths:
The attenuation coefficient α is:
α×3Σa(Σs+Σa) (45)
where Σa and Σs are whole-tissue absorption and scattering coefficients, respectively, which are calculated from Mie Theory.
Red and infrared K values as a function of SpO2 may be represented by two linear fits:
r≈−4.03·SpO2−1.17 (46)
ir≈0.102·SpO2−0.753 (47)
in mm2. The overbar denotes the linear fit of the original function. The pulsatile behavior of ΔAw, which couples optical detection with the cardiovascular system model, is:
with Pw,0=(1/3)P0 and Pw,1=(1/3)P1 to account for the poorer compliance of arterioles and capillaries relative to the thoracic aorta. Third and fourth state variables, the red and infrared reflected intensity ratios, R=lac/ldc, are:
R
r,k+1
=cΣ′
s,r
rΣa,rartΔAw+Rr,k+νr (49)
R
ir,k+1
=cΣ′
s,ir
irΣa,irartΔAw+Rir,k+νir (50)
Here, ν are Gaussian-distributed process noises intended to capture the baseline wander of the two channels. The constant c subsumes all factors common to both wavelengths and is treated as a calibration constant. The observation model adds Gaussian-distributed noises, n, to Rr and Rir:
A calibration constant c was used to match the variance of the real lac/ldc signal with the variance of the DSSM-generated signal for each wavelength. After calibration, the age and gender of the patient was entered. Estimates for the means and covariances of both state and parameter PDFs were entered.
Electrocardiograph with Probabilistic Data Processing
While a specific DSSMs and input and output parameters are provided for the purpose of describing the present method, the present invention is not limited to the DSSMs, sensors, biological monitoring devices, inputs, outputs, except as defined by the following claims.
This application is a continuation-in-part of U.S. Ser. No. 12/640,278 filed Dec. 17, 2009, which is non-provisional of U.S. 61/171,802 filed Apr. 22, 2009. This application is additionally related to the following US patent applications: Ser. No. 12/796,512 filed Jun. 8, 2010, issued as U.S. Pat. No. 9,060,722; Ser. No. 13/096,845 filed Apr. 28, 2011, issued as U.S. Pat. No. 9,173,574; Ser. No. 13/096,876 filed Apr. 28, 2011, issued as U.S. Pat. No. 9,275,171; Ser. No. 13/096,904 filed Apr. 28, 2011; Ser. No. Ser. No. 13/181,027 filed Jul. 12, 2011, issued as U.S. Pat. No. 8,494,829; Ser. No. 13/181,140 filed Jul. 12, 2011; and Ser. No. Ser. No. 13/181,247 filed Jul. 12, 2011.
The U.S. Government may have certain rights to this invention pursuant to Contract Number IIP-0839734 awarded by the National Science Foundation.
Number | Date | Country | |
---|---|---|---|
61171802 | Apr 2009 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12640278 | Dec 2009 | US |
Child | 15225803 | US |