Konstantin Ladutenko a9b70a4dba fit d-params cleanup | 2 lat temu | |
---|---|---|
.github | 2 lat temu | |
debian | 4 lat temu | |
doc | 9 lat temu | |
examples | 2 lat temu | |
guiapp | 2 lat temu | |
scattnlay | 2 lat temu | |
src | 2 lat temu | |
tests | 2 lat temu | |
utils | 3 lat temu | |
vue-cli3-webapp | 3 lat temu | |
.clang-format | 2 lat temu | |
.gitignore | 3 lat temu | |
.gitmodules | 3 lat temu | |
CHANGES | 10 lat temu | |
CMakeLists.txt | 2 lat temu | |
COPYING | 5 lat temu | |
LICENSE | 10 lat temu | |
MANIFEST.in | 5 lat temu | |
Makefile | 2 lat temu | |
PKG-INFO | 5 lat temu | |
README.md | 2 lat temu | |
go.sh | 8 lat temu | |
push-to-github.sh | 10 lat temu | |
pyproject.toml | 2 lat temu | |
requirements.txt | 2 lat temu | |
setup.cfg | 6 lat temu | |
setup.py | 2 lat temu | |
tox.ini | 2 lat temu |
Output example: Field distribution inside layered Si\Ag\Si sphere and Poynting vector distribution in Ag sphere with powerflow lines calculated with Scattnlay (scripts field-SiAgSi-flow.py and field-Ag-flow.py from example section as revision ).
Fill the issue here: Issues.
Table of contents:
Limited web version is available at https://physics.ifmo.ru/mie/
To compile the source you will need a C++11 capable compiler. To use MultiPrecision feature you need to install Boost.Multiprecision library:
To compile the Python extension you need NumPy:
And to compile the Debian package you need some tools:
Compilation options
There are also an experimental CMake project and it is possible to compile into JavaScript module (using Emscripten compiler).
Python module
To build and install Python module run from the source code directory:
pip install . --user
Binary files for Ubuntu and derivative distributions can be found at Launchpad To install it you must configure the repository:
sudo add-apt-repository ppa:ovidio/scattering
sudo apt update
and then you simply install the package:
sudo apt install python-scattnlay
You can also install it from PyPi via
sudo pip install python-scattnlay
You can also git clone
and pip install -e .
to develop python package.
from scattnlay import scattnlay, fieldnlay
...
x = ...
m = ...
coords = ...
terms, Qext, Qsca, Qabs, Qbk, Qpr, g, Albedo, S1, S2 = scattnlay(x, m)
terms, E, H = fieldnlay(x, m, coords)
...
./test01.py
scattnlay -l Layers x1 m1.r m1.i [x2 m2.r m2.i ...] [-t ti tf nt] [-c comment]
fieldnlay -l Layers x1 m1.r m1.i [x2 m2.r m2.i ...] -p xi xf nx yi yf ny zi zf nz [-c comment]
./test01.sh > test01.csv
Scattnlay "Hello world!" example:
try {
nmie::MultiLayerMieApplied<double> multi_layer_mie;
multi_layer_mie.AddTargetLayer(core_width, index_Si);
multi_layer_mie.AddTargetLayer(inner_width, index_Ag);
multi_layer_mie.AddTargetLayer(outer_width, index_Si);
multi_layer_mie.SetWavelength(WL);
multi_layer_mie.RunMieCalculation();
double Qabs = multi_layer_mie.GetQabs();
printf("Qabs = %g\n", Qabs);
} catch( const std::invalid_argument& ia ) {
// Will catch if multi_layer_mie fails or other errors.
std::cerr << "Invalid argument: " << ia.what() << std::endl;
return -1;
}
The complete example-minimal.cc
and a bit more complicated
example-get-Mie.cc
can be found in example directory along with
go-cc-examples.sh
script with build commands.
example-get-Mie.cc
can be compiled using double precision or
multiple precision (just include -DMULTI_PRECISION=200
to use 200
digits for calculations).
O. Peña and U. Pal, "Scattering of electromagnetic radiation by a multilayered sphere," Comput. Phys. Commun. 180, 2348-2354 (2009). http://dx.doi.org/10.1016/j.cpc.2009.07.010
K. Ladutenko, O. Peña-Rodríguez, I. Melchakova, I. Yagupov and P. Belov, "Reduction of scattering using thin all-dielectric shells designed by stochastic optimizer," J. Appl. Phys. 116, 184508 (2014). http://dx.doi.org/10.1063/1.4900529
K. Ladutenko, P. Belov, O. Peña-Rodríguez, A. Mirzaei, A. Miroshnichenko and I. Shadrivov, "Superabsorption of light by nanoparticles," Nanoscale 7, 18897-18901 (2015). http://dx.doi.org/10.1039/C5NR05468K
K. Ladutenko, U. Pal, A. Rivera, and O. Peña-Rodríguez, "Mie calculation of electromagnetic near-field for a multilayered sphere," Comp. Phys. Comm. 214, 225-230 (2017). http://dx.doi.org/j.cpc.2017.01.017
We expect that all publications describing work using this software, or all commercial products using it, cite at least one of the following references:
[1] O. Peña and U. Pal, "Scattering of electromagnetic radiation
by a multilayered sphere," Computer Physics Communications, vol. 180, Nov. 2009, pp. 2348-2354.
[2] K. Ladutenko, U. Pal, A. Rivera and O. Peña-Rodríguez, "Mie calculation
of electromagnetic near-field for a multilayered sphere," Computer Physics Communications, vol. 214, May 2017, pp. 225-230.
GPL v3+