pyFAI.utils package¶
pyFAI.utils.bayes module¶
Bayesian evaluation of background for 1D powder diffraction pattern.
Code according to Sivia and David, J. Appl. Cryst. (2001). 34, 318-324
Version: 0.1 2012/03/28
Version: 0.2 2016/10/07: OOP implementation
- 
class 
pyFAI.utils.bayes.BayesianBackground¶ Bases:
objectThis class estimates the background of a powder diffraction pattern
http://journals.iucr.org/j/issues/2001/03/00/he0278/he0278.pdf
The log likelihood is described in correspond to eq7 of the paper:
\[z = y / sigma^2\]if z<0 a quadratic behaviour is expected
if z>>1 it is likely a bragg peak so the penalty should be small: log(z).
The spline is used to have a quadratic behaviour near 0 and the log one near the junction
The threshold is taken at 8 as erf is 1 above 6: The points 6, 7 and 8 are used in the spline to ensure a continuous junction with the logarithmic continuation.
- 
PREFACTOR= 1¶ 
- 
__init__()¶ Initialize self. See help(type(self)) for accurate signature.
- 
background_image(img, sigma=None, mask=None, npt=10, k=3)¶ 
- 
classmethod 
bayes_llk(z)¶ Calculate actually the log-likelihood from a set of weighted error
Re implementation of the following code even slightly faster:
(y<=0)*5*y**2 + (y>0)*(y<8)*pyFAI.utils.bayes.background.spline(y) + (y>=8)*(s1+log(abs(y)+1*(y<8)))
:param float[:] z: weighted error :return: log likelihood :rtype: float[:]
- 
classmethod 
bayes_llk_large(z)¶ used to calculate the log-likelihood of large positive values: logarithmic
- 
classmethod 
bayes_llk_negative(z)¶ used to calculate the log-likelihood of negative values: quadratic
- 
classmethod 
bayes_llk_small(z)¶ used to calculate the log-likelihood of small positive values: fitted with spline
- 
classmethod 
classinit()¶ 
- 
classmethod 
func2d_min(values, d0_sparse, d1_sparse, d0_pos, d1_pos, y_obs, w_obs, valid, k)¶ Function to optimize
- Parameters
 values – values of the background on spline knots
d0_sparse – positions along slowest axis of the spline knots
d1_pos – positions along fastest axis of the spline knots
d0_pos – positions along slowest axis (all coordinates)
d1_pos – positions along fastest axis (all coordinates)
y_obs – intensities actually measured
w_obs – weights of the experimental points
valid – coordinated of valid pixels
k – order of the spline, usually 3
- Returns
 sum of the log-likelihood to be minimized
- 
classmethod 
func_min(y0, x_obs, y_obs, w_obs, x0, k)¶ Function to optimize
- Parameters
 y0 – values of the background
x_obs – experimental values
y_obs – experimental values
w_obs – weights of the experimental points
x0 – position of evaluation of the spline
k – order of the spline, usually 3
- Returns
 sum of the log-likelihood to be minimized
