setup.py 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  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/v' + \
  39. __version__+'.0.tar.gz'
  40. from setuptools import setup
  41. from setuptools.extension import Extension
  42. import numpy as np
  43. import pybind11 as pb
  44. ext_dp = Extension("scattnlay_dp",
  45. ["src/pb11-wrapper.cc"],
  46. language="c++",
  47. include_dirs=[np.get_include(), pb.get_include()],
  48. # extra_compile_args=['-std=c++11']
  49. )
  50. # extra_compile_args=['-std=c++11', '-O3',
  51. # '-mavx2', '-mfma',
  52. # '-finline-limit=1000000', '-ffp-contract=fast']),
  53. ext_mp = Extension("scattnlay_mp",
  54. ["src/pb11-wrapper.cc"],
  55. language="c++",
  56. include_dirs=[np.get_include(), pb.get_include()],
  57. extra_compile_args=[ # '-std=c++11',
  58. '-DMULTI_PRECISION=100'])
  59. # extra_compile_args=['-std=c++11', '-O3',
  60. # '-mavx2', '-mfma',
  61. # '-finline-limit=1000000', '-ffp-contract=fast',
  62. # '-DMULTI_PRECISION=100']),
  63. def run_setup(extensions):
  64. setup(name=__mod__,
  65. version=__version__,
  66. description=__title__,
  67. long_description="""The Python version of scattnlay, a computer implementation of the algorithm for the \
  68. calculation of electromagnetic radiation scattering by a multilayered sphere developed by Yang. It has been \
  69. shown that the program is effective, resulting in very accurate values of scattering efficiencies for a wide \
  70. range of size parameters, which is a considerable improvement over previous implementations of similar algorithms. \
  71. For details see: O. Pena, U. Pal, Comput. Phys. Commun. 180 (2009) 2348-2354.""",
  72. author=__author__,
  73. author_email=__email__,
  74. maintainer=__author__,
  75. maintainer_email=__email__,
  76. keywords=['Mie scattering', 'Multilayered sphere',
  77. 'Efficiency factors', 'Cross-sections'],
  78. url=__url__,
  79. download_url=__download_url__,
  80. license='GPL',
  81. platforms='any',
  82. packages=['scattnlay'], # , 'scattnlay_dp', 'scattnlay_mp'],
  83. test_suite="tests",
  84. ext_modules=extensions,
  85. install_requires=['numpy']
  86. )
  87. try:
  88. run_setup([ext_dp, ext_mp])
  89. except:
  90. print('Failed to build all extensions... Building only in double precision...')
  91. run_setup([ext_dp])