{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "0bcc30f5-8177-4caf-9894-76de754c393a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "# use a GPU if available\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "# Set default tensor type to float64\n",
    "torch.set_default_dtype(torch.float64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "9b7b4f18-d992-4286-a5d0-fa18d5da7d0d",
   "metadata": {},
   "outputs": [],
   "source": [
    "from botorch.utils.sampling import draw_sobol_samples\n",
    "from botorch.optim import optimize_acqf\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "b158fa1e-65e4-424f-aaf1-6b05df410072",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<torch._C.Generator at 0x117d720d0>"
      ]
     },
     "execution_count": 67,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seed = 42\n",
    "# Set the seed for reproducibility\n",
    "torch.manual_seed(seed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "f362fb7c-b9ec-4dfe-9c9a-7f9bcf91643e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/qianxie/Desktop/Curriculum/Graduate/Research/PandoraBayesOPT/pandorabayesopt_env/lib/python3.9/site-packages/botorch/models/utils/assorted.py:202: InputDataWarning: Input data is not standardized (mean = tensor([0.0250]), std = tensor([0.8421])). Please consider scaling the input to zero mean and unit variance.\n",
      "  warnings.warn(msg, InputDataWarning)\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import gpytorch\n",
    "from botorch.models import SingleTaskGP\n",
    "from gpytorch.likelihoods import FixedNoiseGaussianLikelihood\n",
    "from gpytorch.means import ConstantMean\n",
    "from gpytorch.kernels import MaternKernel, ScaleKernel\n",
    "\n",
    "# Example Usage for 1D\n",
    "dim = 1\n",
    "\n",
    "# Define your kernel\n",
    "nu = 2.5\n",
    "lengthscale = 0.1\n",
    "outputscale = 1.0\n",
    "base_kernel = MaternKernel(nu=nu).double()\n",
    "base_kernel.lengthscale = torch.tensor([[lengthscale]])\n",
    "base_kernel.raw_lengthscale.requires_grad = False\n",
    "scale_kernel = ScaleKernel(base_kernel).double()\n",
    "scale_kernel.outputscale = torch.tensor([[outputscale]])\n",
    "scale_kernel.raw_outputscale.requires_grad = False\n",
    "\n",
    "# Define Noise Level\n",
    "noise_level = 1e-4\n",
    "\n",
    "# Initialize Placeholder Data with Correct Dimensions\n",
    "num_samples = 1  # Replace with actual number of samples\n",
    "num_features = 1  # Replace with actual number of features\n",
    "train_X = torch.tensor([[0.0], [0.3], [0.7], [1.0]])  # Placeholder data\n",
    "train_Y = torch.tensor([[0.7], [0.2], [-1.2], [0.4]])             # Placeholder data\n",
    "Yvar = torch.ones(num_samples) * noise_level\n",
    "\n",
    "# Initialize Model\n",
    "model = SingleTaskGP(train_X, train_Y, likelihood = FixedNoiseGaussianLikelihood(noise=Yvar), covar_module=scale_kernel)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "ccd82160-16e8-4adf-93aa-7deb722b3402",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "SingleTaskGP(\n",
       "  (likelihood): FixedNoiseGaussianLikelihood(\n",
       "    (noise_covar): FixedGaussianNoise()\n",
       "  )\n",
       "  (mean_module): ConstantMean()\n",
       "  (covar_module): ScaleKernel(\n",
       "    (base_kernel): MaternKernel(\n",
       "      (raw_lengthscale_constraint): Positive()\n",
       "    )\n",
       "    (raw_outputscale_constraint): Positive()\n",
       "  )\n",
       ")"
      ]
     },
     "execution_count": 69,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "0ad68f96-0d6e-44de-8874-77837ee6d0f1",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/qianxie/Desktop/Curriculum/Graduate/Research/PandoraBayesOPT/pandorabayesopt_env/lib/python3.9/site-packages/gpytorch/likelihoods/gaussian_likelihood.py:300: GPInputWarning: You have passed data through a FixedNoiseGaussianLikelihood that did not match the size of the fixed noise, *and* you did not specify noise. This is treated as a no-op.\n",
      "  warnings.warn(\n",
      "/Users/qianxie/Desktop/Curriculum/Graduate/Research/PandoraBayesOPT/pandorabayesopt_env/lib/python3.9/site-packages/gpytorch/distributions/multivariate_normal.py:319: NumericalWarning: Negative variance values detected. This is likely due to numerical instabilities. Rounding negative variances up to 1e-10.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x1600a5d60>"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "test_x = torch.linspace(0, 1, 101)\n",
    "with torch.no_grad():\n",
    "        \n",
    "    # # Plot the objective function at the test points\n",
    "    # plt.plot(test_x.cpu().numpy(), objective_function(test_x.view(-1,1)).detach().numpy(), 'tab:grey', alpha=0.6)\n",
    "\n",
    "    # Calculate the posterior at the test points\n",
    "    posterior = model.posterior(test_x.unsqueeze(1).unsqueeze(1))\n",
    "\n",
    "    # Get upper and lower confidence bounds (2 standard deviations from the mean)\n",
    "    mean = posterior.mean.squeeze(-1).squeeze(-1).cpu().numpy()\n",
    "    lower, upper = posterior.mvn.confidence_region()\n",
    "    lower = lower.squeeze(-1).squeeze(-1).cpu().numpy()\n",
    "    upper = upper.squeeze(-1).squeeze(-1).cpu().numpy()\n",
    "    # # Plot training points as black stars\n",
    "    # plt.plot(train_x.cpu().numpy(), train_y.cpu().numpy(), 'k*', alpha=0.8)\n",
    "    # Plot posterior means as blue line\n",
    "    plt.plot(test_x.cpu().numpy(), mean, alpha=0.8)\n",
    "    # Shade between the lower and upper confidence bounds\n",
    "    plt.fill_between(test_x.cpu().numpy(), lower, upper, alpha=0.2)\n",
    "    \n",
    "\n",
    "plt.legend(['Mean', 'Confidence'], loc=\"upper left\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "fe6dfe42",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([0.  , 0.01, 0.02, 0.03, 0.04, 0.05, 0.06, 0.07, 0.08, 0.09, 0.1 ,\n",
       "        0.11, 0.12, 0.13, 0.14, 0.15, 0.16, 0.17, 0.18, 0.19, 0.2 , 0.21,\n",
       "        0.22, 0.23, 0.24, 0.25, 0.26, 0.27, 0.28, 0.29, 0.3 , 0.31, 0.32,\n",
       "        0.33, 0.34, 0.35, 0.36, 0.37, 0.38, 0.39, 0.4 , 0.41, 0.42, 0.43,\n",
       "        0.44, 0.45, 0.46, 0.47, 0.48, 0.49, 0.5 , 0.51, 0.52, 0.53, 0.54,\n",
       "        0.55, 0.56, 0.57, 0.58, 0.59, 0.6 , 0.61, 0.62, 0.63, 0.64, 0.65,\n",
       "        0.66, 0.67, 0.68, 0.69, 0.7 , 0.71, 0.72, 0.73, 0.74, 0.75, 0.76,\n",
       "        0.77, 0.78, 0.79, 0.8 , 0.81, 0.82, 0.83, 0.84, 0.85, 0.86, 0.87,\n",
       "        0.88, 0.89, 0.9 , 0.91, 0.92, 0.93, 0.94, 0.95, 0.96, 0.97, 0.98,\n",
       "        0.99, 1.  ]),\n",
       " array([ 0.7       ,  0.69522183,  0.67981446,  0.65539073,  0.62395843,\n",
       "         0.58758053,  0.54817993,  0.50743924,  0.46676179,  0.42727001,\n",
       "         0.38982524,  0.35505833,  0.32340415,  0.29513567,  0.27039501,\n",
       "         0.24922012,  0.2315665 ,  0.21732369,  0.20632676,  0.19836317,\n",
       "         0.19317528,  0.19045939,  0.18986188,  0.19097357,  0.19332387,\n",
       "         0.19637671,  0.19953146,  0.20213327,  0.20349928,  0.20297016,\n",
       "         0.2       ,  0.19429879,  0.18593579,  0.17523277,  0.16261823,\n",
       "         0.14853427,  0.13338216,  0.11749338,  0.10111713,  0.08441784,\n",
       "         0.06747847,  0.05030682,  0.03284294,  0.01496675, -0.00349495,\n",
       "        -0.02276209, -0.04309572, -0.06479289, -0.08818187, -0.11361705,\n",
       "        -0.14147338, -0.17213941, -0.20600855, -0.24346774, -0.28488261,\n",
       "        -0.33057845, -0.38081594, -0.43576087, -0.49544708, -0.559732  ,\n",
       "        -0.62824514, -0.70032991, -0.77498146, -0.85078441, -0.92585805,\n",
       "        -0.99782079, -1.06379241, -1.12046184, -1.16426177, -1.19170954,\n",
       "        -1.2       , -1.18794116, -1.15663641, -1.1088014 , -1.04782743,\n",
       "        -0.97718787, -0.90009658, -0.81933304, -0.73717444, -0.65539388,\n",
       "        -0.57529687, -0.49777782, -0.42338491, -0.35238602, -0.28483188,\n",
       "        -0.22061441, -0.15951969, -0.1012758 , -0.0455962 ,  0.00778035,\n",
       "         0.05905278,  0.10832289,  0.15556275,  0.20058527,  0.24301979,\n",
       "         0.28229655,  0.31764602,  0.3481229 ,  0.37266902,  0.39023627,\n",
       "         0.4       ]),\n",
       " array([ 0.69998   ,  0.43921279,  0.17837926, -0.07372647, -0.31087198,\n",
       "        -0.52901436, -0.72588774, -0.90058845, -1.05319399, -1.18443357,\n",
       "        -1.2954154 , -1.3874086 , -1.46167385, -1.51933545, -1.56128749,\n",
       "        -1.58812791, -1.60011541, -1.59714624, -1.57874939, -1.54410121,\n",
       "        -1.49206206, -1.42124007, -1.33008892, -1.21704824, -1.08073708,\n",
       "        -0.92021076, -0.7352911 , -0.5269762 , -0.29792915, -0.05303445,\n",
       "         0.19998   , -0.06179256, -0.31584824, -0.55470942, -0.7737676 ,\n",
       "        -0.97066771, -1.14475955, -1.29661825, -1.42764518, -1.53974982,\n",
       "        -1.63510623, -1.71597412, -1.78457335, -1.84300087, -1.89318006,\n",
       "        -1.93683382, -1.97547376, -2.0103996 , -2.04270365, -2.0732764 ,\n",
       "        -2.10281023, -2.13179876, -2.16053034, -2.18907445, -2.21726065,\n",
       "        -2.24465017, -2.27050105, -2.29372849, -2.31286337, -2.32601295,\n",
       "        -2.33082984, -2.32449756, -2.30374376, -2.26489604, -2.20399976,\n",
       "        -2.11702278, -2.00017824, -1.85040403, -1.6660458 , -1.4478009 ,\n",
       "        -1.20002   , -1.44394577, -1.65806485, -1.83791087, -1.98264999,\n",
       "        -2.09377534, -2.17415753, -2.22735485, -2.25712523, -2.26709335,\n",
       "        -2.26053421, -2.24024221, -2.20846107, -2.16685594, -2.11651379,\n",
       "        -2.05796244, -1.99120219, -1.91574692, -1.83067421, -1.73468658,\n",
       "        -1.62618785, -1.50338069, -1.36439303, -1.20744242, -1.03104788,\n",
       "        -0.83429835, -0.61718439, -0.3809943 , -0.12876618,  0.13422722,\n",
       "         0.39998   ]),\n",
       " array([ 0.70002   ,  0.95123088,  1.18124966,  1.38450794,  1.55878883,\n",
       "         1.70417543,  1.8222476 ,  1.91546692,  1.98671757,  2.0389736 ,\n",
       "         2.07506588,  2.09752525,  2.10848215,  2.1096068 ,  2.10207751,\n",
       "         2.08656814,  2.06324841,  2.03179361,  1.99140292,  1.94082755,\n",
       "         1.87841262,  1.80215886,  1.70981267,  1.59899538,  1.46738482,\n",
       "         1.31296418,  1.13435403,  0.93124274,  0.70492772,  0.45897478,\n",
       "         0.20002   ,  0.45039015,  0.68771982,  0.90517496,  1.09900406,\n",
       "         1.26773626,  1.41152387,  1.531605  ,  1.62987943,  1.70858549,\n",
       "         1.77006317,  1.81658776,  1.85025924,  1.87293436,  1.88619016,\n",
       "         1.89130963,  1.88928232,  1.88081381,  1.86633992,  1.8460423 ,\n",
       "         1.81986347,  1.78751995,  1.74851323,  1.70213897,  1.64749543,\n",
       "         1.58349328,  1.50886917,  1.42220674,  1.32196922,  1.20654894,\n",
       "         1.07433957,  0.92383775,  0.75378085,  0.56332722,  0.35228366,\n",
       "         0.12138119, -0.12740658, -0.39051965, -0.66247774, -0.93561819,\n",
       "        -1.19998   , -0.93193654, -0.65520798, -0.37969193, -0.11300487,\n",
       "         0.1393996 ,  0.37396437,  0.58868877,  0.78277635,  0.95630558,\n",
       "         1.10994047,  1.24468656,  1.36169125,  1.4620839 ,  1.54685003,\n",
       "         1.61673361,  1.6721628 ,  1.71319533,  1.7394818 ,  1.75024727,\n",
       "         1.74429342,  1.72002648,  1.67551853,  1.60861295,  1.51708746,\n",
       "         1.39889144,  1.25247642,  1.0772401 ,  0.87410422,  0.64624532,\n",
       "         0.40002   ]))"
      ]
     },
     "execution_count": 71,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_x.cpu().numpy(), mean, lower, upper"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "22a13cbd",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "# Reshape or transpose if necessary (depends on how you want to align them)\n",
    "arrays_combined = np.column_stack((test_x.cpu().numpy().flatten(), mean.flatten(), lower.flatten(), upper.flatten()))\n",
    "\n",
    "# Reshape back to have 4 columns, one for each original array\n",
    "# arrays_combined_reshaped = arrays_combined.reshape(-1, 4)\n",
    "\n",
    "# Save to CSV\n",
    "np.savetxt('gp_posterior.csv', arrays_combined, delimiter=',', fmt='%f', header='x, mean, lower, upper')\n",
    "\n",
    "# fmt='%d' is used to format the numbers as integers, change it according to your data type."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "fd41e65d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[ 0.        ,  0.7       ,  0.69998   ,  0.70002   ],\n",
       "       [ 0.01      ,  0.69522183,  0.43921279,  0.95123088],\n",
       "       [ 0.02      ,  0.67981446,  0.17837926,  1.18124966],\n",
       "       [ 0.03      ,  0.65539073, -0.07372647,  1.38450794],\n",
       "       [ 0.04      ,  0.62395843, -0.31087198,  1.55878883],\n",
       "       [ 0.05      ,  0.58758053, -0.52901436,  1.70417543],\n",
       "       [ 0.06      ,  0.54817993, -0.72588774,  1.8222476 ],\n",
       "       [ 0.07      ,  0.50743924, -0.90058845,  1.91546692],\n",
       "       [ 0.08      ,  0.46676179, -1.05319399,  1.98671757],\n",
       "       [ 0.09      ,  0.42727001, -1.18443357,  2.0389736 ],\n",
       "       [ 0.1       ,  0.38982524, -1.2954154 ,  2.07506588],\n",
       "       [ 0.11      ,  0.35505833, -1.3874086 ,  2.09752525],\n",
       "       [ 0.12      ,  0.32340415, -1.46167385,  2.10848215],\n",
       "       [ 0.13      ,  0.29513567, -1.51933545,  2.1096068 ],\n",
       "       [ 0.14      ,  0.27039501, -1.56128749,  2.10207751],\n",
       "       [ 0.15      ,  0.24922012, -1.58812791,  2.08656814],\n",
       "       [ 0.16      ,  0.2315665 , -1.60011541,  2.06324841],\n",
       "       [ 0.17      ,  0.21732369, -1.59714624,  2.03179361],\n",
       "       [ 0.18      ,  0.20632676, -1.57874939,  1.99140292],\n",
       "       [ 0.19      ,  0.19836317, -1.54410121,  1.94082755],\n",
       "       [ 0.2       ,  0.19317528, -1.49206206,  1.87841262],\n",
       "       [ 0.21      ,  0.19045939, -1.42124007,  1.80215886],\n",
       "       [ 0.22      ,  0.18986188, -1.33008892,  1.70981267],\n",
       "       [ 0.23      ,  0.19097357, -1.21704824,  1.59899538],\n",
       "       [ 0.24      ,  0.19332387, -1.08073708,  1.46738482],\n",
       "       [ 0.25      ,  0.19637671, -0.92021076,  1.31296418],\n",
       "       [ 0.26      ,  0.19953146, -0.7352911 ,  1.13435403],\n",
       "       [ 0.27      ,  0.20213327, -0.5269762 ,  0.93124274],\n",
       "       [ 0.28      ,  0.20349928, -0.29792915,  0.70492772],\n",
       "       [ 0.29      ,  0.20297016, -0.05303445,  0.45897478],\n",
       "       [ 0.3       ,  0.2       ,  0.19998   ,  0.20002   ],\n",
       "       [ 0.31      ,  0.19429879, -0.06179256,  0.45039015],\n",
       "       [ 0.32      ,  0.18593579, -0.31584824,  0.68771982],\n",
       "       [ 0.33      ,  0.17523277, -0.55470942,  0.90517496],\n",
       "       [ 0.34      ,  0.16261823, -0.7737676 ,  1.09900406],\n",
       "       [ 0.35      ,  0.14853427, -0.97066771,  1.26773626],\n",
       "       [ 0.36      ,  0.13338216, -1.14475955,  1.41152387],\n",
       "       [ 0.37      ,  0.11749338, -1.29661825,  1.531605  ],\n",
       "       [ 0.38      ,  0.10111713, -1.42764518,  1.62987943],\n",
       "       [ 0.39      ,  0.08441784, -1.53974982,  1.70858549],\n",
       "       [ 0.4       ,  0.06747847, -1.63510623,  1.77006317],\n",
       "       [ 0.41      ,  0.05030682, -1.71597412,  1.81658776],\n",
       "       [ 0.42      ,  0.03284294, -1.78457335,  1.85025924],\n",
       "       [ 0.43      ,  0.01496675, -1.84300087,  1.87293436],\n",
       "       [ 0.44      , -0.00349495, -1.89318006,  1.88619016],\n",
       "       [ 0.45      , -0.02276209, -1.93683382,  1.89130963],\n",
       "       [ 0.46      , -0.04309572, -1.97547376,  1.88928232],\n",
       "       [ 0.47      , -0.06479289, -2.0103996 ,  1.88081381],\n",
       "       [ 0.48      , -0.08818187, -2.04270365,  1.86633992],\n",
       "       [ 0.49      , -0.11361705, -2.0732764 ,  1.8460423 ],\n",
       "       [ 0.5       , -0.14147338, -2.10281023,  1.81986347],\n",
       "       [ 0.51      , -0.17213941, -2.13179876,  1.78751995],\n",
       "       [ 0.52      , -0.20600855, -2.16053034,  1.74851323],\n",
       "       [ 0.53      , -0.24346774, -2.18907445,  1.70213897],\n",
       "       [ 0.54      , -0.28488261, -2.21726065,  1.64749543],\n",
       "       [ 0.55      , -0.33057845, -2.24465017,  1.58349328],\n",
       "       [ 0.56      , -0.38081594, -2.27050105,  1.50886917],\n",
       "       [ 0.57      , -0.43576087, -2.29372849,  1.42220674],\n",
       "       [ 0.58      , -0.49544708, -2.31286337,  1.32196922],\n",
       "       [ 0.59      , -0.559732  , -2.32601295,  1.20654894],\n",
       "       [ 0.6       , -0.62824514, -2.33082984,  1.07433957],\n",
       "       [ 0.61      , -0.70032991, -2.32449756,  0.92383775],\n",
       "       [ 0.62      , -0.77498146, -2.30374376,  0.75378085],\n",
       "       [ 0.63      , -0.85078441, -2.26489604,  0.56332722],\n",
       "       [ 0.64      , -0.92585805, -2.20399976,  0.35228366],\n",
       "       [ 0.65      , -0.99782079, -2.11702278,  0.12138119],\n",
       "       [ 0.66      , -1.06379241, -2.00017824, -0.12740658],\n",
       "       [ 0.67      , -1.12046184, -1.85040403, -0.39051965],\n",
       "       [ 0.68      , -1.16426177, -1.6660458 , -0.66247774],\n",
       "       [ 0.69      , -1.19170954, -1.4478009 , -0.93561819],\n",
       "       [ 0.7       , -1.2       , -1.20002   , -1.19998   ],\n",
       "       [ 0.71      , -1.18794116, -1.44394577, -0.93193654],\n",
       "       [ 0.72      , -1.15663641, -1.65806485, -0.65520798],\n",
       "       [ 0.73      , -1.1088014 , -1.83791087, -0.37969193],\n",
       "       [ 0.74      , -1.04782743, -1.98264999, -0.11300487],\n",
       "       [ 0.75      , -0.97718787, -2.09377534,  0.1393996 ],\n",
       "       [ 0.76      , -0.90009658, -2.17415753,  0.37396437],\n",
       "       [ 0.77      , -0.81933304, -2.22735485,  0.58868877],\n",
       "       [ 0.78      , -0.73717444, -2.25712523,  0.78277635],\n",
       "       [ 0.79      , -0.65539388, -2.26709335,  0.95630558],\n",
       "       [ 0.8       , -0.57529687, -2.26053421,  1.10994047],\n",
       "       [ 0.81      , -0.49777782, -2.24024221,  1.24468656],\n",
       "       [ 0.82      , -0.42338491, -2.20846107,  1.36169125],\n",
       "       [ 0.83      , -0.35238602, -2.16685594,  1.4620839 ],\n",
       "       [ 0.84      , -0.28483188, -2.11651379,  1.54685003],\n",
       "       [ 0.85      , -0.22061441, -2.05796244,  1.61673361],\n",
       "       [ 0.86      , -0.15951969, -1.99120219,  1.6721628 ],\n",
       "       [ 0.87      , -0.1012758 , -1.91574692,  1.71319533],\n",
       "       [ 0.88      , -0.0455962 , -1.83067421,  1.7394818 ],\n",
       "       [ 0.89      ,  0.00778035, -1.73468658,  1.75024727],\n",
       "       [ 0.9       ,  0.05905278, -1.62618785,  1.74429342],\n",
       "       [ 0.91      ,  0.10832289, -1.50338069,  1.72002648],\n",
       "       [ 0.92      ,  0.15556275, -1.36439303,  1.67551853],\n",
       "       [ 0.93      ,  0.20058527, -1.20744242,  1.60861295],\n",
       "       [ 0.94      ,  0.24301979, -1.03104788,  1.51708746],\n",
       "       [ 0.95      ,  0.28229655, -0.83429835,  1.39889144],\n",
       "       [ 0.96      ,  0.31764602, -0.61718439,  1.25247642],\n",
       "       [ 0.97      ,  0.3481229 , -0.3809943 ,  1.0772401 ],\n",
       "       [ 0.98      ,  0.37266902, -0.12876618,  0.87410422],\n",
       "       [ 0.99      ,  0.39023627,  0.13422722,  0.64624532],\n",
       "       [ 1.        ,  0.4       ,  0.39998   ,  0.40002   ]])"
      ]
     },
     "execution_count": 73,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "arrays_combined"
   ]
  }
 ],
 "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.9.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
