{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "This notebook samples random covariance matrices, some of which has a worse condition number from GN^{-1} than GN^{-0.5}."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from scipy.linalg import sqrtm\n",
    "from datetime import datetime\n",
    "import torch\n",
    "import os\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_rand_prod(n, diag=None, U=None, H=None):\n",
    "    if H is None:\n",
    "        # sample a diagonal matrix\n",
    "        if diag is None:\n",
    "            diag = np.abs(np.random.randn(n))\n",
    "\n",
    "        if U is None:\n",
    "            # sample an orthogonal matrix\n",
    "            U = np.random.randn(n, n)\n",
    "            U = np.linalg.qr(U)[0]\n",
    "\n",
    "        H = np.matmul(U, np.matmul(np.diag(diag), U.T))\n",
    "        H_sqrt = np.matmul(U, np.matmul(np.diag(diag**0.5), U.T))\n",
    "    else:\n",
    "        H_sqrt = sqrtm(H)\n",
    "\n",
    "    precond = np.diag(np.diag(H)**-1)\n",
    "\n",
    "    conds = []\n",
    "    for p in np.arange(0.1, 1, 0.1):\n",
    "        # matrix product of a list of matrices\n",
    "        matrices = [H_sqrt, precond**p, H_sqrt]\n",
    "\n",
    "        # compute the product\n",
    "        prod = matrices[0]\n",
    "        for mat in matrices[1:]:\n",
    "            prod = np.matmul(prod, mat)\n",
    "\n",
    "        # compute the condition number\n",
    "        cond = np.linalg.cond(prod)\n",
    "        conds.append(cond)\n",
    "    return H, U, diag, conds\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 3\n",
    "diag = [1, 1e-2, 1e-4]\n",
    "diag = np.array(diag)\n",
    "\n",
    "n_rows = 6\n",
    "n_cols = 6\n",
    "\n",
    "fig, axs = plt.subplots(n_rows, n_cols, figsize=(20, 20))\n",
    "\n",
    "rand_trials = []\n",
    "for i in range(n_rows):\n",
    "    for j in range(n_cols):\n",
    "        H, U, diag, conds = get_rand_prod(n, diag)\n",
    "        rand_trials.append({'H': H, 'U': U, 'diag': diag, 'conds': conds})\n",
    "        axs[i, j].plot(np.arange(0.1, 1, 0.1), conds)\n",
    "        axs[i, j].set_xlabel('p')\n",
    "        axs[i, j].set_ylabel('condition number')\n",
    "        axs[i, j].set_xlim(0.1, 1)\n",
    "        axs[i, j].set_xticks([0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1])\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "common",
   "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.13.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
