USRE44979E1 - System and method for common account based routing of contact records - Google Patents

System and method for common account based routing of contact records Download PDF

Info

Publication number
USRE44979E1
USRE44979E1 US13/668,380 US201213668380A USRE44979E US RE44979 E1 USRE44979 E1 US RE44979E1 US 201213668380 A US201213668380 A US 201213668380A US RE44979 E USRE44979 E US RE44979E
Authority
US
United States
Prior art keywords
contact
records
pool
call
goal
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related, expires
Application number
US13/668,380
Inventor
Richard Rodenbusch, Jr.
Daniel N. Duncan
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Alvaria Cayman Cx
Original Assignee
Noble Systems Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from US09/901,749 external-priority patent/US7142662B2/en
Priority claimed from US10/095,513 external-priority patent/US7103173B2/en
Application filed by Noble Systems Corp filed Critical Noble Systems Corp
Priority to US13/668,380 priority Critical patent/USRE44979E1/en
Application granted granted Critical
Publication of USRE44979E1 publication Critical patent/USRE44979E1/en
Assigned to WELLS FARGO CAPITAL FINANCE, LLC reassignment WELLS FARGO CAPITAL FINANCE, LLC AMENDMENT Assignors: NOBLE SYSTEMS CORPORATION
Assigned to JEFFERIES FINANCE LLC reassignment JEFFERIES FINANCE LLC SECOND LIEN PATENT SECURITY AGREEMENT Assignors: ASPECT SOFTWARE, INC., NOBLE SYSTEMS CORPORATION
Assigned to JEFFERIES FINANCE LLC reassignment JEFFERIES FINANCE LLC FIRST LIEN PATENT SECURITY AGREEMENT Assignors: ASPECT SOFTWARE, INC., NOBLE SYSTEMS CORPORATION
Assigned to NOBLE SYSTEMS CORPORATION reassignment NOBLE SYSTEMS CORPORATION RELEASE BY SECURED PARTY (SEE DOCUMENT FOR DETAILS). Assignors: WELLS FARGO CAPITAL FINANCE, LLC
Assigned to NOBLE SYSTEMS, LLC, A DELAWARE LIMITED LIABILITY COMPANY reassignment NOBLE SYSTEMS, LLC, A DELAWARE LIMITED LIABILITY COMPANY CERTIFICATE OF CONVERSION Assignors: NOBLE SYSTEMS CORPORATION, A GEORGIA CORPORATION
Assigned to ALVARIA, INC., NOBLE SYSTEMS, LLC reassignment ALVARIA, INC. RELEASE BY SECURED PARTY (SEE DOCUMENT FOR DETAILS). Assignors: JEFFRIES FINANCE LLC
Assigned to JEFFERIES FINANCE LLC reassignment JEFFERIES FINANCE LLC PATENT SECURITY AGREEMENT Assignors: ALVARIA CAYMAN (CXIP), ALVARIA CAYMAN (WEM)
Assigned to ALVARIA, INC., NOBLE SYSTEMS, LLC reassignment ALVARIA, INC. RELEASE BY SECURED PARTY (SEE DOCUMENT FOR DETAILS). Assignors: JEFFRIES FINANCE LLC
Assigned to ALVARIA CAYMAN (CX) reassignment ALVARIA CAYMAN (CX) ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: NOBLE SYSTEMS, LLC
Expired - Fee Related legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M3/00Automatic or semi-automatic exchanges
    • H04M3/42Systems providing special services or facilities to subscribers
    • H04M3/50Centralised arrangements for answering calls; Centralised arrangements for recording messages for absent or busy subscribers ; Centralised arrangements for recording messages
    • H04M3/51Centralised call answering arrangements requiring operator intervention, e.g. call or contact centers for telemarketing
    • H04M3/5158Centralised call answering arrangements requiring operator intervention, e.g. call or contact centers for telemarketing in combination with automated outdialling systems

