|
10 лет назад | |
---|---|---|
debian | 10 лет назад | |
doc | 10 лет назад | |
tests | 10 лет назад | |
.gitignore | 10 лет назад | |
CHANGES | 10 лет назад | |
COPYING | 10 лет назад | |
LICENSE | 10 лет назад | |
MANIFEST.in | 10 лет назад | |
Makefile | 10 лет назад | |
PKG-INFO | 10 лет назад | |
README.md | 10 лет назад | |
bessel.cc | 10 лет назад | |
bessel.h | 10 лет назад | |
compare.cc | 10 лет назад | |
go.sh | 10 лет назад | |
nmie-old.cc | 10 лет назад | |
nmie-old.h | 10 лет назад | |
nmie-wrapper.cc | 10 лет назад | |
nmie-wrapper.h | 10 лет назад | |
nmie.cc | 10 лет назад | |
nmie.h | 10 лет назад | |
push-to-github.sh | 10 лет назад | |
py_nmie.cc | 10 лет назад | |
py_nmie.h | 10 лет назад | |
scattnlay.cpp | 10 лет назад | |
scattnlay.pyx | 10 лет назад | |
setup.py | 10 лет назад | |
setup_cython.py | 10 лет назад | |
standalone.cc | 10 лет назад | |
test-negative-epsilon.cc | 10 лет назад |
Compilation options
Python library
Use scattnlay directly
from scattnlay import scattnlay
...
x = ...
m = ...
terms, Qext, Qsca, Qabs, Qbk, Qpr, g, Albedo, S1, S2 = scattnlay(x, m)
...
bash
./test01.py
Standalone program
Execute scattnlay directly Usage:
scattnlay -l Layers x1 m1.r m1.i [x2 m2.r m2.i ...] [-c comment]
bash
./test01.sh > test01.csv
C++ library
try {
MultiLayerMie multi_layer_mie;
multi_layer_mie.SetLayersSize(x);
multi_layer_mie.SetLayersIndex(m);
multi_layer_mie.RunMieCalculation();
*Qsca = multi_layer_mie.GetQsca();
*Qabs = multi_layer_mie.GetQabs();
} catch(const std::invalid_argument& ia) {
// Will catch if multi_layer_mie fails or other errors.
std::cerr << "Invalid argument: " << ia.what() << std::endl;
throw std::invalid_argument(ia);
return -1;
}