.. |pypi-badge| image:: https://img.shields.io/pypi/v/miepython?color=68CA66
:target: https://pypi.org/project/miepython/
:alt: pypi
.. |github-badge| image:: https://img.shields.io/github/v/tag/scottprahl/miepython?label=github&color=68CA66
:target: https://github.com/scottprahl/miepython
:alt: github
.. |conda-badge| image:: https://img.shields.io/conda/vn/conda-forge/miepython?label=conda&color=68CA66
:target: https://github.com/conda-forge/miepython-feedstock
:alt: conda
.. |doi-badge| image:: https://zenodo.org/badge/99259684.svg
:target: https://zenodo.org/badge/latestdoi/99259684
:alt: doi
.. |license-badge| image:: https://img.shields.io/github/license/scottprahl/miepython?color=68CA66
:target: https://github.com/scottprahl/miepython/blob/main/LICENSE.txt
:alt: License
.. |testing-badge| image:: https://github.com/scottprahl/miepython/actions/workflows/test.yml/badge.svg
:target: https://github.com/scottprahl/miepython/actions/workflows/test.yml
:alt: Testing
.. |docs-badge| image:: https://readthedocs.org/projects/miepython/badge?color=68CA66
:target: https://miepython.readthedocs.io
:alt: Docs
.. |downloads-badge| image:: https://img.shields.io/pypi/dm/miepython?color=68CA66
:target: https://pypi.org/project/miepython/
:alt: Downloads
miepython
=========
by Scott Prahl
|pypi-badge| |github-badge| |conda-badge| |doi-badge|
|license-badge| |testing-badge| |docs-badge| |downloads-badge|
``miepython`` is a pure Python module to calculate light scattering for
non-absorbing, partially-absorbing, or perfectly-conducting spheres. Mie
theory is used, following `the procedure described by Wiscombe
<http://opensky.ucar.edu/islandora/object/technotes:232>`_. This code has
been validated against his work.
.. image:: https://raw.githubusercontent.com/scottprahl/miepython/main/docs/mie-diagram2.svg
:width: 700px
:alt: scattering diagram
This code provides functions for calculating the extinction efficiency,
scattering efficiency, backscattering, and scattering asymmetry.
Moreover, a set of angles can be given to calculate the scattering at various
angles for a sphere.
When comparing different Mie scattering codes, make sure that you're
aware of the conventions used by each code. ``miepython`` makes the
following assumptions
* the imaginary part of the complex index of refraction for absorbing spheres is *negative*.
* the scattering phase function is normalized so it equals the *single scattering albedo* when integrated over 4π steradians by default. This normalization can be changed (see the normalization notebook for details).
This code provides functions for calculating the extinction efficiency, scattering efficiency, backscattering, and scattering asymmetry. Moreover, a set of angles can be given to calculate the scattering for a sphere at each of those
angles.
Full documentation at <https://miepython.readthedocs.io>
Pay Attention!
--------------
When comparing different Mie scattering codes, make sure that you're aware of the conventions used by each code. ``miepython`` makes the following assumptions
#. the imaginary part of the complex index of refraction for absorbing spheres is *negative*.
#. the scattering phase function is normalized so it equals the *single scattering albedo* when integrated over 4π steradians. As of version 2.3, this can be changed.
Installation
---------------
Use ``pip``::
pip install miepython
or ``conda``::
conda install -c conda-forge miepython
Or `run this code in the cloud using Google Collaboratory <https://colab.research.google.com/github/scottprahl/miepython/blob/main>`_ by selecting the Jupyter notebook that interests you.
Usage for those that don't do Jupyter
--------------------------------------
Basic Mie Calculations
^^^^^^^^^^^^^^^^^^^^^^^
from miepython import mie
complex_refractive_index = 1.5-1j # convention is negative imaginary part
size_parameter = 1 # 2𝜋(radius)/λ
qext, qsca, qback, g = mie(complex_refractive_index, size_parameter)
print("The extinction efficiency is %.3f" % qext)
print("The scattering efficiency is %.3f" % qsca)
print("The backscatter efficiency is %.3f" % qback)
print("The scattering anisotropy is %.3f" % g)
should produce::
The extinction efficiency is 2.336
The scattering efficiency is 0.663
The backscatter efficiency is 0.573
The scattering anisotropy is 0.192
Simple Dielectric
^^^^^^^^^^^^^^^^^^
The script `01_dielectric.py <https://raw.githubusercontent.com/scottprahl/miepython/main/miepython/examples/01_dielectric.py>`_
.. image:: https://raw.githubusercontent.com/scottprahl/miepython/main/docs/01_plot.svg
Glass Spheres
^^^^^^^^^^^^^^
The script `02_glass.py <https://raw.githubusercontent.com/scottprahl/miepython/main/miepython/examples/02_glass.py>`_
.. image:: https://raw.githubusercontent.com/scottprahl/miepython/main/docs/02_plot.svg
Water Droplets
^^^^^^^^^^^^^^^
The script `03_droplets.py <https://raw.githubusercontent.com/scottprahl/miepython/main/miepython/examples/03_droplets.py>`_
.. image:: https://raw.githubusercontent.com/scottprahl/miepython/main/docs/03_plot.svg
Small Gold Spheres
^^^^^^^^^^^^^^^^^^^
The script `04_gold.py <https://raw.githubusercontent.com/scottprahl/miepython/main/miepython/examples/04_gold.py>`_
.. image:: https://raw.githubusercontent.com/scottprahl/miepython/main/docs/04_plot.svg
Usage for those that use Jupyter
---------------------------------
All the Jupyter notebooks are available in the docs directory and they are all viewable at <https://miepython.readthedocs.io>
Script Examples for those that don't do Jupyter
-----------------------------------------------
All the Jupyter notebooks are in the docs directory and shown at <https://miepython.readthedocs.io>
You can also use a Jupyter notebook immediately (well, you do have wait a bit for everything to get uploaded) by clicking the Google Colaboratory button below
.. image:: https://colab.research.google.com/assets/colab-badge.svg
:target: https://colab.research.google.com/github/scottprahl/miepython/blob/main
:alt: Colab
License
-------
``miepython`` is licensed under the terms of the MIT license.
Raw data
{
"_id": null,
"home_page": "https://github.com/scottprahl/miepython",
"name": "miepython",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.7",
"maintainer_email": null,
"keywords": "mie, scattering, rainbow, droplet, backscatter, sphere, nanoparticle, sphere, cloud, phase function, efficiency, rayleigh, backscattering",
"author": "Scott Prahl",
"author_email": "scott.prahl@oit.edu",
"download_url": "https://files.pythonhosted.org/packages/e2/12/4f6e3f425038ca57ff026812661b9f0c5eb9bf38a39cd1af5e3347fdfb7e/miepython-2.5.5.tar.gz",
"platform": null,
"description": ".. |pypi-badge| image:: https://img.shields.io/pypi/v/miepython?color=68CA66\n :target: https://pypi.org/project/miepython/\n :alt: pypi\n\n.. |github-badge| image:: https://img.shields.io/github/v/tag/scottprahl/miepython?label=github&color=68CA66\n :target: https://github.com/scottprahl/miepython\n :alt: github\n\n.. |conda-badge| image:: https://img.shields.io/conda/vn/conda-forge/miepython?label=conda&color=68CA66\n :target: https://github.com/conda-forge/miepython-feedstock\n :alt: conda\n\n.. |doi-badge| image:: https://zenodo.org/badge/99259684.svg\n :target: https://zenodo.org/badge/latestdoi/99259684\n :alt: doi\n\n.. |license-badge| image:: https://img.shields.io/github/license/scottprahl/miepython?color=68CA66\n :target: https://github.com/scottprahl/miepython/blob/main/LICENSE.txt\n :alt: License\n\n.. |testing-badge| image:: https://github.com/scottprahl/miepython/actions/workflows/test.yml/badge.svg\n :target: https://github.com/scottprahl/miepython/actions/workflows/test.yml\n :alt: Testing\n\n.. |docs-badge| image:: https://readthedocs.org/projects/miepython/badge?color=68CA66\n :target: https://miepython.readthedocs.io\n :alt: Docs\n\n.. |downloads-badge| image:: https://img.shields.io/pypi/dm/miepython?color=68CA66\n :target: https://pypi.org/project/miepython/\n :alt: Downloads\n\nmiepython\n=========\n\nby Scott Prahl\n\n|pypi-badge| |github-badge| |conda-badge| |doi-badge|\n\n|license-badge| |testing-badge| |docs-badge| |downloads-badge|\n\n\n``miepython`` is a pure Python module to calculate light scattering for\nnon-absorbing, partially-absorbing, or perfectly-conducting spheres. Mie\ntheory is used, following `the procedure described by Wiscombe\n<http://opensky.ucar.edu/islandora/object/technotes:232>`_. This code has\nbeen validated against his work. \n\n.. image:: https://raw.githubusercontent.com/scottprahl/miepython/main/docs/mie-diagram2.svg\n :width: 700px\n :alt: scattering diagram\n\nThis code provides functions for calculating the extinction efficiency,\nscattering efficiency, backscattering, and scattering asymmetry.\nMoreover, a set of angles can be given to calculate the scattering at various\nangles for a sphere.\n\nWhen comparing different Mie scattering codes, make sure that you're\naware of the conventions used by each code. ``miepython`` makes the\nfollowing assumptions\n\n* the imaginary part of the complex index of refraction for absorbing spheres is *negative*.\n\n* the scattering phase function is normalized so it equals the *single scattering albedo* when integrated over 4\u03c0 steradians by default. This normalization can be changed (see the normalization notebook for details).\n\nThis code provides functions for calculating the extinction efficiency, scattering efficiency, backscattering, and scattering asymmetry. Moreover, a set of angles can be given to calculate the scattering for a sphere at each of those\nangles.\n\nFull documentation at <https://miepython.readthedocs.io>\n\nPay Attention!\n--------------\n\nWhen comparing different Mie scattering codes, make sure that you're aware of the conventions used by each code. ``miepython`` makes the following assumptions\n\n#. the imaginary part of the complex index of refraction for absorbing spheres is *negative*. \n\n#. the scattering phase function is normalized so it equals the *single scattering albedo* when integrated over 4\u03c0 steradians. As of version 2.3, this can be changed.\n\n\nInstallation\n---------------\n\nUse ``pip``::\n\n pip install miepython\n\nor ``conda``::\n\n conda install -c conda-forge miepython\n\nOr `run this code in the cloud using Google Collaboratory <https://colab.research.google.com/github/scottprahl/miepython/blob/main>`_ by selecting the Jupyter notebook that interests you.\n\nUsage for those that don't do Jupyter\n--------------------------------------\n\nBasic Mie Calculations\n^^^^^^^^^^^^^^^^^^^^^^^\n\n from miepython import mie\n \n complex_refractive_index = 1.5-1j # convention is negative imaginary part\n size_parameter = 1 # 2\ud835\udf0b(radius)/\u03bb\n qext, qsca, qback, g = mie(complex_refractive_index, size_parameter)\n\n print(\"The extinction efficiency is %.3f\" % qext)\n print(\"The scattering efficiency is %.3f\" % qsca)\n print(\"The backscatter efficiency is %.3f\" % qback)\n print(\"The scattering anisotropy is %.3f\" % g)\n\nshould produce::\n\n The extinction efficiency is 2.336\n The scattering efficiency is 0.663\n The backscatter efficiency is 0.573\n The scattering anisotropy is 0.192\n\n\nSimple Dielectric\n^^^^^^^^^^^^^^^^^^\n\nThe script `01_dielectric.py <https://raw.githubusercontent.com/scottprahl/miepython/main/miepython/examples/01_dielectric.py>`_\n\n.. image:: https://raw.githubusercontent.com/scottprahl/miepython/main/docs/01_plot.svg\n\nGlass Spheres\n^^^^^^^^^^^^^^\n\nThe script `02_glass.py <https://raw.githubusercontent.com/scottprahl/miepython/main/miepython/examples/02_glass.py>`_\n\n.. image:: https://raw.githubusercontent.com/scottprahl/miepython/main/docs/02_plot.svg\n\nWater Droplets\n^^^^^^^^^^^^^^^\n\nThe script `03_droplets.py <https://raw.githubusercontent.com/scottprahl/miepython/main/miepython/examples/03_droplets.py>`_\n\n.. image:: https://raw.githubusercontent.com/scottprahl/miepython/main/docs/03_plot.svg\n\nSmall Gold Spheres\n^^^^^^^^^^^^^^^^^^^\n\nThe script `04_gold.py <https://raw.githubusercontent.com/scottprahl/miepython/main/miepython/examples/04_gold.py>`_\n\n.. image:: https://raw.githubusercontent.com/scottprahl/miepython/main/docs/04_plot.svg\n\n\nUsage for those that use Jupyter\n---------------------------------\n\nAll the Jupyter notebooks are available in the docs directory and they are all viewable at <https://miepython.readthedocs.io>\n\n\nScript Examples for those that don't do Jupyter\n-----------------------------------------------\n\nAll the Jupyter notebooks are in the docs directory and shown at <https://miepython.readthedocs.io>\n\nYou can also use a Jupyter notebook immediately (well, you do have wait a bit for everything to get uploaded) by clicking the Google Colaboratory button below\n\n.. image:: https://colab.research.google.com/assets/colab-badge.svg\n :target: https://colab.research.google.com/github/scottprahl/miepython/blob/main\n :alt: Colab\n\n\nLicense\n-------\n\n``miepython`` is licensed under the terms of the MIT license.\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "Mie scattering of a plane wave by a sphere",
"version": "2.5.5",
"project_urls": {
"Homepage": "https://github.com/scottprahl/miepython"
},
"split_keywords": [
"mie",
" scattering",
" rainbow",
" droplet",
" backscatter",
" sphere",
" nanoparticle",
" sphere",
" cloud",
" phase function",
" efficiency",
" rayleigh",
" backscattering"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "21bfc2687d3bbbf20a8dad99593e16ce101d0b3bbe8181dc57e10f7b6c37ff61",
"md5": "f961925f694b8f90c45a94fc1f153496",
"sha256": "d0caa2512439d0b1dae89a764bc56fb4a98ec50580b7aa8675e32bdcdaae98ab"
},
"downloads": -1,
"filename": "miepython-2.5.5-py3-none-any.whl",
"has_sig": false,
"md5_digest": "f961925f694b8f90c45a94fc1f153496",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.7",
"size": 30915,
"upload_time": "2024-12-02T03:09:36",
"upload_time_iso_8601": "2024-12-02T03:09:36.495458Z",
"url": "https://files.pythonhosted.org/packages/21/bf/c2687d3bbbf20a8dad99593e16ce101d0b3bbe8181dc57e10f7b6c37ff61/miepython-2.5.5-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "e2124f6e3f425038ca57ff026812661b9f0c5eb9bf38a39cd1af5e3347fdfb7e",
"md5": "ebe137f929c265eb1e5a97a08dca5c31",
"sha256": "02afaddc8728c25e7583ca9126d697882a744a5333d194fd50de5a3d2f5b3206"
},
"downloads": -1,
"filename": "miepython-2.5.5.tar.gz",
"has_sig": false,
"md5_digest": "ebe137f929c265eb1e5a97a08dca5c31",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.7",
"size": 37894,
"upload_time": "2024-12-02T03:09:37",
"upload_time_iso_8601": "2024-12-02T03:09:37.788187Z",
"url": "https://files.pythonhosted.org/packages/e2/12/4f6e3f425038ca57ff026812661b9f0c5eb9bf38a39cd1af5e3347fdfb7e/miepython-2.5.5.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-02 03:09:37",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "scottprahl",
"github_project": "miepython",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"requirements": [],
"lcname": "miepython"
}