Definitions

  • This invention relates to the field of telephony, computer networks, and customer relationship management, and more particularly to a system and method for common account based routing of contact records.
  • Customer contact centers represent the front line for customer service, marketing operations, and debt collection for many businesses. Typical centers receive or make hundreds of telephone calls, emails, and Internet chat requests per day with the aid of automated telephony and Internet equipment. For instance, predictive dialers such as the MOSAIX Predictive Dialing System (“PDS”) manufactured by Avaya Incorporated automatically dial outbound telephone calls to contact individuals and then transfer the contacted individuals to agents so the agent can talk with the individual.
  • PDS MOSAIX Predictive Dialing System
  • Dialing devices such as predictive dialers save time for the agent placing the call because the dialing device and not the agent dials the telephone number and agents' time is not wasted with unanswered calls or answering machines.
  • Predictive dialers also spread the outbound telephone calls evenly among all the agents working from the dialing device so that the agents share the workload equally and no agents sit idle while others have too many telephone calls to place.
  • Predictive dialers are also a significant component of customer relationship management (CRM) systems which extend the efficiency gained from predictive dialers to other contact channels such as email and live Internet chat.
  • CRM customer relationship management
  • a contact list is divided into as many parts as there are call centers or dialers with each call center receiving its own section of the calling list.
  • this segmentation distributes work, coordination of strategy for outbound calling is difficult since each call center is responsible for its own section of the calling list and has no knowledge of the other call centers' progression with their own calling lists. For instance, if a call center goes down and cannot make outbound telephone calls, the other call centers cannot typically address the downed call center's calling list goals and priorities because the other call centers do not have access to the calling list including the telephone numbers actually called.
  • Work load segmentation typically occurs at a host level, where each device is assigned a portion of the work load. A host downloads the segmented contact list to the individual dialing devices. If one device fails, the other devices do not know the status of the contacts in the failed device's segment.
  • a call center employs categorization and prioritization routing or load leveling routing.
  • categorization and prioritization routing the calls are categorized and prioritized before being sent to the call centers. All of the available call records are organized into distinct groups or pools and each pool of call records is prioritized according to a particular prioritizing scheme.
  • a typical scheme often used at contact centers is to prioritize the inbound calls with the highest priority, live Internet chats second, outbound calls third, and email or other requests last.
  • the agents are segregated into distinct teams and each team receives call records from a particular pool based on the prioritization of the call records.
  • Load leveling routing of call records allows multiple agent teams to work on the same group or pools of records whether the agents are located in the same call center or if the agents are located across multiple call centers. Load leveling routing eliminates the restriction of categorization and prioritization that requires distinct groups of records for agents not working from the same dialing device. This allows for the movement of call records between the agents and call centers.
  • Another difficulty with attempts to coordinate calling campaigns across multiple contact device dialers and/or multiple contact calling centers is that a single individual sometimes has multiple accounts that result in multiple contact attempts to the individual for each account. For instance, an individual may have call records for a delinquent account, a marketing account for new sales and a service quality inquiry. As another example, a calling center may have contracts with multiple businesses to contact each business' delinquent accounts and the delinquent accounts of two or more businesses may share common individuals who are delinquent. In such instances, multiple call centers may simultaneously contact or attempt to contact the same individual for the different accounts. An individual targeted by multiple calling centers is more likely to feel harassed and less likely to cooperate or even respond to the call center inquiries. Multiple attempts to contact the same individual by different call centers result in greater outbound call volume and less effective use of outbound calling capacity.
  • a system and method for distributing contact records utilizing goals based routing is provided which substantially eliminates or reduces disadvantages and problems associated with previously developed systems and methods for distributing contact records.
  • a goal module monitors the performance of one or more pools of contact records and automatically modifies the distribution of the contact records from the pools based on the performance of each pool.
  • distribution of contact records utilizing goals based routing is accomplished by a distribution module interfaced with a plurality of devices.
  • the distribution module includes a plurality of pools and a plurality of queues.
  • the distribution module places contact records into the pools, transfers less than all of the contact records to the queues from the pools, and transfers the queues to the devices.
  • a goal module Associated with the distribution module is a goal module.
  • the goal module monitors the performance of each pool and modifies which queues the pools transfer contact records to based upon the performance of the pools.
  • the goal module defines one or more levels of effort for each queue.
  • the levels of effort determine the percentage of contact records that transfers from a pool to a particular queue.
  • the goal module also determines a goal for each pool that reflects the performance of the pool and prioritizes the pools relative to each other.
  • the goal module monitors the performance of the pools by calculating a goal status for each pool.
  • the goal module uses the goal status to determine a goal state for each pool.
  • the goal state indicates whether a pool is satisfying the goal.
  • the goal module modifies which queues the pools transfer contact records to by transferring the levels of effort between the pools and the queues.
  • the goal states and one or more goal strategies allow for the optimization of the transfer of contact records from the pools to the queues and determine how the goal module modifies which queues the pools transfer contact records to.
  • the goal strategies control how levels of effort between the pools and queues are transferred when a pool is not satisfying the goal.
  • a goal strategy may require the transfer of levels of effort to pools not satisfying their goals or the transfer of levels of effort away from pools not satisfying the goal.
  • the goal module transfers levels of effort in accordance with the goal strategies so that pools having the highest priority maintain or achieve the goals throughout the day.
  • related call records are identified and marked with a relationship tag to coordinate actions for multiple related accounts before a contact attempt is made.
  • This relationship tag may be applied in real-time before a call record is prepared for distribution or when a list of callable records is loaded into the system.
  • a comparison engine analyzes the call records database of one or more call distribution modules to identify and tag related call record accounts, such as call record accounts that are related to a common individual.
  • a common account tag detector associated with each contact device detects an individual relation tag associated with all similarly tagged call records and, before a contact attempt to the individual is made, communicates the relationship tag and related account information to the call distribution module.
  • a common account controller of the call distribution module places a hold on other accounts related to the individual by placing a hold on call records having the relationship tag to prevent the placement of multiple calls to the individual once a call has been initiated.
  • the common account controller routes the related account information (through the feed to the dialing device) to the operator handling the successful contact with the individual to allow simultaneous resolution of the related account call records through the single successful contact.
  • the present invention provides a number of important technical advantages.
  • One important technical advantage is the distribution of contact records based on the performance of the pools.
  • the ability to distribute contact records based on the performance of the pools of contact records allows a call center to operate more efficiently because the call center recognizes when a pool is not sufficiently performing and redistributes the contact record workload to allow for more efficient operation thereby allowing higher priority pools to satisfy performance requirements.
  • Another important technical advantage of the present invention is the distribution of contact records based on the performance of the pools without manual intervention.
  • the goal module monitors the performance of each pool and determines whether a pool is ahead, at, or behind the goal. When a pool is not satisfying a goal, the goal module automatically takes action to modify how the pools transfer contact records to so that the highest priority pools achieve or maintain the goals. Therefore, no manual intervention is required and pools are not adversely affected by the changes. In addition, because no manual intervention is required, there is reduced agent or device downtime when the goal module distributes the contact records based upon the performance of the pools.
  • Another important technical advantage of the present invention is the ability to quickly respond to current pool performance levels. Because the goal module constantly monitors the performance of the pools, the goal module may instantly react to any change in the performance of the pools throughout the day. And because the goal module monitors the performance of all the pools and has the goal states for every pool, when the goal module modifies the distribution of contact records, the goal module takes into account the effects of the modification on the goals for all of the pools so that the highest priority pools achieve or maintain the goals. Therefore, the guess work in distributing contact records based on the performance of the pools is reduced and there are no unexpected results at the end of the day.
  • Another important technical advantage of the present invention is that multiple related call record accounts are handled through a single successful contact attempt.
  • the related account call records are identified and tagged in a predetermined field or database column so that contact devices are able to record a successful contact attempt to all call records.
  • the call distribution device common account controller leverages the successful contact to handle multiple call record accounts related to the same individual without undue delay in transferring the related account information to the contact operator. This reduces outbound call volume by eliminating multiple calls to the same individual and more effectively uses outbound calling resources to improve the distribution of resources across related and unrelated accounts.
  • an operator has greater leverage in resolving business issues with the individual. For instance, an operator generally has greater bargaining power when dealing with an individual over multiple delinquent accounts than a single delinquent account.
  • FIG. 1 depicts a block diagram of plural dialing devices interfaced with a distribution module
  • FIG. 2 illustrates a block diagram of another embodiment of the present invention employing two distribution modules having common account controllers
  • FIG. 3 depicts a flow diagram of a method for distribution outbound telephone calls
  • FIGS. 4a and 4b illustrate a flow diagram for the population of the pools and queues with call records
  • FIG. 5 depicts a flow diagram of a method for goals based routing of contact records employing a meet-goals goal strategy
  • FIG. 6 illustrates a flow diagram of a method for goals based routing of contact records employing an exceed-goals goal strategy.
  • the goal module of the present invention allows for the routing of contact records across one or more than one device based on the performance of the individual pools of contact records quickly and without manual intervention.
  • the goals based routing of contact records allows for dynamically modifying the distribution of contact records based on the performance of the pools of contact records throughout the day without manual intervention, down time, and guesswork.
  • the present invention allows for the routing and distribution of contact records among a plurality of devices and agents based upon the performance of the different pools of contact records.
  • Contact records include such customer contacts as outbound telephone calls, inbound telephone calls, call records, emails, Internet chat requests, online chat requests, and any other appropriate form of customer contact.
  • Devices include such call center or contact center devices as dialing devices including predictive dialers, email servers, Internet chat servers, VoIP servers, telephony servers, web servers, and any other appropriate call center or contact center devices.
  • dialing devices including predictive dialers, email servers, Internet chat servers, VoIP servers, telephony servers, web servers, and any other appropriate call center or contact center devices.
  • FIG. 1 depicts a block diagram for an outbound distribution system 100 for distributing outbound telephone calls employing goals based routing.
  • a distribution module 102 interfaces with a first call center 104 a and a second call center 104 n.
  • System 100 allows call centers 104 a and 104 n to operate as a single group of resources rather than two decentralized units, with distribution module 102 controlling the strategy, workload, and calling efforts for call centers 104 from a single, central location.
  • distribution module 102 interfaces with multiple dialing devices at one or more call centers, or one dialing device located in one call center.
  • Call centers 104 are geographically distributed, each having one or more dialing devices that place telephone calls using information in the call records.
  • Distribution module 102 operates on a SOLARIS, Linux, or an any other appropriate operating system server and communicates with call centers 104 via standardized communications links such as Ethernet, the Internet with protocols such as FTP, CORBA, API, and sockets over TCP/IP, asynchronous transfer mode (“ATM”), or any other appropriate communication link.
  • Call centers 104 each have one or more dialing devices 108 .
  • Dialing devices 108 are predictive dialers such as the MOSAIX PDS manufactured by Avaya Incorporated or other appropriate predictive dialers.
  • interfaced to dialing device 108 a in call center 104 a are three agents 110 a, 110 b, and 110 c with dialing device 108 n of call center 104 n also having three agents 110 d, 110 e, and 110 f interfaced to it.
  • Agents 110 are workstations where operators or agents speak to the individuals, chat with individuals online, complete emails to, or otherwise contact individuals who are contacted by dialing devices 108 .
  • Dialing device 108 dials telephone numbers extracted from the call records. If an individual answers the telephone, dialing device 108 transfers the telephone call to one of agents 110 so that the agent can speak with the individual. Dialing devices 108 therefore improve telephone calling efficiency by dialing the telephone number and transferring the call to an agent only if an individual answers the telephone.
  • System 100 functions by first having distribution module 102 acquire the call records that dialing devices 108 will call. There are several different ways that distribution module 102 acquires the call records.
  • host 112 which is associated with dialing devices 108 , stores raw call records.
  • the raw call records contain information including telephone number, account number, individual name and address, and any other appropriate personal information.
  • a raw call record for Joe Smith includes Joe Smith's telephone number, mailing address, account status, account number, account passwords, gender, marital status, number of children, employment status, and yearly income.
  • Host 112 transfers the raw call records for that day along path 114 a to call center 104 a and dialing device 108 a and along path 114 b to call center 104 n and dialing device 108 n.
  • Distribution module 102 contacts dialing device 108 a within call center 104 a via path 116 a and dialing device 108 n within call center 104 n via path 116 b.
  • Distribution module 102 downloads from dialing devices 108 to call record database 118 the call records.
  • the call records may contain some but not all of the information from the raw call records. Downloading less than all of the information from the raw call records saves bandwidth and allows for efficient operation of distribution module 102 because it handles smaller amounts of data. For instance, distribution module 102 downloads as the call record an individual's name, telephone number, and account number. So the call record for Joe Smith contains Joe Smith's name, his telephone number, and account number.
  • host 112 stores the raw call records. Instead of transferring the raw call records to dialing devices 108 , distribution module 102 downloads the call records from host 112 to call record database 118 via path 120 .
  • dialing devices 108 store the raw call records. Therefore, distribution module 102 contacts call center 104 a and dialing device 108 a via path 116 a and call center 104 n and dialing device 108 n via path 116 b to download the call records to call record database 118 .
  • Scheduling module 122 operates to develop and provide optimal calling strategies for the call records including resource optimization, automated statistical modeling and flexible strategy management. For instance, one such scheduling module 122 is described in U.S. Pat. No. 5,802,161, entitled “Method and System for Optimized Scheduling” issued Sep. 1, 1998, and is hereby incorporated by reference.
  • scheduling module 122 is not required for the operation of distribution module 102 but it affects how distribution module 102 downloads the call records and what information is contained in the call records. For instance, host 112 transfers the raw call records to call center 104 a and dialing device 108 a via path 114 a and call center 104 n and dialing device 108 n via path 114 b.
  • Scheduling module 122 downloads from dialing device 108 a in call center 104 a via path 124 a and from dialing device 108 n in call center 104 n via path 124 b the raw call records. Scheduling module 122 develops call schedules for the raw call records.
  • Distribution module 102 downloads the call records including the call schedule from scheduling module 122 via path 124 c and stores the call records in call record database 118 .
  • Scheduling module 122 downloads the raw call records from host 112 via path 126 .
  • scheduling module 122 adds call schedules to the raw call records before distribution module 102 downloads the call records from scheduling module 122 via path 124 c to call record database 118 .
  • distribution module 102 organizes and transfers the call records from call record database 118 to pools 128 , which are interfaced with distribution module 102 .
  • the pools are sets of callable call records specified by distribution module 102 .
  • Each pool 128 represents a specific and ordered group of call records. In the embodiment shown in FIG. 1 , there are three pools 128 a, 128 b, and 128 c. In alternative embodiments there can be more than three or less than three pools.
  • Distribution module 102 then transfers less than all of the call records from pools 128 to queues 130 . Interfaced with pools 128 are queues 130 a, 130 b, 130 c, and 130 d.
  • a queue is a set of rules for selecting call records from pools having the necessary and sufficient information describing the exact method of transferring call records to dialing devices 108 and any call records assigned to but not yet transferred to dialing devices 108 for dialing devices 108 to call.
  • Distribution module 102 attaches each queue 130 to a particular dialing device 108 and monitors each dialing device. As necessary, distribution module 102 transfers call records from pools 128 in accordance with the configuration of queues 130 which includes selection rules, time of day, time of week, number of calls completed, and number of call records sent.
  • Queues 130 then transfer the call records to their assigned dialing devices 108 .
  • distribution module 102 transfers call records according to the configuration of queues 130 a and 130 b to dialing device 108 a of call center 104 a and according to the configuration of queues 130 c and 130 d to dialing device 108 n of call center 104 n.
  • each queue 130 is associated with a single campaign for the dialing device to which it is assigned.
  • a campaign is an outbound job calling on dialing device 108 that can receive additional call records for calling while the outbound calling job is active. Normally, a campaign on dialing device 108 continues to run until manually stopped or when it runs out of call records to dial.
  • Pools 128 can satisfy transfer requests for call records for one or more than one queue 130 .
  • pool 128 a transfers call records to queue 130 a
  • pool 128 b transfers call records to queues 130 b and 130 c
  • pool 128 c transfers call records to queue 130 d.
  • distribution module 102 can change the queues which request call records from pools 128 throughout the day and in the middle of outbound calling campaigns. For instance, if dialing device 108 n located in call center 104 n calls all the call records in pool 128 c, then distribution module 102 can request that pools 128 a and 128 b transfer call records to queue 130 d.
  • Distribution module 102 transfers the call records to pools 128 , transfers less than all of the call records from pools 128 to queues 130 , and transfers queues 130 to dialing devices 108 before dialing devices 108 begin their daily calling routines. At the beginning of the day, distribution module 102 transfers enough call records from pools 128 to queues 130 to allow for dialing devices 108 to place calls for fifteen, thirty, sixty minutes, or an appropriate amount of time to place calls. Distribution module 102 monitors the calls placed by dialing devices 108 as well as the number of call records remaining to be called to determine how busy dialing devices 108 are and when and how many additional call records to transfer from pools 128 to queues 130 .
  • the monitoring of queues 130 and the transferring of additional call records from pools 128 to queues 130 allows for real-time movement of call records from distribution module 102 to dialing devices 108 throughout the day. For instance, as soon as dialing device 108 a is about to finish calling the call records in the campaign assigned to queue 130 a, distribution module 102 transfers additional call records from pool 128 a to queue 130 a so that dialing device 108 a maintains a steady and level flow of work.
  • Dialing devices 108 also track the call attempt results of every call placed by dialing devices 108 .
  • the call attempt results include whether or not a call resulted in a right party contact, a wrong party contact, no answer, or an answering machine.
  • the objective of a call record for Joe Smith is to talk with Joe Smith. If agent 110 speaks with Joe Smith, that is a right party contact and a successful call attempt result. If Joe's babysitter answers the phone and Joe is not home, that is a wrong party contact and an unsuccessful call attempt result. If no one answers the phone or an answering machine answers the phone, that is an unsuccessful call attempt result since the desired party was not contacted. Therefore throughout the day, distribution module 102 queries dialing devices 108 for call attempt results and uploads the call attempts results. If a call attempt result is unsuccessful, then distribution module 102 updates the call record in pools 128 so that a dialing device 108 may call the call record again at a later time in the day.
  • queues 130 include selection rules that determine how distribution module 102 transfers call records from pools 128 to queues 130 .
  • the selection rules allow for the optimization of the transfer of call records from pools 128 to queues 130 and include priority rules, percentage rules, quotas, queuing theory rules, or any other appropriate rules for optimizing the transfer of call records from pools 128 to queues 130 .
  • the selection rules can be modified on an as needed basis.
  • Priority rules result in distribution module 102 transferring call records from pools 128 to queues 130 based upon an assigned priority for each pool 128 .
  • queue 130 a receives call records from pools 128 a and 128 b with pool 128 a having priority over pool 128 b.
  • Queue 130 b receives call records from pools 128 a and 128 b with pool 128 b having priority over pool 128 a.
  • pool 128 a arrives at 8:00 AM while pool 128 b arrives at 9:00 AM.
  • both queues 130 a and 130 b receive call records from pool 128 a.
  • queue 130 a continues to receive call records from pool 128 a while queue 130 b receives call records from pool 128 b.
  • Percentage rules result in distribution module 102 simultaneously transferring call records from pools 128 to queues 130 .
  • queue 130 c has a percentage configuration with pools 128 b and 128 c and queue 130 d has a percentage configuration with pools 128 b and 128 c.
  • queue 130 c and 130 d receive call records simultaneously from pools 128 b and 128 c.
  • pool 128 b arriving at 8:00 AM
  • pool 128 c arriving at 9:00 AM
  • both queues 130 c and 130 d receive call records from pool 128 b.
  • queues 130 c and 130 d alternatively receive call records from pools 128 b and 128 c.
  • the percentages are variable for instance so that queue 130 c receives 80% of its call records from pool 128 b and 20% of its call records from pool 128 c while queue 130 d receives 60% of its call records from pool 128 b and 40% of its call records from pool 128 c.
  • the selection rules can also incorporate the execution of an optimization module which will determine the optimal mix of call records from each of the available pools 128 based on the optimization constraints and the number of call records needed at the current time.
  • the selection rules can also incorporate pool quotas which are limits set on each pool controlling a maximum activity level such as number of records transferred, number of successful call attempts, and other appropriate indicators of call record activity.
  • distribution module 102 can also set quotas on how many call records dialing devices 108 will call from pools 128 . In the percentage rule example above, distribution module 102 can place a quota on pool 128 b. When dialing devices 108 satisfy the quota for pool 128 b, queues 130 c and 130 d no longer receive call records from pool 128 b and only receive call records from pool 128 c.
  • the selection rules can also be a combination of the percentage rules and the priority rules.
  • queue 130 b receives call records from all three pools 128 a, 128 b, and 128 c. Queue 130 b receives call records from pool 128 b until dialing device 108 a calls all the call records in pool 128 b. At that time, queue 130 b then alternately receives call records from pools 128 a and 128 c. As with the percentage rules above, queue 130 b can receive call records from pools 128 a and 128 c in any percentage breakdown. Therefore, pool 128 b has priority over pools 128 a and 128 c while pools 128 a and 128 c transfer call records using percentage rules.
  • these selection rules allow for skills-based routing between pools 128 .
  • distribution module 102 allows pool 128 a to initially transfer call records to queue 130 a and pool 128 c to initially transfer call records to queue 130 d. If pool 128 c becomes depleted and has no more call records to transfer to queue 130 d, then pool 128 a can begin transferring call records to both queues 130 a and 130 d. This allows distribution module 102 to transfer call records for easy to moderate difficulty customers to the best agents while the less skilled agents work the more difficult customers. And once the easy to moderate difficulty customers call records are depleted, the best agents can begin working the more difficult customer call records.
  • distribution module 102 may also route call records to dialing devices 108 and agents 110 based on the performance of pools 128 . Routing the call records based on the performance of pools 128 allows distribution module 102 to make modifications so that pools 128 having a higher priority are not under-performing.
  • Goal module 103 associated with distribution module 102 and pools 128 , monitors the performance of pools 128 . To monitor the performance of pools 128 , either a user of system 100 or goal module 103 defines a performance metric for each pool 128 . Once the performance metric is defined, goal module 103 applies the performance metric to pools 128 . The performance metric is what goal module 103 uses to measure the performance of pools 128 .
  • the performance metric for pool 128 a may be the number of right party contacts while the performance metric for pool 128 b is the number of accounts attempts and the performance metric for pool 128 c is the number of call records attempted.
  • Each pool 128 may have a different performance metric or pools 128 may have the same performance metric.
  • each of the pools 128 may have more than one performance metric.
  • pool 128 a may have both a performance metric for the number of right party contacts and for the number of total accounts attempted.
  • goal module 103 defines a goal for each pool 128 .
  • the goal can be either an absolute goal or a goal set relative to all the other pools 128 .
  • An absolute goal is a goal tied solely to the performance of the particular pool 128 while a relative goal is tied to the performance of all pools 128 .
  • the goal is related to the selected performance metric. For instance, pool 128 a having a performance metric of number of right party contacts may have a goal of fifty right party contacts while pool 128 c having a performance metric of number of call records attempted has a goal of one hundred call records attempted.
  • pool 128 has more than one performance metric, then the pool 128 will have a goal for each performance metric. For example, if pool 128 a has a performance metric for number of right party contacts and for total number of accounts attempted, pool 128 a may have a goal of 80 right party contacts and 200 accounts attempted. In addition, a pool 128 may also have a combination of goals where there pool 128 only needs to satisfy one of the goals. For instance, pool 128 b may have a goal of 75 right party contacts or 200 accounts attempted and as long as pool 128 b has at least 75 right party contacts or 200 accounts attempted, pool 128 b is considered to be satisfying its goal and experiencing satisfactory performance.
  • the goals may also be end of day goals, mid-day goals, and rate based goals.
  • End of day goals are goals calculated based on the performance of a pool 128 at the end of the day and include such goals as total number of call records attempted and number of right party contacts.
  • Mid-day goals are similar to end of day goals but are calculated based on the time of day. For example, pool 128 a may have a mid-day goal of twenty-five right party contacts by noon.
  • Rate based goals are calculated as a rate of the total calls. For instance, if pool 128 a has a performance metric of right party contact rate, a rate based goal may be 15% of all the call records from pool 128 a should result in a right party contact.
  • goal module 103 defines or constrains levels of effort for each queue 130 .
  • the levels of effort detail the percentage of call records that transfer from a particular pool 128 to a particular queue 130 .
  • the levels of effort are stored in an effort map associated with goal module 103 .
  • Table 1 shows an example effort map for system 100 . An examination of the effort map shown in Table 1 reveals that queue 1 (queue 130 a) has a level of effort of 100% to pool 1 (pool 128 a) meaning queue 130 a receives all of its call records from pool 128 a.
  • Queue 2 (queue 130 b) has a level of effort of 100% to pool 2 (pool 128 b) meaning queue 130 b receives 100% of its call records from pool 128 b.
  • Queue 3 (queue 130 c) has a level of effort of 100% to pool 2 (pool 128 b) meaning queue 130 c receives 100% of its call records from pool 128 b.
  • Queue 4 (queue 130 d) has a level of effort of 100% to pool 3 (pool 128 c) meaning that queue 130 d receives 100% of its call records from pool 128 c. Therefore, 100% of the call records in pool 128 a transfer to queue 130 a, the call records in pool 128 b transfer equally to queues 130 b and 130 c, and 100% of the call records in pool 128 c transfer to queue 130 d.
  • goal module 103 calculates a goal status for each pool 128 .
  • the goal status can be defined as either the absolute difference between the actual metric and the goal or the percentage that a pool 128 is either ahead or behind its goal. For instance, if each pool 128 has a goal of fifty right party contacts and pool 128 a has forty-five right party contacts, pool 128 b has forty-eight right party contracts, and pool 128 c has sixty right party contacts, then pool 128 a has a goal status of ⁇ 10%, pool 128 b has a goal status of ⁇ 4%, and pool 128 c has a goal status of +20% for percentage based goals. Pool 128 a has a goal status of ⁇ 5, pool 128 b has a goal status of ⁇ 2 and pool 128 c has a goal status of +10 for absolute difference based goals.
  • Goal module 103 uses the goal status for each pool 128 to determine a goal state for each pool 128 . Pools 128 will have a goal state for each goal. An example definition of goals states would include the designation of ahead of goal, at goal, or behind goal. Goal module 103 or a user of system of 100 determines what thresholds define each of the available goal states. For example, if the goal states have been defined as ahead of goal, at goal, or behind goal, then a goal status of +10% and above may be ahead of goal, a goal status between +10% and ⁇ 5% may be at goal, and a goal status of ⁇ 5% and below may be behind goal.
  • pool 128 a has a goal state of behind goal ( ⁇ 10%)
  • pool 128 b has a goal state of at goal ( ⁇ 4%)
  • pool 128 c has a goal state of ahead of goal (+20%). Any pool 128 that has a goal state of behind goal is said to be an under-performing pool and therefore experience unsatisfactory performance.
  • goal module 103 also identifies and defines a final goal for each pool 128 .
  • a user of system 100 may also define the final goals for each of the pools 128 .
  • pool 128 a- 128 c each have a final goal of eighty right party contacts.
  • pool 128 a achieves eighty right party contacts. Because pool 128 a has achieved its final goal, it becomes inactive and the call records from pool 128 a are no longer transferred to queue 130 a.
  • goal module 103 modifies which queues 130 pools 128 b and 128 c transfer call records to by allowing pools 128 b and 128 c to transfer call records to queue 130 a. Since pools 128 b and 128 c have not reached their final goals, they are still active and queues 130 and agents 110 who were receiving call records from pool 128 a now receive call records from pools 128 b and 128 c.
  • goal module 103 prioritizes pools 128 relative to each other.
  • Certain pools 128 may contain call records that are of a higher priority than other pools 128 .
  • pool 128 a may contain call records for customers who have previously purchased products
  • pool 128 b may contain call records for customers who have never purchased products
  • pool 128 c may contain call records for customers who are delinquent in paying for products previously purchased. Since a company's highest priority may be to collect the money it is owed, goal module 103 rates pool 128 c with the highest priority while pool 128 a has the second highest priority since it contains call records for customers with whom there is a previous relationship. Pool 128 b has the lowest priority since it contains call records for potential customers.
  • the prioritization of pools 128 enables goal module 103 to adjust the workload of agents 110 so that pools 128 having the highest priority achieve and maintain their goals throughout the day.
  • Goal module 103 modifies the distribution of call records using the goals of pools 128 by modifying which queues 130 pools 128 transfer call records to based on the performance and prioritization of pools 128 .
  • Goal module 103 modifies which queues 130 pools 128 transfer call records to by adjusting or transferring the levels of effort between pools 128 and queues 130 .
  • pool 128 a is of a higher priority than pool 128 c and pool 128 a is behind goal.
  • queue 130 a receives 100% of its call records from pool 128 a and queue 130 d receives 100% of its call records from pool 128 c.
  • goal module 103 transfers level of effort from pool 128 c to pool 128 a so that queue 130 d receives 50% of its call records from pool 128 c and 50% of its call records from pool 128 a while queue 130 a still receives 100% of its call records from pool 128 a.
  • the example effort map shown in Table 2 illustrates which queues 130 pools 128 supply call records to after goal module 103 modifies the distribution of call records. Transferring some of the level of effort from pool 128 c to pool 128 a allows agents 110 who work queue 130 d to work call records from pool 128 a and thereby increase the number of agents 110 accessing call records from pool 128 a so that pool 128 a may satisfy its goal.
  • goal module 103 employs one or more goal strategies.
  • the goal strategies allow for the optimization of the transfer of call records from pools 128 to queues 130 and help to determine how goal module 103 transfers the levels of effort between pools 128 and queues 130 .
  • Goal module 103 may automatically select the goal strategy based upon the call records or a user of system of 100 may select an appropriate goal strategy.
  • goal module 103 transfers levels of effort to pools 128 that are not meeting their goals (a goal state of behind goal) and therefore are experiencing unsatisfactory performance. For example, if pool 128 a is behind goal and pool 128 b is ahead of goal, goal module 103 transfers levels of effort from pool 128 b to pool 128 a so that queues 130 b and 130 c also receive call records from pool 128 a.
  • a number of right party contacts performance metric is a performance metric that might be managed with the meet-goals goal strategy.
  • Another goal strategy is an exceed-goals strategy.
  • goal module 103 transfers levels of effort away from pools 128 that are not meeting their goals (a goal state of behind goal) and therefore have unsatisfactory performance. For instance, if pool 128 b is behind goal and pool 128 c is at goal, goal module 103 transfers levels of effort from pool 128 b to pool 128 c so that queues 130 b and 130 c begin to receive call records from pool 128 c.
  • a right party contact rate performance metric is a performance metric that might be managed using the exceed-goals goal strategy.
  • goal module 103 sets preemptive limits on how much level of effort may be transferred away from pools 128 . These preemptive limits are stored in routing tables of which each pool 128 has its own routing table stored in goal module 103 .
  • An exemplary routing table for pool 128 a is shown in Table 3. In the example routing table of Table 3, if pool 128 a is ahead of goal, then pool 128 a is willing to forego 75% of its total level of effort to pools 128 that are at a higher priority that need additional levels of effort.
  • Pool 128 a is willing to forego 50% of its total level of effort to pools 128 that are at the same priority that need effort if pool 128 a is ahead of goal. Pool 128 a is willing to give up 25% of its total level of effort to pools 128 that are of lower priority if needed if pool 128 a is ahead of goal. The percentages are then set at 40%, 25% and 15% if pool 128 a is currently at goal. If pool 128 a is behind goal, pool 128 a will only give up 25% of its level of effort and only to a pool 128 of higher priority. Each pool 128 has its own routing table and the percentages may vary depending on the number of pools, the number of call records, or any other appropriate factors.
  • the goal states and one or more goal strategies are inputs to and determine the objective functions and the constraints for an optimized solution to the routing determination problem.
  • the goal strategies control how constraints on the levels of effort between pools 128 and queues 130 are relaxed or tightened when a pool 128 is not satisfying the goal.
  • a goal strategy may allow for the transfer of higher levels of effort to pools 128 not satisfying their goals or allow for the transfer of higher levels of effort away from pools 128 not satisfying the goal.
  • the goal module adjusts the level of effort constraints in accordance with the goal strategies so that pools 128 having the highest priority maintain or achieve the goals throughout the day.
  • system 100 employs contingency modules 132 for each dialing device 108 .
  • Contingency modules 132 are associated with dialing devices 108 . Contingency modules 132 secure the call records within their respective dialing devices 108 in case of an outage.
  • distribution module 102 creates call record accounts for dialing devices 108 , locks the call record accounts to dialing devices 108 , creates a contingency download file, and stores the contingency download file in contingency modules 132 .
  • Distribution module 102 updates the contingency download file with call attempt results which prevents dialing devices 108 from calling call records already successfully called.
  • Online interface 134 is a graphical user, platform-independent, password-protected World Wide Web (“WWW”) browser-based interface. Users use online interface 134 to control the settings for distribution module 102 including goal module 103 including application of the selection rules, number of pools, and number of call records to initially transfer to the queues, generate reports, select goal strategies, select performance metrics, select the goals for the pools, define the goal states, modify the effort map and routing tables, and create and modify enterprise parameters. Users access online interface 134 by using browser 136 to access Internet 138 to reach a specific web address. Once at the specific web address, the users enter the appropriate passwords to gain access to online interface 134 .
  • WWW World Wide Web
  • distribution module 102 interfaces with a single dialing device.
  • a single dialing device interfacing with distribution module 102 allows for variable control over similar lists of call records. For instance, call records may be divided into geographies such as states or time zones. Calling can be stopped automatically by distribution module 102 when a quota is reached for a particular geography. Distribution module 102 presents the similar lists of call records for different geographies as different pools but the similar lists of call records for different geographies would represent one calling job within the single dialing device.
  • FIG. 2 illustrates a block diagram of system 150 employing two distribution modules in an alternative embodiment of the present invention.
  • System 100 as shown in FIG. 2 is shown with less detail than in FIG. 1 .
  • Distribution module 152 is associated with two call centers 154 and 156 .
  • Call centers 154 and 156 each have one dialing device 158 .
  • Distribution module 152 provides the same functionality to call centers 154 and 156 that distribution module 102 provides to call centers 104 as described above in the discussion regarding FIG. 1 .
  • Distribution module 152 provides redundancy and prevents distribution module 102 from being overburdened by too many dialing devices. Distribution module 102 functions effectively with more than one dialing device interfaced with it but performance and efficiency suffers when too many dialing devices are attached. Therefore, additional distribution module 152 allows for both it and distribution module 102 to achieve optimal performance and efficiency when adding additional call centers 154 and 156 with additional dialing devices 158 .
  • distribution modules 102 and 152 are in communication with each other including communicating which call records are in the pools and the call attempt results.
  • Distribution modules 102 and 152 transfer call records and call attempt results between themselves just as distribution module 102 transfers call records and call attempt results between dialing devices 108 . Therefore, if dialing devices 158 are idle while dialing devices 108 are overburdened, distribution module 102 transfers call records to distribution module 152 for dialing devices 158 to call. In addition, if distribution module 152 experiences an outage, distribution module 102 transfers the high priority calls from distribution module 152 to dialing devices 108 without worry of calling the same call record a second time in the same day when the first call resulted in a right party contact.
  • the two distribution modules 102 and 152 of system 150 also each include a goal module 103 and 153 .
  • Goal module 153 provides the same functionality to call centers 154 and 156 that goal module 103 provides to call centers 104 as described above in the discussion regarding FIG. 1 .
  • Goal modules 103 and 153 are in communication with each other including communicating the performance of their respective pools and queues.
  • goal modules 103 and 153 can transfer levels of effort between their respective pools just as goal module 103 transfers levels of effort between pools 128 . Therefore if high priority pools 128 are not meeting their goals, then goal module 153 can transfer levels of effort from distribution module 152 so that the high priority pools 128 will achieve their goals.
  • Distribution modules 102 and 152 manage calls from a common database 118 that lists call record accounts for outbound contacts by dialing.
  • a comparison engine 160 interfaces with call records database 118 to analyze and tag related call record accounts.
  • comparison engine 160 relates multiple accounts to a single individual by comparing predetermined factors for common values, such as name, phone number, account number, social security account number, or other factors.
  • Each set of related accounts is tagged with a relationship tag in a predetermined call record field so that a search for that tag value will locate all related call record accounts.
  • distribution module 102 runs contact campaigns to collect delinquent electric bills and distribution module 153 runs contact campaigns to collect delinquent gas bills.
  • the combined call account records are analyzed to identify delinquent gas and electric bills related to the same individual and to tag each of the related delinquent call record accounts with a unique individual relation tag.
  • the lock process 190 locks both records to prevent dialing until results are returned 198 .
  • call record accounts in the call record database are analyzed and, where appropriate, tagged, the call records are transferred to pools and queues as previously described to have outbound call attempts performed by dialer contact devices 108 .
  • call record accounts in the call record database are analyzed in real-time and tagged just before call records are selected for dialing in the dialing device.
  • a common account tag detector 162 associated with the dialer 108 searches to determine if the call record field is populated with a relationship tag. If the call record field is not populated with an individual relation tag, the dialer 108 handles the contact and communicates with distribution module 102 or 152 as described.
  • the dialer 108 communicates the unique individual relation tag to a common account controller 164 of distribution module 102 or 152 .
  • Common account controller 164 initiates a search for the unique relationship tag in the pools of distribution module 102 and 152 to place the call attempt result and a hold on outbound attempts for call record accounts related to the specified account. For example, successful contact by an operator for collection of the delinquent gas bill and delinquent electric bill of an individual may result in payments for each from one call.
  • a flow diagram depicts a process for distributing outbound call records.
  • the process begins at step 170 with the transfer of call records from host 112 , dialing devices 108 , or scheduling module 122 to distribution module 102 .
  • distribution module 102 organizes and arranges the call records into pools 128 . Based upon user inputs distribution module 102 assigns queues 130 to specific dialing devices in step 174 .
  • step 176 distribution module 102 checks to see if the selection rules are to be applied to pools 128 and queues 130 . If the selection rules are not to be applied, then the process continues in step 178 . If selection rules are to be applied, then in step 180 distribution module 102 determines if priority, percentage, or quota rules are applied to pools 128 . If priority rules are applied, then in step 182 distribution module 102 applies the priority rules to pools 128 and queues 130 and the process continues on to step 178 . If percentage rules are applied, then in step 184 distribution module 102 applies the percentage rules to pools 128 and queues 130 and the process continues in step 178 . If the quota rules are applied, then in step 186 distribution module 102 applies the quotas to pools 128 and queues 130 and the process continues to step 178 .
  • Distribution module 102 then delivers enough call records to queues 130 for dialing devices 108 to place telephone calls for fifteen, thirty, sixty minutes, or an appropriate amount of time to place calls in step 178 .
  • distribution module 102 locks the call records assigned to dialing devices 108 and creates a contingency file specific for each dialing device 108 in step 192 .
  • distribution module 102 transfers queues 130 containing the set number of call records to dialing devices 108 .
  • distribution module 102 uploads call record statistics from each queue 130 in step 196 .
  • Distribution module 102 may upload the call record statistics from queues 130 every few seconds, every few minutes, every hour, or any other appropriate interval of time.
  • Call record statistics include such information as how many call records remain to be called and the rate at which dialing devices 108 are depleting the call records in queues 130 .
  • distribution module 102 also uploads call attempt results. Call attempt results include whether a right party contact or wrong party contact was made or whether an answering machine was reached when dialing devices 108 place a telephone call.
  • step 202 distribution module 102 updates the contingency file with the call attempt results specific for dialing devices 108 .
  • step 204 distribution module 102 uses the call record statistics gathered in step 196 to analyze the number of call records remaining to be called and the depletion rate of the call records within queues 130 . Based upon the call attempt results, distribution module 102 re-presents to pools 128 call records where the first attempt to make a right party contact was unsuccessful so that the call record can be called later in the day in step 206 . In addition, the call record can be made unavailable for the remainder of the day if a right party contact was made.
  • distribution module 102 determines in step 208 if more call records need to be sent from pools 128 to queues 130 . If more call records are needed, then in step 210 distribution module 102 sends additional call records from pools 128 to queues 130 and the process repeats beginning with step 176 until manually stopped. But if distribution module 102 determines that no additional call records need to be sent from pools 128 to queues 130 in step 208 , then the process repeats beginning with step 196 until manually stopped or until there are no call records remaining to be called.
  • FIGS. 4a and 4b illustrate a flow diagram for the population of pools 128 and queues 130 with call records.
  • the call records in FIGS. 4a and 4b include scheduling information provided by scheduling module 122 .
  • step 222 the call records pass through scheduling module 122 from either dialing devices 108 or host 112 .
  • Scheduling module 122 adds call scheduling information to each call record as it passes through it.
  • scheduling module 122 transfers the call records containing call scheduling information to call record database 118 within distribution module 102 .
  • Distribution module 102 then arranges the call records into pools 128 in step 226 .
  • distribution module 102 examines each call record to determine how to extract the scheduling information, account number and telephone number from the call record.
  • distribution module 102 flags any call records where the scheduling information or telephone number is stripped from the end of the call record before placing it in the pools 128 .
  • distribution module 102 splits the call records into a plurality of pools 128 .
  • Each pool 128 holds the call record as a data string and the call records are in the same format within pools 128 .
  • distribution module 102 arranges the call records within pools 128 so that each call record is selectable by its account number.
  • the call scheduling information provided by scheduling module 122 allows for an optimum order to call the call records.
  • distribution module 102 uses the call scheduling information to create hourly indices for pools 128 in step 230 .
  • the hourly indices allow for pools 128 to take advantage of the fact that the call order and call priority of each call record changes based upon the time of day. For example, a call record might be scheduled to be the first call at 8:00 AM and if not successfully called at 8:00 AM then rescheduled to be the tenth call made at 6:00 PM.
  • Distribution module 102 creates an index for each hour for each pool 128 .
  • distribution module 102 In addition to the hourly indices, distribution module 102 also creates an immediate index and an overflow index.
  • the immediate index contains call records that are always the first to be called at the beginning of every hourly index.
  • the call records within the immediate index allow real time call record insertion based upon previous call attempts and are often call records that resulted in no contact when called the first time.
  • Call records contained in the overflow index are call records which were not scheduled to be called or call records that do not have call scheduling information.
  • distribution module 102 selects the call records contained in the immediate index. Distribution module 102 also removes any call records that are unavailable to be called and marks the call records as unavailable in step 236 .
  • distribution module 102 determines if it is ready to transfer the call records from pools 128 to queues 130 for this hour and if there are a sufficient number of call records to be transferred from the immediate index to allow for fifteen, thirty, sixty minutes, or an appropriate amount of time for calling. If there are sufficient call records, then in step 239 , distribution module 102 transfers the call records from the pool immediate index to queues 130 .
  • step 240 distribution module 102 selects call records from the appropriate hourly index. These additional call records in combination with call records from the immediate index will allow for fifteen, thirty, sixty minutes, or an appropriate amount of time for calling.
  • step 242 distribution module 102 removes any call records unavailable to be called and marks the call records as unavailable. Distribution module 102 then transfers the call records from the immediate index and the appropriate hourly index to queues 130 in step 239 .
  • step 244 distribution module 102 transfers queues 130 containing the call records to dialing devices 108 . After queues 130 are transferred to dialing devices 108 , in step 246 dialing devices 108 begin calling the call records.
  • distribution module 102 monitors dialing devices 108 and queues 130 for when it is time to send the next hourly index of call records from pools 128 to queues 130 in step 248 .
  • distribution module 102 cannot start morning hour queues before the actual hour of the hourly index and must stop evening hour queues before the hourly index hour expires. For instance, the pool morning hourly index for 10:00 AM cannot be sent from pools 128 to queues 130 before 10:00 AM and the evening hourly index for 7:00 PM must stop calling at 8:00 PM. This is in part to due to telemarketing regulations that regulate the times of day that telemarketing calls may be placed.
  • step 250 distribution module 102 selects the next hourly index to be called and begins the process of transferring the call records from the appropriate hourly index to queues 130 .
  • the process of selecting the next hourly index repeats steps 234 through 244 by first taking call records from the immediate index and adding call records from the appropriate hourly index as explained above.
  • step 248 distribution module 102 determines queue depth and the time to go in step 252 .
  • Queue depth is the amount of call records remaining to be called in the queue while time to go is the amount of time remaining in the hour for the hourly index.
  • step 254 if the depth is not too low and the time to go is not too short so that there are a sufficient amount of call records to call for the remaining time left in the hour, then additional call records are not needed in queue 130 . So in step 256 , the call attempt results regarding a right or wrong party contact are uploaded from dialing devices 108 and sent back to distribution module 102 in step 258 . The process then returns to step 234 of FIG. 4a to begin the next record search.
  • step 254 distribution module 102 determines that the depth is too low or the time to go is too short, then in step 260 distribution module 102 calculates the number of call records needed to finish out the hour for the hourly index.
  • step 262 distribution module 102 selects additional call records to call by repeating steps 234 through 239 above and transferring the call records from the pools 128 to queues 130 in step 264 so that dialing devices 108 do not sit idle but finish out the hour placing telephone calls. The process then returns to step 234 of FIG. 4a to begin the next record search.
  • FIG. 5 depicts a flow diagram of a method for goals based routing of contact records employing a meet-goals goal strategy.
  • the method begins at step 300 when goal module 103 selects a performance metric for each pool 128 , determines a goal for each pool 128 and prioritizes pools 128 relative to each other.
  • goals module 103 calculates a goal status for each pool 128 using the goal and performance metric for each pool 128 .
  • goal module 103 cycles through pools 128 in descending priority order at step 304 .
  • goal module 103 selects a target pool based on its priority. Goal module 103 selects a target pool by first selecting the pool 128 having the highest priority. Goal module 103 then determines the goal state from the goal status for the target pool to determine if the target pool is behind goal at step 308 . If the target pool is not behind goal, then at step 310 goal module 103 checks to see if there are additional pools 128 to cycle through. If there are not additional pools 128 to cycle through, then the process ends. But if there are additional pools 128 to cycle through at step 310 , then the process returns to step 306 where goal module 103 selects the pool 128 having the next highest priority to determine if that target pool is behind goal. If that target pool is not behind goal, then the process repeats until either goal module 103 locates a target pool that is behind goal at step 308 or the process ends because no target pools are behind goal.
  • goal module 103 cycles through donor pools from lowest to highest priority at step 312 .
  • the donor pools include all the other pools 128 except the target pool that was selected at step 308 .
  • goal module 103 selects a donor pool 128 having the lowest priority out of all the donor pools.
  • the goal module 103 determines if the selected donor pool is active and able to donate levels of effort to the target pool at step 316 .
  • a pool 128 is active when it is still transferring contact records to queues 130 and hasn't satisfied its final goal or quota.
  • Goal module 103 examines the routing table for the selected donor pool to determine if the donor pool is able to donate levels of effort to the target pool.
  • goal module 103 Since each pool 128 has its own routing table, goal module 103 must examine the routing table to determine if the donor pool is able to donate any levels of effort. Generally, if the selected donor pool is ahead of goal or at goal, it is able to donate a percentage of level of effort to the target pool regardless of the respective pool priorities. If the donor pool is behind goal but the target pool is of a higher priority, then generally the donor pool is available to donate some percentage of level of effort. If the donor pool is behind goal and the target pool is of the same priority or lower priority, then typically the donor pool is not able to donate any level of effort to the target pool.
  • goal module 103 transfers a percentage of the level of effort from the donor pool to the target pool.
  • Goal module 103 transfers the level of effort from the donor pool to the target pool by modifying the effort map in accordance with the limits specified in the routing table for the donor pool.
  • goal module 103 examines the routing table for the donor pool to determine how much level of effort may be donated from the donor pool to the target pool.
  • goal module 103 transfers 75% of the level of effort for the donor pool to the target pool. Therefore, if pool 128 a is the donor pool and pool 128 c is the target pool, goal module 103 transfers 75% of the level of effort for pool 128 a to pool 128 c thereby allowing queue 130 a to receive 25% of its contact records from pool 128 a and 75% of its contact records from pool 128 c instead of queue 130 a receiving 100% of its contact records from pool 128 a.
  • Pool 128 c now supplies contact records to queues 130 a and 130 d instead of just queue 130 d which allows additional agents 110 to access contact records from pool 128 c and thereby meet the goal for pool 128 c.
  • Goal module 103 then modifies the effort map to reflect this change in the levels of effort between pools 128 .
  • goal module 103 determines if there are additional donor pools to cycle through. If there are additional donor pools to cycle through, then the process returns to step 314 where goal module 103 selects the donor pool having the second lowest priority and the process repeats until there are no more donor pools to cycle through at step 320 . If at step 316 the donor pool is either not active or not able to donate a percentage of level of effort to the target pool, the process proceeds to step 320 where goal module 103 determines if there are additional donor pools to cycle through as described above.
  • step 320 goal module 103 determines that there are no more donor pools to cycle through, the process proceeds to step 310 where goal module 103 determines if there are any additional pools 128 to cycle through. If there are no more pools 128 , then the process ends. If there are additional pools, then the process returns to step 306 where goal module 103 selects the next pool 128 based on its priority to determine if it is behind its goal.
  • the method of FIG. 5 repeats until goal module 103 has checked every pool 128 from highest to lowest priority to see if pools 128 are behind goal. Therefore, the pools 128 having the highest priority are addressed first by goal module 103 ensuring that pools 128 having the highest priority shall achieve and/or maintain their goals by transferring levels of effort away from pools 128 having a lower priority to pools 128 having a higher priority.
  • FIG. 6 illustrates a flow diagram of a method for goals based routing of contact records employing an exceed-goals goal strategy.
  • the method begins at step 330 when goal module 103 selects a performance metric for each pool 128 , determines a goal for each pool 128 and prioritizes pools 128 relative to each other.
  • goal module 103 calculates a goal status for each pool 128 using the goal and performance metric for each pool 128 .
  • goal module 103 cycles through pools 128 in an ascending priority order at step 334 .
  • goal module 103 selects a target pool based on its priority. Goal module 103 selects a target pool by first selecting the pool 128 having the lowest priority. Goal module 103 then determines the goal state using the goal status for target pool to determine if target pool is behind goal at step 338 . If target pool is not behind goal, then at step 340 goal module 103 checks to see if there are additional pools 128 to cycle through. If there are no additional pools 128 to cycle through, the process ends. But if there are additional pools 128 to cycle through at step 340 , then the process returns to step 336 where goal module 103 selects the pool 128 having the next lowest priority to determine if that target pool is behind goal. If that target pool is not behind goal, then the process repeats until either goal module 103 locates a target pool that is behind goal at step 338 or the process ends because no target pools are behind goal.
  • goal module 103 cycles through recipient pools from highest to lowest priority at step 342 .
  • the recipient pools include all the other pools 128 except the target pool that was selected at step 336 .
  • goal module 103 selects a recipient pool having the highest priority out of all the recipient pools. Goal module 103 then determines if the selected recipient pool is active and ahead of its goal at step 346 .
  • a pool 128 is active when it is still transferring contact records to queues 130 and has not satisfied its final goal or quota.
  • goal module 103 transfers a percentage of the level of effort from the target pool to the recipient pool. After goal module 103 transfers the level of effort, at step 340 goal module 103 determines if there are additional pools 128 to cycle through. If there are no additional pools 128 to cycle through at step 340 , then the process ends. But if at step 340 there are additional pools 128 to cycle through, then the process returns to step 336 where goal module 103 selects the target pool having the next lowest priority.
  • step 346 the process proceeds to step 350 where goal module 103 determines if there are additional recipient pools to cycle through. If there are additional recipient pools to cycle through at step 350 , then the process returns to step 344 where goal module 103 selects a recipient pool having the next highest priority and the process repeats as described above.
  • step 350 there are no more recipient pools to cycle through, the process continues to step 352 .
  • the method only proceeds to step 352 after goal module 103 has examined all of the recipient pools to determine if the recipient pools are active and ahead of goal.
  • goal module 103 cycles through recipient pools from highest to lowest priority and at step 354 goal module 103 selects the recipient pool having the highest priority.
  • goal module 103 determines if the selected recipient pool is active and at goal. If the selected recipient pool is active and at goal, then at step 358 goal module 103 transfers a percentage of the level of effort from the target pool to the selected recipient pool.
  • step 340 goal module 103 determines if there are additional pools 128 to cycle through and the process either ends or returns to step 336 .
  • goal module 103 determines if there are additional recipient pools to cycle through. If there are not additional recipient pools to cycle through, then the process continues to step 340 where goal module 103 determines if there are additional pools 128 to cycle through as described above. If there are additional recipient pools to cycle through at step 360 , then the process returns to step 354 where goal module 103 selects the next recipient pool having the next highest priority and the process repeats as described above.
  • the method of FIG. 6 repeats until goal module 103 has checked every pool 128 from lowest to highest priority to see if pools 128 are behind goal. Therefore, the pools 128 having the lowest priority are examined first to determine if they are able to donate a percentage of level of effort to pools 128 having higher priority so that the pools 128 having the highest priority exceed their goals.
  • the present invention applies to the different types of contacts records and devices listed above and manages other types of customer contact requests such as inbound calls, email, Internet chat, online requests for live chat in addition to outbound call records.

