{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "311c39a9",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from random import random\n",
    "import copy\n",
    "import math\n",
    "import scipy\n",
    "import scipy.linalg   # SciPy Linear Algebra Library\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import xlsxwriter\n",
    "from tqdm import tqdm\n",
    "\n",
    "def assign_positive_values(vector1, constant_C):\n",
    "    # Find indices with positive values\n",
    "    positive_indices = np.where(vector1 > 0)[0]\n",
    "    vector_result = copy.deepcopy(vector1)\n",
    "    \n",
    "    # If no positive values, return original vector\n",
    "  #  if len(positive_indices) == 0:\n",
    "   #     return vector\n",
    "\n",
    "    # Generate random values for positive entries\n",
    "    random_values = np.random.rand(len(positive_indices))\n",
    "\n",
    "    # Normalize random values to ensure their sum is equal to constant_C\n",
    "    normalized_random_values = constant_C * (random_values / np.sum(random_values))\n",
    "\n",
    "    # Assign the positive entries with the normalized random values\n",
    "    vector_result[positive_indices] = normalized_random_values\n",
    "\n",
    "    return vector_result\n",
    "# Example usage:\n",
    "\n",
    "def assign_negative_values(vector1, constant_C):\n",
    "    # Find indices with positive values\n",
    "    positive_indices = np.where(vector1 < 0)[0]\n",
    "    vector_result = copy.deepcopy(vector1)\n",
    "    \n",
    "    # If no positive values, return original vector\n",
    "  #  if len(positive_indices) == 0:\n",
    "   #     return vector\n",
    "\n",
    "    # Generate random values for positive entries\n",
    "    random_values = np.random.rand(len(positive_indices))\n",
    "\n",
    "    # Normalize random values to ensure their sum is equal to constant_C\n",
    "    normalized_random_values = -constant_C * (random_values / np.sum(random_values))\n",
    "\n",
    "    # Assign the positive entries with the normalized random values\n",
    "    vector_result[positive_indices] = normalized_random_values\n",
    "\n",
    "    return vector_result\n",
    "\n",
    "def generate_same_sign_vector(vector_V, constant_C):\n",
    "    vector_V_copy = copy.deepcopy(vector_V)\n",
    "    vector_result = assign_positive_values(vector_V_copy, constant_C)\n",
    "    vector_result = assign_negative_values(vector_result, constant_C)\n",
    "    return vector_result\n",
    "\n",
    "def generate_same_sign_matrix(Matrix_M, constant_C):\n",
    "    # Ensure the matrix V has non-zero entries\n",
    "    if np.all(Matrix_M == 0):\n",
    "        raise ValueError(\"Matrix V must have entries different than 0.\")\n",
    "\n",
    "    rows, cols = np.shape(Matrix_M)\n",
    "    matrix_U = np.zeros_like(Matrix_M)\n",
    "\n",
    "    # Loop through each column of the matrix V\n",
    "    for j in range(cols):\n",
    "        constant_C1 = np.random.rand(1)*constant_C\n",
    "        # Extract the j-th column of V\n",
    "        vector_V = Matrix_M[:, j]\n",
    "        # Generate the corresponding vector U\n",
    "        vector_U = generate_same_sign_vector(vector_V, constant_C1)\n",
    "        # Assign the generated vector U to the j-th column of U\n",
    "        matrix_U[:, j] = vector_U\n",
    "    return matrix_U\n",
    "\n",
    "\n",
    "def cyclic_permutation_matrix(n):\n",
    "    M = np.zeros((n, n), dtype = float)\n",
    "\n",
    "    for i in range(n):\n",
    "        M[i, :] = np.roll(np.arange(1, n+1), i)\n",
    "\n",
    "    return M\n",
    "\n",
    "\n",
    "def generate_matrix_coordinate(A):\n",
    "    # Extract the first column of A\n",
    "    x1 = A[:, 0]\n",
    "\n",
    "    # Subtract x1 from the remaining columns of A\n",
    "    B = A[:, 1:] - x1[:, np.newaxis]\n",
    "\n",
    "    return B\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "580ca7b2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "1\n",
      "2\n",
      "3\n"
     ]
    }
   ],
   "source": [
    "\n",
    "#print(\"Me = \\n\", Me)\n",
    "#print(\"M = \\n\", M)\n",
    "iter = 20000\n",
    "Save_cW = np.zeros(iter)\n",
    "n_cases = [10,50,100,150]\n",
    "workbook = xlsxwriter.Workbook('array_data.xlsx')\n",
    "worksheet = workbook.add_worksheet()\n",
    "\n",
    "for j in range(len(n_cases)):\n",
    "    n = n_cases[j]\n",
    "    delta = 0.1*1/n\n",
    "    Const_C = 1 - (n+1)*delta\n",
    "    M = delta*cyclic_permutation_matrix(n).transpose()\n",
    "    Me = generate_matrix_coordinate(M)\n",
    "    \n",
    "    for i in range(iter):\n",
    "        U = generate_same_sign_matrix(Me, Const_C)\n",
    "        #print(\"U = \\n\", U)\n",
    "\n",
    "        Gram_perms = np.matmul((Me+U).transpose(), (Me+U)) \n",
    "        Value_Gram_perms,Vector_Gram_perms = np.linalg.eig(Gram_perms)\n",
    "        min_singular =  math.sqrt(   min(Value_Gram_perms))\n",
    "        Save_cW[i] = (n*delta)/min_singular\n",
    "    print(j)\n",
    "    worksheet.write_column(0, j, Save_cW)\n",
    "\n",
    "workbook.close()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1fcd4cb5",
   "metadata": {},
   "outputs": [],
   "source": [
    "#print(\"Me = \\n\", Me)\n",
    "#print(\"M = \\n\", M)\n",
    "iter = 20000\n",
    "Save_cW = np.zeros(iter)\n",
    "n_cases = [200,300]\n",
    "workbook = xlsxwriter.Workbook('array_data3.xlsx')\n",
    "worksheet = workbook.add_worksheet()\n",
    "\n",
    "for j in range(len(n_cases)):\n",
    "    n = n_cases[j]\n",
    "    delta = 0.1*1/n\n",
    "    Const_C = 1 - (n+1)*delta\n",
    "    M = delta*cyclic_permutation_matrix(n).transpose()\n",
    "    Me = generate_matrix_coordinate(M)\n",
    "    with tqdm(total=iter) as pbar:\n",
    "        \n",
    "        for i in range(iter):\n",
    "            U = generate_same_sign_matrix(Me, Const_C)\n",
    "            #print(\"U = \\n\", U)\n",
    "\n",
    "            Gram_perms = np.matmul((Me+U).transpose(), (Me+U)) \n",
    "            Value_Gram_perms,Vector_Gram_perms = np.linalg.eig(Gram_perms)\n",
    "            min_singular =  math.sqrt(   min(Value_Gram_perms))\n",
    "            Save_cW[i] = (n*delta)/min_singular\n",
    "\n",
    "            #pbar.write('processed: %d' %i)\n",
    "            pbar.update(1)\n",
    "        \n",
    "    worksheet.write_column(0, j, Save_cW)\n",
    "\n",
    "workbook.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "9deb22aa",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████| 20000/20000 [3:31:41<00:00,  1.57it/s]\n"
     ]
    }
   ],
   "source": [
    "#print(\"Me = \\n\", Me)\n",
    "#print(\"M = \\n\", M)\n",
    "iter = 20000\n",
    "Save_cW = np.zeros(iter)\n",
    "n_cases = [1000]\n",
    "workbook = xlsxwriter.Workbook('array_data3.xlsx')\n",
    "workshee2 = workbook.add_worksheet(\"n=1000\")\n",
    "\n",
    "\n",
    "for j in range(len(n_cases)):\n",
    "    n = n_cases[j]\n",
    "    delta = 0.1*1/n\n",
    "    Const_C = 1 - (n+1)*delta\n",
    "    M = delta*cyclic_permutation_matrix(n).transpose()\n",
    "    Me = generate_matrix_coordinate(M)\n",
    "    with tqdm(total=iter) as pbar:\n",
    "        \n",
    "        for i in range(iter):\n",
    "            U = generate_same_sign_matrix(Me, Const_C)\n",
    "            #print(\"U = \\n\", U)\n",
    "\n",
    "            Gram_perms = np.matmul((Me+U).transpose(), (Me+U)) \n",
    "            Value_Gram_perms,Vector_Gram_perms = np.linalg.eig(Gram_perms)\n",
    "            min_singular =  math.sqrt(   min(Value_Gram_perms))\n",
    "            Save_cW[i] = (n*delta)/min_singular\n",
    "\n",
    "            #pbar.write('processed: %d' %i)\n",
    "            pbar.update(1)\n",
    "        \n",
    "    workshee2.write_column(0, j, Save_cW)\n",
    "\n",
    "workbook.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "1b10a9e2",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████| 20000/20000 [1:01:45<00:00,  5.40it/s]\n"
     ]
    }
   ],
   "source": [
    "#print(\"Me = \\n\", Me)\n",
    "#print(\"M = \\n\", M)\n",
    "iter = 20000\n",
    "Save_cW = np.zeros(iter)\n",
    "n_cases = [500]\n",
    "workbook = xlsxwriter.Workbook('array_data4.xlsx')\n",
    "workshee2 = workbook.add_worksheet(\"n=500\")\n",
    "\n",
    "\n",
    "for j in range(len(n_cases)):\n",
    "    n = n_cases[j]\n",
    "    delta = 0.1*1/n\n",
    "    Const_C = 1 - (n+1)*delta\n",
    "    M = delta*cyclic_permutation_matrix(n).transpose()\n",
    "    Me = generate_matrix_coordinate(M)\n",
    "    with tqdm(total=iter) as pbar:\n",
    "        \n",
    "        for i in range(iter):\n",
    "            U = generate_same_sign_matrix(Me, Const_C)\n",
    "            #print(\"U = \\n\", U)\n",
    "\n",
    "            Gram_perms = np.matmul((Me+U).transpose(), (Me+U)) \n",
    "            Value_Gram_perms,Vector_Gram_perms = np.linalg.eig(Gram_perms)\n",
    "            min_singular =  math.sqrt(   min(Value_Gram_perms))\n",
    "            Save_cW[i] = (n*delta)/min_singular\n",
    "\n",
    "            #pbar.write('processed: %d' %i)\n",
    "            pbar.update(1)\n",
    "        \n",
    "    workshee2.write_column(0, j, Save_cW)\n",
    "\n",
    "workbook.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "acfaee7e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x936 with 8 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# PLOT EVERYTHING\n",
    "excel_file = \"array_data.xlsx\"\n",
    "data1 = pd.read_excel(excel_file,usecols='A').to_numpy() # 10\n",
    "data2 = pd.read_excel(excel_file,usecols='B').to_numpy() # 50\n",
    "data3 = pd.read_excel(excel_file,usecols='C').to_numpy() # 100\n",
    "data4 = pd.read_excel(excel_file,usecols='D').to_numpy() # 150\n",
    "data5 = pd.read_excel(excel_file,usecols='E').to_numpy() # 200\n",
    "data6 = pd.read_excel(excel_file,usecols='F').to_numpy() # 300\n",
    "data7 = pd.read_excel(excel_file,usecols='G').to_numpy() # 500\n",
    "data8 = pd.read_excel(excel_file,usecols='H').to_numpy() # 1000\n",
    "\n",
    "data = [data1, data2, data3, data4, data5, data6, data7, data8]\n",
    "\n",
    "\n",
    "xaxes = \"$c_W$\"\n",
    "yaxes = \"Frequency\"\n",
    "titles = ['$n=10$','$n=50$','$n=100$','$n=150$','$n=200$', '$n=300$', '$n=500$', '$n=1000$'] \n",
    "#ratio_toMax = [200,20,20,20]\n",
    "ratio_toMax = [1,1,1,1]\n",
    "f,a = plt.subplots(4,2, figsize=(12, 13))\n",
    "a = a.ravel()\n",
    "for idx,ax in enumerate(a):\n",
    "    #data_min = np.min(data[idx])\n",
    "    #data_max = np.max(data[idx])\n",
    "    data_min = 0\n",
    "    data_max = 40\n",
    "    ax.hist(data[idx], bins=500, range=[data_min, data_max], color='blue', density=False, label=\"$c_W$\")\n",
    "    ax.legend()\n",
    "    ax.set_title(titles[idx])\n",
    "    ax.set_xlabel(xaxes)\n",
    "    ax.set_ylabel(yaxes)\n",
    "plt.tight_layout()\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "# Add labels and title\n",
    "#fig_data = plt.hist(data_array, bins=500, range=[data_min, data_max], color='blue', density=False, label=\"$c_W$\")\n",
    "\n",
    "# Add a legend\n",
    "#plt.legend()\n",
    "\n",
    "# Label the axes\n",
    "#plt.xlabel(\"$c_W$\")\n",
    "#plt.ylabel('Frequency')\n",
    "\n",
    "# Add a title\n",
    "#plt.title(\"Histogram of $c_W$\")\n",
    "\n",
    "#  Save fig\n",
    "plt.savefig('c_W.png', dpi=300)\n",
    "\n",
    "# Show the plot\n",
    "plt.show()"
   ]
  }
 ],
 "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.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
