Overview
A narrow-by facility providing system, methods, and mechanism for filtering information based on a set of properties is described below, and referred to at times as narrow-by. The information consists of a set of items that the user is interacting with, such as documents, presentations, audio and video files, and the like. The properties can be specified by the user (by, for example, putting a set of items in lists and folders), based on actions taken by users in the system (such as commenting on, or liking, or viewing an item), or they can represent a variety of other characteristics. Related properties can also be grouped together. Furthermore, the disclosed techniques provide mechanisms for automatically identifying useful properties and providing an indication of those useful properties to a user to use in narrowing results.
When any set of items is being presented, the system may automatically compute which properties are useful for narrowing it down. These useful properties are presented to the user, who can select from among them. The system also informs the user how many items will remain if any option is selected. Upon selection by the user, the result set is then narrowed down to just those items that match. This is a fast way to reduce a set of items to the ones that the user wishes to see or act upon. Narrow-by can be used to help users perform a variety of applications, including searching, browsing, and managing sets of items.
Various examples of the invention will now be described. The following description provides certain specific details for a thorough understanding and enabling description of these examples. One skilled in the relevant technology will understand, however, that the invention may be practiced without many of these details. Likewise, one skilled in the relevant technology will also understand that the invention may include many other obvious features not described in detail herein. Additionally, some well-known structures or functions may not be shown or described in detail below to avoid unnecessarily obscuring the relevant descriptions of the various examples.
The terminology used below is to be interpreted in its broadest reasonable manner, even though it is being used in conjunction with a detailed description of certain specific examples of the invention. Indeed, certain terms may be emphasized below; however, any terminology intended to be interpreted in any restricted manner will be overtly and specifically defined as such in this Detailed Description section.
In general, narrow-by is a technique for reducing a set of items, representing business information, to ones that a user wishes to see or to act upon. The described system takes an item set and, based on various properties of those items, presents properties that are useful for narrowing down the set. The system computes a number of items that will be available if any of those properties are selected. The resulting list of properties is presented to the user, who can optionally select properties to refine the set of results.
A goal of narrow-by is to reduce the full result set. A particular property is deemed to be “useful” in this context if it applies to a non-zero proper subset of the current result set—in other words, it applies to more than zero of the items but fewer than the total number of items. In some embodiments, a property may be determined to be useful if it applies to more than zero items but fewer than some predetermined threshold number or percentage of the total number of items, such as 1000 items, 10,000 items, 75% of the total number of items, 99% of the total number of items, and so on. When the user selects such a property, indicating that only items with that property should be shown, the number of items in the result set will be reduced, but not to zero.
Narrow-by is a powerful tool for viewing and managing business information. For example,
This model may be called “ANDs of ORs,” meaning that results will be shown that are in any of the chosen lists within a folder (the logical OR of list membership within a folder) but must be in one of the lists selected in every folder (the logical AND of folder membership). It is possible to use alternative models, such as “ANDs of ANDs,” meaning that an item only appears if it is in every list that the user selects. If two lists in a folder are chosen, the item will appear if it is in both of them, rather than in either of them, as is true for the “ANDs of ORs” model.
Note also in
Properties
A variety of types of properties can be used to narrow down a set of items. Properties can stand on their own or can be grouped together. For the purpose of the explanation below, the word property list refers to items that have a particular property. When properties are grouped together, the group is a property folder. For any particular result set, the system considers the property lists that correspond to properties held by one or more of those items.
These are the types of properties supported in the system:
User-Defined Properties
The system may allow users to use item lists, which can further be organized into folders 110 of lists as shown in, for example,
When items are placed in an item list, the system represents that by associating a property with each of those items. Hence, the property list of items containing that property corresponds exactly to the item list. Similarly, if item lists are grouped into item folders, the system groups the corresponding property lists into a property folder.
Item lists and item folders can be created by the user or by another user, or they can be predefined by the system. For example, a collection of case studies might be organized using a “Country” folder, containing a list of names of all the countries in the world.
Lists and folders are only one type of property that users can define. Items are also added to particular collections (i.e., “spots”) and can be associated with different authors. In general, users can attach a wide variety of metadata properties to an item, which can consist of strings (like the name of the author), numbers (like a date), colors (as in priority), status (whether an item has been modified), comments, and the like.
User-Defined Properties of Groupings
The system may allow the user to specify properties for certain groupings, which then are presented in narrow-by view. For example, in
Another kind of user-defined property is shown in
Relationships
The system may compute properties based on relationships that it knows exist between users. For example, in
Inherent Properties of the Item
Some characteristics of an item can be computed by analyzing the item. For example,
User Activities Associated with the Item
The system may allow users to act on items in a variety of ways. For example, items can be added, organized, viewed, edited, commented on, liked, shared with others, or copied into new collections. In addition, the user that performs the acts can have various relationships to the current user; the user might be the current user, or be in a group with the user, or be followed by the user, or be an influential member of the user's community, or have a high affinity to the user that the system has determined through analysis. All of these properties can be used to narrow down a particular result set.
Computed Properties
The system can use a variety of analysis techniques to compute properties of an item. For example, it might use a technique like “basket analysis,” which identifies relationships such as finding pairs of items that have been acted on by the same person. Such an analysis identifies affinities between items—it finds pairs of items that are often of interest to the same person, for example.
One way such analyses could be used in narrow-by is to compute a level of affinity between items (e.g. “high,” “medium,” and “low”). These can be presented as narrow-by options. The same approach could be applied to collections of items, to other people, and so forth.
There are many other kinds of computed properties the system might discover and present to the user: for example, how similar items are to the current item or items being displayed, whether items are different versions of the current item, or whether an item is identical to one that has been sent to the current user in email, perhaps as an attachment.
Presentation
If the user selects multiple properties within a single property folder, items will be shown that have any of those properties. In
In logic terminology, the semantics are “ANDs of ORs.” For example, if the user selects a top-level list called “A,” a list “1” in folder “B,” and lists “3” and “4” in folder “C,” an item will be shown if its properties match the expression (“A” AND “B.1” AND (“C.3” OR “C.4”)).
Once the user has selected a property, any other properties that are no longer useful are disabled. In other words, when the new result set contains zero items with that property, or when every member of the new result set has the property, it is no longer helpful for further refining the result set.
Applications
Narrow-by can be applied in a wide range of applications. In each of these applications, the items may represent a file (such as a presentation), a link to a web page, a person, a collection of items, or other entity that a user may wish to interact with.
Once the result set is narrowed down, the user can apply various operations to the results. For example, the user might view them, or download them to a computer or a device, or copy them to a different collection, or delete them, or add them to a user-defined grouping such as a list.
Implementation
The system can be implemented by using an indexing system supporting faceting, such as Lucene/SOLR. Faceting is a feature of an index that computes how many of the result values have a particular characteristic. Lucene allows facets to be manifest, meaning that they have been explicitly attached to an item and placed into the index, or computed, meaning that they are calculated during the query process.
Query the Index for Faceted Results
Post-Process Query Results
Lucene Returns:
The system can now mask particular facets, based on what it chooses to display to the user. For example, the system might decide to show a maximum of five lists in a particular folder, perhaps choosing those lists that have the largest number of items in them.
The system can also compute values that are not stored in the Lucene index. For example, if the user is following a set of spots, that information is not in the index. The system takes the set of spots that the items are in, and looks up the ones that the user has chosen to follow. These are then displayed as options for the user to select, as shown in
The results are then rendered, with the facets shown on the left-hand side, organized into folders and lists. Each list shows a checkbox next to it that the user can select.
Respond to User Selection of Checkboxes
When the user clicks on a checkbox, it can be one of the following:
Top Level List, as the Only Selection
A “top-level” list represents a stand-alone property that has not been grouped. By selecting it, the user is requesting that only items with this property to be displayed.
The system resubmits the query to Lucene, specifying that this property be present. If the property corresponds to a field facet, the system changes the facet request into a filter. Lucene will only return items that match. If the property corresponds to a query facet, the system creates a custom filter that first computes the value (as above) and then filters out items that do not match.
The counts on all the properties are updated to match the facet values returned from the new query. If a property is no longer useful (i.e., the new result list has zero items with the property or all the items in the new result list have the property) it is disabled for selection.
A Top-Level List, after Something Else was Already Selected Previously
Take the query that was submitted last, and extend it with an AND clause. For example, suppose that a top-level list “A” was selected earlier and now top-level list “B” is being selected. The new query would add the filter (“A” AND “B”), matching only items that have both of those properties.
First List in a Folder
Extend the existing filter, if there is one, with the selected property. Then, resubmit the query once for each other list in the folder, specifying each as a filter. Track the size of the result set. When displaying the other checkboxes, show the delta for each.
To use a simplified example for explanation, suppose a folder “A” contains four lists, “1,” “2,” “3,” and “4,” and that such grouped properties are represented in Lucene as “<Folder>.<List>.” If the user selects list “1,” create four queries. Execute the first one, which contains the filter specifying that Lucene should only return items that contain property “A.1.” Suppose there are 10 results from that query.
Next, execute a query for items that contain (“A.1” OR “A.2”). Suppose that there are 12 items. Next to item 2, display “+2” so the user knows that clicking on the additional list will add two items. Similarly, execute queries for (“A.1” OR “A.3”) and (“A.1” OR “A.4”).
Another List in a Folder, after One has Already been Selected
As above, execute a query that specifies each of the selected lists with an OR clause. And resubmit the query for every unchecked list to compute the counts.
For example, suppose there is a top-level list “B” and a folder “C” that contains lists “1,” “2,” and “3.” The user already selected the top-level list and list “1.” Now, list “2” is also selected. The initial query to submit is (“B” AND (“C.1” OR “C.2”)). This represents items that are in list B and in list 1 or list 2 of folder C. Suppose there are five results. Then submit (“B” AND (“C.1” OR “C.2” OR “C.3”)), and suppose there are eight results. The system would then display the five results from the first query and would place a “+3” next to list “3.”
Enhancements
The system can be enhanced by automatically suggesting which lists or properties the user might find most effective to use narrow-by. This could be based on analyzing the history of the user's prior activity, knowing, for example the users or collections whose content is most likely to be of interest. The system could sort those “suggested” properties to appear earlier, or it could color code them so that they are more visually prominent.
The system can handle large numbers of properties by presenting a search box 810 to the user, rather than listing them explicitly. For example, see
Another feature is that if a user selects an item, the properties the item has can be denoted visually (by, for example, turning them blue and making them bold). This allows the user to quickly identify items similar to the one of interest, by selecting particular properties that the one of interest has. The result set will narrow down to the others that share that property.
The user can request that all properties be shown, even if they are not useful. This allows the set of properties to be edited, and the item to be dragged on top of properties that it does not have in order to associate the item with the properties.
The following discussion provides a brief, general description of a suitable computing environment in which the invention can be implemented. Although not required, aspects of the invention are described in the general context of computer-executable instructions, such as routines executed by a general-purpose data processing device, e.g., a server computer, wireless device or personal computer. Those skilled in the relevant art will appreciate that aspects of the invention can be practiced with other communications, data processing, or computer system configurations, including: Internet appliances, hand-held devices (including personal digital assistants (PDAs)), wearable computers, all manner of cellular or mobile phones (including Voice over IP (VoIP) phones), dumb terminals, media players, gaming devices, multi-processor systems, microprocessor-based or programmable consumer electronics, set-top boxes, network PCs, mini-computers, mainframe computers, and the like. Indeed, the terms “computer,” “server,” “host,” “host system,” and the like are generally used interchangeably herein, and refer to any of the above devices and systems, as well as any data processor.
Aspects of the invention can be embodied in a special purpose computer or data processor that is specifically programmed, configured, or constructed to perform one or more of the computer-executable instructions explained in detail herein. While aspects of the invention, such as certain functions, are described as being performed exclusively on a single device, the invention can also be practiced in distributed environments where functions or modules are shared among disparate processing devices, which are linked through a communications network, such as a Local Area Network (LAN), Wide Area Network (WAN), or the Internet. In a distributed computing environment, program modules may be located in both local and remote memory storage devices.
Aspects of the invention may be stored or distributed on tangible computer-readable media, including magnetically or optically readable computer discs, hard-wired or preprogrammed chips (e.g., EEPROM semiconductor chips), nanotechnology memory, biological memory, or other data storage media. Alternatively, computer implemented instructions, data structures, screen displays, and other data under aspects of the invention may be distributed over the Internet or over other networks (including wireless networks), on a propagated signal on a propagation medium (e.g., an electromagnetic wave, a sound wave, etc.) over a period of time, or they may be provided on any analog or digital network (packet switched, circuit switched, or other scheme).
Unless the context clearly requires otherwise, throughout the description and the claims, the words “comprise,” “comprising,” and the like are to be construed in an inclusive sense, as opposed to an exclusive or exhaustive sense; that is to say, in the sense of “including, but not limited to.” As used herein, the terms “connected,” “coupled,” or any variant thereof means any connection or coupling, either direct or indirect, between two or more elements; the coupling or connection between the elements can be physical, logical, or a combination thereof. Additionally, the words “herein,” “above,” “below,” and words of similar import, when used in this application, refer to this application as a whole and not to any particular portions of this application. Where the context permits, words in the above Detailed Description using the singular or plural number may also include the plural or singular numbers respectively. The word “or,” in reference to a list of two or more items, covers all of the following interpretations of the word: any of the items in the list, all of the items in the list, and any combination of the items in the list.
The above Detailed Description of examples of the invention is not intended to be exhaustive or to limit the invention to the precise form disclosed above. While specific examples for the invention are described above for illustrative purposes, various equivalent modifications are possible within the scope of the invention, as those skilled in the relevant art will recognize. For example, while processes or blocks are presented in a given order, alternative implementations may perform routines having steps, or employ systems having blocks, in a different order, and some processes or blocks may be deleted, moved, added, subdivided, combined, and/or modified to provide alternatives or subcombinations. Each of these processes or blocks may be implemented in a variety of different ways. Also, while processes or blocks are at times shown as being performed in series, these processes or blocks may instead be performed or implemented in parallel, or may be performed at different times. Further, any specific numbers noted herein are only examples: alternative implementations may employ differing values or ranges.
The teachings of the invention provided herein can be applied to other systems, not necessarily the system described above. The elements and acts of the various examples described above can be combined to provide further implementations of the invention. Some alternative implementations of the invention may include not only additional elements to those implementations noted above, but also may include fewer elements.
Any patents and applications and other references noted above, including any that may be listed in accompanying filing papers, are incorporated herein by reference, including U.S. patent application Ser. No. 14/136,322, filed Dec. 20, 2013. Aspects of the invention can be modified, if necessary, to employ the systems, functions, and concepts of the various references described above to provide yet further implementations of the invention.
These and other changes can be made to the invention in light of the above Detailed Description. While the above description describes certain examples of the invention, and describes the best mode contemplated, no matter how detailed the above appears in text, the invention can be practiced in many ways. Details of the system may vary considerably in its specific implementation, while still being encompassed by the invention disclosed herein. As noted above, particular terminology used when describing certain features or aspects of the invention should not be taken to imply that the terminology is being redefined herein to be restricted to any specific characteristics, features, or aspects of the invention with which that terminology is associated. In general, the terms used in the following claims should not be construed to limit the invention to the specific examples disclosed in the specification, unless the above Detailed Description section explicitly defines such terms. Accordingly, the actual scope of the invention encompasses not only the disclosed examples, but also all equivalent ways of practicing or implementing the invention under the claims. In some cases, various steps in the algorithms discussed herein may be added, altered, or removed without departing from the disclosed subject matter. Those skilled in the relevant art will appreciate that features described above may be altered in a variety of ways. For example, the order of the logic may be rearranged, sublogic may be performed in parallel, illustrated logic may be omitted, other logic may be included, etc.
To reduce the number of claims, certain aspects of the invention are presented below in certain claim forms, but the applicant contemplates the various aspects of the invention in any number of claim forms. For example, while only one aspect of the invention is recited as a means-plus-function claim under 35 U.S.C. § 112(f), other aspects may likewise be embodied as a means-plus-function claim, or in other forms, such as being embodied in a computer-readable medium. (Any claims intended to be treated under 35 U.S.C. § 112(f) will begin with the words “means for,” but use of the term “for” in any other context is not intended to invoke treatment under 35 U.S.C. § 112(f).) Accordingly, the applicant reserves the right to pursue additional claims after filing this application to pursue such additional claim forms, in either this application or in a continuing application.
This application claims the benefit of U.S. Provisional Patent Application No. 61/953,258, filed on Mar. 14, 2014, entitled NARROWING INFORMATION SEARCH RESULTS FOR PRESENTATION TO A USER, which is herein incorporated by reference in its entirety. This application is related to U.S. patent application Ser. No. 14/136,322 filed on Dec. 20, 2013, entitled “INTEREST GRAPH-POWERED SEARCH,” U.S. Patent Provisional Application No. 61/745,365 filed on Dec. 21, 2012, entitled “INTEREST GRAPH-POWERED SEARCH,” U.S. Provisional Patent Application No. 61/800,042, filed Mar. 15, 2013, entitled “INTEREST GRAPH-POWERED FEED,” U.S. Provisional Patent Application No. 61/800,322, filed Mar. 15, 2013, entitled “INTEREST GRAPH-POWERED BROWSING,” U.S. Provisional Patent Application No. 61/800,497, filed Mar. 15, 2013, entitled “INTEREST GRAPH-POWERED SHARING,” and U.S. Provisional Patent Application No. 61/914,266, filed Dec. 10, 2013, entitled “SKIM PREVIEW,” each of which is herein incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
7814425 | O'Shaugnessy et al. | Oct 2010 | B1 |
7970721 | Leskovec et al. | Jun 2011 | B2 |
8014634 | Chan | Sep 2011 | B1 |
8402375 | Skare et al. | Mar 2013 | B1 |
8447760 | Tong | May 2013 | B1 |
8510313 | Vaughan et al. | Aug 2013 | B2 |
8554601 | Marsh et al. | Oct 2013 | B1 |
8872804 | Cummings et al. | Oct 2014 | B2 |
20040267700 | Dumais et al. | Dec 2004 | A1 |
20050267799 | Chan et al. | Dec 2005 | A1 |
20060085427 | D'Urso | Apr 2006 | A1 |
20060129538 | Baader et al. | Jun 2006 | A1 |
20060248045 | Toledano | Nov 2006 | A1 |
20070033517 | O'Shaughnessy et al. | Feb 2007 | A1 |
20070079384 | Grinstein | Apr 2007 | A1 |
20070088820 | Kwak et al. | Apr 2007 | A1 |
20070150515 | Brave et al. | Jun 2007 | A1 |
20080154873 | Redlich | Jun 2008 | A1 |
20080306954 | Hornqvist | Dec 2008 | A1 |
20090019026 | Valdes-Perez et al. | Jan 2009 | A1 |
20090106697 | Ward et al. | Apr 2009 | A1 |
20090164431 | Zivkovic et al. | Jun 2009 | A1 |
20090178144 | Redlich | Jul 2009 | A1 |
20090222551 | Neely et al. | Sep 2009 | A1 |
20100070488 | Sylvain | Mar 2010 | A1 |
20100082622 | Irie et al. | Apr 2010 | A1 |
20100146593 | Stahl et al. | Jun 2010 | A1 |
20100198869 | Kalaboukis et al. | Aug 2010 | A1 |
20100235351 | Iwasa et al. | Sep 2010 | A1 |
20100250556 | Park et al. | Sep 2010 | A1 |
20100281389 | Hutchinson et al. | Nov 2010 | A1 |
20110107260 | Park et al. | May 2011 | A1 |
20110191679 | Lin et al. | Aug 2011 | A1 |
20110225153 | Haseyama et al. | Sep 2011 | A1 |
20110238754 | Dasilva et al. | Sep 2011 | A1 |
20110251875 | Cosman | Oct 2011 | A1 |
20120001919 | Lumer | Jan 2012 | A1 |
20120066645 | Laurie et al. | Mar 2012 | A1 |
20120117475 | Lee et al. | May 2012 | A1 |
20120131495 | Goossens et al. | May 2012 | A1 |
20120143859 | Lymperopoulos et al. | Jun 2012 | A1 |
20120158751 | Tseng et al. | Jun 2012 | A1 |
20120191715 | Ruffner et al. | Jul 2012 | A1 |
20120197855 | Chen et al. | Aug 2012 | A1 |
20120271819 | Qiu et al. | Oct 2012 | A1 |
20120278329 | Borggaard et al. | Nov 2012 | A1 |
20120278761 | John | Nov 2012 | A1 |
20120290565 | Wana et al. | Nov 2012 | A1 |
20120290614 | Nandakumar et al. | Nov 2012 | A1 |
20120310926 | Gannu et al. | Dec 2012 | A1 |
20120313948 | Bergman et al. | Dec 2012 | A1 |
20130036114 | Wong et al. | Feb 2013 | A1 |
20130054583 | Macklem et al. | Feb 2013 | A1 |
20130110813 | Holm et al. | May 2013 | A1 |
20130124653 | Vick et al. | May 2013 | A1 |
20130218923 | Kaul et al. | Aug 2013 | A1 |
20130254280 | Yang et al. | Sep 2013 | A1 |
20130268479 | Andler et al. | Oct 2013 | A1 |
20140006399 | Vasudevan et al. | Jan 2014 | A1 |
20140089048 | Bruich et al. | Mar 2014 | A1 |
20140089402 | Liyanage et al. | Mar 2014 | A1 |
20140189516 | Guo et al. | Jul 2014 | A1 |
20140359424 | Lin et al. | Dec 2014 | A1 |
20150177933 | Cueto | Jun 2015 | A1 |
20160042253 | Matei et al. | Feb 2016 | A1 |
20160162591 | Dokania et al. | Jun 2016 | A1 |
Number | Date | Country |
---|---|---|
2012185780 | Sep 2012 | JP |
Entry |
---|
International Search Report and Written Opinion for International Application No. PCT/US2013/076962, dated Apr. 22, 2014, 11 pages. |
International Search Report and Written Opinion for International Application No. PCT/US2014029505, dated Jul. 7, 2014, 11 pages. |
Screenshot of main page of Speaker Deck website. Taken Dec. 10, 2014 https://speakerdeck.com/. |
Screenshot of Frequently Asked Questions page of Speaker Deck website. Taken Dec. 10, 2014 https://speakerdeck.com/faq#file_types. |
Number | Date | Country | |
---|---|---|---|
20150261758 A1 | Sep 2015 | US |
Number | Date | Country | |
---|---|---|---|
61953258 | Mar 2014 | US |