Psipy

Latest version: v0.4.0

Safety actively analyzes 641872 Python packages for vulnerabilities to keep your Python projects secure.

Scan your dependencies

0.4.0

-------------

New features
~~~~~~~~~~~~
- It is now possible trace magnetic field lines through PLUTO data.
The code for doing this is exactly the same as for MAS data.
- Variables from MAS 2T and/or WTD runs can now be read (te, tp, zp, zm, ep, em, heat).

Bug fixes
~~~~~~~~~
- Removed a couple of un-needed dependencies from the package.
- Fixed the erroneous MAS current density normalization.
- Standardized the MAS normalization constants to all be correct to 8 significant figures.
- Fixed :meth:`~psipy.model.variable.Variable.sample_at_coords` erroring for some valid model data.
- Fixed the Matplotlib tracing example in the gallery.

Breaking changes
~~~~~~~~~~~~~~~~
- The ``r`` attribute of `psipy.tracing.flines.FieldLine` is now stored as a
:class:`~astropy.units.Quantity` instead of as an array.
- ``psipy.tracing.flines.FieldLine.xyz`` now returnes a
:class:`~astropy.units.Quantity` instead of an array.
- ``MASPlotter`` has been renamed to `PyvistaPlotter` as it can now plot PLUTO data as well as MAS data.

0.3.1

-------------
New features
~~~~~~~~~~~~
- MAS output files with timestamps > 3 digits long can now be read in.

New behaviour
~~~~~~~~~~~~~
- `psipy.model.variable.Variable.sample_at_coords` will now return ``NaN`` for
any sample points that are out of bounds, and raise a warning letting
the user know some points were out of bounds.

Breaking changes
~~~~~~~~~~~~~~~~
- The radial coordinate input to `psipy.tracing.FortranTracer.trace` is now required to be
a :class:`~astropy.units.Quantity` (with length units) instead of a plain numpy array.
- The radial coordinate input to the sphere methods on ``psipy.visualization.pyvista.MASPlotter`` is now required to be
a :class:`~astropy.units.Quantity` (with length units) instead of a plain numpy array.

Bug fixes
~~~~~~~~~
- Fixed the in-situ sampling example.
- Fixed the multiple-time step sample data only returning a single file.
- Fixed radial coordinate units in PLUTO outputs.

0.3.0

-------------
Python support
~~~~~~~~~~~~~~
Running psipy on Python 3.10 is now officially supported.

Updated requirements
~~~~~~~~~~~~~~~~~~~~
``psipy`` now requires the ``pooch`` package to handle sample data.

Tracing field lines
~~~~~~~~~~~~~~~~~~~
``psipy`` can now trace field lines through models that have all three
components of the magnetic field available. For more information see new pages
in the guide and new examples in the gallery.

Bug fixes
~~~~~~~~~
- Fixed density units assigned to MAS models.
- Loading PLUTO files was broken in version 0.2; this has now been fixed, and
tests added to ensure this doesn't happen again in the future.

0.2.0

-------------
Support for multiple timesteps
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Support for reading in model outputs across multiple timesteps has been added,
where each timestep is stored in an individual file.
:func:`psipy.io.mas.read_mas_file` will automatically read in all the MAS
output files it finds in the given directory. The time coordinate values can be
queried with the new `Variable.time_coords` property of variables.

The following methods have been updated to support this:

- `Variable.sample_at_coords` now accepts a ``t`` argument
to interpolate across timesteps.
- `Variable.plot_radial_cut`,
`Variable.contour_radial_cut`,
`Variable.plot_phi_cut`,
`Variable.contour_phi_cut`,
`Variable.plot_equatorial_cut`, and
`Variable.contour_equatorial_cut` all now accept a
``t_idx`` argument, which is the time index at which to plot the cuts. This
defaults to ``t_idx=0``.

When loading a set of netCDF files they will be lazily loaded along the time
dimension (ie. only one file will be read into memory at any one time).

When loading a set of HDF4 or HDF5 files all of them will be read into
memory, so beware loading lots of them! Support for lazy loading may be
implemented for HDF4 or HDF5 files in the future.

Animations
~~~~~~~~~~
`Variable.plot_radial_cut`, `Variable.plot_phi_cut`, and
`Variable.plot_equatorial_cut` now support animation creation. If multiple
timesteps are loaded in the `Variable` and the timestep isn't specified, a
:class:`~matplotlib.animation.Animation` object will be returend instead of
a single plot being created. See the example gallery for more information on
how to save the animation to disk.

Other new features
~~~~~~~~~~~~~~~~~~
- Added :func:`~psipy.io.mas.convert_hdf_to_netcdf` to convert a set of HDF
files to netCDF files. This is useful for creating animations from large
datasets, as psipy can keep track of a number of netCDF files without reading
them all into memory at once.

Fixes
~~~~~
- Accessing a variable from a model output multiple times will now return the
same object, instead of making two copies of the variable in memory.

0.1.1

-------------
Added the ability to change the units and radial coordinates of a `Variable`.
There are two new examples showing how to do this in the example gallery.

0.1

-----------
First PsiPy release.

Links

Releases

© 2024 Safety CLI Cybersecurity Inc. All Rights Reserved.