This invention relates generally to data processing. More particularly, the invention relates to techniques for viewing data classified and organized in accordance with user criteria.
The ability for users to efficiently access data is important in many aspects of business, education, entertainment and other types of computer applications. As the volume and type of data increases, providing users with tools to access, analyze and manage data becomes increasingly important.
Existing approaches to analyze and organize data in a system typically involve the use of visualization tools such as reports and dashboards. Reports and dashboards enable users to interact with various entities in a system, such as objects and records in a database and provide users with a visual analysis of data results. However, users requiring multiple visual data representations of the data results typically need to interact with multiple user interfaces in order to analyze and view their data results.
It would be desirable to develop a technique to efficiently classify and organize the visual representation of information in a system. It would also be desirable to develop a technique by which users can efficiently interact with this information in accordance with each user's requirements.
The invention includes a computer readable storage medium with executable instructions to associate different entities with different entity classes. Each entity class has an associated set of lenses. Each lens includes metadata characterizing data presentation directives. User criteria is analyzed to deliver a subset of lenses to a user. Each lens includes executable instructions to display to a user a subset of information from a data source in accordance with the data presentation directives.
The invention is more fully appreciated in connection with the following detailed description taken in conjunction with the accompanying drawings, in which:
Like reference numerals refer to corresponding parts throughout the several views of the drawings.
A memory 104 is connected to the bus 106. The memory 104 includes executable instructions to support operations associated with embodiments of the present invention. In one embodiment, the memory 104 includes a Lens Creation Module 108, an Entity Request Module 110, a User Profile Module 112, a Lens Relevancy Module 113, a Data Access Module 114, a Dashboard Layout Module 116 and a Search/Indexing Module 118.
The Lens Creation Module 108 includes executable instructions to define one or more lenses for an entity class associated with an entity. In one embodiment, a lens includes metadata characterizing data presentation directives. Each lens further includes executable instructions to display a subset of information from a data source to a user, in accordance with the data presentation directives. Data lenses may be characterized as a set of semantic rules to filter, sort, group, summarize and format data. A data lens may be implemented as a set of metadata specifying an entity or entity class for which the lens is appropriate. The metadata may include information about what entities the data lens can accept as parameters. It may also include information on how to process an entity and how to render useful information about the entity. The metadata may include security information, for example specifying who can utilize the lens.
The Entity Request Module 110 includes executable instructions to receive an entity request from a user, analyze the entity request in accordance with a set of user criteria and deliver a subset of entities, a subset of entity classes and a subset of lenses in accordance with the user criteria. The user criteria may include, but is not limited to, profile criteria, relevance criteria, access criteria and aesthetic criteria. In one embodiment, the Entity Request Module 110 is coupled to a User Profile Module 112 and a Lens Relevancy Module 113.
In a particular embodiment, the Entity Request Module 110 includes executable instructions to derive profile criteria based on user profile information stored in the User Profile Module 112 and relevance criteria based on user relevancy information stored in the Lens Relevancy Module 113. The user profile information may include, for example, previous lens selections made by a user, user identity information, user group membership information and user permissions. The relevancy information includes information about the relevancy of presenting a set of lenses to a user based on a history of the usage of a particular set of lenses by the user.
In certain embodiments, the Entity Request Module 110 further includes executable instructions to derive access criteria associated with an entity request based on user security information stored in a lens, or security information stored within an Enterprise Reporting Platform system, a Business Intelligence platform or a database. The Entity Request Module 110 may also include executable instructions to derive aesthetic criteria associated with an entity request based on aesthetic information such as value metrics associated with each lens, user lens display size preferences, trusted lens ratings, language relevance of a lens, data freshness associated with a lens, trust level of the lens creator, trust level of the data provided by the lens, optimal display size of the lens, hierarchical relationships between entity classes and so forth.
The Data Access Module 114 includes executable instructions to access data associated with an entity; the data may be stored in the data source 126. The Dashboard Layout Module 116 includes executable instructions to display a subset of information from the data source 126 to a user in accordance with data presentation directives. The Search and Indexing Module 118 includes executable instructions to search for and perform indexing operations related to entities, entity classes and lenses. In one embodiment, the Search and Indexing Module 118 may be coupled to the User Profile Module 110 to enable the access of stored user information, such as security rights, preferences and usage history.
Operationally, in one embodiment of the present invention, the computer 102 pushes data 134-A and 134-B to client devices 132-A and 132-B. The data 134-A and 134-B may include, for example, entity and lens information. The data 134-A and 134-B is processed, formatted and displayed in accordance with the entity and lens information. In one embodiment, the client devices 132-A and 132-B may include thin clients or thick clients with a corresponding division of processing between the server and the client. In one embodiment, the data 134-A may be processed, formatted and displayed in accordance with a lens 136. Alternatively, the computer 102 may also apply a lens to the data 134-B prior to displaying the data. The computer 102 also receives entity requests 130-A and 130-B from client devices 132-A and 132-B. Each entity request is then processed in accordance with a set of user criteria, as discussed above.
The modules in memory 104 are exemplary. The functions of individual modules may be combined. Alternately, the modules may be distributed across a network. It is the functions of the modules that are significant, not the particular implementation or location of any module.
For example, Profile 166 and Desk Location 170 are lenses associated with the entity class Employee 156 and include metadata that characterize profile information and desk location information about the entity “Tom Chester” 152. Salary History (Secure) 168 is a lens associated with the entity class Employee 156 that includes metadata that characterizes salary information about the entity “Tom Chester”. This information is subject to security restrictions specified by the lens.
The lenses Web Search 160, News Search 162 and Related People 164 include data presentation directives characterizing the entity class Person 154 associated with the entity “Tom Chester”. The lenses, Projects 172, Articles 174 and Position Guide 176 include data presentation directives characterizing the entity class Product Manager 158 associated with the same entity. The schema of
One or more entity definitions are received 216. In one embodiment, the entity definitions may be received in response to a user specified definition for an entity classes. In another embodiment, the entity definitions may be received from an existing repository or data source. The entity definitions are associated with the entity classes 218. Keys, attributes and other identifying information are then associated with the entities 220.
Lenses are received or defined 222. The lenses may be automatically generated for an entity class based on characteristics of the entity class. Alternately, the lenses may be specified to support general operations (e.g., search, accounting operations, etc.) The lenses are then associated with the entity classes 224. As shown in
A data schema is generated based on the entity classes and lenses 226.
The existence of previous lens selections for the user is determined 304. For example, a user may have customized the lenses and/or dashboard when searching for an entity with the same entity class as the current entity. If previous lens selections do not exist for the user (304-NO), all the lenses associated with the entity class are determined 312.
If previous lens selections exist for a user (304-YES), then it is determined if the previous lens selections for the user completely match a corresponding entity class 306. If a complete match with a corresponding entity class exists (306-YES), the previous lens selections are supplied to a dashboard 308. If a complete match with a corresponding entity class does not exist (306-NO), the previous lens selections that match the entity class for the entity are ranked with prioritization metadata associated with other lenses to determine the set of lenses to be displayed to the user 310. For example, a partial match may exist when an entity belongs to more than one entity class. The previous lens selections are then combined with all the lenses associated with the entity class 312.
The set of available lenses for the user is then determined 314. Availability may be defined at an individual or group level for each user. In one embodiment, the set of available lenses for the user is determined based on the user criteria. The entity request is analyzed in accordance with the user criteria and a set of lenses are displayed to the user 318. In one embodiment, the analysis includes assigning a weight factor to one or more user criteria associated with the entity request, determining a cumulative relevancy of displaying a particular lens to a user based on the weight factor and displaying a ranked set of lenses to the user in accordance with the cumulative relevancy determined for each lens.
In one embodiment, and as further illustrated in
The personal information lens includes personal information about the entity. The related people lens includes information about people related to the entity. The refine view lens 408 indicates other available lenses to view information about the entity. The blog post lens 410 includes information about blog posts either authored by the entity or that mention the entity. The reporting structure lens 412 includes information about the entity's reporting structure. The public web results lens 416 includes web results for the entity. The internal documents lens 418 includes information about documents in the business organization associated with the entity.
The user may further interact with the information present in a lens by activating one or more links embedded in the information provided by the lens. Further, one or more buttons 420 may be used to supply additional dashboard pages of lenses that can be viewed for the entity. Button 422 provides functionality to select other views and to customize the current view. A customized view, such as dashboard 400, may be saved as a potential previous relevant lens selection. A usage history of viewing the dashboard (without interaction to customize or save the view) can be saved by the User Profile Module 110 to provide a previous relevant lens selection for the user.
An embodiment of the present invention relates to a computer storage product with a computer-readable medium having computer code thereon for performing various computer-implemented operations. The media and computer code may be those specially designed and constructed for the purposes of the present invention, or they may be of the kind well known and available to those having skill in the computer software arts. Examples of computer-readable media include, but are not limited to: magnetic media such as hard disks, floppy disks, and magnetic tape; optical media such as CD-ROMs, DVDs and holographic devices; magneto-optical media; and hardware devices that are specially configured to store and execute program code, such as application-specific integrated circuits (“ASICs”), programmable logic devices (“PLDs”) and ROM and RAM devices. Examples of computer code include machine code, such as produced by a compiler, and files containing higher-level code that are executed by a computer using an interpreter. For example, an embodiment of the invention may be implemented using Java, C++, or other object-oriented programming language and development tools. Another embodiment of the invention may be implemented in hardwired circuitry in place of, or in combination with, machine-executable software instructions.
The foregoing description, for purposes of explanation, used specific nomenclature to provide a thorough understanding of the invention. However, it will be apparent to one skilled in the art that specific details are not required in order to practice the invention. Thus, the foregoing descriptions of specific embodiments of the invention are presented for purposes of illustration and description. They are not intended to be exhaustive or to limit the invention to the precise forms disclosed; obviously, many modifications and variations are possible in view of the above teachings. The embodiments were chosen and described in order to best explain the principles of the invention and its practical applications, they thereby enable others skilled in the art to best utilize the invention and various embodiments with various modifications as are suited to the particular use contemplated. It is intended that the following claims and their equivalents define the scope of the invention.
This application claims priority to U.S. Provisional Patent Application No. 60/979,793 filed Oct. 12, 2007, entitled “Apparatus and Method for Utilizing Data Lenses to Access Data”, the contents of which are incorporated herein.
Number | Date | Country | |
---|---|---|---|
60979793 | Oct 2007 | US |