Skip to main content

A library for three-dimensional, reference-frame conversions

Project description

PyPI Downloads DOI

Rotation of 3-dimensional Frames

import r3f

or for specific functions (like rpy_to_dcm)

from r3f import rpy_to_dcm

Functions

This library includes four sets of functions: general array checks, attitude-representation conversions, reference-frame conversions, and rotation matrix (direction cosine matrix) utilities.

All twenty possible conversions among the following five attitude representations are provided: rotation vector, rotation axis and angle, roll and pitch and yaw (RPY) Euler angles, direction cosine matrix (DCM), and quaternion (quat). However, some of the conversions are built using other conversions. In the following table, the low-level conversions are marked with an x and the conversions build using the other conversions are marked with an o:

vector ax, ang RPY DCM quat
vector - x o o o
ax, ang x - o x x
RPY o x - x x
DCM o x x - x
quat o x x x -

The roll, pitch, and yaw angles are applied in a zyx sequence of passive rotations. The quaternions follow a Hamilton convention. Here is an example:

roll = 20*np.pi/180
pitch = 45*np.pi/180
yaw = 10*np.pi/180
C = r3f.rpy_to_dcm([roll, pitch, yaw])
>> C = [[ 0.69636424  0.1227878  -0.70710678]
    [ 0.07499469  0.96741248  0.24184476]
    [ 0.71375951 -0.2214413   0.66446302]]

In addition to the conversion from the z, y, x sequence of Euler angles to a DCM, the function dcm is also provided for creating a DCM from a generic set of Euler angles in any desired sequence of axes. The conversion back from the rotation matrix to any of 12 possible Euler angle rotations is provided by the euler function. Although this dcm function could be used, two additional functions are provided for generating rotation matrices: dcm_inertial_to_ecef and dcm_ecef_to_navigation. By default, all angles are treated as being in radians, but if the degs parameter is set to True, then they are treated as being in degrees.

This library includes all twelve possible conversions among the following four frames: ECEF (Earth-centered, Earth-fixed), geodetic (latitude, longitude, and height above ellipsoid), local-level tangent, and local-level curvilinear. By default, all local-level coordinates are interpreted as having a North, East, Down (NED) orientation, but if the ned parameter is set to False, the coordinates are interpreted as having an East, North, Up (ENU) orientation. Here is an example:

lat = 45*np.pi/180
lon = 0.0
hae = 1000.0
[xe, ye, ze] = r3f.geodetic_to_ecef([lat, lon, hae])
>> xe = 4518297.985630118
>> ye = 0.0
>> ze = 4488055.515647106

The rotation matrix utility functions are an orthonormalize_dcm function, a rodrigues_rotation function, and an inverse_rodrigues_rotation function. The orthonormalize_dcm function will work to make a rotation matrix normalized and orthogonal, a proper rotation matrix. The two Rodrigues's rotation functions are meant for converting a vector to the matrix exponential of the skew-symmetric matrix of that vector and back again.

Passive Rotations

Unless specifically otherwise stated, all rotations are interpreted as passive. This means they represent rotations of reference frames, not of vectors.

Vectorization

When possible, the functions are vectorized in order to handle processing batches of values. A set of scalars is a 1D array. A set of vectors is a 2D array, with each vector in a column. So, a (3, 7) array is a set of seven vectors, each with 3 elements. If the axis parameter is set to 0, the transpose is true. A set of matrices is a 3D array with each matrix in a stack. The first index is the stack number. So, a (5, 3, 3) array is a stack of five 3x3 matrices. Roll, pitch, and yaw are not treated as a vector but as three separate quantities. The same is true for latitude, longitude, and height above ellipsoid. A quaternion is passed around as an array.

Robustness

In general, the functions in this library check that the inputs are of the correct type and shape. They do not generally handle converting inputs which do not conform to the ideal type and shape. Generally, the allowed types are int, float, list, and np.ndarray.

Constants

The defined constants are

Name Value Definition
A_E 6378137.0 Earth's semi-major axis (m)
F_E 298.257223563 Earth's flattening constant
B_E 6356752.314245 Earth's semi-minor axis (m)
E2 6.694379990141317e-3 Earth's eccentricity squared (ND)
W_EI 7.2921151467e-5 sidereal Earth rate (rad/s)

Functions

The defined functions for attitude-representation conversion are

  • axis_angle_to_vector
  • vector_to_axis_angle
  • rpy_to_vector
  • vector_to_rpy
  • dcm_to_vector
  • vector_to_dcm
  • quat_to_vector
  • vector_to_quat
  • rpy_to_axis_angle
  • axis_angle_to_rpy
  • dcm_to_axis_angle
  • axis_angle_to_dcm
  • quat_to_axis_angle
  • axis_angle_to_quat
  • dcm_to_rpy
  • rpy_to_dcm
  • dcm
  • euler
  • rotate
  • quat_to_rpy
  • rpy_to_quat
  • quat_to_dcm
  • dcm_to_quat
  • dcm_inertial_to_ecef
  • dcm_ecef_to_navigation

The functions for reference-frame conversions are

  • geodetic_to_ecef
  • ecef_to_geodetic
  • tangent_to_ecef
  • ecef_to_tangent
  • curvilinear_to_ecef
  • ecef_to_curvilinear
  • tangent_to_geodetic
  • geodetic_to_tangent
  • curvilinear_to_geodetic
  • geodetic_to_curvilinear
  • curvilinear_to_tangent
  • tangent_to_curvilinear

A few additional rotation matrix utility functions are

  • is_ortho
  • orthonormalize_dcm
  • rodrigues_rotation
  • inverse_rodrigues_rotation

Installation

For instructions on using pip, visit https://pip.pypa.io/en/stable/getting-started/.

To install from pypi.org,

pip install r3f

Or, from the directory of the cloned repo, run

pip install .

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

r3f-2.1.7.tar.gz (33.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

r3f-2.1.7-py3-none-any.whl (31.0 kB view details)

Uploaded Python 3

File details

Details for the file r3f-2.1.7.tar.gz.

File metadata

  • Download URL: r3f-2.1.7.tar.gz
  • Upload date:
  • Size: 33.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.9

File hashes

Hashes for r3f-2.1.7.tar.gz
Algorithm Hash digest
SHA256 4f05eddeee37b76b6842404e48c82191cf23c7d8228d1f2ce1456f9d372b641f
MD5 36d02b15adb85f11ade76477556440b3
BLAKE2b-256 78e864baacefcb0a12c3e1b03ebe9e7acc778e53c28ba6cb7a87ce1b1ae98db1

See more details on using hashes here.

File details

Details for the file r3f-2.1.7-py3-none-any.whl.

File metadata

  • Download URL: r3f-2.1.7-py3-none-any.whl
  • Upload date:
  • Size: 31.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.9

File hashes

Hashes for r3f-2.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 749e401bd1960b240d1d7ebf0829464b7b6681599a20e1bb5942be5dedd5aea8
MD5 a18e07d6b283cda70e5b18a57ca541c5
BLAKE2b-256 2bff5c9dfd3c47be89c0b1cac2305925f74f72fca492b2a66962572be14dec27

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page