{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "from wave_2d import generate_training_data, generate_training_data_varying_param\n",
    "import numpy as np\n",
    "import matplotlib.pylab as plt\n",
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Done 1 out of 2000\n",
      "Done 21 out of 2000\n",
      "Done 41 out of 2000\n",
      "Done 61 out of 2000\n",
      "Done 81 out of 2000\n",
      "Done 101 out of 2000\n",
      "Done 121 out of 2000\n",
      "Done 141 out of 2000\n",
      "Done 161 out of 2000\n",
      "Done 181 out of 2000\n",
      "Done 201 out of 2000\n",
      "Done 221 out of 2000\n",
      "Done 241 out of 2000\n",
      "Done 261 out of 2000\n",
      "Done 281 out of 2000\n",
      "Done 301 out of 2000\n",
      "Done 321 out of 2000\n",
      "Done 341 out of 2000\n",
      "Done 361 out of 2000\n",
      "Done 381 out of 2000\n",
      "Done 401 out of 2000\n",
      "Done 421 out of 2000\n",
      "Done 441 out of 2000\n",
      "Done 461 out of 2000\n",
      "Done 481 out of 2000\n",
      "Done 501 out of 2000\n",
      "Done 521 out of 2000\n",
      "Done 541 out of 2000\n",
      "Done 561 out of 2000\n",
      "Done 581 out of 2000\n",
      "Done 601 out of 2000\n",
      "Done 621 out of 2000\n",
      "Done 641 out of 2000\n",
      "Done 661 out of 2000\n",
      "Done 681 out of 2000\n",
      "Done 701 out of 2000\n",
      "Done 721 out of 2000\n",
      "Done 741 out of 2000\n",
      "Done 761 out of 2000\n",
      "Done 781 out of 2000\n",
      "Done 801 out of 2000\n",
      "Done 821 out of 2000\n",
      "Done 841 out of 2000\n",
      "Done 861 out of 2000\n",
      "Done 881 out of 2000\n",
      "Done 901 out of 2000\n",
      "Done 921 out of 2000\n",
      "Done 941 out of 2000\n",
      "Done 961 out of 2000\n",
      "Done 981 out of 2000\n",
      "Done 1001 out of 2000\n",
      "Done 1021 out of 2000\n",
      "Done 1041 out of 2000\n",
      "Done 1061 out of 2000\n",
      "Done 1081 out of 2000\n",
      "Done 1101 out of 2000\n",
      "Done 1121 out of 2000\n",
      "Done 1141 out of 2000\n",
      "Done 1161 out of 2000\n",
      "Done 1181 out of 2000\n",
      "Done 1201 out of 2000\n",
      "Done 1221 out of 2000\n",
      "Done 1241 out of 2000\n",
      "Done 1261 out of 2000\n",
      "Done 1281 out of 2000\n",
      "Done 1301 out of 2000\n",
      "Done 1321 out of 2000\n",
      "Done 1341 out of 2000\n",
      "Done 1361 out of 2000\n",
      "Done 1381 out of 2000\n",
      "Done 1401 out of 2000\n",
      "Done 1421 out of 2000\n",
      "Done 1441 out of 2000\n",
      "Done 1461 out of 2000\n",
      "Done 1481 out of 2000\n",
      "Done 1501 out of 2000\n",
      "Done 1521 out of 2000\n",
      "Done 1541 out of 2000\n",
      "Done 1561 out of 2000\n",
      "Done 1581 out of 2000\n",
      "Done 1601 out of 2000\n",
      "Done 1621 out of 2000\n",
      "Done 1641 out of 2000\n",
      "Done 1661 out of 2000\n",
      "Done 1681 out of 2000\n",
      "Done 1701 out of 2000\n",
      "Done 1721 out of 2000\n",
      "Done 1741 out of 2000\n",
      "Done 1761 out of 2000\n",
      "Done 1781 out of 2000\n",
      "Done 1801 out of 2000\n",
      "Done 1821 out of 2000\n",
      "Done 1841 out of 2000\n",
      "Done 1861 out of 2000\n",
      "Done 1881 out of 2000\n",
      "Done 1901 out of 2000\n",
      "Done 1921 out of 2000\n",
      "Done 1941 out of 2000\n",
      "Done 1961 out of 2000\n",
      "Done 1981 out of 2000\n",
      " \n"
     ]
    }
   ],
   "source": [
    "s = 128\n",
    "c = 0.1\n",
    "time = 5.0\n",
    "N_data = 2000\n",
    "\n",
    "K_min = 16\n",
    "K_max = 32\n",
    "decay_min = -0.675\n",
    "decay_max = -0.925\n",
    "inp_train, out_train, coeffs, Ks, decays = generate_training_data_varying_param(c = 0.1, \n",
    "                                            time = 5.0, \n",
    "                                            N_data = N_data, \n",
    "                                            K_min = K_min,\n",
    "                                            K_max = K_max,\n",
    "                                            decay_min = decay_min, \n",
    "                                            decay_max = decay_max,\n",
    "                                            s = 128)\n",
    "\n",
    "#generate_training_data(c = c, time = time, N_data = N_data, K = K, decay =decay, s = s)\n",
    "inp_train = np.reshape(inp_train,(1,N_data,s,s))\n",
    "out_train = np.reshape(out_train,(1,N_data,s,s))\n",
    "data = np.concatenate((inp_train, out_train), axis = 0)\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "\n",
    "folder = \"/folder_to_data/\"\n",
    "\n",
    "d = dict()\n",
    "\n",
    "d[\"Kmin\"] = K_min\n",
    "d[\"Kmax\"] = K_max\n",
    "d[\"s\"] = s\n",
    "d[\"decay_min\"] = decay_min\n",
    "d[\"decay_max\"] = decay_max\n",
    "d[\"c\"] = c\n",
    "d[\"time\"] = time\n",
    "d[\"N_data\"] = N_data\n",
    "\n",
    "if not os.path.exists(f\"{folder}\"):\n",
    "    os.makedirs(f\"{folder}\")\n",
    "\n",
    "with open(f\"{folder}/details.json\", \"w\") as f:\n",
    "    json.dump(d, f, indent=4)\n",
    "\n",
    "\n",
    "np.save(f\"{folder}/data.npy\", data)\n",
    "np.save(f\"{folder}/coeffs.npy\", coeffs)\n",
    "np.save(f\"{folder}/Ks.npy\", Ks)\n",
    "np.save(f\"{folder}/decays.npy\", decays)\n"
   ]
  }
 ],
 "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.11.6"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
