Source code for mne_nirs.channels._channels
# Authors: Robert Luke <mail@robertluke.net>
#
# License: BSD (3-clause)
import re
import numpy as np
from mne import pick_types
from mne.io import BaseRaw
from mne.utils import _validate_type
[docs]
def list_sources(raw):
"""
List all the sources in the fNIRS montage.
Parameters
----------
raw : instance of Raw
Raw instance containing fNIRS data.
Returns
-------
sources : list
Unique list of all sources in ascending order.
"""
_validate_type(raw, BaseRaw, "raw")
picks = pick_types(raw.info, meg=False, eeg=False, fnirs=True, exclude=[])
if not len(picks):
raise RuntimeError("Listing source is for fNIRS signals only.")
sources = list()
ch_names = raw.ch_names
for pick in picks:
x = re.search(r"S(\d+)_D(\d+)", ch_names[pick])
sources.append(int(x.group(1)))
sources = np.unique(sources)
return sources
[docs]
def list_detectors(raw):
"""
List all the detectors in the fNIRS montage.
Parameters
----------
raw : instance of Raw
Raw instance containing fNIRS data.
Returns
-------
sources : list
Unique list of all detectors in ascending order.
"""
_validate_type(raw, BaseRaw, "raw")
picks = pick_types(raw.info, meg=False, eeg=False, fnirs=True, exclude=[])
if not len(picks):
raise RuntimeError("Listing source is for fNIRS signals only.")
detectors = list()
ch_names = raw.ch_names
for pick in picks:
x = re.search(r"S(\d+)_D(\d+)", ch_names[pick])
detectors.append(int(x.group(2)))
detectors = np.unique(detectors)
return detectors
[docs]
def drop_sources(raw, sources):
"""
Drop sources.
Parameters
----------
raw : instance of Raw
Raw instance containing fNIRS data.
sources : iterable or str
Iterable (e.g. list) of source(s) or source to remove.
Returns
-------
inst : instance of Raw
The modified instance.
"""
if isinstance(sources, int):
sources = [sources]
try:
all_str = all([isinstance(src, int) for src in sources])
except TypeError:
raise ValueError(
f"'ch_names' must be iterable, got type {type(sources)} ({sources})."
)
if not all_str:
raise ValueError(
"Each element in 'ch_names' must be int, got "
f"{[type(ch) for ch in sources]}."
)
keeps = np.ones(len(raw.ch_names))
for src in sources:
template = f"S{src}_"
for idx in range(len(raw.ch_names)):
if template in raw.ch_names[idx]:
keeps[idx] = 0
keeps = np.where(keeps)[0]
return raw.pick(keeps)
[docs]
def drop_detectors(raw, detectors):
"""
Drop detectors.
Parameters
----------
raw : instance of Raw
Raw instance containing fNIRS data.
detectors : iterable or str
Iterable (e.g. list) of detector(s) or detector to remove.
Returns
-------
inst : instance of Raw
The modified instance.
"""
if isinstance(detectors, int):
detectors = [detectors]
try:
all_str = all([isinstance(det, int) for det in detectors])
except TypeError:
raise ValueError(
f"'ch_names' must be iterable, got type {type(detectors)} ({detectors})."
)
if not all_str:
raise ValueError(
"Each element in 'ch_names' must be int, got "
f"{[type(det) for det in detectors]}."
)
keeps = np.ones(len(raw.ch_names))
for det in detectors:
template = f"_D{det} "
for idx in range(len(raw.ch_names)):
if template in raw.ch_names[idx]:
keeps[idx] = 0
keeps = np.where(keeps)[0]
return raw.pick(keeps)
[docs]
def pick_sources(raw, sources):
"""
Pick sources.
Parameters
----------
raw : instance of Raw
Raw instance containing fNIRS data.
sources : iterable or str
Iterable (e.g. list) of source(s) or source to keep.
Returns
-------
inst : instance of Raw
The modified instance.
"""
if isinstance(sources, int):
sources = [sources]
try:
all_str = all([isinstance(src, int) for src in sources])
except TypeError:
raise ValueError(
f"'ch_names' must be iterable, got type {type(sources)} ({sources})."
)
if not all_str:
raise ValueError(
"Each element in 'ch_names' must be int, got "
f"{[type(ch) for ch in sources]}."
)
keeps = np.zeros(len(raw.ch_names))
for src in sources:
template = f"S{src}_"
for idx in range(len(raw.ch_names)):
if template in raw.ch_names[idx]:
keeps[idx] = 1
keeps = np.where(keeps)[0]
return raw.pick(keeps)
[docs]
def pick_detectors(raw, detectors):
"""
Pick detectors.
Parameters
----------
raw : instance of Raw
Raw instance containing fNIRS data.
detectors : iterable or str
Iterable (e.g. list) of detector(s) or detector to keep.
Returns
-------
inst : instance of Raw
The modified instance.
"""
if isinstance(detectors, int):
detectors = [detectors]
try:
all_str = all([isinstance(det, int) for det in detectors])
except TypeError:
raise ValueError(
f"'ch_names' must be iterable, got type {type(detectors)} ({detectors})."
)
if not all_str:
raise ValueError(
"Each element in 'ch_names' must be int, got "
f"{[type(det) for det in detectors]}."
)
keeps = np.zeros(len(raw.ch_names))
for det in detectors:
template = f"_D{det} "
for idx in range(len(raw.ch_names)):
if template in raw.ch_names[idx]:
keeps[idx] = 1
keeps = np.where(keeps)[0]
return raw.pick(keeps)