Peak Voigt - peak_voigt.py
r"""
This model describes a pseudo-Voigt shaped peak on a flat background.
Definition
----------
This pseudo-Voigt peak function is a weighted linear summation of
Lorentzian (L) and Gaussian (G) peak shapes. The usefulness of this
function is that it produces a peak shape with asymmetry.
The scattering intensity $I(q)$ is calculated as
.. math::
I(q) = scale . [{W_f.I(q)_L} + {(1-W_f).I(q)_G}] + background
where $W_f$ is a weighting factor and
.. math::
I(q)_L = \frac{1}{\bigl(1+\bigl(\frac{q-q_0}{HWHM}\bigr)^2\bigr)}
I(q)_G = \exp\left[ -\frac12 (q-q_0)^2 / \sigma^2 \right]
The peak is taken to be centered at $q_0$ with a HWHM (half-width
half-maximum) of 1.177 $\sigma$, where $\sigma$ is the standard deviation
of the Gaussian. In other words, the widths of the Lorentzian and the
Gaussian have been coupled for convenience of parameterisation.
When $W_f$ = 1 a Lorentzian peak is returned, and when $W_f$ = 0 a
Gaussian peak is returned.
For practical purposes 0 < $sigma$ < 0.1 else no peak is generated.
For 2D data the scattering intensity is calculated in the same way as 1D,
where the $q$ vector is defined as
.. math::
q = \sqrt{q_x^2 + q_y^2}
References
----------
Aaron L. Stancik, Eric B. Brauns
A simple asymmetric lineshape for fitting infrared absorption spectra
Vibrational Spectroscopy 47 (2008) 66-69
Authorship and Verification
---------------------------
* **Author:** Steve King **Date:** 19/11/2019
* **Last Modified by:** Steve King **Date:** 24/06/2020
* **Last Reviewed by:** **Date:**
"""
import numpy as np
from numpy import inf
name = "peak_voigt"
title = "A Voigt peak on a flat background"
description = """\
Evaluates a pseudo-Voigt shaped peak."""
category = "shape-independent"
# ["name", "units", default, [lower, upper], "type", "description"],
parameters = [["wf", "", 0.5, [0, 1], "",
"Weighting factor"],
["q0", "1/Ang", 0.05, [-inf, inf], "",
"Peak position in q"],
["sigma", "1/Ang", 0.005, [0, inf], "",
"Peak width (Std dev)"]]
def Iq(q, wf, q0, sigma):
hwhm = 1.177*sigma
intens = (wf*(1/(1+((q-q0)**2.0/hwhm**2.0))))+((1.0-wf)*np.exp((-0.5*(q-q0)**2.0)/(sigma**2.0)))
return intens
Iq.vectorized = True # Iq accepts an array of q values
demo = dict(scale=100, background=0.1,
wf=0.5, q0=0.05, sigma=0.005)
tests = [
[{'scale': 1.0, 'background' : 0.001, 'wf' : 0.5,
'q0' : 0.05, 'sigma' : 0.005},
[0.0005, 0.0514693877551], [0.00796878321113, 0.950526807316]],
]
Back to Model
Download