| Size: 26163 Comment:  | Size: 23200 Comment:  | 
| Deletions are marked like this. | Additions are marked like this. | 
| Line 7: | Line 7: | 
| * Default montages for EEG (sensor selection) | * Review signals in time-frequency space * Events processes: Select events names from a list instead of having to type them * Display CTF coils: Show discs instead of squares | 
| Line 10: | Line 12: | 
| * Mouse ruler: Measure duration and amplitude by dragging the mouse. | * Mouse ruler: Measure amplitude by dragging the mouse. | 
| Line 13: | Line 15: | 
| * RAW file viewer: * Downsample before filtering? (attention to the filter design) | * RAW file viewer speed (Low priority) :<<BR>> * Consider to change to a format that is faster to read | 
| Line 16: | Line 19: | 
| * Pre-load next page of recordings * Keep the filter specifications in memory instead of recomputing for every page * Bad trials: When changing the status of bad to good: remove the bad segments as well, otherwise it is not processed by processes like the PSD. * Review clinical recordings: Reduce the dimensionality of the data with a simple inverse problem, similar to what we do for the magnetic extrapolation ("Regional sources" in BESA, cf S Rampp) * MEG/EEG registration: Apply the same transformation to multiple runs * Create heat maps: Maybe with matlab function heatmap? * BioSemi: Add menu "Convert naming system" to rename channels into 10-10 (A1=>FPz) | * Keep the filter specifications in memory instead of recomputing for every page<<BR>>(Nice to have) * !BioSemi: Add menu "Convert naming system" to rename channels into 10-10 (A1=>FPz) * Simulations: https://github.com/lrkrol/SEREEGA(Low priority) == ECOG/SEEG == * https://www.sciencedirect.com/science/article/pii/S1053811922005559 * Display (high-priority)(Part SEEG grant): * Group display: Overlay multiple channel files in the same figure, coloring contacts by subject/ROI/Cluster/Electrode name * https://neuroimage.usc.edu/forums/t/37617 * iEEG tab must be read-only when multiple files (hide configuration controls) * Bad channels: Contacts greyed out instead of ignored (Marcel H, Germany)<<BR>>(To diff between band and not-recorded) > Rendering of SEEG electrodes: Full surface modelling with surface mesh (see Lead-DBS models + code that generates them?) * Display time in H:M:S instead of S > If there is t0 in H:M:S instead of S > As an option in Display configuration button>x-axis * view_leadfield_sensitivity: Add closing surfaces at cortex limits * Create clusters from anatomical labels (Anne So) : * Identify contacts in a given anatomical region (volume scout, surface mesh, or label in a volume atlas) / allow extracting the signals from all the contacts in an ROI> As a process to select recordings, then Scouts from Volumen Atlas, Create cluster in channel file, then Extract time series. * Group analysis: extract clusters across subjects, display or average signals (see MIA) (Anne So) * Spike detection (Need to check for current toolboxes from scratch)(contact Nicolas R)(Mosher J)(iEEG BIDS): * https://iopscience.iop.org/article/10.1088/1741-2552/ac9259/pdf * Automatic segmentation of CT: * LeGUI: https://github.com/Rolston-Lab/LeGUI/tree/main/LeGUI<<BR>>https://neuroimage.usc.edu/forums/t/automatic-localization-of-seeg-electrodes/36302/7 * GARDEL: http://meg.univ-amu.fr/wiki/GARDEL:presentation * Discussed with Samuel and Christian (ins-amu.fr) * SEEG DEETO Arnulfo 2015: https://bmcbioinformatics.biomedcentral.com/articles/10.1186/s12859-015-0511-6 * Used routinely at Niguarda Hospital + other hospitals worldwide, reliable tool. * To be used with SEEG-assistant/3DSlicer: https://bmcbioinformatics.biomedcentral.com/articles/10.1186/s12859-017-1545-8 * ECOG Centracchio 2021: https://link.springer.com/content/pdf/10.1007/s11548-021-02325-0.pdf * Classifier on thresholded CT: https://github.com/Jcentracchio/Automated-localization-of-ECoG-electrodes-in-CT-volumes * SEEG Granados 2018 (no code shared): https://link.springer.com/content/pdf/10.1007/s11548-018-1740-8.pdf * ECOG: * Project and display contacts on cortex surface should consider the rigidity of the grids: Contacts cannot rotate, and distance between contacts should remain constant across runs * Method for contacts projection: https://pdfs.semanticscholar.org/f10d/6b899d851f3c4b115404298d7b997cf1d5ab.pdf * ECOG: Brain shift: When creating contact positions on a post-implantation image, the brain shift should be taken into account for creating images of the ECOG contacts on the pre-op brain => iELVis (http://ielvis.pbworks.com/w/page/116347253/FrontPage) <<BR>>Normalization MNI? solutions with !FieldTrip? * Display CT images: Better brightness/contrast adjustment: https://neuroimage.usc.edu/forums/t/automatic-localization-of-seeg-electrodes/36302/8 Range of values is way diff than ones from MRI. Current color maps are not suitable for CT, need to be improved.Together with processing of CT to get electrode positions. * Detection CCEP stim artifacts: Use ImaGIN code ImaGIN_!StimDetect https://f-tract.eu/software/imagin/ * Add support for modeling non-uniform spaced sEEG electrodes (https://neuroimage.usc.edu/forums/t/feature-request-support-seeg-electrodes-with-non-uniform-spacing/39647/6) * VTA and Efields: fast field :https://doi.org/10.1016/j.neuroimage.2020.117330 == Pre-processing == * process_detectbad: * Allow on raw files (for bad channels only) * Add detection on derivative of the signal (see EEGLAB) * Document in tutorial Bad channels * PREP pipeline / EEGLAB (Bigdely-Shamlo 2015) * Improve bad channel/trial detection: * ft_artifact_threshold and ft_rejectartifact * MNE-Python * EEGLAB * Integrate with EYE-EEG (Olaf Dimigen) * Reproduce tutorial: https://www.eyetracking-eeg.org/tutorial.html * Create EYE-EEG plugin + processes (Raphael Lambert) * Process: Detect sacades (extended events) + fixations * Improved ICA * Eye-movement related potentials * Use it to guide ICA: http://www2.hu-berlin.de/eyetracking-eeg/ * ICA: <<BR>> * Automatic classification: ICLabel: https://neuroimage.usc.edu/forums/t/automatic-eeg-ic-ica-classification-for-brainstorm/33785 * Exploration: Add window with spectral decomposition (useful for muscle artifacts) * Export IC time series (and then compute their spectrum): solves the problem above * Import ICA matrices available in EEGLAB .set files * ICA+machine learning: https://www.ncbi.nlm.nih.gov/pubmed/28497769 * Automated artifact rejection: https://arxiv.org/abs/1612.08194 * Spectral representation of ICs * SSP: * Display warning if changing the !ChannelFlag while there is a Projector applied * File format: * Add support to read GDF file format https://github.com/donnchadh/biosig/blob/master/biosig/t200_FileAccess/sload.m * <<BR>> * == Reproducibility toolbox == * Generate fully reproducible scripts, including all the interactive/graphical parts * Record all GUI actions as script calls * Import window: Add button to create the corresponding processing pipeline (to generate script or to edit additional options). * Adding the list of plugins to the reports * Better provenance: History fields, uniform file names... | 
| Line 26: | Line 132: | 
| * Snapshot: Save as image / all figures (similar to Movie/all figure) * Generalize the use of the units (field .DisplayUnits): Rewrite processes to save the units correctly * Colormaps: * Allow brightness/contrast manipulations on the custom colormaps * Global colormap max: Should get the maximum across all the open files * Copy figures to clipboard (with the screencapture function) * Smooth display from figure_image (ERPimage, raster plot...) | * Colormaps: Global colormap max: Should get the maximum across all the open files * Snapshot: * Save as image / all figures (similar to Movie/all figure) | 
| Line 34: | Line 139: | 
| Line 35: | Line 141: | 
| * Display CTF coils: Show discs instead of squares * Use boundary() instead of conhull() in all the display functions (ie. 2DDisc) * Progress bar: Add a "Cancel" button * Error message: Add a link to report directly the bug on the forum * Reorganize menus (Dannie's suggestion): {{attachment:dannie_menus.png||width="382",height="237"}} | == Database == * Save iHeadModel somewhere in the datbase structure * Generalize the use of the units (field .!DisplayUnits): Save in source files | 
| Line 43: | Line 147: | 
| * Thresholding and stat tests the connectivity matrices * Connectivity on unconstrained sources: "Default signal extraction for volume grids should be the time series of the first principal component of the triplet signals after each has been zero-meaned" (SB) * Display of connectivity graphs: * Display as straight lines * Recode 2D graphs * 3D display with anatomical constrains * Display using real position of EEG electrodes * Use new band-pass filters in bst_connectivity ('bst-hfilter' instead of 'bst-fft-fir') * Matrix view of NxN graphs: Add legend of the elements along X and Y axis * Weighted Phase Lag Index (WPLI) * Graph view: * Does not display negative values correctly (correlation or difference of coherence) * Re-write using pure Matlab code and smoothed graphics * Fixed scales for intensity sliders * Text bigger * Too much data in appdata * Fixed scales for intensity sliders * Add "=" shortcut for having graphs with similar configurations * Disable zoom in one region (serious bugs) * NxN on sensors: does not place the sensors correctly in space * Coherence: * Average cross-spectra instead of concatenating epochs (to avoid discontinuities)<<BR>>Explore inter-trial approaches (Esther refers to chronux toolbox) * Granger: Check for minimum time window (Esther: min around 500-1000 data points) * PLV: * Add p-values * Remove evoked * Optimize code * Add time integration * Unconstrained sources * Add warning when running of short windows (because of filters) * Time-resolved correlation/coherence: Display as time bands * Tutorial coherence [1xN] : Reproduce FieldTrip results? * Connect NxN: Display as time series > Display warning before trying to open too many signals | * Define names and unit labels for each connectivity metric * Null models: (Bratislav M) https://www.nature.com/articles/s41583-022-00601-9 * {{attachment:connect_toolboxes.jpg}} * Connect NxN display: * Graph on sensors: Place M/EEG sensors by location, not by channel order * Display as image: Add legend of the elements along X and Y axis * Display as time series: Display warning before trying to open too many signals * Optimize display: use surface() instead of line() for links? (as in figure_3d/PlotFibers) * Time-resolved correlation/coherence: Display as time bands (as done in wavelet, to have same time axis as data) | 
| Line 78: | Line 161: | 
| * Plugin manager: * Export all the software environment to a .zip file (brainstorm + all plugins) * Generate fully reproducible scripts, including all the interactive/graphical parts: * Saving all the interactive operations as process calls * Improving the pipeline editor to handle loops over data files or subjects * Keeping a better track of the provenance of all the data (History field, and maybe more uniform file names) | |
| Line 86: | Line 163: | 
| * https://neuroimage.usc.edu/forums/t/ica-on-very-long-eeg/23556/4 | * BEM single layer (John wants to test it) | 
| Line 88: | Line 166: | 
| * Reproduce other tutorials / examples * Point-spread functions (PSFs) and cross-talk functions: https://mne.tools/stable/auto_examples/inverse/plot_psf_ctf_vertices.html#sphx-glr-auto-examples-inverse-plot-psf-ctf-vertices-py | * Reproduce tutorials / examples from !FieldTrip and MNE-Python: * !FieldTrip ECOG tutorial: http://www.fieldtriptoolbox.org/tutorial/human_ecog * Reproduce tutorials from MNE-Python: https://martinos.org/mne/stable/tutorials.html | 
| Line 91: | Line 172: | 
| Line 92: | Line 174: | 
| * Add FieldTrip functions: | * Chronux toolbox : http://chronux.org/ * Add !FieldTrip functions: | 
| Line 98: | Line 183: | 
| Line 99: | Line 185: | 
| Line 100: | Line 187: | 
| Line 101: | Line 189: | 
| Line 102: | Line 191: | 
| * ft_prepare_sourcemodel: Compute MNI transformation (linear and non-linear) => Peter | |
| Line 104: | Line 193: | 
| * Freqanalysis: ITC * ft_read_atlas('TTatlas+tlrc.BRICK'); | |
| Line 107: | Line 194: | 
| Line 109: | Line 197: | 
| Line 112: | Line 201: | 
| Line 116: | Line 206: | 
| * When computing sources from the pipeline editor: doesn't reselect the options if you click twice on "edit" (works for minnorm, but not for lcmv) | |
| Line 119: | Line 209: | 
| * ICA: * Add Alex's suggestions: https://neuroimage.usc.edu/forums/t/ica-on-very-long-eeg/23556/4 * Add methods: SOBI, Fastica, AMICA/CUDICA/CUDAAMICA (recommended by S Makeig) * Why doesn't the ICA process converge when using 25 components in the EEG tutorial? * Add an option to resample the signals before computing the ICA decomposition * Exploration: Add window with spectral decomposition (useful for muscle artifacts) * Export IC time series (and then compute their spectrum): solves the problem above * Comparison JADE/Infomax: <<BR>> http://journals.plos.org/plosone/article?id=10.1371/journal.pone.0030135 * Use faster methods (MNE-Python?) * Dimension reduction with PCA adds artifacts: Not done by default in EEGLAB<<BR>>Contact: Stephen Shall Jones ( shall-jones@infoscience.otago.ac.nz )<<BR>>Student Carl Leichter detailed this in his thesis * S Makeig: Use ICA to select the IC of interest instead of only removing artifacts * Display of spectrum for components (PSD/FFT) * Import ICA matrices available in EEGLAB .set files * EEGLAB recommends ICA + trial rejection + ICA again: Impossible right now with Brainstorm<<BR>>(http://sccn.ucsd.edu/wiki/Chapter_09:_Decomposing_Data_Using_ICA) * ICA+machine learning: https://www.ncbi.nlm.nih.gov/pubmed/28497769 * Automated artifact rejection: https://arxiv.org/abs/1612.08194 * Use EYE-EEG: EEGLAB toolbox for eye-tracker guided ICA (Olaf Dimigen): http://www2.hu-berlin.de/eyetracking-eeg/ * Other EEGLAB functions: * Step function detection: https://github.com/lucklab/erplab/wiki/Artifact-Detection:-Tutorial * SSP: * Display warning if changing the ChannelFlag while there is a Projector applied * Spectral flattening (John): * ARIMA(5,0,1): Apply on the signal before any frequency/connectivity/PAC analysis * PSD: * Rewrite to have the same input as coherence (frequency resolution instead of window length) * Allow display of Avg+StdErr | |
| Line 148: | Line 210: | 
| Line 149: | Line 212: | 
| * Optimization: bst_timefreq (around l.136), remove evoked in source space: Average should be computed in sensor space instead of source space (requested by Dimitrios) | * Optimization: bst_timefreq (around l.136), remove evoked in source space: Average should be computed in sensor space instead of source space (requested by Dimitrios) | 
| Line 151: | Line 214: | 
| * Matching pursuit: http://m.jneurosci.org/content/36/12/3399.abstract?etoc * Bug: Display logs as negative * Bug: 3D figures: Colormaps with "log" option doesn't work * Bug: Difference of power displayed in log: problems (Soheila) * 2D Layout in spectrum * Make much faster and more memory efficient (C functions coded by Matti ?) * TF scouts: should display average of TF maps * Impossible to keep complex values for unconstrained sources * Pad short epochs with zero values for getting lower frequencies | |
| Line 161: | Line 216: | 
| * Extend clusters tab to display of TF to overlay TF signals (Svet) | |
| Line 163: | Line 217: | 
| * Allow baseline normalization of files computed with time bands | |
| Line 165: | Line 218: | 
| * Review continuous files in time-frequency space (for epilepsy) | |
| Line 167: | Line 219: | 
| * Artifact detection: * Artifact rejection like SPM: if bad in 20%, bad everywhere * Test difference between adjacent samples * Events detection: Add option "std" vs "amplitude" * Simulation: * EEGSourceSim: https://www.sciencedirect.com/science/article/pii/S0165027019302341 * Use field process field "Group" to separate Input/Processing/Output options * Use new Matlab functions: movmean, movsum, movmedian, movmax, movmin, movvar, movstd == Database == * MEG protocols: More flexible organization of the database; sub-conditions to allow different runs X different conditions. * Matrix files: Allow to be dependent from other files * Rename multiple files * Default headmodel lost when reloaded: Keep selection on the hard drive (in brainstormstudy.mat) * Auto-save: * protocol.mat can be too big: do not store the results links in it (and recreate when loading)- http://neuroimage.usc.edu/forums/t/abnormally-slow-behavior/2065/10 * Improve auto-save: add tracking file next to protocol.mat, do not save all the time, only when closing app, and reload protocol at stratup if tracking file is still there == Distributed computing == * Options from FieldTrip: * Loose collection of computers: https://github.com/fieldtrip/fieldtrip/tree/master/peer * Single multicore machine: https://github.com/fieldtrip/fieldtrip/tree/master/engine * Batch system: https://github.com/fieldtrip/fieldtrip/tree/master/qsub * Documentation: https://www.fieldtriptoolbox.org/faq/what_are_the_different_approaches_i_can_take_for_distributed_computing/ * PSOM: http://psom.simexp-lab.org/ == Source modeling == * Unconstrained to flat: Default PCA for stat and connectivity? * Sensitivity maps: https://mne.tools/stable/auto_examples/forward/plot_forward_sensitivity_maps.html * Reproduce results in "Simultaneous human intracerebral stimulation and HD-EEG, ground-truth for source localization methods": https://www.nature.com/articles/s41597-020-0467-x * Use eLORETA instead of sLORETA? <<BR>>https://neuroimage.usc.edu/forums/t/compute-eeg-sources-with-sloreta/13425/6 * "eLORETA algorithm is available in the MEG/EEG Toolbox of Hamburg (METH)": https://www.biorxiv.org/content/biorxiv/early/2019/10/17/809285.full.pdf * Point-spread and cross-talk functions (code in MNE-Python): * https://www.biorxiv.org/content/biorxiv/early/2019/06/18/672956.full.pdf * https://github.com/olafhauk/EEGMEGResolutionAtlas * Dipoles: * Project individual dipoles files on a template * panel_dipoles: Doesn't work with multiple figures * Project sources: Very poor algorithm to project sub-cortical regions and cerebellum (algorithm to fit surfaces should be imrpoved) * Menu head model > Copy to other conditions/subjects (check if applicable first) * Menu Sources > Maximum value: Doesn't work with volume or mixed head models * Mixed head models: * Set loose parameter from the interface * Bug when displaying interpolated in MRI viewer * Volume grid: * Optimize: 3D display (better than 9x9 cubes) * Optimize: vol_dilate (with 26 neighbors) * Menu Sources > Simulate recordings: * Do not close the 3D figures after generating a new file * Add a process equivalent to this menu * Panel Get coordinates: Add button "find maximum" * BEM single sphere: Get implementation from MNE * Unconstrained sources: * Stat and connectivity: what to do? (re-send email John+Sylvain) * Sources on surface: Display peak regions over time (time = color) => A.Gramfort * Process "Extract scouts time series": Add PCA option (replace isnorm with choice PCA/Norm) * Add eyes models to attract eye activity | * requested feature from the forum: * * https://neuroimage.usc.edu/forums/t/event-export-and-process-find-maximum-value-amplitude/41911/2 * * https://neuroimage.usc.edu/forums/t/custom-process-that-involves-merging-of-channels/40638 * * https://neuroimage.usc.edu/forums/t/swloreta-for-source-localization/41882/4 | 
| Line 230: | Line 226: | 
| * FastSurfer: https://deep-mi.org/research/fastsurfer/ * '''SimNIBS''': Replace HEADRECO with CHARM (headreco will be removed in SimNIBS 4) * Infant templates: Add electrodes positions (at least 10-10) * Multi-Scale Brain Parcellator (Lausanne2008): * [[https://github.com/sebastientourbier/multiscalebrainparcellatorhttps://hub.docker.com/r/sebastientourbier/multiscalebrainparcellator|https://github.com/sebastientourbier/multiscalebrainparcellator]] * [[https://github.com/sebastientourbier/multiscalebrainparcellatorhttps://hub.docker.com/r/sebastientourbier/multiscalebrainparcellator|https://hub.docker.com/r/sebastientourbier/multiscalebrainparcellator]] * https://multiscalebrainparcellator.readthedocs.io/en/latest/ * Registration: * Getting electrode positions from 3D scanners: https://sccn.ucsd.edu/wiki/Get_chanlocs * GARDEL: http://meg.univ-amu.fr/wiki/GARDEL:presentation * Use the same registration for multiple recording sessions that have already re-registered previously (eg. with MaxFilter) * When linking multiple EEG recordings including 3D positions, do the registration only once and copy it to all the runs * Select and remove bad digitized head points before automatic coregistration * Load the MNE -transf.fif: http://neuroimage.usc.edu/forums/showthread.php?2830 | * Display parcellation values (matrices) in 3D and 2D. * https://github.com/dutchconnectomelab/Simple-Brain-Plot * Scouts * Import SimNIBS4: Use final_tissues_LUT.txt instead of fixed list of tissues: https://neuroimage.usc.edu/forums/t/removing-a-lesioned-area/38414/20 * Simple-brain-plot: https://github.com/dutchconnectomelab/Simple-Brain-Plot * MNI normalization: More options: * DARTEL / SHOOT * !BrainSuite (wait for Anand) * Import from SimNIBS (Conform2MNI_nonl.nii.gz, MNI2Conform_nonl.nii.gz) | 
| Line 247: | Line 241: | 
| * Adjust CT contrast better: https://neuroimage.usc.edu/forums/t/automatic-localization-of-seeg-electrodes/36302/10 | |
| Line 252: | Line 248: | 
| * Edit fiducials: Replace 6 text boxes with 1 for easy copy-paste (see fiducials.m) * Optimize computation interpolation MRI-surface (tess_tri_interp) => spm_mesh_to_grid * BrainSuite: * Add new labels to all BrainSuite anatomy templates | * Surface>Volume interpolation: Use '''spm_mesh_to_grid''' instead of tess_tri_interp * Defacing: * https://afni.nimh.nih.gov/pub/dist/doc/htmldoc/tutorials/refacer/refacer_run.html * Removing MNI face mask using MNI coordinates (mask available ICMB152 2023b) * Bug import anatomy: Requested nVert > high-resolution cortex surface: Creates an empty cortex_0V * !BrainSuite: | 
| Line 258: | Line 261: | 
| * USCBrain: Add default electrodes positions * FEM templates for different ages: | * USCBrain: Add default electrodes positions * Remove !BrainSuite1 when not needed anymore * Brain2mesh: Add import of 10-10 positions * Templates for different ages: * MNI: https://www.bic.mni.mcgill.ca/ServicesAtlases/NIHPD-obj1 | 
| Line 263: | Line 271: | 
| Line 264: | Line 273: | 
| Line 265: | Line 275: | 
| * Neurodev database: https://jerlab.sc.edu/projects/neurodevelopmental-mri-database/ * https://openneuro.org/datasets/ds000256/versions/00002 * https://osf.io/axz5r/ | |
| Line 268: | Line 284: | 
| * Display scouts in a tree: hemisphere, region, subregion * Sort scouts by region in process options * Downsample to atlas: allow on timefreq/connect files * Project from one hemisphere to the other using registered spheres/squares (http://neuroimage.usc.edu/forums/t/how-to-create-mirror-roi-in-the-other-hemisphere/5910/8) | |
| Line 273: | Line 286: | 
| * Major bug when importing surfaces for an MRI that was re-oriented manually * Surface>Volume interpolation: Use spm_mesh_to_grid * Bug: Hide scouts in the preview of the grid for volume head models | |
| Line 277: | Line 287: | 
| * Allen Institute gene expression atlases: Import in Brainstorm as source maps and display on cortex == ECOG/SEEG == * Electrodes models: Import / export * Contact positions: Import / set / detect * New option: Align on none|inner|cortex to replace ECOG-mid * Add history: Save modifications and transformations applied to the channel files (Marcel) * Project contact positions across subjects or templates (Marcel) * Add menu to import implantation channel file in imported recordings * SEEG/ECOG: Identify contacts in resected areas / identify ROIs for each contact * SEEG/ECOG: Identify contacts in a given anatomical region (volume scout, surface mesh, or label in a volume atlas) / allow extracting the signals from all the contacts in an ROI * Automatic segmentation of CT: * GARDEL: http://meg.univ-amu.fr/wiki/GARDEL:presentation * Arnulfo: https://bmcbioinformatics.biomedcentral.com/articles/10.1186/s12859-015-0511-6 * 3DSlicer/SEEG Assistant: https://bmcbioinformatics.biomedcentral.com/articles/10.1186/s12859-017-1545-8 * ECOG: * Project and display contacts on cortex surface should consider the rigidity of the grids: Contacts cannot rotate, and distance between contacts should remain constant across runs * Method for contacts projection: https://pdfs.semanticscholar.org/f10d/6b899d851f3c4b115404298d7b997cf1d5ab.pdf * ECOG: Brain shift: When creating contact positions on a post-implantation image, the brain shift should be taken into account for creating images of the ECOG contacts on the pre-op brain => iELVis (http://ielvis.pbworks.com/w/page/116347253/FrontPage) * Display: * Bad channels: Contacts greyed out instead of ignored (Marcel) * Display time in H:M:S * Display curved SEEG electrodes * Export list of contacts with a probability of anatomical regions from various atlases: https://neuroimage.usc.edu/forums/t/seeg-contacts-anatomical-location/14756 * Detection CEEP stim artifacts: Use ImaGIN code ImaGIN_StimDetect | * Improving the registration between EEG and anatomy templates: * Warping: Improve the basic alignment of the digitized electrodes on the templat, possibly with Cz and other anatomical landmarks * EEG template positions: rework using a standardized Cz position (+ other landmarks) == Forward modeling == * DUNEuro/FEM: * Add lesion mask to SimNIBS: https://simnibs.github.io/simnibs/build/html/documentation/command_line/add_tissues_to_upsampled.html#add-tissues-to-upsampled-doc * !GeomtryAdapted: Buggy? * Display differences between leadfields: amplitude of difference (right-click > Compare) * Display sensitivity on FEM surface * OpenMEEG: Detect bad results + exclude from leadfield * BEM single sphere: Get implementation from MNE-Python (John Mosher) * Add eyes models to attract eye activity (Put a dipole in each eye) == Source modeling == * Reproduce results in "Simultaneous human intracerebral stimulation and HD-EEG, ground-truth for source localization methods": https://www.nature.com/articles/s41597-020-0467-x * eLORETA instead of sLORETA? * https://neuroimage.usc.edu/forums/t/compute-eeg-sources-with-sloreta/13425/6 * https://neuroimage.usc.edu/forums/t/loreta-and-source-localization/30525 * "eLORETA algorithm is available in the MEG/EEG Toolbox of Hamburg (METH)": https://www.biorxiv.org/content/biorxiv/early/2019/10/17/809285.full.pdf * https://github.com/brainstorm-tools/brainstorm3/issues/114 * Point-spread functions (PSFs) and cross-talk functions: https://mne.tools/stable/auto_examples/inverse/plot_psf_ctf_vertices.html#sphx-glr-auto-examples-inverse-plot-psf-ctf-vertices-py https://www.biorxiv.org/content/biorxiv/early/2019/06/18/672956.full.pdf * https://github.com/olafhauk/EEGMEGResolutionAtlas * Dipoles: * Display dipoles in MRI viewer * panel_dipoles: Doesn't work with multiple figures (SOLVED?) * Project sources: Very poor algorithm to project sub-cortical regions and cerebellum * Maximum: * Menu Sources > Maximum value: Doesn't work with volume or mixed head models * Panel Get coordinates: Add button "find maximum" * Sources on surface: Display peak regions over time (time = color) => A.Gramfort * Volume grid: * Optimize: 3D display (better than 3x3 cubes) * Optimize: vol_dilate (with 26 neighbors) | 
| Line 305: | Line 338: | 
| * Stat on unconstrained sources? * Stat/time series: Hide lines going down to zero (Dimitrios: https://neuroimage.usc.edu/forums/t/common-source-activation-across-subjects-and-conditions/1152/21) * Cluster stat: Add frequency selection option | |
| Line 306: | Line 343: | 
| * Which functions to use? * Write panel similar to Process1 and Process2 to allow the | * Write panel similar to Process1 and Process2 | 
| Line 310: | Line 346: | 
| * Quality control before statistics, on condition averages across subjects:<<BR>>mean(baseline)/std(baseline): shows bad subject quickly. * Use SurfStat: Impements interesting things, like an analytical cluster-based p-value correction (Random-field theory which is used in SPM) - Peter * Export to R or SPSS for advanced stat | * Multivariate stim-response analysis: https://github.com/mickcrosse/mTRF-Toolbox | 
| Line 315: | Line 350: | 
| * Bug import multiple files: use same "time" for all files | |
| Line 317: | Line 351: | 
| * Add option to process to specify the protocol name * Disable logging of sub-processes (reloading the previous report should only show process_import_bids) * Full support for iEEG and EEG | |
| Line 319: | Line 356: | 
| Line 320: | Line 358: | 
| * Read associated empty room * Test all the BIDS examples * BIDS Export: * Add events tsv, channel tsv, EEG, iEEG * '''XDF import''': Use FieldTRip or the EEGLAB plugin, contact Martin Bleichner (Oldenburg)<<BR>>https://github.com/sccn/xdf/blob/master/xdf_sample.xdf | * https://github.com/brainstorm-tools/brainstorm3/issues/139 * Use BIDS-Matlab? * Test datasets: * See list of test datasets in process_import_bids.m * ds004085 / ds004473: Check response epoch + BUG with coordinate interpretation * BIDS export: * EEG, iEEG: Add events.tsv, channel.tsv, electrodes.tsv * Anatomy: Add t1w.json (including fiducials) * Use BIDS-Matlab? * EDF+ reader: Add resampling of channels with different sampling rates | 
| Line 329: | Line 377: | 
| * FieldTrip: Import/Export time-frequency: * Export: http://neuroimage.usc.edu/forums/t/export-time-frequency-to-fieldtrip/1968 * Import: http://neuroimage.usc.edu/forums/t/import-time-frequency-data-from-fieldtrip/2644 | * SPM .mat/.dat: Fix the import of the EEG/SEEG coordinates * EEG File formats:<<BR>> * XLTEK: https://github.com/danielmhanover/OpenXLT * Persyst .lay: https://github.com/ieeg-portal/Persyst-Reader * Nervus .eeg: https://github.com/ieeg-portal/Nervus-Reader * Biopac .acq: https://github.com/ieeg-portal/Biopac-Reader * BCI2000 Input (via EEGLAB plugin) | 
| Line 333: | Line 391: | 
| * Use reader from MNE-Python: mne.io.read_raw_kit (doesn't require Yokogawa slow library) | * Use reader from MNE-Python: mne.io.read_raw_kit (skip Yokogawa slow library) | 
| Line 339: | Line 397: | 
| * EEG File formats: * EEG CeeGraph * EGI: Finish support for epoched files (formats 3,5,7) * XLTEK: https://github.com/danielmhanover/OpenXLT * Persyst .lay: https://github.com/ieeg-portal/Persyst-Reader * Nervus .eeg: https://github.com/ieeg-portal/Nervus-Reader * Biopac .acq: https://github.com/ieeg-portal/Biopac-Reader * gTec EEG recordings: Read directly from the HDF5 files instead of the Matlab exports. * BCI2000 Input (via EEGLAB plugin) | |
| Line 349: | Line 399: | 
| * Review raw on all the file formats (ASCII EEG and Cartool missing) * SPM .mat/.dat: Fix the import of the EEG/SEEG coordinates * Get acquisition date from files: Missing for 4D * Support for OpenJData / JNIfTI: https://github.com/brainstorm-tools/brainstorm3/issues/284 == Distribution & documentation == | * MINC MRI: Add support for "voxel to world" transformation (vox2ras) similarly to .nii == Distribution == * Java-free Matlab: All references of functions below must be removed * '''!JavaFrame''': screencapture.m (used for screen captures of videos) * '''Actxcontrol''': Used for video-EEG * uihtml + !JavaScript callbacks? * ActiveX in .NET app? * Pure Java framce + VLC java plugin? * Other video player? * '''Javacomponent''': * mri_editMask * figure_mri * process_bandpass * List .jar files used from Matlab distribution (e.g. dom) => Check all the import calls * Cleanup !GitHub repository: * https://github.com/brainstorm-tools/brainstorm3/issues/473 * Move external I/O libraries as plugins: * mne-matlab * CEDS64ML * edfimport * eeprobe * son * ricoh * yokogawa == Documentation == * All tutorial datasets in BIDS (including introduction tutorials) * Deface the MRIs of all the tutorials * Count !GitHub clones in the the download stats * MNE-Python 1.0: Test and update install documentation | 
| Line 356: | Line 438: | 
| * Update the organization of derivatives folder (same for ECOG tutorial) * Add review of literature for the resting state MEG | * Update the organization of derivatives folder (full FS folders) | 
| Line 359: | Line 440: | 
| * Tutorial iEEG: * Rename _coordsystem/_electrodes => space_other | |
| Line 363: | Line 443: | 
| Line 364: | Line 445: | 
| * FieldTrip ECOG tutorial: http://www.fieldtriptoolbox.org/tutorial/human_ecog * FieldTrip cortico-muscular coherence tutorial: http://www.fieldtriptoolbox.org/tutorial/coherence * Reproduce tutorials from MNE-Python: https://martinos.org/mne/stable/tutorials.html | |
| Line 368: | Line 447: | 
| Line 369: | Line 449: | 
| * BIDS-EEG example datasets | |
| Line 371: | Line 450: | 
| * Stand-alone ICA tutorial * Move all the files to download to the cloud for faster download everywhere in the world * Workflows FieldTrip: http://www.fieldtriptoolbox.org/faq/what_types_of_datasets_and_their_respective_analyses_are_used_on_fieldtrip * Count GitHub clones in the the download stats * Deface the MRIs of all the tutorials * Clean up the wiki: * Remove all the wiki pages that are not used * Check all the links in all the pages * Check that all the TODO blocks have been properly handled * Remove useless images from all tutorials * Update page count on the main tutorials page | * Stand-alone ICA tutorial * https://archive.physionet.org/ [data and tools] | 
| Line 385: | Line 456: | 
| * MacOS 10.14.5 (Mojave): * Toggle buttons do not show their status * Panel Record: Text is too large for text boxes | |
| Line 391: | Line 459: | 
| Line 394: | Line 463: | 
| Line 395: | Line 465: | 
| * Doesn't close properly on some Linux systems * Focus requests change workspace when processing constantly (Linux systems) * MacOS bugs: * Buttons {Yes,No,Cancel} listed backwards * Record tab: Text of epoch number is too big * Colormap menus: Do not work well on compiled MacOSX 10.9.5 and 10.10 * Canolty maps computation: Fix progress bar | * Doesn't close properly on some Linux systems (SOLVED?) * Focus requests change workspace when processing constantly (Linux systems) (SOLVED?) == Distributed computing == * Options from !FieldTrip: * Loose collection of computers: https://github.com/fieldtrip/fieldtrip/tree/master/peer * Single multicore machine: https://github.com/fieldtrip/fieldtrip/tree/master/engine * Batch system: https://github.com/fieldtrip/fieldtrip/tree/master/qsub * Documentation: https://www.fieldtriptoolbox.org/faq/what_are_the_different_approaches_i_can_take_for_distributed_computing/ * PSOM: http://psom.simexp-lab.org/ * Google: https://www.youtube.com/watch?v=LLMXV3o2FT0 * https://edu.google.com/why-google/case-studies/unc-chapel-hill-gcp/ == Some notes == == Other interesting resources to check for renewal == by tmedani: neurojson: https://neurojson.org/ demo:https://neurojson.org/wiki/index.cgi?Doc/Start/User#Dynamically_downloading_caching_linked_binary_data_resources The Neuroscience Gateway (NSG) https://github.com/sccn/nsgportal/wiki https://www.nsgportal.org/index.html BIDSAPP https://open-neuroscience.com/en/ OPM OPM : https://vbmeg.atr.jp/software/ Soft: https://vbmeg.atr.jp/docs/v22/static/vbmeg2_opm_simulation.html#toc4 https://www.sciencedirect.com/science/article/pii/S1053811923004081 https://www.fieldtriptoolbox.org/tutorial/preprocessing_opm/ https://www.fieldtriptoolbox.org/getting_started/opm_fil/ https://mne.tools/stable/auto_examples/datasets/opm_data.html Potential confusion: sLoreta units, on the tutorial it says the units are A.m and on the forum it says unitless. | 
| Line 404: | Line 499: | 
| * Replace all calls to inpolyhd.m with inpolyhedron.m * bst_bsxfun: After 2016b, we can use directly the scalar operators (./ .* ...) instead of bsxfun. Update bst_bsxfun to skip the use of bsxfun when possible. * Interface scaling: Rewrite class IconLoader to scale only once the icons at startup instead of at each request of an icon (might improve the speed of the rendering of the tree) | * Replace all calls to inpolyhd.m with inpolyhedron.m (10x faster) * Interface scaling: Rewrite class !IconLoader to scale only once the icons at startup instead of at each request of an icon (might improve the speed of the rendering of the tree) | 
| Line 408: | Line 503: | 
| * Interpolations: Use scatteredInterpolant, griddedInterpolant, triangulation.nearestNeighbor (2014b) * bst_warp and channel_project: Use tess_parametrize_new instead of tess_parametrize * Shared kernels: "get bad channels" operation in a different way (reading all the files is too slow) * Optimize bst_get: * Now study and subject have necessarily the same folder name * Replace big switch with separate functions * Fix all the 'todo' blocks in the code | 
What's next
A roadmap to the future developments of Brainstorm.
Contents
Recordings
- Review signals in time-frequency space
- Events processes: Select events names from a list instead of having to type them
- Display CTF coils: Show discs instead of squares
- Sleep scoring wish list (Emily C): - Configurable horizontal lines (for helping detecting visually some thresholds)
- Mouse ruler: Measure amplitude by dragging the mouse.
- Automatic spindle detector
- https://neuroimage.usc.edu/forums/t/page-overlap-while-reviewing-raw-file-a-way-to-set-to-0/11229/13 
 
- RAW file viewer speed (Low priority) : 
 - Consider to change to a format that is faster to read
- Add parameter to make the visual downsampling more or less aggressive
- Keep the filter specifications in memory instead of recomputing for every page 
 (Nice to have)
 
- BioSemi: Add menu "Convert naming system" to rename channels into 10-10 (A1=>FPz) 
- Simulations: https://github.com/lrkrol/SEREEGA(Low priority) 
ECOG/SEEG
- https://www.sciencedirect.com/science/article/pii/S1053811922005559 
- Display (high-priority)(Part SEEG grant): - Group display: Overlay multiple channel files in the same figure, coloring contacts by subject/ROI/Cluster/Electrode name - iEEG tab must be read-only when multiple files (hide configuration controls)
 
- Bad channels: Contacts greyed out instead of ignored (Marcel H, Germany) 
 (To diff between band and not-recorded) > Rendering of SEEG electrodes: Full surface modelling with surface mesh (see Lead-DBS models + code that generates them?)
- Display time in H:M:S instead of S > If there is t0 in H:M:S instead of S > As an option in Display configuration button>x-axis 
- view_leadfield_sensitivity: Add closing surfaces at cortex limits
- Create clusters from anatomical labels (Anne So) :
- Identify contacts in a given anatomical region (volume scout, surface mesh, or label in a volume atlas) / allow extracting the signals from all the contacts in an ROI> As a process to select recordings, then Scouts from Volumen Atlas, Create cluster in channel file, then Extract time series. 
- Group analysis: extract clusters across subjects, display or average signals (see MIA) (Anne So)
 
- Group display: Overlay multiple channel files in the same figure, coloring contacts by subject/ROI/Cluster/Electrode name 
- Spike detection (Need to check for current toolboxes from scratch)(contact Nicolas R)(Mosher J)(iEEG BIDS):
- Automatic segmentation of CT: - Discussed with Samuel and Christian (ins-amu.fr)
- SEEG DEETO Arnulfo 2015: https://bmcbioinformatics.biomedcentral.com/articles/10.1186/s12859-015-0511-6 - Used routinely at Niguarda Hospital + other hospitals worldwide, reliable tool.
- To be used with SEEG-assistant/3DSlicer: https://bmcbioinformatics.biomedcentral.com/articles/10.1186/s12859-017-1545-8 
 
- ECOG Centracchio 2021: https://link.springer.com/content/pdf/10.1007/s11548-021-02325-0.pdf - Classifier on thresholded CT: https://github.com/Jcentracchio/Automated-localization-of-ECoG-electrodes-in-CT-volumes 
 
- SEEG Granados 2018 (no code shared): https://link.springer.com/content/pdf/10.1007/s11548-018-1740-8.pdf 
 
- ECOG: - Project and display contacts on cortex surface should consider the rigidity of the grids: Contacts cannot rotate, and distance between contacts should remain constant across runs
- Method for contacts projection: https://pdfs.semanticscholar.org/f10d/6b899d851f3c4b115404298d7b997cf1d5ab.pdf 
- ECOG: Brain shift: When creating contact positions on a post-implantation image, the brain shift should be taken into account for creating images of the ECOG contacts on the pre-op brain => iELVis (http://ielvis.pbworks.com/w/page/116347253/FrontPage) 
 Normalization MNI? solutions with FieldTrip?
 
- Display CT images: Better brightness/contrast adjustment: https://neuroimage.usc.edu/forums/t/automatic-localization-of-seeg-electrodes/36302/8 Range of values is way diff than ones from MRI. Current color maps are not suitable for CT, need to be improved.Together with processing of CT to get electrode positions. 
- Detection CCEP stim artifacts: Use ImaGIN code ImaGIN_StimDetect https://f-tract.eu/software/imagin/ 
- Add support for modeling non-uniform spaced sEEG electrodes (https://neuroimage.usc.edu/forums/t/feature-request-support-seeg-electrodes-with-non-uniform-spacing/39647/6) 
- VTA and Efields: fast field :https://doi.org/10.1016/j.neuroimage.2020.117330 
Pre-processing
- process_detectbad: - Allow on raw files (for bad channels only)
- Add detection on derivative of the signal (see EEGLAB)
- Document in tutorial Bad channels
- PREP pipeline / EEGLAB (Bigdely-Shamlo 2015)
 
- Improve bad channel/trial detection: - ft_artifact_threshold and ft_rejectartifact
- MNE-Python
- EEGLAB
 
- Integrate with EYE-EEG (Olaf Dimigen) - Reproduce tutorial: https://www.eyetracking-eeg.org/tutorial.html 
- Create EYE-EEG plugin + processes (Raphael Lambert)
- Process: Detect sacades (extended events) + fixations
- Improved ICA
- Eye-movement related potentials
- Use it to guide ICA: http://www2.hu-berlin.de/eyetracking-eeg/ 
 
- ICA: 
 - Automatic classification: ICLabel: https://neuroimage.usc.edu/forums/t/automatic-eeg-ic-ica-classification-for-brainstorm/33785 
- Exploration: Add window with spectral decomposition (useful for muscle artifacts)
- Export IC time series (and then compute their spectrum): solves the problem above
- Import ICA matrices available in EEGLAB .set files
- ICA+machine learning: https://www.ncbi.nlm.nih.gov/pubmed/28497769 
- Automated artifact rejection: https://arxiv.org/abs/1612.08194 
- Spectral representation of ICs
 
- SSP: - Display warning if changing the ChannelFlag while there is a Projector applied 
 
- File format: - Add support to read GDF file format
 
https://github.com/donnchadh/biosig/blob/master/biosig/t200_FileAccess/sload.m
Reproducibility toolbox
- Generate fully reproducible scripts, including all the interactive/graphical parts
- Record all GUI actions as script calls
- Import window: Add button to create the corresponding processing pipeline (to generate script or to edit additional options).
- Adding the list of plugins to the reports
- Better provenance: History fields, uniform file names...
Interface
- Add a warning when computing a forward model with > 100000 sources (check selection) 
- Colormaps: Global colormap max: Should get the maximum across all the open files
- Snapshot: - Save as image / all figures (similar to Movie/all figure)
 
- Contact sheets & movies: use average of time windows instead of single instants, for each picture. 
- Contact sheets: Allow explicit list of times in input (+ display as in MNE-Python with TS)
Database
- Save iHeadModel somewhere in the datbase structure
- Generalize the use of the units (field .DisplayUnits): Save in source files 
Connectivity
- Define names and unit labels for each connectivity metric
- Null models: (Bratislav M) https://www.nature.com/articles/s41583-022-00601-9 
- Connect NxN display: - Graph on sensors: Place M/EEG sensors by location, not by channel order
- Display as image: Add legend of the elements along X and Y axis
- Display as time series: Display warning before trying to open too many signals
- Optimize display: use surface() instead of line() for links? (as in figure_3d/PlotFibers)
 
- Time-resolved correlation/coherence: Display as time bands (as done in wavelet, to have same time axis as data)
Processes
- Add MNE-Python functions: - scikit-learn classifiers
- BEM single layer (John wants to test it)
- https://neuroimage.usc.edu/forums/t/best-way-to-export-to-mne-python/12704/3 
- Reproduce tutorials / examples from FieldTrip and MNE-Python: - FieldTrip ECOG tutorial: http://www.fieldtriptoolbox.org/tutorial/human_ecog 
- Reproduce tutorials from MNE-Python: https://martinos.org/mne/stable/tutorials.html 
 
- Spatial resolution metrics in source space: 
 https://mne.tools/stable/auto_examples/inverse/plot_resolution_metrics.html#sphx-glr-auto-examples-inverse-plot-resolution-metrics-py
- Change the graphic renderer from Matlab
 
- Chronux toolbox : http://chronux.org/ 
- Add FieldTrip functions: - ft_sourceanalysis: - Check noise covariance
- Check all the options of all the methods
- Single trial reconstructions + noise covariance?
- Filters?? http://www.fieldtriptoolbox.org/example/common_filters_in_beamforming 
- Beamformers: Save ftSource.avg.mom 
 http://www.fieldtriptoolbox.org/workshop/meg-uk-2015/fieldtrip-beamformer-demo
- http://www.fieldtriptoolbox.org/tutorial/beamformingextended 
- Baseline? Two inputs?
 
- ft_prepare_heamodel: Add support from BEM surfaces from the Brainstorm database
- ft_volumereslice: http://www.fieldtriptoolbox.org/faq/how_change_mri_orientation_size_fov 
- ft_freqanalysis
- ft_combineplanar
 
- ft_sourceanalysis: 
- Optimization: - Use CUDA for speeding up some operations (filtering, wavelets, etc)
- Use Matlab Coder to optimize: Wavelets, bandpass filter, sinusoid removal
 
- Pipeline editor: - Bug: After "convert to continuous", the time of the following processes should change
- Add loops over subjects/conditions/trial groups
- Events: Allow selection from a drop-down list (similar to option "channelname" in panel_process_selection)
 
- ITC: Inter-trial coherence (see MNE reports for group tutorial) 
 http://www.sciencedirect.com/science/article/pii/S1053811916304232
- Remove line noise: http://www.nitrc.org/projects/cleanline 
- Time-frequency: - Optimization: bst_timefreq (around l.136), remove evoked in source space: Average should be computed in sensor space instead of source space (requested by Dimitrios)
- Short-time Fourier transform: http://www.mikexcohen.com/lectures.html 
- Hilbert with time bands very slow on very long files (eg. 3600s at 1000Hz) because the time vector is still full (10^7 values): save compressed time vector instead.
- When normalizing with baseline: Propagate with the edge effects marked in TFmask
- Allow running TF on montages
- Bug when computing TF on constrained and unconstrained scouts at the same time (in mixed head models for instance): uses only the constrained information and doesn't sum the 3 orientations for the unconstrained regions.
- requested feature from the forum:
 
- * https://neuroimage.usc.edu/forums/t/event-export-and-process-find-maximum-value-amplitude/41911/2 
- * https://neuroimage.usc.edu/forums/t/custom-process-that-involves-merging-of-channels/40638 
- * https://neuroimage.usc.edu/forums/t/swloreta-for-source-localization/41882/4 
Anatomy
- Display parcellation values (matrices) in 3D and 2D.
- Import SimNIBS4: Use final_tissues_LUT.txt instead of fixed list of tissues: https://neuroimage.usc.edu/forums/t/removing-a-lesioned-area/38414/20 
- Simple-brain-plot: https://github.com/dutchconnectomelab/Simple-Brain-Plot 
- MNI normalization: More options: - DARTEL / SHOOT
- BrainSuite (wait for Anand) 
- Import from SimNIBS (Conform2MNI_nonl.nii.gz, MNI2Conform_nonl.nii.gz)
 
- MRI Viewer: - Adjust CT contrast better: https://neuroimage.usc.edu/forums/t/automatic-localization-of-seeg-electrodes/36302/10 
- Pan in zoomed view (shift + click + move?)
- Zoom in/out with mouse (shift + scroll?)
- Ruler tool to measure distances
- Display scouts as additional volumes
- Render surface envelope in the MRI as a thin line instead of the full interpolation matrix 
 Or use inpolyhedron to get a surface mask and then erode it to get the volume envelope
- Surface>Volume interpolation: Use spm_mesh_to_grid instead of tess_tri_interp 
 
- Defacing: - https://afni.nimh.nih.gov/pub/dist/doc/htmldoc/tutorials/refacer/refacer_run.html 
- Removing MNI face mask using MNI coordinates (mask available ICMB152 2023b)
 
- Bug import anatomy: Requested nVert > high-resolution cortex surface: Creates an empty cortex_0V 
- BrainSuite: - Use same colors for left and right for anatomical atlases
- Use for volume coregistration (rigid / non-rigid)
- USCBrain: Add default electrodes positions
- Remove BrainSuite1 when not needed anymore 
 
- Brain2mesh: Add import of 10-10 positions
- Templates for different ages: - MNI: https://www.bic.mni.mcgill.ca/ServicesAtlases/NIHPD-obj1 
- Pediatric head atlases: https://www.pedeheadmod.net/pediatric-head-atlases-v1-2/ 
- https://www.biorxiv.org/content/biorxiv/early/2020/02/09/2020.02.07.939447.full.pdf 
- John Richards: https://www.nitrc.org/frs/?group_id=1361 
- Neurodev database: https://jerlab.sc.edu/projects/neurodevelopmental-mri-database/ 
 
- Scouts: - Display edges in the middle of the faces instead of the vertices
 
- Parcellating volume grids: scikit-learn.cluster.Ward
- Geodesic distance calculations: 
 https://www.mathworks.com/matlabcentral/fileexchange/6110-toolbox-fast-marching
- Improving the registration between EEG and anatomy templates: - Warping: Improve the basic alignment of the digitized electrodes on the templat, possibly with Cz and other anatomical landmarks
- EEG template positions: rework using a standardized Cz position (+ other landmarks)
 
Forward modeling
- DUNEuro/FEM: - Add lesion mask to SimNIBS: https://simnibs.github.io/simnibs/build/html/documentation/command_line/add_tissues_to_upsampled.html#add-tissues-to-upsampled-doc 
- GeomtryAdapted: Buggy? 
- Display differences between leadfields: amplitude of difference (right-click > Compare) 
- Display sensitivity on FEM surface
 
- OpenMEEG: Detect bad results + exclude from leadfield
- BEM single sphere: Get implementation from MNE-Python (John Mosher)
- Add eyes models to attract eye activity (Put a dipole in each eye)
Source modeling
- Reproduce results in "Simultaneous human intracerebral stimulation and HD-EEG, ground-truth for source localization methods": https://www.nature.com/articles/s41597-020-0467-x 
- eLORETA instead of sLORETA? - https://neuroimage.usc.edu/forums/t/compute-eeg-sources-with-sloreta/13425/6 
- https://neuroimage.usc.edu/forums/t/loreta-and-source-localization/30525 
- "eLORETA algorithm is available in the MEG/EEG Toolbox of Hamburg (METH)": https://www.biorxiv.org/content/biorxiv/early/2019/10/17/809285.full.pdf 
- Point-spread functions (PSFs) and cross-talk functions: https://mne.tools/stable/auto_examples/inverse/plot_psf_ctf_vertices.html#sphx-glr-auto-examples-inverse-plot-psf-ctf-vertices-py https://www.biorxiv.org/content/biorxiv/early/2019/06/18/672956.full.pdf 
 
- Dipoles: - Display dipoles in MRI viewer
- panel_dipoles: Doesn't work with multiple figures (SOLVED?)
 
- Project sources: Very poor algorithm to project sub-cortical regions and cerebellum
- Maximum: - Menu Sources > Maximum value: Doesn't work with volume or mixed head models 
- Panel Get coordinates: Add button "find maximum"
- Sources on surface: Display peak regions over time (time = color) => A.Gramfort 
 
- Volume grid: - Optimize: 3D display (better than 3x3 cubes)
- Optimize: vol_dilate (with 26 neighbors)
 
Statistics
- Stat on unconstrained sources?
- Stat/time series: Hide lines going down to zero (Dimitrios: https://neuroimage.usc.edu/forums/t/common-source-activation-across-subjects-and-conditions/1152/21) 
- Cluster stat: Add frequency selection option
- ANOVA: - Write panel similar to Process1 and Process2
- Output = 1 file per effect, all grouped in a node "ANOVA"
- Display several ANOVA maps (from several files) on one single figure, using a "graphic accumulator", towards which one can send any type of graphic object
 
- Multivariate stim-response analysis: https://github.com/mickcrosse/mTRF-Toolbox 
Input / output
- BIDS import: - Add option to process to specify the protocol name
- Disable logging of sub-processes (reloading the previous report should only show process_import_bids)
- Full support for iEEG and EEG
- Read real fiducials (OMEGA) / transformation matrices:
- Use BIDS-Matlab?
 
- Test datasets: - See list of test datasets in process_import_bids.m
- ds004085 / ds004473: Check response epoch + BUG with coordinate interpretation
 
- BIDS export: - EEG, iEEG: Add events.tsv, channel.tsv, electrodes.tsv
- Anatomy: Add t1w.json (including fiducials)
- Use BIDS-Matlab?
 
- EDF+ reader: Add resampling of channels with different sampling rates
- DICOM converter: - Add dcm2nii (MRICron)
- Add MRIConvert
 
- SPM .mat/.dat: Fix the import of the EEG/SEEG coordinates
- EEG File formats: 
 - Persyst .lay: https://github.com/ieeg-portal/Persyst-Reader 
- Nervus .eeg: https://github.com/ieeg-portal/Nervus-Reader 
- Biopac .acq: https://github.com/ieeg-portal/Biopac-Reader 
- BCI2000 Input (via EEGLAB plugin)
 
- 4D file format: - Use reader from MNE-Python: mne.io.read_raw_kit (skip Yokogawa slow library)
- Reference gradiometers: Keep the orientation of the first or second coil?
- Reference gradiometers: Add the sensor definition from coil_def.dat
- Validate with phantom recordings that noise compensation is properly taken into account
- The noise compensation is considered to be always applied on the recordings, not sure this assumption is always correct
- 4D phantom tutorial (JM Badier?)
 
- BST-BIN: Add compression to .bst
- MINC MRI: Add support for "voxel to world" transformation (vox2ras) similarly to .nii
Distribution
- Java-free Matlab: All references of functions below must be removed - JavaFrame: screencapture.m (used for screen captures of videos) 
- Actxcontrol: Used for video-EEG - uihtml + JavaScript callbacks? 
- ActiveX in .NET app?
- Pure Java framce + VLC java plugin?
- Other video player?
 
- Javacomponent: - mri_editMask
- figure_mri
- process_bandpass
 
- List .jar files used from Matlab distribution (e.g. dom) => Check all the import calls 
 
- Cleanup GitHub repository: - Move external I/O libraries as plugins: - mne-matlab
- CEDS64ML
- edfimport
- eeprobe
- son
- ricoh
- yokogawa
 
 
Documentation
- All tutorial datasets in BIDS (including introduction tutorials)
- Deface the MRIs of all the tutorials
- Count GitHub clones in the the download stats 
- MNE-Python 1.0: Test and update install documentation
- Tutorial OMEGA/BIDS: - Update the organization of derivatives folder (full FS folders)
- Download example datasets directly from the OMEGA repository
 
- New tutorials: 
 - Other public datasets: https://github.com/INCF/BIDS-examples/tree/bep008_meg/ 
- EEG/research
- Cam-CAN database: https://camcan-archive.mrc-cbu.cam.ac.uk/dataaccess/<<BR>>(download new datasets, including maxfiltered files and manual fiducial placements) 
- MEG steady-state / high-gamma visual / frequency tagging
- Reproduce results from "Simultaneous human intracerebral stimulation and HD-EEG, ground-truth for source localization methods": https://www.nature.com/articles/s41597-020-0467-x 
- Stand-alone ICA tutorial
- https://archive.physionet.org/ [data and tools] 
 
Current bugs
- Image viewer: - Difficult to get to 100%
- Buggy on some systems
 
- 2DLayout: - (TF) Units are weird with % values
- (TF) Difficult to navigate in frequencies: Scaling+changing frequency resets the scaling
 
- Progress bar: - Doesn't close properly on some Linux systems (SOLVED?)
- Focus requests change workspace when processing constantly (Linux systems) (SOLVED?)
 
Distributed computing
- Options from FieldTrip: - Loose collection of computers: https://github.com/fieldtrip/fieldtrip/tree/master/peer 
- Single multicore machine: https://github.com/fieldtrip/fieldtrip/tree/master/engine 
- Batch system: https://github.com/fieldtrip/fieldtrip/tree/master/qsub 
- Documentation: https://www.fieldtriptoolbox.org/faq/what_are_the_different_approaches_i_can_take_for_distributed_computing/ 
 
Some notes
== Other interesting resources to check for renewal == by tmedani:
neurojson: https://neurojson.org/ demo:https://neurojson.org/wiki/index.cgi?Doc/Start/User#Dynamically_downloading_caching_linked_binary_data_resources
The Neuroscience Gateway (NSG) https://github.com/sccn/nsgportal/wiki https://www.nsgportal.org/index.html
BIDSAPP
https://open-neuroscience.com/en/
OPM OPM : https://vbmeg.atr.jp/software/ Soft: https://vbmeg.atr.jp/docs/v22/static/vbmeg2_opm_simulation.html#toc4 https://www.sciencedirect.com/science/article/pii/S1053811923004081 https://www.fieldtriptoolbox.org/tutorial/preprocessing_opm/ https://www.fieldtriptoolbox.org/getting_started/opm_fil/ https://mne.tools/stable/auto_examples/datasets/opm_data.html
Potential confusion: sLoreta units, on the tutorial it says the units are A.m and on the forum it says unitless.
Geeky programming details
- Replace all calls to inpolyhd.m with inpolyhedron.m (10x faster)
- Interface scaling: Rewrite class IconLoader to scale only once the icons at startup instead of at each request of an icon (might improve the speed of the rendering of the tree) 
- Processes with "radio" and "radio_line" options: Replace with "radio_label" and "radio_linelabel"

