Skip to content

Commit

Permalink
Add resolutions' computations for the case convolutions_out=False in FMM
Browse files Browse the repository at this point in the history
  • Loading branch information
TomLaclavere authored Sep 11, 2024
1 parent 42a4002 commit 47bc64e
Showing 1 changed file with 66 additions and 17 deletions.
83 changes: 66 additions & 17 deletions src/FMM/pipeline.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
import numpy as np
import qubic
import yaml
from scipy.optimize import minimize
from pysimulators.interfaces.healpy import HealpixConvolutionGaussianOperator

### Local packages
Expand Down Expand Up @@ -155,7 +156,7 @@ def __init__(self, comm, file, params):

### Initial maps
self.m_nu_in = self.get_input_map()

### Define reconstructed and TOD operator
self.get_H()

Expand Down Expand Up @@ -391,6 +392,25 @@ def get_dict(self, key="in"):

return dict_qubic

def _get_scalar_acquisition_operator(self):
"""
Function that will compute "scalar acquisition operatord" by applying the acquisition operators to a vector full of ones.
These scalar operators will be used to compute the resolutions in the case where we do not add convolutions during reconstruction.
"""
### Import the acquisition operators
acquisition_operators = self.joint.qubic.H

### Create the vector full of ones which will be used to compute the scalar operators
vector_ones = np.ones(acquisition_operators[0].shapein)

### Apply each sub_operator on the vector
scalar_acquisition_operators = np.empty(len(self.joint.qubic.allnus))
for freq in range(len(self.joint.qubic.allnus)):
scalar_acquisition_operators[freq] = np.mean(
acquisition_operators[freq](vector_ones)
)
return scalar_acquisition_operators

def get_convolution(self):
"""QUBIC resolutions.
Expand All @@ -408,26 +428,25 @@ def get_convolution(self):
"""

### Define FWHMs

fwhm_in = None
fwhm_out = None

### FWHMs during map-making
if self.params["QUBIC"]["convolution_in"]:
fwhm_in = self.joint.qubic.allfwhm.copy()
fwhm_in = self.joint_tod.qubic.allfwhm.copy()
if self.params["QUBIC"]["convolution_out"]:
fwhm_out = np.array([])
for irec in range(self.params["QUBIC"]["nrec"]):
fwhm_out = np.append(
fwhm_out,
np.sqrt(
self.joint.qubic.allfwhm[
irec * self.fsub : (irec + 1) * self.fsub
irec * self.fsub_out : (irec + 1) * self.fsub_out
]
** 2
- np.min(
self.joint.qubic.allfwhm[
irec * self.fsub : (irec + 1) * self.fsub
irec * self.fsub_out : (irec + 1) * self.fsub_out
]
)
** 2
Expand All @@ -445,7 +464,7 @@ def get_convolution(self):
fwhm_rec,
np.min(
self.joint.qubic.allfwhm[
irec * self.fsub : (irec + 1) * self.fsub
irec * self.fsub_out : (irec + 1) * self.fsub_out
]
),
)
Expand All @@ -455,20 +474,50 @@ def get_convolution(self):
and self.params["QUBIC"]["convolution_out"] is False
):
fwhm_rec = np.array([])
scalar_acquisition_operators = self._get_scalar_acquisition_operator()

if self.params["Foregrounds"]["Dust"]:
f_dust = c.ModifiedBlackBody(nu0=353, beta_d=1.54)
weight_factor = f_dust.eval(self.joint.qubic.allnus)
fun = lambda nu: np.abs(fraction - f_dust.eval(nu))
else:
f_cmb = c.CMB()
weight_factor = f_cmb.eval(self.joint.qubic.allnus)
fun = lambda nu: np.abs(fraction - f_cmb.eval(nu))

### Compute expected resolutions and frequencies when not adding convolutions during reconstruction
### See FMM annexe B to understand the computations

for irec in range(self.params["QUBIC"]["nrec"]):
numerator_fwhm, denominator_fwhm = 0, 0
numerator_nus, denominator_nus = 0, 0
for jsub in range(irec * self.fsub_out, (irec + 1) * self.fsub_out):
# Compute the expected reconstructed resolution for sub-acquisition
numerator_fwhm += (
scalar_acquisition_operators[jsub]
* weight_factor[jsub]
* self.fwhm_in[jsub]
)
denominator_fwhm += (
scalar_acquisition_operators[jsub] * weight_factor[jsub]
)

# Compute the expected reconstructed frequencies for sub_acquisition
numerator_nus += (
scalar_acquisition_operators[jsub] * weight_factor[jsub]
)
denominator_nus += scalar_acquisition_operators[jsub]

# Compute the expected resolution
fwhm_rec = np.append(
fwhm_rec,
np.mean(
self.joint.qubic.allfwhm[
irec * self.fsub : (irec + 1) * self.fsub
]
),
fwhm_rec, np.sum(numerator_fwhm) / np.sum(denominator_fwhm)
)

else:
fwhm_rec = np.array([])
for irec in range(self.params["QUBIC"]["nrec"]):
fwhm_rec = np.append(fwhm_rec, 0)
# Compute the expected frequency
fraction = np.sum(numerator_nus) / np.sum(denominator_nus)
x0 = self.nus_Q[irec]
corrected_nu = minimize(fun, x0)
self.nus_Q[irec] = corrected_nu["x"]

if self.rank == 0:
print(f"FWHM for TOD generation : {fwhm_in}")
Expand All @@ -492,7 +541,7 @@ def get_input_map(self):
m_nu_in = np.zeros(
(self.params["QUBIC"]["nrec"], 12 * self.params["SKY"]["nside"] ** 2, 3)
)

for i in range(self.params["QUBIC"]["nrec"]):
m_nu_in[i] = np.mean(
self.external_timeline.m_nu[i * self.fsub : (i + 1) * self.fsub], axis=0
Expand Down

0 comments on commit 47bc64e

Please sign in to comment.