{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 2271,
     "status": "ok",
     "timestamp": 1650986651014,
     "user": {
      "displayName": "Carlo Adornetto",
      "userId": "12456770947398655820"
     },
     "user_tz": -120
    },
    "id": "Hy5ao2Vv1K6V",
    "outputId": "907a400c-476e-43ce-9370-6a56cb22dfbf"
   },
   "outputs": [],
   "source": [
    "#code to generate test examples for the CNN networks\n",
    "#Parallel calls to TMM code\n",
    "# -->saves the entire file in memory while processing: generation of ~500k structures on 16GB RAM is OK\n",
    "#arl92@case.edu 2021-01-22\n",
    "#please refer to copyright\n",
    "\n",
    "\n",
    "import os, sys\n",
    "sys.path.append(os.path.abspath(\"../\")) \n",
    "\n",
    "#include these files in the same folder\n",
    "import TMM_numba as tmm\n",
    "import BB_metals as bb\n",
    "import LD_metals as ld\n",
    "import dielectric_materials as di\n",
    "\n",
    "#required modules to run generator\n",
    "import numpy as np\n",
    "import tables\n",
    "import matplotlib.pyplot as plt\n",
    "import datetime\n",
    "date = datetime.datetime.now()\n",
    "from joblib import Parallel, delayed\n",
    "import multiprocessing\n",
    "from tqdm import tqdm_notebook as tqdm\n",
    "\n",
    "\n",
    "#import materials\n",
    "wave = np.linspace(450,950,200)*1E-9\n",
    "ag = bb.nk_material('Ag',wave)\n",
    "au = bb.nk_material('Au',wave)\n",
    "ni = bb.nk_material('Ni',wave)\n",
    "al2o3 = di.nk_material('al2o3',wave)\n",
    "tio2 = di.nk_material('tio2',wave)\n",
    "ito = di.nk_material('ito',wave)\n",
    "gl = di.nk_Cauchy_Urbach(wave,1.55,0.005) #glass model for substrate (based on 2-parameter cauchy fit of slides in lab)\n",
    "void = np.ones(wave.size) #vacuum\n",
    "\n",
    "materials = np.array([ag,al2o3,ito,ni,tio2])\n",
    "\n",
    "#########################################################################################\n",
    "#System Parameters - What range of parameters are you searching?\n",
    "\n",
    "num_mat = 5                               # number of material choices in each layer (max is number of elements in materials)\n",
    "num_lay = 5                               # number of total layers in each system\n",
    "ang = np.array([25.,45.,65.])              # angles to calculate for each system [deg from normal]\n",
    "min_thick = 1E-9                           # minimum layer thickness [in m]\n",
    "max_thick = 60E-9                          # maximum layer thickness [in m]\n",
    "n_super = void                             # material to be used for superstrate\n",
    "n_subst = gl                               # material to be used for substrate\n",
    "\n",
    "#parameters for generating random data set\n",
    "#np.random.seed(35447)                      # Seed the RNG for reproducability\n",
    "set_length = 10                       # Number of samples in data file (warning: make sure you have enough RAM!)\n",
    "###########################################################################################\n",
    "l = np.ones(num_lay).astype('double')\n",
    "ranges = np.array([min_thick,max_thick])\n",
    "\n",
    "# write a general discription of the dataset including parameters\n",
    "# saved as a txt file in the same folder, makes usage easier\n",
    "comments = 'Materials: Ag,Al2O3,ITO,Ni,TiO2. trange 1-60nm. Return [ang,mats,l, Rp, Rs, Tp, Ts, Ellipsometric] 25-45-65'\n",
    "#this filename is where the data will be saved\n",
    "os.makedirs('../data', exist_ok=True)\n",
    "froot = f'../data/{str(l.size)}l_{str(set_length)}s'\n",
    "print(froot)\n",
    "coms = open(froot+'_comments.txt',\"w\")\n",
    "coms.write(comments)\n",
    "coms.close()\n",
    "\n",
    "################### GENERATION SCRIPT #######################\n",
    "\n",
    "def generate_fcn(wave,n_subst,n_super,materials,num_mat,ranges,ang,l):\n",
    "    \n",
    "    n = np.zeros((l.size,wave.size),dtype=complex)\n",
    "    psi = np.zeros(wave.size*ang.size)\n",
    "    delta = np.zeros(wave.size*ang.size)\n",
    "    rp = np.zeros(wave.size*ang.size)\n",
    "    rs = np.zeros(wave.size*ang.size)\n",
    "    tp = np.zeros(wave.size*ang.size)\n",
    "    ts = np.zeros(wave.size*ang.size) \n",
    "    m = np.zeros((num_mat*l.size))\n",
    "    \n",
    "    # create a random structure within the parameter space\n",
    "    for el in range(0,l.size):\n",
    "        # choose a random material from library\n",
    "        mat = np.random.randint(low=0, high=num_mat)\n",
    "        # do not allow subsequent layers to be the same material\n",
    "        if el > 0:\n",
    "            while mold == mat:\n",
    "                mat = np.random.randint(low=0, high=num_mat)\n",
    "        mold = mat\n",
    "        #assign material to layer\n",
    "        n[el,:] = materials[mat,:]\n",
    "        m[mat+num_mat*el] = 1\n",
    "    \n",
    "        #choose layer thickness\n",
    "        l[el] = np.random.uniform(low=ranges[0],high=ranges[1])\n",
    "        \n",
    "    # calculate output for all angles (flattened arrays)\n",
    "    # set up to return reflectance, transmittance, and ellipsometric data for all structures\n",
    "    for j in range(0,ang.size):     \n",
    "        for i in range(0,wave.size):\n",
    "            (psi[i+wave.size*j],delta[i+wave.size*j]) = tmm.ellips(ang[j], wave[i], n[:,i], l, n_super[i], n_subst[i])\n",
    "            rp[i+wave.size*j] = tmm.reflect_amp(1,ang[j], wave[i], n[:,i], l, n_super[i], n_subst[i])\n",
    "            rs[i+wave.size*j] = tmm.reflect_amp(0,ang[j], wave[i], n[:,i], l, n_super[i], n_subst[i])\n",
    "            tp[i+wave.size*j] = tmm.trans_amp(1,ang[j], wave[i], n[:,i], l, n_super[i], n_subst[i])\n",
    "            ts[i+wave.size*j] = tmm.trans_amp(0,ang[j], wave[i], n[:,i], l, n_super[i], n_subst[i])\n",
    "    \n",
    "\n",
    "    print('####################: ',sum([len(l) for l in [ang,m,l,rp,rs,tp,ts,psi,delta]]))\n",
    "    print([len(i) for i in [ang,m,l,rp,rs,tp,ts,psi,delta]])\n",
    "    print([i.shape for i in [ang,m,l,rp,rs,tp,ts,psi,delta]])\n",
    "    \n",
    "    print(m)\n",
    "    print(l)\n",
    "\n",
    "    data_save = np.concatenate((ang,m,l,rp,rs,tp,ts,psi,delta),axis=None)\n",
    "    data_save = np.reshape(data_save,(1,data_save.size))\n",
    "    print(data_save.shape)\n",
    "    return data_save\n",
    "\n",
    "\n",
    "generate_fcn(wave,n_subst,n_super,materials,num_mat,ranges,ang,l)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 327,
     "referenced_widgets": [
      "ef56ee46d7224c328788c14c7f5f9c17",
      "0e1d2ec247ef4c9daa804042c6753ebf",
      "b714194689294943b5cfa0ae293e1c49",
      "a8a0f84805af4107b413c931c19ce4fa",
      "a21bf86aa6e74564a9b5178c5ab3bcbb",
      "10f7c9e136a24e95b151647dec193f21",
      "4a05c95661ee49a299105c664f6665f0",
      "ca65637a40544b2ca18137722960606a",
      "add1baa2ea3e4e73836f92bfcc24e3a1",
      "6fb85b3fadec4a89a8e9bad6eedc44c0",
      "587dce8053cf40e9936dbdb265fed224"
     ]
    },
    "executionInfo": {
     "elapsed": 22757,
     "status": "ok",
     "timestamp": 1650986673764,
     "user": {
      "displayName": "Carlo Adornetto",
      "userId": "12456770947398655820"
     },
     "user_tz": -120
    },
    "id": "BWbUSYL63j9V",
    "outputId": "0452c445-733b-4832-cc41-baecfaa2d278"
   },
   "outputs": [],
   "source": [
    "\n",
    "print('Generating Parallel Pool...\\n')\n",
    "cores = multiprocessing.cpu_count()\n",
    "print('Parallel: %d Found Cores.\\n'%(cores))\n",
    "print('Generating Data...\\n')\n",
    "results = Parallel(n_jobs=cores)(delayed(generate_fcn)(wave,n_subst,n_super,materials,num_mat,ranges,ang,l) for g in tqdm(range(set_length)))    \n",
    "try:\n",
    "    filename = froot+'.h5'\n",
    "    print('Opening File: %s\\n'%(filename))\n",
    "    f = tables.open_file(filename, mode='w')\n",
    "    atom = tables.Float64Atom()\n",
    "    wid = len(results[0][0])\n",
    "    shape = (0,wid)\n",
    "    array_c = f.create_earray(f.root, 'data',atom, shape)\n",
    "    print('Saving Data...\\n')\n",
    "    for i in range(set_length):\n",
    "        array_c.append(np.reshape(results[i],(1,wid)))\n",
    "    print('Closing File: %s\\n'%(filename))\n",
    "    f.close()\n",
    "    print('Completed!')\n",
    "    del results\n",
    "except:\n",
    "    f.close()\n",
    "    print('Error in datasave!')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "executionInfo": {
     "elapsed": 4,
     "status": "ok",
     "timestamp": 1650986673765,
     "user": {
      "displayName": "Carlo Adornetto",
      "userId": "12456770947398655820"
     },
     "user_tz": -120
    },
    "id": "yNCNOWQ11K6d"
   },
   "outputs": [],
   "source": [
    "f.close()"
   ]
  }
 ],
 "metadata": {
  "colab": {
   "collapsed_sections": [],
   "name": "generate_data_tmm.ipynb",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "base",
   "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.12.9"
  },
  "widgets": {
   "application/vnd.jupyter.widget-state+json": {
    "0e1d2ec247ef4c9daa804042c6753ebf": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "HTMLModel",
     "state": {
      "_dom_classes": [],
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "HTMLModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/controls",
      "_view_module_version": "1.5.0",
      "_view_name": "HTMLView",
      "description": "",
      "description_tooltip": null,
      "layout": "IPY_MODEL_10f7c9e136a24e95b151647dec193f21",
      "placeholder": "​",
      "style": "IPY_MODEL_4a05c95661ee49a299105c664f6665f0",
      "value": "100%"
     }
    },
    "10f7c9e136a24e95b151647dec193f21": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "state": {
      "_model_module": "@jupyter-widgets/base",
      "_model_module_version": "1.2.0",
      "_model_name": "LayoutModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "LayoutView",
      "align_content": null,
      "align_items": null,
      "align_self": null,
      "border": null,
      "bottom": null,
      "display": null,
      "flex": null,
      "flex_flow": null,
      "grid_area": null,
      "grid_auto_columns": null,
      "grid_auto_flow": null,
      "grid_auto_rows": null,
      "grid_column": null,
      "grid_gap": null,
      "grid_row": null,
      "grid_template_areas": null,
      "grid_template_columns": null,
      "grid_template_rows": null,
      "height": null,
      "justify_content": null,
      "justify_items": null,
      "left": null,
      "margin": null,
      "max_height": null,
      "max_width": null,
      "min_height": null,
      "min_width": null,
      "object_fit": null,
      "object_position": null,
      "order": null,
      "overflow": null,
      "overflow_x": null,
      "overflow_y": null,
      "padding": null,
      "right": null,
      "top": null,
      "visibility": null,
      "width": null
     }
    },
    "4a05c95661ee49a299105c664f6665f0": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "DescriptionStyleModel",
     "state": {
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "DescriptionStyleModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "StyleView",
      "description_width": ""
     }
    },
    "587dce8053cf40e9936dbdb265fed224": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "DescriptionStyleModel",
     "state": {
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "DescriptionStyleModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "StyleView",
      "description_width": ""
     }
    },
    "6fb85b3fadec4a89a8e9bad6eedc44c0": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "state": {
      "_model_module": "@jupyter-widgets/base",
      "_model_module_version": "1.2.0",
      "_model_name": "LayoutModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "LayoutView",
      "align_content": null,
      "align_items": null,
      "align_self": null,
      "border": null,
      "bottom": null,
      "display": null,
      "flex": null,
      "flex_flow": null,
      "grid_area": null,
      "grid_auto_columns": null,
      "grid_auto_flow": null,
      "grid_auto_rows": null,
      "grid_column": null,
      "grid_gap": null,
      "grid_row": null,
      "grid_template_areas": null,
      "grid_template_columns": null,
      "grid_template_rows": null,
      "height": null,
      "justify_content": null,
      "justify_items": null,
      "left": null,
      "margin": null,
      "max_height": null,
      "max_width": null,
      "min_height": null,
      "min_width": null,
      "object_fit": null,
      "object_position": null,
      "order": null,
      "overflow": null,
      "overflow_x": null,
      "overflow_y": null,
      "padding": null,
      "right": null,
      "top": null,
      "visibility": null,
      "width": null
     }
    },
    "a21bf86aa6e74564a9b5178c5ab3bcbb": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "state": {
      "_model_module": "@jupyter-widgets/base",
      "_model_module_version": "1.2.0",
      "_model_name": "LayoutModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "LayoutView",
      "align_content": null,
      "align_items": null,
      "align_self": null,
      "border": null,
      "bottom": null,
      "display": null,
      "flex": null,
      "flex_flow": null,
      "grid_area": null,
      "grid_auto_columns": null,
      "grid_auto_flow": null,
      "grid_auto_rows": null,
      "grid_column": null,
      "grid_gap": null,
      "grid_row": null,
      "grid_template_areas": null,
      "grid_template_columns": null,
      "grid_template_rows": null,
      "height": null,
      "justify_content": null,
      "justify_items": null,
      "left": null,
      "margin": null,
      "max_height": null,
      "max_width": null,
      "min_height": null,
      "min_width": null,
      "object_fit": null,
      "object_position": null,
      "order": null,
      "overflow": null,
      "overflow_x": null,
      "overflow_y": null,
      "padding": null,
      "right": null,
      "top": null,
      "visibility": null,
      "width": null
     }
    },
    "a8a0f84805af4107b413c931c19ce4fa": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "HTMLModel",
     "state": {
      "_dom_classes": [],
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "HTMLModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/controls",
      "_view_module_version": "1.5.0",
      "_view_name": "HTMLView",
      "description": "",
      "description_tooltip": null,
      "layout": "IPY_MODEL_6fb85b3fadec4a89a8e9bad6eedc44c0",
      "placeholder": "​",
      "style": "IPY_MODEL_587dce8053cf40e9936dbdb265fed224",
      "value": " 1000/1000 [00:22&lt;00:00, 46.60it/s]"
     }
    },
    "add1baa2ea3e4e73836f92bfcc24e3a1": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "ProgressStyleModel",
     "state": {
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "ProgressStyleModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "StyleView",
      "bar_color": null,
      "description_width": ""
     }
    },
    "b714194689294943b5cfa0ae293e1c49": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "FloatProgressModel",
     "state": {
      "_dom_classes": [],
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "FloatProgressModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/controls",
      "_view_module_version": "1.5.0",
      "_view_name": "ProgressView",
      "bar_style": "success",
      "description": "",
      "description_tooltip": null,
      "layout": "IPY_MODEL_ca65637a40544b2ca18137722960606a",
      "max": 1000,
      "min": 0,
      "orientation": "horizontal",
      "style": "IPY_MODEL_add1baa2ea3e4e73836f92bfcc24e3a1",
      "value": 1000
     }
    },
    "ca65637a40544b2ca18137722960606a": {
     "model_module": "@jupyter-widgets/base",
     "model_module_version": "1.2.0",
     "model_name": "LayoutModel",
     "state": {
      "_model_module": "@jupyter-widgets/base",
      "_model_module_version": "1.2.0",
      "_model_name": "LayoutModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/base",
      "_view_module_version": "1.2.0",
      "_view_name": "LayoutView",
      "align_content": null,
      "align_items": null,
      "align_self": null,
      "border": null,
      "bottom": null,
      "display": null,
      "flex": null,
      "flex_flow": null,
      "grid_area": null,
      "grid_auto_columns": null,
      "grid_auto_flow": null,
      "grid_auto_rows": null,
      "grid_column": null,
      "grid_gap": null,
      "grid_row": null,
      "grid_template_areas": null,
      "grid_template_columns": null,
      "grid_template_rows": null,
      "height": null,
      "justify_content": null,
      "justify_items": null,
      "left": null,
      "margin": null,
      "max_height": null,
      "max_width": null,
      "min_height": null,
      "min_width": null,
      "object_fit": null,
      "object_position": null,
      "order": null,
      "overflow": null,
      "overflow_x": null,
      "overflow_y": null,
      "padding": null,
      "right": null,
      "top": null,
      "visibility": null,
      "width": null
     }
    },
    "ef56ee46d7224c328788c14c7f5f9c17": {
     "model_module": "@jupyter-widgets/controls",
     "model_module_version": "1.5.0",
     "model_name": "HBoxModel",
     "state": {
      "_dom_classes": [],
      "_model_module": "@jupyter-widgets/controls",
      "_model_module_version": "1.5.0",
      "_model_name": "HBoxModel",
      "_view_count": null,
      "_view_module": "@jupyter-widgets/controls",
      "_view_module_version": "1.5.0",
      "_view_name": "HBoxView",
      "box_style": "",
      "children": [
       "IPY_MODEL_0e1d2ec247ef4c9daa804042c6753ebf",
       "IPY_MODEL_b714194689294943b5cfa0ae293e1c49",
       "IPY_MODEL_a8a0f84805af4107b413c931c19ce4fa"
      ],
      "layout": "IPY_MODEL_a21bf86aa6e74564a9b5178c5ab3bcbb"
     }
    }
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 0
}
