Note
Go to the end to download the full example code.
Sphere: Qsca vs diameter#

+-----------------------+-----------------------+
| Sellmeier Materials | Tabulated Materials |
+=======================+=======================+
| BAK1 | copper |
+-----------------------+-----------------------+
| BK7 | calcium |
+-----------------------+-----------------------+
| lithium_niobate | aluminium |
+-----------------------+-----------------------+
| soda_lime_glass | silicon |
+-----------------------+-----------------------+
| fused_silica | polyetylene |
+-----------------------+-----------------------+
| crown | sodium |
+-----------------------+-----------------------+
| argon | gold |
+-----------------------+-----------------------+
| ZBLAN | iron |
+-----------------------+-----------------------+
| germanium | zinc |
+-----------------------+-----------------------+
| SF5 | silver |
+-----------------------+-----------------------+
| air | nickel |
+-----------------------+-----------------------+
| acetone | |
+-----------------------+-----------------------+
| flint | |
+-----------------------+-----------------------+
| BAF10 | |
+-----------------------+-----------------------+
| water | |
+-----------------------+-----------------------+
| polystyren | |
+-----------------------+-----------------------+
<Figure size 1000x600 with 1 Axes>
import numpy as np
from PyMieSim.units import ureg
from PyMieSim.experiment.scatterer_set import SphereSet
from PyMieSim.experiment.source_set import GaussianSet
from PyMieSim.experiment.polarization_set import PolarizationSet
from PyMieSim.experiment.material_set import MaterialSet, MediumSet
from PyMieSim.experiment.setup import Setup
from PyMieSim.material import print_available, SellmeierMaterial
print_available()
polarization_set = PolarizationSet(
angles=[0.0] * ureg.degree,
)
source = GaussianSet(
wavelength=[405] * ureg.nanometer,
polarization=polarization_set,
optical_power=[1e-3] * ureg.watt,
numerical_aperture=[0.2],
)
polystyrene = SellmeierMaterial("BK7")
scatterer = SphereSet(
diameter=np.linspace(10, 1000, 150) * ureg.nanometer,
material=MaterialSet([polystyrene]),
medium=MediumSet([1.33, 1.34, 1.5]),
)
experiment = Setup(scatterer_set=scatterer, source_set=source)
dataframe = experiment.get("Qsca", scale_unit=True)
dataframe.plot(x="scatterer:diameter", show=True)
Total running time of the script: (0 minutes 0.180 seconds)