RECOMMENDATION SYSTEM WITH IMPLICIT FEEDBACK

Information

  • Patent Application
  • 20220237685
  • Publication Number
    20220237685
  • Date Filed
    April 07, 2022
    2 years ago
  • Date Published
    July 28, 2022
    2 years ago
Abstract
A computing device determines a recommendation. A confidence matrix is computed using a predefined weight value. (A) A first parameter matrix is updated using the confidence matrix, a predefined response matrix, a first step-size parameter value, and a first direction matrix. The predefined response matrix includes a predefined response value by each user to each item and at least one matrix value for which a user has not provided a response to an item. (B) A second parameter matrix is updated using the confidence matrix, the predefined response matrix, a second step-size parameter value, and a second direction matrix. (C) An objective function value is updated based on the first and second parameter matrices. (D) The first and second parameter matrices are trained by repeating (A) through (C). The first and second parameter matrices output for use in predicting a recommended item for a requesting user.
Description
BACKGROUND

As a popular approach to collaborative filtering, matrix factorization (MF) models an underlying response matrix as a product of two factor matrices, one for users and one for items. The MF model can be trained based on implicit feedback using an alternating weighted least squares (AWLS) method. The MF model updates the two factor matrices alternately, keeping one fixed while updating the other. An AWLS method is described by Yifan Hu, Yehuda Koren, and Chris Volinsky in their paper titled Collaborative Filtering for Implicit Feedback Datasets and published in the Proceedings from the IEEE International Conference on Data Mining (ICDM 08) by the IEEE CS Press on pages 263-272 in 2008 (the Hu paper). Although the AWLS method improves the learning objective aggressively in each iteration, the AWLS method suffers from high computational cost due to the necessity of inverting a separate matrix for each user and item.


SUMMARY

In an example embodiment, a non-transitory computer-readable medium is provided having stored thereon computer-readable instructions that, when executed by a computing device, cause the computing device to determine a recommendation. A confidence matrix is computed using a predefined weight value defined for each user of a plurality of users and each item of a plurality of items. (A) A first parameter matrix is updated using the computed confidence matrix, a predefined response matrix, a first step-size parameter value that is greater than one, and a first direction matrix. The first parameter matrix includes a row dimension equal to a number of users of the plurality of users. The predefined response matrix includes a predefined response value by each user of the plurality of users to each item of the plurality of items. The predefined response matrix includes at least one matrix value for which a user of the plurality of users has not provided a response to an item of the plurality of items. (B) A second parameter matrix is updated using the computed confidence matrix, the predefined response matrix, a second step-size parameter value that is greater than zero, and a second direction matrix. The second parameter matrix includes a column dimension equal to a number of items of the plurality of items. (C) An objective function value is updated based on the updated first parameter matrix and the updated second parameter matrix. (D) The first parameter matrix and the second parameter matrix are trained by repeating (A) through (C) until the updated first parameter matrix and the updated second parameter matrix satisfy a convergence test. The trained first parameter matrix and the trained second parameter matrix are output for use in predicting a recommended item of the plurality of items for a requesting user of the plurality of users.


In yet another example embodiment, a computing device is provided. The computing device includes, but is not limited to, a processor and a non-transitory computer-readable medium operably coupled to the processor. The computer-readable medium has instructions stored thereon that, when executed by the computing device, cause the computing device to determine a recommendation.


In an example embodiment, a method of determining a recommendation is provided.


Other principal features of the disclosed subject matter will become apparent to those skilled in the art upon review of the following drawings, the detailed description, and the appended claims.





BRIEF DESCRIPTION OF THE DRAWINGS

Illustrative embodiments of the disclosed subject matter will hereafter be described referring to the accompanying drawings, wherein like numerals denote like elements.



FIG. 1 depicts a block diagram of a recommendation device in accordance with an illustrative embodiment.



FIG. 2 depicts a flow diagram of examples of operations performed by a recommendation application of the recommendation device of FIG. 1 in accordance with an illustrative embodiment.



FIG. 3 depicts a sub-model structure for determining recommendations based on content-based and/or collaborative filtering in accordance with an illustrative embodiment.



FIG. 4A shows a training objective function value comparison with a dataset, |F2|=5, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 4B shows an area under ROC curve (AUC) value comparison with the dataset, |F2|=5, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 4C shows a precision value comparison with the dataset, |F2|=5, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 4D shows a recall value comparison with the dataset, |F2|=5, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 5A shows a training objective function value comparison with a dataset, |F2|=5, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 5B shows an AUC value comparison with the dataset, |F2|=5, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 5C shows a precision value comparison with the dataset, |F2|=5, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 5D shows a recall value comparison with the dataset, |F2|=5, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 6A shows a training objective function value comparison with a dataset, |F2|=5, and λ=1 in accordance with an illustrative embodiment.



FIG. 6B shows an AUC value comparison with the dataset, |F2|=5, and λ=1 in accordance with an illustrative embodiment.



FIG. 6C shows a precision value comparison with the dataset, |F2|=5, and λ=1 in accordance with an illustrative embodiment.



FIG. 6D shows a recall value comparison with the dataset, |F2|=5, and λ=1 in accordance with an illustrative embodiment.



FIG. 7A shows a training objective function value comparison with a dataset, |F2|=5, and λ=10 in accordance with an illustrative embodiment.



FIG. 7B shows an AUC value comparison with the dataset, |F2|=5, and λ=10 in accordance with an illustrative embodiment.



FIG. 7C shows a precision value comparison with the dataset, |F2|=5, and λ=10 in accordance with an illustrative embodiment.



FIG. 7D shows a recall value comparison with the dataset, |F2|=5, and λ=10 in accordance with an illustrative embodiment.



FIG. 8A shows a training objective function value comparison with a dataset, |F2|=5, and λ=100 in accordance with an illustrative embodiment.



FIG. 8B shows an AUC value comparison with the dataset, |F2|=5, and λ=100 in accordance with an illustrative embodiment.



FIG. 8C shows a precision value comparison with the dataset, |F2|=5, and λ=100 in accordance with an illustrative embodiment.



FIG. 8D shows a recall value comparison with the dataset, |F2|=5, and λ=100 in accordance with an illustrative embodiment.



FIG. 9A shows a training objective function value comparison with a dataset, |F2|=10, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 9B shows an AUC value comparison with the dataset, |F2|=10, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 9C shows a precision value comparison with the dataset, |F2|=10, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 9D shows a recall value comparison with the dataset, |F2|=10, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 10A shows a training objective function value comparison with a dataset, |F2|=10, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 10B shows an AUC value comparison with the dataset, |F2|=10, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 10C shows a precision value comparison with the dataset, |F2|=10, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 10D shows a recall value comparison with the dataset, |F2|=10, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 11A shows a training objective function value comparison with a dataset, |F2|=10, and λ=1 in accordance with an illustrative embodiment.



FIG. 11B shows an AUC value comparison with the dataset, |F2|=10, and λ=1 in accordance with an illustrative embodiment.



FIG. 11C shows a precision value comparison with the dataset, |F2|=10, and λ=1 in accordance with an illustrative embodiment.



FIG. 11D shows a recall value comparison with the dataset, |F2|=10, and λ=1 in accordance with an illustrative embodiment.



FIG. 12A shows a training objective function value comparison with a dataset, |F2|=10, and λ=10 in accordance with an illustrative embodiment.



FIG. 12B shows an AUC value comparison with the dataset, |F2|=10, and λ=10 in accordance with an illustrative embodiment.



FIG. 12C shows a precision value comparison with the dataset, |F2|=10, and λ=10 in accordance with an illustrative embodiment.



FIG. 12D shows a recall value comparison with the dataset, |F2|=10, and λ=10 in accordance with an illustrative embodiment.



FIG. 13A shows a training objective function value comparison with a dataset, |F2|=10, and λ=100 in accordance with an illustrative embodiment.



FIG. 13B shows an AUC value comparison with the dataset, |F2|=10, and λ=100 in accordance with an illustrative embodiment.



FIG. 13C shows a precision value comparison with the dataset, |F2|=10, and λ=100 in accordance with an illustrative embodiment.



FIG. 13D shows a recall value comparison with the dataset, |F2|=10, and λ=100 in accordance with an illustrative embodiment.



FIG. 14A shows a training objective function value comparison with a dataset, |F2|=20, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 14B shows an AUC value comparison with the dataset, |F2|=20, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 14C shows a precision value comparison with the dataset, |F2|=20, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 14D shows a recall value comparison with the dataset, |F2|=20, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 15A shows a training objective function value comparison with a dataset, |F2|=20, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 15B shows an AUC value comparison with the dataset, |F2|=20, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 15C shows a precision value comparison with the dataset, |F2|=20, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 15D shows a recall value comparison with the dataset, |F2|=20, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 16A shows a training objective function value comparison with a dataset, |F2|=20, and λ=1 in accordance with an illustrative embodiment.



FIG. 16B shows an AUC value comparison with the dataset, |F2|=20, and λ=1 in accordance with an illustrative embodiment.



FIG. 16C shows a precision value comparison with the dataset, |F2|=20, and λ=1 in accordance with an illustrative embodiment.



FIG. 16D shows a recall value comparison with the dataset, |F2|=20, and λ=1 in accordance with an illustrative embodiment.



FIG. 17A shows a training objective function value comparison with a dataset, |F2|=20, and λ=10 in accordance with an illustrative embodiment.



FIG. 17B shows an AUC value comparison with the dataset, |F2|=20, and λ=10 in accordance with an illustrative embodiment.



FIG. 17C shows a precision value comparison with the dataset, |F2|=20, and λ=10 in accordance with an illustrative embodiment.



FIG. 17D shows a recall value comparison with the dataset, |F2|=20, and λ=10 in accordance with an illustrative embodiment.



FIG. 18A shows a training objective function value comparison with a dataset, |F2|=20, and λ=100 in accordance with an illustrative embodiment.



FIG. 18B shows an AUC value comparison with the dataset, |F2|=20, and λ=100 in accordance with an illustrative embodiment.



FIG. 18C shows a precision value comparison with the dataset, |F2|=20, and λ=100 in accordance with an illustrative embodiment.



FIG. 18D shows a recall value comparison with the dataset, |F2|=20, and λ=100 in accordance with an illustrative embodiment.



FIG. 19A shows a training objective function value comparison with a dataset, |F2|=30, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 19B shows an AUC value comparison with the dataset, |F2|=30, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 19C shows a precision value comparison with the dataset, |F2|=30, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 19D shows a recall value comparison with the dataset, |F2|=30, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 20A shows a training objective function value comparison with a dataset, |F2|=30, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 20B shows an AUC value comparison with the dataset, |F2|=30, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 20C shows a precision value comparison with the dataset, |F2|=30, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 20D shows a recall value comparison with the dataset, |F2|=30, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 21A shows a training objective function value comparison with a dataset, |F2|=30, and λ=1 in accordance with an illustrative embodiment.



FIG. 21B shows an AUC value comparison with the dataset, |F2|=30, and λ=1 in accordance with an illustrative embodiment.



FIG. 21C shows a precision value comparison with the dataset, |F2|=30, and λ=1 in accordance with an illustrative embodiment.



FIG. 21D shows a recall value comparison with the dataset, |F2|=30, and λ=1 in accordance with an illustrative embodiment.



FIG. 22A shows a training objective function value comparison with a dataset, |F2|=30, and λ=10 in accordance with an illustrative embodiment.



FIG. 22B shows an AUC value comparison with the dataset, |F2|=30, and λ=10 in accordance with an illustrative embodiment.



FIG. 22C shows a precision value comparison with the dataset, |F2|=30, and λ=10 in accordance with an illustrative embodiment.



FIG. 22D shows a recall value comparison with the dataset, |F2|=30, and λ=10 in accordance with an illustrative embodiment.



FIG. 23A shows a training objective function value comparison with a dataset, |F2|=30, and λ=100 in accordance with an illustrative embodiment.



FIG. 23B shows an AUC value comparison with the dataset, |F2|=30, and λ=100 in accordance with an illustrative embodiment.



FIG. 23C shows a precision value comparison with the dataset, |F2|=30, and λ=100 in accordance with an illustrative embodiment.



FIG. 23D shows a recall value comparison with the dataset, |F2|=30, and λ=100 in accordance with an illustrative embodiment.



