{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "0fb2aa87",
   "metadata": {},
   "source": [
    "# Evaluation of models trained with $c_{IMA}$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e5efe31e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from matplotlib import pyplot as plt"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7be6fdfb",
   "metadata": {},
   "source": [
    "## 2d"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f6b17e20",
   "metadata": {},
   "source": [
    "### KLD"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "94f5f552",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps2/2d/' + \n",
    "                       lag_mult + '/%04i/log/kld_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.boxplot(m, labels=['0.0', '0.5', '1.0'])\n",
    "plt.xlabel('$\\lambda_{CIMA}$')\n",
    "plt.ylabel('KLD')\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/2d/kld_boxplot.png', dpi=300)\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=3)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('KLD', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/2d/kld_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "455f043f",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps0/2d/' + \n",
    "                       lag_mult + '/%04i/log/kld_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.boxplot(m, labels=['0.0', '0.5', '1.0'])\n",
    "plt.xlabel('$\\lambda_{CIMA}$')\n",
    "plt.ylabel('KLD')\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps0/2d/kld_boxplot.png', dpi=300)\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=4)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('KLD', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps0/2d/kld_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ce3f9aa4",
   "metadata": {},
   "source": [
    "### $c_{IMA}$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "20f7ffaf",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps2/2d/' + \n",
    "                       lag_mult + '/%04i/log/cima_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.boxplot(m, labels=['0.0', '0.5', '1.0'])\n",
    "plt.xlabel('$\\lambda_{CIMA}$')\n",
    "plt.ylabel('$c_{IMA}$')\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/2d/cima_boxplot.png', dpi=300)\n",
    "plt.show()\n",
    "\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=5)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.ylim([0, 0.5])\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('$c_{IMA}$', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/2d/cima_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6b3b6504",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps0/2d/' + \n",
    "                       lag_mult + '/%04i/log/cima_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.boxplot(m, labels=['0.0', '0.5', '1.0'])\n",
    "plt.xlabel('$\\lambda_{CIMA}$')\n",
    "plt.ylabel('$c_{IMA}$')\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps0/2d/cima_boxplot.png', dpi=300)\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=5)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.ylim([0, 0.5])\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('$c_{IMA}$', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps0/2d/cima_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2b85dd0f",
   "metadata": {},
   "source": [
    "### Amari distance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c863631a",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps2/2d/' + \n",
    "                       lag_mult + '/%04i/log/amari_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.boxplot(m, labels=['0.0', '0.5', '1.0'])\n",
    "plt.xlabel('$\\lambda_{CIMA}$')\n",
    "plt.ylabel('Amari distance')\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/2d/amari_boxplot.png', dpi=300)\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=6)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.ylim([0, 0.55])\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('Amari distance', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/2d/amari_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9ed06d8a",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps0/2d/' + \n",
    "                       lag_mult + '/%04i/log/amari_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.boxplot(m, labels=['0.0', '0.5', '1.0'])\n",
    "plt.xlabel('$\\lambda_{CIMA}$')\n",
    "plt.ylabel('Amari distance')\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps0/2d/amari_boxplot.png', dpi=300)\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=7)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.ylim([0, 0.6])\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('Amari distance', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps0/2d/amari_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8c4bead4",
   "metadata": {},
   "source": [
    "### MCC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6f90ec4",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps2/2d/' + \n",
    "                       lag_mult + '/%04i/log/mcc_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.boxplot(m, labels=['0.0', '0.5', '1.0'])\n",
    "plt.xlabel('$\\lambda_{CIMA}$')\n",
    "plt.ylabel('MCC')\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/2d/mcc_boxplot.png', dpi=300)\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=6)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.ylim([0.6, 1])\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('MCC', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/2d/mcc_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4f04a7e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps0/2d/' + \n",
    "                       lag_mult + '/%04i/log/mcc_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.boxplot(m, labels=['0.0', '0.5', '1.0'])\n",
    "plt.xlabel('$\\lambda_{CIMA}$')\n",
    "plt.ylabel('MCC')\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps0/2d/mcc_boxplot.png', dpi=300)\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=6)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.ylim([0.65, 1])\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('MCC', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps0/2d/mcc_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5918ca52",
   "metadata": {},
   "source": [
    "## 5d"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7944cef2",
   "metadata": {},
   "source": [
    "### KLD"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a2918b1d",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps2/5d/' + \n",
    "                       lag_mult + '/%04i/log/kld_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.boxplot(m, labels=['0.0', '0.5', '1.0'])\n",
    "plt.xlabel('$\\lambda_{CIMA}$')\n",
    "plt.ylabel('KLD')\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/5d/kld_boxplot.png', dpi=300)\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=6)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('KLD', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/5d/kld_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3e089a82",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps0/5d/' + \n",
    "                       lag_mult + '/%04i/log/kld_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.boxplot(m, labels=['0.0', '0.5', '1.0'])\n",
    "plt.xlabel('$\\lambda_{CIMA}$')\n",
    "plt.ylabel('KLD')\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps0/5d/kld_boxplot.png', dpi=300)\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=6)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('KLD', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps0/5d/kld_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a40a7003",
   "metadata": {},
   "source": [
    "### $c_{IMA}$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b3b538d3",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps2/5d/' + \n",
    "                       lag_mult + '/%04i/log/cima_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.boxplot(m, labels=['0.0', '0.5', '1.0'])\n",
    "plt.xlabel('$\\lambda_{CIMA}$')\n",
    "plt.ylabel('$c_{IMA}$')\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/5d/cima_boxplot.png', dpi=300)\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=5)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.ylim([0, 1.3])\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('$c_{IMA}$', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/5d/cima_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d68315f5",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps0/5d/' + \n",
    "                       lag_mult + '/%04i/log/cima_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.boxplot(m, labels=['0.0', '0.5', '1.0'])\n",
    "plt.xlabel('$\\lambda_{CIMA}$')\n",
    "plt.ylabel('$c_{IMA}$')\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps0/5d/cima_boxplot.png', dpi=300)\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=5)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.ylim([0, 2.3])\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('$c_{IMA}$', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps0/5d/cima_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "742bbdb9",
   "metadata": {},
   "source": [
    "### Amari distance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a2c076b7",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps2/5d/' + \n",
    "                       lag_mult + '/%04i/log/amari_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.boxplot(m, labels=['0.0', '0.5', '1.0'])\n",
    "plt.xlabel('$\\lambda_{CIMA}$')\n",
    "plt.ylabel('Amari distance')\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/5d/amari_boxplot.png', dpi=300)\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=5)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.ylim([0, 1.3])\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('Amari distance', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/5d/amari_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "23a4cc25",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps0/5d/' + \n",
    "                       lag_mult + '/%04i/log/amari_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.boxplot(m, labels=['0.0', '0.5', '1.0'])\n",
    "plt.xlabel('$\\lambda_{CIMA}$')\n",
    "plt.ylabel('Amari distance')\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps0/5d/amari_boxplot.png', dpi=300)\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=3)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.ylim([0, 1.2])\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('Amari distance', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps0/5d/amari_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5f91a85e",
   "metadata": {},
   "source": [
    "### MCC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "236eb118",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps2/5d/' + \n",
    "                       lag_mult + '/%04i/log/mcc_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.boxplot(m, labels=['0.0', '0.5', '1.0'])\n",
    "plt.xlabel('$\\lambda_{CIMA}$')\n",
    "plt.ylabel('MCC')\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/5d/mcc_boxplot.png', dpi=300)\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=6)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.ylim([0.53, 1])\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('MCC', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/5d/mcc_violinplot.pdf')\n",
    "plt.show()\n",
    "vp__ = vp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f5157cd4",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps0/5d/' + \n",
    "                       lag_mult + '/%04i/log/mcc_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.boxplot(m, labels=['0.0', '0.5', '1.0'])\n",
    "plt.xlabel('$\\lambda_{CIMA}$')\n",
    "plt.ylabel('MCC')\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps0/5d/mcc_boxplot.png', dpi=300)\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=6)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.ylim([0.5, 1])\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('MCC', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps0/5d/mcc_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c8c17cf2",
   "metadata": {},
   "source": [
    "## 7d"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "839bb57b",
   "metadata": {},
   "source": [
    "### KLD"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "098a61fc",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps2/7d/' + \n",
    "                       lag_mult + '/%04i/log/kld_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=6)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.ylim([0, 50])\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('KLD', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/7d/kld_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "30fbfbdb",
   "metadata": {},
   "source": [
    "### $c_{IMA}$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "45e47029",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps2/7d/' + \n",
    "                       lag_mult + '/%04i/log/cima_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=5)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.ylim([0, 4])\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('$c_{IMA}$', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/7d/cima_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a4a1b221",
   "metadata": {},
   "source": [
    "### Amari distance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "09715dc9",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps2/7d/' + \n",
    "                       lag_mult + '/%04i/log/amari_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=5)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.ylim([0, 1.8])\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('Amari distance', fontsize=28)\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/7d/amari_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a39c605b",
   "metadata": {},
   "source": [
    "### MCC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e6e73fac",
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "m = []\n",
    "for lag_mult in ['0_0', '0_5', '1_0']:\n",
    "    m_ = []\n",
    "    for i in range(50):\n",
    "        d = np.loadtxt('/draco/u/vstimper/projects/ica-flows/experiments/cima_obj/eps2/7d/' + \n",
    "                       lag_mult + '/%04i/log/mcc_test.csv' % i,\n",
    "                       skiprows=1, delimiter=',')\n",
    "        m_ += [d[-1, 1]]\n",
    "    m_ = np.array(m_)\n",
    "    m += [m_[~np.isnan(m_)]]\n",
    "\n",
    "plt.figure(figsize=(7, 7))\n",
    "vp__ = plt.violinplot(m__, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp__['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "vp = plt.violinplot(m, [0, 0.5, 1], showmedians=True)\n",
    "for el in vp['bodies']:\n",
    "    el.set_facecolor('#1A85FF')\n",
    "    el.set_edgecolor('black')\n",
    "    el.set_linewidth(1.5)\n",
    "    el.set_alpha(.9)\n",
    "for pn in ['cbars', 'cmins', 'cmaxes', 'cmedians']:\n",
    "    vp_ = vp[pn]\n",
    "    vp_.set_edgecolor('black')\n",
    "    vp_.set_linewidth(3)\n",
    "plt.xticks([0, 0.5, 1], fontsize=24)\n",
    "plt.locator_params(axis='y', nbins=6)\n",
    "plt.yticks(fontsize=24)\n",
    "plt.ylim([0.5, 1])\n",
    "plt.xlabel('$\\lambda$', fontsize=28)\n",
    "plt.ylabel('MCC', fontsize=28)\n",
    "#plt.legend([vp__['bodies'][0], vp['bodies'][0]], ['$n=5$', '$n=7$'], fontsize=24, loc='lower right')\n",
    "plt.tight_layout()\n",
    "plt.savefig('/draco/u/vstimper/projects/ica-flows/plots/cima_obj/eps2/7d/mcc_violinplot.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f494d9c5",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
