Currently, when managing information, users oftentimes handle specific units of content, or data items (e.g., email, documents, etc.), in isolation. Typically, a given document may be more useful to a user if it is in context of other related content, especially if the document is a data item of a particular project. For example, consider a user who is working on a project about computers, and he/she has several documents about various components of a computer, as well as several emails from other project members about various subjects relating to a computer. If the user is reading or editing one of the documents about a computer component, it would be most advantageous to the user to have knowledge of the other documents and emails that are contextually related to the particular document that he/she is using.
It is with respect to these and other considerations the present invention has been made.
Embodiments of the present invention solve the above and other problems by providing for automatically discovering a context of a data item, and for bringing together sources of information that may be relevant to the given data item. A data item may be parsed for interesting data or data item features, information may be extracted, and a search may be built and applied to various other data sources based on the context discovered for the parsed data item.
The details of one or more embodiments are set forth in the accompanying drawings and description below. Other features and advantages will be apparent from a reading of the following detailed description and a review of the associated drawings. It is to be understood that the following detailed description is explanatory only and is not restrictive of the invention as claimed.
This summary is provided to introduce a selection of concepts in a simplified form that are further described below in the detailed description. This summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended as an aid in determining the scope of the claimed subject matter.
The accompanying drawings, which are incorporated in and constitute a part of this disclosure, illustrate various embodiments of the present invention. In the drawings:
Embodiments of the present invention are directed to automatically discovering context of a data item, and to bringing together sources of information that may be contextually relevant to the given data item. A data item may be parsed for interesting data or features, such as keywords, questions, answers, terms, links, clip art, authors, senders, receivers, dates, times, as well as, other content from electronic documents, electronic mail, calendar items, contacts items, tasks items, social network communications and the like. Discovered interesting data may be extracted and mapped to a plurality of search mechanisms. A search may be applied to various data sources by the plurality of search mechanisms, and search results may be displayed in a single user interface. A user's interaction with search results and/or feedback provided by a user on search results may be utilized as a data points for future extractions and searches.
The following description refers to the accompanying drawings. Whenever possible, the same reference numbers are used in the drawings and the following description to refer to the same or similar elements. While embodiments of the invention may be described, modifications, adaptations, and other implementations are possible. For example, substitutions, additions, or modifications may be made to the elements illustrated in the drawings, and the methods described herein may be modified by substituting, reordering, or adding stages to the disclosed methods. Accordingly, the following detailed description does not limit the invention. Instead, the proper scope of the invention is defined by the appended claims.
Referring now to the drawings, in which like numerals represent like elements through the several figures, aspects of the present invention and the exemplary operating environment will be described. While the invention will be described in the general context of program modules that execute in conjunction with an application program that runs on an operating system on a personal computer, those skilled in the art will recognize that the invention may also be implemented in combination with other program modules.
Generally, program modules include routines, programs, components, data structures, and other types of structures that perform particular tasks or implement particular abstract data types. Moreover, those skilled in the art will appreciate that the invention may be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, mainframe computers, and the like. The invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote memory storage devices.
As briefly described above, embodiments are directed to automatically discovering context of a data item, and to bringing together sources of information that may be contextually relevant to the given data item.
Embodiments of the present invention may comprise a synchronization framework 106, which is a framework of data collection interfaces 104, herein referred to as data collectors. A data collector 104 is an interface that may communicate with a data source 102, and pull data items 103 that may contain relevant information to a project from the data source 102. A project may be created by a user within a PDAM application 114. When a project is created, a title and description may be given to the project, which may be used as metadata 110 for discovering content that may be of relevance to the project. Data collectors 104 may search for content locally and from external repositories. Discovered content may be suggested to a user, wherein the user may accept a suggested piece of content and that data item 103 may be extracted and stored into a project data store 108.
Information that is exchanged between a data source 102 and a data collector 104 may be customizable. For example, if the data source 102 is an electronic mail application, electronic calendar application, electronic task application, or an application that provides combined resources of these applications, for example, OUTLOOK by MICROSOFT CORPORATION of Redmond, Wash., a data collector 104 may be implemented to interface the email application so that it may be operative for discovering data and metadata of an email. As should be appreciated, there may be multiple extraction points of a data source 102. Accordingly, there may be multiple data collectors 104 for a data source 102. Considering the above example, where the data source 102 is an electronic mail application, electronic calendar application, electronic task application, or combination functionality application, one data collector 104 may be implemented to discover email data, and another data collector 104 may be implemented to discover calendar data, and another to discover task data, etc. A data collector 104 may know not only where to get data, but also how and what type of data to retrieve.
As new data sources 102 are added to a project, a synchronization framework 106 may implement new data collector 104 interfaces. For every possible type of collection, an implementation of that interface may be added to the synchronization framework 106. The synchronization framework 106 may pull in data as well as push data back out to a data source 102. Data may be pulled in via one of two modes. According to a first mode, a data source 102 may be checked for new content according to a specified time interval. For example, a data source 102 may be checked every thirty (30) seconds to see if there is new data available. With some data sources 102, it may be inefficient to pull data in such a manner. By utilizing a subscriber-type model, a data source 102 may notify the synchronization framework 106 when a change occurs. Consider, for example, that a data collection, organization and sharing application, for example, SHAREPOINT by MICROSOFT CORPORATION is a data source 102 for a project. The application may use very large lists to transfer data. The list may have thousands of elements, so it would be inefficient to pull them and check a thousand elements every thirty (30) seconds for new data. Accordingly, a second mode may be utilized to check for new data. The synchronization framework 106 may register for an event, wherein the synchronization framework 106 may be notified when a change has occurred.
As data items 103 that are of relevance to a project are pulled from a data source 102 by a data collector, that data may be stored in a project data store 108. The project data store 108 is a data repository or organizational knowledge base, and may be available to and access by others. Data collectors 104 may put data into a project data store 108 in whatever way may be most efficient for the system. For example, if document information is being collected, that data may be put into the data store 108 by downloading the document and associating the whole document with the project. Alternatively, instead of downloading the full document, a link to the document may be downloaded; and, the link information may be tagged with a last modification date. In the same way that various forms of data may be collected from a variety of aggregation points, the way the data is stored internally can vary. Project data 108 may be a collection of identifications to actual data that may be stored locally or in disparate locations. Data may comprise project related content as well as contact information, and any other available content that may be relevant to a project. A project data store 108 may also comprise metadata 110, such as a title, description, other people who may be joined and working on a project, security descriptors, types of content that should be stored within a project, and how it should be displayed in a user interface 112.
According to one embodiment, data may be stored in a data base table, for example a structured query language (SQL) data table. After a project data store 108 is created, all associated content may be added into the data store. The content may consist of a generic wrapper that provides a name, an identifier, a creation date, and other pieces of metadata along with payloads, which consist of the actual data or links to the actual data. For example, if a user adds a contact to a project, a wrapper may be created that may contain a title of the contact, a date it was created, etc., and a payload. For a contact, the payload would be the unique identifier of the user who is being added as a contact. For every type of content within a project, a wrapper and payload exists.
According to an embodiment, a project may coexist with enterprise-level structured projects which may be projects associated with data, data sources and projects spanning organizations and entities of varying sizes and structures. An enterprise project may be a source from which information may be extracted. An enterprise project may comprise deliverables, which may be defined as PDAM application projects. An overall project system may manage these deliverables or PDAM application projects.
A PDAM application user interface (UI) 112 is a modular user interface that may display data items 103 from multiple data sources 102. For example, a PDAM application UI 112 may display data items 103 like calendar data, emails, tasks, etc. as well as any other type of data, such as word processing documents, spreadsheet documents, presentation documents, and social networking correspondences. The PDAM application UI 112 may borrow functionality of one or more applications, such as an electronic mail application, electronic calendar application, electronic task application, or an application that provides combined resources of these applications for displaying and interacting with calendar, task and email items. The PDAM application UI 112 may also extend functionalities of other applications so that it may display other relevant project information.
Within a PDAM application UI 112, a notification system may be provided. According to an embodiment, when a data collector 104 retrieves a data item 103 from a data source 102, a user may be notified through the PDAM application UI 112 that new information is available, so that the user may then act on it. For example, a person in a project may upload a new document relative to the project. Other members in the project may need to know that a new document has been uploaded. The other users may receive a notification that a new activity is available.
According to another embodiment, a user may publish new data through the PDAM application UI 112 that can be sent out to various data sources 102. For example, if a user has a project linked to various communication sources, such as email, instant messaging, and one or more social networks, for example, FACEBOOK or TWITTER, the user may push content back out to one or more of those communication sources. The user may create an email or text message or other suitable messaging form from within the PDAM application UI 112. The PDAM application UI 112 may act as an aggregator of content as well as a way to push content back out to any desired recipient user or recipient system.
Having described a system framework of a project data aggregation and management (PDAM) application 114, within which embodiments of the present invention may be incorporated,
Referring now to
Once features are extracted from a data item 103, those features may be mapped into a unit that can be sent to one or more search mechanisms to find more relevant suggestions for project content by a search provider interface 126. A search may occur locally on a local computer/memory combination, in an email inbox, within a calendar, on the Internet, within a web-based content management system, such as SHAREPOINT by MICROSOFT CORPORATION of Redmond, Wash., etc. A search mechanism 128 may be selected depending on a particular type of content. For example, if a search is for a document, a search query may be sent to a desktop search or a web-based content management system search. If a search is for an email or calendar item, a search query may be sent to an email application search. According to an embodiment, information about a user, such as information from a user's contacts list, email, task list, Internet browsing history, presence data, location, calendar items, and the like, may be used to improve search results. Search results from all search mechanisms 128 may be displayed within a single user interface 112, and presented to a user, as is shown in
With reference to
Referring now to
The method proceeds to OPERATION 315, where the data item 103 is parsed for contextual information for the data item, including data item features 105, for example, keywords, questions, answers, terms, links, clip art, authors, senders, receivers, dates, times, as well as, other content from electronic documents, electronic mail, calendar items, contacts items, tasks items, social network communications and the like that may be pertinent or contextually relevant to a given project. A feature extractor interface 124 may be utilized to extract select pieces of data. For example, if the data item 103 is a document, the feature extractor interface 124 may select key words, links within the document, clip art, author(s) of the document, etc.
The method proceeds to OPERATION 320, where the selected and extracted data item features may be mapped into a unit that can be sent to various search mechanisms via a search provider interface 126. At OPERATION 325, a federated search scheme may be utilized, wherein multiple search systems may be called on to find other relevant content as was described above with reference to
The method proceeds to OPERATION 330, where results may be displayed within a user interface 112, as illustrated in
As described above, embodiments of the invention may be implemented via local and remote computing and data storage systems, including the systems illustrated and described with reference to
With reference to
Computing device 400 may have additional features or functionality. For example, computing device 400 may also include additional data storage devices (removable and/or non-removable) such as, for example, magnetic disks, optical disks, or tape. Such additional storage is illustrated in
As stated above, a number of program modules and data files may be stored in system memory 404, including operating system 405. While executing on processing unit 402, programming modules 406 and may include the project data aggregation and management application 114 and feature extractor interface 124, wherein project data aggregation and management application 114 and feature extractor interface 124 may contain sufficient computer-executable instructions, which when executed, perform functionalities as described herein. The aforementioned process is an example, and processing unit 402 may perform other processes. Other programming modules that may be used in accordance with embodiments of the present invention may include electronic mail and contacts applications, word processing applications, spreadsheet applications, database applications, slide presentation applications, drawing or computer-aided application programs, etc.
Generally, consistent with embodiments of the invention, program modules may include routines, programs, components, data structures, and other types of structures that may perform particular tasks or that may implement particular abstract data types. Moreover, embodiments of the invention may be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, mainframe computers, and the like. Embodiments of the invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote memory storage devices.
Furthermore, embodiments of the invention may be practiced in an electrical circuit comprising discrete electronic elements, packaged or integrated electronic chips containing logic gates, a circuit utilizing a microprocessor, or on a single chip containing electronic elements or microprocessors. Embodiments of the invention may also be practiced using other technologies capable of performing logical operations such as, for example, AND, OR, and NOT, including but not limited to mechanical, optical, fluidic, and quantum technologies. In addition, embodiments of the invention may be practiced within a general purpose computer or in any other circuits or systems.
Embodiments of the invention, for example, may be implemented as a computer process (method), a computing system, or as an article of manufacture, such as a computer program product or computer readable media. The computer program product may be a computer storage media readable by a computer system and encoding a computer program of instructions for executing a computer process. Accordingly, the present invention may be embodied in hardware and/or in software (including firmware, resident software, micro-code, etc.). In other words, embodiments of the present invention may take the form of a computer program product on a computer-usable or computer-readable storage medium having computer-usable or computer-readable program code embodied in the medium for use by or in connection with an instruction execution system. A computer-usable or computer-readable medium may be any medium that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
The term computer readable media as used herein may include computer storage media. Computer storage media may include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, program modules, or other data. System memory 404, removable storage 409, and non-removable storage 410 are all computer storage media examples (i.e., memory storage.) Computer storage media may include, but is not limited to, RAM, ROM, electrically erasable read-only memory (EEPROM), flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store information and which can be accessed by computing device 400. Any such computer storage media may be part of device 400. Computing device 400 may also have input device(s) 412 such as a keyboard, a mouse, a pen, a sound input device, a touch input device, etc. Output device(s) 414 such as a display, speakers, a printer, etc. may also be included. The aforementioned devices are examples and others may be used.
The term computer readable media as used herein may also include communication media. Communication media may be embodied by computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as a carrier wave or other transport mechanism, and includes any information delivery media. The term “modulated data signal” may describe a signal that has one or more characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media may include wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, radio frequency (RF), infrared, and other wireless media.
Embodiments of the present invention, for example, are described above with reference to block diagrams and/or operational illustrations of methods, systems, and computer program products according to embodiments of the invention. The functions/acts noted in the blocks may occur out of the order as shown in any flowchart. 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/acts involved.
While certain embodiments of the invention have been described, other embodiments may exist. Furthermore, although embodiments of the present invention have been described as being associated with data stored in memory and other storage mediums, data can also be stored on or read from other types of computer-readable media, such as secondary storage devices, like hard disks, floppy disks, or a CD-ROM, a carrier wave from the Internet, or other forms of RAM or ROM. Further, the disclosed methods' stages may be modified in any manner, including by reordering stages and/or inserting or deleting stages, without departing from the invention.
All rights including copyrights in the code included herein are vested in and the property of the Applicant. The Applicant retains and reserves all rights in the code included herein, and grants permission to reproduce the material only in connection with reproduction of the granted patent and for no other purpose.
While the specification includes examples, the invention's scope is indicated by the following claims. Furthermore, while the specification has been described in language specific to structural features and/or methodological acts, the claims are not limited to the features or acts described above. Rather, the specific features and acts described above are disclosed as example for embodiments of the invention.
This application claims benefit under 35 U.S.C. §119(e) of U.S. Provisional Patent application Ser. No. 61/296,343 entitled “Aggregating and Presenting Associated Information (Huddle)” and filed on Jan. 19, 2010, the entirety of which is incorporated by reference herein.
Number | Date | Country | |
---|---|---|---|
61296343 | Jan 2010 | US |