{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "skel_path = \"../ProgressiveTransformersSLP/test.skels\"\n",
    "with open(skel_path, \"r\") as f:\n",
    "    skel = f.readline()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "skels_3d = np.array([float(s) for s in skel.strip().split()])\n",
    "assert len(skels_3d) % 151 == 0\n",
    "skel_len = len(skels_3d) // 151\n",
    "skels_3d = skels_3d.reshape(skel_len, 151)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(61, 150)\n"
     ]
    }
   ],
   "source": [
    "skels_3d = skels_3d[::3, :150]\n",
    "print(skels_3d.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "skel_plot = skels_3d.reshape(skels_3d.shape[0], -1, 3)[:, :, :2]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "from plot_videos import draw_frame_2D\n",
    "\n",
    "frame = np.ones((256, 256, 3), np.uint8) * 255\n",
    "im = draw_frame_2D(frame, skel_plot[1]) # [h, w, c]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7fa3db8119d0>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "im[:, :10, :] = 255\n",
    "\n",
    "plt.subplots_adjust(top=1, bottom=0, right=1, left=0, hspace=0, wspace=0)\n",
    "plt.margins(0, 0)\n",
    "plt.axis('off')\n",
    "plt.imshow(im)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "for i in range(skel_plot.shape[0]):\n",
    "    frame = np.ones((256, 256, 3), np.uint8) * 255\n",
    "    im = draw_frame_2D(frame, skel_plot[i]) # [h, w, c]\n",
    "    im[:, :10, :] = 255\n",
    "    plt.subplots_adjust(top=1, bottom=0, right=1, left=0, hspace=0, wspace=0)\n",
    "    plt.margins(0, 0)\n",
    "    plt.axis('off')\n",
    "    plt.imshow(im)\n",
    "    plt.imsave('pose_{}.png'.format(i), im)"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "63ba4eccd028e31510a5fab74a842dac9613a8dd074a949452161e4e24b6a1c1"
  },
  "kernelspec": {
   "display_name": "Python 3.6.5 ('pt1.8')",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.11"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