FIG. 24A shows a training objective function value comparison with a dataset, |F2|=50, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 24B shows an AUC value comparison with the dataset, |F2|=50, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 24C shows a precision value comparison with the dataset, |F2|=50, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 24D shows a recall value comparison with the dataset, |F2|=50, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 25A shows a training objective function value comparison with a dataset, |F2|=50, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 25B shows an AUC value comparison with the dataset, |F2|=50, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 25C shows a precision value comparison with the dataset, |F2|=50, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 25D shows a recall value comparison with the dataset, |F2|=50, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 26A shows a training objective function value comparison with a dataset, |F2|=50, and λ=1 in accordance with an illustrative embodiment.



FIG. 26B shows an AUC value comparison with the dataset, |F2|=50, and λ=1 in accordance with an illustrative embodiment.



FIG. 26C shows a precision value comparison with the dataset, |F2|=50, and λ=1 in accordance with an illustrative embodiment.



FIG. 26D shows a recall value comparison with the dataset, |F2|=50, and λ=1 in accordance with an illustrative embodiment.



FIG. 27A shows a training objective function value comparison with a dataset, |F2|=50, and λ=10 in accordance with an illustrative embodiment.



FIG. 27B shows an AUC value comparison with the dataset, |F2|=50, and λ=10 in accordance with an illustrative embodiment.



FIG. 27C shows a precision value comparison with the dataset, |F2|=50, and λ=10 in accordance with an illustrative embodiment.



FIG. 27D shows a recall value comparison with the dataset, |F2|=50, and λ=10 in accordance with an illustrative embodiment.



FIG. 28A shows a training objective function value comparison with a dataset, |F2|=50, and λ=100 in accordance with an illustrative embodiment.



FIG. 28B shows an AUC value comparison with the dataset, |F2|=50, and λ=100 in accordance with an illustrative embodiment.



FIG. 28C shows a precision value comparison with the dataset, |F2|=50, and λ=100 in accordance with an illustrative embodiment.



FIG. 28D shows a recall value comparison with the dataset, |F2|=50, and λ=100 in accordance with an illustrative embodiment.



FIG. 29A shows a training objective function value comparison with a dataset, |F2|=100, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 29B shows an AUC value comparison with the dataset, |F2|=100, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 29C shows a precision value comparison with the dataset, |F2|=100, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 29D shows a recall value comparison with the dataset, |F2|=100, and λ=0.01 in accordance with an illustrative embodiment.



FIG. 30A shows a training objective function value comparison with a dataset, |F2|=100, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 30B shows an AUC value comparison with the dataset, |F2|=100, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 30C shows a precision value comparison with the dataset, |F2|=100, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 30D shows a recall value comparison with the dataset, |F2|=100, and λ=0.1 in accordance with an illustrative embodiment.



FIG. 31A shows a training objective function value comparison with a dataset, |F2|=100, and λ=1 in accordance with an illustrative embodiment.



FIG. 31B shows an AUC value comparison with the dataset, |F2|=100, and λ=1 in accordance with an illustrative embodiment.



FIG. 31C shows a precision value comparison with the dataset, |F2|=100, and λ=1 in accordance with an illustrative embodiment.



FIG. 31D shows a recall value comparison with the dataset, |F2|=100, and λ=1 in accordance with an illustrative embodiment.



FIG. 32A shows a training objective function value comparison with a dataset, |F2|=100, and λ=10 in accordance with an illustrative embodiment.



FIG. 32B shows an AUC value comparison with the dataset, |F2|=100, and λ=10 in accordance with an illustrative embodiment.



FIG. 32C shows a precision value comparison with the dataset, |F2|=100, and λ=10 in accordance with an illustrative embodiment.



FIG. 32D shows a recall value comparison with the dataset, |F2|=100, and λ=10 in accordance with an illustrative embodiment.



FIG. 33A shows a training objective function value comparison with a dataset, |F2|=100, and λ=100 in accordance with an illustrative embodiment.



FIG. 33B shows an AUC value comparison with the dataset, |F2|=100, and λ=100 in accordance with an illustrative embodiment.



FIG. 33C shows a precision value comparison with the dataset, |F2|=100, and λ=100 in accordance with an illustrative embodiment.



FIG. 33D shows a recall value comparison with the dataset, |F2|=100, and λ=100 in accordance with an illustrative embodiment.



FIG. 34 depicts a block diagram of a recommendation system in accordance with an illustrative embodiment.



FIG. 35 depicts a block diagram of a user device of the recommendation system of FIG. 34 in accordance with an illustrative embodiment.



FIG. 36 depicts a flow diagram of examples of operations performed by a selection application of the user device of FIG. 35 in accordance with an illustrative embodiment.



FIG. 37 shows a relative performance between using the recommendation application of FIG. 2 referred to as DTOS and an existing recommendation application referred to as AWLS.





DETAILED DESCRIPTION

Recommendation systems are a technology used ubiquitously in web services including online retailers, video streaming providers, and music streaming providers. From the perspective of users, a recommendation system provides a personalized recommendation by helping users find items of interest such as consumer content such as movies, music, books, etc., consumer products, friends, jobs, etc. From the perspective of items, a recommendation system provides a targeted item by identifying potential users that would be interested in the particular item. The information about users, about items, and about the user's response or feedback to items constitute the data used to achieve the goal of recommendation systems.


The information about users, items, and the users' response to items (aka feedback) constitute the data that are used to achieve the goal of recommendation systems. Among the three types of data, the responses carry essential information about the users' preferences for items. Predicting and ranking a user's preferences on new or future items forms the very basis of making recommendations to the user. The user responses can be provided in various ways, which generally fall into two categories: explicit responses and implicit responses. An explicit response is usually a numeral response on a 1 to 5 scale or a binary feedback such as like/dislike. An implicit response, on the other hand, is the execution of a certain action, such as “purchasing a product” on an online retailer, “watching a movie” on a video streaming service, or “listening to a song” on a music streaming service.


An implicit response, like a binary explicit response, can be represented by a binary variable. Despite their common binary nature, however, the two types of responses have a fundamental distinction: a user could rate an item as “like” or “dislike”; in contrast, a user can buy (or watch, listen to, etc.) a product (or movie, song, etc.), but will generally provide no response when such an action is not executed. In other words, an explicit binary response has both positive and negative samples, but an implicit response generally has only positive samples.


Recommendation systems employing users' responses alone, without requiring the information of users or items, are based on a technique known as collaborative filtering. For m users and n items, the responses can be arranged into an m×n matrix R with Rui representing the response of a user u to an item i. Typically, each user responds to only a fraction of the items and each item receives responses from only a fraction of the users making R an incomplete matrix with only a fraction of entries observed and typically many missing matrix values. In this matrix formulation, the goal of recommendation systems, specifically collaborative filtering, becomes predicting the missing entries of R to locate the interesting items or, conversely, the potential users. A missing matrix value indicates that no response has been received from a respective user relative to a respective item. The formulation has particularly motivated a solution to collaborative filtering based on matrix completion, for both real-valued matrices and binary matrices, where in either case theoretical results have been established for successful matrix reconstruction under certain conditions.


A fundamental assumption for matrix completion is that the matrix in question is of low rank. A difficult method to fulfill the assumption is matrix factorization (MF), which models the user-item responses as a product of two factor matrices, R=XY, where rows of X and columns of Y embed users and items, respectively, into a Euclidean space. R is a response matrix. Rui indicates an entry of the respective matrix with row index u and column index i. X and Y are factor matrices of size m×k and k×n, respectively, with k<<min (m, n) enforcing the low-rank condition.


With matrix factorization, user u is represented by the row vector Xu:, item i is represented by the column vector Y:i, and the response of u to i is explicitly or implicitly represented by the inner product Xu:Y:i, where “:” indicates a universal set. Xu: indicates a uth row of the respective matrix, and Y:i indicates an ith column of the respective matrix. The rows of X can be considered a feature representation of the users and the columns of Y as a feature representation of the items. As they are not observed, but rather are inferred from observed user's responses, these vectors are commonly referred to as latent features or factors. Moreover, the latent features of all users and all items may be inferred simultaneously, making it possible to incorporate the benefit of multitask learning (MTL). By the principle of MTL, the feature vector of each user is not only influenced by its own response history, but also by the response histories of other users, with the extent of influence dictated by a similarity between the users. For this reason, a user may discover new interesting items from the response histories of their peers who share similar interests, with the similarity identified from all users' response histories using learning algorithms. The MF model can be trained on implicit feedback using the AWLS method though ALWS suffers from a high computation cost as discussed previously.


A recommendation application 122 overcomes the drawbacks of AWLS. Recommendation application 122 considers that factor matrices may include fixed columns or rows allowing bias terms and/or linear models to be incorporated into the machine learning model. Some columns of X and/or some rows of Y are predefined and fixed. In addition to offering the convenience of updating bias terms along with the latent factors, the model can be used to incorporate engineered features (as opposed to inferred features) of users or items into collaborative filtering.


Recommendation application 122 converts weights of the squared errors into translations of the target variables, which allows construction of an auxiliary problem whose solution requires a single matrix inversion for all users or items. The solution of the auxiliary problem is used to construct a set of solutions for the original problem, with the solutions parameterized by a step size that is optimized. By optimizing the step-size, recommendation application 122 obtains a solution that is guaranteed to yield an improvement of the learning objective in any given iteration, at a computational cost lower than that of AWLS. With the optimal step size, one iteration of the original problem is solved with only two matrix inversions for all users and items. The per iteration computational cost of recommendation application 122 has a lower-order dependency on k than that of AWLS. Experimental results are described herein to demonstrate the benefits of recommendation application 122 over AWLS in terms of generalization performance and computation time. Recommendation application 122 can be used to train and use recommender models, including collaborative filtering, content-based filtering, content-based collaborative filtering, etc.


Referring to FIG. 1, a block diagram of recommendation device 100 is shown in accordance with an illustrative embodiment. Recommendation device 100 may include an input interface 102, an output interface 104, a communication interface 106, a non-transitory computer-readable medium 108, a processor 110, recommendation application 122, input response data 124, and model parameters 126. Fewer, different, and/or additional components may be incorporated into recommendation device 100.


Input interface 102 provides an interface for receiving information from the user or another device for entry into recommendation device 100 as understood by those skilled in the art. Input interface 102 may interface with various input technologies including, but not limited to, a keyboard 112, a mouse 114, a display 116, a track ball, a keypad, one or more buttons, etc. to allow the user to enter information into recommendation device 100 or to make selections presented in a user interface displayed on display 116.


The same interface may support both input interface 102 and output interface 104. For example, display 116 comprising a touch screen provides a mechanism for user input and for presentation of output to the user. Recommendation device 100 may have one or more input interfaces that use the same or a different input interface technology. The input interface technology further may be accessible by recommendation device 100 through communication interface 106.


Output interface 104 provides an interface for outputting information for review by a user of recommendation device 100 and/or for use by another application or device. For example, output interface 104 may interface with various output technologies including, but not limited to, display 116, a speaker 118, a printer 120, etc. Recommendation device 100 may have one or more output interfaces that use the same or a different output interface technology. The output interface technology further may be accessible by recommendation device 100 through communication interface 106.


Communication interface 106 provides an interface for receiving and transmitting data between devices using various protocols, transmission technologies, and media as understood by those skilled in the art. Communication interface 106 may support communication using various transmission media that may be wired and/or wireless. Recommendation device 100 may have one or more communication interfaces that use the same or a different communication interface technology. For example, recommendation device 100 may support communication using an Ethernet port, a Bluetooth antenna, a telephone jack, a USB port, etc. Data and/or messages may be transferred between recommendation device 100 and another computing device of a distributed computing system 130 using communication interface 106.


Computer-readable medium 108 is an electronic holding place or storage for information so the information can be accessed by processor 110 as understood by those skilled in the art. Computer-readable medium 108 can include, but is not limited to, any type of random access memory (RAM), any type of read only memory (ROM), any type of flash memory, etc. such as magnetic storage devices (e.g., hard disk, floppy disk, magnetic strips, . . . ), optical disks (e.g., compact disc (CD), digital versatile disc (DVD), . . . ), smart cards, flash memory devices, etc. Recommendation device 100 may have one or more computer-readable media that use the same or a different memory media technology. For example, computer-readable medium 108 may include different types of computer-readable media that may be organized hierarchically to provide efficient access to the data stored therein as understood by a person of skill in the art. As an example, a cache may be implemented in a smaller, faster memory that stores copies of data from the most frequently/recently accessed main memory locations to reduce an access latency. Recommendation device 100 also may have one or more drives that support the loading of a memory media such as a CD, DVD, an external hard drive, etc. One or more external hard drives further may be connected to recommendation device 100 using communication interface 106.


