33#ifndef WOSS_DEFINITIONS_H
34#define WOSS_DEFINITIONS_H
49 static constexpr inline int WOSS_DECIMAL_PRECISION = 17;
51 static constexpr inline int WOSS_STREAM_TAB_SPACE = 25;
60 constexpr double normCart(
double x,
double y,
double z );
62 constexpr std::tuple< double, double, double>
convSpher2Cart(
double rho,
double theta,
double phi );
64 constexpr std::tuple<double, double, double>
convCart2Spher(
double x,
double y,
double z );
66 constexpr std::tuple<double, double>
rotCartXY(
double rot_angle,
double x_init,
double y_init );
68 constexpr std::tuple<double, double>
rotCartXZ(
double rot_angle,
double x_init,
double z_init );
70 constexpr std::tuple<double, double>
rotCartYZ(
double rot_angle,
double y_init,
double z_init );
72 constexpr std::tuple<double, double, double>
crossProd(
double left_x,
double left_y,
double left_z,
double right_x,
double right_y,
double right_z );
74 constexpr double scalarProd(
double left_x,
double left_y,
double left_z,
double right_x,
double right_y,
double right_z);
76 constexpr double linInterp(
double start_var,
double end_var,
double start_val,
double end_val,
double x_var );
82 std::cout <<
"Press Enter to continue";
83 std::getline( std::cin, response);
86 inline constexpr double normCart(
double x,
double y,
double z ) {
87 return ( sqrt(x*x + y*y + z*z) );
90 inline constexpr std::tuple<double, double, double>
convSpher2Cart(
double rho,
double theta,
double phi ) {
91 auto x = rho*std::sin(theta) * std::cos(phi);
92 auto y = rho*std::sin(theta) * std::sin(phi);
93 auto z = rho*std::cos(theta);
97 inline constexpr std::tuple<double, double, double>
convCart2Spher(
double x,
double y,
double z ) {
98 auto rho = std::sqrt( x*x + y*y + z* z);
99 auto theta = std::acos( z / rho );
100 auto phi = std::atan2( y, x );
101 return {rho, theta, phi};
104 inline constexpr std::tuple<double, double>
rotCartXY(
double rot_angle,
double x_init,
double y_init ) {
105 if (rot_angle == 0) {
110 auto x = std::cos(rot_angle)*x_init - std::sin(rot_angle)*y_init;
111 auto y = std::sin(rot_angle)*x_init + std::cos(rot_angle)*y_init;
115 inline constexpr std::tuple<double, double>
rotCartXZ(
double rot_angle,
double x_init,
double z_init ) {
116 if (rot_angle == 0) {
121 auto x = std::cos(rot_angle)*x_init - std::sin(rot_angle)*z_init;
122 auto z = std::sin(rot_angle)*x_init + std::cos(rot_angle)*z_init;
126 inline constexpr std::tuple<double, double>
rotCartYZ(
double rot_angle,
double y_init,
double z_init ) {
127 if (rot_angle == 0) {
132 auto y = std::cos(rot_angle)*y_init - std::sin(rot_angle)*z_init;
133 auto z = std::sin(rot_angle)*y_init + std::cos(rot_angle)*z_init;
137 inline constexpr std::tuple<double, double, double>
crossProd(
double left_x,
double left_y,
double left_z,
double right_x,
double right_y,
double right_z ) {
138 auto res_x = left_y*right_z - left_z*right_y;
139 auto res_y = left_z*right_x - left_x*right_z;
140 auto res_z = left_x*right_y - left_y*right_x;
141 return {res_x, res_y, res_z};
144 inline constexpr double scalarProd(
double left_x,
double left_y,
double left_z,
double right_x,
double right_y,
double right_z ) {
145 return( left_x*right_x + left_y*right_y + left_z*right_z );
148 inline constexpr double linInterp(
double start_var,
double end_var,
double start_val,
double end_val,
double x_var ) {
149 return (end_val-start_val) / (end_var-start_var) * (x_var-start_var) + start_val;
Definition ac-toolbox-arr-asc-reader.h:44
constexpr double linInterp(double start_var, double end_var, double start_val, double end_val, double x_var)
Definition definitions.h:148
constexpr std::tuple< double, double, double > convSpher2Cart(double rho, double theta, double phi)
Definition definitions.h:90
constexpr std::tuple< double, double, double > crossProd(double left_x, double left_y, double left_z, double right_x, double right_y, double right_z)
Definition definitions.h:137
constexpr std::tuple< double, double > rotCartXZ(double rot_angle, double x_init, double z_init)
Definition definitions.h:115
constexpr double scalarProd(double left_x, double left_y, double left_z, double right_x, double right_y, double right_z)
Definition definitions.h:144
constexpr double normCart(double x, double y, double z)
Definition definitions.h:86
constexpr std::tuple< double, double > rotCartYZ(double rot_angle, double y_init, double z_init)
Definition definitions.h:126
double Bathymetry
Definition definitions.h:44
constexpr std::tuple< double, double > rotCartXY(double rot_angle, double x_init, double y_init)
Definition definitions.h:104
void debugWaitForUser()
Definition definitions.h:79
constexpr std::tuple< double, double, double > convCart2Spher(double x, double y, double z)
Definition definitions.h:97