Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

EELS&CL for particles inside arbitrary host medium #314

Open
wants to merge 102 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
102 commits
Select commit Hold shift + click to select a range
1f0b959
Created new branch EELS for simulations of EELS spectra (issue 155)
to266 Jan 15, 2014
9bae8c9
Added electron beam B_ELECTRON with required subroutines and constant…
to266 Jan 16, 2014
aed6adc
added EELS probability calculations. The iterative solver somehow doe…
to266 Jan 20, 2014
0b61b09
Corrected misstypes and found a bug regarding not passing values if n…
to266 Jan 22, 2014
030495e
merge with trunk
to266 Feb 24, 2014
b30be95
resolved abs(x) error, changed variables to doubles where complex not…
to266 Feb 24, 2014
c435482
Update .gitignore
alkichigin Mar 3, 2020
156099d
Update .gitignore
alkichigin Mar 6, 2020
444207c
Revert "Update .gitignore"
alkichigin Mar 26, 2020
37bb556
Revert "Update .gitignore"
alkichigin Mar 26, 2020
ef325e1
Added beam of an electron
alkichigin Apr 10, 2020
da7f496
added fortran library for Bessel functions calculation
alkichigin Apr 23, 2020
9024ff7
For now the code is proven to work for vacuum
alkichigin May 21, 2020
adc78e6
added eelsprob calculation
alkichigin Jun 2, 2020
51391a0
added EELS support for non-absorbing host medium
alkichigin Jun 3, 2020
fe19f7c
Merge remote-tracking branch 'upstream/master'
alkichigin Jun 19, 2020
8425ef2
Renamed Peels_au to Peels_ev
alkichigin Jun 19, 2020
891b519
merging from upstream
alkichigin Jun 20, 2020
db57873
merging from upstream
alkichigin Jun 20, 2020
8e6c1c5
manually copying doc/history from upstream/master
alkichigin Jun 20, 2020
5067d9d
manually copying non-src files from upstream/master
alkichigin Jun 20, 2020
fc8c314
manually copying src files from upstream\master
alkichigin Jun 20, 2020
379a461
manually copying calculator.c from upstream/master
alkichigin Jun 20, 2020
6c8fdd8
manually deleted merge-related older code parts
alkichigin Jun 21, 2020
2a4d744
manually deleted merge-related code parts
alkichigin Jun 21, 2020
2d61a77
deleted bash script
alkichigin Jun 21, 2020
008060f
fixed minor mistakes, now the code works for EELS on a sphere
alkichigin Jun 21, 2020
9b6c0fd
Update .gitignore
alkichigin Jun 21, 2020
d7e5198
Update .gitignore
alkichigin Jun 21, 2020
041d62a
minor fixes
alkichigin Jun 21, 2020
8e377a6
trancated special_functions.f90
alkichigin Jun 21, 2020
0ec7159
minor fixes
alkichigin Jun 21, 2020
80552ad
Update crosssec.h
alkichigin Jun 21, 2020
a189d22
minor fixes
alkichigin Jun 21, 2020
e5b9496
re-written for the code to work with -prop and -orient, but not teste…
alkichigin Jun 25, 2020
9a3f6e8
optimized GenerateB
alkichigin Jun 26, 2020
531ba06
simplified the code
alkichigin Jun 26, 2020
d65de1f
Manually replaced files from alkichigin/master. Now EELS works in non…
alkichigin Jun 26, 2020
8a5fcb3
merged from upstream and edited decr according to issue #271
alkichigin Jun 28, 2020
613e3ad
Added cathodoluminescence
alkichigin Jul 4, 2020
ea18d69
golden master
alkichigin Jul 20, 2020
aaa66fd
Merge branch 'eels'
alkichigin Jul 22, 2020
83b910f
Merge pull request #1 from adda-team/master
Sunmosk Aug 4, 2020
84749d8
minor tweaks
alkichigin Aug 15, 2020
41a89ff
uploading older version of PAW
alkichigin Aug 26, 2020
3645dee
uploading current PAW v0.3
alkichigin Aug 26, 2020
a6d6853
Added the -mhost option, which enables the non-unity refractive index…
Sunmosk Nov 2, 2020
09efd72
Update crosssec.c
Sunmosk Nov 20, 2020
03189b0
Beta 0.000001
Sunmosk Nov 23, 2020
d327d26
ADDA Wrapper 0.4
alkichigin Dec 29, 2020
8f193b8
removing simulation results
alkichigin Dec 29, 2020
4589ebb
Merge remote-tracking branch 'upstream/master'
alkichigin Dec 29, 2020
eeede49
minor changes
alkichigin Jan 26, 2021
e27071d
Merge remote-tracking branch 'upstream/master'
alkichigin Jan 26, 2021
3aaf891
small improvements
alkichigin Mar 27, 2021
e9247aa
Merge remote-tracking branch 'upstream/master'
alkichigin Mar 27, 2021
3fa7b2e
Merge remote-tracking branch 'sunmosk/master'
alkichigin Mar 27, 2021
f14bc4e
minor fixes
alkichigin Mar 27, 2021
e6f7949
minor fixes
alkichigin Mar 27, 2021
5adc7c9
fixed the bug with kd definition
alkichigin Mar 28, 2021
6c23476
minor change on the examples
alkichigin Mar 28, 2021
72cc273
ADDAWrapper 0.5
alkichigin Mar 30, 2021
86aa0f0
minor fixes
alkichigin Jun 9, 2021
3221b31
Merge remote-tracking branch 'upstream/master'
alkichigin Jun 9, 2021
347964a
ADDA Wrapper plots now uses Arial font
alkichigin Jul 29, 2021
d3aaebe
ADDA Wrapper plots are saved in svg format
alkichigin Jul 29, 2021
86a30f8
-beam_center option introduced
alkichigin Aug 3, 2021
c64dcac
Added -beam_center support for plane waves
alkichigin Aug 8, 2021
5f72571
Added -beam_center description to -h and logging alongside the beam p…
alkichigin Aug 9, 2021
595e344
Gaussian beam fix for -beam_center
alkichigin Aug 24, 2021
c3afaab
preparing merge from upsatream
alkichigin Nov 11, 2021
f9b4777
Merge remote-tracking branch 'upstream/master'
alkichigin Nov 11, 2021
a39dcc3
Modified definitions of cross sections + made kdX, kdY, kdZ doublecom…
Sunmosk Nov 24, 2021
0c5d913
removing .DS_Store
alkichigin Dec 14, 2021
823e209
Merge remote-tracking branch 'upstream/master'
alkichigin Dec 14, 2021
ae5d9fb
examples updated to igt_so
alkichigin Dec 15, 2021
bcc0c90
Merge pull request #1 from Sunmosk/master
alkichigin Dec 15, 2021
5a6dfd8
Cross sections are changed according to mhost, GenerateB and Peels/Pc…
alkichigin Jan 19, 2022
8a9ead2
moved ADDAwrapper to misc, fixed bug in crosssec.c
alkichigin Jan 25, 2022
922756b
Boolean absorbing_host, Solved problems with warnings due to doubleco…
Sunmosk Jan 25, 2022
63dbc96
Merge pull request #3 from alkichigin/master
Sunmosk Jan 25, 2022
2c150f7
Merge branch 'Some-Old-Code' into master
Sunmosk Jan 25, 2022
9e12cf3
minor fix
alkichigin Jan 27, 2022
c13917f
Merge pull request #2 from Sunmosk/master
alkichigin Jan 27, 2022
766a4db
Merge remote-tracking branch 'upstream/master'
alkichigin Jan 27, 2022
a03faed
Delete org.eclipse.cdt.core.prefs
alkichigin Jan 27, 2022
ac64e8c
merge upstream bugfixing
alkichigin Jan 27, 2022
3153101
Merge pull request #5 from alkichigin/master
Sunmosk Jan 27, 2022
4474872
Abs_cross fixed, volume integrals normalized to WaveNum0
Sunmosk Jan 27, 2022
e5a8161
Merge pull request #3 from Sunmosk/master
alkichigin Jan 28, 2022
2b0e969
warnings fix
alkichigin Jan 28, 2022
6103e4f
Adapted ADDAwrapper for Windows
alkichigin Feb 3, 2022
5c01797
Merge remote-tracking branch 'upstream/master'
alkichigin Feb 3, 2022
1f1c83b
Update ADDAwrapper.py
alkichigin Feb 3, 2022
133ef02
adda "varyany" to ADDAwrapper
alkichigin Feb 8, 2022
c967f03
Wrapper now plots in proper 10^-3 rather than former 1e-3
alkichigin Feb 17, 2022
2b8241c
ADDAwrapper now can visualize the dipole set
alkichigin Feb 21, 2022
f4ea2ec
minor fix
alkichigin Feb 21, 2022
5f70d0e
fixed bug
Sunmosk May 10, 2022
a07058d
minor updates
alkichigin Aug 3, 2022
d53d3ae
Merge pull request #4 from Sunmosk/master
alkichigin Aug 3, 2022
f552ad3
Merge remote-tracking branch 'upstream/master'
alkichigin Aug 3, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
88 changes: 88 additions & 0 deletions examples/eels/nanorod/run.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
import sys, os, multiprocessing, numpy as np
if sys.path[1] != os.path.abspath(__file__ + "/../../../../misc/ADDAwrapper") : sys.path.insert(1,os.path.abspath(__file__ + "/../../../../misc/ADDAwrapper")) #This is to import ADDA Wrapper from parent directory
import ADDAwrapper as aw