Processor 110 executes instructions as understood by those skilled in the art. The instructions may be carried out by a special purpose computer, logic circuits, or hardware circuits. Processor 110 may be implemented in hardware and/or firmware. Processor 110 executes an instruction, meaning it performs/controls the operations called for by that instruction. The term “execution” is the process of running an application or the carrying out of the operation called for by an instruction. The instructions may be written using one or more programming language, scripting language, assembly language, etc. Processor 110 operably couples with input interface 102, with output interface 104, with communication interface 106, and with computer-readable medium 108 to receive, to send, and to process information. Processor 110 may retrieve a set of instructions from a permanent memory device and copy the instructions in an executable form to a temporary memory device that is generally some form of RAM. Recommendation device 100 may include a plurality of processors that use the same or a different processing technology.


Some machine-learning approaches may be more efficiently and speedily executed and processed with machine-learning specific processors (e.g., not a generic central processing unit (CPU)). Such processors may also provide additional energy savings when compared to generic CPUs. For example, some of these processors can include a graphical processing unit, an application-specific integrated circuit, a field-programmable gate array, an artificial intelligence accelerator, a purpose-built chip architecture for machine learning, and/or some other machine-learning specific processor that implements a machine learning approach using semiconductor (e.g., silicon, gallium arsenide) devices. These processors may also be employed in heterogeneous computing architectures with a number of and a variety of different types of cores, engines, nodes, and/or layers to achieve additional various energy efficiencies, processing speed improvements, data communication speed improvements, and/or data efficiency targets and improvements throughout various parts of the system.


Recommendation application 122 performs operations associated with defining model parameters 126 from data stored in input response data 124. Model parameters 126 may be used to provide a recommendation to one or more users regarding one or more items or to provide a recommendation to an entity such as a business offering the one or more items regarding one or more users. Some or all of the operations described herein may be embodied in recommendation application 122. The operations may be implemented using hardware, firmware, software, or any combination of these methods.


Referring to the example embodiment of FIG. 1, recommendation application 122 is implemented in software (comprised of computer-readable and/or computer-executable instructions) stored in computer-readable medium 108 and accessible by processor 110 for execution of the instructions that embody the operations of recommendation application 122. Recommendation application 122 may be written using one or more programming languages, assembly languages, scripting languages, etc. Recommendation application 122 may be integrated with other analytic tools. As an example, recommendation application 122 may be part of an integrated data analytics software application and/or software architecture such as that offered by SAS Institute Inc. of Cary, N.C., USA. Merely for illustration, recommendation application 122 may be implemented using or integrated with one or more SAS software tools such as JMP®, Base SAS, SAS® Enterprise Miner™, SAS® Event Stream Processing, SAS/STAT®, SAS® High Performance Analytics Server, SAS® Visual Data Mining and Machine Learning, SAS® LASR™, SAS® In-Database Products, SAS® Scalable Performance Data Engine, SAS® Cloud Analytic Services (CAS), SAS/OR®, SAS/ETS®, SAS® Visual Analytics, SAS® Viya™, and SAS In-Memory Statistics for Hadoop®, etc. all of which are developed and provided by SAS Institute Inc. of Cary, N.C., USA. Data mining, statistical analytics, and response prediction are practically applied in a wide variety of industries to solve technical problems.


Recommendation application 122 may be implemented as a Web application. For example, recommendation application 122 may be configured to receive hypertext transport protocol (HTTP) responses and to send HTTP requests. The HTTP responses may include web pages such as hypertext markup language (HTML) documents and linked objects generated in response to the HTTP requests. Each web page may be identified by a uniform resource locator (URL) that includes the location or address of the computing device that contains the resource to be accessed in addition to the location of the resource on that computing device. The type of file or resource depends on the Internet application protocol such as the file transfer protocol, HTTP, H.323, etc. The file accessed may be a simple text file, an image file, an audio file, a video file, an executable, a common gateway interface application, a Java applet, an extensible markup language (XML) file, or any other type of file supported by HTTP.


Input response data 124 may include response data captured for a plurality of users and a plurality of items as a function of time. For example, the response data may be a response provided by a user with regard to an item of the plurality of items. The data stored in input response data 124 may be captured at different time points periodically, intermittently, when a response is generated, etc. One or more columns of input response data 124 may include a time and/or date value.


The data stored in input response data 124 may be received directly or indirectly from a user device such as user device 3500 (shown referring to FIG. 29) and may or may not be pre-processed in some manner. For example, the data may be pre-processed using an event stream processor such as the SAS® Event Stream Processing Engine (ESPE), developed and provided by SAS Institute Inc. of Cary, N.C., USA. For example, data stored in input response data 124 may be generated as part of the Internet of Things (IoT), where things (e.g., machines, devices, phones, sensors) can be connected to networks and the data from these things collected and processed within the things and/or external to the things before being stored in input response data 124.


Input response data 124 may be stored on computer-readable medium 108 or on one or more computer-readable media of distributed computing system 130 and accessed by recommendation device 100 using communication interface 106, input interface 102, and/or output interface 104. Input response data 124 may be stored in various compressed formats such as a coordinate format, a compressed sparse column format, a compressed sparse row format, etc. The data may be organized using delimited fields, such as comma or space separated fields, fixed width fields, using a SAS® dataset, etc. The SAS dataset may be a SAS® file stored in a SAS® library that a SAS® software tool creates and processes. The SAS dataset contains data values that are organized as a table of observation vectors (rows) and variables (columns) that can be processed by one or more SAS software tools.


Input response data 124 may be stored using various data structures as known to those skilled in the art including one or more files of a file system, a relational database, one or more tables of a system of tables, a structured query language database, etc. on recommendation device 100 or on distributed computing system 130. Recommendation device 100 may coordinate access to input response data 124 that is distributed across distributed computing system 130 that may include one or more computing devices. For example, input response data 124 may be stored in a cube distributed across a grid of computers as understood by a person of skill in the art. As another example, input response data 124 may be stored in a multi-node Hadoop® cluster. For instance, Apache™ Hadoop® is an open-source software framework for distributed computing supported by the Apache Software Foundation. As another example, input response data 124 may be stored in a cloud of computers and accessed using cloud computing technologies, as understood by a person of skill in the art. The SAS® LASR™ Analytic Server may be used as an analytic platform to enable multiple users to concurrently access data stored in input response data 124. The SAS Viya open, cloud-ready, in-memory architecture also may be used as an analytic platform to enable multiple users to concurrently access data stored in input response data 124. SAS CAS may be used as an analytic server with associated cloud services in SAS Viya. Some systems may use SAS In-Memory Statistics for Hadoop® to read big data once and analyze it several times by persisting it in-memory for the entire session. Some systems may be of other types and configurations.


Referring to FIG. 2, example operations associated with recommendation application 122 are described. Additional, fewer, or different operations may be performed depending on the embodiment of recommendation application 122. The order of presentation of the operations of FIG. 2 is not intended to be limiting. Some of the operations may not be performed in some embodiments. Although some of the operational flows are presented in sequence, the various operations may be performed in various repetitions and/or in other orders than those that are illustrated. For example, a user may execute recommendation application 122, which causes presentation of a first user interface window, which may include a plurality of menus and selectors such as drop-down menus, buttons, text boxes, hyperlinks, etc. associated with recommendation application 122 as understood by a person of skill in the art. The plurality of menus and selectors may be accessed in various orders. An indicator may indicate one or more user selections from a user interface, one or more data entries into a data field of the user interface, one or more data items read from computer-readable medium 108 or otherwise defined with one or more default values, etc. that are received as an input by recommendation application 122. The operations of recommendation application 122 further may be performed in parallel using a plurality of threads and/or a plurality of worker computing devices.


In an operation 200, a first indicator may be received that indicates input response data 124. For example, the first indicator indicates a location and a name of input response data 124. As an example, the first indicator may be received by recommendation application 122 after selection from a user interface window or after entry by a user into a user interface window. In an alternative embodiment, input response data 124 may not be selectable. For example, a most recently created dataset may be used automatically. Input response data 124 is read to define R that is an m×n matrix with Rui representing a response between a user u and an item i, where m is a number of the plurality of users, and n is a number of the plurality of items.


In an operation 202, a second indicator may be received that indicates initial parameter matrices X:P and YQ:. As an example, the second indicator may be received by recommendation application 122 after selection from a user interface window or after entry by a user into a user interface window. In an alternative embodiment, the second indicator may not be received. For example, a default value may be stored, for example, in computer-readable medium 108 and used automatically. In another alternative embodiment, the parameter matrices X:P and YQ: may not be selectable. Instead, fixed, predefined matrices may be used.


Referring to FIG. 3, a general form of MF may be defined using R=XY, where R indicates input response data 124, X indicates a user matrix 300, and Y indicates an items matrix 302. A “*” included in the graphic of input response data 124 indicates an observed response entry where the remaining entries are missing. User matrix 300 can be defined as X=[X:F1, X:F2, X:F3], and items matrix 302 can be defined as Y=[YF1:, YF2:, YF3:], where F1, F2 and F3 form a partition F1∪F2∪F3={1, 2, . . . , |F1|+|F2|+|F3|} meaning F1, F2 and F3 are mutually exclusive, where |F1| indicates a cardinality of a respective set such as F1. X:F1, X:F2, X:F3 are submatrices of X obtained by extracting the rows indexed by the elements of F1, F2 and F3, respectively, and YF1:, YF2:YF3: are submatrices of Y obtained by extracting the rows indexed by the elements of F1, F2 and F3, where F1, F2 and F3 are sets of integers. The partition results in a three-term representation of R defined using






R=X
:F

1

Y
F

1

:
+X
:F

2

Y
F

2

:
+X
:F

3

Y
F

3

:.


Without loss of generality, it is assumed that k1<k2<k3 for any k1∈F1, k2∈F2, and k3∈F3. This can be satisfied by shuffling the columns of X and the rows of Y appropriately. Each term is a sub-model. The first term X:F1YF1: is a linear regression model, with X:F1 the predefined user factors 304, and YF1: the associated item regression parameters 314 for the predefined user factors 304. The second term X:F2YF2: is a standard MF model, with X:F2 the latent user factors 308 of the users and YF2: the latent item factors 310 of the items. The third term X:F3YF3: is a linear regression model, with YF3: the predefined item factors 306 and X:F3 the associated user regression parameters 312 for the predefined item factors 306.


X:F1 and/or YF3: are predefined and fixed resulting in a model with partially defined factors. Bias terms and/or linear models may be incorporated into the MF model and their definition adjusted during training. R=XY=X:F1YF1:+X:F2YF2:+X:F3YF3: can be learned in the same way MF is learned, except for additional notations used to designate adjustable factors versus nonadjustable factors X:F1 and YF3:. Use of R=XY=X:F1YF1:+X:F2YF2:+X:F3YF3:, referred to as MF-PDF, has the practical advantage of updating bias terms along with the latent factors and can be used to incorporate engineered features (as opposed to inferred features) of users or items into collaborative filtering.


When |F1|=F31=0, the model is a standard MF model. In an illustrative embodiment, |F1|=F31=1 with X:F1 a column vector of all one's and YF3: a row vector of all ones. In this special case, the regression parameters X:F3 become the biases of the users and YF1: the biases of the items. In alternative embodiments, X:F1 and YF3: can be used to hold engineered features of users and items, respectively.


Although MF-PDF retains the basic structure of MF, MF-PDF has an important difference from the standard MF model: the two matrices X and Y are only partially adjustable and the adjustable part of X is not perfectly aligned with that of Y. More specifically, X:P can be defined as the adjustable part of X while YQ: can be defined as the adjustable part of Y, where P=F2∪F3 and Q=F1∪F2. P≠Q unless |F1|=|F3|=0. Assuming, |F1| or |F3|≠0, X:P and YQ: constitute the parameters of MF-PDF that are to be estimated. F1 and F3 store the indices for a linear model on user or item features. F2 stores indices for latent factors in X and Y.


