Changelog entries for the development version are available at https://hyperspy.readthedocs.io/en/latest/changes.html
.. towncrier-draft-entries:: |release| [UNRELEASED]
- Added :class:`~.api.roi.PolygonROI` and related functionality:
- Added the ROI :class:`~.api.roi.PolygonROI` to create ROIs of arbitrary shape.
- Added functions :func:`~.api.roi.combine_rois` and :func:`~.api.roi.mask_from_rois` to use multiple ROIs to slice signals and create masks, respectively. Currently only :class:`~.api.roi.PolygonROI` is supported. (#3030)
- Add support for plotting navigator and signal plot on same figure using matplotlib subfigures. See examples in the :ref:`custom layout for plots <subfigure_examples_label>` section. (#3343)
- New :attr:`~.axes.AxesManager.signal_axes` and :attr:`~.axes.AxesManager.navigation_axes` :meth:`~.misc.utils.TupleSA.set` and :meth:`~.misc.utils.TupleSA.get` methods to set/get multiple attributes of multiple axes at once. See :ref:`Setting_axis_properties`. (#2756)
- Allow setting optional
hidden
key in definition of signals extending hyperspy, which prevents them from being shown by :func:`~.api.print_known_signal_types`. (#3302) - Improvement of indexing of the :class:`~.axes.AxesManager`:
"nav"
and"sig"
can be used to index the navigation and signal axes, respectively. This can also be used for theaxes
oraxis
keywords arguments, for examples.sum(axis="sig")
will compute the sum over the signal axes. (#3385) - Add support to convert to uniform axis in :meth:`~.api.signals.BaseSignal.interpolate_on_axis`. (#3410)
- Add parameter to normalise spectra in :func:`~.api.plot.plot_spectra` (#3419)
- Add parameters to :func:`~.api.data.atomic_resolution_image` to set the spacing and rotation of the lattice and the size of the signal. (#3420)
- Add option to silence warning when :meth:`~.api.signals.BaseSignal.map` operates on signal containing non-uniform axes or different scales or units. (#3421)
- Add
ax
parameter to :func:`~.api.plot.plot_images`, :func:`~.api.plot.plot_spectra` and :func:`~.api.plot.plot_histograms` to specify the :external+matplotlib:class:`matplotlib.axis.Axis` to use - see examples in :ref:`sphx_glr_auto_examples_data_visualization`. (#3423) - Linear optimizer improvements:
- add linear optimizer using :class:`sklearn.linear_model.LinearRegression` with/without positive constraint; they can be used with
optimizer="ols"
oroptimizer="nnls"
, - improve linear optimizer documentation, mention
alpha
parameter when using :class:`sklearn.linear_model.Ridge`, - pass parameters through to corresponding scikit-learn class or numpy function. (#3426)
- add linear optimizer using :class:`sklearn.linear_model.LinearRegression` with/without positive constraint; they can be used with
- Add
style
parameter to the :func:`~.api.print_known_signal_types` function. (#3439)
- Allow rebinning uniform axis of signal containing non-uniform axis. (#3407)
- Fix old version warning banner in the stable documentation. (#3409)
- Fixes :meth:`~.axes.BaseDataAxis.convert_to_uniform_axis`, which was incorrectly raising an
AttributeError
when used on :class:`~.axes.FunctionalDataAxis`. (#3410) - Fix loading :class:`~.api.model.components1D.Polynomial` component saved with hyperspy <= 2.1.1. (#3413)
- Disable snap to axes for non uniform axis to avoid error when using ROI on non-uniform axis. (#3418)
- Fix non-lazy :meth:`~.api.signals.BaseSignal.map` when using dask processes scheduler. (#3421)
- :meth:`~.api.signals.BaseSignal.get_histogram` fixes:
- fix setting range when falling back to capped bin number,
- set name and units of the returned signal,
- don't remove
range_bins
parameter for lazy signal since dask now supports it. (#3422)
- Silence unnecessary warnings when using non-uniform axis with :meth:`~.api.signals.Signal1D.smooth_lowess` and :meth:`~.api.signals.Signal1D.find_peaks1D_ohaver`. (#3428)
- Fix horizontal plotting with ipympl 0.9.4/ipython 8.24. (#3437)
- Add support for extensions with
src
layout. (#3449) - Fix bug in :func:`~.api.plot.plot_spectra` when reversing legend handles since matplotlib expects a list and not an iterator. (#3456)
- Use custom version scheme in
setuptools_scm
to fix the version in the development version of the documentation for next major and next minor release branches. Previously, only the patch segment was incremented. (#3457)
- Explicitely deprecate
rechunk
keyword argument in :meth:`~.api.signals.BaseSignal.derivative`, which isn't doing anything since HyperSpy 1.7. (#3385) - Linear optimizer
"ridge_regression"
is renamed to"ridge"
in :meth:`~.model.BaseModel.fit`. (#3426)
- Add examples for overlaying a quad mesh marker to an image using the :class:`~.api.plot.markers.Markers` class and the :class:`matplotlib.collections.QuadMesh` class. (#3333)
- Add example: live fast Fourier transform of Signal2D using region of interest. (#3400)
- Update docstring of
set_signal_type
to better represent the HyperSpy2.0 ecosystem (#3435)
- Set
matplotlib
version requirement to >=3.6. (#3450)
- Only import gui widget when the toolkit is enabled. (#3366)
- Tweak documention on dask scheduler. (#3380)
- Fix updating residual line in model plot when changing components. (#3355)
- Avoid changing
data
object when using :meth:`~.api.signals.BaseSignal.add_gaussian_noise` and :meth:`~.api.signals.BaseSignal.add_poissonian_noise`. (#3379) - Avoid replacing the original mask in :meth:`~.api.signals.BaseSignal.blind_source_separation` (#3384)
- Fix gradients in some expression based components (#3388)
- Add old version warning banner in documentation. (#3397)
- Add support for numpy 2.0. (#3386)
- Add a dynamic navigator which updates when the number of navigation dimensions is greater than 3 (#3199)
- Add an example to the gallery to show how to extract a line profile from an image using a :class:`~.api.roi.Line2DROI` (#3227)
- Add an example showing how to handle RGB images. (#3346)
- Use :func:`pint.get_application_registry` to get :class:`pint.UnitRegistry` and facilitate interoperability of pint quantity operation with other modules. (#3357)
- :func:`~.api.plot.plot_roi_map` improvement:
- Add ROIs on signal plot instead of adding them on a sum signal.
- Add support for more than 3 ROIs.
- Add
color
andcmap
parameters to specify color and colormap. - Add
single_figure
parameter to enable plotting on a single figure using :func:`~.api.plot.plot_images` or :func:`~.api.plot.plot_spectra`. - Improve performance of updating ROI maps by a factor 2-4 when moving ROI.
- Update images in :func:`~.api.plot.plot_images` on data change event.
- Remove ROI widgets and disconnect interactive function when closing ROI map figures. (#3364)
- Documentation improvement. (#3365)
- Fix ROI slicing of non-uniform axis (#3328)
- Add the ability to save and load :class:`~.axes.BaseDataAxis` objects to a hyperspy file. (#3342)
- Fix navigator event disconnection and fix plot when changing dtype from/to rbgx. (#3346)
- Fix :func:`~.api.get_configuration_directory_path` function. (#3349)
- Fix :func:`~.api.plot.plot_images` axis ticks discrepancy. (#3361)
- Fixes in :func:`~.api.plot.plot_roi_map`:
- Fix slicing signal when using CircleROI (#3358).
- Fix redundant events when using :class:`~.api.roi.SpanROI`, which was causing flickering of the colorbar in the ROI map figures (#3364)
- Fix development version on
RELEASE_next_minor
branch. (#3368)
- :func:`~.api.plot.plot_roi_map` doesn't return the sum of all ROI maps (
all_sum
) and the signals sliced by the ROIs (roi_signals
), these can be obtained separately using therois
returned by :func:`~.api.plot.plot_roi_map` and :func:`~.api.interactive`. (#3364)
- Ruff update:
- Set the
RELEASE_next_patch
branch as target for thepre-commit.ci
update to keep all branches in synchronisation. - Update ruff to version 0.3.3 and run ruff check/format on source code. (#3335)
- Set the
- Replace deprecated
np.string_
bynp.bytes_
. (#3338) - Enable ruff isort and all pyflakes/Pycodestyle rules, except E501 to avoid confict with black formatting. (#3348)
- Merge
hyperspy.api.no
andhyperspy.api.no_gui
modules since the latter is not necessary anymore. (#3349) - Convert projet readme to markdown, fixes badges on github (#3351)
- Simplify Azure Pipeline CI by removing build and uploading wheels, since this is now done on GitHub CI. (#3356)
- Fix duplicated test and occasional test failure. (#3365)
- Use lower case when checking matplotlib backend in the test suite. (#3367)
- Add
percentile_range
traitsui attribute toImageContrastEditor
necessary for hyperspy/hyperspy_gui_traitsui#76. (#3368)
- Fix bug with side by side plotting of signal containing navigation dimension only. (#3304)
- Fix getting release on some linux system wide install, e.g. Debian or Google colab (#3318)
- Fix incorrect position of
Texts
marker when using mathtext. (#3319)
- Update version switcher. (#3291)
- Fix readme badges and fix broken web links. (#3298)
- Use ruff to lint code. (#3299)
- Use ruff to format code. (#3300)
- Run test suite on osx arm64 on GitHub CI and speed running test suite using all available CPUs (3 or 4) instead of only 2. (#3305)
- Fix API changes in scipy (:func:`scipy.signal.windows.tukey`) and scikit-image (:func:`skimage.restoration.unwrap_phase`). (#3306)
- Fix deprecation warnings and warnings in the test suite (#3320)
- Add documentation on how the documentation is updated and the required manual changes for minor and major releases. (#3321)
- Add Google Analytics ID to learn more about documentation usage. (#3322)
- Setup workflow to push development documentation automatically. (#3297)
- Hyperspy has split off some of the file reading/writing and domain specific functionalities into separate libraries!
- RosettaSciIO: A library for reading and writing scientific data files. See RosettaSciIO release notes for new features and supported formats.
- exSpy: A library for EELS and EDS analysis. See exSpy release notes for new features.
- holoSpy: A library for analysis of (off-axis) electron holography data. See holoSpy release notes for new features.
- The :py:mod:`~.api.plot.markers` API has been refactored
- Lazy markers are now supported
- Plotting many markers is now much faster
- Added :py:class:`~.api.plot.markers.Polygons` marker
- The documentation has been restructured and improved!
- Short example scripts are now included in the documentation
- Improved guides for lazy computing as well as an improved developer guide
- Plotting is easier and more consistent:
- Added horizontal figure layout choice when using the
ipympl
backend - Changing navigation coordinates using the keyboard arrow-keys has been removed.
Use
Crtl
+Arrow
instead. - Jump to navigation position using
shift
+ click in the navigator figure.
- Added horizontal figure layout choice when using the
- HyperSpy now works with Pyodide/Jupyterlite, checkout hyperspy.org/jupyterlite-hyperspy!
- The deprecated API has removed: see the list of API changes and removal in the :ref:`sections below <hyperspy_2.0_api_changes>`.
- :py:meth:`~._signals.lazy.LazySignal.compute` will now pass keyword arguments to the dask :meth:`dask.array.Array.compute` method. This enables setting the scheduler and the number of computational workers. (#2971)
- Changes to :meth:`~.api.signals.BaseSignal.plot`:
- Added horizontal figure layout choice when using the
ipympl
backend. The default layour can be set in the plot section of the preferences GUI. (#3140)
- Added horizontal figure layout choice when using the
- Changes to :meth:`~.api.signals.Signal2D.find_peaks`:
- Lazy signals return lazy peak signals
get_intensity
argument added to get the intensity of the peaks- The signal axes are now stored in the
metadata.Peaks.signal_axes
attribute of the peaks' signal. (#3142)
- Change the logging output so that logging messages are not displayed in red, to avoid confusion with errors. (#3173)
- Added
hyperspy.decorators.deprecated
andhyperspy.decorators.deprecated_argument
:- Provide consistent and clean deprecation
- Added a guide for deprecating code (#3174)
- Add functionality to select navigation position using
shift
+ click in the navigator. (#3175) - Added a
plot_residual
to :py:meth:`~.models.model1d.Model1D.plot`. WhenTrue
, a residual line (Signal - Model) appears in the model figure. (#3186) - Switch to :meth:`matplotlib.axes.Axes.pcolormesh` for image plots involving non-uniform axes. The following cases are covered: 2D-signal with arbitrary navigation-dimension, 1D-navigation and 1D-signal (linescan). Not covered are 2D-navigation images (still uses sliders). (#3192)
- New :meth:`~.api.signals.BaseSignal.interpolate_on_axis` method to switch one axis of a signal. The data is interpolated in the process. (#3214)
- Added :func:`~.api.plot.plot_roi_map`. Allows interactively using a set of ROIs to select regions of the signal axes of a signal and visualise how the signal varies in this range spatially. (#3224)
- Improve syntax in the io module. (#3091)
- Fix behaviour of :py:class:`~.misc.utils.DictionaryTreeBrowser` setter with value of dictionary type (#3094)
- Avoid slowing down fitting by optimising attribute access of model. (#3155)
- Fix harmless error message when using multiple :class:`~.api.roi.RectangularROI`: check if resizer patches are drawn before removing them. Don't display resizers when adding the widget to the figure (widget in unselected state) for consistency with unselected state (#3222)
- Fix keeping dtype in :py:meth:`~.api.signals.BaseSignal.rebin` when the endianess is specified in the dtype (#3237)
- Fix serialization error due to
traits.api.Property
not being serializable if a dtype is specified. See #3261 for more details. (#3262) - Fix setting bounds for
"trf"
,"dogbox"
optimizer (#3244) - Fix bugs in new marker implementation:
- Markers str representation fails if the marker isn't added to a signal
- make :meth:`~.api.plot.markers.Markers.from_signal` to work with all markers - it was only working with :class:`~.api.plot.markers.Points` (#3270)
- Documentation fixes:
- Fix cross-references in documentation and enable sphinx "nitpicky" when building documentation to check for broken links.
- Fix using mutable objects as default argument.
- Change some :class:`~.component.Component` attributes to properties in order to include their docstrings in the API reference. (#3273)
- Restructure documentation:
- Improve structure of the API reference
- Improve introduction and overall structure of documentation
- Add gallery of examples (#3050)
- Add examples to the gallery to show how to use SpanROI and slice signal interactively (#3221)
- Add a section on keeping a clean and sensible commit history to the developer guide. (#3064)
- Replace
sphinx.ext.imgmath
bysphinx.ext.mathjax
to fix the math rendering in the ReadTheDocs build (#3084) - Fix docstring examples in :class:`~.api.signals.BaseSignal` class. Describe how to test docstring examples in developer guide. (#3095)
- Update intersphinx_mapping links of matplotlib, numpy and scipy. (#3218)
- Add examples on creating signal from tabular data or reading from a simple text file (#3246)
- Activate checking of example code in docstring and user guide using
doctest
and fix errors in the code. (#3281) - Update warning of "beta" state in big data section to be more specific. (#3282)
- Add support for passing
**kwargs
to :py:meth:`~.api.signals.Signal2D.plot` when using heatmap style in :py:func:`~.api.plot.plot_spectra` . (#3219) - Add support for pep 660 on editable installs for pyproject.toml based builds of extension (#3252)
- Make HyperSpy compatible with pyodide (hence JupyterLite):
- Set
numba
andnumexpr
as optional dependencies. - Replace
dill
bycloudpickle
. - Fallback to dask synchronous scheduler when running on pyodide.
- Reduce packaging size to less than 1MB.
- Add packaging test on GitHub CI. (#3255)
- Set
- RosettaSciIO was split out of the HyperSpy repository on July 23, 2022. The IO-plugins and related functions so far developed in HyperSpy were moved to the RosettaSciIO repository. (#2972)
- Extend the IO functions to accept alias names for format
name
as defined in RosettaSciIO. (#3009) - Fix behaviour of :meth:`~hyperspy.model.BaseModel.print_current_values`, :meth:`~.component.Component.print_current_values` and :func:`~.api.print_known_signal_types`, which were not printing when running from a script - they were only printing when running in notebook or qtconsole. Now all print_* functions behave consistently: they all print the output instead of returning an object (string or html). The :func:`IPython.display.display` will pick a suitable rendering when running in an "ipython" context, for example notebook, qtconsole. (#3145)
- The markers have been refactored - see the new :py:mod:`~.api.plot.markers` API and the :ref:`gallery of examples <gallery.markers>` for usage. The new :py:class:`~.api.plot.markers.Markers` uses :py:class:`matplotlib.collections.Collection`, is faster and more generic than the previous implementation and also supports lazy markers. Markers saved in HyperSpy files (
hspy
,zspy
) with HyperSpy < 2.0 are converted automatically when loading the file. (#3148) - For all functions with the
rechunk
parameter, the default has been changed fromTrue
toFalse
. This means HyperSpy will not automatically try to change the chunking for lazy signals. The old behaviour could lead to a reduction in performance when working with large lazy datasets, for example 4D-STEM data. (#3166) - Renamed
Signal2D.crop_image
to :meth:`~.api.signals.Signal2D.crop_signal` (#3197) - Changes and improvement of the map function:
- Removes the
parallel
argument - Replace the
max_workers
with thenum_workers
argument to be consistent withdask
- Adds more documentation on setting the dask backend and how to use multiple cores
- Adds
navigation_chunk
argument for setting the chunks with a non-lazy signal - Fix axes handling when the function to be mapped can be applied to the whole dataset - typically when it has the
axis
oraxes
keyword argument. (#3198)
- Removes the
- Remove
physics_tools
since it is not used and doesn't fit in the scope of HyperSpy. (#3235) - Improve the readability of the code by replacing the
__call__
method of some objects with the more explicit_get_current_data
.- Rename
__call__
method of :py:class:`~.api.signals.BaseSignal` to_get_current_data
. - Rename
__call__
method of :py:class:`hyperspy.model.BaseModel` to_get_current_data
. - Remove
__call__
method of the :py:class:`hyperspy.component.Component` class. (#3238)
- Rename
- Rename
hyperspy.api.datasets
to :mod:`hyperspy.api.data` and simplify submodule structure:hyperspy.api.datasets.artificial_data.get_atomic_resolution_tem_signal2d
is renamed to :func:`hyperspy.api.data.atomic_resolution_image`hyperspy.api.datasets.artificial_data.get_luminescence_signal
is renamed to :func:`hyperspy.api.data.luminescence_signal`hyperspy.api.datasets.artificial_data.get_wave_image
is renamed to :func:`hyperspy.api.data.wave_image` (#3253)
As the HyperSpy API evolves, some of its parts are occasionally reorganized or removed. When APIs evolve, the old API is deprecated and eventually removed in a major release. The functions and methods removed in HyperSpy 2.0 are listed below along with migration advises:
AxesManager.show
has been removed, use :py:meth:`~.axes.AxesManager.gui` instead.AxesManager.set_signal_dimension
has been removed, use :py:meth:`~.api.signals.BaseSignal.as_signal1D`, :py:meth:`~.api.signals.BaseSignal.as_signal2D` or :py:meth:`~.api.signals.BaseSignal.transpose` of the signal instance instead.
- The API of the :py:class:`~.api.model.components1D.Polynomial` has changed (it was deprecated in HyperSpy 1.5). The old API had a single parameters
coefficients
, which has been replaced bya0
,a1
, etc. - The
legacy
option (introduced in HyperSpy 1.6) for :class:`~.api.model.components1D.Arctan` has been removed, use :class:`exspy.components.EELSArctan` to use the old API. - The
legacy
option (introduced in HyperSpy 1.6) for :class:`~.api.model.components1D.Voigt` has been removed, use :class:`exspy.components.PESVoigt` to use the old API.
- The
saturated_pixels
keyword argument of :py:meth:`~.api.signals.Signal2D.plot` has been removed, usevmin
and/orvmax
instead. - The
get_complex
property ofhyperspy.drawing.signal1d.Signal1DLine
has been removed. - The keyword argument
line_style
of :py:func:`~.api.plot.plot_spectra` has been renamed tolinestyle
. - Changing navigation coordinates using keyboard
Arrow
has been removed, useCrtl
+Arrow
instead. - The
markers
submodules can not be imported from the :py:mod:`~.api` anymore, use :py:mod:`hyperspy.api.plot.markers` directly, i.e. :class:`hyperspy.api.plot.markers.Arrows`, instead. - The creation of markers has changed to use their class name instead of aliases, for example,
use
m = hs.plot.markers.Lines
instead ofm = hs.plot.markers.line_segment
.
The following deprecated keyword arguments have been removed during the migration of the IO plugins to the RosettaSciIO library:
- The arguments
mmap_dir
andload_to_memory
of the :py:func:`~.api.load` function have been removed, use thelazy
argument instead. - :ref:`Bruker composite file (BCF) <bruker-format>`: The
'spectrum'
option for theselect_type
parameter was removed. Use'spectrum_image'
instead. - :ref:`Electron Microscopy Dataset (EMD) NCEM <emd_ncem-format>`: Using the
keyword
dataset_name
was removed, usedataset_path
instead. - :ref:`NeXus data format <nexus-format>`: The
dataset_keys
,dataset_paths
andmetadata_keys
keywords were removed. Usedataset_key
,dataset_path
andmetadata_key
instead.
The
polyfit
keyword argument has been removed. Usevar_func
instead.The list of possible values for the
algorithm
argument of the :py:meth:`~.api.signals.BaseSignal.decomposition` method has been changed according to the following table:Change of the algorithm
argumenthyperspy < 2.0
hyperspy >= 2.0
fast_svd
SVD along with the argument svd_solver="randomized"
svd
SVD
fast_mlpca
MLPCA along with the argument svd_solver="randomized
mlpca
MLPCA
nmf
NMF
RPCA_GoDec
RPCA
The argument
learning_rate
of theORPCA
algorithm has been renamed tosubspace_learning_rate
.The argument
momentum
of theORPCA
algorithm has been renamed tosubspace_momentum
.The list of possible values for the
centre
keyword argument of the :py:meth:`~.api.signals.BaseSignal.decomposition` method when using theSVD
algorithm has been changed according to the following table:Change of the centre
argumenthyperspy < 2.0
hyperspy >= 2.0
trials
navigation
variables
signal
For lazy signals, a possible value of the
algorithm
keyword argument of the :py:meth:`~._signals.lazy.LazySignal.decomposition` method has been changed from"ONMF"
to"ORNMF"
.Setting the
metadata
andoriginal_metadata
attribute of signals is removed, use the :py:meth:`~.misc.utils.DictionaryTreeBrowser.set_item` and :py:meth:`~.misc.utils.DictionaryTreeBrowser.add_dictionary` methods of themetadata
andoriginal_metadata
attribute instead.
The
iterpath
default value has changed from'flyback'
to'serpentine'
.Changes in the arguments of the :py:meth:`~hyperspy.model.BaseModel.fit` and :py:meth:`~hyperspy.model.BaseModel.multifit` methods:
The
fitter
argument has been renamed tooptimizer
.The list of possible values for the
optimizer
argument has been renamed according to the following table:Renaming of the optimizer
argumenthyperspy < 2.0
hyperspy >= 2.0
fmin
Nelder-Mead
fmin_cg
CG
fmin_ncg
Newton-CG
fmin_bfgs
Newton-BFGS
fmin_l_bfgs_b
L-BFGS-B
fmin_tnc
TNC
fmin_powell
Powell
mpfit
lm
leastsq
lm
loss_function="ml"
has been renamed toloss_function="ML-poisson"
.grad=True
has been changed tograd="analytical"
.- The
ext_bounding
argument has been renamed tobounded
. - The
min_function
argument has been removed, use theloss_function
argument instead. - The
min_function_grad
argument has been removed, use thegrad
argument instead.
The following :py:class:`~hyperspy.model.BaseModel` methods have been removed:
hyperspy.model.BaseModel.set_boundaries
hyperspy.model.BaseModel.set_mpfit_parameters_info
The arguments
parallel
andmax_workers
have been removed from the :py:meth:`~hyperspy.model.BaseModel.as_signal` methods.Setting the
metadata
attribute of a :py:class:`~.samfire.Samfire` has been removed, use the :py:meth:`~.misc.utils.DictionaryTreeBrowser.set_item` and :py:meth:`~.misc.utils.DictionaryTreeBrowser.add_dictionary` methods of themetadata
attribute instead.The deprecated
twin_function
andtwin_inverse_function
have been privatized.Remove
fancy
argument of :meth:`~hyperspy.model.BaseModel.print_current_values` and :meth:`~.component.Component.print_current_values`, which wasn't changing the output rendering.The attribute
channel_switches
of :py:class:`~hyperspy.model.BaseModel` have been privatized, instead use the :py:meth:`~hyperspy.model.BaseModel.set_signal_range_from_mask` or any other methods to set the signal range, such as :py:meth:`~.models.model1d.Model1D.set_signal_range`, :py:meth:`~.models.model1d.Model1D.add_signal_range` or :py:meth:`~.models.model1d.Model1D.remove_signal_range` and their :py:class:`~.models.model2d.Model2D` counterparts.
metadata.Signal.binned
is removed, use theis_binned
axis attribute instead, e. g.s.axes_manager[-1].is_binned
.Some possible values for the
bins
argument of the :py:meth:`~.api.signals.BaseSignal.get_histogram` method have been changed according to the following table:Change of the bins
argumenthyperspy < 2.0
hyperspy >= 2.0
scotts
scott
freedman
fd
The
integrate_in_range
method has been removed, use :py:class:`~.roi.SpanROI` followed by :py:meth:`~.api.signals.BaseSignal.integrate1D` instead.The
progressbar
keyword argument of the :py:meth:`~._signals.lazy.LazySignal.compute` method has been removed, useshow_progressbar
instead.The deprecated
comp_label
argument of the methods :py:meth:`~.api.signals.BaseSignal.plot_decomposition_loadings`, :py:meth:`~.api.signals.BaseSignal.plot_decomposition_factors`, :py:meth:`~.api.signals.BaseSignal.plot_bss_loadings`, :py:meth:`~.api.signals.BaseSignal.plot_bss_factors`, :py:meth:`~.api.signals.BaseSignal.plot_cluster_distances`, :py:meth:`~.api.signals.BaseSignal.plot_cluster_labels` has been removed, use thetitle
argument instead.The :py:meth:`~.api.signals.BaseSignal.set_signal_type` now raises an error when passing
None
to thesignal_type
argument. Usesignal_type=""
instead.Passing an "iterating over navigation argument" to the :py:meth:`~.api.signals.BaseSignal.map` method is removed, pass a HyperSpy signal with suitable navigation and signal shape instead.
- :meth:`~.api.signals.Signal2D.find_peaks` now returns lazy signals in case of lazy input signal.
- The
warn_if_guis_are_missing
HyperSpy preferences setting has been removed, as it is not necessary anymore.
- Pin third party GitHub actions and add maintenance guidelines on how to update them (#3027)
- Drop support for python 3.7, update oldest supported dependencies and simplify code accordingly (#3144)
- IPython and IParallel are now optional dependencies (#3145)
- Fix Numpy 1.25 deprecation: implicit array to scalar conversion in :py:meth:`~.signals.Signal2D.align2D` (#3189)
- Replace deprecated :mod:`scipy.misc` by :mod:`scipy.datasets` in documentation (#3225)
- Fix documentation version switcher (#3228)
- Replace deprecated :py:class:`scipy.interpolate.interp1d` with :py:func:`scipy.interpolate.make_interp_spline` (#3233)
- Add support for python 3.12 (#3256)
- Consolidate package metadata:
- use
pyproject.toml
only - clean up unmaintained packaging files
- use
setuptools_scm
to define version - add python 3.12 to test matrix (#3268)
- use
- Pin pytest-xdist to 3.5 as a workaround for test suite failure on Azure Pipeline (#3274)
- Allows for loading of
.hspy
files saved with version 2.0.0 and greater and no unit or name set for some axis. (#3241)
- Backport of 3189: fix Numpy1.25 deprecation: implicite array to scalar conversion in :py:meth:`~.api.signals.Signal2D.align2D` (#3243)
- Pin pillow to <10.1 to avoid imageio error. (#3251)
- Fix plotting boolean array with :py:func:`~.api.plot.plot_images` (#3118)
- Fix test with scipy1.11 and update deprecated
scipy.interpolate.interp2d
in the test suite (#3124) - Use intersphinx links to fix links to scikit-image documentation (#3125)
- Improve performance of model.multifit by avoiding axes.is_binned repeated evaluation (#3126)
- Simplify release workflow and replace deprecated
actions/create-release
action withsoftprops/action-gh-release
. (#3117) - Add support for python 3.11 (#3134)
- Pin
imageio
to <2.28 (#3138)
- Fixes an array indexing bug when loading a .sur file format spectra series. (#3060)
- Speed up
to_numpy
function to avoid slow down when used repeatedly, typically during fitting (#3109)
- Replace
sphinx.ext.imgmath
bysphinx.ext.mathjax
to fix the math rendering in the ReadTheDocs build (#3084)
- Add support for Phenom .elid revision 3 and 4 formats (#3073)
- Add pooch as test dependency, as it is required to use scipy.dataset in latest scipy (1.10) and update plotting test. Fix warning when plotting non-uniform axis (#3079)
- Fix matplotlib 3.7 and scikit-learn 1.4 deprecations (#3102)
- Add support for new pattern to generate random numbers introduced in dask 2023.2.1. Deprecate usage of :py:class:`numpy.random.RandomState` in favour of :py:func:`numpy.random.default_rng`. Bump scipy minimum requirement to 1.4.0. (#3103)
- Fix checking links in documentation for domain, which aren't compatible with sphinx linkcheck (#3108)
- Fix error when reading Velox containing FFT with odd number of pixels (#3040)
- Fix pint Unit for pint>=0.20 (#3052)
- Fix deprecated import of scipy
ascent
in docstrings and the test suite (#3032) - Fix error handling when trying to convert a ragged signal to non-ragged for numpy >=1.24 (#3033)
- Fix getting random state dask for dask>=2022.10.0 (#3049)
- Fix some errors and remove unnecessary code identified by LGTM. (#2977)
- Fix error which occurs when guessing output size in the :py:meth:`~.api.signals.BaseSignal.map` function and using dask newer than 2022.7.1 (#2981)
- Fix display of x-ray lines when using log norm and the intensity at the line is 0 (#2995)
- Fix handling constant derivative in :py:meth:`~.api.signals.Signal1D.spikes_removal_tool` (#3005)
- Fix removing horizontal or vertical line widget; regression introduced in hyperspy 1.7.0 (#3008)
- Add a note in the user guide to explain that when a file contains several datasets, :py:func:`~.api.load` returns a list of signals instead of a single signal and that list indexation can be used to access a single signal. (#2975)
- Fix extension test suite CI workflow. Enable workflow manual trigger (#2982)
- Fix deprecation warning and time zone test failing on windows (locale dependent) (#2984)
- Fix external links in the documentation and add CI build to check external links (#3001)
- Fix hyperlink in bibliography (#3015)
- Fix matplotlib
SpanSelector
import for matplotlib 3.6 (#3016)
- Fixes invalid file chunks when saving some signals to hspy/zspy formats. (#2940)
- Fix issue where a TIFF image from an FEI FIB/SEM navigation camera image would not be read due to missing metadata (#2941)
- Respect
show_progressbar
parameter in :py:meth:`~.api.signals.BaseSignal.map` (#2946) - Fix regression in :py:meth:`~hyperspy.models.model1d.Model1D.set_signal_range` which was raising an error when used interactively (#2948)
- Fix :py:class:`~.api.roi.SpanROI` regression: the output of :py:meth:`~.roi.BaseInteractiveROI.interactive` was not updated when the ROI was changed. Fix errors with updating limits when plotting empty slice of data. Improve docstrings and test coverage. (#2952)
- Fix stacking signals that contain their variance in metadata. Previously it was raising an error when specifying the stacking axis. (#2954)
- Fix missing API documentation of several signal classes. (#2957)
- Fix two bugs in :py:meth:`~.api.signals.BaseSignal.decomposition`:
- The poisson noise normalization was not applied when giving a signal_mask
- An error was raised when applying a
signal_mask
on a signal with signal dimension larger than 1. (#2964)
- Fix and complete docstrings of :py:meth:`~.api.signals.Signal2D.align2D` and :py:meth:`~.api.signals.Signal2D.estimate_shift2D`. (#2961)
- Minor refactor of the EELS subshells in the
elements
dictionary. (#2868) - Fix packaging of test suite and tweak tests to pass on different platform of blas implementation (#2933)
- Add
filter_zero_loss_peak
argument to thehyperspy._signals.eels.EELSSpectrum.spikes_removal_tool
method (#1412) - Add :py:meth:`~.api.signals.Signal2D.calibrate` method to :py:class:`~.api.signals.Signal2D` signal, which allows for interactive calibration (#1791)
- Add
hyperspy._signals.eels.EELSSpectrum.vacuum_mask
method to:hyperspy._signals.eels.EELSSpectrum
signal (#2183) - Support for :ref:`relative slicing <signal.indexing>` (#2386)
- Implement non-uniform axes, not all hyperspy functionalities support non-uniform axes, see this tracking issue for progress. (#2399)
- Add (weighted) :ref:`linear least square fitting <linear_fitting-label>`. Close #488 and #574. (#2422)
- Support for reading :external+rsciio:ref:`JEOL EDS data<jeol-format>` (#2488)
- Plot overlayed images - see :ref:`plotting several images<plot.images>` (#2599)
- Add initial support for :ref:`GPU computation<gpu_processing>` using cupy (#2670)
- Add
height
property to the :py:class:`~._components.gaussian2d.Gaussian2D` component (#2688) - Support for reading and writing :external+rsciio:ref:`TVIPS image stream data<tvips-format>` (#2780)
- Add in :external+rsciio:ref:`zspy format<zspy-format>`: hspy specification with the zarr format. Particularly useful to speed up loading and :ref:`saving large datasets<big_data.saving>` by using concurrency. (#2825)
- Support for reading :external+rsciio:ref:`DENSsolutions Impulse data<dens-format>` (#2828)
- Add lazy loading for :external+rsciio:ref:`JEOL EDS data<jeol-format>` (#2846)
- Add :ref:`html representation<lazy._repr_html_>` for lazy signals and the :py:meth:`~._signals.lazy.LazySignal.get_chunk_size` method to get the chunk size of given axes (#2855)
- Add support for Hamamatsu HPD-TA Streak Camera tiff files, with axes and metadata parsing. (#2908)
- Signals with 1 value in the signal dimension will now be :py:class:`~.api.signals.BaseSignal` (#2773)
- :py:func:`exspy.material.density_of_mixture` now throws a Value error when the density of an element is unknown (#2775)
- Improve error message when performing Cliff-Lorimer quantification with a single line intensity (#2822)
- Fix bug for the hydrogenic gdos k edge (#2859)
- Fix bug in axes.UnitConversion: the offset value was initialized by units. (#2864)
- Fix bug where the :py:meth:`~.api.signals.BaseSignal.map` function wasn't operating properly when an iterating signal was larger than the input signal. (#2878)
- In case the Bruker defined XML element node at SpectrumRegion contains no information on the specific selected X-ray line (if there is only single line available), suppose it is 'Ka' line. (#2881)
- When loading Bruker Bcf,
cutoff_at_kV=None
does no cutoff (#2898) - Fix bug where the :py:meth:`~.api.signals.BaseSignal.map` function wasn't operating properly when an iterating signal was not an array. (#2903)
- Fix bug for not saving ragged arrays with dimensions larger than 2 in the ragged dimension. (#2906)
- Fix bug with importing some spectra from eelsdb and add progress bar (#2916)
- Fix bug when the spikes_removal_tool would not work interactively for signal with 0-dimension navigation space. (#2918)
- Deprecate
hyperspy.axes.AxesManager.set_signal_dimension
in favour of using :py:meth:`~.api.signals.BaseSignal.as_signal1D`, :py:meth:`~.api.signals.BaseSignal.as_signal2D` or :py:meth:`~.api.signals.BaseSignal.transpose` of the signal instance instead. (#2830)
- :ref:`Region of Interest (ROI)<roi-label>` can now be created without specifying values (#2341)
- mpfit cleanup (#2494)
- Document reading Attolight data with the sur/pro format reader (#2559)
- Lazy signals now caches the current data chunk when using multifit and when plotting, improving performance. (#2568)
- Read cathodoluminescence metadata from digital micrograph files, amended in PR #2894 (#2590)
- Add possibility to search/access nested items in DictionaryTreeBrowser (metadata) without providing full path to item. (#2633)
- Improve :py:meth:`~.api.signals.BaseSignal.map` function in :py:class:`~.api.signals.BaseSignal` by utilizing dask for both lazy and non-lazy signals. This includes adding a lazy_output parameter, meaning non-lazy signals now can output lazy results. See the :ref:`user guide<lazy_output-map-label>` for more information. (#2703)
- :external+rsciio:ref:`NeXus<nexus-format>` file with more options when reading and writing (#2725)
- Add
dtype
argument to :py:meth:`~.api.signals.BaseSignal.rebin` (#2764) - Add option to set output size when :external+rsciio:ref:`exporting images<image-format>` (#2791)
- Add :py:meth:`~.axes.AxesManager.switch_iterpath` context manager to switch iterpath (#2795)
- Add options not to close file (lazy signal only) and not to write dataset for hspy file format, see :external+rsciio:ref:`hspy-format` for details (#2797)
- Add Github workflow to run test suite of extension from a pull request. (#2824)
- Add :py:attr:`~.api.signals.BaseSignal.ragged` attribute to :py:class:`~.api.signals.BaseSignal` to clarify when a signal contains a ragged array. Fix inconsistency caused by ragged array and add a :ref:`ragged array<signal.ragged>` section to the user guide (#2842)
- Import hyperspy submodules lazily to speed up importing hyperspy. Fix autocompletion signals submodule (#2850)
- Add support for JEOL SightX tiff file (#2862)
- Add new markers
hyperspy.drawing._markers.arrow
,hyperspy.drawing._markers.ellipse
and filledhyperspy.drawing._markers.rectangle
. (#2871) - Add metadata about the file-reading and saving operations to the Signals produced by :py:func:`~.api.load` and :py:meth:`~.api.signals.BaseSignal.save` (see the :ref:`metadata structure <general-file-metadata>` section of the user guide) (#2873)
- expose Stage coordinates and rotation angle in metada for sem images in bcf reader. (#2911)
metadata.Signal.binned
is replaced by an axis parameter, e. g.axes_manager[-1].is_binned
(#2652)- when loading Bruker bcf,
cutoff_at_kV=None
(default) applies no more automatic cutoff. - New acceptable values
"zealous"
and"auto"
do automatic cutoff. (#2910)
- when loading Bruker bcf,
- Deprecate the ability to directly set
metadata
andoriginal_metadata
Signal attributes in favor of using :py:meth:`~.misc.utils.DictionaryTreeBrowser.set_item` and :py:meth:`~.misc.utils.DictionaryTreeBrowser.add_dictionary` methods or specifying metadata when creating signals (#2913)
- Fix warning when build doc and formatting user guide (#2762)
- Drop support for python 3.6 (#2839)
- Continuous integration fixes and improvements; Bump minimal version requirement of dask to 2.11.0 and matplotlib to 3.1.3 (#2866)
- Tweak tests tolerance to fix tests failure on aarch64 platform; Add python 3.10 build. (#2914)
- Add support for matplotlib 3.5, simplify maintenance of
RangeWidget
and some signal tools. (#2922) - Compress some tiff tests files to reduce package size (#2926)
- Suspend plotting during :meth:`exspy.models.EELSModel.smart_fit` call (#2796)
- make :py:meth:`~.api.signals.BaseSignal.add_marker` also check if the plot is not active before plotting signal (#2799)
- Fix irresponsive ROI added to a signal plot with a right hand side axis (#2809)
- Fix :py:func:`~.api.plot.plot_histograms` drawstyle following matplotlib API change (#2810)
- Fix incorrect :py:meth:`~.api.signals.BaseSignal.map` output size of lazy signal when input and output axes do not match (#2837)
- Add support for latest h5py release (3.5) (#2843)
- Rename
line_style
tolinestyle
in :py:func:`~.api.plot.plot_spectra` to match matplotlib argument name (#2810)
- :py:meth:`~.roi.BaseInteractiveROI.add_widget` can now take a string or integer instead of tuple of string or integer (#2809)
- Fix parsing EELS aperture label with unexpected value, for example 'Imaging' instead of '5 mm' (#2772)
- Lazy datasets can now be saved out as blockfiles (blo) (#2774)
- ComplexSignals can now be rebinned without error (#2789)
- Method :py:meth:`~.api.model.components1D.Polynomial.estimate_parameters` of the :py:class:`~._components.polynomial.Polynomial` component now supports order greater than 10 (#2790)
- Update minimal requirement of dependency importlib_metadata from >= 1.6.0 to >= 3.6 (#2793)
- When saving a dataset with a dtype other than
uint8 to a blockfile
(blo) it is now possible to provide the argument
intensity_scaling
to map the intensity values to the reduced range (#2774)
- Fix image comparison failure with numpy 1.21.0 (#2774)
- Fix ROI snapping regression (#2720)
- Fix :py:meth:`~.api.signals.Signal1D.shift1D`, :py:meth:`~.api.signals.Signal1D.align1D` and
hyperspy._signals.eels.EELSSpectrum.align_zero_loss_peak
regression with navigation dimension larger than one (#2729) - Fix disconnecting events when closing figure and :py:meth:`~.api.signals.Signal1D.remove_background` is active (#2734)
- Fix :py:meth:`~.api.signals.BaseSignal.map` regression of lazy signal with navigation chunks of size of 1 (#2748)
- Fix unclear error message when reading a hspy file saved using blosc compression and
hdf5plugin
hasn't been imported previously (#2760) - Fix saving
navigator
of lazy signal (#2763)
- Use
importlib_metadata
instead ofpkg_resources
for extensions registration to speed up the import process and making it possible to install extensions and use them without restarting the python session (#2709) - Don't import hyperspy extensions when registering extensions (#2711)
- Improve docstrings of various fitting methods (#2724)
- Improve speed of :py:meth:`~.api.signals.Signal1D.shift1D` (#2750)
- Add support for recent EMPAD file; scanning size wasn't parsed. (#2757)
- Add drone CI to test arm64 platform (#2713)
- Fix latex doc build on github actions (#2714)
- Use towncrier to generate changelog automatically (#2717)
- Fix test suite to support dask 2021.4.1 (#2722)
- Generate changelog when building doc to keep the changelog of the development doc up to date on https://hyperspy.readthedocs.io/en/latest (#2758)
- Use mamba and conda-forge channel on azure pipeline (#2759)
This is a maintenance release that adds support for python 3.9 and includes numerous bug fixes and enhancements. See the issue tracker for details.
- Fix disconnect event when closing navigator only plot (fixes #996), (#2631)
- Fix incorrect chunksize when saving EMD NCEM file and specifying chunks (#2629)
- Fix :py:meth:`~.api.signals.Signal2D.find_peaks` GUIs call with laplacian/difference of gaussian methods (#2622 and #2647)
- Fix various bugs with
CircleWidget
andLine2DWidget
(#2625) - Fix setting signal range of model with negative axis scales (#2656)
- Fix and improve mask handling in lazy decomposition; Close #2605 (#2657)
- Plot scalebar when the axis scales have different sign, fixes #2557 (#2657)
- Fix :py:meth:`~.api.signals.Signal1D.align1D` returning zeros shifts (#2675)
- Fix finding dataset path for EMD NCEM file containing more than one dataset in a group (#2673)
- Fix squeeze function for multiple zero-dimensional entries, improved docstring, added to user guide. (#2676)
- Fix error in Cliff-Lorimer quantification using absorption correction (#2681)
- Fix
navigation_mask
bug in decomposition when provided as numpy array (#2679) - Fix closing image contrast tool and setting vmin/vmax values (#2684)
- Fix range widget with matplotlib 3.4 (#2684)
- Fix bug in :py:func:`~.api.interactive` with function returning None. Improve user guide example. (#2686)
- Fix broken events when changing signal type #2683
- Fix setting offset in rebin: the offset was changed in the wrong axis (#2690)
- Fix reading XRF bruker file, close #2689 (#2694)
- Widgets plotting improvement and add
pick_tolerance
to plot preferences (#2615) - Pass keyword argument to the image IO plugins (#2627)
- Improve error message when file not found (#2597)
- Add update instructions to user guide (#2621)
- Improve plotting navigator of lazy signals, add
navigator
setter to lazy signals (#2631) - Use
'dask_auto'
when rechunk=True in :py:meth:`~._signals.lazy.LazySignal.change_dtype` for lazy signal (#2645) - Use dask chunking when saving lazy signal instead of rechunking and leave the user to decide what is the suitable chunking (#2629)
- Added lazy reading support for FFT and DPC datasets in FEI emd datasets (#2651).
- Improve error message when initialising SpanROI with left >= right (#2604)
- Allow running the test suite without the pytest-mpl plugin (#2624)
- Add Releasing guide (#2595)
- Add support for python 3.9, fix deprecation warning with matplotlib 3.4.0 and bump minimum requirement to numpy 1.17.1 and dask 2.1.0. (#2663)
- Use native endianess in numba jitted functions. (#2678)
- Add option not to snap ROI when calling the :py:meth:`~.roi.BaseInteractiveROI.interactive` method of a ROI (#2686)
- Make :py:class:`~.misc.utils.DictionaryTreeBrowser` lazy by default - see #368 (#2623)
- Speed up setting CI on azure pipeline (#2694)
- Improve performance issue with the map method of lazy signal (#2617)
- Add option to copy/load original metadata in
hs.stack
andhs.load
to avoid largeoriginal_metadata
which can slowdown processing. Close #1398, #2045, #2536 and #1568. (#2691)
- Fix warnings when building documentation (#2596)
- Drop support for numpy<1.16, in line with NEP 29 and fix protochip reader for numpy 1.20 (#2616)
- Run test suite against upstream dependencies (numpy, scipy, scikit-learn and scikit-image) (#2616)
- Update external links in the loading data section of the user guide (#2627)
- Fix various future and deprecation warnings from numpy and scikit-learn (#2646)
- Fix
iterpath
VisibleDeprecationWarning when using :py:meth:`~.models.model1d.Model1D.fit_component` (#2654) - Add integration test suite documentation in the developer guide. (#2663)
- Fix SkewNormal component compatibility with sympy 1.8 (#2701)
This is a maintenance release that adds compatibility with h5py 3.0 and includes numerous bug fixes and enhancements. See the issue tracker for details.
- Support for the following file formats:
hyperspy._signals.eels.EELSSpectrum.print_edges_near_energy
method that, if the hyperspy-gui-ipywidgets package is installed, includes an awesome interactive mode. See :external+exspy:ref:`eels_elemental_composition-label`.- Model asymmetric line shape components:
- :external+exspy:ref:`EDS absorption correction <eds_absorption-label>`.
- :ref:`Argand diagram for complex signals <complex.argand>`.
- :ref:`Multiple peak finding algorithms for 2D signals <peak_finding-label>`.
- :ref:`cluster_analysis-label`.
- The :py:meth:`~.api.signals.BaseSignal.get_histogram` now uses numpy's
np.histogram_bin_edges()
and supports all of its
bins
keyword values. - Further improvements to the contrast adjustment tool.
Test it by pressing the
h
key on any image. - The following components have been rewritten using :py:class:`~._components.expression.Expression`, boosting their speeds among other benefits.
- The model fitting :py:meth:`~hyperspy.model.BaseModel.fit` and :py:meth:`~hyperspy.model.BaseModel.multifit` methods have been vastly improved. See :ref:`model.fitting` and the API changes section below.
- New serpentine iteration path for multi-dimensional fitting. See :ref:`model.multidimensional-label`.
- The :py:func:`~.api.plot.plot_spectra` function now listens to events to update the figure automatically. See :ref:`this example <sphx_glr_auto_examples_region_of_interest_ExtractLineProfile.py>`.
- Improve thread-based parallelism. Add
max_workers
argument to the :py:meth:`~.api.signals.BaseSignal.map` method, such that the user can directly control how many threads they launch. - Many improvements to the :py:meth:`~.api.signals.BaseSignal.decomposition` and :py:meth:`~.api.signals.BaseSignal.blind_source_separation` methods, including support for scikit-learn like algorithms, better API and much improved documentation. See :ref:`ml-label` and the API changes section below.
- Add option to calculate the absolute thickness to the EELS
hyperspy._signals.eels.EELSSpectrum.estimate_thickness
method. See :external+exspy:ref:`eels_thickness-label`. - Vastly improved performance and memory footprint of the :py:meth:`~.api.signals.Signal2D.estimate_shift2D` method.
- The :py:meth:`~.api.signals.Signal1D.remove_background` method can now remove Doniach, exponential, Lorentzian, skew normal, split Voigt and Voigt functions. Furthermore, it can return the background model that includes an estimation of the reduced chi-squared.
- The performance of the maximum-likelihood PCA method was greatly improved.
- All ROIs now have a
__getitem__
method, enabling e.g. using them with the unpack*
operator. See :ref:`roi-slice-label` for an example. - New syntax to set the contrast when plotting images. In particular, the
vmin
andvmax
keywords now take values likevmin="30th"
to clip the minimum value to the 30th percentile. See :ref:`signal.fft` for an example. - The :py:meth:`~.api.signals.Signal1D.plot` and
:py:meth:`~.api.signals.Signal2D.plot` methods take a new keyword
argument
autoscale
. See :ref:`plot.customize_images` for details. - The contrast editor and the decomposition methods can now operate on complex signals.
- The default colormap can now be set in :ref:`preferences <configuring-hyperspy-label>`.
- The :py:meth:`~.api.signals.Signal2D.plot` keyword argument
saturated_pixels
is deprecated. Please usevmin
and/orvmax
instead. - The :py:func:`~.api.load` keyword argument
dataset_name
has been renamed todataset_path
. - The :py:meth:`~.api.signals.BaseSignal.set_signal_type` method no longer takes
None
. Use the empty string""
instead. - The :py:meth:`~.api.signals.BaseSignal.get_histogram`
bins
keyword values have been renamed as follows for consistency with numpy:"scotts"
->"scott"
,"freedman"
->"fd"
- Multiple changes to the syntax of the :py:meth:`~hyperspy.model.BaseModel.fit`
and :py:meth:`~hyperspy.model.BaseModel.multifit` methods:
- The
fitter
keyword has been renamed tooptimizer
. - The values that the
optimizer
keyword take have been renamed for consistency with scipy:"fmin"
->"Nelder-Mead"
,"fmin_cg"
->"CG"
,"fmin_ncg"
->"Newton-CG"
,"fmin_bfgs"
->"BFGS"
,"fmin_l_bfgs_b"
->"L-BFGS-B"
,"fmin_tnc"
->"TNC"
,"fmin_powell"
->"Powell"
,"mpfit"
->"lm"
(in combination with"bounded=True"
),"leastsq"
->"lm"
,
- Passing integer arguments to
parallel
to select the number of workers is now deprecated. Useparallel=True, max_workers={value}
instead. - The
method
keyword has been renamed toloss_function
. - The
loss_function
value"ml"
has been renamed to"ML-poisson"
. - The
grad
keyword no longer takes boolean values. It takes the following values instead:"fd"
,"analytical"
, callable orNone
. - The
ext_bounding
keyword has been deprecated and will be removed. Usebounded=True
instead. - The
min_function
keyword argument has been deprecated and will be removed. Useloss_function
instead., - The
min_function_grad
keyword arguments has been deprecated and will be removed. Usegrad
instead. - The
iterpath
default will change from'flyback'
to'serpentine'
in HyperSpy version 2.0.
- The
- The following :py:class:`~hyperspy.model.BaseModel` methods are now private:
hyperspy.model.BaseModel.set_boundaries
hyperspy.model.BaseModel.set_mpfit_parameters_info
- The
comp_label
keyword of the machine learning plotting functions has been renamed totitle
. - The :py:class:`~hyperspy.learn.rpca.orpca` constructor's
learning_rate
keyword has been renamed tosubspace_learning_rate
- The :py:class:`~hyperspy.learn.rpca.orpca` constructor's
momentum
keyword has been renamed tosubspace_momentum
- The :py:class:`~hyperspy.learn.svd_pca.svd_pca` constructor's
centre
keyword values have been renamed as follows:"trials"
->"navigation"
"variables"
->"signal"
- The
bounds
keyword argument of the :py:meth:`~._signals.lazy.LazySignal.decomposition` is deprecated and will be removed. - Several syntax changes in the :py:meth:`~.api.signals.BaseSignal.decomposition` method:
- Several
algorithm
keyword values have been renamed as follows:"svd"
:"SVD"
,"fast_svd"
:"SVD"
,"nmf"
:"NMF"
,"fast_mlpca"
:"MLPCA"
,"mlpca"
:"MLPCA"
,"RPCA_GoDec"
:"RPCA"
,
- The
polyfit
argument has been deprecated and will be removed. Usevar_func
instead.
- Several
This is a maintenance release that adds compatibility with Numpy 1.17 and Dask 2.3.0 and fixes a bug in the Bruker reader. See the issue tracker for details.
This is a maintenance release that fixes some regressions introduced in v1.5. Follow the following links for details on all the bugs fixed.
- New method :py:meth:`hyperspy.component.Component.print_current_values`. See :ref:`the User Guide for details <Component.print_current_values>`.
- New :py:class:`hyperspy._components.skew_normal.SkewNormal` component.
- New :py:meth:`hyperspy.api.signals.BaseSignal.apply_apodization` method and
apodization
keyword for :py:meth:`hyperspy.api.signals.BaseSignal.fft`. See :ref:`signal.fft` for details. - Estimation of number of significant components by the elbow method. See :ref:`mva.scree_plot`.
- The contrast adjustment tool has been hugely improved. Test it by pressing the
h
key on any image. - The :ref:`Developer Guide <dev_guide>` has been extended, enhanced and divided into chapters.
- Signals with signal dimension equal to 0 and navigation dimension 1 or 2 are automatically transposed when using :py:func:`hyperspy.api.plot.plot_images` or :py:func:`hyperspy.api.plot.plot_spectra` respectively. This is specially relevant when plotting the result of EDS quantification. See :external+exspy:ref:`eds-label` for examples.
- The following components have been rewritten using
:py:class:`hyperspy._components.expression.Expression`, boosting their
speeds among other benefits. Multiple issues have been fixed on the way.
- :py:class:`hyperspy._components.lorentzian.Lorentzian`
- :py:class:`hyperspy._components.exponential.Exponential`
- :py:class:`hyperspy._components.bleasdale.Bleasdale`
- :py:class:`hyperspy._components.rc.RC`
- :py:class:`hyperspy._components.logistic.Logistic`
- :py:class:`hyperspy._components.error_function.Erf`
- :py:class:`hyperspy._components.gaussian2d.Gaussian2D`
- :py:class:`exspy.components.VolumePlasmonDrude`
- :py:class:`exspy.components.DoublePowerLaw`
- The
hyperspy._components.polynomial_deprecated.Polynomial
component will be deprecated in HyperSpy 2.0 in favour of the new :py:class:`hyperspy._components.polynomial.Polynomial` component, that is based on :py:class:`hyperspy._components.expression.Expression` and has an improved API. To start using the new component pass thelegacy=False
keyword to the thehyperspy._components.polynomial_deprecated.Polynomial
component constructor.
- Drop support for python 3.5
- New extension mechanism that enables external packages to register HyperSpy objects. See :ref:`writing_extensions-label` for details.
This is a maintenance release. Among many other fixes and enhancements, this release fixes compatibility issues with Matplotlib v 3.1. Follow the following links for details on all the bugs fixed and enhancements.
This is a maintenance release. Follow the following links for details on all the bugs fixed and enhancements.
This release fixes compatibility issues with Python 3.7.
This is a minor release. Follow the following links for details on all the bugs fixed, enhancements and new features.
- Support for three new file formats:
- Reading FEI's Velox EMD file format based on the HDF5 open standard. See :external+rsciio:ref:`emd_fei-format`.
- Reading Bruker's SPX format. See :external+rsciio:ref:`bruker-format`.
- Reading and writing the mrcz open format. See :external+rsciio:ref:`mrcz-format`.
- New
hyperspy.datasets.artificial_data
module which contains functions for generating artificial data, for use in things like docstrings or for people to test HyperSpy functionalities. See :ref:`example-data-label`. - New :meth:`~.api.signals.BaseSignal.fft` and :meth:`~.api.signals.BaseSignal.ifft` signal methods. See :ref:`signal.fft`.
- New :meth:`holospy.signals.HologramImage.statistics` method to compute useful hologram parameters. See :external+holospy:ref:`holography.stats-label`.
- Automatic axes units conversion and better units handling using pint. See :ref:`quantity_and_converting_units`.
- New :class:`~.roi.Line2DROI` :meth:`~.roi.Line2DROI.angle` method. See :ref:`roi-label` for details.
- :py:func:`~.api.plot.plot_images` improvements (see :ref:`plot.images` for details):
- The
cmap
option of :py:func:`~.api.plot.plot_images` supports iterable types, allowing the user to specify different colormaps for the different images that are plotted by providing a list or other generator. - Clicking on an individual image updates it.
- The
- New customizable keyboard shortcuts to navigate multi-dimensional datasets. See :ref:`visualization-label`.
- The :py:meth:`~.api.signals.Signal1D.remove_background` method now operates much faster in multi-dimensional datasets and adds the options to interatively plot the remainder of the operation and to set the removed background to zero. See :ref:`signal1D.remove_background` for details.
- The :py:meth:`~.api.signals.Signal2D.plot` method now takes a
norm
keyword that can be "linear", "log", "auto" or a matplotlib norm. See :ref:`plot.customize_images` for details. Moreover, there are three new extra keyword arguments,fft_shift
andpower_spectrum
, that are useful when plotting fourier transforms. See :ref:`signal.fft`. - The :py:meth:`~.api.signals.Signal2D.align2D` and :py:meth:`~.api.signals.Signal2D.estimate_shift2D` can operate with sub-pixel accuracy using skimage's upsampled matrix-multiplication DFT. See :ref:`signal2D.align`.
This is a maintenance release. Follow the following links for details on all the bugs fixed and enhancements.
This is a maintenance release. Follow the following links for details on all the bugs fixed and enhancements.
Starting with this version, the HyperSpy WinPython Bundle distribution is no longer released in sync with HyperSpy. For HyperSpy WinPython Bundle releases see https://github.com/hyperspy/hyperspy-bundle
This is a minor release. Follow the following links for details on all the bugs fixed, feature and documentation enhancements, and new features.
- :py:meth:`~.api.signals.BaseSignal.rebin` supports upscaling and rebinning to arbitrary sizes through linear interpolation. See :ref:`rebin-label`. It also runs faster if numba is installed.
- :py:attr:`~.axes.AxesManager.signal_extent` and :py:attr:`~.axes.AxesManager.navigation_extent` properties to easily get the extent of each space.
- New IPywidgets Graphical User Interface (GUI) elements for the Jupyter Notebook. See the new hyperspy_gui_ipywidgets package. It is not installed by default, see :ref:`install-label` for details.
- All the :ref:`roi-label` now have a
gui
method to display a GUI if at least one of HyperSpy's GUI packgages are installed.
- Creating many markers is now much faster.
- New "Stage" metadata node. See :ref:`metadata_structure` for details.
- The Brucker file reader now supports the new version of the format. See :external+rsciio:ref:`bruker-format`.
- HyperSpy is now compatible with all matplotlib backends, including the nbagg which is particularly convenient for interactive data analysis in the Jupyter Notebook in combination with the new hyperspy_gui_ipywidgets package. See :ref:`importing_hyperspy-label`.
- The
vmin
andvmax
arguments of the :py:func:`~.api.plot.plot_images` function now accept lists to enable setting these parameters for each plot individually. - The :py:meth:`~.api.signals.BaseSignal.plot_decomposition_results` and :py:meth:`~.api.signals.BaseSignal.plot_bss_results` methods now makes a better guess of the number of navigators (if any) required to visualise the components. (Previously they were always plotting four figures by default.)
- All functions that take a signal range can now take a :py:class:`~.roi.SpanROI`.
- The following ROIs can now be used for indexing or slicing (see :ref:`here <roi-slice-label>` for details):
- Permanent markers (if any) are now displayed when plotting by default.
- HyperSpy no longer depends on traitsui (fixing many installation issues) and ipywidgets as the GUI elements based on these packages have now been splitted into separate packages and are not installed by default.
- The following methods now raise a
ValueError
when not providing the number of components ifoutput_dimension
was not specified when performing a decomposition. (Previously they would plot as many figures as available components, usually resulting in memory saturation): - The default extension when saving to HDF5 following HyperSpy's specification
is now
hspy
instead ofhdf5
. See :external+rsciio:ref:`hspy-format`. - The following methods are deprecated and will be removed in HyperSpy 2.0
.axes.AxesManager.show
. Use :py:meth:`~.axes.AxesManager.gui` instead.- All
notebook_interaction
method. Use the equivalentgui
method instead. hyperspy.api.signals.Signal1D.integrate_in_range
. Use :py:meth:`~.api.signals.BaseSignal.integrate1D` instead.
- The following items have been removed from
:ref:`preferences <configuring-hyperspy-label>`:
General.default_export_format
General.lazy
Model.default_fitter
Machine_learning.multiple_files
Machine_learning.same_window
Plot.default_style_to_compare_spectra
Plot.plot_on_load
Plot.pylab_inline
EELS.fine_structure_width
EELS.fine_structure_active
EELS.fine_structure_smoothing
EELS.synchronize_cl_with_ll
EELS.preedge_safe_window_width
EELS.min_distance_between_edges_for_fine_structure
- New
Preferences.GUIs
section to enable/disable the installed GUI toolkits.
- In addition to adding ipywidgets GUI elements, the traitsui GUI elements have been splitted into a separate package. See the new hyperspy_gui_traitsui package.
- The new
hyperspy.ui_registry
enables easy connection of external GUI elements to HyperSpy. This is the mechanism used to split the traitsui and ipywidgets GUI elements.
This is a minor release. Follow the following links for details on all the bugs fixed, enhancements and new features.
- Lazy loading and evaluation. See :ref:`big-data-label`.
- Parallel :py:meth:`~.api.signals.BaseSignal.map` and all the functions that use it internally (a good fraction of HyperSpy's functionaly). See :ref:`map-label`.
- :external+holospy:ref:`electron-holography-label` reconstruction.
- Support for reading :external+rsciio:ref:`edax-format` files.
- New signal methods :py:meth:`~.api.signals.BaseSignal.indexmin` and :py:meth:`~.api.signals.BaseSignal.valuemin`.
- Easier creation of :py:class:`~._components.expression.Expression` components using substitutions. See the :ref:`User Guide for details <expression_component-label>`.
- :py:class:`~._components.expression.Expression` takes two dimensional functions that can automatically include a rotation parameter. See the :ref:`User Guide for details <expression_component-label>`.
- Better support for EMD files.
- The scree plot got a beauty treatment and some extra features. See :ref:`mva.scree_plot`.
- :py:meth:`~.api.signals.BaseSignal.map` can now take functions that return differently-shaped arrays or arbitrary objects, see :ref:`map-label`.
- Add support for stacking multi-signal files. See :ref:`load-multiple-label`.
- Markers can now be saved to hdf5 and creating many markers is easier and faster. See :ref:`plot.markers`.
- Add option to save to HDF5 file using the ".hspy" extension instead of ".hdf5". See :external+rsciio:ref:`hspy-format`. This will be the default extension in HyperSpy 1.3.
- Most of HyperSpy plotting features are now covered by unittests. See :ref:`plot-test-label`.
- unittests migrated from nose to pytest. See :ref:`testing-label`.
This is a maintenance release. Follow the following links for details on all the bugs fixed and enhancements.
This is a maintenance release. Follow the following link for details on all the bugs fixed.
- Prettier X-ray lines labels.
- New metadata added to the HyperSpy metadata specifications:
magnification
,frame_number
,camera_length
,authors
,doi
,notes
andquantity
. See :ref:`metadata_structure` for details. - The y-axis label (for 1D signals) and colorbar label (for 2D signals)
are now taken from the new
metadata.Signal.quantity
. - The
time
anddate
metadata are now stored in the ISO 8601 format. - All metadata in the HyperSpy metadata specification is now read from all supported file formats when available.
This is a minor release. Follow the following links for details on all the bugs fixed.
- :py:meth:`~hyperspy.model.BaseModel.fit` takes a new algorithm, the global optimizer differential evolution.
- :py:meth:`~hyperspy.model.BaseModel.fit` algorithm, leastsq, inherits SciPy's bound constraints support (requires SciPy >= 0.17).
- :py:meth:`~hyperspy.model.BaseModel.fit` algorithm names changed to be consistent scipy.optimze.minimize() notation.
This is a maintenance release. Follow the following links for details on all the bugs fixed.
This is a major release. Here we only list the highlist. A detailed list of changes is available in github.
- :ref:`roi-label`.
- :ref:`Robust PCA <mva.rpca>` (RPCA) and online RPCA algorithms.
- Numpy ufuncs can now :ref:`operate on HyperSpy's signals <ufunc-label>`.
- ComplexSignal and specialised subclasses to :ref:`operate on complex data <complex_data-label>`.
- Events :ref:`logging <logger-label>`.
- Query and fetch spectr from :func:`exspy.data.eelsdb` from The EELS Database.
- :ref:`interactive-label`.
- :ref:`events-label`.
- :ref:`SAMFire-label`.
- Store :ref:`models in hdf5 files <storing_models-label>`.
- Add :ref:`fancy indexing <model_indexing-label>` to Model.
- :ref:Two-dimensional model fitting (:py:class:`~.models.model2d.Model2D`).
- :external+exspy:ref:`Z-factors quantification <eds_quantification-label>`.
- :external+exspy:ref:`Cross section quantification <eds_quantification-label>`.
- :external+exspy:ref:`EDS curve fitting <eds_fitting-label>`.
- X-ray :external+exspy:ref:`absorption coefficient database <eds_absorption_db-label>`.
- Support for reading certain files without :ref:`loading them to memory <load_to_memory-label>`.
- :external+rsciio:ref:`Bruker's composite file (bcf) <bruker-format>` reading support.
- :external+rsciio:ref:`Electron Microscopy Datasets (EMD) <emd-format>` read and write support.
- :external+rsciio:ref:`SEMPER unf <semper-format>` read and write support.
- :external+rsciio:ref:`DENS heat log <dens-format>` read support.
- :external+rsciio:ref:`NanoMegas blockfile <blockfile-format>` read and write support.
- More useful
AxesManager
repr string with html repr for Jupyter Notebook. - Better progress bar (tqdm).
- Add support for :external+rsciio:ref:`writing/reading scale and unit to tif files <tiff-format>` to be read with ImageJ or DigitalMicrograph.
- The following sections of the User Guide were revised and largely overwritten:
- New :ref:`dev_guide`.
- Split :ref:`components <model_components-label>` into
components1D
andcomponents2D
. - Remove
record_by
from metadata. - Remove simulation classes.
- The :py:class:`~.api.signals.Signal1D`,
hyperspy._signals.image.Signal2D
and :py:class:`~.api.signals.BaseSignal` classes deprecated the old Spectrum Image and Signal classes.
This is a maintenance release. Follow the following links for details on all the bugs fixed, feature and documentation enhancements.
It also includes a new feature and introduces an important API change that will be fully enforced in Hyperspy 1.0.
- Widgets to interact with the model components in the Jupyter Notebook. See :ref:`here <notebook_interaction-label>` and #1007 .
The new :py:class:`~.api.signals.BaseSignal`,
:py:class:`~.api.signals.Signal1D` and
:py:class:`~.api.signals.Signal2D` deprecate hyperspy.signal.Signal
,
:py:class:`~.api.signals.Signal1D` and :py:class:`~.api.signals.Signal2D`
respectively. Also as_signal1D
, as_signal2D`
, to_signal1D
and to_signal2D
deprecate as_signal1D
, as_signal2D
, to_spectrum
and to_image
. See #963 and #943 for details.
This release adds support for Python 3 and drops support for Python 2. In all other respects it is identical to 0.8.3.
This is a maintenance release that includes fixes for multiple bugs, some enhancements, new features and API changes. This is set to be the last HyperSpy release for Python 2. The release (HyperSpy 0.8.4) will support only Python 3.
Importantly, the way to start HyperSpy changes (again) in this release. Please read carefully :ref:`importing_hyperspy-label` for details.
The broadcasting rules have also changed. See :ref:`signal.operations` for details.
Follow the following links for details on all the bugs fixed, documentation enhancements, enhancements, new features and API changes
This is a maintenance release that fixes an issue with the Python installers. Those who have successfully installed 0.8.1 do not need to upgrade.
This is a maintenance release. Follow the following links for details on all the bugs fixed, feature and documentation enhancements.
Importantly, the way to start HyperSpy changes in this release. Read :ref:`importing_hyperspy-label` for details.
It also includes some new features and introduces important API changes that will be fully enforced in Hyperspy 1.0.
- Support for IPython 3.0.
%hyperspy
IPython magic to easily and transparently import HyperSpy, matplotlib and numpy when using IPython.- :py:class:`~._components.expression.Expression` model component to easily create analytical function components. More details :ref:`here <expression_component-label>`.
hyperspy.signal.Signal.unfolded
context manager.hyperspy.signal.Signal.derivative
method.- :ref:`syntax to access the components in the model <model_components-label>` that includes pretty printing of the components.
hyperspy.hspy
is now deprecated in favour of the new :py:mod:`hyperspy.api`. The new API renames and/or move several modules as folows:hspy.components
->hyperspy.api.model.components
hspy.utils
->hyperspy.api
hspy.utils.markers
hyperspy.api.plot.markers
hspy.utils.example_signals
->hyperspy.api.datasets.example_signals
In HyperSpy 0.8.1 the full content of
hyperspy.hspy
is still imported in the user namespace, but this can now be disabled inhs.preferences.General.import_hspy
. In Hyperspy 1.0 it will be disabled by default and thehyperspy.hspy
module will be fully removed in HyperSpy 0.10. We encourage all users to migrate to the new syntax. For more details see :ref:`importing_hyperspy-label`.Indexing the
hyperspy.signal.Signal
class is now deprecated. We encourage all users to useisig
andinav
instead for indexing.hyperspy.hspy.create_model
is now deprecated in favour of the new equivalenthyperspy.signal.Signal.create_model
Signal
method.hyperspy.signal.Signal.unfold_if_multidim
is deprecated.
- :py:meth:`~.api.signals.Signal1D.spikes_removal_tool` displays derivative max value when used with GUI.
- Progress-bar can now be suppressed by passing
show_progressbar
argument to all functions that generate it.
- HDF5 file format now supports saving lists, tuples, binary strings and signals in metadata.
- New class,
hyperspy.drawing.marker.MarkerBase
, to plot markers withhspy.utils.plot.markers
module. See :ref:`plot.markers`. - New method to plot images with the :py:func:`~.api.plot.plot_images` function in
hspy.utils.plot.plot_images
. See :ref:`plot.images`. - Improved
hyperspy._signals.image.Signal2D.plot
method to customize the image. See :ref:`plot.customize_images`.
- New method for quantifying EDS TEM spectra using Cliff-Lorimer method,
hyperspy._signals.eds_tem.EDSTEMSpectrum.quantification
. See :external+exspy:ref:`eds_quantification-label`. - New method to estimate for background subtraction,
hyperspy._signals.eds.EDSSpectrum.estimate_background_windows
. See :external+exspy:ref:`eds_background_subtraction-label`. - New method to estimate the windows of integration,
hyperspy._signals.eds.EDSSpectrum.estimate_integration_windows
. - New specific
hyperspy._signals.eds.EDSSpectrum.plot
method, with markers to indicate the X-ray lines, the window of integration or/and the windows for background subtraction. See :external+exspy:ref:`eds_plot_markers-label`. - New examples of signal in the
hspy.utils.example_signals
module.hyperspy.misc.example_signals_loading.load_1D_EDS_SEM_spectrum
hyperspy.misc.example_signals_loading.load_1D_EDS_TEM_spectrum
- New method to mask the vaccum,
hyperspy._signals.eds_tem.EDSTEMSpectrum.vacuum_mask
and a specifichyperspy._signals.eds_tem.EDSTEMSpectrum.decomposition
method that incoroporate the vacuum mask
- :py:class:`~hyperspy.component.Component` and :py:class:`~hyperspy.component.Parameter` now inherit
traits.api.HasTraits
that enabletraitsui
to modify these objects. hyperspy.misc.utils.attrsetter
is added, behaving as the default pythonsetattr
with nested attributes.- Several widget functions were made internal and/or renamed:
add_patch_to
->_add_patch_to
set_patch
->_set_patch
onmove
->_onmousemove
update_patch_position
->_update_patch_position
update_patch_size
->_update_patch_size
add_axes
->set_mpl_ax
This is a maintenance release. A list of fixed issues is available in the 0.7.3 milestone in the github repository.
This is a maintenance release. A list of fixed issues is available in the 0.7.2 milestone in the github repository.
This is a maintenance release. A list of fixed issues is available in the 0.7.1 milestone in the github repository.
- Add suspend/resume model plot updating. See :ref:`model.visualization`.
- New syntax to index the :py:class:`~.axes.AxesManager`.
- New Signal methods to transform between Signal subclasses. More information
:ref:`here <transforming_signal-label>`.
hyperspy.signal.Signal.set_signal_type
hyperspy.signal.Signal.set_signal_origin
hyperspy.signal.Signal.as_signal2D
hyperspy.signal.Signal.as_signal1D
- The string representation of the Signal class now prints the shape of the data and includes a separator between the navigation and the signal axes e.g (100, 10| 5) for a signal with two navigation axes of size 100 and 10 and one signal axis of size 5.
- Add support for RGBA data. See :ref:`signal.change_dtype`.
- The default toolkit can now be saved in the preferences.
- Added full compatibility with the Qt toolkit that is now the default.
- Added compatibility witn the the GTK and TK toolkits, although with no GUI features.
- It is now possible to run HyperSpy in a headless system.
- Added a CLI to
hyperspy.signal.Signal1DTools.remove_background
. - New
hyperspy.signal.Signal1DTools.estimate_peak_width
method to estimate peak width. - New methods to integrate over one axis:
hyperspy.signal.Signal.integrate1D
andhyperspy.signal.Signal1DTools.integrate_in_range
. - New
hyperspy.signal.Signal.metadata
attribute,Signal.binned
. Several methods behave differently on binned and unbinned signals. See :ref:`signal.binned`. - New
hyperspy.signal.Signal.map
method to easily transform the data using a function that operates on individual signals. See :ref:`signal.iterator`. - New
hyperspy.signal.Signal.get_histogram
andhyperspy.signal.Signal.print_summary_statistics
methods. - The spikes removal tool has been moved to the :class:`~.api.signals.Signal1D` class so that it is available for all its subclasses.
- The
hyperspy.signal.Signal.split`
method now can automatically split back stacked signals into its original part. See :ref:`signal.stack_split`.
- Improved support for FEI's emi and ser files.
- Improved support for Gatan's dm3 files.
- Add support for reading Gatan's dm4 files.
- Use the blitting capabilities of the different toolkits to speed up the plotting of images.
- Added several extra options to the Signal
hyperspy.signal.Signal.plot
method to customize the navigator. See :ref:`visualization-label`. - Add compatibility with IPython's matplotlib inline plotting.
- New function, :py:func:`~.api.plot.plot_spectra`, to plot several spectra in the same figure. See :ref:`plot.spectra`.
- New function, :py:func:`~.api.plot.plot_signals`, to plot several signals at the same time. See :ref:`plot.signals`.
- New function, :py:func:`~.api.plot.plot_histograms`, to plot the histrograms of several signals at the same time. See :ref:`plot.signals`.
- The chi-squared, reduced chi-squared and the degrees of freedom are computed automatically when fitting. See :ref:`model.fitting`.
- New functionality to plot the individual components of a model. See :ref:`model.visualization`.
- New method,
hyperspy.model.Model.fit_component
, to help setting the starting parameters. See :ref:`model.starting`.
- The PCA scree plot can now be easily obtained as a Signal. See :ref:`mva.scree_plot`.
- The decomposition and blind source separation components can now be obtained
as
hyperspy.signal.Signal
instances. See :ref:`mva.get_results`. - New methods to plot the decomposition and blind source separation results that support n-dimensional loadings. See :ref:`mva.visualization`.
- New
hyperspy.signal.Signal
subclass,hyperspy._signals.dielectric_function.DielectricFunction
.
- New method,
hyperspy._signals.eels.EELSSpectrum.kramers_kronig_analysis
to calculate the dielectric function from low-loss electron energy-loss spectra based on the Kramers-Kronig relations. See :external+exspy:ref:`eels.kk`. - New method to align the zero-loss peak,
hyperspy._signals.eels.EELSSpectrum.align_zero_loss_peak
.
- New signal, EDSSpectrum especialized in EDS data analysis, with subsignal for EDS with SEM and with TEM: EDSSEMSpectrum and EDSTEMSpectrum. See :external+exspy:ref:`eds-label`.
- New database of EDS lines available in the
elements
attribute of thehspy.utils.material
module. - Adapted methods to calibrate the spectrum, the detector and the microscope. See :external+exspy:ref:`eds_calibration-label`.
- Specific methods to describe the sample,
hyperspy._signals.eds.EDSSpectrum.add_elements
andhyperspy._signals.eds.EDSSpectrum.add_lines
. See :external+exspy:ref:`eds_sample-label` - New method to get the intensity of specific X-ray lines:
hyperspy._signals.eds.EDSSpectrum.get_lines_intensity
. See :external+exspy:ref:`eds_sample-label`
- hyperspy.misc has been reorganized. Most of the functions in misc.utils has
been rellocated to specialized modules. misc.utils is no longer imported in
hyperspy.hspy
. A newhyperspy.utils
module is imported instead. - Objects that have been renamed
hspy.elements
->utils.material.elements
.Signal.navigation_indexer
->inav
.Signal.signal_indexer
->isig
.Signal.mapped_parameters
->Signal.metadata
.Signal.original_parameters
->Signal.original_metadata
.
- The metadata has been reorganized. See :ref:`metadata_structure`.
- The following signal methods now operate out-of-place:
hyperspy.signal.Signal.swap_axes
hyperspy.signal.Signal.rebin
- Signal now supports indexing and slicing. See :ref:`signal.indexing`.
- Most arithmetic and rich arithmetic operators work with signal. See :ref:`signal.operations`.
- Much improved EELSSpectrum methods:
hyperspy._signals.eels.EELSSpectrum.estimate_zero_loss_peak_centre
,hyperspy._signals.eels.EELSSpectrum.estimate_elastic_scattering_intensity
andhyperspy._signals.eels.EELSSpectrum.estimate_elastic_scattering_threshold
. - The axes can now be given using their name e.g.
s.crop("x", 1,10)
- New syntax to specify position over axes: an integer specifies the indexes
over the axis and a floating number specifies the position in the axis units
e.g.
s.crop("x", 1, 10.)
crops over the axis x (in meters) from index 1 to value 10 meters. Note that this may make your old scripts behave in unexpected ways as just renaming the old *_in_units and *_in_values methods won't work in most cases. - Most methods now use the natural order i.e. X,Y,Z.. to index the axes.
- Add padding to fourier-log and fourier-ratio deconvolution to fix the wrap-around problem and increase its performance.
- New
hyperspy.components.eels_cl_edge.EELSCLEdge.get_fine_structure_as_spectrum
EELSCLEdge method. - New
hyperspy.components.arctan.Arctan
model component. - New
hyperspy.model.Model.enable_adjust_position
andhyperspy.model.Model.disable_adjust_position
to easily change the position of components using the mouse on the plot. - New Model methods
hyperspy.model.Model.set_parameters_value
,hyperspy.model.Model.set_parameters_free
andhyperspy.model.Model.set_parameters_not_free
to easily set several important component attributes of a list of components at once. - New :py:func:`~.api.stack` function to stack signals.
- New Signal methods:
hyperspy.signal.Signal.integrate_simpson
,hyperspy.signal.Signal.max
,hyperspy.signal.Signal.min
,hyperspy.signal.Signal.var
, andhyperspy.signal.Signal.std
. - New sliders window to easily navigate signals with navigation_dimension > 2.
- The Ripple (rpl) reader can now read rpl files produced by INCA.
The following functions has been renamed or removed:
components.EELSCLEdge
- knots_factor -> fine_structure_smoothing
- edge_position -> onset_energy
- energy_shift removed
components.Voigt.origin -> centre
signals.Signal1D
- find_peaks_1D -> Signal.find_peaks1D_ohaver
- align_1D -> Signal.align1D
- shift_1D -> Signal.shift1D
- interpolate_1D -> Signal.interpolate1D
signals.Signal2D.estimate_2D_translation -> Signal.estimate_shift2D
Signal
- split_in -> split
- crop_in_units -> crop
- crop_in_pixels -> crop
Change syntax to create Signal objects. Instead of a dictionary Signal.__init__ takes keywords e.g with a new syntax .
>>> s = signals.Signal1D(np.arange(10))
instead of>>> s = signals.Signal1D({'data' : np.arange(10)})
- New Signal method get_current_signal proposed by magnunor.
- New Signal save method keyword extension to easily change the saving format while keeping the same file name.
- New EELSSpectrum methods: estimate_elastic_scattering_intensity, fourier_ratio_deconvolution, richardson_lucy_deconvolution, power_law_extrapolation.
- New Signal1D method: hanning_taper.
- The print_current_values Model method was raising errors when fine structure was enabled or when only_free = False.
- The load function signal_type keyword was not passed to the readers.
- The spikes removal tool was unable to find the next spikes when the spike was detected close to the limits of the spectrum.
- load was raising an UnicodeError when the title contained non-ASCII characters.
- In Windows HyperSpy Here was opening in the current folder, not in the selected folder.
- The fine structure coefficients were overwritten with their std when charging values from the model.
- Storing the parameters in the maps and all the related functionality was broken for 1D spectrum.
- Remove_background was broken for 1D spectrum.
- EELSSpectrum.find_low_loss_centre was renamed to estimate_zero_loss_peak_centre.
- EELSSpectrum.calculate_FWHM was renamed to estimate_FWHM.
- The documentation was thoroughly revised, courtesy of M. Walls.
- New user interface to remove spikes from EELS spectra.
- New align2D signals.Signal2D method to align image stacks.
- When loading image files, the data are now automatically converted to grayscale when all the color channels are equal.
- Add the possibility to load a stack memory mapped (similar to ImageJ virtual stack).
- Improved hyperspy starter script that now includes the possibility to start HyperSpy in the new IPython notebook.
- Add "HyperSpy notebook here" to the Windows context menu.
- The information displayed in the plots produced by Signal.plot have been enhanced.
- Added Egerton's sigmak3 and sigmal3 GOS calculations (translated from matlab by I. Iyengar) to the EELS core loss component.
- A browsable dictionary containing the chemical elements and their onset energies is now available in the user namespace under the variable name elements.
- The ripple file format now supports storing the beam energy, the collection and the convergence angle.
- The EELS core loss component had a bug in the calculation of the relativistic gamma that produced a gamma that was always approximately zero. As a consequence the GOS calculation was wrong, especially for high beam energies.
- Loading msa files was broken when running on Python 2.7.2 and newer.
- Saving images to rpl format was broken.
- Performing BSS on data decomposed with poissonian noise normalization was failing when some columns or rows of the unfolded data were zero, what occurs often in EDX data for example.
- Importing some versions of scikits learn was broken
- The progress bar was not working properly in the new IPython notebook.
- The constrast of the image was not automatically updated.
- spatial_mask was renamed to navigation_mask.
- Signal1D and Signal2D are not loaded into the user namespace by default. The signals module is loaded instead.
- Change the default BSS algorithm to sklearn fastica, that is now distributed with HyperSpy and used in case that sklearn is not installed e.g. when using EPDFree.
- _slicing_axes was renamed to signal_axes.
- _non_slicing_axes to navigation_axes.
- All the Model *_in_pixels methods were renamed to to _*_in_pixel.
- EELSCLEdge.fs_state was renamed to fine_structure_active.
- EELSCLEdge.fslist was renamed to fine_structure_coeff.
- EELSCLEdge.fs_emax was renamed to fine_structure_width.
- EELSCLEdge.freedelta was renamed to free_energy_shift.
- EELSCLEdge.delta was renamed to energy_shift.
- A value of True in a mask now means that the item is masked all over HyperSpy.
- Added TIFF 16, 32 and 64 bits support by using (and distributing) Christoph Gohlke's tifffile library.
- Improved UTF8 support.
- Reduce the number of required libraries by making mdp and hdf5 not mandatory.
- Improve the information returned by __repr__ of several objects.
- DictionaryBrowser now has an export method, i.e. mapped parameters and original_parameters can be exported.
- New _id_name attribute for Components and Parameters. Improvements in their __repr__ methods.
- Component.name can now be overwriten by the user.
- New Signal.__str__ method.
- Include HyperSpy in The Python Package Index.
- Non-ascii characters breaking IO and print features fixed.
- Loading of multiple files at once using wildcards fixed.
- Remove broken hyperspy-gui script.
- Remove unmantained and broken 2D peak finding and analysis features.
- In EELS automatic background feature creates a PowerLaw component, adds it to the model an add it to a variable in the user namespace. The variable has been renamed from bg to background.
- pes_gaussian Component renamed to pes_core_line_shape.
- Add a slider to the filter ui.
- Add auto_replot to sum.
- Add butterworth filter.
- Added centring and auto_transpose to the svd_pca algorithm.
- Keep the mva_results information when changing the signal type.
- Added sparse_pca and mini_batch_sparse_pca to decomposition algorithms.
- Added TV to the smoothing algorithms available in BSS.
- Added whitening to the mdp ICA preprocessing.
- Add explained_variance_ratio.
- Improvements in saving/loading mva data.
- Add option to perform ICA on the scores.
- Add orthomax FA algorithm.
- Add plot methods to Component and Parameter.
- Add plot_results to Model.
- Add possibility to export the decomposition and bss results to a folder.
- Add Signal method change_dtype.
- Add the possibility to pass extra parameters to the ICA algorithm.
- Add the possibility to reproject the data after a decomposition.
- Add warning when decomposing a non-float signal.
- adds a method to get the PCs as a Signal1D object and adds smoothing to the ICA preprocessing.
- Add the possibility to select the energy range in which to perform spike removal operations.
- the smoothings guis now offer differentiation and line color option. Smoothing now does not require a gui.
- Fix reverse_ic which was not reversing the scores and improve the autoreversing method.
- Avoid cropping when is not needed.
- Changed criteria to reverse the ICs.
- Changed nonans default to False for plotting.
- Change the whitening algorithm to a svd based one and add sklearn fastica algorithm.
- Clean the ummixing info after a new decomposition.
- Increase the chances that similar independent components will have the same indexes.
- Make savitzky-golay smoothing work without raising figures.
- Make plot_decomposition* plot only the number of factors/scores determined by output_dimension.
- make the Parameter __repr__ method print its name.
- New contrast adjustment tool.
- New export method for Model, Component and Parameter.
- New Model method: print_current_values.
- New signal, spectrum_simulation.
- New smoothing algorithm: total variance denoising.
- Plotting the components in the same or separate windows is now configurable in the preferences.
- Plotting the spikes is now optional.
- Return an error message when the decomposition algorithm is not recognised.
- Store the masks in mva_results.
- The free parameters are now automically updated on chaning the free attribute.
- Added missing keywords to plot_pca_factors and plot_ica_factors.
- renamed incorrectly named exportPca and exportIca functions.
- an error was raised when calling generate_data_from_model.
- a signal with containing nans was failing to plot.
- attempting to use any decomposition plotting method after loading with mva_results.load was raising an error.
- a typo was causing in error in pca when normalize_variance = True.
- a typo was raising an error when cropping the decomposition dimension.
- commit 5ff3798105d6 made decomposition and other methods raise an error.
- BUG-FIXED: the decomposition centering index was wrong.
- ensure_directory was failing for the current directory.
- model data forced to be 3D unnecessarily.
- non declared variable was raising an error.
- plot naming for peak char factor plots were messed up.
- plot_RGB was broken.
- plot_scores_2D was using the transpose of the shape to reshape the scores.
- remove background was raising an error when the navigation dimension was 0.
- saving the scores was sometimes transposing the shape.
- selecting indexes while using the learning export functions was raising an error.
- the calibrate ui was calculating wrongly the calibration the first time that Apply was pressed.
- the offset estimation was summing instead of averaging.
- the plot_explained_variance_ratio was actually plotting the cumulative, renamed.
- the signal mask in decomposition and ica was not being raveled.
- the slice attribute was not correctly set at init in some scenarios.
- the smoothing and calibrabrion UIs were freezing when the plots where closed before closing the UI window.
- to_spectrum was transposing the navigation dimension.
- variance2one was operating in the wrong axis.
- when closing the plots of a model, the UI object was not being destroyed.
- when plotting an image the title was not displayed.
- when the axis size was changed (e.g. after cropping) the set_signal_dimension method was not being called.
- when using transform the data was being centered and the resulting scores were wrong.
- in decomposition V rename to explained_variance.
- In FixedPattern, default interpolation changed to linear.
- Line and parabole components deleted + improvements in the docstrings.
- pca_V = variance.
- mva_result renamed to learning_results.
- pca renamed to decomposition.
- pca_v and mva_results.v renamed to scores pc renamed to factors . pca_build_SI renamed to get_pca_model ica_build_SI renamed to get_ica_model.
- plot_explained_variance renamed to plot_explained_variance_ratio.
- principal_components_analysis renamed to decomposition.
- rename eels_simulation to eels_spectrum_simulation.
- Rename the output parameter of svd_pca and add scores.
- Replace plot_lev by plot_explained_variance_ratio.
- Scores renamed to loadings.
- slice_bool renamed to navigate to make its function more explicit.
- smoothing renamed to pretreatment and butter added.
- variance2one renamed to normalize_variance.
- w renamed to unmixing matrix and fixes a bug when loading a mva_result in which output_dimension = None.
- ubshells are again availabe in the interactive session.
- Several changes to the interface.
- The documentation was updated to reflex the last changes.
- The microscopes.csv file was updated so it no longer contains the Orsay VG parameters.