{
 "cells": [
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "f7bf07b9-d489-4484-acb9-175cb740dc60",
   "metadata": {},
   "source": [
    "# Cifar-10 tutorial\n",
    "\n",
    "This notebook introduces advanced tools like MLP mixer, which involves residual connections with Lipschitz guarantees, other input space (HSB) and loss gradient clipping.\n",
    "\n",
    "## Imports"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "8a0eebdf-6082-4d00-aa14-b42953217a93",
   "metadata": {},
   "source": [
    "The library is based on tensorflow."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "91c2965e-0375-4966-bc55-776204af9d69",
   "metadata": {},
   "outputs": [],
   "source": [
    "import tensorflow as tf"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "9356cd9b-6f79-45f1-8f2e-c46a526c4ae7",
   "metadata": {},
   "source": [
    "### lip-dp dependencies\n",
    "\n",
    "The need a model `DP_Model` that handles the noisification of gradients. It is trained with a `loss`. The model is initialized with the convenience function `DPParameters`. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "1e5d58f8-386c-44c7-8c5d-e5b69b5be231",
   "metadata": {},
   "outputs": [],
   "source": [
    "from lipdp import losses\n",
    "from lipdp.model import DP_Model\n",
    "from lipdp.model import DPParameters"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "3a247cd3-48d6-4854-92df-01420d3bea80",
   "metadata": {},
   "source": [
    "The `DP_Accountant` callback keeps track of $(\\epsilon,\\delta)$-DP values epoch after epoch. In practice we may be interested in reaching the maximum val_accuracy under privacy constraint $\\epsilon$: the convenience function `get_max_epochs` exactly does that by performing a dichotomy search over the number of epochs."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "950c5c56-4b34-4653-aaf3-7d97acc1f5f2",
   "metadata": {},
   "outputs": [],
   "source": [
    "from lipdp.model import DP_Accountant\n",
    "from lipdp.sensitivity import get_max_epochs"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "893d3078-5166-428c-9cb1-d29ec1f05d71",
   "metadata": {},
   "source": [
    "The framework requires a control of the maximum norm of inputs. This can be ensured with input clipping for example: `bound_clip_value`."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f395c9fc-b67d-4fd2-be4b-b1c43221ebcb",
   "metadata": {},
   "outputs": [],
   "source": [
    "from lipdp.pipeline import bound_clip_value\n",
    "from lipdp.pipeline import load_and_prepare_data"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "e54a79db-24b4-4dae-b684-170fa743bc5d",
   "metadata": {},
   "source": [
    "## Setup DP Lipschitz model\n",
    "\n",
    "Here we apply the \"global\" strategy, with a noise multiplier $2.5$. Note that for Cifar-10 the dataset size is $N=50,000$, and it is recommended that $\\delta<\\frac{1}{N}$. So we propose a value of $\\delta=10^{-5}$.  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "f79ea3b0-33a6-401c-a3a3-e314939fd269",
   "metadata": {},
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "dp_parameters = DPParameters(\n",
    "    noisify_strategy=\"global\",\n",
    "    noise_multiplier=4.0,\n",
    "    delta=1e-5,\n",
    ")\n",
    "\n",
    "epsilon_max = 10.0"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ba392eec-4451-49e5-bd45-883af7aa2d40",
   "metadata": {},
   "source": [
    "With many parameters, it can be interesting to use `local` strategy over `global`, since the effective noise growths as $\\mathcal{O}(\\sqrt{(D)})$ in `global` strategy. Since the privacy leakge is more important is `local` strategy, we compensate with high `noise_multiplier`.\n",
    "\n",
    "![DP-SGD accountant](fig_accountant.png \"DP-SGD accountant\")"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "6482128c-ac2e-4cdd-9bbd-6d3172c292b1",
   "metadata": {},
   "source": [
    "### Loading the data\n",
    "\n",
    "We clip the elementwise input upper-bound to $40.0$. The operates in `HSV` space. The train set is augmented with random left/right flips."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "a8ed0fc4-4655-4bad-a6ac-8697cd5bc7a6",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2023-05-24 17:27:24.335576: I tensorflow/core/platform/cpu_feature_guard.cc:151] This TensorFlow binary is optimized with oneAPI Deep Neural Network Library (oneDNN) to use the following CPU instructions in performance-critical operations:  AVX2 FMA\n",
      "To enable them in other operations, rebuild TensorFlow with the appropriate compiler flags.\n",
      "2023-05-24 17:27:24.905888: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1525] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 47066 MB memory:  -> device: 0, name: Quadro RTX 8000, pci bus id: 0000:03:00.0, compute capability: 7.5\n"
     ]
    }
   ],
   "source": [
    "def augmentation_fct(image, label):\n",
    "    image = tf.image.random_flip_left_right(image)\n",
    "    return image, label\n",
    "\n",
    "input_upper_bound = 30.0\n",
    "ds_train, ds_test, dataset_metadata = load_and_prepare_data(\n",
    "    \"cifar10\",\n",
    "    colorspace=\"HSV\",\n",
    "    batch_size=10_000,\n",
    "    drop_remainder=True,  # accounting assumes fixed batch size\n",
    "    augmentation_fct=augmentation_fct,\n",
    "    bound_fct=bound_clip_value(  # other strategies are possible, like normalization.\n",
    "        input_upper_bound\n",
    "    ),  # clipping preprocessing allows to control input bound\n",
    ")"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "eb356c04-a836-4f49-93d7-7e0cc4c12b1d",
   "metadata": {},
   "source": [
    "### Build the MLP Mixer model\n",
    "\n",
    "We imitate the interface of Keras. We use common layers found in deel-lip, which a wrapper that handles the bound propagation. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "be32d5d7-efc7-4cc6-91bc-1a2b9bedddca",
   "metadata": {},
   "outputs": [],
   "source": [
    "from lipdp.layers import DP_AddBias\n",
    "from lipdp.layers import DP_BoundedInput\n",
    "from lipdp.layers import DP_ClipGradient\n",
    "from lipdp.layers import DP_Flatten\n",
    "from lipdp.layers import DP_GroupSort\n",
    "from lipdp.layers import DP_Lambda\n",
    "from lipdp.layers import DP_LayerCentering\n",
    "from lipdp.layers import DP_Permute\n",
    "from lipdp.layers import DP_QuickSpectralDense\n",
    "from lipdp.layers import DP_Reshape\n",
    "from lipdp.layers import DP_ScaledGlobalL2NormPooling2D\n",
    "from lipdp.layers import DP_ScaledL2NormPooling2D\n",
    "from lipdp.layers import DP_QuickSpectralConv2D"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "15b21796-b8e7-41d3-8718-0efdb5d92179",
   "metadata": {},
   "source": [
    "The MLP Mixer uses residual connections. Residuals connections are handled with the utility function `make_residuals` that wraps the layers inside a block that handles bounds propagation.\n",
    "\n",
    "![Residuals Connections](residuals.png \"Residual Connections\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "0590e72d-ce2e-48c1-a8ae-e86ecd32b524",
   "metadata": {},
   "outputs": [],
   "source": [
    "from lipdp.layers import make_residuals"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9d75f692-c66d-4318-a915-f16707ed87fa",
   "metadata": {},
   "source": [
    "Now, we proceed with the creation of the environnement."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "30cf44ed-653b-4eaa-8ed9-26e4815db511",
   "metadata": {},
   "outputs": [],
   "source": [
    "skip_connections = False  # use skip connections, like in original MLP Mixer architecture.\n",
    "clip_loss_gradient = 2**0.5  # elementwise gradient is clipped to value sqrt(2) - which is the maximum for CCE loss.\n",
    "add_biases = False  # Add biases after linear transformations.\n",
    "biases_norm_max = 0.05\n",
    "hidden_size = 64\n",
    "mlp_seq_dim = 64\n",
    "mlp_channel_dim = 128\n",
    "num_mixer_layers = 2  # Two MLP Mixer blocks.\n",
    "layer_centering = False  # Centering operation (like LayerNormalization without the reducing operation). Linear 1-Lipschitz.\n",
    "patch_size = 4  # Number of pixels in each patch.\n",
    "\n",
    "def create_MLP_Mixer(dp_parameters, dataset_metadata, upper_bound):\n",
    "    input_shape = (32, 32, 3)\n",
    "    layers = [DP_BoundedInput(input_shape=input_shape, upper_bound=upper_bound)]\n",
    "\n",
    "    layers.append(\n",
    "        DP_Lambda(\n",
    "            tf.image.extract_patches,\n",
    "            arguments=dict(\n",
    "                sizes=[1, patch_size, patch_size, 1],\n",
    "                strides=[1, patch_size, patch_size, 1],\n",
    "                rates=[1, 1, 1, 1],\n",
    "                padding=\"VALID\",\n",
    "            ),\n",
    "        )\n",
    "    )\n",
    "\n",
    "    seq_len = (input_shape[0] // patch_size) * (input_shape[1] // patch_size)\n",
    "\n",
    "    layers.append(DP_Reshape((seq_len, (patch_size ** 2) * input_shape[-1])))\n",
    "    layers.append(\n",
    "        DP_QuickSpectralDense(\n",
    "            units=hidden_size, use_bias=False, kernel_initializer=\"identity\"\n",
    "        )\n",
    "    )\n",
    "\n",
    "    for _ in range(num_mixer_layers):\n",
    "        to_add = [\n",
    "            DP_Permute((2, 1)),\n",
    "            DP_QuickSpectralDense(\n",
    "                units=mlp_seq_dim, use_bias=False, kernel_initializer=\"identity\"\n",
    "            ),\n",
    "        ]\n",
    "        if add_biases:\n",
    "            to_add.append(DP_AddBias(biases_norm_max))\n",
    "        to_add.append(DP_GroupSort(2))\n",
    "        if layer_centering:\n",
    "            to_add.append(DP_LayerCentering())\n",
    "        to_add += [\n",
    "            DP_QuickSpectralDense(\n",
    "                units=seq_len, use_bias=False, kernel_initializer=\"identity\"\n",
    "            ),\n",
    "            DP_Permute((2, 1)),\n",
    "        ]\n",
    "\n",
    "        if skip_connections:\n",
    "            layers += make_residuals(\"1-lip-add\", to_add)\n",
    "        else:\n",
    "            layers += to_add\n",
    "\n",
    "        to_add = [\n",
    "            DP_QuickSpectralDense(\n",
    "                units=mlp_channel_dim, use_bias=False, kernel_initializer=\"identity\"\n",
    "            ),\n",
    "        ]\n",
    "        if add_biases:\n",
    "            to_add.append(DP_AddBias(biases_norm_max))\n",
    "        to_add.append(DP_GroupSort(2))\n",
    "        if layer_centering:\n",
    "            to_add.append(DP_LayerCentering())\n",
    "        to_add.append(\n",
    "            DP_QuickSpectralDense(\n",
    "                units=hidden_size, use_bias=False, kernel_initializer=\"identity\"\n",
    "            )\n",
    "        )\n",
    "\n",
    "        if skip_connections:\n",
    "            layers += make_residuals(\"1-lip-add\", to_add)\n",
    "        else:\n",
    "            layers += to_add\n",
    "\n",
    "    layers.append(DP_Flatten())\n",
    "    layers.append(\n",
    "        DP_QuickSpectralDense(units=10, use_bias=False, kernel_initializer=\"identity\")\n",
    "    )\n",
    "\n",
    "    layers.append(DP_ClipGradient(clip_loss_gradient))\n",
    "\n",
    "    model = DP_Model(\n",
    "        layers,\n",
    "        dp_parameters=dp_parameters,\n",
    "        dataset_metadata=dataset_metadata,\n",
    "        name=\"mlp_mixer\",\n",
    "    )\n",
    "\n",
    "    model.build(input_shape=(None, *input_shape))\n",
    "\n",
    "    return model"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "09777811",
   "metadata": {},
   "source": [
    "We compile the model with:\n",
    "* any first order optimizer (e.g Adam). No adaptation is needed.\n",
    "* a loss with known Lipschitz constant, e.g Categorical Cross-entropy with temperature."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "efd97e75-34f0-49fa-ad2c-1816247f1611",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"mlp_mixer\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " dp__bounded_input (DP_Bound  multiple                 0         \n",
      " edInput)                                                        \n",
      "                                                                 \n",
      " dp__lambda (DP_Lambda)      multiple                  0         \n",
      "                                                                 \n",
      " dp__reshape (DP_Reshape)    multiple                  0         \n",
      "                                                                 \n",
      " dp__quick_spectral_dense (D  multiple                 3072      \n",
      " P_QuickSpectralDense)                                           \n",
      "                                                                 \n",
      " dp__permute (DP_Permute)    multiple                  0         \n",
      "                                                                 \n",
      " dp__quick_spectral_dense_1   multiple                 4096      \n",
      " (DP_QuickSpectralDense)                                         \n",
      "                                                                 \n",
      " dp__group_sort (DP_GroupSor  multiple                 0         \n",
      " t)                                                              \n",
      "                                                                 \n",
      " dp__quick_spectral_dense_2   multiple                 4096      \n",
      " (DP_QuickSpectralDense)                                         \n",
      "                                                                 \n",
      " dp__permute_1 (DP_Permute)  multiple                  0         \n",
      "                                                                 \n",
      " dp__quick_spectral_dense_3   multiple                 8192      \n",
      " (DP_QuickSpectralDense)                                         \n",
      "                                                                 \n",
      " dp__group_sort_1 (DP_GroupS  multiple                 0         \n",
      " ort)                                                            \n",
      "                                                                 \n",
      " dp__quick_spectral_dense_4   multiple                 8192      \n",
      " (DP_QuickSpectralDense)                                         \n",
      "                                                                 \n",
      " dp__permute_2 (DP_Permute)  multiple                  0         \n",
      "                                                                 \n",
      " dp__quick_spectral_dense_5   multiple                 4096      \n",
      " (DP_QuickSpectralDense)                                         \n",
      "                                                                 \n",
      " dp__group_sort_2 (DP_GroupS  multiple                 0         \n",
      " ort)                                                            \n",
      "                                                                 \n",
      " dp__quick_spectral_dense_6   multiple                 4096      \n",
      " (DP_QuickSpectralDense)                                         \n",
      "                                                                 \n",
      " dp__permute_3 (DP_Permute)  multiple                  0         \n",
      "                                                                 \n",
      " dp__quick_spectral_dense_7   multiple                 8192      \n",
      " (DP_QuickSpectralDense)                                         \n",
      "                                                                 \n",
      " dp__group_sort_3 (DP_GroupS  multiple                 0         \n",
      " ort)                                                            \n",
      "                                                                 \n",
      " dp__quick_spectral_dense_8   multiple                 8192      \n",
      " (DP_QuickSpectralDense)                                         \n",
      "                                                                 \n",
      " dp__flatten (DP_Flatten)    multiple                  0         \n",
      "                                                                 \n",
      " dp__quick_spectral_dense_9   multiple                 40960     \n",
      " (DP_QuickSpectralDense)                                         \n",
      "                                                                 \n",
      " dp__clip_gradient (DP_ClipG  multiple                 0         \n",
      " radient)                                                        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 93,184\n",
      "Trainable params: 93,184\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n"
     ]
    }
   ],
   "source": [
    "model = create_MLP_Mixer(dp_parameters, dataset_metadata, input_upper_bound)\n",
    "model.compile(\n",
    "    # Compile model using DP loss\n",
    "    loss=losses.DP_TauCategoricalCrossentropy(256.0),\n",
    "    # this method is compatible with any first order optimizer\n",
    "    optimizer=tf.keras.optimizers.Adam(learning_rate=2e-4),\n",
    "    metrics=[\"accuracy\"],\n",
    ")\n",
    "model.summary()"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "28ae2da5-ed40-4131-8721-73bbc73fa68d",
   "metadata": {},
   "source": [
    "Observe that the model contains only 246K parmaeters. This is an advantage of MLP Mixer architectures: the number of parameters is small. However the number of FLOPS can be quite high. Without gradient clipping, huge batch sizes can be used, which benefits to privacy/utility ratio. \n",
    "\n",
    "In order to control epsilon, we compute the adequate number of epochs."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "dd611afd-be30-4bd3-b658-48d1961247aa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "epoch bounds = (0, 512.0) and epsilon = 14.81894855578722 at epoch 512.0\n",
      "epoch bounds = (256.0, 512.0) and epsilon = 9.820083418023108 at epoch 256.0\n",
      "epoch bounds = (256.0, 384.0) and epsilon = 12.31951600358698 at epoch 384.0\n",
      "epoch bounds = (256.0, 320.0) and epsilon = 11.069799714608529 at epoch 320.0\n",
      "epoch bounds = (256.0, 288.0) and epsilon = 10.44494156631582 at epoch 288.0\n",
      "epoch bounds = (256.0, 272.0) and epsilon = 10.132512492169463 at epoch 272.0\n",
      "epoch bounds = (264.0, 272.0) and epsilon = 9.976297955096285 at epoch 264.0\n",
      "epoch bounds = (264.0, 268.0) and epsilon = 10.054405223632873 at epoch 268.0\n",
      "epoch bounds = (264.0, 266.0) and epsilon = 10.015351589364581 at epoch 266.0\n",
      "epoch bounds = (265.0, 266.0) and epsilon = 9.995824772230431 at epoch 265.0\n"
     ]
    }
   ],
   "source": [
    "num_epochs = get_max_epochs(epsilon_max, model)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "53e94244",
   "metadata": {},
   "source": [
    "## Train the model\n",
    "\n",
    "The model can be trained, and the DP Accountant will automatically track the privacy loss."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "0ddcb192-547e-400e-87bb-2d4246185c64",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.1751 - accuracy: 0.1077\n",
      " (0.5205893807331654, 1e-05)-DP guarantees for epoch 1 \n",
      "\n",
      "5/5 [==============================] - 8s 547ms/step - loss: 0.1751 - accuracy: 0.1077 - val_loss: 0.1409 - val_accuracy: 0.1045\n",
      "Epoch 2/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.1243 - accuracy: 0.1061\n",
      " (0.7169615437758403, 1e-05)-DP guarantees for epoch 2 \n",
      "\n",
      "5/5 [==============================] - 3s 451ms/step - loss: 0.1243 - accuracy: 0.1061 - val_loss: 0.1145 - val_accuracy: 0.1055\n",
      "Epoch 3/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.1124 - accuracy: 0.1170\n",
      " (0.8714581783028138, 1e-05)-DP guarantees for epoch 3 \n",
      "\n",
      "5/5 [==============================] - 3s 386ms/step - loss: 0.1124 - accuracy: 0.1170 - val_loss: 0.1095 - val_accuracy: 0.1124\n",
      "Epoch 4/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.1051 - accuracy: 0.1178\n",
      " (1.0041033056975341, 1e-05)-DP guarantees for epoch 4 \n",
      "\n",
      "5/5 [==============================] - 3s 416ms/step - loss: 0.1051 - accuracy: 0.1178 - val_loss: 0.1019 - val_accuracy: 0.1173\n",
      "Epoch 5/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0994 - accuracy: 0.1219\n",
      " (1.121902451763874, 1e-05)-DP guarantees for epoch 5 \n",
      "\n",
      "5/5 [==============================] - 3s 404ms/step - loss: 0.0994 - accuracy: 0.1219 - val_loss: 0.0973 - val_accuracy: 0.1199\n",
      "Epoch 6/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0950 - accuracy: 0.1287\n",
      " (1.2297900098052366, 1e-05)-DP guarantees for epoch 6 \n",
      "\n",
      "5/5 [==============================] - 3s 372ms/step - loss: 0.0950 - accuracy: 0.1287 - val_loss: 0.0952 - val_accuracy: 0.1274\n",
      "Epoch 7/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0927 - accuracy: 0.1332\n",
      " (1.3301791512711914, 1e-05)-DP guarantees for epoch 7 \n",
      "\n",
      "5/5 [==============================] - 2s 355ms/step - loss: 0.0927 - accuracy: 0.1332 - val_loss: 0.0917 - val_accuracy: 0.1319\n",
      "Epoch 8/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0896 - accuracy: 0.1396\n",
      " (1.425115891691246, 1e-05)-DP guarantees for epoch 8 \n",
      "\n",
      "5/5 [==============================] - 3s 360ms/step - loss: 0.0896 - accuracy: 0.1396 - val_loss: 0.0898 - val_accuracy: 0.1348\n",
      "Epoch 9/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0878 - accuracy: 0.1423\n",
      " (1.512644960027369, 1e-05)-DP guarantees for epoch 9 \n",
      "\n",
      "5/5 [==============================] - 2s 367ms/step - loss: 0.0878 - accuracy: 0.1423 - val_loss: 0.0876 - val_accuracy: 0.1386\n",
      "Epoch 10/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0857 - accuracy: 0.1461\n",
      " (1.599192443478913, 1e-05)-DP guarantees for epoch 10 \n",
      "\n",
      "5/5 [==============================] - 3s 359ms/step - loss: 0.0857 - accuracy: 0.1461 - val_loss: 0.0859 - val_accuracy: 0.1469\n",
      "Epoch 11/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0840 - accuracy: 0.1543\n",
      " (1.6782666312983627, 1e-05)-DP guarantees for epoch 11 \n",
      "\n",
      "5/5 [==============================] - 3s 353ms/step - loss: 0.0840 - accuracy: 0.1543 - val_loss: 0.0844 - val_accuracy: 0.1497\n",
      "Epoch 12/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0829 - accuracy: 0.1556\n",
      " (1.7566369758486253, 1e-05)-DP guarantees for epoch 12 \n",
      "\n",
      "5/5 [==============================] - 3s 358ms/step - loss: 0.0829 - accuracy: 0.1556 - val_loss: 0.0829 - val_accuracy: 0.1516\n",
      "Epoch 13/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0816 - accuracy: 0.1578\n",
      " (1.833150779023074, 1e-05)-DP guarantees for epoch 13 \n",
      "\n",
      "5/5 [==============================] - 3s 367ms/step - loss: 0.0816 - accuracy: 0.1578 - val_loss: 0.0819 - val_accuracy: 0.1565\n",
      "Epoch 14/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0806 - accuracy: 0.1618\n",
      " (1.903546174784228, 1e-05)-DP guarantees for epoch 14 \n",
      "\n",
      "5/5 [==============================] - 3s 370ms/step - loss: 0.0806 - accuracy: 0.1618 - val_loss: 0.0809 - val_accuracy: 0.1592\n",
      "Epoch 15/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0794 - accuracy: 0.1657\n",
      " (1.9739415712927695, 1e-05)-DP guarantees for epoch 15 \n",
      "\n",
      "5/5 [==============================] - 3s 353ms/step - loss: 0.0794 - accuracy: 0.1657 - val_loss: 0.0799 - val_accuracy: 0.1614\n",
      "Epoch 16/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0788 - accuracy: 0.1654\n",
      " (2.044336966003477, 1e-05)-DP guarantees for epoch 16 \n",
      "\n",
      "5/5 [==============================] - 2s 358ms/step - loss: 0.0788 - accuracy: 0.1654 - val_loss: 0.0791 - val_accuracy: 0.1642\n",
      "Epoch 17/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0778 - accuracy: 0.1696\n",
      " (2.111107170532668, 1e-05)-DP guarantees for epoch 17 \n",
      "\n",
      "5/5 [==============================] - 3s 373ms/step - loss: 0.0778 - accuracy: 0.1696 - val_loss: 0.0783 - val_accuracy: 0.1667\n",
      "Epoch 18/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0773 - accuracy: 0.1720\n",
      " (2.173720558035018, 1e-05)-DP guarantees for epoch 18 \n",
      "\n",
      "5/5 [==============================] - 3s 355ms/step - loss: 0.0773 - accuracy: 0.1720 - val_loss: 0.0775 - val_accuracy: 0.1713\n",
      "Epoch 19/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0765 - accuracy: 0.1745\n",
      " (2.236333946199693, 1e-05)-DP guarantees for epoch 19 \n",
      "\n",
      "5/5 [==============================] - 3s 357ms/step - loss: 0.0765 - accuracy: 0.1745 - val_loss: 0.0768 - val_accuracy: 0.1718\n",
      "Epoch 20/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0755 - accuracy: 0.1785\n",
      " (2.298947335447459, 1e-05)-DP guarantees for epoch 20 \n",
      "\n",
      "5/5 [==============================] - 3s 351ms/step - loss: 0.0755 - accuracy: 0.1785 - val_loss: 0.0761 - val_accuracy: 0.1749\n",
      "Epoch 21/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0751 - accuracy: 0.1809\n",
      " (2.3615607218535017, 1e-05)-DP guarantees for epoch 21 \n",
      "\n",
      "5/5 [==============================] - 2s 370ms/step - loss: 0.0751 - accuracy: 0.1809 - val_loss: 0.0755 - val_accuracy: 0.1779\n",
      "Epoch 22/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0744 - accuracy: 0.1807\n",
      " (2.424031214499055, 1e-05)-DP guarantees for epoch 22 \n",
      "\n",
      "5/5 [==============================] - 3s 359ms/step - loss: 0.0744 - accuracy: 0.1807 - val_loss: 0.0749 - val_accuracy: 0.1782\n",
      "Epoch 23/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0737 - accuracy: 0.1829\n",
      " (2.4794700865598074, 1e-05)-DP guarantees for epoch 23 \n",
      "\n",
      "5/5 [==============================] - 2s 353ms/step - loss: 0.0737 - accuracy: 0.1829 - val_loss: 0.0744 - val_accuracy: 0.1796\n",
      "Epoch 24/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0735 - accuracy: 0.1836\n",
      " (2.5344857802909178, 1e-05)-DP guarantees for epoch 24 \n",
      "\n",
      "5/5 [==============================] - 2s 353ms/step - loss: 0.0735 - accuracy: 0.1836 - val_loss: 0.0738 - val_accuracy: 0.1815\n",
      "Epoch 25/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0730 - accuracy: 0.1853\n",
      " (2.589501472054093, 1e-05)-DP guarantees for epoch 25 \n",
      "\n",
      "5/5 [==============================] - 3s 371ms/step - loss: 0.0730 - accuracy: 0.1853 - val_loss: 0.0733 - val_accuracy: 0.1836\n",
      "Epoch 26/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0726 - accuracy: 0.1884\n",
      " (2.6445171621630954, 1e-05)-DP guarantees for epoch 26 \n",
      "\n",
      "5/5 [==============================] - 3s 356ms/step - loss: 0.0726 - accuracy: 0.1884 - val_loss: 0.0729 - val_accuracy: 0.1857\n",
      "Epoch 27/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0722 - accuracy: 0.1881\n",
      " (2.699532854747239, 1e-05)-DP guarantees for epoch 27 \n",
      "\n",
      "5/5 [==============================] - 2s 349ms/step - loss: 0.0722 - accuracy: 0.1881 - val_loss: 0.0723 - val_accuracy: 0.1882\n",
      "Epoch 28/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0715 - accuracy: 0.1901\n",
      " (2.754548546420506, 1e-05)-DP guarantees for epoch 28 \n",
      "\n",
      "5/5 [==============================] - 3s 371ms/step - loss: 0.0715 - accuracy: 0.1901 - val_loss: 0.0718 - val_accuracy: 0.1879\n",
      "Epoch 29/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0711 - accuracy: 0.1928\n",
      " (2.809564239271509, 1e-05)-DP guarantees for epoch 29 \n",
      "\n",
      "5/5 [==============================] - 3s 360ms/step - loss: 0.0711 - accuracy: 0.1928 - val_loss: 0.0715 - val_accuracy: 0.1915\n",
      "Epoch 30/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0710 - accuracy: 0.1933\n",
      " (2.8645799306976425, 1e-05)-DP guarantees for epoch 30 \n",
      "\n",
      "5/5 [==============================] - 2s 362ms/step - loss: 0.0710 - accuracy: 0.1933 - val_loss: 0.0710 - val_accuracy: 0.1922\n",
      "Epoch 31/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0701 - accuracy: 0.1993\n",
      " (2.915773408283026, 1e-05)-DP guarantees for epoch 31 \n",
      "\n",
      "5/5 [==============================] - 2s 352ms/step - loss: 0.0701 - accuracy: 0.1993 - val_loss: 0.0706 - val_accuracy: 0.1940\n",
      "Epoch 32/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0698 - accuracy: 0.1996\n",
      " (2.9633676512735834, 1e-05)-DP guarantees for epoch 32 \n",
      "\n",
      "5/5 [==============================] - 2s 355ms/step - loss: 0.0698 - accuracy: 0.1996 - val_loss: 0.0702 - val_accuracy: 0.1964\n",
      "Epoch 33/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0695 - accuracy: 0.2004\n",
      " (3.010961895901816, 1e-05)-DP guarantees for epoch 33 \n",
      "\n",
      "5/5 [==============================] - 3s 375ms/step - loss: 0.0695 - accuracy: 0.2004 - val_loss: 0.0699 - val_accuracy: 0.1984\n",
      "Epoch 34/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0692 - accuracy: 0.1995\n",
      " (3.0585561401091397, 1e-05)-DP guarantees for epoch 34 \n",
      "\n",
      "5/5 [==============================] - 3s 352ms/step - loss: 0.0692 - accuracy: 0.1995 - val_loss: 0.0696 - val_accuracy: 0.1975\n",
      "Epoch 35/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0685 - accuracy: 0.2045\n",
      " (3.1061503817189315, 1e-05)-DP guarantees for epoch 35 \n",
      "\n",
      "5/5 [==============================] - 3s 349ms/step - loss: 0.0685 - accuracy: 0.2045 - val_loss: 0.0692 - val_accuracy: 0.2009\n",
      "Epoch 36/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0686 - accuracy: 0.2045\n",
      " (3.1537446235861095, 1e-05)-DP guarantees for epoch 36 \n",
      "\n",
      "5/5 [==============================] - 3s 364ms/step - loss: 0.0686 - accuracy: 0.2045 - val_loss: 0.0689 - val_accuracy: 0.2032\n",
      "Epoch 37/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0684 - accuracy: 0.2033\n",
      " (3.2013388677062005, 1e-05)-DP guarantees for epoch 37 \n",
      "\n",
      "5/5 [==============================] - 2s 349ms/step - loss: 0.0684 - accuracy: 0.2033 - val_loss: 0.0686 - val_accuracy: 0.2033\n",
      "Epoch 38/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0684 - accuracy: 0.2024\n",
      " (3.2489331117939875, 1e-05)-DP guarantees for epoch 38 \n",
      "\n",
      "5/5 [==============================] - 3s 352ms/step - loss: 0.0684 - accuracy: 0.2024 - val_loss: 0.0683 - val_accuracy: 0.2046\n",
      "Epoch 39/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0675 - accuracy: 0.2064\n",
      " (3.296527354122463, 1e-05)-DP guarantees for epoch 39 \n",
      "\n",
      "5/5 [==============================] - 3s 390ms/step - loss: 0.0675 - accuracy: 0.2064 - val_loss: 0.0681 - val_accuracy: 0.2055\n",
      "Epoch 40/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0678 - accuracy: 0.2071\n",
      " (3.3441215974412257, 1e-05)-DP guarantees for epoch 40 \n",
      "\n",
      "5/5 [==============================] - 2s 343ms/step - loss: 0.0678 - accuracy: 0.2071 - val_loss: 0.0679 - val_accuracy: 0.2061\n",
      "Epoch 41/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0670 - accuracy: 0.2076\n",
      " (3.391715841019588, 1e-05)-DP guarantees for epoch 41 \n",
      "\n",
      "5/5 [==============================] - 2s 348ms/step - loss: 0.0670 - accuracy: 0.2076 - val_loss: 0.0676 - val_accuracy: 0.2047\n",
      "Epoch 42/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0670 - accuracy: 0.2074\n",
      " (3.4393100820764655, 1e-05)-DP guarantees for epoch 42 \n",
      "\n",
      "5/5 [==============================] - 3s 362ms/step - loss: 0.0670 - accuracy: 0.2074 - val_loss: 0.0673 - val_accuracy: 0.2077\n",
      "Epoch 43/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0668 - accuracy: 0.2091\n",
      " (3.4869043257012042, 1e-05)-DP guarantees for epoch 43 \n",
      "\n",
      "5/5 [==============================] - 3s 365ms/step - loss: 0.0668 - accuracy: 0.2091 - val_loss: 0.0671 - val_accuracy: 0.2098\n",
      "Epoch 44/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0664 - accuracy: 0.2133\n",
      " (3.5344943006583662, 1e-05)-DP guarantees for epoch 44 \n",
      "\n",
      "5/5 [==============================] - 2s 353ms/step - loss: 0.0664 - accuracy: 0.2133 - val_loss: 0.0668 - val_accuracy: 0.2111\n",
      "Epoch 45/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0662 - accuracy: 0.2116\n",
      " (3.577278802435221, 1e-05)-DP guarantees for epoch 45 \n",
      "\n",
      "5/5 [==============================] - 3s 368ms/step - loss: 0.0662 - accuracy: 0.2116 - val_loss: 0.0666 - val_accuracy: 0.2110\n",
      "Epoch 46/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0658 - accuracy: 0.2144\n",
      " (3.6176202954309518, 1e-05)-DP guarantees for epoch 46 \n",
      "\n",
      "5/5 [==============================] - 3s 363ms/step - loss: 0.0658 - accuracy: 0.2144 - val_loss: 0.0663 - val_accuracy: 0.2136\n",
      "Epoch 47/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0660 - accuracy: 0.2136\n",
      " (3.6579617884266824, 1e-05)-DP guarantees for epoch 47 \n",
      "\n",
      "5/5 [==============================] - 3s 361ms/step - loss: 0.0660 - accuracy: 0.2136 - val_loss: 0.0662 - val_accuracy: 0.2103\n",
      "Epoch 48/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0658 - accuracy: 0.2124\n",
      " (3.698303280878773, 1e-05)-DP guarantees for epoch 48 \n",
      "\n",
      "5/5 [==============================] - 3s 378ms/step - loss: 0.0658 - accuracy: 0.2124 - val_loss: 0.0660 - val_accuracy: 0.2126\n",
      "Epoch 49/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0651 - accuracy: 0.2170\n",
      " (3.7386447748463074, 1e-05)-DP guarantees for epoch 49 \n",
      "\n",
      "5/5 [==============================] - 3s 356ms/step - loss: 0.0651 - accuracy: 0.2170 - val_loss: 0.0658 - val_accuracy: 0.2141\n",
      "Epoch 50/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0650 - accuracy: 0.2147\n",
      " (3.778986264959221, 1e-05)-DP guarantees for epoch 50 \n",
      "\n",
      "5/5 [==============================] - 2s 359ms/step - loss: 0.0650 - accuracy: 0.2147 - val_loss: 0.0657 - val_accuracy: 0.2139\n",
      "Epoch 51/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0649 - accuracy: 0.2157\n",
      " (3.819327759198358, 1e-05)-DP guarantees for epoch 51 \n",
      "\n",
      "5/5 [==============================] - 3s 362ms/step - loss: 0.0649 - accuracy: 0.2157 - val_loss: 0.0654 - val_accuracy: 0.2154\n",
      "Epoch 52/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0646 - accuracy: 0.2177\n",
      " (3.859669252353283, 1e-05)-DP guarantees for epoch 52 \n",
      "\n",
      "5/5 [==============================] - 3s 374ms/step - loss: 0.0646 - accuracy: 0.2177 - val_loss: 0.0652 - val_accuracy: 0.2159\n",
      "Epoch 53/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0647 - accuracy: 0.2164\n",
      " (3.900010744909916, 1e-05)-DP guarantees for epoch 53 \n",
      "\n",
      "5/5 [==============================] - 3s 398ms/step - loss: 0.0647 - accuracy: 0.2164 - val_loss: 0.0651 - val_accuracy: 0.2139\n",
      "Epoch 54/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0642 - accuracy: 0.2180\n",
      " (3.9403522382284417, 1e-05)-DP guarantees for epoch 54 \n",
      "\n",
      "5/5 [==============================] - 2s 356ms/step - loss: 0.0642 - accuracy: 0.2180 - val_loss: 0.0649 - val_accuracy: 0.2165\n",
      "Epoch 55/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0643 - accuracy: 0.2178\n",
      " (3.9806937272852823, 1e-05)-DP guarantees for epoch 55 \n",
      "\n",
      "5/5 [==============================] - 3s 385ms/step - loss: 0.0643 - accuracy: 0.2178 - val_loss: 0.0648 - val_accuracy: 0.2190\n",
      "Epoch 56/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0642 - accuracy: 0.2194\n",
      " (4.021035219696142, 1e-05)-DP guarantees for epoch 56 \n",
      "\n",
      "5/5 [==============================] - 3s 358ms/step - loss: 0.0642 - accuracy: 0.2194 - val_loss: 0.0646 - val_accuracy: 0.2190\n",
      "Epoch 57/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0641 - accuracy: 0.2193\n",
      " (4.061376713362479, 1e-05)-DP guarantees for epoch 57 \n",
      "\n",
      "5/5 [==============================] - 3s 357ms/step - loss: 0.0641 - accuracy: 0.2193 - val_loss: 0.0644 - val_accuracy: 0.2188\n",
      "Epoch 58/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0637 - accuracy: 0.2209\n",
      " (4.101718205195644, 1e-05)-DP guarantees for epoch 58 \n",
      "\n",
      "5/5 [==============================] - 3s 389ms/step - loss: 0.0637 - accuracy: 0.2209 - val_loss: 0.0643 - val_accuracy: 0.2203\n",
      "Epoch 59/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0636 - accuracy: 0.2207\n",
      " (4.142059698567775, 1e-05)-DP guarantees for epoch 59 \n",
      "\n",
      "5/5 [==============================] - 2s 350ms/step - loss: 0.0636 - accuracy: 0.2207 - val_loss: 0.0641 - val_accuracy: 0.2217\n",
      "Epoch 60/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0631 - accuracy: 0.2238\n",
      " (4.182401188996273, 1e-05)-DP guarantees for epoch 60 \n",
      "\n",
      "5/5 [==============================] - 2s 350ms/step - loss: 0.0631 - accuracy: 0.2238 - val_loss: 0.0639 - val_accuracy: 0.2218\n",
      "Epoch 61/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0635 - accuracy: 0.2223\n",
      " (4.222742681534986, 1e-05)-DP guarantees for epoch 61 \n",
      "\n",
      "5/5 [==============================] - 3s 357ms/step - loss: 0.0635 - accuracy: 0.2223 - val_loss: 0.0638 - val_accuracy: 0.2214\n",
      "Epoch 62/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0628 - accuracy: 0.2212\n",
      " (4.263084178169554, 1e-05)-DP guarantees for epoch 62 \n",
      "\n",
      "5/5 [==============================] - 3s 358ms/step - loss: 0.0628 - accuracy: 0.2212 - val_loss: 0.0637 - val_accuracy: 0.2214\n",
      "Epoch 63/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0629 - accuracy: 0.2236\n",
      " (4.303425669322495, 1e-05)-DP guarantees for epoch 63 \n",
      "\n",
      "5/5 [==============================] - 3s 357ms/step - loss: 0.0629 - accuracy: 0.2236 - val_loss: 0.0635 - val_accuracy: 0.2238\n",
      "Epoch 64/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0628 - accuracy: 0.2244\n",
      " (4.343767159305043, 1e-05)-DP guarantees for epoch 64 \n",
      "\n",
      "5/5 [==============================] - 2s 357ms/step - loss: 0.0628 - accuracy: 0.2244 - val_loss: 0.0633 - val_accuracy: 0.2229\n",
      "Epoch 65/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0627 - accuracy: 0.2242\n",
      " (4.384108652677016, 1e-05)-DP guarantees for epoch 65 \n",
      "\n",
      "5/5 [==============================] - 3s 375ms/step - loss: 0.0627 - accuracy: 0.2242 - val_loss: 0.0632 - val_accuracy: 0.2232\n",
      "Epoch 66/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0625 - accuracy: 0.2260\n",
      " (4.42445014497077, 1e-05)-DP guarantees for epoch 66 \n",
      "\n",
      "5/5 [==============================] - 2s 344ms/step - loss: 0.0625 - accuracy: 0.2260 - val_loss: 0.0630 - val_accuracy: 0.2248\n",
      "Epoch 67/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0625 - accuracy: 0.2271\n",
      " (4.4647916365799585, 1e-05)-DP guarantees for epoch 67 \n",
      "\n",
      "5/5 [==============================] - 3s 368ms/step - loss: 0.0625 - accuracy: 0.2271 - val_loss: 0.0628 - val_accuracy: 0.2265\n",
      "Epoch 68/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0622 - accuracy: 0.2292\n",
      " (4.505133128586104, 1e-05)-DP guarantees for epoch 68 \n",
      "\n",
      "5/5 [==============================] - 3s 365ms/step - loss: 0.0622 - accuracy: 0.2292 - val_loss: 0.0626 - val_accuracy: 0.2242\n",
      "Epoch 69/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0623 - accuracy: 0.2276\n",
      " (4.544958472325187, 1e-05)-DP guarantees for epoch 69 \n",
      "\n",
      "5/5 [==============================] - 2s 359ms/step - loss: 0.0623 - accuracy: 0.2276 - val_loss: 0.0626 - val_accuracy: 0.2254\n",
      "Epoch 70/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0619 - accuracy: 0.2288\n",
      " (4.580253889044595, 1e-05)-DP guarantees for epoch 70 \n",
      "\n",
      "5/5 [==============================] - 2s 362ms/step - loss: 0.0619 - accuracy: 0.2288 - val_loss: 0.0624 - val_accuracy: 0.2272\n",
      "Epoch 71/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0619 - accuracy: 0.2288\n",
      " (4.613504255128257, 1e-05)-DP guarantees for epoch 71 \n",
      "\n",
      "5/5 [==============================] - 2s 356ms/step - loss: 0.0619 - accuracy: 0.2288 - val_loss: 0.0623 - val_accuracy: 0.2258\n",
      "Epoch 72/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0617 - accuracy: 0.2283\n",
      " (4.646754619793705, 1e-05)-DP guarantees for epoch 72 \n",
      "\n",
      "5/5 [==============================] - 3s 379ms/step - loss: 0.0617 - accuracy: 0.2283 - val_loss: 0.0622 - val_accuracy: 0.2262\n",
      "Epoch 73/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0615 - accuracy: 0.2309\n",
      " (4.680004986868141, 1e-05)-DP guarantees for epoch 73 \n",
      "\n",
      "5/5 [==============================] - 3s 363ms/step - loss: 0.0615 - accuracy: 0.2309 - val_loss: 0.0621 - val_accuracy: 0.2292\n",
      "Epoch 74/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0614 - accuracy: 0.2298\n",
      " (4.713255352027643, 1e-05)-DP guarantees for epoch 74 \n",
      "\n",
      "5/5 [==============================] - 3s 392ms/step - loss: 0.0614 - accuracy: 0.2298 - val_loss: 0.0619 - val_accuracy: 0.2273\n",
      "Epoch 75/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0616 - accuracy: 0.2288\n",
      " (4.746505714565027, 1e-05)-DP guarantees for epoch 75 \n",
      "\n",
      "5/5 [==============================] - 2s 346ms/step - loss: 0.0616 - accuracy: 0.2288 - val_loss: 0.0618 - val_accuracy: 0.2283\n",
      "Epoch 76/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0613 - accuracy: 0.2314\n",
      " (4.779756080992392, 1e-05)-DP guarantees for epoch 76 \n",
      "\n",
      "5/5 [==============================] - 3s 375ms/step - loss: 0.0613 - accuracy: 0.2314 - val_loss: 0.0617 - val_accuracy: 0.2285\n",
      "Epoch 77/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0611 - accuracy: 0.2321\n",
      " (4.813006446042454, 1e-05)-DP guarantees for epoch 77 \n",
      "\n",
      "5/5 [==============================] - 3s 368ms/step - loss: 0.0611 - accuracy: 0.2321 - val_loss: 0.0615 - val_accuracy: 0.2279\n",
      "Epoch 78/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0609 - accuracy: 0.2321\n",
      " (4.84625681135709, 1e-05)-DP guarantees for epoch 78 \n",
      "\n",
      "5/5 [==============================] - 2s 366ms/step - loss: 0.0609 - accuracy: 0.2321 - val_loss: 0.0614 - val_accuracy: 0.2309\n",
      "Epoch 79/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0608 - accuracy: 0.2326\n",
      " (4.879507178851574, 1e-05)-DP guarantees for epoch 79 \n",
      "\n",
      "5/5 [==============================] - 3s 359ms/step - loss: 0.0608 - accuracy: 0.2326 - val_loss: 0.0613 - val_accuracy: 0.2316\n",
      "Epoch 80/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0608 - accuracy: 0.2311\n",
      " (4.912757545677179, 1e-05)-DP guarantees for epoch 80 \n",
      "\n",
      "5/5 [==============================] - 2s 352ms/step - loss: 0.0608 - accuracy: 0.2311 - val_loss: 0.0612 - val_accuracy: 0.2311\n",
      "Epoch 81/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0607 - accuracy: 0.2333\n",
      " (4.9460079085624, 1e-05)-DP guarantees for epoch 81 \n",
      "\n",
      "5/5 [==============================] - 2s 344ms/step - loss: 0.0607 - accuracy: 0.2333 - val_loss: 0.0611 - val_accuracy: 0.2317\n",
      "Epoch 82/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0607 - accuracy: 0.2341\n",
      " (4.979258270989774, 1e-05)-DP guarantees for epoch 82 \n",
      "\n",
      "5/5 [==============================] - 2s 339ms/step - loss: 0.0607 - accuracy: 0.2341 - val_loss: 0.0610 - val_accuracy: 0.2338\n",
      "Epoch 83/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0604 - accuracy: 0.2339\n",
      " (5.012508634818511, 1e-05)-DP guarantees for epoch 83 \n",
      "\n",
      "5/5 [==============================] - 2s 358ms/step - loss: 0.0604 - accuracy: 0.2339 - val_loss: 0.0609 - val_accuracy: 0.2318\n",
      "Epoch 84/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0605 - accuracy: 0.2348\n",
      " (5.045759003430268, 1e-05)-DP guarantees for epoch 84 \n",
      "\n",
      "5/5 [==============================] - 3s 360ms/step - loss: 0.0605 - accuracy: 0.2348 - val_loss: 0.0608 - val_accuracy: 0.2312\n",
      "Epoch 85/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0603 - accuracy: 0.2332\n",
      " (5.0790093680054635, 1e-05)-DP guarantees for epoch 85 \n",
      "\n",
      "5/5 [==============================] - 3s 348ms/step - loss: 0.0603 - accuracy: 0.2332 - val_loss: 0.0607 - val_accuracy: 0.2326\n",
      "Epoch 86/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0600 - accuracy: 0.2355\n",
      " (5.112259736439092, 1e-05)-DP guarantees for epoch 86 \n",
      "\n",
      "5/5 [==============================] - 3s 364ms/step - loss: 0.0600 - accuracy: 0.2355 - val_loss: 0.0606 - val_accuracy: 0.2333\n",
      "Epoch 87/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0600 - accuracy: 0.2357\n",
      " (5.14551009793596, 1e-05)-DP guarantees for epoch 87 \n",
      "\n",
      "5/5 [==============================] - 2s 351ms/step - loss: 0.0600 - accuracy: 0.2357 - val_loss: 0.0604 - val_accuracy: 0.2335\n",
      "Epoch 88/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0598 - accuracy: 0.2397\n",
      " (5.178760460033292, 1e-05)-DP guarantees for epoch 88 \n",
      "\n",
      "5/5 [==============================] - 2s 348ms/step - loss: 0.0598 - accuracy: 0.2397 - val_loss: 0.0603 - val_accuracy: 0.2327\n",
      "Epoch 89/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0596 - accuracy: 0.2377\n",
      " (5.212010824793953, 1e-05)-DP guarantees for epoch 89 \n",
      "\n",
      "5/5 [==============================] - 2s 345ms/step - loss: 0.0596 - accuracy: 0.2377 - val_loss: 0.0602 - val_accuracy: 0.2333\n",
      "Epoch 90/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0597 - accuracy: 0.2372\n",
      " (5.24526119058743, 1e-05)-DP guarantees for epoch 90 \n",
      "\n",
      "5/5 [==============================] - 2s 356ms/step - loss: 0.0597 - accuracy: 0.2372 - val_loss: 0.0601 - val_accuracy: 0.2336\n",
      "Epoch 91/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0595 - accuracy: 0.2367\n",
      " (5.278511560314511, 1e-05)-DP guarantees for epoch 91 \n",
      "\n",
      "5/5 [==============================] - 2s 361ms/step - loss: 0.0595 - accuracy: 0.2367 - val_loss: 0.0600 - val_accuracy: 0.2331\n",
      "Epoch 92/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0598 - accuracy: 0.2373\n",
      " (5.311761920262455, 1e-05)-DP guarantees for epoch 92 \n",
      "\n",
      "5/5 [==============================] - 3s 355ms/step - loss: 0.0598 - accuracy: 0.2373 - val_loss: 0.0599 - val_accuracy: 0.2358\n",
      "Epoch 93/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0594 - accuracy: 0.2368\n",
      " (5.3450122912656255, 1e-05)-DP guarantees for epoch 93 \n",
      "\n",
      "5/5 [==============================] - 3s 364ms/step - loss: 0.0594 - accuracy: 0.2368 - val_loss: 0.0598 - val_accuracy: 0.2346\n",
      "Epoch 94/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0592 - accuracy: 0.2380\n",
      " (5.37826264973137, 1e-05)-DP guarantees for epoch 94 \n",
      "\n",
      "5/5 [==============================] - 2s 351ms/step - loss: 0.0592 - accuracy: 0.2380 - val_loss: 0.0597 - val_accuracy: 0.2347\n",
      "Epoch 95/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0593 - accuracy: 0.2357\n",
      " (5.4115130208687106, 1e-05)-DP guarantees for epoch 95 \n",
      "\n",
      "5/5 [==============================] - 2s 360ms/step - loss: 0.0593 - accuracy: 0.2357 - val_loss: 0.0596 - val_accuracy: 0.2348\n",
      "Epoch 96/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0594 - accuracy: 0.2376\n",
      " (5.444763387799843, 1e-05)-DP guarantees for epoch 96 \n",
      "\n",
      "5/5 [==============================] - 2s 349ms/step - loss: 0.0594 - accuracy: 0.2376 - val_loss: 0.0595 - val_accuracy: 0.2362\n",
      "Epoch 97/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0589 - accuracy: 0.2411\n",
      " (5.47801375480832, 1e-05)-DP guarantees for epoch 97 \n",
      "\n",
      "5/5 [==============================] - 2s 363ms/step - loss: 0.0589 - accuracy: 0.2411 - val_loss: 0.0594 - val_accuracy: 0.2375\n",
      "Epoch 98/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0590 - accuracy: 0.2404\n",
      " (5.511264111964721, 1e-05)-DP guarantees for epoch 98 \n",
      "\n",
      "5/5 [==============================] - 2s 350ms/step - loss: 0.0590 - accuracy: 0.2404 - val_loss: 0.0593 - val_accuracy: 0.2377\n",
      "Epoch 99/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0586 - accuracy: 0.2406\n",
      " (5.544514479570887, 1e-05)-DP guarantees for epoch 99 \n",
      "\n",
      "5/5 [==============================] - 2s 347ms/step - loss: 0.0586 - accuracy: 0.2406 - val_loss: 0.0593 - val_accuracy: 0.2389\n",
      "Epoch 100/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0587 - accuracy: 0.2436\n",
      " (5.5777648468507035, 1e-05)-DP guarantees for epoch 100 \n",
      "\n",
      "5/5 [==============================] - 3s 356ms/step - loss: 0.0587 - accuracy: 0.2436 - val_loss: 0.0592 - val_accuracy: 0.2383\n",
      "Epoch 101/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0586 - accuracy: 0.2405\n",
      " (5.611015209476669, 1e-05)-DP guarantees for epoch 101 \n",
      "\n",
      "5/5 [==============================] - 3s 362ms/step - loss: 0.0586 - accuracy: 0.2405 - val_loss: 0.0590 - val_accuracy: 0.2382\n",
      "Epoch 102/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0586 - accuracy: 0.2409\n",
      " (5.644265572603777, 1e-05)-DP guarantees for epoch 102 \n",
      "\n",
      "5/5 [==============================] - 3s 359ms/step - loss: 0.0586 - accuracy: 0.2409 - val_loss: 0.0589 - val_accuracy: 0.2376\n",
      "Epoch 103/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0584 - accuracy: 0.2425\n",
      " (5.67751593629532, 1e-05)-DP guarantees for epoch 103 \n",
      "\n",
      "5/5 [==============================] - 3s 366ms/step - loss: 0.0584 - accuracy: 0.2425 - val_loss: 0.0588 - val_accuracy: 0.2397\n",
      "Epoch 104/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0583 - accuracy: 0.2422\n",
      " (5.710766303023046, 1e-05)-DP guarantees for epoch 104 \n",
      "\n",
      "5/5 [==============================] - 3s 370ms/step - loss: 0.0583 - accuracy: 0.2422 - val_loss: 0.0587 - val_accuracy: 0.2384\n",
      "Epoch 105/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0582 - accuracy: 0.2425\n",
      " (5.7440166690784755, 1e-05)-DP guarantees for epoch 105 \n",
      "\n",
      "5/5 [==============================] - 3s 364ms/step - loss: 0.0582 - accuracy: 0.2425 - val_loss: 0.0586 - val_accuracy: 0.2383\n",
      "Epoch 106/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0583 - accuracy: 0.2411\n",
      " (5.777267031618594, 1e-05)-DP guarantees for epoch 106 \n",
      "\n",
      "5/5 [==============================] - 2s 345ms/step - loss: 0.0583 - accuracy: 0.2411 - val_loss: 0.0586 - val_accuracy: 0.2387\n",
      "Epoch 107/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0578 - accuracy: 0.2438\n",
      " (5.8105173958576675, 1e-05)-DP guarantees for epoch 107 \n",
      "\n",
      "5/5 [==============================] - 2s 343ms/step - loss: 0.0578 - accuracy: 0.2438 - val_loss: 0.0585 - val_accuracy: 0.2409\n",
      "Epoch 108/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0582 - accuracy: 0.2442\n",
      " (5.843767765269359, 1e-05)-DP guarantees for epoch 108 \n",
      "\n",
      "5/5 [==============================] - 2s 359ms/step - loss: 0.0582 - accuracy: 0.2442 - val_loss: 0.0584 - val_accuracy: 0.2440\n",
      "Epoch 109/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0578 - accuracy: 0.2456\n",
      " (5.877018127929281, 1e-05)-DP guarantees for epoch 109 \n",
      "\n",
      "5/5 [==============================] - 2s 355ms/step - loss: 0.0578 - accuracy: 0.2456 - val_loss: 0.0584 - val_accuracy: 0.2419\n",
      "Epoch 110/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0580 - accuracy: 0.2440\n",
      " (5.910268490844311, 1e-05)-DP guarantees for epoch 110 \n",
      "\n",
      "5/5 [==============================] - 2s 362ms/step - loss: 0.0580 - accuracy: 0.2440 - val_loss: 0.0583 - val_accuracy: 0.2429\n",
      "Epoch 111/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0578 - accuracy: 0.2473\n",
      " (5.943518855328065, 1e-05)-DP guarantees for epoch 111 \n",
      "\n",
      "5/5 [==============================] - 2s 350ms/step - loss: 0.0578 - accuracy: 0.2473 - val_loss: 0.0583 - val_accuracy: 0.2448\n",
      "Epoch 112/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0577 - accuracy: 0.2469\n",
      " (5.9767692222925275, 1e-05)-DP guarantees for epoch 112 \n",
      "\n",
      "5/5 [==============================] - 3s 348ms/step - loss: 0.0577 - accuracy: 0.2469 - val_loss: 0.0582 - val_accuracy: 0.2447\n",
      "Epoch 113/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0579 - accuracy: 0.2479\n",
      " (6.0100195891034165, 1e-05)-DP guarantees for epoch 113 \n",
      "\n",
      "5/5 [==============================] - 2s 348ms/step - loss: 0.0579 - accuracy: 0.2479 - val_loss: 0.0581 - val_accuracy: 0.2453\n",
      "Epoch 114/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0576 - accuracy: 0.2468\n",
      " (6.043269950764723, 1e-05)-DP guarantees for epoch 114 \n",
      "\n",
      "5/5 [==============================] - 3s 361ms/step - loss: 0.0576 - accuracy: 0.2468 - val_loss: 0.0580 - val_accuracy: 0.2432\n",
      "Epoch 115/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0574 - accuracy: 0.2472\n",
      " (6.076520315246205, 1e-05)-DP guarantees for epoch 115 \n",
      "\n",
      "5/5 [==============================] - 2s 357ms/step - loss: 0.0574 - accuracy: 0.2472 - val_loss: 0.0579 - val_accuracy: 0.2441\n",
      "Epoch 116/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0573 - accuracy: 0.2476\n",
      " (6.109770681686705, 1e-05)-DP guarantees for epoch 116 \n",
      "\n",
      "5/5 [==============================] - 2s 363ms/step - loss: 0.0573 - accuracy: 0.2476 - val_loss: 0.0579 - val_accuracy: 0.2440\n",
      "Epoch 117/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0575 - accuracy: 0.2470\n",
      " (6.143021045607053, 1e-05)-DP guarantees for epoch 117 \n",
      "\n",
      "5/5 [==============================] - 3s 357ms/step - loss: 0.0575 - accuracy: 0.2470 - val_loss: 0.0578 - val_accuracy: 0.2479\n",
      "Epoch 118/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0572 - accuracy: 0.2481\n",
      " (6.1762714106501475, 1e-05)-DP guarantees for epoch 118 \n",
      "\n",
      "5/5 [==============================] - 3s 360ms/step - loss: 0.0572 - accuracy: 0.2481 - val_loss: 0.0576 - val_accuracy: 0.2450\n",
      "Epoch 119/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0572 - accuracy: 0.2500\n",
      " (6.209521499901805, 1e-05)-DP guarantees for epoch 119 \n",
      "\n",
      "5/5 [==============================] - 3s 367ms/step - loss: 0.0572 - accuracy: 0.2500 - val_loss: 0.0576 - val_accuracy: 0.2446\n",
      "Epoch 120/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0569 - accuracy: 0.2497\n",
      " (6.241605627485653, 1e-05)-DP guarantees for epoch 120 \n",
      "\n",
      "5/5 [==============================] - 2s 355ms/step - loss: 0.0569 - accuracy: 0.2497 - val_loss: 0.0575 - val_accuracy: 0.2451\n",
      "Epoch 121/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0569 - accuracy: 0.2510\n",
      " (6.271221812058615, 1e-05)-DP guarantees for epoch 121 \n",
      "\n",
      "5/5 [==============================] - 2s 351ms/step - loss: 0.0569 - accuracy: 0.2510 - val_loss: 0.0574 - val_accuracy: 0.2445\n",
      "Epoch 122/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0571 - accuracy: 0.2481\n",
      " (6.298196491974402, 1e-05)-DP guarantees for epoch 122 \n",
      "\n",
      "5/5 [==============================] - 2s 359ms/step - loss: 0.0571 - accuracy: 0.2481 - val_loss: 0.0574 - val_accuracy: 0.2447\n",
      "Epoch 123/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0568 - accuracy: 0.2517\n",
      " (6.324510712314491, 1e-05)-DP guarantees for epoch 123 \n",
      "\n",
      "5/5 [==============================] - 2s 345ms/step - loss: 0.0568 - accuracy: 0.2517 - val_loss: 0.0573 - val_accuracy: 0.2481\n",
      "Epoch 124/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0570 - accuracy: 0.2505\n",
      " (6.350824932887864, 1e-05)-DP guarantees for epoch 124 \n",
      "\n",
      "5/5 [==============================] - 3s 359ms/step - loss: 0.0570 - accuracy: 0.2505 - val_loss: 0.0573 - val_accuracy: 0.2449\n",
      "Epoch 125/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0567 - accuracy: 0.2489\n",
      " (6.377139153079873, 1e-05)-DP guarantees for epoch 125 \n",
      "\n",
      "5/5 [==============================] - 2s 368ms/step - loss: 0.0567 - accuracy: 0.2489 - val_loss: 0.0572 - val_accuracy: 0.2450\n",
      "Epoch 126/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0570 - accuracy: 0.2488\n",
      " (6.403453374888347, 1e-05)-DP guarantees for epoch 126 \n",
      "\n",
      "5/5 [==============================] - 3s 349ms/step - loss: 0.0570 - accuracy: 0.2488 - val_loss: 0.0572 - val_accuracy: 0.2485\n",
      "Epoch 127/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0566 - accuracy: 0.2539\n",
      " (6.429767596763488, 1e-05)-DP guarantees for epoch 127 \n",
      "\n",
      "5/5 [==============================] - 3s 391ms/step - loss: 0.0566 - accuracy: 0.2539 - val_loss: 0.0571 - val_accuracy: 0.2452\n",
      "Epoch 128/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0565 - accuracy: 0.2505\n",
      " (6.4560818158974875, 1e-05)-DP guarantees for epoch 128 \n",
      "\n",
      "5/5 [==============================] - 3s 367ms/step - loss: 0.0565 - accuracy: 0.2505 - val_loss: 0.0570 - val_accuracy: 0.2466\n",
      "Epoch 129/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0566 - accuracy: 0.2522\n",
      " (6.482396036898421, 1e-05)-DP guarantees for epoch 129 \n",
      "\n",
      "5/5 [==============================] - 2s 343ms/step - loss: 0.0566 - accuracy: 0.2522 - val_loss: 0.0570 - val_accuracy: 0.2461\n",
      "Epoch 130/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0561 - accuracy: 0.2521\n",
      " (6.5087102545452, 1e-05)-DP guarantees for epoch 130 \n",
      "\n",
      "5/5 [==============================] - 2s 353ms/step - loss: 0.0561 - accuracy: 0.2521 - val_loss: 0.0569 - val_accuracy: 0.2468\n",
      "Epoch 131/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0562 - accuracy: 0.2534\n",
      " (6.53502447810436, 1e-05)-DP guarantees for epoch 131 \n",
      "\n",
      "5/5 [==============================] - 2s 374ms/step - loss: 0.0562 - accuracy: 0.2534 - val_loss: 0.0569 - val_accuracy: 0.2470\n",
      "Epoch 132/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0563 - accuracy: 0.2530\n",
      " (6.5613386977335715, 1e-05)-DP guarantees for epoch 132 \n",
      "\n",
      "5/5 [==============================] - 2s 350ms/step - loss: 0.0563 - accuracy: 0.2530 - val_loss: 0.0568 - val_accuracy: 0.2501\n",
      "Epoch 133/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0561 - accuracy: 0.2564\n",
      " (6.587652915827986, 1e-05)-DP guarantees for epoch 133 \n",
      "\n",
      "5/5 [==============================] - 3s 368ms/step - loss: 0.0561 - accuracy: 0.2564 - val_loss: 0.0569 - val_accuracy: 0.2470\n",
      "Epoch 134/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0561 - accuracy: 0.2555\n",
      " (6.613967135260202, 1e-05)-DP guarantees for epoch 134 \n",
      "\n",
      "5/5 [==============================] - 3s 402ms/step - loss: 0.0561 - accuracy: 0.2555 - val_loss: 0.0568 - val_accuracy: 0.2492\n",
      "Epoch 135/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0564 - accuracy: 0.2535\n",
      " (6.6402813578423405, 1e-05)-DP guarantees for epoch 135 \n",
      "\n",
      "5/5 [==============================] - 2s 347ms/step - loss: 0.0564 - accuracy: 0.2535 - val_loss: 0.0567 - val_accuracy: 0.2499\n",
      "Epoch 136/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0559 - accuracy: 0.2552\n",
      " (6.666595582737012, 1e-05)-DP guarantees for epoch 136 \n",
      "\n",
      "5/5 [==============================] - 2s 360ms/step - loss: 0.0559 - accuracy: 0.2552 - val_loss: 0.0567 - val_accuracy: 0.2506\n",
      "Epoch 137/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0560 - accuracy: 0.2562\n",
      " (6.692909796982604, 1e-05)-DP guarantees for epoch 137 \n",
      "\n",
      "5/5 [==============================] - 3s 364ms/step - loss: 0.0560 - accuracy: 0.2562 - val_loss: 0.0566 - val_accuracy: 0.2484\n",
      "Epoch 138/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0560 - accuracy: 0.2538\n",
      " (6.719224016310403, 1e-05)-DP guarantees for epoch 138 \n",
      "\n",
      "5/5 [==============================] - 2s 349ms/step - loss: 0.0560 - accuracy: 0.2538 - val_loss: 0.0565 - val_accuracy: 0.2471\n",
      "Epoch 139/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0560 - accuracy: 0.2526\n",
      " (6.74553823900151, 1e-05)-DP guarantees for epoch 139 \n",
      "\n",
      "5/5 [==============================] - 3s 399ms/step - loss: 0.0560 - accuracy: 0.2526 - val_loss: 0.0565 - val_accuracy: 0.2509\n",
      "Epoch 140/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0560 - accuracy: 0.2536\n",
      " (6.771852459824933, 1e-05)-DP guarantees for epoch 140 \n",
      "\n",
      "5/5 [==============================] - 3s 493ms/step - loss: 0.0560 - accuracy: 0.2536 - val_loss: 0.0564 - val_accuracy: 0.2493\n",
      "Epoch 141/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0557 - accuracy: 0.2555\n",
      " (6.798166680154963, 1e-05)-DP guarantees for epoch 141 \n",
      "\n",
      "5/5 [==============================] - 3s 391ms/step - loss: 0.0557 - accuracy: 0.2555 - val_loss: 0.0563 - val_accuracy: 0.2511\n",
      "Epoch 142/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0559 - accuracy: 0.2541\n",
      " (6.824480898392123, 1e-05)-DP guarantees for epoch 142 \n",
      "\n",
      "5/5 [==============================] - 3s 443ms/step - loss: 0.0559 - accuracy: 0.2541 - val_loss: 0.0563 - val_accuracy: 0.2484\n",
      "Epoch 143/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0560 - accuracy: 0.2547\n",
      " (6.850795124433479, 1e-05)-DP guarantees for epoch 143 \n",
      "\n",
      "5/5 [==============================] - 3s 368ms/step - loss: 0.0560 - accuracy: 0.2547 - val_loss: 0.0563 - val_accuracy: 0.2487\n",
      "Epoch 144/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0556 - accuracy: 0.2545\n",
      " (6.877109344205954, 1e-05)-DP guarantees for epoch 144 \n",
      "\n",
      "5/5 [==============================] - 3s 374ms/step - loss: 0.0556 - accuracy: 0.2545 - val_loss: 0.0562 - val_accuracy: 0.2487\n",
      "Epoch 145/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0555 - accuracy: 0.2569\n",
      " (6.903423558068683, 1e-05)-DP guarantees for epoch 145 \n",
      "\n",
      "5/5 [==============================] - 3s 378ms/step - loss: 0.0555 - accuracy: 0.2569 - val_loss: 0.0562 - val_accuracy: 0.2508\n",
      "Epoch 146/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0558 - accuracy: 0.2560\n",
      " (6.929737777126363, 1e-05)-DP guarantees for epoch 146 \n",
      "\n",
      "5/5 [==============================] - 3s 387ms/step - loss: 0.0558 - accuracy: 0.2560 - val_loss: 0.0561 - val_accuracy: 0.2504\n",
      "Epoch 147/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0557 - accuracy: 0.2556\n",
      " (6.956052008535497, 1e-05)-DP guarantees for epoch 147 \n",
      "\n",
      "5/5 [==============================] - 3s 372ms/step - loss: 0.0557 - accuracy: 0.2556 - val_loss: 0.0561 - val_accuracy: 0.2509\n",
      "Epoch 148/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0557 - accuracy: 0.2538\n",
      " (6.982366223228706, 1e-05)-DP guarantees for epoch 148 \n",
      "\n",
      "5/5 [==============================] - 3s 381ms/step - loss: 0.0557 - accuracy: 0.2538 - val_loss: 0.0561 - val_accuracy: 0.2528\n",
      "Epoch 149/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0553 - accuracy: 0.2580\n",
      " (7.0086804403647855, 1e-05)-DP guarantees for epoch 149 \n",
      "\n",
      "5/5 [==============================] - 3s 357ms/step - loss: 0.0553 - accuracy: 0.2580 - val_loss: 0.0560 - val_accuracy: 0.2530\n",
      "Epoch 150/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0549 - accuracy: 0.2595\n",
      " (7.034994664689931, 1e-05)-DP guarantees for epoch 150 \n",
      "\n",
      "5/5 [==============================] - 3s 361ms/step - loss: 0.0549 - accuracy: 0.2595 - val_loss: 0.0560 - val_accuracy: 0.2519\n",
      "Epoch 151/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0554 - accuracy: 0.2585\n",
      " (7.061308885525292, 1e-05)-DP guarantees for epoch 151 \n",
      "\n",
      "5/5 [==============================] - 2s 355ms/step - loss: 0.0554 - accuracy: 0.2585 - val_loss: 0.0559 - val_accuracy: 0.2531\n",
      "Epoch 152/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0554 - accuracy: 0.2580\n",
      " (7.087623106633284, 1e-05)-DP guarantees for epoch 152 \n",
      "\n",
      "5/5 [==============================] - 2s 355ms/step - loss: 0.0554 - accuracy: 0.2580 - val_loss: 0.0558 - val_accuracy: 0.2543\n",
      "Epoch 153/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0553 - accuracy: 0.2585\n",
      " (7.113937323136563, 1e-05)-DP guarantees for epoch 153 \n",
      "\n",
      "5/5 [==============================] - 3s 365ms/step - loss: 0.0553 - accuracy: 0.2585 - val_loss: 0.0558 - val_accuracy: 0.2537\n",
      "Epoch 154/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0551 - accuracy: 0.2595\n",
      " (7.140251544398778, 1e-05)-DP guarantees for epoch 154 \n",
      "\n",
      "5/5 [==============================] - 3s 359ms/step - loss: 0.0551 - accuracy: 0.2595 - val_loss: 0.0558 - val_accuracy: 0.2551\n",
      "Epoch 155/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0550 - accuracy: 0.2600\n",
      " (7.166565767658498, 1e-05)-DP guarantees for epoch 155 \n",
      "\n",
      "5/5 [==============================] - 3s 355ms/step - loss: 0.0550 - accuracy: 0.2600 - val_loss: 0.0557 - val_accuracy: 0.2569\n",
      "Epoch 156/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0553 - accuracy: 0.2561\n",
      " (7.192879981310637, 1e-05)-DP guarantees for epoch 156 \n",
      "\n",
      "5/5 [==============================] - 2s 353ms/step - loss: 0.0553 - accuracy: 0.2561 - val_loss: 0.0556 - val_accuracy: 0.2545\n",
      "Epoch 157/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0550 - accuracy: 0.2581\n",
      " (7.2191942080187195, 1e-05)-DP guarantees for epoch 157 \n",
      "\n",
      "5/5 [==============================] - 3s 356ms/step - loss: 0.0550 - accuracy: 0.2581 - val_loss: 0.0556 - val_accuracy: 0.2566\n",
      "Epoch 158/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0550 - accuracy: 0.2601\n",
      " (7.245508431022666, 1e-05)-DP guarantees for epoch 158 \n",
      "\n",
      "5/5 [==============================] - 2s 353ms/step - loss: 0.0550 - accuracy: 0.2601 - val_loss: 0.0556 - val_accuracy: 0.2574\n",
      "Epoch 159/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0548 - accuracy: 0.2599\n",
      " (7.27182264840541, 1e-05)-DP guarantees for epoch 159 \n",
      "\n",
      "5/5 [==============================] - 2s 343ms/step - loss: 0.0548 - accuracy: 0.2599 - val_loss: 0.0555 - val_accuracy: 0.2567\n",
      "Epoch 160/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0548 - accuracy: 0.2616\n",
      " (7.298136867745498, 1e-05)-DP guarantees for epoch 160 \n",
      "\n",
      "5/5 [==============================] - 2s 367ms/step - loss: 0.0548 - accuracy: 0.2616 - val_loss: 0.0554 - val_accuracy: 0.2560\n",
      "Epoch 161/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0551 - accuracy: 0.2595\n",
      " (7.324451088022072, 1e-05)-DP guarantees for epoch 161 \n",
      "\n",
      "5/5 [==============================] - 3s 349ms/step - loss: 0.0551 - accuracy: 0.2595 - val_loss: 0.0554 - val_accuracy: 0.2577\n",
      "Epoch 162/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0548 - accuracy: 0.2606\n",
      " (7.350765305854425, 1e-05)-DP guarantees for epoch 162 \n",
      "\n",
      "5/5 [==============================] - 2s 352ms/step - loss: 0.0548 - accuracy: 0.2606 - val_loss: 0.0554 - val_accuracy: 0.2580\n",
      "Epoch 163/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0547 - accuracy: 0.2588\n",
      " (7.37707952170881, 1e-05)-DP guarantees for epoch 163 \n",
      "\n",
      "5/5 [==============================] - 2s 351ms/step - loss: 0.0547 - accuracy: 0.2588 - val_loss: 0.0553 - val_accuracy: 0.2549\n",
      "Epoch 164/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0546 - accuracy: 0.2585\n",
      " (7.403393741099066, 1e-05)-DP guarantees for epoch 164 \n",
      "\n",
      "5/5 [==============================] - 3s 379ms/step - loss: 0.0546 - accuracy: 0.2585 - val_loss: 0.0553 - val_accuracy: 0.2591\n",
      "Epoch 165/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0546 - accuracy: 0.2607\n",
      " (7.429707969366283, 1e-05)-DP guarantees for epoch 165 \n",
      "\n",
      "5/5 [==============================] - 3s 368ms/step - loss: 0.0546 - accuracy: 0.2607 - val_loss: 0.0552 - val_accuracy: 0.2574\n",
      "Epoch 166/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0547 - accuracy: 0.2598\n",
      " (7.456022189620042, 1e-05)-DP guarantees for epoch 166 \n",
      "\n",
      "5/5 [==============================] - 2s 356ms/step - loss: 0.0547 - accuracy: 0.2598 - val_loss: 0.0551 - val_accuracy: 0.2544\n",
      "Epoch 167/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0544 - accuracy: 0.2589\n",
      " (7.4823364015791975, 1e-05)-DP guarantees for epoch 167 \n",
      "\n",
      "5/5 [==============================] - 2s 343ms/step - loss: 0.0544 - accuracy: 0.2589 - val_loss: 0.0552 - val_accuracy: 0.2570\n",
      "Epoch 168/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0546 - accuracy: 0.2620\n",
      " (7.508650622437409, 1e-05)-DP guarantees for epoch 168 \n",
      "\n",
      "5/5 [==============================] - 2s 343ms/step - loss: 0.0546 - accuracy: 0.2620 - val_loss: 0.0551 - val_accuracy: 0.2585\n",
      "Epoch 169/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0544 - accuracy: 0.2609\n",
      " (7.5349648424170645, 1e-05)-DP guarantees for epoch 169 \n",
      "\n",
      "5/5 [==============================] - 3s 371ms/step - loss: 0.0544 - accuracy: 0.2609 - val_loss: 0.0550 - val_accuracy: 0.2591\n",
      "Epoch 170/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0545 - accuracy: 0.2618\n",
      " (7.561279065737033, 1e-05)-DP guarantees for epoch 170 \n",
      "\n",
      "5/5 [==============================] - 3s 369ms/step - loss: 0.0545 - accuracy: 0.2618 - val_loss: 0.0551 - val_accuracy: 0.2582\n",
      "Epoch 171/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0542 - accuracy: 0.2642\n",
      " (7.587593290867159, 1e-05)-DP guarantees for epoch 171 \n",
      "\n",
      "5/5 [==============================] - 3s 372ms/step - loss: 0.0542 - accuracy: 0.2642 - val_loss: 0.0551 - val_accuracy: 0.2598\n",
      "Epoch 172/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0543 - accuracy: 0.2640\n",
      " (7.613907506714526, 1e-05)-DP guarantees for epoch 172 \n",
      "\n",
      "5/5 [==============================] - 3s 369ms/step - loss: 0.0543 - accuracy: 0.2640 - val_loss: 0.0550 - val_accuracy: 0.2604\n",
      "Epoch 173/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0543 - accuracy: 0.2642\n",
      " (7.640221723584304, 1e-05)-DP guarantees for epoch 173 \n",
      "\n",
      "5/5 [==============================] - 3s 359ms/step - loss: 0.0543 - accuracy: 0.2642 - val_loss: 0.0549 - val_accuracy: 0.2604\n",
      "Epoch 174/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0542 - accuracy: 0.2635\n",
      " (7.666535950048996, 1e-05)-DP guarantees for epoch 174 \n",
      "\n",
      "5/5 [==============================] - 2s 344ms/step - loss: 0.0542 - accuracy: 0.2635 - val_loss: 0.0549 - val_accuracy: 0.2628\n",
      "Epoch 175/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0541 - accuracy: 0.2648\n",
      " (7.692850164248792, 1e-05)-DP guarantees for epoch 175 \n",
      "\n",
      "5/5 [==============================] - 2s 358ms/step - loss: 0.0541 - accuracy: 0.2648 - val_loss: 0.0548 - val_accuracy: 0.2625\n",
      "Epoch 176/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0542 - accuracy: 0.2637\n",
      " (7.719164393302542, 1e-05)-DP guarantees for epoch 176 \n",
      "\n",
      "5/5 [==============================] - 2s 358ms/step - loss: 0.0542 - accuracy: 0.2637 - val_loss: 0.0547 - val_accuracy: 0.2621\n",
      "Epoch 177/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0540 - accuracy: 0.2661\n",
      " (7.745478613553454, 1e-05)-DP guarantees for epoch 177 \n",
      "\n",
      "5/5 [==============================] - 2s 351ms/step - loss: 0.0540 - accuracy: 0.2661 - val_loss: 0.0546 - val_accuracy: 0.2665\n",
      "Epoch 178/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0541 - accuracy: 0.2668\n",
      " (7.771792822684058, 1e-05)-DP guarantees for epoch 178 \n",
      "\n",
      "5/5 [==============================] - 2s 353ms/step - loss: 0.0541 - accuracy: 0.2668 - val_loss: 0.0546 - val_accuracy: 0.2659\n",
      "Epoch 179/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0539 - accuracy: 0.2685\n",
      " (7.7981070469012, 1e-05)-DP guarantees for epoch 179 \n",
      "\n",
      "5/5 [==============================] - 2s 357ms/step - loss: 0.0539 - accuracy: 0.2685 - val_loss: 0.0545 - val_accuracy: 0.2646\n",
      "Epoch 180/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0538 - accuracy: 0.2682\n",
      " (7.824421268798268, 1e-05)-DP guarantees for epoch 180 \n",
      "\n",
      "5/5 [==============================] - 2s 352ms/step - loss: 0.0538 - accuracy: 0.2682 - val_loss: 0.0545 - val_accuracy: 0.2656\n",
      "Epoch 181/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0538 - accuracy: 0.2671\n",
      " (7.850735498247861, 1e-05)-DP guarantees for epoch 181 \n",
      "\n",
      "5/5 [==============================] - 2s 358ms/step - loss: 0.0538 - accuracy: 0.2671 - val_loss: 0.0545 - val_accuracy: 0.2639\n",
      "Epoch 182/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0539 - accuracy: 0.2661\n",
      " (7.877049711425853, 1e-05)-DP guarantees for epoch 182 \n",
      "\n",
      "5/5 [==============================] - 3s 368ms/step - loss: 0.0539 - accuracy: 0.2661 - val_loss: 0.0544 - val_accuracy: 0.2645\n",
      "Epoch 183/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0537 - accuracy: 0.2635\n",
      " (7.903363929529842, 1e-05)-DP guarantees for epoch 183 \n",
      "\n",
      "5/5 [==============================] - 3s 356ms/step - loss: 0.0537 - accuracy: 0.2635 - val_loss: 0.0544 - val_accuracy: 0.2645\n",
      "Epoch 184/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0538 - accuracy: 0.2641\n",
      " (7.929678153587394, 1e-05)-DP guarantees for epoch 184 \n",
      "\n",
      "5/5 [==============================] - 3s 361ms/step - loss: 0.0538 - accuracy: 0.2641 - val_loss: 0.0543 - val_accuracy: 0.2641\n",
      "Epoch 185/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0535 - accuracy: 0.2668\n",
      " (7.955992381685565, 1e-05)-DP guarantees for epoch 185 \n",
      "\n",
      "5/5 [==============================] - 2s 348ms/step - loss: 0.0535 - accuracy: 0.2668 - val_loss: 0.0543 - val_accuracy: 0.2638\n",
      "Epoch 186/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0535 - accuracy: 0.2641\n",
      " (7.982306589145621, 1e-05)-DP guarantees for epoch 186 \n",
      "\n",
      "5/5 [==============================] - 3s 357ms/step - loss: 0.0535 - accuracy: 0.2641 - val_loss: 0.0543 - val_accuracy: 0.2654\n",
      "Epoch 187/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0537 - accuracy: 0.2653\n",
      " (8.008620808026855, 1e-05)-DP guarantees for epoch 187 \n",
      "\n",
      "5/5 [==============================] - 3s 412ms/step - loss: 0.0537 - accuracy: 0.2653 - val_loss: 0.0542 - val_accuracy: 0.2651\n",
      "Epoch 188/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0535 - accuracy: 0.2656\n",
      " (8.034935029136395, 1e-05)-DP guarantees for epoch 188 \n",
      "\n",
      "5/5 [==============================] - 3s 488ms/step - loss: 0.0535 - accuracy: 0.2656 - val_loss: 0.0542 - val_accuracy: 0.2662\n",
      "Epoch 189/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0536 - accuracy: 0.2653\n",
      " (8.061249248434443, 1e-05)-DP guarantees for epoch 189 \n",
      "\n",
      "5/5 [==============================] - 3s 444ms/step - loss: 0.0536 - accuracy: 0.2653 - val_loss: 0.0541 - val_accuracy: 0.2659\n",
      "Epoch 190/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0533 - accuracy: 0.2676\n",
      " (8.087563469816706, 1e-05)-DP guarantees for epoch 190 \n",
      "\n",
      "5/5 [==============================] - 3s 405ms/step - loss: 0.0533 - accuracy: 0.2676 - val_loss: 0.0541 - val_accuracy: 0.2663\n",
      "Epoch 191/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0534 - accuracy: 0.2669\n",
      " (8.113877688170744, 1e-05)-DP guarantees for epoch 191 \n",
      "\n",
      "5/5 [==============================] - 3s 385ms/step - loss: 0.0534 - accuracy: 0.2669 - val_loss: 0.0541 - val_accuracy: 0.2675\n",
      "Epoch 192/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0535 - accuracy: 0.2648\n",
      " (8.140191906358039, 1e-05)-DP guarantees for epoch 192 \n",
      "\n",
      "5/5 [==============================] - 3s 392ms/step - loss: 0.0535 - accuracy: 0.2648 - val_loss: 0.0540 - val_accuracy: 0.2676\n",
      "Epoch 193/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0534 - accuracy: 0.2680\n",
      " (8.166506132866681, 1e-05)-DP guarantees for epoch 193 \n",
      "\n",
      "5/5 [==============================] - 3s 379ms/step - loss: 0.0534 - accuracy: 0.2680 - val_loss: 0.0540 - val_accuracy: 0.2676\n",
      "Epoch 194/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0533 - accuracy: 0.2654\n",
      " (8.192820350846777, 1e-05)-DP guarantees for epoch 194 \n",
      "\n",
      "5/5 [==============================] - 2s 356ms/step - loss: 0.0533 - accuracy: 0.2654 - val_loss: 0.0540 - val_accuracy: 0.2679\n",
      "Epoch 195/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0531 - accuracy: 0.2681\n",
      " (8.219134573417037, 1e-05)-DP guarantees for epoch 195 \n",
      "\n",
      "5/5 [==============================] - 3s 381ms/step - loss: 0.0531 - accuracy: 0.2681 - val_loss: 0.0541 - val_accuracy: 0.2654\n",
      "Epoch 196/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0532 - accuracy: 0.2671\n",
      " (8.24544879099129, 1e-05)-DP guarantees for epoch 196 \n",
      "\n",
      "5/5 [==============================] - 3s 381ms/step - loss: 0.0532 - accuracy: 0.2671 - val_loss: 0.0540 - val_accuracy: 0.2658\n",
      "Epoch 197/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0535 - accuracy: 0.2666\n",
      " (8.271763016196239, 1e-05)-DP guarantees for epoch 197 \n",
      "\n",
      "5/5 [==============================] - 3s 389ms/step - loss: 0.0535 - accuracy: 0.2666 - val_loss: 0.0540 - val_accuracy: 0.2656\n",
      "Epoch 198/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0534 - accuracy: 0.2676\n",
      " (8.298077232897459, 1e-05)-DP guarantees for epoch 198 \n",
      "\n",
      "5/5 [==============================] - 3s 415ms/step - loss: 0.0534 - accuracy: 0.2676 - val_loss: 0.0539 - val_accuracy: 0.2656\n",
      "Epoch 199/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0531 - accuracy: 0.2672\n",
      " (8.324391446543665, 1e-05)-DP guarantees for epoch 199 \n",
      "\n",
      "5/5 [==============================] - 3s 380ms/step - loss: 0.0531 - accuracy: 0.2672 - val_loss: 0.0538 - val_accuracy: 0.2658\n",
      "Epoch 200/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0534 - accuracy: 0.2638\n",
      " (8.350705669706155, 1e-05)-DP guarantees for epoch 200 \n",
      "\n",
      "5/5 [==============================] - 2s 358ms/step - loss: 0.0534 - accuracy: 0.2638 - val_loss: 0.0538 - val_accuracy: 0.2659\n",
      "Epoch 201/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0533 - accuracy: 0.2672\n",
      " (8.377019893272927, 1e-05)-DP guarantees for epoch 201 \n",
      "\n",
      "5/5 [==============================] - 2s 369ms/step - loss: 0.0533 - accuracy: 0.2672 - val_loss: 0.0538 - val_accuracy: 0.2678\n",
      "Epoch 202/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0533 - accuracy: 0.2685\n",
      " (8.403334112768452, 1e-05)-DP guarantees for epoch 202 \n",
      "\n",
      "5/5 [==============================] - 3s 362ms/step - loss: 0.0533 - accuracy: 0.2685 - val_loss: 0.0537 - val_accuracy: 0.2677\n",
      "Epoch 203/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0528 - accuracy: 0.2701\n",
      " (8.429648329088547, 1e-05)-DP guarantees for epoch 203 \n",
      "\n",
      "5/5 [==============================] - 2s 351ms/step - loss: 0.0528 - accuracy: 0.2701 - val_loss: 0.0537 - val_accuracy: 0.2669\n",
      "Epoch 204/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0528 - accuracy: 0.2696\n",
      " (8.455962556505566, 1e-05)-DP guarantees for epoch 204 \n",
      "\n",
      "5/5 [==============================] - 2s 344ms/step - loss: 0.0528 - accuracy: 0.2696 - val_loss: 0.0537 - val_accuracy: 0.2681\n",
      "Epoch 205/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0532 - accuracy: 0.2691\n",
      " (8.4822767745793, 1e-05)-DP guarantees for epoch 205 \n",
      "\n",
      "5/5 [==============================] - 2s 348ms/step - loss: 0.0532 - accuracy: 0.2691 - val_loss: 0.0536 - val_accuracy: 0.2692\n",
      "Epoch 206/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0531 - accuracy: 0.2703\n",
      " (8.508590990133396, 1e-05)-DP guarantees for epoch 206 \n",
      "\n",
      "5/5 [==============================] - 3s 354ms/step - loss: 0.0531 - accuracy: 0.2703 - val_loss: 0.0535 - val_accuracy: 0.2683\n",
      "Epoch 207/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0529 - accuracy: 0.2705\n",
      " (8.534905221654196, 1e-05)-DP guarantees for epoch 207 \n",
      "\n",
      "5/5 [==============================] - 3s 348ms/step - loss: 0.0529 - accuracy: 0.2705 - val_loss: 0.0535 - val_accuracy: 0.2661\n",
      "Epoch 208/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0526 - accuracy: 0.2726\n",
      " (8.56121943210842, 1e-05)-DP guarantees for epoch 208 \n",
      "\n",
      "5/5 [==============================] - 2s 351ms/step - loss: 0.0526 - accuracy: 0.2726 - val_loss: 0.0535 - val_accuracy: 0.2671\n",
      "Epoch 209/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0530 - accuracy: 0.2703\n",
      " (8.58753364829852, 1e-05)-DP guarantees for epoch 209 \n",
      "\n",
      "5/5 [==============================] - 2s 350ms/step - loss: 0.0530 - accuracy: 0.2703 - val_loss: 0.0534 - val_accuracy: 0.2691\n",
      "Epoch 210/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0527 - accuracy: 0.2701\n",
      " (8.613847875406321, 1e-05)-DP guarantees for epoch 210 \n",
      "\n",
      "5/5 [==============================] - 2s 344ms/step - loss: 0.0527 - accuracy: 0.2701 - val_loss: 0.0534 - val_accuracy: 0.2676\n",
      "Epoch 211/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0525 - accuracy: 0.2713\n",
      " (8.640162093797892, 1e-05)-DP guarantees for epoch 211 \n",
      "\n",
      "5/5 [==============================] - 3s 350ms/step - loss: 0.0525 - accuracy: 0.2713 - val_loss: 0.0534 - val_accuracy: 0.2689\n",
      "Epoch 212/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0527 - accuracy: 0.2711\n",
      " (8.666476313556027, 1e-05)-DP guarantees for epoch 212 \n",
      "\n",
      "5/5 [==============================] - 2s 346ms/step - loss: 0.0527 - accuracy: 0.2711 - val_loss: 0.0533 - val_accuracy: 0.2679\n",
      "Epoch 213/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0524 - accuracy: 0.2722\n",
      " (8.692790541337777, 1e-05)-DP guarantees for epoch 213 \n",
      "\n",
      "5/5 [==============================] - 3s 356ms/step - loss: 0.0524 - accuracy: 0.2722 - val_loss: 0.0532 - val_accuracy: 0.2673\n",
      "Epoch 214/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0526 - accuracy: 0.2705\n",
      " (8.719104752659717, 1e-05)-DP guarantees for epoch 214 \n",
      "\n",
      "5/5 [==============================] - 3s 355ms/step - loss: 0.0526 - accuracy: 0.2705 - val_loss: 0.0532 - val_accuracy: 0.2675\n",
      "Epoch 215/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0523 - accuracy: 0.2729\n",
      " (8.745418971706883, 1e-05)-DP guarantees for epoch 215 \n",
      "\n",
      "5/5 [==============================] - 3s 359ms/step - loss: 0.0523 - accuracy: 0.2729 - val_loss: 0.0532 - val_accuracy: 0.2674\n",
      "Epoch 216/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0525 - accuracy: 0.2733\n",
      " (8.77173318977154, 1e-05)-DP guarantees for epoch 216 \n",
      "\n",
      "5/5 [==============================] - 3s 362ms/step - loss: 0.0525 - accuracy: 0.2733 - val_loss: 0.0532 - val_accuracy: 0.2662\n",
      "Epoch 217/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0525 - accuracy: 0.2719\n",
      " (8.798047413801395, 1e-05)-DP guarantees for epoch 217 \n",
      "\n",
      "5/5 [==============================] - 3s 353ms/step - loss: 0.0525 - accuracy: 0.2719 - val_loss: 0.0531 - val_accuracy: 0.2676\n",
      "Epoch 218/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0524 - accuracy: 0.2741\n",
      " (8.82436163499698, 1e-05)-DP guarantees for epoch 218 \n",
      "\n",
      "5/5 [==============================] - 2s 348ms/step - loss: 0.0524 - accuracy: 0.2741 - val_loss: 0.0531 - val_accuracy: 0.2671\n",
      "Epoch 219/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0525 - accuracy: 0.2702\n",
      " (8.850675857122916, 1e-05)-DP guarantees for epoch 219 \n",
      "\n",
      "5/5 [==============================] - 3s 386ms/step - loss: 0.0525 - accuracy: 0.2702 - val_loss: 0.0531 - val_accuracy: 0.2672\n",
      "Epoch 220/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0527 - accuracy: 0.2709\n",
      " (8.876990076626331, 1e-05)-DP guarantees for epoch 220 \n",
      "\n",
      "5/5 [==============================] - 3s 376ms/step - loss: 0.0527 - accuracy: 0.2709 - val_loss: 0.0531 - val_accuracy: 0.2668\n",
      "Epoch 221/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0525 - accuracy: 0.2715\n",
      " (8.903304291167267, 1e-05)-DP guarantees for epoch 221 \n",
      "\n",
      "5/5 [==============================] - 3s 363ms/step - loss: 0.0525 - accuracy: 0.2715 - val_loss: 0.0531 - val_accuracy: 0.2661\n",
      "Epoch 222/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0524 - accuracy: 0.2721\n",
      " (8.929618511328595, 1e-05)-DP guarantees for epoch 222 \n",
      "\n",
      "5/5 [==============================] - 3s 378ms/step - loss: 0.0524 - accuracy: 0.2721 - val_loss: 0.0530 - val_accuracy: 0.2677\n",
      "Epoch 223/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0521 - accuracy: 0.2726\n",
      " (8.955932731489924, 1e-05)-DP guarantees for epoch 223 \n",
      "\n",
      "5/5 [==============================] - 2s 353ms/step - loss: 0.0521 - accuracy: 0.2726 - val_loss: 0.0530 - val_accuracy: 0.2686\n",
      "Epoch 224/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0521 - accuracy: 0.2727\n",
      " (8.982246951651252, 1e-05)-DP guarantees for epoch 224 \n",
      "\n",
      "5/5 [==============================] - 2s 350ms/step - loss: 0.0521 - accuracy: 0.2727 - val_loss: 0.0530 - val_accuracy: 0.2690\n",
      "Epoch 225/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0522 - accuracy: 0.2706\n",
      " (9.00856117181258, 1e-05)-DP guarantees for epoch 225 \n",
      "\n",
      "5/5 [==============================] - 3s 353ms/step - loss: 0.0522 - accuracy: 0.2706 - val_loss: 0.0529 - val_accuracy: 0.2701\n",
      "Epoch 226/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0521 - accuracy: 0.2715\n",
      " (9.034875391973909, 1e-05)-DP guarantees for epoch 226 \n",
      "\n",
      "5/5 [==============================] - 3s 396ms/step - loss: 0.0521 - accuracy: 0.2715 - val_loss: 0.0529 - val_accuracy: 0.2690\n",
      "Epoch 227/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0521 - accuracy: 0.2713\n",
      " (9.061189612135239, 1e-05)-DP guarantees for epoch 227 \n",
      "\n",
      "5/5 [==============================] - 3s 365ms/step - loss: 0.0521 - accuracy: 0.2713 - val_loss: 0.0529 - val_accuracy: 0.2702\n",
      "Epoch 228/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0520 - accuracy: 0.2729\n",
      " (9.087503832296568, 1e-05)-DP guarantees for epoch 228 \n",
      "\n",
      "5/5 [==============================] - 3s 366ms/step - loss: 0.0520 - accuracy: 0.2729 - val_loss: 0.0529 - val_accuracy: 0.2698\n",
      "Epoch 229/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0518 - accuracy: 0.2717\n",
      " (9.113818052457898, 1e-05)-DP guarantees for epoch 229 \n",
      "\n",
      "5/5 [==============================] - 3s 364ms/step - loss: 0.0518 - accuracy: 0.2717 - val_loss: 0.0528 - val_accuracy: 0.2704\n",
      "Epoch 230/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0518 - accuracy: 0.2710\n",
      " (9.140132272619226, 1e-05)-DP guarantees for epoch 230 \n",
      "\n",
      "5/5 [==============================] - 3s 371ms/step - loss: 0.0518 - accuracy: 0.2710 - val_loss: 0.0528 - val_accuracy: 0.2693\n",
      "Epoch 231/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0519 - accuracy: 0.2725\n",
      " (9.166446492780555, 1e-05)-DP guarantees for epoch 231 \n",
      "\n",
      "5/5 [==============================] - 2s 357ms/step - loss: 0.0519 - accuracy: 0.2725 - val_loss: 0.0528 - val_accuracy: 0.2674\n",
      "Epoch 232/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0517 - accuracy: 0.2743\n",
      " (9.192760712941883, 1e-05)-DP guarantees for epoch 232 \n",
      "\n",
      "5/5 [==============================] - 3s 361ms/step - loss: 0.0517 - accuracy: 0.2743 - val_loss: 0.0528 - val_accuracy: 0.2685\n",
      "Epoch 233/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0519 - accuracy: 0.2712\n",
      " (9.219074933103212, 1e-05)-DP guarantees for epoch 233 \n",
      "\n",
      "5/5 [==============================] - 3s 353ms/step - loss: 0.0519 - accuracy: 0.2712 - val_loss: 0.0527 - val_accuracy: 0.2687\n",
      "Epoch 234/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0517 - accuracy: 0.2731\n",
      " (9.24538915326454, 1e-05)-DP guarantees for epoch 234 \n",
      "\n",
      "5/5 [==============================] - 3s 370ms/step - loss: 0.0517 - accuracy: 0.2731 - val_loss: 0.0527 - val_accuracy: 0.2663\n",
      "Epoch 235/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0518 - accuracy: 0.2720\n",
      " (9.27170337342587, 1e-05)-DP guarantees for epoch 235 \n",
      "\n",
      "5/5 [==============================] - 3s 350ms/step - loss: 0.0518 - accuracy: 0.2720 - val_loss: 0.0527 - val_accuracy: 0.2663\n",
      "Epoch 236/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0515 - accuracy: 0.2729\n",
      " (9.298017593587199, 1e-05)-DP guarantees for epoch 236 \n",
      "\n",
      "5/5 [==============================] - 2s 352ms/step - loss: 0.0515 - accuracy: 0.2729 - val_loss: 0.0526 - val_accuracy: 0.2658\n",
      "Epoch 237/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0517 - accuracy: 0.2726\n",
      " (9.324331813748529, 1e-05)-DP guarantees for epoch 237 \n",
      "\n",
      "5/5 [==============================] - 2s 353ms/step - loss: 0.0517 - accuracy: 0.2726 - val_loss: 0.0526 - val_accuracy: 0.2650\n",
      "Epoch 238/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0515 - accuracy: 0.2752\n",
      " (9.350646033909857, 1e-05)-DP guarantees for epoch 238 \n",
      "\n",
      "5/5 [==============================] - 3s 357ms/step - loss: 0.0515 - accuracy: 0.2752 - val_loss: 0.0525 - val_accuracy: 0.2655\n",
      "Epoch 239/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0517 - accuracy: 0.2739\n",
      " (9.376960254071186, 1e-05)-DP guarantees for epoch 239 \n",
      "\n",
      "5/5 [==============================] - 3s 368ms/step - loss: 0.0517 - accuracy: 0.2739 - val_loss: 0.0525 - val_accuracy: 0.2665\n",
      "Epoch 240/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0515 - accuracy: 0.2736\n",
      " (9.403274474232514, 1e-05)-DP guarantees for epoch 240 \n",
      "\n",
      "5/5 [==============================] - 3s 356ms/step - loss: 0.0515 - accuracy: 0.2736 - val_loss: 0.0525 - val_accuracy: 0.2673\n",
      "Epoch 241/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0517 - accuracy: 0.2729\n",
      " (9.429588694393843, 1e-05)-DP guarantees for epoch 241 \n",
      "\n",
      "5/5 [==============================] - 3s 364ms/step - loss: 0.0517 - accuracy: 0.2729 - val_loss: 0.0524 - val_accuracy: 0.2674\n",
      "Epoch 242/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0518 - accuracy: 0.2746\n",
      " (9.455902914555171, 1e-05)-DP guarantees for epoch 242 \n",
      "\n",
      "5/5 [==============================] - 3s 359ms/step - loss: 0.0518 - accuracy: 0.2746 - val_loss: 0.0525 - val_accuracy: 0.2694\n",
      "Epoch 243/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0515 - accuracy: 0.2756\n",
      " (9.482217134716501, 1e-05)-DP guarantees for epoch 243 \n",
      "\n",
      "5/5 [==============================] - 2s 357ms/step - loss: 0.0515 - accuracy: 0.2756 - val_loss: 0.0524 - val_accuracy: 0.2699\n",
      "Epoch 244/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0512 - accuracy: 0.2760\n",
      " (9.50853135487783, 1e-05)-DP guarantees for epoch 244 \n",
      "\n",
      "5/5 [==============================] - 3s 367ms/step - loss: 0.0512 - accuracy: 0.2760 - val_loss: 0.0524 - val_accuracy: 0.2712\n",
      "Epoch 245/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0514 - accuracy: 0.2756\n",
      " (9.534845575173634, 1e-05)-DP guarantees for epoch 245 \n",
      "\n",
      "5/5 [==============================] - 3s 360ms/step - loss: 0.0514 - accuracy: 0.2756 - val_loss: 0.0523 - val_accuracy: 0.2700\n",
      "Epoch 246/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0512 - accuracy: 0.2758\n",
      " (9.561159795911662, 1e-05)-DP guarantees for epoch 246 \n",
      "\n",
      "5/5 [==============================] - 2s 344ms/step - loss: 0.0512 - accuracy: 0.2758 - val_loss: 0.0523 - val_accuracy: 0.2716\n",
      "Epoch 247/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0512 - accuracy: 0.2783\n",
      " (9.587474015660208, 1e-05)-DP guarantees for epoch 247 \n",
      "\n",
      "5/5 [==============================] - 2s 352ms/step - loss: 0.0512 - accuracy: 0.2783 - val_loss: 0.0523 - val_accuracy: 0.2719\n",
      "Epoch 248/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0514 - accuracy: 0.2768\n",
      " (9.613788235533915, 1e-05)-DP guarantees for epoch 248 \n",
      "\n",
      "5/5 [==============================] - 3s 366ms/step - loss: 0.0514 - accuracy: 0.2768 - val_loss: 0.0522 - val_accuracy: 0.2711\n",
      "Epoch 249/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0511 - accuracy: 0.2780\n",
      " (9.64006012187098, 1e-05)-DP guarantees for epoch 249 \n",
      "\n",
      "5/5 [==============================] - 2s 352ms/step - loss: 0.0511 - accuracy: 0.2780 - val_loss: 0.0522 - val_accuracy: 0.2720\n",
      "Epoch 250/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0511 - accuracy: 0.2746\n",
      " (9.665736679745127, 1e-05)-DP guarantees for epoch 250 \n",
      "\n",
      "5/5 [==============================] - 3s 352ms/step - loss: 0.0511 - accuracy: 0.2746 - val_loss: 0.0522 - val_accuracy: 0.2731\n",
      "Epoch 251/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0509 - accuracy: 0.2777\n",
      " (9.690604545814235, 1e-05)-DP guarantees for epoch 251 \n",
      "\n",
      "5/5 [==============================] - 3s 357ms/step - loss: 0.0509 - accuracy: 0.2777 - val_loss: 0.0522 - val_accuracy: 0.2727\n",
      "Epoch 252/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0511 - accuracy: 0.2793\n",
      " (9.714604392289775, 1e-05)-DP guarantees for epoch 252 \n",
      "\n",
      "5/5 [==============================] - 3s 354ms/step - loss: 0.0511 - accuracy: 0.2793 - val_loss: 0.0522 - val_accuracy: 0.2701\n",
      "Epoch 253/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0511 - accuracy: 0.2751\n",
      " (9.737670917278972, 1e-05)-DP guarantees for epoch 253 \n",
      "\n",
      "5/5 [==============================] - 3s 354ms/step - loss: 0.0511 - accuracy: 0.2751 - val_loss: 0.0522 - val_accuracy: 0.2719\n",
      "Epoch 254/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0510 - accuracy: 0.2764\n",
      " (9.759732027763015, 1e-05)-DP guarantees for epoch 254 \n",
      "\n",
      "5/5 [==============================] - 3s 365ms/step - loss: 0.0510 - accuracy: 0.2764 - val_loss: 0.0522 - val_accuracy: 0.2718\n",
      "Epoch 255/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0510 - accuracy: 0.2765\n",
      " (9.780707877727917, 1e-05)-DP guarantees for epoch 255 \n",
      "\n",
      "5/5 [==============================] - 3s 341ms/step - loss: 0.0510 - accuracy: 0.2765 - val_loss: 0.0522 - val_accuracy: 0.2708\n",
      "Epoch 256/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0511 - accuracy: 0.2758\n",
      " (9.80055660088896, 1e-05)-DP guarantees for epoch 256 \n",
      "\n",
      "5/5 [==============================] - 3s 364ms/step - loss: 0.0511 - accuracy: 0.2758 - val_loss: 0.0521 - val_accuracy: 0.2726\n",
      "Epoch 257/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0508 - accuracy: 0.2767\n",
      " (9.820083418023108, 1e-05)-DP guarantees for epoch 257 \n",
      "\n",
      "5/5 [==============================] - 2s 360ms/step - loss: 0.0508 - accuracy: 0.2767 - val_loss: 0.0520 - val_accuracy: 0.2722\n",
      "Epoch 258/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0511 - accuracy: 0.2740\n",
      " (9.839610235157256, 1e-05)-DP guarantees for epoch 258 \n",
      "\n",
      "5/5 [==============================] - 3s 348ms/step - loss: 0.0511 - accuracy: 0.2740 - val_loss: 0.0520 - val_accuracy: 0.2707\n",
      "Epoch 259/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0507 - accuracy: 0.2782\n",
      " (9.859137052291402, 1e-05)-DP guarantees for epoch 259 \n",
      "\n",
      "5/5 [==============================] - 3s 367ms/step - loss: 0.0507 - accuracy: 0.2782 - val_loss: 0.0520 - val_accuracy: 0.2731\n",
      "Epoch 260/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0510 - accuracy: 0.2761\n",
      " (9.87866386942555, 1e-05)-DP guarantees for epoch 260 \n",
      "\n",
      "5/5 [==============================] - 3s 353ms/step - loss: 0.0510 - accuracy: 0.2761 - val_loss: 0.0519 - val_accuracy: 0.2707\n",
      "Epoch 261/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0509 - accuracy: 0.2751\n",
      " (9.898190686559698, 1e-05)-DP guarantees for epoch 261 \n",
      "\n",
      "5/5 [==============================] - 3s 379ms/step - loss: 0.0509 - accuracy: 0.2751 - val_loss: 0.0519 - val_accuracy: 0.2724\n",
      "Epoch 262/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0511 - accuracy: 0.2766\n",
      " (9.917717503693844, 1e-05)-DP guarantees for epoch 262 \n",
      "\n",
      "5/5 [==============================] - 2s 352ms/step - loss: 0.0511 - accuracy: 0.2766 - val_loss: 0.0520 - val_accuracy: 0.2729\n",
      "Epoch 263/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0508 - accuracy: 0.2773\n",
      " (9.937244320827991, 1e-05)-DP guarantees for epoch 263 \n",
      "\n",
      "5/5 [==============================] - 2s 342ms/step - loss: 0.0508 - accuracy: 0.2773 - val_loss: 0.0520 - val_accuracy: 0.2708\n",
      "Epoch 264/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0507 - accuracy: 0.2777\n",
      " (9.95677113796214, 1e-05)-DP guarantees for epoch 264 \n",
      "\n",
      "5/5 [==============================] - 3s 366ms/step - loss: 0.0507 - accuracy: 0.2777 - val_loss: 0.0519 - val_accuracy: 0.2733\n",
      "Epoch 265/265\n",
      "5/5 [==============================] - ETA: 0s - loss: 0.0505 - accuracy: 0.2784\n",
      " (9.976297955096285, 1e-05)-DP guarantees for epoch 265 \n",
      "\n",
      "5/5 [==============================] - 3s 378ms/step - loss: 0.0505 - accuracy: 0.2784 - val_loss: 0.0519 - val_accuracy: 0.2738\n"
     ]
    }
   ],
   "source": [
    "hist = model.fit(\n",
    "    ds_train,\n",
    "    epochs=num_epochs,\n",
    "    validation_data=ds_test,\n",
    "    callbacks=[\n",
    "        # accounting is done thanks to a callback\n",
    "        DP_Accountant(log_fn=\"logging\"),  # wandb.log also available.\n",
    "    ],\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8e139678-6ec6-4a2e-980b-83059c98c48b",
   "metadata": {},
   "source": [
    "This final val_accuracy is compliant with results reported in other framework. For comparison, in Opacus tutorials, the Resnet 18 reaches 60% val_accuracy at $\\epsilon=47$, but 15% at $\\epsilon=13$. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "db636e0c-0334-45ee-b953-e4cc85bb7d8e",
   "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.8.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
