The present disclosure relates to the field of computers, and specifically to the use of computers in handling service requests. Still more particularly, the present disclosure relates to routing trouble tickets to appropriate Subject Matter Experts (SMEs).
Enterprises often support hundreds of clients using a framework designed to route requests for assistance to appropriate resources, including a human resource. Such resources have different areas of expertise. Thus, requests for assistance are sent to a resource that has the appropriate expertise/knowledge/ability needed to handle a particular type of request. However, maintaining a listing of such areas of expertise and the persons who have them is impractical and/or impossible for a large enterprise, since 1) areas of expertise are always changing, and 2) personnel changes are commonplace. Furthermore, by narrowly defining a human resource according to his personal areas of expertise, such systems are unable to handle spikes in request traffic, since the resource pool is fixed and limited.
A method, system, and/or computer program product handles trouble tickets in a service unit. Friend members of a social network group to which a proxy Subject Matter Expert (SME) belongs are identified. Areas of expertise, which include expertise in a particular subject, that are held by the friend members of the social network group are identified, and then associated with the proxy SME. A trouble ticket related to the particular subject is received, and a primary SME that personally has a level of expertise to handle the trouble ticket is identified. In response to the primary SME being unavailable, the trouble ticket is transmitted to the proxy SME for handling by one or more of the friend members from the social network group to which the proxy SME belongs.
The present invention may be a system, a method, and/or a computer program product. The computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present invention.
The computer readable storage medium can be a tangible device that can retain and store instructions for use by an instruction execution device. The computer readable storage medium may be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination of the foregoing. A non-exhaustive list of more specific examples of the computer readable storage medium includes 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), a static random access memory (SRAM), a portable compact disc read-only memory (CD-ROM), a digital versatile disk (DVD), a memory stick, a floppy disk, a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon, and any suitable combination of the foregoing. A computer readable storage medium, as used herein, is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire.
Computer readable program instructions described herein can be downloaded to respective computing/processing devices from a computer readable storage medium or to an external computer or external storage device via a network, for example, the Internet, a local area network, a wide area network and/or a wireless network. The network may comprise copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers. A network adapter card or network interface in each computing/processing device receives computer readable program instructions from the network and forwards the computer readable program instructions for storage in a computer readable storage medium within the respective computing/processing device.
Computer readable program instructions for carrying out operations of the present invention may be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Smalltalk, C++ or the like, and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The computer readable program instructions 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 local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider). In some embodiments, electronic circuitry including, for example, programmable logic circuitry, field-programmable gate arrays (FPGA), or programmable logic arrays (PLA) may execute the computer readable program instructions by utilizing state information of the computer readable program instructions to personalize the electronic circuitry, in order to perform aspects of the present invention.
Aspects of the present invention are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems), and computer program products according to embodiments of the invention. 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, can be implemented by computer readable program instructions.
These computer readable 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 data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer readable program instructions may also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
The computer readable program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
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 embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which comprises one or more executable instructions for implementing the specified logical function(s). In some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. 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, can be implemented by special purpose hardware-based systems that perform the specified functions or acts or carry out combinations of special purpose hardware and computer instructions.
Today, issues may arise in a service desk environment that appear to be unique or requiring skills in a certain area that is not readily available. If the issue is centered around a well-known subject, it is routed to the appropriate group or person who represents that subject area. If it is not, the ticket is very frequently routed to many different groups and many different people until someone with knowledge in that very narrow area is assigned to resolve the issue. This causes quite a bit of delay in resolving issues. Furthermore, there is a vast amount of knowledge that is not currently utilized within the group of service agents' peers. That is, since handling trouble tickets (i.e., service tickets) is not part of these peers' job description, their ability to help in handling service calls is not utilized. Thus, the present invention provides a method, system, and/or computer product that mines social media, social networks and external user community sites to understand not only what kind of technology a particular service agent is familiar with, but also what kind of business and relationships that agent has with subject matter experts (whose job description may or may not include handling requests for assistance from customers) that might be leveraged. The present invention also overcomes the problem of fixed systems, such as a database describing interests, skills, classes, etc. of human resources, which becomes out of date very rapidly.
Note that the terms “social media” and “social websites” are utilized interchangeably herein, and are defined as on-line services that allow individuals, corporations, and other entities to electronically communicate in a controlled (via a social media service) community environment. The terms “media group” and “social media group” are likewise used interchangeably, and are defined as a predefined group of entities within a social website.
With reference now to the figures, and in particular to
Exemplary computer 102 includes a processor 104 that is coupled to a system bus 106. Processor 104 may utilize one or more processors, each of which has one or more processor cores. A video adapter 108, which drives/supports a display 110, is also coupled to system bus 106. System bus 106 is coupled via a bus bridge 112 to an input/output (I/O) bus 114. An I/O interface 116 is coupled to I/O bus 114. I/O interface 116 affords communication with various I/O devices, including a keyboard 118, a mouse 120, a media tray 122 (which may include storage devices such as CD-ROM drives, multi-media interfaces, etc.), a printer 124, and external USB port(s) 126. While the format of the ports connected to I/O interface 116 may be any known to those skilled in the art of computer architecture, in one embodiment some or all of these ports are universal serial bus (USB) ports.
As depicted, computer 102 is able to communicate with a software deploying server 150, using a network interface 130. Network interface 130 is a hardware network interface, such as a network interface card (NIC), etc. Network 128 may be an external network such as the Internet, or an internal network such as an Ethernet or a virtual private network (VPN).
A hard drive interface 132 is also coupled to system bus 106. Hard drive interface 132 interfaces with a hard drive 134. In one embodiment, hard drive 134 populates a system memory 136, which is also coupled to system bus 106. System memory is defined as a lowest level of volatile memory in computer 102. This volatile memory includes additional higher levels of volatile memory (not shown), including, but not limited to, cache memory, registers and buffers. Data that populates system memory 136 includes computer 102's operating system (OS) 138 and application programs 144.
OS 138 includes a shell 140, for providing transparent user access to resources such as application programs 144. Generally, shell 140 is a program that provides an interpreter and an interface between the user and the operating system. More specifically, shell 140 executes commands that are entered into a command line user interface or from a file. Thus, shell 140, also called a command processor, is generally the highest level of the operating system software hierarchy and serves as a command interpreter. The shell provides a system prompt, interprets commands entered by keyboard, mouse, or other user input media, and sends the interpreted command(s) to the appropriate lower levels of the operating system (e.g., a kernel 142) for processing. Note that while shell 140 is a text-based, line-oriented user interface, the present invention will equally well support other user interface modes, such as graphical, voice, gestural, etc.
As depicted, OS 138 also includes kernel 142, which includes lower levels of functionality for OS 138, including providing essential services required by other parts of OS 138 and application programs 144, including memory management, process and task management, disk management, and mouse and keyboard management.
Application programs 144 include a renderer, shown in exemplary manner as a browser 146. Browser 146 includes program modules and instructions enabling a world wide web (WWW) client (i.e., computer 102) to send and receive network messages to the Internet using hypertext transfer protocol (HTTP) messaging, thus enabling communication with software deploying server 150 and other computer systems.
Application programs 144 in computer 102's system memory (as well as software deploying server 150's system memory) also include a Trouble Ticket Assignment Logic (TTAL) 148. TTAL 148 includes code for implementing the processes described below, including those described in
Note that the hardware elements depicted in computer 102 are not intended to be exhaustive, but rather are representative to highlight essential components required by the present invention. For instance, computer 102 may include alternate memory storage devices such as magnetic cassettes, digital versatile disks (DVDs), Bernoulli cartridges, and the like. These and other variations are intended to be within the spirit and scope of the present invention.
With reference now to
In one embodiment, the request 204 itself is also only machine-interpretable, such as a voltage level, frequency, etc. of an electronic signal that is the request 204, and which is interpreted by hardware within WMS 206. That is, if request 204 is of a predefined voltage/frequency signal, the hardware within WMS 206 will interpret this predefined voltage/frequency signal as indicative of a specific problem/trouble with the monitored system 203.
Whether user-entered or automatically entered, request 204 may be a request to fix a problem with a computer (hardware or software), resolve a billing dispute, handle a legal issue such as complying with regulatory issues in a foreign country, etc. As depicted in
In the example shown in
In the example shown in
With reference now to
In one embodiment, membership in social media group 316 is limited to only those entities selected by proxy SME 312. For example, proxy SME 312 may select certain issue experts that proxy SME 312 has worked with on other projects, etc., and thus knows that they are appropriate resources to handle trouble tickets.
In one embodiment, membership in social media group 316 is limited to only those entities selected by WMS 306. That is, WMS 306 will data mine information about various entities, including experts 314a-314c shown in
Since social media group 316 includes experts 314a-314c in corresponding Issues A-C, then proxy SME 312 is able to handle, through consultations with and/or referrals to experts 314a-314c, trouble tickets 308a-308c. For example, in one embodiment, proxy SME 312 receives the trouble ticket 308a regarding Issue A, gets advice from expert 314a on how to handle the trouble ticket 308a, and then proxy SME 312 communicates a solution back to the customer on customer client computer 302. In another embodiment/example, however, proxy SME 312 sends the trouble ticket 308a (which includes contact information for the customer making the request 304) to expert 314a, who then responds directly to the customer by providing a solution to Issue A.
Rather than requiring proxy SME 312 to remember what areas of expertise are held by members of his social media group 316, WMS 306 determines what areas of expertise each of the peers (i.e., experts 314a-314c) in social media group 316 hold. In one embodiment, this is accomplished by interrogating a database that simply includes a profile of each of the experts 314a-314c, including their areas of expertise. In another embodiment, however, WMS 306 data mines information associated with the experts 314a-314c in order to determine what their respective areas of expertise are. For example, consider the data mining described in
For example and with reference to criterion (1), if a poster of the content shared by the social media group 316 has a profile showing that he has been predefined as an expert in Issue A but not in Issue B, then any posts about Issue A by that poster are given more weight than his/her posts about Issue B.
With reference to criterion (2), if a particular post has been peer-reviewed and given a strong review (e.g., by a number of “Like” responses indicating that they agree with the post), then that post will be given a higher weighting than a post that has not been favorably received.
With reference to criterion (3), a particular post that was made within the past month would be weighted heavier than a post that was posted ten years ago. That is, a person's level of expertise in a particular area, and thus the significance of his/her posts regarding that particular area, is assumed to decrease over time, since the poster is no longer actively posting in that particular area (thus indicating a drop in activity by that poster regarding that particular area).
With reference to criterion (4), activities being performed by the poster at the time of the post affect the weighting of his/her posts. For example, assume that a poster is working on a project related to Issue A when he filed a post on a social media website. This post has a greater weight than a post that, although related to Issue A, was made while the poster was working on a project that was unrelated to Issue A. That is, if a person was in the act of working on a project, doing research, writing a paper, presenting a seminar, etc. related to Issue A at the time of the post, then an assumption is made that whatever he/she posted at that time is significant, and thus deserves a high weight. However, if the person was working on an unrelated issue (i.e., Issue X) at the time of the posting related to Issue A, then an assumption is made that the posting does not reflect the most current state of the art regarding Issue A, since the poster was devoting his attention to Issue X, and not Issue A, at the time of the post.
With reference to criterion (5), a post is weighted according to whether the post was by one member or by multiple members (experts 314a-314c) of the social media group 316. That is, if a post about Issue A came from only one of the members of the social media group 316 (e.g., expert 314a), then that posting is weighted lower than if the post about Issue A was co-authored by multiple experts (particularly those with known expertise in Issue A within the social media group 316), since the post was collaborative and thus inherently peer-reviewed.
Note that the social media topics 402 and their quantity of postings depicted in
With reference to scenario (a), breaking out the quantity (weighted or unweighted) of posts for a particular social media topic by a single member of the social media group 316 will indicate what areas of expertise that single member has. In the example shown in depiction 400, assume that A-C and L-M identify topics that a particular member of the social media group 316 has posted on. Since this particular member has posted on Topics/Issues/Areas A, B, and C more than the predetermined threshold indicated by line 404, then that particular member is deemed to be an expert in Topics/Issues/Areas A, B, and C.
With reference to scenario (b), assume that a group of members of the social media group 316 (e.g., a subgroup that includes all members deemed to be experts in a particular area) post entries related to Topics/Issues/Areas A, B, and C as well as Topics/Issues/Areas L, M, and N. Collectively, this subgroup is deemed to have collective expertise (i.e., by utilizing them together as a subgroup to handle a particular trouble ticket) related to Topics/Issues/Areas A, B, and C, since together they have posted more than the predetermined threshold indicted by line 404 for Topics/Issues/Areas A, B, and C. However, since the quantity of posts related to Topics/Issues/Areas L, M, and N has not exceeded the predetermined threshold indicated by line 404, then this subgroup, even working together, are not considered to be experts in Topics/Issues/Areas L, M, and N.
With regards to scenario (c) all members of the social media group 316, a similar analysis for the collective level of expertise for all members of the social media group 316 is used for the subgroup discussed in scenario (b).
With reference now to
In one embodiment of the present invention, data mining posts and other social media content of potential peer experts utilizes the following steps.
Step (1). The Social Mining Analytics Engine (SMAE) 504 queries the Work Management System (WMS) 506 and pulls in the next batch of users to inspect. The system 500 may also pull in additional social media sites with credentials.
Step (2). The SMAE queries database 502 and pulls in a fresh list of terms that should be considered along with the corresponding concept. This can be any technical or non-technical terms. Since a user is linked to a Skill Concept such as Networking, terms such as “IPSec Tables”, “Natted IP Address”, “Socket”, “Packet Filtering” will correspond to a concept called “Networking”.
Step (3). SMAE 504 then cycles through the available sites from SMS 508.
Step (4). For each site in SMS 508, SMAE 504 cycles through the users of each site that the SMAE 504 tracks.
Step (5). SMAE 504 connects to a current site and pulls a list of recent (since the last inspection) posts created for a user. The SMAE 504 now has a series of social media posts for a given user for a given site.
Step (6). At this point, SMAE 504 applies a matching algorithm that compares the posts to a database of terms in an attempt to understand which (if any) Skill Concepts might have been discussed in the post.
Step (7). If the terms match, SMAE 504 applies a peer acknowledgement signature to understand if any other users of that site have “liked”, “bumped”, referenced, or shared the information and if so, how many times. The more times a particular post is acknowledged, the more weight this post carries.
Step (8). Based on the information in Steps (6) and (7), a score is calculated for each Skill Concept that can be identified.
Step (9). SMAE 504 updates the user's record to incorporate the new score with any previous scores for the given concept.
Step (10). SMAE 504 compares the total score (i.e., the previous score augmented by the current weight) to a threshold for a given concept to determine if this user should or should not be considered “skilled” in the given concept. For example, if a user has been posting over the course of a month about a given network topic, and with this most recent inspection, they now have a Network Concept skill of 300, that may cross the threshold and the user should be upgraded from a level 2 skill at networking to a level 3.
Step (11). SMAE 504 updates the work management system (WMS 506) with the user's new skill rating for a given Concept and moves on to the next matched term.
With reference now to
After initiator block 602, friend members of a social network group to which a proxy Subject Matter Expert (SME) belongs are identified (block 604) In one embodiment, only the friend members and the proxy SME are members of this social network group.
As described in block 606, areas of expertise held by the friend members of the social network group are identified, either by data mining their entries on social media sites or by reviewing their profiles. The identified areas of expertise include expertise in a particular subject (e.g., Areas/Issues/Fields A-C, as described above).
As described in block 608, the areas of expertise, held by the friend members of the social network group, are then associated with the proxy SME. For example, in
As described in block 610, a trouble ticket related to a particular subject is generated (e.g., in response to receiving a request from a customer, such as the request 304 depicted in
As described in block 612, a primary SME (e.g., primary SME 212 depicted in
In one embodiment of the present invention, a subgroup of friends from the friend members of the social network group is identified. In one embodiment, this subgroup of friends is made up of persons who have all worked on past projects with the proxy SME, thus giving the proxy SME an assurance that any member of this subgroup is capable of handling the trouble ticket, and/or will be compatible with the customer. Based on these criteria, the trouble ticket is then transmitted only to this subgroup of friends.
In one embodiment of the present invention, the trouble ticket is transmitted from a work management system (e.g., WMS 306 described above with
In one embodiment of the present invention, the areas of expertise held by the friend members of the social network group are identified by data mining entries, made by the friend members of the social network group, on a shared message board used by the social network group (e.g., as described in
In one embodiment of the present invention, a trouble ticket is generated for a particular problem. In this embodiment, the trouble ticket is parsed into multiple sub-tickets, where each sub-ticket addresses a subcomponent issue of the particular problem. That is, assume that the request from the customer (and the resulting trouble ticket) is for a server that won't boot up. However, an examination of signals from the monitored system (e.g., monitored system 203 being monitored by customer client computer 302 in
In one embodiment of the present invention, the trouble ticket is assigned to the proxy SME to be handled personally by the proxy SME. That is, the proxy SME will still consult with his peers within the social media group, but all communications with the customer are by the proxy SME.
In one embodiment of the present invention, a proxy area of expertise is defined for the proxy SME as comprising the areas of expertise held by the friend members of the social network group. For example, as shown in
In one embodiment of the present invention, the proxy area of expertise assigned to proxy SME is modified according to a quantity of social media topic entries posted by the friend members of the social network group. That is, the more posts made by the peers within the proxy SME's social group on a particular subject, the greater the level of “proxy expertise” is given to the proxy SME.
In one embodiment of the present invention, the primary SME is from a plurality of SMEs that all have expertise in the particular subject. In this embodiment, all of the other SMEs are interrogated for current real-time availability. If none of the primary SMEs from the plurality of SMEs are available, then the trouble ticket is sent to the proxy SME.
In one embodiment of the present invention, the trouble ticket is generated in response to a customer transmitting a request for service to a work management hardware system, where the customer transmitted the request from a client hardware device, and where a response to the request for service will be handled by an electronic communication between the customer and at least one service computer used by at least one of the friend members of the social network group. That is, as described above, the request is generated by a client hardware device, such as the customer client computer 302 depicted in
As described herein, the present invention utilizes social media to build a profile of incident resolvers based on mining social media posts (including, but not limited to sites such as public social media websites, internal social media sites, message boards, etc.). In one embodiment, the system mines social media posts and maintains an index of technical terms, which leads to primary specialization for certain individuals. This allows the new concept of a “specialization by proximity” to become available. This “specialization by proxy” allows a service center to search for Subject Matter Experts (SMEs) not only within its primary tier1/2/3 agents, but also to make use of their associates' knowledge. Thus in one embodiment, if there is no primary resource available for a given technology, the trouble ticket is routed to a proxy SME that has an associate that is an expert in that field. Based on the usage of social networking, the amount and complexity of issues that can be assigned to that proxy SME grows exponentially based on his/her associates.
As described in the written specification and drawings herein, in one or more embodiments a specialization by proxy method/system understand an expertise of a proxy SME's peer groups and, barring any other viable primary SME candidate, route a trouble ticket to a “Specialist by proxy”. This allows the system to take advantage of knowledge of peers as well as primary SMEs, in order to route tickets and work to agents that can find the right answer, even if they do not know it themselves.
Note that any methods described in the present disclosure may be implemented through the use of a VHDL (VHSIC Hardware Description Language) program and a VHDL chip. VHDL is an exemplary design-entry language for Field Programmable Gate Arrays (FPGAs), Application Specific Integrated Circuits (ASICs), and other similar electronic devices. Thus, any software-implemented method described herein may be emulated by a hardware-based VHDL program, which is then applied to a VHDL chip, such as a FPGA.
Having thus described embodiments of the present invention of the present application in detail and by reference to illustrative embodiments thereof, it will be apparent that modifications and variations are possible without departing from the scope of the present invention defined in the appended claims.