Method and system for visualization of threaded email conversations

Information

  • Patent Grant
  • 7506263
  • Patent Number
    7,506,263
  • Date Filed
    Tuesday, February 5, 2008
    16 years ago
  • Date Issued
    Tuesday, March 17, 2009
    15 years ago
Abstract
An embodiment of the invention uses the message sequence chart (MSC) and various visual cues to provide an interactive visualization of threaded electronic conversations (e.g., in email, bulletin board, instant message, or social network) by presenting to users various information about a particular conversation or the conjunction of separate conversations, such as sequences of messages, conversation participants, time in transit, time send/received, and other message attributes.
Description
BACKGROUND OF THE INVENTION

In general, the move to Web 2.0 has focused much more on user-centric computing and has both enabled and highlighted the need for contextual collaboration and the social aspects of collaboration. The common methods for collaboration include email and bulletin boards. However, the current email agents focus on the management of individual messages rather than focusing on the collaboration between parties. For example, email agents tend to order the messages based on the time of arrival or sort them by subject line, but they do not provide for a visualization of conversations in electronic form such that the collaboration between parties becomes the focus of the user.


SUMMARY OF THE INVENTION

One embodiment of the invention described here pertains to the visualization of threaded electronic conversations (email) such that a client application can present various information about a particular conversation (or the conjunction of separate conversations) allowing the user to easily see message sequences, conversation participants, time in transit, time in process and other information.


One embodiment is equally applicable to electronic mail, bulletin boards, instant messaging or other forms of conversation and is equally applicable both to traditional desktop based mail agents as well as web 2.0 browser-based applications (such as social networking sites). This disclosure will use the example of email consistently throughout but the invention is applicable to other forms of conversation.


The visualization, with appropriate actions available on the visual elements, allows for even traditional email to become more of a social and collaborative tool than simply a message-oriented and reactive one. One embodiment uses the industry standard Message Sequence Chart (MSC) notation common in software and systems design languages such as the Unified Modeling Language (UML) or Specification and Description Language (SDL).





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a schematic diagram of a visualization of an email thread.



FIG. 2 is a data flow diagram showing an example of message processing steps



FIG. 3 is a schematic diagram of the incomplete view of visualization email thread.



FIG. 4 is a schematic diagram of the visualization email threads with an out of sequence participant.



FIG. 5 is a schematic diagram of an example of the visual cue reference sample.





DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

One embodiment uses the industry standard MSC notation common in software and systems design languages such as the ML or SDL. The following example demonstrates the visualization of a simple email exchange in one embodiment.


The simple exchange depicted in FIG. 1 corresponds to the first author Simon (110) sending a message to Kevin (112). After some time, Kevin forwards the message to Steve (114) who after reading it replies to Kevin. Finally, Kevin forwards the response back to Simon. The visualization allows any participant to view that part of the exchange they have available to them and see the participants in the exchange (denotes by the icons along the top) and the visual cues such as the slant of the arrows (e.g., 120) indicating the time taken to deliver the message, the length of the thick vertical bar (e.g., 116) indicating the time the message sat in the users inbox, and a time bar (118) indicating when various events occurred.


One embodiment presents visual cues such as the use of hover-over tool tips to display the actual time taken for a message or the email address of a user. In one embodiment, each message transit arrow (e.g., 120) responds to common email operations such as reply-to or forward to allow the user to respond to a particular message.


The flowchart in FIG. 2 indicates the steps taken in one embodiment of the invention from the user selecting a message that is included in a thread of interest to the presentation of the visualization. Here, a user selects one or more messages to use as a context (210). The mail agent searches (212) the mail store (226) for related messages, using message IDs, subject text and other heuristics. Messages may be found which are related but which appear to be in different threads (214). The user is prompted to include (or not) related threads (216). If user selects to include related threads, the mail agent searches the mail store for messages related to the new threads (218). Next, the messages are parsed to find embedded responses (222). One embodiment presents the visualization (224) in the display using user information (e.g. icons/images representing each thread participant) extracted from a user store (228) such as a directory server. In case of no image, one embodiment uses default icons.


