{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Eyeglasses Regression Case Study"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "os.environ['KMP_WARNINGS'] = 'off'\n",
    "\n",
    "import os\n",
    "import sys\n",
    "import warnings\n",
    "\n",
    "if not sys.warnoptions:\n",
    "    warnings.simplefilter(\"ignore\")\n",
    "    os.environ[\"PYTHONWARNINGS\"] = \"ignore\" # Also affect subprocesses"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import tensorflow as tf\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics import accuracy_score, r2_score, mean_squared_error\n",
    "\n",
    "import gudhi.tensorflow.perslay as prsl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1999"
     ]
    }
   ],
   "source": [
    "import tadasets\n",
    "from ripser import ripser, Rips\n",
    "import gudhi as gd\n",
    "\n",
    "n_data = 2000\n",
    "\n",
    "np.random.seed(565656)\n",
    "\n",
    "R = np.random.normal(loc=10.0,scale=2.5,size=(n_data,))\n",
    "\n",
    "clouds = [tadasets.eyeglasses(n=200,r1=20,r2=r,noise=1) for r in R]\n",
    "\n",
    "pds = []\n",
    "\n",
    "for i,cloud in enumerate(clouds):\n",
    "    print(i,end='\\r')\n",
    "    A_complex = gd.AlphaComplex(points = cloud)\n",
    "    A_complex_tree = A_complex.create_simplex_tree()\n",
    "    A_complex_tree.compute_persistence()\n",
    "    dgm = A_complex_tree.persistence_intervals_in_dimension(1)\n",
    "\n",
    "    pds.append(dgm)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2000"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(pds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for cloud in clouds[:3]:\n",
    "    plt.scatter(cloud[:,0],cloud[:,1])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# PersLay"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"font-weight: bold\">Model: \"functional\"</span>\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[1mModel: \"functional\"\u001b[0m\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\">┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━┓\n",
       "┃<span style=\"font-weight: bold\"> Layer (type)                    </span>┃<span style=\"font-weight: bold\"> Output Shape           </span>┃<span style=\"font-weight: bold\">       Param # </span>┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━┩\n",
       "│ pd_input (<span style=\"color: #0087ff; text-decoration-color: #0087ff\">InputLayer</span>)           │ (<span style=\"color: #00d7ff; text-decoration-color: #00d7ff\">None</span>, <span style=\"color: #00d7ff; text-decoration-color: #00d7ff\">None</span>, <span style=\"color: #00af00; text-decoration-color: #00af00\">2</span>)        │             <span style=\"color: #00af00; text-decoration-color: #00af00\">0</span> │\n",
       "├─────────────────────────────────┼────────────────────────┼───────────────┤\n",
       "│ perslay (<span style=\"color: #0087ff; text-decoration-color: #0087ff\">Perslay</span>)               │ (<span style=\"color: #00d7ff; text-decoration-color: #00d7ff\">None</span>, <span style=\"color: #00af00; text-decoration-color: #00af00\">10</span>, <span style=\"color: #00af00; text-decoration-color: #00af00\">10</span>, <span style=\"color: #00af00; text-decoration-color: #00af00\">1</span>)      │            <span style=\"color: #00af00; text-decoration-color: #00af00\">45</span> │\n",
       "├─────────────────────────────────┼────────────────────────┼───────────────┤\n",
       "│ flatten (<span style=\"color: #0087ff; text-decoration-color: #0087ff\">Flatten</span>)               │ (<span style=\"color: #00d7ff; text-decoration-color: #00d7ff\">None</span>, <span style=\"color: #00af00; text-decoration-color: #00af00\">100</span>)            │             <span style=\"color: #00af00; text-decoration-color: #00af00\">0</span> │\n",
       "├─────────────────────────────────┼────────────────────────┼───────────────┤\n",
       "│ concatenate (<span style=\"color: #0087ff; text-decoration-color: #0087ff\">Concatenate</span>)       │ (<span style=\"color: #00d7ff; text-decoration-color: #00d7ff\">None</span>, <span style=\"color: #00af00; text-decoration-color: #00af00\">100</span>)            │             <span style=\"color: #00af00; text-decoration-color: #00af00\">0</span> │\n",
       "├─────────────────────────────────┼────────────────────────┼───────────────┤\n",
       "│ dense (<span style=\"color: #0087ff; text-decoration-color: #0087ff\">Dense</span>)                   │ (<span style=\"color: #00d7ff; text-decoration-color: #00d7ff\">None</span>, <span style=\"color: #00af00; text-decoration-color: #00af00\">16</span>)             │         <span style=\"color: #00af00; text-decoration-color: #00af00\">1,616</span> │\n",
       "├─────────────────────────────────┼────────────────────────┼───────────────┤\n",
       "│ dense_1 (<span style=\"color: #0087ff; text-decoration-color: #0087ff\">Dense</span>)                 │ (<span style=\"color: #00d7ff; text-decoration-color: #00d7ff\">None</span>, <span style=\"color: #00af00; text-decoration-color: #00af00\">8</span>)              │           <span style=\"color: #00af00; text-decoration-color: #00af00\">136</span> │\n",
       "├─────────────────────────────────┼────────────────────────┼───────────────┤\n",
       "│ dense_2 (<span style=\"color: #0087ff; text-decoration-color: #0087ff\">Dense</span>)                 │ (<span style=\"color: #00d7ff; text-decoration-color: #00d7ff\">None</span>, <span style=\"color: #00af00; text-decoration-color: #00af00\">1</span>)              │             <span style=\"color: #00af00; text-decoration-color: #00af00\">9</span> │\n",
       "└─────────────────────────────────┴────────────────────────┴───────────────┘\n",
       "</pre>\n"
      ],
      "text/plain": [
       "┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━━━━━━━━┓\n",
       "┃\u001b[1m \u001b[0m\u001b[1mLayer (type)                   \u001b[0m\u001b[1m \u001b[0m┃\u001b[1m \u001b[0m\u001b[1mOutput Shape          \u001b[0m\u001b[1m \u001b[0m┃\u001b[1m \u001b[0m\u001b[1m      Param #\u001b[0m\u001b[1m \u001b[0m┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━━━━━━━━┩\n",
       "│ pd_input (\u001b[38;5;33mInputLayer\u001b[0m)           │ (\u001b[38;5;45mNone\u001b[0m, \u001b[38;5;45mNone\u001b[0m, \u001b[38;5;34m2\u001b[0m)        │             \u001b[38;5;34m0\u001b[0m │\n",
       "├─────────────────────────────────┼────────────────────────┼───────────────┤\n",
       "│ perslay (\u001b[38;5;33mPerslay\u001b[0m)               │ (\u001b[38;5;45mNone\u001b[0m, \u001b[38;5;34m10\u001b[0m, \u001b[38;5;34m10\u001b[0m, \u001b[38;5;34m1\u001b[0m)      │            \u001b[38;5;34m45\u001b[0m │\n",
       "├─────────────────────────────────┼────────────────────────┼───────────────┤\n",
       "│ flatten (\u001b[38;5;33mFlatten\u001b[0m)               │ (\u001b[38;5;45mNone\u001b[0m, \u001b[38;5;34m100\u001b[0m)            │             \u001b[38;5;34m0\u001b[0m │\n",
       "├─────────────────────────────────┼────────────────────────┼───────────────┤\n",
       "│ concatenate (\u001b[38;5;33mConcatenate\u001b[0m)       │ (\u001b[38;5;45mNone\u001b[0m, \u001b[38;5;34m100\u001b[0m)            │             \u001b[38;5;34m0\u001b[0m │\n",
       "├─────────────────────────────────┼────────────────────────┼───────────────┤\n",
       "│ dense (\u001b[38;5;33mDense\u001b[0m)                   │ (\u001b[38;5;45mNone\u001b[0m, \u001b[38;5;34m16\u001b[0m)             │         \u001b[38;5;34m1,616\u001b[0m │\n",
       "├─────────────────────────────────┼────────────────────────┼───────────────┤\n",
       "│ dense_1 (\u001b[38;5;33mDense\u001b[0m)                 │ (\u001b[38;5;45mNone\u001b[0m, \u001b[38;5;34m8\u001b[0m)              │           \u001b[38;5;34m136\u001b[0m │\n",
       "├─────────────────────────────────┼────────────────────────┼───────────────┤\n",
       "│ dense_2 (\u001b[38;5;33mDense\u001b[0m)                 │ (\u001b[38;5;45mNone\u001b[0m, \u001b[38;5;34m1\u001b[0m)              │             \u001b[38;5;34m9\u001b[0m │\n",
       "└─────────────────────────────────┴────────────────────────┴───────────────┘\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"font-weight: bold\"> Total params: </span><span style=\"color: #00af00; text-decoration-color: #00af00\">1,806</span> (7.05 KB)\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[1m Total params: \u001b[0m\u001b[38;5;34m1,806\u001b[0m (7.05 KB)\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"font-weight: bold\"> Trainable params: </span><span style=\"color: #00af00; text-decoration-color: #00af00\">1,804</span> (7.05 KB)\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[1m Trainable params: \u001b[0m\u001b[38;5;34m1,804\u001b[0m (7.05 KB)\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"font-weight: bold\"> Non-trainable params: </span><span style=\"color: #00af00; text-decoration-color: #00af00\">2</span> (8.00 B)\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[1m Non-trainable params: \u001b[0m\u001b[38;5;34m2\u001b[0m (8.00 B)\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[1m44/44\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m3s\u001b[0m 38ms/step\n",
      "Test R2: 0.138\n",
      "Test MSE: 5.737\n",
      "1\n",
      "\u001b[1m44/44\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m3s\u001b[0m 37ms/step\n",
      "Test R2: -0.029\n",
      "Test MSE: 6.653\n",
      "2\n",
      "\u001b[1m44/44\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m3s\u001b[0m 39ms/step\n",
      "Test R2: 0.086\n",
      "Test MSE: 6.064\n",
      "3\n",
      "\u001b[1m44/44\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m3s\u001b[0m 37ms/step\n",
      "Test R2: 0.214\n",
      "Test MSE: 5.014\n",
      "4\n",
      "\u001b[1m44/44\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m3s\u001b[0m 37ms/step\n",
      "Test R2: 0.274\n",
      "Test MSE: 4.768\n",
      "[ 0.13821036 -0.02884233  0.08564079  0.21435869  0.27383214] 0.13663992881774903 0.10473744837955731\n"
     ]
    }
   ],
   "source": [
    "N = 5\n",
    "\n",
    "scores_dataset = np.zeros((N,))\n",
    "\n",
    "for i in range(N):\n",
    "    print(i)\n",
    "\n",
    "    indices = np.arange(len(pds))\n",
    "    train_idx, test_idx, y_train, y_test = train_test_split(\n",
    "        indices,\n",
    "        R,             \n",
    "        test_size=0.7)\n",
    "    \n",
    "    pds_train_list = [pds[i] for i in train_idx]\n",
    "    pds_test_list  = [pds[i] for i in test_idx]\n",
    "    \n",
    "    # Convert to RaggedTensors\n",
    "    pds_train = tf.ragged.constant(pds_train_list, ragged_rank=1, dtype=tf.float32)\n",
    "    pds_test  = tf.ragged.constant(pds_test_list,  ragged_rank=1, dtype=tf.float32)\n",
    "    \n",
    "    y_train = np.asarray(y_train, dtype=np.float32)\n",
    "    y_test  = np.asarray(y_test, dtype=np.float32)\n",
    "    \n",
    "    y_train = y_train.reshape(-1, 1)\n",
    "    y_test  = y_test.reshape(-1, 1)\n",
    "    \n",
    "    rho_10   = tf.keras.layers.BatchNormalization()\n",
    "    rho_20   = tf.keras.layers.BatchNormalization()\n",
    "    rho_50   = tf.keras.layers.BatchNormalization()\n",
    "    rho_tent = tf.keras.layers.BatchNormalization()\n",
    "    perm_op = tf.math.reduce_sum  # sum over PD points\n",
    "    \n",
    "    # =================================================\n",
    "    # 1. Three Gaussian φ branches + one Tent branch\n",
    "    # =================================================\n",
    "    \n",
    "    phi_gauss_10 = prsl.GaussianPerslayPhi(\n",
    "        image_size=(10, 10),\n",
    "        image_bnds=((0.0, 1.0), (0.0, 2.0)),\n",
    "        variance=0.05,\n",
    "    )\n",
    "    phi_gauss_20 = prsl.GaussianPerslayPhi(\n",
    "        image_size=(20, 20),\n",
    "        image_bnds=((0.0, 1.0), (0.0, 2.0)),\n",
    "        variance=0.05,\n",
    "    )\n",
    "    phi_gauss_50 = prsl.GaussianPerslayPhi(\n",
    "        image_size=(50, 50),\n",
    "        image_bnds=((0.0, 1.0), (0.0, 2.0)),\n",
    "        variance=0.05,\n",
    "    )\n",
    "    \n",
    "    samples_tent = np.linspace(0.0, 2.0, 50).astype(np.float32)\n",
    "    phi_tent = prsl.TentPerslayPhi(samples=samples_tent)\n",
    "    \n",
    "    \n",
    "    for phi in [phi_gauss_10, phi_gauss_20, phi_gauss_50]:\n",
    "        if hasattr(phi, \"variance\") and isinstance(phi.variance, tf.Variable):\n",
    "            setattr(phi.variance, \"regularizer\", None)\n",
    "            phi._trainable_variables.append(phi.variance)\n",
    "    \n",
    "    if hasattr(phi_tent, \"samples\") and isinstance(phi_tent.samples, tf.Variable):\n",
    "        setattr(phi_tent.samples, \"regularizer\", None)\n",
    "        phi_tent._trainable_variables.append(phi_tent.samples)\n",
    "    \n",
    "    # =================================================\n",
    "    # 2. GaussianMixturePerslayWeight with K components\n",
    "    # =================================================\n",
    "    \n",
    "    K = 10  # number of mixture components\n",
    "    \n",
    "    # Means roughly covering the birth–death box, with moderate sigmas\n",
    "    mu_x = np.linspace(0.05, 0.95, K, dtype=np.float32)\n",
    "    mu_y = np.linspace(0.1, 1.9,  K, dtype=np.float32)\n",
    "    sigma_x = np.full(K, 0.15, dtype=np.float32)\n",
    "    sigma_y = np.full(K, 0.30, dtype=np.float32)\n",
    "    \n",
    "    gaussians = np.vstack([mu_x, mu_y, sigma_x, sigma_y])  # (4, K)\n",
    "    \n",
    "    weight_gauss_10 = prsl.GaussianMixturePerslayWeight(gaussians=gaussians)\n",
    "    weight_gauss_20 = prsl.GaussianMixturePerslayWeight(gaussians=gaussians)\n",
    "    weight_gauss_50 = prsl.GaussianMixturePerslayWeight(gaussians=gaussians)\n",
    "    weight_tent     = prsl.GaussianMixturePerslayWeight(gaussians=gaussians)\n",
    "        \n",
    "    def make_gmm_weight_trainable(w_layer):\n",
    "        if hasattr(w_layer, \"W\") and isinstance(w_layer.W, tf.Variable):\n",
    "            setattr(w_layer.W, \"regularizer\", None)\n",
    "            w_layer._trainable_variables.append(w_layer.W)\n",
    "    \n",
    "    for w in [weight_gauss_10, weight_gauss_20, weight_gauss_50, weight_tent]:\n",
    "        make_gmm_weight_trainable(w)\n",
    "    \n",
    "    # -------------------------------------------------\n",
    "    # 2.B PowerPerslayWeight \n",
    "    # -------------------------------------------------\n",
    "    \n",
    "    weight_gauss_10_p = prsl.PowerPerslayWeight(constant=1.0, power=1.0)\n",
    "    weight_gauss_20_p = prsl.PowerPerslayWeight(constant=1.0, power=1.0)\n",
    "    weight_gauss_50_p = prsl.PowerPerslayWeight(constant=1.0, power=1.0)\n",
    "    weight_tent_p     = prsl.PowerPerslayWeight(constant=1.0, power=1.0)\n",
    "    \n",
    "    for w in [weight_gauss_10_p, weight_gauss_20_p, weight_gauss_50_p, weight_tent_p]:\n",
    "        make_gmm_weight_trainable(w)\n",
    "    \n",
    "    # =================================================\n",
    "    # 3. PersLay layers\n",
    "    # =================================================\n",
    "    \n",
    "    perslay_gauss_10 = prsl.Perslay(\n",
    "        phi=phi_gauss_10,\n",
    "        weight=weight_gauss_10,\n",
    "        perm_op=perm_op,\n",
    "        rho=rho_10,\n",
    "    )\n",
    "    \n",
    "    perslay_gauss_20 = prsl.Perslay(\n",
    "        phi=phi_gauss_20,\n",
    "        weight=weight_gauss_20,\n",
    "        perm_op=perm_op,\n",
    "        rho=rho_20,\n",
    "    )\n",
    "    \n",
    "    perslay_gauss_50 = prsl.Perslay(\n",
    "        phi=phi_gauss_50,\n",
    "        weight=weight_gauss_50,\n",
    "        perm_op=perm_op,\n",
    "        rho=rho_50,\n",
    "    )\n",
    "    \n",
    "    perslay_tent = prsl.Perslay(\n",
    "        phi=phi_tent,\n",
    "        weight=weight_tent,\n",
    "        perm_op=perm_op,\n",
    "        rho=rho_tent,\n",
    "    )\n",
    "    \n",
    "    # =================================================\n",
    "    # 4. Keras model \n",
    "    # =================================================\n",
    "    \n",
    "    inputs = tf.keras.Input(shape=(None, 2), ragged=True, name=\"pd_input\")\n",
    "    \n",
    "    x10   = perslay_gauss_10(inputs)\n",
    "    x20   = perslay_gauss_20(inputs)\n",
    "    x50   = perslay_gauss_50(inputs)\n",
    "    xtent = perslay_tent(inputs)\n",
    "    \n",
    "    x10   = tf.keras.layers.Flatten()(x10)\n",
    "    x20   = tf.keras.layers.Flatten()(x20)\n",
    "    x50   = tf.keras.layers.Flatten()(x50)\n",
    "    xtent = tf.keras.layers.Flatten()(xtent)\n",
    "    \n",
    "#    x = tf.keras.layers.Concatenate()([x10, x20, x50, xtent])\n",
    "    x = tf.keras.layers.Concatenate()([x10])\n",
    "    \n",
    "    x = tf.keras.layers.Dense(16, activation=\"relu\")(x)\n",
    "#    x = tf.keras.layers.Dropout(0.15)(x)\n",
    "    x = tf.keras.layers.Dense(8, activation=\"relu\")(x)\n",
    "    \n",
    "    outputs = tf.keras.layers.Dense(1, activation=\"linear\")(x)\n",
    "    \n",
    "    model = tf.keras.Model(inputs=inputs, outputs=outputs)\n",
    "    \n",
    "    if i == 0:\n",
    "        model.summary()\n",
    "    \n",
    "    # =================================================\n",
    "    # 5. Train the model \n",
    "    # =================================================\n",
    "    \n",
    "    model.compile(\n",
    "        optimizer=tf.keras.optimizers.Adam(learning_rate=1e-3),\n",
    "        loss=\"mse\",          # REGRESSION loss\n",
    "        metrics=[\"mse\"],    \n",
    "    )\n",
    "    \n",
    "    history = model.fit(\n",
    "        pds_train,\n",
    "        y_train,\n",
    "        validation_split=0.3,\n",
    "        epochs=30,\n",
    "        batch_size=32,\n",
    "        verbose=0,\n",
    "    )\n",
    "    \n",
    "    # =================================================\n",
    "    # 6. Evaluate on the test set \n",
    "    # =================================================\n",
    "    \n",
    "    y_pred = model.predict(pds_test).ravel()\n",
    "    y_true = y_test.ravel()\n",
    "    \n",
    "    r2  = r2_score(y_true, y_pred)\n",
    "    mse  = mean_squared_error(y_true, y_pred)\n",
    "\n",
    "    scores_dataset[i]=r2\n",
    "    print(f\"Test R2: {r2:.3f}\")\n",
    "    print(f\"Test MSE: {mse:.3f}\")\n",
    "\n",
    "print(scores_dataset,np.mean(scores_dataset),np.std(scores_dataset))\n",
    "np.save('PersLay_scores_eyeglasses',scores_dataset)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Eyeglasses: 0.2481888175010681 0.03153864666943581"
   ]
  }
 ],
 "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.13.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
