{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%matplotlib notebook\n",
    "import os\n",
    "import csv\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "from context import *\n",
    "from helpers.utils import load_perf_metrics, configure_plot_axes, load_adaptation_metrics\n",
    "from helpers.constants import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def read_loglike_results(base_direc, n_adapt, n_trials=50, index_col=1):\n",
    "    methods = ['no_adaptation', 'transfer', 'transfer_last_layer', 'proposed', 'retrained_target']\n",
    "    loglike = {m: [] for m in methods}\n",
    "    fname = os.path.join(base_direc, 'results_{:d}'.format(n_adapt), 'loglike_comparison.csv')\n",
    "    fp = open(fname, mode='r')\n",
    "    cr = csv.reader(fp, delimiter=',')\n",
    "    for i, row in enumerate(cr):\n",
    "        if i == 0:\n",
    "            continue\n",
    "\n",
    "        loglike[row[0]].append(float(row[index_col]))\n",
    "\n",
    "    fp.close()\n",
    "    mean_loglike = dict()\n",
    "    median_loglike = dict()\n",
    "    CI_loglike = dict()\n",
    "    for m in methods:\n",
    "        vals = np.array(loglike[m])[:n_trials]\n",
    "        if vals.shape[0] != n_trials:\n",
    "            print(\"WARNING: method {} calculates using {} trials.\".format(m, vals.shape[0]))\n",
    "        \n",
    "        mean_loglike[m] = np.mean(vals)\n",
    "        p = np.percentile(vals, [2.5, 50, 97.5])\n",
    "        median_loglike[m] = p[1]\n",
    "        CI_loglike[m] = (p[0], p[2])\n",
    "        \n",
    "    return mean_loglike, median_loglike, CI_loglike"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "base_dir = '/Users/jr/Documents/research/code/domain_adaptation/expts_icml22/mdn_gmm_data_lambda_max_1'\n",
    "methods = ['no_adaptation', 'transfer', 'transfer_last_layer', 'proposed', 'retrained_target']\n",
    "n_adapt_list = np.array([2, 4, 6, 8, 10, 12, 14, 16, 18, 20])\n",
    "\n",
    "plots_dir = os.path.join(base_dir, 'plots')\n",
    "if not os.path.isdir(plots_dir):\n",
    "    os.makedirs(plots_dir)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_sizes = n_adapt_list.shape[0]\n",
    "mean_loglike = {m: np.zeros(n_sizes) for m in methods}\n",
    "median_loglike = {m: np.zeros(n_sizes) for m in methods}\n",
    "CI_loglike = {m: np.zeros((n_sizes, 2)) for m in methods}\n",
    "for i, n_adapt in enumerate(n_adapt_list):\n",
    "    means_, medians_, CI_ = read_loglike_results(base_dir, n_adapt)\n",
    "    for m in methods:\n",
    "        mean_loglike[m][i] = means_[m]\n",
    "        median_loglike[m][i] = medians_[m]\n",
    "        CI_loglike[m][i, 0] = CI_[m][0]\n",
    "        CI_loglike[m][i, 1] = CI_[m][1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "legend_names = {\n",
    "    'no_adaptation': 'No adapt',\n",
    "    'transfer': 'Finetune',\n",
    "    'transfer_last_layer': 'Finetune last',\n",
    "    'proposed': 'Affine adapt (ours)',\n",
    "    'retrained_target': 'Retrained MDN'\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "/* Put everything inside the global mpl namespace */\n",
       "/* global mpl */\n",
       "window.mpl = {};\n",
       "\n",
       "mpl.get_websocket_type = function () {\n",
       "    if (typeof WebSocket !== 'undefined') {\n",
       "        return WebSocket;\n",
       "    } else if (typeof MozWebSocket !== 'undefined') {\n",
       "        return MozWebSocket;\n",
       "    } else {\n",
       "        alert(\n",
       "            'Your browser does not have WebSocket support. ' +\n",
       "                'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
       "                'Firefox 4 and 5 are also supported but you ' +\n",
       "                'have to enable WebSockets in about:config.'\n",
       "        );\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n",
       "    this.id = figure_id;\n",
       "\n",
       "    this.ws = websocket;\n",
       "\n",
       "    this.supports_binary = this.ws.binaryType !== undefined;\n",
       "\n",
       "    if (!this.supports_binary) {\n",
       "        var warnings = document.getElementById('mpl-warnings');\n",
       "        if (warnings) {\n",
       "            warnings.style.display = 'block';\n",
       "            warnings.textContent =\n",
       "                'This browser does not support binary websocket messages. ' +\n",
       "                'Performance may be slow.';\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.imageObj = new Image();\n",
       "\n",
       "    this.context = undefined;\n",
       "    this.message = undefined;\n",
       "    this.canvas = undefined;\n",
       "    this.rubberband_canvas = undefined;\n",
       "    this.rubberband_context = undefined;\n",
       "    this.format_dropdown = undefined;\n",
       "\n",
       "    this.image_mode = 'full';\n",
       "\n",
       "    this.root = document.createElement('div');\n",
       "    this.root.setAttribute('style', 'display: inline-block');\n",
       "    this._root_extra_style(this.root);\n",
       "\n",
       "    parent_element.appendChild(this.root);\n",
       "\n",
       "    this._init_header(this);\n",
       "    this._init_canvas(this);\n",
       "    this._init_toolbar(this);\n",
       "\n",
       "    var fig = this;\n",
       "\n",
       "    this.waiting = false;\n",
       "\n",
       "    this.ws.onopen = function () {\n",
       "        fig.send_message('supports_binary', { value: fig.supports_binary });\n",
       "        fig.send_message('send_image_mode', {});\n",
       "        if (fig.ratio !== 1) {\n",
       "            fig.send_message('set_device_pixel_ratio', {\n",
       "                device_pixel_ratio: fig.ratio,\n",
       "            });\n",
       "        }\n",
       "        fig.send_message('refresh', {});\n",
       "    };\n",
       "\n",
       "    this.imageObj.onload = function () {\n",
       "        if (fig.image_mode === 'full') {\n",
       "            // Full images could contain transparency (where diff images\n",
       "            // almost always do), so we need to clear the canvas so that\n",
       "            // there is no ghosting.\n",
       "            fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "        }\n",
       "        fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "    };\n",
       "\n",
       "    this.imageObj.onunload = function () {\n",
       "        fig.ws.close();\n",
       "    };\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._init_header = function () {\n",
       "    var titlebar = document.createElement('div');\n",
       "    titlebar.classList =\n",
       "        'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n",
       "    var titletext = document.createElement('div');\n",
       "    titletext.classList = 'ui-dialog-title';\n",
       "    titletext.setAttribute(\n",
       "        'style',\n",
       "        'width: 100%; text-align: center; padding: 3px;'\n",
       "    );\n",
       "    titlebar.appendChild(titletext);\n",
       "    this.root.appendChild(titlebar);\n",
       "    this.header = titletext;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function () {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = (this.canvas_div = document.createElement('div'));\n",
       "    canvas_div.setAttribute(\n",
       "        'style',\n",
       "        'border: 1px solid #ddd;' +\n",
       "            'box-sizing: content-box;' +\n",
       "            'clear: both;' +\n",
       "            'min-height: 1px;' +\n",
       "            'min-width: 1px;' +\n",
       "            'outline: 0;' +\n",
       "            'overflow: hidden;' +\n",
       "            'position: relative;' +\n",
       "            'resize: both;'\n",
       "    );\n",
       "\n",
       "    function on_keyboard_event_closure(name) {\n",
       "        return function (event) {\n",
       "            return fig.key_event(event, name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    canvas_div.addEventListener(\n",
       "        'keydown',\n",
       "        on_keyboard_event_closure('key_press')\n",
       "    );\n",
       "    canvas_div.addEventListener(\n",
       "        'keyup',\n",
       "        on_keyboard_event_closure('key_release')\n",
       "    );\n",
       "\n",
       "    this._canvas_extra_style(canvas_div);\n",
       "    this.root.appendChild(canvas_div);\n",
       "\n",
       "    var canvas = (this.canvas = document.createElement('canvas'));\n",
       "    canvas.classList.add('mpl-canvas');\n",
       "    canvas.setAttribute('style', 'box-sizing: content-box;');\n",
       "\n",
       "    this.context = canvas.getContext('2d');\n",
       "\n",
       "    var backingStore =\n",
       "        this.context.backingStorePixelRatio ||\n",
       "        this.context.webkitBackingStorePixelRatio ||\n",
       "        this.context.mozBackingStorePixelRatio ||\n",
       "        this.context.msBackingStorePixelRatio ||\n",
       "        this.context.oBackingStorePixelRatio ||\n",
       "        this.context.backingStorePixelRatio ||\n",
       "        1;\n",
       "\n",
       "    this.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband_canvas = (this.rubberband_canvas = document.createElement(\n",
       "        'canvas'\n",
       "    ));\n",
       "    rubberband_canvas.setAttribute(\n",
       "        'style',\n",
       "        'box-sizing: content-box; position: absolute; left: 0; top: 0; z-index: 1;'\n",
       "    );\n",
       "\n",
       "    // Apply a ponyfill if ResizeObserver is not implemented by browser.\n",
       "    if (this.ResizeObserver === undefined) {\n",
       "        if (window.ResizeObserver !== undefined) {\n",
       "            this.ResizeObserver = window.ResizeObserver;\n",
       "        } else {\n",
       "            var obs = _JSXTOOLS_RESIZE_OBSERVER({});\n",
       "            this.ResizeObserver = obs.ResizeObserver;\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.resizeObserverInstance = new this.ResizeObserver(function (entries) {\n",
       "        var nentries = entries.length;\n",
       "        for (var i = 0; i < nentries; i++) {\n",
       "            var entry = entries[i];\n",
       "            var width, height;\n",
       "            if (entry.contentBoxSize) {\n",
       "                if (entry.contentBoxSize instanceof Array) {\n",
       "                    // Chrome 84 implements new version of spec.\n",
       "                    width = entry.contentBoxSize[0].inlineSize;\n",
       "                    height = entry.contentBoxSize[0].blockSize;\n",
       "                } else {\n",
       "                    // Firefox implements old version of spec.\n",
       "                    width = entry.contentBoxSize.inlineSize;\n",
       "                    height = entry.contentBoxSize.blockSize;\n",
       "                }\n",
       "            } else {\n",
       "                // Chrome <84 implements even older version of spec.\n",
       "                width = entry.contentRect.width;\n",
       "                height = entry.contentRect.height;\n",
       "            }\n",
       "\n",
       "            // Keep the size of the canvas and rubber band canvas in sync with\n",
       "            // the canvas container.\n",
       "            if (entry.devicePixelContentBoxSize) {\n",
       "                // Chrome 84 implements new version of spec.\n",
       "                canvas.setAttribute(\n",
       "                    'width',\n",
       "                    entry.devicePixelContentBoxSize[0].inlineSize\n",
       "                );\n",
       "                canvas.setAttribute(\n",
       "                    'height',\n",
       "                    entry.devicePixelContentBoxSize[0].blockSize\n",
       "                );\n",
       "            } else {\n",
       "                canvas.setAttribute('width', width * fig.ratio);\n",
       "                canvas.setAttribute('height', height * fig.ratio);\n",
       "            }\n",
       "            canvas.setAttribute(\n",
       "                'style',\n",
       "                'width: ' + width + 'px; height: ' + height + 'px;'\n",
       "            );\n",
       "\n",
       "            rubberband_canvas.setAttribute('width', width);\n",
       "            rubberband_canvas.setAttribute('height', height);\n",
       "\n",
       "            // And update the size in Python. We ignore the initial 0/0 size\n",
       "            // that occurs as the element is placed into the DOM, which should\n",
       "            // otherwise not happen due to the minimum size styling.\n",
       "            if (fig.ws.readyState == 1 && width != 0 && height != 0) {\n",
       "                fig.request_resize(width, height);\n",
       "            }\n",
       "        }\n",
       "    });\n",
       "    this.resizeObserverInstance.observe(canvas_div);\n",
       "\n",
       "    function on_mouse_event_closure(name) {\n",
       "        return function (event) {\n",
       "            return fig.mouse_event(event, name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mousedown',\n",
       "        on_mouse_event_closure('button_press')\n",
       "    );\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mouseup',\n",
       "        on_mouse_event_closure('button_release')\n",
       "    );\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'dblclick',\n",
       "        on_mouse_event_closure('dblclick')\n",
       "    );\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mousemove',\n",
       "        on_mouse_event_closure('motion_notify')\n",
       "    );\n",
       "\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mouseenter',\n",
       "        on_mouse_event_closure('figure_enter')\n",
       "    );\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mouseleave',\n",
       "        on_mouse_event_closure('figure_leave')\n",
       "    );\n",
       "\n",
       "    canvas_div.addEventListener('wheel', function (event) {\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        on_mouse_event_closure('scroll')(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.appendChild(canvas);\n",
       "    canvas_div.appendChild(rubberband_canvas);\n",
       "\n",
       "    this.rubberband_context = rubberband_canvas.getContext('2d');\n",
       "    this.rubberband_context.strokeStyle = '#000000';\n",
       "\n",
       "    this._resize_canvas = function (width, height, forward) {\n",
       "        if (forward) {\n",
       "            canvas_div.style.width = width + 'px';\n",
       "            canvas_div.style.height = height + 'px';\n",
       "        }\n",
       "    };\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    this.rubberband_canvas.addEventListener('contextmenu', function (_e) {\n",
       "        event.preventDefault();\n",
       "        return false;\n",
       "    });\n",
       "\n",
       "    function set_focus() {\n",
       "        canvas.focus();\n",
       "        canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    window.setTimeout(set_focus, 100);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function () {\n",
       "    var fig = this;\n",
       "\n",
       "    var toolbar = document.createElement('div');\n",
       "    toolbar.classList = 'mpl-toolbar';\n",
       "    this.root.appendChild(toolbar);\n",
       "\n",
       "    function on_click_closure(name) {\n",
       "        return function (_event) {\n",
       "            return fig.toolbar_button_onclick(name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    function on_mouseover_closure(tooltip) {\n",
       "        return function (event) {\n",
       "            if (!event.currentTarget.disabled) {\n",
       "                return fig.toolbar_button_onmouseover(tooltip);\n",
       "            }\n",
       "        };\n",
       "    }\n",
       "\n",
       "    fig.buttons = {};\n",
       "    var buttonGroup = document.createElement('div');\n",
       "    buttonGroup.classList = 'mpl-button-group';\n",
       "    for (var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            /* Instead of a spacer, we start a new button group. */\n",
       "            if (buttonGroup.hasChildNodes()) {\n",
       "                toolbar.appendChild(buttonGroup);\n",
       "            }\n",
       "            buttonGroup = document.createElement('div');\n",
       "            buttonGroup.classList = 'mpl-button-group';\n",
       "            continue;\n",
       "        }\n",
       "\n",
       "        var button = (fig.buttons[name] = document.createElement('button'));\n",
       "        button.classList = 'mpl-widget';\n",
       "        button.setAttribute('role', 'button');\n",
       "        button.setAttribute('aria-disabled', 'false');\n",
       "        button.addEventListener('click', on_click_closure(method_name));\n",
       "        button.addEventListener('mouseover', on_mouseover_closure(tooltip));\n",
       "\n",
       "        var icon_img = document.createElement('img');\n",
       "        icon_img.src = '_images/' + image + '.png';\n",
       "        icon_img.srcset = '_images/' + image + '_large.png 2x';\n",
       "        icon_img.alt = tooltip;\n",
       "        button.appendChild(icon_img);\n",
       "\n",
       "        buttonGroup.appendChild(button);\n",
       "    }\n",
       "\n",
       "    if (buttonGroup.hasChildNodes()) {\n",
       "        toolbar.appendChild(buttonGroup);\n",
       "    }\n",
       "\n",
       "    var fmt_picker = document.createElement('select');\n",
       "    fmt_picker.classList = 'mpl-widget';\n",
       "    toolbar.appendChild(fmt_picker);\n",
       "    this.format_dropdown = fmt_picker;\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = document.createElement('option');\n",
       "        option.selected = fmt === mpl.default_extension;\n",
       "        option.innerHTML = fmt;\n",
       "        fmt_picker.appendChild(option);\n",
       "    }\n",
       "\n",
       "    var status_bar = document.createElement('span');\n",
       "    status_bar.classList = 'mpl-message';\n",
       "    toolbar.appendChild(status_bar);\n",
       "    this.message = status_bar;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.request_resize = function (x_pixels, y_pixels) {\n",
       "    // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
       "    // which will in turn request a refresh of the image.\n",
       "    this.send_message('resize', { width: x_pixels, height: y_pixels });\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.send_message = function (type, properties) {\n",
       "    properties['type'] = type;\n",
       "    properties['figure_id'] = this.id;\n",
       "    this.ws.send(JSON.stringify(properties));\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.send_draw_message = function () {\n",
       "    if (!this.waiting) {\n",
       "        this.waiting = true;\n",
       "        this.ws.send(JSON.stringify({ type: 'draw', figure_id: this.id }));\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_save = function (fig, _msg) {\n",
       "    var format_dropdown = fig.format_dropdown;\n",
       "    var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
       "    fig.ondownload(fig, format);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_resize = function (fig, msg) {\n",
       "    var size = msg['size'];\n",
       "    if (size[0] !== fig.canvas.width || size[1] !== fig.canvas.height) {\n",
       "        fig._resize_canvas(size[0], size[1], msg['forward']);\n",
       "        fig.send_message('refresh', {});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function (fig, msg) {\n",
       "    var x0 = msg['x0'] / fig.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / fig.ratio;\n",
       "    var x1 = msg['x1'] / fig.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / fig.ratio;\n",
       "    x0 = Math.floor(x0) + 0.5;\n",
       "    y0 = Math.floor(y0) + 0.5;\n",
       "    x1 = Math.floor(x1) + 0.5;\n",
       "    y1 = Math.floor(y1) + 0.5;\n",
       "    var min_x = Math.min(x0, x1);\n",
       "    var min_y = Math.min(y0, y1);\n",
       "    var width = Math.abs(x1 - x0);\n",
       "    var height = Math.abs(y1 - y0);\n",
       "\n",
       "    fig.rubberband_context.clearRect(\n",
       "        0,\n",
       "        0,\n",
       "        fig.canvas.width / fig.ratio,\n",
       "        fig.canvas.height / fig.ratio\n",
       "    );\n",
       "\n",
       "    fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_figure_label = function (fig, msg) {\n",
       "    // Updates the figure title.\n",
       "    fig.header.textContent = msg['label'];\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_cursor = function (fig, msg) {\n",
       "    fig.rubberband_canvas.style.cursor = msg['cursor'];\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_message = function (fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function (fig, _msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function (fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_history_buttons = function (fig, msg) {\n",
       "    for (var key in msg) {\n",
       "        if (!(key in fig.buttons)) {\n",
       "            continue;\n",
       "        }\n",
       "        fig.buttons[key].disabled = !msg[key];\n",
       "        fig.buttons[key].setAttribute('aria-disabled', !msg[key]);\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_navigate_mode = function (fig, msg) {\n",
       "    if (msg['mode'] === 'PAN') {\n",
       "        fig.buttons['Pan'].classList.add('active');\n",
       "        fig.buttons['Zoom'].classList.remove('active');\n",
       "    } else if (msg['mode'] === 'ZOOM') {\n",
       "        fig.buttons['Pan'].classList.remove('active');\n",
       "        fig.buttons['Zoom'].classList.add('active');\n",
       "    } else {\n",
       "        fig.buttons['Pan'].classList.remove('active');\n",
       "        fig.buttons['Zoom'].classList.remove('active');\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function () {\n",
       "    // Called whenever the canvas gets updated.\n",
       "    this.send_message('ack', {});\n",
       "};\n",
       "\n",
       "// A function to construct a web socket function for onmessage handling.\n",
       "// Called in the figure constructor.\n",
       "mpl.figure.prototype._make_on_message_function = function (fig) {\n",
       "    return function socket_on_message(evt) {\n",
       "        if (evt.data instanceof Blob) {\n",
       "            var img = evt.data;\n",
       "            if (img.type !== 'image/png') {\n",
       "                /* FIXME: We get \"Resource interpreted as Image but\n",
       "                 * transferred with MIME type text/plain:\" errors on\n",
       "                 * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "                 * to be part of the websocket stream */\n",
       "                img.type = 'image/png';\n",
       "            }\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src\n",
       "                );\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                img\n",
       "            );\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        } else if (\n",
       "            typeof evt.data === 'string' &&\n",
       "            evt.data.slice(0, 21) === 'data:image/png;base64'\n",
       "        ) {\n",
       "            fig.imageObj.src = evt.data;\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        var msg = JSON.parse(evt.data);\n",
       "        var msg_type = msg['type'];\n",
       "\n",
       "        // Call the  \"handle_{type}\" callback, which takes\n",
       "        // the figure and JSON message as its only arguments.\n",
       "        try {\n",
       "            var callback = fig['handle_' + msg_type];\n",
       "        } catch (e) {\n",
       "            console.log(\n",
       "                \"No handler for the '\" + msg_type + \"' message type: \",\n",
       "                msg\n",
       "            );\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        if (callback) {\n",
       "            try {\n",
       "                // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
       "                callback(fig, msg);\n",
       "            } catch (e) {\n",
       "                console.log(\n",
       "                    \"Exception inside the 'handler_\" + msg_type + \"' callback:\",\n",
       "                    e,\n",
       "                    e.stack,\n",
       "                    msg\n",
       "                );\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "};\n",
       "\n",
       "// from https://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function (e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e) {\n",
       "        e = window.event;\n",
       "    }\n",
       "    if (e.target) {\n",
       "        targ = e.target;\n",
       "    } else if (e.srcElement) {\n",
       "        targ = e.srcElement;\n",
       "    }\n",
       "    if (targ.nodeType === 3) {\n",
       "        // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "    }\n",
       "\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    var boundingRect = targ.getBoundingClientRect();\n",
       "    var x = e.pageX - (boundingRect.left + document.body.scrollLeft);\n",
       "    var y = e.pageY - (boundingRect.top + document.body.scrollTop);\n",
       "\n",
       "    return { x: x, y: y };\n",
       "};\n",
       "\n",
       "/*\n",
       " * return a copy of an object with only non-object keys\n",
       " * we need this to avoid circular references\n",
       " * https://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys(original) {\n",
       "    return Object.keys(original).reduce(function (obj, key) {\n",
       "        if (typeof original[key] !== 'object') {\n",
       "            obj[key] = original[key];\n",
       "        }\n",
       "        return obj;\n",
       "    }, {});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.mouse_event = function (event, name) {\n",
       "    var canvas_pos = mpl.findpos(event);\n",
       "\n",
       "    if (name === 'button_press') {\n",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * this.ratio;\n",
       "    var y = canvas_pos.y * this.ratio;\n",
       "\n",
       "    this.send_message(name, {\n",
       "        x: x,\n",
       "        y: y,\n",
       "        button: event.button,\n",
       "        step: event.step,\n",
       "        guiEvent: simpleKeys(event),\n",
       "    });\n",
       "\n",
       "    /* This prevents the web browser from automatically changing to\n",
       "     * the text insertion cursor when the button is pressed.  We want\n",
       "     * to control all of the cursor setting manually through the\n",
       "     * 'cursor' event from matplotlib */\n",
       "    event.preventDefault();\n",
       "    return false;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function (_event, _name) {\n",
       "    // Handle any extra behaviour associated with a key event\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.key_event = function (event, name) {\n",
       "    // Prevent repeat events\n",
       "    if (name === 'key_press') {\n",
       "        if (event.key === this._key) {\n",
       "            return;\n",
       "        } else {\n",
       "            this._key = event.key;\n",
       "        }\n",
       "    }\n",
       "    if (name === 'key_release') {\n",
       "        this._key = null;\n",
       "    }\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.key !== 'Control') {\n",
       "        value += 'ctrl+';\n",
       "    }\n",
       "    else if (event.altKey && event.key !== 'Alt') {\n",
       "        value += 'alt+';\n",
       "    }\n",
       "    else if (event.shiftKey && event.key !== 'Shift') {\n",
       "        value += 'shift+';\n",
       "    }\n",
       "\n",
       "    value += 'k' + event.key;\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, { key: value, guiEvent: simpleKeys(event) });\n",
       "    return false;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onclick = function (name) {\n",
       "    if (name === 'download') {\n",
       "        this.handle_save(this, null);\n",
       "    } else {\n",
       "        this.send_message('toolbar_button', { name: name });\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onmouseover = function (tooltip) {\n",
       "    this.message.textContent = tooltip;\n",
       "};\n",
       "\n",
       "///////////////// REMAINING CONTENT GENERATED BY embed_js.py /////////////////\n",
       "// prettier-ignore\n",
       "var _JSXTOOLS_RESIZE_OBSERVER=function(A){var t,i=new WeakMap,n=new WeakMap,a=new WeakMap,r=new WeakMap,o=new Set;function s(e){if(!(this instanceof s))throw new TypeError(\"Constructor requires 'new' operator\");i.set(this,e)}function h(){throw new TypeError(\"Function is not a constructor\")}function c(e,t,i,n){e=0 in arguments?Number(arguments[0]):0,t=1 in arguments?Number(arguments[1]):0,i=2 in arguments?Number(arguments[2]):0,n=3 in arguments?Number(arguments[3]):0,this.right=(this.x=this.left=e)+(this.width=i),this.bottom=(this.y=this.top=t)+(this.height=n),Object.freeze(this)}function d(){t=requestAnimationFrame(d);var s=new WeakMap,p=new Set;o.forEach((function(t){r.get(t).forEach((function(i){var r=t instanceof window.SVGElement,o=a.get(t),d=r?0:parseFloat(o.paddingTop),f=r?0:parseFloat(o.paddingRight),l=r?0:parseFloat(o.paddingBottom),u=r?0:parseFloat(o.paddingLeft),g=r?0:parseFloat(o.borderTopWidth),m=r?0:parseFloat(o.borderRightWidth),w=r?0:parseFloat(o.borderBottomWidth),b=u+f,F=d+l,v=(r?0:parseFloat(o.borderLeftWidth))+m,W=g+w,y=r?0:t.offsetHeight-W-t.clientHeight,E=r?0:t.offsetWidth-v-t.clientWidth,R=b+v,z=F+W,M=r?t.width:parseFloat(o.width)-R-E,O=r?t.height:parseFloat(o.height)-z-y;if(n.has(t)){var k=n.get(t);if(k[0]===M&&k[1]===O)return}n.set(t,[M,O]);var S=Object.create(h.prototype);S.target=t,S.contentRect=new c(u,d,M,O),s.has(i)||(s.set(i,[]),p.add(i)),s.get(i).push(S)}))})),p.forEach((function(e){i.get(e).call(e,s.get(e),e)}))}return s.prototype.observe=function(i){if(i instanceof window.Element){r.has(i)||(r.set(i,new Set),o.add(i),a.set(i,window.getComputedStyle(i)));var n=r.get(i);n.has(this)||n.add(this),cancelAnimationFrame(t),t=requestAnimationFrame(d)}},s.prototype.unobserve=function(i){if(i instanceof window.Element&&r.has(i)){var n=r.get(i);n.has(this)&&(n.delete(this),n.size||(r.delete(i),o.delete(i))),n.size||r.delete(i),o.size||cancelAnimationFrame(t)}},A.DOMRectReadOnly=c,A.ResizeObserver=s,A.ResizeObserverEntry=h,A}; // eslint-disable-line\n",
       "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Left button pans, Right button zooms\\nx/y fixes axis, CTRL fixes aspect\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\\nx/y fixes axis\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pgf\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";/* global mpl */\n",
       "\n",
       "var comm_websocket_adapter = function (comm) {\n",
       "    // Create a \"websocket\"-like object which calls the given IPython comm\n",
       "    // object with the appropriate methods. Currently this is a non binary\n",
       "    // socket, so there is still some room for performance tuning.\n",
       "    var ws = {};\n",
       "\n",
       "    ws.binaryType = comm.kernel.ws.binaryType;\n",
       "    ws.readyState = comm.kernel.ws.readyState;\n",
       "    function updateReadyState(_event) {\n",
       "        if (comm.kernel.ws) {\n",
       "            ws.readyState = comm.kernel.ws.readyState;\n",
       "        } else {\n",
       "            ws.readyState = 3; // Closed state.\n",
       "        }\n",
       "    }\n",
       "    comm.kernel.ws.addEventListener('open', updateReadyState);\n",
       "    comm.kernel.ws.addEventListener('close', updateReadyState);\n",
       "    comm.kernel.ws.addEventListener('error', updateReadyState);\n",
       "\n",
       "    ws.close = function () {\n",
       "        comm.close();\n",
       "    };\n",
       "    ws.send = function (m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function (msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        var data = msg['content']['data'];\n",
       "        if (data['blob'] !== undefined) {\n",
       "            data = {\n",
       "                data: new Blob(msg['buffers'], { type: data['blob'] }),\n",
       "            };\n",
       "        }\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(data);\n",
       "    });\n",
       "    return ws;\n",
       "};\n",
       "\n",
       "mpl.mpl_figure_comm = function (comm, msg) {\n",
       "    // This is the function which gets called when the mpl process\n",
       "    // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
       "\n",
       "    var id = msg.content.data.id;\n",
       "    // Get hold of the div created by the display call when the Comm\n",
       "    // socket was opened in Python.\n",
       "    var element = document.getElementById(id);\n",
       "    var ws_proxy = comm_websocket_adapter(comm);\n",
       "\n",
       "    function ondownload(figure, _format) {\n",
       "        window.open(figure.canvas.toDataURL());\n",
       "    }\n",
       "\n",
       "    var fig = new mpl.figure(id, ws_proxy, ondownload, element);\n",
       "\n",
       "    // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
       "    // web socket which is closed, not our websocket->open comm proxy.\n",
       "    ws_proxy.onopen();\n",
       "\n",
       "    fig.parent_element = element;\n",
       "    fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
       "    if (!fig.cell_info) {\n",
       "        console.error('Failed to find cell for figure', id, fig);\n",
       "        return;\n",
       "    }\n",
       "    fig.cell_info[0].output_area.element.on(\n",
       "        'cleared',\n",
       "        { fig: fig },\n",
       "        fig._remove_fig_handler\n",
       "    );\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_close = function (fig, msg) {\n",
       "    var width = fig.canvas.width / fig.ratio;\n",
       "    fig.cell_info[0].output_area.element.off(\n",
       "        'cleared',\n",
       "        fig._remove_fig_handler\n",
       "    );\n",
       "    fig.resizeObserverInstance.unobserve(fig.canvas_div);\n",
       "\n",
       "    // Update the output cell to use the data from the current canvas.\n",
       "    fig.push_to_output();\n",
       "    var dataURL = fig.canvas.toDataURL();\n",
       "    // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
       "    // the notebook keyboard shortcuts fail.\n",
       "    IPython.keyboard_manager.enable();\n",
       "    fig.parent_element.innerHTML =\n",
       "        '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "    fig.close_ws(fig, msg);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.close_ws = function (fig, msg) {\n",
       "    fig.send_message('closing', msg);\n",
       "    // fig.ws.close()\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.push_to_output = function (_remove_interactive) {\n",
       "    // Turn the data on the canvas into data in the output cell.\n",
       "    var width = this.canvas.width / this.ratio;\n",
       "    var dataURL = this.canvas.toDataURL();\n",
       "    this.cell_info[1]['text/html'] =\n",
       "        '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function () {\n",
       "    // Tell IPython that the notebook contents must change.\n",
       "    IPython.notebook.set_dirty(true);\n",
       "    this.send_message('ack', {});\n",
       "    var fig = this;\n",
       "    // Wait a second, then push the new image to the DOM so\n",
       "    // that it is saved nicely (might be nice to debounce this).\n",
       "    setTimeout(function () {\n",
       "        fig.push_to_output();\n",
       "    }, 1000);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function () {\n",
       "    var fig = this;\n",
       "\n",
       "    var toolbar = document.createElement('div');\n",
       "    toolbar.classList = 'btn-toolbar';\n",
       "    this.root.appendChild(toolbar);\n",
       "\n",
       "    function on_click_closure(name) {\n",
       "        return function (_event) {\n",
       "            return fig.toolbar_button_onclick(name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    function on_mouseover_closure(tooltip) {\n",
       "        return function (event) {\n",
       "            if (!event.currentTarget.disabled) {\n",
       "                return fig.toolbar_button_onmouseover(tooltip);\n",
       "            }\n",
       "        };\n",
       "    }\n",
       "\n",
       "    fig.buttons = {};\n",
       "    var buttonGroup = document.createElement('div');\n",
       "    buttonGroup.classList = 'btn-group';\n",
       "    var button;\n",
       "    for (var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            /* Instead of a spacer, we start a new button group. */\n",
       "            if (buttonGroup.hasChildNodes()) {\n",
       "                toolbar.appendChild(buttonGroup);\n",
       "            }\n",
       "            buttonGroup = document.createElement('div');\n",
       "            buttonGroup.classList = 'btn-group';\n",
       "            continue;\n",
       "        }\n",
       "\n",
       "        button = fig.buttons[name] = document.createElement('button');\n",
       "        button.classList = 'btn btn-default';\n",
       "        button.href = '#';\n",
       "        button.title = name;\n",
       "        button.innerHTML = '<i class=\"fa ' + image + ' fa-lg\"></i>';\n",
       "        button.addEventListener('click', on_click_closure(method_name));\n",
       "        button.addEventListener('mouseover', on_mouseover_closure(tooltip));\n",
       "        buttonGroup.appendChild(button);\n",
       "    }\n",
       "\n",
       "    if (buttonGroup.hasChildNodes()) {\n",
       "        toolbar.appendChild(buttonGroup);\n",
       "    }\n",
       "\n",
       "    // Add the status bar.\n",
       "    var status_bar = document.createElement('span');\n",
       "    status_bar.classList = 'mpl-message pull-right';\n",
       "    toolbar.appendChild(status_bar);\n",
       "    this.message = status_bar;\n",
       "\n",
       "    // Add the close button to the window.\n",
       "    var buttongrp = document.createElement('div');\n",
       "    buttongrp.classList = 'btn-group inline pull-right';\n",
       "    button = document.createElement('button');\n",
       "    button.classList = 'btn btn-mini btn-primary';\n",
       "    button.href = '#';\n",
       "    button.title = 'Stop Interaction';\n",
       "    button.innerHTML = '<i class=\"fa fa-power-off icon-remove icon-large\"></i>';\n",
       "    button.addEventListener('click', function (_evt) {\n",
       "        fig.handle_close(fig, {});\n",
       "    });\n",
       "    button.addEventListener(\n",
       "        'mouseover',\n",
       "        on_mouseover_closure('Stop Interaction')\n",
       "    );\n",
       "    buttongrp.appendChild(button);\n",
       "    var titlebar = this.root.querySelector('.ui-dialog-titlebar');\n",
       "    titlebar.insertBefore(buttongrp, titlebar.firstChild);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._remove_fig_handler = function (event) {\n",
       "    var fig = event.data.fig;\n",
       "    if (event.target !== this) {\n",
       "        // Ignore bubbled events from children.\n",
       "        return;\n",
       "    }\n",
       "    fig.close_ws(fig, {});\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function (el) {\n",
       "    el.style.boxSizing = 'content-box'; // override notebook setting of border-box.\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function (el) {\n",
       "    // this is important to make the div 'focusable\n",
       "    el.setAttribute('tabindex', 0);\n",
       "    // reach out to IPython and tell the keyboard manager to turn it's self\n",
       "    // off when our div gets focus\n",
       "\n",
       "    // location in version 3\n",
       "    if (IPython.notebook.keyboard_manager) {\n",
       "        IPython.notebook.keyboard_manager.register_events(el);\n",
       "    } else {\n",
       "        // location in version 2\n",
       "        IPython.keyboard_manager.register_events(el);\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function (event, _name) {\n",
       "    // Check for shift+enter\n",
       "    if (event.shiftKey && event.which === 13) {\n",
       "        this.canvas_div.blur();\n",
       "        // select the cell after this one\n",
       "        var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
       "        IPython.notebook.select(index + 1);\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_save = function (fig, _msg) {\n",
       "    fig.ondownload(fig, null);\n",
       "};\n",
       "\n",
       "mpl.find_output_cell = function (html_output) {\n",
       "    // Return the cell and output element which can be found *uniquely* in the notebook.\n",
       "    // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
       "    // IPython event is triggered only after the cells have been serialised, which for\n",
       "    // our purposes (turning an active figure into a static one), is too late.\n",
       "    var cells = IPython.notebook.get_cells();\n",
       "    var ncells = cells.length;\n",
       "    for (var i = 0; i < ncells; i++) {\n",
       "        var cell = cells[i];\n",
       "        if (cell.cell_type === 'code') {\n",
       "            for (var j = 0; j < cell.output_area.outputs.length; j++) {\n",
       "                var data = cell.output_area.outputs[j];\n",
       "                if (data.data) {\n",
       "                    // IPython >= 3 moved mimebundle to data attribute of output\n",
       "                    data = data.data;\n",
       "                }\n",
       "                if (data['text/html'] === html_output) {\n",
       "                    return [cell, data, j];\n",
       "                }\n",
       "            }\n",
       "        }\n",
       "    }\n",
       "};\n",
       "\n",
       "// Register the function which deals with the matplotlib target/channel.\n",
       "// The kernel may be null if the page has been refreshed.\n",
       "if (IPython.notebook.kernel !== null) {\n",
       "    IPython.notebook.kernel.comm_manager.register_target(\n",
       "        'matplotlib',\n",
       "        mpl.mpl_figure_comm\n",
       "    );\n",
       "}\n"
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<img src=\"data:image/png;base64,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\" width=\"640\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot the log-likelihood vs number of target samples\n",
    "fs = 13\n",
    "fig = plt.figure()\n",
    "y_vals = []\n",
    "for i, m in enumerate(['no_adaptation', 'proposed', 'transfer', 'transfer_last_layer', 'retrained_target']):\n",
    "    plt.plot(n_adapt_list, mean_loglike[m], linestyle='-', linewidth=0.75, color=COLORS[i], \n",
    "             marker=POINT_STYLES[i], label=legend_names[m])\n",
    "    y_vals.extend(mean_loglike[m])\n",
    "\n",
    "# plt.yscale('log')\n",
    "# Increase the upper y-limit a bit\n",
    "y_bot, y_top = plt.ylim()\n",
    "plt.ylim((-10, 1.0 * y_top))\n",
    "\n",
    "plt.xticks(n_adapt_list, fontsize=fs)\n",
    "plt.yticks(fontsize=fs)\n",
    "plt.xlabel('#target samples per-class', fontsize=fs, fontweight='normal')\n",
    "plt.ylabel('Log-likelihood', fontsize=fs, fontweight='normal')\n",
    "plt.grid(True, axis='both', linestyle='dashed', linewidth=0.75, alpha=1.)\n",
    "# plt.legend(loc='best', ncol=1, fontsize=10)\n",
    "# plt.legend(loc='upper center', frameon=True, bbox_to_anchor=(0.5, 1.15), ncol=3, \n",
    "#            fontsize=10, fancybox=False)\n",
    "# Save the figure\n",
    "plot_filename = os.path.join(plots_dir, 'plot_loglike')\n",
    "fig.tight_layout()\n",
    "fig.savefig(plot_filename + '.png', dpi=600, bbox_inches='tight')\n",
    "fig.savefig(plot_filename + '.pdf', dpi=600, bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
