Skip to content

Releases: pyxem/orix

orix 0.10.1

03 Oct 11:34
14bc03b
Compare
Choose a tag to compare

orix 0.10.1 is a patch release of orix, an open-source Python library for handling orientations, rotations and crystal symmetry.

This release includes some deprecations, but most importantly it fixes a bug when indexing or slicing into an already indexed/sliced CrystalMap.

See below, the changelog or the GitHub changelog for all updates from the previous release.

Deprecated

  • Parameter z when creating a CrystalMap and the z and dz attributes of the class are deprecated and will be removed in 0.11.0. Support for 3D crystal maps is minimal and brittle, and it was therefore decided to remove it altogether.
  • Passing shape or step_sizes with three values to create_coordinate_arrays() is depreacted and will raise an error in 0.11.0. See the previous point for the reason.
  • Parameter depth in CrystalMapPlot.plot_map() is depreacted and will be removed in 0.11.0. See the top point for the reason.

Fixed

  • StereographicPlot.scatter() now accepts both c/color and s/sizes to set the color and sizes of scatter points, in line with matplotlib.axes.Axes.scatter().
  • Indexing/slicing into an already indexed/sliced CrystalMap now correctly returns the index/slice according to CrystalMap.shape and not the original shape of the un-sliced map.

orix 0.10.0

22 Sep 11:17
f33153f
Compare
Choose a tag to compare

NOTE: This release has been yanked and should not be used. A relevant patch fix (and little else) has been added in 0.10.1.

orix 0.10.0 is a minor release of orix, an open-source Python library for handling orientations, rotations and crystal symmetry

See below, the changelog or the GitHub changelog for all updates from the previous release.

Added

  • Support for type hints has been introduced and a section on this topic has been added to the contributing guide.
  • Vector3d.pole_density_function() has been implemented which allows for calculation of the Pole Density Function (PDF) and quantification of poles in the stereographic projection.
  • Seven methods for sampling unit vectors from regular grids on S2 via orix.sampling.sample_S2().
  • Calculation of the Inverse Pole Density Function (IPDF), ie. pole density in the crystal point group fundamental sector, through InversePoleFigurePlot.pole_density_function().
  • The orix.measure module has been introduced. The measure module is related to quantification of orientation and vector data.
  • Plotting the IPF color key on a created InversePoleFigurePlot is now possible with plot_ipf_color_key().
  • Examples gallery to documentation.

Changed

  • Moved part of documentation showing plotting of Wulff net and symmetry markers from the tutorials to examples.
  • Renamed user guide notebooks to tutorials in documentation.
  • Reference frame labels of stereographic projection of Symmetry.plot() from (a, b) to (e1, e2), signifying the standard Cartesian reference frame attached to a crystal.
  • Tighten distribution of random orientation clusters in tutorial showing clustering across fundamental region boundaries, to avoid clustering sometimes giving two clusters instead of three.

Removed

  • Support for Python 3.6 has been removed. The minimum supported version in orix is now Python 3.7.
  • Object3d.check(), Quaternion.check_quaternion() and Vector3d.check_vector(), as these methods were not used internally.
  • Deprecated method distance() of Misorientation and Orientation classes, use get_distance_matrix() instead.

Fixed

  • Plotting of unit cells works with Matplotlib v3.6, at the expense of a warning raised with earlier versions.

orix 0.9.0.post0

18 May 12:47
14639a1
Compare
Choose a tag to compare

orix 0.9.0.post0 is a post-release of orix, an open-source Python library for handling orientations, rotations and crystal symmetry.

This release is necessary so that the 0.9.0 release is successfully uploaded to Zenodo.

See v0.8.2...v0.9.0.post0 for a complete list of changes.

orix 0.9.0

16 May 13:43
fb269b0
Compare
Choose a tag to compare

orix 0.9.0 is a minor release of orix, an open-source Python library for handling orientations, rotations and crystal symmetry.

This version contains many small and some larger changes, including enhancements to existing classes and bug fixes. See the changelog or v0.8.2...v0.9.0 for a complete list of changes.

Notable changes:

  • orix.scalar.Scalar has been removed, so the data held by Scalar, like class properties Rotation.angle, Vector3d.azimuth and so on, are returned directly as a numpy.ndarray.
  • Creating rotations from Euler angles interprets the angles in the Bunge convention by default, i.e. rotations are transformations from the sample to the crystal.
  • Reducing memory usage when computing the misorientation distance matrix, rotation outer products and quaternion-vector outer products have been added via lazy computation with dask.
  • The alignment of crystal axes in the package is documented in the user guide.

orix 0.9.0rc2