Landscapes

  • Business, Economics & Management (AREA)
  • Marketing (AREA)
  • Engineering & Computer Science (AREA)
  • Signal Processing (AREA)
  • Telephonic Communication Services (AREA)

Abstract

A method and system is provided for common account based distribution of contact records. A comparison engine analyzes call record accounts to identify and tag related call records, such as call record accounts related to the same individual. A common account tag detector detects related accounts and communicates with a common account controller of a distribution module that distributes contact attempts in pools and queues. The common account controller locates related accounts, such as by searching for accounts having the same tag, to prevent additional contact attempts to the individual associated with the related accounts. The related accounts are forwarded to the operator who made the successful contact to coordinate resolution of the related accounts along with the account that originated the contact attempt.

Description

RELATED PATENT APPLICATION
This application is a continuation of application Ser. No. 10/456,575, filed on Jun. 6, 2003, entitled “System and Method for Common Account Based Routing of Contact Records,” now U.S. Pat. No. 7,054,434, issued May 30, 2006, which is a continuation-in-part of application Ser. No. 10/095,513, filed Mar. 12, 2001, now U.S. Pat. No. 7,103,173, issued Sep. 5, 2006, which is a continuation-in-part of application Ser. No. 09/901,749, filed Jul. 9, 2001, now U.S. Pat. No. 7,142,662, issued Nov. 28, 2006, all of which are incorporated herein by reference in their entireties.
TECHNICAL FIELD OF THE INVENTION
This invention relates to the field of telephony, computer networks, and customer relationship management, and more particularly to a system and method for common account based routing of contact records.
BACKGROUND OF THE INVENTION
Customer contact centers represent the front line for customer service, marketing operations, and debt collection for many businesses. Typical centers receive or make hundreds of telephone calls, emails, and Internet chat requests per day with the aid of automated telephony and Internet equipment. For instance, predictive dialers such as the MOSAIX Predictive Dialing System (“PDS”) manufactured by Avaya Incorporated automatically dial outbound telephone calls to contact individuals and then transfer the contacted individuals to agents so the agent can talk with the individual.
Devices such as dialing devices, email servers, chat servers, VoIP servers, telephony servers, and web servers allow agents to save time in contacting customers and receiving requests from customers. Dialing devices such as predictive dialers save time for the agent placing the call because the dialing device and not the agent dials the telephone number and agents' time is not wasted with unanswered calls or answering machines. Predictive dialers also spread the outbound telephone calls evenly among all the agents working from the dialing device so that the agents share the workload equally and no agents sit idle while others have too many telephone calls to place. Predictive dialers are also a significant component of customer relationship management (CRM) systems which extend the efficiency gained from predictive dialers to other contact channels such as email and live Internet chat.
Many businesses are increasing their marketing efforts, customer service programs, and bad debt collection efforts by having multiple customer contact centers or call centers or multiple devices located at a single site to serve more customers. Typically, when businesses have multiple sites, the centers are located in different geographic locations which makes coordination of customer contact strategies difficult.
Thus businesses generally manage call centers individually, with separate staffing, calling strategies, goals, and functions. Generally, a contact list is divided into as many parts as there are call centers or dialers with each call center receiving its own section of the calling list. Although this segmentation distributes work, coordination of strategy for outbound calling is difficult since each call center is responsible for its own section of the calling list and has no knowledge of the other call centers' progression with their own calling lists. For instance, if a call center goes down and cannot make outbound telephone calls, the other call centers cannot typically address the downed call center's calling list goals and priorities because the other call centers do not have access to the calling list including the telephone numbers actually called.
A similar problem occurs with a single call center having multiple CRM systems having multiple devices. Work load segmentation typically occurs at a host level, where each device is assigned a portion of the work load. A host downloads the segmented contact list to the individual dialing devices. If one device fails, the other devices do not know the status of the contacts in the failed device's segment.
Difficulties also arise in the routing of outbound calls, call records, or contact records to the agents in a single calling center or multiple calling centers. Typically when routing calls, a call center employs categorization and prioritization routing or load leveling routing. With categorization and prioritization routing, the calls are categorized and prioritized before being sent to the call centers. All of the available call records are organized into distinct groups or pools and each pool of call records is prioritized according to a particular prioritizing scheme. A typical scheme often used at contact centers is to prioritize the inbound calls with the highest priority, live Internet chats second, outbound calls third, and email or other requests last. The agents are segregated into distinct teams and each team receives call records from a particular pool based on the prioritization of the call records.
Load leveling routing of call records allows multiple agent teams to work on the same group or pools of records whether the agents are located in the same call center or if the agents are located across multiple call centers. Load leveling routing eliminates the restriction of categorization and prioritization that requires distinct groups of records for agents not working from the same dialing device. This allows for the movement of call records between the agents and call centers.
However, none of the above call record routing techniques adjusts the agent and pool workload based on the performance or the performance goals of the call record pools. Generally, if a call record pool is not maintaining a desired performance, manual intervention by a system administrator is required to adjust for the under performing call record pool. In order to address the under performing call record pool, agents must move from one team to another in order to have the ability to access call records from the under performing pool and thereby improve the call record pool performance. But this is a slow process that typically results in agent and call center downtime and often cannot be made quickly enough to respond to current call record pool performance.
In addition, such manual intervention decisions to correct under performing call records pools typically require guess work and making decisions without considering all the available options and the effect on the other call record pools. The system administrator must guess as to the effects on the other call record pools when agents are moved from pools maintaining or achieving performance requirements to under performing pools. If agent moves are made incorrectly, then additional pools may start under performing due to the agents that were moved to the under performing pool. Therefore the performance of the call record pools requires constant supervision to ensure that by the end of the calling day the performance requirements for the highest priority pools are satisfied.
Another difficulty with attempts to coordinate calling campaigns across multiple contact device dialers and/or multiple contact calling centers is that a single individual sometimes has multiple accounts that result in multiple contact attempts to the individual for each account. For instance, an individual may have call records for a delinquent account, a marketing account for new sales and a service quality inquiry. As another example, a calling center may have contracts with multiple businesses to contact each business' delinquent accounts and the delinquent accounts of two or more businesses may share common individuals who are delinquent. In such instances, multiple call centers may simultaneously contact or attempt to contact the same individual for the different accounts. An individual targeted by multiple calling centers is more likely to feel harassed and less likely to cooperate or even respond to the call center inquiries. Multiple attempts to contact the same individual by different call centers result in greater outbound call volume and less effective use of outbound calling capacity.
SUMMARY OF THE INVENTION
Therefore, a need has arisen for a system and method that distributes contact records based on the performance of the pools of contact records.
A further need has arisen for a system and method that automatically monitors the performance of the pools and automatically adjusts the distribution of contact records based on the performance of the pools.
A further need exists for a system and method which coordinates contact attempts for related but separate contact record accounts.
In accordance with the present invention, a system and method for distributing contact records utilizing goals based routing is provided which substantially eliminates or reduces disadvantages and problems associated with previously developed systems and methods for distributing contact records. A goal module monitors the performance of one or more pools of contact records and automatically modifies the distribution of the contact records from the pools based on the performance of each pool.
In accordance with one aspect of the present invention, distribution of contact records utilizing goals based routing is accomplished by a distribution module interfaced with a plurality of devices. The distribution module includes a plurality of pools and a plurality of queues. The distribution module places contact records into the pools, transfers less than all of the contact records to the queues from the pools, and transfers the queues to the devices. Associated with the distribution module is a goal module. The goal module monitors the performance of each pool and modifies which queues the pools transfer contact records to based upon the performance of the pools.
In one embodiment, the goal module defines one or more levels of effort for each queue. The levels of effort determine the percentage of contact records that transfers from a pool to a particular queue. The goal module also determines a goal for each pool that reflects the performance of the pool and prioritizes the pools relative to each other. As the agents access the contact records from the queues, the goal module monitors the performance of the pools by calculating a goal status for each pool. The goal module uses the goal status to determine a goal state for each pool. The goal state indicates whether a pool is satisfying the goal. Based upon the goal states for each pool, the goal module modifies which queues the pools transfer contact records to by transferring the levels of effort between the pools and the queues.
In an alternate embodiment, the goal states and one or more goal strategies allow for the optimization of the transfer of contact records from the pools to the queues and determine how the goal module modifies which queues the pools transfer contact records to. The goal strategies control how levels of effort between the pools and queues are transferred when a pool is not satisfying the goal. A goal strategy may require the transfer of levels of effort to pools not satisfying their goals or the transfer of levels of effort away from pools not satisfying the goal. The goal module transfers levels of effort in accordance with the goal strategies so that pools having the highest priority maintain or achieve the goals throughout the day.
In another alternative embodiment, related call records are identified and marked with a relationship tag to coordinate actions for multiple related accounts before a contact attempt is made. This relationship tag may be applied in real-time before a call record is prepared for distribution or when a list of callable records is loaded into the system. A comparison engine analyzes the call records database of one or more call distribution modules to identify and tag related call record accounts, such as call record accounts that are related to a common individual. A common account tag detector associated with each contact device detects an individual relation tag associated with all similarly tagged call records and, before a contact attempt to the individual is made, communicates the relationship tag and related account information to the call distribution module. A common account controller of the call distribution module places a hold on other accounts related to the individual by placing a hold on call records having the relationship tag to prevent the placement of multiple calls to the individual once a call has been initiated. The common account controller routes the related account information (through the feed to the dialing device) to the operator handling the successful contact with the individual to allow simultaneous resolution of the related account call records through the single successful contact.
The present invention provides a number of important technical advantages. One important technical advantage is the distribution of contact records based on the performance of the pools. The ability to distribute contact records based on the performance of the pools of contact records allows a call center to operate more efficiently because the call center recognizes when a pool is not sufficiently performing and redistributes the contact record workload to allow for more efficient operation thereby allowing higher priority pools to satisfy performance requirements.
Another important technical advantage of the present invention is the distribution of contact records based on the performance of the pools without manual intervention. The goal module monitors the performance of each pool and determines whether a pool is ahead, at, or behind the goal. When a pool is not satisfying a goal, the goal module automatically takes action to modify how the pools transfer contact records to so that the highest priority pools achieve or maintain the goals. Therefore, no manual intervention is required and pools are not adversely affected by the changes. In addition, because no manual intervention is required, there is reduced agent or device downtime when the goal module distributes the contact records based upon the performance of the pools.
Another important technical advantage of the present invention is the ability to quickly respond to current pool performance levels. Because the goal module constantly monitors the performance of the pools, the goal module may instantly react to any change in the performance of the pools throughout the day. And because the goal module monitors the performance of all the pools and has the goal states for every pool, when the goal module modifies the distribution of contact records, the goal module takes into account the effects of the modification on the goals for all of the pools so that the highest priority pools achieve or maintain the goals. Therefore, the guess work in distributing contact records based on the performance of the pools is reduced and there are no unexpected results at the end of the day.
Another important technical advantage of the present invention is that multiple related call record accounts are handled through a single successful contact attempt. The related account call records are identified and tagged in a predetermined field or database column so that contact devices are able to record a successful contact attempt to all call records. The call distribution device common account controller leverages the successful contact to handle multiple call record accounts related to the same individual without undue delay in transferring the related account information to the contact operator. This reduces outbound call volume by eliminating multiple calls to the same individual and more effectively uses outbound calling resources to improve the distribution of resources across related and unrelated accounts. Further, by handling multiple call record accounts in a single call to an individual, an operator has greater leverage in resolving business issues with the individual. For instance, an operator generally has greater bargaining power when dealing with an individual over multiple delinquent accounts than a single delinquent account.
BRIEF DESCRIPTION OF THE DRAWINGS
For a more complete understanding of the present invention and the advantages thereof, reference is now made to the following description taken in conjunction with the accompanying drawings in which like reference numbers indicate like features, and wherein:
FIG. 1 depicts a block diagram of plural dialing devices interfaced with a distribution module;
FIG. 2 illustrates a block diagram of another embodiment of the present invention employing two distribution modules having common account controllers;
FIG. 3 depicts a flow diagram of a method for distribution outbound telephone calls;
FIGS. 4a and 4b illustrate a flow diagram for the population of the pools and queues with call records;
FIG. 5 depicts a flow diagram of a method for goals based routing of contact records employing a meet-goals goal strategy; and
FIG. 6 illustrates a flow diagram of a method for goals based routing of contact records employing an exceed-goals goal strategy.
DETAILED DESCRIPTION OF THE INVENTION
Preferred embodiments of the present invention are illustrated in the figures, like numeral being used to refer like and corresponding parts of the various drawings.
Under previous systems and methods for routing contact records, the redistribution of contact records among the devices and agents based upon the performance of the of the different pools of contact records required manual intervention often involving guesswork as to the effects of performance based changes, the shutting down of the devices, starting a new job on the device, or moving agents between the devices. The goal module of the present invention allows for the routing of contact records across one or more than one device based on the performance of the individual pools of contact records quickly and without manual intervention. The goals based routing of contact records allows for dynamically modifying the distribution of contact records based on the performance of the pools of contact records throughout the day without manual intervention, down time, and guesswork.
The present invention allows for the routing and distribution of contact records among a plurality of devices and agents based upon the performance of the different pools of contact records. Contact records include such customer contacts as outbound telephone calls, inbound telephone calls, call records, emails, Internet chat requests, online chat requests, and any other appropriate form of customer contact. Devices include such call center or contact center devices as dialing devices including predictive dialers, email servers, Internet chat servers, VoIP servers, telephony servers, web servers, and any other appropriate call center or contact center devices. In the figures below, reference is made to call records and dialing devices but the present invention equally applies to the other types of contact records and devices listed above.
FIG. 1 depicts a block diagram for an outbound distribution system 100 for distributing outbound telephone calls employing goals based routing. A distribution module 102 interfaces with a first call center 104a and a second call center 104n. System 100 allows call centers 104a and 104n to operate as a single group of resources rather than two decentralized units, with distribution module 102 controlling the strategy, workload, and calling efforts for call centers 104 from a single, central location. In alternative embodiments, distribution module 102 interfaces with multiple dialing devices at one or more call centers, or one dialing device located in one call center.
Call centers 104 are geographically distributed, each having one or more dialing devices that place telephone calls using information in the call records. Distribution module 102 operates on a SOLARIS, Linux, or an any other appropriate operating system server and communicates with call centers 104 via standardized communications links such as Ethernet, the Internet with protocols such as FTP, CORBA, API, and sockets over TCP/IP, asynchronous transfer mode (“ATM”), or any other appropriate communication link.
Call centers 104 each have one or more dialing devices 108. Dialing devices 108 are predictive dialers such as the MOSAIX PDS manufactured by Avaya Incorporated or other appropriate predictive dialers. In the embodiment shown in FIG. 1, interfaced to dialing device 108a in call center 104a are three agents 110a, 110b, and 110c with dialing device 108n of call center 104n also having three agents 110d, 110e, and 110f interfaced to it. Agents 110 are workstations where operators or agents speak to the individuals, chat with individuals online, complete emails to, or otherwise contact individuals who are contacted by dialing devices 108.
Dialing device 108 dials telephone numbers extracted from the call records. If an individual answers the telephone, dialing device 108 transfers the telephone call to one of agents 110 so that the agent can speak with the individual. Dialing devices 108 therefore improve telephone calling efficiency by dialing the telephone number and transferring the call to an agent only if an individual answers the telephone.
System 100 functions by first having distribution module 102 acquire the call records that dialing devices 108 will call. There are several different ways that distribution module 102 acquires the call records.
For instance, host 112, which is associated with dialing devices 108, stores raw call records. The raw call records contain information including telephone number, account number, individual name and address, and any other appropriate personal information. For example, a raw call record for Joe Smith includes Joe Smith's telephone number, mailing address, account status, account number, account passwords, gender, marital status, number of children, employment status, and yearly income.
Host 112 transfers the raw call records for that day along path 114a to call center 104a and dialing device 108a and along path 114b to call center 104n and dialing device 108n. Distribution module 102 contacts dialing device 108a within call center 104a via path 116a and dialing device 108n within call center 104n via path 116b. Distribution module 102 downloads from dialing devices 108 to call record database 118 the call records. The call records may contain some but not all of the information from the raw call records. Downloading less than all of the information from the raw call records saves bandwidth and allows for efficient operation of distribution module 102 because it handles smaller amounts of data. For instance, distribution module 102 downloads as the call record an individual's name, telephone number, and account number. So the call record for Joe Smith contains Joe Smith's name, his telephone number, and account number.
In an alternative embodiment, host 112 stores the raw call records. Instead of transferring the raw call records to dialing devices 108, distribution module 102 downloads the call records from host 112 to call record database 118 via path 120.
Alternatively, dialing devices 108 store the raw call records. Therefore, distribution module 102 contacts call center 104a and dialing device 108a via path 116a and call center 104n and dialing device 108n via path 116b to download the call records to call record database 118.
Scheduling module 122 operates to develop and provide optimal calling strategies for the call records including resource optimization, automated statistical modeling and flexible strategy management. For instance, one such scheduling module 122 is described in U.S. Pat. No. 5,802,161, entitled “Method and System for Optimized Scheduling” issued Sep. 1, 1998, and is hereby incorporated by reference.
The integration of scheduling module 122 is not required for the operation of distribution module 102 but it affects how distribution module 102 downloads the call records and what information is contained in the call records. For instance, host 112 transfers the raw call records to call center 104a and dialing device 108a via path 114a and call center 104n and dialing device 108n via path 114b. Scheduling module 122 downloads from dialing device 108a in call center 104a via path 124a and from dialing device 108n in call center 104n via path 124b the raw call records. Scheduling module 122 develops call schedules for the raw call records. Distribution module 102 downloads the call records including the call schedule from scheduling module 122 via path 124c and stores the call records in call record database 118.
Alternative embodiments also employ scheduling module 122 in the delivery of call records to distribution module 102. Scheduling module 122 downloads the raw call records from host 112 via path 126. As before, scheduling module 122 adds call schedules to the raw call records before distribution module 102 downloads the call records from scheduling module 122 via path 124c to call record database 118.
Once distribution module 102 stores the call records in call record database 118, distribution module 102 organizes and transfers the call records from call record database 118 to pools 128, which are interfaced with distribution module 102. The pools are sets of callable call records specified by distribution module 102. Each pool 128 represents a specific and ordered group of call records. In the embodiment shown in FIG. 1, there are three pools 128a, 128b, and 128c. In alternative embodiments there can be more than three or less than three pools.
Distribution module 102 then transfers less than all of the call records from pools 128 to queues 130. Interfaced with pools 128 are queues 130a, 130b, 130c, and 130d. A queue is a set of rules for selecting call records from pools having the necessary and sufficient information describing the exact method of transferring call records to dialing devices 108 and any call records assigned to but not yet transferred to dialing devices 108 for dialing devices 108 to call. Distribution module 102 attaches each queue 130 to a particular dialing device 108 and monitors each dialing device. As necessary, distribution module 102 transfers call records from pools 128 in accordance with the configuration of queues 130 which includes selection rules, time of day, time of week, number of calls completed, and number of call records sent. Queues 130 then transfer the call records to their assigned dialing devices 108. For instance, distribution module 102 transfers call records according to the configuration of queues 130a and 130b to dialing device 108a of call center 104a and according to the configuration of queues 130c and 130d to dialing device 108n of call center 104n.
In addition, each queue 130 is associated with a single campaign for the dialing device to which it is assigned. A campaign is an outbound job calling on dialing device 108 that can receive additional call records for calling while the outbound calling job is active. Normally, a campaign on dialing device 108 continues to run until manually stopped or when it runs out of call records to dial.
Pools 128 can satisfy transfer requests for call records for one or more than one queue 130. For example, pool 128a transfers call records to queue 130a, pool 128b transfers call records to queues 130b and 130c, and pool 128c transfers call records to queue 130d. In addition, distribution module 102 can change the queues which request call records from pools 128 throughout the day and in the middle of outbound calling campaigns. For instance, if dialing device 108n located in call center 104n calls all the call records in pool 128c, then distribution module 102 can request that pools 128a and 128b transfer call records to queue 130d.
Distribution module 102 transfers the call records to pools 128, transfers less than all of the call records from pools 128 to queues 130, and transfers queues 130 to dialing devices 108 before dialing devices 108 begin their daily calling routines. At the beginning of the day, distribution module 102 transfers enough call records from pools 128 to queues 130 to allow for dialing devices 108 to place calls for fifteen, thirty, sixty minutes, or an appropriate amount of time to place calls. Distribution module 102 monitors the calls placed by dialing devices 108 as well as the number of call records remaining to be called to determine how busy dialing devices 108 are and when and how many additional call records to transfer from pools 128 to queues 130. The monitoring of queues 130 and the transferring of additional call records from pools 128 to queues 130 allows for real-time movement of call records from distribution module 102 to dialing devices 108 throughout the day. For instance, as soon as dialing device 108a is about to finish calling the call records in the campaign assigned to queue 130a, distribution module 102 transfers additional call records from pool 128a to queue 130a so that dialing device 108a maintains a steady and level flow of work.
Dialing devices 108 also track the call attempt results of every call placed by dialing devices 108. The call attempt results include whether or not a call resulted in a right party contact, a wrong party contact, no answer, or an answering machine. For example, the objective of a call record for Joe Smith is to talk with Joe Smith. If agent 110 speaks with Joe Smith, that is a right party contact and a successful call attempt result. If Joe's babysitter answers the phone and Joe is not home, that is a wrong party contact and an unsuccessful call attempt result. If no one answers the phone or an answering machine answers the phone, that is an unsuccessful call attempt result since the desired party was not contacted. Therefore throughout the day, distribution module 102 queries dialing devices 108 for call attempt results and uploads the call attempts results. If a call attempt result is unsuccessful, then distribution module 102 updates the call record in pools 128 so that a dialing device 108 may call the call record again at a later time in the day.
An advantage to system 100 is that distribution module 102 controls the transfer of the call records which results in a level work flow for dialing devices 108. To enable better work flow control, queues 130 include selection rules that determine how distribution module 102 transfers call records from pools 128 to queues 130. The selection rules allow for the optimization of the transfer of call records from pools 128 to queues 130 and include priority rules, percentage rules, quotas, queuing theory rules, or any other appropriate rules for optimizing the transfer of call records from pools 128 to queues 130. The selection rules can be modified on an as needed basis.
Priority rules result in distribution module 102 transferring call records from pools 128 to queues 130 based upon an assigned priority for each pool 128. For example, queue 130a receives call records from pools 128a and 128b with pool 128a having priority over pool 128b. Queue 130b receives call records from pools 128a and 128b with pool 128b having priority over pool 128a. Assume that pool 128a arrives at 8:00 AM while pool 128b arrives at 9:00 AM. Initially, both queues 130a and 130b receive call records from pool 128a. At 9:00 AM when pool 128b arrives, queue 130a continues to receive call records from pool 128a while queue 130b receives call records from pool 128b.
Percentage rules result in distribution module 102 simultaneously transferring call records from pools 128 to queues 130. For example, queue 130c has a percentage configuration with pools 128b and 128c and queue 130d has a percentage configuration with pools 128b and 128c. In this configuration, queue 130c and 130d receive call records simultaneously from pools 128b and 128c. With pool 128b arriving at 8:00 AM and pool 128c arriving at 9:00 AM, at 8:00 AM both queues 130c and 130d receive call records from pool 128b. At 9:00 AM, queues 130c and 130d alternatively receive call records from pools 128b and 128c. The percentages are variable for instance so that queue 130c receives 80% of its call records from pool 128b and 20% of its call records from pool 128c while queue 130d receives 60% of its call records from pool 128b and 40% of its call records from pool 128c.
The selection rules can also incorporate the execution of an optimization module which will determine the optimal mix of call records from each of the available pools 128 based on the optimization constraints and the number of call records needed at the current time.
The selection rules can also incorporate pool quotas which are limits set on each pool controlling a maximum activity level such as number of records transferred, number of successful call attempts, and other appropriate indicators of call record activity. When distribution module 102 transfers call records to pools 128, distribution module 102 can also set quotas on how many call records dialing devices 108 will call from pools 128. In the percentage rule example above, distribution module 102 can place a quota on pool 128b. When dialing devices 108 satisfy the quota for pool 128b, queues 130c and 130d no longer receive call records from pool 128b and only receive call records from pool 128c.
The selection rules can also be a combination of the percentage rules and the priority rules. For example, queue 130b receives call records from all three pools 128a, 128b, and 128c. Queue 130b receives call records from pool 128b until dialing device 108a calls all the call records in pool 128b. At that time, queue 130b then alternately receives call records from pools 128a and 128c. As with the percentage rules above, queue 130b can receive call records from pools 128a and 128c in any percentage breakdown. Therefore, pool 128b has priority over pools 128a and 128c while pools 128a and 128c transfer call records using percentage rules.
In addition, these selection rules allow for skills-based routing between pools 128. For example, distribution module 102 allows pool 128a to initially transfer call records to queue 130a and pool 128c to initially transfer call records to queue 130d. If pool 128c becomes depleted and has no more call records to transfer to queue 130d, then pool 128a can begin transferring call records to both queues 130a and 130d. This allows distribution module 102 to transfer call records for easy to moderate difficulty customers to the best agents while the less skilled agents work the more difficult customers. And once the easy to moderate difficulty customers call records are depleted, the best agents can begin working the more difficult customer call records.
In addition, distribution module 102 may also route call records to dialing devices 108 and agents 110 based on the performance of pools 128. Routing the call records based on the performance of pools 128 allows distribution module 102 to make modifications so that pools 128 having a higher priority are not under-performing. Goal module 103, associated with distribution module 102 and pools 128, monitors the performance of pools 128. To monitor the performance of pools 128, either a user of system 100 or goal module 103 defines a performance metric for each pool 128. Once the performance metric is defined, goal module 103 applies the performance metric to pools 128. The performance metric is what goal module 103 uses to measure the performance of pools 128. For example, the performance metric for pool 128a may be the number of right party contacts while the performance metric for pool 128b is the number of accounts attempts and the performance metric for pool 128c is the number of call records attempted. Each pool 128 may have a different performance metric or pools 128 may have the same performance metric. In addition, each of the pools 128 may have more than one performance metric. For instance, pool 128a may have both a performance metric for the number of right party contacts and for the number of total accounts attempted.
Once goal module 103 has determined a performance metric for each pool 128, goal module 103 defines a goal for each pool 128. The goal can be either an absolute goal or a goal set relative to all the other pools 128. An absolute goal is a goal tied solely to the performance of the particular pool 128 while a relative goal is tied to the performance of all pools 128. In addition, the goal is related to the selected performance metric. For instance, pool 128a having a performance metric of number of right party contacts may have a goal of fifty right party contacts while pool 128c having a performance metric of number of call records attempted has a goal of one hundred call records attempted.
If a pool 128 has more than one performance metric, then the pool 128 will have a goal for each performance metric. For example, if pool 128a has a performance metric for number of right party contacts and for total number of accounts attempted, pool 128a may have a goal of 80 right party contacts and 200 accounts attempted. In addition, a pool 128 may also have a combination of goals where there pool 128 only needs to satisfy one of the goals. For instance, pool 128b may have a goal of 75 right party contacts or 200 accounts attempted and as long as pool 128b has at least 75 right party contacts or 200 accounts attempted, pool 128b is considered to be satisfying its goal and experiencing satisfactory performance.
The goals may also be end of day goals, mid-day goals, and rate based goals. End of day goals are goals calculated based on the performance of a pool 128 at the end of the day and include such goals as total number of call records attempted and number of right party contacts. Mid-day goals are similar to end of day goals but are calculated based on the time of day. For example, pool 128a may have a mid-day goal of twenty-five right party contacts by noon. Rate based goals are calculated as a rate of the total calls. For instance, if pool 128a has a performance metric of right party contact rate, a rate based goal may be 15% of all the call records from pool 128a should result in a right party contact.
Similar to the selection rules, goal module 103 defines or constrains levels of effort for each queue 130. The levels of effort detail the percentage of call records that transfer from a particular pool 128 to a particular queue 130. The levels of effort are stored in an effort map associated with goal module 103. Table 1 shows an example effort map for system 100. An examination of the effort map shown in Table 1 reveals that queue 1 (queue 130a) has a level of effort of 100% to pool 1 (pool 128a) meaning queue 130a receives all of its call records from pool 128a. Queue 2 (queue 130b) has a level of effort of 100% to pool 2 (pool 128b) meaning queue 130b receives 100% of its call records from pool 128b. Queue 3 (queue 130c) has a level of effort of 100% to pool 2 (pool 128b) meaning queue 130c receives 100% of its call records from pool 128b. Queue 4 (queue 130d) has a level of effort of 100% to pool 3 (pool 128c) meaning that queue 130d receives 100% of its call records from pool 128c. Therefore, 100% of the call records in pool 128a transfer to queue 130a, the call records in pool 128b transfer equally to queues 130b and 130c, and 100% of the call records in pool 128c transfer to queue 130d.
TABLE 1
Example Effort Map
Pool
1 Pool 2 Pool 3
Queue 1 100%   0% 0%
Queue
2 0% 100% 0%
Queue
3 0% 100% 0%
Queue
4 0%  0% 100% 
As pools 128 begin to transfer call records to queues 130 and agents 110 access the call records, goal module 103 calculates a goal status for each pool 128. The goal status can be defined as either the absolute difference between the actual metric and the goal or the percentage that a pool 128 is either ahead or behind its goal. For instance, if each pool 128 has a goal of fifty right party contacts and pool 128a has forty-five right party contacts, pool 128b has forty-eight right party contracts, and pool 128c has sixty right party contacts, then pool 128a has a goal status of −10%, pool 128b has a goal status of −4%, and pool 128c has a goal status of +20% for percentage based goals. Pool 128a has a goal status of −5, pool 128b has a goal status of −2 and pool 128c has a goal status of +10 for absolute difference based goals.
Goal module 103 uses the goal status for each pool 128 to determine a goal state for each pool 128. Pools 128 will have a goal state for each goal. An example definition of goals states would include the designation of ahead of goal, at goal, or behind goal. Goal module 103 or a user of system of 100 determines what thresholds define each of the available goal states. For example, if the goal states have been defined as ahead of goal, at goal, or behind goal, then a goal status of +10% and above may be ahead of goal, a goal status between +10% and −5% may be at goal, and a goal status of −5% and below may be behind goal. Given these threshold percentages and the goal status for pools 128, pool 128a has a goal state of behind goal (−10%), pool 128b has a goal state of at goal (−4%), and pool 128c has a goal state of ahead of goal (+20%). Any pool 128 that has a goal state of behind goal is said to be an under-performing pool and therefore experience unsatisfactory performance.
Similar to the pool quotas described above, goal module 103 also identifies and defines a final goal for each pool 128. A user of system 100 may also define the final goals for each of the pools 128. When a pool 128 satisfies its final goal, that pool 128 is no longer active and all the queues 130 that were receiving call records from that pool 128 now receive call records from the other pools 128 that have not satisfied their final goals. For instance, pool 128a-128c each have a final goal of eighty right party contacts. At 3:00 PM, pool 128a achieves eighty right party contacts. Because pool 128a has achieved its final goal, it becomes inactive and the call records from pool 128a are no longer transferred to queue 130a. To prevent queue 130a and agents 110 who access call records from queue 130a from becoming inactive, goal module 103 modifies which queues 130 pools 128b and 128c transfer call records to by allowing pools 128b and 128c to transfer call records to queue 130a. Since pools 128b and 128c have not reached their final goals, they are still active and queues 130 and agents 110 who were receiving call records from pool 128a now receive call records from pools 128b and 128c.
Before distribution module 102 begins to transfer queues 130 containing the call records to dialing devices 108, goal module 103 prioritizes pools 128 relative to each other. Certain pools 128 may contain call records that are of a higher priority than other pools 128. For example, pool 128a may contain call records for customers who have previously purchased products, pool 128b may contain call records for customers who have never purchased products, and pool 128c may contain call records for customers who are delinquent in paying for products previously purchased. Since a company's highest priority may be to collect the money it is owed, goal module 103 rates pool 128c with the highest priority while pool 128a has the second highest priority since it contains call records for customers with whom there is a previous relationship. Pool 128b has the lowest priority since it contains call records for potential customers. The prioritization of pools 128 enables goal module 103 to adjust the workload of agents 110 so that pools 128 having the highest priority achieve and maintain their goals throughout the day.
Goal module 103 modifies the distribution of call records using the goals of pools 128 by modifying which queues 130 pools 128 transfer call records to based on the performance and prioritization of pools 128. Goal module 103 modifies which queues 130 pools 128 transfer call records to by adjusting or transferring the levels of effort between pools 128 and queues 130. For example, pool 128a is of a higher priority than pool 128c and pool 128a is behind goal. Using the effort map shown in Table 1, queue 130a receives 100% of its call records from pool 128a and queue 130d receives 100% of its call records from pool 128c. Since pool 128a is of a higher priority, goal module 103 transfers level of effort from pool 128c to pool 128a so that queue 130d receives 50% of its call records from pool 128c and 50% of its call records from pool 128a while queue 130a still receives 100% of its call records from pool 128a. The example effort map shown in Table 2 illustrates which queues 130 pools 128 supply call records to after goal module 103 modifies the distribution of call records. Transferring some of the level of effort from pool 128c to pool 128a allows agents 110 who work queue 130d to work call records from pool 128a and thereby increase the number of agents 110 accessing call records from pool 128a so that pool 128a may satisfy its goal.
TABLE 2
Example Effort Map
Pool
1 Pool 2 Pool 3
Queue 1 100%   0% 0%
Queue
2 0% 100% 0%
Queue
3 0% 100% 0%
Queue
4 50%   0% 50% 
To aid in the distribution of call records based on the performance of pools 128, goal module 103 employs one or more goal strategies. The goal strategies allow for the optimization of the transfer of call records from pools 128 to queues 130 and help to determine how goal module 103 transfers the levels of effort between pools 128 and queues 130. There are different goal strategies that goal module 103 may implement when distributing the call records based on the performance of pools 128. Goal module 103 may automatically select the goal strategy based upon the call records or a user of system of 100 may select an appropriate goal strategy.
One goal strategy is a meet-goals strategy. With the meet-goals strategy, goal module 103 transfers levels of effort to pools 128 that are not meeting their goals (a goal state of behind goal) and therefore are experiencing unsatisfactory performance. For example, if pool 128a is behind goal and pool 128b is ahead of goal, goal module 103 transfers levels of effort from pool 128b to pool 128a so that queues 130b and 130c also receive call records from pool 128a. A number of right party contacts performance metric is a performance metric that might be managed with the meet-goals goal strategy.
Another goal strategy is an exceed-goals strategy. With the exceed-goals strategy, goal module 103 transfers levels of effort away from pools 128 that are not meeting their goals (a goal state of behind goal) and therefore have unsatisfactory performance. For instance, if pool 128b is behind goal and pool 128c is at goal, goal module 103 transfers levels of effort from pool 128b to pool 128c so that queues 130b and 130c begin to receive call records from pool 128c. A right party contact rate performance metric is a performance metric that might be managed using the exceed-goals goal strategy.
To insure that lower priority pools 128 do not become neglected when goal module 103 routes call records based on the performance of pools 128, goal module 103 sets preemptive limits on how much level of effort may be transferred away from pools 128. These preemptive limits are stored in routing tables of which each pool 128 has its own routing table stored in goal module 103. An exemplary routing table for pool 128a is shown in Table 3. In the example routing table of Table 3, if pool 128a is ahead of goal, then pool 128a is willing to forego 75% of its total level of effort to pools 128 that are at a higher priority that need additional levels of effort. Pool 128a is willing to forego 50% of its total level of effort to pools 128 that are at the same priority that need effort if pool 128a is ahead of goal. Pool 128a is willing to give up 25% of its total level of effort to pools 128 that are of lower priority if needed if pool 128a is ahead of goal. The percentages are then set at 40%, 25% and 15% if pool 128a is currently at goal. If pool 128a is behind goal, pool 128a will only give up 25% of its level of effort and only to a pool 128 of higher priority. Each pool 128 has its own routing table and the percentages may vary depending on the number of pools, the number of call records, or any other appropriate factors.
TABLE 3
Example Routing Table
Ahead At Behind
Higher Priority 75% 40% 25% 
Same Priority 50% 25% 0%
Lower Priority 25% 15% 0%
In an alternate embodiment, the goal states and one or more goal strategies are inputs to and determine the objective functions and the constraints for an optimized solution to the routing determination problem. The goal strategies control how constraints on the levels of effort between pools 128 and queues 130 are relaxed or tightened when a pool 128 is not satisfying the goal. A goal strategy may allow for the transfer of higher levels of effort to pools 128 not satisfying their goals or allow for the transfer of higher levels of effort away from pools 128 not satisfying the goal. The goal module adjusts the level of effort constraints in accordance with the goal strategies so that pools 128 having the highest priority maintain or achieve the goals throughout the day.
In case of a communication, dialing device, or call center outage, system 100 employs contingency modules 132 for each dialing device 108. Contingency modules 132 are associated with dialing devices 108. Contingency modules 132 secure the call records within their respective dialing devices 108 in case of an outage. Before distribution module 102 transfers the call records to pools 128, distribution module 102 creates call record accounts for dialing devices 108, locks the call record accounts to dialing devices 108, creates a contingency download file, and stores the contingency download file in contingency modules 132. Distribution module 102 updates the contingency download file with call attempt results which prevents dialing devices 108 from calling call records already successfully called.
Users of system 100 control the functionality of distribution module 102 and goal module 103 through a user interface. The user interface is shown as online interface 134 in FIG. 1 but can be any appropriate type of user interface. Online interface 134 is a graphical user, platform-independent, password-protected World Wide Web (“WWW”) browser-based interface. Users use online interface 134 to control the settings for distribution module 102 including goal module 103 including application of the selection rules, number of pools, and number of call records to initially transfer to the queues, generate reports, select goal strategies, select performance metrics, select the goals for the pools, define the goal states, modify the effort map and routing tables, and create and modify enterprise parameters. Users access online interface 134 by using browser 136 to access Internet 138 to reach a specific web address. Once at the specific web address, the users enter the appropriate passwords to gain access to online interface 134.
Although the embodiment shown in FIG. 1 contains more than one dialing device, in alternative embodiments distribution module 102 interfaces with a single dialing device. A single dialing device interfacing with distribution module 102 allows for variable control over similar lists of call records. For instance, call records may be divided into geographies such as states or time zones. Calling can be stopped automatically by distribution module 102 when a quota is reached for a particular geography. Distribution module 102 presents the similar lists of call records for different geographies as different pools but the similar lists of call records for different geographies would represent one calling job within the single dialing device.
FIG. 2 illustrates a block diagram of system 150 employing two distribution modules in an alternative embodiment of the present invention. System 100 as shown in FIG. 2 is shown with less detail than in FIG. 1.
System 150 employs two distribution modules 102 and 152. Distribution module 152 is associated with two call centers 154 and 156. Call centers 154 and 156 each have one dialing device 158. Distribution module 152 provides the same functionality to call centers 154 and 156 that distribution module 102 provides to call centers 104 as described above in the discussion regarding FIG. 1.
Distribution module 152 provides redundancy and prevents distribution module 102 from being overburdened by too many dialing devices. Distribution module 102 functions effectively with more than one dialing device interfaced with it but performance and efficiency suffers when too many dialing devices are attached. Therefore, additional distribution module 152 allows for both it and distribution module 102 to achieve optimal performance and efficiency when adding additional call centers 154 and 156 with additional dialing devices 158.
In system 150, distribution modules 102 and 152 are in communication with each other including communicating which call records are in the pools and the call attempt results. Distribution modules 102 and 152 transfer call records and call attempt results between themselves just as distribution module 102 transfers call records and call attempt results between dialing devices 108. Therefore, if dialing devices 158 are idle while dialing devices 108 are overburdened, distribution module 102 transfers call records to distribution module 152 for dialing devices 158 to call. In addition, if distribution module 152 experiences an outage, distribution module 102 transfers the high priority calls from distribution module 152 to dialing devices 108 without worry of calling the same call record a second time in the same day when the first call resulted in a right party contact.
The two distribution modules 102 and 152 of system 150 also each include a goal module 103 and 153. Goal module 153 provides the same functionality to call centers 154 and 156 that goal module 103 provides to call centers 104 as described above in the discussion regarding FIG. 1. Goal modules 103 and 153 are in communication with each other including communicating the performance of their respective pools and queues. Through the use of distribution modules 102 and 152, goal modules 103 and 153 can transfer levels of effort between their respective pools just as goal module 103 transfers levels of effort between pools 128. Therefore if high priority pools 128 are not meeting their goals, then goal module 153 can transfer levels of effort from distribution module 152 so that the high priority pools 128 will achieve their goals.
Distribution modules 102 and 152 manage calls from a common database 118 that lists call record accounts for outbound contacts by dialing. In order to identify related call record accounts for more effective handling of the outbound campaign or campaigns, a comparison engine 160 interfaces with call records database 118 to analyze and tag related call record accounts. For instance, comparison engine 160 relates multiple accounts to a single individual by comparing predetermined factors for common values, such as name, phone number, account number, social security account number, or other factors. Each set of related accounts is tagged with a relationship tag in a predetermined call record field so that a search for that tag value will locate all related call record accounts. As an example, distribution module 102 runs contact campaigns to collect delinquent electric bills and distribution module 153 runs contact campaigns to collect delinquent gas bills. The combined call account records are analyzed to identify delinquent gas and electric bills related to the same individual and to tag each of the related delinquent call record accounts with a unique individual relation tag. The lock process 190 locks both records to prevent dialing until results are returned 198.
Once the call record accounts in the call record database are analyzed and, where appropriate, tagged, the call records are transferred to pools and queues as previously described to have outbound call attempts performed by dialer contact devices 108. In an alternative embodiment, call record accounts in the call record database are analyzed in real-time and tagged just before call records are selected for dialing in the dialing device. When a contact attempt is successful, a common account tag detector 162 associated with the dialer 108, searches to determine if the call record field is populated with a relationship tag. If the call record field is not populated with an individual relation tag, the dialer 108 handles the contact and communicates with distribution module 102 or 152 as described. If the call record field is populated, the dialer 108 communicates the unique individual relation tag to a common account controller 164 of distribution module 102 or 152. Common account controller 164 initiates a search for the unique relationship tag in the pools of distribution module 102 and 152 to place the call attempt result and a hold on outbound attempts for call record accounts related to the specified account. For example, successful contact by an operator for collection of the delinquent gas bill and delinquent electric bill of an individual may result in payments for each from one call.
Referring now to FIG. 3, a flow diagram depicts a process for distributing outbound call records. The process begins at step 170 with the transfer of call records from host 112, dialing devices 108, or scheduling module 122 to distribution module 102. In step 172, distribution module 102 organizes and arranges the call records into pools 128. Based upon user inputs distribution module 102 assigns queues 130 to specific dialing devices in step 174.
In step 176, distribution module 102 checks to see if the selection rules are to be applied to pools 128 and queues 130. If the selection rules are not to be applied, then the process continues in step 178. If selection rules are to be applied, then in step 180 distribution module 102 determines if priority, percentage, or quota rules are applied to pools 128. If priority rules are applied, then in step 182 distribution module 102 applies the priority rules to pools 128 and queues 130 and the process continues on to step 178. If percentage rules are applied, then in step 184 distribution module 102 applies the percentage rules to pools 128 and queues 130 and the process continues in step 178. If the quota rules are applied, then in step 186 distribution module 102 applies the quotas to pools 128 and queues 130 and the process continues to step 178.
Distribution module 102 then delivers enough call records to queues 130 for dialing devices 108 to place telephone calls for fifteen, thirty, sixty minutes, or an appropriate amount of time to place calls in step 178. In step 190, distribution module 102 locks the call records assigned to dialing devices 108 and creates a contingency file specific for each dialing device 108 in step 192.
In step 194, distribution module 102 transfers queues 130 containing the set number of call records to dialing devices 108. Periodically, distribution module 102 uploads call record statistics from each queue 130 in step 196. Distribution module 102 may upload the call record statistics from queues 130 every few seconds, every few minutes, every hour, or any other appropriate interval of time. Call record statistics include such information as how many call records remain to be called and the rate at which dialing devices 108 are depleting the call records in queues 130. In addition to uploading call record statistics, in step 198 distribution module 102 also uploads call attempt results. Call attempt results include whether a right party contact or wrong party contact was made or whether an answering machine was reached when dialing devices 108 place a telephone call.
In step 202 distribution module 102 updates the contingency file with the call attempt results specific for dialing devices 108. In step 204, distribution module 102 uses the call record statistics gathered in step 196 to analyze the number of call records remaining to be called and the depletion rate of the call records within queues 130. Based upon the call attempt results, distribution module 102 re-presents to pools 128 call records where the first attempt to make a right party contact was unsuccessful so that the call record can be called later in the day in step 206. In addition, the call record can be made unavailable for the remainder of the day if a right party contact was made.
Based upon the call record statistics, distribution module 102 determines in step 208 if more call records need to be sent from pools 128 to queues 130. If more call records are needed, then in step 210 distribution module 102 sends additional call records from pools 128 to queues 130 and the process repeats beginning with step 176 until manually stopped. But if distribution module 102 determines that no additional call records need to be sent from pools 128 to queues 130 in step 208, then the process repeats beginning with step 196 until manually stopped or until there are no call records remaining to be called.
FIGS. 4a and 4b illustrate a flow diagram for the population of pools 128 and queues 130 with call records. The call records in FIGS. 4a and 4b include scheduling information provided by scheduling module 122.
Referring to FIG. 4a, in step 222 the call records pass through scheduling module 122 from either dialing devices 108 or host 112. Scheduling module 122 adds call scheduling information to each call record as it passes through it. In step 224, scheduling module 122 transfers the call records containing call scheduling information to call record database 118 within distribution module 102. Distribution module 102 then arranges the call records into pools 128 in step 226. When distribution module 102 places the call records into pools 128, distribution module 102 examines each call record to determine how to extract the scheduling information, account number and telephone number from the call record. In addition, distribution module 102 flags any call records where the scheduling information or telephone number is stripped from the end of the call record before placing it in the pools 128.
In step 228, distribution module 102 splits the call records into a plurality of pools 128. Each pool 128 holds the call record as a data string and the call records are in the same format within pools 128. In addition, distribution module 102 arranges the call records within pools 128 so that each call record is selectable by its account number.
The call scheduling information provided by scheduling module 122 allows for an optimum order to call the call records. Using the call scheduling information, distribution module 102 creates hourly indices for pools 128 in step 230. The hourly indices allow for pools 128 to take advantage of the fact that the call order and call priority of each call record changes based upon the time of day. For example, a call record might be scheduled to be the first call at 8:00 AM and if not successfully called at 8:00 AM then rescheduled to be the tenth call made at 6:00 PM. There is a hourly index created for each hour of the calling day and the hourly indices are shown in step 232. Distribution module 102 creates an index for each hour for each pool 128.
In addition to the hourly indices, distribution module 102 also creates an immediate index and an overflow index. The immediate index contains call records that are always the first to be called at the beginning of every hourly index. The call records within the immediate index allow real time call record insertion based upon previous call attempts and are often call records that resulted in no contact when called the first time. Call records contained in the overflow index are call records which were not scheduled to be called or call records that do not have call scheduling information.
Once the call records are arranged into pools 128 and the hourly indices are created, the process of transferring the call records from pools 128 to queues 130 begins. In step 234, distribution module 102 selects the call records contained in the immediate index. Distribution module 102 also removes any call records that are unavailable to be called and marks the call records as unavailable in step 236. In step 238, distribution module 102 determines if it is ready to transfer the call records from pools 128 to queues 130 for this hour and if there are a sufficient number of call records to be transferred from the immediate index to allow for fifteen, thirty, sixty minutes, or an appropriate amount of time for calling. If there are sufficient call records, then in step 239, distribution module 102 transfers the call records from the pool immediate index to queues 130.
If there are not enough call records in the immediate index, then in step 240 distribution module 102 selects call records from the appropriate hourly index. These additional call records in combination with call records from the immediate index will allow for fifteen, thirty, sixty minutes, or an appropriate amount of time for calling. In step 242, distribution module 102 removes any call records unavailable to be called and marks the call records as unavailable. Distribution module 102 then transfers the call records from the immediate index and the appropriate hourly index to queues 130 in step 239.
In step 244, distribution module 102 transfers queues 130 containing the call records to dialing devices 108. After queues 130 are transferred to dialing devices 108, in step 246 dialing devices 108 begin calling the call records.
Referring to FIG. 4b, as dialing devices 108 call the call records, distribution module 102 monitors dialing devices 108 and queues 130 for when it is time to send the next hourly index of call records from pools 128 to queues 130 in step 248. In determining when to send the next hourly index, distribution module 102 cannot start morning hour queues before the actual hour of the hourly index and must stop evening hour queues before the hourly index hour expires. For instance, the pool morning hourly index for 10:00 AM cannot be sent from pools 128 to queues 130 before 10:00 AM and the evening hourly index for 7:00 PM must stop calling at 8:00 PM. This is in part to due to telemarketing regulations that regulate the times of day that telemarketing calls may be placed.
If in step 248 it is time for the next hourly index, then in step 250 distribution module 102 selects the next hourly index to be called and begins the process of transferring the call records from the appropriate hourly index to queues 130. The process of selecting the next hourly index repeats steps 234 through 244 by first taking call records from the immediate index and adding call records from the appropriate hourly index as explained above.
If in step 248 it is not time for the next hour, then distribution module 102 determines queue depth and the time to go in step 252. Queue depth is the amount of call records remaining to be called in the queue while time to go is the amount of time remaining in the hour for the hourly index. In step 254 if the depth is not too low and the time to go is not too short so that there are a sufficient amount of call records to call for the remaining time left in the hour, then additional call records are not needed in queue 130. So in step 256, the call attempt results regarding a right or wrong party contact are uploaded from dialing devices 108 and sent back to distribution module 102 in step 258. The process then returns to step 234 of FIG. 4a to begin the next record search.
If in step 254 distribution module 102 determines that the depth is too low or the time to go is too short, then in step 260 distribution module 102 calculates the number of call records needed to finish out the hour for the hourly index. In step 262, distribution module 102 selects additional call records to call by repeating steps 234 through 239 above and transferring the call records from the pools 128 to queues 130 in step 264 so that dialing devices 108 do not sit idle but finish out the hour placing telephone calls. The process then returns to step 234 of FIG. 4a to begin the next record search.
FIG. 5 depicts a flow diagram of a method for goals based routing of contact records employing a meet-goals goal strategy. The method begins at step 300 when goal module 103 selects a performance metric for each pool 128, determines a goal for each pool 128 and prioritizes pools 128 relative to each other. At step 302 goals module 103 calculates a goal status for each pool 128 using the goal and performance metric for each pool 128. After goal module 103 has calculated a goal status, goal module 103 cycles through pools 128 in descending priority order at step 304.
At step 306, goal module 103 selects a target pool based on its priority. Goal module 103 selects a target pool by first selecting the pool 128 having the highest priority. Goal module 103 then determines the goal state from the goal status for the target pool to determine if the target pool is behind goal at step 308. If the target pool is not behind goal, then at step 310 goal module 103 checks to see if there are additional pools 128 to cycle through. If there are not additional pools 128 to cycle through, then the process ends. But if there are additional pools 128 to cycle through at step 310, then the process returns to step 306 where goal module 103 selects the pool 128 having the next highest priority to determine if that target pool is behind goal. If that target pool is not behind goal, then the process repeats until either goal module 103 locates a target pool that is behind goal at step 308 or the process ends because no target pools are behind goal.
If at step 308, the target pool is behind goal, then goal module 103 cycles through donor pools from lowest to highest priority at step 312. The donor pools include all the other pools 128 except the target pool that was selected at step 308. At step 314, goal module 103 selects a donor pool 128 having the lowest priority out of all the donor pools. The goal module 103 then determines if the selected donor pool is active and able to donate levels of effort to the target pool at step 316. A pool 128 is active when it is still transferring contact records to queues 130 and hasn't satisfied its final goal or quota. Goal module 103 examines the routing table for the selected donor pool to determine if the donor pool is able to donate levels of effort to the target pool. Since each pool 128 has its own routing table, goal module 103 must examine the routing table to determine if the donor pool is able to donate any levels of effort. Generally, if the selected donor pool is ahead of goal or at goal, it is able to donate a percentage of level of effort to the target pool regardless of the respective pool priorities. If the donor pool is behind goal but the target pool is of a higher priority, then generally the donor pool is available to donate some percentage of level of effort. If the donor pool is behind goal and the target pool is of the same priority or lower priority, then typically the donor pool is not able to donate any level of effort to the target pool.
If at step 316 the donor pool is both active and able to donate a percentage of level of effort to the target pool, then at step 318 goal module 103 transfers a percentage of the level of effort from the donor pool to the target pool. Goal module 103 transfers the level of effort from the donor pool to the target pool by modifying the effort map in accordance with the limits specified in the routing table for the donor pool. To donate the level of effort from the donor pool to the target pool, goal module 103 examines the routing table for the donor pool to determine how much level of effort may be donated from the donor pool to the target pool. For instance using the example routing table in Table 3, if the target pool is of a higher priority than the donor pool and the donor pool is above its goal, then goal module 103 transfers 75% of the level of effort for the donor pool to the target pool. Therefore, if pool 128a is the donor pool and pool 128c is the target pool, goal module 103 transfers 75% of the level of effort for pool 128a to pool 128c thereby allowing queue 130a to receive 25% of its contact records from pool 128a and 75% of its contact records from pool 128c instead of queue 130a receiving 100% of its contact records from pool 128a. Pool 128c now supplies contact records to queues 130a and 130d instead of just queue 130d which allows additional agents 110 to access contact records from pool 128c and thereby meet the goal for pool 128c. Goal module 103 then modifies the effort map to reflect this change in the levels of effort between pools 128.
After goal module 103 transfers the level of effort, at step 320 goal module 103 determines if there are additional donor pools to cycle through. If there are additional donor pools to cycle through, then the process returns to step 314 where goal module 103 selects the donor pool having the second lowest priority and the process repeats until there are no more donor pools to cycle through at step 320. If at step 316 the donor pool is either not active or not able to donate a percentage of level of effort to the target pool, the process proceeds to step 320 where goal module 103 determines if there are additional donor pools to cycle through as described above.
When at step 320 goal module 103 determines that there are no more donor pools to cycle through, the process proceeds to step 310 where goal module 103 determines if there are any additional pools 128 to cycle through. If there are no more pools 128, then the process ends. If there are additional pools, then the process returns to step 306 where goal module 103 selects the next pool 128 based on its priority to determine if it is behind its goal.
The method of FIG. 5 repeats until goal module 103 has checked every pool 128 from highest to lowest priority to see if pools 128 are behind goal. Therefore, the pools 128 having the highest priority are addressed first by goal module 103 ensuring that pools 128 having the highest priority shall achieve and/or maintain their goals by transferring levels of effort away from pools 128 having a lower priority to pools 128 having a higher priority.
FIG. 6 illustrates a flow diagram of a method for goals based routing of contact records employing an exceed-goals goal strategy. The method begins at step 330 when goal module 103 selects a performance metric for each pool 128, determines a goal for each pool 128 and prioritizes pools 128 relative to each other. At step 332, goal module 103 calculates a goal status for each pool 128 using the goal and performance metric for each pool 128. After goal module 103 has calculated a goal status, goal module 103 cycles through pools 128 in an ascending priority order at step 334.
At step 336, goal module 103 selects a target pool based on its priority. Goal module 103 selects a target pool by first selecting the pool 128 having the lowest priority. Goal module 103 then determines the goal state using the goal status for target pool to determine if target pool is behind goal at step 338. If target pool is not behind goal, then at step 340 goal module 103 checks to see if there are additional pools 128 to cycle through. If there are no additional pools 128 to cycle through, the process ends. But if there are additional pools 128 to cycle through at step 340, then the process returns to step 336 where goal module 103 selects the pool 128 having the next lowest priority to determine if that target pool is behind goal. If that target pool is not behind goal, then the process repeats until either goal module 103 locates a target pool that is behind goal at step 338 or the process ends because no target pools are behind goal.
If at step 338, the target pool is behind goal, then goal module 103 cycles through recipient pools from highest to lowest priority at step 342. The recipient pools include all the other pools 128 except the target pool that was selected at step 336. At step 344, goal module 103 selects a recipient pool having the highest priority out of all the recipient pools. Goal module 103 then determines if the selected recipient pool is active and ahead of its goal at step 346. A pool 128 is active when it is still transferring contact records to queues 130 and has not satisfied its final goal or quota.
If at step 346 the recipient pool is both active and ahead of its goal, then at step 348 goal module 103 transfers a percentage of the level of effort from the target pool to the recipient pool. After goal module 103 transfers the level of effort, at step 340 goal module 103 determines if there are additional pools 128 to cycle through. If there are no additional pools 128 to cycle through at step 340, then the process ends. But if at step 340 there are additional pools 128 to cycle through, then the process returns to step 336 where goal module 103 selects the target pool having the next lowest priority.
If at step 346 the recipient pool is either not active or not ahead of goal, the process proceeds to step 350 where goal module 103 determines if there are additional recipient pools to cycle through. If there are additional recipient pools to cycle through at step 350, then the process returns to step 344 where goal module 103 selects a recipient pool having the next highest priority and the process repeats as described above.
If at step 350 there are no more recipient pools to cycle through, the process continues to step 352. The method only proceeds to step 352 after goal module 103 has examined all of the recipient pools to determine if the recipient pools are active and ahead of goal. At step 352, goal module 103 cycles through recipient pools from highest to lowest priority and at step 354 goal module 103 selects the recipient pool having the highest priority. At step 356, goal module 103 determines if the selected recipient pool is active and at goal. If the selected recipient pool is active and at goal, then at step 358 goal module 103 transfers a percentage of the level of effort from the target pool to the selected recipient pool. The process then continues on to step 340 where goal module 103 determines if there are additional pools 128 to cycle through and the process either ends or returns to step 336.
If at step 356 goal module 103 determines that the selected recipient pool is either not active or not at goal, then at step 360 goal module 103 determines if there are additional recipient pools to cycle through. If there are not additional recipient pools to cycle through, then the process continues to step 340 where goal module 103 determines if there are additional pools 128 to cycle through as described above. If there are additional recipient pools to cycle through at step 360, then the process returns to step 354 where goal module 103 selects the next recipient pool having the next highest priority and the process repeats as described above.
The method of FIG. 6 repeats until goal module 103 has checked every pool 128 from lowest to highest priority to see if pools 128 are behind goal. Therefore, the pools 128 having the lowest priority are examined first to determine if they are able to donate a percentage of level of effort to pools 128 having higher priority so that the pools 128 having the highest priority exceed their goals.
In an alternate embodiment, the present invention applies to the different types of contacts records and devices listed above and manages other types of customer contact requests such as inbound calls, email, Internet chat, online requests for live chat in addition to outbound call records.
Although the present invention has been described in detail, it should be understood that various changes, substitution, and alterations can be made hereto without parting from the spirit and scope of the invention as defined by the appended claims.

