|
| 1 | +function dp = dprime(data, baseline_idx, signal_idx) |
| 2 | +%DPRIME computes the d-prime modulation index between two time windows |
| 3 | +% |
| 4 | +% Inputs: |
| 5 | +% data - nDims x nTime x nTrials array of embedded signals |
| 6 | +% baseline_idx - indices of baseline time points |
| 7 | +% signal_idx - indices of signal time points |
| 8 | +% |
| 9 | +% Output: |
| 10 | +% dp - 1 x nDims vector of d' values |
| 11 | + |
| 12 | +if isempty(data) |
| 13 | + dp = nan; |
| 14 | + return; |
| 15 | +end |
| 16 | + |
| 17 | +[nDims, ~, nTrials] = size(data); |
| 18 | + |
| 19 | +if nTrials < 2 |
| 20 | + dp = nan(1, nDims); |
| 21 | + return; |
| 22 | +end |
| 23 | + |
| 24 | +% Mean activity per trial within each window |
| 25 | +baseline = squeeze(mean(data(:, baseline_idx, :), 2)); % nDims x nTrials |
| 26 | +signal = squeeze(mean(data(:, signal_idx, :), 2)); % nDims x nTrials |
| 27 | + |
| 28 | +% When nDims == 1, squeeze reduces 1x1xnTrials to a nTrials×1 column; |
| 29 | +% reshape to 1×nTrials so that trailing dimension is always trials. |
| 30 | +if nDims == 1 |
| 31 | + baseline = baseline(:)'; |
| 32 | + signal = signal(:)'; |
| 33 | +end |
| 34 | + |
| 35 | +% Compute d' per dimension (statistics across trials) |
| 36 | +mu_b = mean(baseline, 2); |
| 37 | +mu_s = mean(signal, 2); |
| 38 | +std_b = std(baseline, 0, 2); |
| 39 | +std_s = std(signal, 0, 2); |
| 40 | + |
| 41 | +% Pooled standard deviation: sqrt( (sigma_b^2 + sigma_s^2) / 2 ) |
| 42 | +pooled_std = sqrt(0.5 .* (std_b.^2 + std_s.^2)); |
| 43 | + |
| 44 | +dp = (mu_s - mu_b) ./ pooled_std; |
| 45 | + |
| 46 | +% Return as 1 x nDims row vector |
| 47 | +dp = dp'; |
| 48 | + |
| 49 | +end |
0 commit comments