11 May 13:27
Compare
Choose a tag to compare
orix 0.9.0rc2 Pre-release
Pre-release

orix 0.9.0 is a minor release of orix, an open-source Python library for handling orientations, rotations and crystal symmetry.

This version contains many small and some larger changes, including enhancements to existing classes and bug fixes. See the changelog or v0.8.2...v0.9.0rc2 for a complete list of changes.

Notable changes:

  • orix.scalar.Scalar has been removed, so the data held by Scalar, like class properties Rotation.angle, Vector3d.azimuth and so on, are returned directly as a numpy.ndarray.
  • Creating rotations from Euler angles interprets the angles in the Bunge convention by default, i.e. rotations are transformations from the sample to the crystal.
  • Reducing memory usage when computing the misorientation distance matrix, rotation outer products and quaternion-vector outer products have been added via lazy computation with dask.
  • The alignment of crystal axes in the package is documented in the user guide.

orix 0.9.0rc1

10 May 09:13
a528ceb
Compare
Choose a tag to compare
orix 0.9.0rc1 Pre-release
Pre-release

orix 0.9.0 is a minor release of orix, an open-source Python library for handling orientations, rotations and crystal symmetry.

This version contains many small and some larger changes, including enhancements to existing classes and bug fixes. See the changelog or v0.8.2...v0.9.0rc1 for a complete list of changes.

Notable changes:

  • orix.scalar.Scalar has been removed, so the data held by Scalar, like class properties Rotation.angle, Vector3d.azimuth and so on, are returned directly as a numpy.ndarray.
  • Creating rotations from Euler angles interprets the angles in the Bunge convention by default, i.e. rotations are transformations from the sample to the crystal.
  • Reducing memory usage when computing the misorientation distance matrix, rotation outer products and quaternion-vector outer products have been added via lazy computation with dask.
  • The alignment of crystal axes in the package is documented in the user guide.

orix 0.8.2

21 Feb 09:22
33e06a6
Compare
Choose a tag to compare

orix 0.8.2 is a patch release of orix, an open-source Python library for handling orientations, rotations and crystal symmetry.

Changed

  • orix.quaternion.Quaternion now relies on numpy-quaternion for quaternion conjugation, quaternion-quaternion and quaternion-vector multiplication, and quaternion-quaternion and quaternion-vector outer products.
  • Rounding in functions, e.g. Object3d.unique() and Rotation.unique(), is now set consistently at 12 dp.

Fixed

  • Miller.in_fundamental_sector() doesn't raise errors.
  • Miller.unique() now correctly returns unique vectors due to implemented rounding.

See the changelog or v0.8.1...v0.8.2 for a complete list of changes.

orix 0.8.1

14 Feb 14:43
49ef435
Compare
Choose a tag to compare

orix 0.8.1 is a patch release of orix, an open-source Python library for handling orientations, rotations and crystal symmetry.

The patch fixes a few smaller bugs and corrects the following:

  • Disorientation angles and dot products returned from Orientation methods angle_with() and dot() and dot_outer() which now calculates the misorientation as other * ~self, instead of the other way around. Disorientation angles (o2 - o1).angle and o1.angle_with(o2) are now the same.
  • The inverse indices returned from Rotation.unique(), which now recreate the original Rotation instance.

See the changelog or v0.8.0...v0.8.1 for a complete list of changes.

orix 0.8.0

21 Dec 13:49
9889817
Compare
Choose a tag to compare

orix 0.8.0 is a minor release of orix, an open-source python library for handling orientations, rotations and crystal symmetry.
0.8.0 provides a number of exciting new features as well as internal improvements. For a comprehensive list of changes please refer to the CHANGELOG.

Highlights

  • Users can now plot orientations within an inverse pole figure (#235).
  • Inverse pole figure colouring of spatial maps are also available (#235).
  • Spatial maps can be coloured based on their Euler angles (#201 ).
  • Unit cell orientation can now be plotted with the plot_unit_cell method (#234).

orix 0.7.0

07 Sep 17:57
cec8a99
Compare
Choose a tag to compare

orix 0.7.0 is a minor release of orix, an open-source python library for handling orientations, rotations and crystal symmetry.
0.7.0 provides improvements to the speed, ease of use and flexibility of the package.
For a comprehensive list of changes please refer to the CHANGELOG.

Highlights

  • Memory-efficient calculation of a misorientation angle (geodesic distance) matrix between orientations using Dask.
  • New convenience method Misorientation.scatter() to plot orientations in either axis-angle or Rodrigues fundamental zone.
  • Further streamlining of the documentation.
  • Reading of a crystal map from orientation data in Bruker's HDF5 file format.
  • Uniform sampling of orientation space using cubochoric sampling.