Claims (19)

What is claimed is:
1. A system for coordinating distribution of distributing contact records between plural contact devices to a contact device, each the contact device operable to establish contacts using the contact records and having plural associated contact agents to interact with the contacts, the system comprising:
a distribution module operable to interface with each the contact device and to distribute the contact records to the contact devices device;
a comparison engine operable to identify one or more sets of contact records, the contact records of each set related by one or more factors; and
a common account controller associated with the distribution module and operable to route each of the one or more sets at least one of the one or more sets of contact records identified as related to common contact devices so that each set routes to one the contact device,
wherein the at least one of the one or more sets of contact records identified as related comprises a first contact record and a second contact record, and the contact device is operable to not establish a contact based on the second contact record in light of the second contact record being related to the first contact record.
2. The system of claim 1 wherein the comparison engine is further operable to tag the contact records identified as related, the system further comprising a common account tag detector associated with each the contact device and operable to detect tagged contact records and to communicate to the common account controller call contact attempt results for the tagged contact records.
3. The system of claim 2 wherein the contact devices comprise device comprises an outbound telephone calling devices device.
4. The system of claim 3 wherein the comparison engine identifies related the one or more sets of contact records identified as related by comparing contact record outbound telephone contact numbers.
5. The system of claim 1 wherein the comparison engine identifies related the one or more sets of contact records identified as related by comparing contact record social security account numbers.
6. The system of claim 1 further comprising plural distribution modules, each distribution module associated with one or more predetermined contact devices and having a common account controller, the common account controllers coordinating transfer of related the one or more sets of contact records identified as related to common contact devices.
7. A method for coordinating distribution of contact records between plural contact devices to a contact device, each wherein the contact device is operable to simultaneously establish plural contacts for plural associated agents, the method comprising:
comparing one or more predetermined factors of the contact records to identify one or more sets of related contact records;
distributing the at least one of the one or more sets of related contact records to plural contact devices, each set of related contact records distributed to a common contact device the contact device;
establishing a contact with based on a contact record at a the contact device;
determining that the established contact record has related contact records; and
presenting the related contact records of the contact record to the an agent at associated with the contact device having the established contact.
8. The method of claim 7 wherein comparing the one or more predetermined factors comprises comparing the an individual name associated with each contact record.
9. The method of claim 7 wherein comparing the one or more predetermined factors comprises comparing the a social security account number associated with each contact record.
10. The method of claim 7 wherein comparing the one or more predetermined factors comprises comparing the contact information associated with each contact record.
11. The method of claim 7 wherein establishing a the contact further comprises dialing an outbound telephone number.
12. The method of claim 7 wherein distributing the at least one of the one or more sets of related contact records further comprises:
interfacing the contact devices device with a distribution module; and
distributing the at least one of the one or more sets of related contact records to the contact devices through device using the distribution module.
13. The method of claim 7 wherein establishing a the contact further comprises establishing a voice connection through a using VoIP.
14. A system for coordinating communication between plural contact devices using contact records stored in memory, each of the contact devices operable to establish contacts and having plural associated contact agents to interact with the established contacts, the system comprising:
a comparison engine operable to identify two or more contact records stored in the memory as related to a common account by one or more factors, the comparison engine further operable to tag the contact records related to the common account prior to attempting contact to the common account;
a distribution module operable to interface with one of the contact devices and to distribute a pool of contact records from the memory to the contact device;
a common account controller operable to prevent outbound contact attempts based on the contact records tagged as related to the common account after an initial contact attempt to the common account by the contact device; and
a common account tag detector associated with the contact device operable to communicate information on the initial contact attempt related to the common account to the common account controller.
15. The system of claim 15 wherein the plural contact devices comprise an outbound dialer and an email server.
16. A system for distributing contact records to a contact device operable to establish contacts using the contact records and having plural associated contact agents to interact with the contacts, the system comprising:
at least one computer processor configured to:
interface with the contact device and to distribute the contact records to the contact device;
identify one or more sets of contact records, the contact records for each set related by one or more factors; and
route at least one of the one or more sets of contact records identified as related to the contact device,
wherein the at least one of the one or more sets of contact records identified as related comprises a first contact record and a second contact record, and the contact device does not establish a contact based on the second contact record in light of the second contact record being related to the first contact record.
17. The system of claim 16 wherein the contact device comprises an outbound telephone calling device.
18. The system of claim 16 wherein the at least one computer processor is configured to identify the one or more sets of contact records identified as related by comparing contact record outbound telephone contact numbers.
19. The system of claim 16 wherein the at least one computer processor is configured to identify the one or more sets of contact records identified as related by comparing contact record social security account numbers.
US13/668,380 2001-07-09 2012-11-05 System and method for common account based routing of contact records Expired - Fee Related USRE44979E1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US13/668,380 USRE44979E1 (en) 2001-07-09 2012-11-05 System and method for common account based routing of contact records

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US09/901,749 US7142662B2 (en) 2000-07-11 2001-07-09 Method and system for distributing outbound telephone calls
US10/095,513 US7103173B2 (en) 2001-07-09 2002-03-12 System and method for preemptive goals based routing of contact records
US10/456,575 US7054434B2 (en) 2001-07-09 2003-06-06 System and method for common account based routing of contact records
US11/436,456 US8175258B2 (en) 2001-07-09 2006-05-18 System and method for common account based routing of contact records
US13/668,380 USRE44979E1 (en) 2001-07-09 2012-11-05 System and method for common account based routing of contact records

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US11/436,456 Reissue US8175258B2 (en) 2001-07-09 2006-05-18 System and method for common account based routing of contact records

Publications (1)

Publication Number Publication Date
USRE44979E1 true USRE44979E1 (en) 2014-07-01

Family

ID=32966371

Family Applications (3)

Application Number Title Priority Date Filing Date
US10/456,575 Ceased US7054434B2 (en) 2001-07-09 2003-06-06 System and method for common account based routing of contact records
US11/436,456 Active 2026-01-01 US8175258B2 (en) 2001-07-09 2006-05-18 System and method for common account based routing of contact records
US13/668,380 Expired - Fee Related USRE44979E1 (en) 2001-07-09 2012-11-05 System and method for common account based routing of contact records

Family Applications Before (2)

Application Number Title Priority Date Filing Date
US10/456,575 Ceased US7054434B2 (en) 2001-07-09 2003-06-06 System and method for common account based routing of contact records
US11/436,456 Active 2026-01-01 US8175258B2 (en) 2001-07-09 2006-05-18 System and method for common account based routing of contact records

Country Status (1)

Country Link
US (3) US7054434B2 (en)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
USRE46420E1 (en) * 2000-07-11 2017-05-30 Noble Systems Corporation Method and system for distributing outbound telephone calls
USRE46478E1 (en) * 2000-07-11 2017-07-11 Noble Systems Corporation System and method for preemptive goals based routing of contact records