Like F1, F2 and F3, P and Q are sets of integers. For notation, Ru: indicates a uth row of R, R:i indicates an ith column of R, X:F1 is a sub-matrix of X obtained by extracting the columns indexed by the elements of F1, YF2: is a sub-matrix of Y obtained by extracting the rows indexed by the elements of F2,XuP indicates a uth row of X:P, and YPi indicates an ith column of YP:.


An implicit response Rui can either be labeled as “1” or unlabeled. The label “0” is generally not observable as user u is typically silent when not issuing a positive signal. Therefore, collaborative filtering with implicit feedback is a PU-learning problem (learning with positive and unlabeled samples). To process unlabeled samples, the unlabeled samples can be treated as negative, but deemphasized using an appropriate weighting strategy as described in the Hu paper. Specifically, for any (u, i), Rui∈{0,1} is treated as a binary variable, with Rui=1 indicating that user u has issued a positive response to item i, and Rui=0 indicating that the user u has not responded to the item i and may not be interested in the item i.


Each sample is assigned a weight Wui=1+γCui, where γ>0 is a normalizing constant and Cui measures the confidence about, or the importance of, Rui, with Cui=0 when Rui=0, and Cui>0 for Rui=1. Because γ can be absorbed into Cui, γ=1 for simplicity. To construct the weights Wui, the negative samples are uniformly deemphasized to reflect the fact that silent responses only indicate potential negativity rather than definite negativity. On the other hand, a positive sample Rui can also be associated with a small confidence if its positivity is uncertain. For example, user u may have purchased item i as a gift meaning the positivity of Rui may need to be discounted.


As described in the Hu paper, the PU-learning objective, as applied to the MF-PDF model is given by g(X:P,YQ:)=Σu,iWui(Rui−Xu:Y:i)2+λ(∥X:P2+∥YQ:2), where ∥X:P∥ indicates a Frobenius norm of a respective matrix such as X:P, and λ indicates a regularization parameter that controls a trade-off between the weighted-error term, Wui(Rui−Xu:Y:i)2, and the L2 regularization terms, ∥X:P2+∥YQ:2.


Referring again to FIG. 2, in an operation 204, a third indicator of a regularization parameter value λ may be received. As an example, the third indicator may be received by recommendation application 122 after selection from a user interface window or after entry by a user into a user interface window. In an alternative embodiment, the third indicator may not be received. For example, a default value may be stored, for example, in computer-readable medium 108 and used automatically. In another alternative embodiment, the value of the regularization parameter value λ may not be selectable. Instead, a fixed, predefined value may be used. For illustration, a default value of the regularization parameter value λ may be λ=0.01 though other values may be used subject to 0<λ<∞.


In an operation 205, a fourth indicator of a confidence computation method may be received. As an example, a confidence computation method may be selected from “Popularity”, “Time”, “Quantity”, etc. In an alternative embodiment, the fourth indicator may not be received. For example, a default confidence computation method may be used automatically and/or may not be selectable. Instead, a predefined confidence computation method may be used. For illustration, a default confidence computation method may be “Popularity” if one is not indicated using the fourth indicator. Of course, the confidence computation method may be labeled or selected in a variety of different manners by the user as understood by a person of skill in the art. For illustration, using the “Popularity” method, the weights are computed based on user popularity and item popularity, i.e., Wui=1+ξui, where ξu=|{i: Rui=1, (u, i)∈training dataset}| or a number of items with Rui=1, and ζi=|{u: Rui=1, (u, i)∈training dataset}| or a number of users with Rui=1. For illustration, using the “Time” method, the weights are computed based on an amount of time that user u spent watching or listening to an item i, i.e., Wui=ρCui, where ρ is a normalizing constant with ρ>0, and Cui is the amount of time that user u spent watching or listening to item i, Cui≥0. For illustration, using the “Quantity” method, the weights are computed based on a number of times that user u purchased an item i in a single transaction or during a predefined period of time, i.e., Wui=1+Cui, where Cui is the number of times that user u purchased an item i in a single transaction or during a predefined period of time.


In an operation 206, a fifth indicator of one or more convergence parameter values may be received. For illustration, the one or more convergence parameter values may include one or more of a maximum number of iterations Tx, a first convergence threshold value cT1, and a second convergence threshold value cT2. The first convergence threshold value cT1 may indicate a threshold value for an objective function, and second convergence threshold value cT2 may indicate a threshold value for a change in a value of the objective function. In an alternative embodiment, the fourth indicator may not be received. For example, default value(s) may be stored, for example, in computer-readable medium 108 and used automatically. In another alternative embodiment, the value(s) of the maximum number of iterations Tx, the first convergence threshold value cT1, and/or the second convergence threshold value cT2 may not be selectable. Instead, a fixed, predefined value(s) may be used. For illustration, a default value for the maximum number of iterations Tx may be Tx=100 though other values may be used. For illustration, a default value for the first convergence threshold value cT1 may be cT1=0.1 though other values may be used. For illustration, a default value for the second convergence threshold value cT2 may be cT2=0.01 though other values may be used.


In an operation 208, an iteration counter t is initialized, for example, using t=0, when the maximum number of iterations Tx is used as part of a convergence test.


In an operation 209, a confidence matrix Δui and a confidence squared matrix Δui2 are computed, for example, using Δui=√{square root over (Wui)}−1, and Δui2, respectively, where Wui is computed using the confidence computation method indicated in operation 205. Based on this, the objective function is modified as g(X:P, YQ:)=Σu,i[(Δui+1)(Rui−Xu:Y:i)]2+λ(∥X:P2+∥YQ:2) to convert the weights on squared errors into translations of the target variables. The objective function is minimized by updating X:P with YQ: and then updating YQ: with X:P fixed.


In an operation 210, a first direction matrix D is updated using D=([Δuiº(R−XY)+R]YP:T−XYY:PT−λX:P)(λI+YP:YP:T)−1, where º indicates a Hadamard or element-wise product of two matrices, X=[X:P,X:P], Y=[YQ:, YQ:], P indicates a complement of the respective matrix such as P, I is an identity matrix having dimension (|F2|+|F3|) by (|F2|+|F3|), T indicates a transpose, and the first direction matrix D has dimension m by (|F2|+|F3|). X:Pholds the predefined user factors such as a column of m ones, and YQ: holds the predefined item factors such as a row of n ones.


In an operation 212, a first α parameter value α1 is updated using α0=∥DYP:2+λ∥D∥2 and α10Δui≠0uiDu:YPi)(Δui+1)(Rui−Xu:Y:i), where ∥DYP:2+λ∥D∥2=tr(DTDYp:YP:T)+λtr(DTD), and tr indicates a trace.


In an operation 214, a first β parameter value β1 is updated using β10Δui≠0ui2+2Δui)(Du:YPi)2.


In an operation 216, the parameter matrix X:P is updated using X:P=X:P1D, where η1 is a first step-size parameter value computed using







η
1

=



α
1


β
1




1
.






In an operation 218, a second direction matrix Z is updated using Z=(λI+X:QTX:Q)−1[X:QTuiº(R−XY)+R]−X:QTXY−λYQ:], where the second direction matrix Z has dimension (|F1|+|F2|) by n.


In an operation 220, a second α parameter value α is updated using α0=∥X:QZ∥2+λ∥Z∥2 and α20Δui≠0uiXuQZ:i)(Δui+1)(Rui−Xu:Y:i), where ∥X:QZ∥2+λ∥Z∥2=tr(X:QTX:QZZT)+λtr(ZZT).


In an operation 222, a second β parameter value β2 is updated using β20Δui≠0ui2+2Δui)(XuQZ:i)2.


In an operation 224, the parameter matrix YQ: is updated using YQ:=YQ:2Z, where η2 is a second step-size parameter value computed using







η
2

=



α
2


β
2




1
.






In an operation 226, an objective function value g is updated using g=∥(Δui+J)∘(R−XY)2+λ(∥X:P2+YQ:2), where J indicates an m×n matrix of all ones.


In an operation 228, the iteration counter t is incremented, for example, using t=t+1 when the maximum number of iterations Tx is used as part of the convergence test. When the second convergence threshold value cT2 is used as part of the convergence test, a second convergence parameter is computed using c2=g−g′, where g′ is the objective function value from a previous iteration of 226.


In an operation 230, a determination is made concerning whether the parameter matrices X:P and YQ: have converged. When the parameter matrices X:P and YQ: have converged, processing continues in an operation 232. When the parameter matrices X:P and YQ: have not converged, processing continues in operation 210. For illustration, the parameter matrices X:P and YQ: have converged when t>Tx, and/or when g<cT1, and/or when c2<cT2 depending on which of the one or more convergence parameters is selected for use in operation 206.


In operation 232, the parameter matrices X:P and YQ: are output. For example, the parameter matrices X:P and YQ: may be output to model parameters 126. The predefined user factors 304, X:F1, the predefined item factors 306, YF3:, the associated user regression parameters 312 for the predefined item factors 306, X:F3, and the associated item regression parameters 314 for the predefined user factors 304, YF1:, further may be output. In addition, or in the alternative, a predicted response matrix XY=X:F1YF1:+X:PYP:=X:F3YF3:+X:QYQ: further may be output.


The MovieLens-1M dataset was used to perform a comparative study between recommendation application 122, also referred to herein as DTOS, and AWLS in terms of the speed of learning convergence and the generalization performance. Both algorithms were implemented in Python and executed on the same machine in all of the experiments. The second dataset included 1,000,209 responses of n=3706 movies from m=6040 users resulting in R being a 6040×3706 matrix. The experimental setup described in a paper by Wang et al., titled RippleNet: Propagating User Preferences on the Knowledge Graph for Recommender Systems published In Proceedings of the 27th ACM International Conference on Information and Knowledge Management pages 417-426 in 2018 (RippleNet) was used to make the results comparable.


The explicit responses in the original dataset were transformed into implicit responses using the following steps: (i) each explicit response (numerical response on the scale of 1 to 5) was converted into a positive response Rui=1 if Rui≥4; (ii) all remaining explicit responses were discarded; (iii) for each user, a subset of the negative responses equal in size to the positive ones was drawn from an unlabeled set and labelled as Rui=0 to create an implicit feedback dataset with perfectly-balanced positive and negative samples per user. The implicit feedback dataset was randomly split into training, test and validation datasets, with the ratio 60%, 20%, and 20%, respectively.


The negative responses in the training dataset were not used by either algorithm because the PU-learning objective uses all of the unlabeled entries in R as negative responses, assigning them small weights to counteract their dominance in quantity over positive responses. However, the negative responses in the test and validation datasets were needed as certain performance metrics such as area under ROC curve (AUC) require true negatives.


In addition to AUC, precision and recall were computed as performance measures. For each user u, the precision and recall were computed by ranking the full list of items contained in the training dataset (regardless of users), only excluding the items that u had responded to.


The PU-learning objective has two major hyperparameters: F2 and A assuming that |F1|=|F3|=1. Because |P|=|Q|=|F2|+1 in this case, F2 heavily influences the computational time of DTOS and AWLS. Because DTOS and AWLS optimize the same objective function, a fair comparison of them requires the same hyperparameter values. For this reason, the hyperparameters were not tuned and the validation dataset was not used. Instead, |F2|=5, 10, 20, 30, 50, and 100 and λ=0.01, 0.1, 1, 10, and 100 were each evaluated in combination.


