Miners
AllTripletsMiner
- class oml.miners.inbatch_all_tri.AllTripletsMiner(max_output_triplets: int = 9223372036854775807, device: str = 'cpu')[source]
Bases:
ITripletsMinerInBatchThis miner selects all the possible triplets for the given batch.
HardTripletsMiner
- class oml.miners.inbatch_hard_tri.HardTripletsMiner[source]
Bases:
ITripletsMinerInBatchThis miner selects the hardest triplets based on the distances between the features:
The hardest positive sample has the maximal distance to the anchor sample
The hardest negative sample has the minimal distance to the anchor sample
- __init__()
TripletMinerWithMemory
- class oml.miners.cross_batch.TripletMinerWithMemory(bank_size_in_batches: int, tri_expand_k: int)[source]
Bases:
ITripletsMinerThis miner has a memory bank that allows to sample not only the triplets from the original batch, but also add batches obtained from both the bank and the original batch.
- __init__(bank_size_in_batches: int, tri_expand_k: int)[source]
- Parameters
bank_size_in_batches – The size of the bank calculated in the number batches
tri_expand_k – This parameter defines how many triplets we sample from the bank. Specifically, we return
tri_expand_k * number of original triplets. In particular, iftri_expand_k == 1we sample no triplets from the bank
- sample(features: Tensor, labels: Tensor) Tuple[Tensor, Tensor, Tensor, Tensor][source]
- Parameters
features – Features with the shape of
(batch_size, feat_dim)labels – Labels with the size of
batch_size
- Returns
Triplets made from the original batch and those that were combined from the bank and the batch. We also return an indicator of whether triplet was obtained from the original batch. So, output is the following
(anchor, positive, negative, indicators)
HardClusterMiner
- class oml.miners.inbatch_hard_cluster.HardClusterMiner[source]
Bases:
ITripletsMinerThis miner selects the hardest triplets based on the distance to mean vectors: anchor is a mean vector of features of i-th label in the batch, the hardest positive sample is the most distant from the anchor sample of anchor’s label, the hardest negative sample is the closest mean vector of other labels.
The batch must contain
n_instancesforn_labelswhere both values higher than 1.- __init__()
- sample(features: Tensor, labels: Union[List[int], Tensor]) Tuple[Tensor, Tensor, Tensor][source]
This method samples the hardest triplets in the batch.
- Parameters
features – Tensor with the shape of
[batch_size, embed_dim]that containsn_instancesfor each ofn_labelslabels – Labels with the size of
batch_size
- Returns
n_labelstriplets in the form of(mean_vector, positive, negative_mean_vector)
NHardTripletsMiner
- class oml.miners.inbatch_nhard_tri.NHardTripletsMiner(n_positive: Union[Tuple[int, int], List[int], int] = 1, n_negative: Union[Tuple[int, int], List[int], int] = 1)[source]
Bases:
ITripletsMinerInBatchThis miner selects hard triplets based on distances between features:
hard positive samples have large distance to the anchor sample
hard negative samples have small distance to the anchor sample
Toward the end of the training, annotation errors can affect final metric. If you are not sure about the quality of your dataset, you can use range instead of integer value for parameters and exclude combinations with the largest distances. For example instead picking 5 positive examples, you can use examples from the 2nd hardest to the 5th one.
- __init__(n_positive: Union[Tuple[int, int], List[int], int] = 1, n_negative: Union[Tuple[int, int], List[int], int] = 1)[source]
- Parameters
n_positive – keep
n_positivepositive samples with large distances. If the value is a range, minimal value has to be less than the available amount of labels in batchesn_negative – keep
n_negativenegative pipelines with small distances
Note
If both parameters are 1, the miner is equivalent to
HardTripletsMiner. If both parameters are large enough, the miner can be equivalent toAllTripletsMiner
MinerWithBank
- class oml.miners.miner_with_bank.MinerWithBank(bank_size_in_batches: int, miner: NHardTripletsMiner, need_logs: bool = True)[source]
Bases:
ITripletsMinerThis is a class for cross-batch memory. This implementation uses only samples from the current batch as anchors and finds positive and negative pairs from the bank and the current batch using miner.
- __init__(bank_size_in_batches: int, miner: NHardTripletsMiner, need_logs: bool = True)[source]
- Parameters
bank_size_in_batches – Size of the bank.
miner – Miner, for now we only support
NHardTripletsMinerneed_logs – Set
Trueto store some information to track inself.last_logsproperty.