Families Citing this family (33)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050002515A1 (en) * 1999-07-13 2005-01-06 Mewhinney Brian E. Dialing techniques for a contact center
US7127058B2 (en) * 2002-03-27 2006-10-24 Nortel Networks Limited Managing communications in a call center
US20040117277A1 (en) * 2002-12-16 2004-06-17 Joseph Tagupa Distributing accounts in a workflow system
US7492881B1 (en) * 2003-05-14 2009-02-17 Evercom Systems, Inc. Intelligent queuing of transaction records
US8000989B1 (en) 2004-03-31 2011-08-16 Avaya Inc. Using true value in routing work items to resources
US7953859B1 (en) 2004-03-31 2011-05-31 Avaya Inc. Data model of participation in multi-channel and multi-party contacts
US7779042B1 (en) 2005-08-08 2010-08-17 Avaya Inc. Deferred control of surrogate key generation in a distributed processing architecture
US20070041562A1 (en) * 2005-08-16 2007-02-22 Bernier Martin L Inter campaign and queue cooperation
US8494152B1 (en) 2006-02-28 2013-07-23 Allstate Insurance Company Systems and methods for automated call-handling and processing
JP5028022B2 (en) * 2006-04-25 2012-09-19 キヤノン株式会社 Printing apparatus and document printing method
US7936867B1 (en) 2006-08-15 2011-05-03 Avaya Inc. Multi-service request within a contact center
US8391463B1 (en) 2006-09-01 2013-03-05 Avaya Inc. Method and apparatus for identifying related contacts
US8811597B1 (en) 2006-09-07 2014-08-19 Avaya Inc. Contact center performance prediction
US8938063B1 (en) 2006-09-07 2015-01-20 Avaya Inc. Contact center service monitoring and correcting
US8442917B1 (en) * 2007-09-04 2013-05-14 Ambit Holdings, L.L.C. Energy distribution and marketing backoffice system and method
US10650359B2 (en) 2007-09-04 2020-05-12 Bluenet Holdings, Llc Energy distribution and marketing backoffice system and method
US11610275B1 (en) 2007-09-04 2023-03-21 Bluenet Holdings, Llc System and methods for customer relationship management for an energy provider
US10108976B2 (en) 2007-09-04 2018-10-23 Bluenet Holdings, Llc System and method for marketing sponsored energy services
US8504534B1 (en) 2007-09-26 2013-08-06 Avaya Inc. Database structures and administration techniques for generalized localization of database items
US8856182B2 (en) * 2008-01-25 2014-10-07 Avaya Inc. Report database dependency tracing through business intelligence metadata
US8565386B2 (en) 2009-09-29 2013-10-22 Avaya Inc. Automatic configuration of soft phones that are usable in conjunction with special-purpose endpoints
US8842820B2 (en) * 2009-11-16 2014-09-23 At&T Intellectual Property I, L.P. Enhanced contact center architecture to support agent resource optimization
US9516069B2 (en) 2009-11-17 2016-12-06 Avaya Inc. Packet headers as a trigger for automatic activation of special-purpose softphone applications
US8559979B2 (en) * 2010-04-01 2013-10-15 Sony Corporation Mobile terminal, location-based service server, and information providing system
US9060062B1 (en) * 2011-07-06 2015-06-16 Google Inc. Clustering and classification of recent customer support inquiries
US9674360B2 (en) * 2012-04-19 2017-06-06 Avaya Inc. Management of contacts at contact centers
US9137372B2 (en) 2013-03-14 2015-09-15 Mattersight Corporation Real-time predictive routing
US9106748B2 (en) 2013-05-28 2015-08-11 Mattersight Corporation Optimized predictive routing and methods
US20150086002A1 (en) * 2013-09-25 2015-03-26 Drishti-Soft Solutions Pvt, Ltd. System and method for managing outbound interactions
US10929858B1 (en) * 2014-03-14 2021-02-23 Walmart Apollo, Llc Systems and methods for managing customer data
US20150294404A1 (en) * 2014-04-11 2015-10-15 Innovation Software, Llc Method and system for legal processing for debt collection
US11645344B2 (en) 2019-08-26 2023-05-09 Experian Health, Inc. Entity mapping based on incongruent entity data
US11856141B2 (en) * 2021-12-06 2023-12-26 Avaya Management L.P. Methods and systems of providing response based on communication session participant request urgency