In all of the experiments, the weights were computed based on user popularity and item popularity, i.e., Wui=1+ξui, where ξu=|{i: Rui=1, (u, i)∈training dataset}| and (u=I{u: Rui=1, (u, i)∈training dataset}|. For each combination of |F2| and λ, five independent experiments using DTOS and ALWS were performed on the original MovieLens-1M dataset. In each experiment, the following steps were performed: (a) convert the original dataset into an implicit feedback dataset using the three steps (i), (ii), and (iii) above; (b) split the converted dataset into training, test, and validation datasets with the ratio 60%, 20%, and 20%, respectively; (c) run DTOS for 101 iterations and AWLS for 11 iterations on the training dataset, with the models in iterations 0 through 10 recorded for AWLS and the models in iterations {0, 5, 10, 15, 20, 25, 30, 40, 50, 70, 100} recorded for DTOS; (d) score each recorded model to obtain the AUC as a function of the respective training iteration; and (e) score the model from the last iteration to obtain the precision and recall for K={1, 2, 5, 10, 20, 50, 100}. The models at iteration zero were the initial models and were common for the two methods.


The results are summarized in FIGS. 4A through 33D, where each curve shows the mean values across the five runs. Referring to FIG. 4A, a comparison of a training objective function as a function of time is shown for |F2|=5, and λ=0.01. A first curve 400 was generated using recommendation application 122, and a second curve 401 was generated using AWLS. Referring to FIG. 4B, an AUC value as a function of time is shown for |F2|=5, and λ=0.01. A third curve 410 was generated using recommendation application 122, and a fourth curve 411 was generated using AWLS. In terms of computation time, 100 iterations of DTOS were complete before the first iteration of AWLS. In fact, for all of the combinations |F2|=5, 10, 20, 30, 50, and 100 and λ=0.01, 0.1, 1, 10, and 100, 100 iterations of DTOS were complete before the first iteration of AWLS.


Referring to FIG. 4C, a precision value as a function of time is shown for |F2|=5, and λ=0.01. A fifth curve 420 was generated using recommendation application 122, and a sixth curve 421 was generated using AWLS. Referring to FIG. 4D, a recall value as a function of time is shown for |F2|=5, and λ=0.01. A seventh curve 430 was generated using recommendation application 122, and an eighth curve 431 was generated using AWLS.


Referring to FIG. 5A, a comparison of a training objective function as a function of time is shown for |F2|=5, and λ=0.1. A first curve 500 was generated using recommendation application 122, and a second curve 501 was generated using AWLS. Referring to FIG. 5B, an AUC value as a function of time is shown for |F2|=5, and λ=0.1. A third curve 510 was generated using recommendation application 122, and a fourth curve 511 was generated using AWLS. Referring to FIG. 5C, a precision value as a function of time is shown for |F2|=5, and λ=0.1. A fifth curve 520 was generated using recommendation application 122, and a sixth curve 521 was generated using AWLS. Referring to FIG. 5D, a recall value as a function of time is shown for |F2|=5, and λ=0.1. A seventh curve 530 was generated using recommendation application 122, and an eighth curve 531 was generated using AWLS.


Referring to FIG. 6A, a comparison of a training objective function as a function of time is shown for |F2|=5, and λ=1. A first curve 600 was generated using recommendation application 122, and a second curve 601 was generated using AWLS. Referring to FIG. 6B, an AUC value as a function of time is shown for |F2|=5, and λ=1. A third curve 610 was generated using recommendation application 122, and a fourth curve 611 was generated using AWLS. Referring to FIG. 6C, a precision value as a function of time is shown for |F2|=5, and λ=1. A fifth curve 620 was generated using recommendation application 122, and a sixth curve 621 was generated using AWLS. Referring to FIG. 6D, a recall value as a function of time is shown for |F2|=5, and λ=1. A seventh curve 630 was generated using recommendation application 122, and an eighth curve 631 was generated using AWLS.


Referring to FIG. 7A, a comparison of a training objective function as a function of time is shown for |F2|=5, and λ=10. A first curve 700 was generated using recommendation application 122, and a second curve 701 was generated using AWLS. Referring to FIG. 7B, an AUC value as a function of time is shown for |F2|=5, and λ=10. A third curve 710 was generated using recommendation application 122, and a fourth curve 711 was generated using AWLS. Referring to FIG. 7C, a precision value as a function of time is shown for |F2|=5, and λ=10. A fifth curve 720 was generated using recommendation application 122, and a sixth curve 721 was generated using AWLS. Referring to FIG. 7D, a recall value as a function of time is shown for |F2|=5, and λ=10. A seventh curve 730 was generated using recommendation application 122, and an eighth curve 731 was generated using AWLS.


Referring to FIG. 8A, a comparison of a training objective function as a function of time is shown for |F2|=5, and λ=100. A first curve 800 was generated using recommendation application 122, and a second curve 801 was generated using AWLS. Referring to FIG. 8B, an AUC value as a function of time is shown for |F2|=5, and λ=100. A third curve 810 was generated using recommendation application 122, and a fourth curve 811 was generated using AWLS. Referring to FIG. 8C, a precision value as a function of time is shown for |F2|=5, and λ=100. A fifth curve 820 was generated using recommendation application 122, and a sixth curve 821 was generated using AWLS. Referring to FIG. 8D, a recall value as a function of time is shown for |F2|=5, and λ=100. A seventh curve 830 was generated using recommendation application 122, and an eighth curve 831 was generated using AWLS.


Referring to FIG. 9A, a comparison of a training objective function as a function of time is shown for |F2|=10, and λ=0.01. A first curve 900 was generated using recommendation application 122, and a second curve 901 was generated using AWLS. Referring to FIG. 9B, an AUC value as a function of time is shown for |F2|=10, and λ=0.01. A third curve 910 was generated using recommendation application 122, and a fourth curve 911 was generated using AWLS. Referring to FIG. 9C, a precision value as a function of time is shown for |F2|=10, and λ=0.01. A fifth curve 920 was generated using recommendation application 122, and a sixth curve 921 was generated using AWLS. Referring to FIG. 9D, a recall value as a function of time is shown for |F2|=10, and λ=0.01. A seventh curve 930 was generated using recommendation application 122, and an eighth curve 931 was generated using AWLS.


Referring to FIG. 10A, a comparison of a training objective function as a function of time is shown for |F2|=10, and λ=0.1. A first curve 1000 was generated using recommendation application 122, and a second curve 1001 was generated using AWLS. Referring to FIG. 10B, an AUC value as a function of time is shown for |F2|=10, and λ=0.1. A third curve 1010 was generated using recommendation application 122, and a fourth curve 1011 was generated using AWLS. Referring to FIG. 10C, a precision value as a function of time is shown for |F2|=10, and λ=0.1. A fifth curve 1020 was generated using recommendation application 122, and a sixth curve 1021 was generated using AWLS. Referring to FIG. 10D, a recall value as a function of time is shown for |F2|=10, and λ=0.1. A seventh curve 1030 was generated using recommendation application 122, and an eighth curve 1031 was generated using AWLS.


Referring to FIG. 11A, a comparison of a training objective function as a function of time is shown for |F2|=10, and λ=1. A first curve 1100 was generated using recommendation application 122, and a second curve 1101 was generated using AWLS. Referring to FIG. 11B, an AUC value as a function of time is shown for |F2|=10, and λ=1. A third curve 1110 was generated using recommendation application 122, and a fourth curve 1111 was generated using AWLS. Referring to FIG. 11C, a precision value as a function of time is shown for |F2|=10, and λ=1. A fifth curve 1120 was generated using recommendation application 122, and a sixth curve 1121 was generated using AWLS. Referring to FIG. 11D, a recall value as a function of time is shown for |F2|=10, and λ=1. A seventh curve 1130 was generated using recommendation application 122, and an eighth curve 1131 was generated using AWLS.


Referring to FIG. 12A, a comparison of a training objective function as a function of time is shown for |F2|=10, and λ=10. A first curve 1200 was generated using recommendation application 122, and a second curve 1201 was generated using AWLS. Referring to FIG. 12B, an AUC value as a function of time is shown for |F2|=10, and λ=10. A third curve 1210 was generated using recommendation application 122, and a fourth curve 1211 was generated using AWLS. Referring to FIG. 12C, a precision value as a function of time is shown for |F2|=10, and λ=10. A fifth curve 1220 was generated using recommendation application 122, and a sixth curve 1221 was generated using AWLS. Referring to FIG. 12D, a recall value as a function of time is shown for |F2|=10, and λ=10. A seventh curve 1230 was generated using recommendation application 122, and an eighth curve 1231 was generated using AWLS.


Referring to FIG. 13A, a comparison of a training objective function as a function of time is shown for |F2|=10, and λ=100. A first curve 1300 was generated using recommendation application 122, and a second curve 1301 was generated using AWLS. Referring to FIG. 13B, an AUC value as a function of time is shown for |F2|=10, and λ=100. A third curve 1310 was generated using recommendation application 122, and a fourth curve 1311 was generated using AWLS. Referring to FIG. 13C, a precision value as a function of time is shown for |F2|=10, and λ=100. A fifth curve 1320 was generated using recommendation application 122, and a sixth curve 1321 was generated using AWLS. Referring to FIG. 13D, a recall value as a function of time is shown for |F2|=10, and λ=100. A seventh curve 1330 was generated using recommendation application 122, and an eighth curve 1331 was generated using AWLS.


Referring to FIG. 14A, a comparison of a training objective function as a function of time is shown for |F2|=20, and λ=0.01. A first curve 1400 was generated using recommendation application 122, and a second curve 1401 was generated using AWLS. Referring to FIG. 14B, an AUC value as a function of time is shown for |F2|=20, and λ=0.01. A third curve 1410 was generated using recommendation application 122, and a fourth curve 1411 was generated using AWLS. Referring to FIG. 14C, a precision value as a function of time is shown for |F2|=20, and λ=0.01. A fifth curve 1420 was generated using recommendation application 122, and a sixth curve 1421 was generated using AWLS. Referring to FIG. 14D, a recall value as a function of time is shown for |F2|=20, and λ=0.01. A seventh curve 1430 was generated using recommendation application 122, and an eighth curve 1431 was generated using AWLS.


Referring to FIG. 15A, a comparison of a training objective function as a function of time is shown for |F2|=20, and λ=0.1. A first curve 1500 was generated using recommendation application 122, and a second curve 1501 was generated using AWLS. Referring to FIG. 15B, an AUC value as a function of time is shown for |F2|=20, and λ=0.1. A third curve 1510 was generated using recommendation application 122, and a fourth curve 1511 was generated using AWLS. Referring to FIG. 15C, a precision value as a function of time is shown for |F2|=20, and λ=0.1. A fifth curve 1520 was generated using recommendation application 122, and a sixth curve 1521 was generated using AWLS. Referring to FIG. 15D, a recall value as a function of time is shown for |F2|=20, and λ=0.1. A seventh curve 1530 was generated using recommendation application 122, and an eighth curve 1531 was generated using AWLS.


Referring to FIG. 16A, a comparison of a training objective function as a function of time is shown for |F2|=20, and λ=1. A first curve 1600 was generated using recommendation application 122, and a second curve 1601 was generated using AWLS. Referring to FIG. 16B, an AUC value as a function of time is shown for |F2|=20, and λ=1. A third curve 1610 was generated using recommendation application 122, and a fourth curve 1611 was generated using AWLS. Referring to FIG. 16C, a precision value as a function of time is shown for |F2|=20, and λ=1. A fifth curve 1620 was generated using recommendation application 122, and a sixth curve 1621 was generated using AWLS. Referring to FIG. 16D, a recall value as a function of time is shown for |F2|=20, and λ=1. A seventh curve 1630 was generated using recommendation application 122, and an eighth curve 1631 was generated using AWLS.


Referring to FIG. 17A, a comparison of a training objective function as a function of time is shown for |F2|=20, and λ=10. A first curve 1700 was generated using recommendation application 122, and a second curve 1701 was generated using AWLS. Referring to FIG. 17B, an AUC value as a function of time is shown for |F2|=20, and λ=10. A third curve 1710 was generated using recommendation application 122, and a fourth curve 1711 was generated using AWLS. Referring to FIG. 17C, a precision value as a function of time is shown for |F2|=20, and λ=10. A fifth curve 1720 was generated using recommendation application 122, and a sixth curve 1721 was generated using AWLS. Referring to FIG. 17D, a recall value as a function of time is shown for |F2|=20, and λ=10. A seventh curve 1730 was generated using recommendation application 122, and an eighth curve 1731 was generated using AWLS.


Referring to FIG. 18A, a comparison of a training objective function as a function of time is shown for |F2|=20, and λ=100. A first curve 1800 was generated using recommendation application 122, and a second curve 1801 was generated using AWLS. Referring to FIG. 18B, an AUC value as a function of time is shown for |F2|=20, and λ=100. A third curve 1810 was generated using recommendation application 122, and a fourth curve 1811 was generated using AWLS. Referring to FIG. 18C, a precision value as a function of time is shown for |F2|=20, and λ=100. A fifth curve 1820 was generated using recommendation application 122, and a sixth curve 1821 was generated using AWLS. Referring to FIG. 18D, a recall value as a function of time is shown for |F2|=20, and λ=100. A seventh curve 1830 was generated using recommendation application 122, and an eighth curve 1831 was generated using AWLS.


Referring to FIG. 19A, a comparison of a training objective function as a function of time is shown for |F2|=30, and λ=0.01. A first curve 1900 was generated using recommendation application 122, and a second curve 1901 was generated using AWLS. Referring to FIG. 19B, an AUC value as a function of time is shown for |F2|=30, and λ=0.01. A third curve 1910 was generated using recommendation application 122, and a fourth curve 1911 was generated using AWLS. Referring to FIG. 19C, a precision value as a function of time is shown for |F2|=30, and λ=0.01. A fifth curve 1920 was generated using recommendation application 122, and a sixth curve 1921 was generated using AWLS. Referring to FIG. 19D, a recall value as a function of time is shown for |F2|=30, and λ=0.01. A seventh curve 1930 was generated using recommendation application 122, and an eighth curve 1931 was generated using AWLS.


Referring to FIG. 20A, a comparison of a training objective function as a function of time is shown for |F2|=30, and λ=0.1. A first curve 2000 was generated using recommendation application 122, and a second curve 2001 was generated using AWLS. Referring to FIG. 20B, an AUC value as a function of time is shown for |F2|=30, and λ=0.1. A third curve 2010 was generated using recommendation application 122, and a fourth curve 2011 was generated using AWLS. Referring to FIG. 20C, a precision value as a function of time is shown for |F2|=30, and λ=0.1. A fifth curve 2020 was generated using recommendation application 122, and a sixth curve 2021 was generated using AWLS. Referring to FIG. 20D, a recall value as a function of time is shown for |F2|=30, and λ=0.1. A seventh curve 2030 was generated using recommendation application 122, and an eighth curve 2031 was generated using AWLS.


Referring to FIG. 21A, a comparison of a training objective function as a function of time is shown for |F2|=30, and λ=1. A first curve 2100 was generated using recommendation application 122, and a second curve 2101 was generated using AWLS. Referring to FIG. 21B, an AUC value as a function of time is shown for |F2|=30, and λ=1. A third curve 2110 was generated using recommendation application 122, and a fourth curve 2111 was generated using AWLS. Referring to FIG. 21C, a precision value as a function of time is shown for |F2|=30, and λ=1. A fifth curve 2120 was generated using recommendation application 122, and a sixth curve 2121 was generated using AWLS. Referring to FIG. 21D, a recall value as a function of time is shown for |F2|=30, and λ=1. A seventh curve 2130 was generated using recommendation application 122, and an eighth curve 2131 was generated using AWLS.


Referring to FIG. 22A, a comparison of a training objective function as a function of time is shown for |F2|=30, and λ=10. A first curve 2200 was generated using recommendation application 122, and a second curve 2201 was generated using AWLS. Referring to FIG. 22B, an AUC value as a function of time is shown for |F2|=30, and λ=10. A third curve 2210 was generated using recommendation application 122, and a fourth curve 2211 was generated using AWLS. Referring to FIG. 22C, a precision value as a function of time is shown for |F2|=30, and λ=10. A fifth curve 2220 was generated using recommendation application 122, and a sixth curve 2221 was generated using AWLS. Referring to FIG. 22D, a recall value as a function of time is shown for |F2|=30, and λ=10. A seventh curve 2230 was generated using recommendation application 122, and an eighth curve 2231 was generated using AWLS.


Referring to FIG. 23A, a comparison of a training objective function as a function of time is shown for |F2|=30, and λ=100. A first curve 2300 was generated using recommendation application 122, and a second curve 2301 was generated using AWLS. Referring to FIG. 23B, an AUC value as a function of time is shown for |F2|=30, and λ=100. A third curve 2310 was generated using recommendation application 122, and a fourth curve 2311 was generated using AWLS. Referring to FIG. 23C, a precision value as a function of time is shown for |F2|=30, and λ=100. A fifth curve 2320 was generated using recommendation application 122, and a sixth curve 2321 was generated using AWLS. Referring to FIG. 23D, a recall value as a function of time is shown for |F2|=30, and λ=100. A seventh curve 2330 was generated using recommendation application 122, and an eighth curve 2331 was generated using AWLS.


Referring to FIG. 24A, a comparison of a training objective function as a function of time is shown for |F2|=50, and λ=0.01. A first curve 2400 was generated using recommendation application 122, and a second curve 2401 was generated using AWLS. Referring to FIG. 24B, an AUC value as a function of time is shown for |F2|=50, and λ=0.01. A third curve 2410 was generated using recommendation application 122, and a fourth curve 2411 was generated using AWLS. Referring to FIG. 24C, a precision value as a function of time is shown for |F2|=50, and λ=0.01. A fifth curve 2420 was generated using recommendation application 122, and a sixth curve 2421 was generated using AWLS. Referring to FIG. 24D, a recall value as a function of time is shown for |F2|=50, and λ=0.01. A seventh curve 2430 was generated using recommendation application 122, and an eighth curve 2431 was generated using AWLS.


Referring to FIG. 25A, a comparison of a training objective function as a function of time is shown for |F2|=50, and λ=0.1. A first curve 2500 was generated using recommendation application 122, and a second curve 2501 was generated using AWLS. Referring to FIG. 25B, an AUC value as a function of time is shown for |F2|=50, and λ=0.1. A third curve 2510 was generated using recommendation application 122, and a fourth curve 2511 was generated using AWLS. Referring to FIG. 25C, a precision value as a function of time is shown for |F2|=50, and λ=0.1. A fifth curve 2520 was generated using recommendation application 122, and a sixth curve 2521 was generated using AWLS. Referring to FIG. 25D, a recall value as a function of time is shown for |F2|=50, and λ=0.1. A seventh curve 2530 was generated using recommendation application 122, and an eighth curve 2531 was generated using AWLS.


Referring to FIG. 26A, a comparison of a training objective function as a function of time is shown for |F2|=50, and λ=1. A first curve 2600 was generated using recommendation application 122, and a second curve 2601 was generated using AWLS. Referring to FIG. 26B, an AUC value as a function of time is shown for |F2|=50, and λ=1. A third curve 2610 was generated using recommendation application 122, and a fourth curve 2611 was generated using AWLS. Referring to FIG. 26C, a precision value as a function of time is shown for |F2|=50, and λ=1. A fifth curve 2620 was generated using recommendation application 122, and a sixth curve 2621 was generated using AWLS. Referring to FIG. 26D, a recall value as a function of time is shown for |F2|=50, and λ=1. A seventh curve 2630 was generated using recommendation application 122, and an eighth curve 2631 was generated using AWLS.


Referring to FIG. 27A, a comparison of a training objective function as a function of time is shown for |F2|=50, and λ=10. A first curve 2700 was generated using recommendation application 122, and a second curve 2701 was generated using AWLS. Referring to FIG. 27B, an AUC value as a function of time is shown for |F2|=50, and λ=10. A third curve 2710 was generated using recommendation application 122, and a fourth curve 2711 was generated using AWLS. Referring to FIG. 27C, a precision value as a function of time is shown for |F2|=50, and λ=10. A fifth curve 2720 was generated using recommendation application 122, and a sixth curve 2721 was generated using AWLS. Referring to FIG. 27D, a recall value as a function of time is shown for |F2|=50, and λ=10. A seventh curve 2730 was generated using recommendation application 122, and an eighth curve 2731 was generated using AWLS.


Referring to FIG. 28A, a comparison of a training objective function as a function of time is shown for |F2|=50, and λ=100. A first curve 2800 was generated using recommendation application 122, and a second curve 2801 was generated using AWLS. Referring to FIG. 28B, an AUC value as a function of time is shown for |F2|=50, and λ=100. A third curve 2810 was generated using recommendation application 122, and a fourth curve 2811 was generated using AWLS. Referring to FIG. 28C, a precision value as a function of time is shown for |F2|=50, and λ=100. A fifth curve 2820 was generated using recommendation application 122, and a sixth curve 2821 was generated using AWLS. Referring to FIG. 28D, a recall value as a function of time is shown for |F2|=50, and λ=100. A seventh curve 2830 was generated using recommendation application 122, and an eighth curve 2831 was generated using AWLS.


Referring to FIG. 29A, a comparison of a training objective function as a function of time is shown for |F2|=100, and λ=0.01. A first curve 2900 was generated using recommendation application 122, and a second curve 2901 was generated using AWLS. Referring to FIG. 29B, an AUC value as a function of time is shown for |F2|=100, and λ=0.01. A third curve 2910 was generated using recommendation application 122, and a fourth curve 2911 was generated using AWLS. Referring to FIG. 29C, a precision value as a function of time is shown for |F2|=100, and λ=0.01. A fifth curve 2920 was generated using recommendation application 122, and a sixth curve 2921 was generated using AWLS. Referring to FIG. 29D, a recall value as a function of time is shown for |F2|=100, and λ=0.01. A seventh curve 2930 was generated using recommendation application 122, and an eighth curve 2931 was generated using AWLS.


Referring to FIG. 30A, a comparison of a training objective function as a function of time is shown for |F2|=100, and λ=0.1. A first curve 3000 was generated using recommendation application 122, and a second curve 3001 was generated using AWLS. Referring to FIG. 30B, an AUC value as a function of time is shown for |F2|=100, and λ=0.1. A third curve 3010 was generated using recommendation application 122, and a fourth curve 3011 was generated using AWLS. Referring to FIG. 30C, a precision value as a function of time is shown for |F2|=100, and λ=0.1. A fifth curve 3020 was generated using recommendation application 122, and a sixth curve 3021 was generated using AWLS. Referring to FIG. 30D, a recall value as a function of time is shown for |F2|=100, and λ=0.1. A seventh curve 3030 was generated using recommendation application 122, and an eighth curve 3031 was generated using AWLS.


Referring to FIG. 31A, a comparison of a training objective function as a function of time is shown for |F2|=100, and λ=1. A first curve 3100 was generated using recommendation application 122, and a second curve 3101 was generated using AWLS. Referring to FIG. 31B, an AUC value as a function of time is shown for |F2|=100, and λ=1. A third curve 3110 was generated using recommendation application 122, and a fourth curve 3111 was generated using AWLS. Referring to FIG. 31C, a precision value as a function of time is shown for |F2|=100, and λ=1. A fifth curve 3120 was generated using recommendation application 122, and a sixth curve 3121 was generated using AWLS. Referring to FIG. 31D, a recall value as a function of time is shown for |F2|=100, and λ=1. A seventh curve 3130 was generated using recommendation application 122, and an eighth curve 3131 was generated using AWLS.


Referring to FIG. 32A, a comparison of a training objective function as a function of time is shown for |F2|=100, and λ=10. A first curve 3200 was generated using recommendation application 122, and a second curve 3201 was generated using AWLS. Referring to FIG. 32B, an AUC value as a function of time is shown for |F2|=100, and λ=10. A third curve 3210 was generated using recommendation application 122, and a fourth curve 3211 was generated using AWLS. Referring to FIG. 32C, a precision value as a function of time is shown for |F2|=100, and λ=10. A fifth curve 3220 was generated using recommendation application 122, and a sixth curve 3221 was generated using AWLS. Referring to FIG. 32D, a recall value as a function of time is shown for |F2|=100, and λ=10. A seventh curve 3230 was generated using recommendation application 122, and an eighth curve 3231 was generated using AWLS.


Referring to FIG. 33A, a comparison of a training objective function as a function of time is shown for |F2|=100, and λ=100. A first curve 3300 was generated using recommendation application 122, and a second curve 3301 was generated using AWLS. Referring to FIG. 33B, an AUC value as a function of time is shown for |F2|=100, and λ=100. A third curve 3310 was generated using recommendation application 122, and a fourth curve 3311 was generated using AWLS. Referring to FIG. 33C, a precision value as a function of time is shown for |F2|=100, and λ=100. A fifth curve 3320 was generated using recommendation application 122, and a sixth curve 3321 was generated using AWLS. Referring to FIG. 33D, a recall value as a function of time is shown for |F2|=100, and λ=100. A seventh curve 3330 was generated using recommendation application 122, and an eighth curve 3331 was generated using AWLS.


Referring to FIG. 37, a table 3700 shows a pattern of relative performance between DTOS and AWLS. Each cell corresponds to a case in the experimental results presented in FIGS. 4A-33D. Each cell is marked by the algorithm that provides better performance. In the case of a tie, both algorithms are listed. AWLS provides improved performance in the top-right corner where the hypothesis space has shrunk to such an extent that further regularization is harmful. In the bottom-left corner where the hypothesis space is large, further regularization is beneficial, making the inherent regularization offered by DTOS advantageous.


The results also show that AWLS converged faster in terms of number of iterations while DTOS converged substantially faster in terms of computing time. Convergence can be determined based on a relative change in the objective function value over consecutive iterations. When the relative change is less than a predefined threshold value, convergence may be determined to have been achieved. The difference in time increased as |F2| increased. The faster convergence of AWLS per number of iterations is not surprising because AWLS uses optimal solutions to the local objectives to achieve a maximum improvement of the global objective each iteration. The faster convergence of DTOS indicates that the cost reduction in each iteration is significant enough to counteract the increase in number of iterations, leading to an overall low cost as compared to AWLS. The increased cost reduction with |F2| is a result of the lower-order complexity of DTOS in |F2|.


The converged models of DTOS achieved less optimality for the training objectives than those of AWLS, and the difference increased with λ and decreased with |F2|; however, unless the difference in converged optimality is large, DTOS performed as well as or better than AWLS in terms of the AUC on test data. This indicates that a model that is better in terms of the training objective is not necessarily better in terms of the generalization performance. Model overfitting is one example of such a phenomenon. In the present case, there was an overfitting issue because the PU-learning objective is using virtually all of the entries in R. The optimality difference increases with λ and decreases with |F2| indicating that a less regularized objective is in favor of DTOS possibly indicating that DTOS has an inherent regularization in itself: when the objective does not have enough regularization (either |F2| is large or λ is small), the inherent regularization of DTOS is beneficial; when the objective already has enough regularization (either |F2| is small or λ is large), the inherent regularization of DTOS leads to overly regularized models with degraded performance. Using a common Hessian makes DTOS less prone to any potential inaccuracy in W and makes its solutions more robust. The mechanism of increased robustness plays a similar role to regularization.


DTOS performs consistently better than AWLS in terms of precision and recall, with just a few exceptions when |F2| is small or λ is large. The margin of improvement for precision is particularly significant, demonstrating the value of DTOS in real applications.


Recommendation application 122 solves collaborative filtering problems with implicit feedback and is designed to learn MF-PDF models, a family of hybrid models that combines matrix factorization with linear models. Recommendation application 122 has a low computational complexity and yet achieves reasonable objective improvement in each iteration, leading to an overall faster convergence in time, as compared to AWLS. An interesting property of recommendation application 122 is the inherent regularization, which is particularly beneficial when the training objective is not sufficiently regularized. The experimental results demonstrate that recommendation application 122 can yield significantly better results than AWLS, particularly in terms of precision and recall.


Referring to FIG. 34, a block diagram of a recommendation system 3400 is shown in accordance with an illustrative embodiment. In an illustrative embodiment, recommendation system 3400 may include a user system 3402, recommendation device 100, distributed computing system 130, and a network 3414. Each of user system 3402, recommendation device 100, and distributed computing system 130 may be composed of one or more discrete computing devices in communication through network 3414. Distributed computing system 130 may not be included in an alternative embodiment.


Network 3414 may include one or more networks of the same or different types. Network 3414 can be any type of wired and/or wireless public or private network including a cellular network, a local area network, a wide area network such as the Internet or the World Wide Web, etc. Network 3414 further may comprise sub-networks and consist of any number of communication devices.


The one or more computing devices of user system 3402 may include computing devices of any form factor such as a desktop 3406, a smart phone 3404, a television 3408, a laptop 3410, a personal digital assistant, an integrated messaging device, a tablet computer, etc. User system 3402 can include any number and any combination of form factors of computing devices that may be organized into subnets. The computing devices of user system 3402 may send and receive signals through network 3414 to/from recommendation device 100. The one or more computing devices of user system 3402 may communicate using various transmission media that may be wired and/or wireless as understood by those skilled in the art. The one or more computing devices of user system 3402 may be geographically dispersed from each other and/or co-located.


For illustration, referring to FIG. 35, a block diagram of a user device 3500 is shown in accordance with an example embodiment. User device 3500 is an example computing device of user system 3402. For example, each of desktop 3406, smart phone 3404, television 3408, and laptop 3410 may be an instance of user device 3500. User device 3500 may include a second input interface 3502, a second output interface 3504, a second communication interface 3506, a second non-transitory computer-readable medium 3508, a second processor 3510, and a selection application 3522. Each computing device of user system 3402 may be executing selection application 3522 of the same or different type. User device 3500 may execute selection application 3522 that triggers creation of model parameters 126. Each user device 3500 of user system 3402 may include the same or different components and combinations of components. Fewer, different, and additional components may be incorporated into user device 3500.


Second input interface 3502 provides the same or similar functionality as that described with reference to input interface 102 of recommendation device 100 though referring to user device 3500. Second output interface 3504 provides the same or similar functionality as that described with reference to output interface 104 of recommendation device 100 though referring to user device 3500. Second communication interface 3506 provides the same or similar functionality as that described with reference to communication interface 106 of recommendation device 100 though referring to user device 3500. Data and messages may be transferred between recommendation device 100 and user device 3500 using second communication interface 3506. Second computer-readable medium 3508 provides the same or similar functionality as that described with reference to computer-readable medium 108 of recommendation device 100 though referring to user device 3500. Second processor 3510 provides the same or similar functionality as that described with reference to processor 110 of recommendation device 100 though referring to user device 3500.


Selection application 3522 performs operations associated with requesting response data for a user (item) based on inputs provided from user device 3500. The operations may be implemented using hardware, firmware, software, or any combination of these methods. Referring to the example embodiment of FIG. 35, selection application 3522 is implemented in software (comprised of computer-readable and/or computer-executable instructions) stored in second computer-readable medium 3508 and accessible by second processor 3510 for execution of the instructions that embody the operations of selection application 3522. Selection application 3522 may be written using one or more programming languages, assembly languages, scripting languages, etc. Selection application 3522 may be implemented as a Web application.


Referring to FIG. 36, example operations associated with selection application 3522 are described. Additional, fewer, or different operations may be performed depending on the embodiment of selection application 3522. The order of presentation of the operations of FIG. 36 is not intended to be limiting. Some of the operations may not be performed in some embodiments. Although some of the operational flows are presented in sequence, the various operations may be performed in various repetitions and/or in other orders than those that are illustrated. For example, a user may execute selection application 3522, which causes presentation of a first user interface window, which may include a plurality of menus and selectors such as drop-down menus, buttons, text boxes, hyperlinks, etc. associated with selection application 3522 as understood by a person of skill in the art. The plurality of menus and selectors may be accessed in various orders. For illustration, the Netflix application is an example selection application 3522.


In an operation 3600, a sixth indicator may be received that indicates a request to generate item recommendations for a user of selection application 3522. Alternatively, the request may be to generate user recommendations related to an item for an entity using selection application 3522. For example, a user may be searching for content such as a movie, book, game, music, etc. using selection application 3522 with, for example, a second keyboard 3512, a second microphone 3513, or a second mouse 3514. The request may include an identifier of the user for which recommendations are desired, or an identifier of the item for which user recommendations are desired. For illustration, the identifier of the user may automatically be associated with a user using selection application 3522, for example, through a login process.


In an operation 3602, the request is sent to recommendation device 100 through second communication interface 3506, network 3414, and communication interface 106. In response to receipt of the request, recommendation device 100 may generate a ranked list of items using the matrices output to model parameters 126 in operation 232 that define a prediction response matrix M, where M=XY=X:F1YF1:+X:PYP:−X:F3YF3:+X:QYQ:. For the user associated with the identifier included in the request, a row is selected from M and the responses values for the items are sorted in descending order. One or more top-ranked items may be selected as the recommendation. Alternatively, when an item identifier is included in the request, a column is selected from M and the predicted values for the users are sorted in descending order and used to select top-ranked users. Recommendation device 100 may send a ranked item list or a ranked user list to user device 3500.


In an operation 3604, the ranked item list or the ranked user list is received from recommendation device 100.


In an operation 3606, the ranked item list or the ranked user list is presented, for example, using a second display 3516 or a second speaker 3518.


In an operation 3608, an item response or a user response may be received from the user.


In an operation 3610, the item response or the user response may be sent to recommendation device 100. In response, recommendation device 100 may update the response matrix with the new response information by repeating one or more of operations 200 through 232.


Recommendation application 122 is not limited to recommendation systems. For example, recommendation application 122 can be used on social networks, to predict responses that have not yet occurred but can potentially happen. In this application, the rows and columns are both associated with people, and the entries are associated with responses between people. Thus, R is an m×n matrix with Rui representing a response by a user u to an item i, where the user u represents a first person, the item i represents a second person, and the response matrix R represents responses between the first person and the second person.


In another example, recommendation application 122 can be used for automatic completion of partially-filled surveys. In this application, each person provides answers to a list of questions, leading to a person-versus-question matrix, The person-versus-question matrix typically has heavily-missing entries, as people tend not to answer all of the questions—as a matter of fact, many people may skip a lot of the questions. Using recommendation application 122, one can predict what answers a person would have given to the skipped questions. Thus, R is an m×n matrix with Rui representing a response between a user u and an item i, where the user u represents a survey participant, the item i represents a survey question, and the response matrix R represents answers by the survey participant to a respective survey question.


The word “illustrative” is used herein to mean serving as an example, instance, or illustration. Any aspect or design described herein as “illustrative” is not necessarily to be construed as preferred or advantageous over other aspects or designs. Further, for the purposes of this disclosure and unless otherwise specified, “a” or “an” means “one or more”. Still further, using “and” or “or” in the detailed description is intended to include “and/or” unless specifically indicated otherwise.


The foregoing description of illustrative embodiments of the disclosed subject matter has been presented for purposes of illustration and of description. It is not intended to be exhaustive or to limit the disclosed subject matter to the precise form disclosed, and modifications and variations are possible in light of the above teachings or may be acquired from practice of the disclosed subject matter. The embodiments were chosen and described in order to explain the principles of the disclosed subject matter and as practical applications of the disclosed subject matter to enable one skilled in the art to utilize the disclosed subject matter in various embodiments and with various modifications as suited to the particular use contemplated.

Claims
  • 1. A non-transitory computer-readable medium having stored thereon computer-readable instructions that when executed by a computing device cause the computing device to: compute a confidence matrix using a predefined weight value defined for each user of a plurality of users and each item of a plurality of items;(A) update a first parameter matrix using the computed confidence matrix, a predefined response matrix, a first step-size parameter value that is greater than one, and a first direction matrix, wherein the first parameter matrix includes a row dimension equal to a number of users of the plurality of users, wherein the predefined response matrix includes a predefined response value by each user of the plurality of users to each item of the plurality of items, wherein the predefined response matrix includes at least one matrix value for which a user of the plurality of users has not provided a response to an item of the plurality of items;(B) update a second parameter matrix using the computed confidence matrix, the predefined response matrix, a second step-size parameter value that is greater than zero, and a second direction matrix, wherein the second parameter matrix includes a column dimension equal to a number of items of the plurality of items;(C) update an objective function value based on the updated first parameter matrix and the updated second parameter matrix;(D) train the first parameter matrix and the second parameter matrix by repeating (A) through (C) until the updated first parameter matrix and the updated second parameter matrix satisfy a convergence test; andoutput the trained first parameter matrix and the trained second parameter matrix for use in predicting a recommended item of the plurality of items for a requesting user of the plurality of users.
  • 2. The non-transitory computer-readable medium of claim 1, wherein the convergence test is based on a number of iterations of (C) exceeding a predefined maximum number of iterations.
  • 3. The non-transitory computer-readable medium of claim 1, wherein the convergence test is based on the updated objective function value being less than or equal to a predefined convergence value.
  • 4. The non-transitory computer-readable medium of claim 1, wherein the convergence test is based on a difference between the objective function value updated in (C) and the objective function value updated in a previous iteration of (C) being less than or equal to a predefined convergence value.
  • 5. The non-transitory computer-readable medium of claim 1, wherein, after (D), the computer-readable instructions further cause the computing device to: receive a request to provide the recommended item to the requesting user, wherein the request includes a user identifier of the requesting user; andin response to receipt of the request, identify a row of a prediction matrix associated with the user identifier, wherein the prediction matrix is computed using the trained first parameter matrix and the trained second parameter matrix;rank predicted values included in the identified row from highest value to lowest value to predict the response by the user to each item; andoutput the recommended item based on the ranked predicted values.
  • 6. The non-transitory computer-readable medium of claim 5, wherein the prediction matrix is computed using M=X:F1YF1:+X:PYP:=X:F3YF3:+X:QYQ:, where M is the prediction matrix, X:P is the trained first parameter matrix, YQ: is the trained second parameter matrix, X:F1 is a predefined user factors matrix, YF3: is a predefined item factors matrix, X:F3 is a predefined user regression matrix for YF3:, YF1: is a predefined item regression matrix for X:F1, YP: is a sub-matrix of Y obtained by extracting rows indexed by elements of a P matrix, Y is an item matrix, P=F2∪F3, F2 is a latent matrix that stores latent indices for latent factors in X and Y, F3 is an item index matrix that stores model indices for a linear model on Y, X is a user matrix, and X:Q is a sub-matrix of X obtained by extracting rows indexed by elements of a Q matrix, Q=F1∪F2, F1 is a user index matrix that stores model indices for a linear model on X, and ∪ indicates a union of indicated matrices.
  • 7. The non-transitory computer-readable medium of claim 1, wherein before (A), the first parameter matrix is initialized with a predefined initial first parameter matrix, and the second parameter matrix is initialized with a predefined initial second parameter matrix.
  • 8. The non-transitory computer-readable medium of claim 7, wherein the predefined initial first parameter matrix is a column matrix of m ones, and the predefined initial second parameter matrix is a row matrix of n ones, wherein m indicates the number of users of the plurality of users, and n indicates the number of items of the plurality of items.
  • 9. The non-transitory computer-readable medium of claim 1, wherein the first parameter matrix is updated using X:P=X:P+η1D, where X:P is the first parameter matrix, η1 is the first step-size parameter value, and D is the first direction matrix.
  • 10. The non-transitory computer-readable medium of claim 9, wherein the first step-size parameter value is updated using η1=α1/β1, where α1 is a first α parameter value, and β1 is a first β parameter value.
  • 11. The non-transitory computer-readable medium of claim 10, wherein the first α parameter value is updated using α0=∥DYP:∥2+λ∥D∥2 and α1=α0+ΣΔui≠0(ΔuiDu:YPi)(Δui+1)(Rui−Xu:Y:i), where indicates a Frobenius norm computation of a specified matrix, λ is a predefined regularization parameter value, u is an index to a respective user, i is an index to a respective item, Δui is a u, ith entry of the confidence matrix, Rui is a u, ith entry of the response matrix, Xu: is a uth row of X, X is a user matrix, Y:i is an ith column of Y, Y is an item matrix, Du: is a uth row of D, YPi is an ith column of YP:, YP: is a sub-matrix of Y obtained by extracting rows indexed by elements of a P matrix, P=F2∪F3, F2 is a latent matrix that stores latent indices for latent factors in X and Y, F3 is an item index matrix that stores model indices for a linear model on Y, and ∪ indicates a union of indicated matrices.
  • 12. The non-transitory computer-readable medium of claim 11, wherein the first β parameter value is updated using β1=α0+ΣΔui≠0(Δui2+2Δui)(Du:YPi)2.
  • 13. The non-transitory computer-readable medium of claim 9, wherein the first direction matrix is updated using D=([Δuiº(R−XY)+R]YP:T−XYYP:T−λX:P)(λI+YP:YP:T)−1, where Δui is a u, ith entry of the confidence matrix, u is an index to a respective user, i is an index to a respective item, R is the response matrix, X is a user matrix, Y is an item matrix, λ is a predefined regularization parameter value, YP: is a sub-matrix of Y obtained by extracting rows indexed by elements of a P matrix, P=F2∪F3, F2 is a latent matrix that stores latent indices for latent factors in X and Y, F3 is an item index matrix that stores model indices for a linear model on Y, I is an identity matrix, º indicates a Hadamard product, T indicates a transpose, and ∪ indicates a union of indicated matrices.
  • 14. The non-transitory computer-readable medium of claim 13, wherein X=[X:P,X:P] and Y=[YQ:,YQ:], where YQ: is the second parameter matrix, and   indicates a complement of an indicated matrix.
  • 15. The non-transitory computer-readable medium of claim 13, wherein the first direction matrix D has dimension m by (|F2|+|F3|), where m indicates the number of users of the plurality of users, and | | indicates a cardinality of an indicated matrix.
  • 16. The non-transitory computer-readable medium of claim 1, wherein the second parameter matrix is updated using YQ:=YQ:+η2Z, where YQ: is the second parameter matrix, η2 is the second step-size parameter value, and Z is the second direction matrix.
  • 17. The non-transitory computer-readable medium of claim 16, wherein the second step-size parameter value is updated using
  • 18. The non-transitory computer-readable medium of claim 17, wherein the second α parameter value is updated using α0=∥X:QZ∥2+λ∥Z∥2 and α2=α0+ΣΔui≠0(ΔuiXuQZ:i)(Δui+1)(Rui−Xu:Y:i), where ∥ ∥ indicates a Frobenius norm computation of a specified matrix, λ is a predefined regularization parameter value, u is an index to a respective user, i is an index to a respective item, Δui is a u, ith entry of the confidence matrix, Rui is a u, ith entry of the response matrix, Xu: is a uth row of X, X is a user matrix, Y:i is an ith column of Y, Y is an item matrix, Z:i is an ith column of Z, XuQ is a uth row of X:Q, X:Q is a sub-matrix of X obtained by extracting rows indexed by elements of a Q matrix, Q=F1∪F2, F2 is a latent matrix that stores latent indices for latent factors in X and Y, F1 is a user index matrix that stores model indices for a linear model on X, and ∪ indicates a union of indicated matrices.
  • 19. The non-transitory computer-readable medium of claim 18, wherein the second β parameter value is updated using β2=α0+ΣΔui≠0(Δui2+2Δui)(XuQZ:i)2.
  • 20. The non-transitory computer-readable medium of claim 16, wherein the second direction matrix is updated using Z=(λI+X:QTX:Q)−1[X:QT[Δuiº(R−XY)+R]−X:QTXY−λYQ:], where ∪ is an index to a respective user, i is an index to a respective item, Δui is a u, ith entry of the confidence matrix, R is the response matrix, X is a user matrix, Y is an item matrix, λ is a predefined regularization parameter value, X:Q is a sub-matrix of X obtained by extracting rows indexed by elements of a Q matrix, Q=F1∪F2, F2 is a latent matrix that stores latent indices for latent factors in X and Y, F1 is a user index matrix that stores model indices for a linear model on X, YQ: is the second parameter matrix, I is an identity matrix, º indicates a Hadamard product, T indicates a transpose, and ∪ indicates a union of indicated matrices.
  • 21. The non-transitory computer-readable medium of claim 20, wherein X=[X:P,X:P] and Y=[YQ:,YQ:], where X:P is the first parameter matrix, and   indicates a complement of an indicated matrix.
  • 22. The non-transitory computer-readable medium of claim 20, wherein the second direction matrix Z has dimension (|F1|+|F2|) by n, where n indicates the number of items of the plurality of items, and | | indicates a cardinality of an indicated matrix.
  • 23. The non-transitory computer-readable medium of claim 1, wherein the objective function value is updated using g=∥(Δui+J)∘(R−XY)∥2+λ(∥X:P∥2+YQ:∥2), where g is the objective function value, Δui is a u, ith entry of the confidence matrix, u is an index to a respective user, i is an index to a respective item, J indicates an m×n matrix of all ones, m indicates the number of users of the plurality of users, n indicates the number of items of the plurality of items, R is the response matrix, X is a user matrix, Y is an item matrix, λ is a predefined regularization parameter value, X:P is the first parameter matrix, YQ: is the second parameter matrix, º indicates a Hadamard product, and ∥ ∥ indicates a Frobenius norm computation.
  • 24. The non-transitory computer-readable medium of claim 23, wherein X=[X:P,X:P] and Y=[YQ:,YQ:], where   indicates a complement of an indicated matrix.
  • 25. The non-transitory computer-readable medium of claim 1, wherein each item of the plurality of items is selected from the group consisting of a content item, a survey question, and a person.
  • 26. The non-transitory computer-readable medium of claim 1, wherein each user of the plurality of users is selected from the group consisting of a person and an entity.
  • 27. The non-transitory computer-readable medium of claim 1, wherein the confidence matrix is computed using Δui=√{square root over (Wui)}−1, where u is an index to a respective user, i is an index to a respective item, Δui is a u, ith entry of the confidence matrix, and Wui is a u, ith predefined weight value.
  • 28. The non-transitory computer-readable medium of claim 27, wherein Wui=1+ξu+ζL, where ξu is a number of items with Rui=1, ζi is a number of users with Rui=1, and Rui is a u, ith entry of the response matrix.
  • 29. A computing device comprising: a processor; anda non-transitory computer-readable medium operably coupled to the processor, the computer-readable medium having computer-readable instructions stored thereon that, when executed by the processor, cause the computing device to compute a confidence matrix using a predefined weight value defined for each user of a plurality of users and each item of a plurality of items;(A) update a first parameter matrix using the computed confidence matrix, a predefined response matrix, a first step-size parameter value that is greater than one, and a first direction matrix, wherein the first parameter matrix includes a row dimension equal to a number of users of the plurality of users, wherein the predefined response matrix includes a predefined response value by each user of the plurality of users to each item of the plurality of items, wherein the predefined response matrix includes at least one matrix value for which a user of the plurality of users has not provided a response to an item of the plurality of items;(B) update a second parameter matrix using the computed confidence matrix, the predefined response matrix, a second step-size parameter value that is greater than zero, and a second direction matrix, wherein the second parameter matrix includes a column dimension equal to a number of items of the plurality of items;(C) update an objective function value based on the updated first parameter matrix and the updated second parameter matrix;(D) train the first parameter matrix and the second parameter matrix by repeating (A) through (C) until the updated first parameter matrix and the updated second parameter matrix satisfy a convergence test; andoutput the trained first parameter matrix and the trained second parameter matrix for use in predicting a recommended item of the plurality of items for a requesting user of the plurality of users.
  • 30. A method of determining a recommendation, the method comprising: computing, by a computing device, a confidence matrix using a predefined weight value defined for each user of a plurality of users and each item of a plurality of items;(A) updating, by the computing device, a first parameter matrix using the computed confidence matrix, a predefined response matrix, a first step-size parameter value that is greater than one, and a first direction matrix, wherein the first parameter matrix includes a row dimension equal to a number of users of the plurality of users, wherein the predefined response matrix includes a predefined response value by each user of the plurality of users to each item of the plurality of items, wherein the predefined response matrix includes at least one matrix value for which a user of the plurality of users has not provided a response to an item of the plurality of items;(B) updating, by the computing device, a second parameter matrix using the computed confidence matrix, the predefined response matrix, a second step-size parameter value that is greater than zero, and a second direction matrix, wherein the second parameter matrix includes a column dimension equal to a number of items of the plurality of items;(C) updating, by the computing device, an objective function value based on the updated first parameter matrix and the updated second parameter matrix;(D) training, by the computing device, the first parameter matrix and the second parameter matrix by repeating (A) through (C) until the updated first parameter matrix and the updated second parameter matrix satisfy a convergence test; andoutputting, by the computing device, the trained first parameter matrix and the trained second parameter matrix for use in predicting a recommended item of the plurality of items for a requesting user of the plurality of users.
CROSS-REFERENCE TO RELATED APPLICATIONS

The present application claims the benefit of and priority under 35 U.S.C. § 119(e) to U.S. Provisional Patent Application No. 63/280,019 filed on Nov. 16, 2021, the entire contents of which are hereby incorporated by reference. The present application is also a continuation-in-part of U.S. patent application Ser. No. 17/386,853 that was filed Jul. 28, 2021, the entire contents of which are hereby incorporated by reference. U.S. patent application Ser. No. 17/386,853 claims the benefit of and priority under 35 U.S.C. § 119(e) to U.S. Provisional Patent Application No. 63/121,751 filed on Dec. 4, 2020, and to U.S. Provisional Patent Application No. 63/108,640 filed on Nov. 2, 2020, the entire contents of which are hereby incorporated by reference.

Provisional Applications (3)
Number Date Country
63280019 Nov 2021 US
63108640 Nov 2020 US
63121751 Dec 2020 US
Continuation in Parts (1)
Number Date Country
Parent 17386853 Jul 2021 US
Child 17715214 US