# ADDAWrapper parameters
aw_parameters = dict(
#adda_exec = os.path.abspath(__file__ + "/../../../../win64/adda.exe"), #path to ADDA executable
adda_exec = aw.addaexec_find(mode="seq"), #path to ADDA executable
parallel_procs = multiprocessing.cpu_count()-1, #number of parallel processes is equal to the number of processor cores minus 1

mp_files = [os.path.abspath(__file__ + "/../../../../misc/ADDAwrapper/refractive_index/" + "Au_JHW.csv")], #file with refractive index of the particle, each string contains: ev,mp_re,mp_im
ev_range = np.arange(0.5,3+.01,0.05), #[eV]. Used in "spectrum_" functions. (ev_min,ev_max): range from ev_min[eV] to ev_max[eV]

#Used in "scan_" functions. Beam propagation must be orthogonal to the grid.
#So "prop" must be "0 0 whatever" and rotations with "orient" must be made by 90 degrees.
scan_x_range = (-15,15), #[nm], (x_left, x_right)
scan_y_range = (-50,50), #[nm], (y_bottom, y_top)
scan_step = 1 #dipoles per each step, must be an integer >= 1. Set to 1 for the finest resolution.
#The beam must always blast exactly in the middle between the dipoles,
#so start and stop coordinates will be adjusted, covering more area than you entered. Obligatory to use "no_vol_cor" with scan.
)

