utilities.h

Contents

utilities.h#

Header file for miscellaneous utility functions.

Author

Rahil Makadia makadia2@illinois.edu

LICENSE#

Copyright (C) 2022-2025 Rahil Makadia

This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program; if not, see https://www.gnu.org/licenses.

Defines

real#

Real type to be used for floating point calculations. Choose between double and long double.

PI#

Value of PI.

RAD2DEG#

Conversion factor from radians to degrees.

DEG2RAD#

Conversion factor from degrees to radians.

EARTH_OBLIQUITY#

Value of Earth’s obliquity in radians.

EARTH_RAD_WGS84#

Value of Earth’s WGS84 radius in AU.

EARTH_FLAT_WGS84#

Value of Earth’s WGS84 flattening.

Functions

void wrap_to_2pi(real &angle)#

Wrap an angle to the range [0, 2*pi).

Parameters:

angle[inout] Angle to be wrapped.

void rad_to_deg(const real &rad, real &deg)#

Convert an angle from radians to degrees.

Parameters:
  • rad[in] Angle in radians.

  • deg[out] Angle in degrees.

real rad_to_deg(const real rad)#

Convert an angle from radians to degrees.

Parameters:

rad[in] Angle in radians.

Returns:

real Angle in degrees.

void deg_to_rad(const real &deg, real &rad)#

Convert an angle from degrees to radians.

Parameters:
  • deg[in] Angle in degrees.

  • rad[out] Angle in radians.

real deg_to_rad(const real deg)#

Convert an angle from degrees to radians.

Parameters:

deg[in] Angle in degrees.

Returns:

real Angle in radians.

void sort_vector(std::vector<real> &v, const bool &ascending, std::vector<size_t> &sortedIdx)#

Sort a vector in ascending or descending order.

Parameters:
  • v[inout] Vector to be sorted.

  • ascending[in] True for ascending order, false for descending order.

  • sortedIdx[out] Vector of sorted indices from the original vector.

void sort_vector_by_idx(std::vector<std::vector<real>> &v, const std::vector<size_t> &sortedIdx)#

Sort a vector of vectors based on the indices of another vector.

Parameters:
  • v[inout] Vector of vectors to be sorted.

  • sortedIdx[in] Vector of sorted indices.

void vdot(const std::vector<real> &v1, const std::vector<real> &v2, real &dot)#

Dot product of two vectors.

Parameters:
  • v1[in] Vector 1.

  • v2[in] Vector 2.

  • dot[out] Dot product of v1 and v2.

void vdot(const real *v1, const real *v2, const size_t &dim, real &dot)#

Dot product of two vectors.

Parameters:
  • v1[in] Vector 1.

  • v2[in] Vector 2.

  • dim[in] Dimension of the vectors.

  • dot[out] Dot product of v1 and v2.

void vnorm(const std::vector<real> &v, real &norm)#

Norm of a vector.

Parameters:
  • v[in] Vector.

  • norm[out] Norm of v.

void vnorm(const real *v, const size_t &dim, real &norm)#

Norm of a vector.

Parameters:
  • v[in] Vector.

  • dim[in] Dimension of the vector.

  • norm[out] Norm of v.

void vunit(const std::vector<real> &v, std::vector<real> &unit)#

Unit vector of a vector.

Parameters:
  • v[in] Vector.

  • vunit[out] Unit vector of v.

void vunit(const real *v, const size_t &dim, real *unit)#

Unit vector of a vector.

Parameters:
  • v[in] Vector.

  • dim[in] Dimension of the vector.

  • unit[out] Unit vector of v.

void vcross(const std::vector<real> &v1, const std::vector<real> &v2, std::vector<real> &cross)#

Cross product of two vectors.

Parameters:
  • v1[in] Vector 1.

  • v2[in] Vector 2.

  • v3[out] Cross product of v1 and v2.

void vcross(const real *v1, const real *v2, real *cross)#

Cross product of two vectors.

Parameters:
  • v1[in] Vector 1.

  • v2[in] Vector 2.

  • v3[out] Cross product of v1 and v2.

void vadd(const std::vector<real> &v1, const std::vector<real> &v2, std::vector<real> &sum)#

Add two vectors.

Parameters:
  • v1[in] Vector 1.

  • v2[in] Vector 2.

  • v3[out] Sum of v1 and v2.

void vsub(const std::vector<real> &v1, const std::vector<real> &v2, std::vector<real> &diff)#

