The present invention relates generally to systems and methods that facilitate communications between devices, systems, processes, and/or individuals. More particularly, the present invention relates to a principled procedure for determining when callers should be transferred to operators based on a decision analysis. The procedure integrates models that predict when a call is likely to fail using spoken dialog features with queuing models of call center volume and service time.
Many users have had experiences with the use of automated speech-recognition based call routing systems for accessing data and services by telephone. Such systems have proliferated lately with the advent of more accurate spoken command-and-control and continuous speech recognition systems for limited domains. Even when the scope of an application is restricted, however, such systems can produce frustrating failures. To address user frustration, many designers put in place options for callers to be immediately routed to a live, human operator. Beyond speech recognition systems, other automated systems have been deployed such as the use of touch-tone driven menu systems. Such systems may frustrate users in providing a fixed set of options that either may not appear to offer the right options, offer options that have understandable relevance, and/or may appear to route the caller to a frustrating sequence of options rather than converging quickly to a desired setting.
Automated call handling systems have provided organizations with an opportunity to reduce the costs of handling incoming calls. As a consequence, many companies utilize touch-tone or dial-tone interactive voice-response systems. Unfortunately, callers frequently complain that touch-tone menus are difficult to use and frustrating. Callers in fact frequently seek assistance from a live operator at the first opportunity. To improve user experience with call handling systems, many companies have been turning to spoken dialog systems. These systems utilize automatic speech recognition (ASR) to facilitate requests in natural language. Although customers generally prefer natural language to touch-tone menus, enterprises are discovering that they still fall short of the quality of service that a human operator can provide.
In attempting to provide the best of both automation and live customer service, spoken dialog systems often resort to ad-hoc rules for dispatching calls. Even when these rules are tuned from data, the decision to transfer a call typically does not take into consideration the real-time stakes, such as the cost of customer time and the loss of return on investment.
The following presents a simplified summary of the invention in order to provide a basic understanding of some aspects of the invention. This summary is not an extensive overview of the invention. It is not intended to identify key/critical elements of the invention or to delineate the scope of the invention. Its sole purpose is to present some concepts of the invention in a simplified form as a prelude to the more detailed description that is presented later.
The present invention relates to optimizing automated call routing systems by integrating spoken dialog models with queuing models. A principled procedure and systems design framework is provided that is based on decision theory for determining when callers should be dispatched and how many operators call centers should maintain to minimize support costs. The procedure integrates models that predict when a call is likely to fail based on spoken dialog features with queuing models of call center volume and service time.
Using features from speech engines, a natural language understanding component, and dialog manager, as well as hand-labeled features, classifiers were trained to predict failures before they happen based on observations available to conventional systems after the first exchange, second, third, and so forth. The present invention goes beyond such analyses to further include an optimization of the decision about when to transfer a caller to a live, human operator. The optimization considers the costs and benefits of engaging in dialog strategies, and as such, does not take for granted that when the system is likely to fail, the caller should be transferred immediately to an operator, since this decision depends on the estimated time to failure as well as the estimated length of time that the caller may be waiting in a queue. The queue-theoretic model provides a modeling and simulation capability that can be used for exploration and design of call center staffing. A decision-theoretic procedure of the subject invention incorporates such cost considerations so as to allow a call center to strike a balance between keeping customers in the automated system—taking a gamble that the system will ultimately succeed, versus transferring calls to a live operator at different points in time, based on incoming spoken dialog features extracted in real-time.
To the accomplishment of the foregoing and related ends, certain illustrative aspects of the invention are described herein in connection with the following description and the annexed drawings. These aspects are indicative of various ways in which the invention may be practiced, all of which are intended to be covered by the present invention. Other advantages and novel features of the invention may become apparent from the following detailed description of the invention when considered in conjunction with the drawings.
The subject invention employs decision theory in connection with managing calls. More particularly, management of call traffic and handling of specific calls is important to many businesses, and the subject invention employs decision theory and queuing models in connection with optimizing handling of calls. In one aspect, an optimized procedure is provided, wherein decision models are employed to optimize system dispatch of calls to live operators in order to minimize support costs on an enterprise level while concurrently exploiting real time probabilities that the system will ultimately succeed.
As used in this application, the terms “component,” “model,” “system,” and the like are intended to refer to a computer-related entity, either hardware, a combination of hardware and software, software, or software in execution. For example, a component may be, but is not limited to being, a process running on a processor, a processor, an object, an executable, a thread of execution, a program, and/or a computer. By way of illustration, both an application running on a server and the server can be a component. One or more components may reside within a process and/or thread of execution and a component may be localized on one computer and/or distributed between two or more computers. Also, these components can execute from various computer readable media having various data structures stored thereon. The components may communicate via local and/or remote processes such as in accordance with a signal having one or more data packets (e.g., data from one component interacting with another component in a local system, distributed system, and/or across a network such as the Internet with other systems via the signal).
As used herein, the term “inference” refers generally to the process of reasoning about or inferring states of the system, environment, and/or user from a set of observations as captured via events and/or data. Inference can be employed to identify a specific context or action, or can generate a probability distribution over states, for example. The inference can be probabilistic; that is, the computation of a probability distribution over states of interest based on a consideration of data and events. Inference can also refer to logical inferences, including deterministic techniques employed for composing higher-level events from a set of events and/or data. Such inference results in the construction of new events or actions from a set of observed events and/or stored event data, whether or not the events are correlated in close temporal proximity, and whether the events and data come from one or several event and data sources.
Referring initially to
One or more optimized decision and queuing models 150 are employed with the call routing system 110 to facilitate efficient operations of the system 100, provide more efficient coupling between callers and respondents, and mitigate caller frustration when interacting with such systems. This achieved in part by training the models 150 via a data log 160 that has recorded data of past activities and interactions with the call routing system 110. Output from the models 150 is then employed for call routing determinations. After the models 150 have been trained, the call routing system 100 works in concert with the models 150 to facilitate call routing between callers and individuals to be contacted. As will be described in more detail below, an optimized decision model associated with the automated call routing system 110 determines when calls are likely to fail and a queuing model determines a busyness state of the operator 144. The decision model and the queuing model cooperate to balance costs between directing the calls to the operator 144 and directing the calls through the automated call routing system 110.
Referring now to
The procedure 200 begins with an analysis of call routing system 210 such as a commercially available spoken dialog system called VoiceDialer, for example. The system fields internal calls for directory assistance but can also be adapted for external calls. Using speech recognition, VoiceDialer attempts to identify one of over 20,000 name entries in a global address book. Nearly 60,000 session logs collected and analyzed over a period of 11 months. The system succeeded in correctly identifying the proper name in 45% of the sessions. The success rate jumps to 69% when sessions in which the caller did not attempt to engage the system are removed; in such “no name attempt” sessions, accounting for roughly one out of every three sessions, users completely bypassed interaction with the spoken dialog system by either transferring to an operator with a touchtone command or hanging up. Beyond the alarming failure rates and immediate transfers or hang-ups, longitudinal trends revealed that an increasing percentage of callers were immediately requesting the operator. The urgency of these findings motivated a procedure for optimizing dispatch to an operator based on models constructed from features drawn from the session logs.
Proceeding to 220 of
Models are constructed to predict these outcomes from a set of observational features derived from cases encoded in the logs. An area of interest includes inferring the likelihood of the eventual success versus failure of the spoken dialog interaction. For cost-benefit modeling, inferences of probability distributions over the duration of time until success or failure of the system was also determined.
The spoken dialog features extracted from session logs generally fell into four broad categories (listed along with the total number of features for each category):
It is noted that these features can be observed in real-time as a dialog session progress, with the exception of whole dialog features, which constitute the target variables.
Proceeding to 230, incremental data sets are considered. Since the optimization procedure harnesses models for real-time decision making over the course of a dialog, data is decomposed into sets of features that are revealed incrementally with dialog progression. The fundamental unit of time is considered to be each posting by the speech engine of Automatic speech Recognizer (ASR) outputs. Data can be segmented by detected ASR outputs for at least two reasons: first, ASR features constituted the vast majority of automatically extractable real-time features, and second, alternative dialog units (e.g., “moves,” “adjacency pairs” or exchanges) were unavailable in the transcriptions or provided insufficient discriminatory features.
Four data sets were created with incrementally growing number of features, as summarized in Table 1. The data was split 70/30 for training and testing. Having no ASR output was not included as a data set since not enough features could be extracted, rendering it functionally equivalent to using the marginal distribution in lieu of an inference. Furthermore, data sets with greater than four ASR outputs were not considered since, out of nearly 60,000 session logs, only six such cases were found.
At 240, predictive models are constructed. For model building, Bayesian networks were learned using decision trees to encode local conditional probability distributions within variables using a tool that performs Bayesian structure search (e.g., Chickering, 2002). Decision trees can be learned for both discrete and continuous variables, where splits in the trees are made greedily according to a Bayesian scoring function (e.g., Chickering et al., 1997). Bayesian networks were learned to not only perform inference over joint distributions needed for the decision-theoretic procedure, but also to determine what spoken dialog features would comprise the local structure of about three primary variables of interest: Outcome, as previously defined, Failure, a binary recoding of Outcome with SpeakFound as ‘1’ and ‘0’ for everything else, and, Duration, the expected completion time of the session. It is noted that Duration, a continuous variable for which the decision tree builds a Gaussian distribution, is generally required since cost is typically a function of time.
Table 2 shows a summary of the decision trees that were learned for the target variables in the four data sets. In these cases, the first splits in the decision trees, which represent the feature with the strongest dependency, were ASR features for the most recent n-best list. For example, the decision tree for Outcome trained on available features after the fourth ASR output depended most on the greatest consecutive difference between any two hypotheses for just the last n-best list, and not on any pairwise features between the third and fourth, or the second and third n-best lists, though pairwise features and action sequences were included as dependencies in the tree. It is also noted that Outcome after the fourth recognition only depended on that feature.
Table 3 displays classification accuracies of the decision trees for Outcome and Failure on the test data.
The baselines represent their marginal distributions. Not surprisingly, the Failure models outperformed the Outcome models, with a maximum accuracy of 82% for the data after the fourth recognition. Consistent with intuition, the lift above the marginal gradually rises, with the highest gain relative to the baseline at 23%. Observing the classification accuracy for Outcome after the fourth recognition, despite the fact that there was only one dependency, as stated previously, the model performed 20% better than the baseline. While the lifts for the third and fourth recognitions seem impressive, the baselines are notably low, attesting to the poor performance of convention spoken dialog systems.
The log posterior of the data given the models are reported in Table 4. To evaluate the relative performance of the learned Gaussians for Duration over the marginal log score, models were trained using just that as the target variable. Thereafter, models included Outcome or Failure as the second target variable. It is noted that positive log scores reflect a non-normalized Gaussian density function. The maximum lift above the marginal was 0.24, though unlike the classification accuracies, the lifts for the log scores do not exhibit a trend upward. On the other hand, the log scores in general do seem to improve with more features.
Turning to
The optimization procedure 300 includes a decision-theoretic procedure 310 for analyzing spoken dialog and an integration with queue models 320 for call routing activities which are described in more detail with respect to
With respect to the decision-theoretic procedure 310, one purpose of building models that can predict the likely outcome of a call with a spoken dialog system using real-time, extractable features is to employ them for optimal decision making. Optimization can be approached from many angles. Given that the goal of optimizing dispatch to a live operator is to minimize support costs at the enterprise level, while at the same time exploiting real-time likelihoods, probability and utility are combined within the framework of decision theory. As such, decisions are made according to the principle of maximum expected utility (MEU), which states that the action A=a should be selected that maximizes its expected utility, EU(a/ξ. If ξ denotes background information and H represents possible states of the world, then select actions guided by the following optimization:
where u(a,h) expresses the utility of taking action a when the state of the world is h. Note that cost is simply negative utility. The MEU Principle is implied by compelling assertions about preferences, collectively referred to as the axioms of utility theory (Von Neumann & Morgenstern, 1947).
Relating the MEU principle to the process of optimizing dispatch, let d denote the action of dispatching a call. Furthermore, let S denote the possible outcomes of the call routing system, which, for the sake of simplicity, corresponds to the binary variable Failure. Since transferring a call when the operator is busy poses a problem, let O denote the state of the operators, which may be busy or not busy. Rewriting (1) to include both O and S, the following optimization procedure is obtained:
Dispatch Procedure 340: Dispatch a call to an operator when the expected utility of d, given the state of the operator O and call routing system S, exceeds that of any dialog action a. That is,
∀a≠d[EU(d|S,O)>EU(a|S,O)] (2)
In particular, for dispatch d, applying the definition of conditional probability to obtain:
Calculating the expected utility of a dispatch, as delineated in equation (3), involves three components: first, P(O|S,d), or the likely state of the call center queue; second, P(S), or the likely outcome of the call routing system; and third, u(d,S,O), or the utility of dispatching a call when the operators may or may not be busy and the system may or may not be failing. The first component includes stochastic modeling of the call center queue. The second component was discussed in the previously above, and the third component involves the application of standard cost functions in operations research. The first and last components are described in detail below.
It is noted that generally the only dialog action that affects O, whether or not the operator is busy, is d since a transfer increases the number of callers waiting to be serviced by the operator. The effect of other dialog actions taken by a call routing system remain within the system, and as such:
P(O|S,d)P(S)=P(O|d)P(S) (4)
In other words, O and S are probabilistically independent for all other dialog actions, though for simplicity, the action of keeping someone engaged with the spoken dialog system is the variable considered.
Referring now to
At 420, fitting a Poisson Process is illustrated. Many queues, and in particular, call centers, are generally governed by two parameters: λ, the average arrival rate into the call center, and μ, the average service time to complete a call when an operator receives it. If the counts of inter-arrival and service times follow an exponential distribution, which exhibits the memoryless property of being probabilistically independent of any previous call, the process over time is called a “Poisson process” (Gross & Harris, 1998).
Since a Poisson process is mathematically well-characterized, it was sought to ascertain whether the call center of an organization could be modeled as such. For that effort, about two months of call center data was obtained for weekday working hours. Over 1700 calls were received with varying service completion times. The average rates, which represent the maximum likelihood estimate and method of moments estimate for the exponential distribution, were 4.41 seconds (λ) between calls and 28.22 seconds (μ) to dispense a call. To verify that the distributions were exponential, a log transformation of the empirical distributions was performed and fit regression lines to estimate the correlation coefficients.
At 430 of
where n represents the number of callers, and Pn is a closed form solution for multiple servers that can be found in any queuing theory textbook (e.g., Gross & Harris, 1998). According to (5), an operator is busy when the number of callers in the queue, including the dispatch call from the automated system, exceeds the number of operators at the call center.
At 440 of
u(a,S,O)≅u(a,S)+u(a,O) (6)
Suppose a=d, or dispatch to an operator. Then, equation (6) can be further decomposed into the cost function (note c instead of u):
c(d,S,O)≅CustCost·(t+W)+OpCost·z (7)
where t is the time a caller has already spent in the automated system, and W is the “dwell time,” which includes the time waiting in line and the time being served (Gross & Harris, 1998). W is derived from the M/M/z queuing model. According to equation (7), the cost of dispatching a call is merely the cost of a caller's time with the automated system in the call center, plus the cost of employing z operators for that call. If the state of O is “Not Busy,” then the W term drops out. If the state of S is “System Failing,” then add to equation (7) another term; namely, the return on investment (ROI). The ROI in this context is the amount of capital that the organization would have saved in not hiring more operators.
In order to calculate ROI for the call center, an inter-arrival rate of calls entering the spoken dialog system as a Poisson process was modeled. The average arrival rate was 1.51 seconds, and a linear regression line fit to the log transformation of the empirical distribution revealed a significant correlation (r=0.997, t(30)=65.9, p<0.001), indicating an exponential distribution. Since the average service time of the operators remains similar, an M/M/z queuing model and equation (7) were employed, without the variable t, which is unknown, to determine the optimal number of operators. The optimal number of operators needed to field the calls that would have been handled by the automated system is 25, as shown in
If the dialog action is not dispatch, but d, keeping a caller in the automated spoken dialog system, then the second term of equation (7) drops out since the cost of a caller's time is only considered. Furthermore, if the state of S is “System Not Failing,” then having kept the caller in the system would have saved ROI. Hence, ROI is to be subtracted from the cost function. Also, the future cost of remaining in the system is considered for an estimated amount of time longer than t, the equivalent of Win the queuing model. Fortunately, Gaussian models were learned from the session logs discussed above to estimate this kind of duration.
Putting everything together, the spoken dialog models learned with respect to discussion of
Table 5 displays the results of the analysis on each test set comparing the decision theoretic (DT) procedure against the marginal procedure (Marg). The second row corresponds to the “false positive” cases; that is, dispatching a call that was actually a success. The DT procedure is fairly conservative about making false positives consistently dispatching less than 7% of the calls, whereas the marginal procedure continually increases its false positives, reaching 28% by the last ASR output.
The first row of Table 5 corresponds to those “true positive” cases in which the calls that would have ultimately failed were dispatched correctly. The DT procedure starts off conservatively dispatching cases, since it deems keeping callers in the spoken dialog system more cost efficient in the beginning of a call session, whereas the marginal procedure immediately transfers close to half of the calls. As more recognition results are received and the percentage of calls that ultimately fail in the system increase, the DT procedure gradually lifts the percentage of dispatch, even transferring over half of the failed calls by the fourth ASR output. Although the marginal procedure also demonstrates a similar trend, it does so in a more aggressive manner.
To better appreciate how the DT procedure balances the tradeoffs between dispatching a call to the call center and keeping it within the automated system, the average cost savings can be approximately monetized for each test data set as follows:
The intuition behind equation (8) is that if the expected cost of dispatching is greater than not dispatching and it is decided to stay in, money would then be saved. Conversely, if the expected cost of staying in is greater than dispatching and it is decided to transfer the call, again money is saved. Equation (8) determines the average amount of money saved for both decisions.
Table 6 displays the average cost savings using the DT procedure for all four data sets. The procedure saves more money in the first recognition, where it keeps calls in the system at a point when the probability of success is highest, and again in the fourth recognition, where it dispatches calls to the call center at a point when the probability of success is lowest. Looking only at the average savings when the expected cost of dispatch is lower than the expected cost of keeping a caller in the automated system, a gradually increasing trend of cost savings can be observed, with the highest savings at roughly 3 cents per second.
As described above, the present invention provides a decision-theoretic procedure for determining when callers should be dispatched to a live operator so as to minimize support costs at the enterprise level. The procedure integrated learned models of call failure and success based on extractable real-time spoken dialog features with queuing models of call center volume and service time. The spoken dialog models predicted failure with a maximum accuracy of 82%, a 20% relative lift above the baseline. Using an M/M/z queue fit to call center data, the procedure was evaluated against making decisions from the marginal distribution. The procedure was shown to be conservative about making false positives. For true positives, the procedure reliably dispatched more calls as the probability of success diminished.
One possible limitation in the evaluation of the procedure was that the increase in average arrival rate into the call center was not accounted for as the procedure dispatched more calls. In a live system, the average rate of dispatch can be monitored, and adjust the average rate of arrival in the queuing models of the call center accordingly. Also, while this invention addresses the problem of optimizing dispatch at the enterprise level, the same framework can be applied to optimizing more individualized costs and utilities, such as user frustration, or to simply minimizing just the caller's time, regardless of call center costs.
With reference to
The system bus 818 can be any of several types of bus structure(s) including the memory bus or memory controller, a peripheral bus or external bus, and/or a local bus using any variety of available bus architectures including, but not limited to, 11-bit bus, Industrial Standard Architecture (ISA), Micro-Channel Architecture (MSA), Extended ISA (EISA), Intelligent Drive Electronics (IDE), VESA Local Bus (VLB), Peripheral Component Interconnect (PCI), Universal Serial Bus (USB), Advanced Graphics Port (AGP), Personal Computer Memory Card International Association bus (PCMCIA), and Small Computer Systems Interface (SCSI).
The system memory 816 includes volatile memory 820 and nonvolatile memory 822. The basic input/output system (BIOS), containing the basic routines to transfer information between elements within the computer 812, such as during start-up, is stored in nonvolatile memory 822. By way of illustration, and not limitation, nonvolatile memory 822 can include read only memory (ROM), programmable ROM (PROM), electrically programmable ROM (EPROM), electrically erasable ROM (EEPROM), or flash memory. Volatile memory 820 includes random access memory (RAM), which acts as external cache memory. By way of illustration and not limitation, RAM is available in many forms such as synchronous RAM (SRAM), dynamic RAM (DRAM), synchronous DRAM (SDRAM), double data rate SDRAM (DDR SDRAM), enhanced SDRAM (ESDRAM), Synchlink DRAM (SLDRAM), and direct Rambus RAM (DRRAM).
Computer 812 also includes removable/non-removable, volatile/non-volatile computer storage media.
It is to be appreciated that
A user enters commands or information into the computer 812 through input device(s) 836. Input devices 836 include, but are not limited to, a pointing device such as a mouse, trackball, stylus, touch pad, keyboard, microphone, joystick, game pad, satellite dish, scanner, TV tuner card, digital camera, digital video camera, web camera, and the like. These and other input devices connect to the processing unit 814 through the system bus 818 via interface port(s) 838. Interface port(s) 838 include, for example, a serial port, a parallel port, a game port, and a universal serial bus (USB). Output device(s) 840 use some of the same type of ports as input device(s) 836. Thus, for example, a USB port may be used to provide input to computer 812, and to output information from computer 812 to an output device 840. Output adapter 842 is provided to illustrate that there are some output devices 840 like monitors, speakers, and printers, among other output devices 840, that require special adapters. The output adapters 842 include, by way of illustration and not limitation, video and sound cards that provide a means of connection between the output device 840 and the system bus 818. It should be noted that other devices and/or systems of devices provide both input and output capabilities such as remote computer(s) 844.
Computer 812 can operate in a networked environment using logical connections to one or more remote computers, such as remote computer(s) 844. The remote computer(s) 844 can be a personal computer, a server, a router, a network PC, a workstation, a microprocessor based appliance, a peer device or other common network node and the like, and typically includes many or all of the elements described relative to computer 812. For purposes of brevity, only a memory storage device 846 is illustrated with remote computer(s) 844. Remote computer(s) 844 is logically connected to computer 812 through a network interface 848 and then physically connected via communication connection 850. Network interface 848 encompasses communication networks such as local-area networks (LAN) and wide-area networks (WAN). LAN technologies include Fiber Distributed Data Interface (FDDI), Copper Distributed Data Interface (CDDI), Ethernet/IEEE 1102.3, Token Ring/IEEE 1102.5 and the like. WAN technologies include, but are not limited to, point-to-point links, circuit switching networks like Integrated Services Digital Networks (ISDN) and variations thereon, packet switching networks, and Digital Subscriber Lines (DSL).
Communication connection(s) 850 refers to the hardware/software employed to connect the network interface 848 to the bus 818. While communication connection 850 is shown for illustrative clarity inside computer 812, it can also be external to computer 812. The hardware/software necessary for connection to the network interface 848 includes, for exemplary purposes only, internal and external technologies such as, modems including regular telephone grade modems, cable modems and DSL modems, ISDN adapters, and Ethernet cards.
What has been described above includes examples of the present invention. It is, of course, not possible to describe every conceivable combination of components or methodologies for purposes of describing the present invention, but one of ordinary skill in the art may recognize that many further combinations and permutations of the present invention are possible. Accordingly, the present invention is intended to embrace all such alterations, modifications and variations that fall within the spirit and scope of the appended claims. Furthermore, to the extent that the term “includes” is used in either the detailed description or the claims, such term is intended to be inclusive in a manner similar to the term “comprising” as “comprising” is interpreted when employed as a transitional word in a claim.
This application is a continuation-in-part of U.S. patent application Ser. No. 10/610,486 filed on, Jun. 30, 2003 and entitled IDEAL TRANSFER OF CALL HANDLING FROM AUTOMATED SYSTEMS TO HUMAN OPERATORS BASED ON FORECASTS OF AUTOMATION EFFICACY AND OPERATOR LOAD.
Number | Name | Date | Kind |
---|---|---|---|
4747054 | Chittineni | May 1988 | A |
5291550 | Levy et al. | Mar 1994 | A |
5493692 | Theimer et al. | Feb 1996 | A |
5519773 | Dumas et al. | May 1996 | A |
5530744 | Charalambous et al. | Jun 1996 | A |
5544321 | Theimer et al. | Aug 1996 | A |
5555376 | Theimer et al. | Sep 1996 | A |
5561711 | Muller | Oct 1996 | A |
5603054 | Theimer et al. | Feb 1997 | A |
5611050 | Theimer et al. | Mar 1997 | A |
5812865 | Theimer et al. | Sep 1998 | A |
5848131 | Shaffer et al. | Dec 1998 | A |
5896448 | Holt | Apr 1999 | A |
5995805 | Ogasawara et al. | Nov 1999 | A |
6115462 | Servi et al. | Sep 2000 | A |
6353398 | Amin et al. | Mar 2002 | B1 |
6466232 | Newell et al. | Oct 2002 | B1 |
6480598 | Reding et al. | Nov 2002 | B1 |
6490698 | Horvitz et al. | Dec 2002 | B1 |
6513046 | Abbott, III et al. | Jan 2003 | B1 |
6549915 | Abbott, III et al. | Apr 2003 | B2 |
6672506 | Swartz et al. | Jan 2004 | B2 |
6741188 | Miller et al. | May 2004 | B1 |
6747675 | Abbott et al. | Jun 2004 | B1 |
D494584 | Schlieffers et al. | Aug 2004 | S |
6791580 | Abbott et al. | Sep 2004 | B1 |
6796505 | Pellaumail et al. | Sep 2004 | B2 |
6798876 | Bala | Sep 2004 | B1 |
6801223 | Abbott et al. | Oct 2004 | B1 |
6807274 | Joseph et al. | Oct 2004 | B2 |
6812937 | Abbott et al. | Nov 2004 | B1 |
6837436 | Swartz et al. | Jan 2005 | B2 |
6842877 | Robarts et al. | Jan 2005 | B2 |
7010501 | Roslak et al. | Mar 2006 | B1 |
7040541 | Swartz et al. | May 2006 | B2 |
7063263 | Swartz et al. | Jun 2006 | B2 |
7171378 | Petrovich et al. | Jan 2007 | B2 |
7195157 | Swartz et al. | Mar 2007 | B2 |
7385501 | Miller et al. | Jun 2008 | B2 |
20010030664 | Shulman et al. | Oct 2001 | A1 |
20010040590 | Abbott et al. | Nov 2001 | A1 |
20010040591 | Abbott et al. | Nov 2001 | A1 |
20010043231 | Abbott et al. | Nov 2001 | A1 |
20010043232 | Abbott et al. | Nov 2001 | A1 |
20020032689 | Abbott, III et al. | Mar 2002 | A1 |
20020044152 | Abbott, III et al. | Apr 2002 | A1 |
20020052930 | Abbott et al. | May 2002 | A1 |
20020052963 | Abbott et al. | May 2002 | A1 |
20020054130 | Abbott, III et al. | May 2002 | A1 |
20020054174 | Abbott et al. | May 2002 | A1 |
20020078204 | Newell et al. | Jun 2002 | A1 |
20020080155 | Abbott et al. | Jun 2002 | A1 |
20020080156 | Abbott et al. | Jun 2002 | A1 |
20020083025 | Robarts et al. | Jun 2002 | A1 |
20020083158 | Abbott et al. | Jun 2002 | A1 |
20020087525 | Abbott et al. | Jul 2002 | A1 |
20020099817 | Abbott et al. | Jul 2002 | A1 |
20030035532 | Ganesan | Feb 2003 | A1 |
20030046401 | Abbott et al. | Mar 2003 | A1 |
20030154476 | Abbott, III et al. | Aug 2003 | A1 |
20040005047 | Joseph et al. | Jan 2004 | A1 |
20040098274 | Dezonno et al. | May 2004 | A1 |
20040201500 | Miller et al. | Oct 2004 | A1 |
20050034078 | Abbott et al. | Feb 2005 | A1 |
20050041796 | Joseph et al. | Feb 2005 | A1 |
20050192936 | Meek et al. | Sep 2005 | A1 |
20050266858 | Miller et al. | Dec 2005 | A1 |
20050272442 | Miller et al. | Dec 2005 | A1 |
20060019676 | Miller et al. | Jan 2006 | A1 |
20080090591 | Miller et al. | Apr 2008 | A1 |
20080091537 | Miller et al. | Apr 2008 | A1 |
20080161018 | Miller et al. | Jul 2008 | A1 |
Number | Date | Country |
---|---|---|
1 176 838 | Jan 2002 | EP |
9800787 | Jan 1998 | WO |
Number | Date | Country | |
---|---|---|---|
20040264672 A1 | Dec 2004 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10610486 | Jun 2003 | US |
Child | 10827873 | US |