{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "01f324f2-28c5-4ef7-9529-33e8685b869e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-05-11 11:27:08.770945: E external/local_xla/xla/stream_executor/cuda/cuda_fft.cc:467] Unable to register cuFFT factory: Attempting to register factory for plugin cuFFT when one has already been registered\n",
      "WARNING: All log messages before absl::InitializeLog() is called are written to STDERR\n",
      "E0000 00:00:1746934028.790733 4176544 cuda_dnn.cc:8579] Unable to register cuDNN factory: Attempting to register factory for plugin cuDNN when one has already been registered\n",
      "E0000 00:00:1746934028.796866 4176544 cuda_blas.cc:1407] Unable to register cuBLAS factory: Attempting to register factory for plugin cuBLAS when one has already been registered\n",
      "W0000 00:00:1746934028.812909 4176544 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1746934028.812937 4176544 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1746934028.812941 4176544 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "W0000 00:00:1746934028.812944 4176544 computation_placer.cc:177] computation placer already registered. Please check linkage and avoid linking the same target more than once.\n",
      "2025-05-11 11:27:08.817584: I tensorflow/core/platform/cpu_feature_guard.cc:210] This TensorFlow binary is optimized to use available CPU instructions in performance-critical operations.\n",
      "To enable the following instructions: AVX2 FMA, in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    }
   ],
   "source": [
    "import tensorflow as tf\n",
    "#from matplotlib import pyplot as plt\n",
    "import numpy as np\n",
    "from tensorflow.keras import layers\n",
    "import tensorflow.keras.backend as K\n",
    "\n",
    "import os\n",
    "import sys\n",
    "os.environ[\"KMP_DUPLICATE_LIB_OK\"]=\"TRUE\"\n",
    "\n",
    "# Get the directory of the current script\n",
    "current_working_directory = os.getcwd()\n",
    "\n",
    "# Construct the absolute path to 'Home/function' based on the script's directory\n",
    "relative_path = \"functions\"\n",
    "absolute_path = os.path.abspath(os.path.join(current_working_directory,  '..', relative_path))\n",
    "sys.path.append(absolute_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "40e6af87-fe1e-4c26-8a26-73f448aaeb25",
   "metadata": {},
   "outputs": [],
   "source": [
    "import scipy.io as sio\n",
    "import numpy as np\n",
    "\n",
    "# Load training data\n",
    "train_data = sio.loadmat('./datasets/svhn/train_32x32.mat')\n",
    "x_train = np.transpose(train_data['X'], (3, 0, 1, 2))  # Convert to (N, H, W, C)\n",
    "y_train = train_data['y'].flatten()\n",
    "y_train[y_train == 10] = 0  # Convert label 10 to 0\n",
    "\n",
    "# Load test data\n",
    "test_data = sio.loadmat('./datasets/svhn/test_32x32.mat')\n",
    "x_test = np.transpose(test_data['X'], (3, 0, 1, 2))\n",
    "y_test = test_data['y'].flatten()\n",
    "y_test[y_test == 10] = 0\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "7811230a-aeab-4ebb-9e86-c0f8f10e6452",
   "metadata": {},
   "outputs": [],
   "source": [
    "x_train = x_train.astype('float32') / 255.0\n",
    "x_test = x_test.astype('float32') / 255.0\n",
    "\n",
    "Y_train =  tf.keras.utils.to_categorical(y_train, num_classes=10)\n",
    "Y_test =  tf.keras.utils.to_categorical(y_test, num_classes=10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "6e4e8dd5-304d-4ef6-ab9c-1e3321da2aa2",
   "metadata": {},
   "outputs": [],
   "source": [
    "NUM_EPOCH = 200\n",
    "\n",
    "# training SNR\n",
    "eb_n0 = 25\n",
    "rate = 1 # code rate \n",
    "\n",
    "#trn, tst = utils.get_mnist()\n",
    "\n",
    "# ##### KSG MI estimator #######################\n",
    "# settings = {'kraskov_k': 3}\n",
    "# gpu_est = est.OpenCLKraskovMI(settings = settings)\n",
    "# usage: MI = estimator.estimate(var1, var2)\n",
    "\n",
    "##### setting for communication channel ######\n",
    "\n",
    "def getnoisevariance(SNR,rate,P=1):\n",
    "    # the SNR in args[0] is actually EbN0\n",
    "    snrdB = SNR + 10*np.log10(rate)\n",
    "    snr = 10.0**(snrdB/10.0)\n",
    "    #P_avg = 1\n",
    "    N0 = P/snr\n",
    "    return (N0/2)\n",
    "\n",
    "noise_var = getnoisevariance(eb_n0,rate,P=1)\n",
    "\n",
    "##############################################\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "8441a4ed-8c15-43e6-bcf1-239d3656b89f",
   "metadata": {},
   "outputs": [],
   "source": [
    "### normalized Input before \n",
    "class GaussianNoiseLayer(layers.Layer):\n",
    "    def __init__(self, stddev, **kwargs):\n",
    "        super(GaussianNoiseLayer, self).__init__(**kwargs)\n",
    "        self.stddev = stddev\n",
    "    \n",
    "    def call(self, inputs, training=None):\n",
    "        if training:\n",
    "            noise = tf.random.normal(shape=tf.shape(inputs), mean=0.0, stddev=self.stddev)\n",
    "            return inputs + noise\n",
    "        else:\n",
    "            noise = tf.random.normal(shape=tf.shape(inputs), mean=0.0, stddev=self.stddev)\n",
    "            return inputs + noise\n",
    "    \n",
    "    def get_config(self):\n",
    "        config = super(GaussianNoiseLayer, self).get_config()\n",
    "        config.update({'noise_var': self.stddev})\n",
    "        return config"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d56b5bed-6a99-407d-9f7a-b91518d03bd2",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "class getMIOutput(tf.keras.callbacks.Callback):\n",
    "    def __init__(self, trn, tst, snr, num_selection, do_save_func=None, *args, **kwargs):\n",
    "        super().__init__(*args, **kwargs)\n",
    "        self.trn            = trn\n",
    "        self.tst            = tst\n",
    "        self.snr            = snr\n",
    "        self.num_selection  = num_selection\n",
    "        self.do_save_func   = do_save_func\n",
    "        self.datalist       = []\n",
    "\n",
    "    def on_train_begin(self, logs=None):\n",
    "        # decide which layer(s) we care about—here: layer index 7\n",
    "        self.target_idx = 7\n",
    "        \n",
    "        # build a model that maps the original inputs -> the output of layer 7\n",
    "        self.activation_model = tf.keras.Model(\n",
    "            inputs  = self.model.input,\n",
    "            outputs = self.model.layers[self.target_idx].output\n",
    "        )\n",
    "\n",
    "    def on_epoch_end(self, epoch, logs=None):\n",
    "        # optional skip logic\n",
    "        if self.do_save_func is not None and not self.do_save_func(epoch):\n",
    "            return\n",
    "\n",
    "        # make sure we're in inference mode\n",
    "        # (BatchNorm / Dropout will already be disabled by predict())\n",
    "        x_sel = self.trn[:self.num_selection]\n",
    "\n",
    "        # get activations as a NumPy array\n",
    "        acts = self.activation_model.predict(x_sel, verbose=0)\n",
    "\n",
    "        # package & save\n",
    "        data = {\n",
    "            'activity_tst': [acts]\n",
    "        }\n",
    "        self.datalist.append({'epoch': epoch, 'data': data})\n",
    "\n",
    "    \n",
    "        # Switch back to trainable mode (optional, if training continues after callback)\n",
    "        self.model.trainable=True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "e5d53613-26fd-4b9b-9caa-575224894ef8",
   "metadata": {},
   "outputs": [],
   "source": [
    "label2_list = np.array([[0,1,2,3,4],[1,2,3,4,5],[2,3,4,5,6],[3,4,5,6,7],[4,5,6,7,8],[5,6,7,8,9]])\n",
    "SAMPLE_NUM = 10000\n",
    "\n",
    "#EPOCH  = 2\n",
    "def do_report_new(epoch):\n",
    "    # Only log activity for some epochs.  Mainly this is to make things run faster.\n",
    "    if epoch < 20:       # Log for all first 20 epochs\n",
    "        return True\n",
    "    elif epoch < 50:    # Then for every 5th epoch\n",
    "        return (epoch % 5 == 0)\n",
    "    elif epoch < 200:    # Then every 10th\n",
    "        return (epoch % 10 == 0)\n",
    "    else:                # Then every 100th\n",
    "        return (epoch % 100 == 0)\n",
    "\n",
    "SNR = eb_n0\n",
    "    \n",
    "reporter = getMIOutput(trn=x_train[:20000], \n",
    "                           tst=x_test[:5000], \n",
    "                           snr=SNR,\n",
    "                           num_selection = SAMPLE_NUM,\n",
    "                          do_save_func=do_report_new)\n",
    "\n",
    "\n",
    "def run_simulation():\n",
    "    tf.keras.backend.clear_session()\n",
    "    tf.random.set_seed(42)\n",
    "\n",
    "    ############ Model Structure ###############################\n",
    "\n",
    "    # input_layer  = layers.Input(shape=(32, 32, 3))\n",
    "    # encoder_1 = layers.Conv2D(96, (3, 3), activation='relu', padding='same')(input_layer)\n",
    "    # encoder_2 = layers.Conv2D(32, (3, 3), activation='relu', padding='same')(encoder_1)\n",
    "    # maxpool_2 = layers.MaxPooling2D((2, 2))(encoder_2)\n",
    "    # CE_cnn_1 = layers.Conv2D(32, (3, 3), activation='relu', padding='same', strides=2)(maxpool_2)\n",
    "    # flatten_1 = layers.Flatten()(CE_cnn_1)\n",
    "    # CE_dense_2 = layers.Dense(512, activation='relu')(flatten_1)\n",
    "    # CE_output = tf.keras.layers.Dense(10,activation = 'softmax',name='CE')(CE_dense_2)\n",
    "\n",
    "\n",
    "    input_layer  = layers.Input(shape=(32, 32, 3))\n",
    "    # First Convolutional Block\n",
    "    encoder_1 = layers.Conv2D(16, (3, 3), activation='relu', padding='same')(input_layer)\n",
    "    encoder_1 = layers.Conv2D(16, (3, 3), activation='relu', padding='same')(encoder_1)\n",
    "    #BN_1 = layers.BatchNormalization()(encoder_1)\n",
    "    maxpool_1 = layers.MaxPooling2D((2, 2))(encoder_1)\n",
    "    #dropout_1 = layers.Dropout(0.5)(maxpool_1)\n",
    "\n",
    "    # Second Convolutional Block\n",
    "    encoder_2 = layers.Conv2D(32, (3, 3), activation='relu', padding='same')(maxpool_1)\n",
    "    encoder_2 = layers.Conv2D(32, (3, 3), activation='relu', padding='same')(encoder_2)\n",
    "    #BN_2 = layers.BatchNormalization()(encoder_2)\n",
    "    maxpool_2 = layers.MaxPooling2D((2, 2))(encoder_2)\n",
    "    #dropout_2 = layers.Dropout(0.25)(maxpool_2)\n",
    "\n",
    "    # Global Average Pooling Layer\n",
    "    global_avg_pool = layers.GlobalAveragePooling2D()(encoder_2)\n",
    "\n",
    "    # Fully Connected Layers\n",
    "    dense_1 = layers.Dense(256, activation='relu')(global_avg_pool)\n",
    "    #dense_1 = layers.Dense(64, activation='relu')(dense_1)\n",
    "    #dropout_3 = layers.Dropout(0.5)(dense_1)\n",
    "\n",
    "    # Output Layer\n",
    "    CE_output = layers.Dense(10, activation='softmax', name='CE')(dense_1)\n",
    "\n",
    "\n",
    "    model = tf.keras.Model(inputs = input_layer, outputs = [CE_output])\n",
    "    lr_schedule = tf.keras.optimizers.schedules.ExponentialDecay(\n",
    "    initial_learning_rate=1e-3,\n",
    "    decay_steps=10000,\n",
    "    decay_rate=0.9)\n",
    "    opt = tf.keras.optimizers.SGD(learning_rate=lr_schedule)\n",
    "\n",
    "    model.compile(optimizer=opt,\n",
    "              loss = {'CE' : 'categorical_crossentropy'},\n",
    "              metrics = {'CE' : 'accuracy'},\n",
    "              loss_weights=[1])\n",
    "\n",
    "    #     print(\"current snr: \",SNR)\n",
    "    # #     print(\"====================\")\n",
    "\n",
    "    history = model.fit(x=x_train[:20000], y=Y_train[:20000],\n",
    "                        batch_size=512,\n",
    "                        epochs=EPOCH,\n",
    "                        verbose=1,\n",
    "                        validation_data=(x_test[:5000], Y_test[:5000]),\n",
    "                        callbacks=[reporter,])\n",
    "    \n",
    "    data = reporter.datalist\n",
    "    return data\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "    #############################\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "deabcba3-d185-4cee-a54b-6b6477913a71",
   "metadata": {},
   "outputs": [],
   "source": [
    "\"\"\"\n",
    "normalizing method\n",
    "\"\"\"\n",
    "def global_normalize_inf_norm(data_orig, C, p=2, dim_correction=False):\n",
    "    # flatten each sample to a vector\n",
    "    data = data_orig.reshape(data_orig.shape[0], -1)\n",
    "\n",
    "    # subtract per-feature mean, take absolute\n",
    "    means = np.mean(data, axis=0)\n",
    "    data_centered = np.abs(data - means)\n",
    "\n",
    "    # instead of torch.max + from_numpy, use np.max\n",
    "    # this gives you a 1-D array of length N\n",
    "    row_max = np.max(data_centered, axis=1)\n",
    "\n",
    "    # then take the overall mean\n",
    "    norm = np.mean(row_max)\n",
    "\n",
    "    # apply scaling\n",
    "    return C * (data_orig - means) / (norm + 1e-7)\n",
    "\n",
    "def normalize_data_new(data, C):\n",
    "    # Reshape data as before\n",
    "    data = np.reshape(data, (data.shape[0], int(data.size / data.shape[0])))\n",
    "    \n",
    "    # Subtract the mean\n",
    "    means = np.mean(data, axis=0)\n",
    "    data = data - means\n",
    "    \n",
    "    # Compute the normalization factor\n",
    "    norm = np.sqrt(np.mean(np.sum(data ** 2, axis=1)))\n",
    "    \n",
    "    # Normalize the data\n",
    "    data *= C / norm\n",
    "    \n",
    "    return data, norm ** 2\n",
    "\n",
    "def normalize_data_old(data,C):\n",
    "    data = np.reshape(data, (data.shape[0],int(data.size/data.shape[0])))\n",
    "    \n",
    "    means =  np.mean(data, axis=0) # find the mean for each dimension \n",
    "    data = data - means # data - means for each dimension\n",
    "    \n",
    "    norm = np.tile(np.sqrt(np.mean(data ** 2 ,axis=0)),(data.shape[0],1))\n",
    "#     norm =  np.sqrt(np.mean(np.sum(sqz,axis=1)))\n",
    "    normalized_data = C*data / (norm+(0.0000001))\n",
    "    \n",
    "    return normalized_data,norm**2\n",
    "\n",
    "# def global_normalize_inf_norm(data_orig, C):\n",
    "#     # Reshape data as before\n",
    "#     data = np.reshape(data_orig, (data_orig.shape[0], int(data_orig.size / data_orig.shape[0])))\n",
    "    \n",
    "#     # Subtract the mean\n",
    "#     means = np.mean(data, axis=0)\n",
    "#     data = np.abs(data - means)\n",
    "    \n",
    "#     # Compute the normalization factor\n",
    "\n",
    "#     norm = np.mean(np.max(data,1))\n",
    "#     #print(norm)\n",
    "\n",
    "#     # Normalize the data\n",
    "#     data = data_orig * C / norm\n",
    "    \n",
    "#     return data\n",
    "\n",
    "# def global_normalize_mine(data_orig, C):\n",
    "#     # Reshape data as before\n",
    "#     data = np.reshape(data_orig, (data_orig.shape[0], int(data_orig.size / data_orig.shape[0])))\n",
    "    \n",
    "#     # Subtract the mean\n",
    "#     means = np.mean(data, axis=0)\n",
    "#     data = np.abs(data - means)\n",
    "    \n",
    "#     # Compute the normalization factor\n",
    "#     # norm = np.sqrt(np.mean(np.sum(data ** 2, axis=1)))\n",
    "#     # linalg.norm(x, ord=None, \n",
    "#     norm = np.sqrt(np.mean(np.sum(data ** 2, axis=1)))\n",
    "#     #norm = norm/ np.sqrt(data.shape[1])\n",
    "    \n",
    "#     # print(norm)\n",
    "#     # Normalize the data\n",
    "    \n",
    "#     data = C*data_orig / norm\n",
    "    \n",
    "#     return data\n",
    "\n",
    "\n",
    "def global_normalize_mine(data_orig, C, p=2,dim_correction= False):\n",
    "    # Reshape data as before\n",
    "    data = np.reshape(data_orig, (data_orig.shape[0], int(data_orig.size / data_orig.shape[0])))\n",
    "    \n",
    "    # Subtract the mean\n",
    "    means = np.mean(data, axis=0)\n",
    "    data = np.abs(data - means)\n",
    "  \n",
    "    norm = np.sqrt(np.mean(np.sum(data ** 2, axis=1)))\n",
    "    norm = norm/ np.sqrt(data.shape[1])\n",
    "\n",
    "    data = C*(data_orig-means) / norm\n",
    "    return data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "5cc2d0c7-156e-47de-b69b-95ea68777155",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "start estimating\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1746934039.092474 4176544 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 79091 MB memory:  -> device: 0, name: NVIDIA A100-SXM4-80GB, pci bus id: 0000:4e:00.0, compute capability: 8.0\n",
      "I0000 00:00:1746934039.098033 4176544 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:1 with 54890 MB memory:  -> device: 1, name: NVIDIA A100-SXM4-80GB, pci bus id: 0000:87:00.0, compute capability: 8.0\n",
      "I0000 00:00:1746934039.099738 4176544 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:2 with 44993 MB memory:  -> device: 2, name: NVIDIA A100-SXM4-80GB, pci bus id: 0000:90:00.0, compute capability: 8.0\n",
      "I0000 00:00:1746934039.101469 4176544 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:3 with 79089 MB memory:  -> device: 3, name: NVIDIA A100-SXM4-80GB, pci bus id: 0000:b7:00.0, compute capability: 8.0\n",
      "I0000 00:00:1746934039.103131 4176544 gpu_device.cc:2019] Created device /job:localhost/replica:0/task:0/device:GPU:4 with 54616 MB memory:  -> device: 4, name: NVIDIA A100-SXM4-80GB, pci bus id: 0000:bd:00.0, compute capability: 8.0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/200\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING: All log messages before absl::InitializeLog() is called are written to STDERR\n",
      "I0000 00:00:1746934042.156995 4177115 service.cc:152] XLA service 0x7fc6f0009680 initialized for platform CUDA (this does not guarantee that XLA will be used). Devices:\n",
      "I0000 00:00:1746934042.157035 4177115 service.cc:160]   StreamExecutor device (0): NVIDIA A100-SXM4-80GB, Compute Capability 8.0\n",
      "I0000 00:00:1746934042.157040 4177115 service.cc:160]   StreamExecutor device (1): NVIDIA A100-SXM4-80GB, Compute Capability 8.0\n",
      "I0000 00:00:1746934042.157044 4177115 service.cc:160]   StreamExecutor device (2): NVIDIA A100-SXM4-80GB, Compute Capability 8.0\n",
      "I0000 00:00:1746934042.157048 4177115 service.cc:160]   StreamExecutor device (3): NVIDIA A100-SXM4-80GB, Compute Capability 8.0\n",
      "I0000 00:00:1746934042.157052 4177115 service.cc:160]   StreamExecutor device (4): NVIDIA A100-SXM4-80GB, Compute Capability 8.0\n",
      "2025-05-11 11:27:22.197375: I tensorflow/compiler/mlir/tensorflow/utils/dump_mlir_util.cc:269] disabling MLIR crash reproducer, set env var `MLIR_CRASH_REPRODUCER_DIRECTORY` to enable.\n",
      "I0000 00:00:1746934042.311079 4177115 cuda_dnn.cc:529] Loaded cuDNN version 90300\n",
      "2025-05-11 11:27:24.805706: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_225', 4 bytes spill stores, 4 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:24.910232: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_218', 44 bytes spill stores, 52 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:24.938765: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_533_0', 20 bytes spill stores, 20 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:25.004471: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_531_0', 136 bytes spill stores, 136 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:25.090788: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_218', 16 bytes spill stores, 16 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:25.095777: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_218', 40 bytes spill stores, 40 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:25.126064: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_225', 128 bytes spill stores, 128 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:25.156054: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_218', 4 bytes spill stores, 8 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:25.200952: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_533', 328 bytes spill stores, 328 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:25.269644: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_533', 132 bytes spill stores, 132 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:25.297272: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_533', 3892 bytes spill stores, 3884 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:25.333993: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_531', 200 bytes spill stores, 200 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:25.349461: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_533', 3220 bytes spill stores, 3224 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:25.352293: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_533', 272 bytes spill stores, 272 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:25.373426: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_225', 76 bytes spill stores, 112 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:25.431294: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_531', 8 bytes spill stores, 8 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:25.570310: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_533', 4400 bytes spill stores, 4316 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:25.638684: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_533', 4888 bytes spill stores, 4888 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:25.660246: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_531', 732 bytes spill stores, 732 bytes spill loads\n",
      "\n",
      "Could not load symbol cuFuncGetName. Error: /lib/x86_64-linux-gnu/libcuda.so.1: undefined symbol: cuFuncGetName\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[1m28/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━\u001b[0m\u001b[37m━━━━━━\u001b[0m \u001b[1m0s\u001b[0m 6ms/step - accuracy: 0.1174 - loss: 2.3015 "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "I0000 00:00:1746934048.993794 4177115 device_compiler.h:188] Compiled cluster using XLA!  This line is logged at most once for the lifetime of the process.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[1m39/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m━\u001b[0m \u001b[1m0s\u001b[0m 6ms/step - accuracy: 0.1174 - loss: 2.3014"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-05-11 11:27:30.841135: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_225', 4 bytes spill stores, 4 bytes spill loads\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 99ms/step - accuracy: 0.1174 - loss: 2.3014"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-05-11 11:27:35.265868: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_113', 8 bytes spill stores, 8 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:35.319678: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_113', 8 bytes spill stores, 8 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:35.486022: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_113', 8 bytes spill stores, 8 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:35.506909: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_113', 8 bytes spill stores, 8 bytes spill loads\n",
      "\n",
      "2025-05-11 11:27:35.545612: I external/local_xla/xla/stream_executor/cuda/subprocess_compilation.cc:346] ptxas warning : Registers are spilled to local memory in function 'gemm_fusion_dot_120', 128 bytes spill stores, 128 bytes spill loads\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m17s\u001b[0m 249ms/step - accuracy: 0.1174 - loss: 2.3014 - val_accuracy: 0.1324 - val_loss: 2.3005\n",
      "Epoch 2/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 38ms/step - accuracy: 0.1399 - loss: 2.3002 - val_accuracy: 0.1786 - val_loss: 2.2991\n",
      "Epoch 3/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 35ms/step - accuracy: 0.1787 - loss: 2.2990 - val_accuracy: 0.1976 - val_loss: 2.2978\n",
      "Epoch 4/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 36ms/step - accuracy: 0.1854 - loss: 2.2979 - val_accuracy: 0.1976 - val_loss: 2.2966\n",
      "Epoch 5/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 36ms/step - accuracy: 0.1854 - loss: 2.2967 - val_accuracy: 0.1976 - val_loss: 2.2953\n",
      "Epoch 6/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 40ms/step - accuracy: 0.1854 - loss: 2.2956 - val_accuracy: 0.1976 - val_loss: 2.2941\n",
      "Epoch 7/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 37ms/step - accuracy: 0.1854 - loss: 2.2945 - val_accuracy: 0.1976 - val_loss: 2.2928\n",
      "Epoch 8/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 38ms/step - accuracy: 0.1854 - loss: 2.2934 - val_accuracy: 0.1976 - val_loss: 2.2916\n",
      "Epoch 9/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 39ms/step - accuracy: 0.1854 - loss: 2.2923 - val_accuracy: 0.1976 - val_loss: 2.2904\n",
      "Epoch 10/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 37ms/step - accuracy: 0.1854 - loss: 2.2912 - val_accuracy: 0.1976 - val_loss: 2.2893\n",
      "Epoch 11/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 37ms/step - accuracy: 0.1854 - loss: 2.2902 - val_accuracy: 0.1976 - val_loss: 2.2881\n",
      "Epoch 12/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 37ms/step - accuracy: 0.1854 - loss: 2.2892 - val_accuracy: 0.1976 - val_loss: 2.2870\n",
      "Epoch 13/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 36ms/step - accuracy: 0.1854 - loss: 2.2882 - val_accuracy: 0.1976 - val_loss: 2.2859\n",
      "Epoch 14/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 35ms/step - accuracy: 0.1854 - loss: 2.2872 - val_accuracy: 0.1976 - val_loss: 2.2848\n",
      "Epoch 15/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 38ms/step - accuracy: 0.1854 - loss: 2.2862 - val_accuracy: 0.1976 - val_loss: 2.2838\n",
      "Epoch 16/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 35ms/step - accuracy: 0.1854 - loss: 2.2853 - val_accuracy: 0.1976 - val_loss: 2.2827\n",
      "Epoch 17/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 37ms/step - accuracy: 0.1854 - loss: 2.2844 - val_accuracy: 0.1976 - val_loss: 2.2817\n",
      "Epoch 18/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 35ms/step - accuracy: 0.1854 - loss: 2.2835 - val_accuracy: 0.1976 - val_loss: 2.2807\n",
      "Epoch 19/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 35ms/step - accuracy: 0.1854 - loss: 2.2826 - val_accuracy: 0.1976 - val_loss: 2.2797\n",
      "Epoch 20/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 37ms/step - accuracy: 0.1854 - loss: 2.2817 - val_accuracy: 0.1976 - val_loss: 2.2787\n",
      "Epoch 21/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 36ms/step - accuracy: 0.1854 - loss: 2.2808 - val_accuracy: 0.1976 - val_loss: 2.2778\n",
      "Epoch 22/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2800 - val_accuracy: 0.1976 - val_loss: 2.2768\n",
      "Epoch 23/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2791 - val_accuracy: 0.1976 - val_loss: 2.2759\n",
      "Epoch 24/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2783 - val_accuracy: 0.1976 - val_loss: 2.2749\n",
      "Epoch 25/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2775 - val_accuracy: 0.1976 - val_loss: 2.2740\n",
      "Epoch 26/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 36ms/step - accuracy: 0.1854 - loss: 2.2767 - val_accuracy: 0.1976 - val_loss: 2.2731\n",
      "Epoch 27/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2759 - val_accuracy: 0.1976 - val_loss: 2.2722\n",
      "Epoch 28/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2751 - val_accuracy: 0.1976 - val_loss: 2.2713\n",
      "Epoch 29/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 15ms/step - accuracy: 0.1854 - loss: 2.2743 - val_accuracy: 0.1976 - val_loss: 2.2704\n",
      "Epoch 30/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2735 - val_accuracy: 0.1976 - val_loss: 2.2696\n",
      "Epoch 31/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 36ms/step - accuracy: 0.1854 - loss: 2.2727 - val_accuracy: 0.1976 - val_loss: 2.2687\n",
      "Epoch 32/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 15ms/step - accuracy: 0.1854 - loss: 2.2720 - val_accuracy: 0.1976 - val_loss: 2.2679\n",
      "Epoch 33/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2713 - val_accuracy: 0.1976 - val_loss: 2.2670\n",
      "Epoch 34/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2705 - val_accuracy: 0.1976 - val_loss: 2.2662\n",
      "Epoch 35/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2698 - val_accuracy: 0.1976 - val_loss: 2.2654\n",
      "Epoch 36/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 36ms/step - accuracy: 0.1854 - loss: 2.2691 - val_accuracy: 0.1976 - val_loss: 2.2646\n",
      "Epoch 37/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2684 - val_accuracy: 0.1976 - val_loss: 2.2638\n",
      "Epoch 38/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2677 - val_accuracy: 0.1976 - val_loss: 2.2630\n",
      "Epoch 39/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2670 - val_accuracy: 0.1976 - val_loss: 2.2622\n",
      "Epoch 40/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2664 - val_accuracy: 0.1976 - val_loss: 2.2614\n",
      "Epoch 41/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 36ms/step - accuracy: 0.1854 - loss: 2.2657 - val_accuracy: 0.1976 - val_loss: 2.2607\n",
      "Epoch 42/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2650 - val_accuracy: 0.1976 - val_loss: 2.2599\n",
      "Epoch 43/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2644 - val_accuracy: 0.1976 - val_loss: 2.2592\n",
      "Epoch 44/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2638 - val_accuracy: 0.1976 - val_loss: 2.2585\n",
      "Epoch 45/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2631 - val_accuracy: 0.1976 - val_loss: 2.2578\n",
      "Epoch 46/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 36ms/step - accuracy: 0.1854 - loss: 2.2625 - val_accuracy: 0.1976 - val_loss: 2.2571\n",
      "Epoch 47/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2619 - val_accuracy: 0.1976 - val_loss: 2.2564\n",
      "Epoch 48/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2613 - val_accuracy: 0.1976 - val_loss: 2.2557\n",
      "Epoch 49/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2607 - val_accuracy: 0.1976 - val_loss: 2.2550\n",
      "Epoch 50/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2602 - val_accuracy: 0.1976 - val_loss: 2.2543\n",
      "Epoch 51/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 40ms/step - accuracy: 0.1854 - loss: 2.2596 - val_accuracy: 0.1976 - val_loss: 2.2537\n",
      "Epoch 52/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2590 - val_accuracy: 0.1976 - val_loss: 2.2530\n",
      "Epoch 53/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 12ms/step - accuracy: 0.1854 - loss: 2.2585 - val_accuracy: 0.1976 - val_loss: 2.2524\n",
      "Epoch 54/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2579 - val_accuracy: 0.1976 - val_loss: 2.2517\n",
      "Epoch 55/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 15ms/step - accuracy: 0.1854 - loss: 2.2574 - val_accuracy: 0.1976 - val_loss: 2.2511\n",
      "Epoch 56/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2569 - val_accuracy: 0.1976 - val_loss: 2.2505\n",
      "Epoch 57/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2564 - val_accuracy: 0.1976 - val_loss: 2.2499\n",
      "Epoch 58/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2558 - val_accuracy: 0.1976 - val_loss: 2.2493\n",
      "Epoch 59/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2553 - val_accuracy: 0.1976 - val_loss: 2.2487\n",
      "Epoch 60/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2549 - val_accuracy: 0.1976 - val_loss: 2.2481\n",
      "Epoch 61/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 36ms/step - accuracy: 0.1854 - loss: 2.2544 - val_accuracy: 0.1976 - val_loss: 2.2476\n",
      "Epoch 62/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2539 - val_accuracy: 0.1976 - val_loss: 2.2470\n",
      "Epoch 63/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 15ms/step - accuracy: 0.1854 - loss: 2.2534 - val_accuracy: 0.1976 - val_loss: 2.2465\n",
      "Epoch 64/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2530 - val_accuracy: 0.1976 - val_loss: 2.2459\n",
      "Epoch 65/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 16ms/step - accuracy: 0.1854 - loss: 2.2525 - val_accuracy: 0.1976 - val_loss: 2.2454\n",
      "Epoch 66/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 17ms/step - accuracy: 0.1854 - loss: 2.2521 - val_accuracy: 0.1976 - val_loss: 2.2449\n",
      "Epoch 67/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2517 - val_accuracy: 0.1976 - val_loss: 2.2443\n",
      "Epoch 68/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 16ms/step - accuracy: 0.1854 - loss: 2.2512 - val_accuracy: 0.1976 - val_loss: 2.2438\n",
      "Epoch 69/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2508 - val_accuracy: 0.1976 - val_loss: 2.2433\n",
      "Epoch 70/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2504 - val_accuracy: 0.1976 - val_loss: 2.2428\n",
      "Epoch 71/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 38ms/step - accuracy: 0.1854 - loss: 2.2500 - val_accuracy: 0.1976 - val_loss: 2.2424\n",
      "Epoch 72/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2496 - val_accuracy: 0.1976 - val_loss: 2.2419\n",
      "Epoch 73/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2492 - val_accuracy: 0.1976 - val_loss: 2.2414\n",
      "Epoch 74/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 12ms/step - accuracy: 0.1854 - loss: 2.2489 - val_accuracy: 0.1976 - val_loss: 2.2410\n",
      "Epoch 75/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2485 - val_accuracy: 0.1976 - val_loss: 2.2405\n",
      "Epoch 76/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2481 - val_accuracy: 0.1976 - val_loss: 2.2401\n",
      "Epoch 77/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2478 - val_accuracy: 0.1976 - val_loss: 2.2397\n",
      "Epoch 78/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2475 - val_accuracy: 0.1976 - val_loss: 2.2393\n",
      "Epoch 79/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2471 - val_accuracy: 0.1976 - val_loss: 2.2389\n",
      "Epoch 80/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2468 - val_accuracy: 0.1976 - val_loss: 2.2385\n",
      "Epoch 81/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 35ms/step - accuracy: 0.1854 - loss: 2.2465 - val_accuracy: 0.1976 - val_loss: 2.2381\n",
      "Epoch 82/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2462 - val_accuracy: 0.1976 - val_loss: 2.2377\n",
      "Epoch 83/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2459 - val_accuracy: 0.1976 - val_loss: 2.2373\n",
      "Epoch 84/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2456 - val_accuracy: 0.1976 - val_loss: 2.2370\n",
      "Epoch 85/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2453 - val_accuracy: 0.1976 - val_loss: 2.2366\n",
      "Epoch 86/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2450 - val_accuracy: 0.1976 - val_loss: 2.2363\n",
      "Epoch 87/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2448 - val_accuracy: 0.1976 - val_loss: 2.2359\n",
      "Epoch 88/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2445 - val_accuracy: 0.1976 - val_loss: 2.2356\n",
      "Epoch 89/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2443 - val_accuracy: 0.1976 - val_loss: 2.2353\n",
      "Epoch 90/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2440 - val_accuracy: 0.1976 - val_loss: 2.2350\n",
      "Epoch 91/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 36ms/step - accuracy: 0.1854 - loss: 2.2438 - val_accuracy: 0.1976 - val_loss: 2.2347\n",
      "Epoch 92/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2436 - val_accuracy: 0.1976 - val_loss: 2.2344\n",
      "Epoch 93/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2434 - val_accuracy: 0.1976 - val_loss: 2.2341\n",
      "Epoch 94/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 12ms/step - accuracy: 0.1854 - loss: 2.2431 - val_accuracy: 0.1976 - val_loss: 2.2338\n",
      "Epoch 95/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2429 - val_accuracy: 0.1976 - val_loss: 2.2335\n",
      "Epoch 96/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2427 - val_accuracy: 0.1976 - val_loss: 2.2333\n",
      "Epoch 97/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2426 - val_accuracy: 0.1976 - val_loss: 2.2330\n",
      "Epoch 98/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2424 - val_accuracy: 0.1976 - val_loss: 2.2328\n",
      "Epoch 99/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2422 - val_accuracy: 0.1976 - val_loss: 2.2325\n",
      "Epoch 100/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2420 - val_accuracy: 0.1976 - val_loss: 2.2323\n",
      "Epoch 101/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m3s\u001b[0m 68ms/step - accuracy: 0.1854 - loss: 2.2419 - val_accuracy: 0.1976 - val_loss: 2.2321\n",
      "Epoch 102/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2417 - val_accuracy: 0.1976 - val_loss: 2.2319\n",
      "Epoch 103/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2416 - val_accuracy: 0.1976 - val_loss: 2.2317\n",
      "Epoch 104/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 12ms/step - accuracy: 0.1854 - loss: 2.2414 - val_accuracy: 0.1976 - val_loss: 2.2315\n",
      "Epoch 105/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2413 - val_accuracy: 0.1976 - val_loss: 2.2313\n",
      "Epoch 106/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2411 - val_accuracy: 0.1976 - val_loss: 2.2311\n",
      "Epoch 107/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2410 - val_accuracy: 0.1976 - val_loss: 2.2309\n",
      "Epoch 108/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2409 - val_accuracy: 0.1976 - val_loss: 2.2308\n",
      "Epoch 109/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2408 - val_accuracy: 0.1976 - val_loss: 2.2306\n",
      "Epoch 110/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2407 - val_accuracy: 0.1976 - val_loss: 2.2304\n",
      "Epoch 111/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 35ms/step - accuracy: 0.1854 - loss: 2.2406 - val_accuracy: 0.1976 - val_loss: 2.2303\n",
      "Epoch 112/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2404 - val_accuracy: 0.1976 - val_loss: 2.2301\n",
      "Epoch 113/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 12ms/step - accuracy: 0.1854 - loss: 2.2404 - val_accuracy: 0.1976 - val_loss: 2.2300\n",
      "Epoch 114/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 12ms/step - accuracy: 0.1854 - loss: 2.2403 - val_accuracy: 0.1976 - val_loss: 2.2298\n",
      "Epoch 115/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 15ms/step - accuracy: 0.1854 - loss: 2.2402 - val_accuracy: 0.1976 - val_loss: 2.2297\n",
      "Epoch 116/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 15ms/step - accuracy: 0.1854 - loss: 2.2401 - val_accuracy: 0.1976 - val_loss: 2.2296\n",
      "Epoch 117/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2400 - val_accuracy: 0.1976 - val_loss: 2.2295\n",
      "Epoch 118/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 15ms/step - accuracy: 0.1854 - loss: 2.2399 - val_accuracy: 0.1976 - val_loss: 2.2293\n",
      "Epoch 119/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 15ms/step - accuracy: 0.1854 - loss: 2.2399 - val_accuracy: 0.1976 - val_loss: 2.2292\n",
      "Epoch 120/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 15ms/step - accuracy: 0.1854 - loss: 2.2398 - val_accuracy: 0.1976 - val_loss: 2.2291\n",
      "Epoch 121/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 36ms/step - accuracy: 0.1854 - loss: 2.2397 - val_accuracy: 0.1976 - val_loss: 2.2290\n",
      "Epoch 122/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2397 - val_accuracy: 0.1976 - val_loss: 2.2289\n",
      "Epoch 123/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2396 - val_accuracy: 0.1976 - val_loss: 2.2288\n",
      "Epoch 124/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2395 - val_accuracy: 0.1976 - val_loss: 2.2287\n",
      "Epoch 125/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2395 - val_accuracy: 0.1976 - val_loss: 2.2286\n",
      "Epoch 126/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2394 - val_accuracy: 0.1976 - val_loss: 2.2286\n",
      "Epoch 127/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2394 - val_accuracy: 0.1976 - val_loss: 2.2285\n",
      "Epoch 128/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 12ms/step - accuracy: 0.1854 - loss: 2.2393 - val_accuracy: 0.1976 - val_loss: 2.2284\n",
      "Epoch 129/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2393 - val_accuracy: 0.1976 - val_loss: 2.2283\n",
      "Epoch 130/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2392 - val_accuracy: 0.1976 - val_loss: 2.2282\n",
      "Epoch 131/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 36ms/step - accuracy: 0.1854 - loss: 2.2392 - val_accuracy: 0.1976 - val_loss: 2.2282\n",
      "Epoch 132/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2392 - val_accuracy: 0.1976 - val_loss: 2.2281\n",
      "Epoch 133/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2391 - val_accuracy: 0.1976 - val_loss: 2.2280\n",
      "Epoch 134/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2391 - val_accuracy: 0.1976 - val_loss: 2.2280\n",
      "Epoch 135/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 12ms/step - accuracy: 0.1854 - loss: 2.2391 - val_accuracy: 0.1976 - val_loss: 2.2279\n",
      "Epoch 136/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2390 - val_accuracy: 0.1976 - val_loss: 2.2279\n",
      "Epoch 137/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 15ms/step - accuracy: 0.1854 - loss: 2.2390 - val_accuracy: 0.1976 - val_loss: 2.2278\n",
      "Epoch 138/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 12ms/step - accuracy: 0.1854 - loss: 2.2390 - val_accuracy: 0.1976 - val_loss: 2.2278\n",
      "Epoch 139/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2389 - val_accuracy: 0.1976 - val_loss: 2.2277\n",
      "Epoch 140/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2389 - val_accuracy: 0.1976 - val_loss: 2.2277\n",
      "Epoch 141/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 35ms/step - accuracy: 0.1854 - loss: 2.2389 - val_accuracy: 0.1976 - val_loss: 2.2276\n",
      "Epoch 142/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2389 - val_accuracy: 0.1976 - val_loss: 2.2276\n",
      "Epoch 143/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 16ms/step - accuracy: 0.1854 - loss: 2.2388 - val_accuracy: 0.1976 - val_loss: 2.2275\n",
      "Epoch 144/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2388 - val_accuracy: 0.1976 - val_loss: 2.2275\n",
      "Epoch 145/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2388 - val_accuracy: 0.1976 - val_loss: 2.2274\n",
      "Epoch 146/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 15ms/step - accuracy: 0.1854 - loss: 2.2388 - val_accuracy: 0.1976 - val_loss: 2.2274\n",
      "Epoch 147/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 15ms/step - accuracy: 0.1854 - loss: 2.2387 - val_accuracy: 0.1976 - val_loss: 2.2274\n",
      "Epoch 148/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2387 - val_accuracy: 0.1976 - val_loss: 2.2273\n",
      "Epoch 149/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2387 - val_accuracy: 0.1976 - val_loss: 2.2273\n",
      "Epoch 150/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2387 - val_accuracy: 0.1976 - val_loss: 2.2273\n",
      "Epoch 151/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 35ms/step - accuracy: 0.1854 - loss: 2.2387 - val_accuracy: 0.1976 - val_loss: 2.2272\n",
      "Epoch 152/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2387 - val_accuracy: 0.1976 - val_loss: 2.2272\n",
      "Epoch 153/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2386 - val_accuracy: 0.1976 - val_loss: 2.2272\n",
      "Epoch 154/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2386 - val_accuracy: 0.1976 - val_loss: 2.2272\n",
      "Epoch 155/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 12ms/step - accuracy: 0.1854 - loss: 2.2386 - val_accuracy: 0.1976 - val_loss: 2.2271\n",
      "Epoch 156/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2386 - val_accuracy: 0.1976 - val_loss: 2.2271\n",
      "Epoch 157/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2386 - val_accuracy: 0.1976 - val_loss: 2.2271\n",
      "Epoch 158/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 12ms/step - accuracy: 0.1854 - loss: 2.2386 - val_accuracy: 0.1976 - val_loss: 2.2271\n",
      "Epoch 159/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2386 - val_accuracy: 0.1976 - val_loss: 2.2270\n",
      "Epoch 160/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2386 - val_accuracy: 0.1976 - val_loss: 2.2270\n",
      "Epoch 161/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 35ms/step - accuracy: 0.1854 - loss: 2.2385 - val_accuracy: 0.1976 - val_loss: 2.2270\n",
      "Epoch 162/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2385 - val_accuracy: 0.1976 - val_loss: 2.2270\n",
      "Epoch 163/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2385 - val_accuracy: 0.1976 - val_loss: 2.2269\n",
      "Epoch 164/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2385 - val_accuracy: 0.1976 - val_loss: 2.2269\n",
      "Epoch 165/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2385 - val_accuracy: 0.1976 - val_loss: 2.2269\n",
      "Epoch 166/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2385 - val_accuracy: 0.1976 - val_loss: 2.2269\n",
      "Epoch 167/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2385 - val_accuracy: 0.1976 - val_loss: 2.2269\n",
      "Epoch 168/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2385 - val_accuracy: 0.1976 - val_loss: 2.2269\n",
      "Epoch 169/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2385 - val_accuracy: 0.1976 - val_loss: 2.2268\n",
      "Epoch 170/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2385 - val_accuracy: 0.1976 - val_loss: 2.2268\n",
      "Epoch 171/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 35ms/step - accuracy: 0.1854 - loss: 2.2385 - val_accuracy: 0.1976 - val_loss: 2.2268\n",
      "Epoch 172/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2385 - val_accuracy: 0.1976 - val_loss: 2.2268\n",
      "Epoch 173/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2268\n",
      "Epoch 174/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2268\n",
      "Epoch 175/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2268\n",
      "Epoch 176/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2267\n",
      "Epoch 177/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2267\n",
      "Epoch 178/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2267\n",
      "Epoch 179/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2267\n",
      "Epoch 180/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2267\n",
      "Epoch 181/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 36ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2267\n",
      "Epoch 182/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2267\n",
      "Epoch 183/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2267\n",
      "Epoch 184/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2267\n",
      "Epoch 185/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2266\n",
      "Epoch 186/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2266\n",
      "Epoch 187/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2266\n",
      "Epoch 188/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2266\n",
      "Epoch 189/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2266\n",
      "Epoch 190/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2266\n",
      "Epoch 191/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 36ms/step - accuracy: 0.1854 - loss: 2.2384 - val_accuracy: 0.1976 - val_loss: 2.2266\n",
      "Epoch 192/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 15ms/step - accuracy: 0.1854 - loss: 2.2383 - val_accuracy: 0.1976 - val_loss: 2.2266\n",
      "Epoch 193/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2383 - val_accuracy: 0.1976 - val_loss: 2.2266\n",
      "Epoch 194/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 12ms/step - accuracy: 0.1854 - loss: 2.2383 - val_accuracy: 0.1976 - val_loss: 2.2266\n",
      "Epoch 195/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2383 - val_accuracy: 0.1976 - val_loss: 2.2266\n",
      "Epoch 196/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2383 - val_accuracy: 0.1976 - val_loss: 2.2266\n",
      "Epoch 197/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2383 - val_accuracy: 0.1976 - val_loss: 2.2266\n",
      "Epoch 198/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 13ms/step - accuracy: 0.1854 - loss: 2.2383 - val_accuracy: 0.1976 - val_loss: 2.2265\n",
      "Epoch 199/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2383 - val_accuracy: 0.1976 - val_loss: 2.2265\n",
      "Epoch 200/200\n",
      "\u001b[1m40/40\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m1s\u001b[0m 14ms/step - accuracy: 0.1854 - loss: 2.2383 - val_accuracy: 0.1976 - val_loss: 2.2265\n",
      "finished training\n",
      "current ep  0\n"
     ]
    },
    {
     "ename": "NameError",
     "evalue": "name 'd' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "File \u001b[0;32m<timed exec>:89\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'd' is not defined"
     ]
    }
   ],
   "source": [
    "%%time\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import estimator.MINE_estimate\n",
    "\n",
    "EPOCH = 200\n",
    "SAMPLE_NUM = 8000\n",
    "loop = 10\n",
    "C_z = np.arange(0.4, 2.0, 0.1)\n",
    "z = 1.96\n",
    "\n",
    "# Preallocate arrays for results\n",
    "# ixz_ksg_global_loops = np.zeros((loop, EPOCH))\n",
    "# iyz_ksg_global_loops = np.zeros((loop, EPOCH))\n",
    "# ixz_ksg_local_loops = np.zeros((loop, EPOCH))\n",
    "# iyz_ksg_local_loops = np.zeros((loop, EPOCH))\n",
    "# ixz_ksg_loops = np.zeros((loop, EPOCH))\n",
    "# iyz_ksg_loops = np.zeros((loop, EPOCH))\n",
    "\n",
    "ixz_mine_global_loops = np.zeros((loop, EPOCH))\n",
    "iyz_mine_global_loops = np.zeros((loop, EPOCH))\n",
    "ixz_mine_local_loops = np.zeros((loop, EPOCH))\n",
    "iyz_mine_local_loops = np.zeros((loop, EPOCH))\n",
    "ixz_mine_loops = np.zeros((loop, EPOCH))\n",
    "iyz_mine_loops = np.zeros((loop, EPOCH))\n",
    "\n",
    "energyz_list = np.zeros((EPOCH))\n",
    "\n",
    "# Preprocess data\n",
    "x_original = x_train.reshape(x_train.shape[0], -1)[:SAMPLE_NUM]\n",
    "Y_original = Y_train.reshape(Y_train.shape[0], -1)[:SAMPLE_NUM]\n",
    "\n",
    "# Normalize global data\n",
    "normx_global = global_normalize_inf_norm(x_original, C=1)\n",
    "normy_global = global_normalize_inf_norm(Y_original, C=1)\n",
    "\n",
    "normx_mine_global = global_normalize_mine(x_original, C=1)\n",
    "normy_mine_global = global_normalize_mine(Y_original, C=1)\n",
    "\n",
    "# Normalize local data (precomputing for all loops)\n",
    "normx_local, _ = normalize_data_old(x_train[:SAMPLE_NUM], C=1)\n",
    "normy_local, _ = normalize_data_old(Y_train[:SAMPLE_NUM], C=1)\n",
    "\n",
    "x_original = x_original.astype(np.float32)\n",
    "Y_original = Y_original.astype(np.float32)\n",
    "\n",
    "\n",
    "print(\"start estimating\")\n",
    "\n",
    "# Simulation loop\n",
    "\n",
    "#data = reporter.datalist\n",
    "for l in range(6,loop):\n",
    "    data = run_simulation()\n",
    "    print(\"finished training\")\n",
    "    #reporter.datalist\n",
    "    count = 0\n",
    "    \n",
    "    for ep in range(EPOCH):\n",
    "        if (ep % 20 == 0): \n",
    "            print(\"current ep \", ep)\n",
    "        #print(\"current ep \", ep)\n",
    "        if do_report_new(ep):\n",
    "            activity_data = data[count]['data']['activity_tst'][0][:SAMPLE_NUM]\n",
    "            activity_data = activity_data.astype(np.float32)\n",
    "\n",
    "            # # Global calculation (specific to activity_data)\n",
    "            # normz_global = [global_normalize_inf_norm(activity_data, C=c) for c in C_z]\n",
    "            # MI_global = [gpu_est.estimate(nz, normx_global)[0] for nz in normz_global]\n",
    "            # MIY_global = [gpu_est.estimate(nz, normy_global)[0] for nz in normz_global]\n",
    "            # max_MI_idx = np.argmax(MI_global)\n",
    "            # ixz_ksg_global_loops[l, ep] = MI_global[max_MI_idx]\n",
    "            # iyz_ksg_global_loops[l, ep] = MIY_global[max_MI_idx]\n",
    "            \n",
    "\n",
    "            # # Local calculation (specific to activity_data)\n",
    "            # normz_local, _ = normalize_data_old(activity_data, C=1)\n",
    "            # MI_local = gpu_est.estimate(normz_local, normx_local)[0]\n",
    "            # MIY_local = gpu_est.estimate(normz_local, normy_local)[0]\n",
    "            # ixz_ksg_local_loops[l, ep] = MI_local\n",
    "            # iyz_ksg_local_loops[l, ep] = MIY_local\n",
    "\n",
    "            # # Original calculation\n",
    "            # MI_original = gpu_est.estimate(x_original, activity_data)[0]\n",
    "            # MIY_original = gpu_est.estimate(activity_data, Y_original)[0]\n",
    "            # ixz_ksg_loops[l, ep] = MI_original\n",
    "            # iyz_ksg_loops[l, ep] = MIY_original\n",
    "            \n",
    "#             # MINE Global Estimator\n",
    "            _,energy_z_hat = normalize_data_new(d,C=1)\n",
    "            norm_zlist[ep] = norm_zlist[ep] + energy_z_hat\n",
    "\n",
    "            \n",
    "            normz_mine_global = global_normalize_mine(activity_data, C=1)\n",
    "            MI_mine_global, _ = MINE_estimate.MINE_MI(normx_mine_global, normz_mine_global, total_epochs=50)\n",
    "            MIY_mine_global, _ = MINE_estimate.MINE_MI(normy_mine_global, normz_mine_global, total_epochs=50)\n",
    "            ixz_mine_global_loops[l, ep] = MI_mine_global\n",
    "            iyz_mine_global_loops[l, ep] = MIY_mine_global\n",
    "            \n",
    "            # MINE Local Estimator\n",
    "            normz_mine_local, _ = normalize_data_old(activity_data, C=1)\n",
    "            MI_mine_local, _ = MINE_estimate.MINE_MI(normx_local, normz_mine_local, total_epochs=50)\n",
    "            MIY_mine_local, _ = MINE_estimate.MINE_MI(normy_local, normz_mine_local, total_epochs=50)\n",
    "            ixz_mine_local_loops[l, ep] = MI_mine_local\n",
    "            iyz_mine_local_loops[l, ep] = MIY_mine_local\n",
    "            \n",
    "            # MINE Original Estimator\n",
    "            MI_mine_original, _ = MINE_estimate.MINE_MI(x_original, activity_data, total_epochs=50)\n",
    "            MIY_mine_original, _ = MINE_estimate.MINE_MI(activity_data, Y_original, total_epochs=50)\n",
    "            ixz_mine_loops[l, ep] = MI_mine_original\n",
    "            iyz_mine_loops[l, ep] = MIY_mine_original\n",
    "            count += 1\n",
    "            \n",
    "    \n",
    "\n",
    "    results_dict = {\n",
    "        # \"ixz_ksg_global_loops\": ixz_ksg_global_loops,\n",
    "        # \"iyz_ksg_global_loops\": iyz_ksg_global_loops,\n",
    "        # \"ixz_ksg_local_loops\": ixz_ksg_local_loops,\n",
    "        # \"iyz_ksg_local_loops\": iyz_ksg_local_loops,\n",
    "        # \"ixz_ksg_loops\": ixz_ksg_loops,\n",
    "        # \"iyz_ksg_loops\": iyz_ksg_loops,\n",
    "        \"ixz_mine_global_loops\": ixz_mine_global_loops,\n",
    "        \"iyz_mine_global_loops\": iyz_mine_global_loops,\n",
    "        \"ixz_mine_local_loops\": ixz_mine_local_loops,\n",
    "        \"iyz_mine_local_loops\": iyz_mine_local_loops,\n",
    "        \"ixz_mine_loops\": ixz_mine_loops,\n",
    "        \"iyz_mine_loops\": iyz_mine_loops,\n",
    "    }\n",
    "\n",
    "    # Save the dictionary as a single .npy file\n",
    "    # np.save(\"svhn_mi_epochksg.npy\", results_dict)\n",
    "    np.save(f\"svhn_mi_epoch_mine_iter{l}.npy\", results_dict)\n",
    "\n",
    "# Compute mean and confidence intervals\n",
    "def compute_mean_ci(data_loops):\n",
    "    mean_data = np.mean(data_loops, axis=0)\n",
    "    se_data = np.std(data_loops, axis=0) / np.sqrt(loop)\n",
    "    ci_data = z * se_data\n",
    "    return mean_data, ci_data\n",
    "\n",
    "mean_ixz_ksg_global, ci_ixz_ksg_global = compute_mean_ci(ixz_ksg_global_loops)\n",
    "mean_ixz_ksg_local, ci_ixz_ksg_local = compute_mean_ci(ixz_ksg_local_loops)\n",
    "mean_ixz_ksg, ci_ixz_ksg = compute_mean_ci(ixz_ksg_loops)\n",
    "\n",
    "mean_ixz_mine_global, ci_ixz_mine_global = compute_mean_ci(ixz_mine_global_loops)\n",
    "mean_ixz_mine_local, ci_ixz_mine_local = compute_mean_ci(ixz_mine_local_loops)\n",
    "mean_ixz_mine, ci_ixz_mine = compute_mean_ci(ixz_mine_loops)\n",
    "\n",
    "# Plot example\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.plot(range(EPOCH), mean_ixz_ksg_global, label='ixz_ksg_global', color='blue')\n",
    "plt.fill_between(range(EPOCH),\n",
    "                 mean_ixz_ksg_global - ci_ixz_ksg_global,\n",
    "                 mean_ixz_ksg_global + ci_ixz_ksg_global,  \n",
    "                 color='blue', alpha=0.2)\n",
    "plt.xlabel('Epoch')\n",
    "plt.ylabel('Mutual Information')\n",
    "plt.title('Confidence Interval for ixz_ksg_global')\n",
    "plt.legend()\n",
    "plt.grid()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "8be963b1-e409-4663-881d-ec8248ca1699",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "epoch  0\n",
      "epoch  1\n",
      "epoch  2\n",
      "epoch  3\n",
      "epoch  4\n",
      "epoch  5\n",
      "epoch  6\n",
      "epoch  7\n",
      "epoch  8\n",
      "epoch  9\n",
      "epoch  10\n",
      "epoch  11\n",
      "epoch  12\n",
      "epoch  13\n",
      "epoch  14\n",
      "epoch  15\n",
      "epoch  16\n",
      "epoch  17\n",
      "epoch  18\n",
      "epoch  19\n",
      "epoch  20\n",
      "epoch  25\n",
      "epoch  30\n",
      "epoch  35\n",
      "epoch  40\n",
      "epoch  45\n",
      "epoch  50\n",
      "epoch  60\n",
      "epoch  70\n",
      "epoch  80\n",
      "epoch  90\n",
      "epoch  100\n",
      "epoch  110\n",
      "epoch  120\n",
      "epoch  130\n",
      "epoch  140\n",
      "epoch  150\n",
      "epoch  160\n",
      "epoch  170\n",
      "epoch  180\n",
      "epoch  190\n"
     ]
    }
   ],
   "source": [
    "norm_zlist = np.zeros((EPOCH))\n",
    "\n",
    "count=0\n",
    "\n",
    "#C_z=np.arange(0.4,2.0,0.1)\n",
    "for ep in range(EPOCH):\n",
    "    if do_report_new(ep):\n",
    "        d = data[count]['data']['activity_tst'][0][:SAMPLE_NUM]\n",
    "        print(\"epoch \",ep)\n",
    "\n",
    "        _,energy_z_hat = normalize_data_new(d,C=1)\n",
    "        norm_zlist[ep] = energy_z_hat\n",
    "\n",
    "        \n",
    "        count += 1\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "cc0ffaac-b324-4196-85d3-ece3045ecbf2",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save(\"norm_svhn.csv\",norm_zlist)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "a2e3def3-d748-4631-8dce-35346c2ad807",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.0000000e+00, 0.0000000e+00, 3.5486222e-04, 8.8844413e-04,\n",
       "       0.0000000e+00, 0.0000000e+00, 0.0000000e+00, 0.0000000e+00,\n",
       "       6.0659327e-04, 1.1754154e-03, 9.5550908e-04, 1.8812375e-04,\n",
       "       2.3122286e-04, 0.0000000e+00, 2.2183261e-03, 2.4435758e-03,\n",
       "       2.3792012e-05, 0.0000000e+00, 7.6865422e-04, 4.9307372e-04,\n",
       "       0.0000000e+00, 3.6182769e-06, 2.6851969e-03, 0.0000000e+00,\n",
       "       0.0000000e+00, 0.0000000e+00, 1.2376921e-03, 0.0000000e+00,\n",
       "       0.0000000e+00, 2.4763360e-03, 8.2653074e-04, 1.0101624e-03,\n",
       "       2.8381016e-04, 2.3993084e-04, 0.0000000e+00, 0.0000000e+00,\n",
       "       0.0000000e+00, 0.0000000e+00, 1.3113443e-05, 0.0000000e+00,\n",
       "       3.6729192e-03, 0.0000000e+00, 0.0000000e+00, 7.4837136e-04,\n",
       "       0.0000000e+00, 0.0000000e+00, 4.7010483e-04, 0.0000000e+00,\n",
       "       2.0278523e-10, 0.0000000e+00, 3.7138068e-04, 0.0000000e+00,\n",
       "       0.0000000e+00, 9.7323587e-05, 0.0000000e+00, 2.9023344e-04,\n",
       "       1.4467206e-03, 0.0000000e+00, 2.4766251e-08, 0.0000000e+00,\n",
       "       2.0458673e-04, 0.0000000e+00, 2.8187317e-06, 0.0000000e+00,\n",
       "       0.0000000e+00, 0.0000000e+00, 0.0000000e+00, 0.0000000e+00,\n",
       "       0.0000000e+00, 1.5449414e-05, 1.4156880e-03, 0.0000000e+00,\n",
       "       0.0000000e+00, 0.0000000e+00, 1.0543670e-05, 1.5864995e-03,\n",
       "       0.0000000e+00, 0.0000000e+00, 9.6720509e-10, 1.3907620e-04,\n",
       "       3.6756024e-05, 3.8895360e-04, 0.0000000e+00, 4.8823185e-05,\n",
       "       0.0000000e+00, 1.4036350e-06, 0.0000000e+00, 0.0000000e+00,\n",
       "       5.5315276e-04, 1.5521889e-06, 1.3558497e-04, 0.0000000e+00,\n",
       "       2.2295055e-04, 1.2099504e-04, 2.2993656e-04, 0.0000000e+00,\n",
       "       0.0000000e+00, 0.0000000e+00, 3.1934475e-04, 2.7831338e-04,\n",
       "       2.8358350e-05, 0.0000000e+00, 0.0000000e+00, 1.9709214e-04,\n",
       "       0.0000000e+00, 4.9174591e-06, 1.5221391e-04, 0.0000000e+00,\n",
       "       2.4654789e-06, 2.9155804e-04, 0.0000000e+00, 0.0000000e+00,\n",
       "       0.0000000e+00, 0.0000000e+00, 3.4780464e-06, 0.0000000e+00,\n",
       "       0.0000000e+00, 1.0498394e-03, 0.0000000e+00, 6.8731878e-09,\n",
       "       0.0000000e+00, 2.7095767e-10, 2.5828762e-03, 0.0000000e+00,\n",
       "       3.2360796e-07, 0.0000000e+00, 1.1197943e-04, 0.0000000e+00,\n",
       "       2.3415163e-05, 0.0000000e+00, 8.6892163e-05, 0.0000000e+00,\n",
       "       0.0000000e+00, 0.0000000e+00, 0.0000000e+00, 0.0000000e+00,\n",
       "       9.3127380e-04, 1.5314505e-04, 0.0000000e+00, 4.5644691e-05,\n",
       "       0.0000000e+00, 0.0000000e+00, 0.0000000e+00, 0.0000000e+00,\n",
       "       2.9311946e-04, 5.7786008e-07, 3.7771399e-04, 0.0000000e+00,\n",
       "       0.0000000e+00, 9.3910439e-06, 8.5203555e-07, 9.3461422e-04,\n",
       "       0.0000000e+00, 1.2394169e-03, 1.8059477e-04, 3.0341122e-05,\n",
       "       2.1331401e-04, 5.2702384e-05, 0.0000000e+00, 1.3355401e-04,\n",
       "       0.0000000e+00, 2.2325742e-06, 0.0000000e+00, 0.0000000e+00,\n",
       "       1.9432261e-04, 1.8973991e-07, 2.2842684e-08, 0.0000000e+00,\n",
       "       5.4534816e-04, 6.3279157e-07, 0.0000000e+00, 0.0000000e+00,\n",
       "       1.1693772e-04, 0.0000000e+00, 5.2949148e-05, 0.0000000e+00,\n",
       "       1.0396997e-03, 3.4995133e-05, 1.4709991e-04, 0.0000000e+00,\n",
       "       0.0000000e+00, 0.0000000e+00, 6.1012863e-04, 0.0000000e+00,\n",
       "       0.0000000e+00, 1.4833645e-04, 0.0000000e+00, 0.0000000e+00,\n",
       "       0.0000000e+00, 0.0000000e+00, 9.3742937e-04, 2.9899522e-03,\n",
       "       0.0000000e+00, 0.0000000e+00, 2.6554868e-04, 0.0000000e+00,\n",
       "       0.0000000e+00, 0.0000000e+00, 0.0000000e+00, 1.9804182e-04,\n",
       "       1.6948052e-03, 1.3816518e-04, 5.3353497e-04, 0.0000000e+00,\n",
       "       0.0000000e+00, 1.6952703e-05, 0.0000000e+00, 0.0000000e+00,\n",
       "       6.3076100e-10, 8.0046919e-04, 1.0645120e-04, 9.9255587e-04,\n",
       "       0.0000000e+00, 5.7820266e-04, 0.0000000e+00, 0.0000000e+00,\n",
       "       8.6361718e-09, 0.0000000e+00, 6.9648365e-04, 7.2496611e-04,\n",
       "       1.6485204e-04, 0.0000000e+00, 1.3666344e-03, 3.2734044e-06,\n",
       "       1.2685419e-03, 3.6235762e-04, 0.0000000e+00, 2.3690460e-03,\n",
       "       0.0000000e+00, 1.0372108e-03, 3.0532348e-05, 0.0000000e+00,\n",
       "       5.4171693e-04, 3.3777466e-04, 3.6986658e-04, 2.4361208e-07,\n",
       "       8.3480641e-04, 0.0000000e+00, 0.0000000e+00, 0.0000000e+00,\n",
       "       0.0000000e+00, 2.1396813e-04, 1.6479712e-03, 0.0000000e+00,\n",
       "       1.7898152e-05, 0.0000000e+00, 0.0000000e+00, 6.9396219e-06,\n",
       "       1.1042594e-05, 1.4839552e-03, 0.0000000e+00, 1.2619745e-04,\n",
       "       0.0000000e+00, 2.0090145e-05, 0.0000000e+00, 0.0000000e+00],\n",
       "      dtype=float32)"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "energy_z_hat[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "25efc300-b285-4fb1-b342-01ee2639cfcc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.00555761, 0.00539499, 0.00525626, 0.00514044, 0.00503937,\n",
       "       0.00495025, 0.00487231, 0.00480508, 0.00474668, 0.00469977,\n",
       "       0.00466296, 0.00463896, 0.00462851, 0.00463212, 0.00464857,\n",
       "       0.00467801, 0.00472044, 0.00477598, 0.00484345, 0.0049234 ,\n",
       "       0.00501318, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.00561246, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.006432  , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.00746646, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.00874774, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.01030297, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.01215959, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.01694046, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.023384  , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.03124837, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.03975157, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.04771852, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.05424169, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.05902969, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.06228441, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.06438354, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.06567219, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.06642715, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.06680237, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.06691933, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.        , 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.06684656, 0.        , 0.        , 0.        , 0.        ,\n",
       "       0.        , 0.        , 0.        , 0.        , 0.        ])"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "norm_zlist"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9ba5bf74-9647-467d-b425-2d42c2267d18",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e21f94c-45ff-4615-86f2-b4cd59791f1f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "10b5ff01-0e2d-4b3e-bc38-9b335cb6bd39",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7752255d-e11e-4e72-985c-3678d1e1afc3",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
