{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "08ecab6b-2ed7-43be-a3db-0dae449711f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import random"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e554bb0a-d7a3-4d8f-b1be-c23aceb8c3af",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define the range of t\n",
    "t = np.linspace(0, 10, 500)\n",
    "\n",
    "# Define example values for tj and tk\n",
    "tj = 3\n",
    "tk = 7\n",
    "\n",
    "# Define the functions h_jk^(1)(t) and h_jk^(2)(t)\n",
    "h_jk_1 = np.where((t >= tj) & (t <= tk), (t - tj) / (tk - tj), 0)\n",
    "h_jk_2 = np.where((t >= tj) & (t <= tk), (tk - t) / (tk - tj), 0)\n",
    "\n",
    "# Enable LaTeX rendering for text in plots\n",
    "plt.rcParams['text.usetex'] = True\n",
    "plt.rcParams['font.family'] = 'serif'\n",
    "\n",
    "# Plotting the functions\n",
    "plt.figure(figsize=(8, 6))\n",
    "\n",
    "plt.plot(t, h_jk_1, label=r'$\\zeta_{jk}^{(1)}(t)$', color='red')\n",
    "plt.plot(t, h_jk_2, label=r'$\\zeta_{jk}^{(2)}(t)$', color='orange')\n",
    "\n",
    "plt.axvline(x=tj, color='gray', linestyle='--')\n",
    "plt.axvline(x=tk, color='gray', linestyle='--')\n",
    "\n",
    "# Set x-ticks only at tj and tk\n",
    "plt.xticks([tj, tk], [r'$t_j$', r'$t_k$'],fontsize = 20)\n",
    "\n",
    "plt.title(r'Plot of $\\zeta_{jk}^{(1)}(t)$ and $\\zeta_{jk}^{(2)}(t)$',fontsize = 25)\n",
    "plt.xlabel(r'$t$',fontsize = 20)\n",
    "#plt.ylabel(r'$h(t)$')\n",
    "plt.legend(fontsize = 20)\n",
    "\n",
    "#plt.grid(True)\n",
    "plt.tight_layout()\n",
    "\n",
    "# Save the figure\n",
    "plt.savefig('PLOTS/h_jk.png', dpi=300)\n",
    "\n",
    "# Display the plot\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9cb94947-49fe-4c0f-a982-7e8d634c00d3",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set a random seed for reproducibility\n",
    "np.random.seed(6)\n",
    "\n",
    "# Number of knots\n",
    "m = 8\n",
    "# Define the range\n",
    "n = 50\n",
    "random_numbers = random.sample(range(1, n + 1), m)\n",
    "sorted_numbers = sorted(random_numbers)\n",
    "\n",
    "\n",
    "# Generate random knots within a specified range\n",
    "knots = np.sort(np.random.uniform(0, 10, m))\n",
    "\n",
    "# Generate random values at knots\n",
    "values = np.random.uniform(-1, 1, m)\n",
    "\n",
    "# Define a function for continuous, piecewise linear interpolation\n",
    "def piecewise_linear_function(t, knots, values):\n",
    "    return np.interp(t, knots, values)\n",
    "\n",
    "# Define the range for t\n",
    "t = np.linspace(0, 10, 1000)\n",
    "\n",
    "# Compute the function values\n",
    "f_t = piecewise_linear_function(t, knots, values)\n",
    "\n",
    "# Plot the piecewise linear function\n",
    "plt.figure(figsize=(8, 6))\n",
    "\n",
    "plt.plot(t, f_t, label=r'$\\Delta(t)$', color='blue')\n",
    "plt.scatter(knots, values, color='red', label='Knots')\n",
    "\n",
    "# Add vertical lines at each knot\n",
    "for k in knots:\n",
    "    plt.axvline(x=k, color='gray', linestyle='--')\n",
    "\n",
    "# Label all knots on the x-axis as t_1, t_2, ..., t_(m-1), t_n\n",
    "labels = [f'$t_{{{i+1}}}$' for i in sorted_numbers]\n",
    "plt.xticks(knots, labels,fontsize = 20)\n",
    "\n",
    "plt.title(r'Piecewise Linear Function $\\Delta \\in \\mathcal{D}_m$ with $m=10$ Knots', fontsize = 24)\n",
    "#plt.xlabel(r'$t$',fontsize = 20)\n",
    "#plt.ylabel(r'$\\Delta(t)$',fontsize = 20)\n",
    "plt.legend(fontsize = 18)\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "# Save the figure\n",
    "plt.savefig('PLOTS/delta.png', dpi=300)\n",
    "\n",
    "# Display the plot\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "08eaba43-e5a4-43f4-a285-8e85fbf0dd8c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Enable LaTeX rendering for text in plots\n",
    "plt.rcParams['text.usetex'] = True\n",
    "plt.rcParams['font.family'] = 'serif'\n",
    "\n",
    "# Define the range of t\n",
    "t = np.linspace(0, 10, 500)\n",
    "\n",
    "# Define example values for tj and tk\n",
    "tj = 3\n",
    "tk = 7\n",
    "\n",
    "Delta_t_j = 1.5\n",
    "Delta_t_k = 0.6\n",
    "\n",
    "# Define the functions h_jk^(1)(t) and h_jk^(2)(t)\n",
    "h_jk_1 = np.where((t >= tj) & (t <= tk), Delta_t_k*(t - tj) / (tk - tj), 0)\n",
    "h_jk_2 = np.where((t >= tj) & (t <= tk), Delta_t_j*(tk - t) / (tk - tj), 0)\n",
    "Delta = h_jk_1 + h_jk_2\n",
    "\n",
    "# Plotting the functions\n",
    "plt.figure(figsize=(8, 6))\n",
    "\n",
    "plt.plot(t, h_jk_1, label=r'$\\zeta_{jk}^{(1)}(t)$', color='red')\n",
    "plt.plot(t, h_jk_2, label=r'$\\zeta_{jk}^{(2)}(t)$', color='orange')\n",
    "plt.plot(t, Delta, label=r'$\\Delta(t)$', color='blue')\n",
    "\n",
    "plt.axvline(x=tj, color='gray', linestyle='--')\n",
    "plt.axvline(x=tk, color='gray', linestyle='--')\n",
    "\n",
    "# Set x-ticks only at tj and tk\n",
    "plt.xticks([tj, tk], [r'$t_j$', r'$t_k$'],fontsize = 20)\n",
    "\n",
    "# Set custom y-ticks with only LaTeX symbols, removing numeric labels\n",
    "plt.yticks([0, Delta_t_j, Delta_t_k], [r'0', r'$\\Delta(t_j)$', r'$\\Delta(t_k)$'], fontsize = 20)\n",
    "\n",
    "# Remove y-axis numbers\n",
    "plt.gca().set_yticklabels([r'0', r'$\\Delta(t_j)$', r'$\\Delta(t_k)$'], fontsize= 20)\n",
    "\n",
    "plt.title(r'Plot of $\\zeta_{jk}^{(1)}(t)$, $\\zeta_{jk}^{(2)}(t)$ and $\\Delta(t)$',fontsize = 25)\n",
    "#plt.xlabel(r'$t$')\n",
    "#plt.ylabel(r'$\\Delta(t)$',fontsize = 20)\n",
    "plt.legend(fontsize = 18)\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "# Save the figure\n",
    "plt.savefig('PLOTS/deltasum.png', dpi=300)\n",
    "\n",
    "# Display the plot\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7c9c4379-128b-4bd2-b038-b945902f6081",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2304a5ce-8533-4879-8296-956ef27d0217",
   "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.11.4"
  },
  "vscode": {
   "interpreter": {
    "hash": "3aeb15c8c31224d9ef37a76c0046f703a279f439b6efd04fb2681e5f2715bf2f"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
