{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 35
    },
    "id": "CColl9Gov_Qm",
    "outputId": "891d121b-597d-4860-de71-76f0a49e0069"
   },
   "outputs": [],
   "source": [
    "import os\n",
    "import torch\n",
    "\n",
    "from resonance import plotting, sweeps, sampling, floquet_theory"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000
    },
    "id": "r79xIi5KwtqD",
    "outputId": "30cf1353-44a5-4274-dec7-9e2b2caa64af",
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "freq_min = 0.0\n",
    "freq_max = 0.05\n",
    "num_freq = 10\n",
    "\n",
    "runs_per_frequency = 10\n",
    "\n",
    "amplitude = 0.5\n",
    "variance = 1\n",
    "\n",
    "training_iterations = 10000\n",
    "batch_size = 1\n",
    "observation_noise_variance = 0.0\n",
    "\n",
    "evaluation_period = 100\n",
    "init_at_target = False\n",
    "\n",
    "momenta = [thousandths / 1000 for thousandths in range(999, 949, -5)]\n",
    "learning_rates = [thousandths / 1000 for thousandths in [10, 5, 1]]\n",
    "\n",
    "frequencies = torch.linspace(freq_min, freq_max, num_freq)\n",
    "\n",
    "# Giving the mean process a stationary variance of 0.1 (for an overall \n",
    "# stationary variance of 1.1, given sampling variance of 1.0) puts the \"amplitude\" of the\n",
    "# trajeectories pretty close to previous sinusoid experiments with amplitude 0.5.\n",
    "# And small noise variance essentially controls the noise level (and hence the SNR) of\n",
    "# the process.  We're adding noise additively with sampling variance, and keeping the process\n",
    "# noise variance quite small.  TODO: I wonder if this is literally equivalent to just using a\n",
    "# larger noise variance?  And come to think of it, is this whole AR(p)-as-mean-business equivalent\n",
    "# to just using a MA(p) process?  Jeez that'd be convenient.\n",
    "stationary_variance = 1.1\n",
    "sampling_variance = 1.0\n",
    "noise_variance = 1e-5\n",
    "make_sampler = lambda frequency: sampling.AR2MeanGaussian(stationary_variance, frequency, sampling_variance, noise_variance)\n",
    "\n",
    "results_dir = f'results/AR2_f({freq_min},{freq_max},{num_freq})_r{runs_per_frequency}_a{amplitude}_s{stationary_variance}_v{sampling_variance}_n{noise_variance}_N{training_iterations}_b{batch_size}_e{observation_noise_variance}_t{evaluation_period}_p{init_at_target}'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "scrolled": true,
    "tags": []
   },
   "outputs": [],
   "source": [
    "sweeps.save_sweep(\n",
    "    frequencies = frequencies,\n",
    "    learning_rates = learning_rates,\n",
    "    momenta = momenta,\n",
    "\n",
    "    runs_per_frequency = runs_per_frequency,\n",
    "    training_iterations = training_iterations,\n",
    "\n",
    "    results_dir = results_dir,\n",
    "\n",
    "    make_sampler = make_sampler,\n",
    "    \n",
    "    # target function sampling\n",
    "    observation_noise_variance = observation_noise_variance,\n",
    "\n",
    "    # training parameters\n",
    "    batch_size = batch_size,\n",
    "\n",
    "    # measurement parameters\n",
    "    evaluation_period = evaluation_period,\n",
    "\n",
    "    init_at_target = init_at_target,\n",
    "    \n",
    "    tail_fraction = 0.5,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:04<00:00,  2.12it/s]\n",
      "100%|██████████| 10/10 [00:03<00:00,  2.59it/s]\n",
      "100%|██████████| 10/10 [00:02<00:00,  3.69it/s]\n"
     ]
    }
   ],
   "source": [
    "theoretical_results_dir = floquet_theory.unique_sweep_id(amplitude, momenta, frequencies)\n",
    "\n",
    "floquet_theory.save_theoretical_results(learning_rates, momenta, frequencies, amplitude, theoretical_results_dir)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 573.97it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 348.15it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 10/10 [00:00<00:00, 366.74it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "tail_fraction = 0.5\n",
    "outlier_quantile_threshold = 0.98\n",
    "\n",
    "estimated_amplitude = 0.5\n",
    "\n",
    "plotting.plot_momentum_vs_frequency(\n",
    "    results_dir,\n",
    "    theoretical_results_dir,\n",
    "    learning_rates,\n",
    "    momenta,\n",
    "    frequencies,\n",
    "    runs_per_frequency,\n",
    "    tail_fraction,\n",
    "    outlier_quantile_threshold,\n",
    "    estimated_amplitude,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "collapsed_sections": [],
   "name": "1 - With Gaussian Sampling, Proper SGDm",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3",
   "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.6.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
