{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%config Completer.use_jedi = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from time import time\n",
    "import ot\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.ticker as mtick\n",
    "from scipy.stats import multivariate_normal\n",
    "import seaborn as sn\n",
    "import pandas as pd\n",
    "from pathlib import Path\n",
    "from sklearn.utils import check_random_state\n",
    "from sklearn.feature_extraction.text import CountVectorizer\n",
    "import torch\n",
    "from tqdm.notebook import tqdm\n",
    "# User functions\n",
    "from utils import BaseTransport, GaussianTransport, get_trajectories_for_plotting, calc_parsimony, W2_dist\n",
    "\n",
    "# We will be using data from  the UCI: Breast Cancer Wisconsin (Original)\n",
    "experiment_name = 'CivilComments'\n",
    "data_dir = Path('..') / 'data'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Setting so that the plots look normal even when using dark-reader\n",
    "sn.set_style(\"whitegrid\")\n",
    "sn.set_context(context=\"paper\", font_scale=2)\n",
    "pal = sn.color_palette(\"Set1\")\n",
    "\n",
    "# Setting up specifics for plotting + saving\n",
    "save_figures = True\n",
    "add_legend = False\n",
    "add_title = False\n",
    "add_axis = False\n",
    "save_parms = {'format': 'svg','bbox_inches':'tight', 'pad_inches':0}\n",
    "line_parms = {'linewidth':4, 'color':'k'}\n",
    "if save_figures:\n",
    "    figure_dir = Path('.') / 'figures' / experiment_name  # saves all figures in a figure directory in the local directory\n",
    "    if not figure_dir.exists():\n",
    "        figure_dir.mkdir(parents=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "entire_notebook_start_time = time()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Loading in the data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# data hyperparameters\n",
    "max_features = 500\n",
    "# since we have *many features* now, we limit the max number of features features we search over\n",
    "max_k_shift = 100\n",
    "\n",
    "# Choose one of the comment sections below to uncomment, and then run the notebook with that uncommented\n",
    "# to recreate that experiment!\n",
    "\n",
    "# uncomment below for Explain('female' -> 'male')\n",
    "# is_subdemographic = False\n",
    "# training_frac = 0.2  # used to balance the sample numbers across experiments\n",
    "# demo1 = 'female'\n",
    "# demo2 = 'male'\n",
    "#\n",
    "\n",
    "# # uncomment below for Explain('F_0' -> 'F_1')\n",
    "# is_subdemographic = True\n",
    "# training_frac = 1  # used to balance the sample numbers across experiments\n",
    "# demo_base = 'female'\n",
    "##\n",
    "\n",
    "# # uncomment below for Explain('M_0' -> 'M_1')\n",
    "is_subdemographic = True\n",
    "training_frac = 1  # used to balance the sample numbers across experiments\n",
    "demo_base = 'male'\n",
    "##\n",
    "\n",
    "if is_subdemographic:\n",
    "    demo1 = demo_base + '_nontoxic'  # nontoxic\n",
    "    demo2 = demo_base + '_toxic'     # toxic"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "from wilds import get_dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = get_dataset(dataset='civilcomments', unlabeled=False, root_dir=str(data_dir / experiment_name))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "train = dataset.get_subset('train', frac=training_frac)\n",
    "# train = dataset.get_subset('train')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "demographics_data = {'male':[], 'female':[], 'lgbtq':[], 'christian':[], 'muslim':[],\n",
    "                    'other religions':[], 'white':[], 'black':[]}\n",
    "demographics_label = {'male':[], 'female':[], 'lgbtq':[], 'christian':[], 'muslim':[],\n",
    "                      'other religions':[], 'white':[], 'black':[]}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# splitting the training data up into the demographic groups\n",
    "all_data_arr = np.array(train, dtype=object)  # moving to np since indexing can be quirky in pytorch\n",
    "for metadata_col, corresponding_key in enumerate(demographics_data):\n",
    "    rows_in_demographic = train.metadata_array[:, metadata_col] == 1\n",
    "    demographics_data[corresponding_key] = all_data_arr[rows_in_demographic][:, 0]\n",
    "    demographics_label[corresponding_key] = np.array([item.item() for item in all_data_arr[rows_in_demographic][:, 1]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "if is_subdemographic:\n",
    "    # adding base_nontoxic and base_toxic to the demographics data and labels\n",
    "    demographics_data[demo1] = demographics_data[demo_base][demographics_label[demo_base] == 0]\n",
    "    demographics_label[demo1] = demographics_label[demo_base][demographics_label[demo_base] == 0]\n",
    "\n",
    "    demographics_data[demo2] = demographics_data[demo_base][demographics_label[demo_base] == 1]\n",
    "    demographics_label[demo2] = demographics_label[demo_base][demographics_label[demo_base] == 1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_demographic_counts(demo1, demo2, demographics_data,\n",
    "                           ngram, max_features, equalize_sizes=False):\n",
    "    # splitting between demographic attribute 1 and 2\n",
    "    og_X0 = demographics_data[demo1]\n",
    "    og_X1 = demographics_data[demo2]\n",
    "    if equalize_sizes:\n",
    "        print('Equalizing sizes.')\n",
    "        print('OG sizes:', (og_X0.shape, og_X1.shape))\n",
    "        if og_X0.shape[0] < og_X1.shape[0]:\n",
    "            rng = np.random.RandomState(42)\n",
    "            subsample_idxs = rng.choice(len(og_X1), replace=False, size=len(og_X0))\n",
    "            og_X1 = og_X1[subsample_idxs]  # subsampling to equalize sizes\n",
    "        elif og_X0.shape[0] > og_X1.shape[0]:\n",
    "            rng = np.random.RandomState(42)\n",
    "            subsample_idxs = rng.choice(len(og_X0), replace=False, size=len(og_X1))\n",
    "            og_X0 = og_X0[subsample_idxs]\n",
    "        print('New sizes:', (og_X0.shape, og_X1.shape))\n",
    "    og_X_both = np.concatenate((og_X0, og_X1))\n",
    "    ngram_vectorizer = CountVectorizer(ngram_range=(ngram,ngram),\n",
    "                                       stop_words='english', max_features=max_features)\n",
    "    vectorized_data = ngram_vectorizer.fit_transform(og_X_both)\n",
    "    X0, X1 = vectorized_data[:og_X0.shape[0]], vectorized_data[og_X0.shape[0]:] \n",
    "    return X0.toarray().astype(float), X1.toarray().astype(float), ngram_vectorizer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Equalizing sizes.\n",
      "OG sizes: ((25373,), (4437,))\n",
      "New sizes: ((4437,), (4437,))\n",
      "(4437, 500) (4437, 500)\n"
     ]
    }
   ],
   "source": [
    "ngram = 1  # used for setting the ngram range when building the ngram bag of words\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "X0, X1, ngram_vectorizer = get_demographic_counts(demo1, demo2, demographics_data,\n",
    "                                                  ngram, max_features, equalize_sizes=True)\n",
    "print(X0.shape, X1.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_shift(environment0, environment1, environment2=None, environment_labels=None, features='all', **fig_kwargs):\n",
    "    if environment2 is None:\n",
    "        environments = [environment0, environment1]\n",
    "    else:\n",
    "        environments = [environment0, environment1, environment2]\n",
    "        \n",
    "    fig, axes = plt.subplots(len(environments), 1, **fig_kwargs)\n",
    "    for environment_idx, environment in enumerate(environments):\n",
    "        if type(features) == str and features == 'all':\n",
    "            features = np.arange(environment.shape[1])\n",
    "        for feature_idx in features:\n",
    "            axes[environment_idx].plot(environment[:, feature_idx])\n",
    "        if environment_labels:\n",
    "            axes[environment_idx].set_title(f'Environment {environment_labels[environment_idx]}')\n",
    "        else:\n",
    "            axes[environment_idx].set_title(f'Environment {environment_idx}')\n",
    "    plt.tight_layout()\n",
    "    return None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_shift_results(W2s, W2_deltas, transport_costs):\n",
    "    fig, axes = plt.subplots(3,1, figsize=(8, 8), sharex='all')\n",
    "    fontsize=10\n",
    "    axes[0].plot(W2s, **line_parms)\n",
    "    axes[0].set_title(r'$W_2^2 (T^{(\\ell)}(X), Y)$ distance')\n",
    "    # axes[1].plot(np.diff(W2_deltas))\n",
    "    axes[1].plot(W2_deltas, **line_parms)\n",
    "    axes[1].set_title(r'$\\frac{W_2^2 (X, Y) - W_2^2 (T^{(\\ell)}(X), Y)}{W_2^2 (X, Y)}$% (percent of shift explained)')\n",
    "    # axes[1].set_title('Percent of change explained')\n",
    "    axes[2].plot(transport_costs, **line_parms)\n",
    "    axes[2].set_title('Transport Cost')\n",
    "    axes[2].set_xlabel('Number of features altered')\n",
    "    plt.tight_layout()\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Optimal Transport Between Enviroments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "T = BaseTransport(X0, X1, fit=False, max_iter=1e9)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "d_X01 = W2_dist(X0, X1)\n",
    "Z01 = T.fit_transform(X0, X1, 'forward')\n",
    "d_Z01 = W2_dist(Z01, X1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "W2(E0, E1)=26.822,\t W2(T_ot(E0), E1)=0.000\n"
     ]
    }
   ],
   "source": [
    "print(f'W2(E0, E1)={d_X01:.3f},\\t W2(T_ot(E0), E1)={d_Z01:.3f}')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Sparse Mean shift transport\n",
    "Here are performing mean shift transport between E0, E1 "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "def iterative_mean_shift_transport(X, Y, log=False, max_k_shift=None,\n",
    "                                   feature_names=None):\n",
    "    if log:\n",
    "        from time import time\n",
    "        start_time = time()\n",
    "    W2_X_Y = W2_dist(X, Y)  # calculating the W2 distance before any transporting\n",
    "    X_means = X.mean(axis=0)\n",
    "    Y_means = Y.mean(axis=0)\n",
    "    mean_diff_sort = np.argsort(abs(X_means - Y_means))[::-1]  # sorts in decreasing order\n",
    "    free_dim_mask = np.zeros(X.shape[1], dtype=bool)  # a mask where True mean that feature can be transported\n",
    "    Z_constrained = X.copy()\n",
    "    \n",
    "    if max_k_shift is None:\n",
    "        max_k_shift = X.shape[1]\n",
    "    \n",
    "\n",
    "    W2s = np.zeros(max_k_shift+1)  # W_2^2 distances of each transport, including T=id\n",
    "    W2s[0] = W2_X_Y\n",
    "    W2_deltas = np.zeros(max_k_shift)\n",
    "    transport_costs = np.zeros(max_k_shift+1)\n",
    "    free_dims_over_time = [[]]\n",
    "    shift_directions = []\n",
    "    \n",
    "    for n_free in tqdm(range(max_k_shift)):\n",
    "        newest_free = mean_diff_sort[n_free]  # selecting the next feature to be included in the transport\n",
    "        free_dim_mask[newest_free] = True\n",
    "        Z_constrained[:, newest_free] += Y_means[newest_free] - X_means[newest_free]\n",
    "        shift_direction = np.sign(Y_means[newest_free] - X_means[newest_free])\n",
    "        d_Z_Y = W2_dist(Y, Z_constrained)\n",
    "        # recording\n",
    "        shift_directions.append(shift_direction)\n",
    "        percent_change = 100*(W2_X_Y - d_Z_Y) / W2_X_Y  # given as a %\n",
    "        W2_deltas[n_free] = percent_change\n",
    "        W2s[n_free] = d_Z_Y\n",
    "        transport_costs[n_free+1] = calc_parsimony(X, Z_constrained)\n",
    "        free_dims_over_time.append(np.flatnonzero(free_dim_mask))\n",
    "        shifted_by = Y_means[free_dims_over_time[-1]] - X_means[free_dims_over_time[-1]]\n",
    "        indicies_to_reverse_sort = shifted_by.argsort()[::-1]   # [::-1] to sort in decreasing order\n",
    "        with np.printoptions(precision=2, suppress=True):\n",
    "#             if feature_names is None:\n",
    "#                 shifted_names = free_dims_over_time[-1][indicies_to_reverse_sort]\n",
    "#             else:\n",
    "#                 shifted_names = feature_names[free_dims_over_time[-1][indicies_to_reverse_sort]]\n",
    "#             print(f'For {n_free} free features:\\n',\n",
    "#                   f'\\tFeatures: {shifted_names} have been shifted by: {shifted_by[indicies_to_reverse_sort]}\\n', \n",
    "#                   f'\\tW2: {d_Z_Y:.3f},\\tTotal shift explained: {percent_change:.1f}%')\n",
    "            print(f'For {n_free+1} free,\\tW2: {d_Z_Y:.3f},\\tTotal shift explained: {percent_change:.3f}%')\n",
    "    if log:\n",
    "        print(f'\\nTook {(time() - start_time)/60:.3} mins')\n",
    "    return W2s, W2_deltas, transport_costs, free_dims_over_time, shift_directions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "1b3eb3a2a3e34d8ba4afe5d339fca24a",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/100 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "For 1 free,\tW2: 26.778,\tTotal shift explained: 0.163%\n",
      "For 2 free,\tW2: 26.761,\tTotal shift explained: 0.227%\n",
      "For 3 free,\tW2: 26.749,\tTotal shift explained: 0.272%\n",
      "For 4 free,\tW2: 26.738,\tTotal shift explained: 0.312%\n",
      "For 5 free,\tW2: 26.733,\tTotal shift explained: 0.332%\n",
      "For 6 free,\tW2: 26.728,\tTotal shift explained: 0.349%\n",
      "For 7 free,\tW2: 26.725,\tTotal shift explained: 0.363%\n",
      "For 8 free,\tW2: 26.722,\tTotal shift explained: 0.373%\n",
      "For 9 free,\tW2: 26.720,\tTotal shift explained: 0.381%\n",
      "For 10 free,\tW2: 26.718,\tTotal shift explained: 0.389%\n",
      "For 11 free,\tW2: 26.716,\tTotal shift explained: 0.396%\n",
      "For 12 free,\tW2: 26.714,\tTotal shift explained: 0.403%\n",
      "For 13 free,\tW2: 26.713,\tTotal shift explained: 0.408%\n",
      "For 14 free,\tW2: 26.711,\tTotal shift explained: 0.413%\n",
      "For 15 free,\tW2: 26.710,\tTotal shift explained: 0.417%\n",
      "For 16 free,\tW2: 26.709,\tTotal shift explained: 0.421%\n",
      "For 17 free,\tW2: 26.708,\tTotal shift explained: 0.425%\n",
      "For 18 free,\tW2: 26.707,\tTotal shift explained: 0.428%\n",
      "For 19 free,\tW2: 26.706,\tTotal shift explained: 0.431%\n",
      "For 20 free,\tW2: 26.705,\tTotal shift explained: 0.435%\n",
      "For 21 free,\tW2: 26.705,\tTotal shift explained: 0.438%\n",
      "For 22 free,\tW2: 26.704,\tTotal shift explained: 0.440%\n",
      "For 23 free,\tW2: 26.703,\tTotal shift explained: 0.443%\n",
      "For 24 free,\tW2: 26.703,\tTotal shift explained: 0.445%\n",
      "For 25 free,\tW2: 26.702,\tTotal shift explained: 0.447%\n",
      "For 26 free,\tW2: 26.701,\tTotal shift explained: 0.450%\n",
      "For 27 free,\tW2: 26.701,\tTotal shift explained: 0.452%\n",
      "For 28 free,\tW2: 26.700,\tTotal shift explained: 0.454%\n",
      "For 29 free,\tW2: 26.700,\tTotal shift explained: 0.456%\n",
      "For 30 free,\tW2: 26.699,\tTotal shift explained: 0.457%\n",
      "For 31 free,\tW2: 26.699,\tTotal shift explained: 0.459%\n",
      "For 32 free,\tW2: 26.698,\tTotal shift explained: 0.461%\n",
      "For 33 free,\tW2: 26.698,\tTotal shift explained: 0.462%\n",
      "For 34 free,\tW2: 26.697,\tTotal shift explained: 0.464%\n",
      "For 35 free,\tW2: 26.697,\tTotal shift explained: 0.466%\n",
      "For 36 free,\tW2: 26.697,\tTotal shift explained: 0.467%\n",
      "For 37 free,\tW2: 26.696,\tTotal shift explained: 0.469%\n",
      "For 38 free,\tW2: 26.696,\tTotal shift explained: 0.470%\n",
      "For 39 free,\tW2: 26.695,\tTotal shift explained: 0.472%\n",
      "For 40 free,\tW2: 26.695,\tTotal shift explained: 0.473%\n",
      "For 41 free,\tW2: 26.695,\tTotal shift explained: 0.474%\n",
      "For 42 free,\tW2: 26.694,\tTotal shift explained: 0.476%\n",
      "For 43 free,\tW2: 26.694,\tTotal shift explained: 0.477%\n",
      "For 44 free,\tW2: 26.694,\tTotal shift explained: 0.478%\n",
      "For 45 free,\tW2: 26.693,\tTotal shift explained: 0.479%\n",
      "For 46 free,\tW2: 26.693,\tTotal shift explained: 0.481%\n",
      "For 47 free,\tW2: 26.693,\tTotal shift explained: 0.482%\n",
      "For 48 free,\tW2: 26.692,\tTotal shift explained: 0.483%\n",
      "For 49 free,\tW2: 26.692,\tTotal shift explained: 0.484%\n",
      "For 50 free,\tW2: 26.692,\tTotal shift explained: 0.485%\n",
      "For 51 free,\tW2: 26.692,\tTotal shift explained: 0.486%\n",
      "For 52 free,\tW2: 26.691,\tTotal shift explained: 0.487%\n",
      "For 53 free,\tW2: 26.691,\tTotal shift explained: 0.488%\n",
      "For 54 free,\tW2: 26.691,\tTotal shift explained: 0.489%\n",
      "For 55 free,\tW2: 26.691,\tTotal shift explained: 0.490%\n",
      "For 56 free,\tW2: 26.690,\tTotal shift explained: 0.491%\n",
      "For 57 free,\tW2: 26.690,\tTotal shift explained: 0.491%\n",
      "For 58 free,\tW2: 26.690,\tTotal shift explained: 0.492%\n",
      "For 59 free,\tW2: 26.690,\tTotal shift explained: 0.493%\n",
      "For 60 free,\tW2: 26.689,\tTotal shift explained: 0.494%\n",
      "For 61 free,\tW2: 26.689,\tTotal shift explained: 0.495%\n",
      "For 62 free,\tW2: 26.689,\tTotal shift explained: 0.496%\n",
      "For 63 free,\tW2: 26.689,\tTotal shift explained: 0.497%\n",
      "For 64 free,\tW2: 26.688,\tTotal shift explained: 0.498%\n",
      "For 65 free,\tW2: 26.688,\tTotal shift explained: 0.498%\n",
      "For 66 free,\tW2: 26.688,\tTotal shift explained: 0.499%\n",
      "For 67 free,\tW2: 26.688,\tTotal shift explained: 0.500%\n",
      "For 68 free,\tW2: 26.688,\tTotal shift explained: 0.501%\n",
      "For 69 free,\tW2: 26.687,\tTotal shift explained: 0.501%\n",
      "For 70 free,\tW2: 26.687,\tTotal shift explained: 0.502%\n",
      "For 71 free,\tW2: 26.687,\tTotal shift explained: 0.503%\n",
      "For 72 free,\tW2: 26.687,\tTotal shift explained: 0.504%\n",
      "For 73 free,\tW2: 26.687,\tTotal shift explained: 0.504%\n",
      "For 74 free,\tW2: 26.687,\tTotal shift explained: 0.505%\n",
      "For 75 free,\tW2: 26.686,\tTotal shift explained: 0.506%\n",
      "For 76 free,\tW2: 26.686,\tTotal shift explained: 0.506%\n",
      "For 77 free,\tW2: 26.686,\tTotal shift explained: 0.507%\n",
      "For 78 free,\tW2: 26.686,\tTotal shift explained: 0.507%\n",
      "For 79 free,\tW2: 26.686,\tTotal shift explained: 0.508%\n",
      "For 80 free,\tW2: 26.686,\tTotal shift explained: 0.509%\n",
      "For 81 free,\tW2: 26.685,\tTotal shift explained: 0.509%\n",
      "For 82 free,\tW2: 26.685,\tTotal shift explained: 0.510%\n",
      "For 83 free,\tW2: 26.685,\tTotal shift explained: 0.511%\n",
      "For 84 free,\tW2: 26.685,\tTotal shift explained: 0.511%\n",
      "For 85 free,\tW2: 26.685,\tTotal shift explained: 0.512%\n",
      "For 86 free,\tW2: 26.685,\tTotal shift explained: 0.512%\n",
      "For 87 free,\tW2: 26.684,\tTotal shift explained: 0.513%\n",
      "For 88 free,\tW2: 26.684,\tTotal shift explained: 0.513%\n",
      "For 89 free,\tW2: 26.684,\tTotal shift explained: 0.514%\n",
      "For 90 free,\tW2: 26.684,\tTotal shift explained: 0.514%\n",
      "For 91 free,\tW2: 26.684,\tTotal shift explained: 0.515%\n",
      "For 92 free,\tW2: 26.684,\tTotal shift explained: 0.516%\n",
      "For 93 free,\tW2: 26.684,\tTotal shift explained: 0.516%\n",
      "For 94 free,\tW2: 26.683,\tTotal shift explained: 0.517%\n",
      "For 95 free,\tW2: 26.683,\tTotal shift explained: 0.517%\n",
      "For 96 free,\tW2: 26.683,\tTotal shift explained: 0.518%\n",
      "For 97 free,\tW2: 26.683,\tTotal shift explained: 0.518%\n",
      "For 98 free,\tW2: 26.683,\tTotal shift explained: 0.519%\n",
      "For 99 free,\tW2: 26.683,\tTotal shift explained: 0.519%\n",
      "For 100 free,\tW2: 26.683,\tTotal shift explained: 0.520%\n",
      "\n",
      "Took 9.29 mins\n"
     ]
    }
   ],
   "source": [
    "W2s, W2_deltas, transport_costs, free_dims_over_time, directions = iterative_mean_shift_transport(X0, X1, log=True,\n",
    "                                                                                      max_k_shift=max_k_shift,\n",
    "                                                                                      feature_names=ngram_vectorizer.get_feature_names_out())\n",
    "E01_sparse_mean_shift_results = [W2s, W2_deltas, transport_costs, free_dims_over_time, directions]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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dna22NUzYMAAsVwxIPTnn39W+hJ++vQp9u7dC3Nzc/To0UPjWC0sLAAUrvtFX18f8+fPh46ODj777DO1yVRmZib27t2LH3/8EcC79nZ1dcXdu3dVrkBt2rQJUVFR+OCDD8TbhK9du6a260lxJSVnG1pYWBQqfqLyjl02RBXIiBEjcP78eQwbNgzu7u7Q19fHhQsXkJmZiSZNmqgdGKqp1NRUjBo1CnXr1oWTkxNq1qyJhIQE/PPPP8jIyMCYMWNU9uncuTPGjRuHvn37wtraGufPn8fdu3fh6uqKgQMHivU8PDzw559/4t9//4WHhwc6deokzkOSmpqKZcuWqe2yyUubNm2wefNmLFy4EL1794axsTHkcjm6dOmS737dunXD//73PyxcuBDDhw9HixYt4OjoCGNjY0RERODChQuIjIzE2LFjxX2++eYbDB8+HLNmzUJAQADq1auHu3fv4ty5c6hdu7bSPC6bN2/GxYsX0aZNG9SpUwd6enq4ceMGbt26hdatW8PR0VGs6+bmhoCAAEyfPh329vbQ09NDv379UKtWLY3bgag8YUJCVIF0794dK1aswIYNG3Do0CGYmZmhY8eOmD17NmbMmFGsYxsbG2PWrFm4dOkSrly5Is4y2qRJE4wZMwYdOnRQ2adPnz7w9PTE+vXrceLECVSpUgWjR4/GZ599JnarAO+6J1avXo0tW7bg8OHD2LZtG2QyGZo3b46JEyeqvYslP507d8bMmTPh5+eHDRs2IDMzE56engUmJAAwaNAguLm5Yfv27bhw4QL27dsnzkjbokULfPjhh0oP12vYsCH27duHVatW4fz58zh16hRq1KiBESNG4NNPP1Ua8Dps2DCYmZnh9u3buHTpEnR1dWFnZ4fZs2djxIgRSmNivvzySwiCgIsXLyIgIACCIMDZ2ZkJCVVYnDqeiEpczqnjc14JISLKC8eQEBERkeSYkBAREZHkmJAQERGR5DiGhIiIiCRXIe6yUTdfABEREZVN6p5zVSESEkD9mysJwcHBah88RiWHbVw62M7axzYuHWxn7dNmG+d1EaHCJCRERERUdNnZ2cjIyEB6enq+T/HWFiYkREREWiAIArKyspCeno60tDTxi74oiyb750wm1JWp+znna87HNshkMkyYMAG//vpriT7EMj9MSIiIqNwSBAFpaWlKi+ILXN16zi/3knrN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VyaToXfv3hg0aBD69eun9vlBREREZY1GCYmXlxe8vLw0PmivXr3Qq1cvjeo2adIEGzdu1PjYlYUgCPj777+xYsUKBAQE5FvX0NAQffr0wZAhQ9CvXz+OBSEionKnWINaSTtOnDiBuXPnijPf5qVTp04YM2YMPD09izwHCBERUVnAhKQMiYiIwPTp07F79+4869SsWROjRo3C2LFjxYHARERE5R0TkjIgOzsbmzdvxpw5c8Q5XXJzc3PDjBkzMHDgQBgYGJRugERERFrGhERiYWFh8Pb2xunTp1W26erqYtCgQZgxYwYfMkhERBUaExIJHT9+HKNGjUJMTIzKthYtWuD333+Hi4uLBJERERGVLtVHsJLWpaenY/bs2ejXr59KMmJiYoLly5fjypUrTEaIiKjS4BWSUhYaGorBgwfj8uXLKtt69uyJDRs2oF69eqUfGBERkYR4haQU3bp1C25ubirJiJ6eHpYsWYKAgAAmI0REVCnxCkkp+eeff+Dp6Ym3b98qldepUwe7d+9Gu3btJIqMiIhIerxCUgp27doFd3d3lWSkf//+uHXrFpMRIiKq9JiQaNmKFSswfPhwZGRkKJXPmDEDhw4d4rNmiIiIwC4brfL398fMmTNVypctW4ZZs2ZJEBEREVHZxIRESzIyMlSSEQMDA2zZsgUjRoyQKCoiIqKyiQmJlqxfvx4hISHiuo6ODo4dO6bxU5CJiIgqE44h0YL4+Hh88803SmXjxo1jMkJERJQHJiRa8L///U9pBlZTU1N89913EkZERERUtjEhKWGPHz/GypUrlcq++OIL2NraShQRERFR2ceEpIR98cUXSE9PF9dr166t9k4bIiIi+j9MSErQuXPnsG/fPqWyH374ASYmJhJFREREVD4wISkhgiBgzpw5SmWtWrXC8OHDJYqIiIio/GBCUkJOnDiBS5cuKZUtX74curpsYiIiooLw27IECIKABQsWKJX1798fnTp1kigiIiKi8oUJSQk4evQorl+/rlT27bffShQNERFR+cOEpJgEQcDChQuVygYOHIgWLVpIFBEREVH5w4SkmA4dOoRbt24pleVOUIiIiCh/TEiKITs7WyX58PLygpOTk0QRERERlU9MSIph//79CAwMFNd1dHR4dYSIiKgICnza7927d3H06FFcunQJYWFhyMjIQMOGDeHl5YWhQ4dCR0dH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",
      "text/plain": [
       "<Figure size 576x576 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plotting results for sparse mean shift transport between E0, E1\n",
    "plot_shift_results(W2s, W2_deltas, transport_costs)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Iterative unconstrained feature transport"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "def iterative_unconstrained_feature_transport(X, Y, T, log=False, max_k_shift=None,\n",
    "                                              feature_names=None):\n",
    "    if max_k_shift is None:\n",
    "        max_k_shift = X.shape[1]\n",
    "    if log:\n",
    "        from time import time\n",
    "        start_time = time()\n",
    "        print('Calculating Zot')\n",
    "    Z_OT = T.fit(X,Y).forward(X)\n",
    "    if log:\n",
    "        print('Zot calculated!')\n",
    "    W2_X_Y = W2_dist(X, Y)  # calculating the W2 distance before any transporting\n",
    "    argsorted_diff = np.linalg.norm(Z_OT - X, axis=0).argsort()[::-1]  # a feature-wise divergence array in decreasing order\n",
    "    free_dim_mask = np.zeros(X.shape[1], dtype=bool)  # a mask where True mean that feature can be transported\n",
    "    Z_sparse_OT = X.copy()\n",
    "    W2s = np.zeros(max_k_shift+1)  # W_2^2 distances of each transport, including T=id\n",
    "    W2s[0] = W2_X_Y\n",
    "    W2_deltas = np.zeros(max_k_shift)\n",
    "    transport_costs = np.zeros(max_k_shift+1)\n",
    "    free_dims_over_time = [[]]\n",
    "    shift_directions = []\n",
    "    for n_free in tqdm(range(max_k_shift)):\n",
    "        newest_free = argsorted_diff[n_free]  # selecting the next feature to be included in the transport\n",
    "        free_dim_mask[newest_free] = True\n",
    "        Z_sparse_OT[:, newest_free] = Z_OT[:, newest_free]\n",
    "        shift_direction = np.sign((Z_OT[:, newest_free] - X[:, newest_free]).mean())\n",
    "        d_Z_Y = W2_dist(Y, Z_sparse_OT)\n",
    "        # recording\n",
    "        percent_change = 100*(W2_X_Y - d_Z_Y) / W2_X_Y  # given as a %\n",
    "        W2_deltas[n_free] = percent_change\n",
    "        W2s[n_free+1] = d_Z_Y\n",
    "        transport_costs[n_free+1] = calc_parsimony(X, Z_sparse_OT)\n",
    "        free_dims_over_time.append(np.flatnonzero(free_dim_mask))\n",
    "        shift_directions.append(shift_direction)\n",
    "        print(f'For {n_free+1} free,\\tW2: {d_Z_Y:.3f},\\tTotal shift explained: {percent_change:.3f}%')\n",
    "    if log:\n",
    "        print(f'\\nTook {(time() - start_time)/60:.3} mins')\n",
    "    return W2s, W2_deltas, transport_costs, free_dims_over_time, shift_directions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating Zot\n",
      "Zot calculated!\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8da953cdc39647fa9c1e18c408e68ccc",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/100 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "For 1 free,\tW2: 26.419,\tTotal shift explained: 1.502%\n",
      "For 2 free,\tW2: 26.071,\tTotal shift explained: 2.801%\n",
      "For 3 free,\tW2: 25.733,\tTotal shift explained: 4.059%\n",
      "For 4 free,\tW2: 25.404,\tTotal shift explained: 5.288%\n",
      "For 5 free,\tW2: 25.121,\tTotal shift explained: 6.341%\n",
      "For 6 free,\tW2: 24.858,\tTotal shift explained: 7.320%\n",
      "For 7 free,\tW2: 24.605,\tTotal shift explained: 8.267%\n",
      "For 8 free,\tW2: 24.358,\tTotal shift explained: 9.188%\n",
      "For 9 free,\tW2: 24.122,\tTotal shift explained: 10.067%\n",
      "For 10 free,\tW2: 23.902,\tTotal shift explained: 10.886%\n",
      "For 11 free,\tW2: 23.709,\tTotal shift explained: 11.605%\n",
      "For 12 free,\tW2: 23.517,\tTotal shift explained: 12.322%\n",
      "For 13 free,\tW2: 23.341,\tTotal shift explained: 12.977%\n",
      "For 14 free,\tW2: 23.170,\tTotal shift explained: 13.615%\n",
      "For 15 free,\tW2: 23.004,\tTotal shift explained: 14.234%\n",
      "For 16 free,\tW2: 22.840,\tTotal shift explained: 14.844%\n",
      "For 17 free,\tW2: 22.684,\tTotal shift explained: 15.426%\n",
      "For 18 free,\tW2: 22.534,\tTotal shift explained: 15.987%\n",
      "For 19 free,\tW2: 22.384,\tTotal shift explained: 16.547%\n",
      "For 20 free,\tW2: 22.236,\tTotal shift explained: 17.099%\n",
      "For 21 free,\tW2: 22.089,\tTotal shift explained: 17.646%\n",
      "For 22 free,\tW2: 21.950,\tTotal shift explained: 18.166%\n",
      "For 23 free,\tW2: 21.813,\tTotal shift explained: 18.673%\n",
      "For 24 free,\tW2: 21.680,\tTotal shift explained: 19.171%\n",
      "For 25 free,\tW2: 21.547,\tTotal shift explained: 19.666%\n",
      "For 26 free,\tW2: 21.416,\tTotal shift explained: 20.155%\n",
      "For 27 free,\tW2: 21.286,\tTotal shift explained: 20.639%\n",
      "For 28 free,\tW2: 21.158,\tTotal shift explained: 21.118%\n",
      "For 29 free,\tW2: 21.034,\tTotal shift explained: 21.578%\n",
      "For 30 free,\tW2: 20.911,\tTotal shift explained: 22.037%\n",
      "For 31 free,\tW2: 20.799,\tTotal shift explained: 22.457%\n",
      "For 32 free,\tW2: 20.686,\tTotal shift explained: 22.875%\n",
      "For 33 free,\tW2: 20.575,\tTotal shift explained: 23.291%\n",
      "For 34 free,\tW2: 20.465,\tTotal shift explained: 23.701%\n",
      "For 35 free,\tW2: 20.355,\tTotal shift explained: 24.111%\n",
      "For 36 free,\tW2: 20.247,\tTotal shift explained: 24.513%\n",
      "For 37 free,\tW2: 20.140,\tTotal shift explained: 24.911%\n",
      "For 38 free,\tW2: 20.035,\tTotal shift explained: 25.303%\n",
      "For 39 free,\tW2: 19.930,\tTotal shift explained: 25.694%\n",
      "For 40 free,\tW2: 19.829,\tTotal shift explained: 26.072%\n",
      "For 41 free,\tW2: 19.730,\tTotal shift explained: 26.440%\n",
      "For 42 free,\tW2: 19.632,\tTotal shift explained: 26.806%\n",
      "For 43 free,\tW2: 19.534,\tTotal shift explained: 27.171%\n",
      "For 44 free,\tW2: 19.438,\tTotal shift explained: 27.529%\n",
      "For 45 free,\tW2: 19.343,\tTotal shift explained: 27.885%\n",
      "For 46 free,\tW2: 19.247,\tTotal shift explained: 28.241%\n",
      "For 47 free,\tW2: 19.153,\tTotal shift explained: 28.593%\n",
      "For 48 free,\tW2: 19.059,\tTotal shift explained: 28.942%\n",
      "For 49 free,\tW2: 18.966,\tTotal shift explained: 29.289%\n",
      "For 50 free,\tW2: 18.874,\tTotal shift explained: 29.633%\n",
      "For 51 free,\tW2: 18.782,\tTotal shift explained: 29.977%\n",
      "For 52 free,\tW2: 18.690,\tTotal shift explained: 30.320%\n",
      "For 53 free,\tW2: 18.598,\tTotal shift explained: 30.662%\n",
      "For 54 free,\tW2: 18.508,\tTotal shift explained: 30.998%\n",
      "For 55 free,\tW2: 18.418,\tTotal shift explained: 31.331%\n",
      "For 56 free,\tW2: 18.330,\tTotal shift explained: 31.662%\n",
      "For 57 free,\tW2: 18.241,\tTotal shift explained: 31.993%\n",
      "For 58 free,\tW2: 18.152,\tTotal shift explained: 32.324%\n",
      "For 59 free,\tW2: 18.066,\tTotal shift explained: 32.645%\n",
      "For 60 free,\tW2: 17.981,\tTotal shift explained: 32.961%\n",
      "For 61 free,\tW2: 17.897,\tTotal shift explained: 33.273%\n",
      "For 62 free,\tW2: 17.814,\tTotal shift explained: 33.585%\n",
      "For 63 free,\tW2: 17.732,\tTotal shift explained: 33.891%\n",
      "For 64 free,\tW2: 17.651,\tTotal shift explained: 34.192%\n",
      "For 65 free,\tW2: 17.570,\tTotal shift explained: 34.492%\n",
      "For 66 free,\tW2: 17.490,\tTotal shift explained: 34.791%\n",
      "For 67 free,\tW2: 17.410,\tTotal shift explained: 35.091%\n",
      "For 68 free,\tW2: 17.330,\tTotal shift explained: 35.389%\n",
      "For 69 free,\tW2: 17.251,\tTotal shift explained: 35.682%\n",
      "For 70 free,\tW2: 17.174,\tTotal shift explained: 35.971%\n",
      "For 71 free,\tW2: 17.096,\tTotal shift explained: 36.260%\n",
      "For 72 free,\tW2: 17.020,\tTotal shift explained: 36.544%\n",
      "For 73 free,\tW2: 16.944,\tTotal shift explained: 36.827%\n",
      "For 74 free,\tW2: 16.869,\tTotal shift explained: 37.107%\n",
      "For 75 free,\tW2: 16.794,\tTotal shift explained: 37.387%\n",
      "For 76 free,\tW2: 16.719,\tTotal shift explained: 37.666%\n",
      "For 77 free,\tW2: 16.645,\tTotal shift explained: 37.944%\n",
      "For 78 free,\tW2: 16.571,\tTotal shift explained: 38.218%\n",
      "For 79 free,\tW2: 16.498,\tTotal shift explained: 38.490%\n",
      "For 80 free,\tW2: 16.426,\tTotal shift explained: 38.759%\n",
      "For 81 free,\tW2: 16.354,\tTotal shift explained: 39.027%\n",
      "For 82 free,\tW2: 16.283,\tTotal shift explained: 39.294%\n",
      "For 83 free,\tW2: 16.212,\tTotal shift explained: 39.558%\n",
      "For 84 free,\tW2: 16.141,\tTotal shift explained: 39.823%\n",
      "For 85 free,\tW2: 16.070,\tTotal shift explained: 40.086%\n",
      "For 86 free,\tW2: 16.000,\tTotal shift explained: 40.349%\n",
      "For 87 free,\tW2: 15.930,\tTotal shift explained: 40.609%\n",
      "For 88 free,\tW2: 15.860,\tTotal shift explained: 40.867%\n",
      "For 89 free,\tW2: 15.792,\tTotal shift explained: 41.125%\n",
      "For 90 free,\tW2: 15.723,\tTotal shift explained: 41.380%\n",
      "For 91 free,\tW2: 15.654,\tTotal shift explained: 41.636%\n",
      "For 92 free,\tW2: 15.586,\tTotal shift explained: 41.889%\n",
      "For 93 free,\tW2: 15.518,\tTotal shift explained: 42.143%\n",
      "For 94 free,\tW2: 15.451,\tTotal shift explained: 42.394%\n",
      "For 95 free,\tW2: 15.384,\tTotal shift explained: 42.646%\n",
      "For 96 free,\tW2: 15.317,\tTotal shift explained: 42.895%\n",
      "For 97 free,\tW2: 15.249,\tTotal shift explained: 43.145%\n",
      "For 98 free,\tW2: 15.183,\tTotal shift explained: 43.395%\n",
      "For 99 free,\tW2: 15.116,\tTotal shift explained: 43.644%\n",
      "For 100 free,\tW2: 15.049,\tTotal shift explained: 43.892%\n",
      "\n",
      "Took 11.8 mins\n"
     ]
    }
   ],
   "source": [
    "T = BaseTransport(X0, X1, fit=False, max_iter=1e9)\n",
    "W2s, W2_deltas, transport_costs, free_dims_over_time, directions = iterative_unconstrained_feature_transport(X0, X1, T,\n",
    "                                                                                                 log=True,\n",
    "                                                                                                 max_k_shift=max_k_shift)\n",
    "E01_unconstrained_sparse_shift_results = [W2s, W2_deltas, transport_costs, free_dims_over_time, directions]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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jXMS27U2sE1Vj21aO9iuqleXbdooA0nLli2RlpYGiUQi11OSlZUFKyurKp/Ly8tL1dUjIiKiFzTKu2ycnZ1RWlqKuLg4mfX37t3DvXv35Aa7EhERkXo1ykAyZMgQaGhoYNu2bTLrt27dCgCcEZWIiKieaZSXbBwdHfH2229jz549EAQBPj4+iIuLw549ezBixAi4u7uru4pERERUhobw4lzmjURxcbH4LJu7d+/CwsICI0eOxPTp06Gjo6Pu6hEREVEZjTaQEBERUcPRKMeQEBERUcPCQEJERERqx0BCREREasdAQkRERGrHQEJERERqx0BCREREasdAQkRERGrHQEJERERqx0BCREREasdAQkRERGrHQEJERERqx0BCREREasdAQkRERGrHQEJERERqx0BCREREasdAQkRERGrHQEJERERqx0BCREREasdAQkRERGrHQEJERERqx0BCREREasdAQkRERGrHQEJERERqx0BCREREasdAQkRERGrHQEJERERqx0BCREREasdAQkRERGrHQEJERERqx0BCREREasdAQkRERGrHQEJERERqx0BCREREaqet7goQkXIcHByqvK+VlRXOnj1bi7Vp+D7//HMcOnQIZ86cQZs2bZQ+/tatW9i2bRuCg4Nx69YtSCQStGjRAu7u7nj99dfh6+tbC7WW5eDggG7dumHbtm21XhZRbWEgIWpgZsyYIbdu9erVMDExwcSJE2XWm5iY1FW1XkoHDhzA119/jaKiInh4eGDkyJEwMDDA3bt3ERISghMnTmDy5Mn4/PPP1V1VonqPgYSogfnoo4/k1q1evRpNmjRRuI1qx7lz5/C///0PzZo1w6+//oquXbvKbC8qKsK+ffuQkpKiphoSNSwagiAI6q4EEdWMg4OD3OWZ0NBQBAQEYMaMGejRowdWrVqFuLg4mJmZ4ezZs5BIJNi9ezfOnTuHlJQUPHjwAGZmZujevTs++ugjtG/fXqaMVatWYfXq1di6dSvu3buHjRs3Ij09HU2bNsWIESPw8ccfQ0tLS9y/tLQUe/fuxd69e5GZmYmioiI0b94c7u7ueP/992FnZwcAOHjwIObPn48lS5bAwMAAGzZsQGpqKpo0aYJhw4bh448/hqGhoUxdioqKsHXrVhw+fBjXr1+Hnp4e3Nzc8P7776NLly4y+0ovyZw6dQonTpzAgQMH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",
      "text/plain": [
       "<Figure size 576x576 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plotting results for unconstrained sparse shift transport between E0, E1\n",
    "plot_shift_results(W2s, W2_deltas, transport_costs)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Generating plots specifically to be shown in paper"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmwAAAFTCAYAAACEUVDAAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAABdmklEQVR4nO3deXwM9/8H8Ndsjs2JIAeh6qcSJOIqdbWKuqmj4mxStBJt0YNvT6Xf+n5VD9WirvJtS5U0pRShrWqrKK1QTYi4jwS55N57d35/pNlau0l2Y7Ozyb6ej/ZBZj47854dO3nv5xREURRBRERERE5LJnUARERERFQ5JmxERERETo4JGxEREZGTY8JGRERE5OSYsBERERE5OSZsRERERE6OCRsRERGRk2PCRkREROTkJEnYVq9ejdGjR6NTp07o3bs3Xn75ZeTk5NT4eU+dOoWBAwdCr9dXWi42NhZ79+6t8XiIiIiIrCFJwpacnIwpU6bg66+/xsqVK3Hp0iXMmjWrxs+7dOlSTJs2DW5ubibbDxw4gP79++Pf//43AGDGjBlYunQpuAgEEREROQPBGZam+uuvvxAdHY3Dhw+jUaNGNXKOa9euYdiwYTh48CDq1atnsm/QoEGIjY3FgQMHsGbNGoiiiD59+mDx4sXo2bNnjcRDREREZC2n6MNWUlICd3d3+Pn5me3T6/UYMmQIZs+efVfn2LNnDzp06GCWrJ06dQpyuRwA0LJlSwCAIAh46KGHkJSUZPFY9ooJAE6cOIHw8HDs37//ro8l1Tm3bduG8PBwbNu2zbjt6NGjCA8Px/Lly+1yDleg0WjwwQcf4JFHHkFERATCw8ORlpYmdVhEROQErErYrl27hvDwcEyfPt3i/vnz5yM8PByTJk2yuP8///kPwsPDsXPnTrN9Go0GS5YswaOPPmpMnG731Vdf4dKlS5g5cyYAwGAwoFOnTggPD7fq//79+wMAjh8/joiICLPjHzp0CD169MDPP/+MPn36GLdHRkbi2LFjFq/nzpjKXb16Fe3atcO4ceMsvu7UqVPo1KkTHnjgAVy5cgUAjP34lixZUmXfuoosWrQI4eHhWLNmTYVlFixYgPDwcLz//vt2OWdNc8WEb926dVizZg2aNm2Kp556CjNnzkTjxo0dcu6MjIwqP0sxMTFmrztx4gSefPJJdOnSBZ06dcKkSZPw888/OyTmu1Gd692xYwfmz5+PMWPGIDIyEuHh4di3b59EV/CPn3/+GStWrMCOHTukDsXIlpiuXbuGw4cPIysrC+vWrcP27duhVqsdECVR7eJuTaHyWqni4mKzffn5+cYPpaX9JSUl2LZtG4KDgzF48GCTfQaDAS+99BL0ej1ef/11s9fqdDqsXLkSDz74IMLCwgAApaWlmDZtmkm5K1euYOfOnWjbtq0xQSt3zz33AACuX7+Orl27mp3jxIkT6NWrFw4cOIAHHnjAuD0wMBDXr1+3KqbbzzVkyBDs2rULR44cQffu3Y37bt68iRkzZkCn0+GTTz5BixYtjPumTZuGadOmYe/evRg2bJjZOavy5JNP4ssvv8TGjRsxdepUeHp6muxft24dtmzZgsGDB2POnDl2OWdVoqKikJSUhICAALsfu646cOAAfHx8sH79enh4eEgSQ8uWLSv89xAaGmry8+HDhzF9+nR4eXlh2LBh8Pb2xp49exAfH4+3334bY8aMcUTId8WW6/3oo4+QmZmJhg0bonHjxrhx44YjQgQA7N+/H4WFhRg9ejTi4+MRHR2NRx55BLNmzcIHH3yArl274ssvvwRQ9gV5zpw58Pb2xnPPPYclS5Zg3759uHLlCuLj443H/P7775GTk4PJkydjzZo1aN26NYKCgpCamooJEybYNabb40pKSsLJkydx8OBB9O7dG61atUJMTAwSExPRunVr/N///R8OHTqEfv36VXotvXr1shjr3V4XkbOyKmHz9/eHIAgoLS0127dlyxaoVCo0adIEJSUlZvu//vprlJaWYsaMGSa/hERRxGuvvYb09HRs2rTJYnPo/v37kZ2djZdeeskkljsHKGzcuBE7d+7E4MGDMWPGDIvXoFarzRIZALhw4QI8PDzw+OOPQyb7p8LRy8sLGo0GBoPBZLulmG4XFxeH3bt3Y+3atcaEraSkBHFxccjJycH777+P+++/3+Q13bt3R2BgIBISEqqVPAUHB2PMmDFISEjAt99+i7Fjxxr37d2711ir9u6770IQBLucsyre3t5o1aqV3Y9bl+Xk5CAgIECyZA0A/u///s+qAUBarRbz5s2Dm5sbvvzyS4SHhwMA4uPjMXr0aPz3v/9Fv3790KBBg7uK588//0THjh3v6hiVsfZ6gbKE495770XTpk2xfPlyrFixosbiulO9evWQ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",
      "text/plain": [
       "<Figure size 720x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Visualizing the Pareoto Frontier and % explained for E0->E1 for sparse mean shift\n",
    "fontsize=10\n",
    "figs, axes = plt.subplots(1, 2, figsize=(10,5))\n",
    "axes[0].plot(E01_sparse_mean_shift_results[0])\n",
    "axes[0].set_title(r'$W_2^2 (T^{(\\ell)}(X), Y)$ distance for E0 -> E1')\n",
    "axes[1].plot(E01_sparse_mean_shift_results[1])\n",
    "axes[1].set_title(r'$\\frac{W_2^2 (X, Y) - W_2^2 (T^{(\\ell)}(X), Y)}{W_2^2 (X, Y)}$% (percent of shift explained)', fontsize=fontsize)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Visualizing the % explained for both E0->E1 and E1->E2 for unconstrained sparse feature shift\n",
    "fontsize=10\n",
    "figs, axes = plt.subplots(1, 2, figsize=(10,5))\n",
    "axes[0].plot(E01_unconstrained_sparse_shift_results[0])\n",
    "axes[0].set_title(r'$W_2^2 (T^{(\\ell)}(X), Y)$ distance for E0 -> E1')\n",
    "axes[1].plot(E01_unconstrained_sparse_shift_results[1])\n",
    "axes[1].set_title(r'$\\frac{W_2^2 (X, Y) - W_2^2 (T^{(\\ell)}(X), Y)}{W_2^2 (X, Y)}$% (percent of shift explained)', fontsize=fontsize)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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f4hEIuzevVuq3NfXFwDg4OAgKXv8+DEePHggczwAmeN3794NdXV19OvXr8D3XrVqFaytrdG7d29JmYGBAf7991/J69jY2Ao7u5uIiIioLFSqMZOmpqYYOXIkAgICIAgCunbtiqioKAQEBGDIkCFo166dpO348ePx9OlTxMTESMp69eqFbt26YceOHUhLS4OZmRn++usvHDt2DDNmzEDDhg3lvu+ff/6Js2fPIiwsTKp84MCB2LFjB+rUqYN3797h3LlzWLlyZdlcPBEREVEFVKmSSQBYtGgRDA0NERgYiPDwcBgYGGDGjBmYMmWKQsdv2bIFmzZtwtGjR3Hw4EE0adIEixYtktmbO19WVhaWLl2KmTNnolGjRlJ106ZNQ1paGvz8/KCmpoYZM2ZgyJAhn3yNRERERJWFSKiMCypVEREREbCysirT9+CSDRUT+6XiYt9UTOyXiot9UzGV1dJA8vKWSjVmkoiIiIgqFiaTRERERFRiTCaJiIiIqMQ4ZlKJCtqWiIiIiKgikjdmkskkEREREZUYH3MTERERUYkxmSQiIiKiEmMySUREREQlxmSSiIiIiEqMySQRERERlRiTSSIiIiIqMSaTRERERFRiTCarmNzcXGzfvh19+vSBmZkZevfujd9++w05OTnKDq1auHPnDlavXg1HR0d06NAB7dq1w9ChQ7F3717IW9I1PDwcw4YNg7m5OTp37owffvgBL1++VELk1dODBw9gZmYGExMTnD17Vqae/VN+Xr58iRUrVqBnz54wMzND165dMWnSJPz7779S7dgn5Ss1NRVr165F37590a5dO3Tr1g2TJk3C5cuXZdqyb0rfu3fvsGXLFkydOhXdunWDiYkJZs2aVWD74vTB/fv34erqCisrK1haWmLixIm4d+9eieLkouVVzJIlS7B3717Y29uja9euiIyMxP79+zF06FB4eHgoO7wqb86cObh06RL69OmDNm3aQCwW49ixY/jnn38wcuRILF++XNI2LCwMc+bMgZmZGYYPH46UlBTs2rULhoaGCAwMRI0aNZR4JVWfIAhwcXHB3bt3kZ6eDi8vL/To0UNSz/4pP48fP4aLiwtUVVUxZMgQNG7cGK9fv0ZUVBScnJxgbW0NgH1S3rKysuDo6Ihnz55h5MiRMDY2RkpKCgIDA/H06VP89ttv6NmzJwD2TVl58uQJevXq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gqqqKp49e4br169DV1cXx48fBwDs2rULf//9Nzp16oQmTZpAVVUVN27cwM2bN9GxY0eFtgo1MzPDli1b4ObmhunTp8PU1BRWVlaoVasWkpOTceXKFcTHx8td0FxRzs7OWLlyJYYMGQI7OzuIxWJcvHgRBgYGkgk7n8LNzQ1///03li9fjkuXLqF58+aIjo7GjRs30KFDB1y/fl3qLvSYMWPwzz//ICQkBFevXkWnTp1Qv359JCUlISYmBtHR0QgICJCMt/zpp5/g5OSEb7/9VmqdyYSEBJiYmEgm6RB9KiaTRJWcuro6Zs2aVeAdmB49euDnn3/Gtm3bcOjQIdSrVw9DhgzB9OnTiz0TuiQ+++wz/PTTT/j555/h5+cHkUiEvn37yl0CqFevXjh06BB27NiBv//+GxcuXIC2tjYaN26McePGSS2+/SkWL16M1q1bY9++fdi7dy9UVFTQqlUrLFmyRGYZlbKkqamJXbt2ISAgACEhIQgLC0NOTg709fVhYmKCadOmSSZoqKqqYtu2bfD09MSff/6J27dvo3nz5vDw8ECDBg3kJpM//PADBEHA33//jePHj0MQBLRr1w6NGzdGzZo14e3tDQ8PD1y9ehX//PMPrK2tERAQAC8vr2Jfy2effYagoCDs2rULp0+fxv79+6GmpoYGDRqgR48eUnd7nZycoKOjg1u3buHy5ctQUVGBoaEh5s2bB2dnZ4XHwXbv3h0nT57E7t27cf78eRw+fBgZGRnQ09NDmzZtMHPmTDg4OBT7WvKNHTsWqqqq8Pf3x/79+1GnTh306dMH3377balMejM0NMS+ffuwdu1a/P333/j7779hYWEBf39/bNiwAQCkxo6KRCJ4enrC1tYWgYGBOH36NDIyMlC/fn00b94cixcvlpq8ZGpqCn9/f3h6euLMmTNQV1dHp06dsH79eri7u39y/ET5RILwwR5cREREpFR5eXno3bs3MjIyFN42lUiZOGaSiIhISeStVbljxw48ffoUvXr1UkJERMXHO5NERERK0qFDB5ibm6N58+YQBAG3b9/GrVu3UL9+fRw6dKjEu/wQlScmk0REREry888/4/z583j+/DkyMzNRv359dOvWDdOnT0fjxo2VHR6RQphMEhEREVGJccwkEREREZUYk0kiIiIiKjEmk0RERERUYkwmiYiIiKjEmEwSERERUYkxmSQiIiKiEvt/SZNvltgqdV8AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Visualizing the Pareoto Frontier and % explained for both E0->E1 and E1->E2 for sparse mean shift\n",
    "fontsize=15\n",
    "figs, axes = plt.subplots(1, 1, figsize=(10,5))\n",
    "axes.plot(E01_sparse_mean_shift_results[1], **line_parms)\n",
    "axes.plot(E01_unconstrained_sparse_shift_results[1], **line_parms, linestyle='--')\n",
    "if add_title: axes.set_title(r'$\\frac{W_2^2 (X, Y) - W_2^2 (T^{(\\ell)}(X), Y)}{W_2^2 (X, Y)}$% (percent of shift explained)', fontsize=fontsize)\n",
    "for idx in range(1):\n",
    "    axes.set_xlabel('Number of Features Changed')\n",
    "    axes.yaxis.set_major_formatter(mtick.PercentFormatter())\n",
    "# plt.tight_layout()\n",
    "# plt.legend()\n",
    "axes.set_ylabel('Percent Explained')\n",
    "if add_legend: plt.legend()\n",
    "if save_figures: plt.savefig(figure_dir / f'mean-shift-E01-E12-percent-explained.{save_parms[\"format\"]}', **save_parms)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The Full notebook took 21.5 mins\n"
     ]
    }
   ],
   "source": [
    "print(f'The Full notebook took {(time() - entire_notebook_start_time)/60:.3} mins')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "def sign_to_str(sign):\n",
    "    if sign == 1 or sign == 1.0:\n",
    "        return '+'\n",
    "    else:\n",
    "        return '-'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "For pushforward of male_nontoxic comments to male_toxic comments:\n",
      "For k=1:\n",
      "\tmean:\t+ trump\t0.2272%\n",
      "\tOT:\t- women\t2.801%\n",
      "\n",
      "For k=2:\n",
      "\tmean:\t- women\t0.2716%\n",
      "\tOT:\t- men\t4.059%\n",
      "\n",
      "For k=3:\n",
      "\tmean:\t+ black\t0.3117%\n",
      "\tOT:\t+ man\t5.288%\n",
      "\n",
      "For k=4:\n",
      "\tmean:\t- church\t0.3318%\n",
      "\tOT:\t+ people\t6.341%\n",
      "\n",
      "For k=5:\n",
      "\tmean:\t+ stupid\t0.3485%\n",
      "\tOT:\t+ like\t7.32%\n",
      "\n",
      "For k=6:\n",
      "\tmean:\t+ gay\t0.3627%\n",
      "\tOT:\t+ trump\t8.267%\n",
      "\n",
      "For k=7:\n",
      "\tmean:\t+ racist\t0.3727%\n",
      "\tOT:\t+ just\t9.188%\n",
      "\n",
      "For k=8:\n",
      "\tmean:\t- god\t0.3813%\n",
      "\tOT:\t+ don\t10.07%\n",
      "\n",
      "For k=9:\n",
      "\tmean:\t- jesus\t0.3889%\n",
      "\tOT:\t+ black\t10.89%\n",
      "\n",
      "For k=10:\n",
      "\tmean:\t+ man\t0.3961%\n",
      "\tOT:\t- male\t11.61%\n",
      "\n",
      "For k=11:\n",
      "\tmean:\t+ sex\t0.4027%\n",
      "\tOT:\t- woman\t12.32%\n",
      "\n",
      "For k=12:\n",
      "\tmean:\t- female\t0.408%\n",
      "\tOT:\t- know\t12.98%\n",
      "\n",
      "For k=13:\n",
      "\tmean:\t+ like\t0.4132%\n",
      "\tOT:\t- think\t13.61%\n",
      "\n",
      "For k=14:\n",
      "\tmean:\t- time\t0.4173%\n",
      "\tOT:\t- time\t14.23%\n",
      "\n",
      "For k=15:\n",
      "\tmean:\t+ rape\t0.4211%\n",
      "\tOT:\t- church\t14.84%\n",
      "\n",
      "For k=16:\n",
      "\tmean:\t- good\t0.4246%\n",
      "\tOT:\t- right\t15.43%\n",
      "\n",
      "For k=17:\n",
      "\tmean:\t+ muslim\t0.4281%\n",
      "\tOT:\t- did\t15.99%\n",
      "\n",
      "For k=18:\n",
      "\tmean:\t- did\t0.4315%\n",
      "\tOT:\t+ want\t16.55%\n",
      "\n",
      "For k=19:\n",
      "\tmean:\t- work\t0.4349%\n",
      "\tOT:\t- good\t17.1%\n",
      "\n",
      "For k=20:\n",
      "\tmean:\t+ ignorant\t0.4376%\n",
      "\tOT:\t- does\t17.65%\n",
      "\n",
      "For k=21:\n",
      "\tmean:\t- male\t0.4402%\n",
      "\tOT:\t- say\t18.17%\n",
      "\n",
      "For k=22:\n",
      "\tmean:\t+ idiot\t0.4427%\n",
      "\tOT:\t- way\t18.67%\n",
      "\n",
      "For k=23:\n",
      "\tmean:\t+ pathetic\t0.445%\n",
      "\tOT:\t- years\t19.17%\n",
      "\n",
      "For k=24:\n",
      "\tmean:\t- men\t0.4473%\n",
      "\tOT:\t+ children\t19.67%\n",
      "\n",
      "For k=25:\n",
      "\tmean:\t+ guy\t0.4495%\n",
      "\tOT:\t+ sex\t20.15%\n",
      "\n",
      "For k=26:\n",
      "\tmean:\t- life\t0.4518%\n",
      "\tOT:\t- make\t20.64%\n",
      "\n",
      "For k=27:\n",
      "\tmean:\t+ don\t0.4538%\n",
      "\tOT:\t- god\t21.12%\n",
      "\n",
      "For k=28:\n",
      "\tmean:\t+ hillary\t0.4557%\n",
      "\tOT:\t- need\t21.58%\n",
      "\n",
      "For k=29:\n",
      "\tmean:\t+ america\t0.4574%\n",
      "\tOT:\t+ gay\t22.04%\n",
      "\n",
      "For k=30:\n",
      "\tmean:\t- family\t0.4591%\n",
      "\tOT:\t- female\t22.46%\n",
      "\n",
      "For k=31:\n",
      "\tmean:\t- years\t0.4608%\n",
      "\tOT:\t+ sexual\t22.87%\n",
      "\n",
      "For k=32:\n",
      "\tmean:\t- christ\t0.4624%\n",
      "\tOT:\t- life\t23.29%\n",
      "\n",
      "For k=33:\n",
      "\tmean:\t- said\t0.464%\n",
      "\tOT:\t- believe\t23.7%\n",
      "\n",
      "For k=34:\n",
      "\tmean:\t- think\t0.4656%\n",
      "\tOT:\t- said\t24.11%\n",
      "\n",
      "For k=35:\n",
      "\tmean:\t+ ridiculous\t0.4672%\n",
      "\tOT:\t+ old\t24.51%\n",
      "\n",
      "For k=36:\n",
      "\tmean:\t- gender\t0.4687%\n",
      "\tOT:\t- going\t24.91%\n",
      "\n",
      "For k=37:\n",
      "\tmean:\t- catholic\t0.4702%\n",
      "\tOT:\t+ matter\t25.3%\n",
      "\n",
      "For k=38:\n",
      "\tmean:\t- fact\t0.4716%\n",
      "\tOT:\t+ really\t25.69%\n",
      "\n",
      "For k=39:\n",
      "\tmean:\t- point\t0.473%\n",
      "\tOT:\t- world\t26.07%\n",
      "\n",
      "For k=40:\n",
      "\tmean:\t+ disgusting\t0.4743%\n",
      "\tOT:\t- person\t26.44%\n",
      "\n",
      "For k=41:\n",
      "\tmean:\t+ clinton\t0.4757%\n",
      "\tOT:\t- doesn\t26.81%\n",
      "\n",
      "For k=42:\n",
      "\tmean:\t+ just\t0.4769%\n",
      "\tOT:\t- anti\t27.17%\n",
      "\n",
      "For k=43:\n",
      "\tmean:\t+ country\t0.4782%\n",
      "\tOT:\t- young\t27.53%\n",
      "\n",
      "For k=44:\n",
      "\tmean:\t- does\t0.4793%\n",
      "\tOT:\t- jesus\t27.89%\n",
      "\n",
      "For k=45:\n",
      "\tmean:\t+ president\t0.4805%\n",
      "\tOT:\t+ racist\t28.24%\n",
      "\n",
      "For k=46:\n",
      "\tmean:\t+ sick\t0.4816%\n",
      "\tOT:\t- thing\t28.59%\n",
      "\n",
      "For k=47:\n",
      "\tmean:\t- know\t0.4827%\n",
      "\tOT:\t+ country\t28.94%\n",
      "\n",
      "For k=48:\n",
      "\tmean:\t+ racism\t0.4837%\n",
      "\tOT:\t- fact\t29.29%\n",
      "\n",
      "For k=49:\n",
      "\tmean:\t- law\t0.4847%\n",
      "\tOT:\t- work\t29.63%\n",
      "\n",
      "For k=50:\n",
      "\tmean:\t+ donald\t0.4857%\n",
      "\tOT:\t+ guy\t29.98%\n",
      "\n",
      "For k=51:\n",
      "\tmean:\t- change\t0.4867%\n",
      "\tOT:\t- human\t30.32%\n",
      "\n",
      "For k=52:\n",
      "\tmean:\t+ whites\t0.4877%\n",
      "\tOT:\t- law\t30.66%\n",
      "\n",
      "For k=53:\n",
      "\tmean:\t+ people\t0.4886%\n",
      "\tOT:\t+ president\t31.0%\n",
      "\n",
      "For k=54:\n",
      "\tmean:\t+ hate\t0.4896%\n",
      "\tOT:\t- let\t31.33%\n",
      "\n",
      "For k=55:\n",
      "\tmean:\t+ obama\t0.4905%\n",
      "\tOT:\t+ muslim\t31.66%\n",
      "\n",
      "For k=56:\n",
      "\tmean:\t- state\t0.4915%\n",
      "\tOT:\t+ males\t31.99%\n",
      "\n",
      "For k=57:\n",
      "\tmean:\t- human\t0.4924%\n",
      "\tOT:\t+ stupid\t32.32%\n",
      "\n",
      "For k=58:\n",
      "\tmean:\t- francis\t0.4933%\n",
      "\tOT:\t- support\t32.64%\n",
      "\n",
      "For k=59:\n",
      "\tmean:\t+ killing\t0.4942%\n",
      "\tOT:\t- problem\t32.96%\n",
      "\n",
      "For k=60:\n",
      "\tmean:\t- home\t0.4951%\n",
      "\tOT:\t- things\t33.27%\n",
      "\n",
      "For k=61:\n",
      "\tmean:\t+ crimes\t0.496%\n",
      "\tOT:\t+ real\t33.58%\n",
      "\n",
      "For k=62:\n",
      "\tmean:\t+ muslims\t0.4968%\n",
      "\tOT:\t- better\t33.89%\n",
      "\n",
      "For k=63:\n",
      "\tmean:\t- new\t0.4976%\n",
      "\tOT:\t+ america\t34.19%\n",
      "\n",
      "For k=64:\n",
      "\tmean:\t- great\t0.4984%\n",
      "\tOT:\t+ rape\t34.49%\n",
      "\n",
      "For k=65:\n",
      "\tmean:\t- based\t0.4992%\n",
      "\tOT:\t- police\t34.79%\n",
      "\n",
      "For k=66:\n",
      "\tmean:\t+ sexual\t0.5%\n",
      "\tOT:\t- year\t35.09%\n",
      "\n",
      "For k=67:\n",
      "\tmean:\t- case\t0.5007%\n",
      "\tOT:\t- gender\t35.39%\n",
      "\n",
      "For k=68:\n",
      "\tmean:\t+ voted\t0.5014%\n",
      "\tOT:\t- point\t35.68%\n",
      "\n",
      "For k=69:\n",
      "\tmean:\t- priesthood\t0.5021%\n",
      "\tOT:\t+ little\t35.97%\n",
      "\n",
      "For k=70:\n",
      "\tmean:\t- high\t0.5029%\n",
      "\tOT:\t- child\t36.26%\n",
      "\n",
      "For k=71:\n",
      "\tmean:\t- social\t0.5036%\n",
      "\tOT:\t+ group\t36.54%\n",
      "\n",
      "For k=72:\n",
      "\tmean:\t- question\t0.5043%\n",
      "\tOT:\t- actually\t36.83%\n",
      "\n",
      "For k=73:\n",
      "\tmean:\t- equality\t0.5049%\n",
      "\tOT:\t- ve\t37.11%\n",
      "\n",
      "For k=74:\n",
      "\tmean:\t+ media\t0.5055%\n",
      "\tOT:\t- didn\t37.39%\n",
      "\n",
      "For k=75:\n",
      "\tmean:\t+ blame\t0.5062%\n",
      "\tOT:\t- look\t37.67%\n",
      "\n",
      "For k=76:\n",
      "\tmean:\t- holy\t0.5068%\n",
      "\tOT:\t- new\t37.94%\n",
      "\n",
      "For k=77:\n",
      "\tmean:\t- way\t0.5075%\n",
      "\tOT:\t- come\t38.22%\n",
      "\n",
      "For k=78:\n",
      "\tmean:\t- tax\t0.5081%\n",
      "\tOT:\t+ left\t38.49%\n",
      "\n",
      "For k=79:\n",
      "\tmean:\t- faith\t0.5087%\n",
      "\tOT:\t- yes\t38.76%\n",
      "\n",
      "For k=80:\n",
      "\tmean:\t+ supporters\t0.5093%\n",
      "\tOT:\t- far\t39.03%\n",
      "\n",
      "For k=81:\n",
      "\tmean:\t+ victims\t0.5099%\n",
      "\tOT:\t- great\t39.29%\n",
      "\n",
      "For k=82:\n",
      "\tmean:\t+ blacks\t0.5105%\n",
      "\tOT:\t- family\t39.56%\n",
      "\n",
      "For k=83:\n",
      "\tmean:\t- say\t0.5111%\n",
      "\tOT:\t- government\t39.82%\n",
      "\n",
      "For k=84:\n",
      "\tmean:\t- equal\t0.5117%\n",
      "\tOT:\t+ hate\t40.09%\n",
      "\n",
      "For k=85:\n",
      "\tmean:\t- issue\t0.5122%\n",
      "\tOT:\t- free\t40.35%\n",
      "\n",
      "For k=86:\n",
      "\tmean:\t- pay\t0.5128%\n",
      "\tOT:\t- violence\t40.61%\n",
      "\n",
      "For k=87:\n",
      "\tmean:\t+ ll\t0.5134%\n",
      "\tOT:\t+ american\t40.87%\n",
      "\n",
      "For k=88:\n",
      "\tmean:\t+ sexist\t0.5139%\n",
      "\tOT:\t- society\t41.12%\n",
      "\n",
      "For k=89:\n",
      "\tmean:\t- history\t0.5144%\n",
      "\tOT:\t- doing\t41.38%\n",
      "\n",
      "For k=90:\n",
      "\tmean:\t- bishops\t0.515%\n",
      "\tOT:\t- wrong\t41.64%\n",
      "\n",
      "For k=91:\n",
      "\tmean:\t- 000\t0.5155%\n",
      "\tOT:\t- long\t41.89%\n",
      "\n",
      "For k=92:\n",
      "\tmean:\t+ hell\t0.516%\n",
      "\tOT:\t+ got\t42.14%\n",
      "\n",
      "For k=93:\n",
      "\tmean:\t- day\t0.5166%\n",
      "\tOT:\t- day\t42.39%\n",
      "\n",
      "For k=94:\n",
      "\tmean:\t- government\t0.5171%\n",
      "\tOT:\t- mean\t42.65%\n",
      "\n",
      "For k=95:\n",
      "\tmean:\t- important\t0.5176%\n",
      "\tOT:\t- read\t42.9%\n",
      "\n",
      "For k=96:\n",
      "\tmean:\t+ race\t0.5181%\n",
      "\tOT:\t+ says\t43.15%\n",
      "\n",
      "For k=97:\n",
      "\tmean:\t+ kill\t0.5186%\n",
      "\tOT:\t- use\t43.4%\n",
      "\n",
      "For k=98:\n",
      "\tmean:\t- love\t0.5191%\n",
      "\tOT:\t- maybe\t43.64%\n",
      "\n",
      "For k=99:\n",
      "\tmean:\t- long\t0.5196%\n",
      "\tOT:\t- care\t43.89%\n",
      "\n"
     ]
    }
   ],
   "source": [
    "def convert_free_dims(free_dims_over_time):\n",
    "    # converting free_dims_over_time to an array where the jth element\n",
    "    # is the dim that is added at the jth timestep\n",
    "    free_dims = []\n",
    "    for free_dims_at_t in free_dims_over_time:\n",
    "        for free_dim in free_dims_at_t:\n",
    "            if free_dim not in free_dims:\n",
    "                free_dims.append(free_dim)\n",
    "    free_dims = np.array(free_dims)\n",
    "    return free_dims\n",
    "\n",
    "mean_free_dims = convert_free_dims(E01_sparse_mean_shift_results[-2])\n",
    "OT_free_dims = convert_free_dims(E01_unconstrained_sparse_shift_results[-2])\n",
    "\n",
    "feature_names = ngram_vectorizer.get_feature_names_out()\n",
    "previous_OT_W2_delta = 0.0\n",
    "previous_mean_W2_delta = 0.0\n",
    "\n",
    "mean_words = []\n",
    "OT_words = []\n",
    "\n",
    "print(f'For pushforward of {demo1} comments to {demo2} comments:')\n",
    "\n",
    "for idx in range(1,max_k_shift):\n",
    "    mean_free_dim = mean_free_dims[idx]\n",
    "    curr_mean_W2_delta = E01_sparse_mean_shift_results[1][idx]\n",
    "    \n",
    "    OT_free_dim = OT_free_dims[idx]\n",
    "    curr_OT_W2_delta = E01_unconstrained_sparse_shift_results[1][idx]\n",
    "    \n",
    "    mean_words.append(feature_names[mean_free_dim])\n",
    "    OT_words.append(feature_names[OT_free_dim])\n",
    "    \n",
    "    OT_dir = sign_to_str(E01_unconstrained_sparse_shift_results[-1][idx])\n",
    "    mean_dir = sign_to_str(E01_sparse_mean_shift_results[-1][idx])\n",
    "    \n",
    "    message = f'For k={idx}:\\n\\tmean:\\t{mean_dir} {feature_names[mean_free_dim]}\\t{curr_mean_W2_delta:.4}%\\n' + \\\n",
    "              f'\\tOT:\\t{OT_dir} {feature_names[OT_free_dim]}\\t{curr_OT_W2_delta:.4}%\\n'\n",
    "    print(message)\n",
    "    \n",
    "    previous_mean_W2_delta = curr_mean_W2_delta\n",
    "    previous_OT_W2_delta = curr_OT_W2_delta"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.7.11 ('py37')",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.11"
  },
  "vscode": {
   "interpreter": {
    "hash": "5ab0220f0ca30ec7bac8a7e209564eceae6d15412b9f87f3c2f91206aa8b151c"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
