Embodiments of the present disclosure generally relate to contact centers, and, in particular, to a system and method to adapt conference attributes depending upon free-form conference membership.
Conferences are often set up using attributes that are expected to be compatible with most or all terminals expected to be participating in the conference. Conference participation may be free-form (i.e., dynamic), such that terminals may join or leave the conference during its usage.
One aspect of the present disclosure relates to a method of dynamically maintaining conference attributes during a conference that includes conducting the conference according to a first set of conference attributes based on a first set of member terminals currently members of the conference and detecting during the conference that conference membership changes from the first set of member terminals to a second set of member terminals participating in the conference. Thus, a second set of conference attributes can be determined based on the second set of member terminals so that the attributes of the conference can be dynamically changed so as to be conducted according to the second set of conference attributes rather than the first set of conference attributes.
For example, the conference is initially established between the first set of member terminals and detecting the change in conference membership comprises detecting a joining member terminal that joins the conference and/or detecting the change in conference membership comprises detecting a leaving member terminal, from among the first set of member terminals, that leaves the conference.
Additionally, respective capabilities of each of the first set of member terminals can be determined, wherein the first set of conference attributes is based on the respective capabilities and, also, the respective capabilities of each of the second set of member terminals can be determined, wherein the second set of conference attributes is based on the respective capabilities. The respective capabilities can, for example, be retrieved from a context store of the contact center. And used to determine a respective identification of each of the first set of member terminals and/or determine a respective identification of each of the second set of member terminals. Further, the information retrieved from the context store can be used to determine a respective identification of a respective user associated with each of the first set of member terminals. Based on the member terminals, or the users associated with the member terminals, presently part of a conference, the different conference attributes can be dynamically changed to accommodate the current conference members. For example, conference attributes such as who has talking privileges or who is allowed to be the loudest speaker can be dynamically modified. Additionally, conference resources utilized to provide the conference can be identified as no longer necessary (given the present conference members) and these resources can be released in order to be available to other conferences.
Another aspect of the present disclosure relates to a system for dynamically maintaining conference attributes during a conference that includes a memory device storing executable instructions and a processor in communication with the memory device. In particular, the processor, when executing the executable instructions: a) conducts the conference according to a first set of conference attributes based on a first set of member terminals currently members of the conference; b) detects during the conference that conference membership changes from the first set of member terminals to a second set of member terminals participating in the conference; c) determines a second set of conference attributes based on the second set of member terminals; and d) conducts the conference according to the second set of conference attributes rather than the first set of conference attributes.
So the manner in which the above recited features of the present disclosure may be understood in detail, a more particular description of embodiments of the present disclosure, briefly summarized above, may be had by reference to embodiments, which are illustrated in the appended drawings. It is to be noted, however, the appended drawings illustrate only typical embodiments encompassed within the scope of the present disclosure, and, therefore, are not to be considered limiting, for the present disclosure may admit to other equally effective embodiments, wherein:
The present disclosure will be illustrated below in conjunction with an exemplary communications system. Although well suited for use with, e.g., a system having an Automated Call or Contact Distribution (ACD) system or other similar contact processing switch, the present disclosure is not limited to any particular type of communications system switch or configuration of system elements. Those skilled in the art will recognize that the disclosed techniques may be used in any communications application in which it is desirable to provide improved contact processing.
In the following detailed description, numerous specific details are set forth in order to provide a thorough understanding of embodiments or other examples described herein. In some instances, well-known methods, procedures, components and circuits have not been described in detail, so as to not obscure the following description. Further, the examples disclosed are for illustrative purposes only and should not be construed as limiting of the scope of embodiments of the present disclosure.
The term “a” or “an” entity refers to one or more of that entity. As such, the terms “a” (or “an”), “one or more,” and “at least one” may be used interchangeably herein. It is also to be noted that the terms “comprising,” “including,” and “having” may be used interchangeably.
The term “automatic” and variations thereof, as used herein, refers to any process or operation done without material human input when the process or operation is performed. However, a process or operation may be automatic, even though performance of the process or operation uses material or immaterial human input, if the input is received before performance of the process or operation. Human input is deemed to be material if such input influences how the process or operation will be performed. Human input that consents to the performance of the process or operation is not deemed to be “material.”
The term “computer-readable medium” as used herein refers to any tangible storage and/or transmission medium that participates in storing and/or providing instructions to a processor for execution. Such a medium may take many forms, including but not limited to, non-volatile media, volatile media, and transmission media. Non-volatile media includes, for example, NVRAM, or magnetic or optical disks. Volatile media includes dynamic memory, such as main memory. Common forms of computer-readable media include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, or any other magnetic medium, magneto-optical medium, a CD-ROM, any other optical medium, punch cards, paper tape, any other physical medium with patterns of holes, RAM, PROM, EPROM, FLASH-EPROM, solid state medium like a memory card, any other memory chip or cartridge, a carrier wave as described hereinafter, or any other medium from which a computer may read. A digital file attachment to e-mail or other self-contained information archive or set of archives is considered a distribution medium equivalent to a tangible storage medium. When the computer-readable media is configured as a database, it is to be understood that the database may be any type of database, such as relational, hierarchical, object-oriented, and/or the like. Accordingly, the disclosure is considered to include a tangible storage medium or distribution medium and prior art-recognized equivalents and successor media, in which the software implementations of the present disclosure are stored.
As used herein in connection with embodiments of the present disclosure, the term “contact” refers to a communications from a user or customer. The communications may be by way of any communications medium such as, but not limited to, a telephone call, e-mail, instant message, web chat, and the like. The terms “user” and “customer” denote a party external to the contact center and are used herein to refer to the other party to a contact or a communications session. A user or customer may include, for example, a person requesting assistance for himself or herself or a person requesting assistance for a third party and may also include, for example, a person having a commercial relationship with the contact center or with a business represented by the contact center.
For each “contact” received by the contact center, a computer of the contact center will instantiate a “contact object,” which may comprise one or more variables, functions, and data structures that represent the contact. Each contact object comprises a number of attributes, which are assigned values based on its corresponding contact. Each contact object can also include pointers, links or references to other data and/or attributes associated with its corresponding contact. The contact object may be passed amongst the different queues, databases, systems, software applications and other computer-based resources of the contact center. Each contact object may also include a forward reference to another contact object and a backward reference to yet another contact object. In this manner, a prioritized list, or queue, of contact objects may be constructed.
The terms “determine,” “calculate,” and “compute,” and variations thereof, as used herein, are used interchangeably and include any type of methodology, process, mathematical operation or technique.
As used herein, the term “gateway” may generally comprise any device that sends and receives data between devices. For example, a gateway may comprise routers, switches, bridges, firewalls, other network elements, and the like, and any combination thereof.
The term “module” as used herein refers to any known or later developed hardware, software, firmware, artificial intelligence, fuzzy logic, or combination of hardware and software that is capable of performing the functionality associated with that element. Also, while the present disclosure is described in terms of exemplary embodiments, it should be appreciated those individual aspects of the present disclosure may be separately claimed.
As used herein, the term “signal” may include one or more of an electrical signal, a radio signal, an optical signal, an acoustic signal, and so forth.
The terms “switch,” “server,” “contact center server,” or “contact center computer server” as used herein should be understood to include a Private Branch Exchange (PBX), an ACD system, an enterprise switch, or other type of telecommunications system switch or server, as well as other types of processor-based communications control devices such as, but not limited to, media servers, computers, adjuncts, and the like.
Automatic Call or Contact Distribution (ACD) is a communications server software feature that processes incoming, outgoing, and internal calls and distributes them to groups of extensions called hunt groups or splits. The communications server also sends information about the operation of the ACD to a Call Management System (CMS) which stores and formats the data and produces real-time and historical reports on ACD activity. ACD is used by a contact center to route incoming calls to specifically assigned splits/skills and agents. ACD allows a system administrator to create an efficient call management environment.
One or more embodiments of the present disclosure may utilize Session Initiation Protocol (SIP) as a communications protocol. SIP is a communications protocol that is known and described in Internet Engineering Task Force (IETF) Request For Comment (RFC) 3261, the content of which is hereby incorporated by reference in its entirety. SIP is an open signaling protocol for establishing many kinds of real-time communications sessions. Examples of the types of communications sessions that may be established using SIP include voice, video, and/or instant messaging. SIP also facilitates peer-to-peer communications sessions. These communications sessions may be carried out on any type of communications device such as a personal computer, laptop computer, Personal Digital Assistant, telephone, mobile phone, cellular phone, or the like. One key feature of SIP is its ability to use an end-user's Address of Record (AOR) as a single unifying public address for all communications. Thus, in a world of SIP-enhanced communications, a user's AOR becomes their single address that links the user to all of the communications devices associated with the user. Using this AOR, a caller can reach any one of the user's communications devices, also referred to as User Agents (UAs) without having to know each of the unique device addresses or phone numbers.
Users or any other addressable entities in a SIP framework are identified by Universal Resource Identifiers (URI). Each such Internet-style address (for example, sip: johndoe@avaya.com) maps into one or more Contacts, each of which typically represents a device or service at which the corresponding user may be reached. Examples include phones, desktop multimedia clients, instant message accounts, email accounts and so on. The SIP framework is responsible for routing a request for a peer-to-peer session addressed to a given URL to one or more appropriate contacts for that URL. The SIP framework may utilize information about the preferences, presence, and location of the user identified by the URL to determine the most appropriate contacts. The protocol also provides mechanisms to specify the type of session that is requested, as well as means to change session parameters.
SIP is not a vertically integrated communications system. Rather, SIP is a component that may be used with other IETF protocols to build a complete multimedia architecture. Typically, these architectures will include protocols such as Real-Time Transport Protocol (RTP) (RFC 3550) for transporting real-time data and providing Quality of Service (QoS) feedback, the Real-Time Streaming Protocol (RTSP) (RFC 2326) for controlling delivery of streaming media, the Media Gateway Control Protocol (MEGACO) (RFC 3015) for controlling gateways to the Public Switched Telephone Network (PSTN), and the Session Description Protocol (SDP) (RFC 4566) for describing multimedia sessions. Therefore, SIP may be used in conjunction with other protocols in order to provide complete services to the users. However, the basic functionality and operation of SIP does not depend on any of these protocols.
The Real-Time Transport Control Protocol (RTCP) is a protocol that is known and described in IETC RFC 3550. RTCP provides out-of-band statistics and control information for an RTP media stream. It is associated with RTP in the delivery and packaging of a media stream but does not transport the media stream itself. Typically, the RTP media stream will be sent on an even-numbered user datagram protocol (UDP) port, with RTCP messages being sent over the next higher odd-numbered port. RTCP may be used to provide feedback on the QoS in media distribution by periodically sending statistics information to participants in a streaming multimedia session. Systems implementing RTCP gather statistics for a media connection and information such as transmitted octet and packet counts, lost packet counts, jitter, and round-trip delay time. An application program may use this information to control QoS parameters, for instance by limiting a flow rate or by using a different codec.
As explained in more detail with respect to
The contact center 100 further comprises a plurality of working agents operating packet-switched (first) communications devices 134-1 to 134-N (such as computer workstations or personal computers) and/or circuit-switched (second) communications devices 138-1 to 138-N, where N is an integer, N≧1. The first agent communications devices 134-1 to 134-N may include, for example, IP hardphones such as the 4600 Series IP Phones™ by Avaya Inc., IP softphones such as the IP Softphone™ by Avaya Inc., Personal Digital Assistants (PDAs), Personal Computers (PCs), laptops, packet-based H.320 video phones and conferencing units, packet-based voice messaging and response units, packet-based traditional computer telephony adjuncts, peer-to-peer based communications devices, and any other suitable communications device. In one configuration, the server 110, the network 154, and the first agent communications devices 134-1 to 134-N are SIP compatible and may include interfaces for various other protocols such as the Lightweight Directory Access Protocol (LDAP), H.248, H.323, Simple Mail Transfer Protocol (SMTP), IMAP4, ISDN, E1/T1, and analog line or trunk. The second agent communications devices 138-1 to 138-N may each correspond to one of a set of internal extensions Ext1 to ExtN, respectively, and may include, for example, wired and wireless telephones, PDAs, H.320 videophones and conferencing units, voice messaging and response units, traditional computer telephony adjuncts, and any other suitable communications device. The second agent communications devices 138-1 to 138-N may be in communications with the external communications devices 174-1 to 174-M via one or more link(s) 152. The link(s) 152 is depicted with a dashed line to indicate that it represents a logical representation of the connections between the external communications devices 174-1 to 174-M and the second communications devices 138-1 to 138-N. The actual, physical connection between these devices can include various routing through the network 142, possibly the boundary device 130, and one or more of the servers 110, 148, 126.
It should be noted that the present disclosure does not require any particular type of information transport medium between the components of the contact center 100, i.e., the present disclosure may be implemented with any desired type of transport medium as well as combinations of different types of transport channels. It should also be emphasized that the configuration of the elements of the contact center 100 as shown in
The contact center server 110 and the media server 148 may each be connected to the LAN 142 via its own respective communications link 140, 146, as shown, or via the switch 158 (not shown). The contact center server 110 may also be connected via one or more optional communications links (not shown) to one or more other components of the contact center 100, including for example, the media server 148, the call recorder 144, the biometrics engine 136, and the outbound campaign 132. As will be appreciated, the one or more other servers 126 may also include a scanner (which is normally not connected to the switch 130), VoIP software, video call software, voice messaging software, an IP voice server, a fax server, a web server, an e-mail server, and the like.
The boundary device 130 may include the functionality of one or more of a switch 158, a computer-telephony integration (CTI) interface 160, a SIP gateway 162, or a security gateway 164. The switch 158 and/or server 110 may comprise any architecture for directing contacts to the one or more agent communications devices 134, 138 (see
As shown in
The servers and/or computers of the contact center 100 can also include a context store 127 and a harvest module 129. These two features are shown as separate systems in
In one embodiment, the harvest module 129 may communicate with a ticketing system, an order tool system, a sentiment analysis engine, a customer relationship management (CRM) system, and a business process management system (BPM) to build or add data to the context store 127. The harvest module 129 may communicate with these systems and provide updated data to the context store 127 according to various contacts that are being handled and monitored within the contact center 100.
In an example, following a customer interaction with an agent of the contact center 100, the harvest module 129 may update the context store 127. In another embodiment, the ticketing system, the order tool system, the sentiment analysis data, the customer relationship management (CRM) system, and the business process management system (BPM) may directly push information, as well as, extract it out of the context store 127.
As an example, the sentiment analysis data may include sentiment of a contact, for example, happy, angry, complain, etc. during an interaction of the contact with a contact center agent.
The CRM updates may include data about any update in customer or contact relation with the enterprise or the contact center. The order update information may include update about the total order placed by the contact. The call/interaction metrics may include call duration, number of participants, was call transferred, was supervisor involved, etc. Further, any component or system of the contact center 100, for example, a self-service system, can access the context store 127, retrieve the context information, update it, change it, put it back in again, and so on and so forth.
The harvest module 129 may harvest relevant data from disparate sources related to customers. For example, the harvest module 129 may harvest relevant data related to the customers from the context store 127. In one embodiment, the harvest module 129 harvests the sentiment analysis data, the CRM updates, the order update information, Post call/interaction survey, Call/interaction metrics, and any interaction context data, as described above. The harvest module 129 gathers this data and other information that has changed during, and in the aftermath of, the customer interaction.
The context store 127 may further store any information, for example, information related to interaction, information related to context of interaction, current information, or case information, and updated information. For example, once an agent finishes a call, the harvest module 129 can start processing and storing the information in the context store 127.
The context store 127 provides a centralized data cache to the various applications in the contact center 100. The context store 127 can provide a RESTful Web Service API so that other applications can set or get context information. While various database schemes may be contemplated, the context information stored about a contact is stored so that the information can be searched and retrieved based on any of a variety of data stored therein. For example, each entry in the context store can include a) a ContextID which is a text field that contains a unique identifier for the context entry; b) the data, which can include multiple key-value pairs; and c) a GroupID which allows logical groups of related context entries to be created.
As described herein, various data, or context, about a contact can be generated, retrieved and stored. This contextual information can include present attributes about the contact, a device associated with the contact, a location of a user associated with the contact, an identity of the user associated with the contact; devices and/or locations associated with past contacts involving the associated user or user device, social media information about the user associated with the contact, and past purchases, past inquiries, group affiliation and demographic information about the user associated with the contact. The contextual information can also include various information about contact center resources, agents, and problem resolution associated with past interactions with the user associated with a contact.
Although some embodiments are discussed with reference to a client-server architecture, it is to be understood that the principles of the present disclosure apply to other network architectures. For example, the present disclosure applies to peer-to-peer networks, such as those envisioned by SIP. In the client-server model or paradigm, network services and the programs used by end users to access the services are described. The client side provides a user with an interface for requesting services from the network, and the server side is responsible for accepting user requests for services and providing the services transparent to the user. By contrast, in the peer-to-peer model or paradigm, each networked host runs both the client and server parts of an application program. Additionally, the disclosure does not require the presence of packet- or circuit-switched networks.
Referring to
As may be seen in
Included among the control programs in the server 110 is a work item vector 216. Contacts incoming to the contact center are assigned by the work item vector 216 to different work item queues 208a-n based on a number of predetermined criteria, including customer identity, customer needs, contact center needs, current contact center queue lengths, customer value, and the agent skill that is required for the proper handling of the contact. Agents who are available for handling work items are assigned to agent queues 212a-n based on the skills that they possess. An agent may have multiple skills, and hence may be assigned to multiple agent queues 212a-n simultaneously. Furthermore, an agent may have different levels of skill expertise (e.g., skill levels 1-N in one configuration or merely primary skill levels and secondary skill levels in another configuration), and hence may be assigned to different agent queues 212a-n at different expertise levels.
In one configuration, the contact center may be operated by a contract operator, and each of the work item queues 208a-n, and possibly each of the agent queues 212a-n, corresponds to a different client. Each client may have a separate service level agreement or other type of performance measurement agreement with the contract operator regarding performance expectations, goals, requirements or specifications for the client's respective queue(s). The service level agreement may set forth penalties, such as financial penalties, for failing to comply with the service level agreement's requirements.
The contact center server 110 may be notified via the LAN 142 of an incoming work item by the communications component (e.g., the switch 130, fax server, e-mail server, web server, and/or other server) receiving the incoming work item. The incoming work item is held by the receiving telecommunications component until the server 110 forwards instructions to the component to forward or route the contact to a specific contact center resource, such as the IVR 122, one or more of the other servers such as a voice mail server 118, and/or a first or second agent communications device 134, 138 associated with a selected agent.
The server 110 distributes and connects these work items to first or second agent communications devices 134, 138 of available agents based on the predetermined criteria noted above. When the server 110 forwards a voice contact (or first work item) to an agent, the server 110 also forwards customer-related information from the database(s) 114 to the agent's computer work station for viewing (such as by a pop-up display) to permit the agent to better serve the customer. Depending on the contact center configuration, the server 110 may forward a list of work items to an available agent to preview before forwarding the work item itself and the data associated therewith to the agent. The agents process the work items or contacts sent to them by the server 110. This embodiment is particularly suited for a Customer Relationship Management (CRM) environment in which customers are permitted to use any media to contact a business. In a CRM environment, both real-time and non-real-time contacts must be handled and distributed with equal efficiency and effectiveness.
According to an embodiment of the present disclosure, also included among the programs executing on the server 110 are an agent and work item selector 220 and a controller 224, as shown in
Agent and customer profiles are typically maintained and updated by a profile generator (not shown). Upon the completion of handling a work item, the generator may collect selected metrics for the work item. These metrics include the skill involved in servicing the work item, the identifier of the servicing agent, the contact duration, the transaction or contact type (e.g., catalog sale, information request, complaint, etc.), the time-of-day, the result (e.g., the type of sale, the number of units sold, revenue generated, service ticket closure or escalation, the information provided, etc.), a self-rating of the servicing agent respecting the agent's proficiency in handling the work item, the rating of the customer of the agent's proficiency in handling the work item, the rating of another party, such as the agent's supervisor or another observer, of how the work item was serviced, whether the agent requested assistance, and whether the agent's training was completed, and stores the information in the database(s) 114, such as CMS 228. The metrics over a selected period of time are typically stored under each agent's profile and may include metrics associated with a plurality of work items serviced by the agent for each agent skill. Each agent's profile may also contain his or her skills and/or level(s) of skill expertise. Each customer profile includes metrics associated with a plurality of contacts by the customer.
The controller 224 has access to various performance measures of each of the agent resources and the contact handling history of the resources in the system. The controller 224 is also configured to use various systems, known in the art, to assess the performance of individual agent resources in processing work items. The controller 224 is further configured to find an area of competency for each of the agent resources based on their performance measures and contact handling history. The controller 224 is further configured to utilize such findings in maximizing contact center efficiency.
As for conference calls that are bridged at the contact center 100, considering the instantaneous membership in the conference, the original attributes used when setting up the conference may no longer be appropriate. Embodiments in accordance with the present disclosure provide an improved method and system to provide flexible conference attributes in response to dynamic membership in the conference.
As mentioned earlier, a context store can be plug-in to a contact center computing environment that helps enable context-sensitive, real-time customer contact information to be updated from multiple sources and shared between the various components and points in the enterprise through which a customer passes. The context store may have a representational state transfer (REST) Web services API that facilitates the creation and population of context store instances, and the subsequent update and retrieval of context data. Access to a context store may be by way of a set of public function calls, which may include a client-side Java version of an API that facilitates Java developers to integrate a context store in other application programs.
A context store may be used to gather and to store information from various data sources and application programs. An audit trail may be maintained by the context store to keep a record of interactions and the gathered information.
A conference (e.g., a conference call) typically is set up by one person, i.e., a conference organizer. Normally, the conference organizer defines the beginning and the end of the conference. Various communication systems (e.g., a contact center, a public-branch exchange (PBX), etc.) may be used to set up and participate in a conference.
In contrast, embodiments in accordance with the present disclosure may improve upon the set-up and management of conferences in situations where conference participants are co-located or are in physical proximity within a predetermined distance or range. Conferences including such users may be more free-form or ad hoc in nature, such that users may add, drop, or change communication parameters at will. Control of such a conference is decentralized, such that there is not necessarily a need to maintain a conference owner, at least until some predetermined terminating event occurs, such as a time out in the system occurs, or some other interaction decides to escalate it, or tear it down.
For example, suppose a conference in accordance with an embodiment of the present disclosure has been set up and at least a pair of users are using the conference. Now suppose that a third user appears (e.g., enters the co-located space), who is using a device with different capabilities (e.g., more robust or less robust video or audio recording, or different short-range communication capability, different application programs available, etc.). Embodiments may take note and adjust conference parameters accordingly to take advantage of or compensate for the different capabilities of the new device. In other embodiments, an existing conference participant may want to leave the conference, and the conference attributes may be inappropriate or suboptimal for the remaining conference participants.
Embodiments in accordance with the present disclosure may improve the management of conferences within enterprise network 104 by accessing a context store to retrieve information related to the conference, e.g., information about the conference participants, or about the conference itself such as how it was set up, current mode of operation, metadata, etc.
A context store may be provisioned with details on how to generate customized conferences that have individualized capabilities, user interfaces, and so forth. For example, a customized conference may have specialized greetings, or a specialized hotkey user interface.
A context store may be provisioned, either dynamically or statically, with information about conference participants who are accessing the conference using various devices.
Customized conferences may be identified using a predetermined identifier, e.g., a URL, QR-Code, a textual code, a transmission technology identifier (e.g., Wi-Fi SSID, code for NFC or Bluetooth, etc.), and so forth. A person wishing to join or otherwise access a conference may join by first retrieving or generating the predetermined identifier (e.g., by displaying an invitation message that has an imbedded predetermined identifier), and then presenting the predetermined identifier to an input device (e.g., a scanner, a keyboard, a wireless signal sniffer, etc.). Thereafter, the user's communication device may join the conference, with communication modes or parameters adjusted for the capabilities of the user's device. For example, a voice-only communication device may join in voice-only mode, but a video capable communication device may join in video mode if that is the user's preference.
Embodiments in accordance with the present disclosure may offer a simplified process to join a present or future conference, by use of the predetermined identifier. For example, a potential conference participant may scan an NFC-enabled business card at a reader in order to enter the predetermined identifier into the system. Thereafter, an application program may use the predetermined identifier to retrieve information (e.g., settings, preferences, and permissions related to the conference and/or the potential conference participant) from a context store. The context store then may set up a customized conference for the potential conference participant to use.
Embodiments in accordance with the present disclosure may also be used by conference attendees to set up services or media streams that are related to the main conference. For example, co-located conference attendees of a video conference may receive an invitation to a related chat room, or may elect to receive subtitles to help overcome language barriers.
In other usage scenario examples, co-located conference attendees may be using a device of various levels of robustness or capability. Embodiments may issue to conference attendees a token that, when presented to a context store, would be recognized by the context store as identifying individualized customer profile and contact setup information. The token may then be used to set up additional individualized services for users with secondary communication devices (e.g., a co-located tablet computer).
Referring again to
Next, process 400 transitions to step 403, at which a request is detected from another terminal to join the conference. For example, a user with a mobile terminal may wander within short-range communication distance of the conference, and the terminal may be configured to automatically attempt to connect to networks within range. In other embodiments, the request may be a request to leave the conference from a terminal currently participating in the conference.
Next, process 400 transitions to step 405, at which embodiments obtain an identification of the terminal and optionally an identification of the user of the terminal.
Next, process 400 transitions to step 407, at which a context store is consulted in order to retrieve attributes of the terminal or its user. For example, the terminal may have relatively more expanded or limited communication capabilities compared to other terminals already participating in the conference or, in the case of an exiting terminal, the other terminals that would be remaining.
Next, process 400 transitions to step 409, at which attributes of the conference are modified based upon attributes of the terminals remaining in the conference after the other terminal either joins or leaves the conference. Thus, based on the current conference participants, the attributes of the conference (e.g., connection types, data rates, etc.) are modified to accommodate those conference participants.
Turning now to
According to
The flowchart continues in step 504 by detecting during the conference, by the computer of the contact center, that conference membership changes from the first set of member terminals to a second set of member terminals participating in the conference and, in step 506, determining, by the computer of the contact center, a second set of conference attributes based on the second set of member terminals. The conference server, or other server of the contact center, monitors the conference and detects when a new terminal joins the conference or when one of the current member terminals leaves the conference. Upon detecting such a membership change, the context store can once again be consulted to determine the capabilities and communication attributes of the terminals which are currently members of the conference. Based on any membership changes, the flowchart of
Thus, the method of the flowchart of
Furthermore, the following additional steps can be performed as well a) retrieving, by the computer of the contact center, the respective capabilities from a context store of the contact center; b) determining, by the computer of the contact center, a respective identification of each of the first set of member terminals; c) determining, by the computer of the contact center, a respective identification of each of the second set of member terminals; and d) determining, by the computer of the contact center, a respective identification of a respective user associated with each of the first set of member terminals.
Because almost any type of data about present or past contacts can be stored in the context store, and retrieved from the context store, device or terminal identifiers, device or terminal capabilities, and user's associated with various devices and terminals can be stored in a way that associates the information in a way that the relationships between the different data is preserved to simplify locating in the context store any one piece of data based on another, related piece of data.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various aspects of the present disclosure. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). In addition, while the flowcharts have been discussed and illustrated in relation to a particular sequence of events, it should be appreciated that changes, additions, and omissions to this sequence may occur without materially affecting the operation of the disclosure. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, may be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
As will be appreciated by one skilled in the art, aspects of the present disclosure may be illustrated and described herein in any of a number of patentable classes or context including any new and useful process, machine, manufacture, or composition of matter, or any new and useful improvement thereof. Accordingly, aspects of the present disclosure may be implemented entirely hardware, entirely software (including firmware, resident software, micro-code, etc.) or combining software and hardware implementation that may all generally be referred to herein as a “circuit,” “module,” “component,” or “system.” Furthermore, aspects of the present disclosure may take the form of a computer program product embodied in one or more computer readable media having computer readable program code embodied thereon.
Any combination of one or more computer readable media may be utilized. The computer readable media may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an appropriate optical fiber with a repeater, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that may contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that may communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device. Program code embodied on a computer readable signal medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
Computer program code for carrying out operations for aspects of the present disclosure may be written in any combination of one or more programming languages, including an object oriented programming language such as JAVA, SCALA, SMALLTALK, EIFFEL, JADE, EMERALD, C++, CII, VB.NET, PYTHON or the like, conventional procedural programming languages, such as the “c” programming language, VISUAL BASIC, FORTRAN 2003, PERL, COBOL 2002, PHP, ABAP, dynamic programming languages such as PYTHON, RUBY, and GROOVY, or other programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a LAN or WAN, or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider) or in a cloud computing environment or offered as a service such as a Software as a Service (SaaS).
Aspects of the present disclosure are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatuses (systems) and computer program products according to embodiments of the disclosure. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, may be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable instruction execution apparatus, create a mechanism for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. Alternatively, a symmetric multiprocessor (SMP) system or other configuration including a plurality of processors may be used.
These computer program instructions may also be stored in a computer readable medium that when executed may direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions when stored in the computer readable medium produce an article of manufacture including instructions which when executed, cause a computer to implement the function/act specified in the flowchart and/or block diagram block or blocks. The computer program instructions may also be loaded onto a computer, other programmable instruction execution apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatuses or other devices to produce a computer implemented process such that the instructions that execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
While the exemplary embodiments illustrated herein show the various components of the system collocated, certain components of the system may be located remotely, at distant portions of a distributed network, such as a LAN and/or the Internet, or within a dedicated system. Thus, it should be appreciated, that the components of the system may be combined in to one or more devices, such as a switch, server, and/or adjunct, or collocated on a particular node of a distributed network, such as an analog and/or digital telecommunications network, a packet-switch network, or a circuit-switched network. It will be appreciated from the preceding description, and for reasons of computational efficiency, that the components of the system may be arranged at any location within a distributed network of components without affecting the operation of the system. For example, the various components may be located in a switch such as a PBX and media server, gateway, in one or more communications devices, at one or more users' premises, or some combination thereof. Similarly, one or more functional portions of the system could be distributed between a telecommunications device(s) and an associated computing device.
Furthermore, it should be appreciated that the various links connecting the elements may be wired or wireless links, or any combination thereof, or any other known or later developed element(s) that is capable of supplying and/or communicating data to and from the connected elements. These wired or wireless links may also be secure links and may be capable of communicating encrypted information. Transmission media used as links, for example, may be any suitable carrier for electrical signals, including coaxial cables, copper wire, and fiber optics, and may take the form of acoustic or light waves, such as those generated during radio-wave and infra-red data communications.
Referring to
Also connected to the I/O bus may be devices such as a graphics adapter 616, storage 618 and a computer usable storage medium 620 having computer usable program code embodied thereon. The computer usable program code may be executed to execute any aspect of the present disclosure, for example, to implement aspect of any of the methods, computer program products and/or system components illustrated in
A number of variations and modifications of the disclosure may be used. It would be possible to provide for some features of the disclosure without providing others. For example, in one alternative embodiment, the systems and methods of this disclosure may be implemented in conjunction with a special purpose computer, a programmed microprocessor or microcontroller and peripheral integrated circuit element(s), an ASIC or other integrated circuit, a digital signal processor, a hard-wired electronic or logic circuit such as discrete element circuit, a programmable logic device or gate array such as PLD, PLA, FPGA, PAL, special purpose computer, any comparable means, or the like. In general, any device(s) or means capable of implementing the methodology illustrated herein may be used to implement the various aspects of this disclosure. Exemplary hardware that may be used for the present disclosure includes computers, handheld devices, telephones (e.g., cellular, Internet enabled, digital, analog, hybrids, and others), and other hardware known in the art. Some of these devices include processors (e.g., a single or multiple microprocessors), memory, nonvolatile storage, input devices, and output devices. Furthermore, alternative software implementations including, but not limited to, distributed processing or component/object distributed processing, parallel processing, or virtual machine processing may also be constructed to implement the methods described herein.
Although the present disclosure describes components and functions implemented in the embodiments with reference to particular standards and protocols, the disclosure is not limited to such standards and protocols. Other similar standards and protocols not mentioned herein are in existence and are considered to be included in the present disclosure. Moreover, the standards and protocols mentioned herein and other similar standards and protocols not mentioned herein are periodically superseded by faster or more effective equivalents having essentially the same functions. Such replacement standards and protocols having the same functions are considered equivalents included in the present disclosure.
While the foregoing is directed to embodiments of the present disclosure, other and further embodiments of the present disclosure may be devised without departing from the basic scope thereof. It is understood that various embodiments described herein may be utilized in combination with any other embodiment described, without departing from the scope contained herein. Further, the foregoing description is not intended to be exhaustive or to limit the present disclosure to the precise form disclosed. Modifications and variations are possible in light of the above teachings or may be acquired from practice of the present disclosure.
This application claims the benefit of U.S. Provisional Patent Application Ser. No. 62/207,506, filed on Aug. 20, 2015, entitled SYSTEM AND METHOD FOR FREE-FORM CONFERENCE, the entire contents of which are hereby incorporated by reference.
Number | Date | Country | |
---|---|---|---|
62207506 | Aug 2015 | US |