{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "16f1658e-79cf-497a-b082-c2a817a98fff",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using backend: pytorch\n",
      "Other supported backends: tensorflow.compat.v1, tensorflow, jax, paddle.\n",
      "paddle supports more examples now and is recommended.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computing Forward Solutions.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Processing samples: 100%|█████████████████████████████████████████████████████████████████| 1/1 [00:01<00:00,  1.32s/it]\n"
     ]
    }
   ],
   "source": [
    "from rte import *\n",
    "import math\n",
    "import matplotlib.pyplot as plt\n",
    "import os\n",
    "os.environ[\"DDE_BACKEND\"] = \"pytorch\"\n",
    "import deepxde as dde\n",
    "from time import time\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore', message='.*rcond.*')\n",
    "import csv\n",
    "import numpy as np\n",
    "import random\n",
    "import argparse\n",
    "\n",
    "# Set random seed\n",
    "seed = 314\n",
    "random.seed(seed)\n",
    "np.random.seed(seed)\n",
    "torch.manual_seed(seed)\n",
    "if torch.cuda.is_available():\n",
    "    torch.cuda.manual_seed_all(seed)\n",
    "\n",
    "# Parameters\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "L = 1.0\n",
    "dr = 0.01\n",
    "dtheta = 2 * math.pi / 12\n",
    "ep_index = -3\n",
    "N = 51  # Number of particles\n",
    "Ntrunc = 20\n",
    "myRTE = RTESolver(L, dr, dtheta, ep_index, device)\n",
    "\n",
    "# Fixed Test Distributions, 3 distributions so K=3.\n",
    "GP = MaternGP(Ntrunc, dim=2, alpha=2, tau=1, sigma=1, device=device) # Define to get Ntrunc^2 eigenvalues of matern kernel\n",
    "GP_mean = MaternGP(myRTE.Nr, dim=2, alpha=2, tau=1, device=device) # Define to sample an NrxNr matrix as mean\n",
    "\n",
    "c = GP.sqrt_eig[None,:,:]*torch.randn(1,Ntrunc,Ntrunc,device=device)\n",
    "GP_mean = GP_mean.sample(1)\n",
    "loga = myRTE.c_to_loga(c) + GP_mean \n",
    "\n",
    "a = torch.exp(loga)\n",
    "u = myRTE.compute_u(a)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "d39cee98-3c41-41d0-b63b-c8a51d830658",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(a[0].cpu())\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "# plt.savefig('Images/scattering.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "528ceb01-57e6-44cb-a79e-200e2aaa7a63",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(u[0].cpu())\n",
    "plt.xticks([])\n",
    "plt.yticks([])\n",
    "# plt.savefig(f'Images/OutputEpsilon{myRTE.epsilon}.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fe98b16a-9313-408e-bc5f-d90691f3e49d",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
