This invention relates generally to data modeling and analysis, and more particularly to a variational relevance vector machine for such data modeling and analysis.
Data modeling has become an important tool in solving complex and large real-world computerizable problems. Applications of data modeling include data compression, density estimation and data visualization. A data modeling technique used for these and other applications is probabilistic modeling. It has proven to be a popular technique for data modeling applications such as speech recognition, vision, handwriting recognition, information retrieval and intelligent interfaces. One framework for developing such applications involves the representation of probability distributions as directed acyclic graphs, which are also known as Bayesian networks, belief networks, and probabilistic independence networks, among other terms.
In probabilistic modeling, usually a training data set is given that includes input vectors {xn}n=1N along with a set of corresponding targets {tn}n=1N, the latter of which can be real values, in the case of regression analysis, or class labels, in the case of classification analysis. From this training set, a model of p(t|x) is attempted to be inferred, with the object of making accurate predictions of t for new, unlabelled, examples of x. Generally, the principal challenge is to find the appropriate complexity of this model. Scoring alternative models by training set accuracy alone is usually undesirable, since increasing the model complexity, while reducing the training set error, can easily lead to over-fitting and poor generalization. A more robust approach is to introduce a prior distribution over models, which is used in conjunction with the information supplied by the training data to infer the prediction model. This prior distribution, also referred to as a prior, can be explicit, such as in a Bayesian framework, or can be implicit in other approaches.
One method for classification, that has also been extended to regression, is known as the support vector machine (SVM). Although it does not estimate p(t|x), it makes predictions based on a discriminant function of the form
where {wn} are the model weights and K(•,•) is a kernel function. A feature of the SVM is that its cost function attempts to minimize the number of errors made on the training set while simultaneously maximizing the margin between the two classes, in the feature space implicitly defined by the kernel. This maximum-margin principle is an appealing prior for classification, and ultimately drives many of the weights to zero, resulting in a sparse kernel classifier where the non-zero weights are associated with xn, that are either on the margin or lie on the wrong side of it. Model complexity is thus constrained such that only these support vectors determine the decision function. In practice, in addition to fitting the model to the training data, it is also necessary to estimate the parameter (usually, denoted C) which regulate the trade-off between the training errors and size of margin, which may entail additional cross-validation.
A disadvantage with the SVM as a general matter is that it utilizes many kernel functions, and may not yield as optimal test performance as may be desired. Furthermore, the SVM utilizes parameters (i.e., those denoted C), which add unwanted complications to the model. To address these concerns, the copending and coassigned patent application entitled “Relevance Vector Machine,” filed on Sep. 4, 1999, and assigned Ser. No. 09/391,093, describes a Relevance Vector Machine (RVM) that utilizes a functional form that is equivalent to the SVM, but which is a probabilistic model. It achieves comparable recognition accuracy to the SVM, but advantageously provides a full predictive distribution, and requires substantially fewer kernel functions. As described in this prior application, the RVM relied on the use of type II maximum likelihood, referred to as the evidence framework, to generate point estimates of the hyperparameters that govern model sparsity. However, because analysts desire to have different approaches, techniques and tools to solve a given model, there is a motivation for the present invention. Furthermore, the approach described here provides a closer a approximation to a fully Bayesian treatment than has been possible previously, and this is expected to be advantageous for problems involving data sets of limited size.
The invention relates to a variational relevance vector machine (RVM). The RVM is a probabilistic basis model of the same functional form of the SVM. Sparsity is achieved through a Bayesian treatment, where a prior is introduced over the weights governed by a set of what are referred to as hyperparameters—one such hyperparameter associated with each weight, whose most probable values are iteratively estimated from the data. The posterior distribution of many of the weights is sharply peaked around zero, in practice. The variational RVM utilizes a variational approach to solve the model, in particular using product approximations to obtain the posterior distribution. In particular, the product approximation used is the distribution of the hyperparameters, times the distribution of the weights, times the distribution of predetermined additional parameters, that differ as to whether a classification-oriented (discrete) model is being provided, or a regression-oriented (continuous) model is being provided. For the latter, the predetermined additional parameters account for noise, while for the former, the predetermined additional parameters account for a lower bound.
In one embodiment, a computer-implemented method includes selecting an initial set of hyperparameters, and iteratively updating the distribution of the set of weights, the distribution of the set of hyperparameters, and the distribution of the set of predetermined additional parameters, until a predetermined convergence criterion has been reach. Thus, the product of these distributions, as they have been iteratively updated until the predetermined convergence criterion has been reached, approximates the posterior distribution for modeling of a data set.
RVM has advantages not found in prior art approaches such as SVM. As compared to SVM, for example, the non-zero weights in the RVM have been seen to not be associated with examples close to the decision boundary, but rather appear to represent more prototypical examples of classes. These examples are termed relevance vectors. Generally, the trained RVM utilizes many fewer basis functions than the corresponding SVM, and often exhibits superior test performance. Furthermore, no additional validation of parameters (such as C) is necessary to specify the model, save those associated with the basis.
The invention includes computer-implemented methods, machine-readable media, computerized systems, and computers of varying scopes. Other aspects, embodiments and advantages of the invention, beyond those described here, will become apparent by reading the detailed description and with reference to the drawings.
In the following detailed description of exemplary embodiments of the invention, reference is made to the accompanying drawings which form a part hereof, and in which is shown by way of illustration specific exemplary embodiments in which the invention may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the invention, and it is to be understood that other embodiments may be utilized and that logical, mechanical, electrical and other changes may be made without departing from the spirit or scope of the present invention. The following detailed description is, therefore, not to be taken in a limiting sense, and the scope of the present invention is defined only by the appended claims.
Some portions of the detailed descriptions which follow are presented in terms of algorithms and symbolic representations of operations on data bits within a computer memory. These algorithmic descriptions and representations are the means used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. An algorithm is here, and generally, conceived to be a self-consistent sequence of steps leading to a desired result. The steps are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated.
It has proven convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like. It should be borne in mind, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to these quantities. Unless specifically stated otherwise as apparent from the following discussions, it is appreciated that throughout the present invention, discussions utilizing terms such as processing or computing or calculating or determining or displaying or the like, refer to the action and processes of a computer system, or similar electronic computing device, that manipulates and transforms data represented as physical (electronic) quantities within the computer system's registers and memories into other data similarly represented as physical quantities within the computer system memories or registers or other such information storage, transmission or display devices.
Operating Environment
Referring to
Moreover, those skilled in the art will appreciate that the invention may be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, network PC's, minicomputers, mainframe computers, and the like. The invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote memory storage devices.
The exemplary hardware and operating environment of
The system bus 23 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures. The system memory may also be referred to as simply the memory, and includes read only memory (ROM) 24 and random access memory (RAM) 25. A basic input/output system (BIOS) 26, containing the basic routines that help to transfer information between elements within the computer 20, such as during start-up, is stored in ROM 24. The computer 20 further includes a hard disk drive 27 for reading from and writing to a hard disk, not shown, a magnetic disk drive 28 for reading from or writing to a removable magnetic disk 29, and an optical disk drive 30 for reading from or writing to a removable optical disk 31 such as a CD ROM or other optical media.
The hard disk drive 27, magnetic disk drive 28, and optical disk drive 30 are connected to the system bus 23 by a hard disk drive interface 32, a magnetic disk drive interface 33, and an optical disk drive interface 34, respectively. The drives and their associated computer-readable media provide nonvolatile storage of computer-readable instructions, data structures, program modules and other data for the computer 20. It should be appreciated by those skilled in the art that any type of computer-readable media which can store data that is accessible by a computer, such as magnetic cassettes, flash (RAMs), read only memories (ROMs), and the like, may be used in the exemplary operating environment.
A number of program modules may be stored on the hard disk, magnetic disk 29, optical disk 31, ROM 24, or RAM 25, including an operating system 35, one or more application programs 36, other program modules 37, and program data 38. A user may enter commands and information into the personal computer 20 through input devices such as a keyboard 40 and pointing device 42. Other input devices (not shown) may include a microphone, joystick, game pad, satellite dish, scanner, or the like. These and other input devices are often connected to the processing unit 21 through a serial port interface 46 that is coupled to the system bus, but may be connected by other interfaces, such as a parallel port, game port, or a universal serial bus (USB). A monitor 47 or other type of display device is also connected to the system bus 23 via an interface, such as a video adapter 48. In addition to the monitor, computers typically include other peripheral output devices (not shown), such as speakers and printers.
The computer 20 may operate in a networked environment using logical connections to one or more remote computers, such as remote computer 49. These logical connections are achieved by a communication device coupled to or a part of the computer 20; the invention is not limited to a particular type of communications device. The remote computer 49 may be another computer, a server, a router, a network PC, a client, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 20, although only a memory storage device 50 has been illustrated in FIG. 1. The logical connections depicted in
When used in a LAN-networking environment, the computer 20 is connected to the local network 51 through a network interface or adapter 53, which is one type of communications device. When used in a WAN-networking environment, the computer typically includes a modem 54, a type of communications device, or any other type of communications device for establishing communications over the wide area network 52, such as the Internet. The modem 54, which may be internal or external, is connected to the system bus 23 via the serial port interface 46. In a networked environment, program modules depicted relative to the personal computer 20, or portions thereof, may be stored in the remote memory storage device. It is appreciated that the network connections shown are exemplary and other means of and communications devices for establishing a communications link between the computers may be used.
Generalized Linear Prediction Models
In this section of the detailed description, generalized linear prediction models are overviewed, as an introduction to the relevance vector machines described in the succeeding sections of the detailed description. Referring first to
Referring next to
y(x)=g{s(x)},
where the weighted sum is
and wi are the weights associated with the M basis functions.
Relevance Vector Machines RVM's) Generally
In this section of the detailed description, an overview of RVM's is presented. This overview is consistent with the treatment of RVM's provided in the copending and coassigned patent application entitled “Relevance Vector Machines,” filed on Sep. 4, 1999, and assigned Ser. No. 09/391,093. In subsequent sections of the detailed description, variational RVM's according to varying embodiments of the invention are described.
The RVM makes probabilistic predictions but still retains the predictive performance of the support vector machine (SVM). It preserves the sparseness property of the SVM. For a wide variety of problems, it has been found to actually lead to models that are dramatically sparser than the corresponding SVM, while sacrificing little if any of the accuracy of the prediction.
For regression problems, the RVM models the conditional distribution of the target variable, given an input vector x, as a Gaussian distribution of the form
P(t|x,w,τ)=N(t|y(x,w), τ−1)
where the notation N(z|m,S) is used to denote a multi-variate Gaussian distribution over z with mean m and covariance S. In the above equation, τ is the inverse noise parameter, and the conditional mean y(x, w) is given by
Assuming an independent, identically distribution data set X={xn},T={tn}, the likelihood function can be written
The parameters are given a Gaussian prior of the form
where α={αm} is a vector of hyperparameters, with one hyperparameter αm assigned to each model parameter wm In the previously filed patent application, values for these hyperparameters are estimated using the framework of type-II maximum likelihood in which the marginal likelihood P(T|X,α,τ) is maximized with respect to α and τ. Evaluation of this marginal likelihood requires integration over the model parameters
P(T|X,α,τ)=∫P(T|X,w,τ)P(w|α)dw
Since this involves the convolution of two exponential-quadratic functions, the integration can be performed analytically, giving
P(T|X,ατ)=N(t|0,S)
where t=(t1, . . . ,tN), and
S=τ−1I+ΦA−1ΦT
in which I is the N×N unit matrix, A=diag(αm), and Φis the N×(N+1) design matrix with columns φm, so that (Φ)nm=φ(xn;xm). Maximization of
P(T|X,α,τ)=N(t|0,S)
with respect to the {αm} can be performed efficiently using an iterative re-estimation process obtained by setting the derivatives of the marginal log likelihood to zero. During the process of this optimization, many of the αm are driven to large values, so that the corresponding model parameters wm are effectively pruned out. The corresponding terms can be omitted from the trained model, with the training data vectors xn, associated with the remaining kernel functions being termed relevance vectors. A similar re-estimation process is used to optimize τsimultaneously with the αm parameters.
In the classification version of the RVM, the conditional distribution of targets is given by
P(t|x,w)=σ(y)t[1−σ(y)]1−t
where σ(y)=(1+exp(−y))−and y(x, w) is given by
Attention is confined to the case t∈{0,1}. Assuming independent, identically distributed data, the likelihood function is obtained in the form
As before, the prior over the weights takes the form
However, the integration required by
P(T|X,α,τ)=∫P(T|X,w,τ)P(w|α)dw
in order to evaluate the marginal likelihood can no longer be performed analytically. Therefore, in the previous patent application, a local Gaussian approximation is used to the posterior distribution of the weights. Optimization of the hyperparameters can then be performed using a re-estimation framework, and alternates with re-evaluation of the mode of the posterior, until convergence. Thus, the previous patent application estimates point values for the hyperparameters. As will be described in the next sections of the detailed description, embodiments of the invention utilize variational inference to achieve a more complete Bayesian treatment.
Variational Inference
In this section of the detailed description, an overview of variational inference as can be performed in accordance with embodiments of the invention is given. In a general probabilistic model, the stochastic variables can be partitioned into those corresponding to the observed data, denoted D, and the remaining unobserved variables, denoted θ. The marginal probability of the observed data, which is the model evidence, is obtained by integrating over θ,
P(D)=∫P(D,θ)dθ
However, this integration typically is analytically intractable. Variational methods address this difficulty by introducing a distribution Q(θ), which, for arbitrary choice of Q, allows the marginal log likelihood to be decomposed into terms
lnP(D)=L(Q)+KL(Q∥P)
where
and KL(Q∥P) is the Kullback-Leibler divergence between Q(θ) and the posterior distribution P(θ|D), and is given by
Since KL(Q∥P)≧0, then L(Q) is a rigorous lower bound on ln P(D). Furthermore, since ln P(D) is independent of Q, maximizing L(Q) is equivalent to minimizing KL (Q∥P), and therefore Q(θ) represents an approximation to the posterior distribution P(θ|D).
Therefore, for a suitable choice for the Q distribution, the quantity L(Q) may be tractable to determine, even though the original model evidence function is not. Thus, a variational approach seeks to choose a suitable form for Q(θ) that is sufficiently simple that the lower bound L(θ) can be evaluated and yet which is sufficiently flexible that the bound is reasonably tight. Generally, a family of Q distributions is selected, and then the best approximation within this family is sought by maximizing the lower bound with respect to Q. One approach is to assume some specific parameterized functional form for Q and then to optimize L with respect to the parameters of the distribution.
Another approach, as is described more fully in the remainder of the detailed description, is to consider a factorized form over the component variables {θi} in θ, so that
The lower bound is then maximized over all possible factorial distributions by performing a free-form maximization over the Qi, leading to
where •k≠i denotes an expectation with respect to the distributions Qk(θk) for all k≠i. If the probabilistic model is expressed as a directed acyclic graph with a node for each of the factors Qi(θi), then the solution for Qi(θi) depends only on the Q distributions for variables that are in the Markov blanket of the node i in the graph.
It is noted that the last equation of the previous paragraph represents an implicit solution for the factors Qi(θi), because the right-hand side depends on moments with respect to the Qk≠i. For conjugate conditional distributions (e.g., linear-Gaussian models with Gamma priors, in the case of continuous variables), this leads to standard distributions for which the required moments can be evaluated. A solution is then determined iteratively by initializing the moments, and cycling through the variables, updating each distribution in turn using
Controlling Model Complexity
In this section of the detailed description, the manner by which varying embodiments of the invention can provide for controlling model complexity is described. The Relevance Vector framework generally provides a manner for solving regression and classification problems in which models are sought that are highly sparse, by selecting a subset from a larger pool of candidate kernel functions, one for each example in the training set. Continuous hyperparameters are used to govern model complexity, thereby avoiding the intractable problem of searching over an exponentially large discrete space of model structures.
One manner to remove superfluous parameters it to use a pruning prior given by a Laplacian of the form
P(w)=λexp(−λ|w)
However, such a choice of prior does not lead to a tractable variational treatment, since the corresponding variational solution cannot be evaluated analytically.
Therefore, an alternative framework is used, based on a hierarchical prior of the form
P(w|α)=N(w|0,α−1)
in which a hyperprior is used given by
P(α)=Γ(α|a,b)≡bααα−1e−bα/Γ(a)
where Γ(a) is the Gamma function. This distribution has the useful properties
α=a/b, α2−α2=a/b2.
The marginal distribution of w is then obtained by integrating over α.
The variational framework can be rendered tractable by working not directly with the marginal distribution P(w), but instead leaving hierarchical conjugate form explicit, and introduce a factorial representation given by Q(w,α)=Q(w)Q(α). This is also advantageous because it becomes possible to evaluate the lower bound L as a closed-form analytic expression. This is useful for monitoring the convergence of the iterative optimization, and also for checking the accuracy of an implementation that can be embodied in software, such as one or more computer programs running on a computer as has been described in conjunction with
Variational Relevance Vector Regression
In this section of the detailed description, relevance vector regression, used in conjunction with continuous data sets, is described, in accordance with one embodiment of the invention, utilizing a variational approach. Thus, the Relevance Vector Machine (RVM) is augmented by the introduction of hyperpriors given by a separate distribution for each hyperparameter αm of the form P(αm)=Γ(αm|a,b). Similarly, a prior is introduced over the inverse noise variance τgiven by P(τ)=Γ(τ|c,d). Broad hyperpriors are obtained by setting a=b=c=d=10−6 in one embodiment. Together with the likelihood function
and the weight prior
a complete probabilistic specification of the model is achieved.
Next, a factorial approximation is considered to the posterior distribution P(w,α,τ|X,T) given by Q(w,α,τ)=Qw(w)Qα(α)Qτ(τ). Due to the conjugacy properties of the chosen distributions, the general solution
can be evaluated analytically, giving
where
The requirement moments are evaluated using
w=μw
wwT=Σw+μwμwT
αm=ãm/{tilde over (b)}m
lnαm=φ(ãm)−ln{tilde over (b)}m
τ={tilde over (c)}/{tilde over (d)}
lnτ=φ({tilde over (c)})−ln {tilde over (d)}
where the φfunction is defined by
The full predictive distribution P(t|x,X,T) is given by
P(t|x,X,T)=∫∫P(t|x,w,τ)P(w,τ|X,T)dw dr
In the variational framework, the true posterior P(w,τ|X,T) is replaced by the variational approximation Qw(w)·Qτ(τ). Integration over both w and r is intractable. However, as the number of data points increases, the distribution of τ becomes tightly concentrated around its mean value. To see this, it is noted that the variance of τ is given by τ2−τ2={tilde over (c)}/{tilde over (d)}˜O(1N) for large N. Thus, the predictive distribution can be approximated by using
P(t|x, X, T)=∫P
(t|x, w,τ)Qw(w)dw
which is the convolution of two Gaussian distributions. Using
P(t|x,w,τ)=N(t|y(x,w), τ−1)
and
Qw(w)=N(w|μw,Σw)
the following is then obtained
P(t|x,X,T)=N(t|μwTφ(x), σ2)
where the input-dependent variance is given by
The lower bound L can also be evaluated, taking the form
=ln P(T|X,w,τ)+lnP(w|
α)+lnP(α)+lnP(τ)
−lnQw(w)−lnQ60(α)
−lnQτ(τ)
in which
Variational Relevance Vector Classification
In this section of the detailed description, relevance vector classification, used in conjunction with discrete data sets, is described, in accordance with one embodiment of the invention, utilizing a variational approach. Classification is somewhat more complex than regression, because a fully conjugate hierarchical structure is not present. Resolution of this difficulty is now described. The log marginal probability of the target data, given the input data, can be written
lnP(T|X)=ln ∫∫P(T|X,w)P(w|α)P(α)dw dα
As before, a factorized variational posterior of the form Qw(w)·Qα(α) is introduced, and the following lower bound on the log marginal probability is obtained
However, the right-hand side of the above is intractable. Therefore, a further bound is introduced using the inequality
where z=(2t−1)y and λ(ξ)=(¼ξ)tanh(ξ/2). Here, ξ is a variational parameter, such that equality is achieved for ξ=z. Thus,
where zn=(2tn−1)wTφn. Substituting into
and noting that P(T|X,w)/F(T,X,w,ξ)≧1 implies lnP(T|X,w)/F(T,X,w, ξ)≧0, a lower bound on the original lower bound is obtained,
The right-hand side of the above equation is now optimized with respect to Qw(w) and Q60(α), as well as with respect to the parameters ξ={ξn}. The variational optimization for Qw(w) yields a normal distribution of the form
where A=diag(αm). Similarly, variational optimization of Q60(α) yields a product of Gamma distributions of the form
Finally, maximizing
with respect to the variational parameters ξn gives re-estimation equations of the form
ξn2=ΦnTwwTφn.
The lower bound given by the right-hand side of
can also be evaluated, as
L=ln F +ln P(w|α)+lnP(α)−lnQw(w)−Qα(α)
where
Predictions from the trained model for new inputs can be obtained by substituting the posterior mean weights into
P(t|x,w)=σ(y)1[1−σ(y)]1−t
to give the predictive distribution in the form
P(t|x,w).
Furthermore, a more accurate estimate can take into account the weight uncertainty by marginalizing over the posterior distribution of the weights. Using the variational result Qw(w) for the posterior distribution leads to convolution of a sigmoid with a Gaussian, which is intractable. From symmetry, however, such a marginalization does not change the location of the p=0.5 decision surface.
Methods
In this section of the detailed description, methods for implementing a variational relevance vector machine, according to varying embodiments of the invention, are presented. The variational relevance vector machine allows a user to generate a simpler (less complex) model as compared to other techniques, such as a support vector machine, using a variational approach. The computer-implemented methods are desirably realized at least in part as one or more programs running on a computer—that is, as a program executed from a computer-readable medium such as a memory by a processor of a computer. The programs are desirably storable on a machine-readable medium such as a floppy disk or a CD-ROM, for distribution and installation and execution on another computer. The program or programs can be a part of a computer system or a computer, such as that described in conjunction with
Referring to
In 402, an initial set of hyperparameters is selected. Ultimately, the set of hyperparameters is used for determining a prior distribution for the data set, for modeling thereof, using a variational approach. The prior distribution is approximated by a product of the distribution of the set of hyperparameters, the distribution of a set of weights, and the distribution of a set of predetermined additional parameters, which in the case of a continuous data set for regression are parameters accounting for noise, and which in the case of a discrete data set for classification are parameters accounting for a (second) lower bound.
Thus, 404, 406, 408 or 410, and 412 represent the iterative cycle of the variational approach for a relevance vector machine. In 404, the distribution for the set of weights is updated, and then in 406, the distribution of the set of hyperparameters (the α parameters) is updated. Next, depending on whether regression or classification is being performed, either the distribution for the parameters taking into account noise (the τ parameters), in the former case, or the distribution for the parameters taking into account the (second) lower bound (the ξ parameters). If the predetermined convergence criterion (as alluded to in the preceding sections of the detailed description) has not been achieved, then the method iterates again, proceeding from 412 back to 404. Otherwise, the method proceeds from 412 to 414.
In 414, at least the posterior distribution, as has been determined, is output. The complete model, including the distribution, may be output as well in one embodiment. The invention is not limited to the manner by which output is accomplished. For example, in one embodiment, output can be to a further analysis program or software component, that allows for analysis and conclusions to be drawn. As another example, output can be displayed on a displayed device, or printed to a printer, etc. As a third example, output can be stored on a storage device, for later further analysis program or software component.
Conclusion
Although specific embodiments have been illustrated and described herein, it will be appreciated by those of ordinary skill in the art that any arrangement which is calculated to achieve the same purpose may be substituted for the specific embodiments shown. This application is intended to cover any adaptations or variations of the present invention. Therefore, it is manifestly intended that this invention be limited only by the following claims and equivalents thereof.
Number | Name | Date | Kind |
---|---|---|---|
5684929 | Cortes et al. | Nov 1997 | A |
5692107 | Simoudis et al. | Nov 1997 | A |
5720003 | Chiang et al. | Feb 1998 | A |
5855011 | Tatsuoka | Dec 1998 | A |
6556960 | Bishop et al. | Apr 2003 | B1 |
6633857 | Tipping | Oct 2003 | B1 |
6671661 | Bishop | Dec 2003 | B1 |