Citations (174)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4881261A (en) 1988-06-29 1989-11-14 Rockwell International Corporation Method for predictive pacing of calls in a calling system
US5040208A (en) 1989-11-03 1991-08-13 International Business Machines Corporation Coordinated voice and data display having temporary storage of transaction data
US5185782A (en) 1991-02-08 1993-02-09 A&T Bell Laboratories ACD arrangement for automatically returning a call at a time specified by the original caller
US5214688A (en) * 1990-06-05 1993-05-25 Inventions, Inc. Method and apparatus for dynamic and interdependent processing of inbound calls and outbound calls
US5297195A (en) * 1991-10-02 1994-03-22 Teledirect International, Inc. Method and apparatus for automatic telephone scheduling system
US5335269A (en) 1992-03-12 1994-08-02 Rockwell International Corporation Two dimensional routing apparatus in an automatic call director-type system
US5343518A (en) * 1993-01-14 1994-08-30 Davox Corporation System and method for controlling the dialing order of call record lists in an automated dialing system
US5436965A (en) * 1993-11-16 1995-07-25 Automated Systems And Programming, Inc. Method and system for optimization of telephone contact campaigns
US5440585A (en) 1993-06-14 1995-08-08 At&T Corp. Applications of simultaneous analog and digital communication
US5444774A (en) 1992-06-26 1995-08-22 At&T Corp. Interactive queuing sytem for call centers
US5448555A (en) 1993-06-14 1995-09-05 At&T Corp. Simultaneous analog and digital communication
US5479487A (en) 1993-02-11 1995-12-26 Intervoice Limited Partnership Calling center employing unified control system
US5499289A (en) 1994-12-06 1996-03-12 At&T Corp. Systems, methods and articles of manufacture for performing distributed telecommunications
US5499291A (en) 1993-01-14 1996-03-12 At&T Corp. Arrangement for automating call-center agent-schedule-notification and schedule-adherence functions
US5509055A (en) 1993-06-30 1996-04-16 At&T Corp. Inbound telecommunications services resources management system
US5533108A (en) 1994-03-18 1996-07-02 At&T Corp. Method and system for routing phone calls based on voice and data transport capability
US5537436A (en) 1993-06-14 1996-07-16 At&T Corp. Simultaneous analog and digital communication applications
US5574781A (en) 1994-12-08 1996-11-12 At&T Translation indicator for database-queried communications services
US5594790A (en) * 1993-01-14 1997-01-14 Davox Corporation Method for selecting and controlling the automatic dialing of a call record campaign
US5627884A (en) 1995-06-26 1997-05-06 Williams; Mark J. Method for returning inbound calls
US5717747A (en) 1996-05-31 1998-02-10 Lucent Technologies Inc. Arrangement for facilitating plug-and-play call features
US5721770A (en) 1996-07-02 1998-02-24 Lucent Technologies Inc. Agent vectoring programmably conditionally assigning agents to various tasks including tasks other than handling of waiting calls
US5732218A (en) 1997-01-02 1998-03-24 Lucent Technologies Inc. Management-data-gathering system for gathering on clients and servers data regarding interactions between the servers, the clients, and users of the clients during real use of a network of clients and servers
US5740238A (en) 1995-11-03 1998-04-14 Lucent Technologies Inc. Method and apparatus for queuing a call to the best backup split
US5742674A (en) 1995-12-22 1998-04-21 At&T Corp. Automatic call-back system and method using data indicating best time to call
US5751795A (en) 1995-08-11 1998-05-12 Lucent Technologies Inc. Broadcasting of information through telephone switching system display messages
US5754639A (en) 1995-11-03 1998-05-19 Lucent Technologies Method and apparatus for queuing a call to the best split
US5757904A (en) 1996-02-05 1998-05-26 Lucent Technologies Inc. Context-sensitive presentation of information to call-center agents
US5757644A (en) 1996-07-25 1998-05-26 Eis International, Inc. Voice interactive call center training method using actual screens and screen logic
US5796791A (en) 1996-10-15 1998-08-18 Intervoice Limited Partnership Network based predictive dialing
US5825870A (en) 1996-04-05 1998-10-20 Genesys Telecommunications Laboratories Methods and apparatus for implementing a network call center
US5828747A (en) 1997-01-28 1998-10-27 Lucent Technologies Inc. Call distribution based on agent occupancy
US5838682A (en) 1995-11-28 1998-11-17 Bell Atlantic Network Services, Inc. Method and apparatus for establishing communications with a remote node on a switched network based on hypertext dialing information received from a packet network
US5848143A (en) 1995-03-02 1998-12-08 Geotel Communications Corp. Communications system using a central controller to control at least one network and agent system
US5867559A (en) 1996-02-20 1999-02-02 Eis International, Inc. Real-time, on-line, call verification system
US5898772A (en) 1997-05-29 1999-04-27 Lucent Technologies Inc. Logical PC agent
US5903877A (en) 1996-09-30 1999-05-11 Lucent Technologies Inc. Transaction center for processing customer transaction requests from alternative media sources
US5903641A (en) 1997-01-28 1999-05-11 Lucent Technologies Inc. Automatic dynamic changing of agents' call-handling assignments
US5905793A (en) 1997-03-07 1999-05-18 Lucent Technologies Inc. Waiting-call selection based on anticipated wait times
US5926539A (en) 1997-09-12 1999-07-20 Genesys Telecommunications Laboratories, Inc. Method and apparatus for determining agent availability based on level of uncompleted tasks
US5930337A (en) 1997-02-04 1999-07-27 Lucent Technologies Inc. Dynamic message-mailbox size variation
US5933476A (en) 1997-05-30 1999-08-03 Northern Telecom Limited TTY telephone display and related processes systems and apparatus
US5940475A (en) 1997-05-30 1999-08-17 Northern Telecom Limited Telephone system integrated text based communication apparatus and system to enhance access for TDD and/or TTY devices
US5943395A (en) 1997-05-30 1999-08-24 Northern Telecom Limited Telephone apparatus, systems, and processes to enhance access for TDD and/or TTY devices
US5946386A (en) 1996-03-11 1999-08-31 Xantel Corporation Call management system with call control from user workstation computers
US5960382A (en) 1997-07-07 1999-09-28 Lucent Technologies Inc. Translation of an initially-unknown message
US5982873A (en) 1997-03-07 1999-11-09 Lucent Technologies Inc. Waiting-call selection based on objectives
US5987115A (en) 1996-12-03 1999-11-16 Northern Telecom Limited Systems and methods for servicing calls by service agents connected via standard telephone lines
US5991293A (en) 1997-05-23 1999-11-23 Nortel Networks Corporation Circuit arrangement for providing internet connectivity to a computer in a key telephone system
US6002749A (en) 1997-05-30 1999-12-14 Nortel Networks Corporation Telephone system integrated text based communication apparatus and systems to establish communication links to TDD and/or TTY devices and other telephone and text server systems
US6002760A (en) 1998-02-17 1999-12-14 Genesys Telecommunications Laboratories, Inc. Intelligent virtual queue
US6009162A (en) 1996-10-31 1999-12-28 Lucent Technologies Inc. Telecommunication feature for exchange of translation information between a computer and a telecommunication switching system
US6014439A (en) 1997-04-08 2000-01-11 Walker Asset Management Limited Partnership Method and apparatus for entertaining callers in a queue
US6038302A (en) 1998-04-02 2000-03-14 Lucent Technologies Inc. Methods and apparatus for processing phantom calls placed via computer-telephony integration (CTI)
US6052460A (en) 1997-12-17 2000-04-18 Lucent Technologies Inc. Arrangement for equalizing levels of service among skills
US6061442A (en) 1997-03-07 2000-05-09 Lucent Technologies Inc. Method and apparatus for improved call control scheduling in a distributed system with dissimilar call processors
US6064730A (en) 1996-06-18 2000-05-16 Lucent Technologies Inc. Customer-self routing call center
US6064731A (en) 1998-10-29 2000-05-16 Lucent Technologies Inc. Arrangement for improving retention of call center's customers
US6070012A (en) 1998-05-22 2000-05-30 Nortel Networks Corporation Method and apparatus for upgrading software subsystems without interrupting service
US6078650A (en) 1997-05-30 2000-06-20 Nortel Networks Corporation Telephone system integrated text based communication processes to enhance access for TDD and/or TTY devices
US6088444A (en) 1997-04-11 2000-07-11 Walker Asset Management Limited Partnership Method and apparatus for value-based queuing of telephone calls
US6088441A (en) 1997-12-17 2000-07-11 Lucent Technologies Inc. Arrangement for equalizing levels of service among skills
US6088442A (en) 1998-03-16 2000-07-11 Lucent Technologies Inc. Automatic wireless alerting on an automatic call distribution center
US6091808A (en) 1996-10-17 2000-07-18 Nortel Networks Corporation Methods of and apparatus for providing telephone call control and information
US6118861A (en) 1997-08-14 2000-09-12 Nortel Networks Corporation Calling party invoked held call monitoring
US6122364A (en) 1997-12-02 2000-09-19 Nortel Networks Corporation Internet network call center
US6154530A (en) 1997-04-22 2000-11-28 U.S. Philips Corporation Telecommunication equipment, system and method comprising management means for managing subscriber call-back lists
US6163607A (en) 1998-04-09 2000-12-19 Avaya Technology Corp. Optimizing call-center performance by using predictive data to distribute agents among calls
US6163606A (en) 1998-09-16 2000-12-19 Lucent Technologies Inc. System for providing virtual called party identification in a voice mail system
US6181776B1 (en) 1997-12-24 2001-01-30 Nortel Networks Limited Network management of automatic call distributor resources
US6188673B1 (en) 1997-09-02 2001-02-13 Avaya Technology Corp. Using web page hit statistics to anticipate call center traffic
US6188762B1 (en) 1997-12-01 2001-02-13 Stephen Shooster Web call center/PSTN to TCPIP internet network
US6192122B1 (en) 1998-02-12 2001-02-20 Avaya Technology Corp. Call center agent selection that optimizes call wait times
US6192050B1 (en) 1997-08-29 2001-02-20 Nortel Networks Limited Method and apparatus for inquiry response via internet
US6205412B1 (en) 1997-07-09 2001-03-20 Genesys Telecommunications Laboratories, Inc. Methods in computer simulation of telephony systems
US6208721B1 (en) 1999-01-22 2001-03-27 Lucent Technologies Inc. Method and apparatus for identifying telephone callers who have been unsuccessful in reaching a called destination
US6215784B1 (en) 1997-12-24 2001-04-10 Nortel Networks Limited Method and system for voice call completion using information retrieved from an open application on a computing machine
US20010000458A1 (en) 1998-12-11 2001-04-26 Yuri Shtivelman Method for estimating telephony system-queue waiting time in an agent level routing environment
US6226377B1 (en) 1998-03-06 2001-05-01 Avaya Technology Corp. Prioritized transaction server allocation
US6233332B1 (en) 1998-06-03 2001-05-15 Avaya Technology Corp. System for context based media independent communications processing
US6240391B1 (en) 1999-05-25 2001-05-29 Lucent Technologies Inc. Method and apparatus for assembling and presenting structured voicemail messages
US6256381B1 (en) 1998-10-30 2001-07-03 Avaya Technology Corp. System and method for identifying a data record associated with a transferred telephone call
US6256299B1 (en) 1998-04-30 2001-07-03 Avaya Technology Corp. Automatic service provider notification of unauthorized terminal activity
US6272216B1 (en) 1998-06-01 2001-08-07 Avaya Technology Corp Customer self routing call center
US6272544B1 (en) 1998-09-08 2001-08-07 Avaya Technology Corp Dynamically assigning priorities for the allocation of server resources to completing classes of work based upon achievement of server level goals
US20010021646A1 (en) 2000-02-08 2001-09-13 Lucent Technologies Inc. System and method for routing special number calls in a telecommunication network
US6292550B1 (en) 1998-06-01 2001-09-18 Avaya Technology Corp. Dynamic call vectoring
US6295353B1 (en) 1998-10-07 2001-09-25 Avaya Technology Corp. Arrangement for efficiently updating status information of a network call-routing system
US6298127B1 (en) 1998-07-13 2001-10-02 Nortel Networks Limited Call transfer and conference with separate billing records per leg
US6314177B1 (en) 1998-12-22 2001-11-06 Nortel Networks Limited Communications handling center and communications forwarding method using agent attributes
US20010038624A1 (en) 1999-03-19 2001-11-08 Greenberg Jeffrey Douglas Internet telephony for ecommerce
US20010040887A1 (en) 1997-10-09 2001-11-15 Yuri Shtivelman Apparatus and methods enhancing call routing to and within call-centers
US6327362B1 (en) 1998-11-23 2001-12-04 Lucent Technologies Inc. System and method including dynamic differential treatment in workflows and contact flow
US6337858B1 (en) 1997-10-10 2002-01-08 Nortel Networks Limited Method and apparatus for originating voice calls from a data network
US20020010645A1 (en) 2000-07-12 2002-01-24 David Hagen Backend commerce engine
US6349205B1 (en) 1999-04-15 2002-02-19 Lucent Technologies Inc. Method for converting an existing subscriber to a wireless communications system
US6353667B1 (en) 1998-08-27 2002-03-05 Avaya Technology Corp. Minimum interruption cycle time threshold for reserve call center agents
US6353851B1 (en) 1998-12-28 2002-03-05 Lucent Technologies Inc. Method and apparatus for sharing asymmetric information and services in simultaneously viewed documents on a communication system
US6356632B1 (en) 1998-12-31 2002-03-12 Avaya Technology Corp. Call selection and agent selection in a call center based on agent staffing schedule
US6359982B1 (en) 1999-01-12 2002-03-19 Avaya Technologies Corp. Methods and apparatus for determining measures of agent-related occupancy in a call center
US6366666B2 (en) 1998-12-16 2002-04-02 Avaya Technology Corp. Adjustment of call selection to achieve target values for interval-based performance metrics in a call center
US6366668B1 (en) 1999-03-11 2002-04-02 Avaya Technology Corp. Method of routing calls in an automatic call distribution network
US6377944B1 (en) 1998-12-11 2002-04-23 Avaya Technology Corp. Web response unit including computer network based communication
US6385646B1 (en) * 1996-08-23 2002-05-07 At&T Corp. Method and system for establishing voice communications in an internet environment
US6385191B1 (en) 1996-11-14 2002-05-07 Avaya Technology Corp. Extending internet calls to a telephony call center
US6389132B1 (en) 1999-10-13 2002-05-14 Avaya Technology Corp. Multi-tasking, web-based call center
US6392666B1 (en) 1999-07-21 2002-05-21 Avaya Technology Corp. Telephone call center monitoring system allowing real-time display of summary views and interactively defined detailed views
US6404747B1 (en) 1998-06-02 2002-06-11 Avaya Technology Corp. Integrated audio and video agent system in an automatic call distribution environment
US20020073155A1 (en) 1999-01-08 2002-06-13 Lucent Technologies Inc. Methods and apparatus for enabling shared web-based interaction in stateful servers
US6408066B1 (en) 1999-12-15 2002-06-18 Lucent Technologies Inc. ACD skill-based routing
US20020101854A1 (en) 2001-01-30 2002-08-01 Joseph Siegrist Remote media control for voice over internet telephony and related applications
US20020101866A1 (en) 1995-10-25 2002-08-01 Alec Miloslavsky Method and apparatus for determining and using multiple object states in an intelligent internet protocol telephony network
US6430174B1 (en) 1997-12-26 2002-08-06 Nortel Networks Ltd. Communication system supporting simultaneous voice and multimedia communications and method of operation therefore
US6434230B1 (en) 1999-02-02 2002-08-13 Avaya Technology Corp. Rules-based queuing of calls to call-handling resources
US6445788B1 (en) 1999-06-17 2002-09-03 Genesys Telecommunications Laboratories, Inc. Method and apparatus for providing fair access to agents in a communication center
US6449618B1 (en) 1999-03-25 2002-09-10 Lucent Technologies Inc. Real-time event processing system with subscription model
US6449341B1 (en) 1998-08-25 2002-09-10 Mci Communications Corporation Apparatus and method for managing a software system via analysis of call center trouble tickets
US20020131399A1 (en) 1998-02-17 2002-09-19 Laurent Philonenko Queue prioritization based on competitive user input
US6459774B1 (en) 1999-05-25 2002-10-01 Lucent Technologies Inc. Structured voicemail messages
US6459788B1 (en) 1999-04-27 2002-10-01 Sprint Communications Company L.P. Call center resource processor
US20020141561A1 (en) 2000-04-12 2002-10-03 Austin Logistics Incorporated Method and system for self-service scheduling of inbound inquiries
US6463346B1 (en) 1999-10-08 2002-10-08 Avaya Technology Corp. Workflow-scheduling optimization driven by target completion time
US6470077B1 (en) 2000-03-13 2002-10-22 Avaya Technology Corp. Apparatus and method for storage and accelerated playback of voice samples in a call center
US6473505B1 (en) 1999-04-27 2002-10-29 Sprint Communications Company L.P. Call processing system for handling calls to a call center
US6473404B1 (en) 1998-11-24 2002-10-29 Connect One, Inc. Multi-protocol telecommunications routing optimization
US6477559B1 (en) 1998-08-21 2002-11-05 Aspect Communications Corporation Method and apparatus for remotely accessing an automatic transaction processing system
US6480698B2 (en) 1996-12-02 2002-11-12 Chi Fai Ho Learning method and system based on questioning
US6480601B1 (en) 1999-11-12 2002-11-12 Concerto Software, Inc. Voice and data transfer from outbound dialing to inbound ACD queue
US6480484B2 (en) 1998-06-09 2002-11-12 Avaya Technology Corp. Internet-intranet greeting service
US20020169834A1 (en) 1995-10-25 2002-11-14 Alec Miloslavsky Apparatus and methods for routing electronic mail in a processing center
US20020183072A1 (en) 2001-04-17 2002-12-05 Galia Steinbach BeyondguideTM method and system
US6493447B1 (en) 1997-11-21 2002-12-10 Mci Communications Corporation Contact server for call center for syncronizing simultaneous telephone calls and TCP/IP communications
US6496831B1 (en) 1999-03-25 2002-12-17 Lucent Technologies Inc. Real-time event processing system for telecommunications and other applications
US20020194272A1 (en) 1997-11-18 2002-12-19 Min Zhu Method for establishing a communication connection between two or more users via a network of interconnected computers
US20020194047A1 (en) 2001-05-17 2002-12-19 International Business Machines Corporation End-to-end service delivery (post-sale) process
US6498921B1 (en) 1999-09-01 2002-12-24 Chi Fai Ho Method and system to answer a natural-language question
US6499023B1 (en) 1999-02-19 2002-12-24 Lucent Technologies Inc. Data item evaluation based on the combination of multiple factors
US20020196277A1 (en) 2000-03-21 2002-12-26 Sbc Properties, L.P. Method and system for automating the creation of customer-centric interfaces
US6502133B1 (en) 1999-03-25 2002-12-31 Lucent Technologies Inc. Real-time event processing system with analysis engine using recovery information
US20030001625A1 (en) 2001-06-27 2003-01-02 Intel Corporation Dual-stage comparator unit
US6505183B1 (en) 1999-02-04 2003-01-07 Authoria, Inc. Human resource knowledge modeling and delivery system
US20030007612A1 (en) 2000-03-29 2003-01-09 Garcia Gustavo Manuel Marin Damil Method and apparatus for recording and automated playback of personal agent greetings in a communication-center environment
US20030007625A1 (en) 2000-01-31 2003-01-09 Robert Pines Communication assistance system and method
US20030013438A1 (en) 2001-07-12 2003-01-16 Darby George Eugene Pocket concierge system and method
US6512415B1 (en) 1985-07-10 2003-01-28 Ronald A. Katz Technology Licensing Lp. Telephonic-interface game control system
US20030026409A1 (en) 2001-07-31 2003-02-06 Sbc Technology Resources, Inc. Telephone call processing in an interactive voice response call management system
US20030033382A1 (en) 1999-02-05 2003-02-13 Bogolea Steven C. Interactive communication system
US6526397B2 (en) 1998-06-19 2003-02-25 Nortel Networks Limited Resource management facilitation
US6535601B1 (en) 1998-08-27 2003-03-18 Avaya Technology Corp. Skill-value queuing in a call center
US6539090B1 (en) 1998-10-06 2003-03-25 Lucent Technologies, Inc. Generalized arrangement for routing telecommunications calls
US6539538B1 (en) 1995-11-13 2003-03-25 Concerto Software, Inc. Intelligent information routing system and method
US6542156B1 (en) 1999-07-21 2003-04-01 Avaya Technology Corp. Telephone call center monitoring system with integrated three-dimensional display of multiple split activity data
US6549769B1 (en) 1999-10-29 2003-04-15 Concerto Software, Inc. System and method for integrating text messaging to an outbound call system
US6560649B1 (en) 1999-02-10 2003-05-06 Avaya Technology Corp. Hierarchical service level remediation for competing classes based upon achievement of service level goals
US20030088660A1 (en) 2000-03-01 2003-05-08 Bruce Florman Techniques for load distribution processing for call centers and other processing systems
US6563788B1 (en) 1998-02-17 2003-05-13 Genesys Telecommunications Laboratories, Inc. Method and apparatus for call distribution and override with priority recognition and fairness timing routines
US6563920B1 (en) 1999-12-15 2003-05-13 Avaya Technology Corp. Methods and apparatus for processing of communications in a call center based on variable rest period determinations
US6563916B1 (en) 1998-07-08 2003-05-13 Lucent Technologies Inc. System for transmitting a change in call queued/hold state across a communications network
US6567787B1 (en) 1998-08-17 2003-05-20 Walker Digital, Llc Method and apparatus for determining whether a verbal message was spoken during a transaction at a point-of-sale terminal
US6571240B1 (en) 2000-02-02 2003-05-27 Chi Fai Ho Information processing for searching categorizing information in a document based on a categorization hierarchy and extracted phrases
US6570975B2 (en) 1993-02-22 2003-05-27 Murex Securities, Ltd. Automated telecommunications call processing method
US6570976B2 (en) 1998-01-08 2003-05-27 Kabushiki Kaisha Toshiba Multimedia private branch exchanger and private branch exchange system
US20030099342A1 (en) 2001-11-28 2003-05-29 Sbc Technology Resources, Inc. Method of billing in an abbreviated dialing service
US6574605B1 (en) 1998-11-17 2003-06-03 Citibank, N.A. Method and system for strategic services enterprise workload management
US6577720B1 (en) 1999-12-29 2003-06-10 Nortel Networks Corporation System and method for providing high-speed communications using a public terminal
US6581205B1 (en) 1998-12-17 2003-06-17 International Business Machines Corporation Intelligent compilation of materialized view maintenance for query processing systems
US20030115353A1 (en) 1998-09-11 2003-06-19 Deryugin Vladimir N. Method and apparatus for extended management of state and interaction of a remote knowledge worker from a contact center
US20030115545A1 (en) 1999-02-19 2003-06-19 Lucent Technologies Inc. Dynamic display of data item evaluation
US6584439B1 (en) 1999-05-21 2003-06-24 Winbond Electronics Corporation Method and apparatus for controlling voice controlled devices
US20030120395A1 (en) 2001-12-21 2003-06-26 General Motors Corporation Method and system for managing vehicle control modules through telematics
US6587545B1 (en) 2000-03-04 2003-07-01 Lucent Technologies Inc. System for providing expanded emergency service communication in a telecommunication network
US6587557B1 (en) * 1999-09-07 2003-07-01 Concerto Software, Inc. System and method of distributing outbound telephony services over a computer network
US6594470B1 (en) 1999-10-28 2003-07-15 Nortel Networks Limited System and method for remote management of call center operations
US6597783B1 (en) * 2000-02-01 2003-07-22 Cisco Systems, Inc. System and method for storing, routing, and tracking digital documents in a call center

