{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from einfact import NNEinFact\n",
    "\n",
    "Y = np.load('uber.npz')['Y']\n",
    "\n",
    "model_str = 'wk,hk,dk,ikr,jkr->whdij'\n",
    "\n",
    "shape_dict = {**dict(zip(model_str.split('->')[-1], Y.shape)), 'k': 10, 'r': 6}\n",
    "\n",
    "model = NNEinFact(model_str, shape_dict=shape_dict, device = 'cuda', alpha=0.5, beta = 0.5)\n",
    "\n",
    "model.fit(Y, verbose=True)\n",
    "\n",
    "Theta_WK, Theta_HK, Theta_DK, Theta_IKR, Theta_JKR = model.get_params()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "\n",
    "plt.imshow(Theta_HK, aspect='auto')\n",
    "plt.xticks(range(10), labels=[f'{i}' for i in range(1,11)])\n",
    "plt.xlabel('Latent Classes (k)')\n",
    "plt.ylabel('Hours of Day')\n",
    "plt.yticks(range(1, 24, 3), labels= [f'{i} AM' if i < 12 else (f'{i-12} PM' if i > 12 else '12 PM') for i in range(1, 24, 3)])\n",
    "plt.show()"
   ]
  }
 ],
 "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.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
