Source code for mne_nirs.channels._roi
# Authors: Robert Luke <mail@robertluke.net>
#
# License: BSD (3-clause)
import numpy as np
from mne.utils import warn
[docs]
def picks_pair_to_idx(raw, sd_pairs, on_missing="error"):
"""
Return a list of picks for specified source detector pairs.
If multiple channel have the same source detector pair,
for example if there are multiple wavelengths or chromaphore, then
all channels matching the requested sources and detectors will be
returned.
Parameters
----------
raw : instance of Raw
The haemoglobin data.
sd_pairs : list of lists
List of source detector pairs. For example, to request the picks for
channels comprising of source 1 detector 4 and source 13
detector 4 you would specify [[1, 4], [13, 4]].
on_missing : str
What to do if one or several requested source detector are not found
in the recording.
Valid keys are 'error' | 'warning' | 'ignore'
Default is 'error'. If on_missing is 'warning' it will proceed but
warn, if 'ignore' it will proceed silently. Note.
If none of the event ids are found in the data, an error will be
automatically generated irrespective of this parameter.
Returns
-------
picks : list of integers
List of picks corresponding to requested source detector pairs.
"""
ch_names = raw.ch_names
picks = list()
for pair in sd_pairs:
pair_name = "S" + str(pair[0]) + "_D" + str(pair[1]) + " "
pair_picks = np.where([pair_name in ch for ch in ch_names])[0]
if len(pair_picks) == 0:
msg = "No matching channels found for source %s detector %s" % (
pair[0],
pair[1],
)
if on_missing == "error":
print(pair_picks)
raise ValueError(msg)
elif on_missing == "warning":
warn(msg)
else:
# on_missing == 'ignore':
continue
[picks.append(pick) for pick in pair_picks]
return picks