{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "import os\n",
    "from pathlib import Path\n",
    "\n",
    "from src.metrics import obtain_metrics_minimality, obtain_metrics_sufficiency"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 5.1. Minimality with Independent FoV Dataset\n",
    "def generate_minimality_dataset(alpha=0., beta=0., n_samples=1000):\n",
    "    y1 = np.random.rand(n_samples)*np.pi\n",
    "    y2 = np.random.rand(n_samples)*np.pi\n",
    "    y3 = np.random.rand(n_samples)*np.pi\n",
    "    y4 = np.random.rand(n_samples)*np.pi\n",
    "    n = np.random.rand(n_samples)*np.pi\n",
    "    y = np.array([y1, y2, y3, y4]).T\n",
    "    z = np.array([\n",
    "        np.cos((1-beta) * ((1-alpha)*y1 + alpha*y2) + beta * n), \n",
    "        np.cos((1-beta) * ((1-alpha)*y2 + alpha*y3) + beta * n), \n",
    "        np.cos((1-beta) * ((1-alpha)*y3 + alpha*y4) + beta * n), \n",
    "        np.cos((1-beta) * ((1-alpha)*y4 + alpha*y1) + beta * n), \n",
    "        #np.random.rand(n_samples)\n",
    "    ]).T\n",
    "    return y, z\n",
    "\n",
    "\n",
    "# 5.2. Sufficiency with Independent FoV Dataset\n",
    "def generate_sufficiency_dataset(alpha=0., gamma=1., n_samples=1000):\n",
    "    y1 = np.random.rand(n_samples)*np.pi\n",
    "    y2 = np.random.rand(n_samples)*np.pi\n",
    "    y3 = np.random.rand(n_samples)*np.pi\n",
    "    y4 = np.random.rand(n_samples)*np.pi\n",
    "    y = np.array([y1, y2, y3, y4]).T\n",
    "    z = np.array([\n",
    "        np.cos(gamma * ((1-alpha)*y1 + alpha*y2)), \n",
    "        np.cos(gamma * ((1-alpha)*y2 + alpha*y3)), \n",
    "        np.cos(gamma * ((1-alpha)*y3 + alpha*y4)), \n",
    "        np.cos(gamma * ((1-alpha)*y4 + alpha*y1)), \n",
    "        #np.random.rand(n_samples)\n",
    "    ]).T\n",
    "    return y, z\n",
    "\n",
    "\n",
    "# 5.3 & 5.4. Minimality and Sufficiency with Dependent FoV Dataset\n",
    "def generate_dependent_dataset(alpha=0., delta=0., n_samples=1000):\n",
    "    y1 = np.random.rand(n_samples)*np.pi\n",
    "    y2 = np.random.rand(n_samples)*np.pi\n",
    "    y3 = (1-delta)*y1 + delta*y2\n",
    "    y4 = (1-delta)*y2 + delta*y1\n",
    "    y = np.array([y1, y2, y3, y4]).T\n",
    "    z = np.array([\n",
    "        np.cos((1-alpha)*y1 + alpha*y2), \n",
    "        np.cos((1-alpha)*y2 + alpha*y3), \n",
    "        np.cos((1-alpha)*y3 + alpha*y4),\n",
    "        np.cos((1-alpha)*y4 + alpha*y1),\n",
    "    ]).T\n",
    "    return y, z"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%capture\n",
    "# 5.1. Minimality with Independent FoV Dataset\n",
    "alphas = np.arange(0., 0.5001, 0.025)\n",
    "betas = np.arange(0., 1.001, 0.05)\n",
    "\n",
    "scores = {alpha: {beta: obtain_metrics_minimality(\n",
    "    *generate_minimality_dataset(alpha, beta)\n",
    ") for beta in betas} for alpha in alphas}\n",
    "\n",
    "fname = os.path.join(Path.cwd(), 'minimality_independent.pkl')\n",
    "with open(fname, 'wb') as file:\n",
    "    pickle.dump(scores, file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%capture\n",
    "# 5.2. Sufficiency with Independent FoV Dataset\n",
    "alphas = np.arange(0., 0.5001, 0.025)\n",
    "gammas = np.arange(1., 2.001, 0.05)\n",
    "\n",
    "scores = {alpha: {gamma: obtain_metrics_sufficiency(\n",
    "    *generate_sufficiency_dataset(alpha, gamma)\n",
    ") for gamma in gammas} for alpha in alphas}\n",
    "\n",
    "fname = os.path.join(Path.cwd(), 'sufficiency_independent.pkl')\n",
    "with open(fname, 'wb') as file:\n",
    "    pickle.dump(scores, file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%capture\n",
    "# 5.3. Minimality with Dependent FoV Dataset\n",
    "alphas = np.arange(0., 0.5001, 0.025)\n",
    "deltas = np.arange(0., 0.5001, 0.025)\n",
    "\n",
    "scores = {alpha: {delta: obtain_metrics_minimality(\n",
    "    *generate_dependent_dataset(alpha, delta)\n",
    ") for delta in deltas} for alpha in alphas}\n",
    "\n",
    "fname = os.path.join(Path.cwd(), 'minimality_dependent.pkl')\n",
    "with open(fname, 'wb') as file:\n",
    "    pickle.dump(scores, file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%capture\n",
    "# 5.4. Sufficiency with Dependent FoV Dataset\n",
    "alphas = np.arange(0., 0.5001, 0.025)\n",
    "deltas = np.arange(0., 0.5001, 0.025)\n",
    "\n",
    "scores = {alpha: {delta: obtain_metrics_sufficiency(\n",
    "    *generate_dependent_dataset(alpha, delta)\n",
    ") for delta in deltas} for alpha in alphas}\n",
    "\n",
    "fname = os.path.join(Path.cwd(), 'sufficiency_dependent.pkl')\n",
    "with open(fname, 'wb') as file:\n",
    "    pickle.dump(scores, file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "%%capture\n",
    "from src.metrics import obtain_metrics_fre\n",
    "\n",
    "# Independent Minimality Dataset\n",
    "alphas = np.arange(0., 0.5001, 0.025)\n",
    "betas = np.arange(0., 1.001, 0.05)\n",
    "scores = {alpha: {beta: obtain_metrics_fre(\n",
    "    *generate_minimality_dataset(alpha, beta)\n",
    ") for beta in betas} for alpha in alphas}\n",
    "fname = os.path.join(Path.cwd(), 'minimality_fre.pkl')\n",
    "with open(fname, 'wb') as file:\n",
    "    pickle.dump(scores, file)\n",
    "\n",
    "\n",
    "# Independent Sufficiency Dataset\n",
    "alphas = np.arange(0., 0.5001, 0.025)\n",
    "gammas = np.arange(1., 2.001, 0.05)\n",
    "scores = {alpha: {gamma: obtain_metrics_fre(\n",
    "    *generate_sufficiency_dataset(alpha, gamma)\n",
    ") for gamma in gammas} for alpha in alphas}\n",
    "fname = os.path.join(Path.cwd(), 'sufficiency_fre.pkl')\n",
    "with open(fname, 'wb') as file:\n",
    "    pickle.dump(scores, file)\n",
    "\n",
    "\n",
    "# Dependent Dataset\n",
    "alphas = np.arange(0., 0.5001, 0.025)\n",
    "deltas = np.arange(0., 0.5001, 0.025)\n",
    "scores = {alpha: {delta: obtain_metrics_fre(\n",
    "    *generate_dependent_dataset(alpha, delta)\n",
    ") for delta in deltas} for alpha in alphas}\n",
    "fname = os.path.join(Path.cwd(), 'dependent_fre.pkl')\n",
    "with open(fname, 'wb') as file:\n",
    "    pickle.dump(scores, file)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "venv",
   "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
