{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "829166d1",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "%matplotlib inline\n",
    "from matplotlib import pyplot as plt\n",
    "import keras\n",
    "\n",
    "import json\n",
    "import os\n",
    "\n",
    "import sys\n",
    "sys.path.insert(0, '../../../')\n",
    "\n",
    "import ml\n",
    "\n",
    "from keras.optimizers import Adam\n",
    "from keras.losses import MeanSquaredError\n",
    "from keras.callbacks import EarlyStopping\n",
    "\n",
    "\n",
    "dtypes = ['train', 'validate', 'test']\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "db9a55dc",
   "metadata": {},
   "source": [
    "# Physics-aware network training"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d8474196",
   "metadata": {},
   "source": [
    "We train physics-aware networks in this notebook. We also save the trained model's weights and predictions. Additional predictions are made on mirror circuits, if a mirror circuit dataset exists."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ce4928ad",
   "metadata": {},
   "source": [
    "Set the experiment number."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "98d071ef",
   "metadata": {},
   "outputs": [],
   "source": [
    "exp_num = 4"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "64a78f86",
   "metadata": {},
   "source": [
    "Set up file paths and create the folders in which the model weights and predictions will be kept."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c7712a67",
   "metadata": {},
   "outputs": [],
   "source": [
    "alphas = {'train': 1, 'validate': .75, 'test': .4}\n",
    "\n",
    "exp_path = f'./experiment_{exp_num}/'\n",
    "sim_path = exp_path + '/simulation_results/'\n",
    "proc_path = exp_path + '/processed_inputs_and_outputs/'\n",
    "\n",
    "model_path = exp_path + '/models/'\n",
    "history_path = exp_path + '/training_histories/'\n",
    "pred_path = exp_path + '/predictions/'\n",
    "\n",
    "os.makedirs(model_path, exist_ok = True)\n",
    "os.makedirs(history_path, exist_ok = True)\n",
    "os.makedirs(pred_path, exist_ok = True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b72fbe8d",
   "metadata": {},
   "source": [
    "Load up the circuits and the (scaled) infidelities."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "65fe96f4",
   "metadata": {},
   "outputs": [],
   "source": [
    "circuits = np.load(proc_path+'/processed_high_fidelity_circuits.npz')\n",
    "infidelities = np.load(proc_path+'/processed_infidelities.npz')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b09a1cb8",
   "metadata": {},
   "source": [
    "Load up the necessary meta information, and create some necessary model parameters (e.g., the list of tracked errors)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "8d7b2c86",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(exp_path+'/meta.json', 'r') as f:\n",
    "    meta = json.load(f)\n",
    "\n",
    "num_qubits = meta['num_qubits']\n",
    "max_error_weight = meta['max_error_weight']\n",
    "num_hops = meta['num_hops']\n",
    "num_channels = meta['num_channels']\n",
    "if meta['geometry'] == 'ring':\n",
    "    adj_matrix = ml.newtools.ring_adj_matrix(num_qubits)\n",
    "    laplace = ml.newtools.laplace_from_qubit_graph(adj_matrix)\n",
    "else:\n",
    "    print(f'You have not implemented the {geometry} geometry.')\n",
    "\n",
    "error_gens = ml.newtools.up_to_weight_k_error_gens_from_qubit_graph(max_error_weight, num_qubits, laplace, num_hops)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c6b78f12",
   "metadata": {},
   "source": [
    "Quick visual verification that you have a good distribution of infidelities."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "6c197289",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7fe0f04369a0>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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0uuvv662bdvqww8/tB+AfTExcwMAQAswbNgw/elPf1J1dbWkHwLJvffeq4CAAB0/flyTJk1S586d1bZtW0VEROjzzz8/75mbPXv2qEuXLgoLC7O3de/evUHdyy+/rLS0NF1++eWKiIjQq6+++qPvUVhYqC+++EKRkZGKiIhQRESEoqOjdfLkSX355ZeNOAK+w8wNAAAtwKBBg1RfX6/33ntPN910kzZs2KDZs2dLkh577DGtWrVKzz33nK655hqFhobqrrvuOu+ffSzL+tGat956S48++qief/55de/eXZGRkXr22We1ZcuWc+5XX1+v1NRUvfHGGw1eu/zyy8+rP18j3AAA0AKEhoZqyJAheuONN/TFF1/o2muvVWpqqiRpw4YNGjFihH7+859LkiorKxt1wm7nzp21aNEiVVVVKTQ0VJK0efNmr5oNGzYoPT1do0ePtredPvMSHBysuro6r2033nij3nzzTcXGxioqKuq8e2pO/CwFAEALMWzYML333nv6/e9/r/vuu8/efs0112jZsmUqKirSJ598oqysrAZXVp1LVlaWLrvsMo0aNUq7d+/W+++/r+eee86r5pprrtH27du1atUq7du3T0888YS2bdvmVZOQkKBPP/1Ue/fu1ZEjR1RbW6thw4apffv2uvPOO7VhwwYVFxdr3bp1euSRR3T48OELOyBNRLgBAKCF+I//+A9FR0dr7969ysrKsrfPmTNH7dq1U3p6ugYNGqS+ffvqxhtvPO9xIyIi9O6772r37t3q2rWrpk2bppkzZ3rVPPTQQxoyZIjuuecedevWTf/4xz+8ZnEk6YEHHlDHjh3t83L+9re/KSwsTOvXr1eHDh00ZMgQderUSSNHjlRVVZXfZnIc1vn8ENcKVVRUyOl0yuPxNMvBTZjyns/HvBD7nxng7xYAwO9Onjyp4uJiJSYmqk2bNv5uB2dxrr+TL76/mbkBAABGIdwAAACjEG4AAIBRCDcAAMAohBsAAGAUwg0AADAK4QYAABiFcAMAAIxCuAEAAEYh3AAAAKPwVHAAwCXhj/v+eNHe6+5r7270Pj179tQNN9yguXPn+qSHESNG6OjRo3r77bd9Ml5rwswNAAAwCuEGAAA/GzFihNatW6cXXnhBDodDDodD+/fv1+7du9W/f39FREQoLi5O2dnZOnLkiL3f//3f/yklJUWhoaGK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NXnyZKWkpCg8PFxut1v333+/vvnmm0a/D+GmEd58803l5ORo2rRp+vjjj/Xv//7vuuOOO3Tw4EF/t9airVu3TmPGjNHmzZtVUFCg77//XhkZGTp+/Li/W2s1tm3bpvnz5+snP/mJv1tpFcrLy3XLLbcoKChIf/nLX7R79249//zzzX7X8tZu5syZevnll5Wfn689e/Zo1qxZevbZZzVv3jx/t9biHD9+XF26dFF+fv4ZX581a5Zmz56t/Px8bdu2TS6XS3369NGxY8cucqcty7mO24kTJ7Rjxw498cQT2rFjh5YtW6Z9+/Zp8ODBjX8jC+ft5ptvth566CGvbdddd501ZcoUP3XUOpWVlVmSrHXr1vm7lVbh2LFjVlJSklVQUGD16NHDeuSRR/zdUos3efJk69Zbb/V3G63OgAEDrJEjR3ptGzJkiHXffff5qaPWQZK1fPlye72+vt5yuVzWM888Y287efKk5XQ6rZdfftkPHbZMpx+3M9m6daslyTpw4ECjxmbm5jzV1NSosLBQGRkZXtszMjK0adMmP3XVOnk8HklSdHS0nztpHcaMGaMBAwaod+/e/m6l1VixYoXS0tJ09913KzY2Vl27dtWrr77q77ZavFtvvVV//etftW/fPknSJ598oo0bN6p///5+7qx1KS4uVmlpqdf3RUhIiHr06MH3RSN5PB45HI5Gz7q26DsUtyRHjhxRXV1dg4d2xsXFNXi4J87OsiyNHz9et956q5KTk/3dTou3dOlS7dixQ9u2bfN3K63KV199pZdeeknjx4/Xr3/9a23dulUPP/ywQkJCdP/99/u7vRZr8uTJ8ng8uu666xQQEKC6ujo9/fTTGjp0qL9ba1VOfSec6fviwIED/mipVTp58qSmTJmirKysRj+ElHDTSA6Hw2vdsqwG23B2Y8eO1aeffqqNGzf6u5UW79ChQ3rkkUe0evVqtWnTxt/ttCr19fVKS0tTbm6uJKlr167atWuXXnrpJcLNObz55ptavHixlixZouuvv15FRUXKycmR2+3W8OHD/d1eq8P3RdPV1tbq3nvvVX19vV588cVG70+4OU/t27dXQEBAg1masrKyBukcZzZu3DitWLFC69ev15VXXunvdlq8wsJClZWVKTU11d5WV1en9evXKz8/X9XV1QoICPBjhy3XFVdcoc6dO3tt69Spk/70pz/5qaPW4bHHHtOUKVN07733SpJSUlJ04MAB5eXlEW4aweVySfphBueKK66wt/N9cX5qa2uVmZmp4uJiffDBB42etZG4Wuq8BQcHKzU1VQUFBV7bCwoKlJ6e7qeuWgfLsjR27FgtW7ZMH3zwgRITE/3dUqvQq1cvffbZZyoqKrKXtLQ0DRs2TEVFRQSbc7jlllsa3G5g3759fn/obkt34sQJXXaZ99dCQEAAl4I3UmJiolwul9f3RU1NjdatW8f3xY84FWz+/ve/a82aNYqJiWnSOMzcNML48eOVnZ2ttLQ0de/eXfPnz9fBgwf10EMP+bu1Fm3MmDFasmSJ3nnnHUVGRtqzX06nU6GhoX7uruWKjIxscF5SeHi4YmJiOF/pRzz66KNKT09Xbm6uMjMztXXrVs2fP1/z58/3d2st2qBBg/T000+rQ4cOuv766/Xxxx9r9uzZGjlypL9ba3EqKyv1xRdf2OvFxcUqKipSdHS0OnTooJycHOXm5iopKUlJSUnKzc1VWFiYsrKy/Ni1/53ruLndbt11113asWOH/vznP6uurs7+voiOjlZwcPD5v1ETr+C6ZP3P//yPddVVV1nBwcHWjTfeyOXM50HSGZfXX3/d3621OlwKfv7effddKzk52QoJCbGuu+46a/78+f5uqcWrqKiwHnnkEatDhw5WmzZtrKuvvtqaNm2aVV1d7e/WWpy1a9ee8f/Xhg8fblnWD5eD/+Y3v7FcLpcVEhJi3XbbbdZnn33m36ZbgHMdt+Li4rN+X6xdu7ZR7+OwLMtqegYDAABoWTjnBgAAGIVwAwAAjEK4AQAARiHcAAAAoxBuAACAUQg3AADAKIQbAABgFMINAAAwCuEGAAAYhXADAACMQrgBAABGIdwAAACj/D95TFEZ7besiAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "for dt in dtypes:\n",
    "    ax.hist(infidelities[dt] / 100, label = dt, alpha = alphas[dt])\n",
    "ax.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "d0e1e776",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4985"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(infidelities['train'])+len(infidelities['validate'])+len(infidelities['test'])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c42ed5bd",
   "metadata": {},
   "source": [
    "# Create  and train the network"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "28e11606",
   "metadata": {},
   "source": [
    "The next cell instantiates the model (`CircuitErrorVec`) and trains the model using the Adam optimizer and MSE as the loss function. We use early stopping to cut the model training short when the model's validation loss plateaus."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c42ed5bd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/200\n",
      "88/88 [==============================] - 185s 743ms/step - loss: 13283.9688 - val_loss: 7331.5669\n",
      "Epoch 2/200\n",
      "88/88 [==============================] - 54s 618ms/step - loss: 5465.7305 - val_loss: 6721.7227\n",
      "Epoch 3/200\n",
      "88/88 [==============================] - 52s 594ms/step - loss: 5213.3467 - val_loss: 6535.8374\n",
      "Epoch 4/200\n",
      "88/88 [==============================] - 53s 603ms/step - loss: 5039.8135 - val_loss: 6392.6055\n",
      "Epoch 5/200\n",
      "88/88 [==============================] - 57s 646ms/step - loss: 5036.8828 - val_loss: 6452.4775\n",
      "Epoch 6/200\n",
      "88/88 [==============================] - 53s 606ms/step - loss: 4968.7144 - val_loss: 6506.0825\n",
      "Epoch 7/200\n",
      "88/88 [==============================] - 53s 604ms/step - loss: 4903.1870 - val_loss: 6178.8188\n",
      "Epoch 8/200\n",
      "88/88 [==============================] - 53s 601ms/step - loss: 4910.9546 - val_loss: 6288.7627\n",
      "Epoch 9/200\n",
      "88/88 [==============================] - 53s 604ms/step - loss: 4886.1577 - val_loss: 6379.4390\n",
      "Epoch 10/200\n",
      "88/88 [==============================] - 52s 592ms/step - loss: 4912.6484 - val_loss: 6376.4497\n",
      "Epoch 11/200\n",
      "88/88 [==============================] - 52s 590ms/step - loss: 4936.9487 - val_loss: 6301.0264\n",
      "Epoch 12/200\n",
      "88/88 [==============================] - 54s 609ms/step - loss: 4832.2446 - val_loss: 6229.2363\n",
      "Epoch 13/200\n",
      "88/88 [==============================] - 52s 593ms/step - loss: 4833.5547 - val_loss: 6259.7705\n",
      "Epoch 14/200\n",
      "88/88 [==============================] - 54s 613ms/step - loss: 4735.5991 - val_loss: 7009.0381\n",
      "Epoch 15/200\n",
      "88/88 [==============================] - 54s 613ms/step - loss: 4770.6079 - val_loss: 5222.2061\n",
      "Epoch 16/200\n",
      "88/88 [==============================] - 56s 641ms/step - loss: 4319.4644 - val_loss: 4727.1729\n",
      "Epoch 17/200\n",
      "88/88 [==============================] - 61s 698ms/step - loss: 4379.3813 - val_loss: 5088.1943\n",
      "Epoch 18/200\n",
      "88/88 [==============================] - 67s 757ms/step - loss: 3665.0688 - val_loss: 3586.4380\n",
      "Epoch 19/200\n",
      "88/88 [==============================] - 61s 699ms/step - loss: 2523.2021 - val_loss: 2887.8479\n",
      "Epoch 20/200\n",
      "88/88 [==============================] - 72s 815ms/step - loss: 1976.5889 - val_loss: 2627.1179\n",
      "Epoch 21/200\n",
      "88/88 [==============================] - 80s 909ms/step - loss: 1625.2996 - val_loss: 2240.9211\n",
      "Epoch 22/200\n",
      "88/88 [==============================] - 77s 881ms/step - loss: 1340.4016 - val_loss: 1990.5868\n",
      "Epoch 23/200\n",
      "88/88 [==============================] - 80s 908ms/step - loss: 1220.5933 - val_loss: 1739.2740\n",
      "Epoch 24/200\n",
      "88/88 [==============================] - 76s 870ms/step - loss: 1055.1759 - val_loss: 1718.7976\n",
      "Epoch 25/200\n",
      "88/88 [==============================] - 55s 622ms/step - loss: 972.5225 - val_loss: 1637.4968\n",
      "Epoch 26/200\n",
      "88/88 [==============================] - 47s 534ms/step - loss: 790.2816 - val_loss: 1468.1270\n",
      "Epoch 27/200\n",
      "88/88 [==============================] - 63s 705ms/step - loss: 687.2676 - val_loss: 1280.3773\n",
      "Epoch 28/200\n",
      "88/88 [==============================] - 45s 513ms/step - loss: 588.7120 - val_loss: 1154.7145\n",
      "Epoch 29/200\n",
      "88/88 [==============================] - 43s 488ms/step - loss: 488.8975 - val_loss: 1124.9429\n",
      "Epoch 30/200\n",
      "88/88 [==============================] - 43s 491ms/step - loss: 418.7882 - val_loss: 1254.0078\n",
      "Epoch 31/200\n",
      "88/88 [==============================] - 43s 488ms/step - loss: 420.6429 - val_loss: 1123.6036\n",
      "Epoch 32/200\n",
      "88/88 [==============================] - 43s 488ms/step - loss: 339.9037 - val_loss: 1101.1263\n",
      "Epoch 33/200\n",
      "88/88 [==============================] - 43s 484ms/step - loss: 291.9486 - val_loss: 1040.1111\n",
      "Epoch 34/200\n",
      "88/88 [==============================] - 43s 490ms/step - loss: 249.7766 - val_loss: 1031.0173\n",
      "Epoch 35/200\n",
      "88/88 [==============================] - 43s 490ms/step - loss: 241.6764 - val_loss: 1061.6478\n",
      "Epoch 36/200\n",
      "88/88 [==============================] - 43s 489ms/step - loss: 205.8216 - val_loss: 1084.9974\n",
      "Epoch 37/200\n",
      "88/88 [==============================] - 43s 491ms/step - loss: 188.6343 - val_loss: 1026.4646\n",
      "Epoch 38/200\n",
      "88/88 [==============================] - 43s 484ms/step - loss: 169.0682 - val_loss: 1001.6308\n",
      "Epoch 39/200\n",
      "88/88 [==============================] - 43s 493ms/step - loss: 144.0827 - val_loss: 1008.0871\n",
      "Epoch 40/200\n",
      "88/88 [==============================] - 43s 492ms/step - loss: 143.2017 - val_loss: 1077.5278\n",
      "Epoch 41/200\n",
      "88/88 [==============================] - 43s 495ms/step - loss: 170.2358 - val_loss: 1027.8632\n",
      "Epoch 42/200\n",
      "88/88 [==============================] - 43s 491ms/step - loss: 125.1314 - val_loss: 1002.9097\n",
      "Epoch 43/200\n",
      "88/88 [==============================] - 43s 489ms/step - loss: 116.6919 - val_loss: 1024.6511\n"
     ]
    }
   ],
   "source": [
    "from keras.callbacks import EarlyStopping\n",
    "\n",
    "layer_snipper = ml.newneuralnets.layer_snipper_from_qubit_graph\n",
    "layer_snipper_args = [num_qubits, num_channels, laplace, num_hops]\n",
    "\n",
    "optimizer = keras.optimizers.Adam(learning_rate=1e-3)\n",
    "\n",
    "circuit_dense = ml.newneuralnets.CircuitErrorVec(num_qubits, num_channels, error_gens, layer_snipper,\n",
    "                                                layer_snipper_args)\n",
    "\n",
    "circuit_dense.compile(optimizer, loss=keras.losses.MeanSquaredError())\n",
    "\n",
    "callback = EarlyStopping(monitor='val_loss', patience=10, min_delta = 50)\n",
    "\n",
    "history1 = circuit_dense.fit(circuits['train'], infidelities['train'], epochs=200, batch_size=32, \n",
    "                             validation_data=[circuits['validate'], infidelities['validate']], callbacks = [callback])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5d7ab554",
   "metadata": {},
   "source": [
    "Use the trained model to make predictions. Also compute the MAE of the model's predictions (these are not saved)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "dd8d8559",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "88/88 [==============================] - 13s 75ms/step\n",
      "30/30 [==============================] - 2s 65ms/step\n",
      "39/39 [==============================] - 3s 72ms/step\n"
     ]
    }
   ],
   "source": [
    "predictions = {dtype: circuit_dense.predict(circuits[dtype]) for dtype in ['train', 'validate', 'test']}\n",
    "abs_errors = {dt: np.abs(predictions[dt]/100-infidelities[dt]/100) for dt in dtypes}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "743b922d",
   "metadata": {},
   "source": [
    "Save the model's predictions, weights, and training history."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "3fc6dff6",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.savez_compressed(pred_path + 'processed_custom_neural_net_predictions.npz', **predictions)\n",
    "\n",
    "circuit_dense.save_weights(model_path+'custom_neural_network/')\n",
    "\n",
    "with open(history_path + 'custom-network-history.json', 'w') as file:\n",
    "    json.dump(history1.history, file)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "503e864e",
   "metadata": {},
   "source": [
    "# Make and view predictions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "c3df4e0d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7fe0e531a820>"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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G3bs2AHGGCZOnGhXoG78+PHYtGkTzpw5gy+//BK5ubn44x//aHed5cuX48UXX0RaWhpOnTqF77//HpMmTbJr89RTT+H//u//8Oabb+L06dPYunUrkpKSHPqs1Wrx4IMP4tZbb3U49+mnnyItLQ2LFy/Gb7/9hjVr1mDjxo144YUXbG327t2LJ554AgcPHsSuXbtgNpsxceJEVFVV2drUf08KCgrw4YcfguM43HPPPQ73XLFiRZPL455//nlER0c7HK+oqMCkSZNw3XXX4dChQ/jpp58QGBiISZMm2QIOmUyGBx98EDt37sSZM2ewYsUKrF69GosXL7a71syZM/H9999jzZo1OHPmDNavX4++fdvvmw8hpIPI2YIjG/6FB8ofRZrpEZwRe1iO6wqATQ8COVvar2+sg9FqtQwA02q1Dueqq6tZTk4Oq66ubtE9vjtxlY14LZPFpX5r+xnxWib77sTVFl23KUlJSWzBggV2x/r27cvS0tKctn/++edZ37597Y499thjbMSIES7v8e9//5sFBASwyspKp+cBsM2bNzscnzt3LpsxY0bjL6CBX375hQFg58+fd9nmm2++YRzHsZqaGsYYY6WlpczX15dlZma6fE5OTg6TSqXs9OnTTfbh3nvvZS+99BJbvHgxGzRokN25J554gk2YMMHuWEpKChs9erTL62k0GgaA7d2712WbGTNmOFyXMcaOHz/OevTowQoKCly+z9u3b2d9+/Zlp06dYgDYsWPHbOcOHz7MALBLly7Zjv36669NvsdPP/203Wv67rvvmEqlYiUlJS6f05C3frcIIR2YYGbsrb5M+IeKPfTCKyztbyms+h+hjC0OrP1RMfZWP0u7Zmjs89sd3W6EJONkAR5fl40CrcHueKHWgMfXZSPjZEGr3LempgZHjx7FxIkT7Y5PnDgR+/fvd/qcAwcOOLSfNGkSjhw54jBEb7VmzRrcd9998PPz87iPe/bsQUREBK6//nrMnz8fGo3GZduqqiqsXbsW8fHxLndoLi0txaeffoqRI0dCJrNU9tu1axdEUcSVK1fQr18/9OjRAzNnzrTbVHHr1q3o1asXvv32W8THx6Nnz5545JFHUFpaanf9tWvXIjc312F0wGr06NE4evQosrKyAAAXLlzA9u3b7aazGtJqtQAslYWdKSoqwrZt2/DnP//Z7rher8f999+P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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for dt in dtypes:\n",
    "    plt.scatter(predictions[dt]/100, infidelities[dt]/100, label=np.mean(abs_errors[dt]))\n",
    "\n",
    "max_infidelity = np.max([np.max(infidelities[dt]) for dt in dtypes]) / 100\n",
    "max_pred = np.max([np.max(predictions[dt]) for dt in dtypes]) / 100\n",
    "max_val = max(max_infidelity, max_pred)\n",
    "                        \n",
    "plt.plot([0,max_val+.5],[0,max_val+.5], ':')\n",
    "plt.xlim(0,max_val+.5)\n",
    "plt.ylim(0,max_val+.5)\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6752c05a",
   "metadata": {},
   "source": [
    "# Mirror circuit predictions"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1a0f86c3",
   "metadata": {},
   "source": [
    "In the next few cells, we will re-create the model trained on the {exp_num} dataset using its saved weights. Then we make and save the model's predictions on the dataset's mirror circuits."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "ead8e093",
   "metadata": {},
   "outputs": [],
   "source": [
    "alphas = {'train': 1, 'validate': .75, 'test': .4}\n",
    "\n",
    "exp_path = f'./experiment_{exp_num}/'\n",
    "sim_path = exp_path + '/simulation_results/'\n",
    "proc_path = exp_path + '/processed_inputs_and_outputs/'\n",
    "\n",
    "model_path = exp_path + '/models/'\n",
    "history_path = exp_path + '/training_histories/'\n",
    "pred_path = exp_path + '/predictions/'\n",
    "\n",
    "with open(exp_path+'/meta.json', 'r') as f:\n",
    "    meta = json.load(f)\n",
    "\n",
    "num_qubits = meta['num_qubits']\n",
    "max_error_weight = meta['max_error_weight']\n",
    "num_hops = meta['num_hops']\n",
    "num_channels = meta['num_channels']\n",
    "if meta['geometry'] == 'ring':\n",
    "    adj_matrix = ml.newtools.ring_adj_matrix(num_qubits)\n",
    "    laplace = ml.newtools.laplace_from_qubit_graph(adj_matrix)\n",
    "else:\n",
    "    print(f'You have not implemented the {geometry} geometry.')\n",
    "\n",
    "error_gens = ml.newtools.up_to_weight_k_error_gens_from_qubit_graph(max_error_weight, num_qubits, laplace, num_hops)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "dd017786",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<tensorflow.python.checkpoint.checkpoint.CheckpointLoadStatus at 0x7fe0f75c7520>"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Load up the model\n",
    "\n",
    "layer_snipper = ml.newneuralnets.layer_snipper_from_qubit_graph\n",
    "layer_snipper_args = [num_qubits, num_channels, laplace, num_hops]\n",
    "\n",
    "optimizer = keras.optimizers.Adam(learning_rate=1e-3)\n",
    "\n",
    "circuit_dense1 = ml.newneuralnets.CircuitErrorVec(num_qubits, num_channels, error_gens, layer_snipper,\n",
    "                                                layer_snipper_args)\n",
    "\n",
    "# circuit_dense1.compile(optimizer, loss=keras.losses.MeanSquaredError())\n",
    "\n",
    "circuit_dense1.load_weights(model_path+'custom_neural_network/')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "0be0c55c",
   "metadata": {},
   "outputs": [],
   "source": [
    "o_circuits = np.load(proc_path + '/processed_mirrored_circuits.npz')['circuits']\n",
    "o_infidelities = np.load(proc_path + '/processed_mirrored_infidelities.npz')['infidelities']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "982f9003",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "24/24 [==============================] - 44s 74ms/step\n"
     ]
    }
   ],
   "source": [
    "o_predictions = circuit_dense1.predict(o_circuits)\n",
    "o_abs_errors = np.abs(o_predictions/100-o_infidelities/100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "b67aa1f5",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.savez_compressed(pred_path + '/processed_custom_neural_net_mirrored_predictions.npz', predictions = o_predictions)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "543d52bb",
   "metadata": {},
   "source": [
    "Quick visualization of the model's out-of-distribution performance on mirror circuits."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "3b73132b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7fdf804f5e80>"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(o_predictions/100, o_infidelities/100, label=np.mean(o_abs_errors))\n",
    "\n",
    "max_infidelity = np.max(o_infidelities) / 100\n",
    "max_pred = np.max(o_predictions) / 100\n",
    "max_val = max(max_infidelity, max_pred)\n",
    "                        \n",
    "plt.plot([0,max_val+.5],[0,max_val+.5], ':')\n",
    "plt.xlim(0,max_val+.5)\n",
    "plt.ylim(0,max_val+.5)\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fa168fa0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c85a0cea",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "QPL",
   "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.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
