What’s new#
0.9.2.dev#
NEW#
- save_glm_to_bidshas been added, which writes model outputs to disk according to BIDS convention (#2715 by Taylor Salo).
- permuted_olsand- non_parametric_inferencenow support TFCE statistic (#3196 by Taylor Salo).
- permuted_olsand- non_parametric_inferencenow support cluster-level Family-wise error correction (#3181 by Taylor Salo).
Fixes#
- Fix - _NEUROVAULT_BASE_URLand- _NEUROSYNTH_FETCH_WORDS_URLin- nilearn/datasets/neurovault.pyby using https instead of http (#3281 by Manon Pietrantoni).
- Convert references in - nilearn/mass_univariate/permuted_least_squares.pyto use bibtex format (#3222 by Yasmin Mzayek).
- Update Craddock 2012 parcellation url in - nilearn/datasets/atlas.py(#3233 by Vasco Diogo)
- plot_roifailed before when used with the “contours” view type and passing a list of cut coordinates in display mode “x”, “y” or “z”; this has been corrected (#3241 by Jerome Dockes).
- plot_markerscan now plot a single scatter point (#3255 by Caglar Cakan).
- Fix title display for - plot_surf_stat_map. The- titleargument does not set the figure title anymore but the axis title. (#3220 by Raphael Meudec).
- load_surf_meshloaded FreeSurfer specific surface files (e.g. .pial) with a shift in the coordinates. This is fixed by adding the c_ras coordinates to the mesh coordinates (#3235 by Yasmin Mzayek).
- Function - nilearn.glm.second_level.second_level._check_second_level_inputnow raises an error when- flm_objectargument is- Falseand- second_level_inputis a list of- FirstLevelModel(#3283 by Matthieu Joulot).
- Function - resample_imgnow warns the user if the provided image has an- sformcode equal to 0 or None (#3284 by Matthieu Joulot).
- Fix usage of - scipy.stats.gamma.pdfin- _gamma_difference_hrffunction under- nilearn/glm/first_level/hemodynamic_models.py, which resulted in slight distortion of HRF (#3297 by Kun CHEN).
- Fix bug introduced due to a fix in the pre-release version of scipy ( - 1.9.0rc1) which now enforces that elements of a band-pass filter must meet condition- Wn[0] < Wn[1]. Now if band-pass elements are equal- butterworthreturns an unfiltered signal with a warning (#3293 by Yasmin Mzayek).
- The parameter - alphais now correctly passed to- plot_glass_brainin- plot_connectome(#3306 by Koen Helwegen).
Enhancements#
- Add sample_masks to - fitfor censoring time points (#3193 by Hao-Ting Wang).
- Function - run_glmand class- FirstLevelModelnow accept a- random_stateparameter, which allows users to seed the- KMeanscluster model used to estimate AR coefficients. (#3185 by Sami Jawhar).
- Conform seeding and docstrings in module - _utils.data_gen(#3262 by Yasmin Mzayek).
- Docstrings of module - second_levelwere improved (#3030 by Nicolas Gensollen).
- In - get_clusters_table, when the center of mass of a binary cluster falls outside the cluster, report the nearest within-cluster voxel instead (#3292 by Connor Lane).
Changes#
- Function - plot_carpetargument- cmapnow respects behaviour specified by docs and changes the color of the carpet_plot. Changing the label colors is now delegated to a new variable- cmap_labels(#3209 by Daniel Gomez).
- Function - fetch_surf_fsaverageno longer supports the previously deprecated option- fsaverage5_sphere(#3229 by Taylor Salo).
- Classes - RegressionResults,- SimpleRegressionResults,- OLSModel, and- LikelihoodModelResultsno longer support deprecated shortened attribute names, including- df_resid,- wdesign,- wresid,- norm_resid,- resid, and- wY(#3229 by Taylor Salo).
- Function - fetch_openneuro_dataset_indexis now deprecated in favor of the new- fetch_ds000030_urlsfunction (#3216 by Taylor Salo).
- 64-bit integers in Nifti files: some tools such as FSL, SPM and AFNI cannot handle Nifti images containing 64-bit integers. To avoid compatibility issues, it is best to avoid writing such images and in the future trying to create them with nibabel without explicitly specifying a data type will result in an error. See details in this issue: https://github.com/nipy/nibabel/issues/1046 and this PR: https://github.com/nipy/nibabel/pull/1082. To avoid this, - new_img_likenow warns when given int64 arrays and converts them to int32 when possible (ie when it would not result in an overflow). Moreover, any atlas fetcher that returned int64 images now produces images containing smaller ints. (#3227 by Jerome Dockes)
- Refactors fmriprep confound loading such that that the parsing of the relevant image file and the loading of the confounds are done in separate steps (#3274 by David G Ellis). 
- Private submodules, functions, and classes from the - decompositionmodule now start with a “_” character to make it clear that they are not part of the public API (#3141 by Nicolas Gensollen).
- Convert references in - nilearn/glm/regression.pyand- nilearn/glm/thresholding.pyto use footcite/footbibliography (#3302 by Ahmad Chamma).
- Boolean input data in - new_img_likenow defaults to np.uint8 instead of np.int8 (#3286 by Yasmin Mzayek).
0.9.1#
Released April 2022
This is a bugfix release.
Fixes#
- Fix function - permuted_ols, which was only returning the null distribution (- h0_fmax) for the first regressor (#3184 by Taylor Salo).
- Fix function - fetch_abide_pcpwhich was returning empty phenotypes and- func_preprocafter release- 0.9.0due to supporting pandas dataframes in fetchers (#3174 by Nicolas Gensollen).
- Fix function - fetch_atlas_harvard_oxfordand- fetch_atlas_juelichwhich were returning the image in the filename attribute instead of the path to the image (#3179 by Raphael Meudec).
- Fix function - nilearn.image._apply_cluster_size_threshold, which resulted in wrong clusters extraction when- cluster_sizewas non-zero (#3201 by Bertrand Thirion).
- Fix colorbars in - plot_stat_map,- plot_glass_brainand- plot_surf_stat_mapwhich could extend beyond the figure for users with newest matplotlib version (- >=3.5.1) (#3188 by Raphael Meudec).
- Function - fetch_atlas_aalnow works with all supported versions of- SPM(5, 8, and 12). (#3098 by Nicolas Gensollen).
Enhancements#
- New example in Beta-Series Modeling for Task-Based Functional Connectivity and Decoding to demonstrate how to implement common beta series models with nilearn (#3127 by Taylor Salo). 
- Function - plot_carpetnow accepts a- t_rparameter, which allows users to provide the TR of the image when the image’s header may not be accurate. (#3165 by Taylor Salo).
- Terms Probabilistic atlas and Deterministic atlas were added to the glossary and references were added to atlas fetchers (#3152 by Nicolas Gensollen). 
- Functions in - nilearn.datasetshave been organized by the type of data in the references page and- fetch_mixed_gambleshas been added to the documentation (#3207 by Taylor Salo).
Changes#
- The documentation for - get_clusters_tablehas been improved, with more information about what inputs are valid and what the resulting table should look like (#3178 by Taylor Salo).
- Requirements files have been consolidated into a - setup.cfgfile and installation instructions have been simplified (#2953 by Taylor Salo).
0.9.0#
Released January 2022
HIGHLIGHTS#
Warning
- Surface plotting functions can now produce interactive plots with - Plotly. This can be selected with the- engineparameter (set it to- matplotlibor- plotly) (#2902 by Nicolas Gensollen).
- New module - nilearn.interfacesto implement loading and saving utilities with various interfaces (fMRIPrep, BIDS…) (#3061 by Nicolas Gensollen).
- New functions - load_confoundsand- load_confounds_strategyto load confound variables easily from fMRIPrep outputs (#2946 and #3016 by Hao-Ting Wang).
- New class - HierarchicalKMeanswhich yields more balanced clusters than- KMeans. It is also callable through- Parcellationsusing- method=hierarchical_kmeans(#2282 by Thomas Bazeille).
- Masker objects like - NiftiMaskernow belong to the new module- nilearn.maskers. The old import style, through the module- input_data, still works but has been deprecated (#3065 by Nicolas Gensollen).
- Class - NiftiMapsMaskercan now generate HTML reports in the same way as- NiftiMaskerand- NiftiLabelsMasker(#2880 by Nicolas Gensollen).
- The contributing documentation and maintenance pages were improved (#3010 by Nicolas Gensollen). 
NEW#
- Support for Python 3.6 is deprecated and will be removed in release 0.10. Users with a Python 3.6 environment will be warned at their first Nilearn import and encouraged to update to more recent versions of Python (#3026 by Nicolas Gensollen). 
- Masker objects like - NiftiMaskernow belong to the new module- nilearn.maskers. The old import style, through the module- input_data, still works but has been deprecated (#3065 by Nicolas Gensollen).
- New module - nilearn.interfacesto implement loading and saving utilities with various interfaces (fMRIPrep, BIDS…) (#3061 by Nicolas Gensollen).
- New submodule - nilearn.interfaces.fmriprepto implement loading utilities for fMRIPrep (#3061 by Nicolas Gensollen).
- New function - load_confoundsto load confound variables easily from fMRIPrep outputs (#2946 by Hao-Ting Wang).
- New function - load_confounds_strategyto load confound variables from fMRIPrep outputs using four preset strategies:- simple,- scrubbing,- compcor, and- ica_aroma(#3016 by Hao-Ting Wang).
- New submodule - nilearn.interfaces.bidsto implement loading utilities for BIDS datasets (#3126 by Taylor Salo).
- New function - get_bids_filesto select files easily from BIDS datasets (#3126 by Taylor Salo).
- New function - parse_bids_filenameto identify subparts of BIDS filenames (#3126 by Taylor Salo).
- New submodule - nilearn.interfaces.fslto implement loading utilities for FSL outputs. (#3126 by Taylor Salo).
- New function - get_design_from_fslmatto load design matrices from FSL files (#3126 by Taylor Salo).
- Surface plotting functions like - plot_surf_stat_mapnow have an- engineparameter, defaulting to- matplotlib, but which can be set to- plotly. If- plotlyand- kaleidoare installed, this will generate an interactive plot of the surface map using- plotlyinstead of- matplotlib. Note that this functionality is still experimental, and that some capabilities supported by our- matplotlibengine are not yet supported by the- plotlyengine (#2902 by Nicolas Gensollen).
- When using the - plotlyengine, surface plotting functions derived from- plot_surfreturn a new display object, a- PlotlySurfaceFigure, which provides a similar interface to the- Figurereturned with the- matplotlibengine (#3036 by Nicolas Gensollen).
- Class - NiftiMapsMaskercan now generate HTML reports in the same way as- NiftiMaskerand- NiftiLabelsMasker. The report enables the users to browse through the spatial maps with a previous and next button. The users can filter the maps they wish to display by passing an integer, or a list of integers to- generate_report(#2880 by Nicolas Gensollen).
- New class - HierarchicalKMeanswhich yields more balanced clusters than- KMeans. It is also callable through- Parcellationsusing- method=hierarchical_kmeans(#2282 by Thomas Bazeille).
Fixes#
- When a label image with non integer values was provided to the - NiftiLabelsMasker, its- generate_reportmethod was raising an- IndexError(#3009 by Nicolas Gensollen).
- Function - plot_markersdid not work when the- display_modeparameter included- land- rand the parameter- node_sizewas provided as an array (#3013 by Leonard Sasse).
- Method - generate_reportthrew a- TypeErrorwhen- FirstLevelModelwas instantiated with- mask_imgbeing a- NiftiMasker. Function- make_glm_reportwas fixed accordingly (#3035 by Alexis Thual).
- Function - find_parcellation_cut_coordsnow returns coordinates and labels having the same order as the one of the input labels index (#3078 by Myeong Seop Song).
- Convert references in - nilearn/regions/region_extractor.pyto use footcite / footbibliography (#3111 by Neelay Shah).
- Fixed Hommel value computation in - nilearn/glm/thresholding.pyused in the- cluster_level_inferencefunction (#3109 by Bertrand Thirion).
- Fixed computation of Benjamini-Hocheberg threshold in - nilearn/glm/thresholding.pyfunction (#3137 by Bertrand Thirion).
- Attribute - scaling_axisof- FirstLevelModelhas been deprecated and will be removed in- 0.11.0. When scaling is performed, the attribute- signal_scalingis used to define the axis instead (#3135 by Nicolas Gensollen).
Enhancements#
- Function - threshold_imgaccepts new parameters- cluster_thresholdand- two_sided.- cluster_thresholdapplies a cluster-size threshold (in voxels).- two_sided, which is- Trueby default, separately thresholds both positive and negative values in the map, as was done previously. When- two_sidedis- False, only values greater than or equal to the threshold are retained (#2965 by Taylor Salo).
- Function - cleanraises a warning when the user sets parameters- detrendand- standardize_confoundto- False. The user is suggested to set one of those options to- True, or standardize/demean the confounds before using the function (#3003 by Hao-Ting Wang).
- The contributing documentation and maintenance pages were improved, especially towards ways of contributing to the project which do not require to write code. The roles of the Triage team were defined more clearly with sections on issue Labels and issue Closing policy (#3010 by Nicolas Gensollen). 
- It is now possible to provide custom HRF models to - FirstLevelModel. The custom model should be defined as a function, or a list of functions, implementing the same API as Nilearn’s usual models (see- spm_hrffor example). The example Example of MRI response functions was also modified to demo how to define custom HRF models (#2942 by Nicolas Gensollen).
- Class - NiftiLabelsMaskernow gives a warning when some labels are removed from the label image at transform time due to resampling of the label image to the data image (#3008 by Nicolas Gensollen).
- Function - non_parametric_inferencenow accepts- DataFrameas possible values for its- second_level_inputparameter. Note that a new parameter- first_level_contrasthas been added to this function to enable this feature (#3042 by Nicolas Gensollen).
- Tests from - nilearn/plotting/tests/test_img_plotting.pyhave been refactored and reorganized in separate files in new folder- nilearn/plotting/tests/test_img_plotting/(#3015 by Nicolas Gensollen).
- Once a - SecondLevelModelhas been fitted and contrasts have been computed, it is now possible to access the- residuals,- predicted, and- r_squaremodel attributes like it was already possible for- FirstLevelModel(#3033 by Nicolas Gensollen).
- Importing - nilearn.plottingwill now raise a warning if the- matplotlibbackend has been changed from its original value, instead of silently modifying it (#3077 by Raphael Meudec).
- Function - plot_imgand deriving functions like- plot_anat,- plot_stat_map, or- plot_epinow accept an optional argument- cbar_tick_formatto specify how numbers should be displayed on the colorbar. This is consistent with the API of surface plotting functions (see release- 0.7.1). The default format is scientific notation (#2859 by Nicolas Gensollen).
Changes#
- Nibabel 2.x is no longer supported. Please consider upgrading to Nibabel >= 3.0 (#3106 by Nicolas Gensollen). 
- Deprecated function - nilearn.datasets.fetch_cobrehas been removed (#3081 by Nicolas Gensollen).
- Deprecated function - nilearn.plotting.plot_connectome_strengthhas been removed (#3082 by Nicolas Gensollen).
- Deprecated function - nilearn.masking.compute_gray_matter_maskhas been removed (#3090 by Nicolas Gensollen).
- Deprecated parameter - sessionsof function- cleanhas been removed. Use- runsinstead (#3093 by Nicolas Gensollen).
- Deprecated parameters - sessionsand- sample_maskof- NiftiMaskerhave been removed. Please use- runsinstead of- sessions, and provide a- sample_maskthrough- transform(#3133 by Nicolas Gensollen).
- Function - glm.first_level.compute_regressorwill now raise an exception if parameter- cond_idis not a string which could be used to name a python variable. For instance, number strings (ex: “1”) will no longer be accepted as valid condition names. In particular, this will also impact- glm.first_level.make_first_level_design_matrixand- glm.first_level.FirstLevelModel, for which proper condition names will also be needed (#3025 by Alexis Thual).
- Replace parameter - sessionswith- runsin function- clean_imgas this replacement was already made for function- cleanin #2821 in order to match BIDS semantics. The use of- sessionsin function- clean_imgis deprecated and will be removed in- 0.10.0(#3039 by Nicolas Gensollen).
- Display objects have been reorganized. For example, - Slicers(like the- OrthoSlicer) are all in file- nilearn/plotting/displays/_slicers.py, and- Projectors(like the- OrthoProjector) are all in file- nilearn/plotting/displays/_projectors.py. All display objects have been added to the public API, and examples have been improved to show how to use these objects to customize figures obtained with plotting functions (#3073 by Nicolas Gensollen).
- Descriptions of datasets retrieved with fetchers from - nilearn.datasetsare now python strings rather than- bytes. Therefore, decoding the descriptions is no longer necessary (#2655 by Nicolas Gensollen).
- Dataset fetchers returning a - recarraycan now return a- DataFrameinstead. These fetchers now have a- legacy_formatoptional argument defaulting to- Truefor backward compatibility. Users will be warned that this parameter will default to- Falsein release- 0.11.0, making- DataFramethe default return type instead or- recarray(#2829 by Ahmad Chamma).
0.8.1#
Released September 2021
HIGHLIGHTS#
- New atlas fetcher - fetch_atlas_juelichto download Juelich atlas from FSL (#2723 by Ahmad Chamma).
- New grey and white-matter template and mask loading functions: - load_mni152_gm_template,- load_mni152_wm_template,- load_mni152_gm_mask, and- load_mni152_wm_mask(#2738 by Ana Luisa Pinho).
- The Contributing has been reworked. It now provides insights on nilearn organization as a project as well as more explicit Contribution Guidelines (#2755 by Thomas Bazeille). 
- Function - binarize_imgbinarizes images into 0 and 1 (#2900 by Daniel Gomez).
NEW#
- New atlas fetcher - fetch_atlas_juelichto download Juelich atlas from FSL (#2723 by Ahmad Chamma).
- The Contributing has been reworked. It now provides insights on nilearn organization as a project as well as more explicit Contribution Guidelines (#2755 by Thomas Bazeille). 
- Function - load_mni152_gm_templatetakes the skullstripped 1mm-resolution version of the grey-matter MNI152 template and re-samples it using a different resolution, if specified (#2738 by Ana Luisa Pinho).
- Function - load_mni152_wm_templatetakes the skullstripped 1mm-resolution version of the white-matter MNI152 template and re-samples it using a different resolution, if specified (#2738 by Ana Luisa Pinho).
- Function - load_mni152_gm_maskloads mask from the grey-matter MNI152 template (#2738 by Ana Luisa Pinho).
- Function - load_mni152_wm_maskloads mask from the white-matter MNI152 template (#2738 by Ana Luisa Pinho).
- Function - binarize_imgbinarizes images into 0 and 1 (#2900 by Daniel Gomez).
- Classes - NiftiMasker,- MultiNiftiMasker, and objects relying on such maskers (- Decoderor- CanICAfor example) can now use new options for the argument- mask_strategy:- whole-brain-templatefor whole-brain template (same as previous option- template),- gm-templatefor grey-matter template, and- wm-templatefor white-matter template (#2904 by Nicolas Gensollen).
Fixes#
- Function - compute_multi_brain_maskhas replaced- nilearn.masking.compute_multi_grey_matter_mask. A- maskparameter has been added; it accepts three types of masks—i.e.- whole-brain,- grey-matter, and- white-matter—following the enhancements made in the function- nilearn.masking.compute_brain_maskin this release (#2738 by Ana Luisa Pinho).
- Fix colorbar of function - view_imgwhich was not visible for some combinations of black_bg and bg_img parameters (#2876 by Nicolas Gensollen).
- Fix missing title with function - plot_surfand deriving functions (#2941 by Nicolas Gensollen).
Enhancements#
- Function - load_mni152_templateresamples 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 (#2738 by Ana Luisa Pinho).
- Function - load_mni152_brain_maskaccepts now the parameter- resolution, which will set the resolution of the template used for the masking (#2738 by Ana Luisa Pinho).
- Function - compute_brain_maskaccepts 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 (#2738 by Ana Luisa Pinho).
- 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 (#2875 by Nicolas Gensollen). 
- The - data_dirargument can now be either a- pathlib.Pathor a- str. This extension affects datasets and atlas fetchers (#2928 by Raphael Meudec).
Changes#
- The version of the script jquery.min.js was bumped from - 3.3.1to- 3.6.0due to potential vulnerability issues with versions- < 3.5.0(#2944 by Nicolas Gensollen).
0.8.0#
Released June 2021
HIGHLIGHTS#
Warning
- Class - NiftiLabelsMaskercan now generate HTML reports in the same way as the- NiftiMasker(#2707 by Nicolas Gensollen).
- Function - cleannow accepts a new parameter- sample_maskof shape- (number of scans - number of volumes removed, )(#2858 by Hao-Ting Wang).
- All inherent classes of - nilearn.maskers.BaseMaskercan use the parameter- sample_maskfor sub-sample masking (#2858 by Hao-Ting Wang).
- Function - fetch_surf_fsaveragenow accepts- fsaverage3,- fsaverage4and- fsaverage6as values for parameter- mesh, so that all resolutions of fsaverage from 3 to 7 are now available (#2815 by Alexis Thual).
- Function - fetch_surf_fsaveragenow provides attributes- {area, curv, sphere, thick}_{left, right}for all fsaverage resolutions (#2815 by Alexis Thual).
- Function - run_glmnow allows auto regressive noise models of order greater than one (#2532 by Robert Luke).
NEW#
- Function - cleannow accepts a new parameter- sample_maskof 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 (#2858 by Hao-Ting Wang).
- All inherent classes of - nilearn.maskers.BaseMaskercan use the parameter- sample_maskfor sub-sample masking (#2858 by Hao-Ting Wang).
- Class - NiftiLabelsMaskercan now generate HTML reports in the same way as- 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 (#2707 by Nicolas Gensollen).
Fixes#
- Convert references in - signal.py,- atlas.py,- func.py,- neurovault.py, and- struct.pyto use footcite / footbibliography (#2806 by Jeremy Lefort-Besnard).
- Fix detrending and temporal filtering order for confounders in function - clean, so that these operations are applied in the same order as for the signals, i.e., first detrending and then temporal filtering (see #2730) (#2732 by Javier Rasero).
- Fix number of attributes returned by the nilearn.glm.first_level.FirstLevelModel._get_voxelwise_model_attribute method in the - FirstLevelModel. It used to return only the first attribute, and now returns as many attributes as design matrices (#2792 by Raphael Meudec).
- Plotting functions that show a stack of slices from a 3D image (e.g. - plot_stat_map) will now plot the slices in the user specified order, rather than automatically sorting into ascending order (see #1155) (#2831 by Evan Edmond).
- Fix the axes zoom in function - plot_img_on_surfso brain would not be cutoff, and edited function so less white space surrounds brain views and smaller colorbar using gridspec (#2798 by Tom Vanasse).
- Fix inconsistency in prediction values of - sklearn.dummy.DummyClassifierfor- Decoder(see #2767) (#2826 by Binh Nguyen).
Enhancements#
- Function - view_markersnow accepts an optional argument- marker_labelsto provide labels to each marker (#2745 by Greydon Gilmore).
- Function - plot_surfnow accepts new values for- avg_methodargument, such as- min,- max, or even a custom python function to compute the value displayed for each face of the plotted mesh (#2790 by Alexis Thual).
- Function - view_img_on_surfcan now optionally pass through parameters to function- vol_to_surfusing the- vol_to_surf_kwargsargument. One application is better HTML visualization of atlases (https://nilearn.github.io/auto_examples/01_plotting/plot_3d_map_to_surface_projection.html) (#2805 by Evan Edmond).
- Function - view_connectomenow accepts an optional argument- node_colorto provide a single color for all nodes, or one color per node. It defaults to- autowhich colors markers according to the viridis colormap (#2810 by Raphael Meudec).
- Function - cleanhas been refactored to clarify the data flow (#2821 by Hao-Ting Wang).
- Parameter - sessionshas been replaced with- runsin- cleanto match BIDS semantics.- sessionshas been deprecated and will be removed in- 0.9.0(#2821 by Hao-Ting Wang).
- Add argument - filterin- cleanand allow a selection of signal filtering strategies:- butterwothfor butterworth filter,- cosinefor discrete cosine transformation, and- Falsefor no filtering (#2821 by Hao-Ting Wang).
- Change the default strategy for - sklearn.dummy.DummyClassifierfrom- priorto- stratified(#2826 by Binh Nguyen).
- Function - run_glmnow allows auto regressive noise models of order greater than one (#2532 by Robert Luke).
- Moves parameter - sample_maskfrom- NiftiMaskerto method- transformin base class- nilearn.maskers.BaseMasker(#2858 by Hao-Ting Wang).
- Function - fetch_surf_fsaveragenow accepts- fsaverage3,- fsaverage4and- fsaverage6as values for parameter- mesh, so that all resolutions of fsaverage from 3 to 7 are now available (#2815 by Alexis Thual).
- Function - fetch_surf_fsaveragenow provides attributes- {area, curv, sphere, thick}_{left, right}for all fsaverage resolutions (#2815 by Alexis Thual).
Changes#
- Python - 3.5is no longer supported. We recommend upgrading to Python- 3.7(#2869 by Nicolas Gensollen).
- Support for Nibabel - 2.xis now deprecated and will be removed in the- 0.9release. Users with a version of Nibabel- < 3.0will be warned at their first Nilearn import (#2869 by Nicolas Gensollen).
- 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 
 - (#2869 by Nicolas Gensollen). 
- Function - sym_to_vecfrom- nilearn.connectomewas deprecated since release- 0.4and has been removed (#2867 by Nicolas Gensollen).
- Function - nilearn.datasets.fetch_nyu_restwas deprecated since release- 0.6.2and has been removed (#2868 by Nicolas Gensollen).
- Class - NiftiMaskerreplaces attribute- sessionswith- runsand deprecates attribute- sessionsin- 0.9.0. Match the relevant change in function- clean(#2858 by Hao-Ting Wang).
0.7.1#
Released March 2021
HIGHLIGHTS#
- New atlas fetcher - fetch_atlas_difumoto 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 (#2619 by Nicolas Gensollen).
- Decoderand- DecoderRegressorare now implemented with random predictions to estimate a chance level (#2622 by Kamalakar Reddy Daddy).
- Functions - plot_epi,- plot_roi,- plot_stat_map,- plot_prob_atlasare now implemented with new display mode- Mosaic. That implies plotting 3D maps in multiple columns and rows in a single axes (#2684 by Kamalakar Reddy Daddy).
- Function - plot_carpetnow supports discrete atlases. When an atlas is used, a colorbar is added to the figure, optionally with labels corresponding to the different values in the atlas (#2702 by Taylor Salo).
NEW#
- New atlas fetcher - fetch_atlas_difumoto 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 (#2619 by Nicolas Gensollen).
- Function - glm.Contrast.one_minus_pvaluewas added to ensure numerical stability of p-value estimation. It computes 1 - p-value using the Cumulative Distribution Function in the same way as function- nilearn.glm.Contrast.p_valuecomputes the p-value using the Survival Function. (#2567 by Ana Luisa Pinho).
Fixes#
- Fix altered, non-zero baseline in design matrices where multiple events in the same condition end at the same time (see #2674) (#2553 by Martin Wegrzyn). 
- Fix testing issues on ARM machine (#2606 by Kamalakar Reddy Daddy). 
Enhancements#
- Decoderand- DecoderRegressorare now implemented with random predictions to estimate a chance level (#2622 by Kamalakar Reddy Daddy).
- Decoder,- DecoderRegressor,- FREMRegressor, and- FREMClassifiernow override the- scoremethod to use whatever scoring strategy was defined through the- scoringattribute instead of the sklearn default. If the- scoringattribute of the decoder is set to- None, the scoring strategy will default to accuracy for classifiers and to r2 score for regressors (#2669 by Nicolas Gensollen).
- Function - plot_surfand deriving functions like- plot_surf_roinow accept an optional argument- cbar_tick_formatto specify how numbers should be displayed on the colorbar of surface plots. The default format is scientific notation except for function- plot_surf_roifor which it is set as integers (#2643 by Nicolas Gensollen).
- Function - plot_carpetnow supports discrete atlases. When an atlas is used, a colorbar is added to the figure, optionally with labels corresponding to the different values in the atlas (#2702 by Taylor Salo).
- NiftiMasker,- NiftiLabelsMasker,- MultiNiftiMasker,- NiftiMapsMasker, and- NiftiSpheresMaskercan now compute high variance confounds on the images provided to- transformand regress them out automatically. This behaviour is controlled through the- high_variance_confoundsboolean parameter of these maskers which default to- False(#2697 by Nicolas Gensollen).
- NiftiLabelsMaskernow automatically replaces- NaNsin input data with zeros, to match the behavior of other maskers (#2712 by Taylor Salo).
- Function - fetch_neurovaultnow implements a- resampleboolean argument to either perform a fixed resampling during download or keep original images. This can be handy to reduce disk usage. By default, the downloaded images are not resampled (#2696 by Raphael Meudec).
- Functions - plot_epi,- plot_roi,- plot_stat_map,- plot_prob_atlasare now implemented with new display mode- Mosaic. That implies plotting 3D maps in multiple columns and rows in a single axes (#2684 by Kamalakar Reddy Daddy).
- Function - cleannow has a- pscstandardization option which allows time series with negative mean values (#2714 by Hao-Ting Wang).
- Functions - make_glm_reportand- get_clusters_tablehave a new argument,- two_sided, which allows for two-sided thresholding, which is disabled by default (#2719 by Taylor Salo).
0.7.0#
Released November 2020
HIGHLIGHTS#
- Nilearn now includes the functionality of Nistats as - nilearn.glm. This module is experimental, hence subject to change in any future release. Here’s a guide to replacing Nistats imports to work in Nilearn. (#2299, #2304, and #2307 by Kshitij Chawla, and #2509 by Binh Nguyen).
- New classes - 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 (#2000 by Binh Nguyen).
- New classes - nilearn.decoding.FREMClassifier(for classification) and- nilearn.decoding.FREMRegressor(for regression) extend the- Decoderobject with one fast clustering step at the beginning and aggregates a high number of estimators trained on various splits of the training set (#2327 by Thomas Bazeille).
- New plotting functions: - plot_eventto visualize events file.
- plot_roican now plot ROIs in contours with- view_typeargument.
- plot_carpetgenerates a “carpet plot” (also known as a “Power plot” or a “grayplot”)
- plot_img_on_surfgenerates multiple views of- plot_surf_stat_mapin a single figure.
- plot_markersshows network nodes (markers) on a glass brain template
- plot_surf_contoursplots the contours of regions of interest on the surface
 
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_eventto visualize events file. The function accepts the BIDS events file read using pandas utilities.
- Plotting function - nilearn.plotting.plot_roican now plot ROIs in contours with view_type argument.
- New plotting function - nilearn.plotting.plot_carpetgenerates 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_surfgenerates multiple views of- nilearn.plotting.plot_surf_stat_mapin a single figure.
- nilearn.plotting.plot_markersshows 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_contoursplots 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.maskers.NiftiLabelsMaskerno longer ignores its mask_img
- nilearn.masking.compute_brain_maskhas 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_olsno 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#
- Function - nilearn.datasets.fetch_cobrehas been deprecated and will be removed in release 0.9 .
- Function - nilearn.plotting.plot_connectome_strengthhas been deprecated and will be removed in release 0.9 .
- nilearn.connectome.ConnectivityMeasurecan now remove confounds in its transform step.
- nilearn.surface.vol_to_surfcan now sample between two nested surfaces (eg white matter and pial surfaces) at specific cortical depths
- nilearn.datasets.fetch_surf_fsaveragenow also downloads white matter surfaces.
0.6.2#
Released February 2020
ENHANCEMENTS#
- Generated documentation now includes Binder links to launch examples interactively in the browser (#2300 by Elizabeth DuPre). 
- NiftiSpheresMaskernow has an inverse transform, projecting spheres to the corresponding- mask_img(#2429 by Simon Steinkamp).
Fixes#
- More robust matplotlib backend selection (#2302 by Gael Varoquaux). 
- Typo in example fixed (#2312 by Jon Haitz Legarreta Gorrono). 
Changes#
- Function - nilearn.datasets.fetch_nyu_resthas been deprecated and will be removed in Nilearn- 0.8.0(#2308 by Joshua Teves).
Contributors#
The following people contributed to this release:
0.6.1#
Released January 2020
ENHANCEMENTS#
- HTML pages use the user-provided plot title, if any, as their title (#2272 by Jerome Dockes). 
Fixes#
- Fetchers for developmental_fmri and localizer datasets resolve URLs correctly (#2290 by Elizabeth DuPre). 
Contributors#
The following people contributed to this release:
0.6.0#
Released December 2019
HIGHLIGHTS#
Warning
3.5 environment will be warned at their first Nilearn import.Matplotlib -- v2.0.Scikit-learn -- v0.19.Scipy -- v0.19.NEW#
- New method for - NiftiMaskerinstances for generating reports viewable in a web browser, Jupyter Notebook, or VSCode (#2019 by Elizabeth DuPre).
- New function - get_datato 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_datamethod. You may also consider using the Nibabel method- nibabel.nifti1.Nifti1Image.get_fdata, which returns the data cast to floating-point. See BIAP8. As a benefit, the- get_datafunction works on niimg-like objects such as filenames (see input_output) (#2172 by Jerome Dockes).
- New class - ReNAimplementing parcellation method ReNA: Fast agglomerative clustering based on recursive nearest neighbor grouping. Yields very fast & accurate models, without creation of giant clusters (#1336 by Andrés Hoyos Idrobo).
- New function - nilearn.plotting.plot_connectome_strengthto plot the strength of a connectome on a glass brain. Strength is absolute sum of the edges at a node (#2028 by Guillaume Lemaitre).
- Function - resample_imghas 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 class- NiftiMaskerwhen using the- mask_strategy="template"option for brains in MNI space (#2025 by Greg Kiar).
- New brain development fMRI dataset fetcher - datasets.fetch_development_fmrican 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 (#1953 by Kamalakar Reddy Daddy).
ENHANCEMENTS#
- Functions - view_img_on_surf,- view_surfand- view_connectomecan display a title, and allow disabling the colorbar, and setting its height and the fontsize of its ticklabels (#1951 by Jerome Dockes).
- Rework of the standardize-options of function - cleanand the various Maskers in- nilearn.maskers. You can now set- standardizeto- zscoreor- psc.- pscstands for- Percent Signal Change, which can be a meaningful metric for BOLD (#1952 by Gilles de Hollander).
- Class - NiftiLabelsMaskernow accepts an optional- strategyparameter which allows it to change the function used to reduce values within each labelled ROI. Available functions include- mean,- median,- minimum,- maximum,- standard_deviationand- variance. This change is also introduced in function- img_to_signals_labels(#2221 by Daniel Gomez).
- Function - view_surfnow accepts surface data provided as a file path (#2057 by Jerome Dockes).
CHANGES#
- Function - plot_imgnow has explicit keyword arguments- bg_img,- vminand- vmaxto control the background image and the bounds of the colormap. These arguments were already accepted in- kwargsbut not documented before (#2157 by Jerome Dockes).
FIXES#
- Class - NiftiLabelsMaskerno longer truncates region means to their integral part when input images are of integer type (#2195 by Kshitij Chawla).
- The argument - version='det'in function- fetch_atlas_pauli_2017now works as expected (#2235 by Ryan Hammonds).
- pip install nilearnnow installs the necessary dependencies (#2214 by Kshitij Chawla).
Lots of other fixes in documentation and examples. More detailed change list follows:
0.6.0rc#
NEW#
Warning
- Function - view_connectomeno longer accepts old parameter names. Instead of- coords,- threshold,- cmap, and- marker_size, use- node_coords,- edge_threshold,- edge_cmap, and- node_sizerespectively (#2255 by Kshitij Chawla).
- Function - view_markersno longer accepts old parameter names. Instead of- coordand- color, use- marker_coordsand- marker_colorrespectively (#2255 by Kshitij Chawla).
- 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 (#2214 by Kshitij Chawla). 
Changes#
- Add a warning to - Parcellationsif the generated number of parcels does not match the requested number of parcels (#2240 by Elizabeth DuPre).
- Class - NiftiLabelsMaskernow accepts an optional- strategyparameter which allows it to change the function used to reduce values within each labelled ROI. Available functions include- mean,- median,- minimum,- maximum,- standard_deviationand- variance. This change is also introduced in function- img_to_signals_labels(#2221 by Daniel Gomez).
Fixes#
- Class - NiftiLabelsMaskerno longer truncates region means to their integral part when input images are of integer type (#2195 by Kshitij Chawla).
- Function - smooth_imgno longer fails if- fwhmis a- numpy.ndarray(#2107 by Paula Sanz-Leon).
- pip install nilearnnow installs the necessary dependencies (#2214 by Kshitij Chawla).
- Function - new_img_likeno longer attempts to copy non-iterable headers (#2212 by Kshitij Chawla).
- Nilearn no longer raises - ImportErrorfor nose when Matplotlib is not installed (#2231 by Kshitij Chawla).
- The argument - version='det'in function- fetch_atlas_pauli_2017now works as expected (#2235 by Ryan Hammonds).
- Method - inverse_transformnow works without the need to call- transformfirst (#2248 by Gael Varoquaux).
Contributors#
The following people contributed to this release (in alphabetical order):
0.6.0b0#
Released November 2019
Warning
NEW#
- New function - get_datato 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_datamethod. You may also consider using the Nibabel method- nibabel.nifti1.Nifti1Image.get_fdata, which returns the data cast to floating-point. See BIAP8. As a benefit, the- get_datafunction works on niimg-like objects such as filenames (see input_output) (#2172 by Jerome Dockes).
Changes#
- All functions and examples now use function - get_datarather than the deprecated method- nibabel.Nifti1Image.get_data(#2172 by Jerome Dockes).
- Function - fetch_neurovaultnow does not filter out images that have their metadata field- is_validcleared by default (#2169 by Jerome Dockes).
- Users can now specify fetching data for adults, children, or both from - fetch_development_fmri.
Fixes#
- Function - plot_connectomenow correctly displays marker size on ‘l’ and ‘r’ orientations, if an array or a list is passed to the function.
Contributors#
The following people contributed to this release (in alphabetical order):
0.6.0a0#
Released October 2019
NEW#
Warning
Matplotlib -- v2.0.Scikit-learn -- v0.19.Scipy -- v0.19.- A new method for - NiftiMaskerinstances for generating reports viewable in a web browser, Jupyter Notebook, or VSCode (#2019 by Elizabeth DuPre).
- joblibis now a dependency (#2090 by Jerome Dockes).
- New class - ReNAimplementing parcellation method ReNA: Fast agglomerative clustering based on recursive nearest neighbor grouping. Yields very fast & accurate models, without creation of giant clusters (#1336 by Andrés Hoyos Idrobo).
- New function - nilearn.plotting.plot_connectome_strengthto plot the strength of a connectome on a glass brain. Strength is absolute sum of the edges at a node (#2028 by Guillaume Lemaitre).
- Function - resample_imghas 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 class- NiftiMaskerwhen using the- mask_strategy="template"option for brains in MNI space (#2025 by Greg Kiar).
- New brain development fMRI dataset fetcher - fetch_development_fmrican 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.pyto compare methods for classifying subjects into age groups based on functional connectivity. Similar example in- examples/03_connectivity/plot_group_level_connectivity.pysimplified (#2063 by Jerome Dockes).
- Merged - examples/03_connectivity/plot_adhd_spheres.pyand- examples/03_connectivity/plot_sphere_based_connectome.pyto remove duplication across examples. The improved- examples/03_connectivity/plot_sphere_based_connectome.pycontains concepts previously reviewed in both examples (#2013 by Jake Vogel).
- Merged - examples/03_connectivity/plot_compare_decomposition.pyand- examples/03_connectivity/plot_canica_analysis.pyinto an improved- examples/03_connectivity/plot_compare_decomposition.py(#2013 by Jake Vogel).
- The Localizer dataset now follows the BIDS organization. 
Changes#
- All the connectivity examples are changed from ADHD to brain development fMRI dataset. 
- Examples - plot_decoding_tutorial,- plot_haxby_decoder,- plot_haxby_different_estimators,- plot_haxby_full_analysis,- plot_oasis_vbmnow use- Decoderand- DecoderRegressorinstead of sklearn SVC and SVR (#2000 by Binh Nguyen).
- Functions - view_img_on_surf,- view_surfand- view_connectomecan display a title, and allow disabling the colorbar, and setting its height and the fontsize of its ticklabels (#1951 by Jerome Dockes).
- Rework of the standardize-options of function - cleanand the various Maskers in- nilearn.maskers. You can now set- standardizeto- zscoreor- psc.- pscstands for- Percent Signal Change, which can be a meaningful metric for BOLD (#1952 by Gilles de Hollander).
- Function - plot_imgnow has explicit keyword arguments- bg_img,- vminand- vmaxto control the background image and the bounds of the colormap. These arguments were already accepted in- kwargsbut not documented before (#2157 by Jerome Dockes).
- Function - view_connectomenow converts- NaNsin the adjacency matrix to 0 (#2166 by Jerome Dockes).
- Removed the plotting connectomes example which used the Seitzman atlas from - examples/03_connectivity/plot_sphere_based_connectome.py. The atlas data is unsuitable for the method & the example is redundant (#2177 by Kshitij Chawla).
Fixes#
- Function - plot_glass_brainwith- colorbar=Truedoes not crash when images have- NaNs(#1953 by Kamalakar Reddy Daddy).
- Function - add_contoursnow accepts- thresholdargument for- filled=False. Now- thresholdis equally applied when asked for fillings in the contours.
- Functions - plot_surfand- plot_surf_stat_mapno longer threshold zero values when no threshold is given (#1997 by Julia Huntenburg).
- Function - plot_surf_stat_mapused with a thresholded map but without a background map results in the surface mesh being displayed in half-transparent grey to maintain a 3D perception (#1997 by Julia Huntenburg).
- Function - view_surfnow accepts surface data provided as a file path.
- Function - plot_glass_brainnow correctly displays the left ‘l’ orientation even when the given images are completely masked (empty images) (#1888 by Kamalakar Reddy Daddy).
- Function - plot_matrixwith providing- labels=None,- False, or an empty list now correctly disables labels (#2083 by Moritz Boos).
- Function - plot_surf_roinow takes- vmin, and- vmaxparameters (#2052 by Ian Abenes).
- Function - fetch_surf_nki_enhancedis now downloading the correct left and right functional surface data for each subject (#2118 by Julia Huntenburg).
- Function - fetch_atlas_schaefer_2018now downloads from release version- 0.14.3(instead of- 0.8.1) by default, which includes corrected region label names along with 700 and 900 region parcelations (#2138 by Dan Gale).
- Colormap creation functions have been updated to avoid matplotlib deprecation warnings about colormap reversal (#2131 by Eric Larson). 
- Neurovault fetcher no longer fails if unable to update dataset metadata file due to faulty permissions. 
Contributors#
The following people contributed to this release (in alphabetical order):
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 Python 3.5.
We recommend switching to Python 3.6.
Fixes#
- Plotting - .mgzfiles in MNE broke in- 0.5.1and has been fixed.
Contributors#
The following people contributed to this release:
Kshitij Chawla (11)
Gael Varoquaux (3)
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 - dtypefrom header information.
- New display mode - tiledwhich allows 2x2 plot arrangement when plotting three cuts (see Plotting brain images).
- Class - NiftiLabelsMaskernow 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 - fetch_atlas_schaefer_2018.
- New function - fetch_coords_seitzman_2018.
Changes#
- Lighting used for interactive surface plots changed; plots may look a bit different. 
- Function - view_connectomedefault colormap is- bwr, consistent with function- plot_connectome.
- Function - view_connectomeparameter names are consistent with function- plot_connectome:- coordsis now- node_coord.
- marker_sizeis now- node_size.
- cmapis now- edge_cmap.
- thresholdis now- edge_threshold.
 
- Functions - view_markersand- view_connectomecan accept different marker sizes for each node / marker.
- Function - plotting.view_markersdefault marker color is now- red, consistent with- add_markers().
- Function - plotting.view_markersparameter names are consistent with- add_markers():- coordsis now- marker_coords.
- colorsis now- marker_color.
 
- Function - view_img_on_surfnow accepts a- symmetric_cmapargument to control whether the colormap is centered around 0 and a- vminargument.
- Users can now control the size and fontsize of colorbars in interactive surface and connectome plots, or disable the colorbar. 
Fixes#
- Example - plot_seed_to_voxel_correlationnow really saves z-transformed maps.
- Function - connected_regionsand class- RegionExtractornow correctly use the provided- mask_img.
- Function - load_niimgno longer drops header if- dtypeis changed.
- Class - NiftiSpheresMaskerno longer silently ignores voxels if no- mask_imgis specified.
- Interactive brainsprites generated from - view_imgare correctly rendered in Jupyter Book.
Known Issues#
- On Python2, functions - view_connectomeand function- view_markersdo not show parameters names in function signature when using- help()and similar features. Please refer to their docstrings for this information.
- Plotting - .mgzfiles in MNE is broken.
Contributors#
The following people contributed to this release:
Bertrand Thirion (2)
Kshitij Chawla (90)
Franz Liem (22)
Jerome Dockes (16)
Gael Varoquaux (11)
Salma Bougacha (8)
himanshupathak21061998 (7)
Elizabeth DuPre (2)
Eric Larson (1)
Pierre Bellec (1)
0.5.0#
Released November 2018
NEW#
- interactive plotting functions, eg for use in a notebook. 
- New functions - view_surfand- view_img_on_surffor interactive visualization of maps on the cortical surface in a web browser.
- New functions - view_connectomeand- view_markersfor interactive visualization of connectomes and seed locations in 3D.
- New function - view_imgfor interactive visualization of volumes with 3 orthogonal cuts.
Note
Function view_img was nilearn.plotting.view_stat_map in alpha and beta releases.
- Function - find_parcellation_cut_coordsfor extraction of coordinates on brain parcellations denoted as labels.
- Function - find_probabilistic_atlas_cut_coordsfor extraction of coordinates on brain probabilistic maps.
- 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#
- Function - clean_imgnow accepts a mask to restrict the cleaning of the image, reducing memory load and computation time.
- NiftiMaskersnow have a- dtypeparameter, 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). 
- 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. 
- The - fitmethod now accepts 4D niimgs.
- Anaconda link in the installation documentation updated. 
- Scipyis listed as a dependency for Nilearn installation.
Changes#
- Default value of - t_rin functions- cleanand- clean_imgis- Noneand cannot be- Noneif- low_passor- high_passis specified.
Lots of changes and improvements. Detailed change list for each release follows.
0.5.0 rc#
Highlights#
- Function - view_img(formerly- nilearn.plotting.view_stat_mapin Nilearn- 0.5.0pre-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.
- Function - clean_imgnow 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#
- Function - view_imgis now using the- brainsprite.jslibrary, which results in much smaller notebooks or html pages. The interactive viewer also looks more similar to the plots generated by function- plot_stat_map, and most parameters found in- plot_stat_mapare now supported in- view_img.
- Function - clean_imgnow accepts a mask to restrict the cleaning of the image. This approach can help to reduce the memory load and computation time.
- Method - fitraises a meaningful error in regression tasks if the target Y contains all 1s.
Changes#
- Default value of - t_rin functions- cleanand- clean_imgis changed from 2.5 to- None. If- low_passor- high_passis specified, then- t_rneeds to be specified as well otherwise it will raise an error.
- Order of filters in functions - cleanand- clean_imghas 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).
- Function - clean_imgnow accepts a mask to restrict the cleaning of the image. This approach can help to reduce the memory load and computation time.
- Function - view_imgis now using the- brainsprite.jslibrary, which results in much smaller notebooks or html pages. The interactive viewer also looks more similar to the plots generated by- plot_stat_map, and most parameters found in- plot_stat_mapare now supported in- view_img.
Contributors#
The following people contributed to this release:
Gael Varoquaux (15)
Pierre Bellec (114)
Michael Notter (30)
Kshitij Chawla (28)
himanshupathak21061998 (4)
Christian Horea (1)
Jerome Dockes (7)
0.5.0 beta#
Released October 2018
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) (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 (by Eric Larson). 
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#
- Method - decoding.SearchLight.fitnow accepts 4D niimgs (by Dan Gale).
- plotting.view_markers.open_in_browser()in- js_plotting_utilsfixed.
- Brainomics dataset has been replaced in several examples. 
- Lots of other fixes in documentation and examples. 
Changes#
- In function - img_to_signals_labels, the- See Alsosection in documentation now also points to- NiftiLabelsMaskerand- NiftiMapsMasker.
- Scipyis listed as a dependency for Nilearn installation.
- Anaconda link in the installation documentation updated. 
Contributors#
The following people contributed to this release:
Gael Varoquaux (58)
Kshitij Chawla (115)
Jerome Dockes (15)
Oscar Esteban (14)
Eric Larson (10)
Bertrand Thirion (3)
Alexandre Abadie (5)
Sourav Singh (4)
Alex Rothberg (3)
AnaLu (3)
Christian Horea (3)
Jason Gors (3)
Jean Remi King (3)
MADHYASTHA Meghana (3)
Simon Steinkamp (3)
Salma Bougacha (3)
sfvnMAC (3)
Akshay (2)
Daniel Gomez (2)
Pierre Bellec (2)
Ariel Rokem (2)
erramuzpe (2)
foucault (2)
jehane (2)
Sylvain LANNUZEL (1)
Aki Nikolaidis (1)
Christophe Bedetti (1)
Dan Gale (1)
Dillon Plunkett (1)
Greg Operto (1)
Ivan Gonzalez (1)
Yaroslav Halchenko (1)
dtyulman (1)
0.5.0 alpha#
Released August 2018
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#
- All - NiftiMaskersnow have a- dtypeargument. For now the default behaviour is to keep the same data type as the input data.
- Displays created by plotting functions can now add a scale bar to indicate the size in mm or cm (see Plotting brain images) (by Oscar Esteban). 
- New functions - view_surfand- view_surfand- view_img_on_surffor interactive visualization of maps on the cortical surface in a web browser.
- New functions - view_connectomeand- view_markersto visualize connectomes and seed locations in 3D
- New function - nilearn.plotting.view_stat_map(renamed to- view_imgin stable release) for interactive visualization of volumes with 3 orthogonal cuts.
- New function - fetch_surf_fsaverageto download either- fsaverageor- fsaverage5(Freesurfer cortical meshes).
- New function - fetch_atlas_pauli_2017to download a recent subcortical neuroimaging atlas.
- New function - find_parcellation_cut_coordsfor extraction of coordinates on brain parcellations denoted as labels.
- New function - find_probabilistic_atlas_cut_coordsfor extraction of coordinates on brain probabilistic maps.
- New functions - fetch_neurovault_auditory_computation_taskand- fetch_neurovault_motor_taskfor simple example data.
Changes#
- Function - nilearn.datasets.fetch_surf_fsaverage5is deprecated and will be removed in a future release. Use function- fetch_surf_fsaverage, with the parameter- mesh="fsaverage5"(the default) instead.
- fsaverage5surface data files are now shipped directly with Nilearn (see #1705 for discussion).
- sklearn.cross_validationand- sklearn.grid_searchhave been replaced by- sklearn.model_selectionin 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:
Gael Varoquaux (49)
Jerome Dockes (180)
Kshitij Chawla (57)
Sylvain Lan (38)
Gilles de Hollander (10)
Bertrand Thirion (4)
MENUET Romuald (4)
Moritz Boos (3)
Peer Herholz (1)
Pierre Bellec (1)
0.4.2#
Released June 2018
Few important bugs fix release for OHBM conference.
Changes#
- Default colormaps for surface plotting functions have changed to be more consistent with slice plotting. - plot_surf_stat_mapnow uses- cold_hot, as- plot_stat_mapdoes, and- plot_surf_roinow uses- gist_ncar, as- plot_roidoes.
- Improve 3D surface plotting: lock the aspect ratio of the plots and reduce the whitespace around the plots. 
Fixes#
- Fix bug with input repetition time (TR) which had no effect in signal cleaning (fixed by Pradeep Reddy Raamana). 
- Fix issues with signal extraction on list of 3D images in - Parcellations.
- Fix issues with raising - AttributeErrorrather than- HTTPErrorin datasets fetching utilities (by Jerome Dockes).
- Fix issues in datasets testing function uncompression of files (by Pierre Glaser). 
0.4.1#
Released March 2018
This bug fix release is focused on few bug fixes and minor developments.
Enhancements#
- Classes - CanICAand- DictLearninghave a new attribute- components_img_providing directly the components learned as a- Nifti1Image. This avoids the step of unmasking the attribute- components_which is true for older versions (#1536 by Kamalakar Reddy Daddy).
- New class - nilearn.regions.Parcellationsfor learning brain parcellations on fMRI data (#1370 by Kamalakar Reddy Daddy).
- Add optional reordering of the matrix using a argument - reorderwith function- plot_matrix.
Note
This feature is usable only if SciPy version is >= 1.0.0.
Changes#
- Using output attribute - components_which is an extracted components in classes- CanICAand- DictLearningis deprecated and will be removed in next two releases. Use- components_img_instead (#1536 by Kamalakar Reddy Daddy).
Bug fixes#
- Fix issues using function - plot_connectomewhen string is passed in- node_colorwith display modes left and right hemispheric cuts in the glass brain.
- Fix bug while plotting only coordinates using - add_markerson glass brain (#1595 by Kamalakar Reddy Daddy).
- Fix issues with estimators in decomposition module when input images are given in glob patterns. 
- Fix bug loading - Nifti2Image.
- Fix bug while adjusting contrast of the background template while using function - plot_prob_atlas.
- Fix colormap bug with recent - matplotlib 2.2.0.
0.4.0#
Released November 2017
Highlights#
- New function - vol_to_surfto project volume data to the surface.
- New function - plot_matrixto display matrices, eg connectomes.
Enhancements#
- New function - vol_to_surfto project a 3d or 4d brain volume on the cortical surface.
- New function - plot_matrixto display connectome matrices.
- Expose function - coord_transformfor end users. Useful to transform coordinates (x, y, z) from one image space to another space.
- Function - resample_imgnow takes a linear resampling option (implemented by Joe Necus).
- Function - fetch_atlas_talairachto fetch the Talairach atlas (#1523 by Jerome Dockes).
- Enhancing new surface plotting functions, added new parameters - axesand- figureto accept user-specified instances in- plot_surf,- plot_surf_stat_map, and- plot_surf_roi.
- Class - SearchLighthas new parameter- groupsto do- LeaveOneGroupOuttype cv with new scikit-learn module model selection.
- Enhancing the glass brain plotting in back view ‘y’ direction. 
- New parameter - resampling_interpolationis added in most used plotting functions to have user control for faster visualizations.
- Upgraded to - Sphinx-Gallery 0.1.11.
Fixes#
- Dimming factor applied to background image in plotting functions with - dimparameter 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: Function - find_xyz_cut_coordsnow takes a- mask_imgargument which is a niimg, rather than a- maskargument, which used to be a numpy array.
- The minimum required version for - scipyis now- 0.14.
- Dropped support for - Nibabelolder than- 2.0.2.
- Function - smooth_imgno longer accepts smoothing parameter FWHM as 0. Behavior is changed in according to the issues with recent- SciPyversion- 1.0.0.
- dimfactor 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 - anteriorand- posteriorview added to the- plot_surffamily views.
- Using argument - anat_imgfor placing background image in function- plot_prob_atlasis deprecated. Use argument- bg_imginstead.
- The examples now use - pandasfor the behavioral information.
Contributors#
The following people contributed to this release:
Jerome Dockes (127)
Gael Varoquaux (62)
Jeff Chiang (11)
Elizabeth DuPre (9)
Jona Sassenhagen (9)
Sylvain Lan (7)
J Necus (6)
AnaLu (3)
Jean-Rémi King (3)
MADHYASTHA Meghana (3)
Salma Bougacha (3)
sfvnMAC (3)
Eric Larson (2)
Christian Horea (2)
Moritz Boos (2)
Alex Rothberg (1)
Bertrand Thirion (1)
Christophe Bedetti (1)
John Griffiths (1)
Mehdi Rahim (1)
Sylvain LANNUZEL (1)
Yaroslav Halchenko (1)
clfs (1)
0.3.1#
Released June 2017
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.
Changes#
- The function - sym_to_vecis deprecated and will be removed in release- 0.4. Use function- sym_matrix_to_vecinstead.
- Added argument - smoothing_fwhmto- RegionExtractorto control smoothing according to the resolution of atlas images.
Fixes#
- The helper function - largest_connected_componentshould 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 - Nifti1Imagepassed to resampling the image.
Enhancements#
- New functions - fetch_neurovaultand- fetch_neurovault_idshelp you download statistical maps from the Neurovault platform.
- New function - vec_to_sym_matrixreshapes vectors to symmetric matrices. It acts as the reverse of function- sym_matrix_to_vec.
- Add an option allowing to vectorize connectivity matrices returned by the - transformmethod of class- ConnectivityMeasure.
- Class - ConnectivityMeasurenow exposes an- inverse_transformmethod, useful for going back from vectorized connectivity coefficients to connectivity matrices. Also, it allows to recover the covariance matrices for the “tangent” kind.
- Reworking and renaming of connectivity measures example. Renamed from - plot_connectivity_measuresto- plot_group_level_connectivity.
- Tighter bounding boxes when using - add_contoursfor plotting.
- Function - largest_connected_component_imgto directly extract the largest connected component from- Nifti1Image.
- Improvements in plotting, decoding and functional connectivity examples. 
0.3.0#
Released April 2017
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.
Changes#
- Function - find_cut_slicesnow supports to accept- Nifti1Imageas an input for argument- img.
- Helper functions - _get_mask_volumeand- _adjust_screening_percentileare now moved to- param_validationfile in utilities module to be used in common with Decoder object.
Fixes#
- Fix bug uncompressing tar files with datasets fetcher. 
- Fixed bunch of CircleCI documentation build failures. 
- Fixed deprecations - set_axis_bgcolorrelated to matplotlib in plotting functions.
- Fixed bug related to not accepting a list of arrays as an input to unmask, in - nilearn.maskingmodule.
Enhancements#
0.3.0 beta#
Released February 2017
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 - NiBabelis now- 1.2.0, to support loading annotated data with freesurfer.
Changes#
- A helper function - _safe_get_dataas a nilearn utility now safely removes- NaNvalues in the images with argument- ensure_finite=True.
- Functions - cov_to_corrand- prec_to_partialcan now be used.
Fixes#
- Fix colormap issue with - colorbar=Truewhen using qualitative colormaps. Fixed in according with changes of- matplotlib 2.0fixes.
- Fix plotting functions to work with - NaNvalues in the images.
- Fix bug related get - dtypeof the images with- nibabel get_data().
- Fix bug in function - clean_img.
Enhancements#
- New function - connected_label_regionsto 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. - Matplotlibwith version higher- 1.3.1is required for plotting surface data using these functions.
- Function - plot_surfcan be used for plotting surfaces mesh data with optional background.
- Function - plot_surf_stat_mapcan be used for plotting statistical maps on a brain surface with optional background.
- Function - plot_surf_roican be used for plotting statistical maps rois onto brain surface.
- Function - nilearn.datasets.fetch_surf_fsaverage5can be used for surface data object to be as background map for the above plotting functions.
- New function - fetch_atlas_surf_destrieuxcan give you Destrieux et. al 2010 cortical atlas in- fsaverage5surface space.
- New function - fetch_surf_nki_enhancedgives you resting state data preprocessed and projected to- fsaverage5surface space.
- Two good examples in plotting gallery shows how to fetch atlas and NKI data and used for plotting on brain surface. 
- New function - load_surf_meshin- surf_plottingmodule for loading surface mesh data into two arrays, containing- (x, y, z)coordinates for mesh vertices and indices of mesh faces.
- New function - load_surf_datain- surf_plottingmodule for loading data of numpy array to represented on a surface mesh.
- Add fetcher for Allen et al. 2011 RSN atlas in - fetch_atlas_allen_2011.
- Function - nilearn.datasets.fetch_cobreis 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. 
- coverallsis replaced with- codecov.
- Upgraded to - Sphinxversion- 0.1.7.
- Extensive plotting example shows how to use contours and filled contours on glass brain. 
0.2.6#
Released September 2016
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.
Fixes#
- Change default - dtypein function- concat_imgsto be the original type of the data (see #1238).
- Fix - SearchLightthat did not run without- process_maskor with one voxel mask.
- Fix flipping of left hemisphere when plotting glass brain. 
- Fix bug when downloading ABIDE timeseries. 
Enhancements#
- Sphinx-galleryupdated to version- 0.1.3.
- Refactoring of examples and documentation. 
- Better ordering of regions in function - fetch_coords_dosenbach_2010.
- Remove outdated power atlas example. 
Changes#
- The parameter - n_subjectsis deprecated and will be removed in future release. Use- subjectsinstead in function- fetch_haxby.
- The function - fetch_haxbywill now fetch the data accepting input given in- subjectsas a list than integer.
- Replace - get_affineby- affinewith recent versions of- nibabel.
0.2.5.1#
Released August 2016
This is a bugfix release.
The new minimum required version of scikit-learn is 0.14.1.
Changes#
- Default option for - dimargument 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-learnvalidation tools have been imported and are now used to check consistency of input data, in SpaceNet for example.
New#
- Add an option to select only off-diagonal elements in function - 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 - ConnectivityMeasure.
Fixes#
- Scipy 0.18introduces a bug in a corner-case of resampling. Nilearn- 0.2.5can 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#
Released June 2016
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#
- New display_mode options in functions - plot_glass_brainand- plot_connectome. It is possible to plot right and left hemisphere projections separately.
- New function - load_mni152_brain_maskto load canonical brain mask image in MNI template space.
- New function - fetch_icbm152_brain_gm_maskto load brain grey matter mask image.
- New function - load_imgloads data from a filename or a list of filenames.
- New function - clean_imgapplies the cleaning function- cleanon all voxels.
- New simple data downloader - fetch_localizer_button_taskto simplify some examples.
- Function - fetch_localizer_contrastscan now download a specific list of subjects rather than a range of subjects.
- New function - get_data_dirsto check where nilearn downloads data.
Contributors#
Contributors (from git shortlog -ns 0.2.4..0.2.5):
Gael Varoquaux (55)
Alexandre Abraham (39)
Martin Perez-Guevara (26)
Amadeus Kanaan (8)
Alexandre Abadie (3)
Arthur Mensch (3)
Elvis Dohmatob (3)
Loic Estève (3)
Jerome Dockes (2)
Alexandre M. S (1)
Bertrand Thirion (1)
Ivan Gonzalez (1)
Roberto Guidotti (1)
0.2.4#
Released April 2016
The 0.2.4 is a small release focused on documentation for teaching.
New#
- The path given to the - memoryargument of object now have their “~” expanded to the homedir.
- Display object created by plotting now uniformly expose an - add_markersmethod.
- Function - plot_connectomenow plots connectome with colorbars.
- New function - resample_to_imgto resample one image on another one (just resampling / interpolation, no coregistration).
Changes#
- Atlas fetcher - fetch_atlas_msdlnow returns directly labels of the regions in output variable- labelsand its coordinates in output variable- region_coordsand its type of network in- networks.
- The output variable name - regionsis now changed to- mapsin AAL atlas fetcher- fetch_atlas_aal.
- AAL atlas now returns directly its labels in variable - labelsand its index values in variable- indices.
0.2.3#
Released February 2016
Changelog#
The 0.2.3 is a small feature release for BrainHack 2016.
New features#
- Mathematical formulas based on - numpyfunctions can be applied on an image or a list of images using function- math_img.
- Downloader for COBRE datasets of 146 rest fMRI subjects with function - nilearn.datasets.fetch_cobre.
- Downloader for Dosenbach atlas - fetch_coords_dosenbach_2010.
- Fetcher for multiscale functional brain parcellations (BASC) - fetch_atlas_basc_multiscale_2015.
Bug fixes#
- Better dimming on white background for plotting. 
0.2.2#
Released February 2016
The 0.2.2 is a bugfix + dependency update release (for sphinx-gallery).
It aims at preparing a renewal of the tutorials.
New#
- Fetcher for Megatrawl Netmats dataset. 
Enhancements#
- Flake8 is now run on pull requests. 
- Reworking of the documentation organization. 
- Sphinx-galleryupdated to version- 0.1.1.
- The default - n_subjects=Nonein function- fetch_adhdis now changed to- n_subjects=30.
Fixes#
- Fix - symmetric_splitbehavior in function- fetch_atlas_harvard_oxford.
- Fix casting errors when providing integer data to function - high_variance_confounds.
- Fix matplotlib - 1.5.0compatibility in function- plot_prob_atlas.
- Fix matplotlib backend choice on Mac OS X. 
- Function - find_xyz_cut_coordsraises a meaningful error when 4D data is provided instead of 3D.
- Class - NiftiSpheresMaskerhandles radius smaller than the size of a voxel.
- Class - RegionExtractorhandles data containing- Nans.
- Confound regression does not force systematically the normalization of the confounds. 
- Force time series normalization in - ConnectivityMeasureand check dimensionality of the input.
- Function - nilearn._utils.numpy_conversions.csv_to_arraycould consider valid CSV files as invalid.
Changes#
- 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):
Alexandre Abraham (22)
Loic Estève (21)
Gael Varoquaux (19)
Alexandre Abadie (12)
Salma Bougacha (7)
Danilo Bzdok (3)
Arthur Mensch (1)
Ben Cipollini (1)
Elvis Dohmatob (1)
Óscar Nájera (1)
0.2.1#
Released December 2015
Changelog#
Small bugfix for more flexible input types (targetter in particular at making code easier in nistats).
0.2.0#
Released December 2015
Changelog#
Warning
The new minimum required version of scikit-learn is 0.13.
New features#
- The new module - nilearn.connectomenow has class- nilearn.connectome.ConnectivityMeasurecan be useful for computing functional connectivity matrices.
- The function - nilearn.connectome.sym_to_vecin same module- nilearn.connectomeis also implemented as a helper function to class- nilearn.connectome.ConnectivityMeasure.
- The class - decomposition.DictLearningin- nilearn.decompositionis a decomposition method similar to ICA that imposes sparsity on components instead of independence between them.
- Integrating back references template from - sphinx-galleryof- 0.0.11version release.
- Globbing expressions can now be used in all nilearn functions expecting a list of files. 
- The new module - nilearn.regionsnow has class- regions.RegionExtractorwhich can be used for post processing brain regions of interest extraction.
- The function - connected_regionsin- nilearn.regionsis also implemented as a helper function to- regions.RegionExtractor.
- The function - threshold_imgin- nilearn.imageis implemented to use it for thresholding statistical maps.
Enhancements#
- Making website a bit elaborated & modernise by using - sphinx-gallery.
- Documentation enhancement by integrating - sphinx-gallerynotebook style examples.
- Documentation about class - maskers.NiftiSpheresMasker.
Bug fixes#
- Fixed bug to control the behaviour when - cut_coords=0in function- plot_stat_mapin- nilearn.plotting(See #784).
- Fixed bug in function - copy_imgoccurred while caching the Nifti images (See #793).
- Fixed bug causing an - IndexErrorin- fast_abs_percentile(See #875).
API changes summary#
- The utilities in function - group_sparse_covariancehave been moved into module- nilearn.connectome.
- The default value for number of cuts ( - n_cuts) in function- find_cut_slicesin- nilearn.plottingmodule has been changed from 12 to 7 i.e.- n_cuts=7.
Contributors#
Contributors (from git shortlog -ns 0.1.4..0.2.0):
Elvis Dohmatob (822)
Gael Varoquaux (142)
Alexandre Abraham (119)
Loic Estève (90)
Alexandre Abadie (65)
Chris Gorgolewski (43)
Salma Bougacha (39)
Danilo Bzdok (29)
Martin Perez-Guevara (20)
Mehdi Rahim (19)
Óscar Nájera (19)
Arthur Mensch (8)
Ben Cipollini (8)
Julia Huntenburg (4)
Michael Hanke (2)
Ariel Rokem (2)
Bertrand Thirion (1)
0.1.4#
Released July 2015
Highlights#
- New class - nilearn.maskers.NiftiSpheresMaskerwhich extracts 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):
Alexandre Abraham (141)
Gael Varoquaux (15)
Loic Estève (10)
Arthur Mensch (2)
Danilo Bzdok (2)
Michael Hanke (2)
Mehdi Rahim (1)
0.1.3#
Released May 2015
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.
Warning
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)
Fixes#
- Dealing with - NaNsin function- 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_overlayfinds- vminand- vmaxautomatically.
- Function - plot_connectomenow supports- vminand- vmax.
- Detrending 3D images no longer puts them to zero. 
Contributors (from git shortlog -ns 0.1.2..0.1.3):
Alexandre Abraham (129)
Loic Estève (67)
Gael Varoquaux (57)
Ben Cipollini (44)
Danilo Bzdok (37)
Elvis Dohmatob (20)
Óscar Nájera (14)
Salma Bougacha (9)
Bertrand Thirion (1)
0.1.2#
Released March 2015
Changelog#
The 0.1.2 release is a bugfix release, specifically to fix the NiftiMapsMasker.
0.1.1#
Released February 2015
Changelog#
The main change compared to 0.1.0 is the addition of connectome plotting
via the function plot_connectome.
See the plotting documentation for more details.
Contributors (from git shortlog -ns 0.1..0.1.1):
Loic Estève (81)
Alexandre Abraham (18)
Danilo Bzdok (18)
Ben Cipollini (14)
Gael Varoquaux (2)
0.1.0#
Released February 2015
Changelog#
First release of nilearn.
Contributors (from git shortlog -ns 0.1):
Gael Varoquaux (600)
Alexandre Abraham (483)
Loic Estève (302)
Philippe Gervais (254)
Virgile Fritsch (122)
Michael Eickenberg (83)
Jean Kossaifi (59)
Jaques Grobler (57)
Danilo Bzdok (46)
Chris Gorgolewski (35)
Ronald Phlypo (28)
Ben Cipollini (25)
Bertrand Thirion (15)
Alexandre Gramfort (13)
Fabian Pedregosa (12)
Yannick Schwartz (11)
Mehdi Rahim (9)
Óscar Nájera (7)
Elvis Dohmatob (6)
Jason Gors (3)
Salma Bougacha (3)
Alexandre Savio (1)
Jan Margeta (1)
Matthias Ekman (1)
Michael Waskom (1)
Vincent Michel (1)