In particular, the parsing of messages is important, as those messages that are in user's inbox only represent those sent to the user; however, more messages may include embedded responses as shown in listing 1. In Bulletin Board systems where all messages are public, an embodiment processes all messages discretely to present visualization. In an email systems where an email agent only has access to those messages sent to the particular user, an embodiment parses out these responses to allow for the presentation of more of the conversation even when the entire store of messages is not available to the mail agent. Below is an example listing of an e-mail message:


Listing 1.






    • From: Kevin [mailto:kevin@.com]

    • Sent: Mon 8/6/2007 4:01 PM

    • To: simon@.com

    • Subject: Fw: the project

    • This project is now finished.

    • > From: Steve [mailto:steve@.com]

    • > Sent: Mon 8/6/2007 2:30 PM

    • > To: kevin@.com

    • > Subject: Re: the project

    • >

    • > All done now

    • >

    • >> From: Kevin [mailto:kevin@.com]

    • >> Sent: Mon 8/6/2007 11:00 AM

    • >> To: steve@.com

    • >> Subject: Fw: the project

    • >>

    • >> Can you deal with this please?

    • >>

    • >>> From: Simon [mailto:simon@.com]

    • >>> Sent: Mon 8/6/2007 9:01 AM

    • >>> To: kevin@.com

    • >>> Subject: the project

    • >>>

    • >>> We need to finish this project





While a user may send a message to a group of people (either by selecting multiple To: or Cc: addresses) or by selecting a mailing list, the actual conversations are point-to-point. In one embodiment, upon the user hovering the mouse over individual arrow line within the visualizations, To: or Cc: list are displayed for the message represented by the arrow. One embodiment navigates directly to the corresponding message to display the precise details when the user clicks on the arrow.



FIG. 1 demonstrates an embodiment with a scenario where a visualization of the message involves three users sending messages back and forth. In another scenario (FIG. 3), Steve (314) (and not Simon (310)) requests the visualization of the same thread. In this scenario, the user (Steve) has replied to the message from Kevin (312), but he may not know where the messages go from there; so the user sees an incomplete view of the thread (FIG. 3). In particular, the arrow corresponding to the user's reply does not indicate any transmit time (as the user would not necessarily know when it was delivered). Also, there is no indicator on the vertical line for Kevin, as to the time taken for that user to process the message is unknown in this scenario. One embodiment uses a flat line (316) for the message representation from Steve to Kevin to indicate no or unknown transit time.


An embodiment deals with a scenario depicted in FIG. 4 where one or more users appear “out of sequence” in a thread because someone sent them a message but that information is not reflected in their reply and they appear to enter a conversation at some point. One embodiment displays this occurrence in the visualization by showing the message arrive into the thread by a person or entity (416) without showing the message sent to that person or entity (e.g., by any other participants 410, 412, or 414). In one embodiment, the corresponding message arrow is displayed as a flat arrow (418).


One embodiment deals with visualization of multiple related threads as well as related messages in a single thread. For example, the user, Steve, before replying to the message from Kevin forwards the message to Jan; however, Steve changes the subject to something more appropriate before sending. This thread goes to Bob (a fifth person in the e-mail thread) who also sends a copy back to Simon. Therefore, an embodiment determines this message as part of a new thread but it also determines that some of the message content is shared and therefore it marks the thread as related. One embodiment superimposes these threads in one visualization by using different colors or other visual cues for messages belonging to different threads.


One embodiment indicates certain message actions such as send, reply, and forward with different visual cues allowing the user to quickly see the dynamic nature of the conversation. For example, as shown in FIG. 5, filled arrow heads indicate a message sent; empty arrow heads indicate a message forwarded; a double arrow head indicate a message being replied to; a double empty arrow head on a dashed line indicates a system message (e.g., the user requested a delivery-receipt message which has been delivered to the user). One embodiment categorizes and treats read-receipt and message cancellation as system messages.


One embodiment uses additional cues to denote properties of messages such as their being marked as urgent, having attachments, being signed or encrypted. An embodiment visually identifies additional system messages such as “out of office”, or “mail delivery” reports with separate visual cues.


