PNN

Reference:

Qu Y et al. “Product-based neural networks for user response prediction.” in ICDM 2016

Reference code:
class recbole.model.context_aware_recommender.pnn.InnerProductLayer(num_feature_field, device)[source]

Bases: Module

InnerProduct Layer used in PNN that compute the element-wise product or inner product between feature vectors.

forward(feat_emb)[source]
Parameters:

feat_emb (torch.FloatTensor) – 3D tensor with shape: [batch_size,num_pairs,embedding_size].

Returns:

The inner product of input tensor. shape of [batch_size, num_pairs]

Return type:

inner_product(torch.FloatTensor)

training: bool
class recbole.model.context_aware_recommender.pnn.OuterProductLayer(num_feature_field, embedding_size, device)[source]

Bases: Module

OuterProduct Layer used in PNN. This implementation is adapted from code that the author of the paper published on https://github.com/Atomu2014/product-nets.

forward(feat_emb)[source]
Parameters:

feat_emb (torch.FloatTensor) – 3D tensor with shape: [batch_size,num_pairs,embedding_size].

Returns:

The outer product of input tensor. shape of [batch_size, num_pairs]

Return type:

outer_product(torch.FloatTensor)

training: bool
class recbole.model.context_aware_recommender.pnn.PNN(config, dataset)[source]

Bases: ContextRecommender

PNN calculate inner and outer product of feature embedding. You can choose the product option with the parameter of use_inner and use_outer

calculate_loss(interaction)[source]

Calculate the training loss for a batch data.

Parameters:

interaction (Interaction) – Interaction class of the batch.

Returns:

Training loss, shape: []

Return type:

torch.Tensor

forward(interaction)[source]

Defines the computation performed at every call.

Should be overridden by all subclasses.

Note

Although the recipe for forward pass needs to be defined within this function, one should call the Module instance afterwards instead of this since the former takes care of running the registered hooks while the latter silently ignores them.

predict(interaction)[source]

Predict the scores between users and items.

Parameters:

interaction (Interaction) – Interaction class of the batch.

Returns:

Predicted scores for given users and items, shape: [batch_size]

Return type:

torch.Tensor

reg_loss()[source]

Calculate the L2 normalization loss of model parameters. Including weight matrices of mlp layers.

Returns:

The L2 Loss tensor. shape of [1,]

Return type:

loss(torch.FloatTensor)

training: bool