Pulse arrival time uncertainty propagation
Copyright (C) 2022 Miodrag Bolic
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details <https://www.gnu.org/licenses/>.
This code was developed by Miodrag Bolic for the book PERVASIVE CARDIAC AND RESPIRATORY MONITORING DEVICES.
Acknowledgements:
Uncertainty propagations is based on the code: Joe Klebba (2021). Uncertainty Propagation Functions (https://www.mathworks.com/matlabcentral/fileexchange/89812-uncertainty-propagation-functions), MATLAB Central File Exchange. Retrieved May 19, 2021
% Changing the path from main_folder to a particular chapter
main_path=fileparts(which('Main_Content.mlx'));
%addpath(append(main_path,'/Chapter2'))
cd (append(main_path,'/Chapter8/PATUncertainty'))
addpath(append(main_path,'/Service'))
SAVE_FLAG=0; % saving the figures in a file
Fitting PAT vs systolic data
Fitting is done based on regression SBP=a*ln(PAT)+b
Let us assume that the physiological signals used to obtain PAT values are sampled at 250 Hz which means that the sampling period is 4 ms. We will present the error in timing using uniform distribution in the range from -0.002s to 0.002s.
clear_all_but('SAVE_FLAG')
fprintf('\nExample: PAT\n')
fo = fitoptions('Method','NonlinearLeastSquares',...
linearfittype = fittype({'log(x)','1'},'options',fo);
fit_res = fit(patsbp.PAT,patsbp.SBP,linearfittype)
fit_res =
Linear model:
fit_res(x) = a*log(x) + b
Coefficients (with 95% confidence bounds):
a = -95.74 (-111.3, -80.2)
b = 17.7 (2.168, 33.23)
ci = confint(fit_res,0.67);
std_a=abs(ci(1,1)-fit_res.a) % obtain standard deviation for parameter a
std_b=abs(ci(2,2)-fit_res.b) % obtain standard deviation for parameter b
plot(patsbp.PAT,patsbp.SBP,'o')
ylabel("Systolic blood pressure (mmHg)")
legend({'SBP measurements', 'Regression line'})
title('Beat-to-beat SBP versus PAT for one subject')
annonation_save('a)',"Fig8.6a.jpg", SAVE_FLAG);
Defining the uncertainties of the parameters
b=fit_res.b; ub=std_b; % these values are obtained after fitting
a=fit_res.a; ua=std_a; % these values are obtained after fitting
PAT_data=PAT*ones(n,1)+unifrnd(-0.002,0.002,n,1)-unifrnd(-0.002,0.002,n,1);
Performing uncertainty propagation
[CI,valMC]=propUncertMC(f,{{a ua};{b,ub};{'Custom',PAT_data}},n,'mean','varHist',60,'hist',60);
xlabel("Systolic blood pressure (mmHg)")
title('Histogram obtained using Monte Carlo sampling')
annonation_save('b)',"Fig8.6b.jpg", SAVE_FLAG);
uncertMC = (CI(2)-CI(1))/2
% Computing 95% intervals
[CI95,valMC]=propUncertMC(f,{{a ua};{b,ub};{'Custom',PAT_data}},n,'mean','CI',0.95)
Excersize: repeat uncertainty quantification for the case when uncertainties in estimating coefficients are negligible: ub=ua=0.0001. What is the standard deviation and 95% confidence intervals in this case.
Averaging the estimated over time
T=15; %averaging over T pulsees
uncertMC_T=uncertMC/sqrt(15)
Example of calculating uncertainty subtraction of two uniform random variable
%Now truncate the distribution to prevent complex numbers.
[CI,valMC]=propUncertMC(f1,{{'uniform',-0.05,0.002};{'uniform',-0.002,0.002}},n,'mean','varHist',60,'hist',60);
uncertMC = (CI(2)-CI(1))/2 % this is a triangular distribution and therefore this way of computing uncertianty is not valid