{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "551c0ea6-d647-4590-aa87-18822f2c594d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import json"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "08f6985b",
   "metadata": {},
   "source": [
    "# Configurations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b68c75fe",
   "metadata": {},
   "outputs": [],
   "source": [
    "nn_model_config={\n",
    "    'activation':'relu',\n",
    "    'hidden':10,\n",
    "    'hidden_num':15,\n",
    "    'output':4,\n",
    "    'input':1,\n",
    "    'layer_scale':1e-1,\n",
    "    'loss_trainable':True,\n",
    "    'normalize':False,\n",
    "}\n",
    "conv_model_config={\n",
    "    'filters':[16,16,16,16],\n",
    "    'repeats':[2,2,1,1],\n",
    "    'input_shape':(None,None,3),\n",
    "    'activation':'relu',\n",
    "    'strides':2,\n",
    "    'kernel_sizes':3,\n",
    "    'layer_scale':1.,\n",
    "    'scale_trainable':False,\n",
    "    'loss_trainable':True,\n",
    "    'conv_shortcut':False,\n",
    "    'expand_dim':False, #adding channel dim for e.g. MNIST\n",
    "    'output_shape':10,\n",
    "}\n",
    "\n",
    "mpc_config={\n",
    "    'mpc_stride':1,\n",
    "    'different_loss':False,\n",
    "    'update_stride':True,\n",
    "    'update_state':False,\n",
    "    'update_together':None,\n",
    "    'block_start':1,\n",
    "}\n",
    "base_config={\n",
    "    'gpu':0, #select GPU to use\n",
    "    'repeats':3,\n",
    "    'metrics':['acc'],\n",
    "    'model':'res',\n",
    "    'filters_repeats':[([16],[1]),([16],[2]),([16]*2,[2,1]),([16]*2,[2,2]),([16]*3,[2,2,1]),([16]*4,[2,2,1,1])], #for df1 only\n",
    "    'model_config':conv_model_config,\n",
    "    'mpc_config':mpc_config,\n",
    "    'horizon_stride':[(1,1),(2,1),(3,1),(4,1),(5,1),(6,1),(3,2),(4,2)],\n",
    "    'train_process_sample_times':6, #for df3 only\n",
    "    'sample_interval_epochs':100, #for df3 only\n",
    "    'epochs':40,\n",
    "    'batch_size':32,\n",
    "    'learning_rate':1e-2,\n",
    "}\n",
    "\n",
    "nn_modify_config1={\n",
    "    'model_config':nn_model_config,\n",
    "    'horizon_stride':[(1,1),(2,1),(3,1),(5,1),(7,1),(10,1),(13,1),(14,1),(15,1)],\n",
    "    'loss':'mse',\n",
    "    'metrics':[],\n",
    "    'batch_size':100,\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ec460b1c",
   "metadata": {},
   "outputs": [],
   "source": [
    "d=10\n",
    "config_linear=base_config.copy()\n",
    "config_linear.update(nn_modify_config1)\n",
    "config_linear['model_config']=nn_model_config.copy()\n",
    "config_linear['model_config'].update({'hidden':d,'layer_scale':.1,'activation':None,'input':d,'output':d})\n",
    "config_linear['mpc_config']=mpc_config.copy()\n",
    "config_linear.update({'d':d,'model':'linear','index':1,'learning_rate':3e-2})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "000c39dd",
   "metadata": {},
   "outputs": [],
   "source": [
    "config_res=base_config.copy()\n",
    "config_res.update(nn_modify_config1)\n",
    "config_res['model_config']=nn_model_config.copy()\n",
    "config_res['model_config'].update({'hidden':10})\n",
    "config_res['mpc_config']=mpc_config.copy()\n",
    "config_res['index']=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3d00674",
   "metadata": {},
   "outputs": [],
   "source": [
    "config_conv=base_config.copy()\n",
    "config_conv['model']='conv'\n",
    "config_conv['model_config']=conv_model_config.copy()\n",
    "config_conv['model_config'].update({\n",
    "    'filters':[16,32,64],\n",
    "    'repeats':[10,10,10],\n",
    "    'strides':[1,2,2,],\n",
    "    'layer_scale':1.,\n",
    "})\n",
    "config_conv['mpc_config']=mpc_config.copy()\n",
    "config_conv.update({\n",
    "    'horizon_stride':[(i,1) for i in [1,2,3,4,5,7,10,13,15,16,18,21,24,26,27,28,29,30]],\n",
    "    'index':1,\n",
    "})"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "61b31b49-92ec-4ecf-b56d-206e8e42292c",
   "metadata": {},
   "source": [
    "# Test grad"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ccce49df-033b-4545-a88e-a263642f5f20",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "config_linear1=config_linear.copy()\n",
    "config_linear1['experiment']='grad'\n",
    "config_linear1['model_config'].update({'hidden_num':20,'layer_scale':.1,\n",
    "#                                        'horizon_stride':[(i,1) for i in range(1,10)]+[(i*10,1) for i in range(1,20)]+[(190+i,1) for i in range(1,11)]\n",
    "                                      })\n",
    "with open('./experiment_config.json','w') as j:\n",
    "    json.dump(config_linear1,j)\n",
    "!python ./Experiments_integrate.py"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2cdedf6c-49cf-44a7-9ddd-ea0da528750b",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "config_res1=config_res.copy()\n",
    "config_res1['experiment']='grad'\n",
    "config_res1['model_config']=nn_model_config.copy()\n",
    "config_res1['model_config'].update({'layer_scale':.01})\n",
    "with open('./experiment_config.json','w') as j:\n",
    "    json.dump(config_res1,j)\n",
    "!python ./Experiments_integrate.py"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0e5a4be7-7c73-444f-ae8c-5f9989bbe35c",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "config_conv['experiment']='grad'\n",
    "with open('./experiment_config.json','w') as j:\n",
    "    json.dump(config_conv1,j)\n",
    "!python ./Experiments_integrate.py"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "21b6a381",
   "metadata": {},
   "source": [
    "# Test storage"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9935aa49",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "config_linear1=config_linear.copy()\n",
    "config_linear1['experiment']='storage'\n",
    "config_linear1['eager']=True\n",
    "with open('./experiment_config.json','w') as j:\n",
    "    json.dump(config_linear1,j)\n",
    "!python ./Experiments_integrate.py\n",
    "config_linear1['eager']=False\n",
    "with open('./experiment_config.json','w') as j:\n",
    "    json.dump(config_linear1,j)\n",
    "!python ./Experiments_integrate.py"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b18d827b",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "config_res1=config_res.copy()\n",
    "config_res1['experiment']='storage'\n",
    "config_res1['eager']=True\n",
    "with open('./experiment_config.json','w') as j:\n",
    "    json.dump(config_res1,j)\n",
    "!python ./Experiments_integrate.py\n",
    "config_res1['eager']=False\n",
    "with open('./experiment_config.json','w') as j:\n",
    "    json.dump(config_res1,j)\n",
    "!python ./Experiments_integrate.py"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9cba2092",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "config_conv1=config_conv.copy()\n",
    "config_conv1['experiment']='storage'\n",
    "config_conv1['eager']=True\n",
    "with open('./experiment_config.json','w') as j:\n",
    "    json.dump(config_conv1,j)\n",
    "!python ./Experiments_integrate.py\n",
    "config_conv1['eager']=False\n",
    "with open('./experiment_config.json','w') as j:\n",
    "    json.dump(config_conv1,j)\n",
    "!python ./Experiments_integrate.py"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b6b9e76e",
   "metadata": {},
   "source": [
    "# Test fix horizon"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f8278820",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "config_linear1=config_linear.copy()\n",
    "config_linear1['experiment']='fix'\n",
    "with open('./experiment_config.json','w') as j:\n",
    "    json.dump(config_linear1,j)\n",
    "!python ./Experiments_integrate.py"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "17281f1e",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "config_res1=config_res.copy()\n",
    "config_res1['experiment']='fix'\n",
    "with open('./experiment_config.json','w') as j:\n",
    "    json.dump(config_res1,j)\n",
    "!python ./Experiments_integrate.py"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8eb06be9",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "config_conv1=config_conv.copy()\n",
    "config_conv1['experiment']='fix'\n",
    "with open('./experiment_config.json','w') as j:\n",
    "    json.dump(config_conv1,j)\n",
    "!python ./Experiments_integrate.py"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fc034cba",
   "metadata": {},
   "source": [
    "## LoCo algorithm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "14886310",
   "metadata": {},
   "outputs": [],
   "source": [
    "config_linear1=config_linear.copy()\n",
    "config_linear1.update({'experiment':'fix','model':'linear_loco','horizon_strides':[(6,3),(10,5)]})\n",
    "with open('./experiment_config.json','w') as j:\n",
    "    json.dump(config_linear1,j)\n",
    "!python ./Experiments_integrate.py"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "caed3862",
   "metadata": {},
   "outputs": [],
   "source": [
    "config_res1=config_linear.copy()\n",
    "config_res1.update({'experiment':'fix','model':'res_loco','horizon_strides':[(6,3),(10,5)]})\n",
    "with open('./experiment_config.json','w') as j:\n",
    "    json.dump(config_res1,j)\n",
    "!python ./Experiments_integrate.py"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7b02280c",
   "metadata": {},
   "outputs": [],
   "source": [
    "config_conv1=config_linear.copy()\n",
    "config_conv1.update({'experiment':'fix','model':'conv_loco','horizon_strides':[(12,6),(20,10)]})\n",
    "with open('./experiment_config.json','w') as j:\n",
    "    json.dump(config_conv1,j)\n",
    "!python ./Experiments_integrate.py"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "86f1094e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ab64843f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3119e15c",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