hd = (92.6-7.8)/7.8

# ADDA command line arguments
adda_cmdlineargs = dict(
# Particle
shape = f"capsule {hd}",
size = 7.8, #[nm]
grid = 8, #dipoles per x-axis size of the particle
mhost = "1.45 0", #refractive index of the host medium
orient = "90 90 0", #rotating the particle

# Beam
beam = "electron 100", #Energy[keV]
beam_center = "10 20 0", # x[nm] y[nm] z[nm] - beam center coordinates
prop = "0 0 -1", #beam propagation direction vector

# Precision and performance
eps = 2, #Residual norm

# Additional options
sym = "enf", #Do not simulate second polarization
scat_matr = "none", #Do not calculate the Mueller matrix
no_vol_cor = "", #Disable volume correction
iter = "qmr2", #Iterative solver
pol = "igt_so", #Polarizability prescription
int = "igt_so", #Interaction term
Csca = "", #Calculate Csca with the Romberg integral. Needed to properly calculate Cathodoluminesce
alldir_inp = os.path.abspath(__file__ + "/../../../../misc/ADDAwrapper/Csca_default.txt")
)

### Executing commands
if __name__ == '__main__':

# Execute spectra simulations for different positions of the beam to find plasmon peaks
aw_parameters['dirname'] = os.path.abspath(__file__ + "/../" + "spectrumline")
aw_parameters["spectrumline_startpoint"] = (10,0) # (x,y) [nm]
aw_parameters["spectrumline_endpoint"] = (10,50) # (x,y) [nm]
aw_parameters["spectrumline_points"] = 15 # how many points, including startpoint and endpoint
aw.spectrumline_execute(aw_parameters,adda_cmdlineargs) # Execute simulation
aw.spectrumline_collect("Peels",aw_parameters) # Collect EELS spectrum
aw.spectrumline_plot("Peels",aw_parameters) # Plot EELS spectrum
aw.spectrumline_collect("Pcl",aw_parameters) # Collect CL spectrum
aw.spectrumline_plot("Pcl",aw_parameters) # Plot CL spectrum

