{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from torch.nn.functional import relu\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import os\n",
    "import scipy\n",
    "from math import ceil\n",
    "\n",
    "from policy_selection_for_inventories.simulator import Simulator\n",
    "\n",
    "from policy_selection_for_inventories.algorithms.gapsi_autodiff import GAPSI_Autodiff\n",
    "from policy_selection_for_inventories.algorithms.gapsi_special import GAPSI_Special\n",
    "\n",
    "import policy_selection_for_inventories\n",
    "\n",
    "from policy_selection_for_inventories.environments.ls_fifop_product import LS_FIFOP_Product\n",
    "from policy_selection_for_inventories.environments.infinite_warehouse import Infinite_Warehouse\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "T = 200\n",
    "K = 1\n",
    "demands = [torch.cat([torch.zeros(T//2), torch.ones(T//2)]) for _ in range(K)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "lifetime = 2\n",
    "leadtime = 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "purchase_cost = 1*torch.ones(T)\n",
    "holding_cost = 1*torch.ones(T)\n",
    "selling_price = 0*torch.ones(T)\n",
    "outdating_cost = 1*torch.ones(T)\n",
    "penalty_cost = 10*torch.ones(T)\n",
    "\n",
    "products = [\n",
    "    LS_FIFOP_Product(lifetime, leadtime, demands[k], purchase_cost, holding_cost, selling_price, outdating_cost, penalty_cost, 10*T*demands[k].numpy().max())\n",
    "    for k in range(K)\n",
    "]\n",
    "environment = Infinite_Warehouse(products)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "features = [torch.ones(T,1) for _ in range(K)]\n",
    "\n",
    "algorithms_name = [\"GAPSI with auto-differentiation\", \"GAPSI with custom derivatives\"]\n",
    "algorithms = [\n",
    "    GAPSI_Autodiff(environment, [1], 0.1, 50, 1.0*torch.ones(1), 0.0*torch.ones(1), 2.0*torch.ones(1), features), \n",
    "    GAPSI_Special(environment, [1], 0.1, 50, 1.0*torch.ones(1), 0.0*torch.ones(1), 2.0*torch.ones(1), features)\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "states, controls, costs, parameters, computation_times = Simulator(environment, algorithms, False, False).run(T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 650x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "linestyles = [\"-\", \"--\"]\n",
    "colors = [\"r\", \"b\"]\n",
    "plt.figure(figsize=(6.5,2.5))\n",
    "for alg_idx, alg_name in enumerate(algorithms_name) :\n",
    "    plt.plot((parameters[alg_idx]*features[0]).sum(dim=1), label=alg_name, linestyle=linestyles[alg_idx], color=colors[alg_idx])\n",
    "plt.ylim(-0.02,1.05)\n",
    "plt.plot(demands[0], label=\"Demand\", color=\"k\", alpha=0.5)\n",
    "plt.legend(loc=\"lower right\")\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"../../images/stagnation.png\")\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "inventory_policy_selection",
   "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.11.6"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
