## Deep Domain Adaptation based on ELOT for VisDA, Office-31, and Office-Home datasets

Official Python3 implementations of our paper entitle "Elastic Optimal Transport with Applications to Domain Adaptation".

### Code organization
elot.py : this file implements elastic optimal transport solver.

data_list.py : this file contains functions to create the dataset.

evaluate.py : this file is used to evaluate model trained on the VisDA dataset.

lr_schedule.py : this file implements the learning rate scheduler.

network.py : this file contains the architecture of the generator and the classifier.

pre_process.py : this file implements preprocessing techniques.

train.py : this file implements the conventional DA training process for all datasets.


### Terminologies
--net : architecture type of the generator

--dset : name of the dataset

--test_interval : interval of two continuous test phase

--s_dset_path : path to the source dataset

--stratify_source : use stratify sampling

--t_dset_path : path to the target dataset

--batch_size : mini-batch size

--k : number of mini-batches

--stop_step : number of iterations

--ot_type : type of OT loss (balanced, unbalanced, partial, elot)

--eta1 : weight of embedding loss ($\alpha$ in our paper)

--eta2 : weight of transportation loss ($\beta$ in our paper)

--epsilon : OT regularization coefficient for Sinkhorn algorithm

--tau : marginal penalization coefficient in UOT

--mass : fraction of masses in POT

--bomb : Using Batch of Mini-batches

--ebomb : Using entropic Batch of Mini-batches

--breg : OT regularization coefficient for entropic Batch of Mini-batches


## Acknowledgment
The codes are adapted from [Mini-batch-OT](https://github.com/UT-Austin-Data-Science-Group/Mini-batch-OT). We are very grateful for their open sources.