- 
s1= 2.5435828321944816¶ 
- 
spline= <scipy.interpolate.fitpack2.InterpolatedUnivariateSpline object>¶ 
- 
classmethod 
test_bayes_llk()¶ Test plot of log(likelihood) Similar to as figure 3 of Sivia and David, J. Appl. Cryst. (2001). 34, 318-324
pyFAI.utils.decorators module¶
Bunch of useful decorators
- 
pyFAI.utils.decorators.deprecated(func=None, reason=None, replacement=None, since_version=None, only_once=False, skip_backtrace_count=1, deprecated_since=None)¶ Decorator that deprecates the use of a function
- Parameters
 reason (str) – Reason for deprecating this function (e.g. “feature no longer provided”,
replacement (str) – Name of replacement function (if the reason for deprecating was to rename the function)
since_version (str) – First pyFAI version for which the function was deprecated (e.g. “0.5.0”).
only_once (bool) – If true, the deprecation warning will only be generated one time. Default is true.
skip_backtrace_count (int) – Amount of last backtrace to ignore when logging the backtrace
deprecated_since (Union[int,str]) – If provided, log it as warning since a version of the library, else log it as debug
- 
pyFAI.utils.decorators.deprecated_warning(type_, name, reason=None, replacement=None, since_version=None, only_once=True, skip_backtrace_count=0, deprecated_since=None)¶ Function to log a deprecation warning
- Parameters
 type (str) – Nature of the object to be deprecated: “Module”, “Function”, “Class” …
name – Object name.
reason (str) – Reason for deprecating this function (e.g. “feature no longer provided”,
replacement (str) – Name of replacement function (if the reason for deprecating was to rename the function)
since_version (str) – First pyFAI version for which the function was deprecated (e.g. “0.5.0”).
only_once (bool) – If true, the deprecation warning will only be generated one time for each different call locations. Default is true.
skip_backtrace_count (int) – Amount of last backtrace to ignore when logging the backtrace
deprecated_since (Union[int,str]) – If provided, log the deprecation as warning since a version of the library, else log it as debug.
- 
pyFAI.utils.decorators.timeit(func)¶ 
pyFAI.utils.ellipse module¶
This modules contains a function to fit without refinement an ellipse on a set of points ….
- 
class 
pyFAI.utils.ellipse.Ellipse(center_1, center_2, angle, half_long_axis, half_short_axis)¶ Bases:
tuple- 
angle¶ Alias for field number 2
- 
center_1¶ Alias for field number 0
- 
center_2¶ Alias for field number 1
- 
half_long_axis¶ Alias for field number 3
- 
half_short_axis¶ Alias for field number 4
- 
 
- 
pyFAI.utils.ellipse.fit_ellipse(pty, ptx, _allow_delta=True)¶ Fit an ellipse
inspired from http://nicky.vanforeest.com/misc/fitEllipse/fitEllipse.html
- Parameters
 pty – point coordinates in the slow dimension (y)
ptx – point coordinates in the fast dimension (x)
- Raises
 ValueError – If the ellipse can’t be fitted
pyFAI.utils.header_utils module¶
This modules contains helper function relative to image header.
- 
exception 
pyFAI.utils.header_utils.MonitorNotFound¶ Bases:
ExceptionRaised when monitor information in not found or is not valid.
- 
pyFAI.utils.header_utils.get_monitor_value(image, monitor_key)¶ Return the monitor value from an image using an header key.
- Parameters
 image (fabio.fabioimage.FabioImage) – Image containing the header
monitor_key (str) – Key containing the monitor
- Returns
 returns the monitor else raise an exception
- Return type
 float
- Raises
 MonitorNotFound – when the expected monitor is not found on the header
pyFAI.utils.logging_utils module¶
This modules contains helper function relative to logging system.
- 
class 
pyFAI.utils.logging_utils.PrePostEmitStreamHandler(handler)¶ Bases:
logging.HandlerHandler to allow to hook a function before and after the emit function.
The main logging feature is delegated to a sub handler.
- 
__init__(handler)¶ Initializes the instance - basically setting the formatter to None and the filter list to empty.
- 
emit(record)¶ Call pre_emit function then delegate the emit to the sub handler.
- 
post_emit()¶ 
- 
pre_emit()¶ 
- 
 
- 
pyFAI.utils.logging_utils.prepost_emit_callback(logger, pre_callback, post_callback)¶ Context manager to add pre/post emit callback to a logger
- 
pyFAI.utils.logging_utils.set_prepost_emit_callback(logger, pre_callback, post_callback)¶ Patch the logging system to have a working progress bar without glitch. pyFAI define a default handler then we have to rework it
- Returns
 The new handler
pyFAI.utils.mathutil module¶
Utilities, mainly for image treatment
- 
pyFAI.utils.mathutil.binning(input_img, binsize, norm=True)¶ - Parameters
 input_img – input ndarray
binsize – int or 2-tuple representing the size of the binning
norm – if False, do average instead of sum
- Returns
 binned input ndarray
- 
pyFAI.utils.mathutil.center_of_mass(img)¶ Calculate the center of mass of of the array. Like scipy.ndimage.measurements.center_of_mass :param img: 2-D array :return: 2-tuple of float with the center of mass
- 
pyFAI.utils.mathutil.deg2rad(dd)¶ Convert degrees to radian in the range -pi->pi
- Parameters
 dd – angle in degrees
Nota: depending on the platform it could be 0<2pi A branch is cheaper than a trigo operation
- 
pyFAI.utils.mathutil.dog(s1, s2, shape=None)¶ 2D difference of gaussian typically 1 to 10 parameters
- 
pyFAI.utils.mathutil.dog_filter(input_img, sigma1, sigma2, mode='reflect', cval=0.0)¶ 2-dimensional Difference of Gaussian filter implemented with FFT
- Parameters
 input_img (array-like) – input_img array to filter
sigma (scalar or sequence of scalars) – standard deviation for Gaussian kernel. The standard deviations of the Gaussian filter are given for each axis as a sequence, or as a single number, in which case it is equal for all axes.
mode – {‘reflect’,’constant’,’nearest’,’mirror’, ‘wrap’}, optional The
modeparameter determines how the array borders are handled, wherecvalis the value when mode is equal to ‘constant’. Default is ‘reflect’cval – scalar, optional Value to fill past edges of input if
modeis ‘constant’. Default is 0.0
- 
pyFAI.utils.mathutil.expand(input_img, sigma, mode='constant', cval=0.0)¶ Expand array a with its reflection on boundaries
- Parameters
 a – 2D array
sigma – float or 2-tuple of floats.
mode – “constant”, “nearest”, “reflect” or “mirror”
cval – filling value used for constant, 0.0 by default
Nota: sigma is the half-width of the kernel. For gaussian convolution it is adviced that it is 4*sigma_of_gaussian
- 
pyFAI.utils.mathutil.expand2d(vect, size2, vertical=True)¶ This expands a vector to a 2d-array.
The result is the same as:
if vertical: numpy.outer(numpy.ones(size2), vect) else: numpy.outer(vect, numpy.ones(size2))
This is a ninja optimization: replace *1 with a memcopy, saves 50% of time at the ms level.
- Parameters
 vect – 1d vector
size2 – size of the expanded dimension
vertical – if False the vector is expanded to the first dimension. If True, it is expanded to the second dimension.
- 
pyFAI.utils.mathutil.gaussian(M, std)¶ Return a Gaussian window of length M with standard-deviation std.
This differs from the scipy.signal.gaussian implementation as: - The default for sym=False (needed for gaussian filtering without shift) - This implementation is normalized
- Parameters
 M – length of the windows (int)
std – standatd deviation sigma
The FWHM is 2*numpy.sqrt(2 * numpy.pi)*std
- 
pyFAI.utils.mathutil.gaussian_filter(input_img, sigma, mode='reflect', cval=0.0, use_scipy=True)¶ 2-dimensional Gaussian filter implemented with FFT
- Parameters
 input_img (array-like) – input array to filter
sigma (scalar or sequence of scalars) – standard deviation for Gaussian kernel. The standard deviations of the Gaussian filter are given for each axis as a sequence, or as a single number, in which case it is equal for all axes.
mode – {‘reflect’,’constant’,’nearest’,’mirror’, ‘wrap’}, optional The
modeparameter determines how the array borders are handled, wherecvalis the value when mode is equal to ‘constant’. Default is ‘reflect’cval – scalar, optional Value to fill past edges of input if
modeis ‘constant’. Default is 0.0
- 
pyFAI.utils.mathutil.is_far_from_group(pt, lst_pts, d2)¶ Tells if a point is far from a group of points, distance greater than d2 (distance squared)
- Parameters
 pt – point of interest
lst_pts – list of points
d2 – minimum distance squarred
- Returns
 True If the point is far from all others.
- 
pyFAI.utils.mathutil.maximum_position(img)¶ Same as scipy.ndimage.measurements.maximum_position: Find the position of the maximum of the values of the array.
- Parameters
 img – 2-D image
- Returns
 2-tuple of int with the position of the maximum
- 
pyFAI.utils.mathutil.measure_offset(img1, img2, method='numpy', withLog=False, withCorr=False)¶ Measure the actual offset between 2 images :param img1: ndarray, first image :param img2: ndarray, second image, same shape as img1 :param withLog: shall we return logs as well ? boolean :return: tuple of floats with the offsets
- 
pyFAI.utils.mathutil.relabel(label, data, blured, max_size=None)¶ Relabel limits the number of region in the label array. They are ranked relatively to their max(I0)-max(blur(I0))
- Parameters
 label – a label array coming out of
scipy.ndimage.measurement.labeldata – an array containing the raw data
blured – an array containing the blurred data
max_size – the max number of label wanted
- Returns
 array like label
- 
pyFAI.utils.mathutil.round_fft(N)¶ This function returns the integer >=N for which size the Fourier analysis is faster (fron the FFT point of view)
Credit: Alessandro Mirone, ESRF, 2012
- Parameters
 N – interger on which one would like to do a Fourier transform
- Returns
 integer with a better choice
- 
pyFAI.utils.mathutil.roundfft(*args, **kwargs)¶ 
- 
pyFAI.utils.mathutil.rwp(obt, ref)¶ Compute \(\sqrt{\sum \frac{4\cdot(obt-ref)^2}{(obt + ref)^2}}\).
This is done for symmetry reason between obt and ref
- Parameters
 obt (2-list of array of the same size) – obtained data
obt – reference data
- Returns
 Rwp value, lineary interpolated
- 
pyFAI.utils.mathutil.shift(input_img, shift_val)¶ Shift an array like scipy.ndimage.interpolation.shift(input_img, shift_val, mode=”wrap”, order=0) but faster :param input_img: 2d numpy array :param shift_val: 2-tuple of integers :return: shifted image
- 
pyFAI.utils.mathutil.shiftFFT(*args, **kwargs)¶ 
- 
pyFAI.utils.mathutil.shift_fft(input_img, shift_val, method='fft')¶ Do shift using FFTs
Shift an array like scipy.ndimage.interpolation.shift(input, shift, mode=”wrap”, order=”infinity”) but faster :param input_img: 2d numpy array :param shift_val: 2-tuple of float :return: shifted image
- 
pyFAI.utils.mathutil.unBinning(*args, **kwargs)¶ 
- 
pyFAI.utils.mathutil.unbinning(binnedArray, binsize, norm=True)¶ - Parameters
 binnedArray – input ndarray
binsize – 2-tuple representing the size of the binning
norm – if True (default) decrease the intensity by binning factor. If False, it is non-conservative
- Returns
 unBinned input ndarray
pyFAI.utils.orderedset module¶
- 
class 
pyFAI.utils.orderedset.OrderedSet(iterable=None)¶ Bases:
collections.abc.MutableSet- 
__init__(iterable=None)¶ Initialize self. See help(type(self)) for accurate signature.
- 
add(key)¶ Add an element.
- 
discard(key)¶ Remove an element. Do not raise an exception if absent.
- 
pop(last=True)¶ Return the popped value. Raise KeyError if empty.
- 
 
pyFAI.utils.shell module¶
Module containing utilities around shell command line.
- 
class 
pyFAI.utils.shell.ProgressBar(title, max_value, bar_width)¶ Bases:
objectProgress bar in shell mode
- 
__init__(title, max_value, bar_width)¶ Create a progress bar using a title, a maximum value and a graphical size.
The display is done with stdout using carriage return to to hide the previous progress. It is not possible to use stdout for something else whill a progress bar is in use.
The result looks like:
Title [■■■■■■ ] 50% Message
- Parameters
 title (str) – Title displayed before the progress bar
max_value (float) – The maximum value of the progress bar
bar_width (int) – Size of the progressbar in the screen
- 
clear()¶ Remove the progress bar from the display and move the cursor at the beginning of the line using carriage return.
- 
display()¶ Display the progress bar to stdout
- 
update(value, message='', max_value=None)¶ Update the progrss bar with the progress bar’s current value.
Set the progress bar’s current value, compute the percentage of progress and update the screen with. Carriage return is used first and then the content of the progress bar. The cursor is at the begining of the line.
- Parameters
 value (float) – progress bar’s current value
message (str) – message displayed after the progress bar
max_value (float) – If not none, update the maximum value of the progress bar
- 
 
pyFAI.utils.stringutil module¶
- 
class 
pyFAI.utils.stringutil.SafeFormatter¶ Bases:
string.FormatterLike default formater but unmatched keys are still present into the result string
- 
get_field(field_name, args, kwargs)¶ 
- 
 
- 
pyFAI.utils.stringutil.latex_to_unicode(string)¶ Returns a unicode representation from latex strings used by pyFAI.
Note
The latex string could be removed from the pyFAI core.
- Parameters
 string (str) – A latex string to convert
- Return type
 str
- 
pyFAI.utils.stringutil.safe_format(format_string, arguments)¶ Like default str.format but unmatching patterns will be still present into the result string.
- Parameters
 str (format_string) – Format string as defined in the default formatter.
dict or tuple (arguments) – Arbitrary set of positional and keyword arguments.
- Return type
 str
- 
pyFAI.utils.stringutil.to_bool(string)¶ Returns a safe boolean from a string.
- Raises
 ValueError – If the string do not contains a boolean information.
- 
pyFAI.utils.stringutil.to_ordinal(number)¶ Returns a string from an ordinal value with it’s suffix.
- Parameters
 number (int) – A number refering to a position
- Return type
 str
- 
pyFAI.utils.stringutil.to_scientific_unicode(value, digits=3)¶ Convert a float value into a string using scientific notation and superscript unicode character.
This avoid using HTML in some case, when Qt widget does not support it.
- Parameters
 value (float) – Value to convert to displayable string
digits (int) – Number of digits expected (3 means 1.000).
Module contents¶
Module with miscelaneous tools
- 
class 
pyFAI.utils.FixedParameters¶ Bases:
setLike a set, made for FixedParameters in geometry refinement
- 
add_or_discard(key, value=True)¶ Add a value to a set if value, else discard it :param key: element to added or discared from set :type value: boolean. If None do nothing ! :return: None
- 
 
- 
pyFAI.utils.calc_checksum(ary, safe=True)¶ Calculate the checksum by default (or returns its buffer location if unsafe)
- 
pyFAI.utils.convert_CamelCase(name)¶ convert a function name in CamelCase into camel_case
- 
pyFAI.utils.expand_args(args)¶ Takes an argv and expand it (under Windows, cmd does not convert
*.tifinto a list of files. Keeps only valid files (thanks to glob)- Parameters
 args – list of files or wilcards
- Returns
 list of actual args
- 
pyFAI.utils.float_(val)¶ Convert anything to a float … or None if not applicable
- 
pyFAI.utils.fully_qualified_name(obj)¶ Return the fully qualified name of an object
- 
pyFAI.utils.get_calibration_dir()¶ get the full path of a calibration directory
- Returns
 the full path of the calibrant file
- 
pyFAI.utils.get_cl_file(resource)¶ get the full path of a openCL resource file
The resource name can be prefixed by the name of a resource directory. For example “silx:foo.png” identify the resource “foo.png” from the resource directory “silx”. See also
silx.resources.register_resource_directory().- Parameters
 resource (str) – Resource name. File name contained if the opencl directory of the resources.
- Returns
 the full path of the openCL source file
- 
pyFAI.utils.get_ui_file(filename)¶ get the full path of a user-interface file
- Returns
 the full path of the ui
- 
pyFAI.utils.int_(val)¶ Convert anything to an int … or None if not applicable
- 
class 
pyFAI.utils.lazy_property(fget)¶ Bases:
objectmeant to be used for lazy evaluation of an object attribute. property should represent non-mutable data, as it replaces itself.
- 
__init__(fget)¶ Initialize self. See help(type(self)) for accurate signature.
- 
 
- 
pyFAI.utils.readFloatFromKeyboard(text, dictVar)¶ Read float from the keyboard ….
- Parameters
 text – string to be displayed
dictVar – dict of this type: {1: [set_dist_min],3: [set_dist_min, set_dist_guess, set_dist_max]}
- 
pyFAI.utils.str_(val)¶ Convert anything to a string … but None -> “”