Note
Go to the end to download the full example code.
Sphere: coherent coupling vs sampling#
Importing the package dependencies: numpy, PyMieSim
import numpy
from TypedUnit import ureg
from PyMieSim.experiment.detector import CoherentMode
from PyMieSim.experiment.scatterer import Sphere
from PyMieSim.experiment.source import Gaussian
from PyMieSim.experiment import Setup
from PyOptik import Material
source = Gaussian(
wavelength=400 * ureg.nanometer,
polarization=90 * ureg.degree,
optical_power=1e-3 * ureg.watt,
NA=0.2 * ureg.AU,
)
scatterer = Sphere(
diameter=5000 * ureg.nanometer,
property=Material.BK7,
medium_property=1 * ureg.RIU,
source=source,
)
detector = CoherentMode(
mode_number=["LP01"],
rotation=[0] * ureg.degree,
NA=[0.1] * ureg.AU,
phi_offset=numpy.linspace(-20, 20, 200) * ureg.degree,
gamma_offset=[0] * ureg.degree,
sampling=[10, 20, 40, 80, 160, 500] * ureg.AU,
polarization_filter=[0] * ureg.degree,
)
experiment = Setup(scatterer=scatterer, source=source, detector=detector)
dataframe = experiment.get("coupling")
dataframe.plot(x="detector:phi_offset")

<Figure size 800x500 with 1 Axes>
Total running time of the script: (0 minutes 0.554 seconds)