0.8.1

Released September 2021

HIGHLIGHTS

NEW

Fixes

Enhancements

  • nilearn.datasets.load_mni152_template resamples now the template to a preset resolution different from the resolution of the original template, i.e. 1mm. The default resolution is 2mm, which means that the new template is resampled to the resolution of the old template. Nevertheless, the shape of the template changed from (91, 109, 91) to (99, 117, 95); the affine also changed from array([[-2., 0., 0., 90.], [0., 2., 0., -126.], [0., 0., 2., -72.], [0., 0., 0., 1.]]) to array([[1., 0., 0., -98.], [0., 1., 0., -134.], [0., 0., 1., -72.], [0., 0., 0., 1.]]). Additionally, the new template has also been rescaled; whereas the old one varied between 0 and 8339, the new one varies between 0 and 255.

  • nilearn.datasets.load_mni152_brain_mask accepts now the parameter resolution, which will set the resolution of the template used for the masking.

  • nilearn.masking.compute_brain_mask accepts now as input the whole-brain, 1mm-resolution, MNI152 T1 template instead of the averaged, whole-brain, 2mm-resolution MNI152 T1 template; it also accepts as input the grey-matter and white-matter ICBM152 1mm-resolution templates dated from 2009.

  • Common parts of docstrings across Nilearn can now be filled automatically using the decorator nilearn._utils.fill_doc. This can be applied to common function parameters or common lists of options for example. The standard parts are defined in a single location (nilearn._utils.docs.py) which makes them easier to maintain and update. (See #2875)

  • The data_dir argument can now be either a pathlib.Path or a string. This extension affects datasets and atlas fetchers.

Changes

  • The version of the script jquery.min.js was bumped from 3.3.1 to 3.6.0 due to potential vulnerability issues with versions < 3.5.0.

0.8.0

Released June 2021

HIGHLIGHTS

Warning

Python 3.5 is no longer supported. We recommend upgrading to Python 3.8.

Support for Nibabel 2.x is deprecated and will be removed in the 0.9 release.
Users with a version of Nibabel < 3.0 will be warned at their first Nilearn import.

Minimum supported versions of packages have been bumped up:
- Numpy – v1.16
- SciPy – v1.2
- Scikit-learn – v0.21
- Nibabel – v2.5
- Pandas – v0.24

NEW

  • nilearn.signal.clean accepts new parameter sample_mask. shape: (number of scans - number of volumes removed, ) Masks the niimgs along time/fourth dimension to perform scrubbing (remove volumes with high motion) and/or non-steady-state volumes. Masking is applied before signal cleaning.

  • All inherent classes of nilearn.input_data.BaseMasker can use parameter sample_mask for sub-sample masking.

  • nilearn.input_data.NiftiLabelsMasker can now generate HTML reports in the same way as nilearn.input_data.NiftiMasker. The report shows the regions defined by the provided label image and provide summary statistics on each region (name, volume…). If a functional image was provided to fit, the middle image is plotted with the regions overlaid as contours. Finally, if a mask is provided, its contours are shown in green.

Fixes

  • Convert references in signal.py, atlas.py, func.py, neurovault.py, and struct.py to use footcite / footbibliography.

  • Fix detrending and temporal filtering order for confounders in nilearn.signal.clean, so that these operations are applied in the same order as for the signals, i.e., first detrending and then temporal filtering (https://github.com/nilearn/nilearn/issues/2730).

  • Fix number of attributes returned by the nilearn.glm.first_level.FirstLevelModel._get_voxelwise_model_attribute method in the first level model. It used to return only the first attribute, and now returns as many attributes as design matrices.

  • Plotting functions that show a stack of slices from a 3D image (e.g. nilearn.plotting.plot_stat_map) will now plot the slices in the user specified order, rather than automatically sorting into ascending order (https://github.com/nilearn/nilearn/issues/1155).

  • Fix the axes zoom on plot_img_on_surf function so brain would not be cutoff, and edited function so less white space surrounds brain views & smaller colorbar using gridspec (https://github.com/nilearn/nilearn/pull/2798).

  • Fix inconsistency in prediction values of Dummy Classifier for Decoder object (https://github.com/nilearn/nilearn/issues/2767).

Enhancements

Changes

  • Python 3.5 is no longer supported. We recommend upgrading to Python 3.7.

  • Support for Nibabel 2.x is now deprecated and will be removed in the 0.9 release. Users with a version of Nibabel < 3.0 will be warned at their first Nilearn import.

  • Minimum supported versions of packages have been bumped up:

    • Numpy – v1.16

    • SciPy – v1.2

    • Scikit-learn – v0.21

    • Nibabel – v2.5

    • Pandas – v0.24

  • Function sym_to_vec from nilearn.connectome was deprecated since release 0.4 and has been removed.

  • Fetcher nilearn.datasets.fetch_nyu_rest is deprecated since release 0.6.2 and has been removed.

  • nilearn.input_data.NiftiMasker replaces sessions with runs and deprecates attribute sessions in 0.9.0. Match the relevant change in nilearn.signal.clean.

0.7.1

Released March 2021

HIGHLIGHTS

NEW

  • New atlas fetcher nilearn.datasets.fetch_atlas_difumo to download Dictionaries of Functional Modes, or “DiFuMo”, that can serve as atlases to extract functional signals with different dimensionalities (64, 128, 256, 512, and 1024). These modes are optimized to represent well raw BOLD timeseries, over a with range of experimental conditions.

  • nilearn.glm.Contrast.one_minus_pvalue was added to ensure numerical stability of p-value estimation. It computes 1 - p-value using the Cumulative Distribution Function in the same way as nilearn.glm.Contrast.p_value computes the p-value using the Survival Function.

Fixes

Enhancements

0.7.0

Released November 2020

HIGHLIGHTS

Warning

Minimum required version of Joblib is now 0.12.

NEW

  • Nilearn now includes the functionality of Nistats. Here’s a guide to replacing Nistats imports to work in Nilearn.

  • New decoder object nilearn.decoding.Decoder (for classification) and nilearn.decoding.DecoderRegressor (for regression) implement a model selection scheme that averages the best models within a cross validation loop. The resulting average model is the one used as a classifier or a regressor. These two objects also leverage the NiftiMaskers to provide a direct interface with the Nifti files on disk.

  • New FREM object nilearn.decoding.FREMClassifier (for classification) and nilearn.decoding.FREMRegressor (for regression) extend the decoder object pipeline with one fast clustering step at the beginning (yielding an implicit spatial regularization) and aggregates a high number of estimators trained on various splits of the training set. This returns a state-of-the-art decoding pipeline at a low computational cost. These two objects also leverage the NiftiMaskers to provide a direct interface with the Nifti files on disk.

  • Plot events file Use nilearn.plotting.plot_event to visualize events file. The function accepts the BIDS events file read using pandas utilities.

  • Plotting function nilearn.plotting.plot_roi can now plot ROIs in contours with view_type argument.

  • New plotting function nilearn.plotting.plot_carpet generates a “carpet plot” (also known as a “Power plot” or a “grayplot”), for visualizing global patterns in 4D functional data over time.

  • New plotting function nilearn.plotting.plot_img_on_surf generates multiple views of nilearn.plotting.plot_surf_stat_map in a single figure.

  • nilearn.plotting.plot_markers shows network nodes (markers) on a glass brain template and color code them according to provided nodal measure (i.e. connection strength). This function will replace nilearn.plotting.plot_connectome_strength.

  • New plotting function nilearn.plotting.plot_surf_contours plots the contours of regions of interest on the surface, optionally overlaid on top of a statistical map.

  • The position annotation on the plot methods now implements the decimals option to enable annotation of a slice coordinate position with the float.

  • New example in Cortical surface-based searchlight decoding to demo how to do cortical surface-based searchlight decoding with Nilearn.

  • confounds or additional regressors for design matrix can be specified as numpy arrays or pandas DataFrames interchangeably

  • The decomposition estimators will now accept argument per_component with score method to explain the variance for each component.

Fixes

  • nilearn.input_data.NiftiLabelsMasker no longer ignores its mask_img

  • nilearn.masking.compute_brain_mask has replaced nilearn.masking.compute_gray_matter_mask. Features remained the same but some corrections regarding its description were made in the docstring.

  • the default background (MNI template) in plotting functions now has the correct orientation; before left and right were inverted.

  • first level modelling can deal with regressors having multiple events which share onsets or offsets. Previously, such cases could lead to an erroneous baseline shift.

  • nilearn.mass_univariate.permuted_ols no longer returns transposed t-statistic arrays when no permutations are performed.

  • Fix decomposition estimators returning explained variance score as 0. based on all components i.e., when per_component=False.

  • Fix readme file of the Destrieux 2009 atlas.

Changes

0.6.2

ENHANCEMENTS

  • Generated documentation now includes Binder links to launch examples interactively in the browser

  • nilearn.input_data.NiftiSpheresMasker now has an inverse transform, projecting spheres to the corresponding mask_img.

Fixes

  • More robust matplotlib backend selection

  • Typo in example fixed

Changes

  • Atlas nilearn.datasets.fetch_nyu_rest has been deprecated and will be removed in Nilearn 0.8.0 .

Contributors

The following people contributed to this release:

Elizabeth DuPre
Franz Liem
Gael Varoquaux
Jon Haitz Legarreta Gorroño
Joshua Teves
Kshitij Chawla (kchawla-pi)
Zvi Baratz
Simon R. Steinkamp

0.6.1

ENHANCEMENTS

  • html pages use the user-provided plot title, if any, as their title

Fixes

  • Fetchers for developmental_fmri and localizer datasets resolve URLs correctly.

Contributors

The following people contributed to this release:

Elizabeth DuPre
Jerome Dockes
Kshitij Chawla (kchawla-pi)

0.6.0

Released December 2019

HIGHLIGHTS

Warning

Python2 and 3.4 are no longer supported. We recommend upgrading to Python 3.6 minimum.

Support for Python3.5 will be removed in the 0.7.x release.
Users with a Python3.5 environment will be warned at their first Nilearn import.

joblib is now a dependency

Minimum supported versions of packages have been bumped up.
- Matplotlib – v2.0
- Scikit-learn – v0.19
- Scipy – v0.19

NEW

  • A new method for nilearn.input_data.NiftiMasker instances for generating reports viewable in a web browser, Jupyter Notebook, or VSCode.

  • A new function nilearn.image.get_data to replace the deprecated nibabel method Nifti1Image.get_data. Now use nilearn.image.get_data(img) rather than img.get_data(). This is because Nibabel is removing the get_data method. You may also consider using the Nibabel Nifti1Image.get_fdata, which returns the data cast to floating-point. See https://github.com/nipy/nibabel/wiki/BIAP8 . As a benefit, the get_data function works on niimg-like objects such as filenames (see http://nilearn.github.io/manipulating_images/input_output.html ).

  • Parcellation method ReNA: Fast agglomerative clustering based on recursive nearest neighbor grouping. Yields very fast & accurate models, without creation of giant clusters. nilearn.regions.ReNA

  • Plot connectome strength Use nilearn.plotting.plot_connectome_strength to plot the strength of a connectome on a glass brain. Strength is absolute sum of the edges at a node.

  • Optimization to image resampling

  • New brain development fMRI dataset fetcher nilearn.datasets.fetch_development_fmri can be used to download movie-watching data in children and adults. A light-weight dataset implemented for teaching and usage in the examples. All the connectivity examples are changed from ADHD to brain development fmri dataset.

ENHANCEMENTS

CHANGES

  • nilearn.plotting.plot_img now has explicit keyword arguments bg_img, vmin and vmax to control the background image and the bounds of the colormap. These arguments were already accepted in kwargs but not documented before.

FIXES

Lots of other fixes in documentation and examples. More detailed change list follows:

0.6.0rc NEW — .. warning:

- :func:`nilearn.plotting.view_connectome` no longer accepts old parameter names.
  Instead of `coords`, `threshold`, `cmap`, and `marker_size`,
  use `node_coords`, `edge_threshold`, `edge_cmap`, `node_size` respectively.

- :func:`nilearn.plotting.view_markers` no longer accepts old parameter names.
  Instead of `coord` and `color`, use `marker_coords` and `marker_color` respectively.
  • Support for Python3.5 will be removed in the 0.7.x release. Users with a Python3.5 environment will be warned at their first Nilearn import.

Changes

Fixes

Contributors

The following people contributed to this release (in alphabetical order):

Chris Markiewicz
Dan Gale
Daniel Gomez
Derek Pisner
Elizabeth DuPre
Eric Larson
Gael Varoquaux
Jerome Dockes
JohannesWiesner
Kshitij Chawla (kchawla-pi)
Paula Sanz-Leon
ltetrel
ryanhammonds

0.6.0b0

Released November 2019

Warning

Python2 and 3.4 are no longer supported. Pip will raise an error in these environments.
Minimum supported version of Python is now 3.5 .
We recommend upgrading to Python 3.6 .

NEW

Changes

Fixes

Contributors

The following people contributed to this release (in alphabetical order):

Jake Vogel
Jerome Dockes
Kshitij Chawla (kchawla-pi)
Roberto Guidotti

0.6.0a0

Released October 2019

NEW

Warning

Python2 and 3.4 are no longer supported. We recommend upgrading to Python 3.6 minimum.

Minimum supported versions of packages have been bumped up.
- Matplotlib – v2.0
- Scikit-learn – v0.19
- Scipy – v0.19
  • A new method for nilearn.input_data.NiftiMasker instances for generating reports viewable in a web browser, Jupyter Notebook, or VSCode.

  • joblib is now a dependency

  • Parcellation method ReNA: Fast agglomerative clustering based on recursive nearest neighbor grouping. Yields very fast & accurate models, without creation of giant clusters. nilearn.regions.ReNA

  • Plot connectome strength Use nilearn.plotting.plot_connectome_strength to plot the strength of a connectome on a glass brain. Strength is absolute sum of the edges at a node.

  • Optimization to image resampling nilearn.image.resample_img has been optimized to pad rather than resample images in the special case when there is only a translation between two spaces. This is a common case in nilearn.input_data.NiftiMasker when using the mask_strategy=”template” option for brains in MNI space.

  • New brain development fMRI dataset fetcher nilearn.datasets.fetch_development_fmri can be used to download movie-watching data in children and adults; a light-weight dataset implemented for teaching and usage in the examples.

  • New example in examples/05_advanced/plot_age_group_prediction_cross_val.py to compare methods for classifying subjects into age groups based on functional connectivity. Similar example in examples/03_connectivity/plot_group_level_connectivity.py simplified.

  • Merged examples/03_connectivity/plot_adhd_spheres.py and examples/03_connectivity/plot_sphere_based_connectome.py to remove duplication across examples. The improved examples/03_connectivity/plot_sphere_based_connectome.py contains concepts previously reviewed in both examples.

  • Merged examples/03_connectivity/plot_compare_decomposition.py and examples/03_connectivity/plot_canica_analysis.py into an improved examples/03_connectivity/plot_compare_decomposition.py.

  • The Localizer dataset now follows the BIDS organization.

Changes

Fixes

Contributors

The following people contributed to this release (in alphabetical order):

Alexandre Abraham
Alexandre Gramfort
Ana Luisa
Ana Luisa Pinho
Andrés Hoyos Idrobo
Antoine Grigis
BAZEILLE Thomas
Bertrand Thirion
Colin Reininger
Céline Delettre
Dan Gale
Daniel Gomez
Elizabeth DuPre
Eric Larson
Franz Liem
Gael Varoquaux
Gilles de Hollander
Greg Kiar
Guillaume Lemaitre
Ian Abenes
Jake Vogel
Jerome Dockes
Jerome-Alexis Chevalier
Julia Huntenburg
Kamalakar Daddy
Kshitij Chawla (kchawla-pi)
Mehdi Rahim
Moritz Boos
Sylvain Takerkart

0.5.2

Released April 2019

NEW

Warning

This is the last release supporting Python2 and 3.4 .
The lowest Python version supported is now Python3.5.
We recommend switching to Python3.6 .

Fixes

  • Plotting .mgz files in MNE broke in 0.5.1 and has been fixed.

Contributors

The following people contributed to this release:

11  Kshitij Chawla (kchawla-pi)
 3  Gael Varoquaux
 2  Alexandre Gramfort

0.5.1

Released April 2019

NEW

  • Support for Python2 & Python3.4 will be removed in the next release. We recommend Python 3.6 and up. Users with a Python2 or Python3.4 environment will be warned at their first Nilearn import.

  • Calculate image data dtype from header information

  • New display mode ‘tiled’ which allows 2x2 plot arrangement when plotting three cuts (see Plotting brain images).

  • NiftiLabelsMasker now consumes less memory when extracting the signal from a 3D/4D image. This is especially noteworthy when extracting signals from large 4D images.

  • New function nilearn.datasets.fetch_atlas_schaefer_2018

  • New function nilearn.datasets.fetch_coords_seitzman_2018

Changes

Fixes

  • Example plot_seed_to_voxel_correlation now really saves z-transformed maps.

  • region_extractor.connected_regions and regions.RegionExtractor now correctly use the provided mask_img.

  • load_niimg no longer drops header if dtype is changed.

  • NiftiSpheresMasker no longer silently ignores voxels if no mask_img is specified.

  • Interactive brainsprites generated from view_img are correctly rendered in Jupyter Book.

Known Issues

Contributors

The following people contributed to this release:

2  Bertrand Thirion
90  Kshitij Chawla (kchawla-pi)
22  fliem
16  Jerome Dockes
11  Gael Varoquaux
8  Salma Bougacha
7  himanshupathak21061998
2  Elizabeth DuPre
1  Eric Larson
1  Pierre Bellec

0.5.0

Released November 2018

NEW

interactive plotting functions, eg for use in a notebook.

Note

nilearn.plotting.view_img was nilearn.plotting.view_stat_map in alpha and beta releases.

Minimum supported versions of packages have been bumped up.
  • scikit-learn – v0.18

  • scipy – v0.17

  • pandas – v0.18

  • numpy – v1.11

  • matplotlib – v1.5.1

Nilearn Python2 support is being removed in the near future.

Users with a Python2 environment will be warned at their first Nilearn import.

Additional dataset downloaders for examples and tutorials.

ENHANCEMENTS

nilearn.image.clean_img now accepts a mask to restrict the cleaning of the image, reducing memory load and computation time.

NiftiMaskers now have a dtype parameter, by default keeping the same data type as the input data.

Displays by plotting functions can now add a scale bar (see Plotting brain images)

IMPROVEMENTS

  • Lots of other fixes in documentation and examples.

  • A cleaner layout and improved navigation for the website, with a better introduction.

  • Dataset fetchers are now more reliable, less verbose.

  • Searchlight().fit() now accepts 4D niimgs.

  • Anaconda link in the installation documentation updated.

  • Scipy is listed as a dependency for Nilearn installation.

Notable Changes

Default value of t_r in nilearn.signal.clean and nilearn.image.clean_img is None and cannot be None if low_pass or high_pass is specified.

Lots of changes and improvements. Detailed change list for each release follows.

0.5.0 rc

Highlights

nilearn.plotting.view_img (formerly nilearn.plotting.view_stat_map in Nilearn 0.5.0 pre-release versions) generates significantly smaller notebooks and HTML pages while getting a more consistent look and feel with Nilearn’s plotting functions. Huge shout out to Pierre Bellec (pbellec) for making a great feature awesome and for sportingly accommodating all our feedback.

nilearn.image.clean_img now accepts a mask to restrict the cleaning of

the image. This approach can help to reduce the memory load and computation time. Big thanks to Michael Notter (miykael).

Enhancements

Changes

  • Default value of t_r in nilearn.signal.clean and nilearn.image.clean_img is changed from 2.5 to None. If low_pass or high_pass is specified, then t_r needs to be specified as well otherwise it will raise an error.

  • Order of filters in nilearn.signal.clean and nilearn.image.clean_img has changed to detrend, low- and high-pass filter, remove confounds and standardize. To ensure orthogonality between temporal filter and confound removal, an additional temporal filter will be applied on the confounds before removing them. This is according to Lindquist et al. (2018).

  • nilearn.image.clean_img now accepts a mask to restrict the cleaning of the image. This approach can help to reduce the memory load and computation time.

  • nilearn.plotting.view_img is now using the brainsprite.js library, which results in much smaller notebooks or html pages. The interactive viewer also looks more similar to the plots generated by nilearn.plotting.plot_stat_map, and most parameters found in plot_stat_map are now supported in view_img.

Contributors

The following people contributed to this release:

15 Gael Varoquaux
114 Pierre Bellec
30 Michael Notter
28 Kshitij Chawla (kchawla-pi)
4 Kamalakar Daddy
4 himanshupathak21061998
1 Horea Christian
7 Jerome Dockes

0.5.0 beta

Highlights

Nilearn Python2 support is being removed in the near future. Users with a Python2 environment will be warned at their first Nilearn import.

Enhancements

Displays created by plotting functions can now add a scale bar

to indicate the size in mm or cm (see Plotting brain images), contributed by Oscar Esteban

Colorbars in plotting functions now have a middle gray background

suitable for use with custom colormaps with a non-unity alpha channel. Contributed by Eric Larson (larsoner)

Loads of fixes and quality of life improvements

  • A cleaner layout and improved navigation for the website, with a better introduction.

  • Less warnings and verbosity while using certain functions and during dataset downloads.

  • Improved backend for the dataset fetchers means more reliable dataset downloads.

  • Some datasets, such as the ICBM, are now compressed to take up less disk space.

Fixes

  • Searchlight().fit() now accepts 4D niimgs. Contributed by Dan Gale (danjgale).

  • plotting.view_markers.open_in_browser() in js_plotting_utils fixed

  • Brainomics dataset has been replaced in several examples.

  • Lots of other fixes in documentation and examples.

Changes

  • In nilearn.regions.img_to_signals_labels, the See Also section in documentation now also points to NiftiLabelsMasker and NiftiMapsMasker

  • Scipy is listed as a dependency for Nilearn installation.

  • Anaconda link in the installation documentation updated.

Contributors

The following people contributed to this release:

58  Gael Varoquaux
115  Kshitij Chawla (kchawla-pi)
15  Jerome Dockes
14  oesteban
10  Eric Larson
6  Kamalakar Daddy
3  Bertrand Thirion
5  Alexandre Abadie
4  Sourav Singh
3  Alex Rothberg
3  AnaLu
3  Demian Wassermann
3  Horea Christian
3  Jason Gors
3  Jean Remi King
3  MADHYASTHA Meghana
3  SRSteinkamp
3  Simon Steinkamp
3  jerome-alexis_chevalier
3  salma
3  sfvnMAC
2  Akshay
2  Daniel Gomez
2  Guillaume Lemaitre
2  Pierre Bellec
2  arokem
2  erramuzpe
2  foucault
2  jehane
1  Sylvain LANNUZEL
1  Aki Nikolaidis
1  Christophe Bedetti
1  Dan Gale
1  Dillon Plunkett
1  Dimitri Papadopoulos Orfanos
1  Greg Operto
1  Ivan Gonzalez
1  Yaroslav Halchenko
1  dtyulman

0.5.0 alpha

This is an alpha release: to download it, you need to explicitly ask for the version number:

pip install nilearn==0.5.0a0

Highlights

  • Minimum supported versions of packages have been bumped up.
    • scikit-learn – v0.18

    • scipy – v0.17

    • pandas – v0.18

    • numpy – v1.11

    • matplotlib – v1.5.1

  • New interactive plotting functions, eg for use in a notebook.

Enhancements

Changes

  • nilearn.datasets.fetch_surf_fsaverage5 is deprecated and will be removed in a future release. Use nilearn.datasets.fetch_surf_fsaverage, with the parameter mesh=”fsaverage5” (the default) instead.

  • fsaverage5 surface data files are now shipped directly with Nilearn. Look to issue #1705 for discussion.

  • sklearn.cross_validation and sklearn.grid_search have been replaced by sklearn.model_selection in all the examples.

  • Colorbars in plotting functions now have a middle gray background suitable for use with custom colormaps with a non-unity alpha channel.

Contributors

The following people contributed to this release:

49  Gael Varoquaux
180  Jerome Dockes
57  Kshitij Chawla (kchawla-pi)
38  SylvainLan
36  Kamalakar Daddy
10  Gilles de Hollander
4  Bertrand Thirion
4  MENUET Romuald
3  Moritz Boos
1  Peer Herholz
1  Pierre Bellec

0.4.2

Few important bugs fix release for OHBM conference.

Changes

Bug fixes

  • Fix bug with input repetition time (TR) which had no effect in signal cleaning. Fixed by Pradeep Raamana.

  • Fix issues with signal extraction on list of 3D images in nilearn.regions.Parcellations.

  • Fix issues with raising AttributeError rather than HTTPError in datasets fetching utilities. By Jerome Dockes.

  • Fix issues in datasets testing function uncompression of files. By Pierre Glaser.

0.4.1

This bug fix release is focused on few bug fixes and minor developments.

Enhancements

Changes

Bug fixes

  • Fix issues using nilearn.plotting.plot_connectome when string is passed in node_color with display modes left and right hemispheric cuts in the glass brain.

  • Fix bug while plotting only coordinates using add_markers on glass brain. See issue #1595

  • Fix issues with estimators in decomposition module when input images are given in glob patterns.

  • Fix bug loading Nifti2Images.

  • Fix bug while adjusting contrast of the background template while using nilearn.plotting.plot_prob_atlas

  • Fix colormap bug with recent matplotlib 2.2.0

0.4.0

Highlights:

Enhancements

Bug fixes

  • Dimming factor applied to background image in plotting functions with “dim” parameter will no longer accepts as string (‘-1’). An error will be raised.

  • Fixed issues with matplotlib 2.1.0.

  • Fixed issues with SciPy 1.0.0.

Changes

  • Backward incompatible change: nilearn.plotting.find_xyz_cut_coords now takes a mask_img argument which is a niimg, rather than a mask argument, which used to be a numpy array.

  • The minimum required version for scipy is now 0.14

  • Dropped support for Nibabel older than 2.0.2.

  • nilearn.image.smooth_img no longer accepts smoothing parameter fwhm as 0. Behavior is changed in according to the issues with recent SciPy version 1.0.0.

  • “dim” factor range is slightly increased to -2 to 2 from -1 to 1. Range exceeding -1 meaning more increase in contrast should be cautiously set.

  • New ‘anterior’ and ‘posterior’ view added to the plot_surf family views

  • Using argument anat_img for placing background image in nilearn.plotting.plot_prob_atlas is deprecated. Use argument bg_img instead.

  • The examples now use pandas for the behavioral information.

Contributors

The following people contributed to this release:

127  Jerome Dockes
 62  Gael Varoquaux
 36  Kamalakar Daddy
 11  Jeff Chiang
  9  Elizabeth DuPre
  9  Jona Sassenhagen
  7  Sylvain Lan
  6  J Necus
  5  Pierre-Olivier Quirion
  3  AnaLu
  3  Jean Remi King
  3  MADHYASTHA Meghana
  3  Salma Bougacha
  3  sfvnMAC
  2  Eric Larson
  2  Horea Christian
  2  Moritz Boos
  1  Alex Rothberg
  1  Bertrand Thirion
  1  Christophe Bedetti
  1  John Griffiths
  1  Mehdi Rahim
  1  Sylvain LANNUZEL
  1  Yaroslav Halchenko
  1  clfs

0.3.1

This is a minor release for BrainHack.

Highlights

  • Dropped support for scikit-learn older than 0.14.1 Minimum supported version is now 0.15.

Changelog

Bug fix

  • The helper function largest_connected_component should now work with inputs of non-native data dtypes.

  • Fix plotting issues when non-finite values are present in background anatomical image.

  • A workaround to handle non-native endianness in the Nifti images passed to resampling the image.

Enhancements

0.3.0

In addition, more details of this release are listed below. Please checkout in 0.3.0 beta release section for minimum version support of dependencies, latest updates, highlights, changelog and enhancements.

Changelog

  • Function nilearn.plotting.find_cut_slices now supports to accept Nifti1Image as an input for argument img.

  • Helper functions _get_mask_volume and _adjust_screening_percentile are now moved to param_validation file in utilities module to be used in common with Decoder object.

Bug fix

  • Fix bug uncompressing tar files with datasets fetcher.

  • Fixed bunch of CircleCI documentation build failures.

  • Fixed deprecations set_axis_bgcolor related to matplotlib in plotting functions.

  • Fixed bug related to not accepting a list of arrays as an input to unmask, in masking module.

Enhancements

  • ANOVA SVM example on Haxby datasets plot_haxby_anova_svm in Decoding section now uses SelectPercentile to select voxels rather than SelectKBest.

  • New function fast_svd implementation in base decomposition module to Automatically switch between randomized and lapack SVD (heuristic of scikit-learn).

0.3.0 beta

To install the beta version, use:

pip install --upgrade --pre nilearn

Highlights

  • Simple surface plotting

  • A function to break a parcellation into its connected components

  • Dropped support for scikit-learn older than 0.14.1 Minimum supported version is now 0.14.1.

  • Dropped support for Python 2.6

  • Minimum required version of NiBabel is now 1.2.0, to support loading annotated data with freesurfer.

Changelog

Bug fix

  • Fix colormap issue with colorbar=True when using qualitative colormaps Fixed in according with changes of matplotlib 2.0 fixes.

  • Fix plotting functions to work with NAN values in the images.

  • Fix bug related get dtype of the images with nibabel get_data().

  • Fix bug in nilearn clean_img

Enhancements

  • A new function nilearn.regions.connected_label_regions to extract the connected components represented as same label to regions apart with each region labelled as unique label.

  • New plotting modules for surface plotting visualization. Matplotlib with version higher 1.3.1 is required for plotting surface data using these functions.

  • Function nilearn.plotting.plot_surf can be used for plotting surfaces mesh data with optional background.

  • A function nilearn.plotting.plot_surf_stat_map can be used for plotting statistical maps on a brain surface with optional background.

  • A function nilearn.plotting.plot_surf_roi can be used for plotting statistical maps rois onto brain surface.

  • A function nilearn.datasets.fetch_surf_fsaverage5 can be used for surface data object to be as background map for the above plotting functions.

  • A new data fetcher function nilearn.datasets.fetch_atlas_surf_destrieux can give you Destrieux et. al 2010 cortical atlas in fsaverage5 surface space.

  • A new functional data fetcher function nilearn.datasets.fetch_surf_nki_enhanced gives you resting state data preprocessed and projected to fsaverage5 surface space.

  • Two good examples in plotting gallery shows how to fetch atlas and NKI data and used for plotting on brain surface.

  • Helper function load_surf_mesh in surf_plotting module for loading surface mesh data into two arrays, containing (x, y, z) coordinates for mesh vertices and indices of mesh faces.

  • Helper function load_surf_data in surf_plotting module for loading data of numpy array to represented on a surface mesh.

  • Add fetcher for Allen et al. 2011 RSN atlas in nilearn.datasets.fetch_atlas_allen_2011.

  • A function nilearn.datasets.fetch_cobre is now updated to new light release of COBRE data (schizophrenia)

  • A new example to show how to extract regions on labels image in example section manipulating images.

  • coveralls is replaces with codecov

  • Upgraded to Sphinx version 0.1.7

  • Extensive plotting example shows how to use contours and filled contours on glass brain.

0.2.6

Changelog

This release enhances usage of several functions by fine tuning their parameters. It allows to select which Haxby subject to fetch. It also refactors documentation to make it easier to understand. Sphinx-gallery has been updated and nilearn is ready for new nibabel 2.1 version. Several bugs related to masks in Searchlight and ABIDE fetching have been resolved.

Bug fix

  • Change default dtype in nilearn.image.concat_imgs to be the original type of the data (see #1238).

  • Fix SearchLight that did not run without process_mask or with one voxel mask.

  • Fix flipping of left hemisphere when plotting glass brain.

  • Fix bug when downloading ABIDE timeseries

Enhancements

API changes summary

  • The parameter ‘n_subjects’ is deprecated and will be removed in future release. Use ‘subjects’ instead in nilearn.datasets.fetch_haxby.

  • The function nilearn.datasets.fetch_haxby will now fetch the data accepting input given in ‘subjects’ as a list than integer.

  • Replace get_affine by affine with recent versions of nibabel.

0.2.5.1

Changelog

This is a bugfix release. The new minimum required version of scikit-learn is 0.14.1

API changes summary

  • default option for dim argument in plotting functions which uses MNI template as a background image is now changed to ‘auto’ mode. Meaning that an automatic contrast setting on background image is applied by default.

  • Scikit-learn validation tools have been imported and are now used to check consistency of input data, in SpaceNet for example.

New features

  • Add an option to select only off-diagonal elements in sym_to_vec. Also, the scaling of matrices is modified: we divide the diagonal by sqrt(2) instead of multiplying the off-diagonal elements.

  • Connectivity examples rely on nilearn.connectome.ConnectivityMeasure

Bug fix

  • Scipy 0.18 introduces a bug in a corner-case of resampling. Nilearn 0.2.5 can give wrong results with scipy 0.18, but this is fixed in 0.2.6.

  • Broken links and references fixed in docs

0.2.5

Changelog

The 0.2.5 release includes plotting for connectomes and glass brain with hemisphere-specific projection, as well as more didactic examples and improved documentation.

New features

Contributors

Contributors (from git shortlog -ns 0.2.4..0.2.5):

55  Gael Varoquaux
39  Alexandre Abraham
26  Martin Perez-Guevara
20  Kamalakar Daddy
 8  amadeuskanaan
 3  Alexandre Abadie
 3  Arthur Mensch
 3  Elvis Dohmatob
 3  Loïc Estève
 2  Jerome Dockes
 1  Alexandre M. S
 1  Bertrand Thirion
 1  Ivan Gonzalez
 1  robbisg

0.2.4

Changelog

The 0.2.4 is a small release focused on documentation for teaching.

New features

  • The path given to the “memory” argument of object now have their “~” expanded to the homedir

  • Display object created by plotting now uniformly expose an “add_markers” method.

  • plotting plot_connectome with colorbar is now implemented in function nilearn.plotting.plot_connectome

  • New function nilearn.image.resample_to_img to resample one img on another one (just resampling / interpolation, no coregistration)

API changes summary

  • Atlas fetcher nilearn.datasets.fetch_atlas_msdl now returns directly labels of the regions in output variable ‘labels’ and its coordinates in output variable ‘region_coords’ and its type of network in ‘networks’.

  • The output variable name ‘regions’ is now changed to ‘maps’ in AAL atlas fetcher in nilearn.datasets.fetch_atlas_aal.

  • AAL atlas now returns directly its labels in variable ‘labels’ and its index values in variable ‘indices’.

0.2.3

Changelog

The 0.2.3 is a small feature release for BrainHack 2016.

New features

Bug fixes

  • Better dimming on white background for plotting

0.2.2

Changelog

The 0.2.2 is a bugfix + dependency update release (for sphinx gallery). It aims at preparing a renewal of the tutorials.

New features

  • Fetcher for Megatrawl Netmats dataset.

Enhancements

  • Flake8 is now run on pull requests.

  • Reworking of the documentation organization.

  • Sphinx-gallery updated to version 0.1.1

  • The default n_subjects=None in nilearn.datasets.fetch_adhd is now changed to n_subjects=30.

Bug fixes

API changes summary

  • Deprecated dataset downloading function have been removed.

  • Download progression message refreshing rate has been lowered to sparsify CircleCI logs.

Contributors

Contributors (from git shortlog -ns 0.2.1..0.2.2):

39  Kamalakar Daddy
22  Alexandre Abraham
21  Loïc Estève
19  Gael Varoquaux
12  Alexandre Abadie
 7  Salma
 3  Danilo Bzdok
 1  Arthur Mensch
 1  Ben Cipollini
 1  Elvis Dohmatob
 1  Óscar Nájera

0.2.1

Changelog

Small bugfix for more flexible input types (targetter in particular at making code easier in nistats).

0.2

Changelog

The new minimum required version of scikit-learn is 0.13

New features

Enhancements

  • Making website a bit elaborated & modernise by using sphinx-gallery.

  • Documentation enhancement by integrating sphinx-gallery notebook style examples.

  • Documentation about nilearn.input_data.NiftiSpheresMasker.

Bug fixes

API changes summary

Contributors

Contributors (from git shortlog -ns 0.1.4..0.2.0):

822  Elvis Dohmatob
142  Gael Varoquaux
119  Alexandre Abraham
 90  Loïc Estève
 85  Kamalakar Daddy
 65  Alexandre Abadie
 43  Chris Filo Gorgolewski
 39  Salma BOUGACHA
 29  Danilo Bzdok
 20  Martin Perez-Guevara
 19  Mehdi Rahim
 19  Óscar Nájera
 17  martin
  8  Arthur Mensch
  8  Ben Cipollini
  4  ainafp
  4  juhuntenburg
  2  Martin_Perez_Guevara
  2  Michael Hanke
  2  arokem
  1  Bertrand Thirion
  1  Dimitri Papadopoulos Orfanos

0.1.4

Changelog

Highlights:

  • NiftiSpheresMasker: extract signals from balls specified by their coordinates

  • Obey Debian packaging rules

  • Add the Destrieux 2009 and Power 2011 atlas

  • Better caching in maskers

Contributors (from git shortlog -ns 0.1.3..0.1.4):

141  Alexandre Abraham
 15  Gael Varoquaux
 10  Loïc Estève
  2  Arthur Mensch
  2  Danilo Bzdok
  2  Michael Hanke
  1  Mehdi Rahim

0.1.3

Changelog

The 0.1.3 release is a bugfix release that fixes a lot of minor bugs. It also includes a full rewamp of the documentation, and support for Python 3.

Minimum version of supported packages are now:

  • numpy 1.6.1

  • scipy 0.9.0

  • scikit-learn 0.12.1

  • Matplotlib 1.1.1 (optional)

A non exhaustive list of issues fixed:

  • Dealing with NaNs in plot_connectome

  • Fix extreme values in colorbar were sometimes brok

  • Fix confounds removal with single confounds

  • Fix frequency filtering

  • Keep header information in images

  • add_overlay finds vmin and vmax automatically

  • vmin and vmax support in plot_connectome

  • detrending 3D images no longer puts them to zero

Contributors (from git shortlog -ns 0.1.2..0.1.3):

129  Alexandre Abraham
 67  Loïc Estève
 57  Gael Varoquaux
 44  Ben Cipollini
 37  Danilo Bzdok
 20  Elvis Dohmatob
 14  Óscar Nájera
  9  Salma BOUGACHA
  8  Alexandre Gramfort
  7  Kamalakar Daddy
  3  Demian Wassermann
  1  Bertrand Thirion

0.1.2

Changelog

The 0.1.2 release is a bugfix release, specifically to fix the NiftiMapsMasker.

0.1.1

Changelog

The main change compared to 0.1 is the addition of connectome plotting via the nilearn.plotting.plot_connectome function. See the plotting documentation for more details.

Contributors (from git shortlog -ns 0.1..0.1.1):

81  Loïc Estève
18  Alexandre Abraham
18  Danilo Bzdok
14  Ben Cipollini
 2  Gaël Varoquaux

0.1

Changelog

First release of nilearn.

Contributors (from git shortlog -ns 0.1):

600  Gaël Varoquaux
483  Alexandre Abraham
302  Loïc Estève
254  Philippe Gervais
122  Virgile Fritsch
 83  Michael Eickenberg
 59  Jean Kossaifi
 57  Jaques Grobler
 46  Danilo Bzdok
 35  Chris Filo Gorgolewski
 28  Ronald Phlypo
 25  Ben Cipollini
 15  Bertrand Thirion
 13  Alexandre Gramfort
 12  Fabian Pedregosa
 11  Yannick Schwartz
  9  Mehdi Rahim
  7  Óscar Nájera
  6  Elvis Dohmatob
  4  Konstantin Shmelkov
  3  Jason Gors
  3  Salma Bougacha
  1  Alexandre Savio
  1  Jan Margeta
  1  Matthias Ekman
  1  Michael Waskom
  1  Vincent Michel