Receiver Operating Characteristic (ROC)
As done in several of our previously published works, we always use ROC analysis to examine the performance of proposed analysis methods, focusing on the AUC as the outcome variable and comparing results based on varying “data quality” inputs. To generate ROC analysis, we will take the experimental data provided by our collaborating partners as well as our own datasets. For evoked signal analysis, a simulated evoked response was added to half of the channels of the experimental fNIRS data at specific contrast-to-noise ratio based on expectations of the study effect. Through numerous iterations of jittered event timing, a ROC curve can be generated. For connectivity analysis, pairs of channels will be selected from either the same data file or different data files. Although the expected true correlation is unknown, we are anticipating a nonzero correlation between data traces collected on the same subject at the same time. In other words, any correlation between two traces from different subjects (or recorded on different days) would be a false discovery. In each simulation, two data traces were randomly selected from the same subject’s data (nonzero correlation expected) or two null data pairs.
This example show how to compare various pipelines
raw = nirs.testing.simARNoise_shortsep;
job = nirs.modules.OpticalDensity();
job = nirs.modules.Resample(job);
job = nirs.modules.BeerLambertLaw(job);
List{1}={nirs.modules.GLM};
List{2}={nirs.modules.GLM};
List{2}{1}.type=‘AR-IRLS’;
%Preprocessing using PCA filter from same data file, then GLM using AR-IRLS
List{3}={nirs.modules.PCAFilter
List{3}{2}.type=‘AR-IRLS’;
%Preprocessing using short-separation filter from same data file, then GLM using AR-IRLS
List{4}={advanced.nirs.modules.ShortDistanceFilter
List{4}{2}.type=‘AR-IRLS’;
%Short-separation channels as regression for solving GLM (using AR-IRLS)
List{5}={nirs.modules.GLM};
List{5}{1}.type=‘AR-IRLS’;
List{5}{1}.AddShortSepRegressors=true;
ROCtest(j) = nirs.testing.ChannelStatsROC;
getdata = @(i)nirs.testing.simData(Hb(i),nirs.testing.randStimDesign(Hb(i).time,30,60));
ROCtest(j).simfunc=@()getdata(randi(length(Hb),1,1));
jobs = nirs.modules.listToPipeline(List{j});
ROCtest(j).pipeline=jobs;
for i = 1:length(ROCtest)
ROCtest(i) = ROCtest(i).run(iter);
end
Finished 1 of 1.
Finished iter: 1
Finished 1 of 1.
Finished iter: 2
Finished 1 of 1.
Finished iter: 3
Finished 1 of 1.
Finished iter: 4
Finished 1 of 1.
Finished iter: 5
Finished 1 of 1.
Finished iter: 6
Finished 1 of 1.
Finished iter: 7
Finished 1 of 1.
Finished iter: 8
Finished 1 of 1.
Finished iter: 9
Finished 1 of 1.
Finished iter: 10
…………………………………………..Finished 1 of 1.
Finished iter: 1
…………………………………………..Finished 1 of 1.
Finished iter: 2
…………………………………………..Finished 1 of 1.
Finished iter: 3
…………………………………………..Finished 1 of 1.
Finished iter: 4
…………………………………………..Finished 1 of 1.
Finished iter: 5
…………………………………………..Finished 1 of 1.
Finished iter: 6
…………………………………………..Finished 1 of 1.
Finished iter: 7
…………………………………………..Finished 1 of 1.
Finished iter: 8
…………………………………………..Finished 1 of 1.
Finished iter: 9
…………………………………………..Finished 1 of 1.
Finished iter: 10
Removing first 8 components (79.7838%)
Removing first 8 components (79.0149%)
…………………………………………..Finished 1 of 1.
Finished iter: 1
Removing first 7 components (76.6964%)
Removing first 8 components (79.0259%)
…………………………………………..Finished 1 of 1.
Finished iter: 2
Removing first 7 components (76.7906%)
Removing first 8 components (78.6567%)
…………………………………………..Finished 1 of 1.
Finished iter: 3
Removing first 7 components (76.461%)
Removing first 8 components (79.0757%)
…………………………………………..Finished 1 of 1.
Finished iter: 4
Removing first 7 components (76.3631%)
Removing first 8 components (78.721%)
…………………………………………..Finished 1 of 1.
Finished iter: 5
Removing first 8 components (79.7623%)
Removing first 8 components (79.2559%)
…………………………………………..Finished 1 of 1.
Finished iter: 6
Removing first 7 components (76.6659%)
Removing first 8 components (78.5725%)
…………………………………………..Finished 1 of 1.
Finished iter: 7
Removing first 7 components (76.8647%)
Removing first 8 components (79.145%)
…………………………………………..Finished 1 of 1.
Finished iter: 8
Removing first 8 components (79.6226%)
Removing first 8 components (78.4367%)
…………………………………………..Finished 1 of 1.
Finished iter: 9
Removing first 7 components (76.7173%)
Removing first 8 components (78.7535%)
…………………………………………..Finished 1 of 1.
Finished iter: 10
1 of 1
……………………………………………………………………….Finished 1 of 1.
Finished iter: 1
1 of 1
……………………………………………………………………….Finished 1 of 1.
Finished iter: 2
1 of 1
……………………………………………………………………….Finished 1 of 1.
Finished iter: 3
1 of 1
……………………………………………………………………….Finished 1 of 1.
Finished iter: 4
1 of 1
……………………………………………………………………….Finished 1 of 1.
Finished iter: 5
1 of 1
……………………………………………………………………….Finished 1 of 1.
Finished iter: 6
1 of 1
……………………………………………………………………….Finished 1 of 1.
Finished iter: 7
1 of 1
……………………………………………………………………….Finished 1 of 1.
Finished iter: 8
1 of 1
……………………………………………………………………….Finished 1 of 1.
Finished iter: 9
1 of 1
……………………………………………………………………….Finished 1 of 1.
Finished iter: 10
…………………………..Finished 1 of 1.
Finished iter: 1
…………………………..Finished 1 of 1.
Finished iter: 2
…………………………..Finished 1 of 1.
Finished iter: 3
…………………………..Finished 1 of 1.
Finished iter: 4
…………………………..Finished 1 of 1.
Finished iter: 5
…………………………..Finished 1 of 1.
Finished iter: 6
…………………………..Finished 1 of 1.
Finished iter: 7
…………………………..Finished 1 of 1.
Finished iter: 8
…………………………..Finished 1 of 1.
Finished iter: 9
…………………………..Finished 1 of 1.
Finished iter: 10
toc
Elapsed time is 126.326728 seconds.
disp(‘This 10 iterations takes about 2-min’)
This 10 iterations takes about 2-min
To see the results