setup.py 3.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. #!/usr/bin/env python3
  2. # -*- coding: UTF-8 -*-
  3. #
  4. # Copyright (C) 2009-2019 Ovidio Peña Rodríguez <ovidio@bytesfall.com>
  5. # Copyright (C) 2013-2019 Konstantin Ladutenko <kostyfisik@gmail.com>
  6. #
  7. # This file is part of scattnlay
  8. #
  9. # This program is free software: you can redistribute it and/or modify
  10. # it under the terms of the GNU General Public License as published by
  11. # the Free Software Foundation, either version 3 of the License, or
  12. # (at your option) any later version.
  13. #
  14. # This program is distributed in the hope that it will be useful,
  15. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. # GNU General Public License for more details.
  18. #
  19. # The only additional remark is that we expect that all publications
  20. # describing work using this software, or all commercial products
  21. # using it, cite at least one of the following references:
  22. # [1] O. Peña and U. Pal, "Scattering of electromagnetic radiation by
  23. # a multilayered sphere," Computer Physics Communications,
  24. # vol. 180, Nov. 2009, pp. 2348-2354.
  25. # [2] K. Ladutenko, U. Pal, A. Rivera, and O. Peña-Rodríguez, "Mie
  26. # calculation of electromagnetic near-field for a multilayered
  27. # sphere," Computer Physics Communications, vol. 214, May 2017,
  28. # pp. 225-230.
  29. #
  30. # You should have received a copy of the GNU General Public License
  31. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  32. __version__ = '2.3'
  33. __title__ = 'Calculation of the scattering of EM radiation by a multilayered sphere'
  34. __mod__ = 'python-scattnlay'
  35. __author__ = 'Ovidio Peña Rodríguez'
  36. __email__ = 'ovidio@bytesfall.com'
  37. __url__ = 'https://github.com/ovidiopr/scattnlay'
  38. __download_url__ = 'https://github.com/ovidiopr/scattnlay/archive/v2.2.0.tar.gz'
  39. from setuptools import setup
  40. from setuptools.extension import Extension
  41. import numpy as np
  42. import pybind11 as pb
  43. setup(name=__mod__,
  44. version=__version__,
  45. description=__title__,
  46. long_description="""The Python version of scattnlay, a computer implementation of the algorithm for the \
  47. calculation of electromagnetic radiation scattering by a multilayered sphere developed by Yang. It has been \
  48. shown that the program is effective, resulting in very accurate values of scattering efficiencies for a wide \
  49. range of size parameters, which is a considerable improvement over previous implementations of similar algorithms. \
  50. For details see: O. Pena, U. Pal, Comput. Phys. Commun. 180 (2009) 2348-2354.""",
  51. author=__author__,
  52. author_email=__email__,
  53. maintainer=__author__,
  54. maintainer_email=__email__,
  55. keywords=['Mie scattering', 'Multilayered sphere', 'Efficiency factors', 'Cross-sections'],
  56. url=__url__,
  57. download_url=__download_url__,
  58. license='GPL',
  59. platforms='any',
  60. packages=['scattnlay'], # , 'scattnlay_dp', 'scattnlay_mp'],
  61. ext_modules=[Extension("scattnlay_dp",
  62. ["src/nmie.cc", "src/nmie-pybind11.cc", "src/pb11_wrapper.cc"],
  63. language="c++",
  64. include_dirs=[np.get_include(), pb.get_include()],
  65. extra_compile_args=['-std=c++11']),
  66. Extension("scattnlay_mp",
  67. ["src/nmie.cc", "src/nmie-pybind11.cc", "src/pb11_wrapper.cc"],
  68. language="c++",
  69. include_dirs=[np.get_include(), pb.get_include()],
  70. extra_compile_args=['-std=c++11', '-DMULTI_PRECISION=100'])]
  71. )