Pace-neutrons

Latest version: v0.4.0

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

Scan your dependencies

Page 1 of 5

4.0.0

* New features
- Updated to use libpymcr [v0.2.1](https://github.com/pace-neutrons/libpymcr/releases/tag/v0.2.1)
- Features from that include: specifying function handle using the `` operator,
use of `Ctrl+C` to interrrupt Matlab execution, better formatting of Matlab output

* Bugfixes
- Now have `ctf` for Matlab R2021b to R2024b included in distribution.
- Support for Python 3.13 added, support for Python 3.7 dropped.


[v0.3.0a1](https://github.com/pace-neutrons/pace-python/compare/v0.2.0...v0.3.0a0)

* New features
- Add ability to use existing Horace/SpinW rather than downloading
- Check included to test provided Horace/SpinW path
- Add option to exclude Horace/SpinW from build
- Add option to set version/release to download
- Version checking for both Horace and SpinW included
- Inclusion of libpymcr enabling use of previously incompatible Matlab and Python versions
- IPythonMagics module moved to [libpymcr](https://pypi.org/project/libpymcr/).

* For developers (CI changes)
- Update to use PACE-shared-lib
- Add parametrised pipeline
- Update for use with rocky8 and icdpacewin
- Use conda environments throughout
- Remove podman usage
- Introduce seperate build installer stage
- Remove reliance on external powershell and bash scripts

* Notes
- Brille test currently disabled (see 28)

[v0.2.0](https://github.com/pace-neutrons/pace-python/compare/v0.1.4...v0.2.0)

3.6.2

* New features
- Add support for Horace parallel framework. Use `m.hpc('on')` to activate and then set the cluster type `m.hpc_config().parallel_cluster = <x>` where `<x> = 'parpool'`, `'herbert'` or `'mpiexec_mpi'`.

* Bugfixes
- Fix bug where Matlab `+namespaces` were not accessible in Python
- Several small bugs when using with Spyder.

[v0.1.4](https://github.com/pace-neutrons/pace-python/compare/v0.1.3...v0.1.4)

* New features
- New `pace_neutrons` wrapper script to launch PACE, setting all needed paths
- Can also launch jupyter or spyder with `pace_neutrons --spyder` or `pace_neutrons --jupyter`
- Facility to download and install MCR automatically or on first use

* Bugfixes
- If neither spyder or jupyter installed will use IPython (now a dependency)
- Fix logic error in searching for MCR runtime DLL. Will use registry on Windows.

[v0.1.3](https://github.com/pace-neutrons/pace-python/compare/v0.1.1...v0.1.3)

Updated to Horace 3.6.1.

* Bugfixes
- Fix MatlabProxyObject `__setattr__` - can now do e.g. `h = m.herbert_config(); h.use_mex = True`
- Fix `worker_v2 not found in initialisation` error
- Fix DataTypes.py encoding list recursion.

[v0.1.1](https://github.com/pace-neutrons/pace-python/compare/v0.1.0...v0.1.1)

Initial public beta version of pace_python.

Please download the `pace_python_matlab_installer` file for your OS and run it. This will install the Matlab Runtime and a GUI installer app. Run the installer app (`pace_python_installer`) which will install miniconda and the `pace_python` module (if you have an existing Python installation you wish to use, select `Custom Installation` in the app).

If you select `Jupyter` and/or `Spyder` (both recommended) in the `Default Installation` option, then after the installation finishes, you will see links to Jupyter and Spyder in your start menu (on Windows) which you can use to start Jupyter/Spyder with pace-python. Then run:


import pace_python
m = pace_python.Matlab()
m.horace()


To start the Horace GUI.

If you have any problems, please create an issue on this repository.


`Unreleased <https://github.com/pace-neutrons/Euphonic/compare/v1.4.1...HEAD>`_
-------------------------------------------------------------------------------

- Bug fixes

- Make Spectrum directly accessible from euphonic.spectra. (This was
accidentally lost in a refactor, affecting downstream that uses
Spectrum as a type annotation.)

1.4.1

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

- Bug fixes

- CASTEP 25.1 allows Born effective charges to be calculated by
Berry Phase methods without a corresponding dielectric tensor. In
such cases, no long-range term can be subtracted from the Force
Constants (or reconstructed). Euphonic uses the presence of Born
effective charges to indicate such a subtraction; to prevent
ill-defined cases, ForceConstants now sets both Born charges and
dielectric tensor to None if only one was provided.

- An optional parameter is provided to change how bin edges are
obtained from bin centres: previously the bin edges were constrained
to the initial data range, but this can lead to incorrect scaling
when performing broadening. Variable-width broadening schemes are
now allowed to extrapolate the bin edges in order to get the correct
width scaling.

Outside of broadening, the default behaviour is unchanged in order
to maintain backward compatibility. This is likely to be changed
in the next "major version" (i.e. API-breaking release) of
Euphonic.

- Maintenance

- The euphonic.spectra module has been broken up into a subpackage
with the single-spectrum classes defined in euphonic.spectra.base
and the collections in euphonic.spectra.collections. This is not a
breaking change: the public classes, functions and type annotations
remain importable from euphonic.spectra.

- CASTEP 25.1 includes an extra field in .castep_bin files,
indicating whether Born effective charges were read from an
external file. For clarity and safety, this field is now
explicitly read by the Euphonic .castep_bin parser, but remains unused.

- The release process has been reworked to reduce manual steps: a
top-level "release" action will now sequence most of the
steps. (Post-release testing is still separate.)

1.4.0.post1

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

This post-release makes some changes to the source-distribution build process:
- A bug is fixed in the version-numbering script; this particularly affected Windows
- A copies of the unit tests and documentation were mistakenly included
in tarballs, making them excessively large. This is no longer present.


- Bug fixes

- Fixed a bug in the version numbering mechanism affecting builds from sdist
on Windows and environments where Git is unavailable

- Reduce size of sdist, removing docs and tests from
archive. (Restoring similar size to pre-v1.4.0 releases.)

- Maintenance

- Source builds automatically tested on Windows as part of
build/deployment process

1.4.0

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

This release includes some significant modernisation and maintenance,
as well as new features and performance enhancements.

- Requirements

- Python 3.8, 3.9 is no longer supported

- Python 3.12 is supported

- importlib_resources backport is no longer required

- `toolz <https://toolz.readthedocs.io/en/latest/index.html>`_ is
a new requirement

- Some other dependency requirements have been increased in order
to simplify maintenance and testing:

- Minimum version of numpy increased from 1.19.3 to 1.24.0

- Minimum version of matplotlib increased from 3.2 to 3.8

- Minimum version of Pint increased from 0.19 to 0.22

- Minimum version of PyYAML increased from 3.13 to 6.0

- Minimum version of h5py increaased from 2.10 to 3.6

- Minimum version of threadpoolctl increased from 1.0 to 3.0.


- Improvements

- A "reciprocal_spectroscopy" Pint context is made available in the
unit registry for tricky conversions between reciprocal
frequency/energy units. It is not active by default but can be
enabled with e.g.

(10 * ureg("1 / meV")).to("cm", "reciprocal_spectroscopy")

This can also help to avoid divide-by-zero issues when performing
energy <-> wavenumber conversions.

- A Spectrum2DCollection class has been added to euphonic.spectra,
which shares many features with Spectrum1DCollection

- In particular, the ``iter_metadata`` method is recommended when
one needs to iterate over the collection metadata without
copying the spectral data to new objects.

- Both Spectrum1DCollection and Spectrum2DCollection have a
``.from_spectra()`` constructor with an "unsafe" option which
bypasses some consistency checks on the component data. This
should only be used when confident that these will be consistent,
such as when iterating over an existing collection.

- Performance optimisations have been made to the "item getter" for
Spectrum1DCollection (and Spectrum2DCollection); it should now be
significantly faster to access and iterate over the contained
spectra.

- A ``euphonic.writers.phonon_website`` module has been added with a
function to export QpointPhononModes to appropriate JSON for use
with the phonon visualisation website
http://henriquemiranda.github.io/phononwebsite/

From the command-line, this can be accessed with a
``--save-web-json`` argument to the ``euphonic-dispersion`` tool.

- Bug fixes

- Metadata strings from Castep-imported PDOS data are now converted
from numpy strings to native Python strings.

- Spectra from CASTEP .phonon_dos files are now imported with units
of reciprocal energy (e.g. 1/meV)

- Maintenance

- Cleared up unit-conversion-related warnings, de-cluttering the
expected test suite output.

- The Spectrum1DCollection class was significantly refactored to
support addition of Spectrum2DCollection and improve
maintainability.

- Entire build system rework, migrating to ``pyproject.toml`` form
with ``meson-python``, ``cibuildwheel`` and removing
``versioneer`` to simplify future development and maintenance.

1.3.2

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

- Requirements

- ``packaging`` library added to dependencies.

- Bug fixes

- Fixed an error loading QpointPhononModes from JSON when there is a
single q-point in the data

- Improvements

- When loading ``.castep_bin`` files, explicitly check the CASTEP
version number and give a useful error message if this is < 17.1.
(These files are missing information about the unit cell origins,
and would previously cause an error with an unhelpful message.)

- Maintenance

- Compatibility fix for spglib 2.4 update: a new sanity-check in
spglib raises TypeError when using empty unit cell and this needs
handling when looking for high-symmetry labels

- Compatibility fix for Numpy 2.0 update: avoid some
broadcasting issues with array shape returned by ``np.unique``

- Update reference to scipy.integrate.simpson (scipy.integrate.simps
is deprecated)

- Filter out spglib deprecation warnings caused by SeeK-path.

Page 1 of 5

© 2025 Safety CLI Cybersecurity Inc. All Rights Reserved.