probability_weighted_ae
ProbabilityWeightedAutoencoder(module, loss_fn='mse', optimizer_fn='sgd', lr=0.001, device='cpu', seed=42, skip_threshold=0.9, window_size=250, **kwargs)
¶
Bases: Autoencoder
Wrapper for PyTorch autoencoder models for anomaly detection that
reduces the employed learning rate based on an outlier probability
estimate of the input example as well as a threshold probability
skip_threshold
. If the outlier probability is above the threshold,
the learning rate is reduced to less than 0. Given the probability
estimate \(p_out\), the adjusted learning rate
\(lr_adj\) is \(lr * 1 - (rac{p_out}{skip_threshold})\).
PARAMETER | DESCRIPTION |
---|---|
module
|
Torch Module that builds the autoencoder to be wrapped.
The Module should accept parameter
TYPE:
|
loss_fn
|
Loss function to be used for training the wrapped model.
Can be a loss function provided by
TYPE:
|
optimizer_fn
|
Optimizer to be used for training the wrapped model.
Can be an optimizer class provided by
TYPE:
|
lr
|
Base learning rate of the optimizer.
TYPE:
|
skip_threshold
|
Threshold probability to use as a reference for the reduction of the base learning rate.
TYPE:
|
device
|
Device to run the wrapped model on. Can be "cpu" or "cuda".
TYPE:
|
seed
|
Random seed to be used for training the wrapped model.
TYPE:
|
**kwargs
|
Parameters to be passed to the Examples
DEFAULT:
|
Rolling
|
|
learn_one(x, y=None, **kwargs)
¶
Performs one step of training with a single example, scaling the employed learning rate based on the outlier probability estimate of the input example.
PARAMETER | DESCRIPTION |
---|---|
**kwargs
|
DEFAULT:
|
x
|
Input example.
TYPE:
|
RETURNS | DESCRIPTION |
---|---|
ProbabilityWeightedAutoencoder
|
The autoencoder itself. |