| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 | #!/usr/bin/env python# -*- coding: UTF-8 -*-##    Copyright (C) 2009-2015 Ovidio Peña Rodríguez <ovidio@bytesfall.com>#    Copyright (C) 2013-2015  Konstantin Ladutenko <kostyfisik@gmail.com>##    This file is part of python-scattnlay##    This program is free software: you can redistribute it and/or modify#    it under the terms of the GNU General Public License as published by#    the Free Software Foundation, either version 3 of the License, or#    (at your option) any later version.##    This program is distributed in the hope that it will be useful,#    but WITHOUT ANY WARRANTY; without even the implied warranty of#    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the#    GNU General Public License for more details.##    The only additional remark is that we expect that all publications#    describing work using this software, or all commercial products#    using it, cite the following reference:#    [1] O. Pena and U. Pal, "Scattering of electromagnetic radiation by#        a multilayered sphere," Computer Physics Communications,#        vol. 180, Nov. 2009, pp. 2348-2354.##    You should have received a copy of the GNU General Public License#    along with this program.  If not, see <http://www.gnu.org/licenses/>.# This test case calculates the electric field in the # E-k plane, for an spherical Si-Ag-Si nanoparticle. Core radius is 17.74 nm,# inner layer 23.31nm, outer layer 22.95nm. Working wavelength is 800nm, we use# silicon epsilon=13.64+i0.047, silver epsilon= -28.05+i1.525import scattnlayfrom scattnlay import fieldnlayfrom scattnlay import scattnlayfrom fieldplot import fieldplotimport numpy as npimport cmathepsilon_Si = 13.64 + 0.047jepsilon_Ag = -28.05 + 1.525j# epsilon_Si = 2.0 + 0.047j# epsilon_Ag = -2.0 + 1.525j# air = 1# epsilon_Si = air*2# epsilon_Ag = air*2index_Si = np.sqrt(epsilon_Si)index_Ag = np.sqrt(epsilon_Ag)print(index_Si)print(index_Ag)# # Values for 800 nm, taken from http://refractiveindex.info/# index_Si = 3.69410 + 0.0065435j# index_Ag = 0.18599 + 4.9886jWL=800 #nmcore_width = 17.74 #nm Siinner_width = 23.31 #nm Agouter_width = 22.95 #nm  Sicore_r = core_widthinner_r = core_r+inner_widthouter_r = inner_r+outer_width# n1 = 1.53413# n2 = 0.565838 + 7.23262jnm = 1.0x = np.ones((3), dtype = np.float64)x[0] = 2.0*np.pi*core_r/WLx[1] = 2.0*np.pi*inner_r/WLx[2] = 2.0*np.pi*outer_r/WLm = np.ones((3), dtype = np.complex128)m[0] = index_Si/nmm[1] = index_Ag/nmm[2] = index_Si/nmprint "x =", xprint "m =", mnpts = 501factor=2.2flow_total = 21crossplane='XZ'#crossplane='YZ'#crossplane='XY'# Options to plot: Eabs, Habs, Pabs, angleEx, angleHyfield_to_plot='Eabs'#field_to_plot='angleEx'comment='SiAgSi-absorber-flow'WL_units='nm'import matplotlib.pyplot as pltfig, axs = plt.subplots(1,1)#, sharey=True, sharex=True)fig.tight_layout()fieldplot(fig, axs, x,m, WL, comment, WL_units, crossplane, field_to_plot, npts, factor, flow_total,          subplot_label=' ',is_flow_extend=False, outline_width=1.5)#fieldplot(x,m, WL, comment, WL_units, crossplane, field_to_plot, npts, factor, flow_total, is_flow_extend=False)# for ax in axs:#     ax.locator_params(axis='x',nbins=5)#     ax.locator_params(axis='y',nbins=5)fig.subplots_adjust(hspace=0.3, wspace=-0.1)plt.savefig(comment+"-R"+str(int(round(x[-1]*WL/2.0/np.pi)))+"-"+crossplane+"-"                    +field_to_plot+".pdf",pad_inches=0.02, bbox_inches='tight')plt.draw()#    plt.show()plt.clf()plt.close()
 |