Gaussian beam#
The BeamGauss class models a Gaussian beam and provides methods to compute its properties and represent it in terms of spherical harmonics. The key mathematical concepts and formulas used in this class are described below.
Real space representation#
BeamGauss.gaussian_beam(): Computes the value of the Gaussian beam at a given angle \(\theta\).
A Gaussian beam is characterized by its Full Width at Half Maximum (FWHM) and amplitude. The beam profile as a function of angle \(\theta\) is given by:
where:
- \(A\) is the amplitude of the beam. 
- \(\sigma\) is the standard deviation of the Gaussian, related to the FWHM by \(\sigma = \frac{\text{FWHM}}{\sqrt{8 \ln 2}}\). 
Spherical Harmonics Representation#
BeamGauss.get_alm(): Computes the spherical harmonics coefficients \(a_{\ell m}\) for the beam. The class also supports polarized beams, where the polarization angle \(\psi_{\text{pol}}\) and cross-polar leakage are taken into account. The spherical harmonics coefficients for the polarized components are adjusted accordingly.
Circular Beam#
For a circular Gaussian beam, the spherical harmonics coefficients \(a_{\ell m}\) are computed as follows:
If the beam is polarized, the coefficients for the polarized components are given by:
Elliptical Beam#
For an elliptical Gaussian beam, the coefficients are more complex and involve modified Bessel functions of the first kind \(I_v(x)\) and we must promise that \(m\) is even:
where:
- \(\sigma_x\) is the standard deviation along the major axis of the ellipse. 
- \(e\) is the ellipticity of the beam. When \(e=1\), the beam is circular. 
For the polarized components, the coefficients are adjusted based on the polarization angle \(\psi_{\text{pol}}\) and the inclination angle \(\psi_{\text{ell}}\):
Cross-Polar Leakage#
The multipoles are adjusted for cross-polar leakage, \(\epsilon\) by scaling the coefficients:
Normalization#
Finally, the coefficients are normalized:
Get Beam Profile Map#
BeamGauss.get_profile(): Provides the beam map profile at a given nside.
Example Usage#
from grasp2alm import BeamGauss
# Initialize a Gaussian beam with FWHM of 1 degree and amplitude of 1
beam = BeamGauss(fwhm_deg=4.0, amplitude=1.0)
# Compute the value of the beam at 0.5 degrees
theta = np.linspace(0, np.pi/2, 1000)
value = beam.gaussian_beam(theta)
# Compute the spherical harmonics coefficients up to lmax=10
alm = beam.get_alm(
    lmax=500,
    mmax=500,
    ellipticity=0.5,
    psi_ell_rad=np.pi / 6,
    psi_pol_rad=0.0,
    cross_polar_leakage=0.0,
)
# Get the beam profile at nside=64
beam_map = beam.get_profile(nside=128)
plt.figure(figsize=(15,5))
hp.gnomview(beam_map[0], rot=[0, 90], xsize=800, title='$I$ beam', sub=(1,3,1))
hp.gnomview(beam_map[1], rot=[0, 90], xsize=800, title='$Q$ beam', sub=(1,3,2))
hp.gnomview(beam_map[2], rot=[0, 90], xsize=800, title='$U$ beam', sub=(1,3,3))
