Nav apraksta

Ovidio Peña Rodríguez 7219d21e9c Update the REDME file to explain the dependences for the the compilation of the Python extension and the Debian package. 8 gadi atpakaļ
debian ae294b55fd Changed version number to '2.0'. 10 gadi atpakaļ
doc 57c7261705 updated fiel plotting script 9 gadi atpakaļ
examples c72d4e94de bug fix 8 gadi atpakaļ
src c72d4e94de bug fix 8 gadi atpakaļ
tests 1c85c9614f applied example comiples with templates using double 8 gadi atpakaļ
utils 098e75e02b Even more changes. Reorganized code. 10 gadi atpakaļ
.gitignore 55496bd28e Gauss integration verified vs Gauss law 8 gadi atpakaļ
CHANGES 1b7786ad5a Initial commit based on Ovidio version of python-scattnlay 0.3.0 10 gadi atpakaļ
COPYING c23b1aae05 Reorganized source code 10 gadi atpakaļ
LICENSE 1b7786ad5a Initial commit based on Ovidio version of python-scattnlay 0.3.0 10 gadi atpakaļ
MANIFEST.in bfafd4bcfb Reorganized code and increased version number to 2.0.0 10 gadi atpakaļ
Makefile 796dc711df nmie-applied compiles with double 8 gadi atpakaļ
PKG-INFO ae294b55fd Changed version number to '2.0'. 10 gadi atpakaļ
README.md 7219d21e9c Update the REDME file to explain the dependences for the the compilation of the Python extension and the Debian package. 8 gadi atpakaļ
go.sh e8024478b5 change missed .h to .hpp 8 gadi atpakaļ
push-to-github.sh eea51ce5ca Changes to push script 10 gadi atpakaļ
scattnlay.pyx f4efce1cd4 Several changes to complete the features 10 gadi atpakaļ
setup.py ae294b55fd Changed version number to '2.0'. 10 gadi atpakaļ
setup_cython.py ae294b55fd Changed version number to '2.0'. 10 gadi atpakaļ

README.md

output example Output example: Field distribution inside layered Si\Ag\Si sphere and Poynting vector distribution in Ag sphere with poweflow lines calculated with Scattnlay (scripts field-SiAgSi-flow.py and field-Ag-flow.py from example section as revision ).

Discuss:

Try to join our Gitter chat:

Fill the issue here: Issues.

How to use scattnlay

Table of contents:

Compile Code:

To compile the source you will need C++11 capable compiler. To use MultiPrecision feature you need to install Boost.Multiprecision library (at least 1.58 ver).

To compile the Python extension you also need the following packages:

  • python-numpy (>= 1.0)
  • python-support (>= 0.6)
  • python-all-dev (any version)
  • python-numpy-dev (any version)

To compile the Debian package you also need the following packages:

  • debhelper (>=7.0.0)
  • cdbs (>= 0.4.49)

Compilation options

  • make source - Create source package for Python extension
  • make cython - Convert Cython code to C++
  • make python_ext - Create Python extension using C++ code
  • make cython_ext - Create Python extension using Cython code
  • make install - Install Python extension on local system
  • make buildrpm - Generate a rpm package for Python extension
  • make builddeb - Generate a deb package for Python extension
  • make standalone - Create standalone programs (scattnlay and fieldnlay)
  • make clean - Delete temporal files

Use:

  1. Python library
    • Use scattnlay directly
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)
...
  • Execute some of the test scripts (located in the folder 'tests/python') Example:
./test01.py
  1. Standalone program
    • Execute scattnlay directly:
scattnlay -l Layers x1 m1.r m1.i [x2 m2.r m2.i ...] [-t ti tf nt] [-c comment]
  • Execute fieldnlay directly:
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]
  • Execute some of the test scripts (located in the folder 'tests/shell'):
./test01.sh > test01.csv
  1. C++ library

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).

Papers

  1. "Scattering of electromagnetic radiation by a multilayered sphere" O. Pena and U. Pal, Computer Physics Communications, vol. 180, Nov. 2009, pp. 2348-2354. http://dx.doi.org/10.1016/j.cpc.2009.07.010

  2. "Reduction of scattering using thin all-dielectric shells designed by stochastic optimizer" Konstantin Ladutenko, Ovidio Peña-Rodríguez, Irina Melchakova, Ilya Yagupov, and Pavel Belov J. Appl. Phys., vol. 116, pp. 184508, 2014 http://dx.doi.org/10.1063/1.4900529

  3. "Superabsorption of light by nanoparticles" Konstantin Ladutenko, Pavel Belov, Ovidio Peña-Rodríguez, Ali Mirzaei, Andrey E. Miroshnichenko and Ilya V. Shadrivov Nanoscale, 2015,7, 18897-18901 http://dx.doi.org/10.1039/C5NR05468K

Acknowledgment

We expect that all publications describing work using this software, or all commercial products using it, cite the following reference:

O. Pena and U. Pal, "Scattering of electromagnetic radiation by a multilayered sphere," Computer Physics Communications, vol. 180, Nov. 2009, pp. 2348-2354.

License

GPL v3+