123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260 |
- import snlay as sn
- import numpy as np
- from scipy import interpolate
- from noise import pnoise1
- import random
- from tmm import coh_tmm
- import multiprocessing as mp
- import makeqx as mkq
- matsdict = {
- 1: "./materials/gold.dat",
- 2: "./materials/silicon.dat",
- 3: "./materials/silica.dat",
- 4: "./materials/tio2.dat",
- 5: "./materials/silver.dat",
- }
- def get_nk(datafile, wavelengths):
- """Reads the given file and returns the n+ik complex at
- the given wavelength after suitable interpolation
- :datafile: TODO
- :wavelength: TODO
- :returns: TODO
- """
- rawdisp = np.loadtxt(datafile)
- f_r = interpolate.interp1d(rawdisp[:, 0], rawdisp[:, 1])
- f_i = interpolate.interp1d(rawdisp[:, 0], rawdisp[:, 2])
- return f_r(wavelengths) + 1j * f_i(wavelengths)
- def nk_2_eps(n):
- """TODO: Docstring for nk_2_epsnk_2_eps.
- :returns: complex epsilon given n and kappa
- """
- eps_r = n.real ** 2 - n.imag ** 2
- eps_i = 2 * n.real * n.imag
- return eps_r + 1j * eps_i
- def eps_2_nk(eps):
- """TODO: Docstring for nk_2_epsnk_2_eps.
- :returns: complex epsilon given n and kappa
- """
- modeps = np.abs(eps)
- n_r = np.sqrt(0.5 * (modeps + eps.real))
- n_i = np.sqrt(0.5 * (modeps - eps.real))
- return n_r + 1j * n_i
- def LL_mixing(fH, n_H, n_L):
- """TODO: Docstring for brugg_mixingbrugg_mixing.
- Given the volumne fraction of the higher index material, give the effective
- index of the layer
- :fH: volumne fraction from 0 to 1
- :n_H: ri of the higher index material
- :n_L: ri of the lower index material
- :returns: TODO
- """
- eH = nk_2_eps(n_H)
- eL = nk_2_eps(n_L)
- bigK = fH * (eH - 1) / (eH + 2) + (1 - fH) * (eL - 1) / (eL + 2)
- e_eff = (1 + 2 * bigK) / (1 - bigK)
- return eps_2_nk(e_eff)
- def make_qxn(num_layers, dlevels=0):
- """TODO: Docstring for make_qxn.
- :num_layers: TODO
- :returns: TODO
- """
- uni = np.linspace(0, 2*num_layers, 2*num_layers, endpoint=False)
- rwalk = np.zeros_like(uni).reshape((num_layers,2))
- rwalk[:,0] = mkq.make_qx(num_layers)
- if dlevels != 0:
- rwalk[:,1] = mkq.digitize_qx(mkq.make_qx(num_layers), dlevels)
- else:
- rwalk[:,1] = mkq.make_qx(num_layers)
- return rwalk.flatten()
- def make_nxdx(qx, d_min, d_max, wavelen=550, n_substrate=1.52):
- """TODO: Docstring for make_nxdx.
- :qx: TODO
- :n_substrate: TODO
- :layer_thickness: TODO
- :returns: TODO
- """
- num_layers = int(qx.size/2)
- qx = qx.reshape((num_layers, 2))
-
- d_x = qx[:,0]
- d_x = [np.inf] + d_x.tolist() + [np.inf]
- sde = LL_mixing(
- fH=qx[:,1], n_H=2.58, n_L=1.45
- )
-
- n_x = [1.0] + sde.tolist() + [n_substrate]
- return d_x, n_x
- def tmm_eval_wbk(qx, d_min , d_max, inc_ang, lam, n_subs=1.52):
- """TODO: Docstring for tmm_eval.
- :qx: TODO
- :returns: TODO
- """
- degree = np.pi / 180
- d_x, n_x = make_nxdx(qx=qx, d_min=d_min, d_max=d_max, wavelen=lam, n_substrate=n_subs)
- Rs = 100 * coh_tmm("s", n_x, d_x, th_0=inc_ang * degree, lam_vac=lam)
-
- return Rs
- def tmm_eval_wsweep(
- qx, d_min , d_max, inc_ang, lam_low=400, lam_high=800, lam_pts=50, n_subs=1.52
- ):
- """TODO: Docstring for tmm_eval.
- :qx: TODO
- :lam_low: TODO
- lam_high: TODO
- :lam_pts: TODO
- :returns: TODO
- """
- degree = np.pi / 180
- lams = np.linspace(lam_low, lam_high, endpoint=True, num=lam_pts)
- Rs = np.zeros(lams.size)
-
- for lidx, lam in enumerate(lams):
- d_x, n_x = make_nxdx(qx=qx, d_min=0, d_max=1, wavelen=lam, n_substrate=n_subs)
- Rs[lidx] = 100 * coh_tmm("s", n_x, d_x, th_0=inc_ang * degree, lam_vac=lam)
-
- return Rs
|