Family Cites Families (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5295184A (en) * 1991-05-30 1994-03-15 Davox Corporation Dynamically adjustable call pacing system
US5341412A (en) * 1991-10-10 1994-08-23 Executone Information Systems, Inc. Apparatus and a method for predictive call dialing
US5592543A (en) * 1994-06-01 1997-01-07 Davox Corporation Method and system for allocating agent resources to a telephone call campaign
EP0696125A3 (en) * 1994-08-02 1999-06-02 Rockwell International Corporation Telecommunication system with inbound call responsive predictive outdialing system and method
US5594791A (en) * 1994-10-05 1997-01-14 Inventions, Inc. Method and apparatus for providing result-oriented customer service
US5570419A (en) * 1995-10-13 1996-10-29 Intervoice Limited Partnership System and method for an improved predictive dialer
US5940476A (en) * 1996-06-28 1999-08-17 Distributed Software Development, Inc. System and method for identifying an unidentified caller
US5802161A (en) * 1996-03-22 1998-09-01 Austin Logistics Inc. Method and system for optimized scheduling
US5793861A (en) * 1996-06-11 1998-08-11 Executone Information Systems, Inc. Transaction processing system and method
US5822400A (en) * 1996-08-19 1998-10-13 Davox Corporation Call record scheduling system and method
US6046762A (en) * 1997-04-01 2000-04-04 Cosmocom, Inc. Multimedia telecommunication automatic call distribution system
BR9812617A (en) * 1997-06-02 2002-05-28 Broadpoint Communications Inc Communication system for sending promotional messages
US6198814B1 (en) * 1997-10-17 2001-03-06 Debra Ann Marie Gill System and method for entering call outcome records in a computer database in an outbound predictive dialing application
US5991395A (en) * 1997-11-04 1999-11-23 Genesys Telecommunications Laboratories, Inc. Implementation of call-center outbound dialing capability at a telephony network level
US6278776B1 (en) * 1997-12-22 2001-08-21 Ser Solutions Outbound switch pacing
US6310951B1 (en) * 1998-09-25 2001-10-30 Ser Solutions, Inc. Reassignment of agents
US6751297B2 (en) * 2000-12-11 2004-06-15 Comverse Infosys Inc. Method and system for multimedia network based data acquisition, recording and distribution

Patent Citations (185)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6512415B1 (en) 1985-07-10 2003-01-28 Ronald A. Katz Technology Licensing Lp. Telephonic-interface game control system
US4881261A (en) 1988-06-29 1989-11-14 Rockwell International Corporation Method for predictive pacing of calls in a calling system
US5040208A (en) 1989-11-03 1991-08-13 International Business Machines Corporation Coordinated voice and data display having temporary storage of transaction data
US5214688A (en) * 1990-06-05 1993-05-25 Inventions, Inc. Method and apparatus for dynamic and interdependent processing of inbound calls and outbound calls
US5185782A (en) 1991-02-08 1993-02-09 A&T Bell Laboratories ACD arrangement for automatically returning a call at a time specified by the original caller
US5297195A (en) * 1991-10-02 1994-03-22 Teledirect International, Inc. Method and apparatus for automatic telephone scheduling system
US5335269A (en) 1992-03-12 1994-08-02 Rockwell International Corporation Two dimensional routing apparatus in an automatic call director-type system
US5444774A (en) 1992-06-26 1995-08-22 At&T Corp. Interactive queuing sytem for call centers
US5594790A (en) * 1993-01-14 1997-01-14 Davox Corporation Method for selecting and controlling the automatic dialing of a call record campaign
US5499291A (en) 1993-01-14 1996-03-12 At&T Corp. Arrangement for automating call-center agent-schedule-notification and schedule-adherence functions
US5343518A (en) * 1993-01-14 1994-08-30 Davox Corporation System and method for controlling the dialing order of call record lists in an automated dialing system
US5479487A (en) 1993-02-11 1995-12-26 Intervoice Limited Partnership Calling center employing unified control system
US6570975B2 (en) 1993-02-22 2003-05-27 Murex Securities, Ltd. Automated telecommunications call processing method
US5661718A (en) 1993-06-14 1997-08-26 Lucent Technologies Inc. Simultaneous analog and digital communication
US5448555A (en) 1993-06-14 1995-09-05 At&T Corp. Simultaneous analog and digital communication
US5915003A (en) 1993-06-14 1999-06-22 Lucent Technologies Inc. Sketching unit for transmission of sketches and notes over normal telephone lines
US5537436A (en) 1993-06-14 1996-07-16 At&T Corp. Simultaneous analog and digital communication applications
US5440585A (en) 1993-06-14 1995-08-08 At&T Corp. Applications of simultaneous analog and digital communication
US5509055A (en) 1993-06-30 1996-04-16 At&T Corp. Inbound telecommunications services resources management system
US5436965A (en) * 1993-11-16 1995-07-25 Automated Systems And Programming, Inc. Method and system for optimization of telephone contact campaigns
US5533108A (en) 1994-03-18 1996-07-02 At&T Corp. Method and system for routing phone calls based on voice and data transport capability
US5499289A (en) 1994-12-06 1996-03-12 At&T Corp. Systems, methods and articles of manufacture for performing distributed telecommunications
US5574781A (en) 1994-12-08 1996-11-12 At&T Translation indicator for database-queried communications services
US5848143A (en) 1995-03-02 1998-12-08 Geotel Communications Corp. Communications system using a central controller to control at least one network and agent system
US5878130A (en) 1995-03-02 1999-03-02 Geotel Communications Corp Communications system and method for operating same
US5627884A (en) 1995-06-26 1997-05-06 Williams; Mark J. Method for returning inbound calls
US5751795A (en) 1995-08-11 1998-05-12 Lucent Technologies Inc. Broadcasting of information through telephone switching system display messages
US20030021259A1 (en) 1995-10-25 2003-01-30 Alec Miloslavsky Apparatus and methods for coordinating internet protocol telephone and data communications
US6581105B2 (en) 1995-10-25 2003-06-17 Genesys Telecommunications Laboratories, Inc. Apparatus and method for improving e-mail routing in an internet protocol network telephony call-in center
US20020169834A1 (en) 1995-10-25 2002-11-14 Alec Miloslavsky Apparatus and methods for routing electronic mail in a processing center
US20020101866A1 (en) 1995-10-25 2002-08-01 Alec Miloslavsky Method and apparatus for determining and using multiple object states in an intelligent internet protocol telephony network
US5754639A (en) 1995-11-03 1998-05-19 Lucent Technologies Method and apparatus for queuing a call to the best split
US5740238A (en) 1995-11-03 1998-04-14 Lucent Technologies Inc. Method and apparatus for queuing a call to the best backup split
US6539538B1 (en) 1995-11-13 2003-03-25 Concerto Software, Inc. Intelligent information routing system and method
US5838682A (en) 1995-11-28 1998-11-17 Bell Atlantic Network Services, Inc. Method and apparatus for establishing communications with a remote node on a switched network based on hypertext dialing information received from a packet network
US5742674A (en) 1995-12-22 1998-04-21 At&T Corp. Automatic call-back system and method using data indicating best time to call
US5757904A (en) 1996-02-05 1998-05-26 Lucent Technologies Inc. Context-sensitive presentation of information to call-center agents
US5867559A (en) 1996-02-20 1999-02-02 Eis International, Inc. Real-time, on-line, call verification system
US5946386A (en) 1996-03-11 1999-08-31 Xantel Corporation Call management system with call control from user workstation computers
US5825870A (en) 1996-04-05 1998-10-20 Genesys Telecommunications Laboratories Methods and apparatus for implementing a network call center
US5717747A (en) 1996-05-31 1998-02-10 Lucent Technologies Inc. Arrangement for facilitating plug-and-play call features
US6064730A (en) 1996-06-18 2000-05-16 Lucent Technologies Inc. Customer-self routing call center
US5721770A (en) 1996-07-02 1998-02-24 Lucent Technologies Inc. Agent vectoring programmably conditionally assigning agents to various tasks including tasks other than handling of waiting calls
US5757644A (en) 1996-07-25 1998-05-26 Eis International, Inc. Voice interactive call center training method using actual screens and screen logic
US6385646B1 (en) * 1996-08-23 2002-05-07 At&T Corp. Method and system for establishing voice communications in an internet environment
US5903877A (en) 1996-09-30 1999-05-11 Lucent Technologies Inc. Transaction center for processing customer transaction requests from alternative media sources
US5796791A (en) 1996-10-15 1998-08-18 Intervoice Limited Partnership Network based predictive dialing
US6091808A (en) 1996-10-17 2000-07-18 Nortel Networks Corporation Methods of and apparatus for providing telephone call control and information
US6009162A (en) 1996-10-31 1999-12-28 Lucent Technologies Inc. Telecommunication feature for exchange of translation information between a computer and a telecommunication switching system
US6385191B1 (en) 1996-11-14 2002-05-07 Avaya Technology Corp. Extending internet calls to a telephony call center
US6480698B2 (en) 1996-12-02 2002-11-12 Chi Fai Ho Learning method and system based on questioning
US6501937B1 (en) 1996-12-02 2002-12-31 Chi Fai Ho Learning method and system based on questioning
US5987115A (en) 1996-12-03 1999-11-16 Northern Telecom Limited Systems and methods for servicing calls by service agents connected via standard telephone lines
US5732218A (en) 1997-01-02 1998-03-24 Lucent Technologies Inc. Management-data-gathering system for gathering on clients and servers data regarding interactions between the servers, the clients, and users of the clients during real use of a network of clients and servers
US5903641A (en) 1997-01-28 1999-05-11 Lucent Technologies Inc. Automatic dynamic changing of agents' call-handling assignments
US5828747A (en) 1997-01-28 1998-10-27 Lucent Technologies Inc. Call distribution based on agent occupancy
US5930337A (en) 1997-02-04 1999-07-27 Lucent Technologies Inc. Dynamic message-mailbox size variation
US5905793A (en) 1997-03-07 1999-05-18 Lucent Technologies Inc. Waiting-call selection based on anticipated wait times
US6061442A (en) 1997-03-07 2000-05-09 Lucent Technologies Inc. Method and apparatus for improved call control scheduling in a distributed system with dissimilar call processors
US5982873A (en) 1997-03-07 1999-11-09 Lucent Technologies Inc. Waiting-call selection based on objectives
US6014439A (en) 1997-04-08 2000-01-11 Walker Asset Management Limited Partnership Method and apparatus for entertaining callers in a queue
US6301354B1 (en) 1997-04-08 2001-10-09 Walker Digital, Llc Method and apparatus for entertaining callers in a queue
US6088444A (en) 1997-04-11 2000-07-11 Walker Asset Management Limited Partnership Method and apparatus for value-based queuing of telephone calls
US6154530A (en) 1997-04-22 2000-11-28 U.S. Philips Corporation Telecommunication equipment, system and method comprising management means for managing subscriber call-back lists
US5991293A (en) 1997-05-23 1999-11-23 Nortel Networks Corporation Circuit arrangement for providing internet connectivity to a computer in a key telephone system
US5898772A (en) 1997-05-29 1999-04-27 Lucent Technologies Inc. Logical PC agent
US6002749A (en) 1997-05-30 1999-12-14 Nortel Networks Corporation Telephone system integrated text based communication apparatus and systems to establish communication links to TDD and/or TTY devices and other telephone and text server systems
US5943395A (en) 1997-05-30 1999-08-24 Northern Telecom Limited Telephone apparatus, systems, and processes to enhance access for TDD and/or TTY devices
US5940475A (en) 1997-05-30 1999-08-17 Northern Telecom Limited Telephone system integrated text based communication apparatus and system to enhance access for TDD and/or TTY devices
US6078650A (en) 1997-05-30 2000-06-20 Nortel Networks Corporation Telephone system integrated text based communication processes to enhance access for TDD and/or TTY devices
US5933476A (en) 1997-05-30 1999-08-03 Northern Telecom Limited TTY telephone display and related processes systems and apparatus
US5960382A (en) 1997-07-07 1999-09-28 Lucent Technologies Inc. Translation of an initially-unknown message
US6205412B1 (en) 1997-07-09 2001-03-20 Genesys Telecommunications Laboratories, Inc. Methods in computer simulation of telephony systems
US6118861A (en) 1997-08-14 2000-09-12 Nortel Networks Corporation Calling party invoked held call monitoring
US6192050B1 (en) 1997-08-29 2001-02-20 Nortel Networks Limited Method and apparatus for inquiry response via internet
US6188673B1 (en) 1997-09-02 2001-02-13 Avaya Technology Corp. Using web page hit statistics to anticipate call center traffic
US5926539A (en) 1997-09-12 1999-07-20 Genesys Telecommunications Laboratories, Inc. Method and apparatus for determining agent availability based on level of uncompleted tasks
US20010040887A1 (en) 1997-10-09 2001-11-15 Yuri Shtivelman Apparatus and methods enhancing call routing to and within call-centers
US6337858B1 (en) 1997-10-10 2002-01-08 Nortel Networks Limited Method and apparatus for originating voice calls from a data network
US20020194272A1 (en) 1997-11-18 2002-12-19 Min Zhu Method for establishing a communication connection between two or more users via a network of interconnected computers
US6493447B1 (en) 1997-11-21 2002-12-10 Mci Communications Corporation Contact server for call center for syncronizing simultaneous telephone calls and TCP/IP communications
US6188762B1 (en) 1997-12-01 2001-02-13 Stephen Shooster Web call center/PSTN to TCPIP internet network
US6122364A (en) 1997-12-02 2000-09-19 Nortel Networks Corporation Internet network call center
US6052460A (en) 1997-12-17 2000-04-18 Lucent Technologies Inc. Arrangement for equalizing levels of service among skills
US6088441A (en) 1997-12-17 2000-07-11 Lucent Technologies Inc. Arrangement for equalizing levels of service among skills
US6181776B1 (en) 1997-12-24 2001-01-30 Nortel Networks Limited Network management of automatic call distributor resources
US6215784B1 (en) 1997-12-24 2001-04-10 Nortel Networks Limited Method and system for voice call completion using information retrieved from an open application on a computing machine
US6430174B1 (en) 1997-12-26 2002-08-06 Nortel Networks Ltd. Communication system supporting simultaneous voice and multimedia communications and method of operation therefore
US6570976B2 (en) 1998-01-08 2003-05-27 Kabushiki Kaisha Toshiba Multimedia private branch exchanger and private branch exchange system
US6192122B1 (en) 1998-02-12 2001-02-20 Avaya Technology Corp. Call center agent selection that optimizes call wait times
US6002760A (en) 1998-02-17 1999-12-14 Genesys Telecommunications Laboratories, Inc. Intelligent virtual queue
US20020131399A1 (en) 1998-02-17 2002-09-19 Laurent Philonenko Queue prioritization based on competitive user input
US6563788B1 (en) 1998-02-17 2003-05-13 Genesys Telecommunications Laboratories, Inc. Method and apparatus for call distribution and override with priority recognition and fairness timing routines
US6226377B1 (en) 1998-03-06 2001-05-01 Avaya Technology Corp. Prioritized transaction server allocation
US6088442A (en) 1998-03-16 2000-07-11 Lucent Technologies Inc. Automatic wireless alerting on an automatic call distribution center
US6038302A (en) 1998-04-02 2000-03-14 Lucent Technologies Inc. Methods and apparatus for processing phantom calls placed via computer-telephony integration (CTI)
US6163607A (en) 1998-04-09 2000-12-19 Avaya Technology Corp. Optimizing call-center performance by using predictive data to distribute agents among calls
US6173053B1 (en) 1998-04-09 2001-01-09 Avaya Technology Corp. Optimizing call-center performance by using predictive data to distribute calls among agents
US6256299B1 (en) 1998-04-30 2001-07-03 Avaya Technology Corp. Automatic service provider notification of unauthorized terminal activity
US6070012A (en) 1998-05-22 2000-05-30 Nortel Networks Corporation Method and apparatus for upgrading software subsystems without interrupting service
US6292550B1 (en) 1998-06-01 2001-09-18 Avaya Technology Corp. Dynamic call vectoring
US6272216B1 (en) 1998-06-01 2001-08-07 Avaya Technology Corp Customer self routing call center
US6404747B1 (en) 1998-06-02 2002-06-11 Avaya Technology Corp. Integrated audio and video agent system in an automatic call distribution environment
US6233332B1 (en) 1998-06-03 2001-05-15 Avaya Technology Corp. System for context based media independent communications processing
US6480484B2 (en) 1998-06-09 2002-11-12 Avaya Technology Corp. Internet-intranet greeting service
US6526397B2 (en) 1998-06-19 2003-02-25 Nortel Networks Limited Resource management facilitation
US6563916B1 (en) 1998-07-08 2003-05-13 Lucent Technologies Inc. System for transmitting a change in call queued/hold state across a communications network
US6298127B1 (en) 1998-07-13 2001-10-02 Nortel Networks Limited Call transfer and conference with separate billing records per leg
US6567787B1 (en) 1998-08-17 2003-05-20 Walker Digital, Llc Method and apparatus for determining whether a verbal message was spoken during a transaction at a point-of-sale terminal
US6477559B1 (en) 1998-08-21 2002-11-05 Aspect Communications Corporation Method and apparatus for remotely accessing an automatic transaction processing system
US6449341B1 (en) 1998-08-25 2002-09-10 Mci Communications Corporation Apparatus and method for managing a software system via analysis of call center trouble tickets
US6353667B1 (en) 1998-08-27 2002-03-05 Avaya Technology Corp. Minimum interruption cycle time threshold for reserve call center agents
US6535601B1 (en) 1998-08-27 2003-03-18 Avaya Technology Corp. Skill-value queuing in a call center
US6272544B1 (en) 1998-09-08 2001-08-07 Avaya Technology Corp Dynamically assigning priorities for the allocation of server resources to completing classes of work based upon achievement of server level goals
US20030115353A1 (en) 1998-09-11 2003-06-19 Deryugin Vladimir N. Method and apparatus for extended management of state and interaction of a remote knowledge worker from a contact center
US6163606A (en) 1998-09-16 2000-12-19 Lucent Technologies Inc. System for providing virtual called party identification in a voice mail system
US6539090B1 (en) 1998-10-06 2003-03-25 Lucent Technologies, Inc. Generalized arrangement for routing telecommunications calls
US6295353B1 (en) 1998-10-07 2001-09-25 Avaya Technology Corp. Arrangement for efficiently updating status information of a network call-routing system
US6064731A (en) 1998-10-29 2000-05-16 Lucent Technologies Inc. Arrangement for improving retention of call center's customers
US6256381B1 (en) 1998-10-30 2001-07-03 Avaya Technology Corp. System and method for identifying a data record associated with a transferred telephone call
US6574605B1 (en) 1998-11-17 2003-06-03 Citibank, N.A. Method and system for strategic services enterprise workload management
US6327362B1 (en) 1998-11-23 2001-12-04 Lucent Technologies Inc. System and method including dynamic differential treatment in workflows and contact flow
US6473404B1 (en) 1998-11-24 2002-10-29 Connect One, Inc. Multi-protocol telecommunications routing optimization
US6377944B1 (en) 1998-12-11 2002-04-23 Avaya Technology Corp. Web response unit including computer network based communication
US20010000458A1 (en) 1998-12-11 2001-04-26 Yuri Shtivelman Method for estimating telephony system-queue waiting time in an agent level routing environment
US6366666B2 (en) 1998-12-16 2002-04-02 Avaya Technology Corp. Adjustment of call selection to achieve target values for interval-based performance metrics in a call center
US6581205B1 (en) 1998-12-17 2003-06-17 International Business Machines Corporation Intelligent compilation of materialized view maintenance for query processing systems
US6314177B1 (en) 1998-12-22 2001-11-06 Nortel Networks Limited Communications handling center and communications forwarding method using agent attributes
US6353851B1 (en) 1998-12-28 2002-03-05 Lucent Technologies Inc. Method and apparatus for sharing asymmetric information and services in simultaneously viewed documents on a communication system
US6356632B1 (en) 1998-12-31 2002-03-12 Avaya Technology Corp. Call selection and agent selection in a call center based on agent staffing schedule
US20020073155A1 (en) 1999-01-08 2002-06-13 Lucent Technologies Inc. Methods and apparatus for enabling shared web-based interaction in stateful servers
US6359982B1 (en) 1999-01-12 2002-03-19 Avaya Technologies Corp. Methods and apparatus for determining measures of agent-related occupancy in a call center
US6208721B1 (en) 1999-01-22 2001-03-27 Lucent Technologies Inc. Method and apparatus for identifying telephone callers who have been unsuccessful in reaching a called destination
US6560330B2 (en) 1999-02-02 2003-05-06 Avaya Technology Corp. Rules-based queuing of calls to call-handling resources
US6434230B1 (en) 1999-02-02 2002-08-13 Avaya Technology Corp. Rules-based queuing of calls to call-handling resources
US6505183B1 (en) 1999-02-04 2003-01-07 Authoria, Inc. Human resource knowledge modeling and delivery system
US20030033382A1 (en) 1999-02-05 2003-02-13 Bogolea Steven C. Interactive communication system
US6560649B1 (en) 1999-02-10 2003-05-06 Avaya Technology Corp. Hierarchical service level remediation for competing classes based upon achievement of service level goals
US6499023B1 (en) 1999-02-19 2002-12-24 Lucent Technologies Inc. Data item evaluation based on the combination of multiple factors
US20030115545A1 (en) 1999-02-19 2003-06-19 Lucent Technologies Inc. Dynamic display of data item evaluation
US6366668B1 (en) 1999-03-11 2002-04-02 Avaya Technology Corp. Method of routing calls in an automatic call distribution network
US20010038624A1 (en) 1999-03-19 2001-11-08 Greenberg Jeffrey Douglas Internet telephony for ecommerce
US6502133B1 (en) 1999-03-25 2002-12-31 Lucent Technologies Inc. Real-time event processing system with analysis engine using recovery information
US6449618B1 (en) 1999-03-25 2002-09-10 Lucent Technologies Inc. Real-time event processing system with subscription model
US6496831B1 (en) 1999-03-25 2002-12-17 Lucent Technologies Inc. Real-time event processing system for telecommunications and other applications
US6349205B1 (en) 1999-04-15 2002-02-19 Lucent Technologies Inc. Method for converting an existing subscriber to a wireless communications system
US6473505B1 (en) 1999-04-27 2002-10-29 Sprint Communications Company L.P. Call processing system for handling calls to a call center
US6459788B1 (en) 1999-04-27 2002-10-01 Sprint Communications Company L.P. Call center resource processor
US6584439B1 (en) 1999-05-21 2003-06-24 Winbond Electronics Corporation Method and apparatus for controlling voice controlled devices
US6459774B1 (en) 1999-05-25 2002-10-01 Lucent Technologies Inc. Structured voicemail messages
US6240391B1 (en) 1999-05-25 2001-05-29 Lucent Technologies Inc. Method and apparatus for assembling and presenting structured voicemail messages
US20030002654A1 (en) 1999-06-17 2003-01-02 Torba Dmitriy A. Method and apparatus for providing fair access to agents in a communication center
US6445788B1 (en) 1999-06-17 2002-09-03 Genesys Telecommunications Laboratories, Inc. Method and apparatus for providing fair access to agents in a communication center
US6392666B1 (en) 1999-07-21 2002-05-21 Avaya Technology Corp. Telephone call center monitoring system allowing real-time display of summary views and interactively defined detailed views
US6542156B1 (en) 1999-07-21 2003-04-01 Avaya Technology Corp. Telephone call center monitoring system with integrated three-dimensional display of multiple split activity data
US6498921B1 (en) 1999-09-01 2002-12-24 Chi Fai Ho Method and system to answer a natural-language question
US6587557B1 (en) * 1999-09-07 2003-07-01 Concerto Software, Inc. System and method of distributing outbound telephony services over a computer network
US6463346B1 (en) 1999-10-08 2002-10-08 Avaya Technology Corp. Workflow-scheduling optimization driven by target completion time
US6389132B1 (en) 1999-10-13 2002-05-14 Avaya Technology Corp. Multi-tasking, web-based call center
US6594470B1 (en) 1999-10-28 2003-07-15 Nortel Networks Limited System and method for remote management of call center operations
US6549769B1 (en) 1999-10-29 2003-04-15 Concerto Software, Inc. System and method for integrating text messaging to an outbound call system
US6480601B1 (en) 1999-11-12 2002-11-12 Concerto Software, Inc. Voice and data transfer from outbound dialing to inbound ACD queue
US6563920B1 (en) 1999-12-15 2003-05-13 Avaya Technology Corp. Methods and apparatus for processing of communications in a call center based on variable rest period determinations
US6408066B1 (en) 1999-12-15 2002-06-18 Lucent Technologies Inc. ACD skill-based routing
US6577720B1 (en) 1999-12-29 2003-06-10 Nortel Networks Corporation System and method for providing high-speed communications using a public terminal
US20030007625A1 (en) 2000-01-31 2003-01-09 Robert Pines Communication assistance system and method
US6597783B1 (en) * 2000-02-01 2003-07-22 Cisco Systems, Inc. System and method for storing, routing, and tracking digital documents in a call center
US6571240B1 (en) 2000-02-02 2003-05-27 Chi Fai Ho Information processing for searching categorizing information in a document based on a categorization hierarchy and extracted phrases
US6385302B1 (en) 2000-02-08 2002-05-07 Lucent Technologies Inc. System and method for handling special number calls using on-demand answering stations
US20010021646A1 (en) 2000-02-08 2001-09-13 Lucent Technologies Inc. System and method for routing special number calls in a telecommunication network
US20030088660A1 (en) 2000-03-01 2003-05-08 Bruce Florman Techniques for load distribution processing for call centers and other processing systems
US6587545B1 (en) 2000-03-04 2003-07-01 Lucent Technologies Inc. System for providing expanded emergency service communication in a telecommunication network
US6470077B1 (en) 2000-03-13 2002-10-22 Avaya Technology Corp. Apparatus and method for storage and accelerated playback of voice samples in a call center
US20020196277A1 (en) 2000-03-21 2002-12-26 Sbc Properties, L.P. Method and system for automating the creation of customer-centric interfaces
US20030007612A1 (en) 2000-03-29 2003-01-09 Garcia Gustavo Manuel Marin Damil Method and apparatus for recording and automated playback of personal agent greetings in a communication-center environment
US20020141561A1 (en) 2000-04-12 2002-10-03 Austin Logistics Incorporated Method and system for self-service scheduling of inbound inquiries
US20020010645A1 (en) 2000-07-12 2002-01-24 David Hagen Backend commerce engine
US20020101854A1 (en) 2001-01-30 2002-08-01 Joseph Siegrist Remote media control for voice over internet telephony and related applications
US20020183072A1 (en) 2001-04-17 2002-12-05 Galia Steinbach BeyondguideTM method and system
US20020194047A1 (en) 2001-05-17 2002-12-19 International Business Machines Corporation End-to-end service delivery (post-sale) process
US20030001625A1 (en) 2001-06-27 2003-01-02 Intel Corporation Dual-stage comparator unit
US20030013438A1 (en) 2001-07-12 2003-01-16 Darby George Eugene Pocket concierge system and method
US20030026409A1 (en) 2001-07-31 2003-02-06 Sbc Technology Resources, Inc. Telephone call processing in an interactive voice response call management system
US20030099342A1 (en) 2001-11-28 2003-05-29 Sbc Technology Resources, Inc. Method of billing in an abbreviated dialing service
US20030120395A1 (en) 2001-12-21 2003-06-26 General Motors Corporation Method and system for managing vehicle control modules through telematics

Non-Patent Citations (6)

* Cited by examiner, † Cited by third party
Title
"C@ll Center Solutions-1998 Product of the Year"; https://www.praxon.com/news/art-2-99prodofyear.htm.
"Choosing the Best: CTI® Magazine's 1998 Products of the Year"; https://www.tmcnet.com/articles/0199/ctipoty98.htm.
CentreVu® Advocate; "PowerCall Center Routing that Leaves Nothing to Chance"; Lucent Technologies 1998.
CentreVu® AdvocatesSM Research Simulation white paper; "CentreVu Advocate Research Simulation, Environments with CentreVu Advocate"; Lucent Technologies 1999.
Foster, Robin Harris and De Reyt, Stanny; "Re-inventing the Call Centre with Predicive and Adaptive Execution"; The Journal of the Institution of British Telecommunication Engineers, vol. 18, Part 2, pp. 180-184 1999.
Lucent's CentreVu® AdvocateSM white paper; Lucent's CentreVu Advocate. Breakthrough Solutions for Your Success; Lucent Technologies 1999.

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
USRE46420E1 (en) * 2000-07-11 2017-05-30 Noble Systems Corporation Method and system for distributing outbound telephone calls
USRE46467E1 (en) * 2000-07-11 2017-07-04 Noble Systems Corporation Method and system for distributing outbound telephone calls
USRE46478E1 (en) * 2000-07-11 2017-07-11 Noble Systems Corporation System and method for preemptive goals based routing of contact records

Also Published As

Publication number Publication date
US20030198336A1 (en) 2003-10-23
US8175258B2 (en) 2012-05-08
US7054434B2 (en) 2006-05-30
US20060256951A1 (en) 2006-11-16

Similar Documents

Publication Publication Date Title
USRE44979E1 (en) System and method for common account based routing of contact records
USRE46478E1 (en) System and method for preemptive goals based routing of contact records
US7715546B2 (en) System and method for updating contact records
USRE46420E1 (en) Method and system for distributing outbound telephone calls
US7502460B2 (en) Method and system for distributing outbound telephone calls
US6535492B2 (en) Method and apparatus for assigning agent-led chat sessions hosted by a communication center to available agents based on message load and agent skill-set
US10447855B1 (en) Agent training sensitive call routing system
US9838537B2 (en) System for indicating priority levels for transaction and task engagement in a call center
US8259924B2 (en) System for creation and dynamic management of incoming interactions
US6766012B1 (en) System and method for allocating agent resources to a telephone call campaign based on agent productivity
US7418094B2 (en) Method and apparatus for multimedia interaction routing according to agent capacity sets
US6128380A (en) Automatic call distribution and training system
US6937715B2 (en) Contact center management
US12101440B1 (en) Dynamic precision queue routing
US20070055777A1 (en) Multi-media contact channel in agent state control system and method for use in a contact center
EP1111526A2 (en) Dynamic distributed resources management system and method of provisioning therefor

Legal Events

Date Code Title Description
ZAAA Notice of allowance and fees due

Free format text: ORIGINAL CODE: NOA

ZAAB Notice of allowance mailed

Free format text: ORIGINAL CODE: MN/=.

AS Assignment

Owner name: WELLS FARGO CAPITAL FINANCE, LLC, CALIFORNIA

Free format text: AMENDMENT;ASSIGNOR:NOBLE SYSTEMS CORPORATION;REEL/FRAME:035812/0507

Effective date: 20150528

FPAY Fee payment

Year of fee payment: 4

FEPP Fee payment procedure

Free format text: ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 8

AS Assignment

Owner name: JEFFERIES FINANCE LLC, NEW YORK

Free format text: SECOND LIEN PATENT SECURITY AGREEMENT;ASSIGNORS:NOBLE SYSTEMS CORPORATION;ASPECT SOFTWARE, INC.;REEL/FRAME:057674/0664

Effective date: 20210506

Owner name: JEFFERIES FINANCE LLC, NEW YORK

Free format text: FIRST LIEN PATENT SECURITY AGREEMENT;ASSIGNORS:NOBLE SYSTEMS CORPORATION;ASPECT SOFTWARE, INC.;REEL/FRAME:057261/0093

Effective date: 20210506

AS Assignment

Owner name: NOBLE SYSTEMS CORPORATION, GEORGIA

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:WELLS FARGO CAPITAL FINANCE, LLC;REEL/FRAME:056193/0363

Effective date: 20210506

FEPP Fee payment procedure

Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

AS Assignment

Owner name: NOBLE SYSTEMS, LLC, A DELAWARE LIMITED LIABILITY COMPANY, GEORGIA

Free format text: CERTIFICATE OF CONVERSION;ASSIGNOR:NOBLE SYSTEMS CORPORATION, A GEORGIA CORPORATION;REEL/FRAME:066794/0435

Effective date: 20240305

AS Assignment

Owner name: ALVARIA CAYMAN (CX), GEORGIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:NOBLE SYSTEMS, LLC;REEL/FRAME:066850/0556

Effective date: 20240320

Owner name: NOBLE SYSTEMS, LLC, GEORGIA

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:JEFFRIES FINANCE LLC;REEL/FRAME:066850/0428

Effective date: 20240320

Owner name: ALVARIA, INC., GEORGIA

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:JEFFRIES FINANCE LLC;REEL/FRAME:066850/0428

Effective date: 20240320

Owner name: NOBLE SYSTEMS, LLC, GEORGIA

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:JEFFRIES FINANCE LLC;REEL/FRAME:066850/0384

Effective date: 20240320

Owner name: ALVARIA, INC., GEORGIA

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:JEFFRIES FINANCE LLC;REEL/FRAME:066850/0384

Effective date: 20240320

Owner name: JEFFERIES FINANCE LLC, NEW YORK

Free format text: PATENT SECURITY AGREEMENT;ASSIGNORS:ALVARIA CAYMAN (WEM);ALVARIA CAYMAN (CXIP);REEL/FRAME:066850/0334

Effective date: 20240320

LAPS Lapse for failure to pay maintenance fees

Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY