You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
In cases where limited data are available, it might be possible that samples are labelled in different aspects. In such a case, it might be beneficial to use a multi-objective loss, i.e., a utility that wraps other losses and that is responsible for passing embeddings and labels to each one of the losses configured.
I propose such an implementation, PytorchMetricLearningWrapper might be an example.
Usage scenario
Suppose that you are training a model to search for art images. These images can be said to be related or unrelated according to our point of comparison. For instance, two images may feature the same object but in stylistically different ways. These stylistic feature may be coming from the art movement or artist's personal legacy. In this case, the ideal embedding space should be able to encode an image with a vector containing these pieces of information. However, these features form different sets of labels. Our labels may include a string of visual captioning, an artistic description, the name of the artist, the year of creation. If we want to encourage our model encode all of them, then we need to use a separate loss instance for each one of them.
We can categorise similarity learning losses into two main categories: pair-based losses such as Contrastive Loss or Triplet Loss, and proxy-based losses such as ArcFace and Proxy-NCA. The former can provide feedback on one-to-main relationships of similarity in the dataset while too slow in convergence. The latter are pretty much faster in convergence, but they are not so good at organizing the intra-class embedding space. There is a recent approach to combine both of them, i.e., using two types of losses simultaneously to get the best of two worlds. A relevant paper, PDF
The text was updated successfully, but these errors were encountered:
In cases where limited data are available, it might be possible that samples are labelled in different aspects. In such a case, it might be beneficial to use a multi-objective loss, i.e., a utility that wraps other losses and that is responsible for passing embeddings and labels to each one of the losses configured.
I propose such an implementation,
PytorchMetricLearningWrapper
might be an example.Usage scenario
The text was updated successfully, but these errors were encountered: