{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from matching import *\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "params = [0.6, 0.8, 1, 1.2, 1.4]\n",
    "sizes = [10, 20, 50, 100, 200, 500, 1000,2000,5000,10000,20000,50000,int(1e5),int(2e5),int(5e5),int(1e6)]\n",
    "print(params)\n",
    "print(sizes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "offline = np.zeros((len(sizes), len(params)))\n",
    "minpreddegree = np.zeros((len(sizes), len(params)))\n",
    "for i, n in enumerate(sizes):\n",
    "  for j, param in enumerate(params):\n",
    "    degrees_u = (n/2) / np.arange(1,n+1)**param\n",
    "    degrees_u = np.sort(degrees_u)\n",
    "    offline_prediction = offline_bound_expected(n, n, degrees_u, verbose=False)\n",
    "    predprocess = simulate_diffeqs(n, n, degrees_u, verbose=False)\n",
    "    mpd_prediction = n - np.sum(predprocess)\n",
    "    offline[i, j] = offline_prediction\n",
    "    minpreddegree[i, j] = mpd_prediction\n",
    "    print('Size, Param: {}, {}'.format(n, param))\n",
    "    print('minpreddegree, offline, ratio: {:2f}, {:2f}, {:2f}'.format(minpreddegree[i,j], offline[i,j], minpreddegree[i,j]/offline[i,j]))\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "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.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
