{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os, sys, errno, time\n",
    "import numpy as np\n",
    "\n",
    "import lib.midi as midi\n",
    "import lib.util as util\n",
    "\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "scoredir = '/home/thickstn/alignment-eval/data/score/'\n",
    "perfdir = '/home/thickstn/alignment-eval/data/perf/'\n",
    "gtdir = '/home/thickstn/alignment-eval/align/ground/'\n",
    "spectradir = '/home/thickstn/alignment-eval/align/spectra/'\n",
    "chromadir = '/home/thickstn/alignment-eval/align/chroma/'\n",
    "cqtdir = '/home/thickstn/alignment-eval/align/cqt/'\n",
    "\n",
    "file = '000_bwv863p'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "perf_audio = os.path.join(perfdir, file + '.wav')\n",
    "perf_transcript = os.path.join(perfdir, file + '.midi')\n",
    "score = os.path.join(scoredir, util.map_score(file) + '.midi')\n",
    "    \n",
    "gt_align = os.path.join(gtdir, file + '.txt')\n",
    "sp_align = os.path.join(spectradir, file + '.txt')\n",
    "ch_align = os.path.join(chromadir, file + '.txt')\n",
    "cqt_align = os.path.join(cqtdir, file + '.txt')\n",
    "\n",
    "perf_events,perf_start,perf_end = midi.load_midi_events(perf_transcript, strip_ends=False)\n",
    "score_events,score_start,score_end = midi.load_midi_events(score, strip_ends=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "gt_alignment = np.loadtxt(gt_align)\n",
    "sp_alignment = np.loadtxt(sp_align)\n",
    "ch_alignment = np.loadtxt(ch_align)\n",
    "cqt_alignment = np.loadtxt(cqt_align)\n",
    "\n",
    "perfroll = util.pianoroll(perf_events)\n",
    "groundroll = util.pscore(score_events, gt_alignment, start=perf_start)\n",
    "spectraroll = util.pscore(score_events, sp_alignment, start=perf_start)\n",
    "chromaroll = util.pscore(score_events, ch_alignment, start=perf_start)\n",
    "cqtroll = util.pscore(score_events, cqt_alignment, start=perf_start)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Visualizing the ground-truth alignment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0,0.5,'Pitch')"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f470c2b6908>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_windows = 1000\n",
    "\n",
    "fig, ax = plt.subplots(3,figsize=(20, 10), sharex=True)\n",
    "fig.suptitle('Visualizing the ground-truth alignment between performance and score', fontsize=26)\n",
    "\n",
    "ax[0].imshow(perfroll[:,50:90][:num_windows,::-1].T, interpolation='none', cmap='Greys', aspect=4)\n",
    "ax[0].set_title('Pianoroll performance (Disklavier digital recording)', fontsize=20)\n",
    "ax[0].set_xticks([]); ax[0].set_yticks([])\n",
    "ax[0].set_ylabel('Pitch', fontsize=16)\n",
    "ax[1].imshow(groundroll[:,50:90][:num_windows,::-1].T, interpolation='none', cmap='Greys', aspect=4)\n",
    "ax[1].set_title('Performance-aligned score', fontsize=20)\n",
    "ax[1].set_xticks([]); ax[1].set_yticks([])\n",
    "ax[1].set_ylabel('Pitch', fontsize=16)\n",
    "util.colorplot(ax[2], perfroll[:,50:90][:num_windows,::-1], groundroll[:num_windows,50:90][:,::-1])\n",
    "ax[2].set_title('Diff between the performance and the performance-aligned score', fontsize=20)\n",
    "ax[2].set_xticks([]); ax[2].set_yticks([])\n",
    "ax[2].set_xlabel('Time', fontsize=16)\n",
    "ax[2].set_ylabel('Pitch', fontsize=16)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Comparing alignment algorithms to the ground-truth alignment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0,0.5,'Pitch')"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f470af6a6a0>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_windows = 1000\n",
    "\n",
    "fig, ax = plt.subplots(3,figsize=(20, 10),sharex=True)\n",
    "fig.suptitle('Difference between the ground truth alignment and various candidate alignments', fontsize=26)\n",
    "\n",
    "util.colorplot(ax[0], groundroll[:,50:90][:num_windows,::-1], spectraroll[:num_windows,50:90][:,::-1])\n",
    "ax[0].set_title('Spectrogram alignment', fontsize=20)\n",
    "ax[0].set_xticks([]); ax[0].set_yticks([])\n",
    "ax[0].set_ylabel('Pitch', fontsize=16)\n",
    "util.colorplot(ax[1], groundroll[:,50:90][:num_windows,::-1], chromaroll[:num_windows,50:90][:,::-1])\n",
    "ax[1].set_title('Chromagram alignment', fontsize=20)\n",
    "ax[1].set_xticks([]); ax[1].set_yticks([])\n",
    "ax[1].set_ylabel('Pitch', fontsize=16)\n",
    "util.colorplot(ax[2], groundroll[:,50:90][:num_windows,::-1], cqtroll[:num_windows,50:90][:,::-1])\n",
    "ax[2].set_title('CQT alignment', fontsize=20)\n",
    "ax[2].set_xticks([]); ax[2].set_yticks([])\n",
    "ax[2].set_xlabel('Time', fontsize=16)\n",
    "ax[2].set_ylabel('Pitch', fontsize=16)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.5.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
