{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "based on https://pennylane.ai/qml/demos/tutorial_expressivity_fourier_series/ and the paper *The effect of data encoding on\n",
    "the expressive power of variational quantum machine learning models* by [Schuld, Sweke, and Meyer (2020)](https://arxiv.org/abs/2008.08605)"
   ]
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-16T11:00:07.683026Z",
     "start_time": "2025-09-16T11:00:03.936636Z"
    }
   },
   "cell_type": "code",
   "source": [
    "from pathlib import Path\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "import pennylane as qml\n",
    "import jax, jaxlib\n",
    "import jax.numpy as jnp\n",
    "import optax\n",
    "\n",
    "from sklearn.metrics import r2_score\n",
    "import pandas as pd\n",
    "import pickle\n"
   ],
   "outputs": [],
   "execution_count": 1
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-16T11:00:07.690713Z",
     "start_time": "2025-09-16T11:00:07.685641Z"
    }
   },
   "cell_type": "code",
   "source": [
    "seed = 42\n",
    "np.random.seed(seed)"
   ],
   "outputs": [],
   "execution_count": 2
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Fitting functions with parallel Pauli-rotation encoding"
   ]
  },
  {
   "cell_type": "code",
   "source": [
    "# define Feature Map S\n",
    "# contains prefactor alpha to allow for exponentially increasing frequencies\n",
    "\n",
    "def S(alpha, x, num_wires, serial):\n",
    "    \"\"\"Feature Map with pre-factor\"\"\"\n",
    "    # adjust x input to match number of dimensions / desired prefactor sequence. Current int div by 2 assumes 2d input and encoding of first dim into wires 0 and 1, 2nd dim into wires 2 and 3\n",
    "    for w in range(num_wires): \n",
    "        qml.RX(alpha[w]*x[w//2], wires=w)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-09-16T11:00:07.691510Z",
     "start_time": "2025-09-16T11:00:07.689564Z"
    }
   },
   "outputs": [],
   "execution_count": 3
  },
  {
   "cell_type": "code",
   "source": [
    "# define basic circuit architecture for Ansatz W - see main Opt Loop for a circuit drawing to check optically\n",
    "\n",
    "def W_ladder(theta, trainable_block_layers, num_wires):\n",
    "    \"\"\"Ansatz layer with variable number of train blocks consisting of CNOTs and Rot gates\"\"\"\n",
    "    for i in range(trainable_block_layers):\n",
    "        qml.Rot(theta[i][num_wires-1][0], theta[i][num_wires-1][1], theta[i][num_wires-1][2], wires = 0)\n",
    "        for j in range(num_wires-1):\n",
    "            qml.CNOT(wires = [j, j+1])\n",
    "            qml.Rot(theta[i][j][0], theta[i][j][1], theta[i][j][2], wires = j+1)\n",
    "        "
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-09-16T11:00:07.699566Z",
     "start_time": "2025-09-16T11:00:07.694166Z"
    }
   },
   "outputs": [],
   "execution_count": 4
  },
  {
   "cell_type": "code",
   "source": [
    "# weights initialisation\n",
    "\n",
    "def random_weights_uniform(num_serial_ansatz_layers, trainable_block_layers, num_wires, num_rot_params):\n",
    "    return 2 * np.pi * np.random.random(size=(num_serial_ansatz_layers, trainable_block_layers, num_wires, num_rot_params))\n"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-09-16T11:00:07.706704Z",
     "start_time": "2025-09-16T11:00:07.699761Z"
    }
   },
   "outputs": [],
   "execution_count": 5
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Setting up and Training the model"
   ]
  },
  {
   "cell_type": "code",
   "source": [
    "# enable jax for faster execution\n",
    "\n",
    "jax.config.update(\"jax_enable_x64\", True)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-09-16T11:00:07.706907Z",
     "start_time": "2025-09-16T11:00:07.702778Z"
    }
   },
   "outputs": [],
   "execution_count": 6
  },
  {
   "cell_type": "code",
   "source": [
    "# define MSE as loss function\n",
    "\n",
    "def square_loss(targets, predictions):\n",
    "    loss = 0\n",
    "    for t, p in zip(targets, predictions):\n",
    "        loss += (t - p) ** 2\n",
    "    loss = loss / len(targets)\n",
    "    return 0.5 * loss"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-09-16T11:00:07.716125Z",
     "start_time": "2025-09-16T11:00:07.707270Z"
    }
   },
   "outputs": [],
   "execution_count": 7
  },
  {
   "cell_type": "code",
   "source": [
    "# update parameters with jax / jit\n",
    "\n",
    "@jax.jit\n",
    "def update(params, opt_state, x, y):\n",
    "    loss, grads = jax.value_and_grad(cost)(params, x, y)\n",
    "    updates, opt_state = opt.update(grads, opt_state, params)\n",
    "    params = optax.apply_updates(params, updates)\n",
    "    return params, opt_state, loss, grads\n"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-09-16T11:00:07.716312Z",
     "start_time": "2025-09-16T11:00:07.709249Z"
    }
   },
   "outputs": [],
   "execution_count": 8
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-16T11:00:07.716559Z",
     "start_time": "2025-09-16T11:00:07.713945Z"
    }
   },
   "cell_type": "code",
   "source": [
    "# select initial prefactors alpha for exponential encoding, add separate inner list [] for each serial FM layer\n",
    "\n",
    "initial_alpha = [[3.0, 9.0, 3.0, 9.0]]"
   ],
   "outputs": [],
   "execution_count": 9
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-16T11:00:07.740579Z",
     "start_time": "2025-09-16T11:00:07.716774Z"
    }
   },
   "cell_type": "code",
   "source": [
    "# load target functions dataset\n",
    "\n",
    "with open('../data/input/datasets_2d.pkl', 'rb') as f:\n",
    "    loaded_datasets = pickle.load(f)\n"
   ],
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/michaelpoppel/PycharmProjects/freq_sel_near_zero_weights_init/bp/lib/python3.10/site-packages/sklearn/base.py:442: InconsistentVersionWarning: Trying to unpickle estimator MinMaxScaler from version 1.7.1 when using version 1.7.2. This might lead to breaking code or invalid results. Use at your own risk. For more info please refer to:\n",
      "https://scikit-learn.org/stable/model_persistence.html#security-maintainability-limitations\n",
      "  warnings.warn(\n"
     ]
    }
   ],
   "execution_count": 10
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "outputs": [
    {
     "data": {
      "text/plain": "dict_keys(['xy_all', 'z_all', 'xy_train', 'xy_test', 'z_train', 'z_test', 'scaler_xy', 'scaler_z', 'grid_shape', 'coefficients'])"
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# quick check to confirm that dataset loading has worked\n",
    "\n",
    "loaded_datasets[0].keys()"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-09-16T11:00:07.749390Z",
     "start_time": "2025-09-16T11:00:07.742366Z"
    }
   }
  },
  {
   "cell_type": "code",
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-09-16T11:05:44.001581Z",
     "start_time": "2025-09-16T11:00:07.755726Z"
    }
   },
   "source": [
    "# Optimization Loop\n",
    "\n",
    "# use this hyperparameter to loop over increasing number of parameters\n",
    "max_trainable_block_layers = 11 # max number of train blocks (excl) within 1 Ansatz layer between FMs\n",
    "\n",
    "num_runs_per_function = 10\n",
    "max_steps = 5000\n",
    "lr = 0.001\n",
    "batch_size = 40\n",
    "num_wires = 4\n",
    "num_serial_ansatz_layers = 2 # one extra Ansatz layer in front, so max of 3 leads to 2 Ansatz layers and 1 serial FM\n",
    "num_rot_params = 3 # number of rotational parameters within 1 train Block\n",
    "\n",
    "# Initialize an empty DataFrame to store metrics\n",
    "metrics_df = pd.DataFrame(columns=[\"Approach\", \"Degree\", \"Run\", \"R2_Score\", \"numParams\"])\n",
    "\n",
    "# define path to save results\n",
    "model_name = f\"selFreqs_parallel_ternary_2nd\"\n",
    "fileDir = Path(f'../results/')     \n",
    "fileDir.mkdir(parents=True, exist_ok=True)\n",
    "filename = Path(f\"{model_name}_{int(num_wires)}wires_{num_serial_ansatz_layers-1}ser_targetMultipleFourier2d\")\n",
    "filepathDataframe = Path.joinpath(fileDir, filename).with_suffix('.csv')\n",
    "\n",
    "\n",
    "for trainable_block_layers in range(1, max_trainable_block_layers):\n",
    "    \n",
    "    print(f\"running {trainable_block_layers} train blocks of {max_trainable_block_layers}\")\n",
    "\n",
    "    dev = qml.device(\"default.qubit\", wires = num_wires)\n",
    "    # define model with loop to allow for additional train blocks / parameters in circuit\n",
    "    @qml.qnode(dev)\n",
    "    def standard_parallel_quantum_model(alpha, weights, x=None):\n",
    "        W_ladder(weights[0], trainable_block_layers, num_wires)\n",
    "        for i in range(num_serial_ansatz_layers-1):\n",
    "            S(alpha[i], x, num_wires, i)\n",
    "            W_ladder(weights[i+1], trainable_block_layers, num_wires)\n",
    "\n",
    "        return qml.expval(qml.PauliZ(wires=num_wires-1))\n",
    "\n",
    "    # get circuit plotted for inspection\n",
    "    fig, ax = qml.draw_mpl(standard_parallel_quantum_model, expansion_strategy=\"device\")(initial_alpha, random_weights_uniform(num_serial_ansatz_layers, trainable_block_layers, num_wires, num_rot_params), [0.5, 0.5])\n",
    "    plt.show()\n",
    "\n",
    "    # transform circuit into jit\n",
    "    standard_parallel_quantum_model_jit = jax.jit(standard_parallel_quantum_model)\n",
    "    alpha = jnp.array(initial_alpha)\n",
    "    \n",
    "    # define cost function\n",
    "    def cost(params, x, y):\n",
    "        weights = params[\"weights\"]\n",
    "        predictions = [standard_parallel_quantum_model_jit(alpha, weights, x_) for x_ in x]\n",
    "        return square_loss(y, predictions).squeeze()\n",
    "    \n",
    "    # run circuit for full set of target functions\n",
    "    for func in range(len(loaded_datasets)):\n",
    "    \n",
    "        print(f\"running function {func+1} of {len(loaded_datasets)}\")\n",
    "        \n",
    "        dataset = loaded_datasets[func]\n",
    "        x_all = dataset[\"xy_all\"]\n",
    "        x_train = dataset[\"xy_train\"]\n",
    "        x_test = dataset[\"xy_test\"]\n",
    "        y_all = dataset[\"z_all\"]\n",
    "        y_train = dataset[\"z_train\"]\n",
    "        y_test = dataset[\"z_test\"]\n",
    "\n",
    "        # run for several runs to avoid any seed luck with the initialization of the weights\n",
    "        for run in range(num_runs_per_function):\n",
    "    \n",
    "            weights_flex = random_weights_uniform(num_serial_ansatz_layers, trainable_block_layers, num_wires, num_rot_params)\n",
    "            weights_flex = jnp.array(weights_flex)\n",
    "            \n",
    "            opt = optax.adam(lr)\n",
    "    \n",
    "            params = {'weights': weights_flex}\n",
    "            opt_state = opt.init(params)\n",
    "            cst = [cost(params, x_train, y_train)]  # initial cost\n",
    "            \n",
    "            # run optimization\n",
    "            for step in range(max_steps):\n",
    "    \n",
    "                # select batch of data\n",
    "                batch_index = np.random.randint(0, len(x_train), (batch_size,))\n",
    "                x_batch = jnp.array(x_train[batch_index])\n",
    "                y_batch = jnp.array(y_train[batch_index])\n",
    "    \n",
    "                # update parameters\n",
    "                params, opt_state, c, gradients = update(params, opt_state, x_batch, y_batch)\n",
    "                \n",
    "                # update cost history and print periodically\n",
    "                cst.append(c)\n",
    "                print_freq = 1000\n",
    "                if (step + 1) % print_freq == 0:\n",
    "                    print(\"Cost at step {0:3}: {1}\".format(step + 1, c))\n",
    "    \n",
    "            # calculate R2 on test set with trained weights\n",
    "            weights = params[\"weights\"]\n",
    "            pred_test = [standard_parallel_quantum_model_jit(alpha, weights, x_) for x_ in x_test]  # test set for R2 calc\n",
    "            r2 = r2_score(y_test, pred_test)\n",
    "            numParams = jnp.size(weights)\n",
    "            \n",
    "            print(\"numParams: \", numParams) # for periodic output as status update\n",
    "            \n",
    "            # Append metrics to the DataFrame\n",
    "            metrics_df = pd.concat([metrics_df, pd.DataFrame({\n",
    "                \"Approach\": f\"{model_name}_{func}\",\n",
    "                \"Run\": [run],\n",
    "                \"Cost\": [c],\n",
    "                \"R2_Score\": [r2],\n",
    "                \"numParams\": [numParams]\n",
    "            })], ignore_index=True)\n",
    "    \n",
    "            # Save to a file after each iteration\n",
    "            metrics_df.to_csv(filepathDataframe, index=False)\n",
    "    \n",
    "            # print metrics for interim updates\n",
    "            print(f\"Approach {model_name}: Run: {run}, Cost = {c:.4f}, R2_Score = {r2:.4f}\")\n",
    "    "
   ],
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running 1 train blocks of 11\n"
     ]
    },
    {
     "data": {
      "text/plain": "<Figure size 1400x500 with 1 Axes>",
      "image/png": "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zBlJVbegqEuLFi2cr/EVDodDJSUlRofhdY1570F3FBQUOO8JWv0QqV27dik6Olqvv/66JKm8vFzvvPOOIiMjNWvWLJf3P/jgg+rTp4+2b9+uzz77TN27d/dq/FeqqKjQhQsXDPv8G1VRUaEDBw54bPsHDhzQmTNn6jwj1ld4Oz+quZMndZk9e7aWLFmiixcvasKECbrnnnu8FHFtnsgPjlfXz9ePVzAX6gcAAIA5REREyGKxGB0GGoC/cH1MSUmJmjVrZnQYfs9ms+nll192WXfzzTdrz549SkhIkCR98803Ki0tVc+ePRUREVFrGz179tT27duVm5traAMmKytLWVlZhn2+2ZWVlTkvt0fDuJMndZk/f74uXrwoSfr4449VUlJSZw55gz/kB8crwBjUDwAAAPecP39eTZs2NToMNIBfP/Su+szi+s4iPnv2bL1nHyOw9evXTw6HQw6HQ8ePH9frr7+u48ePa8CAATp//rykqt8fSYqOjq5zGz/96U9dXgf4G3fypKacnBzNnTtX7du319SpU1VQUKC0tDQvR+5fOF4BAAAAABqTX59hXH3v4vz8fCUnJ7v87N///rfOnz+vrl27GhHadYuIiKi3EePPpkyZYthZZ23atNHUqVN15swZzZkzR7NmzdJbb72lFi1aSJKKi4vrfN+///1vSXK+ziijRo3SggULDI3hRlRUVCg6Olrl5eUe2b7ValVxcbFPX1JsZH5Uqy9PrlRWVqYnn3xSDodD69atU6dOnbRt2zYtWrRIgwcPVkpKitfj9kR+cLy6fr5+vIK5UD8AAADMwagrSnH9/Pov3Pvvv1/z5s3Ttm3b9Nhjj7n8bOvWrc7X+BKLxRKQp/GHhoYaHYJmzpyp1atXa+nSpZo8ebJ+/vOfKywsTF999VWdl9T/4x//kCTdfffdznXBwcGSpEuXLnkrbIWGhvr878ydd96p7Oxsj23b1680MEN+VKuZJ1c+LG3WrFnKy8tTWlqa877F69atU9euXfX000/rwIEDXv9DwhP5YYbx4HgFVKF+AAAAAA3n17ekeOCBBxQXF6e3335bubm5zvVnzpzR3Llz1aRJEz355JPGBQifEh4erunTp6uiokK///3v1aRJEz3++OM6efKk5s2b5/Lajz/+WFu3blVCQoK6devmXN+qVStJ0rFjx7wau6+79957fXLbgahm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9QNNG6oxH3RXn5qxXbhwQYcOHWqUbcMVDWMAAACYxk9+8hPFxcVJqnrAlr+q3rf4+Hi1bNnS2GAAwA9QP4CG++KLL1yW4+Pjr/thd439oLu6REVFOfO8Ws19QOOgYQwAAABTefjhhyVVnZHir6r3rX///gZHAgD+g/oBNMz//u//uizXdY96d3jqQXd1qRljzX1A46BhDAAAAFMZN26cJGnLli0qKioyOJrGV1hYqC1btkj6cV8BADeO+gE0zMWLF12Wb7rppuvajqcedFeXmjHW3Ac0DhrGAAAAMJX27dvrgQcekN1u14oVK4wOp9GtWLFCDodDvXv3Vvv27Y0OBwD8BvUDaJjf/va3+uKLL7Rr1y799a9/1cSJExu8DU8/6K6miRMn6q9//at27dqlL774Qs8995xHPifQ0TAGAACA6TzzzDOSqi69LSsrMziaxlNWVua8nLh6HwEAjYf6Abivbdu2uueee9SjRw/96le/0l133dWg93vjQXc13X333frVr36lHj166J577lHbtm098jmBjoYxAAAATGfAgAG69dZbdfz4cW3YsMHocBrNn//8Z504cUJt27Z13msTANB4qB+A93jjQXcwBg1jAAAAmE5ISIjGjx8vSXr++ed16tQpgyO6cadOndK0adMkVZ0dFhISYnBEAOB/qB+Ad3jzQXfwPhrGAAAAMKXnnntOSUlJKi4u1qRJk4wO54ZNnDhRxcXFSkpK4n57AOBB1A/A87z5oDt4Hw1jAAAAmJLVatWaNWsUFBSkt99+W++9957RIV23zZs365133lFwcLDWrl0rq9VqdEgA4LeoH4BneftBd/A+GsYAAAAwra5duzovwx07dqxPXlp88uRJjR07VpI0bdo0denSxeCI6ma3240OwbSM+G4Yj/rx3cAd1A/vISfr54/1w4gH3TUWflfdR8MYAAAApva73/3OeWnxiBEjdOnSJaNDctulS5c0cuRIHT9+XElJSfrd735ndEhONc9SKy8vNygS8ysrK3NZDgsLa/TPYDzc543xgH+gfngGxyv3+WP98OUH3VE/3EfDGAAAAKYWFhamNWvWKDQ0VO+//77GjBkjh8NhdFjX5HA4NGbMGL3//vtq0qSJ6S4lrjlJKikpMSgS86v53Xhigsl4uM8b4wH/QP3wDI5X7vO3+uHrD7qjfriPhjEAAABMr2vX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"
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running function 1 of 10\n",
      "Cost at step 1000: 0.030113793184814303\n",
      "Cost at step 2000: 0.031505786907646216\n",
      "Cost at step 3000: 0.027683857306821658\n",
      "Cost at step 4000: 0.03733328007306875\n",
      "Cost at step 5000: 0.03356039656693893\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 0, Cost = 0.0336, R2_Score = 0.0788\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/lp/jt0n7jd956q7d8s04306_43r0000gn/T/ipykernel_99665/645245382.py:105: FutureWarning: The behavior of DataFrame concatenation with empty or all-NA entries is deprecated. In a future version, this will no longer exclude empty or all-NA columns when determining the result dtypes. To retain the old behavior, exclude the relevant entries before the concat operation.\n",
      "  metrics_df = pd.concat([metrics_df, pd.DataFrame({\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cost at step 1000: 0.040203861162955275\n",
      "Cost at step 2000: 0.053383017323266446\n",
      "Cost at step 3000: 0.04564348608668522\n",
      "Cost at step 4000: 0.04762984380885635\n",
      "Cost at step 5000: 0.05917465201583719\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 1, Cost = 0.0592, R2_Score = 0.0412\n",
      "Cost at step 1000: 0.03668252714093249\n",
      "Cost at step 2000: 0.048877966010016836\n",
      "Cost at step 3000: 0.06635023422108415\n",
      "Cost at step 4000: 0.039948585752759086\n",
      "Cost at step 5000: 0.05471833232062395\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 2, Cost = 0.0547, R2_Score = -0.0270\n",
      "Cost at step 1000: 0.015574333830251847\n",
      "Cost at step 2000: 0.04181336500465977\n",
      "Cost at step 3000: 0.04936699873719141\n",
      "Cost at step 4000: 0.04760710950928301\n",
      "Cost at step 5000: 0.026069051574349567\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 3, Cost = 0.0261, R2_Score = 0.1538\n",
      "Cost at step 1000: 0.0438454913573566\n",
      "Cost at step 2000: 0.017707321941371014\n",
      "Cost at step 3000: 0.029400206924054928\n",
      "Cost at step 4000: 0.026808682049273502\n",
      "Cost at step 5000: 0.03505997843219717\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 4, Cost = 0.0351, R2_Score = 0.0683\n",
      "Cost at step 1000: 0.07976876470912346\n",
      "Cost at step 2000: 0.07357231717410555\n",
      "Cost at step 3000: 0.05684825013486716\n",
      "Cost at step 4000: 0.048957517846567926\n",
      "Cost at step 5000: 0.04035804081406946\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 5, Cost = 0.0404, R2_Score = 0.0724\n",
      "Cost at step 1000: 0.0375250168450444\n",
      "Cost at step 2000: 0.03397805057477903\n",
      "Cost at step 3000: 0.04925826675688529\n",
      "Cost at step 4000: 0.0609574284342433\n",
      "Cost at step 5000: 0.027683431409507676\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 6, Cost = 0.0277, R2_Score = 0.1350\n",
      "Cost at step 1000: 0.06709225110816551\n",
      "Cost at step 2000: 0.040463619077682526\n",
      "Cost at step 3000: 0.03961774668585685\n",
      "Cost at step 4000: 0.03100637427460194\n",
      "Cost at step 5000: 0.03731335915029115\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 7, Cost = 0.0373, R2_Score = 0.1193\n",
      "Cost at step 1000: 0.05586584057186905\n",
      "Cost at step 2000: 0.045686902250910925\n",
      "Cost at step 3000: 0.03222411208557489\n",
      "Cost at step 4000: 0.035951042035051665\n",
      "Cost at step 5000: 0.03289543576823142\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 8, Cost = 0.0329, R2_Score = 0.1329\n",
      "Cost at step 1000: 0.06596598921453088\n",
      "Cost at step 2000: 0.020277887601768574\n",
      "Cost at step 3000: 0.047058913763840686\n",
      "Cost at step 4000: 0.0507889113932677\n",
      "Cost at step 5000: 0.047314922067939365\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 9, Cost = 0.0473, R2_Score = 0.0483\n",
      "running function 2 of 10\n",
      "Cost at step 1000: 0.014168346379494563\n",
      "Cost at step 2000: 0.04212570020896014\n",
      "Cost at step 3000: 0.04789263243227308\n",
      "Cost at step 4000: 0.02602186977193944\n",
      "Cost at step 5000: 0.037157537339294375\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 0, Cost = 0.0372, R2_Score = 0.1311\n",
      "Cost at step 1000: 0.054858076825450214\n",
      "Cost at step 2000: 0.021452438593396045\n",
      "Cost at step 3000: 0.02840301143456101\n",
      "Cost at step 4000: 0.037468361098089285\n",
      "Cost at step 5000: 0.028888854586944207\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 1, Cost = 0.0289, R2_Score = 0.1535\n",
      "Cost at step 1000: 0.03480177859109568\n",
      "Cost at step 2000: 0.021266761431631392\n",
      "Cost at step 3000: 0.04038956910783589\n",
      "Cost at step 4000: 0.02878001991689226\n",
      "Cost at step 5000: 0.028436762790719813\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 2, Cost = 0.0284, R2_Score = 0.1361\n",
      "Cost at step 1000: 0.0527446329564503\n",
      "Cost at step 2000: 0.035780301930574104\n",
      "Cost at step 3000: 0.03476298202578478\n",
      "Cost at step 4000: 0.03589661016288706\n",
      "Cost at step 5000: 0.036334010013945685\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 3, Cost = 0.0363, R2_Score = 0.1311\n",
      "Cost at step 1000: 0.022787546969024443\n",
      "Cost at step 2000: 0.037034688529321236\n",
      "Cost at step 3000: 0.028781275613605557\n",
      "Cost at step 4000: 0.03824606135587369\n",
      "Cost at step 5000: 0.0232565817365055\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 4, Cost = 0.0233, R2_Score = 0.1072\n",
      "Cost at step 1000: 0.03613213247698747\n",
      "Cost at step 2000: 0.020364495658367482\n",
      "Cost at step 3000: 0.03121084784650341\n",
      "Cost at step 4000: 0.02605616240551489\n",
      "Cost at step 5000: 0.057329277969649865\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 5, Cost = 0.0573, R2_Score = 0.1881\n",
      "Cost at step 1000: 0.07308183919390619\n",
      "Cost at step 2000: 0.0449079917473115\n",
      "Cost at step 3000: 0.03998127506779472\n",
      "Cost at step 4000: 0.03876408807452114\n",
      "Cost at step 5000: 0.031162424112182535\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 6, Cost = 0.0312, R2_Score = 0.1349\n",
      "Cost at step 1000: 0.044953324792240484\n",
      "Cost at step 2000: 0.025911979421125553\n",
      "Cost at step 3000: 0.017938725968205196\n",
      "Cost at step 4000: 0.03519982073225585\n",
      "Cost at step 5000: 0.03835604249587432\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 7, Cost = 0.0384, R2_Score = 0.1353\n",
      "Cost at step 1000: 0.04509281503710341\n",
      "Cost at step 2000: 0.028152615701000878\n",
      "Cost at step 3000: 0.0396683584108377\n",
      "Cost at step 4000: 0.03515047500172794\n",
      "Cost at step 5000: 0.03149615146882877\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 8, Cost = 0.0315, R2_Score = 0.1584\n",
      "Cost at step 1000: 0.043457264878980786\n",
      "Cost at step 2000: 0.033429427669721866\n",
      "Cost at step 3000: 0.03598976318119261\n",
      "Cost at step 4000: 0.046709380626748696\n",
      "Cost at step 5000: 0.026895292920354193\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 9, Cost = 0.0269, R2_Score = 0.2018\n",
      "running function 3 of 10\n",
      "Cost at step 1000: 0.05161654990141156\n",
      "Cost at step 2000: 0.03723156024576091\n",
      "Cost at step 3000: 0.025892791172481056\n",
      "Cost at step 4000: 0.02253494042110133\n",
      "Cost at step 5000: 0.026280444820307794\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 0, Cost = 0.0263, R2_Score = 0.3086\n",
      "Cost at step 1000: 0.04362195268742128\n",
      "Cost at step 2000: 0.023828503771716664\n",
      "Cost at step 3000: 0.03866650354165395\n",
      "Cost at step 4000: 0.030924336556569083\n",
      "Cost at step 5000: 0.04691486652084134\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 1, Cost = 0.0469, R2_Score = 0.2051\n",
      "Cost at step 1000: 0.03916067821783681\n",
      "Cost at step 2000: 0.03554520258119034\n",
      "Cost at step 3000: 0.025991866541252674\n",
      "Cost at step 4000: 0.02523077261761992\n",
      "Cost at step 5000: 0.022004163484522415\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 2, Cost = 0.0220, R2_Score = 0.2744\n",
      "Cost at step 1000: 0.037887112685276524\n",
      "Cost at step 2000: 0.05072828892624675\n",
      "Cost at step 3000: 0.03941278141025889\n",
      "Cost at step 4000: 0.01880332025252984\n",
      "Cost at step 5000: 0.0413452480544087\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 3, Cost = 0.0413, R2_Score = 0.2652\n",
      "Cost at step 1000: 0.03146795586790761\n",
      "Cost at step 2000: 0.03078982726298341\n",
      "Cost at step 3000: 0.024232857823748996\n",
      "Cost at step 4000: 0.024483426301844347\n",
      "Cost at step 5000: 0.03281589895837272\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 4, Cost = 0.0328, R2_Score = 0.2509\n",
      "Cost at step 1000: 0.04412760366287568\n",
      "Cost at step 2000: 0.023982997329987377\n",
      "Cost at step 3000: 0.023917217015279005\n",
      "Cost at step 4000: 0.031479272014002205\n",
      "Cost at step 5000: 0.030750885579396453\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 5, Cost = 0.0308, R2_Score = 0.3041\n",
      "Cost at step 1000: 0.07621428475736591\n",
      "Cost at step 2000: 0.04619598179241261\n",
      "Cost at step 3000: 0.033859480182190864\n",
      "Cost at step 4000: 0.023799366805370106\n",
      "Cost at step 5000: 0.03948580258828089\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 6, Cost = 0.0395, R2_Score = 0.3003\n",
      "Cost at step 1000: 0.04174141752283978\n",
      "Cost at step 2000: 0.036660061160727384\n",
      "Cost at step 3000: 0.021163908174765614\n",
      "Cost at step 4000: 0.0246182689724517\n",
      "Cost at step 5000: 0.04644514077172584\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 7, Cost = 0.0464, R2_Score = 0.2059\n",
      "Cost at step 1000: 0.06373014641841246\n",
      "Cost at step 2000: 0.04679212813643097\n",
      "Cost at step 3000: 0.033531433497229264\n",
      "Cost at step 4000: 0.019755463317999104\n",
      "Cost at step 5000: 0.03832050854908389\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 8, Cost = 0.0383, R2_Score = 0.2524\n",
      "Cost at step 1000: 0.03354667920093776\n",
      "Cost at step 2000: 0.045474029087902844\n",
      "Cost at step 3000: 0.03685119752220966\n",
      "Cost at step 4000: 0.03606088344911801\n",
      "Cost at step 5000: 0.030238403937685204\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 9, Cost = 0.0302, R2_Score = 0.1221\n",
      "running function 4 of 10\n",
      "Cost at step 1000: 0.030656500012575777\n",
      "Cost at step 2000: 0.02326352866026188\n",
      "Cost at step 3000: 0.019512137151670897\n",
      "Cost at step 4000: 0.026932045247943844\n",
      "Cost at step 5000: 0.028812782459772646\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 0, Cost = 0.0288, R2_Score = 0.1881\n",
      "Cost at step 1000: 0.036365681134164204\n",
      "Cost at step 2000: 0.03552544982943709\n",
      "Cost at step 3000: 0.03431880290643552\n",
      "Cost at step 4000: 0.026530487284600213\n",
      "Cost at step 5000: 0.027010956985261042\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 1, Cost = 0.0270, R2_Score = 0.2017\n",
      "Cost at step 1000: 0.04306973218015913\n",
      "Cost at step 2000: 0.03432209564536223\n",
      "Cost at step 3000: 0.02349051198187525\n",
      "Cost at step 4000: 0.03088858787421833\n",
      "Cost at step 5000: 0.033220489901195895\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 2, Cost = 0.0332, R2_Score = 0.2043\n",
      "Cost at step 1000: 0.024538765744582035\n",
      "Cost at step 2000: 0.03310681088551553\n",
      "Cost at step 3000: 0.039045082133783326\n",
      "Cost at step 4000: 0.045144900616034135\n",
      "Cost at step 5000: 0.04273751247779904\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 3, Cost = 0.0427, R2_Score = 0.1765\n",
      "Cost at step 1000: 0.03221346190160384\n",
      "Cost at step 2000: 0.018161887264253298\n",
      "Cost at step 3000: 0.025499550522060262\n",
      "Cost at step 4000: 0.03164436023658607\n",
      "Cost at step 5000: 0.04224671502133977\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 4, Cost = 0.0422, R2_Score = 0.1806\n",
      "Cost at step 1000: 0.03019418832265504\n",
      "Cost at step 2000: 0.031756144489746785\n",
      "Cost at step 3000: 0.02104175912150697\n",
      "Cost at step 4000: 0.027854102441271924\n",
      "Cost at step 5000: 0.030161338350820334\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 5, Cost = 0.0302, R2_Score = 0.2600\n",
      "Cost at step 1000: 0.050505499116303754\n",
      "Cost at step 2000: 0.040922614105694824\n",
      "Cost at step 3000: 0.06049489422290886\n",
      "Cost at step 4000: 0.02781048134128374\n",
      "Cost at step 5000: 0.023319143563999205\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 6, Cost = 0.0233, R2_Score = 0.1857\n",
      "Cost at step 1000: 0.034803614594598985\n",
      "Cost at step 2000: 0.02297450801377266\n",
      "Cost at step 3000: 0.026174571296919937\n",
      "Cost at step 4000: 0.03681564915621279\n",
      "Cost at step 5000: 0.022456520966311896\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 7, Cost = 0.0225, R2_Score = 0.2238\n",
      "Cost at step 1000: 0.036428026069901344\n",
      "Cost at step 2000: 0.039268080738532496\n",
      "Cost at step 3000: 0.04140202632402816\n",
      "Cost at step 4000: 0.05193626758289686\n",
      "Cost at step 5000: 0.03338509725534218\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 8, Cost = 0.0334, R2_Score = 0.1280\n",
      "Cost at step 1000: 0.04733207341522048\n",
      "Cost at step 2000: 0.03312440960516807\n",
      "Cost at step 3000: 0.030641923110778\n",
      "Cost at step 4000: 0.022907829179808485\n",
      "Cost at step 5000: 0.04386077510515134\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 9, Cost = 0.0439, R2_Score = 0.2103\n",
      "running function 5 of 10\n",
      "Cost at step 1000: 0.055429538301737295\n",
      "Cost at step 2000: 0.037508023770245785\n",
      "Cost at step 3000: 0.021297422849253282\n",
      "Cost at step 4000: 0.030187175979363618\n",
      "Cost at step 5000: 0.03156293788386016\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 0, Cost = 0.0316, R2_Score = 0.1474\n",
      "Cost at step 1000: 0.01670751748872675\n",
      "Cost at step 2000: 0.02751865840753941\n",
      "Cost at step 3000: 0.04004996556595071\n",
      "Cost at step 4000: 0.028806892227896286\n",
      "Cost at step 5000: 0.02347579251325282\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 1, Cost = 0.0235, R2_Score = 0.1346\n",
      "Cost at step 1000: 0.04495717249849404\n",
      "Cost at step 2000: 0.026558386239720906\n",
      "Cost at step 3000: 0.018537651146831435\n",
      "Cost at step 4000: 0.020581891342981384\n",
      "Cost at step 5000: 0.014773881092142706\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 2, Cost = 0.0148, R2_Score = 0.1383\n",
      "Cost at step 1000: 0.026519384123324316\n",
      "Cost at step 2000: 0.03661263698991696\n",
      "Cost at step 3000: 0.04648137301418721\n",
      "Cost at step 4000: 0.042158507867439396\n",
      "Cost at step 5000: 0.06082589392923297\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 3, Cost = 0.0608, R2_Score = -0.9454\n",
      "Cost at step 1000: 0.031517125986135396\n",
      "Cost at step 2000: 0.016491891720675524\n",
      "Cost at step 3000: 0.021026221045262503\n",
      "Cost at step 4000: 0.01500554670511383\n",
      "Cost at step 5000: 0.02753285807725966\n",
      "numParams:  24\n",
      "Approach selFreqs_parallel_ternary_2nd: Run: 4, Cost = 0.0275, R2_Score = 0.1476\n",
      "Cost at step 1000: 0.023975975046734963\n",
      "Cost at step 2000: 0.01684666821154183\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "KeyboardInterrupt\n",
      "\n"
     ]
    }
   ],
   "execution_count": 12
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-09-16T11:05:44.009264Z",
     "start_time": "2025-09-16T11:05:44.007231Z"
    }
   },
   "cell_type": "code",
   "source": [],
   "outputs": [],
   "execution_count": null
  }
 ],
 "metadata": {
  "kernelspec": {
   "name": "python3",
   "language": "python",
   "display_name": "Python 3 (ipykernel)"
  },
  "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.15"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 0
}