Subtract two vectors.

Parameters:
  • v1[in] Vector 1.

  • v2[in] Vector 2.

  • v3[out] Difference of v1 and v2.

void vcmul(const std::vector<real> &v, const real &c, std::vector<real> &vc)#

Multiply a vector by a constant.

Parameters:
  • v[in] Vector.

  • c[in] Constant.

  • vc[out] Product of v and c.

void vvmul(const std::vector<real> &v1, const std::vector<real> &v2, std::vector<real> &v3)#

Multiply two vectors element-wise.

Parameters:
  • v1[in] Vector 1.

  • v2[in] Vector 2.

  • v3[out] Element-wise product of v1 and v2.

void vabs_max(const std::vector<real> &v, real &max)#

Find the maximum absolute value in a vector.

Parameters:
  • v[in] Vector.

  • max[out] Maximum absolute value in v.

void vabs_max(const real *v, const size_t &dim, real &max)#

Find the maximum absolute value in a vector.

Parameters:
  • v[in] Vector.

  • dim[in] Dimension of the vector.

  • max[out] Maximum absolute value in v.

void mat_vec_mul(const std::vector<std::vector<real>> &A, const std::vector<real> &v, std::vector<real> &Av)#

Multiply a matrix by a vector.

Parameters:
  • A[in] Matrix.

  • v[in] Vector.

  • Av[out] Product of A and v.

void vec_mat_mul(const std::vector<real> &v, real **A, const size_t &dim, std::vector<real> &vA)#

Multiply a vector by a matrix.

Parameters:
  • v[in] Vector.

  • A[in] Matrix.

  • dim[in] Dimension of the vector and matrix.

  • vA[out] Product of v and A.

void mat_mat_mul(const std::vector<std::vector<real>> &A, const std::vector<std::vector<real>> &B, std::vector<std::vector<real>> &AB)#

Multiply two matrices.

Parameters:
  • A[in] Matrix 1.

  • B[in] Matrix 2.

  • AB[out] Product of A and B.

void mat3_inv(const std::vector<std::vector<real>> &A, std::vector<std::vector<real>> &Ainv)#

Invert a 3x3 matrix.

Parameters:
  • A[in] Matrix to be inverted.

  • Ainv[out] Inverted matrix.

void mat3_mat3_mul(const real *A, const real *B, real *prod)#

Multiply two 3x3 matrices.

Parameters:
  • A[in] Matrix 1.

  • B[in] Matrix 2.

  • prod[out] Product of A and B.

void mat3_mat3_add(const real *A, const real *B, real *sum)#

Add two 3x3 matrices.

Parameters:
  • A[in] Matrix 1.

  • B[in] Matrix 2.

  • sum[out] Sum of A and B.

void rot_mat_x(const real &theta, std::vector<std::vector<real>> &R)#

Rotation matrix about the x-axis.

Parameters:
  • theta[in] Angle of rotation in radians.

  • R[out] Rotation matrix.

void rot_mat_y(const real &theta, std::vector<std::vector<real>> &R)#

Rotation matrix about the y-axis.

Parameters:
  • theta[in] Angle of rotation in radians.

  • R[out] Rotation matrix.

void rot_mat_z(const real &theta, std::vector<std::vector<real>> &R)#

Rotation matrix about the z-axis.

Parameters:
  • theta[in] Angle of rotation in radians.

  • R[out] Rotation matrix.

void LU_decompose(std::vector<std::vector<real>> &A, const size_t &N, const real &tol, size_t *P)#

Decompose a matrix into its LU form.

Parameters:
  • A[inout] Matrix to be decomposed.

  • N[in] Size of the matrix.

  • tol[in] Tolerance for degeneracy.

  • P[out] Permutation matrix.

void LU_inverse(std::vector<std::vector<real>> &A, const size_t *P, const size_t &N, std::vector<std::vector<real>> &AInv)#

Invert a matrix using its LU decomposition.

Parameters:
  • A[in] Matrix to be inverted.

  • P[in] Permutation matrix.

  • N[in] Size of the matrix.

  • AInv[out] Inverted matrix.

void mat_inv(std::vector<std::vector<real>> mat, std::vector<std::vector<real>> &matInv, const real &tol = 1.0e-16L)#

Invert a matrix.

Parameters:
  • mat[in] Matrix to be inverted.

  • matInv[out] Inverted matrix.

  • tol[in] Tolerance for degeneracy.