# Execute scan of particle's cross-section for single energy ev
aw_parameters['dirname'] = os.path.abspath(__file__ + "/../" + "scan2.4")
aw_parameters["ev"] = 2.4
aw.scan_execute(aw_parameters,adda_cmdlineargs)
# Collect and map scanned EELS/CL probabilities on particle's cross-section
aw.scan_collect("Peels",aw_parameters)
aw.scan_plot("Peels",aw_parameters)
aw.scan_collect("Pcl",aw_parameters)
aw.scan_plot("Pcl",aw_parameters)

# Visual representation of the dipole set
cmdline = aw.cmdline_construct(aw_parameters,adda_cmdlineargs)
cmdline += f" -dir {os.path.abspath(__file__ + '/../geom/')}"
cmdline += " -save_geom"
cmdline += " -prognosis"
cmdline += " > /dev/null"
os.system(cmdline)
fig1,ax1 = aw.geometry("geom/capsule.geom", ["gold"])
ax1.axis("off")
ax1.view_init(30, -30)
fig1.savefig("geometry.svg", bbox_inches='tight')

102 changes: 102 additions & 0 deletions examples/eels/sphere/run.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
import sys, os, multiprocessing, numpy as np
if sys.path[1] != os.path.abspath(__file__ + "/../../../../misc/ADDAwrapper") : sys.path.insert(1,os.path.abspath(__file__ + "/../../../../misc/ADDAwrapper")) #This is to import ADDA wrapper from parent directory
import ADDAwrapper as aw

# ADDAWrapper parameters
aw_parameters = dict(
#adda_exec = os.path.abspath(__file__ + "/../../../../win64/adda.exe"), #path to ADDA executable
adda_exec = aw.addaexec_find(mode="seq"), #path to ADDA executable
parallel_procs = multiprocessing.cpu_count()-1, #number of parallel processes is equal to the number of processor cores minus 1

mp_files = [os.path.abspath(__file__ + "/../../../../misc/ADDAwrapper/refractive_index/" + "Ag_JHW.csv")], #file with refractive index of the particle, each string contains: ev,mp_re,mp_im
ev_range = np.arange(2.5,4.5+.01,0.05), #[eV]. Used in "spectrum_" functions.
ev = 3.45, #[eV]. Used in "scan_" and "extrapolation_" functions.

spectrumline_startpoint = (0,50), # (x,y) [nm]
spectrumline_endpoint = (50,50), # (x,y) [nm]
spectrumline_points = 10, #how many points, including startpoint and endpoint

#Used in "scan_" functions. Beam propagation must be orthogonal to the grid.
#So "prop" must be "0 0 whatever" and rotations with "orient" must be made by 90 degrees.
scan_x_range = (0,30), #[nm], (x_left, x_right)
scan_y_range = (0,30), #[nm], (y_bottom, y_top)
scan_step = 1 #dipoles per each step, must be an integer >= 1
#The beam must always blast exactly in the middle between the dipoles,
#so start and stop coordinates will be adjusted, covering more area than you entered. Obligatory to use "no_vol_cor" with scan.
)

