skada.deep.DANN
- skada.deep.DANN(module, layer_name, reg=1, domain_classifier=None, num_features=None, base_criterion=None, domain_criterion=None, **kwargs)[source]
Domain-Adversarial Training of Neural Networks (DANN).
From [15].
- Parameters:
- moduletorch module (class or instance)
A PyTorch
Module
. In general, the uninstantiated class should be passed, although instantiated modules will also work.- layer_namestr
The name of the module's layer whose outputs are collected during the training.
- regfloat, default=1
Regularization parameter for DA loss.
- domain_classifiertorch module, default=None
A PyTorch
Module
used to classify the domain. If None, a domain classifier is created following [1]_.- num_featuresint, default=None
Size of the input of domain classifier, e.g size of the last layer of the feature extractor. If domain_classifier is None, num_features has to be provided.
- base_criteriontorch criterion (class)
The base criterion used to compute the loss with source labels. If None, the default is torch.nn.CrossEntropyLoss.
- domain_criteriontorch criterion (class)
The criterion (loss) used to compute the DANN loss. If None, a BCELoss is used.
References
[15]Yaroslav Ganin et. al. Domain-Adversarial Training of Neural Networks. In Journal of Machine Learning Research, 2016.
Examples using skada.deep.DANN
Adversarial domain adaptation methods.