When mobile communication devices first became available to the general public they had very limited functionality. For example, the first devices merely transmitted text or voice signals. However, as technology has advanced, such devices have followed suit. Additionally, and somewhat in parallel, the number of mobile device applications has been rapidly growing since the inception of the first personal digital assistant (PDA). For example, at first, PDAs were simply used to manage contacts, to-do collections, and calendars; however, eventually they grew to provide nearly unlimited functionality as the number of applications grew.
Today, modern mobile devices, including cell phones, resemble advanced PDAs with voice, text, and/or data transmissions, as well as numerous applications for doing just about anything one could imagine. Thus, in today's world of ever-increasing mobility, it is no surprise that there are literally hundreds of thousands of mobile device applications. For example, one mobile device application provider touts that they offer over two hundred thousand applications for a single device.
As such, mobile device users may be overwhelmed when searching for applications for their devices. For example, if a user begins a search for a document reader application, they may find over fifty results, many of which have excellent, and similar, ratings. As such, finding mobile device applications may be confusing and time consuming. Unfortunately, current systems are not equipped to help users easily track down the best applications in an easy and efficient manner.
This summary is provided to introduce simplified concepts for an application store tastemaker recommendation service, which is further described below in the Detailed Description. This summary is not intended to identify essential features of the claimed subject matter, nor is it intended for use in determining the scope of the claimed subject matter. Generally, the application store tastemaker recommendation service described herein involves using a central location to filter and rank mobile application query results based on tastemaker recommendations. As used herein, the term “tastemaker” may refer to an expert or a perceived expert with relation to an application or a genre of applications, including mobile applications. Tastemakers may, but need not necessarily, be friends, social acquaintances, or other members of a user's social network. In one aspect, the server may leverage viral marketing by helping applications gain credibility among potential purchasers through recommendations from social acquaintances and/or based on social acquaintances' usage.
In one aspect, an application store tastemaker recommendation service may receive a request for information pertaining to an application or a type of application. The service may discover available applications related to the requested application by performing a search. The service may also determine a tastemaker with respect to the available applications and collect data and/or recommendations from the tastemaker. Further, the service may filter and/or rank the search results based on the collected data, and may display the filtered and/or ranked search results upon receiving an indication that a search is complete and/or to repeat the filtering and/or ranking
The detailed description is set forth with reference to the accompanying figures. In the figures, the left-most digit(s) of a reference number identifies the figure in which the reference number first appears. The use of the same reference numbers in different figures indicates similar or identical items.
This disclosure is directed, in part, to techniques for implementing an application store tastemaker recommendation service. This disclosure is also related to providing a simple way for mobile device users to navigate overwhelmingly large mobile and non-mobile application query results. In addition, this disclosure is also related to leveraging viral marketing to help mobile applications gain credibility through usage information and/or social acquaintances' recommendations. Techniques for creating a social graph made up of a multitude of social acquaintances found within one's social networks are also disclosed. Additionally, techniques for determining experts among one's social graph and harnessing their expertise and comments are also disclosed. As such, the techniques may allow a mobile device user to determine which mobile applications are best for their needs based on reviews, comments, blog entries, likes, dislikes, and/or practices of those users within their social graph. Additionally, the techniques may provide a method for keeping track of which social acquaintances in one's social graph are tastemakers for specific mobile applications, mobile application genres, and/or mobile devices. Further, as used herein, the term social network is used to describe one's circle of social acquaintances (e.g., people whose contact information is stored within one's digital contact collection, email collection, and/or social networking website collection, etc.), and, as such, is not limited to any particular social network.
In one aspect, a social graph may be made up of interconnected nodes, with a root node (or other centralized type of node) representing a user and each other node representing a social acquaintance found within the user's social circle. In other words, social acquaintances of a user, or of a user's social acquaintances, may be represented by nodes within the user's social graph at differing distances (i.e., differing numbers of nodes away) from the user node. For example, direct social acquaintances (e.g., those within the user's circle of social acquaintances) may be represented as acquaintance nodes that share a single edge with the user node. Additionally, indirect social acquaintances (e.g., social acquaintances of social acquaintances) may be represented as nodes that share a single edge with acquaintance nodes, rather than with the user node.
In one instance, a user may wish to install new mobile applications on a mobile device. In this example, a user may wish to find a document reader that is compatible with the mobile device they use, and with the documents stored thereon. Upon searching for mobile document readers, the user may be presented with an overwhelming number of results. Additionally, however, in one example, the user may be able to sign-in to an application store or tastemaker recommendation service that can help filter the results based on data collected from those in the user's social graph. In one example, where the service collects user data, the service will provide opt-in and/or opt-out functionality. For example, in one instance, prior to any user information being collected and/or shared, the user whose information is to be collected will be notified and given the option to opt-out. Further, in one aspect, enhanced security measures will be employed in order to protect the user and/or application data.
For example, the application store may be configured to determine what mobile devices and mobile applications are being, or have been, used by the user's social acquaintances. In one example, the service may be configured to operate in a cloud. In other examples, however, the service could be hosted on a server, a server farm, or other server-type implementation instead of, or in combination with, the cloud. Throughout this disclosure, references to the “cloud” may include any or all of the above implementation examples. Additionally, the application store or tastemaker recommendation service may also be configured to receive and organize recommendation information about document reader applications from the user's social acquaintances. This recommendation information may be based on application reviews, answered polls, blog posts, whether the social acquaintance installed and/or uninstalled the same or similar applications, whether the social acquaintance is considered a tastemaker, whether the social acquaintance has social acquaintances who are considered tastemakers, combinations of the foregoing, or the like.
As such, the application store may be able to help the user choose the best document reader application by filtering and/or ranking the query results based on the recommendation information. In one example, the user may choose to filter the results by removing from the results all applications that none of his social acquaintances have installed. In another example, the user may choose to filter the results by removing all applications that any of his social acquaintances have ever uninstalled. In yet another example, the user may wish to rank the results, with or without filtering them first, based on reviews or blog posts written by social acquaintances that are considered tastemakers. By way of example only, similar to filtering out applications that the user's social acquaintances have uninstalled, the user make rank or score more negatively applications that their social acquaintances have uninstalled as opposed to applications that were never installed or never uninstalled. Additionally, in yet another example, the user may create a poll to ask his social acquaintances for help regarding the query results. Those that answer may provide valuable recommendation information that can be used for filtering and/or ranking of the results and/or results of future searches by the same or different users. In addition, those who answer may increase their own tastemaker status within the system. Further, while several examples of filtering and/or ranking query results based on recommendations are described above, any number of combinations of the foregoing examples or combinations of any of the afore-mentioned types of recommendation information may be implemented.
In one aspect, a tastemaker may be declared by the user as a social acquaintance whom the user trusts as an expert based on personal knowledge about the social acquaintance. However, tastemaker status may also be conferred automatically by the application service and may be based on quantity and/or quality of a social acquaintance's participation with the service. In other words, the more reviews, blog posts, poll answers, and the like, that the social acquaintance submits, the higher that social acquaintance's tastemaker status may be. Additionally, the more success a social acquaintance has with their recommendations, the higher that social acquaintance's tastemaker status may be as well. Further, tastemaker status may be increased or decreased with respect other users who follow the tastemaker's recommendations based on feedback from those other users. That is, a tastemaker's status may decrease with respect to a user if that user reports that the tastemaker's recommendation was poor. In one example, a tastemaker may have social acquaintances who they consider tastemakers. These second level tastemakers, as well as their tastemakers (third level tastemakers) may be accessible by the user as well. In this way, each user may be able to receive information from any nth level tastemaker; where n is an integer greater than zero, within their own and/or their social acquaintance's social graphs.
Further, the user 104 may also interact with one or more applications that represent the social networks 116 of the user 104, seen as arrow 118. As discussed above, and by way of example only, social networks 116 may include data about social acquaintances found in any combination of a user's Web-based social networking sites, email applications, contact collections, and the like. For example, a user 120 may be a social acquaintance of the user 104 and may also be a contact on Facebook® or other social networking site. Additionally, a user 122 may be a social acquaintance of the user 104 and may also be a Microsoft® Office Outlook® email contact. As such, both user 120 and user 122 may be part of the social networks 116 of user 104. In one aspect, any person whom user 104 can contact digitally, whether by the Internet, cellular network, private network connection, or the like, may be considered part of the user's 104 social networks 116. While only two users 120 and 122 are shown here in social networks 116, any number of users may exist depending on how many social acquaintances the user 104 has, or how many social acquaintances the user 122 has in social networks 116.
In one aspect, the tastemaker service 102 may interact with the social networks 116 of the user 104, seen as arrows 126 and 128. For example, arrow 126 may represent that the service 102 may actively crawl the social networks 116 of the user 104 and arrow 128 may represent that the data received in response to the crawling may be compiled to make a social graph 130. Additionally, arrow 128 may represent data being sent to the social graph 130 of service 102 as a feed (e.g., Really Simple Syndication (RSS) or other type of news feed) to which service 102 may subscribe. In other words, social graph 130 may represent the combined user information of each social acquaintance of user 104 found within the social networks 116. The data received, and stored in the social graph 130, may include information about what mobile applications the social acquaintances have installed and/or uninstalled on their own mobile devices. In one example, the social graph 130 may be stored in the cloud for each individual session of the user 104 or it may be stored in the cloud for future use, in which case it may grow and change over time as the social networks 116 of the user 104 grow and change. Additionally, the tastemaker service 102 may utilize the social graph 130 to help the user 104 filter and/or rank mobile application queries.
In addition, in one aspect, the tastemaker service 102 may crawl the social networks 116, seen as arrow 132, or the social graph 130 to determine whether a social acquaintance is a tastemaker. In other words, in response to crawls of the social networks 116, or social the graph 130, information pertaining to recommendations, answered polls, application reviews, and the like may be transmitted, seen as arrow 134, to user data storage 136. The user data storage 136 may store the user data in the cloud for the tastemaker service 102 such that it can be aggregated and reviewed to aid in the filtering and ranking of application queries of the user 104. In some examples, the social graph 130 and the user data storage 136 may communicate with one another so the data can be shared. However, in other examples, the user data may be stored in the social graph 130 alone.
By way of example only, user 122 may also operate a mobile device 138. In one aspect, the tastemaker service 102 may crawl an application store such as AppStore 112 to determine what applications have been installed and/or uninstalled on the mobile device 138. Alternatively, or additionally, the tastemaker service 102 may crawl the mobile device 138, seen as arrow 140, for applications that have been installed and/or uninstalled on the mobile device 138. The tastemaker service 102 may use this information to help the user 104 filter and/or rank the application query results. While arrow 142 shows this data being transmitted to the user data storage 136, as mentioned above, this information may also be transmitted and stored directly to the social graph 130.
Additionally, as discussed above, social networks 208 may be any type of application or service that facilitates the connection of social acquaintances. In one aspect, social networks 208 includes each social acquaintance of user 202 that may be contacted via digital means such that they can be queried for reviews, comments, recommendations, and/or answers to poll questions. As discussed above, the tastemaker system 200 may crawl AppStore 206 and/or social networks 208 for information to aid in the filtering and/or ranking of mobile application queries.
In one aspect, the tastemaker system 200 may also include an integrated AppStore 210 or it may be a function of AppStore 210. In other words, the tastemaker system 200 may be a service provided by AppStore 210. However, in this case, the tastemaker system 200 may still be able to crawl other AppStores, such as, but not limited to, AppStore 206. In one example, the AppStore 210 may store data about local or previously crawled mobile applications in app data storage 212. When a user performs an application query, the collection of available mobile applications may be determined based on the data stored in the app data storage 212, whether the data was local or found during a crawl of a remote AppStore 206. Additionally, the tastemaker system 200 may also include a social network graph service 214 for creating a social graph as described above with respect to
In one aspect, the tastemaker system 200 may include a review service 218 for receiving and storing mobile application reviews in application reviews storage 220. By way of example only, the review service 218 may be configured to receive reviews from social acquaintances of user 202, tastemakers known throughout the system, and/or social acquaintances of social acquaintances. Additionally, in some examples, the review service 218 may provide a platform for social acquaintances, or other tastemakers, to write reviews, a platform for user 202 to request a review of an application from a social acquaintance or other known tastemaker, or a platform for others to provide reviews of a tastemaker's previous recommendation. In this way, a tastemaker's status may be challenged, or decreased, based on reviewers commenting that the advice was poor. Alternatively, a tastemaker's status may be increased by good reviews of the recommendation (i.e., explicit feedback) or by a notification that others followed the recommendation and installed, or didn't uninstall, the recommended application (i.e., implicit feedback).
Additionally, the tastemaker system 200 may include a polling service 222 for storing poll questions and their results in poll data storage 224. By way of example only, and similar to the review service 218, the polling service 222 may be configured to receive answered polls from social acquaintances of user 202, tastemakers known throughout the system, and/or social acquaintances of social acquaintances. Additionally, the polling service 222 may be configured to provide a platform for user 202 to write poll questions for answering questions about a mobile application being researched. In this way, if the user 202 is interested in having a specific question answered, they may draft a poll via the polling service 222. The polling service 222 may provide this poll to all the user's 202 social acquaintances, to only specific social acquaintances, to only tastemakers, any combination of the foregoing, or the like. Additionally, the poll may be presented to the public and the responses may be weighted based on the tastemaker status of the responders. In one aspect, the polling service 222 may provide an answered poll for public access. In other words, the poll may be searched by the search service 204, or any public search engine. As such, other users may be able to read the poll even if they are not accessing the tastemaker system 200.
The tastemaker system 200 may also include a tastemaker index 226 for storing information about which social acquaintances, or social acquaintances of social acquaintances, are tastemakers. The tastemaker index 226 may store the information in user data storage 228. This information may be used, along with the application reviews 220 and poll data 224, to help the user 202 filter and rank their application query results. As discussed above, however, the user data 228 may also include the application reviews 220 and the poll data 224. That is, the application reviews 220 and the poll data 224 may in fact be user data 228. Thus, the data may be managed by the different services 218 and 222, but with pointers from the user data storage 228, or it may be managed in one central location, such as user data storage 228.
Further, the tastemaker system 200 may also include an index 230 for storing the results of crawling the AppStore 206. This index may be particularly useful when the tastemaker system 200 does not include AppStore 210. That is, the index 230 may be used to index the mobile applications that are discovered during a crawl of a remote AppStore 210 such that the tastemaker system 200 does not have to host the applications themselves. In this way, the tastemaker system 200 may be able to keep track of available mobile applications that reside on other systems or, in particular, in other AppStores. In addition, the index 230 may be able to differentiate between mobile applications that are compatible with different mobile devices and/or different operating systems. For example, the index 230 may be able to store information about a single document reader that runs on multiple different operating systems. In this way, the tastemaker system 200 may be able to filter the application query results for the user 202 based on a type of mobile device and/or operating system. Similarly, the review service 218 and the polling service 222 may be capable of sorting their reviews and polls in the same way.
In this particular implementation, the process 300 may begin at block 302 of
In one aspect, the process 300 may determine social acquaintances of a user at block 306. This determination may include searching a user's social networks, searching an already created social graph of the user, or both. As discussed above, these social acquaintances may be anyone of which the user has digital contact information. At block 308, the process 300 may query an application store or one or more devices of a person determined to be a social acquaintance of the user for one or more applications that have been installed and/or uninstalled on that person's device. In other words, the process 300 may query an application store account of or a device of a user's social acquaintance to determine what mobile applications the social acquaintance has installed and/or uninstalled on their device. In one example, this information may be used to determine a recommendation for mobile applications and/or for filtering and/or ranking a mobile application collection. At block 310, the process 300 may filter the collection of available mobile applications that was determined at block 304. However, in other examples, the process 300 may filter a different collection. Additionally, as discussed above, the filtering may be based on the query performed at block 308, such that a user may choose to only view applications from the collection that have been installed by their social acquaintances.
The process 300 may determine tastemakers from the collection of social acquaintances at block 312. In one aspect, tastemakers may be determined based on what applications they (the user's social acquaintances) have installed, uninstalled, written reviews about, answered polls about, etc. At block 314, the process 300 may collect the reviews, poll answers, etc., from the tastemakers. The process 300 may proceed to rank the filtered collection at block 316. Similar to filtering the collection at block 310, and by way of example only, the collection of available mobile applications may be ranked based on the information acquired regarding reviews, polls, blog entries, likes and dislikes of others, etc. In one aspect, ranking the collection at block 316 includes changing the order of the collection without removing entries in the collection. On the other hand, filtering the collection at block 310 may include removing entries from the collection. However, in another aspect, filtering may include re-ordering the collection without removing entries, and ranking may include removing entries.
At block 318, the process 300 may display the ranked and/or filtered collection to the user to aid in making a decision. At decision block 320, the process 300 may determine whether the search is complete. In one aspect, this determination may be based on querying the user about whether they are finished searching. In another aspect, this determination may be made based on the user indicating, without first being queried, that the search is complete. In yet another aspect, the process 300 may determine implicitly that the search is complete based on the user logging-out of the AppStore, or otherwise terminating their on-line session, or based on the size of the remaining collection. For example, if the query results have been filtered to where there is only one result remaining, the process 300 may imply that the search is complete. Additionally, the user may select a query results size of a number of entries, and the process may determine that the search is complete when the results collection reaches the selected size. If the process 300 determines, at decision block 320, that the search is not complete, the process may return to block 310 for further filtering, ranking, polling, reviewing, and/or tastemaker discovering. On the other hand, if the search is complete at decision block 318, the process 300 may terminate by providing the ability to purchase a selected mobile application at block 322.
The process 314 may further determine, at decision block 410, whether a mobile application review has been received. Alternatively, if no poll was requested at decision block 400, the process may proceed directly to decision block 410 without processing the poll at all. If the process 314 determines at decision block 410 that a review was received, the process 314 may store the review data at block 412 and then search for tastemakers among social acquaintances, and/or social acquaintances of social acquaintances at block 414. On the other hand, if no review was received at decision block 410, the process 314 may proceed directly to block 414. Searching for tastemakers among a user's social acquaintances, and/or social acquaintances of social acquaintances, may include searching the user's social graph for answered polls, written reviews, and followed recommendations. In one aspect, searching for tastemakers may also, or alternatively, include processing feedback information about whether other users followed or agreed with the tastemakers.
At decision block 416, the process 314 may determine if every tastemaker within a user's social graph, or social networks, has been discovered. If not, the process 314 may continue to search for more tastemakers at block 414. Alternatively, however, if the process determines that every tastemaker has been discovered, or if the user indicates that enough tastemakers have been found, the process 314 may then proceed to block 316 in
In one illustrative configuration, the computing environment 500 comprises at least a memory 502 and one or more processing units (or processor(s)) 504. The processor(s) 504 may be implemented as appropriate in hardware, software, firmware, or combinations thereof. Software or firmware implementations of the processor(s) 504 may include computer-executable or machine-executable instructions written in any suitable programming language to perform the various functions described.
Memory 502 may store program instructions that are loadable and executable on the processor(s) 504, as well as data generated during the execution of these programs. Depending on the configuration and type of computing device, memory 502 may be volatile (such as random access memory (RAM)) and/or non-volatile (such as read-only memory (ROM), flash memory, etc.). The computing device or server may also include additional removable storage 506 and/or non-removable storage 508 including, but not limited to, magnetic storage, optical disks, and/or tape storage. The disk drives and their associated computer-readable media may provide non-volatile storage of computer readable instructions, data structures, program modules, and other data for the computing devices. In some implementations, the memory 502 may include multiple different types of memory, such as static random access memory (SRAM), dynamic random access memory (DRAM), or ROM.
Memory 502, removable storage 506, and non-removable storage 508 are all examples of computer-readable storage media. Computer-readable storage media includes, but is not limited to, volatile and non-volatile, 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. Memory 502, removable storage 506, and non-removable storage 508 are all examples of computer storage media. Additional types of computer storage media that may be present include, but are not limited to, phase change memory (PRAM), SRAM, DRAM, other types of RAM, ROM, electrically erasable programmable read-only memory (EEPROM), flash memory or other memory technology, compact disc read-only memory (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 the desired information and which can be accessed by the server or other computing device. Combinations of any of the above may also be included within the scope of computer-readable storage media.
The computing environment 500 may also contain communications connection(s) 510 that allow the computing environment 500 to communicate with a stored database, another computing device or server, user terminals, and/or other devices on a network. The computing environment 500 may also include input device(s) 512 such as a keyboard, mouse, pen, voice input device, touch input device, etc., and output device(s) 514, such as a display, speakers, printer, etc.
Turning to the contents of the memory 502 in more detail, the memory 502 may include an operating system 516 and one or more application programs or services for implementing an application store tastemaker recommendation service including an AppStore crawling module 518. The AppStore crawling module may be configured to crawl one or more AppStores, whether local or remote, for available mobile applications that may purchased and/or downloaded. In one aspect the crawling may be in response to a user's query. Additionally, in one aspect, the results of this crawling may be further manipulated by other modules stored in the memory 502. Further, the AppStore crawling module 518 may also be configured to crawl one or more AppStores for information pertaining to which applications have been installed and/or uninstalled on which devices.
The memory 502 may further include an application index module 520. The application index module 520 may be configured to store results from the AppStore crawling module 518. In this way, a local collection of available mobile applications may be maintained in the memory 502 without requiring the computing environment 500 to host all of the available applications.
Additionally, the memory 502 may also include a social network graphing module 522 for crawling a user's social networks and creating a social graph. As discussed above, the social graph may contain information about the social acquaintances of the user including, but not limited to, what types of applications they have installed and/or uninstalled on their own mobile devices.
The memory 502 may further include a tastemaker module 524. The tastemaker module 524 may be configured to determine which social acquaintances of the user, or social acquaintances of the user's social acquaintances, are tastemakers. In addition, the tastemaker module 524 may be configured to rank tastemakers, maintain tastemaker status information, and review information about the tastemakers provided by others.
In addition, the memory 502 may also include an application filtering/ranking module 526. The application filtering/ranking module 526 may be configured to filter and/or rank a user's query results based on information gathered by other modules stored in the memory 502. By way of example only, the application filtering/ranking module 526 may provide a user interface (UI) to the user for implementing the ranking and/or filtering.
The memory 502 may further include a polling service module 528 and a review service module 530. As discussed in detail above, these two modules may be configured for providing and/or receiving polls and/or reviews related to mobile applications. In some aspects, the polls and/or reviews may be related to available mobile application found in a user's query results after crawling AppStores. However, in other aspects, the polls and/or reviews may be related to any available application, in which case, the computing environment 500 may store the reviews and/or polls in the memory 502 for later use.
Additionally, the memory 502 may include an application purchasing module 532 configured to provide a user with the ability to purchase one or more of the mobile applications being researched. In one aspect, the user may purchase mobile applications that are being sold by a local AppStore stored in the memory 502. However, in other aspects, the application purchasing module 532 may be configured to allow a user to purchase mobile applications from a remote AppStore.
Further, the memory 502 may also include a social acquaintance crawling module 534. In one aspect, the social acquaintance crawling module 534 may be configured to crawl the AppStores that a user's social acquaintances are associated with to determine what applications the social acquaintance has installed and/or uninstalled in the past. In another aspect, the social acquaintance crawling module 534 may be configured to crawl a social acquaintance's public comments, reviews, and/or blog posts. Still, in other aspects, the social acquaintance crawling module 534 may configured to crawl a social acquaintance's device to determine what applications the social acquaintance has installed and/or uninstalled on the device in the past. As discussed above, this information may be used to aid in filtering and/or ranking of a user's query results.
The memory 502 may also include a search engine module 536 for receiving queries pertaining to mobile or other applications. In one example, the application store crawling module 518 may crawl application stores based at least in part on the query. In some instances, the query may be received from a user.
Illustrative methods and systems of an application store tastemaker recommendation system are described above. Some or all of these systems and methods may, but need not, be implemented at least partially by an architecture such as that shown in
Although embodiments have been described in language specific to structural features and/or methodological acts, it is to be understood that the disclosure is not necessarily limited to the specific features or acts described. Rather, the specific features and acts are disclosed as illustrative forms of implementing the embodiments.