US20150124953A1 - System and method for maximizing efficiency of call transfer speed - Google Patents
System and method for maximizing efficiency of call transfer speed Download PDFInfo
- Publication number
- US20150124953A1 US20150124953A1 US14/596,774 US201514596774A US2015124953A1 US 20150124953 A1 US20150124953 A1 US 20150124953A1 US 201514596774 A US201514596774 A US 201514596774A US 2015124953 A1 US2015124953 A1 US 2015124953A1
- Authority
- US
- United States
- Prior art keywords
- customer
- call
- batch
- transferred
- notification
- 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.)
- Granted
Links
- 238000000034 method Methods 0.000 title claims abstract description 115
- 238000012546 transfer Methods 0.000 title abstract description 79
- 238000004891 communication Methods 0.000 claims abstract description 30
- 238000012913 prioritisation Methods 0.000 claims 25
- 239000003795 chemical substances by application Substances 0.000 description 259
- 230000006870 function Effects 0.000 description 41
- 238000005516 engineering process Methods 0.000 description 15
- 230000007246 mechanism Effects 0.000 description 8
- 230000008569 process Effects 0.000 description 8
- 230000000977 initiatory effect Effects 0.000 description 7
- 238000003825 pressing Methods 0.000 description 7
- 230000003287 optical effect Effects 0.000 description 6
- 230000009471 action Effects 0.000 description 5
- 230000009286 beneficial effect Effects 0.000 description 5
- 238000010586 diagram Methods 0.000 description 5
- 238000012552 review Methods 0.000 description 4
- 230000000644 propagated effect Effects 0.000 description 3
- 230000005540 biological transmission Effects 0.000 description 2
- 238000004590 computer program Methods 0.000 description 2
- 230000001934 delay Effects 0.000 description 2
- 230000002452 interceptive effect Effects 0.000 description 2
- 238000012423 maintenance Methods 0.000 description 2
- 238000007726 management method Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 230000002093 peripheral effect Effects 0.000 description 2
- 239000004065 semiconductor Substances 0.000 description 2
- 238000012549 training Methods 0.000 description 2
- 241001522296 Erithacus rubecula Species 0.000 description 1
- 238000013475 authorization Methods 0.000 description 1
- 230000006399 behavior Effects 0.000 description 1
- 230000004397 blinking Effects 0.000 description 1
- 230000000903 blocking effect Effects 0.000 description 1
- 239000000872 buffer Substances 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 239000003086 colorant Substances 0.000 description 1
- 238000012790 confirmation Methods 0.000 description 1
- 238000013523 data management Methods 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 238000012544 monitoring process Methods 0.000 description 1
- 239000013307 optical fiber Substances 0.000 description 1
- 238000012545 processing Methods 0.000 description 1
- 230000004044 response Effects 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
- 238000012384 transportation and delivery Methods 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M3/00—Automatic or semi-automatic exchanges
- H04M3/42—Systems providing special services or facilities to subscribers
- H04M3/50—Centralised arrangements for answering calls; Centralised arrangements for recording messages for absent or busy subscribers ; Centralised arrangements for recording messages
- H04M3/51—Centralised call answering arrangements requiring operator intervention, e.g. call or contact centers for telemarketing
- H04M3/523—Centralised call answering arrangements requiring operator intervention, e.g. call or contact centers for telemarketing with call distribution or queueing
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M3/00—Automatic or semi-automatic exchanges
- H04M3/42—Systems providing special services or facilities to subscribers
- H04M3/50—Centralised arrangements for answering calls; Centralised arrangements for recording messages for absent or busy subscribers ; Centralised arrangements for recording messages
- H04M3/51—Centralised call answering arrangements requiring operator intervention, e.g. call or contact centers for telemarketing
- H04M3/5158—Centralised call answering arrangements requiring operator intervention, e.g. call or contact centers for telemarketing in combination with automated outdialling systems
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M3/00—Automatic or semi-automatic exchanges
- H04M3/42—Systems providing special services or facilities to subscribers
- H04M3/50—Centralised arrangements for answering calls; Centralised arrangements for recording messages for absent or busy subscribers ; Centralised arrangements for recording messages
- H04M3/51—Centralised call answering arrangements requiring operator intervention, e.g. call or contact centers for telemarketing
- H04M3/5183—Call or contact centers with computer-telephony arrangements
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M3/00—Automatic or semi-automatic exchanges
- H04M3/42—Systems providing special services or facilities to subscribers
- H04M3/58—Arrangements for transferring received calls from one subscriber to another; Arrangements affording interim conversations between either the calling or the called party and a third party
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M2201/00—Electronic components, circuits, software, systems or apparatus used in telephone systems
- H04M2201/14—Delay circuits; Timers
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M2201/00—Electronic components, circuits, software, systems or apparatus used in telephone systems
- H04M2201/38—Displays
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M2203/00—Aspects of automatic or semi-automatic exchanges
- H04M2203/35—Aspects of automatic or semi-automatic exchanges related to information services provided via a voice call
- H04M2203/357—Autocues for dialog assistance
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M2203/00—Aspects of automatic or semi-automatic exchanges
- H04M2203/40—Aspects of automatic or semi-automatic exchanges related to call centers
- H04M2203/404—Collaboration among agents
Definitions
- the present invention is generally related to call centers, and more particularly, is related to efficient handling of call center calls.
- the talker to allow the talker to have a productive call with the customer, it is beneficial for the talker to view data regarding the customer. Since the customer data is displayed at the same time as when the call is transferred or a short time after the call is transferred, the talker is at a disadvantage and not capable of preparing to handle the call effectively ahead of time.
- the foregoing fact causes the talker to react to a transferred call with a delay since the talker has to review the customer data after the call is transferred.
- the foregoing facts reduce effectiveness of the talker in performing the important objectives of: 1) making sure that the customer does not know that there was a dialing agent involved in making the call; and, 2) being prepared to pitch the customer effectively based on past notes regarding a history and facts regarding the customer. Therefore, there is a need for a system and method that allows the talker to be prepared prior to when the customer call is transferred.
- Prior systems and methods also transfer all attributes of customer data when a call is transferred. Such transfer of all attributes of customer data through the network is burdensome and takes time, which in turn introduces delay in transferring customer data. Such delay causes slowness in the talker responding when the call is actually transferred. Thus, there is a need for a system and method that minimizes the amount of customer data that needs to be transferred through the network, thereby increasing the speed of data transfer.
- Embodiments of the present invention provide a system and method for maximizing efficiency of call transfer from being between a customer and a dialing agent to being between the customer and a talker.
- One embodiment of the system contains a dialing agent computer, a talker computer, a central data server, and a central voice server.
- the dialing agent computer has a memory, and a processor configured by the memory to provide a notification that a dialed customer has been connected (referred to herein as a connected customer) via a call and is ready for a call transfer, wherein the dialing agent computer is used by a dialing agent.
- the talker computer has a memory, and a processor configured by the memory to receive a first customer identification associated with the dialed customer prior to or at the same time as dialing of the customer and to receive a second customer identification associated with the connected customer after the connected customer has been connected to the dialing agent, wherein the talker computer is used by a talker.
- the central data server contains a memory, and a processor configured by the memory to perform the steps of: receiving the notification from the dialing agent computer confirming that the dialed customer has been connected; transferring the first customer identification associated with the dialed customer to the talker computer prior to or at the same time as dialing the dialed customer for purposes of highlighting a customer record on the talker computer in a first manner; and after the dialing agent computer acknowledges connection to the dialed customer, transferring the second customer identification associated with the connected customer to the talker computer for purposes of highlighting a customer record on the talker computer in a second manner.
- the talker computer Prior to the dialing agent providing the notification that the dialing agent is dialing the dialed customer, the talker computer has stored therein data associated with the connected customer.
- the present invention can also be viewed as providing methods for maximizing efficiency of call transfer from being between a customer and a dialing agent, to being between the customer and a talker.
- one embodiment of such a method can be broadly summarized by the following steps: entering a dialing agent and a talker into a campaign to maintain direct communication with the dialing agent and with the talker; calling a customer via use of a dialing agent device; receiving from the dialing agent a request to transfer a connected customer from communicating with the dialing agent to communicating with a talker; and after receiving the request to transfer, transmitting an identification of a customer record associated with the connected customer to a talker computer for identifying the customer record, where the customer record has been previously stored on the talker computer prior to receiving the request to transfer.
- FIG. 1 is a schematic diagram illustrating a system for maximizing efficiency of call transfer speed in accordance with the present invention.
- FIG. 2 is a block diagram further illustrating a general purpose computer.
- FIG. 3 is a flowchart illustrating an initiation process performed by the central data server of FIG. 1 , in accordance with the first exemplary embodiment of the present invention.
- FIG. 4 is an exemplary screen view illustrating an interface for creating a customer list based on specific search criteria, which may be viewed by a party logging into the central data server and selecting to create a customer list.
- FIG. 5 is an exemplary screen view illustrating an interface for creating and scheduling a campaign specifying one or more talker and one or more dialing agent.
- FIG. 6 is a flowchart illustrating a method for joining a campaign, in accordance with the first exemplary embodiment of the present invention.
- FIG. 7 is an exemplary screen view illustrating an interface for the dialing agent or talker to select and join a campaign.
- FIG. 8 is an example of a screenview illustrating an interface provided to a dialing agent while the dialing agent is attempting to join a campaign, where the dialing agent is forced to wait until the talker joins the campaign.
- FIG. 9 is an example of a screenview illustrating an interface provided to a dialing agent after the talker joins the campaign.
- FIG. 10 is an example of a screenview illustrating an interface provided to a talker after the talker joins a campaign using the talker computer, but where the talker is yet to join the voice conference bridge using the talker telephone.
- FIG. 11 is an example of a screenview illustrating an interface provided to a talker after the talker joins a campaign using the talker computer, and after the talker has joined the voice conference bridge using the talker telephone.
- FIG. 12 is a flowchart illustrating actions initiated and performed during initiation of a campaign, in accordance with the first exemplary embodiment of the present invention.
- FIG. 13 is an example of a screenview illustrating an interface provided to a dialing agent during the dialing of a customer.
- FIG. 14 is a flowchart illustrating a process of handling a call after dialing by the central voice server, in accordance with the first exemplary embodiment of the present invention.
- FIG. 15 is an example of a screenview illustrating an interface provided to talker when 3 customer records dialed by dialing agents are highlighted and talker reviewing customer notes history, ahead of call transfer.
- FIG. 16 is an example of a screenview illustrating an interface provided to talker when a transferred customer's record is shaded differently to differentiate from the other two customer records that are being dialed.
- the present invention provides a system and method for maximizing speed of transferring a call from taking place between a dialing agent and a customer, to taking place between a talker and a customer, by providing customer data to the talker ahead of the call transfer, minimizing the amount of customer data transferred, and minimizing the delay associated with talker selection at the time of call transfer by knowing ahead of time which talker to transfer the call to.
- customer data is displayed in a talker screen ahead of call transfer allowing the talker to be prepared by reviewing customer data, such as, for example, notes history and the like, ahead of call transfer.
- Customer list A list of customers.
- Dial A telephone call made to a customer in the customer list.
- Connect A telephone call answered by a live customer.
- Dialing agent Each person who is the first person that handles a call made to a customer and navigates the call (through phone voice menus, phone operators, voicemails, wrong phone numbers, and the like) until the call reaches the correct target customer on the customer list, while the system may dial the telephone number of the customer and establishes connection between the person's phone and customer in the customer list, where the person transfers a live customer call to a talker, via a central voice server.
- Talker The person waiting in a voice conference bridge who accepts a transferred telephone call and speaks to a customer after the transfer of the telephone call.
- Campaign The session when the dialing agent and the talker work together, in which the dialing agent, via a central voice server, dials the customers and transfers the call between the dialing agent and the customer to the call between the talker and the customer.
- Dialing Agent Software The software component of a dialing agent computer that provides functionality necessary for performance by the dialing agent, in accordance with the present system and method.
- Talker Software The software component of a talker computer that provides functionality for performance by the talker, in accordance with the present system and method.
- step is either performed by: i) a dialing agent through the use of dialing agent software; ii) a dialing agent through the use of a dialing agent telephone; or iii) dialing agent software automatically without a dialing agent initiating a step.
- step is either performed by: i) a dialing agent through the use of dialing agent software; ii) a dialing agent through the use of a dialing agent telephone; or iii) dialing agent software automatically without a dialing agent initiating a step.
- dialing agent software automatically without a dialing agent initiating a step.
- FIG. 1 is a schematic diagram illustrating a system 10 for maximizing the efficiency of the call transfer speed through communicating customer data to the talker ahead of call transfer, minimizing data transfer delay, and minimizing talker selection delay, in accordance with the present invention.
- the system 10 includes a dialing agent computer 20 having dialing agent software stored therein, a dialing agent telephone 22 , a talker computer 24 having talker software stored therein, a talker telephone 26 , a central data server 100 , a central voice server 150 , and a customer telephone 200 .
- a computer may be any device having a memory and processor, and being able to store therein functionality associated with software. Examples of computers may include, but are not limited to, a desktop computer, a portable computer such as a laptop computer, or a personal data assistant.
- FIG. 2 is a block diagram further illustrating a general purpose computer. It should be noted that functionality of the present system and method can be implemented in software, firmware, hardware, or a combination thereof.
- FIG. 1 illustrates three dialing agent computers 20 A, 20 B, 20 C, three dialing agent telephones 22 A, 22 B, 22 C, and three customer telephones 200 A, 200 B, 200 C.
- a telephone can be a traditional analog hardware telephone, digital hardware telephone, a software telephone (such as session initiation protocol (SIP) client software), or the like that could be used to communicate human voice. Since the capability of a telephone could potentially be implemented using a piece of software executed in a computer, the telephone and computer need not be two different devices and instead, both can be in one computer device.
- SIP session initiation protocol
- the central voice server 150 can be a traditional PBX (Private Branch Exchange) that has the capability of performing switching functions based on commands received through CTI (Computer Telephony Interface) or software based PBX, or the like.
- PBX Primary Branch Exchange
- CTI Computer Telephony Interface
- PBX software based PBX
- the central data server 100 contains components similar to a computer, such as, but not limited to, a memory, processor, local bus, input/output devices, and a storage device.
- a computer such as, but not limited to, a memory, processor, local bus, input/output devices, and a storage device.
- a detailed description of a generic computer structure is provided hereinbelow.
- the storage capability and structure of the storage device within the central data server 100 may be different from that of a standard generic computer storage device, however, one having ordinary skill in the art would know such structure and differences.
- the central data server 100 may store therein a list of customers for contacting, as well as data regarding the customers.
- Such data may include data that is typically used in marketing such as, but not limited to, account name, contact full name, address, phone number, date last contacted, notes regarding results of the last communication, and other data.
- the central voice server 150 Since the capability of the central voice server 150 could be implemented using software executed in a computer, the central data server 100 and central voice server 150 need not be two different devices and instead both could be in one computer.
- Telephone communication links 12 , 14 , and 16 could be implemented using traditional analog telephone lines or digital telephone lines utilizing various digital communication protocols such as SIP, PRI (Primary Rate Interface), or the like.
- computer communication links 11 and 13 could be implemented using a LAN (Local Area Network), a WAN (Wide Area Network), mobile network, or the like.
- a central server communication link 15 may also be provided for communication between the central data server 100 and the central voice server 150 .
- the central server communication link 15 can be implemented using computer communication links or phone communication links described above.
- FIG. 2 is a block diagram further illustrating a general purpose computer 300 .
- the computer 300 includes a processor 302 , memory 310 , storage device 304 , and one or more input and/or output (I/O) devices 306 (or peripherals) that are communicatively coupled via a local interface 308 .
- the local interface 308 can be, for example but not limited to, one or more buses or other wired or wireless connections, as is known in the art.
- the local interface 308 may have additional elements, which are omitted for simplicity, such as controllers, buffers (caches), drivers, repeaters, and receivers, to enable communications. Further, the local interface 308 may include address, control, and/or data connections to enable appropriate communications among the aforementioned components.
- the processor 302 is a hardware device for executing software, particularly that stored in the memory 310 .
- the processor 302 can be any custom made or commercially available processor, a central processing unit (CPU), an auxiliary processor among several processors associated with the computer 300 , a semiconductor based microprocessor (in the form of a microchip or chip set), a macroprocessor, or generally any device for executing software instructions.
- the memory 310 can include any one or combination of volatile memory elements (e.g., random access memory (RAM, such as DRAM, SRAM, SDRAM, etc.)) and nonvolatile memory elements (e.g., ROM, hard drive, tape, CDROM, etc.). Moreover, the memory 310 may incorporate electronic, magnetic, optical, and/or other types of storage media. Note that the memory 310 can have a distributed architecture, where various components are situated remote from one another, but can be accessed by the processor 302 .
- the software 350 in the memory 310 may include one or more separate programs, each of which contains an ordered listing of executable instructions for implementing logical functions of the system, as described below.
- the software 350 would contain an ordered listing of executable instructions for implementing logical functions required of the dialing agent computer 20 , as described below.
- the software 350 would contain an ordered listing of executable instructions for implementing logical functions required of the talker computer 24 , as described below.
- the software 350 would contain an ordered listing of executable instructions for implementing logical functions required of the central data server 100 , as described below.
- software of the dialing agent computer 20 , software of the talker computer 24 , and software of the central data server 100 may instead be one software package having separate modules to perform functionality of the dialing agent computer 20 , the talker computer 24 , and the central data server 100 , respectively.
- the memory 310 may contain an operating system (O/S) 312 .
- the operating system 312 essentially controls the execution of computer programs and provides scheduling, input-output control, file and data management, memory management, and communication control and related services.
- Functionality of the computer may be provided by a source program, executable program (object code), script, or any other entity containing a set of instructions to be performed.
- a source program then the program needs to be translated via a compiler, assembler, interpreter, or the like, which may or may not be included within the memory 310 , so as to operate properly in connection with the O/S 312 .
- functionality of the computer can be written as (a) an object oriented programming language, which has classes of data and methods, or (b) a procedure programming language, which has routines, subroutines, and/or functions.
- the I/O devices 306 may include input devices, for example but not limited to, a microphone, a keyboard, mouse, scanner, joystick or other input device. Furthermore, the I/O devices 306 may also include output devices, for example but not limited to, a display, or other output devices. The I/O devices 306 may further include devices that communicate via both inputs and outputs, for instance but not limited to, a modulator/demodulator (modem; for accessing another device, system, or network), a radio frequency (RF) or other transceiver, a telephonic interface, a bridge, a router, or other devices that function both as an input and an output.
- modem for accessing another device, system, or network
- RF radio frequency
- the processor 302 When the computer 300 is in operation, the processor 302 is configured to execute the software 350 stored within the memory 310 , to communicate data to and from the memory 310 , and to generally control operations of the computer 300 pursuant to the software 350 .
- the software 350 and the O/S 312 in whole or in part, but typically the latter, are read by the processor 302 , perhaps buffered within the processor 302 , and then executed.
- a computer readable medium is an electronic, magnetic, optical, or other physical device or means that can contain or store a computer program for use by or in connection with a computer related system or method.
- the functionality can be embodied in any computer-readable medium for use by or in connection with an instruction execution system, apparatus, or device, such as a computer-based system, processor-containing system, or other system that can fetch the instructions from the instruction execution system, apparatus, or device and execute the instructions.
- a “computer-readable medium” can be any means that can store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
- the computer readable medium can be, for example but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation medium. More specific examples (a nonexhaustive list) of the computer-readable medium would include the following: an electrical connection (electronic) having one or more wires, a portable computer diskette (magnetic), a random access memory (RAM) (electronic), a read-only memory (ROM) (electronic), an erasable programmable read-only memory (EPROM, EEPROM, or Flash memory) (electronic), an optical fiber (optical), and a portable compact disc read-only memory (CDROM) (optical).
- an electrical connection having one or more wires
- a portable computer diskette magnetic
- RAM random access memory
- ROM read-only memory
- EPROM erasable programmable read-only memory
- EPROM erasable programmable read-only memory
- CDROM portable compact disc read-only memory
- the computer-readable medium could even be paper or another suitable medium upon which the program is printed, as the program can be electronically captured, via for instance optical scanning of the paper or other medium, then compiled, interpreted or otherwise processed in a suitable manner if necessary, and then stored in a computer memory.
- the functionality of the computer is implemented in hardware
- the functionality can be implemented with any or a combination of the following technologies, which are each well known in the art: a discrete logic circuit(s) having logic gates for implementing logic functions upon data signals, an application specific integrated circuit (ASIC) having appropriate combinational logic gates, a programmable gate array(s) (PGA), a field programmable gate array (FPGA), or other technologies.
- ASIC application specific integrated circuit
- PGA programmable gate array
- FPGA field programmable gate array
- FIG. 3 is a flowchart 400 illustrating an initiation process performed by the central data server 100 in order to maximize efficiency in call transfers.
- any process descriptions or blocks in flowcharts should be understood as representing modules, segments, portions of code, or steps that include one or more instructions for implementing specific logical functions in the process, and alternative implementations are included within the scope of the present invention in which functions may be executed out of order from that shown or discussed, including substantially concurrently or in reverse order, depending on the functionality involved, as would be understood by those reasonably skilled in the art of the present invention. In addition, it may be the case that a function may be skipped.
- customer data that is used for dialing customers is made available in the central data server 100 .
- Customer data may be imported into the central data server 100 one or more customer records at a time from one or more file, or each customer record of the customer data may be individually entered directly into the central data server 100 .
- One having ordinary skill in the art would appreciate that other methods may be used to populate customer data into the central data server 100 .
- the central data server 100 creates a customer list for use in a campaign. Creation of the customer list is based on specific criteria that is important to selecting an appropriate customer for marketing purposes. As an example, if calls are being made for purposes of speaking with potential purchasers of male shaving products, it might be beneficial to have the customer list include only males over the age of sixteen. As a way of another example, if calls are being made for purposes of speaking with potential purchasers of office supplies, it might be beneficial to have the customer list include only customers whose job function is related to purchasing office supplies for their businesses.
- the central data server 100 may use any known methods for creating the customer list, such as, but not limited to, indexing the customer list based upon key words and querying the customer list based on specific search criteria.
- the customer list may be created by a user of the present system.
- a talker may log into the central data server 100 , via use of the talker computer 24 and associated software, for creating of a customer list.
- FIG. 4 is an exemplary screen view illustrating an interface 450 for creating a customer list based on specific search criteria, which may be viewed by a party logging into the central data server 100 and selecting to create a customer list.
- the interface 450 contains a name field 452 for providing a name for the customer list, a description field 454 for describing the customer list, a search condition field 456 for specifying how to search the customers within the central data server 100 in creating the customer list, and a sort field 458 for sorting the resulting customers. It should be noted that there could be more than one search condition field and more than one sort field.
- a campaign may be created.
- a campaign is created by a user of the central data server 100 selecting to create a campaign and the central data server 100 creating the campaign after the user has provided specific requested information for creation of the campaign.
- the user may be a talker that logs into the central data server 100 , via use of the talker computer 24 and associated software, for creating a campaign.
- dialing agents, talkers, and time slots are selected.
- a campaign may be created in the system by scheduling specific time with one or more dialing agents to dial a specific customer list, transfer calls to specific talkers, and update the customer information.
- FIG. 5 is an exemplary screen view illustrating an interface 470 for creating and scheduling a campaign specifying one or more talker and one or more dialing agent.
- the interface 470 contains: a campaign name field 472 , for identifying the name of the campaign; a campaign type field 474 , for identifying the type of campaign for classification and reporting purposes; a start time field 476 for defining the start time of the campaign (date and time in the day); an end time field 478 for defining the end time of the campaign (data and time in the day); a cost field 480 for defining the cost associated with a campaign and tracking the budget against a specific type of campaigns; a talker field 482 for identifying one or more talkers for the campaign; a dialing agent field 484 for identifying one or more dialing agents for the campaign; and, a list selection field 486 for identifying specific predefined lists that may be of interest to the campaign creator (such as the example shown of the contacts in Nevada).
- the interface 470 also contains: a dialer column field 488 for defining which column in the customer record should be used to obtain the phone number to dial the customer; a called ID display field 490 for specifying whether or not a specific caller identification should be displayed to the customer during a telephone call; a phone server name field 492 for defining which central voice server should be used for the campaign; a phone server host address field 494 for defining the computer host address (for example not limited to, IP address or hostname within a domain) of the central voice server; a phone server login field 496 for defining a login required for use by the dialing agent and talk to enter a campaign; a phone server password field 498 for use by the dialing agent and talker to enter a campaign; and a campaign instructions field 499 for providing any specific instructions (optional) that could be used by the dialing agents or other users of the system.
- a dialer column field 488 for defining which column in the customer record should be used to obtain the phone number to dial the customer
- a talker may specify whether to block or unblock the caller ID when the dialing agent is dialing customers during that campaign. If the caller ID is unblocked the talker is allowed to select a list of caller IDs allocated for that campaign and when a customer is dialed by a dialing agent, the central voice server 150 displays a specific caller ID picked from the list of caller IDs selected by the talker for that campaign.
- the central data server 100 may pick such a specific caller ID by using techniques such as, but not limited to, round robin, random selection, or the like and send such caller ID to the central voice server 150 directly or indirectly through the dialing agent computer 20 .
- the central data server 100 sends a notification to all parties who are assigned as part of the created campaign.
- the central data server 100 may transmit electronic mail (email) to each dialing agent and talker identified by the campaign.
- a calendar event may be transmitted to each dialing agent and talker identified by the campaign, for populating calendar software on the dialing agent computer 20 and talker computer 24 .
- the notifications may instead be transmitted to personal devices of the dialing agents and talkers, such as to their cellular telephone or personal data assistant.
- a campaign could be created with minimal information to just schedule the time slot for the talker and dialing agents, and the other campaign details (for example but not limited to the customer list, caller id blocking or unblocking, which central voice server to be used) could be finalized just before starting the campaign, if required at all.
- the other campaign details for example but not limited to the customer list, caller id blocking or unblocking, which central voice server to be used
- a person having ordinary skill in the art would know how to modify the interface 470 or to divide the interface into multiple interfaces to implement this embodiment.
- the campaign details that are not captured during the time of campaign creation could be captured using one or more interface screens just before the talker starting the campaign and then the talker may proceed to start the campaign.
- FIG. 6 is a flowchart 500 illustrating a method for joining a campaign, in accordance with the first exemplary embodiment of the present invention.
- dialing agents and talker associated with a campaign attempt to join a pre-scheduled campaign from their associated computers.
- the dialing agent computer 20 Upon the dialing agent attempting to join a specific campaign, the dialing agent computer 20 (through the dialing agent software) sends a request with the campaign identifier (associated with the specific campaign selected by the dialing agent) to the central data server 100 to join the campaign.
- the central data server 100 Upon receiving such request to join the campaign, the central data server 100 checks whether the talker has already joined the campaign and, if the talker has not already joined the campaign the dialing agent is forced to wait until the talker joins the campaign and upon the talker joining the campaign the dialing agent is allowed to proceed with joining the campaign.
- Such mechanism provides flexibility to allow updates to the campaign specific settings (for example, but not limited to, caller ID block or unblock, customer list, etc) and updates to customer data (attributes of the customer data shown as part of the list such as customer account name, customer contact name, title, phone number, email, address, notes history and the like) until up to the moment prior to the talker joining the campaign.
- the dialing agent may be allowed to join the campaign at any time after the campaign is created and need not be forced to wait until the talker joins the campaign.
- FIG. 7 is an exemplary screen view illustrating an interface 550 for the dialing agent or talker to select and attempt to join a campaign. As shown by FIG.
- the interface 550 contains: a campaign name field 552 for selecting the campaign to join; a list name field 554 for displaying the name of the list selected during creation of the campaign; a talker name field 556 for listing the talker(s) assigned to the campaign; a dialing agent name field 558 for displaying the dialing agent(s) assigned to the campaign; a start time field 560 for displaying the start time of the campaign; and, an end time field 562 for displaying the end time of the campaign.
- the dialing agent and/or talker may be allowed to, including but not limited to, choose to join the campaign, edit the campaign, create a new campaign, or delete a campaign. While not required, requiring a login of the dialing agent and/or talker into the present system, via the central data server 100 , provides for confirmation of identity.
- the customer list and associated customer data for the campaign (associated with the campaign identifier received as part of the request sent by dialing agent's computer to join the campaign) is transmitted from the central data server 100 to the computer of the dialing agent and/or talker that has joined the campaign. Transmission of the customer list and customer data is performed upon joining of the campaign to ensure that all data required during communication with a customer is located at the dialing agent computer 20 and the talker computer 24 prior to the dialing agent selecting to place a call to a customer on the customer list. Specifically, in accordance with the present system and method, the dialing agent computer 20 and the talker computer 24 contain the customer data prior to the dialing agent selecting to place a call.
- the central data server 100 may transmit to a dialing agent computer 20 only the portion of the customer data needed to perform the dialing agent's function and may transmit to the talker computer 24 only the portion of the customer data needed to perform the talker's function.
- the customer list and associated customer data may be forwarded at any time prior to beginning of the campaign, as long as the talker has the customer list (in the correct order consistent with the customer list in the dialing agent computer) and customer data on his computer prior to the dialing agent selecting to place a call to a customer.
- the dialing agent could be allowed to join the campaign prior to, after, or at the same time as when the talker joins the campaign and flexibility could be provided to allow updates to certain portion of the campaign specific settings (for example, but not limited to, caller ID block or unblock, customer list, and other settings) and updates to customer data (attributes of the customer data shown as part of the list such as customer account name, customer contact name, title, phone number, email, address, notes history and the like) until up to the moment that the talker presses a “GO” button viewed by the talker computer 24 after joining the campaign.
- the campaign specific settings for example, but not limited to, caller ID block or unblock, customer list, and other settings
- customer data attributetes of the customer data shown as part of the list such as customer account name, customer contact name, title, phone number, email, address, notes history and the like
- the foregoing flexibility could be achieved by transmitting the updated portion of the campaign specific settings and customer list (with customer data) from one component of the system 10 where an update might be taking place (for example, but not limited to, the talker computer 24 ) to other components of the system 10 that need to know such updates (for example, but not limited to, the dialing agent computer 20 ) upon the talker pressing the “GO” button.
- the talker may recognize that a customer is not the correct target upon reviewing that customer record's notes history shown in the talker computer 24 and, therefore, the talker would set the do-not-call flag associated with that customer record.
- Such update is then propagated to the central data server 100 , which in turn forces the central data server 100 not to select that particular customer record for dialing (if that customer record is yet to be dialed).
- the talker changes the caller ID for the campaign and such update is propagated to the central voice server 150 for use moving forward. It should be noted, based on implementation preferences, such updates may be propagated to the central data server 100 to allow central data server 100 to have stored therein the updated information for future use.
- the dialing agent may be allowed to join the campaign before, after, or at the same time as, when the talker joins the campaign and the synchronization of updates takes place among different components of the system.
- the central data server 100 may not transmit the customer list to the dialing agent computer 20 and the talker computer 24 .
- the central data server 100 may select an initial batch of customer records for dialing and transmits such batch to the dialing agent computer 20 and the talker computer 24 .
- the central data server 100 could select the next batch of customer records for dialing and transmit such next batch to the dialing agent computer 20 and talker computer 24 (and this cycle goes on until the entire customer list is exhausted or the campaign ends).
- the dialing agent computer 20 and talker computer 24 may append that batch with the currently shown customer records. Based on implementation preferences, to keep the computer memory utilization low, the previously dialed customer records (that are no longer needed to stay in dialing agent computer 20 and/or talker computer 24 ) associated with previous batches may be removed from the dialing agent computer 20 and talker computer 24 .
- Each customer record could have associated priority information (located in one or more fields of the customer record) and the central data server 100 could use such priority information to decide on, including but not limited to, whether to move up or move down that customer record within the sequence of customer records selected dynamically for dialing through batches, how many times a specific customer record could re-appear allowing that customer record to be called multiple times with a campaign (or within a specific period of time), time gap between two consecutive calls to the same customer record, etc.
- priority information located in one or more fields of the customer record
- the central data server 100 could use such priority information to decide on, including but not limited to, whether to move up or move down that customer record within the sequence of customer records selected dynamically for dialing through batches, how many times a specific customer record could re-appear allowing that customer record to be called multiple times with a campaign (or within a specific period of time), time gap between two consecutive calls to the same customer record, etc.
- customer data including but not limited to priority information
- the central data server 100 may use the updated information as part of the logic used to select the customer records for dialing in the next batch of customer records.
- the central data server 100 may use additional logic to move a particular customer record up or down the sequence of customer records selected dynamically for dialing through batches to make sure that multiple customer records whose calls will be going to the same phone operator are not appearing next to each other in the calling list. The foregoing flexibility may be required to avoid having multiple dialing agents calling the same phone operator concurrently.
- the central data server 100 may select a customer record for dialing only if the allowed-to-call checkbox is checked. If the allowed-to-call checkbox is checked, the central data server 100 may select a customer record only if the current date and time is equal to or after the date and time specified in the “do not call until” field in the customer record. Based on implementation preferences, a variation of the foregoing embodiment could be implemented by having the central data server 100 select only one customer record for dialing and transmit to the dialing agent computer 20 and talker computer 24 , upon the dialing agent computer 20 requesting the next customer record for dialing.
- the central data server 100 is sending each customer record itself only just before dialing, there is no need to send the customer unique ID separately to notify the customer record that is being dialed. If such newly received customer record is appended with other previously received customer records that were previously dialed as initiated by the dialing agent computer 20 , the newly received customer record that is being dialed may need to be highlighted to show which customer record is currently being dialed. It should be noted that when multiple dialing agents are participating in the campaign there could be multiple customer records that are being dialed concurrently by multiple dialing agents and such multiple customer records that are currently being dialed could be transmitted to a talker computer 24 for displaying the customer records.
- the newly received customer records that are currently being dialed may need to be highlighted to differentiate the customer records that are being dialed from the previously received and previously dialed customer records. It should be noted that upon the dialing agent transferring a customer call, the associated customer record need to be highlighted differently in the talker computer 24 to differentiate the customer record that is transferred versus the customer records that are being dialed. Such notification of customer record whose call is transferred could be accomplished by transmitting the customer unique ID since the associated customer record has been transmitted previously when the dialing of that customer record began. A person having ordinary skill in the art would know the various techniques that could be used within the foregoing embodiment.
- the customer list associated with the particular campaign may be displayed in a tabular list on the computer 20 of each dialing agent associated with the campaign and on the computer 24 of the talker associated with the campaign. It should be noted that the list need not be tabular.
- FIG. 8 is an example of a screenview illustrating an interface 590 provided to a dialing agent while the dialing agent is attempting to join a campaign, where the dialing agent is forced to wait until the talker joins the campaign.
- the dialing agents are allowed to join the campaign. This is assuming that there is only one talker and one or more dialing agent, however, it is noted that the present system and method may have one or more dialing agent and one or more talker in a campaign.
- the talker after joining the campaign through the talker computer 24 , the talker joins a voice conference bridge hosted in the central voice server 150 by having the central voice server 150 call the phone number of the talker telephone 26 or by the talker manually calling the conference bridge phone number via use of the talker telephone 26 .
- the talker may be listening to on hold music played in the conference bridge or the talker may simply be placed on hold.
- FIG. 9 is an example of a screenview illustrating an interface 600 provided to a dialing agent after the dialing agent joining the campaign.
- the interface 600 provides a view of the customer list associated with the campaign.
- Fields of the customer list include an account name field 602 , a contact name field 604 , a phone number field 606 , an email field 608 , a last result field 610 for identifying results of the last call and notes history, a created date field 612 , and a contact status field 614 for keeping track of the status (for example, but not limited to, the sales status such as “interested to see demo”, “proposal sent”, “contract signed”, etc).
- the customer list and customer data are located on the dialing agent computer 20 prior to initiating customer dialing.
- the interface 600 also contains a current status window 616 for identifying a current status of the campaign to the dialing agent.
- the current status window 616 contains: a campaign name field 618 , which displays the name of the campaign that the dialing agent is assigned to; a campaign time field 620 for displaying the time at which the campaign is scheduled to begin; and a campaign status field 622 for displaying whether the campaign is ready to begin, if the campaign is not ready to begin, or if the campaign is on hold, such as due to the talker being busy, the talker having left the conference bridge, due to the talker not yet having entered the conference bridge, or due to the talker yet to press the “GO” button viewed by the talker computer 24 to start the campaign.
- the current status window 616 also contains: an account field 624 for listing the account name for the record currently being transferred; a contact field 626 for listing the contact currently being transferred; a phone number field 628 for listing the phone number of the contact currently being transferred; and, a call status field 630 for listing the current call status.
- the current status window 616 also contains a transfer button 632 for allowing the dialing agent to transfer a call to a talker, as is described in further detail hereinbelow.
- FIG. 10 is an example of a screenview illustrating an interface 650 provided to a talker after the talker joins a campaign using the talker computer 24 , but where the talker is yet to join the voice conference bridge using the talker telephone 26 .
- the interface 650 shows various fields (including but not limited to campaign name, campaign start time, campaign status, conference bridge phone number, conference bridge ID, password, number of dialing agents who joined the campaign, number of customer records dialed so far, number of customer calls transferred so far, currently transferred customer record fields, etc) that are appropriate for the talker.
- FIG. 10 is an example of a screenview illustrating an interface 650 provided to a talker after the talker joins a campaign using the talker computer 24 , but where the talker is yet to join the voice conference bridge using the talker telephone 26 .
- the interface 650 shows various fields (including but not limited to campaign name, campaign start time, campaign status, conference bridge phone number, conference bridge ID, password, number of dialing agents who joined the campaign, number of customer records
- FIG. 11 is an example of a screenview illustrating an interface 700 provided to a talker after the talker joins a campaign using the talker computer 24 , and after the talker has joined the voice conference bridge using the talker telephone 26 .
- a status window 702 of the interface 700 displays the status of the system 10 as ready to start. It should be noted that based on implementation preferences, the status window 702 could be implemented as a part of the window where the customer list with customer data is shown.
- the campaign becomes ready to start when the following conditions are met: i) the talker joins the campaign through the talker computer 24 ; ii) the talker is connected to the voice conference bridge through the talker telephone 26 ; and, iii) one or more dialing agents join the campaign through their computers and are ready to dial customers.
- FIG. 12 is a flowchart 750 illustrating actions initiated and performed during initiation of a campaign. While FIG. 12 is provided with regard to a single dialing agent, one having ordinary skill in the art would appreciate that there may be more than one dialing agent in the present system, resulting in the steps of FIG. 12 being performed by each dialing agent. As shown by block 752 , the dialing agent computer 24 checks whether the campaign is on hold. Though the campaign is ready to start, the campaign may remain on hold until the talker presses a “Go” button, or performs another step to show that the talker is ready for the campaign to begin.
- the talker may pre-record a voice message by pressing a button provided by the talker software located on the talker computer 24 , and requesting one or more dialing agent to play a pre-recorded voice message of the talker whenever the dialing agent encounters a voice mail of the customer as a result of the customer call going to the customer's voice mail.
- the dialing agent computer 20 via the dialing agent software, requests from the central data server 100 a unique identifier associated with the record of a specific customer to call.
- the dialing agent is referred here in singular term in order to simplify the description, there could be multiple dialing agents joining the campaign and performing the actions associated with the dialing agent.
- the central data server 100 responds to the dialing agent computer 20 by transmitting a customer unique identifier to the dialing agent computer 20 and concurrently the central data server 100 transmits the same customer unique identifier to the talker computer 24 .
- the customer unique identifier is specifically designed to be very short in size. For example, the customer unique identifier could be just a row identifier starting from 1 to n (where ‘n’ is the maximum number of records shown by the customer list).
- the central data server 100 assigns different records in the customer list to different dialing agents.
- the customer record dialed by the dialing agent is highlighted on the computer screen of the dialing agent as well as the computer screen of the talker.
- the dialing agent computer 20 via the dialing agent software, locates the customer record associated with the customer unique identifier received from the central data server 100 , in the customer list, and highlights that customer record in the tabular list on the screen associated with the dialing agent computer 20 , which is viewed by the dialing agent.
- the talker computer 24 via the talker computer software, locates the same customer record and highlights that customer record in the tabular list on the screen associated with the talker computer 24 , which is viewed by the talker.
- the customer list may or may not be displayed in a tabular list format on the dialing agent computer 20 or the talker computer 24 .
- the talker could review the notes history of customers that are being dialed and get ready to handle the transferred customer call. By following this sequence, the talker is capable of reviewing customer data and being prepared for a transferred customer call prior to receiving the customer call (described hereinbelow).
- the present system and method transfers unique identifiers for highlighting records presently being called and highlighting calls being transferred to the talker, where customers presently being called are highlighted different from customers being transferred to the talker.
- the process for transferring unique identifiers and highlighting is described in additional detail hereinbelow.
- the central voice server 150 upon request from the dialing agent computer 20 to start dialing a specific customer phone number (associated with the unique customer identifier received from the central data server), the central voice server 150 starts dialing that phone number. It should be noted that the objective of the function shown by block 760 is to establish a call between the dialing agent and customer.
- the dialing agent uses his/her telephone 22 to navigate the phone menus, interactive voice response systems, wrong phone numbers, phone operators, and the like to reach the correct customer. Based on implementation preferences, the dialing agent computer could send a dial request directly to the central voice server 150 or indirectly to the central voice server 150 through the central data server 100 .
- the dialing agent has not previously joined a voice conference bridge hosted in the central voice server 150 .
- the central voice server 150 starts dialing the dialing agent telephone 22 and upon the dialing agent answering the dialing agent telephone 22 the central voice server 150 proceeds to start dialing the customer phone and bridges the customer call with dialing agent.
- the dialing agent telephone 22 could be configured to answer automatically (sometimes referred as “auto answering”) when the call is made by the central voice server 150 and in which case the dialing agent telephone 22 automatically answers without having the dialing agent answer.
- the dialing agent joins a voice conference bridge hosted in the central voice server 150 by having the central voice server 150 call the phone number of the dialing agent telephone 22 or by the dialing agent manually calling the conference bridge phone number via use of the dialing agent telephone 22 .
- the talker may be listening to on hold music played in the conference bridge or the dialing agent may be simply placed on hold.
- the dialing agent computer 20 requests the central voice server 150 to start dialing a specific customer phone number (associated with the unique customer ID)
- the central voice server 150 starts dialing the customer phone number and bridges the customer call with the dialing agent waiting in the conference bridge.
- One having ordinary skill in the art would know the various techniques that could be used to accomplish the function depicted by block 760 .
- the function depicted by block 760 could be implemented by having the central data server 100 make a request to the central voice server 150 to dial the customer phone number (associated with the customer unique identifier) concurrently when the central data server 100 transmits the customer unique identifier to the dialing agent computer 20 and the talker computer 24 as shown by block 756 , thereby eliminating the need to have the dialing agent make a request to dial the customer record as shown by the block 760 .
- the caller ID displayed could be dynamically customized based on the attributes of the customer phone number. For example but not limited to, based on the geographical area code of the customer phone number the caller ID could be a phone number that belongs to the same area code as the customer area code or an area code closer to the customer's area code.
- FIG. 13 is an example of a screenview illustrating an interface 780 provided to a dialing agent during the dialing of a customer.
- the customer record of the customer currently being dialed is highlighted 782 so that the dialing agent is aware of which customer is currently being dialed.
- an interface window 784 is provided for providing the dialing agent with a status of the current call and for allowing the dialing agent to provide instructions to the dialing agent computer 20 .
- the interface window 784 displays the campaign name, campaign time, campaign status, account name, contact, phone number, and call status for the current call. Options to hang up, take a break, and dial the next number are provided to the dialing agent.
- an option is provided on the interface window 784 to play a voice message (pre-recorded voice message of the talker that could be played whenever the dialing agent encounters a voice mail of the customer as a result of the customer call going to the customer's voice mail). Further, an option is provided on the interface window 784 to transfer a call to the talker.
- Each dialing agent may take a break by clicking a “Take a break” button, in which case the dialing agent software pauses, allowing the dialing agent to take a break until the “Resume” button is clicked. It should be noted that upon clicking the “Take a break” button if there is a customer call already in progress it may not be appropriate to hang up that call and instead the dialing agent may continue to complete such call using the dialing agent telephone 22 and then proceed to take the break.
- the talker may take a break by pressing the “Hold” button, in which case the talker computer 24 requests the central data server 100 to put the campaign on hold and the central data server 100 puts the campaign on hold allowing the talker to take a break until the “Go” button is pressed.
- dialing agents are not allowed to transfer any more calls to the talker and any previously initiated calls should be handled by dialing agents by performing certain pre-defined tasks (hang up, hang up now and redial when the campaign resumes, follow pre-defined script and the like); and, ii) dialing agents are not allowed to initiate new calls.
- a person having ordinary skill in the art would know that in an alternative embodiment having multiple talkers, when a talker requests to take a break by pressing the “Hold” button, only that particular talker could be given a break (that is, that particular talker is not ready to take the transferred customer call) and the campaign could continue if at least one other talker is ready to take the transferred customer call. The campaign may not be put on hold as long as at least one talker is ready to take the transferred customer call.
- FIG. 14 is a flowchart 800 illustrating a process of handling a call after dialing by the central voice server 150 .
- the dialing agent determines whether the correct customer is reached by recognizing live customer voice in the phone call. Based on the implementation of voice recognition technology, the dialing agent may perform the foregoing determination with or without the help of voice recognition technology.
- the dialing agent upon determining that the correct customer could not be reached, performs certain pre-defined tasks, such as, for example, but not limited to, playing a pre-recorded voice message recorded by the talker previously (if the customer call results in a customer voicemail) or leaving a voice message using the voice of the dialing agent (if the customer call results in a customer voicemail), entering notes against the customer record, and the like.
- the dialing agent upon determining that the correct customer is reached (by recognizing live customer voice in the phone call), the dialing agent presses the transfer button provided by the dialing agent software, within the interface window 784 , and the campaign status is determined to know whether the campaign is on hold or not.
- the campaign will go on hold for various reasons such as when the talker is busy talking to another customer, when the talker has left the system, and the like.
- the central data server 100 may keep checking the campaign status continuously and keep updating the campaign status on the screen of the dialing agent.
- Checking the campaign status may take place by the software of the central data server 100 by continuously monitoring (in short time intervals) to know whether the talker is ready to take the customer call (for example but not limited to, by checking whether the talker is still waiting in the conference bridge and by checking whether the talker computer 24 is in continuous communication with the central data server 100 ).
- Campaign status information is also proactively maintained. Such campaign status information could be used to take actions proactively in the system, for example but not limited to, the action described in the succeeding sentence.
- the dialing agent Before attempting to transfer the call, if the dialing agent sees the campaign status as being on hold, the dialing agent need not attempt to press the transfer button provided by the dialing agent software and instead proceeds to the step shown by block 808 . As shown by block 808 , upon determining that the campaign is on hold, the dialing agent performs certain pre-defined tasks such as talking to the customer and scheduling an appointment for the talker and the customer to connect later, and the like.
- the dialing agent software transfers the call to the conference bridge of the talker and notifies the central data server 100 with the transferred customer unique identifier. Simultaneously, when the call is transferred, the central data server 100 puts the campaign on hold to make sure that another dialing agent cannot transfer another customer to the talker.
- the call transfer function illustrated by block 810 could be implemented by having the dialing agent software send a transfer command directly to the central voice server 150 or indirectly to the central voice server 150 through the central data server 100 .
- the dialing agent computer 20 could send a request to the central data server 100 to transfer the customer call.
- the central data server 100 could check whether the campaign is on hold, upon determining that the campaign not on hold, the central data server 100 can proceed to put the campaign on hold, and then transfer the customer call to the conference bridge of the talker (by sending a request to the central voice server 150 ).
- the on hold music played to the talker Upon the transfer of the call, the on hold music played to the talker will stop (if on hold music was being played), a short beep sound will be played to alert the talker, and the talker can start the conversation with the customer.
- the central data server 100 receives the transferred customer unique identifier from the dialing agent computer 20 and then transmits to the talker computer 24 the unique identifier of the customer who is being transferred.
- the central voice server 150 could start playing a pre-recorded voice greeting previously recorded by the talker to the customer called first and then proceed to transfer the customer call to the talker (or such pre-recorded greeting could be played concurrently while the customer call is transferred to talker).
- the foregoing arrangement could keep the customer engaged while the customer call is being transferred and provide a few extra seconds of time for the talker to get started with the conversation. It should be noted that upon the customer call transfer the talker may hear his/her pre-recorded greeting being played to the customer and waits until his greeting is completed playing and then start the conversation.
- the customer record associated with the transferred unique identifier is highlighted differently in the tabular list shown on the talker computer 24 .
- the unique identifier of the transferred customer has already been provided to the talker computer 24 when the dialing agent began dialing and the associated customer record was highlighted in the talker computer 24 (ahead of call transfer) to allow the talker to be prepared and during the step depicted by block 810 the same customer unique identifier is sent a second time to notify the talker of which one of the customers is transferred among the few customers being dialed. Since the talker has already reviewed the customer data ahead of call transfer, the talker is able to respond effectively without delay and have a productive conversation.
- highlighting of the customer record associated with the transferred unique identifier may be performed in many different manners.
- the customer record associated with the transferred unique identifier may be highlighted in a different color than the other customer records that are being dialed on the customer list.
- the dialing agent computer 20 could transmit the customer unique ID and the status of the call being ended to the central data server 100 and central data server 100 notifies the talker computer 24 of the customer unique ID and provides the status of call as having been ended.
- the talker computer 24 could remove the highlighting of that customer record since the dialing of that customer record has ended (based on implementation preferences, instead of removing the highlighting of that customer record it could be highlighted in a separate color or shade to indicate that customer record has been dialed and such dialing has ended without resulting in a customer call transfer).
- FIG. 15 is an example of a screenview illustrating an interface 900 provided to talker when 3 customer records are being dialed by the dialing agents.
- the 3 customer records that are currently being dialed are highlighted 904 to show to the talker which customer records are currently being dialed.
- Notes history 906 is shown to the talker.
- a status window 902 shows the campaign status, number of dialing agents currently dialing, number of dials so far and other relevant information.
- Status window 902 provides the options to put the campaign on Hold and GO.
- FIG. 16 is an example of a screenview illustrating an interface 950 provided to talker when a customer call is transferred to talker and 2 other customer records are being dialed.
- the transferred customer record is shaded differently 956 to differentiate the transferred customer record from the other 2 customer records 958 that are being dialed.
- a status window 952 shows the currently transferred customer record fields (account name, contact name, phone number, etc), campaign status, number of dialing agents currently dialing, number of dials so far and other relevant information.
- a window 954 is shown where the talker enters notes and schedules a follow up.
- the dialing agent computer 20 could repeat the steps of FIG. 12 to continue to dial the next customer record associated with the next customer unique identifier transmitted by the central data server 100 for dialing. This cycle may continue until the dialing agent exits the campaign or the campaign ends.
- the dialing agents and talker can update the customer information and notes, and schedule follow up events.
- the dialing agent might learn that a specific customer no longer works in a business or that the phone number is a wrong phone number or a different contact within a business is the right decision maker, resulting in the dialing agent inserting a new customer record(s) or modifying the customer information to properly reflect current information.
- the present system via the central data server 100 , central voice server 150 , the taker computer 24 , and the dialing agent computer 20 , collects various data such as the number of dials made by each dialing agent, the number of calls transferred by each dialing agent, call duration, and the like. A report could be generated based on the collected data.
- the talker closes down the campaign screen on the talker computer 24 .
- the central data server 100 requests the central data server 100 to end the campaign and in turn the central data server 100 notifies the central voice server 150 to end the campaign (and the central voice server 150 ends the campaign by ending the telephone connection of the talker to the voice conference bridge) and changes the campaign status as being ended or closed.
- the talker has the ability to notify the central data server 100 to start the dialing from a specific customer record in the customer list (instead of starting from the beginning of the customer list).
- the central data server 100 could be implemented using Web application server technologies or stand alone server technology that interacts with other components of the system 10 through client-server technology.
- the central voice server 150 could be implemented using a PBX system such as Asterisk.
- Dialing agent software and talker software may be implemented using stand-alone code that communicates with other components of the system through client-server technology, or using web browser Ajax technology or web browser with plug-in, or using a combination of Web technology and automatic delivery of code from a Web server to browsers using technologies for example but not limited to Java or ActiveX.
- the system may or may not integrate with a third party customer relationship management (“CRM”) to implement the functions of the central data server, dialing agent software, and talker software.
- CRM customer relationship management
- Communication between the central voice server 150 and other components of the system 10 may or may not go through the central data server 100 .
- communication between any two components of the system 10 could be accomplished using various mechanisms such as but not limited to Ethernet, Internet, TCP/IP, and shared memory based communication, and shared storage based communication.
- communication between any two components of the system 10 could be accomplished using messages with variations in content. For example, upon customer call transfer the central data server 100 could transmit to the talker computer 24 a portion of the customer record that could be used to uniquely identify the transferred customer record in the talker computer 24 instead transmitting the unique customer identifier associated with the transferred customer.
- the components of the system may or may not use a local or server based database system to store and retrieve customer lists and data.
- a component may act only as a client or may act only a server or may act as both a client and a server.
- the functions performed by each component of the system could be restructured by removing a specific function (whole function or a portion of a function) from one component and delegating such function to be performed by another component.
- a portion of the function performed by the central data server 100 that involves the transmission of the customer list to one or more component of the system 10 directly retrieve the customer list from a file or database that is accessible and limit the function of the central data server 100 to provide the necessary data (such as but not limited to, campaign status) for coordination among the components of the system 10 .
- the whole function performed by the central data server 100 could be delegated by having the dialing agent computer 20 , talker computer 24 , and central voice server 150 communicate among themselves and coordinate among themselves to accomplish the overall function of system 10 of the present invention and thereby eliminating the need to have the central data server 100 as part of the system 10 .
- dialing agent computer 20 could be implemented by having a computer terminal that provides access to a remote computer where the remote computer performs the function of the computer.
- certain resources including but not limited to screen and peripheral device
- events of the remote computer are mapped to the computer terminal.
- the foregoing implementation could be accomplished using technologies, such as but not limited to, remote desktop client, remote desktop connection, remote desktop server, computer terminal, terminal server, and the like.
- the dialing agent computer 20 could be a computer terminal that has remote desktop client software which connects to the remote desktop server (where dialing agent software is located) and the dialing agent is allowed to see the dialing agent software interface (and interact with the dialing agent software) located in the remote desktop server via the computer terminal.
- the talker computer 24 could be a computer terminal allowing the talker to see and interact with the talker software located in the remote desktop server. It should be noted that by using the foregoing technique it is possible to have the dialing agent software, talker software, the central data server 100 , and the central voice server be located in the same server (and based on the implementation preferences such components may or may be implemented as software modules in the server). Based on the implementation preferences, such server could provide shared memory access to the different components of the system for communication and coordination.
- one component of the system could send and receive information directly from the other component or indirectly through one or more components.
- the call transfer function depicted by the block 810 could be implemented by having the dialing agent software send a call transfer request to the central voice server 150 directly, or the same call transfer function could be implemented by having the dialing agent software send a call transfer request to the central data server 100 and in turn the central data server 100 send a call transfer request to the central voice server 150 .
- the step illustrated by block 504 in FIG.
- the central data server 100 may transmit only customer list information and the source (for example, but not limited to, a specific database) from where to get the associated customer data and the dialing agent computer 20 and/or talker computer 24 may get the customer data from the source specified by the central data server 100 .
- the source for example, but not limited to, a specific database
- each component of the system 10 could be a logical component that is implemented by having multiple instances of the component working with or without coordination among such instances. Such implementation may be needed to improve the attributes of the system 10 , such as but not limited to, the scalability, reliability, redundancy, and availability. Some of the techniques that could be used in such implementation could be, including but not limited to, clustering, load balancing, distributed computing and cloud computing).
- the central data server 100 could be implemented by having more than one computer configured to work as a cluster for the purposes of, including but not limited to, balancing the work load among the computers in the cluster, delegating the function performed by a non-working computer (when a computer in the cluster is not working due to failure or shut down intentionally by maintenance personnel for maintenance) to other computers in the cluster in order to maintain high availability, and keep the overall cost of the central data server 100 .
- a component of system 10 is implemented by having multiple instances (as described herein above), one or more instances may or may not share the same processor, memory, storage, and the like.
- a person having ordinary skill in the art would understand the various forms of technologies and techniques that could be used to embody the invention.
- highlighting of customer records may be used to highlight the dialing agent screen and the talker screen to differentiate the customers who are being dialed, who is currently transferred, who were previously transferred, who were unsuccessfully dialed previously that did not result in a call transfer, to whom dialing agents have successfully played a pre-recorded voice message previously recorded by talker, and to represent other customer status.
- highlighting may be performed by one or more of many different methods such as, but not limited to, changing colors, blinking, circling, shading, changing the border around the customer information, showing the customer information in specific area of the screen, and pointing to customer information shown in the computer.
- the system since a specific talker is pre-selected for a given campaign, at the time of call transfer the system knows the talker ahead of time and the system does not have to look for an available talker at the time of call transfer. Hence, the speed of call transfer is faster.
- Various components of the present system may be designed to update each other continuously (with short time intervals between updates) and such updates could include, but are not limited to, updates of information that need to be exchanged between the components and the information about whether the connectivity between them is healthy. Such updates could be implemented by having one component poll the other component continuously (with short time intervals between the polling) to provide updates as well as receive updates at the same time. If the technology used for implementation permits, such updates may be performed asynchronously by having a component send updates to other component(s) only when there is a change of information that needs to be exchanged. It should be noted that the present system may be implemented to perform security checks at various steps to ensure proper authentication of user of the system and appropriate authorization to access various functions of the system and/or access or update various portions of data in the system.
- the talker will be busy in attending the call transferred to the conference bridge (where the talker is waiting readily) and the campaign data server software will put the campaign on a hold status. After the campaign goes into a hold status, any other call currently in progress between the dialing agent and the customer could be dropped and, based on the option, redialed again when the campaign resumes or the dialing agent may proceed with the call and talk to the customer to arrange a scheduled time for the talker to contact the customer directly at a later time.
- the system could continuously exchange among the talker computer 24 and the dialing agent computer 20 the incremental updates made to customer records.
- the exchange of incremental updates of customer data could be performed at a lower priority and the task of transferring the call (and the associated customer's unique identifier) could be performed at a higher priority.
- the system could use other mechanisms that allow the talker to wait readily to handle the transferred customer call.
- Such alternative mechanisms could include, but are not limited to, queue, parking lot, and the like.
- a person having ordinary skill in the art of the present invention would understand the various types of mechanisms in the central voice server that could be used in a system embodying the present invention.
- the system could be implemented to have more than one talker wait in a queue (or alternative mechanisms) to handle the transferred customer calls.
- This configuration reduces the chances of needing the dialing agent to handle the customer call himself/herself due to the talker becoming busy. The higher the number of talkers available, the lesser the chance of not having a talker available to handle the transferred customer call and, in turn, the lesser the chance of the dialing agent needing to handle the customer call himself/herself. If more than one talker is waiting to handle the transferred customer call the central data server 100 may need to select one of the available talkers during the time of call transfer.
- a delay associated with such selection of talker during the time of call transfer could be minimized by having the system pre-select one of the available talkers to handle the next transferred call.
- Such pre-selection process could be executed on a continuous basis whenever the previously preselected talker becomes busy (and keep maintaining the designated talker to handle the next transferred call).
- multiple people may participate in a transferred customer call.
- the present system may be implemented to have one or more individuals join the customer call along with the talker.
- Such additional individual(s) may participate in a listen only mode, participate in a listening and talking mode, or participate in a whisper mode in which the talker could hear such individual's voice but not the customer. Participation of additional individuals could be necessary for training purposes or assisting the customer along with the talker.
- one or more persons could participate (in various modes such as listen only, whispering to the one or more participants, or listening and talking to everyone in the call) in the call between the dialing agent and customer for the purposes of training and coaching.
- the system could be implemented by 1) automating all or a portion of the dialing agent's function to navigate a customer phone call (through including, but limited to, phone menus and voicemails) until reaching the live customer, by using techniques such as but not limited to, playing the correct sequence of digits (along with the appropriate delays in between digits) that were stored as part of the customer data, and 2) having the system recognize whether a live human voice is encountered in a phone call.
- the system could dial the customer phone number, navigate the phone call (through but not limited to phone menus and voicemails), and upon the live customer picking up the call, recognize the live human voice and transfer that call to the talker.
- the phone call navigation could be fully performed by the system, the foregoing arrangement could eliminate the need to have the human dialing agent by having the system do the same phone call navigation work.
- the dialing agent software function could be modified to operate in a non-interactive mode and implemented as a module in the central data server.
- customer call transfer (followed by phone call navigation by the system) if the talker is busy, based on implementation preferences, such call could be transferred to one of the secondary talker(s) waiting to handle such calls.
- Secondary talkers could be individuals with skills equal to, more, or less skilled than the talker based on the requirement.
- the customer records for which the phone call navigation function could not be automated fully by having the system perform the phone call navigation function the human dialing agent is required for phone call navigation and the system could be used to assist the human dialing agent by automating a certain portion of the customer call navigation.
- Each customer record could be marked as whether the phone call navigation is fully possible by the system or not. Based on the mix of customer records (navigation by system fully possible versus navigation requiring human dialing agents) there is possibility to have no human dialing agents or a lesser number of human dialing agents working alongside of the system performing the function of the dialing agent(s) in a campaign.
- the system, a user of the system, or a combination of the user and the system could update the customer record with information including but not limited to 1) whether the customer phone number is a direct dial phone number or goes to a phone menu(s) that could be navigated by pressing specific digits, and 2) if dialing the phone number goes to a phone menu, the digits such as menu options or extension number that need be pressed (along with the delay that need to be provided between each such digits) to navigate through each phone menu that may be encountered, until the phone call ringing the correct target customer.
- the dialing agent is navigating phone menus during a customer call one of the components of the system could be implemented to learn and automatically capture the digits pressed by the dialing agent (along with the delay between digits) and store that information in the associated customer record. While the dialing agent is on a customer call, the system could assist the dialing agent to identify whether the call is picked by a live human being or a phone menu, and upon encountering a phone menu the system could assist the dialing agent by automatically playing the digits required to navigate that phone menu. In a customer call that is designated, a system could navigate fully until reaching the live person.
- the system could recognize that live human voice and transfer the call to the talker (or, based on implementation preference, transfer that call to an available dialing agent to navigate further until the correct live target customer is reached, upon which the dialing agent will further transfer the call to the talker).
- live human voice or, based on implementation preference, transfer that call to an available dialing agent to navigate further until the correct live target customer is reached, upon which the dialing agent will further transfer the call to the talker.
- the list of customer records and customer data shown on the dialing agent computer may or may not be the same as that shown in the talker computer. Notwithstanding the above variations, it should be emphasized that (1) when the dialing agent(s) is dialing a customer record(s), concurrently the same customer record(s) is highlighted in the talker computer (to accomplish this, the talker computer should receive the customer record(s) dialed by the dialing agent simultaneously at the same time or before when the customer record(s) is highlighted to show that customer record(s) is being dialed), and (2) when a customer call is transferred by the dialing agent the customer record associated with the transferred customer call is highlighted differently on the talker computer to allow the talker to differentiate the customer record whose call is transferred versus the customer record(s) that is being dialed. By following this sequence, the talker is capable of reviewing customer data and being prepared for a transferred customer call prior to receiving such transferred customer call.
Landscapes
- Engineering & Computer Science (AREA)
- Signal Processing (AREA)
- Business, Economics & Management (AREA)
- Marketing (AREA)
- Telephonic Communication Services (AREA)
Abstract
Description
- This application is a continuation of and claims priority to copending U.S. Application entitled, “SYSTEM AND METHOD FOR MAXIMIZING EFFICIENCY OF CALL TRANSFER SPEED” having Ser. No. 14/057,758, filed Oct. 18, 2013, which claims priority to a U.S. application having Ser. No. 13/278,764, filed Oct. 21, 2011, now U.S. Pat. No. 8,594,308, issued on Nov. 26, 2013, which claims priority to expired U.S. Provisional Application entitled “SYSTEM AND METHOD FOR MAXIMIZING EFFICIENT CALL TRANSFER SPEED”, having Ser. No. 61/405,587, filed Oct. 21, 2010, all of which are entirely incorporated herein by reference.
- The present invention is generally related to call centers, and more particularly, is related to efficient handling of call center calls.
- Systems and methods presently exist for transferring a customer call taking place between a dialing agent and a customer, to taking place between a talker and a customer, without the customer knowing that a dialing agent was involved in completing the call between the talker and customer, and without the customer knowing that navigating systems and people (phone voice menus, operators, wrong phone numbers and the like) were involved prior to getting the live customer on the phone. Many of these systems and methods transfer the call between the dialing agent and the customer to between the talker and the customer fast enough, without significant delay. Unfortunately, these systems and methods transfer and display customer data at the screen of the talker at the same time as when the call is transferred or a short time after the call is transferred. Specifically, to allow the talker to have a productive call with the customer, it is beneficial for the talker to view data regarding the customer. Since the customer data is displayed at the same time as when the call is transferred or a short time after the call is transferred, the talker is at a disadvantage and not capable of preparing to handle the call effectively ahead of time.
- The foregoing fact causes the talker to react to a transferred call with a delay since the talker has to review the customer data after the call is transferred. In addition, the foregoing facts reduce effectiveness of the talker in performing the important objectives of: 1) making sure that the customer does not know that there was a dialing agent involved in making the call; and, 2) being prepared to pitch the customer effectively based on past notes regarding a history and facts regarding the customer. Therefore, there is a need for a system and method that allows the talker to be prepared prior to when the customer call is transferred.
- Prior systems and methods also transfer all attributes of customer data when a call is transferred. Such transfer of all attributes of customer data through the network is burdensome and takes time, which in turn introduces delay in transferring customer data. Such delay causes slowness in the talker responding when the call is actually transferred. Thus, there is a need for a system and method that minimizes the amount of customer data that needs to be transferred through the network, thereby increasing the speed of data transfer.
- Prior systems and methods also have multiple talkers. The decision to select a specific talker is made at the time that the call is transferred, which is burdensome and takes time, which in turn introduces additional delay in transferring the call. Such delay causes the talker not to engage the customer quickly, which can negatively affect the call. Thus, there is also a need for a system and method that minimizes the delay associated with selection of the talker.
- Embodiments of the present invention provide a system and method for maximizing efficiency of call transfer from being between a customer and a dialing agent to being between the customer and a talker. Briefly described, in architecture, one embodiment of the system, among others, can be implemented as follows. One embodiment of the system contains a dialing agent computer, a talker computer, a central data server, and a central voice server. The dialing agent computer has a memory, and a processor configured by the memory to provide a notification that a dialed customer has been connected (referred to herein as a connected customer) via a call and is ready for a call transfer, wherein the dialing agent computer is used by a dialing agent. The talker computer has a memory, and a processor configured by the memory to receive a first customer identification associated with the dialed customer prior to or at the same time as dialing of the customer and to receive a second customer identification associated with the connected customer after the connected customer has been connected to the dialing agent, wherein the talker computer is used by a talker. The central data server contains a memory, and a processor configured by the memory to perform the steps of: receiving the notification from the dialing agent computer confirming that the dialed customer has been connected; transferring the first customer identification associated with the dialed customer to the talker computer prior to or at the same time as dialing the dialed customer for purposes of highlighting a customer record on the talker computer in a first manner; and after the dialing agent computer acknowledges connection to the dialed customer, transferring the second customer identification associated with the connected customer to the talker computer for purposes of highlighting a customer record on the talker computer in a second manner. Prior to the dialing agent providing the notification that the dialing agent is dialing the dialed customer, the talker computer has stored therein data associated with the connected customer.
- The present invention can also be viewed as providing methods for maximizing efficiency of call transfer from being between a customer and a dialing agent, to being between the customer and a talker. In this regard, one embodiment of such a method, among others, can be broadly summarized by the following steps: entering a dialing agent and a talker into a campaign to maintain direct communication with the dialing agent and with the talker; calling a customer via use of a dialing agent device; receiving from the dialing agent a request to transfer a connected customer from communicating with the dialing agent to communicating with a talker; and after receiving the request to transfer, transmitting an identification of a customer record associated with the connected customer to a talker computer for identifying the customer record, where the customer record has been previously stored on the talker computer prior to receiving the request to transfer.
- Other systems, methods, features, and advantages of the present invention will be or become apparent to one with skill in the art upon examination of the following drawings and detailed description. It is intended that all such additional systems, methods, features, and advantages be included within this description, be within the scope of the present invention, and be protected by the accompanying claims.
- Many aspects of the invention can be better understood with reference to the following drawings. The components in the drawings are not necessarily to scale, emphasis instead being placed upon clearly illustrating the principles of the present invention. Moreover, in the drawings, like reference numerals designate corresponding parts throughout the several views.
-
FIG. 1 is a schematic diagram illustrating a system for maximizing efficiency of call transfer speed in accordance with the present invention. -
FIG. 2 is a block diagram further illustrating a general purpose computer. -
FIG. 3 is a flowchart illustrating an initiation process performed by the central data server ofFIG. 1 , in accordance with the first exemplary embodiment of the present invention. -
FIG. 4 is an exemplary screen view illustrating an interface for creating a customer list based on specific search criteria, which may be viewed by a party logging into the central data server and selecting to create a customer list. -
FIG. 5 is an exemplary screen view illustrating an interface for creating and scheduling a campaign specifying one or more talker and one or more dialing agent. -
FIG. 6 is a flowchart illustrating a method for joining a campaign, in accordance with the first exemplary embodiment of the present invention. -
FIG. 7 is an exemplary screen view illustrating an interface for the dialing agent or talker to select and join a campaign. -
FIG. 8 is an example of a screenview illustrating an interface provided to a dialing agent while the dialing agent is attempting to join a campaign, where the dialing agent is forced to wait until the talker joins the campaign. -
FIG. 9 is an example of a screenview illustrating an interface provided to a dialing agent after the talker joins the campaign. -
FIG. 10 is an example of a screenview illustrating an interface provided to a talker after the talker joins a campaign using the talker computer, but where the talker is yet to join the voice conference bridge using the talker telephone. -
FIG. 11 is an example of a screenview illustrating an interface provided to a talker after the talker joins a campaign using the talker computer, and after the talker has joined the voice conference bridge using the talker telephone. -
FIG. 12 is a flowchart illustrating actions initiated and performed during initiation of a campaign, in accordance with the first exemplary embodiment of the present invention. -
FIG. 13 is an example of a screenview illustrating an interface provided to a dialing agent during the dialing of a customer. -
FIG. 14 is a flowchart illustrating a process of handling a call after dialing by the central voice server, in accordance with the first exemplary embodiment of the present invention. -
FIG. 15 is an example of a screenview illustrating an interface provided to talker when 3 customer records dialed by dialing agents are highlighted and talker reviewing customer notes history, ahead of call transfer. -
FIG. 16 is an example of a screenview illustrating an interface provided to talker when a transferred customer's record is shaded differently to differentiate from the other two customer records that are being dialed. - The present invention provides a system and method for maximizing speed of transferring a call from taking place between a dialing agent and a customer, to taking place between a talker and a customer, by providing customer data to the talker ahead of the call transfer, minimizing the amount of customer data transferred, and minimizing the delay associated with talker selection at the time of call transfer by knowing ahead of time which talker to transfer the call to. Each of the foregoing techniques, as described in detail herein, could be used individually, or collectively two or more techniques could be used together. Customer data is displayed in a talker screen ahead of call transfer allowing the talker to be prepared by reviewing customer data, such as, for example, notes history and the like, ahead of call transfer. Only a necessary minimal amount of data providing a unique identifier is transferred to the talker when the call is being transferred, thereby increasing speed of call transfer. The delay associated with selecting the available talker at the time of call transfer is minimized by pre-selecting the talker ahead of call transfer and having the talker wait in a voice server and ready to accept the transferred call.
- While the following describes the present system and method in detail it is beneficial to provide certain definitions.
- Customer: A person to whom a telephone call is made.
- Customer list: A list of customers.
- Dial: A telephone call made to a customer in the customer list.
- Connect: A telephone call answered by a live customer.
- Dialing agent: Each person who is the first person that handles a call made to a customer and navigates the call (through phone voice menus, phone operators, voicemails, wrong phone numbers, and the like) until the call reaches the correct target customer on the customer list, while the system may dial the telephone number of the customer and establishes connection between the person's phone and customer in the customer list, where the person transfers a live customer call to a talker, via a central voice server.
- Talker: The person waiting in a voice conference bridge who accepts a transferred telephone call and speaks to a customer after the transfer of the telephone call.
- Campaign: The session when the dialing agent and the talker work together, in which the dialing agent, via a central voice server, dials the customers and transfers the call between the dialing agent and the customer to the call between the talker and the customer.
- Dialing Agent Software: The software component of a dialing agent computer that provides functionality necessary for performance by the dialing agent, in accordance with the present system and method.
- Talker Software: The software component of a talker computer that provides functionality for performance by the talker, in accordance with the present system and method.
- It should be noted that whenever the present description refers to a step being performed by a dialing agent, based on the context, this means that the step is either performed by: i) a dialing agent through the use of dialing agent software; ii) a dialing agent through the use of a dialing agent telephone; or iii) dialing agent software automatically without a dialing agent initiating a step. This same reasoning pertains to steps performed by the talker.
-
FIG. 1 is a schematic diagram illustrating asystem 10 for maximizing the efficiency of the call transfer speed through communicating customer data to the talker ahead of call transfer, minimizing data transfer delay, and minimizing talker selection delay, in accordance with the present invention. Referring toFIG. 1 , thesystem 10 includes a dialing agent computer 20 having dialing agent software stored therein, a dialingagent telephone 22, atalker computer 24 having talker software stored therein, atalker telephone 26, acentral data server 100, acentral voice server 150, and a customer telephone 200. - It should be noted that a computer may be any device having a memory and processor, and being able to store therein functionality associated with software. Examples of computers may include, but are not limited to, a desktop computer, a portable computer such as a laptop computer, or a personal data assistant.
FIG. 2 is a block diagram further illustrating a general purpose computer. It should be noted that functionality of the present system and method can be implemented in software, firmware, hardware, or a combination thereof. - Returning to
FIG. 1 , within thesystem 10 there may be one or more than one dialing agent computer 20, dialingagent telephone 22,talker computer 24,talker telephone 26,central data server 100,central voice server 150, and/or customer telephone 200. For exemplary purposes,FIG. 1 illustrates three dialingagent computers agent telephones customer telephones - In accordance with the present invention, a telephone can be a traditional analog hardware telephone, digital hardware telephone, a software telephone (such as session initiation protocol (SIP) client software), or the like that could be used to communicate human voice. Since the capability of a telephone could potentially be implemented using a piece of software executed in a computer, the telephone and computer need not be two different devices and instead, both can be in one computer device.
- The
central voice server 150 can be a traditional PBX (Private Branch Exchange) that has the capability of performing switching functions based on commands received through CTI (Computer Telephony Interface) or software based PBX, or the like. - In accordance with the present invention, the
central data server 100 contains components similar to a computer, such as, but not limited to, a memory, processor, local bus, input/output devices, and a storage device. A detailed description of a generic computer structure is provided hereinbelow. Of course, the storage capability and structure of the storage device within thecentral data server 100 may be different from that of a standard generic computer storage device, however, one having ordinary skill in the art would know such structure and differences. In accordance with the first exemplary embodiment, thecentral data server 100 may store therein a list of customers for contacting, as well as data regarding the customers. Such data may include data that is typically used in marketing such as, but not limited to, account name, contact full name, address, phone number, date last contacted, notes regarding results of the last communication, and other data. - Since the capability of the
central voice server 150 could be implemented using software executed in a computer, thecentral data server 100 andcentral voice server 150 need not be two different devices and instead both could be in one computer. - Telephone communication links 12, 14, and 16 could be implemented using traditional analog telephone lines or digital telephone lines utilizing various digital communication protocols such as SIP, PRI (Primary Rate Interface), or the like. In addition, computer communication links 11 and 13 could be implemented using a LAN (Local Area Network), a WAN (Wide Area Network), mobile network, or the like. A central
server communication link 15 may also be provided for communication between thecentral data server 100 and thecentral voice server 150. The centralserver communication link 15 can be implemented using computer communication links or phone communication links described above. - One having ordinary skill in the art would understand the various types of devices, types of telephone communication links, and computer communication links that could be used in a
system 10 embodying the present invention, and that other such devices and links may be provided. -
FIG. 2 is a block diagram further illustrating ageneral purpose computer 300. Generally, in terms of hardware architecture, as shown inFIG. 2 , thecomputer 300 includes aprocessor 302,memory 310,storage device 304, and one or more input and/or output (I/O) devices 306 (or peripherals) that are communicatively coupled via alocal interface 308. Thelocal interface 308 can be, for example but not limited to, one or more buses or other wired or wireless connections, as is known in the art. Thelocal interface 308 may have additional elements, which are omitted for simplicity, such as controllers, buffers (caches), drivers, repeaters, and receivers, to enable communications. Further, thelocal interface 308 may include address, control, and/or data connections to enable appropriate communications among the aforementioned components. - The
processor 302 is a hardware device for executing software, particularly that stored in thememory 310. Theprocessor 302 can be any custom made or commercially available processor, a central processing unit (CPU), an auxiliary processor among several processors associated with thecomputer 300, a semiconductor based microprocessor (in the form of a microchip or chip set), a macroprocessor, or generally any device for executing software instructions. - The
memory 310 can include any one or combination of volatile memory elements (e.g., random access memory (RAM, such as DRAM, SRAM, SDRAM, etc.)) and nonvolatile memory elements (e.g., ROM, hard drive, tape, CDROM, etc.). Moreover, thememory 310 may incorporate electronic, magnetic, optical, and/or other types of storage media. Note that thememory 310 can have a distributed architecture, where various components are situated remote from one another, but can be accessed by theprocessor 302. - The
software 350 in thememory 310 may include one or more separate programs, each of which contains an ordered listing of executable instructions for implementing logical functions of the system, as described below. As an example, in the case of the dialing agent computer 20, thesoftware 350 would contain an ordered listing of executable instructions for implementing logical functions required of the dialing agent computer 20, as described below. In addition, in the case of thetalker computer 24, thesoftware 350 would contain an ordered listing of executable instructions for implementing logical functions required of thetalker computer 24, as described below. Further, in the case of thecentral data server 100, thesoftware 350 would contain an ordered listing of executable instructions for implementing logical functions required of thecentral data server 100, as described below. - It should be noted that in accordance with an alternative embodiment of the invention, software of the dialing agent computer 20, software of the
talker computer 24, and software of thecentral data server 100 may instead be one software package having separate modules to perform functionality of the dialing agent computer 20, thetalker computer 24, and thecentral data server 100, respectively. - Although not required, it is possible for the
memory 310 to contain an operating system (O/S) 312. Theoperating system 312 essentially controls the execution of computer programs and provides scheduling, input-output control, file and data management, memory management, and communication control and related services. - Functionality of the computer may be provided by a source program, executable program (object code), script, or any other entity containing a set of instructions to be performed. When a source program, then the program needs to be translated via a compiler, assembler, interpreter, or the like, which may or may not be included within the
memory 310, so as to operate properly in connection with the O/S 312. Furthermore, functionality of the computer can be written as (a) an object oriented programming language, which has classes of data and methods, or (b) a procedure programming language, which has routines, subroutines, and/or functions. - The I/
O devices 306 may include input devices, for example but not limited to, a microphone, a keyboard, mouse, scanner, joystick or other input device. Furthermore, the I/O devices 306 may also include output devices, for example but not limited to, a display, or other output devices. The I/O devices 306 may further include devices that communicate via both inputs and outputs, for instance but not limited to, a modulator/demodulator (modem; for accessing another device, system, or network), a radio frequency (RF) or other transceiver, a telephonic interface, a bridge, a router, or other devices that function both as an input and an output. - When the
computer 300 is in operation, theprocessor 302 is configured to execute thesoftware 350 stored within thememory 310, to communicate data to and from thememory 310, and to generally control operations of thecomputer 300 pursuant to thesoftware 350. Thesoftware 350 and the O/S 312, in whole or in part, but typically the latter, are read by theprocessor 302, perhaps buffered within theprocessor 302, and then executed. - When the functionality of the computer is implemented in software, as is shown in
FIG. 2 , it should be noted that the functionality can be stored on any computer readable medium for use by or in connection with any computer related system or method. In the context of this document, a computer readable medium is an electronic, magnetic, optical, or other physical device or means that can contain or store a computer program for use by or in connection with a computer related system or method. The functionality can be embodied in any computer-readable medium for use by or in connection with an instruction execution system, apparatus, or device, such as a computer-based system, processor-containing system, or other system that can fetch the instructions from the instruction execution system, apparatus, or device and execute the instructions. In the context of this document, a “computer-readable medium” can be any means that can store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device. - The computer readable medium can be, for example but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or propagation medium. More specific examples (a nonexhaustive list) of the computer-readable medium would include the following: an electrical connection (electronic) having one or more wires, a portable computer diskette (magnetic), a random access memory (RAM) (electronic), a read-only memory (ROM) (electronic), an erasable programmable read-only memory (EPROM, EEPROM, or Flash memory) (electronic), an optical fiber (optical), and a portable compact disc read-only memory (CDROM) (optical). Note that the computer-readable medium could even be paper or another suitable medium upon which the program is printed, as the program can be electronically captured, via for instance optical scanning of the paper or other medium, then compiled, interpreted or otherwise processed in a suitable manner if necessary, and then stored in a computer memory.
- In an alternative embodiment, where the functionality of the computer is implemented in hardware, the functionality can be implemented with any or a combination of the following technologies, which are each well known in the art: a discrete logic circuit(s) having logic gates for implementing logic functions upon data signals, an application specific integrated circuit (ASIC) having appropriate combinational logic gates, a programmable gate array(s) (PGA), a field programmable gate array (FPGA), or other technologies.
-
FIG. 3 is aflowchart 400 illustrating an initiation process performed by thecentral data server 100 in order to maximize efficiency in call transfers. It should be noted that any process descriptions or blocks in flowcharts should be understood as representing modules, segments, portions of code, or steps that include one or more instructions for implementing specific logical functions in the process, and alternative implementations are included within the scope of the present invention in which functions may be executed out of order from that shown or discussed, including substantially concurrently or in reverse order, depending on the functionality involved, as would be understood by those reasonably skilled in the art of the present invention. In addition, it may be the case that a function may be skipped. - As shown by
block 402, customer data that is used for dialing customers is made available in thecentral data server 100. Customer data may be imported into thecentral data server 100 one or more customer records at a time from one or more file, or each customer record of the customer data may be individually entered directly into thecentral data server 100. One having ordinary skill in the art would appreciate that other methods may be used to populate customer data into thecentral data server 100. - As shown by
block 404, thecentral data server 100 creates a customer list for use in a campaign. Creation of the customer list is based on specific criteria that is important to selecting an appropriate customer for marketing purposes. As an example, if calls are being made for purposes of speaking with potential purchasers of male shaving products, it might be beneficial to have the customer list include only males over the age of sixteen. As a way of another example, if calls are being made for purposes of speaking with potential purchasers of office supplies, it might be beneficial to have the customer list include only customers whose job function is related to purchasing office supplies for their businesses. Thecentral data server 100 may use any known methods for creating the customer list, such as, but not limited to, indexing the customer list based upon key words and querying the customer list based on specific search criteria. - The customer list may be created by a user of the present system. As an example, a talker may log into the
central data server 100, via use of thetalker computer 24 and associated software, for creating of a customer list.FIG. 4 is an exemplary screen view illustrating aninterface 450 for creating a customer list based on specific search criteria, which may be viewed by a party logging into thecentral data server 100 and selecting to create a customer list. As shown byFIG. 4 , theinterface 450 contains aname field 452 for providing a name for the customer list, adescription field 454 for describing the customer list, asearch condition field 456 for specifying how to search the customers within thecentral data server 100 in creating the customer list, and asort field 458 for sorting the resulting customers. It should be noted that there could be more than one search condition field and more than one sort field. - Returning to
FIG. 3 , as shown byblock 406, a campaign may be created. A campaign is created by a user of thecentral data server 100 selecting to create a campaign and thecentral data server 100 creating the campaign after the user has provided specific requested information for creation of the campaign. As an example, the user may be a talker that logs into thecentral data server 100, via use of thetalker computer 24 and associated software, for creating a campaign. In creating the campaign, dialing agents, talkers, and time slots are selected. A campaign may be created in the system by scheduling specific time with one or more dialing agents to dial a specific customer list, transfer calls to specific talkers, and update the customer information. -
FIG. 5 is an exemplary screen view illustrating aninterface 470 for creating and scheduling a campaign specifying one or more talker and one or more dialing agent. As shown byFIG. 5 , theinterface 470 contains: acampaign name field 472, for identifying the name of the campaign; acampaign type field 474, for identifying the type of campaign for classification and reporting purposes; astart time field 476 for defining the start time of the campaign (date and time in the day); anend time field 478 for defining the end time of the campaign (data and time in the day); acost field 480 for defining the cost associated with a campaign and tracking the budget against a specific type of campaigns; atalker field 482 for identifying one or more talkers for the campaign; a dialingagent field 484 for identifying one or more dialing agents for the campaign; and, alist selection field 486 for identifying specific predefined lists that may be of interest to the campaign creator (such as the example shown of the contacts in Nevada). - The
interface 470 also contains: a dialer column field 488 for defining which column in the customer record should be used to obtain the phone number to dial the customer; a calledID display field 490 for specifying whether or not a specific caller identification should be displayed to the customer during a telephone call; a phoneserver name field 492 for defining which central voice server should be used for the campaign; a phone serverhost address field 494 for defining the computer host address (for example not limited to, IP address or hostname within a domain) of the central voice server; a phoneserver login field 496 for defining a login required for use by the dialing agent and talk to enter a campaign; a phoneserver password field 498 for use by the dialing agent and talker to enter a campaign; and acampaign instructions field 499 for providing any specific instructions (optional) that could be used by the dialing agents or other users of the system. - It should be noted that when a campaign is created, a talker may specify whether to block or unblock the caller ID when the dialing agent is dialing customers during that campaign. If the caller ID is unblocked the talker is allowed to select a list of caller IDs allocated for that campaign and when a customer is dialed by a dialing agent, the
central voice server 150 displays a specific caller ID picked from the list of caller IDs selected by the talker for that campaign. It should be noted that based on the implementation preferences, when a customer is dialed thecentral data server 100 may pick such a specific caller ID by using techniques such as, but not limited to, round robin, random selection, or the like and send such caller ID to thecentral voice server 150 directly or indirectly through the dialing agent computer 20. - Returning to
FIG. 3 , as shown byblock 408, thecentral data server 100 sends a notification to all parties who are assigned as part of the created campaign. As an example, thecentral data server 100 may transmit electronic mail (email) to each dialing agent and talker identified by the campaign. In addition, a calendar event may be transmitted to each dialing agent and talker identified by the campaign, for populating calendar software on the dialing agent computer 20 andtalker computer 24. It should be noted that the notifications may instead be transmitted to personal devices of the dialing agents and talkers, such as to their cellular telephone or personal data assistant. - In an alternative embodiment of the present invention, a campaign could be created with minimal information to just schedule the time slot for the talker and dialing agents, and the other campaign details (for example but not limited to the customer list, caller id blocking or unblocking, which central voice server to be used) could be finalized just before starting the campaign, if required at all. A person having ordinary skill in the art would know how to modify the
interface 470 or to divide the interface into multiple interfaces to implement this embodiment. For example, the campaign details that are not captured during the time of campaign creation could be captured using one or more interface screens just before the talker starting the campaign and then the talker may proceed to start the campaign. -
FIG. 6 is aflowchart 500 illustrating a method for joining a campaign, in accordance with the first exemplary embodiment of the present invention. As shown byblock 502, dialing agents and talker associated with a campaign attempt to join a pre-scheduled campaign from their associated computers. Upon the dialing agent attempting to join a specific campaign, the dialing agent computer 20 (through the dialing agent software) sends a request with the campaign identifier (associated with the specific campaign selected by the dialing agent) to thecentral data server 100 to join the campaign. Upon receiving such request to join the campaign, thecentral data server 100 checks whether the talker has already joined the campaign and, if the talker has not already joined the campaign the dialing agent is forced to wait until the talker joins the campaign and upon the talker joining the campaign the dialing agent is allowed to proceed with joining the campaign. Such mechanism provides flexibility to allow updates to the campaign specific settings (for example, but not limited to, caller ID block or unblock, customer list, etc) and updates to customer data (attributes of the customer data shown as part of the list such as customer account name, customer contact name, title, phone number, email, address, notes history and the like) until up to the moment prior to the talker joining the campaign. - In an alternative embodiment, based on implementation preferences, if the updates to campaign settings and customer data are allowed only until the campaign is created, the dialing agent may be allowed to join the campaign at any time after the campaign is created and need not be forced to wait until the talker joins the campaign.
- The time schedule of the campaign could be used to schedule the availability of dialing agents and the talker, and such time schedule may or may not act as a restriction if the campaign is started at a time outside of the pre-scheduled time.
FIG. 7 is an exemplary screen view illustrating aninterface 550 for the dialing agent or talker to select and attempt to join a campaign. As shown byFIG. 7 , theinterface 550 contains: acampaign name field 552 for selecting the campaign to join; alist name field 554 for displaying the name of the list selected during creation of the campaign; atalker name field 556 for listing the talker(s) assigned to the campaign; a dialingagent name field 558 for displaying the dialing agent(s) assigned to the campaign; astart time field 560 for displaying the start time of the campaign; and, anend time field 562 for displaying the end time of the campaign. - Based on the implementation preferences, depending upon security level of the dialing agent and/or talker, the dialing agent and/or talker may be allowed to, including but not limited to, choose to join the campaign, edit the campaign, create a new campaign, or delete a campaign. While not required, requiring a login of the dialing agent and/or talker into the present system, via the
central data server 100, provides for confirmation of identity. - Returning to
FIG. 6 , when a dialing agent and/or talker has joined the campaign, as shown byblock 504, the customer list and associated customer data for the campaign (associated with the campaign identifier received as part of the request sent by dialing agent's computer to join the campaign) is transmitted from thecentral data server 100 to the computer of the dialing agent and/or talker that has joined the campaign. Transmission of the customer list and customer data is performed upon joining of the campaign to ensure that all data required during communication with a customer is located at the dialing agent computer 20 and thetalker computer 24 prior to the dialing agent selecting to place a call to a customer on the customer list. Specifically, in accordance with the present system and method, the dialing agent computer 20 and thetalker computer 24 contain the customer data prior to the dialing agent selecting to place a call. - In a further alternative embodiment, the
central data server 100 may transmit to a dialing agent computer 20 only the portion of the customer data needed to perform the dialing agent's function and may transmit to thetalker computer 24 only the portion of the customer data needed to perform the talker's function. - In the first exemplary embodiment of the present invention, the customer list and associated customer data may be forwarded at any time prior to beginning of the campaign, as long as the talker has the customer list (in the correct order consistent with the customer list in the dialing agent computer) and customer data on his computer prior to the dialing agent selecting to place a call to a customer.
- In another alternative embodiment of the invention, the dialing agent could be allowed to join the campaign prior to, after, or at the same time as when the talker joins the campaign and flexibility could be provided to allow updates to certain portion of the campaign specific settings (for example, but not limited to, caller ID block or unblock, customer list, and other settings) and updates to customer data (attributes of the customer data shown as part of the list such as customer account name, customer contact name, title, phone number, email, address, notes history and the like) until up to the moment that the talker presses a “GO” button viewed by the
talker computer 24 after joining the campaign. The foregoing flexibility could be achieved by transmitting the updated portion of the campaign specific settings and customer list (with customer data) from one component of thesystem 10 where an update might be taking place (for example, but not limited to, the talker computer 24) to other components of thesystem 10 that need to know such updates (for example, but not limited to, the dialing agent computer 20) upon the talker pressing the “GO” button. - In another alternative embodiment of the invention, having the dialing agent allowed to join the campaign prior to, after, or at the same time as when talker joins the campaign, flexibility could be provided to allow updates to take place to certain portion of the campaign specific settings and customer data until the time even after the talker has joined the campaign and pressed the “GO” button (that is allowing the updates to take place while the campaign is in progress). The foregoing flexibility could be accomplished by synchronizing the updates taking place in one component of the
system 10 with the other components that need to know such updates in real time (or near real time) and the behavior of thesystem 10 could be modified in real time (or near real time). For example, while the campaign is in progress, the talker may recognize that a customer is not the correct target upon reviewing that customer record's notes history shown in thetalker computer 24 and, therefore, the talker would set the do-not-call flag associated with that customer record. Such update is then propagated to thecentral data server 100, which in turn forces thecentral data server 100 not to select that particular customer record for dialing (if that customer record is yet to be dialed). As a way of another example, while the campaign is in progress the talker changes the caller ID for the campaign and such update is propagated to thecentral voice server 150 for use moving forward. It should be noted, based on implementation preferences, such updates may be propagated to thecentral data server 100 to allowcentral data server 100 to have stored therein the updated information for future use. - In another alternative embodiment, the dialing agent may be allowed to join the campaign before, after, or at the same time as, when the talker joins the campaign and the synchronization of updates takes place among different components of the system. Up until the talker presses the “GO” button to start the campaign, the
central data server 100 may not transmit the customer list to the dialing agent computer 20 and thetalker computer 24. Upon the talker pressing the “GO” button via use of thetalker computer 24, thecentral data server 100 may select an initial batch of customer records for dialing and transmits such batch to the dialing agent computer 20 and thetalker computer 24. Upon completing the dialing of a portion of the batch, thecentral data server 100 could select the next batch of customer records for dialing and transmit such next batch to the dialing agent computer 20 and talker computer 24 (and this cycle goes on until the entire customer list is exhausted or the campaign ends). Upon receiving each batch of customer records for dialing, the dialing agent computer 20 andtalker computer 24 may append that batch with the currently shown customer records. Based on implementation preferences, to keep the computer memory utilization low, the previously dialed customer records (that are no longer needed to stay in dialing agent computer 20 and/or talker computer 24) associated with previous batches may be removed from the dialing agent computer 20 andtalker computer 24. Each customer record could have associated priority information (located in one or more fields of the customer record) and thecentral data server 100 could use such priority information to decide on, including but not limited to, whether to move up or move down that customer record within the sequence of customer records selected dynamically for dialing through batches, how many times a specific customer record could re-appear allowing that customer record to be called multiple times with a campaign (or within a specific period of time), time gap between two consecutive calls to the same customer record, etc. - Still in accordance with the abovementioned alternative embodiment, based on implementation preferences, it should be noted that new customer records could be inserted and customer data (including but not limited to priority information) could be updated before starting the campaign or while the dialing session is in progress, by any user of the system and the
central data server 100 may use the updated information as part of the logic used to select the customer records for dialing in the next batch of customer records. Further, thecentral data server 100 may use additional logic to move a particular customer record up or down the sequence of customer records selected dynamically for dialing through batches to make sure that multiple customer records whose calls will be going to the same phone operator are not appearing next to each other in the calling list. The foregoing flexibility may be required to avoid having multiple dialing agents calling the same phone operator concurrently. Thecentral data server 100 may select a customer record for dialing only if the allowed-to-call checkbox is checked. If the allowed-to-call checkbox is checked, thecentral data server 100 may select a customer record only if the current date and time is equal to or after the date and time specified in the “do not call until” field in the customer record. Based on implementation preferences, a variation of the foregoing embodiment could be implemented by having thecentral data server 100 select only one customer record for dialing and transmit to the dialing agent computer 20 andtalker computer 24, upon the dialing agent computer 20 requesting the next customer record for dialing. It should be noted that since thecentral data server 100 is sending each customer record itself only just before dialing, there is no need to send the customer unique ID separately to notify the customer record that is being dialed. If such newly received customer record is appended with other previously received customer records that were previously dialed as initiated by the dialing agent computer 20, the newly received customer record that is being dialed may need to be highlighted to show which customer record is currently being dialed. It should be noted that when multiple dialing agents are participating in the campaign there could be multiple customer records that are being dialed concurrently by multiple dialing agents and such multiple customer records that are currently being dialed could be transmitted to atalker computer 24 for displaying the customer records. If such newly received customer records are appended with other previously received customer records in thetalker computer 24, the newly received customer records that are currently being dialed may need to be highlighted to differentiate the customer records that are being dialed from the previously received and previously dialed customer records. It should be noted that upon the dialing agent transferring a customer call, the associated customer record need to be highlighted differently in thetalker computer 24 to differentiate the customer record that is transferred versus the customer records that are being dialed. Such notification of customer record whose call is transferred could be accomplished by transmitting the customer unique ID since the associated customer record has been transmitted previously when the dialing of that customer record began. A person having ordinary skill in the art would know the various techniques that could be used within the foregoing embodiment. - Returning to the first exemplary embodiment of the invention, the customer list associated with the particular campaign may be displayed in a tabular list on the computer 20 of each dialing agent associated with the campaign and on the
computer 24 of the talker associated with the campaign. It should be noted that the list need not be tabular. -
FIG. 8 is an example of a screenview illustrating an interface 590 provided to a dialing agent while the dialing agent is attempting to join a campaign, where the dialing agent is forced to wait until the talker joins the campaign. Alternatively, if the talker has joined the campaign, the dialing agents are allowed to join the campaign. This is assuming that there is only one talker and one or more dialing agent, however, it is noted that the present system and method may have one or more dialing agent and one or more talker in a campaign. - As shown by
block 506, after joining the campaign through thetalker computer 24, the talker joins a voice conference bridge hosted in thecentral voice server 150 by having thecentral voice server 150 call the phone number of thetalker telephone 26 or by the talker manually calling the conference bridge phone number via use of thetalker telephone 26. Upon joining the voice conference bridge, the talker may be listening to on hold music played in the conference bridge or the talker may simply be placed on hold. -
FIG. 9 is an example of a screenview illustrating aninterface 600 provided to a dialing agent after the dialing agent joining the campaign. As shown byFIG. 9 , theinterface 600 provides a view of the customer list associated with the campaign. Fields of the customer list include an account name field 602, a contact name field 604, a phone number field 606, an email field 608, a last result field 610 for identifying results of the last call and notes history, a created date field 612, and a contact status field 614 for keeping track of the status (for example, but not limited to, the sales status such as “interested to see demo”, “proposal sent”, “contract signed”, etc). It is noted that the customer list and customer data are located on the dialing agent computer 20 prior to initiating customer dialing. - The
interface 600 also contains acurrent status window 616 for identifying a current status of the campaign to the dialing agent. Thecurrent status window 616 contains: acampaign name field 618, which displays the name of the campaign that the dialing agent is assigned to; acampaign time field 620 for displaying the time at which the campaign is scheduled to begin; and acampaign status field 622 for displaying whether the campaign is ready to begin, if the campaign is not ready to begin, or if the campaign is on hold, such as due to the talker being busy, the talker having left the conference bridge, due to the talker not yet having entered the conference bridge, or due to the talker yet to press the “GO” button viewed by thetalker computer 24 to start the campaign. Thecurrent status window 616 also contains: anaccount field 624 for listing the account name for the record currently being transferred; acontact field 626 for listing the contact currently being transferred; aphone number field 628 for listing the phone number of the contact currently being transferred; and, acall status field 630 for listing the current call status. Thecurrent status window 616 also contains atransfer button 632 for allowing the dialing agent to transfer a call to a talker, as is described in further detail hereinbelow. -
FIG. 10 is an example of a screenview illustrating aninterface 650 provided to a talker after the talker joins a campaign using thetalker computer 24, but where the talker is yet to join the voice conference bridge using thetalker telephone 26. Theinterface 650 shows various fields (including but not limited to campaign name, campaign start time, campaign status, conference bridge phone number, conference bridge ID, password, number of dialing agents who joined the campaign, number of customer records dialed so far, number of customer calls transferred so far, currently transferred customer record fields, etc) that are appropriate for the talker. In addition,FIG. 11 is an example of a screenview illustrating aninterface 700 provided to a talker after the talker joins a campaign using thetalker computer 24, and after the talker has joined the voice conference bridge using thetalker telephone 26. As shown byFIG. 11 , astatus window 702 of theinterface 700 displays the status of thesystem 10 as ready to start. It should be noted that based on implementation preferences, thestatus window 702 could be implemented as a part of the window where the customer list with customer data is shown. - In accordance with the first exemplary embodiment, the campaign becomes ready to start when the following conditions are met: i) the talker joins the campaign through the
talker computer 24; ii) the talker is connected to the voice conference bridge through thetalker telephone 26; and, iii) one or more dialing agents join the campaign through their computers and are ready to dial customers. -
FIG. 12 is aflowchart 750 illustrating actions initiated and performed during initiation of a campaign. WhileFIG. 12 is provided with regard to a single dialing agent, one having ordinary skill in the art would appreciate that there may be more than one dialing agent in the present system, resulting in the steps ofFIG. 12 being performed by each dialing agent. As shown byblock 752, the dialingagent computer 24 checks whether the campaign is on hold. Though the campaign is ready to start, the campaign may remain on hold until the talker presses a “Go” button, or performs another step to show that the talker is ready for the campaign to begin. If the talker prefers, before starting the campaign by pressing the “Go” button, the talker may pre-record a voice message by pressing a button provided by the talker software located on thetalker computer 24, and requesting one or more dialing agent to play a pre-recorded voice message of the talker whenever the dialing agent encounters a voice mail of the customer as a result of the customer call going to the customer's voice mail. - As shown by
block 754, once the campaign starts, meaning that the campaign is not on hold, the dialing agent computer 20, via the dialing agent software, requests from the central data server 100 a unique identifier associated with the record of a specific customer to call. Though the dialing agent is referred here in singular term in order to simplify the description, there could be multiple dialing agents joining the campaign and performing the actions associated with the dialing agent. - As shown by
block 756, thecentral data server 100 responds to the dialing agent computer 20 by transmitting a customer unique identifier to the dialing agent computer 20 and concurrently thecentral data server 100 transmits the same customer unique identifier to thetalker computer 24. The customer unique identifier is specifically designed to be very short in size. For example, the customer unique identifier could be just a row identifier starting from 1 to n (where ‘n’ is the maximum number of records shown by the customer list). - In an embodiment having multiple dialing agents, to avoid conflicts, the
central data server 100 assigns different records in the customer list to different dialing agents. The customer record dialed by the dialing agent is highlighted on the computer screen of the dialing agent as well as the computer screen of the talker. - As shown by block 758, the dialing agent computer 20, via the dialing agent software, locates the customer record associated with the customer unique identifier received from the
central data server 100, in the customer list, and highlights that customer record in the tabular list on the screen associated with the dialing agent computer 20, which is viewed by the dialing agent. Concurrently, thetalker computer 24, via the talker computer software, locates the same customer record and highlights that customer record in the tabular list on the screen associated with thetalker computer 24, which is viewed by the talker. - At any given time, if more than one dialing agent is dialing the customer records in the customer list, all such customer records dialed by different dialing agents are highlighted in the tabular list on the computer screen of the talker. It should be noted that the customer list may or may not be displayed in a tabular list format on the dialing agent computer 20 or the
talker computer 24. The talker could review the notes history of customers that are being dialed and get ready to handle the transferred customer call. By following this sequence, the talker is capable of reviewing customer data and being prepared for a transferred customer call prior to receiving the customer call (described hereinbelow). In this manner a meaningful conversation between the taker and the customer may begin right away with transfer of the customer call to the talker, since the talker has previously received and reviewed the customer data well in advance of the call transfer, as was aware of the customer records being dialed. Based on the implementation preferences, it should be noted that certain portions of the customer data that the talker needs to review could be readily shown in the talker computer and additional portion of the customer data could be fetched from a database and shown to the talker upon the talker requesting such portion of data by clicking specific icons or buttons or links. In accordance with the first exemplary embodiment of the present invention, if time permits, the talker could also review the notes history of customers in the list who will be dialed in the near future. - Instead of transferring customer data with a call transfer, as performed by prior systems, the present system and method transfers unique identifiers for highlighting records presently being called and highlighting calls being transferred to the talker, where customers presently being called are highlighted different from customers being transferred to the talker. The process for transferring unique identifiers and highlighting is described in additional detail hereinbelow.
- As shown by block 760, upon request from the dialing agent computer 20 to start dialing a specific customer phone number (associated with the unique customer identifier received from the central data server), the
central voice server 150 starts dialing that phone number. It should be noted that the objective of the function shown by block 760 is to establish a call between the dialing agent and customer. The dialing agent uses his/hertelephone 22 to navigate the phone menus, interactive voice response systems, wrong phone numbers, phone operators, and the like to reach the correct customer. Based on implementation preferences, the dialing agent computer could send a dial request directly to thecentral voice server 150 or indirectly to thecentral voice server 150 through thecentral data server 100. In accordance with the first exemplary embodiment, the dialing agent has not previously joined a voice conference bridge hosted in thecentral voice server 150. When the dialing agent computer 20 requests thecentral voice server 150 to start dialing a specific customer phone number (associated with the unique customer ID), thecentral voice server 150 starts dialing the dialingagent telephone 22 and upon the dialing agent answering the dialingagent telephone 22 thecentral voice server 150 proceeds to start dialing the customer phone and bridges the customer call with dialing agent. It should be noted that based on the implementation preferences, the dialingagent telephone 22 could be configured to answer automatically (sometimes referred as “auto answering”) when the call is made by thecentral voice server 150 and in which case the dialingagent telephone 22 automatically answers without having the dialing agent answer. - In an alternative embodiment in accordance with the present invention, after the dialing agent joins the campaign through the dialing agent computer 20, the dialing agent joins a voice conference bridge hosted in the
central voice server 150 by having thecentral voice server 150 call the phone number of the dialingagent telephone 22 or by the dialing agent manually calling the conference bridge phone number via use of the dialingagent telephone 22. Upon joining the voice conference bridge, the talker may be listening to on hold music played in the conference bridge or the dialing agent may be simply placed on hold. In the foregoing embodiment, when the dialing agent computer 20 requests thecentral voice server 150 to start dialing a specific customer phone number (associated with the unique customer ID), thecentral voice server 150 starts dialing the customer phone number and bridges the customer call with the dialing agent waiting in the conference bridge. One having ordinary skill in the art would know the various techniques that could be used to accomplish the function depicted by block 760. - In an alternative embodiment, the function depicted by block 760 could be implemented by having the
central data server 100 make a request to thecentral voice server 150 to dial the customer phone number (associated with the customer unique identifier) concurrently when thecentral data server 100 transmits the customer unique identifier to the dialing agent computer 20 and thetalker computer 24 as shown byblock 756, thereby eliminating the need to have the dialing agent make a request to dial the customer record as shown by the block 760. - In an alternative embodiment, when calling a customer the caller ID displayed could be dynamically customized based on the attributes of the customer phone number. For example but not limited to, based on the geographical area code of the customer phone number the caller ID could be a phone number that belongs to the same area code as the customer area code or an area code closer to the customer's area code.
-
FIG. 13 is an example of a screenview illustrating aninterface 780 provided to a dialing agent during the dialing of a customer. As shown byFIG. 13 , the customer record of the customer currently being dialed is highlighted 782 so that the dialing agent is aware of which customer is currently being dialed. In addition, an interface window 784 is provided for providing the dialing agent with a status of the current call and for allowing the dialing agent to provide instructions to the dialing agent computer 20. As shown byFIG. 13 , the interface window 784 displays the campaign name, campaign time, campaign status, account name, contact, phone number, and call status for the current call. Options to hang up, take a break, and dial the next number are provided to the dialing agent. In addition, an option is provided on the interface window 784 to play a voice message (pre-recorded voice message of the talker that could be played whenever the dialing agent encounters a voice mail of the customer as a result of the customer call going to the customer's voice mail). Further, an option is provided on the interface window 784 to transfer a call to the talker. - Each dialing agent may take a break by clicking a “Take a break” button, in which case the dialing agent software pauses, allowing the dialing agent to take a break until the “Resume” button is clicked. It should be noted that upon clicking the “Take a break” button if there is a customer call already in progress it may not be appropriate to hang up that call and instead the dialing agent may continue to complete such call using the
dialing agent telephone 22 and then proceed to take the break. The talker may take a break by pressing the “Hold” button, in which case thetalker computer 24 requests thecentral data server 100 to put the campaign on hold and thecentral data server 100 puts the campaign on hold allowing the talker to take a break until the “Go” button is pressed. After the campaign goes on hold; i) dialing agents are not allowed to transfer any more calls to the talker and any previously initiated calls should be handled by dialing agents by performing certain pre-defined tasks (hang up, hang up now and redial when the campaign resumes, follow pre-defined script and the like); and, ii) dialing agents are not allowed to initiate new calls. A person having ordinary skill in the art would know that in an alternative embodiment having multiple talkers, when a talker requests to take a break by pressing the “Hold” button, only that particular talker could be given a break (that is, that particular talker is not ready to take the transferred customer call) and the campaign could continue if at least one other talker is ready to take the transferred customer call. The campaign may not be put on hold as long as at least one talker is ready to take the transferred customer call. -
FIG. 14 is aflowchart 800 illustrating a process of handling a call after dialing by thecentral voice server 150. As shown byblock 802, the dialing agent determines whether the correct customer is reached by recognizing live customer voice in the phone call. Based on the implementation of voice recognition technology, the dialing agent may perform the foregoing determination with or without the help of voice recognition technology. - As shown by block 804, upon determining that the correct customer could not be reached, the dialing agent performs certain pre-defined tasks, such as, for example, but not limited to, playing a pre-recorded voice message recorded by the talker previously (if the customer call results in a customer voicemail) or leaving a voice message using the voice of the dialing agent (if the customer call results in a customer voicemail), entering notes against the customer record, and the like.
- As shown by
block 806, upon determining that the correct customer is reached (by recognizing live customer voice in the phone call), the dialing agent presses the transfer button provided by the dialing agent software, within the interface window 784, and the campaign status is determined to know whether the campaign is on hold or not. The campaign will go on hold for various reasons such as when the talker is busy talking to another customer, when the talker has left the system, and the like. When the campaign is on hold, the customer call cannot be transferred since there is no talker available to talk to the customer. It should be noted that thecentral data server 100 may keep checking the campaign status continuously and keep updating the campaign status on the screen of the dialing agent. Checking the campaign status may take place by the software of thecentral data server 100 by continuously monitoring (in short time intervals) to know whether the talker is ready to take the customer call (for example but not limited to, by checking whether the talker is still waiting in the conference bridge and by checking whether thetalker computer 24 is in continuous communication with the central data server 100). Campaign status information is also proactively maintained. Such campaign status information could be used to take actions proactively in the system, for example but not limited to, the action described in the succeeding sentence. - Before attempting to transfer the call, if the dialing agent sees the campaign status as being on hold, the dialing agent need not attempt to press the transfer button provided by the dialing agent software and instead proceeds to the step shown by
block 808. As shown byblock 808, upon determining that the campaign is on hold, the dialing agent performs certain pre-defined tasks such as talking to the customer and scheduling an appointment for the talker and the customer to connect later, and the like. - As shown by block 810, upon determining that the campaign is not on hold, the dialing agent software transfers the call to the conference bridge of the talker and notifies the
central data server 100 with the transferred customer unique identifier. Simultaneously, when the call is transferred, thecentral data server 100 puts the campaign on hold to make sure that another dialing agent cannot transfer another customer to the talker. - Based on implementation preferences, the call transfer function illustrated by block 810 could be implemented by having the dialing agent software send a transfer command directly to the
central voice server 150 or indirectly to thecentral voice server 150 through thecentral data server 100. In an embodiment where the dialing agent computer 20 sends the customer call transfer request indirectly to thecentral voice server 150 through thecentral data server 100, the dialing agent computer 20 could send a request to thecentral data server 100 to transfer the customer call. Upon receiving such request, thecentral data server 100 could check whether the campaign is on hold, upon determining that the campaign not on hold, thecentral data server 100 can proceed to put the campaign on hold, and then transfer the customer call to the conference bridge of the talker (by sending a request to the central voice server 150). - Upon the transfer of the call, the on hold music played to the talker will stop (if on hold music was being played), a short beep sound will be played to alert the talker, and the talker can start the conversation with the customer. When the customer call is transferred, concurrently the
central data server 100 receives the transferred customer unique identifier from the dialing agent computer 20 and then transmits to thetalker computer 24 the unique identifier of the customer who is being transferred. - In another embodiment of the present invention, upon call transfer request from the dialing agent computer 20 (depicted by the block 810) the
central voice server 150 could start playing a pre-recorded voice greeting previously recorded by the talker to the customer called first and then proceed to transfer the customer call to the talker (or such pre-recorded greeting could be played concurrently while the customer call is transferred to talker). The foregoing arrangement could keep the customer engaged while the customer call is being transferred and provide a few extra seconds of time for the talker to get started with the conversation. It should be noted that upon the customer call transfer the talker may hear his/her pre-recorded greeting being played to the customer and waits until his greeting is completed playing and then start the conversation. - As shown by
block 812, the customer record associated with the transferred unique identifier is highlighted differently in the tabular list shown on thetalker computer 24. The unique identifier of the transferred customer has already been provided to thetalker computer 24 when the dialing agent began dialing and the associated customer record was highlighted in the talker computer 24 (ahead of call transfer) to allow the talker to be prepared and during the step depicted by block 810 the same customer unique identifier is sent a second time to notify the talker of which one of the customers is transferred among the few customers being dialed. Since the talker has already reviewed the customer data ahead of call transfer, the talker is able to respond effectively without delay and have a productive conversation. It should be noted that highlighting of the customer record associated with the transferred unique identifier may be performed in many different manners. As an example, the customer record associated with the transferred unique identifier may be highlighted in a different color than the other customer records that are being dialed on the customer list. - In accordance with the present invention, upon dialing agent ending a customer call the dialing agent computer 20 could transmit the customer unique ID and the status of the call being ended to the
central data server 100 andcentral data server 100 notifies thetalker computer 24 of the customer unique ID and provides the status of call as having been ended. Upon receiving such information, thetalker computer 24 could remove the highlighting of that customer record since the dialing of that customer record has ended (based on implementation preferences, instead of removing the highlighting of that customer record it could be highlighted in a separate color or shade to indicate that customer record has been dialed and such dialing has ended without resulting in a customer call transfer). -
FIG. 15 is an example of a screenview illustrating aninterface 900 provided to talker when 3 customer records are being dialed by the dialing agents. As shown byFIG. 15 , the 3 customer records that are currently being dialed are highlighted 904 to show to the talker which customer records are currently being dialed. Noteshistory 906 is shown to the talker. In addition, astatus window 902 shows the campaign status, number of dialing agents currently dialing, number of dials so far and other relevant information.Status window 902 provides the options to put the campaign on Hold and GO. -
FIG. 16 is an example of a screenview illustrating aninterface 950 provided to talker when a customer call is transferred to talker and 2 other customer records are being dialed. As shown byFIG. 16 , the transferred customer record is shaded differently 956 to differentiate the transferred customer record from the other 2customer records 958 that are being dialed. In addition, astatus window 952 shows the currently transferred customer record fields (account name, contact name, phone number, etc), campaign status, number of dialing agents currently dialing, number of dials so far and other relevant information. Further, awindow 954 is shown where the talker enters notes and schedules a follow up. - In accordance with the present invention, upon the dialing agent transferring a customer call or ending a customer call that did not result in a call transfer, the dialing agent computer 20 could repeat the steps of
FIG. 12 to continue to dial the next customer record associated with the next customer unique identifier transmitted by thecentral data server 100 for dialing. This cycle may continue until the dialing agent exits the campaign or the campaign ends. - In accordance with the present invention, although not a necessity, the dialing agents and talker can update the customer information and notes, and schedule follow up events. For example, the dialing agent might learn that a specific customer no longer works in a business or that the phone number is a wrong phone number or a different contact within a business is the right decision maker, resulting in the dialing agent inserting a new customer record(s) or modifying the customer information to properly reflect current information. In addition, the present system, via the
central data server 100,central voice server 150, thetaker computer 24, and the dialing agent computer 20, collects various data such as the number of dials made by each dialing agent, the number of calls transferred by each dialing agent, call duration, and the like. A report could be generated based on the collected data. - In accordance with an alternative embodiment of the invention, once the talker makes the decision to end the campaign, the talker closes down the campaign screen on the
talker computer 24. Upon such closing down of screen in thetalker computer 24 requests thecentral data server 100 to end the campaign and in turn thecentral data server 100 notifies thecentral voice server 150 to end the campaign (and thecentral voice server 150 ends the campaign by ending the telephone connection of the talker to the voice conference bridge) and changes the campaign status as being ended or closed. This forces all of the dialing agents for that campaign to close down their screens, by having the dialing agent software continuously monitor in short time intervals to know whether the campaign has been closed and upon knowing that the campaign has been closed the dialing agent software could force the dialing agent to close down their screens. When the campaign is started again, the talker has the ability to notify thecentral data server 100 to start the dialing from a specific customer record in the customer list (instead of starting from the beginning of the customer list). - In an embodiment of the present invention, the
central data server 100 could be implemented using Web application server technologies or stand alone server technology that interacts with other components of thesystem 10 through client-server technology. Thecentral voice server 150 could be implemented using a PBX system such as Asterisk. Dialing agent software and talker software may be implemented using stand-alone code that communicates with other components of the system through client-server technology, or using web browser Ajax technology or web browser with plug-in, or using a combination of Web technology and automatic delivery of code from a Web server to browsers using technologies for example but not limited to Java or ActiveX. The system may or may not integrate with a third party customer relationship management (“CRM”) to implement the functions of the central data server, dialing agent software, and talker software. Communication between thecentral voice server 150 and other components of thesystem 10 may or may not go through thecentral data server 100. Based on implementation preferences, communication between any two components of thesystem 10 could be accomplished using various mechanisms such as but not limited to Ethernet, Internet, TCP/IP, and shared memory based communication, and shared storage based communication. Further, based on implementation preferences, communication between any two components of thesystem 10 could be accomplished using messages with variations in content. For example, upon customer call transfer thecentral data server 100 could transmit to the talker computer 24 a portion of the customer record that could be used to uniquely identify the transferred customer record in thetalker computer 24 instead transmitting the unique customer identifier associated with the transferred customer. Based on implementation preferences, the components of the system may or may not use a local or server based database system to store and retrieve customer lists and data. - Based on the type of technology used for communication between any two components of the
system 10 and choice of the method used for embodying the current invention, a component may act only as a client or may act only a server or may act as both a client and a server. Based on implementation preferences, the functions performed by each component of the system (including but not limited to, central data server, central voice server, talker software, and dialing agent software) could be restructured by removing a specific function (whole function or a portion of a function) from one component and delegating such function to be performed by another component. In an embodiment, a portion of the function performed by thecentral data server 100 that involves the transmission of the customer list to one or more component of the system 10 (for example but not limited to having dialing agent computer 20 and talker computer 24) directly retrieve the customer list from a file or database that is accessible and limit the function of thecentral data server 100 to provide the necessary data (such as but not limited to, campaign status) for coordination among the components of thesystem 10. In an alternative embodiment, the whole function performed by thecentral data server 100 could be delegated by having the dialing agent computer 20,talker computer 24, andcentral voice server 150 communicate among themselves and coordinate among themselves to accomplish the overall function ofsystem 10 of the present invention and thereby eliminating the need to have thecentral data server 100 as part of thesystem 10. To accomplish the foregoing example, techniques such as but not limited to communication and coordination among multiple components of system 10 (including but not limited to dialing agent computer 20,talker computer 24, and central voice server 150) via shared memory or local memory in each component that is being synchronized with the local memory of the other components. It should be noted that communication via shared memory is a possibility if the different components ofsystem 10 are implemented to be located in a computer (including but not limited a server, cluster of computers, computer network, or the like) that makes such shared memory available for access by multiple components. Such implementation where the different components of the system 10 (such as but not limited to dialing agent computer 20 and talker computer 24) to be located in a computer (that provides shared memory access among the components) could be accomplished with the technique that is described herein below. - It should be noted that the dialing agent computer 20,
talker computer 24, and any other computer that requires the interaction with a user in thesystem 10 could be implemented by having a computer terminal that provides access to a remote computer where the remote computer performs the function of the computer. In such mechanism, certain resources (including but not limited to screen and peripheral device) and events of the remote computer are mapped to the computer terminal. The foregoing implementation could be accomplished using technologies, such as but not limited to, remote desktop client, remote desktop connection, remote desktop server, computer terminal, terminal server, and the like. For example, the dialing agent computer 20 could be a computer terminal that has remote desktop client software which connects to the remote desktop server (where dialing agent software is located) and the dialing agent is allowed to see the dialing agent software interface (and interact with the dialing agent software) located in the remote desktop server via the computer terminal. As a way of another example, similar to the foregoing example, thetalker computer 24 could be a computer terminal allowing the talker to see and interact with the talker software located in the remote desktop server. It should be noted that by using the foregoing technique it is possible to have the dialing agent software, talker software, thecentral data server 100, and the central voice server be located in the same server (and based on the implementation preferences such components may or may be implemented as software modules in the server). Based on the implementation preferences, such server could provide shared memory access to the different components of the system for communication and coordination. - Further, one component of the system could send and receive information directly from the other component or indirectly through one or more components. For example, based on implementation preferences, the call transfer function depicted by the block 810 (in
FIG. 14 ) could be implemented by having the dialing agent software send a call transfer request to thecentral voice server 150 directly, or the same call transfer function could be implemented by having the dialing agent software send a call transfer request to thecentral data server 100 and in turn thecentral data server 100 send a call transfer request to thecentral voice server 150. As a way of another example, in the step illustrated by block 504 (inFIG. 6 ) instead of transmitting the customer list and associated customer data to the dialing agent computer 20 and/ortalker computer 24, thecentral data server 100 may transmit only customer list information and the source (for example, but not limited to, a specific database) from where to get the associated customer data and the dialing agent computer 20 and/ortalker computer 24 may get the customer data from the source specified by thecentral data server 100. - Based on the implementation preferences, each component of the
system 10 could be a logical component that is implemented by having multiple instances of the component working with or without coordination among such instances. Such implementation may be needed to improve the attributes of thesystem 10, such as but not limited to, the scalability, reliability, redundancy, and availability. Some of the techniques that could be used in such implementation could be, including but not limited to, clustering, load balancing, distributed computing and cloud computing). For example, thecentral data server 100 could be implemented by having more than one computer configured to work as a cluster for the purposes of, including but not limited to, balancing the work load among the computers in the cluster, delegating the function performed by a non-working computer (when a computer in the cluster is not working due to failure or shut down intentionally by maintenance personnel for maintenance) to other computers in the cluster in order to maintain high availability, and keep the overall cost of thecentral data server 100. It should be noted when a component ofsystem 10 is implemented by having multiple instances (as described herein above), one or more instances may or may not share the same processor, memory, storage, and the like. A person having ordinary skill in the art would understand the various forms of technologies and techniques that could be used to embody the invention. - It should be noted that the highlighting of customer records, as described herein, may be used to highlight the dialing agent screen and the talker screen to differentiate the customers who are being dialed, who is currently transferred, who were previously transferred, who were unsuccessfully dialed previously that did not result in a call transfer, to whom dialing agents have successfully played a pre-recorded voice message previously recorded by talker, and to represent other customer status. In addition, highlighting may be performed by one or more of many different methods such as, but not limited to, changing colors, blinking, circling, shading, changing the border around the customer information, showing the customer information in specific area of the screen, and pointing to customer information shown in the computer.
- In addition to the abovementioned, in accordance with the first embodiment, since a specific talker is pre-selected for a given campaign, at the time of call transfer the system knows the talker ahead of time and the system does not have to look for an available talker at the time of call transfer. Hence, the speed of call transfer is faster.
- Various components of the present system may be designed to update each other continuously (with short time intervals between updates) and such updates could include, but are not limited to, updates of information that need to be exchanged between the components and the information about whether the connectivity between them is healthy. Such updates could be implemented by having one component poll the other component continuously (with short time intervals between the polling) to provide updates as well as receive updates at the same time. If the technology used for implementation permits, such updates may be performed asynchronously by having a component send updates to other component(s) only when there is a change of information that needs to be exchanged. It should be noted that the present system may be implemented to perform security checks at various steps to ensure proper authentication of user of the system and appropriate authorization to access various functions of the system and/or access or update various portions of data in the system.
- It is also beneficial to have a policy for handling customer calls when the talker is busy. In accordance with an alternative embodiment of the invention, once a call is transferred, the talker will be busy in attending the call transferred to the conference bridge (where the talker is waiting readily) and the campaign data server software will put the campaign on a hold status. After the campaign goes into a hold status, any other call currently in progress between the dialing agent and the customer could be dropped and, based on the option, redialed again when the campaign resumes or the dialing agent may proceed with the call and talk to the customer to arrange a scheduled time for the talker to contact the customer directly at a later time.
- In accordance with another alternative embodiment of the invention, besides highlighting the customer record that is being dialed in both the dialing agent computer 20 and the
talker computer 24, the system could continuously exchange among thetalker computer 24 and the dialing agent computer 20 the incremental updates made to customer records. To accomplish such exchange of updates without compromising the speed of call transfer, the exchange of incremental updates of customer data could be performed at a lower priority and the task of transferring the call (and the associated customer's unique identifier) could be performed at a higher priority. - In accordance with a further alternative embodiment of the invention, instead of using a conference bridge as a mechanism in the
central voice server 150, the system could use other mechanisms that allow the talker to wait readily to handle the transferred customer call. Such alternative mechanisms could include, but are not limited to, queue, parking lot, and the like. A person having ordinary skill in the art of the present invention would understand the various types of mechanisms in the central voice server that could be used in a system embodying the present invention. - While the abovementioned did mention that more than one dialing agent and more than one talker may be provided within the present system and method, in another embodiment of the present invention, the system could be implemented to have more than one talker wait in a queue (or alternative mechanisms) to handle the transferred customer calls. This configuration reduces the chances of needing the dialing agent to handle the customer call himself/herself due to the talker becoming busy. The higher the number of talkers available, the lesser the chance of not having a talker available to handle the transferred customer call and, in turn, the lesser the chance of the dialing agent needing to handle the customer call himself/herself. If more than one talker is waiting to handle the transferred customer call the
central data server 100 may need to select one of the available talkers during the time of call transfer. A delay associated with such selection of talker during the time of call transfer could be minimized by having the system pre-select one of the available talkers to handle the next transferred call. Such pre-selection process could be executed on a continuous basis whenever the previously preselected talker becomes busy (and keep maintaining the designated talker to handle the next transferred call). - Further, multiple people may participate in a transferred customer call. For example, the present system may be implemented to have one or more individuals join the customer call along with the talker. Such additional individual(s) may participate in a listen only mode, participate in a listening and talking mode, or participate in a whisper mode in which the talker could hear such individual's voice but not the customer. Participation of additional individuals could be necessary for training purposes or assisting the customer along with the talker. It should be noted that one or more persons could participate (in various modes such as listen only, whispering to the one or more participants, or listening and talking to everyone in the call) in the call between the dialing agent and customer for the purposes of training and coaching.
- In an alternative embodiment of the present invention, the system could be implemented by 1) automating all or a portion of the dialing agent's function to navigate a customer phone call (through including, but limited to, phone menus and voicemails) until reaching the live customer, by using techniques such as but not limited to, playing the correct sequence of digits (along with the appropriate delays in between digits) that were stored as part of the customer data, and 2) having the system recognize whether a live human voice is encountered in a phone call. For certain customer records where the navigation function could be automated fully by having the system perform the navigation function, the system could dial the customer phone number, navigate the phone call (through but not limited to phone menus and voicemails), and upon the live customer picking up the call, recognize the live human voice and transfer that call to the talker. For the customer records where the phone call navigation could be fully performed by the system, the foregoing arrangement could eliminate the need to have the human dialing agent by having the system do the same phone call navigation work. It should be noted that if the system is performing the phone call navigation function fully for certain customer records without having the human dialing agent involvement there is no need to have a separate dialing agent computer and no need to display the customer record that is being dialed in the dialing agent computer screen (and instead the dialing agent software function could be modified to operate in a non-interactive mode and implemented as a module in the central data server). During such customer call transfer (followed by phone call navigation by the system) if the talker is busy, based on implementation preferences, such call could be transferred to one of the secondary talker(s) waiting to handle such calls. Secondary talkers could be individuals with skills equal to, more, or less skilled than the talker based on the requirement. The customer records for which the phone call navigation function could not be automated fully by having the system perform the phone call navigation function, the human dialing agent is required for phone call navigation and the system could be used to assist the human dialing agent by automating a certain portion of the customer call navigation. Each customer record could be marked as whether the phone call navigation is fully possible by the system or not. Based on the mix of customer records (navigation by system fully possible versus navigation requiring human dialing agents) there is possibility to have no human dialing agents or a lesser number of human dialing agents working alongside of the system performing the function of the dialing agent(s) in a campaign.
- Based on implementation preferences in the foregoing embodiment, the system, a user of the system, or a combination of the user and the system, could update the customer record with information including but not limited to 1) whether the customer phone number is a direct dial phone number or goes to a phone menu(s) that could be navigated by pressing specific digits, and 2) if dialing the phone number goes to a phone menu, the digits such as menu options or extension number that need be pressed (along with the delay that need to be provided between each such digits) to navigate through each phone menu that may be encountered, until the phone call ringing the correct target customer. It should be noted that while the dialing agent is navigating phone menus during a customer call one of the components of the system could be implemented to learn and automatically capture the digits pressed by the dialing agent (along with the delay between digits) and store that information in the associated customer record. While the dialing agent is on a customer call, the system could assist the dialing agent to identify whether the call is picked by a live human being or a phone menu, and upon encountering a phone menu the system could assist the dialing agent by automatically playing the digits required to navigate that phone menu. In a customer call that is designated, a system could navigate fully until reaching the live person. If the customer call encounters a live human voice instead of an expected phone menu the system could recognize that live human voice and transfer the call to the talker (or, based on implementation preference, transfer that call to an available dialing agent to navigate further until the correct live target customer is reached, upon which the dialing agent will further transfer the call to the talker). A person having ordinary skill in the art would know the various techniques that could be used in the foregoing embodiment.
- In accordance with the present invention, there could be many variations on (including, but not limited to) how the customer list and data are created, campaign is created, campaign is started, what portion of the customer list and customer data are transmitted to the dialing agent computer and talker computer and when transmitted, and whether the customer records are allowed to undergo changes while the campaign is in progress. Further, there could be many variations in (including, but not limited to) whether the customer list is finalized and transmitted to the dialing agent computer and talker computer before starting the campaign, or whether the customer list is generated dynamically (in a small batch of records or one customer record at a time) based on specific customer record selection logic and transmitted to the dialing agent and talker computer while the campaign is in progress. At any given time, the list of customer records and customer data shown on the dialing agent computer may or may not be the same as that shown in the talker computer. Notwithstanding the above variations, it should be emphasized that (1) when the dialing agent(s) is dialing a customer record(s), concurrently the same customer record(s) is highlighted in the talker computer (to accomplish this, the talker computer should receive the customer record(s) dialed by the dialing agent simultaneously at the same time or before when the customer record(s) is highlighted to show that customer record(s) is being dialed), and (2) when a customer call is transferred by the dialing agent the customer record associated with the transferred customer call is highlighted differently on the talker computer to allow the talker to differentiate the customer record whose call is transferred versus the customer record(s) that is being dialed. By following this sequence, the talker is capable of reviewing customer data and being prepared for a transferred customer call prior to receiving such transferred customer call.
- It should be noted that whenever this document refers to a “customer record” the fields associated with a specific customer record shown to the dialing agent could vary from the fields associated with the same customer record shown to talker. It should be noted that whenever this document refers to “concurrently”, “simultaneously”, “in real time” or “at the same time” or other terminology referring similar meaning should be interpreted by taking into account reasonable delays associated with speed of computers, phone systems and networks.
- It should be emphasized that the above-described embodiments of the present invention are merely possible examples of implementations, merely set forth for a clear understanding of the principles of the invention. Many variations and modifications may be made to the above-described embodiments of the invention without departing substantially from the spirit and principles of the invention. All such modifications and variations are intended to be included herein within the scope of this disclosure and the present invention and protected by the following claims.
Claims (94)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/596,774 US9467566B2 (en) | 2010-10-21 | 2015-01-14 | System and method for maximizing efficiency of call transfer speed |
Applications Claiming Priority (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US40558710P | 2010-10-21 | 2010-10-21 | |
US13/278,764 US8594308B2 (en) | 2010-10-21 | 2011-10-21 | System and method for maximizing efficiency of call transfer speed |
US14/057,758 US8964963B2 (en) | 2010-10-21 | 2013-10-18 | System and method for maximizing efficiency of call transfer speed |
US14/596,774 US9467566B2 (en) | 2010-10-21 | 2015-01-14 | System and method for maximizing efficiency of call transfer speed |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/057,758 Continuation US8964963B2 (en) | 2010-10-21 | 2013-10-18 | System and method for maximizing efficiency of call transfer speed |
Publications (2)
Publication Number | Publication Date |
---|---|
US20150124953A1 true US20150124953A1 (en) | 2015-05-07 |
US9467566B2 US9467566B2 (en) | 2016-10-11 |
Family
ID=45973042
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US13/278,764 Active US8594308B2 (en) | 2010-10-21 | 2011-10-21 | System and method for maximizing efficiency of call transfer speed |
US14/057,758 Active US8964963B2 (en) | 2010-10-21 | 2013-10-18 | System and method for maximizing efficiency of call transfer speed |
US14/596,774 Active US9467566B2 (en) | 2010-10-21 | 2015-01-14 | System and method for maximizing efficiency of call transfer speed |
Family Applications Before (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US13/278,764 Active US8594308B2 (en) | 2010-10-21 | 2011-10-21 | System and method for maximizing efficiency of call transfer speed |
US14/057,758 Active US8964963B2 (en) | 2010-10-21 | 2013-10-18 | System and method for maximizing efficiency of call transfer speed |
Country Status (6)
Country | Link |
---|---|
US (3) | US8594308B2 (en) |
EP (1) | EP2630781B1 (en) |
JP (1) | JP2013540407A (en) |
AU (1) | AU2011316871A1 (en) |
CA (1) | CA2815399C (en) |
WO (1) | WO2012054851A1 (en) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9237233B2 (en) | 2010-10-21 | 2016-01-12 | Micro Macro Assets Llc | System and method for providing sales and marketing acceleration and effectiveness |
US9467566B2 (en) * | 2010-10-21 | 2016-10-11 | Micro Macro Assets Llc | System and method for maximizing efficiency of call transfer speed |
US9674364B2 (en) | 2010-10-21 | 2017-06-06 | Micro Macro Assets, Llc | Comprehensive system and method for providing sales and marketing acceleration and effectiveness |
US11968326B2 (en) | 2010-10-21 | 2024-04-23 | Micro Macro Assets, Llc | System and method improving inbound leads and phone calls processing in sales and marketing engagement |
Families Citing this family (38)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8401171B1 (en) | 2010-12-20 | 2013-03-19 | United Services Automobile Association (Usaa) | Computing device assistance for phone based customer service representative interaction |
US10432788B2 (en) | 2012-03-06 | 2019-10-01 | Connectandsell, Inc. | Coaching in an automated communication link establishment and management system |
US9258423B1 (en) | 2012-03-06 | 2016-02-09 | Connectandsell, Inc. | Contextual lead generation in an automated communication link establishment and management system |
US8649500B1 (en) | 2012-03-06 | 2014-02-11 | Connectandsell, Inc. | Dynamic allocation of agents for outbound calling in an automated communication link establishment and management system |
US11743382B2 (en) * | 2012-03-06 | 2023-08-29 | Connectandsell, Inc. | Coaching in an automated communication link establishment and management system |
US8948372B1 (en) | 2012-03-06 | 2015-02-03 | Connectandsell, Inc. | Contextual lead generation in an automated communication link establishment and management system |
US9876886B1 (en) | 2012-03-06 | 2018-01-23 | Connectandsell, Inc. | System and method for automatic update of calls with portable device |
US9986076B1 (en) | 2012-03-06 | 2018-05-29 | Connectandsell, Inc. | Closed loop calling process in an automated communication link establishment and management system |
US11012563B1 (en) | 2012-03-06 | 2021-05-18 | Connectandsell, Inc. | Calling contacts using a wireless handheld computing device in combination with a communication link establishment and management system |
US8600019B1 (en) * | 2012-08-28 | 2013-12-03 | West Corporation | Intelligent interactive voice response system for processing customer communications |
US9471811B2 (en) | 2012-08-31 | 2016-10-18 | Ncr Corporation | Learning a new peripheral using a security provisioning manifest |
US9344281B2 (en) * | 2012-08-31 | 2016-05-17 | Ncr Corporation | Detecting fraud using operational parameters for a peripheral |
US9020140B2 (en) * | 2012-11-05 | 2015-04-28 | Sap Se | Telephonic teleservices management |
US8649501B1 (en) | 2012-12-28 | 2014-02-11 | Convergent Resources Holdings, LLC | Interactive dialing system |
US10887296B2 (en) * | 2012-12-31 | 2021-01-05 | Ncr Corporation | Secure provisioning manifest for controlling peripherals attached to a computer |
WO2014164765A1 (en) * | 2013-03-11 | 2014-10-09 | Micro Macro Assets Llc | System and method for providing sales and marketing acceleration and effectiveness |
US9049300B1 (en) | 2013-03-14 | 2015-06-02 | Itellas, Llc | Telephonic privacy systems |
US9807237B2 (en) * | 2014-06-27 | 2017-10-31 | Vonage Business Inc. | System and method for a progressive dialer for outbound calls |
WO2016015036A1 (en) * | 2014-07-25 | 2016-01-28 | Micro Macro Assets Llc | Comprehensive system and method for providing sales and marketing acceleration and effectiveness |
US10827064B2 (en) | 2016-06-13 | 2020-11-03 | Google Llc | Automated call requests with status updates |
JP6736691B2 (en) | 2016-06-13 | 2020-08-05 | グーグル エルエルシー | Escalation to a human operator |
US9979823B2 (en) * | 2016-08-29 | 2018-05-22 | Genesys Telecommunications Laboratories, Inc. | Contact center system and method for advanced outbound communications to a contact group |
US11818292B1 (en) * | 2017-02-13 | 2023-11-14 | Intrado Corporation | Multimode service communication configuration |
CN107682572B (en) * | 2017-10-26 | 2020-01-14 | 平安科技(深圳)有限公司 | Customer incoming line distribution method, system, computer equipment and storage medium |
CN107682576B (en) * | 2017-10-26 | 2020-01-14 | 平安科技(深圳)有限公司 | Customer incoming line distribution method, system, computer equipment and storage medium |
WO2019111419A1 (en) * | 2017-12-08 | 2019-06-13 | 株式会社コンベックス | Information processing device |
US20190197278A1 (en) * | 2017-12-13 | 2019-06-27 | Genista Biosciences Inc. | Systems, computer readable media, and methods for retrieving information from an encoded food label |
US11516344B2 (en) * | 2019-01-29 | 2022-11-29 | Avaya, Inc. | Systems and methods for assigning contacts in a blended contact center |
US11700329B2 (en) * | 2019-03-29 | 2023-07-11 | Avaya Inc. | Managed channel for agent-to-agent consultation |
KR20210114480A (en) | 2019-05-06 | 2021-09-23 | 구글 엘엘씨 | automatic call system |
US11158321B2 (en) | 2019-09-24 | 2021-10-26 | Google Llc | Automated calling system |
WO2021188126A1 (en) | 2020-03-20 | 2021-09-23 | Google Llc | Semi-delegated calling by an automated assistant on behalf of human participant |
US11303749B1 (en) | 2020-10-06 | 2022-04-12 | Google Llc | Automatic navigation of an interactive voice response (IVR) tree on behalf of human user(s) |
CN112367434B (en) * | 2020-11-11 | 2022-04-12 | 国家电网有限公司客户服务中心 | Automatic distribution system for power grid customer service operation resources |
US11223722B1 (en) * | 2020-12-23 | 2022-01-11 | AcqueonTechnologies Inc. | System and method for unified autodial campaign management |
CN113067951B (en) * | 2021-03-17 | 2022-11-22 | 平安普惠企业管理有限公司 | Terminal communication management method and device, computer equipment and readable storage medium |
CN113596268B (en) * | 2021-07-27 | 2022-11-11 | 平安普惠企业管理有限公司 | Redialing processing method and device, electronic equipment and storage medium |
IT202200012422A1 (en) | 2022-06-13 | 2023-12-13 | Colligo S P A | CONTACTABILITY OPTIMIZATION SYSTEM FOR CALL CENTER |
Citations (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
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 |
US6167266A (en) * | 1998-05-29 | 2000-12-26 | Ericsson Inc. | Method for handling of positioning triggers for batch location requests within a location services system |
US6345094B1 (en) * | 1998-06-08 | 2002-02-05 | Davox Corporation | Inbound/outbound call record processing system and method |
US20040002988A1 (en) * | 2002-06-26 | 2004-01-01 | Praveen Seshadri | System and method for modeling subscriptions and subscribers as data |
US20040002958A1 (en) * | 2002-06-26 | 2004-01-01 | Praveen Seshadri | System and method for providing notification(s) |
US20040098480A1 (en) * | 1998-01-06 | 2004-05-20 | Hiroaki Sekizawa | System and method for monitoring the state of a plurality of machines connected via a computer network |
US20060203994A1 (en) * | 2005-03-10 | 2006-09-14 | Cisco Technology, Inc. | Method and system for transferring a call at an automatic call distribution system |
US20070121902A1 (en) * | 2005-11-03 | 2007-05-31 | Andrei Stoica | Transfer of live calls |
US20070121859A1 (en) * | 2003-10-14 | 2007-05-31 | Vladimir Smelyansky | System and process for mass telephony conference call |
US20070156656A1 (en) * | 2002-06-26 | 2007-07-05 | Microsoft Corporation | Programming model for subscription services |
US7793141B1 (en) * | 2008-05-15 | 2010-09-07 | Bank Of America Corporation | eCommerce outage customer notification |
US20110072367A1 (en) * | 2009-09-24 | 2011-03-24 | etape Partners, LLC | Three dimensional digitally rendered environments |
US20110116618A1 (en) * | 2009-11-19 | 2011-05-19 | Vadim Zyarko | System and Methods for Selecting a Dialing Strategy for Placing an Outbound Call |
US8594308B2 (en) * | 2010-10-21 | 2013-11-26 | Micro Macro Assets Llc | System and method for maximizing efficiency of call transfer speed |
US20140247933A1 (en) * | 2010-10-21 | 2014-09-04 | Micro Macro Assets, Llc | System and method for providing sales and marketing acceleration and effectiveness |
Family Cites Families (20)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6141412A (en) * | 1994-06-01 | 2000-10-31 | Davox Corporation | Unscheduled event task processing system |
US5822400A (en) * | 1996-08-19 | 1998-10-13 | Davox Corporation | Call record scheduling system and method |
JP3634610B2 (en) * | 1998-01-27 | 2005-03-30 | 富士通株式会社 | Automatic call system |
US20050002515A1 (en) | 1999-07-13 | 2005-01-06 | Mewhinney Brian E. | Dialing techniques for a contact center |
US7068642B1 (en) * | 1999-09-17 | 2006-06-27 | Concerto Software, Inc. | System and method of propagating exclusion records in a networked computer telephony integration system |
US7092509B1 (en) | 1999-09-21 | 2006-08-15 | Microlog Corporation | Contact center system capable of handling multiple media types of contacts and method for using the same |
US6751310B1 (en) | 2000-04-05 | 2004-06-15 | Concerto Software, Inc. | System and method for prioritizing telephone call campaigns based on campaign productivity |
US7110525B1 (en) | 2001-06-25 | 2006-09-19 | Toby Heller | Agent training sensitive call routing system |
US7715546B2 (en) * | 2001-07-09 | 2010-05-11 | Austin Logistics Incorporated | System and method for updating contact records |
US7372952B1 (en) | 2002-03-07 | 2008-05-13 | Wai Wu | Telephony control system with intelligent call routing |
JP4084082B2 (en) * | 2002-05-15 | 2008-04-30 | エヌ・ティ・ティ・コミュニケーションズ株式会社 | Call center control system with outbound business support function |
US20060153357A1 (en) | 2005-01-08 | 2006-07-13 | Arup Acharya | Method and apparatus for providing contextual information with telephone calls |
US7873156B1 (en) * | 2006-09-29 | 2011-01-18 | Verint Americas Inc. | Systems and methods for analyzing contact center interactions |
US7873157B1 (en) * | 2007-02-23 | 2011-01-18 | Avaya Inc. | Method and apparatus for performing predictive dialing |
US8447691B2 (en) | 2007-05-30 | 2013-05-21 | Hsbc Card Services, Inc. | Systems and methods for NACHA compliant ACH transfers using an automated voice response system |
JP2010050937A (en) * | 2008-08-25 | 2010-03-04 | Promise Co Ltd | Automatic call origination system |
JP5532598B2 (en) * | 2008-12-15 | 2014-06-25 | 富士通株式会社 | Operator management system, method and program |
US8238543B2 (en) * | 2009-06-01 | 2012-08-07 | Genesys Telecommunications Laboratories, Inc. | System and methods for predicting future agent readiness for handling an interaction in a call center |
US8861710B2 (en) * | 2010-05-19 | 2014-10-14 | Avaya Inc. | Playing expected wait time on agent's notification |
US20120076283A1 (en) | 2010-09-23 | 2012-03-29 | Ajmera Dinesh | Predictive Customer Service Environment |
-
2011
- 2011-10-21 CA CA2815399A patent/CA2815399C/en active Active
- 2011-10-21 JP JP2013535123A patent/JP2013540407A/en active Pending
- 2011-10-21 AU AU2011316871A patent/AU2011316871A1/en not_active Abandoned
- 2011-10-21 EP EP11835230.1A patent/EP2630781B1/en not_active Not-in-force
- 2011-10-21 US US13/278,764 patent/US8594308B2/en active Active
- 2011-10-21 WO PCT/US2011/057317 patent/WO2012054851A1/en active Application Filing
-
2013
- 2013-10-18 US US14/057,758 patent/US8964963B2/en active Active
-
2015
- 2015-01-14 US US14/596,774 patent/US9467566B2/en active Active
Patent Citations (18)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
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 |
US20040098480A1 (en) * | 1998-01-06 | 2004-05-20 | Hiroaki Sekizawa | System and method for monitoring the state of a plurality of machines connected via a computer network |
US6167266A (en) * | 1998-05-29 | 2000-12-26 | Ericsson Inc. | Method for handling of positioning triggers for batch location requests within a location services system |
US6345094B1 (en) * | 1998-06-08 | 2002-02-05 | Davox Corporation | Inbound/outbound call record processing system and method |
US20040002988A1 (en) * | 2002-06-26 | 2004-01-01 | Praveen Seshadri | System and method for modeling subscriptions and subscribers as data |
US20040002958A1 (en) * | 2002-06-26 | 2004-01-01 | Praveen Seshadri | System and method for providing notification(s) |
US20070156656A1 (en) * | 2002-06-26 | 2007-07-05 | Microsoft Corporation | Programming model for subscription services |
US20070121859A1 (en) * | 2003-10-14 | 2007-05-31 | Vladimir Smelyansky | System and process for mass telephony conference call |
US20060203994A1 (en) * | 2005-03-10 | 2006-09-14 | Cisco Technology, Inc. | Method and system for transferring a call at an automatic call distribution system |
US20070121902A1 (en) * | 2005-11-03 | 2007-05-31 | Andrei Stoica | Transfer of live calls |
US7793141B1 (en) * | 2008-05-15 | 2010-09-07 | Bank Of America Corporation | eCommerce outage customer notification |
US20110072367A1 (en) * | 2009-09-24 | 2011-03-24 | etape Partners, LLC | Three dimensional digitally rendered environments |
US20110116618A1 (en) * | 2009-11-19 | 2011-05-19 | Vadim Zyarko | System and Methods for Selecting a Dialing Strategy for Placing an Outbound Call |
US8594308B2 (en) * | 2010-10-21 | 2013-11-26 | Micro Macro Assets Llc | System and method for maximizing efficiency of call transfer speed |
US20140247933A1 (en) * | 2010-10-21 | 2014-09-04 | Micro Macro Assets, Llc | System and method for providing sales and marketing acceleration and effectiveness |
US8938058B2 (en) * | 2010-10-21 | 2015-01-20 | Micro Macro Assets Llc | System and method for providing sales and marketing acceleration and effectiveness |
US8964963B2 (en) * | 2010-10-21 | 2015-02-24 | Micro Macro Assets, Llc | System and method for maximizing efficiency of call transfer speed |
US20150104000A1 (en) * | 2010-10-21 | 2015-04-16 | Micro Macro Assets, Llc | System and method for providing sales and marketing acceleration and effectiveness |
Cited By (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9237233B2 (en) | 2010-10-21 | 2016-01-12 | Micro Macro Assets Llc | System and method for providing sales and marketing acceleration and effectiveness |
US9467566B2 (en) * | 2010-10-21 | 2016-10-11 | Micro Macro Assets Llc | System and method for maximizing efficiency of call transfer speed |
US9674364B2 (en) | 2010-10-21 | 2017-06-06 | Micro Macro Assets, Llc | Comprehensive system and method for providing sales and marketing acceleration and effectiveness |
US9979820B2 (en) | 2010-10-21 | 2018-05-22 | Micro Macro Assets Llc | Predictive resource scheduling for efficient sales and marketing acceleration |
US10284721B2 (en) | 2010-10-21 | 2019-05-07 | Micro Macro Assets Llc | Repetition of communication attempts based on communication outcome for effective sales and marketing engagement |
US10715661B2 (en) | 2010-10-21 | 2020-07-14 | Micro Macro Assets, Llc | System and method for scalable and efficient multi-channel communication |
US10979566B2 (en) | 2010-10-21 | 2021-04-13 | Micro Macro Assets Llc | Optimizing next step action based on agent availability for effective sales and marketing engagement |
US11575786B2 (en) | 2010-10-21 | 2023-02-07 | Micro Macro Assets Llc | Optimizing next step action to increase overall outcome in sales and marketing engagement |
US11968326B2 (en) | 2010-10-21 | 2024-04-23 | Micro Macro Assets, Llc | System and method improving inbound leads and phone calls processing in sales and marketing engagement |
Also Published As
Publication number | Publication date |
---|---|
US20140044253A1 (en) | 2014-02-13 |
CA2815399C (en) | 2017-05-16 |
JP2013540407A (en) | 2013-10-31 |
US8594308B2 (en) | 2013-11-26 |
US9467566B2 (en) | 2016-10-11 |
EP2630781A4 (en) | 2016-06-15 |
US20120099720A1 (en) | 2012-04-26 |
AU2011316871A1 (en) | 2013-05-23 |
CA2815399A1 (en) | 2012-04-26 |
EP2630781B1 (en) | 2018-06-20 |
US8964963B2 (en) | 2015-02-24 |
EP2630781A1 (en) | 2013-08-28 |
WO2012054851A1 (en) | 2012-04-26 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9467566B2 (en) | System and method for maximizing efficiency of call transfer speed | |
US9237233B2 (en) | System and method for providing sales and marketing acceleration and effectiveness | |
US11095773B2 (en) | Coaching in an automated communication link establishment and management system | |
US8649500B1 (en) | Dynamic allocation of agents for outbound calling in an automated communication link establishment and management system | |
US9258423B1 (en) | Contextual lead generation in an automated communication link establishment and management system | |
US11272062B2 (en) | Assisted-communication with intelligent personal assistant | |
US11012565B2 (en) | Computer-implemented system and method for efficiently facilitating appointments within a call center via an automatic call distributor | |
US6760423B1 (en) | Call initiation via calendar | |
US20120114112A1 (en) | Call center with federated communications | |
US8948372B1 (en) | Contextual lead generation in an automated communication link establishment and management system | |
US11805203B2 (en) | Calling contacts using a wireless handheld computing device in combination with a communication link establishment and management system | |
US9986076B1 (en) | Closed loop calling process in an automated communication link establishment and management system | |
CN109831591A (en) | Method of calling, device and the terminal of call center | |
US20230239402A1 (en) | Coaching in an automated communication link establishment and management system | |
US9876886B1 (en) | System and method for automatic update of calls with portable device | |
CA2905351A1 (en) | System and method for providing sales and marketing acceleration and effectiveness |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: MICRO MACRO ASSETS LLC, NEW HAMPSHIRE Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SOUNDAR, SENRAJ;REEL/FRAME:034711/0406 Effective date: 20131024 |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YR, SMALL ENTITY (ORIGINAL EVENT CODE: M2551); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY Year of fee payment: 4 |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY |
|
FEPP | Fee payment procedure |
Free format text: 7.5 YR SURCHARGE - LATE PMT W/IN 6 MO, SMALL ENTITY (ORIGINAL EVENT CODE: M2555); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YR, SMALL ENTITY (ORIGINAL EVENT CODE: M2552); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY Year of fee payment: 8 |