In one embodiment, a mail agent provides additional semantics for messages such as “this message is an addendum to/continuation of the conversation” or “this message contains a new assertion that could serve as a focal point for new replies”. In one embodiment, such tags enable email agents to efficiently identify and process related messages.


One embodiment of the invention turns on or off visual cues per user's setting and specification in order to reduce “clutter” in the visualization. One embodiment filters the messages by type per user's setting or specification. E.g., the embodiment removes all system messages from the display.


One embodiment of the invention is a method for visualization of threaded emails, the method comprising:

    • receiving email threads from a sequence of emails between multiple users;
    • using a message sequence chart notation to represent the email threads;
    • representing time on a first axis;
    • representing the email threads on a second axis; wherein the first axis and the second axis are orthogonal with respect to each other;
    • using an arrow to indicate the direction of an email;
    • representing each of reply, send, forward, system, urgent, and attachment messages using different unique shapes, thickness, and symbols;
    • using slope of the arrow to indicate passage of time corresponding to the first axis;
    • one of the multiple users selecting one or more emails from the sequence of emails, to use as a context;
    • a mail agent searching a mail storage for a related message, with respect to the selected one or more emails from the sequence of emails;
    • in case the related message is found, prompting the one of the multiple users to decide to include or not include the related message;
    • parsing messages to find embedded responses;
    • providing icons for visualization purpose from a user store or a directory server;
    • hovering over the arrow to display TO-list, CC-list, and other information from its corresponding message;
    • displaying an incomplete view;
    • displaying an out-of-sequence view;
    • displaying related messages and threads;
    • using colors, shadings, symbols, dotted lines, arrows, different sizes, and different thicknesses, to indicate relationships between the related messages and threads, context, topic, or subject;
    • displaying delivery-receipt, read-receipt, out-of-office, addendum, continuation, approval, counter-argument, and message cancellation;
    • tagging the messages;
    • filtering the messages;
    • hiding the messages;
    • removing the messages; and
    • aggregating, tabulating, and summarizing details of the messages.


A system, apparatus, or device comprising one of the following items is an example of the invention: email, thread, message, user, sequence chart, time, line or arrow representing a message, visual cues, message attributes, context, mail storage, mail agent, mail server, bulletin board, social network, response, embedded response, icon, image, user information, user information store, directory server, any display screen, computer display, views, topic or subject, tag, filter, query result, or any software, applying the method mentioned above, for purpose of invitation or visualization of threaded emails.


Any variations of the above teaching are also intended to be covered by this patent application.

Claims
  • 1. A method for visualization of threaded emails, said method comprising: receiving email threads from a sequence of emails between multiple users;using a message sequence chart notation to represent said email threads;
US Referenced Citations (24)
Number Name Date Kind
6219826 De Pauw et al. Apr 2001 B1
6594673 Smith et al. Jul 2003 B1
7421660 Charnock et al. Sep 2008 B2
20030158903 Rohall et al. Aug 2003 A1
20030177190 Moody et al. Sep 2003 A1
20040117768 Chang et al. Jun 2004 A1
20040153456 Charnock et al. Aug 2004 A1
20040260756 Forstall et al. Dec 2004 A1
20050114781 Brownholtz et al. May 2005 A1
20060117273 Smith et al. Jun 2006 A1
20060173824 Bensky et al. Aug 2006 A1
20060173961 Turski et al. Aug 2006 A1
20060195785 Portnoy et al. Aug 2006 A1
20060271630 Bensky et al. Nov 2006 A1
20070061738 Taboada et al. Mar 2007 A1
20070106729 Adams et al. May 2007 A1
20070132767 Wright et al. Jun 2007 A1
20070143428 Kumar et al. Jun 2007 A1
20070214137 Gloor Sep 2007 A1
20070250576 Kumar et al. Oct 2007 A1
20070276901 Glinsky et al. Nov 2007 A1
20080091656 Charnock et al. Apr 2008 A1
20080201068 Boyersmith et al. Aug 2008 A1
20080244372 Rohall et al. Oct 2008 A1
Foreign Referenced Citations (1)
Number Date Country
WO2007029116 Mar 2007 WO