skada.deep.CDAN

skada.deep.CDAN(module, layer_name, reg=1, max_features=4096, domain_classifier=None, num_features=None, n_classes=None, base_criterion=None, domain_criterion=None, **kwargs)[source]

Conditional Domain Adversarial Networks (CDAN).

From [16].

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.

max_featuresint, default=4096

Maximum size of the input for the domain classifier. 4096 is the largest number of units in typical deep network according to [1]_.

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 embedding space e.g. the size of the output of layer_name. If domain_classifier is None, num_features has to be provided.

n_classesint, default None

Number of output classes. If domain_classifier is None, n_classes 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 CDAN loss. If None, a BCELoss is used.

References

[16]

Mingsheng Long et. al. Conditional Adversarial Domain Adaptation In NeurIPS, 2016.