SENet was originally used in computer vision, but was later applied to recommendation system.
Consider discrete attributes on a product. Convert them into embedding to get features. For m features, each of which is expressed in a k-dimension vector. Take average pooling to make it into an m * 1 vector. (? why would that help?) .
From m * 1 vector, apply a fully connected layer and a ReLU layer. Output an (m / r) * 1 dimension vector. (r is a compression ratio).
From (m / r) * 1 dimension vector, apply fully connected and a sigmoid layer. Output an m * 1 dimension vector.
Now use this m * 1 vector from the last step as weight - apply this weights to the initial m*k matrix again with row-wise multiplication to get another m*k matrix.
(The intuitive meaning of the operations above is to take away irrelevant features from the matrix.)
The core of SENet is to apply weight at each field. Note that the fields can have features in different dimensions.
Cross two vectors between field i and field j. (All fields are in m-dimension.)
- by inner product: Xi.transpose * Xj = scaler
- Hadamard product of two vectors (element-wise multiplication) = vector.
Bilinear Cross:
- by inner product: Xi.transpose * Wij * Xj . (Inserted a matrix in between the inner product)
Note that there are too many pairs of fields. So we can only take a selective set of field pairs to perform Bilinear Cross.
- Hadamard product of two vectors: Hadamard( Xi , Wij * Xj )
Likewise, in practice, selective set of field pairs of used to perform Bilinear Cross.
FiBiNet:
- Combine SENet and Bilinear Cross.
- Take the embeddings for each field to 3 paths: bilinear network, SENet + bilinear network and the original embeddings concatenated. Concatenate all 3 vectors together and apply another network.
Reference: https://www.youtube.com/watch?v=nF37qtNvw1E
No comments:
Post a Comment