{
 "cells": [
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Product Kernels\n",
    "\n",
    "This notebook illustrates use of products, for both manifolds and kernels. Specifically, we will (i) construct a Matérn kernel on the product manifold \n",
    "$$\n",
    "X \\times Y\n",
    "$$\n",
    "using individual eigenfunctions from both spaces, and (ii) construct kernels \n",
    "$$\n",
    "k((x,y), (x',y')) = k_X(x,x') k_X(y,y')\n",
    "$$\n",
    "whose arguments are pairs of points $(x,y)$ on two manifolds $X$ and $Y$, and where $k_X$ and $k_Y$ are kernels on $X$ and $Y$."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO: Using numpy backend\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from geometric_kernels.spaces import Circle, ProductDiscreteSpectrumSpace\n",
    "from geometric_kernels.kernels import MaternKarhunenLoeveKernel"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Here, we construct a Matérn kernel on a product manifold. In this example, our manifolds will be $X = Y = \\mathbb{S}_1$, which are both circles. The product manifold $X \\times Y = \\mathbb{T}_2 = \\mathbb{S}_1^2$ is a two-dimensional torus. Since both $X$ and $Y$ are compact, they admit a countable number of eigenfunctions: we use this to represent their product as a `ProductDiscreteSpectrumSpace`, which keeps appropriate track of products of eigenfunctions. To plot the kernels, we also create a grid of evaluation points."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_eigenfunctions = 11\n",
    "product = ProductDiscreteSpectrumSpace(Circle(), Circle(), num_eigen=num_eigenfunctions**2)\n",
    "eigenfunctions = product.get_eigenfunctions(num_eigenfunctions**2)\n",
    "\n",
    "line = np.linspace(0, 2*np.pi, 20)\n",
    "ones = np.ones(20)\n",
    "grid = np.stack(\n",
    "    (line[:, None] * ones[None, :],\n",
    "    line[None, :] * ones[:, None]),\n",
    "    axis=-1).reshape(20**2, 2)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Using the constructed product space, we can now construct the kernel in the standard manner, and initialize its parameters."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "kernel = MaternKarhunenLoeveKernel(product, num_eigenfunctions**2)\n",
    "\n",
    "params, state = kernel.init_params_and_state()\n",
    "params['nu'] = np.array(2.5)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We now plot the resulting kernel $k((10,10),(x,y))$ for $(x,y)$ pairs on a grid."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x17b7c3c10>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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b78tY0zE4Dl27JjOnj0bun3y5EmVlJTo3Llz6t+/v+69917t3btX/fv3j7Y9AEAP5xkTb5eWRK+xsVEZGRmaoGlK8pK7ux37PFvXAkpeYqKlQvbOMnvJln7Vauu5SfISLT0/rirsXBmuKuxcmR58VeEl06bt2qSGhgalp6d3OJbvKgQAOIXgAgA4heACADiF4AIAOIXgAgA4heACADiF4AIAOIXgAgA4heACADiF4AIAOIXgAgA4JaYzICP+2Jq52Euw991ytr5/zQta7Clo6XsPE3r4Z0Nb29zid/BZ+/pVS98v+GWp+PpeQNf18FcVAKCnIbgAAE4huAAATiG4AABOIbgAAE4huAAATiG4AABOIbgAAE4huAAATiG4AABOIbgAAE4huAAATiG4AABOIbgAAE4huAAATiG4AABOIbgAAE7pETMgX57x9JLapB450ahnsZadzyqesdiTpZlmbW4lGUszIJse/tnQ1izBxuYMyLYK9exZme1tKDsuqU1S57ZVjwiu8+fPS5J2aXM3dxIjNvcvW7Usvn50yWItAE47f/68MjIyOhzjGWsfBbpPMBjUqVOnlJaWJs+L/Lm7sbFRubm5OnHihNLT07uww2tD313L1b4ld3un764Vj30bY3T+/Hnl5OQoIaHjMxU94ogrISFBAwcO7PT49PT0uPlhRYO+u5arfUvu9k7fXSve+r7akdZlPfwEPACgpyG4AABOua6Cy+fzafny5fL5fN3dSlTou2u52rfkbu/03bVc7fuyHnFxBgDg+nFdHXEBANxHcAEAnEJwAQCcQnABAJzS44Jr1apVGjx4sFJTU5Wfn699+/Z1OP6dd97RiBEjlJqaqlGjRmnz5q792qiysjLdc889SktL04ABAzR9+nQdPny4w3XKy8vleV7Ykpqa2kUdf2nFihVX9DBixIgO1+nubS1JgwcPvqJvz/O0aNGidsd357beuXOnpk6dqpycHHmep40bN4Y9bozRsmXLlJ2drV69eqmwsFBHjhy5at1oXyM2+25ra9OSJUs0atQo9enTRzk5OZozZ45OnTrVYc2/Zn+z2bckzZs374oepkyZctW63bm9JbW7v3uepxdffDFiza7Y3teiRwXX+vXrVVpaquXLl6uyslJ5eXkqKirSmTNn2h2/e/dulZSUaP78+Tp48KCmT5+u6dOn69ChQ13W844dO7Ro0SLt3btXW7duVVtbmyZPnqzm5uYO10tPT9fp06dDS01NTRd1/JWRI0eG9bBr166IY+NhW0vSH//4x7Cet27dKkmaOXNmxHW6a1s3NzcrLy9Pq1atavfxn//85/r1r3+tNWvW6OOPP1afPn1UVFSkixcvRqwZ7WvEdt8XLlxQZWWlnn32WVVWVurdd9/V4cOH9eCDD161bjT7m+2+L5syZUpYD2+99VaHNbt7e0sK6/f06dNau3atPM/TQw891GHdWG/va2J6kHHjxplFixaFbgcCAZOTk2PKysraHf/www+bBx54IOy+/Px88w//8A8x7bMjZ86cMZLMjh07Io5Zt26dycjI6Lqm2rF8+XKTl5fX6fHxuK2NMeaJJ54wt956qwkGg+0+Hg/b2hhjJJn33nsvdDsYDJqsrCzz4osvhu6rr683Pp/PvPXWWxHrRPsasd13e/bt22ckmZqamohjot3frlV7fc+dO9dMmzYtqjrxuL2nTZtmvvvd73Y4pqu3d7R6zBFXa2urDhw4oMLCwtB9CQkJKiws1J49e9pdZ8+ePWHjJamoqCji+K7Q0NAgSbrxxhs7HNfU1KRBgwYpNzdX06ZN06efftoV7YU5cuSIcnJyNHToUM2ePVu1tbURx8bjtm5tbdUbb7yhxx57rMMvZ46Hbf2Xqqur5ff7w7ZpRkaG8vPzI27Tv+Y10hUaGhrkeZ769u3b4bho9rdY2b59uwYMGKDhw4dr4cKFOnfuXMSx8bi96+rq9MEHH2j+/PlXHRsP2zuSHhNcZ8+eVSAQUGZmZtj9mZmZ8vv97a7j9/ujGh9rwWBQTz75pL7zne/ozjvvjDhu+PDhWrt2rTZt2qQ33nhDwWBQ48eP18mTJ7us1/z8fJWXl2vLli1avXq1qqurdd9994WmmPlL8batJWnjxo2qr6/XvHnzIo6Jh23dnsvbLZpt+te8RmLt4sWLWrJkiUpKSjr8stdo97dYmDJlil5//XVVVFToZz/7mXbs2KHi4mIFAu3P2xWP2/u1115TWlqavv/973c4Lh62d0d6xLfD9xSLFi3SoUOHrnouuaCgQAUFBaHb48eP1+23365XXnlFL7zwQqzblCQVFxeH/j169Gjl5+dr0KBB2rBhQ6c+zcWDV199VcXFxcrJyYk4Jh62dU/V1tamhx9+WMYYrV69usOx8bC/PfLII6F/jxo1SqNHj9att96q7du3a9KkSV3Sw7Vau3atZs+efdULjOJhe3ekxxxx9evXT4mJiaqrqwu7v66uTllZWe2uk5WVFdX4WFq8eLHef/99ffTRR1FN0SJJycnJuuuuu3T06NEYdXd1ffv21bBhwyL2EE/bWpJqamq0bds2Pf7441GtFw/bWlJou0WzTf+a10isXA6tmpoabd26NeqpNa62v3WFoUOHql+/fhF7iKftLUm///3vdfjw4aj3eSk+tvfX9ZjgSklJ0dixY1VRURG6LxgMqqKiIuwT89cVFBSEjZekrVu3RhwfC8YYLV68WO+9954+/PBDDRkyJOoagUBAn3zyibKzs2PQYec0NTXp2LFjEXuIh239devWrdOAAQP0wAMPRLVePGxrSRoyZIiysrLCtmljY6M+/vjjiNv0r3mNxMLl0Dpy5Ii2bdumm266KeoaV9vfusLJkyd17ty5iD3Ey/a+7NVXX9XYsWOVl5cX9brxsL3DdPfVITa9/fbbxufzmfLycvM///M/5oc//KHp27ev8fv9xhhj/v7v/948/fTTofF/+MMfTFJSkvnFL35h/vznP5vly5eb5ORk88knn3RZzwsXLjQZGRlm+/bt5vTp06HlwoULoTF/2fdzzz1nfvvb35pjx46ZAwcOmEceecSkpqaaTz/9tMv6/qd/+iezfft2U11dbf7whz+YwsJC069fP3PmzJl2e46HbX1ZIBAwt9xyi1myZMkVj8XTtj5//rw5ePCgOXjwoJFkXnrpJXPw4MHQ1Xc//elPTd++fc2mTZvMn/70JzNt2jQzZMgQ88UXX4RqfPe73zW/+c1vQrev9hqJdd+tra3mwQcfNAMHDjRVVVVh+3xLS0vEvq+2v8W67/Pnz5unnnrK7Nmzx1RXV5tt27aZu+++29x2223m4sWLEfvu7u19WUNDg+ndu7dZvXp1uzW6Y3tfix4VXMYY85vf/MbccsstJiUlxYwbN87s3bs39Nj9999v5s6dGzZ+w4YNZtiwYSYlJcWMHDnSfPDBB13ar6R2l3Xr1kXs+8knnww9x8zMTPO9733PVFZWdmnfs2bNMtnZ2SYlJcXcfPPNZtasWebo0aMRezam+7f1Zb/97W+NJHP48OErHounbf3RRx+1u29c7i8YDJpnn33WZGZmGp/PZyZNmnTFcxo0aJBZvnx52H0dvUZi3Xd1dXXEff6jjz6K2PfV9rdY933hwgUzefJk079/f5OcnGwGDRpkFixYcEUAxdv2vuyVV14xvXr1MvX19e3W6I7tfS2Y1gQA4JQe8zsuAMD1geACADiF4AIAOIXgAgA4heACADiF4AIAOIXgAgA4heACADiF4AIAOIXgAgA4heACADiF4AIAOOX/AQT6kbnThaHiAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "k_xx = kernel.K(params, state, grid, grid)\n",
    "k_xx = k_xx.reshape(20,20,20,20)\n",
    "\n",
    "plt.imshow(k_xx[10,10])"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Next, we will construct a product kernel \n",
    "$$\n",
    "k((x,y), (x',y')) = k_X(x,x') k_X(y,y')\n",
    ".\n",
    "$$\n",
    "We start by construcitng a kernel on the circle $Y$, and plot it."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x17eec2430>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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AGAVggsAYBWCCwBgFYILAGAVggsAYBWCCwBgFYILAGAVggsAYBWCCwBgFYILAGAVggsAYBWCCwBgFYILAGAVggsAYJWoB9fYsWPlcDguW1asWBGyvry8/LLapKSkaLcFABgion4/ro8//lg9PT2B9WPHjul73/ue7r///rBjUlJSdPz48cC6w+GIdlsAgCEi6sGVlpYWtP6zn/1MN910k+68886wYxwOhzIyMqLdCgBgCIrpe1xdXV167bXX9Mgjj/R6FtXe3q4xY8YoKytLixYt0meffRbLtgAAFov6Gddfq6ioUGtrq5YuXRq2ZuLEidq0aZOmTp0qr9erF154QbNmzdJnn32mUaNGhRzT2dmpzs7OwLrP55MkTZrapGHDE6P6GAAAsdfd0aWmPtbG9Izr1VdfVUFBgdxud9ia3NxcLVmyRNOmTdOdd96pd955R2lpaXrllVfCjiktLZXL5QosWVlZsWgfADAIxSy4GhsbtWvXLj366KMRjRs2bJhuv/121dXVha1Zs2aNvF5vYDl16tTVtgsAsETMgmvz5s0aOXKk7r777ojG9fT06NNPP1VmZmbYGqfTqZSUlKAFAHBtiElw+f1+bd68WcXFxUpICH4bbcmSJVqzZk1g/dlnn9Xvf/97/eUvf1FNTY3+8R//UY2NjRGfqQEArg0xuThj165dampq0iOPPHLZvqamJsXFfZWXX3zxhR577DF5PB5df/31mj59ug4cOKBbb701Fq0BACznMMaYgW7iavl8PrlcLs3/3eNcVQgAFuru6NLvC34jr9d7xbd/+K5CAIBVCC4AgFUILgCAVQguAIBVCC4AgFUILgCAVQguAIBVCC4AgFUILgCAVQguAIBVCC4AgFViegfk/rbqxvc1PJksBgDbdLT59fs+1vJXHgBgFYILAGAVggsAYBWCCwBgFYILAGAVggsAYBWCCwBgFYILAGAVggsAYBWCCwBgFYILAGAVggsAYBWCCwBgFYILAGAVggsAYBWCCwBgFYILAGAVggsAYJWEgW4gmmYkxSsliSwGANv4uh19ruWvPADAKgQXAMAqBBcAwCoEFwDAKgQXAMAqEQfXvn37tHDhQrndbjkcDlVUVATtN8Zo7dq1yszM1HXXXae8vDydOHHiisctKyvT2LFjlZSUpJycHB06dCjS1gAA14CIg6ujo0PZ2dkqKysLuf8Xv/iFfv3rX+vll1/WRx99pOHDhys/P18XLlwIe8ytW7eqpKRE69atU01NjbKzs5Wfn6+zZ89G2h4AYIhzGGPM1x7scGjbtm0qLCyU9D9nW263Wz/60Y+0atUqSZLX61V6errKy8v14IMPhjxOTk6OZsyYoQ0bNkiS/H6/srKy9MMf/lBPPfXUFfvw+XxyuVz64v+MV0oyr34CgG18bX5dP+Ev8nq9SklJ6bU2qn/lGxoa5PF4lJeXF9jmcrmUk5Oj6urqkGO6urp05MiRoDFxcXHKy8sLO6azs1M+ny9oAQBcG6IaXB6PR5KUnp4etD09PT2w72+dO3dOPT09EY0pLS2Vy+UKLFlZWVHoHgBgAytfV1uzZo28Xm9gOXXq1EC3BADoJ1ENroyMDElSS0tL0PaWlpbAvr81YsQIxcfHRzTG6XQqJSUlaAEAXBuiGlzjxo1TRkaGqqqqAtt8Pp8++ugj5ebmhhyTmJio6dOnB43x+/2qqqoKOwYAcO2K+Nvh29vbVVdXF1hvaGhQbW2tbrjhBo0ePVpPPvmk/vVf/1U333yzxo0bp6efflputztw5aEkzZs3T/fee69WrlwpSSopKVFxcbG+9a1vaebMmfrVr36ljo4OPfzww1f/CAEAQ0rEwXX48GHNnTs3sF5SUiJJKi4uVnl5uf7lX/5FHR0devzxx9Xa2qrZs2ersrJSSUlJgTH19fU6d+5cYH3x4sX6/PPPtXbtWnk8Hk2bNk2VlZWXXbABAMBVfY5rsOBzXABgtwH7HBcAALE2pO6A/PGFHg0fZv0JJABcczou+PtcyxkXAMAqBBcAwCoEFwDAKgQXAMAqBBcAwCoEFwDAKgQXAMAqBBcAwCoEFwDAKgQXAMAqBBcAwCoEFwDAKgQXAMAqBBcAwCoEFwDAKgQXAMAqBBcAwCoEFwDAKgkD3UA0vfB/8zVseOJAtwEAiFB3R5ek3/SpljMuAIBVCC4AgFUILgCAVQguAIBVCC4AgFUILgCAVQguAIBVCC4AgFUILgCAVQguAIBVCC4AgFUILgCAVQguAIBVCC4AgFUiDq59+/Zp4cKFcrvdcjgcqqioCOzr7u7W6tWrNWXKFA0fPlxut1tLlizRmTNnej3m+vXr5XA4gpZJkyZF/GAAAENfxMHV0dGh7OxslZWVXbbvyy+/VE1NjZ5++mnV1NTonXfe0fHjx3XPPfdc8biTJ09Wc3NzYNm/f3+krQEArgER30iyoKBABQUFIfe5XC7t3LkzaNuGDRs0c+ZMNTU1afTo0eEbSUhQRkZGpO0AAK4xMb8DstfrlcPhUGpqaq91J06ckNvtVlJSknJzc1VaWho26Do7O9XZ2RlY9/l8kqQ/fzJacUlJUesdANA//Bcu9Lk2phdnXLhwQatXr1ZRUZFSUlLC1uXk5Ki8vFyVlZXauHGjGhoaNGfOHLW1tYWsLy0tlcvlCixZWVmxeggAgEEmZsHV3d2tBx54QMYYbdy4sdfagoIC3X///Zo6dary8/O1Y8cOtba26q233gpZv2bNGnm93sBy6tSpWDwEAMAgFJOXCi+FVmNjoz744INez7ZCSU1N1YQJE1RXVxdyv9PplNPpjEarAADLRP2M61JonThxQrt27dI3vvGNiI/R3t6u+vp6ZWZmRrs9AIDlIg6u9vZ21dbWqra2VpLU0NCg2tpaNTU1qbu7W//wD/+gw4cP6z//8z/V09Mjj8cjj8ejrq6uwDHmzZunDRs2BNZXrVqlvXv36uTJkzpw4IDuvfdexcfHq6io6OofIQBgSIn4pcLDhw9r7ty5gfWSkhJJUnFxsdavX6//+q//kiRNmzYtaNzu3bt11113SZLq6+t17ty5wL7Tp0+rqKhI58+fV1pammbPnq2DBw8qLS0t0vYAAENcxMF11113yRgTdn9v+y45efJk0Pqbb74ZaRsAgGsU31UIALAKwQUAsArBBQCwCsEFALAKwQUAsArBBQCwCsEFALAKwQUAsArBBQCwCsEFALAKwQUAsEpM7sc1UFL/6FB8omOg2wAARKiny6GmPtZyxgUAsArBBQCwCsEFALAKwQUAsArBBQCwCsEFALAKwQUAsArBBQCwCsEFALAKwQUAsArBBQCwCsEFALAKwQUAsArBBQCwCsEFALAKwQUAsArBBQCwypC6A7LrL51KSOAOyABgm4sXO/tcyxkXAMAqBBcAwCoEFwDAKgQXAMAqBBcAwCoRB9e+ffu0cOFCud1uORwOVVRUBO1funSpHA5H0LJgwYIrHresrExjx45VUlKScnJydOjQoUhbAwBcAyIOro6ODmVnZ6usrCxszYIFC9Tc3BxY3njjjV6PuXXrVpWUlGjdunWqqalRdna28vPzdfbs2UjbAwAMcRF/jqugoEAFBQW91jidTmVkZPT5mC+++KIee+wxPfzww5Kkl19+We+99542bdqkp556KtIWAQBDWEze49qzZ49GjhypiRMnavny5Tp//nzY2q6uLh05ckR5eXlfNRUXp7y8PFVXV4cc09nZKZ/PF7QAAK4NUQ+uBQsW6Le//a2qqqr085//XHv37lVBQYF6enpC1p87d049PT1KT08P2p6eni6PxxNyTGlpqVwuV2DJysqK9sMAAAxSUf/KpwcffDDw7ylTpmjq1Km66aabtGfPHs2bNy8qP2PNmjUqKSkJrPt8PsILAK4RMb8cfvz48RoxYoTq6upC7h8xYoTi4+PV0tIStL2lpSXs+2ROp1MpKSlBCwDg2hDz4Dp9+rTOnz+vzMzMkPsTExM1ffp0VVVVBbb5/X5VVVUpNzc31u0BACwTcXC1t7ertrZWtbW1kqSGhgbV1taqqalJ7e3t+vGPf6yDBw/q5MmTqqqq0qJFi/TNb35T+fn5gWPMmzdPGzZsCKyXlJToP/7jP7Rlyxb96U9/0vLly9XR0RG4yhAAgEsifo/r8OHDmjt3bmD90ntNxcXF2rhxoz755BNt2bJFra2tcrvdmj9/vp577jk5nc7AmPr6ep07dy6wvnjxYn3++edau3atPB6Ppk2bpsrKyssu2AAAwGGMMQPdxNXy+XxyuVyaM2etEhKSBrodAECELl68oA8/fFZer/eK1y3wXYUAAKsQXAAAq0T9c1wDKfH/tioh3nnlQgDAoBLX09n32hj2AQBA1BFcAACrEFwAAKsQXAAAqxBcAACrEFwAAKsQXAAAqxBcAACrEFwAAKsQXAAAqxBcAACrEFwAAKsQXAAAqxBcAACrEFwAAKsQXAAAqxBcAACrDKk7IOsLr+RIHOguAACRMl19LuWMCwBgFYILAGAVggsAYBWCCwBgFYILAGAVggsAYBWCCwBgFYILAGAVggsAYBWCCwBgFYILAGAVggsAYBWCCwBgFYILAGCViINr3759WrhwodxutxwOhyoqKoL2OxyOkMvzzz8f9pjr16+/rH7SpEkRPxgAwNAXcXB1dHQoOztbZWVlIfc3NzcHLZs2bZLD4dB9993X63EnT54cNG7//v2RtgYAuAZEfCPJgoICFRQUhN2fkZERtL59+3bNnTtX48eP772RhITLxgIA8Ldi+h5XS0uL3nvvPS1btuyKtSdOnJDb7db48eP10EMPqampKWxtZ2enfD5f0AIAuDZEfMYViS1btig5OVk/+MEPeq3LyclReXm5Jk6cqObmZj3zzDOaM2eOjh07puTk5MvqS0tL9cwzz1y23d/WLr9jWNT6BwD0D7/p7nOtwxhjvu4Pcjgc2rZtmwoLC0PunzRpkr73ve/ppZdeiui4ra2tGjNmjF588cWQZ2udnZ3q7OwMrPt8PmVlZWluwn1KILgAwDoXTbd2X/zf8nq9SklJ6bU2ZmdcH374oY4fP66tW7dGPDY1NVUTJkxQXV1dyP1Op1NOp/NqWwQAWChm73G9+uqrmj59urKzsyMe297ervr6emVmZsagMwCAzSIOrvb2dtXW1qq2tlaS1NDQoNra2qCLKXw+n95++209+uijIY8xb948bdiwIbC+atUq7d27VydPntSBAwd07733Kj4+XkVFRZG2BwAY4iJ+qfDw4cOaO3duYL2kpESSVFxcrPLycknSm2++KWNM2OCpr6/XuXPnAuunT59WUVGRzp8/r7S0NM2ePVsHDx5UWlpapO0BAIa4q7o4Y7Dw+XxyuVxcnAEAlork4gy+qxAAYBWCCwBgFYILAGAVggsAYBWCCwBgFYILAGAVggsAYBWCCwBgFYILAGAVggsAYBWCCwBglZjeAbm/mYsXZRyOgW4DABAhYy72uZYzLgCAVQguAIBVCC4AgFUILgCAVQguAIBVCC4AgFUILgCAVQguAIBVCC4AgFUILgCAVQguAIBVCC4AgFUILgCAVQguAIBVCC4AgFUILgCAVQguAIBVhsQdkI0xkqSL6pbMADcDAIjYRXVL+urveW+GRHC1tbVJkvZrxwB3AgC4Gm1tbXK5XL3WOExf4m2Q8/v9OnPmjJKTk+VwOMLW+Xw+ZWVl6dSpU0pJSenHDq8OffcvW/uW7O2dvvvXYOzbGKO2tja53W7FxfX+LtaQOOOKi4vTqFGj+lyfkpIyaP5jRYK++5etfUv29k7f/Wuw9X2lM61LuDgDAGAVggsAYJVrKricTqfWrVsnp9M50K1EhL77l619S/b2Tt/9y9a+LxkSF2cAAK4d19QZFwDAfgQXAMAqBBcAwCoEFwDAKkMuuMrKyjR27FglJSUpJydHhw4d6rX+7bff1qRJk5SUlKQpU6Zox47+/dqo0tJSzZgxQ8nJyRo5cqQKCwt1/PjxXseUl5fL4XAELUlJSf3U8f9Yv379ZT1MmjSp1zEDPdeSNHbs2Mv6djgcWrFiRcj6gZzrffv2aeHChXK73XI4HKqoqAjab4zR2rVrlZmZqeuuu055eXk6ceLEFY8b6e9INPvu7u7W6tWrNWXKFA0fPlxut1tLlizRmTNnej3m13m+RbNvSVq6dOllPSxYsOCKxx3I+ZYU8vnucDj0/PPPhz1mf8z31RhSwbV161aVlJRo3bp1qqmpUXZ2tvLz83X27NmQ9QcOHFBRUZGWLVumo0ePqrCwUIWFhTp27Fi/9bx3716tWLFCBw8e1M6dO9Xd3a358+ero6Oj13EpKSlqbm4OLI2Njf3U8VcmT54c1MP+/fvD1g6GuZakjz/+OKjnnTt3SpLuv//+sGMGaq47OjqUnZ2tsrKykPt/8Ytf6Ne//rVefvllffTRRxo+fLjy8/N14cKFsMeM9Hck2n1/+eWXqqmp0dNPP62amhq98847On78uO65554rHjeS51u0+75kwYIFQT288cYbvR5zoOdbUlC/zc3N2rRpkxwOh+67775ejxvr+b4qZgiZOXOmWbFiRWC9p6fHuN1uU1paGrL+gQceMHfffXfQtpycHPPP//zPMe2zN2fPnjWSzN69e8PWbN682bhcrv5rKoR169aZ7OzsPtcPxrk2xpgnnnjC3HTTTcbv94fcPxjm2hhjJJlt27YF1v1+v8nIyDDPP/98YFtra6txOp3mjTfeCHucSH9Hot13KIcOHTKSTGNjY9iaSJ9vVytU38XFxWbRokURHWcwzveiRYvMd7/73V5r+nu+IzVkzri6urp05MgR5eXlBbbFxcUpLy9P1dXVIcdUV1cH1UtSfn5+2Pr+4PV6JUk33HBDr3Xt7e0aM2aMsrKytGjRIn322Wf90V6QEydOyO12a/z48XrooYfU1NQUtnYwznVXV5dee+01PfLII71+OfNgmOu/1dDQII/HEzSnLpdLOTk5Yef06/yO9Aev1yuHw6HU1NRe6yJ5vsXKnj17NHLkSE2cOFHLly/X+fPnw9YOxvluaWnRe++9p2XLll2xdjDMdzhDJrjOnTunnp4epaenB21PT0+Xx+MJOcbj8URUH2t+v19PPvmkvvOd7+i2224LWzdx4kRt2rRJ27dv12uvvSa/369Zs2bp9OnT/dZrTk6OysvLVVlZqY0bN6qhoUFz5swJ3GLmbw22uZakiooKtba2aunSpWFrBsNch3Jp3iKZ06/zOxJrFy5c0OrVq1VUVNTrl71G+nyLhQULFui3v/2tqqqq9POf/1x79+5VQUGBenp6QtYPxvnesmWLkpOT9YMf/KDXusEw370ZEt8OP1SsWLFCx44du+Jrybm5ucrNzQ2sz5o1S7fccoteeeUVPffcc7FuU5JUUFAQ+PfUqVOVk5OjMWPG6K233urT/80NBq+++qoKCgrkdrvD1gyGuR6quru79cADD8gYo40bN/ZaOxiebw8++GDg31OmTNHUqVN10003ac+ePZo3b16/9HC1Nm3apIceeuiKFxgNhvnuzZA54xoxYoTi4+PV0tIStL2lpUUZGRkhx2RkZERUH0srV67Uu+++q927d0d0ixZJGjZsmG6//XbV1dXFqLsrS01N1YQJE8L2MJjmWpIaGxu1a9cuPfrooxGNGwxzLSkwb5HM6df5HYmVS6HV2NionTt3RnxrjSs93/rD+PHjNWLEiLA9DKb5lqQPP/xQx48fj/g5Lw2O+f5rQya4EhMTNX36dFVVVQW2+f1+VVVVBf0f81/Lzc0NqpeknTt3hq2PBWOMVq5cqW3btumDDz7QuHHjIj5GT0+PPv30U2VmZsagw75pb29XfX192B4Gw1z/tc2bN2vkyJG6++67Ixo3GOZaksaNG6eMjIygOfX5fProo4/CzunX+R2JhUuhdeLECe3atUvf+MY3Ij7GlZ5v/eH06dM6f/582B4Gy3xf8uqrr2r69OnKzs6OeOxgmO8gA311SDS9+eabxul0mvLycvPHP/7RPP744yY1NdV4PB5jjDH/9E//ZJ566qlA/R/+8AeTkJBgXnjhBfOnP/3JrFu3zgwbNsx8+umn/dbz8uXLjcvlMnv27DHNzc2B5csvvwzU/G3fzzzzjHn//fdNfX29OXLkiHnwwQdNUlKS+eyzz/qt7x/96Edmz549pqGhwfzhD38weXl5ZsSIEebs2bMhex4Mc31JT0+PGT16tFm9evVl+wbTXLe1tZmjR4+ao0ePGknmxRdfNEePHg1cffezn/3MpKammu3bt5tPPvnELFq0yIwbN87893//d+AY3/3ud81LL70UWL/S70is++7q6jL33HOPGTVqlKmtrQ16znd2dobt+0rPt1j33dbWZlatWmWqq6tNQ0OD2bVrl7njjjvMzTffbC5cuBC274Ge70u8Xq/5u7/7O7Nx48aQxxiI+b4aQyq4jDHmpZdeMqNHjzaJiYlm5syZ5uDBg4F9d955pykuLg6qf+utt8yECRNMYmKimTx5snnvvff6tV9JIZfNmzeH7fvJJ58MPMb09HTz/e9/39TU1PRr34sXLzaZmZkmMTHR3HjjjWbx4sWmrq4ubM/GDPxcX/L+++8bSeb48eOX7RtMc7179+6Qz41L/fn9fvP000+b9PR043Q6zbx58y57TGPGjDHr1q0L2tbb70is+25oaAj7nN+9e3fYvq/0fIt1319++aWZP3++SUtLM8OGDTNjxowxjz322GUBNNjm+5JXXnnFXHfddaa1tTXkMQZivq8GtzUBAFhlyLzHBQC4NhBcAACrEFwAAKsQXAAAqxBcAACrEFwAAKsQXAAAqxBcAACrEFwAAKsQXAAAqxBcAACrEFwAAKv8P9Cwg5sHMXIOAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "kernel_single = MaternKarhunenLoeveKernel(Circle(), num_eigenfunctions)\n",
    "\n",
    "params_single, state_single = kernel_single.init_params_and_state()\n",
    "params_single['nu'] = np.array(2.5)\n",
    "\n",
    "k_xx_single_1 = kernel_single.K(params_single, state_single, grid[..., :1], grid[..., :1]).reshape(20,20,20,20)\n",
    "plt.imshow(k_xx_single_1[10,10])\n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Similarly, we can construct and plot the kernel on $X$, which lives on the other axis."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x17ef214f0>"
      ]
     },
     "execution_count": 9,
     "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": [
    "k_xx_single_2 = kernel_single.K(params_single, state_single, grid[..., 1:], grid[..., 1:]).reshape(20,20,20,20)\n",
    "plt.imshow(k_xx_single_2[10,10])"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Now, constructing the product kernel is as simple as multiplying the two kernels togetherL we plot the resulting kernel below."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x17f01bb20>"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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uMPHfT6ffJZeWAAAbrH+UaExRgsXLtQHH3ygjz/+WIMGDYq5RjAY1GeffaacnBzb7QEAHGf9jGvBggV6++23tWHDBmVkZCgQCEiS/H6/evXqJUmaNWuWbrnlFpWXl0uSXnzxRd1333361re+pfr6er388ss6duyYnnzySdvtAQAcZz24Vq5cKUkaN25cxP1r1qzRnDlzJEm1tbVKSvr6ZO/LL7/UvHnzFAgEdOONN2r06NHauXOn7rzzTtvtAQAcF9eLM7pLY2Oj/H4/F2d0qRYXZ3QJF2d0CRdndLEWF2dcUSwXZ/BdhQAApxBcAACnEFwAAKcQXAAApxBcAACnEFwAAKcQXAAApxBcAACnEFwAAKcQXAAApxBcAACnxG09rqvC8+x+r1+isPT9gpK97xi0+b2AXlqanTrX9bJSR5JMLzvfVRhKt7huXIql4+Cive+78y7Y+Y5BL8XiS5F33lIdi68lbXbKGEtfefgVi997aIUndfHrEznjAgA4heACADiF4AIAOIXgAgA4heACADiF4AIAOIXgAgA4heACADiF4AIAOIXgAgA4heACADiF4AIAOIXgAgA4heACADiF4AIAOIXgAgA4heACADilh62AnGR1teBEYWvVYsneysWexZV9vV52Vi42GddZqSNJQb+dntpvsLdSdCjNzrGd1GZv5dvUZjurVyc32Hsp8mytXJyUgKupW1pJWbK9mrINSayADADomQguAIBTCC4AgFMILgCAUwguAIBTrAfXsmXL5HlexDZs2LBO93nvvfc0bNgwpaena8SIEdq4caPttgAAPURczriGDx+uU6dOhbcdO3ZEHbtz506VlpZq7ty52r9/v6ZOnaqpU6fqwIED8WgNAOC4uARXSkqKsrOzw1ufPn2ijv2Xf/kXTZo0ST/84Q91xx136KWXXtI999yj5cuXx6M1AIDj4hJchw4dUm5urgYPHqyZM2eqtrY26thdu3apqKgo4r7i4mLt2rUr6j6tra1qbGyM2AAA1wbrwVVQUKCKigpt2rRJK1euVE1NjR544AE1NTV1OD4QCCgrKyvivqysLAUCgaj/j/Lycvn9/vCWl5dn9WcAACQu68FVUlKi6dOna+TIkSouLtbGjRtVX1+vdevWWft/LF68WA0NDeHt+PHj1moDABJb3L+rsHfv3hoyZIgOHz7c4ePZ2dmqq6uL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t2PHjnVTx18bPnx4RA87duyIOjYR5lqSfv/730f0vHnzZknS9OnTo+5ztea6paVF+fn5WrFiRYeP/+xnP9OvfvUrrVq1Sp9++qmuv/56FRcX68KFC1Frxvocsd33uXPnVFVVpeeff15VVVV6//33dfDgQT388MNXrBvL8Wa770smTZoU0cM777zTac2rPd+SIvo9deqUVq9eLc/z9P3vf7/TuvGe72/E9CBjxowxCxYsCN8OBoMmNzfXlJeXdzj+0UcfNQ899FDEfQUFBebv//7v49pnZ06fPm0kmW3btkUds2bNGuP3+7uvqQ4sXbrU5Ofnd3l8Is61McY89dRT5rbbbjOhUKjDxxNhro0xRpL54IMPwrdDoZDJzs42L7/8cvi++vp64/P5zDvvvBO1TqzPEdt9d2TPnj1Gkjl27FjUMbEeb99UR33Pnj3bTJkyJaY6iTjfU6ZMMd/97nc7HdPd8x2rHnPG1dbWpn379qmoqCh8X1JSkoqKirRr164O99m1a1fEeEkqLi6OOr47NDQ0SJJuuummTsc1NzdrwIABysvL05QpU/T55593R3sRDh06pNzcXA0ePFgzZ85UbW1t1LGJONdtbW1666239MQTT3T65cyJMNd/rqamRoFAIGJO/X6/CgoKos7pX/Ic6Q4NDQ3yPE+9e/fudFwsx1u8bN26Vf369dPQoUM1f/58nT17NurYRJzvuro6ffTRR5o7d+4VxybCfEfTY4LrzJkzCgaDysrKirg/KytLgUCgw30CgUBM4+MtFArp6aef1ne+8x3dddddUccNHTpUq1ev1oYNG/TWW28pFApp7NixOnHiRLf1WlBQoIqKCm3atEkrV65UTU2NHnjggfASM38u0eZaktavX6/6+nrNmTMn6phEmOuOXJq3WOb0L3mOxNuFCxe0aNEilZaWdvplr7Eeb/EwadIkvfnmm6qsrNRPf/pTbdu2TSUlJQoGO17/KxHn+4033lBGRoYeeeSRTsclwnx3pkd8O3xPsWDBAh04cOCKnyUXFhaqsLAwfHvs2LG644479Nprr+mll16Kd5uSpJKSkvB/jxw5UgUFBRowYIDWrVvXpXdzieD1119XSUmJcnNzo45JhLnuqdrb2/Xoo4/KGKOVK1d2OjYRjrfHHnss/N8jRozQyJEjddttt2nr1q2aMGFCt/TwTa1evVozZ8684gVGiTDfnekxZ1x9+vRRcnKy6urqIu6vq6tTdnZ2h/tkZ2fHND6eFi5cqA8//FCffPJJTEu0SFJqaqruvvtuHT58OE7dXVnv3r01ZMiQqD0k0lxL0rFjx7RlyxY9+eSTMe2XCHMtKTxvsczpX/IciZdLoXXs2DFt3rw55qU1rnS8dYfBgwerT58+UXtIpPmWpN/+9rc6ePBgzMe8lBjz/ad6THClpaVp9OjRqqysDN8XCoVUWVkZ8Y75TxUWFkaMl6TNmzdHHR8PxhgtXLhQH3zwgT7++GMNGjQo5hrBYFCfffaZcnJy4tBh1zQ3N+vIkSNRe0iEuf5Ta9asUb9+/fTQQw/FtF8izLUkDRo0SNnZ2RFz2tjYqE8//TTqnP4lz5F4uBRahw4d0pYtW3TzzTfHXONKx1t3OHHihM6ePRu1h0SZ70tef/11jR49Wvn5+THvmwjzHeFqXx1i07vvvmt8Pp+pqKgw//3f/21+8IMfmN69e5tAIGCMMebv/u7vzLPPPhse/7vf/c6kpKSYn//85+aPf/yjWbp0qUlNTTWfffZZt/U8f/584/f7zdatW82pU6fC27lz58Jj/rzvF154wfzmN78xR44cMfv27TOPPfaYSU9PN59//nm39f2P//iPZuvWraampsb87ne/M0VFRaZPnz7m9OnTHfacCHN9STAYNLfeeqtZtGjRZY8l0lw3NTWZ/fv3m/379xtJ5pVXXjH79+8PX333k5/8xPTu3dts2LDB/OEPfzBTpkwxgwYNMufPnw/X+O53v2t+/etfh29f6TkS777b2trMww8/bPr372+qq6sjjvnW1taofV/peIt3301NTeaZZ54xu3btMjU1NWbLli3mnnvuMbfffru5cOFC1L6v9nxf0tDQYK677jqzcuXKDmtcjfn+JnpUcBljzK9//Wtz6623mrS0NDNmzBize/fu8GMPPvigmT17dsT4devWmSFDhpi0tDQzfPhw89FHH3Vrv5I63NasWRO176effjr8M2ZlZZnvfe97pqqqqlv7njFjhsnJyTFpaWnmlltuMTNmzDCHDx+O2rMxV3+uL/nNb35jJJmDBw9e9lgizfUnn3zS4bFxqb9QKGSef/55k5WVZXw+n5kwYcJlP9OAAQPM0qVLI+7r7DkS775ramqiHvOffPJJ1L6vdLzFu+9z586ZiRMnmr59+5rU1FQzYMAAM2/evMsCKNHm+5LXXnvN9OrVy9TX13dY42rM9zfBsiYAAKf0mN9xAQCuDQQXAMApBBcAwCkEFwDAKQQXAMApBBcAwCkEFwDAKQQXAMApBBcAwCkEFwDAKQQXAMApBBcAwCn/HxDEdWNgRAiCAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "k_xx_product = k_xx_single_1 * k_xx_single_2\n",
    "plt.imshow(k_xx_product[10,10])"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The product Matérn kernel $k^{(\\nu)}_{X\\times Y}$ is not necessarily the same as the product of two Matérn kernels $k^{(\\nu)}_X$ and $k^{(\\nu)}_Y$ on its components: in general, we have\n",
    "$$\n",
    "k_{X\\times Y}^{(\\nu)}((x,y), (x',y')) \\neq k^{(\\nu)}_X(x,x') k^{(\\nu)}_X(y,y')\n",
    ".\n",
    "$$\n",
    "Equality holds for the squared exponential kernel $\\nu = \\infty$, but not in general.\n",
    "The difference, however, can be numerically small, as we see below: in practice, we can recommend using both variants, since in most cases they will behave similarly.\n",
    "One advantage of working with $k^{(\\nu)}_X(x,x') k^{(\\nu)}_X(y,y')$ is that it allows one to define separate length scales for each kernel, allowing one to apply techniques such as *automatic relevance determination* on manifolds."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.022036036149764272"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.abs(k_xx - k_xx_product).max()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "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.6"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
