.. include:: ./substitutions.rst Validation ========== The two primary approaches to validating experimental data included in DearEIS are linear Kramers-Kronig testing and Z-HIT analysis. The former is a widely adopted approach based on attempting to fit a specific type of equivalent circuit, which is known *a priori* to be Kramers-Kronig transformable. The latter approach reconstructs the modulus data from the (typically) more stable phase data, which can reveal issues such as drift at low frequencies due to time invariant behavior exhibited by the measured system. Kramers-Kronig testing ---------------------- Data validation based on linear Kramers-Kronig testing can be performed in the **Kramers-Kronig** tab (:numref:`kk_tab`) which contains the following: - various settings that determine how the Kramers-Kronig test is performed - combo boxes that can be used to choose the active data set and the active test result - a table of statistics related to the active test result - a table of settings that were used to obtain the active result - different plots .. _kk_tab: .. figure:: https://raw.githubusercontent.com/wiki/vyrjana/DearEIS/images/kramers-kronig-tab.png :alt: The Kramers-Kronig tab of a project A Kramers-Kronig test result for an impedance spectrum with a negative differential resistance. The three variants of the linear Kramers-Kronig test (complex, real, and imaginary) described by `Boukamp (1995) `_ have been included. These have been implemented using either least squares fitting or matrix inversion. There is also an implementation that uses complex non-linear least squares fitting. These tests can be performed with a fixed number of time constants (i.e., RC elements), |N_tau|, using the **Manual** mode. However, it is recommended that |N_tau| is determined automatically using one or more methods of the following methods by using either the **Auto** or the **Exploratory** mode. .. list-table:: Methods for suggesting the optimum number of time constants (i.e., the number of parallel/series RC elements). :header-rows: 1 * - Method - Reference * - 1: |mu|-criterion - `Schönleber et al. (2014) `_ * - 2: norm of fitted variables - `Plank et al. (2022) `_ * - 3: norm of curvatures - `Plank et al. (2022) `_ * - 4: number of sign changes among curvatures - `Plank et al. (2022) `_ * - 5: mean distance between sign changes among curvatures - `Yrjänä and Bobacka (2024) `_ * - 6: apex of |log sum abs tau R| (or |log sum abs tau C|) *versus* |N_tau| - `Yrjänä and Bobacka (2024) `_ The intermediate results of these methods can be inspected in the **Exploratory** mode as a means of detecting and dealing with issues such as false negatives. .. note:: A custom combination of methods 3, 4, and 5 is used by default. However, a specific method or combination of methods can be chosen via the window that shows up when using the **Exploratory** mode or via the **Settings > Defaults** window. In addition to |N_tau|, the range of time constants can and `should also be optimized `_. The range of time constants are by default defined by the reciprocals of the maximum and minimum frequencies of the impedance spectrum. However, the limits can be adjusted by an extension factor, |F_ext|, which is initially set to :math:`\log{F_{ext}} = 0` in terms of the settings provided in DearEIS. The optimal range of time constants may be wider (:math:`\log{F_{ext}} > 0`) or narrower (:math:`\log{F_{ext}} < 0`) than the default range. There are settings for the limits to use when optimizing |log F_ext| and the number of evaluations to perform. A specific |log F_ext| can also be used directly by setting the number of evaluations to zero. Some immittance spectra may need to be validated using based on their admittance representations rather than their impedance representations. It is therefore recommended that the **Representation** setting is set to **Auto**, which results in both the impedance and the admittance representation being tested. .. note:: If you only wish to validate the impedance representation of the immittance data, then see :ref:`parallel impedances` for information about how to process impedance data that include, e.g., negative differential resistances before attempting to validate the data. The test results are presented in the form of a table of statistics (e.g., |pseudo chi-squared| which indicates the quality of the fit) and different plots such as one of the relative residuals of the fit. Exploratory mode ~~~~~~~~~~~~~~~~ If the **Exploratory** mode is used, then the intermediate results of the linear Kramers-Kronig test and the various methods for suggesting the optimal number of RC elements are presented in a window that pops up. The main advantages of using the **Exploratory** mode over the **Auto** mode are that one can: - evaluate how |pseudo chi-squared| behaves as a function of |log F_ext| and |N_tau|, and how the values used by the different methods for suggesting the optimal |N_tau| behave - manually adjust, e.g., the representation, |log F_ext|, and/or |N_tau| .. _exploratory_window_log_fext: .. figure:: https://raw.githubusercontent.com/wiki/vyrjana/DearEIS/images/kramers-kronig-tab-exploratory-log-fext.png :alt: 3D plot of pseudo chi-squared as a function of the number of RC elements and the extension factor of the range of time constants The extension or contraction of the range of time constants can be evaluated using a 3D plot as shown here. Rapid (i.e. partial) evaluations of different |log F_ext| values have been used here. The full range of |N_tau| have only been evaluated with the initial :math:`\log{F_{ext}} = 0` and the optimal :math:`\log{F_{ext}} = -0.151`. .. _exploratory_window_num_rc: .. figure:: https://raw.githubusercontent.com/wiki/vyrjana/DearEIS/images/kramers-kronig-tab-exploratory-num-rc.png :alt: Settings and results pertaining to suggesting the optimal number of RC elements The settings for suggesting the optimal number of RC elements can be adjusted. By default, the lower and upper limits are suggested automatically, and then a combination of methods 3, 4, and 5 are used to suggest the number of RC elements. Various plots can be viewed to evaluate the results. References: - `Boukamp, B.A., 1995, J. Electrochem. Soc., 142, 1885-1894 `_ - `Schönleber, M., Klotz, D., and Ivers-Tiffée, E., 2014, Electrochim. Acta, 131, 20-27 `_ - `Plank, C., Rüther, T., and Danzer, M.A., 2022, 2022 International Workshop on Impedance Spectroscopy (IWIS), pp. 1–6 `_ - `Yrjänä, V. and Bobacka, J., 2024, Electrochim. Acta, 504, 144951 `_ .. raw:: latex \clearpage Z-HIT analysis -------------- Data validation using the `Z-HIT algorithm `_ can be performed in the **Z-HIT analysis** tab (:numref:`zhit_tab`) that contains the following: - the various settings that determine how the Z-HIT analysis is performed - combo boxes that can be used to choose the active data set and the active analysis result - a table of statistics related to the active analysis result - a table of the settings that were used to obtain the active result - different plots .. _zhit_tab: .. figure:: https://raw.githubusercontent.com/wiki/vyrjana/DearEIS/images/zhit-tab.png :alt: The Z-HIT analysis tab of a project The modulus data that is plotted in the upper plot has been reconstructed (red line) based on the phase data (orange markers and green line) of some example data that exhibits drift at low frequencies (blue markers). The Z-HIT algorithm was first described by Ehm et al. (2000) and provides a means of validating recorded impedance spectra using a modified logarithmic Hilbert transformation. The phase data is typically smoothed before it is interpolated using a spline, and then it is integrated and derivated to reconstruct the modulus data. The final step is an adjustment of the offset of the reconstructed modulus data by fitting to a subset of the experimental data that is unaffected by, e.g., drift. This subset of data points is typically in the range of 1 Hz to 1000 Hz. .. note:: The modulus data is not reconstructed perfectly. There are often minor deviations even with ideal data. DearEIS offers a few options for smoothing algorithm and interpolation spline, and several different window functions for the weights to use during offset adjustment. The weights can also be previewed in a window (:numref:`weights_window`) that is accessible via the **Preview weights** button that is located below the section for settings. This window can help with selecting a window function and appropriate parameters for it. .. _weights_window: .. figure:: https://raw.githubusercontent.com/wiki/vyrjana/DearEIS/images/zhit-tab-weights.png :alt: A window for previewing weights It is possible to preview the weights that could be applied when fitting the approximated modulus data to the experimental modulus data. The shaded region shows the position of the window function while the orange markers show the weight (from 0.0 to 1.0) that could be applied. The results are presented in the form of a table of statistics and different plots. References: - Ehm, W., Göhr, H., Kaus, R., Röseler, B., and Schiller, C.A., 2000, Acta Chimica Hungarica, 137 (2-3), 145-157. - Ehm, W., Kaus, R., Schiller, C.A., and Strunz, W., 2001, in “New Trends in Electrochemical Impedance Spectroscopy and Electrochemical Noise Analysis”. - `Schiller, C.A., Richter, F., Gülzow, E., and Wagner, N., 2001, 3, 374-378 `_ .. raw:: latex \clearpage Applying old settings and masks ------------------------------- The settings that were used to perform the active test result are also presented as a table and these settings can be applied by pressing the **Apply settings** button. The mask that was applied to the data set when the test was performed can be applied by pressing the **Apply mask** button. If the mask that is applied to the data set has changed since an earlier analysis was performed, then that will be indicated clearly above the statistics table. .. figure:: https://raw.githubusercontent.com/wiki/vyrjana/DearEIS/images/kramers-kronig-tab-warning.png :alt: Invalid result because the data set mask has changed An example of the warning (red text on the left-hand side) that could be shown if, e.g., the mask applied to a data set has been changed after an analysis has been performed. In this case, several points of the high-frequency semi-circle in the Nyquist plot have been omitted. These features make it easy to restore old settings/masks in case, e.g., DearEIS has been closed and relaunched, or after trying out different settings. .. raw:: latex \clearpage