{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "06994aba",
   "metadata": {},
   "source": [
    "### importing dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4e9135ba",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load the .npy file (Interior points)\n",
    "\n",
    "import numpy as np\n",
    "file_path = \"10d/interior_train.npy\"\n",
    "data = np.load(file_path)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6ab4452c",
   "metadata": {},
   "source": [
    "## Training Interior points"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "0d1805c0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Shape of the dataset: (16000, 10)\n",
      "Data type: float64\n"
     ]
    }
   ],
   "source": [
    "# Display basic information about the dataset\n",
    "print(\"Shape of the dataset:\", data.shape)\n",
    "print(\"Data type:\", data.dtype)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "61e74f94",
   "metadata": {},
   "outputs": [],
   "source": [
    "interior_data = data[:2000]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f1b65277",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Shape of the training interior dataset: (20000, 11)\n"
     ]
    }
   ],
   "source": [
    "# Define time t as (10,) dataset\n",
    "t = np.linspace(0, 1, 10)  # Example data\n",
    "\n",
    "# Repeat each time value for all rows in x_y_z\n",
    "t_repeated = np.repeat(t, interior_data.shape[0])\n",
    "\n",
    "# Tile x_y_z so that it aligns with repeated t\n",
    "x_y_z_tiled = np.tile(interior_data, (t.size, 1))\n",
    "\n",
    "# Combine t and x_y_z into a single array\n",
    "interior_train_dataset = np.column_stack((t_repeated, x_y_z_tiled))\n",
    "\n",
    "# Print the shape and a preview of the resulting dataset\n",
    "print(\"Shape of the training interior dataset:\", interior_train_dataset.shape)\n",
    "# print(\"Sample data:\\n\", final_dataset) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "460d1bc2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset saved to Interior_train_points.npy\n"
     ]
    }
   ],
   "source": [
    "# Assuming `final_dataset` is your array of shape (200, 4)\n",
    "file_name = \"Interior_train_points.npy\"\n",
    "\n",
    "# Save the array to a .npy file\n",
    "np.save(file_name, interior_train_dataset)\n",
    "\n",
    "print(f\"Dataset saved to {file_name}\") "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9d4f8b0c",
   "metadata": {},
   "source": [
    "### Training Initial points"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "232ec8bd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(4000, 10)\n"
     ]
    }
   ],
   "source": [
    "initial_data = data[:4000]\n",
    "print(initial_data.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "75d65629",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Shape of the training initial dataset: (4000, 11)\n"
     ]
    }
   ],
   "source": [
    "t = np.zeros(4000)\n",
    "final_initial_dataset = np.column_stack((t, initial_data))\n",
    "\n",
    "print(\"Shape of the training initial dataset:\", final_initial_dataset.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "5937b7c6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset saved to Initial_train_points.npy\n"
     ]
    }
   ],
   "source": [
    "# Assuming `final_dataset` is your array of shape (200, 4)\n",
    "file_name = \"Initial_train_points.npy\"\n",
    "\n",
    "# Save the array to a .npy file\n",
    "np.save(file_name, final_initial_dataset)\n",
    "\n",
    "print(f\"Dataset saved to {file_name}\") "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b1ebcbc7",
   "metadata": {},
   "source": [
    "### Training boundary points"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "b2176422",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load the .npy file\n",
    "file_path = \"10d/boundary_train.npy\"\n",
    "data_bd = np.load(file_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "35c45295",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_boundary = data_bd[:400]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "25bb6ab2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Shape of the training boundary dataset: (4000, 11)\n"
     ]
    }
   ],
   "source": [
    "# Define time t as (10,) dataset\n",
    "t = np.linspace(0, 1, 10)  # Example data\n",
    "\n",
    "# Repeat each time value for all rows in x_y_z\n",
    "t_repeated = np.repeat(t, data_boundary.shape[0])\n",
    "\n",
    "# Tile x_y_z so that it aligns with repeated t\n",
    "x_y_z_tiled = np.tile(data_boundary, (t.size, 1))\n",
    "\n",
    "# Combine t and x_y_z into a single array\n",
    "final_dataset_bd = np.column_stack((t_repeated, x_y_z_tiled))\n",
    "\n",
    "# Print the shape and a preview of the resulting dataset\n",
    "print(\"Shape of the training boundary dataset:\", final_dataset_bd.shape)\n",
    "# print(\"Sample data:\\n\", final_dataset_bd) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "b64652f8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset saved to boundary_train_points.npy\n"
     ]
    }
   ],
   "source": [
    "# Assuming `final_dataset` is your array of shape (200, 4)\n",
    "file_name = \"boundary_train_points.npy\"\n",
    "\n",
    "# Save the array to a .npy file\n",
    "np.save(file_name, final_dataset_bd)\n",
    "\n",
    "print(f\"Dataset saved to {file_name}\") "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "dfeb9f3c",
   "metadata": {},
   "source": [
    "### Testing points"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7c19df39",
   "metadata": {},
   "source": [
    "### Boundary testing points"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "33521112",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load the .npy file\n",
    "file_path = \"10d/boundary_test.npy\"\n",
    "data_bd_test = np.load(file_path)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "a32f1f24",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(2000, 10)\n"
     ]
    }
   ],
   "source": [
    "print(data_bd_test.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "c4794eb5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(20000,)\n",
      "Shape of the boundary testing dataset: (20000, 11)\n"
     ]
    }
   ],
   "source": [
    "# Define time t as (10,) dataset\n",
    "t = np.linspace(0, 1, 10)  # Example data\n",
    "\n",
    "# Repeat each time value for all rows in x_y_z\n",
    "t_repeated = np.repeat(t, data_bd_test.shape[0])\n",
    "print(t_repeated.shape)\n",
    "\n",
    "# Tile x_y_z so that it aligns with repeated t\n",
    "x_y_z_tiled = np.tile(data_bd_test, (t.size, 1))\n",
    "\n",
    "# Combine t and x_y_z into a single array\n",
    "final_dataset_bd_test = np.column_stack((t_repeated, x_y_z_tiled))\n",
    "\n",
    "# Print the shape and a preview of the resulting dataset\n",
    "print(\"Shape of the boundary testing dataset:\", final_dataset_bd_test.shape)\n",
    "# print(\"Sample data:\\n\", final_dataset_bd_test) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "bdccc6b5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset saved to boundary_test_points.npy\n"
     ]
    }
   ],
   "source": [
    "# Assuming `final_dataset` is your array of shape (200, 4)\n",
    "file_name = \"boundary_test_points.npy\"\n",
    "\n",
    "# Save the array to a .npy file\n",
    "np.save(file_name, final_dataset_bd_test)\n",
    "\n",
    "print(f\"Dataset saved to {file_name}\") "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "05210b31",
   "metadata": {},
   "source": [
    "### interior testing points"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "1016f729",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Shape of the dataset: (8000, 10)\n"
     ]
    }
   ],
   "source": [
    "# Load the .npy file\n",
    "file_path = \"10d/interior_test.npy\"\n",
    "data_interior_test = np.load(file_path)\n",
    "# Display basic information about the dataset\n",
    "print(\"Shape of the dataset:\", data_interior_test.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "3f491839",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(2000, 10)\n"
     ]
    }
   ],
   "source": [
    "data_interior_updated_test = data_interior_test[::4]\n",
    "print(data_interior_updated_test.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "94a34f1d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Shape of the interior testing dataset: (20000, 11)\n"
     ]
    }
   ],
   "source": [
    "# Define time t as (10,) dataset\n",
    "t = np.linspace(0, 1, 10)  # Example data\n",
    "\n",
    "# Repeat each time value for all rows in x_y_z\n",
    "t_repeated = np.repeat(t, data_interior_updated_test.shape[0])\n",
    "# print(t_repeated.shape)\n",
    "\n",
    "# Tile x_y_z so that it aligns with repeated t\n",
    "x_y_z_tiled = np.tile(data_interior_updated_test, (t.size, 1))\n",
    "\n",
    "# Combine t and x_y_z into a single array\n",
    "final_dataset_interior_test = np.column_stack((t_repeated, x_y_z_tiled))\n",
    "\n",
    "# Print the shape and a preview of the resulting dataset\n",
    "print(\"Shape of the interior testing dataset:\", final_dataset_interior_test.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "33b4fcac",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Dataset saved to interior_test_points.npy\n"
     ]
    }
   ],
   "source": [
    "# Assuming `final_dataset` is your array of shape (200, 4)\n",
    "file_name = \"interior_test_points.npy\"\n",
    "\n",
    "# Save the array to a .npy file\n",
    "np.save(file_name, final_dataset_interior_test)\n",
    "\n",
    "print(f\"Dataset saved to {file_name}\") "
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pytorch",
   "language": "python",
   "name": "pytorch"
  },
  "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
