Computing devices have long utilized a hierarchical file system in which applications, files and other content are stored in one or more folders which can, in turn, be stored in other folders. While such a file system can provide users with the ability to store a large quantity of data in an organized manner, it can also render it difficult for users to find specific content quickly. Additionally, such a file system can be difficult to navigate using modern portable computing devices that may comprise displays of limited size, so as to enhance their portability.
Instead, modern portable computing devices often implement a simplified user interface that presents a wide variety of content, such as different application programs, at a single level, such as through multiple “screens” that a user can navigate to utilizing touch gestures or other like user input appropriate for a portable computing context. While such a simplified user interface can be utilized efficiently, especially in a portable computing context, when a user has installed a limited number of application programs and other content, users having a large number of application programs and content can find such a simplified user interface challenging. In particular, it can require additional effort on the part of the user to identify and locate a particular application program, or content. Users often have to resort to utilizing search functionality to identify and locate application programs and content that is sought, or, alternatively, users have to resort to flipping back and forth between multiple screens of information to identify and locate the application program and content that they seek.
In one embodiment, a correlation can be established between a current user context and content that the user will likely subsequently access. Such content can then be proactively presented to the user, thereby enabling the user to efficiently access such content.
In another embodiment, the correlation between the current user context and the content that the user will likely subsequently access can be established based on historical data collected from the same user, including content accessed by the user, the order in which it was accessed, the user's location when accessing such content, the time and day when such accessing took place, other content available or installed on the user's computing device, and other like user context data.
In a further embodiment, a correlation between a current user context and the content that will likely subsequently be accessed can be based on historical data collected from a myriad of users. Such a correlation can reflect what an average user will likely subsequently access given a current user context. The content that an average user will likely subsequently access can be proactively presented, either in addition to, or in place of, the content that the specific user to whom the presentation is made will likely subsequently access.
In a still further embodiment, a user interface can provide a defined area within which content can be proactively presented to a user. Such a defined area can include the ability to proactively present content with differing importance, and can include the ability to proactively present content while the user is utilizing other application programs.
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 to be used to limit the scope of the claimed subject matter.
Additional features and advantages will be made apparent from the following detailed description that proceeds with reference to the accompanying drawings.
The following detailed description may be best understood when taken in conjunction with the accompanying drawings, of which:
The following description relates to the proactive presentation of content, including application programs and other content, to a user. Such proactive presentation enables a user to more efficiently access such content, saves the user from having to search for such content and can remind the user of forgotten content or introduce the user to new content, such as new application programs that can provide greater benefits than application programs currently being utilized by the user. A user context can be correlated to content that is likely to be subsequently accessed. One such a correlation can be specific to a given user, while another such correlation can be general to a collection, or class, of users. Correlations between a current user context and content subsequently accessed can be based on historical data and can be defined in terms of mathematical functions or semantic relationships. Such correlations can then be utilized to identify content that is likely to be subsequently accessed, and such content can be proactively presented to a user. A user interface can provide a defined area within which proactive presentations of content can be made, including while the user is utilizing other application programs.
For purposes of illustration, the mechanisms described herein make reference to specific exemplary uses of a proactive content presentation mechanism. In particular, mechanisms described herein focus upon the proactive presentation of application programs within the context of a user interface presented by a mobile computing device. The mechanisms described, however, are not limited to the proactive presentation of application programs. For example, the mechanisms described are equally applicable to the proactive presentation of online content such as webpages, including both static and dynamic webpages, and other like content. Similarly, the mechanisms described are equally utilizable by other types of computing devices. Consequently, references to specific types of content and specific types of computing devices are meant to be exemplary only and are not meant to limit the scope of the teachings provided herein.
Although not required, the description below will be in the general context of computer-executable instructions, such as program modules, being executed by a computing device. More specifically, the description will reference acts and symbolic representations of operations that are performed by one or more computing devices or peripherals, unless indicated otherwise. As such, it will be understood that such acts and operations, which are at times referred to as being computer-executed, include the manipulation by a processing unit of electrical signals representing data in a structured form. This manipulation transforms the data or maintains it at locations in memory, which reconfigures or otherwise alters the operation of the computing device or peripherals in a manner well understood by those skilled in the art. The data structures where data is maintained are physical locations that have particular properties defined by the format of the data.
Generally, program modules include routines, programs, objects, components, data structures, and the like that perform particular tasks or implement particular abstract data types. Moreover, those skilled in the art will appreciate that the computing devices need not be limited to conventional personal computers, and include other computing configurations, including hand-held devices, multi-processor systems, microprocessor based or programmable consumer electronics, network PCs, minicomputers, mainframe computers, and the like. Similarly, the computing devices need not be limited to stand-alone computing devices, as the mechanisms 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.
Turning to
In one embodiment, the computer-executable instructions executing on the client computing device 140 can collect information that can define a current user context. For example, as illustrated in the exemplary system 100 of
Information from the interaction log 150 can, in one embodiment, be continuously provided to a recommendation computing device 110, as illustrated by the communication 151. The recommendation computing device 110 can then utilize such information to make recommendations 182. More specifically, the recommendation computing device 110 can determine, based upon a current user context, as obtained from the interaction log 150, what content the user is likely to access next. Such content can then be proactively presented to the user, thereby saving the user the effort of having to identify and locate such content themselves. For example, the user of the client computing device 130 can commute to their place of employment via train, and, while standing on the platform waiting for the train, the user can utilize the client computing device 130 to first check their email, and then subsequently listen to music. In such an example, data from the interaction log 150 can be utilized to identify a correlation between the user's geographic location 141 and the user's actions 131. Subsequently, when the recommendation computing device 110 learns that the current user context of the user of the client computing device 130 is that the user is standing on the train platform and is accessing their email, the recommendation computing device 110 can provide a recommendation 182, identifying the music application program, since the recommendation computing device 110 can determine that the music application program is likely to be the next content accessed by the user. The user of the client computing device 130, in such an example, can, upon completing perusing their email, find the music application program prominently displayed on a user interface of the client computing device 130. The user will then be able to select the music application program in a more efficient manner. By prominently and proactively displaying the music application program, in the above example, the above-described mechanisms can aid the user, since the user no longer needs to manually search for such an application program. In addition, users can often become distracted by their surroundings and then require additional time to recall what activity they sought to perform next, especially when the relevant content, such as the music application program, is not currently being displayed to the user in the particular user interface being displayed by the client computing device. In further embodiments, described in detail below, users can be prominently and proactively presented with application programs that can be more useful to the user than existing application programs that the user currently has installed on the client computing device, thereby deriving further benefits.
One exemplary user interface for proactively providing content to a user, such as via the client computing device 130, is illustrated in the exemplary system 100 of
The determination, by the recommendation computing device 110, of which one or more application programs, or other content, the user of the client computing device 130 is likely to access next can be based on models 181 that can be provided by a modeling computing device 120, which can either be distinct from the recommendation computing device 110 or can be co-located there with, including being part of the single executing process that can perform the functionality of both the recommendation computing device 110 and the modeling computing device 120. The modeling computing device 120 can, in one embodiment, generate one or more models 181, correlating a current user context to content that the user is likely to subsequently access, based upon the user data 111 that can be collected, such as by the recommendation computing device 110, from the specific user to whom the recommendations 182 are being made. Thus, the recommendations made based upon such a model can be specific to a particular user. In another embodiment, the modeling computing device 120 can generate one or more models 181, correlating a current user context to content that the user is likely to subsequently access, based upon external user data 121 that can be collected from other users. In such another embodiment, the models based upon the external user data 121 can reflect, given a current user context, the content that an average user is likely to access next.
Turning to
In one embodiment, one aspect of the current user context that can be considered in determining which content a user is likely to subsequently access, can be user input indicative of a desire or intention of the user. For example, a user searching for airline or hotel information may likely subsequently access their calendar in order to enter information regarding airline tickets or hotel reservations that the user may have made. As another example, a user searching for a particular band, or other like performing artist, may likely subsequently access a music application in order to listen to such a band. Such user input evidencing explicit user intent can be quantified and included as part of a context vector, such as the context vector 250.
The context vector 250 can be provided to a user-specific predictor 210 which can generate output 230 identifying one or more elements of content, such as one or more applications, that the user is likely to subsequently access, together with an identification of the probability, for each identified element of content, that the user will subsequently access such content. In one embodiment, as illustrated by the exemplary system 200 of
The user-specific predictor 210 can be generated through any one of a number of statistical methodologies for defining such relationships. For example, the user-specific predictor 210 can be generated using known techniques such as Hidden Markov Models (HMMs). As another example, user-specific predictor 210 can be generated utilizing mechanisms based upon the frequency of defined occurrences. In yet another example, logistic regression models can be utilized to generate the user-specific predictor 210. In such an example, the user-specific predictor 210 can be trained utilizing stochastic gradient descent mechanisms.
Once the user-specific predictor 210 generates the output 230, a selector 260 can select one or more of the content identified in the output 230 to be presented as one of the presented recommendations 270 to the user of the computing device. For example, in one embodiment, the selector 260 can simply select the top three applications, or other content, from among the output 230, having the highest probability of being selected next by the user. In another embodiment, the selector 260 can apply a threshold such that no applications, or other content, is selected for presentation to the user if the probability of such content being selected next by the user is below the applied threshold.
Once the recommendations 270 are presented to the user, the user will have an opportunity to select one of those recommendations and such a user selection 271 can then become part of the user data 111 providing further training for the user-specific predictor 210. For example, if an application is among the recommendations 270 presented to the user, and the user selects such an application, such a user selection 271 can generate new user data 111 that can more closely associate that application with the context which was used to predict that this application will be launched next. By contrast, if the user did not select such an application, the user selection 271 that the user did make can generate new user data 111 that can less closely associate the recommended application with the preceding context, and can, instead, more closely associate the application the user did end up selecting with the context from which such an application was selected.
In one embodiment, in addition to utilizing a user-specific predictor 210 that is trained based upon the historical data collected from a specific user, a general predictor 220 can also be utilized to generate output 240 that can represent, colloquially, the content that an average user would select given equivalent context to that of the specific user to whom the recommendations 270 are being presented. The general predictor 220 can be trained in a manner analogous to that utilized to train the user-specific predictor 210, except that the general predictor 220 can be trained utilizing external user data 121, which can be analogous to the user data 111, except the external user data 121 can be collected from one or more users other than the user of the computing device to whom the recommendations 270 are being presented.
If a general predictor 220 is utilized, the selector 260 can, in one embodiment, select some, or all, of the content identified by the output 230 of the user-specific predictor 210 and some, or all, of the content identified by the output 240 of the general predictor 220 to form the set of recommendations 270 that can be presented to the user. For example, the selector 260 can form the recommendations 270 that are presented to the user by selecting the three most likely applications, from among the output 230, and the two most likely applications, from among the output 240. As another example, the selector 260 can select from among the output 230 and the output 240 based upon explicitly stated user preferences. For example, the user may specify that they only desire one application from among the output 240 of the general predictor 220, in which case the selector 260 can honor such an explicitly stated user preference. In one embodiment, the selector 260 can identify duplicates from among the output 230 and 240 and can ensure that such duplication is not included in the recommendations 270 that are presented to the user.
Turning to
A correlation between applications can thus be recognized from the edges that are found to exist, which can, themselves, be based upon historical data. More specifically, an edge can indicate the existence of at least one transition between a first node from which the edge starts and a second node where the edge ends, such as, for example, a transition, by a user, from using one application program to next using another, different application program. The weighting applied to the edges can then be based on a quantity of such transitions, which can again be derived from historical data. For example, and with reference to the exemplary system 300 of
Utilizing such a semantical relationship, a correlation can be established from which an application that will be subsequently accessed by the user can be predicted given a current user context, which can, as explained above, include an application that the user is currently utilizing. For example, and with reference to exemplary system 300 of
Turning to
In another embodiment, such as that illustrated by the exemplary user interface 430, visual cues can be provided to the user as to the importance, or weight, assigned to particular content. Such visual cues can be in the form of colors, fonts, highlighting, special effects, or other like visual cues. In the specific example shown in the exemplary user interface 430 of
In yet another embodiment, such as that illustrated by the exemplary user interface 450, content that it is anticipated the user will subsequently access can be presented within a defined area 460 even within the context 451 of an application program that the user is currently utilizing. For example, to avoid distracting the user while utilizing of the application program presenting the application program context 451, the defined area 460 can be presented only in response to specific user action, or inaction. A user could trigger the presentation of the defined area 460, and the recommendations contained therein, by, for example, performing a swipe touch gesture. As another example, the defined area 460 can be presented in response to a period of user interaction, which can be deemed to signify that the user has ceased interacting with the application program presenting the application program context 451.
The sequence of user interfaces 470, 480 and 490 illustrates one exemplary mechanism by which a defined area, such as the defined areas described in detail above, can be utilized to present suggested content to a user reflecting what the system anticipates the user will next desire to access. In particular, the user interface 470 can include application program icons 471 and 472 that can represent applications that it is deemed the user will subsequently access. The user can then access, in the particular example illustrated in
In one embodiment, although not specifically illustrated by the exemplary user interfaces of
Turning to
If only user-specific suggestions are to be provided, such as can be determined at step 550, processing can proceed to step 590 and the content identified at step 540 can be presented to the user, such as in the manner described in detail above. The relevant processing can then end step 599. Conversely, if, at step 550, it is determined that suggestions based on average users are also to be provided to the user, such as due to an explicit user option indicating that the user desires to receive such suggestions, processing can proceed to step 560 at which point the context vector generated at step 520 can be provided to a general predictor, such as that described in detail above. The general predictor can, like the user-specific predictor, output one or more content and an indication of the probability, for each such content identified, that the user will next select such content given the context received at step 510. One or more of the content output by the general predictor, at step 560, can be selected at step 570 for presentation to the user. As indicated previously, such as selection can be based on quantity, defined thresholds, and other like selection criteria. At step 580, the content selected at step 540 can be amalgamated with the content selected at step 570 for presentation to the user. Such an amalgamation can include the removal of any duplicates, and an appropriate ordering, such as, for example, presenting all of the content selected at step 540 independently of the content selected at step 570, or, alternatively, interleaving the content selected at step 540 and the content selected at step 570 according to one or more criteria, such as the determined probability that the user will next select such content. Such an amalgamation can then be presented to the user at step 590. The relevant processing can then end at step 599.
In one embodiment, not specifically illustrated by the flow diagram 500 of
Turning to
The computing device 600 also typically includes computer readable media, which can include any available media that can be accessed by computing device 600 and includes both volatile and nonvolatile media and removable and non-removable media. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. Computer storage media includes media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by the computing device 600. Computer storage media, however, does not include communication media. Communication media typically embodies 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. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of the any of the above should also be included within the scope of computer readable media.
The system memory 630 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 631 and the aforementioned RAM 632. A basic input/output system 633 (BIOS), containing the basic routines that help to transfer information between elements within computing device 600, such as during start-up, is typically stored in ROM 631. RAM 632 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 620. By way of example, and not limitation,
The computing device 600 may also include other removable/non-removable, volatile/nonvolatile computer storage media. By way of example only,
The drives and their associated computer storage media discussed above and illustrated in
The computing device 600 can operate in a networked environment using logical connections to one or more remote computers. The computing device 600 is illustrated as being connected to a general network connection 661 through a network interface or adapter 660 which is, in turn, connected to the system bus 621. In a networked environment, program modules depicted relative to the computing device 600, or portions or peripherals thereof, may be stored in the memory of one or more other computing devices that are communicatively coupled to the computing device 600 through the general network connection 661. It will be appreciated that the network connections shown are exemplary and other means of establishing a communications link between computing devices may be used.
As can be seen from the above description, mechanisms for proactively providing content, such as applications, to users in order to save the users the effort of searching for it have been presented. In view of the many possible variations of the subject matter described herein, we claim as our invention all such embodiments as may come within the scope of the following claims and equivalents thereto.