A system and method for applying a first filter and a second filter, such as a recommendation and a constraint filter, to a plurality of items, including determining a cost of applying the first filter and the second filter to the plurality of items, and determining an order of applying the first and second filters based on the cost of applying the first and second filters.
|
21. A method, comprising:
sending a recommendation request to a server; and
receiving a recommendation list generated by the server of a constraint filter and a recommendation filter in an order based on a cost of applying the constraint filter and the recommendation filter, wherein the constraint filter determines if each of a plurality of items satisfies a constraint and the recommendation filter assigns a predicted enjoyment value to each item.
19. A system, comprising:
means for receiving a recommendation request from a user;
means for determining an order for applying a constraint filter and a recommendation filter to a plurality of items based on a cost of applying the constraint filter and the recommendation filter, wherein the constraint filter determines if each item satisfies a constraint and the recommendation filter assigns a predicted enjoyment value to each item; and
means for generating a recommendation list, comprising applying the constraint filter and the recommendation filter in the determined order.
23. A method, comprising:
setting parameters for a constraint filter and a recommendation filter based on a received recommendation request;
determining respective costs of applying the constraint filter and the recommendation filter to items in a data processing system, the costs being associated with a probability a selected one of the items will pass both the constraint filter and the recommendation filter;
applying a first one of the constraint or recommendation filter having a lower one of the costs; and
applying a second one of the constraint or recommendation filter having a higher one of the costs.
12. A system, comprising:
a recommendation server comprising a processing device configured to:
receive a recommendation request,
determine an order for applying a constraint filter and a recommendation filter to a plurality of items based on a cost of applying the constraint filter and the recommendation filter, wherein the constraint filter determines if each item satisfies a constraint and the recommendation filter assigns a predicted enjoyment value to each item, and
generate a recommendation list, the generating comprising applying the constraint filter and the recommendation filter in the determined order.
31. A system, comprising:
means for setting parameters for a constraint filter and a recommendation filter based on a received recommendation request;
means for determining respective costs of applying the constraint filter and the recommendation filter to items in a data processing system, the costs being associated with a probability a selected one of the items will pass both the constraint filter and the recommendation filter;
means for applying a first one of the constraint or recommendation filter having a lower one of the costs; and
means for applying a second one of the constraint or recommendation filter having a higher one of the costs.
17. A computer program product comprising a non-transitory computer readable storage medium having control logic stored therein, the control logic, when executed, causing a processor to perform operations comprising:
receiving a recommendation request;
determining an order for applying a constraint filter and a recommendation filter to a plurality of items based on a cost of applying the constraint filter and the recommendation filter, wherein the constraint filter determines if each item satisfies a constraint and the recommendation filter assigns a predicted enjoyment value to each item; and
generating a recommendation list, the generating comprising applying the constraint filter and the recommendation filter in the determined order.
30. A non-transitory computer readable medium having instructions stored thereon, execution of which, by a computing device, causes the computing device to perform operations comprising:
setting parameters for a constraint filter and a recommendation filter based on a received recommendation request;
determining respective costs of applying the constraint filter and the recommendation filter to items in a data processing system, the costs being associated with a probability a selected one of the items will pass both the constraint filter and the recommendation filter;
applying a first one of the constraint or recommendation filter having a lower one of the costs; and
applying a second one of the constraint or recommendation filter having a higher one of the costs.
1. A method for applying filters to a plurality of items in a data processing system comprising:
receiving a recommendation request;
specifying a constraint filter that selects items satisfying a constraint;
determining an order of the filters based on a cost of applying the filters, including:
applying the constraint filter first when a cost of applying the filters when the constraint filter is applied first is lower than a cost of applying the filters when a recommendation filter is applied first, wherein the constraint filter determines if each item satisfies the constraint, and
applying the recommendation filter first when the cost of applying the filters when the recommendation filter is applied first is lower than the cost of applying the filters when the constraint filter is applied first, wherein the recommendation filter assigns a predicted enjoyment value to each item.
8. A method, comprising:
determining an order for applying a constraint filter and a recommendation filter to a plurality of items, comprising:
calculating a cost of applying the constraint filter and the recommendation filter in a first order based at least on
(i) a number of results required,
(ii) a probability that a randomly selected item of the plurality of items will pass a second applied filter of the constraint filter and the recommendation filter,
(iii) a cost of applying a first applied filter of the constraint filter and the recommendation filter to generate a single item, and
(iv) a cost of applying the second applied filter of the constraint filter and the recommendation filter to the single item; and
generating a recommendation list, comprising applying the constraint filter and the recommendation filter to the plurality of items according to the determined order, wherein the constraint filter determines if each item satisfies a constraint and the recommendation filter assigns a predicted enjoyment value to each item.
2. The method of
analyzing a cost for applying the filters to the items; and
determining a probability that the items will pass both filters.
3. The method of
C=M/P(G+R), wherein M is a number of desired items, P is a probability that the items will pass a second applied filter, G is a time to retrieve the items, and R is a time to decide if the items will pass the second applied filter.
4. The method of
calculating the cost of applying the filters based at least on a probability that a randomly selected item of the plurality of items will pass a second applied filter of the recommendation and constraint filters.
5. The method of
6. The method of
11. The method of
13. The system of
14. The system of
15. The system of
18. The computer program product of
20. The system of
22. The method of
24. The method of
25. The method of
26. The method of
28. The method of
29. The method of
|
This application is a divisional of U.S. application Ser. No. 09/404,597, filed Sep. 24, 1999, now U.S. Pat. No. 7,461,058, which is incorporated by reference herein in its entirety.
1. Field of the Invention
This invention relates generally to data processing systems, and more particularly, collaborative filtering and recommender systems.
2. Background
Recommender systems are becoming widely used in e-commerce business activities. For example, systems that make personalized recommendations are used as a marketing tool to turn “window shoppers” into buyers, increase cross-sells and up-sells, and deepen customer loyalty. Recommender systems allow e-commerce operators to take advantage of customer databases to provide valuable personalized service to customers.
Current recommender systems can make generic recommendations to customers, but they do not take into account many of the business rules that merchandisers wish to implement, such as “don't recommend an item that is out of stock,” “don't recommend an item from a category that the customer has not selected,” “don't recommend items that are not in season,” or “don't recommend inappropriate items to minors.” In other words, current recommender systems base recommendations solely on the customer preference data.
Existing recommender systems allow only the simplest form of filtering, and they do it one of two ways, prefiltering or postfiltering.
Prefiltering requires a constraint system that discovers acceptable items and then submits all discovered items to a prediction system that makes recommendations from this subset. Prefiltering has some serious practical limitations, however. For example, gathering the list of acceptable items is difficult to accomplish efficiently as the list of acceptable items may be very large since it is selected from the whole item catalog.
Postfiltering also requires a system to filter the recommendation list. Postfiltering requires that the recommendation system produce more recommendations than actually required. The oversized list is passed to a constraint system, which then removes unacceptable items. Although postfiltering may avoid the problem of having to select items from a large list, it may fail to provide recommendations if the postfiltering eliminates all items.
Methods and systems consistent with the present invention provide a recommendation server that receives a recommendation request from a user of a client computer. The recommendation server contains software to provide recommendations to the user. To provide the recommendations, the recommendation server applies a constraint filter and a recommendation filter to a set of items.
In accordance with methods and systems consistent with the present invention, a method for providing a recommendation list specifies a constraint filter to select items satisfying a constraint, selects the items that satisfy the constraint filter, computes predicted values based on a recommendation filter, and appends the items meeting predetermined criteria.
In accordance with methods and systems consistent with the present invention, a method for applying a recommendation filter and a constraint filter to a plurality of items is provided. The method receives a recommendation request from a user, specifies a constraint filter to select ones of the items satisfying a constraint, and determines the order of the filters based on a cost of the filters. The method applies the constraint filter first when the cost of the constraint filter is lower than the cost of the recommendation filter. Otherwise, the method applies the recommendation filter first when the cost of the recommendation filter is lower than the cost of the constraint filter.
The accompanying drawings, which are incorporated in and constitute a part of this specification, illustrate an implementation of the invention and, together with the description, serve to explain the advantages and principles of the invention. In the drawings,
The following detailed description of the invention refers to the accompanying drawings. Although the description includes exemplary implementations, other implementations are possible, and changes may be made to the implementations described without departing from the spirit and scope of the invention. The following detailed description does not limit the invention. Instead, the scope of the invention is defined by the appended claims. Wherever possible, the same reference numbers will be used throughout the drawings and the following description to refer to the same or like parts.
Overview
Recommender systems provide recommendations to users based on various attributes. For example, collaborative filtering (CF) systems are a specific type of recommender system that recommend items to a user based on the opinions of other users. In their purest form, CF systems do not consider the content of the items at all, relying exclusively on the judgment of humans of the item's value. In this way, CF systems attempt to recapture the cross-topic recommendations that are common in communities of people.
Commercial applications of ratings-based collaborative filtering now exist in a variety of domains including books, music, grocery products, dry goods, and information. One example of a CF-system is the GroupLens Research system that provides a CF for Usenet news and movies. More information on CF technology may be found at <http://www.netperceptions.com>, hereby incorporated by reference.
To use the recommendation system, an operator may first create a constraint using a constraint language that allows different business rules to be described in textual form. For example, to select a candidate from a set of red items, a constraint may be: “candidate isa red-thing.” To select a candidate from a set of movies that are both comedies and not r-rated, a constraint may be: “candidate isa comedy and not candidate isa r-rated.”
An item may be anything for which a user may recommend. For example, in the domain of movies, each movie may be an item. An item may be assigned arbitrarily to one or more categories. For example, a fiction book may be a member of the “Fiction” category. Category membership may represent any attribute of a user or item. For example, an item that is in stock may be a member of the “in stock” category or an item that is red may be a member of the “red-things” category. This type of categorization allows the recommendation system to apply a constraint filter based on any attribute or combination of attributes of the item. A constraint filter is a software with a complex boolean expression as an attribute that the recommendation system uses to restrict items.
A constraint may also consist of free variables. A free variable is a placeholder for an attribute that can be determined at execution time. For example, to provide the user with the ability to choose a category when applying a constraint, a constraint may be: “candidate isa X,” where the user inputs X at runtime.
Once the operator creates the constraint, the recommendation system may begin accepting recommendation requests from a user. To use the recommendation system, a user may access a web site with instructions and web pages for the user to fill out to use the recommendation system. Upon accessing the web site, the user enters a recommendation request including values for various free variables and the number of items desired. The recommendation request may include the values for the free variables for the constraint filter, the number of items desired and user information. One skilled in the art will appreciate that other methods may be used to obtain a recommendation request, such as a telephone call center or manual entry.
Once the recommendation system receives the recommendation request, the system next determines the order of a constraint filter and a recommendation filter to apply to the received recommendation request. The constraint filter determines whether an item satisfies a constraint and the recommendation filter determines a predicted value of the item based on historical or statistical information. One type of recommendation filter is the well-known collaborative filtering (CF) technique.
The recommendation filter may compute a predicted value to determine if an item should be recommended. A predicted value is a number that rates an item according to certain criteria. For example, a predicted value may be used to rank an item based on recommendations from similar users of the recommendation system. The predicted value is essentially an estimate of how much a user is likely to enjoy an item and may be determined, for example, by a CF technique. One skilled in the art will appreciate that the predicted value may be determined in a number of different ways, such as previous purchases, previous comments or a particular rating given by the user.
To determine the order of filters to apply, the recommendation system determines the cost of applying successively each filter to all items. The cost of applying each filter is explained below. For example, if the cost to apply a constraint filter before a recommendation filter is lower than the other sequence, the recommendation system may choose to apply the constraint filter first. Preferably, the recommendation system provides a recommendation to a user with the lowest cost.
Once the order of the filters is determined, the recommendation system recommends a list of items to the user that the user may be interested in based on the recommendation filter and also passes the constraint filter. If the cheapest method is to apply the constraint filter first, each time an item passes the constraint, it becomes a potential candidate for a recommendation list. The candidate is then passed to the recommendation filter. If the candidate passes the recommendation filter, the candidate and the candidate's predicted value are appended to a recommendation list.
System Components
Recommendation server 120 transmits and receives web pages from a browser on client computer 112 using hypertext markup language (HTML), Java or other techniques. These web pages may-include-images or instructions to obtain recommendation requests from a user. Recommendation server 120 also contains a database that stores various data, such as constraint filters, recommendation filters and items, further described below.
Although only one client computer 112 is depicted, one skilled in the art will appreciate that data processing system 100 may contain many more client computers and additional client sites. One skilled in the art will also appreciate that client computer 112 may come with the recommendation server software already installed.
As shown in
Secondary storage device 320 includes grammar file 322 containing a set of rules which map textual constraints to their internal representation in the constraint filter. Secondary storage device also includes database 324 with constraint table 326 that stores built constraints to use with recommendation software 312 and item table 328 with attribute information about each item. For example, item table 328 could store a category identification, item number, and number in stock.
Although aspects of the present invention are described as being stored in memory, one skilled in the art will appreciate that these aspects may be stored on or read from other computer-readable media, such as secondary storage devices, like hard disks, floppy disks, and CD-ROM; a carrier wave received from a network like the Internet; or other forms of ROM or RAM. Additionally, although specific components and programs of client computer 112 and recommendation server 120 have been described, one skilled in the art will appreciate that these may contain additional or different components or programs.
Constraint Creation Process
Once the constraint is verified for the correct syntax, constraint builder software may translate the textual constraint into, for example, a constraint in a tree structure format (step 406). Constraint builder software 314 includes the well-known yacc parser to translate the textual constraint. The builder software reads grammar specification file 322 and generates a constraint tree consisting of objects by using the grammar specifications applied to the textual constraint. The new constraint tree is in a format acceptable to recommendation software 312.
Grammar specification file 322 consists of many different object formats to create the constraint tree, such as logical expression objects, relational expression objects or leaf objects. Logical expression objects are a type of boolean expression, such as AND, OR or NOT. Relational expression objects compare two leaf objects. Leaf objects represent any entity in the application domain. A leaf may be a category leaf, free variable leaf, candidate leaf, or subject leaf. A category leaf represents at least one item in database 324, such as “Thriller” or “Shoes.” A free variable leaf is essentially a placeholder that is specified at execution time by the user or operator. The free variable leaf stores a variable name, which is bound to an actual entity in the application domain during the recommendation process, further described below. Similar to the free variable leaf, the candidate leaf is also a placeholder. The candidate leaf represents the actual item discovered by the recommendation filter. Finally, a subject leaf is a placeholder for the user who requested the recommendation. For example, a user may have an attribute of being 14 years old. Thus, leaf objects in the constraint tree may reflect this attribute.
For example, a textual constraint created by an operator to produce recommendations for movies that are now playing, and are of a genre selected by a user, and prohibits the recommendation of r-rated movies to minors may be:
X: (candidate isa movie) and (candidate isa X) and (candidate isa NowPlay) and (not (subject isa minor) and (candidate isa R-rated)).
Constraint builder software 314 would translate the textual constraint to the tree of objects depicted in
Once constraint builder software 314 translates the textual constraint to a constraint tree, the constraint tree is placed as an entity in constraint table 326 (step 408). The constraint tree is used later by recommendation software 312 during the recommendation process. This completes the constraint creation process.
Recommendation Process
Once received at recommendation server 120, recommendation software 312 binds the free variables in the appropriate constraint with the category selected by the user and the number of items desired (step 508). To do so, recommendation software 312 first locates the appropriate constraint in constraint table 326. The constraint may be found in constraint table 326, for example, by a tag appended to the recommendation request indicating the constraint. Once located, recommendation software 312 descends the constraint tree to locate free variable objects. Once a free variable object is found, recommendation software 312 copies the information from the recommendation request to the free variable. For example, in
Index
Object
1
Jazz
2
Rock
Step 508 uses the array when descending the constraint tree searching for a free variable object. When a free variable object is located, the index is matched and the corresponding object is copied to the free variable object. Ultimately, recommendation software 312 will examine each node in the constraint tree to locate all free variables and store corresponding information in each free variable. Although two free variables were used in
After the free variables in the constraint tree are bound, recommendation software 312 examines each item in item table 328 for an item to recommend to the user. The process begins with recommendation software determining the lowest cost method to complete a recommendation request (step 510). To do so, recommendation software 312 determines the cost of applying constraint filter 316 and recommendation filter 318 in different orders to the items. As shown in
If the cost of generating a sufficient number of items by applying the generation interface of the-constraint filter before applying the rejection interface of the recommendation filter is lower than applying the generation interface of the recommendation filter before applying the rejection interface of the constraint filter, then recommendation software 312 will apply the generation interface of the constraint system first to item table 328. Otherwise, recommendation software 312 applies the generation interface of the recommendation filter first. The cost may be approximated by the following equation:
Cost=(number of results required/probability that a randomly selected item will pass the rejection interface of the second filter)*(cost of applying the generation interface of the first filter to generate a single item+cost of applying the rejection interface of the second filter to a single item)
Once the order of the filters is determined, recommendation software 312 determines if enough items have been located (step 512). That is, recommendation software continues to discover new items in item table 328 until the required number of items requested from the user has been reached. Once an item has been discovered in item table 328, the item is evaluated (step 514). Evaluation occurs by applying the constraint filter to the item. Items that pass the constraint filter will be passed to the recommendation filter (step 516). An item passes the constraint filter when it satisfies the constraints conditions. If an item does not pass the constraint filter, the item is discarded and not recommended.
Next, the recommendation filter may compute a predicted value for the item (step 518). Also in step 518, each item whose predicted value is at least a threshold value is appended to a result list for display on client computer 112. The results may be displayed in HTML.
Methods, systems, and articles of manufacture consistent with the present invention provide a recommendation server that receives a recommendation request from a user of a client computer. The recommendation server contains software to provide recommendations to the user. To provide the recommendations, the recommendation server applies a constraint filter and a recommendation filter on a set of items.
The foregoing description of an implementation of the invention has been presented for purposes of illustration and description. It is not exhaustive and does not limit the invention to the precise form disclosed. Modifications and variations are possible in light of the above teachings or may be acquired from practicing of the invention. For example, the described implementation includes software but the present invention may be implemented as a combination of hardware and software or in hardware alone.
Guralnik, Valerie, Rauser, John
Patent | Priority | Assignee | Title |
9734170, | Feb 06 2014 | International Business Machines Corporation | Multilevel filters for cache-efficient access |
9740714, | Feb 06 2014 | International Business Machines Corporation | Multilevel filters for cache-efficient access |
9940356, | Jul 31 2014 | International Business Machines Corporation | Efficient join-filters for parallel processing |
9946748, | Jul 31 2014 | International Business Machines Corporation | Efficient join-filters for parallel processing |
Patent | Priority | Assignee | Title |
4870579, | Oct 01 1987 | Adobe Systems Incorporated | System and method of predicting subjective reactions |
4996642, | Oct 01 1987 | Adobe Systems Incorporated | System and method for recommending items |
5091852, | Jan 29 1988 | Hitachi, Ltd. | System for optimizing query processing in a relational database |
5345585, | Dec 02 1991 | International Business Machines Corporation | Method for optimizing processing of join queries by determining optimal processing order and assigning optimal join methods to each of the join operations |
5668987, | Aug 31 1995 | SYBASE, INC , A CORP OF DE | Database system with subquery optimizer |
5749081, | Apr 06 1995 | Microsoft Technology Licensing, LLC | System and method for recommending items to a user |
5790426, | Apr 30 1996 | VIRTUAL DEVELOPMENT CORPORATION | Automated collaborative filtering system |
5835087, | Nov 29 1994 | Pinpoint Incorporated | System for generation of object profiles for a system for customized electronic identification of desirable objects |
5872850, | Jun 30 1995 | Microsoft Technology Licensing, LLC | System for enabling information marketplace |
5884282, | Apr 30 1996 | FELLOWSHIP FILTERING TECHNOLOGIES, LLC | Automated collaborative filtering system |
5893909, | Aug 21 1996 | Fuji Xerox Co., Ltd. | Information processing apparatus and information processing method |
5918014, | Dec 27 1995 | GOOGLE LLC | Automated collaborative filtering in world wide web advertising |
5983214, | Apr 04 1996 | HUDSON BAY MASTER FUND LTD | System and method employing individual user content-based data and user collaborative feedback data to evaluate the content of an information entity in a large information communication network |
6006218, | Feb 28 1997 | Microsoft Technology Licensing, LLC | Methods and apparatus for retrieving and/or processing retrieved information as a function of a user's estimated knowledge |
6006225, | Jun 15 1998 | Amazon Technologies, Inc | Refining search queries by the suggestion of correlated terms from prior searches |
6016475, | Oct 08 1996 | MINNESOTA UNIVERSITY OF, REGENTS OF, THE | System, method, and article of manufacture for generating implicit ratings based on receiver operating curves |
6018738, | Jan 22 1998 | Microsoft Technology Licensing, LLC | Methods and apparatus for matching entities and for predicting an attribute of an entity based on an attribute frequency value |
6041311, | Jun 30 1995 | Microsoft Technology Licensing, LLC | Method and apparatus for item recommendation using automated collaborative filtering |
6049777, | Jun 30 1995 | Microsoft Technology Licensing, LLC | Computer-implemented collaborative filtering based method for recommending an item to a user |
6064980, | Mar 17 1998 | Amazon Technologies, Inc | System and methods for collaborative recommendations |
6067542, | Oct 20 1995 | TERADATA US, INC | Pragma facility and SQL3 extension for optimal parallel UDF execution |
6092049, | Jun 30 1995 | Microsoft Technology Licensing, LLC | Method and apparatus for efficiently recommending items using automated collaborative filtering and feature-guided automated collaborative filtering |
6108493, | Oct 07 1996 | REGENTS OF THE UNVIERSITY OF MINNESOTA | System, method, and article of manufacture for utilizing implicit ratings in collaborative filters |
6112186, | Jun 30 1995 | Microsoft Technology Licensing, LLC | Distributed system for facilitating exchange of user information and opinion using automated collaborative filtering |
6266649, | Sep 18 1998 | Amazon Technologies, Inc | Collaborative recommendations using item-to-item similarity mappings |
6308175, | Apr 04 1996 | HUDSON BAY MASTER FUND LTD | Integrated collaborative/content-based filter structure employing selectively shared, content-based profile data to evaluate information entities in a massive information network |
6313745, | Jan 06 2000 | Fujitsu Limited | System and method for fitting room merchandise item recognition using wireless tag |
6314420, | Apr 04 1996 | HUDSON BAY MASTER FUND LTD | Collaborative/adaptive search engine |
6317722, | Sep 18 1998 | Amazon Technologies, Inc | Use of electronic shopping carts to generate personal recommendations |
6321179, | Jun 29 1999 | GOOGLE LLC | System and method for using noisy collaborative filtering to rank and present items |
6321221, | Jul 17 1998 | CALLSTAT SOLUTIONS LLC | System, method and article of manufacture for increasing the user value of recommendations |
6334127, | Jul 17 1998 | CALLSTAT SOLUTIONS LLC | System, method and article of manufacture for making serendipity-weighted recommendations to a user |
6341281, | Apr 14 1998 | SYBASE, INC , A CORPORATION OF DELAWARE | Database system with methods for optimizing performance of correlated subqueries by reusing invariant results of operator tree |
6356889, | Sep 30 1998 | International Business Machines Corporation | Method for determining optimal database materializations using a query optimizer |
6377943, | Jan 20 1999 | ORACLE INTERNATIONAL CORPORATION OIC | Initial ordering of tables for database queries |
6412012, | Dec 23 1998 | CXT SYSTEMS, INC | System, method, and article of manufacture for making a compatibility-aware recommendations to a user |
6415368, | Dec 22 1999 | GOOGLE LLC | System and method for caching |
6434550, | Apr 14 2000 | Oracle OTC Subsidiary LLC | Temporal updates of relevancy rating of retrieved information in an information search system |
6438579, | Jul 16 1999 | Microsoft Corporation | Automated content and collaboration-based system and methods for determining and providing content recommendations |
6460036, | Nov 28 1994 | Pinpoint Incorporated | System and method for providing customized electronic newspapers and target advertisements |
6487539, | Aug 06 1999 | eBay Inc | Semantic based collaborative filtering |
6489968, | Nov 18 1999 | A9 COM, INC | System and method for exposing popular categories of browse tree |
6493702, | May 05 1999 | GOOGLE LLC | System and method for searching and recommending documents in a collection using share bookmarks |
6629079, | Jun 25 1998 | AMAZON COM, INC | Method and system for electronic commerce using multiple roles |
6636836, | Jul 21 1999 | M&SERVICE CO , LTD | Computer readable medium for recommending items with multiple analyzing components |
6671818, | Nov 22 1999 | Accenture Global Services Limited | Problem isolation through translating and filtering events into a standard object format in a network based supply chain |
7461058, | Sep 24 1999 | CDN INNOVATIONS, LLC | Optimized rule based constraints for collaborative filtering systems |
7734680, | Sep 30 1999 | S I SV EL SOCIETA ITALIANA PER LO SVILUPPO DELL ELETTRONICA S P A | Method and apparatus for realizing personalized information from multiple information sources |
20020065721, | |||
20020120609, | |||
20020199194, | |||
20030191737, | |||
20040034652, | |||
20050091245, | |||
20050125307, | |||
20070124276, | |||
CA2249096, | |||
JP10143540, | |||
JP10143541, | |||
JP10162025, | |||
JP10162027, | |||
JP10162028, | |||
JP10198706, | |||
JP10228482, | |||
JP10228487, | |||
JP10240749, | |||
JP10247198, | |||
JP10257405, | |||
JP10260955, | |||
JP10283403, | |||
JP10289245, | |||
JP10301950, | |||
JP10307845, | |||
JP10320415, | |||
JP1032797, | |||
JP10340270, | |||
JP1063680, | |||
JP1063681, | |||
JP1063749, | |||
JP1074206, | |||
JP1091642, | |||
JP1091647, | |||
JP1091686, | |||
JP11007453, | |||
JP11007472, | |||
JP11015840, | |||
JP11045265, | |||
JP11045284, | |||
JP11045286, | |||
JP11045289, | |||
JP11045290, | |||
JP11053394, | |||
JP11066081, | |||
JP11066097, | |||
JP11066098, | |||
JP11096164, | |||
JP11110410, | |||
JP11120189, | |||
JP11134345, | |||
JP11134361, | |||
JP11143900, | |||
JP11161670, | |||
JP11164217, | |||
JP11175546, | |||
JP11184890, | |||
JP11184891, | |||
JP11195035, | |||
JP11205706, | |||
JP11212996, | |||
JP11232278, | |||
JP11232287, | |||
JP11250091, | |||
JP11259497, | |||
JP11272574, | |||
JP11282874, | |||
JP11282875, | |||
JP11308547, | |||
JP11312177, | |||
JP11316759, | |||
JP11328266, | |||
JP11338869, | |||
JP11338872, | |||
JP11338879, | |||
JP11345446, | |||
JP11509019, | |||
JP1169605, | |||
JP2000013708, | |||
JP2000023112, | |||
JP2000048046, | |||
JP2000057090, | |||
JP7152771, | |||
JP7234881, | |||
JP8331077, | |||
JP9163027, | |||
JP9265478, | |||
WO124032, | |||
WO137162, | |||
WO9833135, | |||
WO9840832, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Nov 02 1999 | RAUSER, JOHN | NETPERCEPTIONS, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 050858 | /0303 | |
Nov 02 1999 | GURALNIK, VALERIE | NETPERCEPTIONS, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 050858 | /0303 | |
Jan 14 2002 | MULIER, FILIP | NET PERCEPTIONS, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 025682 | /0108 | |
Jan 23 2002 | DRISKILL, ROBERT | NET PERCEPTIONS, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 025682 | /0125 | |
Mar 15 2002 | EKHAUS, MICHAEL A | NET PERCEPTIONS, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 025685 | /0347 | |
Dec 30 2003 | NET PERCEPTIONS, INC | Thalveg Data Flow LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 025660 | /0417 | |
Oct 31 2008 | Thalveg Data Flow LLC | (assignment on the face of the patent) | / | |||
Oct 31 2019 | Thalveg Data Flow LLC | INTELLECTUAL VENTURES ASSETS 147 LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 050885 | /0182 | |
Nov 15 2019 | INTELLECTUAL VENTURES ASSETS 147 LLC | CDN INNOVATIONS, LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 051406 | /0850 |
Date | Maintenance Fee Events |
Mar 27 2017 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
May 24 2021 | REM: Maintenance Fee Reminder Mailed. |
Oct 01 2021 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Oct 01 2021 | M1555: 7.5 yr surcharge - late pmt w/in 6 mo, Large Entity. |
Date | Maintenance Schedule |
Oct 01 2016 | 4 years fee payment window open |
Apr 01 2017 | 6 months grace period start (w surcharge) |
Oct 01 2017 | patent expiry (for year 4) |
Oct 01 2019 | 2 years to revive unintentionally abandoned end. (for year 4) |
Oct 01 2020 | 8 years fee payment window open |
Apr 01 2021 | 6 months grace period start (w surcharge) |
Oct 01 2021 | patent expiry (for year 8) |
Oct 01 2023 | 2 years to revive unintentionally abandoned end. (for year 8) |
Oct 01 2024 | 12 years fee payment window open |
Apr 01 2025 | 6 months grace period start (w surcharge) |
Oct 01 2025 | patent expiry (for year 12) |
Oct 01 2027 | 2 years to revive unintentionally abandoned end. (for year 12) |