Source code for paws.core.operations.PROCESSING.INTEGRATION.ApplyIntegrator2d

import numpy as np
from collections import OrderedDict

import pyFAI

from ... import Operation as opmod 
from ...Operation import Operation

inputs = OrderedDict(
    image_data=None,
    integrator=None,
    npt_rad=1000,
    npt_azim=1000,
    polz_factor=0.,
    unit='q_A^-1',
    integrate_args={})
outputs = OrderedDict(
    q=None,
    chi=None,
    I_at_q_chi=None)

[docs]class ApplyIntegrator2d(Operation): """Integrate an image using an existing PyFAI.AzimuthalIntegrator. Input image data (ndarray), PyFAI.AzimuthalIntegrator, and a dict of other keyword parameters to be passed to PyFAI.AzimuthalIntegrator.integrate1d(). Refer to the PyFAI documentation at http://pyfai.readthedocs.io/en/latest/ for supported keyword arguments as well as parameter definitions and defaults. """ def __init__(self): super(ApplyIntegrator2d,self).__init__(inputs,outputs) self.input_doc['image_data'] = '2d array representing intensity for each pixel' self.input_doc['integrator'] = 'A PyFAI.AzimuthalIntegrator object' self.input_doc['npt_rad'] = 'number of q-points to integrate' self.input_doc['npt_azim'] = 'number of chi-points to integrate' self.input_doc['polz_factor'] = 'polarization factor, '\ 'in case polarization correction is needed' self.input_doc['unit'] = 'choice of unit. See PyFAI documentation for options.' self.input_doc['integrate_args'] = 'dict of keyword args '\ 'to pass to pyFAI.AzimuthalIntegrator.integrate2d(). '\ 'Where relevant, the values in this dict will be replaced '\ 'by inputs to the operation, e.g. for npt_rad and npt_azim.' self.output_doc['q'] = 'Scattering vector magnitude q array in 1/Angstrom.' self.output_doc['chi'] = 'Azimuthal angle array.' self.output_doc['I_at_q_chi'] = '2d array of integrated intensity at q,chi.' self.input_datatype['unit'] = 'str' self.input_datatype['integrate_args'] = 'dict' self.input_datatype['npt_rad'] = 'int' self.input_datatype['npt_azim'] = 'int' self.input_datatype['polz_factor'] = 'float'
[docs] def run(self): img = self.inputs['image_data'] intgtr = self.inputs['integrator'] npt_rad = self.inputs['npt_rad'] npt_azim = self.inputs['npt_azim'] kw = self.inputs['integrate_args'] if self.inputs['polz_factor']: kw['polarization_factor'] = self.inputs['polz_factor'] if self.inputs['unit']: kw['unit'] = self.inputs['unit'] I_at_q_chi,q,chi = intgtr.integrate2d(img,npt_rad,npt_azim,**kw) self.outputs['q'] = q self.outputs['chi'] = chi self.outputs['I_at_q_chi'] = I_at_q_chi