World Ocean Simulation System (WOSS) library
definitions.h
Go to the documentation of this file.
1/* WOSS - World Ocean Simulation System -
2 *
3 * Copyright (C) 2009 2025 Federico Guerra
4 * and regents of the SIGNET lab, University of Padova
5 *
6 * Author: Federico Guerra - WOSS@guerra-tlc.com
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License version 2 as
10 * published by the Free Software Foundation;
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 */
21
22
33#ifndef WOSS_DEFINITIONS_H
34#define WOSS_DEFINITIONS_H
35
36
37#include <iostream>
38#include <cmath>
39#include <tuple>
40
41
42namespace woss {
43
44 using Bathymetry = double;
45
49 static constexpr inline int WOSS_DECIMAL_PRECISION = 17;
50
51 static constexpr inline int WOSS_STREAM_TAB_SPACE = 25;
52
53
54
58 void debugWaitForUser();
59
60 constexpr double normCart( double x, double y, double z );
61
62 constexpr std::tuple< double, double, double> convSpher2Cart( double rho, double theta, double phi );
63
64 constexpr std::tuple<double, double, double> convCart2Spher( double x, double y, double z );
65
66 constexpr std::tuple<double, double> rotCartXY( double rot_angle, double x_init, double y_init );
67
68 constexpr std::tuple<double, double> rotCartXZ( double rot_angle, double x_init, double z_init );
69
70 constexpr std::tuple<double, double> rotCartYZ( double rot_angle, double y_init, double z_init );
71
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 );
73
74 constexpr double scalarProd( double left_x, double left_y, double left_z, double right_x, double right_y, double right_z);
75
76 constexpr double linInterp( double start_var, double end_var, double start_val, double end_val, double x_var );
77
79 inline void debugWaitForUser()
80 {
81 std::string response;
82 std::cout << "Press Enter to continue";
83 std::getline( std::cin, response);
84 }
85
86 inline constexpr double normCart( double x, double y, double z ) {
87 return ( sqrt(x*x + y*y + z*z) );
88 }
89
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);
94 return {x, y, z};
95 }
96
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};
102 }
103
104 inline constexpr std::tuple<double, double> rotCartXY( double rot_angle, double x_init, double y_init ) {
105 if (rot_angle == 0) {
106 auto x = x_init;
107 auto y = y_init;
108 return {x, y};
109 }
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;
112 return {x, y};
113 }
114
115 inline constexpr std::tuple<double, double> rotCartXZ( double rot_angle, double x_init, double z_init ) {
116 if (rot_angle == 0) {
117 auto x = x_init;
118 auto z = z_init;
119 return {x, z};
120 }
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;
123 return {x, z};
124 }
125
126 inline constexpr std::tuple<double, double> rotCartYZ( double rot_angle, double y_init, double z_init ) {
127 if (rot_angle == 0) {
128 auto y = y_init;
129 auto z = z_init;
130 return {y, z};
131 }
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;
134 return {y, z};
135 }
136
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};
142 }
143
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 );
146 }
147
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;
150 }
151
152}
153
154#endif /* WOSS_DEFINITIONS_H */
155
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