# ADDA command line arguments
adda_cmdlineargs = dict(
# Particle
shape = "sphere",
size = 40, #[nm]
grid = 32, #dipoles per x-axis size of the particle
mhost = "1 0", #refractive index of the host medium

# Beam
beam = "electron 100", #Energy[keV]
beam_center = "60 0 0", # x[nm] y[nm] z[nm] - beam center coordinates
prop = "0 0 -1", #beam propagation direction vector

# Precision and performance
eps = 2, #Residual norm

# Additional options
sym = "enf", #Do not simulate second polarization
scat_matr = "none", #Do not calculate the Mueller matrix
no_vol_cor = "", #Disable volume correction
iter = "qmr2", #Iterative solver
pol = "igt_so", #Polarizability prescription
int = "igt_so", #Interaction term
Csca = "", #Calculate Csca with the Romberg integral. Needed to properly calculate Cathodoluminesce
alldir_inp = os.path.abspath(__file__ + "/../../../../misc/ADDAwrapper/Csca_default.txt")
)

### Executing commands
if __name__ == '__main__':

# Execute spectrum
aw_parameters["dirname"] = os.path.abspath(__file__ + "/../" + "spectrum")
aw.spectrum_execute(aw_parameters,adda_cmdlineargs)
# Collect and plot EELS probabilities
aw.spectrum_collect("Peels",aw_parameters)
aw.spectrum_plot("Peels",aw_parameters)
# Collect and plot CL probabilities
aw.spectrum_collect("Pcl",aw_parameters)
aw.spectrum_plot("Pcl",aw_parameters)

# Execute extrapolation for single energy ev
aw_parameters["dirname"] = os.path.abspath(__file__ + "/../" + "extrapolation")
aw.extrapolation_execute(aw_parameters,adda_cmdlineargs)
# Collect and plot EELS probabilities for different y~1/grid with extrapolated value in y=0 (with errorbar)
aw.extrapolation_collect("Peels",aw_parameters)
aw.extrapolation_plot("Peels",aw_parameters)

# Execute spectrum with extrapolation at each energy ev
aw_parameters["dirname"] = os.path.abspath(__file__ + "/../" + "spectrum_with_extrapolation")
aw.spectrum_with_extrapolation_execute(aw_parameters,adda_cmdlineargs)
# Collect and plot fit EELS probabilities spectrum (with errorbar)
aw.spectrum_with_extrapolation_collect("Peels",aw_parameters)
aw.spectrum_with_extrapolation_plot("Peels",aw_parameters)

# Execute scan of particle's cross-section for single energy ev
aw_parameters["dirname"] = os.path.abspath(__file__ + "/../" + "scan")
aw.scan_execute(aw_parameters,adda_cmdlineargs)
# Collect and map scanned EELS probabilities on particle's cross-section
aw.scan_collect("Peels",aw_parameters)
aw.scan_plot("Peels",aw_parameters)
aw.scan_collect("Pcl",aw_parameters)
aw.scan_plot("Pcl",aw_parameters)

# Visual representation of the dipole set
cmdline = aw.cmdline_construct(aw_parameters,adda_cmdlineargs)
cmdline += f" -dir {os.path.abspath(__file__ + '/../geom/')}"
cmdline += " -save_geom"
cmdline += " -prognosis"
cmdline += " > /dev/null"
os.system(cmdline)
fig1,ax1 = aw.geometry("geom/sphere.geom", ["silver"])
ax1.axis("off")
ax1.view_init(30, -30)
fig1.savefig("geometry.svg", bbox_inches='tight')

Loading