Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[API] Reading montage for EEG/iEEG from electrodes.tsv and coordsystem.json #605

Open
adam2392 opened this issue Oct 25, 2020 · 2 comments

Comments

@adam2392
Copy link
Member

Describe the problem

I was reading in some dataset and wanted to read in the montage again later, but without reading in the whole raw file. However, that is not possible right now.

Describe your solution

Outside of read_raw_bids, it would be nice to be able to have a public API for read_montage_bids or something that gets the electrode coordinates and other data (e.g. impedance) and returns a DigMontage, or a dictionary of coordinate points(?)

Describe possible alternatives

I suppose, I could always just run read_raw_bids again and do raw.get_montage(), but that seems extra to me.

Additional context

Idk if this is possible for MEG, since I don't work w/ it (yet), but they have a coordsystem.json at least.

@agramfort
Copy link
Member

agramfort commented Oct 25, 2020 via email

@adam2392
Copy link
Member Author

I would like to revive this discussion if possible. In some clinical workflows for iEEG, one might not have an existing EEG-data file yet, when they would like to localize the electrode coordinates. E.g.

  1. epilepsy monitor patient and collect data in NK/EDF formats
  2. Meanwhile, CT and T1 scans are collected to perform anatomical parcellation (e.g. using FreeSurfer) and electrode localization (e.g. using FieldTrip)
  3. It would be ideal to get IO for the electrodes.tsv and coordsystem.json files that will end up working with MNE-python/mne-bids, but without the need to use read_raw_bids.
  4. Sometime later, iEEG data acquisition is complete, and the electrodes.tsv and coordsystem.json files are already ready to be used.

The following could use some iterating probably. For sake of an example:

def read_dig_bids(elecs_fname, coordsystem_fname):
# creates a DigMontage from the read in files that are supposedly BIDS-compliant and handles error/warning checks

and

def write_electrodes_tsv(name, x, y, z, size=None, impedance=None, **kwargs):
# writes the electrodes.tsv file

def write_coordsystem_json(
# writes the coordsystem.json file

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants