See the LICENSE file for license rights and limitations. By downloading and/or installing this software and associated files on your computing system you agree to use the software under the terms and condition as specified in the License agreement.
If this toolbox has been useful for you, please cite [1,2,3].
This toolbox implements the minimal expected switch duration (MESD) metric to evaluate the performance of neural decoders for auditory attention detection in the context of neuro-steered hearing prostheses as published in [1,2]. The ESD metric is an interpretable, single-number metric that combines both accuracy and decision window length. It allows easy comparison between neural decoders based on a interpretable criterion.
Developed and tested in MATLAB R2018b and in Python 3.8.9.
All functions are documented properly in their respective m-files (MATLAB toolbox) and in the respective functions in the python module (Python toolbox). Additional documentation and examples can be found in the doc folder, which contains a manual in pdf format and a MESD demo file for MATLAB as well as a MESD demo in a jupyter notebook for Python to illustrate the usage of the various functions. A quick start guide is provided in the next section.
All functions needed to compute the MESD metric can be found in the MESD folder for Matab users / MESD folder for Python users. Before starting, make sure that this folder is added to the MATLAB / system path.
Computation of the MESD performance metric
The MESD is computed in four steps:
- Construction of the p(tau)-performance curve by interpolating through the evaluated (on real EEG and audio data) (tau_i,p_i)-points (decision window length accuracy).
- Optimization of the Markov chain in the number of states N for each sampled tau on the p(tau)-performance curve.
- Computation of the expected switch duration ESD(p(tau),tau,N_tau) per sampled tau and corresponding optimal number of states N_tau.
- The MESD is equal to the minimal expected switch duration over all evaluated ESD's.
These steps are implemented in the main-function computeMESD.m / compute_MESD.py. Given the evaluated (tau_i,p_i)-performance points (tau,p)
, the MESD can be computed with:
mesd = computeMESD(tau,p); % MATLAB
mesd, *_ = compute_MESD(tau,p); # Python
The default hyperparameter values are P_0 = 0.8 (confidence level), c = 0.65 (lower bound confidence interval), N_min = 5 (minimal number of states) and K = 1000 (number of samples evaluated on the performance curve). These hyperparameters can be adapted via extra arguments in the computeMESD.m
-function / compute_MESD.py
-function.
The toolbox also provides a computeESD.m-function / compute_ESD-function to compute the ESD for a given performance pair (tau,p):
esd = computeESD(tau,p); % MATLAB
esd, *_ = compute_ESD(tau,p); # Python
Designing an optimal Markov chain model for a neuro-steered hearing prosthesis
In Section II-C, a methodology is proposed to design an optimal Markov chain model for an adaptive gain control system in a neuro-steered hearing prosthesis. For a fixed accuracy p and hyperparameters P_0, c and N_min, the optimal number of states can be found with:
Nopt = optimizeMarkovChain(p,Nmin,P0,c); % MATLAB
Nopt = optimize_Markov_chain(tau,p,N_min,P0,c); # Python
The optimal model for a certain neural decoder (represented by evaluated (tau_i,p_i)-points) can be identified by extra outputs of the computeMESD
-function:
[mesd,Nopt,tauOpt,pOpt] = computeMESD(tau,p,'Nmin',Nmin,'P0',P0,'c',c); % MATLAB
mesd, N_opt, tau_opt, p_opt = compute_MESD(tau,p,N_min,P0,c) # Python
[1] S. Geirnaert, T. Francart, and A. Bertrand, "An Interpretable Performance Metric for Auditory Attention Decoding Algorithms in a Context of Neuro-Steered Gain Control," IEEE Transactions on Neural Systems and Rehabilitation Engineering, 28(1), 307-317 (2020)
[2] S. Geirnaert, T. Francart, and A. Bertrand, "A New Metric to Evaluate Auditory Attention Detection Performance Based on a Markov Chain," Proc. European Signal Processing Conference (EUSIPCO), A Coruña, Spain, Sept. 2019
[3] S. Geirnaert, T. Francart, and A. Bertrand, "MESD toolbox," August 2019, Available online, URL: https://github.com/exporl/mesd-toolbox