{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "e43bf1dd",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import sympy as sp\n",
    "from scipy.optimize import minimize"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "00d9b739",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1, 1) Sigma -0.42, -0.27.\n",
      "(1, 1) Alpha 0.59, 0.69.\n",
      "(1, 2) Sigma -0.33, -0.20.\n",
      "(1, 2) Alpha 0.54, 0.64.\n",
      "(1, 3) Sigma -0.25, -0.13.\n",
      "(1, 3) Alpha 0.50, 0.59.\n",
      "(1, 4) Sigma -0.18, -0.08.\n",
      "(1, 4) Alpha 0.47, 0.55.\n",
      "(1, 5) Sigma -0.13, -0.04.\n",
      "(1, 5) Alpha 0.44, 0.51.\n",
      "(1, 6) Sigma -0.08, 0.04.\n",
      "(1, 6) Alpha 0.38, 0.48.\n",
      "(1, 7) Sigma 0.00, 0.11.\n",
      "(1, 7) Alpha 0.34, 0.43.\n",
      "(1, 8) Sigma 0.07, 0.16.\n",
      "(1, 8) Alpha 0.30, 0.38.\n",
      "(1, 9) Sigma 0.12, 0.22.\n",
      "(1, 9) Alpha 0.25, 0.34.\n",
      "(1, 10) Sigma 0.19, 0.29.\n",
      "(1, 10) Alpha 0.20, 0.29.\n",
      "(1, 11) Sigma 0.25, 0.35.\n",
      "(1, 11) Alpha 0.15, 0.24.\n",
      "(1, 12) Sigma 0.32, 0.40.\n",
      "(1, 12) Alpha 0.11, 0.18.\n",
      "(1, 13) Sigma 0.37, 0.47.\n",
      "(1, 13) Alpha 0.04, 0.14.\n",
      "(2, 1) Sigma -0.35, -0.21.\n",
      "(2, 1) Alpha 0.64, 0.75.\n",
      "(2, 2) Sigma -0.26, -0.14.\n",
      "(2, 2) Alpha 0.60, 0.70.\n",
      "(2, 3) Sigma -0.19, -0.08.\n",
      "(2, 3) Alpha 0.56, 0.65.\n",
      "(2, 4) Sigma -0.13, -0.02.\n",
      "(2, 4) Alpha 0.52, 0.61.\n",
      "(2, 5) Sigma -0.07, 0.02.\n",
      "(2, 5) Alpha 0.49, 0.57.\n",
      "(2, 6) Sigma -0.03, 0.10.\n",
      "(2, 6) Alpha 0.43, 0.53.\n",
      "(2, 7) Sigma 0.05, 0.15.\n",
      "(2, 7) Alpha 0.39, 0.48.\n",
      "(2, 8) Sigma 0.11, 0.21.\n",
      "(2, 8) Alpha 0.35, 0.43.\n",
      "(2, 9) Sigma 0.17, 0.27.\n",
      "(2, 9) Alpha 0.30, 0.39.\n",
      "(2, 10) Sigma 0.23, 0.33.\n",
      "(2, 10) Alpha 0.24, 0.34.\n",
      "(2, 11) Sigma 0.30, 0.39.\n",
      "(2, 11) Alpha 0.19, 0.29.\n",
      "(2, 12) Sigma 0.36, 0.44.\n",
      "(2, 12) Alpha 0.15, 0.23.\n",
      "(2, 13) Sigma 0.41, 0.51.\n",
      "(2, 13) Alpha 0.09, 0.19.\n",
      "(3, 1) Sigma -0.28, -0.14.\n",
      "(3, 1) Alpha 0.70, 0.81.\n",
      "(3, 2) Sigma -0.20, -0.08.\n",
      "(3, 2) Alpha 0.65, 0.75.\n",
      "(3, 3) Sigma -0.13, -0.02.\n",
      "(3, 3) Alpha 0.61, 0.70.\n",
      "(3, 4) Sigma -0.07, 0.03.\n",
      "(3, 4) Alpha 0.58, 0.66.\n",
      "(3, 5) Sigma -0.02, 0.08.\n",
      "(3, 5) Alpha 0.54, 0.62.\n",
      "(3, 6) Sigma 0.03, 0.15.\n",
      "(3, 6) Alpha 0.49, 0.59.\n",
      "(3, 7) Sigma 0.10, 0.21.\n",
      "(3, 7) Alpha 0.44, 0.53.\n",
      "(3, 8) Sigma 0.16, 0.25.\n",
      "(3, 8) Alpha 0.40, 0.48.\n",
      "(3, 9) Sigma 0.21, 0.31.\n",
      "(3, 9) Alpha 0.35, 0.44.\n",
      "(3, 10) Sigma 0.28, 0.37.\n",
      "(3, 10) Alpha 0.29, 0.39.\n",
      "(3, 11) Sigma 0.34, 0.43.\n",
      "(3, 11) Alpha 0.24, 0.34.\n",
      "(3, 12) Sigma 0.40, 0.48.\n",
      "(3, 12) Alpha 0.20, 0.28.\n",
      "(3, 13) Sigma 0.45, 0.54.\n",
      "(3, 13) Alpha 0.14, 0.24.\n",
      "(4, 1) Sigma -0.21, -0.08.\n",
      "(4, 1) Alpha 0.76, 0.87.\n",
      "(4, 2) Sigma -0.13, -0.01.\n",
      "(4, 2) Alpha 0.71, 0.81.\n",
      "(4, 3) Sigma -0.07, 0.04.\n",
      "(4, 3) Alpha 0.67, 0.76.\n",
      "(4, 4) Sigma -0.01, 0.09.\n",
      "(4, 4) Alpha 0.63, 0.72.\n",
      "(4, 5) Sigma 0.04, 0.13.\n",
      "(4, 5) Alpha 0.60, 0.68.\n",
      "(4, 6) Sigma 0.08, 0.20.\n",
      "(4, 6) Alpha 0.54, 0.65.\n",
      "(4, 7) Sigma 0.15, 0.26.\n",
      "(4, 7) Alpha 0.49, 0.59.\n",
      "(4, 8) Sigma 0.21, 0.30.\n",
      "(4, 8) Alpha 0.45, 0.54.\n",
      "(4, 9) Sigma 0.26, 0.36.\n",
      "(4, 9) Alpha 0.40, 0.50.\n",
      "(4, 10) Sigma 0.32, 0.42.\n",
      "(4, 10) Alpha 0.34, 0.45.\n",
      "(4, 11) Sigma 0.38, 0.47.\n",
      "(4, 11) Alpha 0.29, 0.39.\n",
      "(4, 12) Sigma 0.44, 0.52.\n",
      "(4, 12) Alpha 0.25, 0.34.\n",
      "(4, 13) Sigma 0.48, 0.58.\n",
      "(4, 13) Alpha 0.18, 0.29.\n",
      "(5, 1) Sigma -0.14, -0.01.\n",
      "(5, 1) Alpha 0.82, 0.93.\n",
      "(5, 2) Sigma -0.07, 0.05.\n",
      "(5, 2) Alpha 0.77, 0.87.\n",
      "(5, 3) Sigma -0.00, 0.10.\n",
      "(5, 3) Alpha 0.73, 0.82.\n",
      "(5, 4) Sigma 0.05, 0.15.\n",
      "(5, 4) Alpha 0.69, 0.78.\n",
      "(5, 5) Sigma 0.10, 0.19.\n",
      "(5, 5) Alpha 0.65, 0.74.\n",
      "(5, 6) Sigma 0.14, 0.25.\n",
      "(5, 6) Alpha 0.60, 0.70.\n",
      "(5, 7) Sigma 0.21, 0.31.\n",
      "(5, 7) Alpha 0.55, 0.64.\n",
      "(5, 8) Sigma 0.26, 0.35.\n",
      "(5, 8) Alpha 0.51, 0.59.\n",
      "(5, 9) Sigma 0.31, 0.41.\n",
      "(5, 9) Alpha 0.45, 0.55.\n",
      "(5, 10) Sigma 0.37, 0.46.\n",
      "(5, 10) Alpha 0.40, 0.50.\n",
      "(5, 11) Sigma 0.43, 0.51.\n",
      "(5, 11) Alpha 0.34, 0.44.\n",
      "(5, 12) Sigma 0.48, 0.56.\n",
      "(5, 12) Alpha 0.30, 0.39.\n",
      "(5, 13) Sigma 0.53, 0.62.\n",
      "(5, 13) Alpha 0.23, 0.34.\n",
      "(6, 1) Sigma -0.07, 0.06.\n",
      "(6, 1) Alpha 0.88, 0.99.\n",
      "(6, 2) Sigma -0.00, 0.12.\n",
      "(6, 2) Alpha 0.83, 0.93.\n",
      "(6, 3) Sigma 0.06, 0.16.\n",
      "(6, 3) Alpha 0.78, 0.88.\n",
      "(6, 4) Sigma 0.11, 0.21.\n",
      "(6, 4) Alpha 0.74, 0.84.\n",
      "(6, 5) Sigma 0.16, 0.24.\n",
      "(6, 5) Alpha 0.71, 0.80.\n",
      "(6, 6) Sigma 0.19, 0.31.\n",
      "(6, 6) Alpha 0.65, 0.76.\n",
      "(6, 7) Sigma 0.26, 0.36.\n",
      "(6, 7) Alpha 0.60, 0.70.\n",
      "(6, 8) Sigma 0.31, 0.40.\n",
      "(6, 8) Alpha 0.56, 0.65.\n",
      "(6, 9) Sigma 0.36, 0.45.\n",
      "(6, 9) Alpha 0.51, 0.61.\n",
      "(6, 10) Sigma 0.41, 0.51.\n",
      "(6, 10) Alpha 0.45, 0.55.\n",
      "(6, 11) Sigma 0.47, 0.56.\n",
      "(6, 11) Alpha 0.39, 0.50.\n",
      "(6, 12) Sigma 0.52, 0.60.\n",
      "(6, 12) Alpha 0.35, 0.44.\n",
      "(6, 13) Sigma 0.56, 0.66.\n",
      "(6, 13) Alpha 0.28, 0.40.\n",
      "(7, 1) Sigma -0.01, 0.12.\n",
      "(7, 1) Alpha 0.94, 1.05.\n",
      "(7, 2) Sigma 0.06, 0.17.\n",
      "(7, 2) Alpha 0.89, 0.99.\n",
      "(7, 3) Sigma 0.12, 0.22.\n",
      "(7, 3) Alpha 0.84, 0.94.\n",
      "(7, 4) Sigma 0.17, 0.26.\n",
      "(7, 4) Alpha 0.80, 0.89.\n",
      "(7, 5) Sigma 0.22, 0.30.\n",
      "(7, 5) Alpha 0.77, 0.85.\n",
      "(7, 6) Sigma 0.25, 0.36.\n",
      "(7, 6) Alpha 0.71, 0.82.\n",
      "(7, 7) Sigma 0.32, 0.41.\n",
      "(7, 7) Alpha 0.66, 0.75.\n",
      "(7, 8) Sigma 0.37, 0.45.\n",
      "(7, 8) Alpha 0.62, 0.70.\n",
      "(7, 9) Sigma 0.41, 0.50.\n",
      "(7, 9) Alpha 0.56, 0.66.\n",
      "(7, 10) Sigma 0.46, 0.55.\n",
      "(7, 10) Alpha 0.51, 0.60.\n",
      "(7, 11) Sigma 0.51, 0.60.\n",
      "(7, 11) Alpha 0.45, 0.55.\n",
      "(7, 12) Sigma 0.57, 0.64.\n",
      "(7, 12) Alpha 0.40, 0.49.\n",
      "(7, 13) Sigma 0.61, 0.69.\n",
      "(7, 13) Alpha 0.34, 0.44.\n",
      "(8, 1) Sigma 0.06, 0.16.\n",
      "(8, 1) Alpha 0.99, 1.09.\n",
      "(8, 2) Sigma 0.13, 0.22.\n",
      "(8, 2) Alpha 0.94, 1.03.\n",
      "(8, 3) Sigma 0.18, 0.26.\n",
      "(8, 3) Alpha 0.90, 0.98.\n",
      "(8, 4) Sigma 0.23, 0.30.\n",
      "(8, 4) Alpha 0.86, 0.93.\n",
      "(8, 5) Sigma 0.27, 0.34.\n",
      "(8, 5) Alpha 0.82, 0.89.\n",
      "(8, 6) Sigma 0.31, 0.39.\n",
      "(8, 6) Alpha 0.76, 0.86.\n",
      "(8, 7) Sigma 0.36, 0.44.\n",
      "(8, 7) Alpha 0.71, 0.80.\n",
      "(8, 8) Sigma 0.41, 0.48.\n",
      "(8, 8) Alpha 0.67, 0.74.\n",
      "(8, 9) Sigma 0.45, 0.53.\n",
      "(8, 9) Alpha 0.61, 0.70.\n",
      "(8, 10) Sigma 0.50, 0.58.\n",
      "(8, 10) Alpha 0.56, 0.65.\n",
      "(8, 11) Sigma 0.55, 0.63.\n",
      "(8, 11) Alpha 0.50, 0.59.\n",
      "(8, 12) Sigma 0.60, 0.66.\n",
      "(8, 12) Alpha 0.45, 0.53.\n",
      "(8, 13) Sigma 0.64, 0.72.\n",
      "(8, 13) Alpha 0.39, 0.48.\n",
      "(9, 1) Sigma 0.11, 1.00.\n",
      "(9, 1) Alpha 0.75, 1.89.\n",
      "(9, 2) Sigma 0.17, 1.00.\n",
      "(9, 2) Alpha 0.75, 1.89.\n",
      "(9, 3) Sigma 0.22, 1.00.\n",
      "(9, 3) Alpha 0.75, 1.89.\n",
      "(9, 4) Sigma 0.27, 1.00.\n",
      "(9, 4) Alpha 0.75, 1.89.\n",
      "(9, 5) Sigma 0.31, 0.40.\n",
      "(9, 5) Alpha 0.87, 0.96.\n",
      "(9, 6) Sigma 0.34, 1.00.\n",
      "(9, 6) Alpha 0.75, 1.89.\n",
      "(9, 7) Sigma 0.40, 1.00.\n",
      "(9, 7) Alpha 0.75, 1.89.\n",
      "(9, 8) Sigma 0.45, 1.00.\n",
      "(9, 8) Alpha 0.71, 1.89.\n",
      "(9, 9) Sigma 0.49, 1.00.\n",
      "(9, 9) Alpha 0.65, 1.89.\n",
      "(9, 10) Sigma 0.54, 1.00.\n",
      "(9, 10) Alpha 0.59, 1.89.\n",
      "(9, 11) Sigma 0.59, 1.00.\n",
      "(9, 11) Alpha 0.54, 1.89.\n",
      "(9, 12) Sigma 0.63, 1.00.\n",
      "(9, 12) Alpha 0.49, 1.89.\n",
      "(9, 13) Sigma 0.67, 1.00.\n",
      "(9, 13) Alpha 0.42, 1.89.\n",
      "(10, 1) Sigma 0.18, 1.00.\n",
      "(10, 1) Alpha 0.75, 1.89.\n",
      "(10, 2) Sigma 0.24, 1.00.\n",
      "(10, 2) Alpha 0.75, 1.89.\n",
      "(10, 3) Sigma 0.29, 1.00.\n",
      "(10, 3) Alpha 0.75, 1.89.\n",
      "(10, 4) Sigma 0.33, 1.00.\n",
      "(10, 4) Alpha 0.75, 1.89.\n",
      "(10, 5) Sigma 0.37, 0.44.\n",
      "(10, 5) Alpha 0.93, 1.00.\n",
      "(10, 6) Sigma 0.40, 1.00.\n",
      "(10, 6) Alpha 0.75, 1.89.\n",
      "(10, 7) Sigma 0.46, 1.00.\n",
      "(10, 7) Alpha 0.75, 1.89.\n",
      "(10, 8) Sigma 0.50, 1.00.\n",
      "(10, 8) Alpha 0.75, 1.89.\n",
      "(10, 9) Sigma 0.54, 1.00.\n",
      "(10, 9) Alpha 0.71, 1.89.\n",
      "(10, 10) Sigma 0.58, 1.00.\n",
      "(10, 10) Alpha 0.65, 1.89.\n",
      "(10, 11) Sigma 0.63, 1.00.\n",
      "(10, 11) Alpha 0.59, 1.89.\n",
      "(10, 12) Sigma 0.68, 1.00.\n",
      "(10, 12) Alpha 0.55, 1.89.\n",
      "(10, 13) Sigma 0.71, 1.00.\n",
      "(10, 13) Alpha 0.48, 1.89.\n",
      "(11, 1) Sigma 0.24, 0.35.\n",
      "(11, 1) Alpha 1.15, 1.27.\n",
      "(11, 2) Sigma 0.30, 0.40.\n",
      "(11, 2) Alpha 1.10, 1.21.\n",
      "(11, 3) Sigma 0.34, 0.43.\n",
      "(11, 3) Alpha 1.06, 1.15.\n",
      "(11, 4) Sigma 0.38, 0.47.\n",
      "(11, 4) Alpha 1.01, 1.11.\n",
      "(11, 5) Sigma 0.42, 0.50.\n",
      "(11, 5) Alpha 0.98, 1.07.\n",
      "(11, 6) Sigma 0.45, 0.55.\n",
      "(11, 6) Alpha 0.91, 1.03.\n",
      "(11, 7) Sigma 0.50, 0.59.\n",
      "(11, 7) Alpha 0.86, 0.96.\n",
      "(11, 8) Sigma 0.54, 0.62.\n",
      "(11, 8) Alpha 0.81, 0.91.\n",
      "(11, 9) Sigma 0.58, 0.66.\n",
      "(11, 9) Alpha 0.76, 0.86.\n",
      "(11, 10) Sigma 0.62, 0.70.\n",
      "(11, 10) Alpha 0.70, 0.80.\n",
      "(11, 11) Sigma 0.67, 0.75.\n",
      "(11, 11) Alpha 0.64, 0.74.\n",
      "(11, 12) Sigma 0.71, 0.78.\n",
      "(11, 12) Alpha 0.59, 0.68.\n",
      "(11, 13) Sigma 0.75, 0.82.\n",
      "(11, 13) Alpha 0.52, 0.63.\n",
      "(12, 1) Sigma 0.31, 0.42.\n",
      "(12, 1) Alpha 1.22, 1.34.\n",
      "(12, 2) Sigma 0.36, 0.46.\n",
      "(12, 2) Alpha 1.16, 1.27.\n",
      "(12, 3) Sigma 0.40, 0.49.\n",
      "(12, 3) Alpha 1.11, 1.22.\n",
      "(12, 4) Sigma 0.44, 0.53.\n",
      "(12, 4) Alpha 1.07, 1.17.\n",
      "(12, 5) Sigma 0.48, 0.55.\n",
      "(12, 5) Alpha 1.04, 1.13.\n",
      "(12, 6) Sigma 0.50, 0.60.\n",
      "(12, 6) Alpha 0.97, 1.09.\n",
      "(12, 7) Sigma 0.55, 0.64.\n",
      "(12, 7) Alpha 0.92, 1.02.\n",
      "(12, 8) Sigma 0.59, 0.67.\n",
      "(12, 8) Alpha 0.87, 0.97.\n",
      "(12, 9) Sigma 0.63, 0.71.\n",
      "(12, 9) Alpha 0.81, 0.92.\n",
      "(12, 10) Sigma 0.67, 0.75.\n",
      "(12, 10) Alpha 0.75, 0.86.\n",
      "(12, 11) Sigma 0.71, 0.79.\n",
      "(12, 11) Alpha 0.69, 0.80.\n",
      "(12, 12) Sigma 0.75, 0.82.\n",
      "(12, 12) Alpha 0.64, 0.74.\n",
      "(12, 13) Sigma 0.78, 0.86.\n",
      "(12, 13) Alpha 0.57, 0.69.\n",
      "(13, 1) Sigma 0.37, 0.47.\n",
      "(13, 1) Alpha 1.28, 1.39.\n",
      "(13, 2) Sigma 0.42, 0.51.\n",
      "(13, 2) Alpha 1.23, 1.33.\n",
      "(13, 3) Sigma 0.46, 0.54.\n",
      "(13, 3) Alpha 1.18, 1.27.\n",
      "(13, 4) Sigma 0.50, 0.57.\n",
      "(13, 4) Alpha 1.14, 1.22.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(13, 5) Sigma 0.53, 0.60.\n",
      "(13, 5) Alpha 1.10, 1.18.\n",
      "(13, 6) Sigma 0.56, 0.64.\n",
      "(13, 6) Alpha 1.03, 1.14.\n",
      "(13, 7) Sigma 0.61, 0.68.\n",
      "(13, 7) Alpha 0.98, 1.07.\n",
      "(13, 8) Sigma 0.64, 0.71.\n",
      "(13, 8) Alpha 0.93, 1.02.\n",
      "(13, 9) Sigma 0.67, 0.75.\n",
      "(13, 9) Alpha 0.87, 0.97.\n",
      "(13, 10) Sigma 0.71, 0.78.\n",
      "(13, 10) Alpha 0.81, 0.91.\n",
      "(13, 11) Sigma 0.75, 0.82.\n",
      "(13, 11) Alpha 0.75, 0.84.\n",
      "(13, 12) Sigma 0.79, 0.85.\n",
      "(13, 12) Alpha 0.70, 0.78.\n",
      "(13, 13) Sigma 0.82, 0.89.\n",
      "(13, 13) Alpha 0.62, 0.73.\n"
     ]
    }
   ],
   "source": [
    "# Define the symbols\n",
    "Sigma, Alpha = sp.symbols('Sigma Alpha', real=True)\n",
    "\n",
    "left_term_1 = 5**(1 - Sigma)\n",
    "left_term_2 = sp.exp(-(-sp.log(0.3))**Alpha) * (20**(1 - Sigma) - 5**(1 - Sigma))\n",
    "right_term_1 = 2**(1 - Sigma)\n",
    "left_term_1_ineq3 = 15**(1 - Sigma)\n",
    "left_term_2_ineq3 = sp.exp(-(-sp.log(0.9))**Alpha) * (20**(1 - Sigma) - 15**(1 - Sigma))\n",
    "\n",
    "series_1_right2 = [34, 37, 41, 46, 53, 62, 75, 92, 110, 150, 200, 300, 500, 850]\n",
    "series_2_right2 = [27, 28, 29, 30, 31, 32, 34, 36, 38, 41, 45, 50, 55, 65]\n",
    "\n",
    "\n",
    "# Prepare the grid of values\n",
    "sigma_range = np.linspace(0, 1, 400)\n",
    "alpha_range = np.linspace(0, 1, 400)\n",
    "sigma_mesh, alpha_mesh = np.meshgrid(sigma_range, alpha_range)\n",
    "\n",
    "# Evaluate each inequality and find the intersection (overlap)\n",
    "overlap = np.ones(sigma_mesh.shape, dtype=bool)  # Initialize with True\n",
    "\n",
    "\n",
    "for i in range(1, len(series_1_right2)):\n",
    "    right_term_2_ineq1 = sp.exp(-(-sp.log(0.1))**Alpha) * (series_1_right2[i]**(1 - Sigma) - 2**(1 - Sigma))\n",
    "    inequality1 = sp.simplify(-left_term_1 - left_term_2 + (right_term_1 + right_term_2_ineq1))\n",
    "    right_term_2_ineq2 = sp.exp(-(-sp.log(0.1))**Alpha) * (series_1_right2[i-1]**(1 - Sigma) - 2**(1 - Sigma))\n",
    "    inequality2 = sp.simplify(left_term_1 + left_term_2 - (right_term_1 + right_term_2_ineq2))\n",
    "    for j in range(1, len(series_2_right2)):\n",
    "        right_term_2_ineq3 = sp.exp(-(-sp.log(0.7))**Alpha) * (series_2_right2[j-1]**(1 - Sigma) - 2**(1 - Sigma))\n",
    "        inequality3 = sp.simplify(left_term_1_ineq3 + left_term_2_ineq3 - (right_term_1 + right_term_2_ineq3))\n",
    "        right_term_2_ineq4 = sp.exp(-(-sp.log(0.7))**Alpha) * (series_2_right2[j]**(1 - Sigma) - 2**(1 - Sigma))\n",
    "        inequality4 = sp.simplify(-left_term_1_ineq3 - left_term_2_ineq3 + (right_term_1 + right_term_2_ineq4))\n",
    "        \n",
    "        # Create numerical functions from the symbolic expressions\n",
    "        inequality_funcs = [\n",
    "            sp.lambdify((Sigma, Alpha), ineq, \"numpy\") for ineq in [inequality1, inequality2, inequality3, inequality4]\n",
    "        ]\n",
    "                # Prepare the grid of values\n",
    "        sigma_range = np.linspace(-1, 1, 400)\n",
    "        alpha_range = np.linspace(0, 2, 400)\n",
    "        sigma_mesh, alpha_mesh = np.meshgrid(sigma_range, alpha_range)\n",
    "\n",
    "        # Evaluate each inequality and find the intersection (overlap)\n",
    "        overlap = np.ones(sigma_mesh.shape, dtype=bool)  # Initialize with True\n",
    "\n",
    "        for func in inequality_funcs:\n",
    "            result = func(sigma_mesh, alpha_mesh) > 0  # True where the inequality holds\n",
    "            overlap &= result  # Combine with logical AND to find overlap\n",
    "\n",
    "        # Now, extract the valid ranges from the overlap\n",
    "        valid_sigma = sigma_mesh[overlap]\n",
    "        valid_alpha = alpha_mesh[overlap]\n",
    "\n",
    "        if valid_sigma.size > 0 and valid_alpha.size > 0:\n",
    "            sigma_min, sigma_max = np.min(valid_sigma), np.max(valid_sigma)\n",
    "            alpha_min, alpha_max = np.min(valid_alpha), np.max(valid_alpha)\n",
    "            print((i,j), f\"Sigma {sigma_min:.2f}, {sigma_max:.2f}.\")\n",
    "            print((i,j), f\"Alpha {alpha_min:.2f}, {alpha_max:.2f}.\")\n",
    "        else:\n",
    "            print((i,j), \"There is no common overlap region where all inequalities hold.\")\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "5d8be4ae",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1, 1) Sigma -0.42, -0.28.\n",
      "(1, 1) Alpha 0.59, 0.69.\n",
      "(1, 2) Sigma -0.32, -0.20.\n",
      "(1, 2) Alpha 0.54, 0.64.\n",
      "(1, 3) Sigma -0.24, -0.14.\n",
      "(1, 3) Alpha 0.51, 0.59.\n",
      "(1, 4) Sigma -0.18, -0.08.\n",
      "(1, 4) Alpha 0.47, 0.55.\n",
      "(1, 5) Sigma -0.12, -0.04.\n",
      "(1, 5) Alpha 0.43, 0.52.\n",
      "(1, 6) Sigma -0.08, 0.04.\n",
      "(1, 6) Alpha 0.38, 0.48.\n",
      "(1, 7) Sigma 0.00, 0.11.\n",
      "(1, 7) Alpha 0.33, 0.42.\n",
      "(1, 8) Sigma 0.07, 0.16.\n",
      "(1, 8) Alpha 0.29, 0.37.\n",
      "(1, 9) Sigma 0.12, 0.22.\n",
      "(1, 9) Alpha 0.25, 0.33.\n",
      "(1, 10) Sigma 0.19, 0.28.\n",
      "(1, 10) Alpha 0.19, 0.29.\n",
      "(1, 11) Sigma 0.26, 0.35.\n",
      "(1, 11) Alpha 0.15, 0.23.\n",
      "(1, 12) Sigma 0.32, 0.40.\n",
      "(1, 12) Alpha 0.10, 0.18.\n",
      "(1, 13) Sigma 0.37, 0.47.\n",
      "(1, 13) Alpha 0.04, 0.14.\n",
      "(2, 1) Sigma -0.35, -0.21.\n",
      "(2, 1) Alpha 0.64, 0.75.\n",
      "(2, 2) Sigma -0.26, -0.14.\n",
      "(2, 2) Alpha 0.60, 0.70.\n",
      "(2, 3) Sigma -0.19, -0.08.\n",
      "(2, 3) Alpha 0.56, 0.64.\n",
      "(2, 4) Sigma -0.12, -0.02.\n",
      "(2, 4) Alpha 0.52, 0.60.\n",
      "(2, 5) Sigma -0.07, 0.02.\n",
      "(2, 5) Alpha 0.49, 0.57.\n",
      "(2, 6) Sigma -0.02, 0.10.\n",
      "(2, 6) Alpha 0.43, 0.54.\n",
      "(2, 7) Sigma 0.05, 0.16.\n",
      "(2, 7) Alpha 0.39, 0.47.\n",
      "(2, 8) Sigma 0.12, 0.20.\n",
      "(2, 8) Alpha 0.35, 0.43.\n",
      "(2, 9) Sigma 0.16, 0.26.\n",
      "(2, 9) Alpha 0.29, 0.39.\n",
      "(2, 10) Sigma 0.23, 0.33.\n",
      "(2, 10) Alpha 0.24, 0.34.\n",
      "(2, 11) Sigma 0.30, 0.39.\n",
      "(2, 11) Alpha 0.19, 0.28.\n",
      "(2, 12) Sigma 0.36, 0.44.\n",
      "(2, 12) Alpha 0.15, 0.23.\n",
      "(2, 13) Sigma 0.41, 0.51.\n",
      "(2, 13) Alpha 0.09, 0.19.\n",
      "(3, 1) Sigma -0.28, -0.14.\n",
      "(3, 1) Alpha 0.70, 0.80.\n",
      "(3, 2) Sigma -0.20, -0.08.\n",
      "(3, 2) Alpha 0.66, 0.75.\n",
      "(3, 3) Sigma -0.13, -0.02.\n",
      "(3, 3) Alpha 0.62, 0.70.\n",
      "(3, 4) Sigma -0.07, 0.03.\n",
      "(3, 4) Alpha 0.58, 0.66.\n",
      "(3, 5) Sigma -0.01, 0.07.\n",
      "(3, 5) Alpha 0.54, 0.62.\n",
      "(3, 6) Sigma 0.03, 0.14.\n",
      "(3, 6) Alpha 0.49, 0.59.\n",
      "(3, 7) Sigma 0.10, 0.20.\n",
      "(3, 7) Alpha 0.44, 0.53.\n",
      "(3, 8) Sigma 0.16, 0.25.\n",
      "(3, 8) Alpha 0.39, 0.48.\n",
      "(3, 9) Sigma 0.22, 0.31.\n",
      "(3, 9) Alpha 0.35, 0.44.\n",
      "(3, 10) Sigma 0.28, 0.37.\n",
      "(3, 10) Alpha 0.29, 0.39.\n",
      "(3, 11) Sigma 0.34, 0.43.\n",
      "(3, 11) Alpha 0.24, 0.33.\n",
      "(3, 12) Sigma 0.40, 0.48.\n",
      "(3, 12) Alpha 0.20, 0.28.\n",
      "(3, 13) Sigma 0.44, 0.55.\n",
      "(3, 13) Alpha 0.13, 0.23.\n",
      "(4, 1) Sigma -0.22, -0.08.\n",
      "(4, 1) Alpha 0.76, 0.86.\n",
      "(4, 2) Sigma -0.13, -0.01.\n",
      "(4, 2) Alpha 0.71, 0.81.\n",
      "(4, 3) Sigma -0.06, 0.04.\n",
      "(4, 3) Alpha 0.67, 0.76.\n",
      "(4, 4) Sigma -0.01, 0.09.\n",
      "(4, 4) Alpha 0.63, 0.72.\n",
      "(4, 5) Sigma 0.04, 0.13.\n",
      "(4, 5) Alpha 0.60, 0.68.\n",
      "(4, 6) Sigma 0.08, 0.20.\n",
      "(4, 6) Alpha 0.54, 0.65.\n",
      "(4, 7) Sigma 0.16, 0.26.\n",
      "(4, 7) Alpha 0.49, 0.59.\n",
      "(4, 8) Sigma 0.22, 0.30.\n",
      "(4, 8) Alpha 0.45, 0.54.\n",
      "(4, 9) Sigma 0.26, 0.36.\n",
      "(4, 9) Alpha 0.40, 0.49.\n",
      "(4, 10) Sigma 0.32, 0.42.\n",
      "(4, 10) Alpha 0.34, 0.44.\n",
      "(4, 11) Sigma 0.38, 0.47.\n",
      "(4, 11) Alpha 0.29, 0.39.\n",
      "(4, 12) Sigma 0.44, 0.52.\n",
      "(4, 12) Alpha 0.25, 0.33.\n",
      "(4, 13) Sigma 0.48, 0.59.\n",
      "(4, 13) Alpha 0.18, 0.29.\n",
      "(5, 1) Sigma -0.14, -0.01.\n",
      "(5, 1) Alpha 0.82, 0.92.\n",
      "(5, 2) Sigma -0.06, 0.05.\n",
      "(5, 2) Alpha 0.77, 0.87.\n",
      "(5, 3) Sigma 0.00, 0.10.\n",
      "(5, 3) Alpha 0.73, 0.82.\n",
      "(5, 4) Sigma 0.05, 0.14.\n",
      "(5, 4) Alpha 0.69, 0.78.\n",
      "(5, 5) Sigma 0.10, 0.18.\n",
      "(5, 5) Alpha 0.66, 0.74.\n",
      "(5, 6) Sigma 0.14, 0.25.\n",
      "(5, 6) Alpha 0.60, 0.70.\n",
      "(5, 7) Sigma 0.21, 0.30.\n",
      "(5, 7) Alpha 0.55, 0.64.\n",
      "(5, 8) Sigma 0.26, 0.35.\n",
      "(5, 8) Alpha 0.51, 0.60.\n",
      "(5, 9) Sigma 0.31, 0.40.\n",
      "(5, 9) Alpha 0.45, 0.55.\n",
      "(5, 10) Sigma 0.36, 0.46.\n",
      "(5, 10) Alpha 0.39, 0.49.\n",
      "(5, 11) Sigma 0.43, 0.52.\n",
      "(5, 11) Alpha 0.34, 0.44.\n",
      "(5, 12) Sigma 0.48, 0.56.\n",
      "(5, 12) Alpha 0.30, 0.38.\n",
      "(5, 13) Sigma 0.53, 0.62.\n",
      "(5, 13) Alpha 0.23, 0.33.\n",
      "(6, 1) Sigma -0.08, 0.06.\n",
      "(6, 1) Alpha 0.88, 0.99.\n",
      "(6, 2) Sigma 0.00, 0.12.\n",
      "(6, 2) Alpha 0.83, 0.93.\n",
      "(6, 3) Sigma 0.06, 0.16.\n",
      "(6, 3) Alpha 0.78, 0.88.\n",
      "(6, 4) Sigma 0.12, 0.20.\n",
      "(6, 4) Alpha 0.74, 0.84.\n",
      "(6, 5) Sigma 0.16, 0.24.\n",
      "(6, 5) Alpha 0.71, 0.80.\n",
      "(6, 6) Sigma 0.20, 0.30.\n",
      "(6, 6) Alpha 0.65, 0.76.\n",
      "(6, 7) Sigma 0.26, 0.36.\n",
      "(6, 7) Alpha 0.60, 0.70.\n",
      "(6, 8) Sigma 0.32, 0.40.\n",
      "(6, 8) Alpha 0.56, 0.65.\n",
      "(6, 9) Sigma 0.36, 0.45.\n",
      "(6, 9) Alpha 0.51, 0.61.\n",
      "(6, 10) Sigma 0.41, 0.51.\n",
      "(6, 10) Alpha 0.45, 0.56.\n",
      "(6, 11) Sigma 0.47, 0.56.\n",
      "(6, 11) Alpha 0.39, 0.49.\n",
      "(6, 12) Sigma 0.53, 0.60.\n",
      "(6, 12) Alpha 0.35, 0.43.\n",
      "(6, 13) Sigma 0.57, 0.66.\n",
      "(6, 13) Alpha 0.28, 0.39.\n",
      "(7, 1) Sigma -0.00, 0.12.\n",
      "(7, 1) Alpha 0.94, 1.04.\n",
      "(7, 2) Sigma 0.07, 0.17.\n",
      "(7, 2) Alpha 0.89, 0.98.\n",
      "(7, 3) Sigma 0.12, 0.22.\n",
      "(7, 3) Alpha 0.84, 0.94.\n",
      "(7, 4) Sigma 0.18, 0.26.\n",
      "(7, 4) Alpha 0.80, 0.89.\n",
      "(7, 5) Sigma 0.22, 0.30.\n",
      "(7, 5) Alpha 0.77, 0.85.\n",
      "(7, 6) Sigma 0.26, 0.36.\n",
      "(7, 6) Alpha 0.71, 0.82.\n",
      "(7, 7) Sigma 0.32, 0.40.\n",
      "(7, 7) Alpha 0.66, 0.75.\n",
      "(7, 8) Sigma 0.36, 0.44.\n",
      "(7, 8) Alpha 0.62, 0.70.\n",
      "(7, 9) Sigma 0.41, 0.50.\n",
      "(7, 9) Alpha 0.56, 0.66.\n",
      "(7, 10) Sigma 0.46, 0.55.\n",
      "(7, 10) Alpha 0.50, 0.60.\n",
      "(7, 11) Sigma 0.52, 0.60.\n",
      "(7, 11) Alpha 0.45, 0.55.\n",
      "(7, 12) Sigma 0.57, 0.64.\n",
      "(7, 12) Alpha 0.40, 0.49.\n",
      "(7, 13) Sigma 0.61, 0.69.\n",
      "(7, 13) Alpha 0.33, 0.44.\n",
      "(8, 1) Sigma 0.06, 0.16.\n",
      "(8, 1) Alpha 1.00, 1.09.\n",
      "(8, 2) Sigma 0.12, 0.22.\n",
      "(8, 2) Alpha 0.94, 1.03.\n",
      "(8, 3) Sigma 0.18, 0.26.\n",
      "(8, 3) Alpha 0.90, 0.98.\n",
      "(8, 4) Sigma 0.23, 0.30.\n",
      "(8, 4) Alpha 0.86, 0.93.\n",
      "(8, 5) Sigma 0.27, 0.34.\n",
      "(8, 5) Alpha 0.82, 0.89.\n",
      "(8, 6) Sigma 0.31, 0.39.\n",
      "(8, 6) Alpha 0.76, 0.86.\n",
      "(8, 7) Sigma 0.36, 0.44.\n",
      "(8, 7) Alpha 0.71, 0.80.\n",
      "(8, 8) Sigma 0.42, 0.48.\n",
      "(8, 8) Alpha 0.67, 0.74.\n",
      "(8, 9) Sigma 0.46, 0.53.\n",
      "(8, 9) Alpha 0.62, 0.70.\n",
      "(8, 10) Sigma 0.51, 0.58.\n",
      "(8, 10) Alpha 0.56, 0.64.\n",
      "(8, 11) Sigma 0.56, 0.63.\n",
      "(8, 11) Alpha 0.50, 0.58.\n",
      "(8, 12) Sigma 0.61, 0.67.\n",
      "(8, 12) Alpha 0.45, 0.53.\n",
      "(8, 13) Sigma 0.65, 0.72.\n",
      "(8, 13) Alpha 0.38, 0.47.\n",
      "(9, 1) Sigma 0.11, 1.00.\n",
      "(9, 1) Alpha 0.32, 1.82.\n",
      "(9, 2) Sigma 0.18, 1.00.\n",
      "(9, 2) Alpha 0.32, 1.82.\n",
      "(9, 3) Sigma 0.22, 1.00.\n",
      "(9, 3) Alpha 0.32, 1.82.\n",
      "(9, 4) Sigma 0.27, 1.00.\n",
      "(9, 4) Alpha 0.32, 1.82.\n",
      "(9, 5) Sigma 0.31, 0.40.\n",
      "(9, 5) Alpha 0.87, 0.96.\n",
      "(9, 6) Sigma 0.34, 1.00.\n",
      "(9, 6) Alpha 0.32, 1.82.\n",
      "(9, 7) Sigma 0.40, 1.00.\n",
      "(9, 7) Alpha 0.32, 1.82.\n",
      "(9, 8) Sigma 0.45, 1.00.\n",
      "(9, 8) Alpha 0.32, 1.82.\n",
      "(9, 9) Sigma 0.49, 1.00.\n",
      "(9, 9) Alpha 0.32, 1.82.\n",
      "(9, 10) Sigma 0.54, 1.00.\n",
      "(9, 10) Alpha 0.32, 1.82.\n",
      "(9, 11) Sigma 0.59, 1.00.\n",
      "(9, 11) Alpha 0.32, 1.82.\n",
      "(9, 12) Sigma 0.64, 1.00.\n",
      "(9, 12) Alpha 0.32, 1.82.\n",
      "(9, 13) Sigma 0.67, 1.00.\n",
      "(9, 13) Alpha 0.32, 1.82.\n",
      "(10, 1) Sigma 0.18, 1.00.\n",
      "(10, 1) Alpha 0.32, 1.82.\n",
      "(10, 2) Sigma 0.24, 1.00.\n",
      "(10, 2) Alpha 0.32, 1.82.\n",
      "(10, 3) Sigma 0.30, 1.00.\n",
      "(10, 3) Alpha 0.32, 1.82.\n",
      "(10, 4) Sigma 0.34, 1.00.\n",
      "(10, 4) Alpha 0.32, 1.82.\n",
      "(10, 5) Sigma 0.38, 0.44.\n",
      "(10, 5) Alpha 0.93, 1.00.\n",
      "(10, 6) Sigma 0.40, 1.00.\n",
      "(10, 6) Alpha 0.32, 1.82.\n",
      "(10, 7) Sigma 0.46, 1.00.\n",
      "(10, 7) Alpha 0.32, 1.82.\n",
      "(10, 8) Sigma 0.51, 1.00.\n",
      "(10, 8) Alpha 0.32, 1.82.\n",
      "(10, 9) Sigma 0.54, 1.00.\n",
      "(10, 9) Alpha 0.32, 1.82.\n",
      "(10, 10) Sigma 0.59, 1.00.\n",
      "(10, 10) Alpha 0.32, 1.82.\n",
      "(10, 11) Sigma 0.64, 1.00.\n",
      "(10, 11) Alpha 0.32, 1.82.\n",
      "(10, 12) Sigma 0.68, 1.00.\n",
      "(10, 12) Alpha 0.32, 1.82.\n",
      "(10, 13) Sigma 0.71, 1.00.\n",
      "(10, 13) Alpha 0.32, 1.82.\n",
      "(11, 1) Sigma 0.24, 0.35.\n",
      "(11, 1) Alpha 1.16, 1.27.\n",
      "(11, 2) Sigma 0.30, 0.40.\n",
      "(11, 2) Alpha 1.10, 1.20.\n",
      "(11, 3) Sigma 0.34, 0.44.\n",
      "(11, 3) Alpha 1.06, 1.15.\n",
      "(11, 4) Sigma 0.38, 0.47.\n",
      "(11, 4) Alpha 1.02, 1.10.\n",
      "(11, 5) Sigma 0.42, 0.50.\n",
      "(11, 5) Alpha 0.98, 1.06.\n",
      "(11, 6) Sigma 0.45, 0.55.\n",
      "(11, 6) Alpha 0.92, 1.02.\n",
      "(11, 7) Sigma 0.51, 0.59.\n",
      "(11, 7) Alpha 0.86, 0.96.\n",
      "(11, 8) Sigma 0.55, 0.62.\n",
      "(11, 8) Alpha 0.82, 0.91.\n",
      "(11, 9) Sigma 0.59, 0.66.\n",
      "(11, 9) Alpha 0.76, 0.86.\n",
      "(11, 10) Sigma 0.63, 0.71.\n",
      "(11, 10) Alpha 0.70, 0.80.\n",
      "(11, 11) Sigma 0.67, 0.75.\n",
      "(11, 11) Alpha 0.64, 0.74.\n",
      "(11, 12) Sigma 0.72, 0.78.\n",
      "(11, 12) Alpha 0.59, 0.68.\n",
      "(11, 13) Sigma 0.75, 0.83.\n",
      "(11, 13) Alpha 0.52, 0.63.\n",
      "(12, 1) Sigma 0.30, 0.42.\n",
      "(12, 1) Alpha 1.22, 1.34.\n",
      "(12, 2) Sigma 0.36, 0.46.\n",
      "(12, 2) Alpha 1.16, 1.27.\n",
      "(12, 3) Sigma 0.40, 0.49.\n",
      "(12, 3) Alpha 1.12, 1.22.\n",
      "(12, 4) Sigma 0.44, 0.53.\n",
      "(12, 4) Alpha 1.08, 1.17.\n",
      "(12, 5) Sigma 0.48, 0.55.\n",
      "(12, 5) Alpha 1.04, 1.12.\n",
      "(12, 6) Sigma 0.51, 0.60.\n",
      "(12, 6) Alpha 0.97, 1.09.\n",
      "(12, 7) Sigma 0.56, 0.64.\n",
      "(12, 7) Alpha 0.92, 1.02.\n",
      "(12, 8) Sigma 0.60, 0.67.\n",
      "(12, 8) Alpha 0.87, 0.96.\n",
      "(12, 9) Sigma 0.63, 0.71.\n",
      "(12, 9) Alpha 0.81, 0.92.\n",
      "(12, 10) Sigma 0.67, 0.75.\n",
      "(12, 10) Alpha 0.76, 0.86.\n",
      "(12, 11) Sigma 0.71, 0.79.\n",
      "(12, 11) Alpha 0.69, 0.80.\n",
      "(12, 12) Sigma 0.76, 0.82.\n",
      "(12, 12) Alpha 0.64, 0.74.\n",
      "(12, 13) Sigma 0.79, 0.86.\n",
      "(12, 13) Alpha 0.58, 0.68.\n",
      "(13, 1) Sigma 0.38, 0.47.\n",
      "(13, 1) Alpha 1.28, 1.39.\n",
      "(13, 2) Sigma 0.42, 0.51.\n",
      "(13, 2) Alpha 1.23, 1.32.\n",
      "(13, 3) Sigma 0.46, 0.55.\n",
      "(13, 3) Alpha 1.18, 1.27.\n",
      "(13, 4) Sigma 0.51, 0.57.\n",
      "(13, 4) Alpha 1.14, 1.22.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(13, 5) Sigma 0.53, 0.60.\n",
      "(13, 5) Alpha 1.10, 1.18.\n",
      "(13, 6) Sigma 0.57, 0.65.\n",
      "(13, 6) Alpha 1.03, 1.14.\n",
      "(13, 7) Sigma 0.61, 0.68.\n",
      "(13, 7) Alpha 0.98, 1.07.\n",
      "(13, 8) Sigma 0.65, 0.71.\n",
      "(13, 8) Alpha 0.93, 1.02.\n",
      "(13, 9) Sigma 0.68, 0.75.\n",
      "(13, 9) Alpha 0.87, 0.97.\n",
      "(13, 10) Sigma 0.72, 0.79.\n",
      "(13, 10) Alpha 0.80, 0.90.\n",
      "(13, 11) Sigma 0.76, 0.82.\n",
      "(13, 11) Alpha 0.74, 0.84.\n",
      "(13, 12) Sigma 0.80, 0.85.\n",
      "(13, 12) Alpha 0.70, 0.78.\n",
      "(13, 13) Sigma 0.83, 0.89.\n",
      "(13, 13) Alpha 0.62, 0.73.\n"
     ]
    }
   ],
   "source": [
    "# Define the symbols\n",
    "Sigma, Alpha = sp.symbols('Sigma Alpha', real=True)\n",
    "\n",
    "left_term_1 = 5**(1 - Sigma)\n",
    "left_term_2 = sp.exp(-(-sp.log(0.3))**Alpha) * (20**(1 - Sigma) - 5**(1 - Sigma))\n",
    "right_term_1 = 2**(1 - Sigma)\n",
    "left_term_1_ineq3 = 15**(1 - Sigma)\n",
    "left_term_2_ineq3 = sp.exp(-(-sp.log(0.9))**Alpha) * (20**(1 - Sigma) - 15**(1 - Sigma))\n",
    "\n",
    "series_1_right2 = [34, 37, 41, 46, 53, 62, 75, 92, 110, 150, 200, 300, 500, 850]\n",
    "series_2_right2 = [27, 28, 29, 30, 31, 32, 34, 36, 38, 41, 45, 50, 55, 65]\n",
    "\n",
    "\n",
    "# Prepare the grid of values\n",
    "sigma_range = np.linspace(0, 1, 100)\n",
    "alpha_range = np.linspace(0, 1, 100)\n",
    "sigma_mesh, alpha_mesh = np.meshgrid(sigma_range, alpha_range)\n",
    "\n",
    "# Evaluate each inequality and find the intersection (overlap)\n",
    "overlap = np.ones(sigma_mesh.shape, dtype=bool)  # Initialize with True\n",
    "\n",
    "\n",
    "for i in range(1, len(series_1_right2)):\n",
    "    right_term_2_ineq1 = sp.exp(-(-sp.log(0.1))**Alpha) * (series_1_right2[i]**(1 - Sigma) - 2**(1 - Sigma))\n",
    "    inequality1 = sp.simplify(-left_term_1 - left_term_2 + (right_term_1 + right_term_2_ineq1))\n",
    "    right_term_2_ineq2 = sp.exp(-(-sp.log(0.1))**Alpha) * (series_1_right2[i-1]**(1 - Sigma) - 2**(1 - Sigma))\n",
    "    inequality2 = sp.simplify(left_term_1 + left_term_2 - (right_term_1 + right_term_2_ineq2))\n",
    "    for j in range(1, len(series_2_right2)):\n",
    "        right_term_2_ineq3 = sp.exp(-(-sp.log(0.7))**Alpha) * (series_2_right2[j-1]**(1 - Sigma) - 2**(1 - Sigma))\n",
    "        inequality3 = sp.simplify(left_term_1_ineq3 + left_term_2_ineq3 - (right_term_1 + right_term_2_ineq3))\n",
    "        right_term_2_ineq4 = sp.exp(-(-sp.log(0.7))**Alpha) * (series_2_right2[j]**(1 - Sigma) - 2**(1 - Sigma))\n",
    "        inequality4 = sp.simplify(-left_term_1_ineq3 - left_term_2_ineq3 + (right_term_1 + right_term_2_ineq4))\n",
    "        \n",
    "        # Create numerical functions from the symbolic expressions\n",
    "        inequality_funcs = [\n",
    "            sp.lambdify((Sigma, Alpha), ineq, \"numpy\") for ineq in [inequality1, inequality2, inequality3, inequality4]\n",
    "        ]\n",
    "                # Prepare the grid of values\n",
    "        sigma_range = np.linspace(-1, 1, 300)\n",
    "        alpha_range = np.linspace(0, 2, 300)\n",
    "        sigma_mesh, alpha_mesh = np.meshgrid(sigma_range, alpha_range)\n",
    "\n",
    "        # Evaluate each inequality and find the intersection (overlap)\n",
    "        overlap = np.ones(sigma_mesh.shape, dtype=bool)  # Initialize with True\n",
    "\n",
    "        for func in inequality_funcs:\n",
    "            result = func(sigma_mesh, alpha_mesh) > 0  # True where the inequality holds\n",
    "            overlap &= result  # Combine with logical AND to find overlap\n",
    "\n",
    "        # Now, extract the valid ranges from the overlap\n",
    "        valid_sigma = sigma_mesh[overlap]\n",
    "        valid_alpha = alpha_mesh[overlap]\n",
    "\n",
    "        if valid_sigma.size > 0 and valid_alpha.size > 0:\n",
    "            sigma_min, sigma_max = np.min(valid_sigma), np.max(valid_sigma)\n",
    "            alpha_min, alpha_max = np.min(valid_alpha), np.max(valid_alpha)\n",
    "            print((i,j), f\"Sigma {sigma_min:.2f}, {sigma_max:.2f}.\")\n",
    "            print((i,j), f\"Alpha {alpha_min:.2f}, {alpha_max:.2f}.\")\n",
    "        else:\n",
    "            print((i,j), \"There is no common overlap region where all inequalities hold.\")\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "07f6eac6",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define the symbolic variables\n",
    "Sigma, Alpha = sp.symbols('Sigma Alpha', real=True)\n",
    "\n",
    "# Define the terms for the inequalities\n",
    "left_term_1 = 5**(1 - Sigma)\n",
    "left_term_2 = sp.exp(-(-sp.log(0.3))**Alpha) * (20**(1 - Sigma) - 5**(1 - Sigma))\n",
    "right_term_1 = 2**(1 - Sigma)\n",
    "left_term_1_ineq3 = 15**(1 - Sigma)\n",
    "left_term_2_ineq3 = sp.exp(-(-sp.log(0.9))**Alpha) * (20**(1 - Sigma) - 15**(1 - Sigma))\n",
    "\n",
    "# Series values as defined in your problem statement\n",
    "series_1_right2 = [34, 37, 41, 46, 53, 62, 75, 92, 110, 150, 200, 300, 500, 850]\n",
    "series_2_right2 = [27, 28, 29, 30, 31, 32, 34, 36, 38, 41, 45, 50, 55, 65]\n",
    "\n",
    "# Create matrices to store results\n",
    "sigma_results = np.full((14, 14), \"No Data\", dtype=object)\n",
    "alpha_results = np.full((14, 14), \"No Data\", dtype=object)\n",
    "\n",
    "# Prepare the grid of values\n",
    "sigma_range = np.linspace(-1, 1, 400)\n",
    "alpha_range = np.linspace(0, 2, 400)\n",
    "sigma_mesh, alpha_mesh = np.meshgrid(sigma_range, alpha_range)\n",
    "\n",
    "inequalities = []\n",
    "for i in range(1, len(series_1_right2)):\n",
    "    for j in range(1, len(series_2_right2)):\n",
    "        # Define inequalities based on series values\n",
    "        right_term_2_ineq1 = sp.exp(-(-sp.log(0.1))**Alpha) * (series_1_right2[i]**(1 - Sigma) - 2**(1 - Sigma))\n",
    "        right_term_2_ineq2 = sp.exp(-(-sp.log(0.1))**Alpha) * (series_1_right2[i-1]**(1 - Sigma) - 2**(1 - Sigma))\n",
    "        right_term_2_ineq3 = sp.exp(-(-sp.log(0.7))**Alpha) * (series_2_right2[j-1]**(1 - Sigma) - 2**(1 - Sigma))\n",
    "        right_term_2_ineq4 = sp.exp(-(-sp.log(0.7))**Alpha) * (series_2_right2[j]**(1 - Sigma) - 2**(1 - Sigma))\n",
    "\n",
    "        ineq1 = sp.simplify(-left_term_1 - left_term_2 + (right_term_1 + right_term_2_ineq1))\n",
    "        ineq2 = sp.simplify(left_term_1 + left_term_2 - (right_term_1 + right_term_2_ineq2))\n",
    "        ineq3 = sp.simplify(left_term_1_ineq3 + left_term_2_ineq3 - (right_term_1 + right_term_2_ineq3))\n",
    "        ineq4 = sp.simplify(-left_term_1_ineq3 - left_term_2_ineq3 + (right_term_1 + right_term_2_ineq4))\n",
    "        \n",
    "        inequality_funcs = [sp.lambdify((Sigma, Alpha), ineq, \"numpy\") for ineq in [ineq1, ineq2, ineq3, ineq4]]\n",
    "\n",
    "        # Evaluate inequalities over the meshgrid\n",
    "        overlap = np.ones(sigma_mesh.shape, dtype=bool)\n",
    "        for func in inequality_funcs:\n",
    "            result = func(sigma_mesh, alpha_mesh) > 0\n",
    "            overlap &= result\n",
    "\n",
    "        # Extract valid ranges from the overlap\n",
    "        valid_sigma = sigma_mesh[overlap]\n",
    "        valid_alpha = alpha_mesh[overlap]\n",
    "\n",
    "        if valid_sigma.size > 0 and valid_alpha.size > 0:\n",
    "            sigma_min, sigma_max = np.min(valid_sigma), np.max(valid_sigma)\n",
    "            alpha_min, alpha_max = np.min(valid_alpha), np.max(valid_alpha)\n",
    "            sigma_results[i][j] = f\"{sigma_min:.2f}, {sigma_max:.2f}\"\n",
    "            alpha_results[i][j] = f\"{alpha_min:.2f}, {alpha_max:.2f}\"\n",
    "\n",
    "# Convert results to DataFrames\n",
    "sigma_df = pd.DataFrame(sigma_results)\n",
    "alpha_df = pd.DataFrame(alpha_results)\n",
    "\n",
    "# Export to CSV\n",
    "sigma_df.to_csv('/Users/jingruj3/Library/CloudStorage/Box-Box/LLM and Behavioral Econ/sigma_results.csv', index=False, header=False)\n",
    "alpha_df.to_csv('/Users/jingruj3/Library/CloudStorage/Box-Box/LLM and Behavioral Econ/alpha_results.csv', index=False, header=False)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ec76ddf4",
   "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.9.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
