Return the spectrum of the spherical harmonic coefficients as a function of spherical harmonic degree.
Usage
array = spectrum(clm, [normalization, degrees, lmax, convention, unit, base])
Returns
array : ndarray, shape (len(degrees)) 1-D ndarray of the spectrum.
Parameters
clm : ndarray, shape (2, lmax + 1, lmax + 1) ndarray containing the spherical harmonic coefficients.
normalization : str, optional, default = ‘4pi’ ‘4pi’, ‘ortho’, ‘schmidt’, or ‘unnorm’ for geodesy 4pi normalized, orthonormalized, Schmidt semi-normalized, or unnormalized coefficients, respectively.
lmax : int, optional, default = len(clm[0,:,0]) - 1. Maximum spherical harmonic degree to output.
degrees : ndarray, optional, default = numpy.arange(lmax+1) Array containing the spherical harmonic degrees where the spectrum is computed.
convention : str, optional, default = ‘power’ The type of spectrum to return: ‘power’ for power spectrum, ‘energy’ for energy spectrum, and ‘l2norm’ for the l2-norm spectrum.
unit : str, optional, default = ‘per_l’ If ‘per_l’, return the total contribution to the spectrum for each spherical harmonic degree l. If ‘per_lm’, return the average contribution to the spectrum for each coefficient at spherical harmonic degree l. If ‘per_dlogl’, return the spectrum per log interval dlog_a(l).
base : float, optional, default = 10. The logarithm base when calculating the ‘per_dlogl’ spectrum.
Notes
This routine returns either the power spectrum, energy spectrum, or l2-norm spectrum of a function that is expressed in spherical harmonics. Total power is defined as the integral of the function squared over all space, divided by the area the function spans. If the mean of the function is zero, this is equivalent to the variance of the function. The total energy is the integral of the function squared over all space and is 4 pi times the total power. For normalized coefficients (‘4pi’, ‘ortho’, or ‘schmidt’), the l2-norm is the sum of the magnitude of the coefficients squared.
The output spectrum can be expresed using one of three units. ‘per_l’ returns the contribution to the total power, energy or l2-norm from all angular orders at degree l. ‘per_lm’ returns the average contribution to the total power, energy or l2-norm from a single coefficient at degree l, and is equal to the ‘per_l’ spectrum divided by (2l+1). ‘per_dlogl’ returns the contribution to the total power, energy or l2-norm from all angular orders over an infinitessimal logarithmic degree band. The contrubution in the band dlog_a(l) is spectrum(l, ‘per_dlogl’)*dlog_a(l), where a is the base, and where spectrum(l, ‘per_dlogl) is equal to spectrum(l, ‘per_l’)*l*log(a).
Edit me