{
 "metadata": {
  "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.10"
  },
  "orig_nbformat": 2,
  "kernelspec": {
   "name": "python3",
   "display_name": "Python 3",
   "language": "python"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2,
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "import sys\n",
    "import json\n",
    "import numpy as np\n",
    "import torch\n",
    "import sys, os\n",
    "user_path=os.getcwd()[:len(os.getcwd())-10]\n",
    "\n",
    "\n",
    "os.chdir(user_path)\n",
    "\n",
    "from leaspy import Leaspy, Data, AlgorithmSettings, Plotter, Dataset, IndividualParameters\n",
    "current_directory = user_path\n",
    "input_directory = os.path.join(current_directory, 'data')\n",
    "output_directory = user_path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "\n",
    "def ScoreComp(saveparam):\n",
    "    \"\"\"\n",
    "    Return the dictionnary D of parameters' standard deviation from a list of parameters saveparam\n",
    "    \"\"\"\n",
    "    print(saveparam)\n",
    "    Train={\"v0\":[],\"g\":[],\"tau_mean\":[]}\n",
    "    for e in saveparam:\n",
    "        param=[e]\n",
    "        Train[\"v0\"].append(e[\"v0\"])\n",
    "        Train[\"g\"].append(e[\"g\"])\n",
    "        Train[\"tau_mean\"].append(e[\"tau_mean\"])\n",
    "       \n",
    "    D={}\n",
    "    for e in Train.keys():\n",
    "       \n",
    "        Train[e]=torch.tensor(Train[e])\n",
    "        TT=Train[e]\n",
    "        D[e]=[]\n",
    "        for k in range(len(TT)-1):\n",
    "            D[e].append(torch.norm(TT[k+1]-TT[k]))\n",
    "    \n",
    "    return D\n",
    "\n",
    "def VariComp(path):\n",
    "    \"\"\"\n",
    "    Take a path and the number of a fold and return the dictionnary of parameters' stantard deviation\n",
    "    \"\"\"\n",
    "    \n",
    "    Mod=Leaspy.load(path)\n",
    "    return ScoreComp(Mod.model.saveParam)\n",
    "\n",
    "\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "experiment_folder =\"Experiment_Alzeihmer_cohort\"\n",
    "path_exp = os.path.join(output_directory, experiment_folder)\n",
    "path_output_calibrate = os.path.join(path_exp, \"calibrate\")\n",
    "i=\"0\"\n",
    "path=os.path.join(path_output_calibrate,\"fold_\"+i,\"model_parameters.json\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "output_type": "stream",
     "name": "stderr",
     "text": [
      "/Users/samuel.gruffaz/Documents/Geodesics Bending/leaspy/models/linear_B.py:56: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n  W1=torch.tensor(W, dtype=torch.float32).clone().detach()\n/Users/samuel.gruffaz/Documents/Geodesics Bending/leaspy/models/linear_B.py:57: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n  X_filtre1=torch.tensor(X_filtre, dtype=torch.float32).clone().detach()\n"
     ]
    },
    {
     "output_type": "execute_result",
     "data": {
      "text/plain": [
       "{'v0': [tensor(0.6089),\n",
       "  tensor(0.3893),\n",
       "  tensor(0.2338),\n",
       "  tensor(0.0763),\n",
       "  tensor(0.1525)],\n",
       " 'g': [tensor(0.0367),\n",
       "  tensor(0.0546),\n",
       "  tensor(0.0590),\n",
       "  tensor(0.0280),\n",
       "  tensor(0.0405)],\n",
       " 'tau_mean': [tensor(0.1312),\n",
       "  tensor(0.0623),\n",
       "  tensor(0.0849),\n",
       "  tensor(0.1485),\n",
       "  tensor(0.1315)]}"
      ]
     },
     "metadata": {},
     "execution_count": 21
    }
   ],
   "source": [
    "VariComp(path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "name =\"Stability_model.json\"\n",
    "path = os.path.join(user_path, \"Synthetic\",name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "output_type": "execute_result",
     "data": {
      "text/plain": [
       "{'v0': [tensor(0.),\n",
       "  tensor(0.0196),\n",
       "  tensor(0.),\n",
       "  tensor(0.0050),\n",
       "  tensor(0.),\n",
       "  tensor(0.0188),\n",
       "  tensor(0.),\n",
       "  tensor(0.0032),\n",
       "  tensor(0.),\n",
       "  tensor(0.0380),\n",
       "  tensor(0.)],\n",
       " 'g': [tensor(0.),\n",
       "  tensor(0.0744),\n",
       "  tensor(0.),\n",
       "  tensor(0.0939),\n",
       "  tensor(0.),\n",
       "  tensor(0.0408),\n",
       "  tensor(0.),\n",
       "  tensor(0.0693),\n",
       "  tensor(0.),\n",
       "  tensor(0.0736),\n",
       "  tensor(0.)],\n",
       " 'tau_mean': [tensor(0.),\n",
       "  tensor(0.0202),\n",
       "  tensor(0.),\n",
       "  tensor(0.0108),\n",
       "  tensor(0.),\n",
       "  tensor(0.0307),\n",
       "  tensor(0.),\n",
       "  tensor(0.0385),\n",
       "  tensor(0.),\n",
       "  tensor(0.0211),\n",
       "  tensor(0.)]}"
      ]
     },
     "metadata": {},
     "execution_count": 29
    }
   ],
   "source": [
    "VariComp(path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ]
}