Advertisement
575

1 - file_structs

575
Apr 22nd, 2023
629
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 3.55 KB | None | 0 0
  1. #pragma once
  2. #ifndef FSTRUCTS_H
  3. #define FSTRUCTS_H
  4.  
  5. #include <cmath>
  6.  
  7.  
  8. struct coordinates {
  9.     double x;
  10.     double y;
  11.     double z;
  12.  
  13.     coordinates(double x = 0.0, double y = 0.0, double z = 0.0)
  14.         : x(x), y(y), z(z)
  15.     {}
  16.  
  17.     coordinates& operator= (const auto& V) {
  18.         x = V.x;
  19.         y = V.y;
  20.         z = V.z;
  21.  
  22.         return *this;
  23.     }
  24.  
  25.     coordinates& operator+= (const auto& V) {
  26.         x += V.x;
  27.         y += V.y;
  28.         z += V.z;
  29.  
  30.         return *this;
  31.     }
  32.  
  33.     coordinates& operator-= (const auto& V) {
  34.         x -= V.x;
  35.         y -= V.y;
  36.         z -= V.z;
  37.  
  38.         return *this;
  39.     }
  40. };
  41.  
  42. coordinates operator+ (coordinates T1, coordinates T2) {
  43.     T1.x += T2.x;
  44.     T1.y += T2.y;
  45.     T1.z += T2.z;
  46.    
  47.     return T1;
  48. }
  49.  
  50. coordinates operator* (coordinates T, double n) {
  51.     T.x *= n;
  52.     T.y *= n;
  53.     T.z *= n;
  54.  
  55.     return T;
  56. }
  57.  
  58.  
  59. struct velocity {
  60.     double x;
  61.     double y;
  62.     double z;
  63.  
  64.     velocity(double x = 0.0, double y = 0.0, double z = 0.0)
  65.         : x(x), y(y), z(z)
  66.     {}
  67.  
  68.     velocity& operator= (const auto& V) {
  69.         x = V.x;
  70.         y = V.y;
  71.         z = V.z;
  72.  
  73.         return *this;
  74.     }
  75.  
  76.     velocity& operator+= (const auto& V) {
  77.         x += V.x;
  78.         y += V.y;
  79.         z += V.z;
  80.  
  81.         return *this;
  82.     }
  83.  
  84.     velocity& operator-= (const auto& V) {
  85.         x -= V.x;
  86.         y -= V.y;
  87.         z -= V.z;
  88.  
  89.         return *this;
  90.     }
  91. };
  92.  
  93. velocity operator+ (velocity T1, velocity T2) {
  94.     T1.x += T2.x;
  95.     T1.y += T2.y;
  96.     T1.z += T2.z;
  97.  
  98.     return T1;
  99. }
  100.  
  101. velocity operator * (velocity T, double n) {
  102.     T.x *= n;
  103.     T.y *= n;
  104.     T.z *= n;
  105.  
  106.     return T;
  107. }
  108.  
  109. struct surface {
  110.     double A;
  111.     double B;
  112.     double C;
  113.     double D;
  114.  
  115.     surface(double A = 0.0, double B = 0.0, double C = 0.0, double D = 0.0)
  116.         : A(A), B(B), C(C), D(D)
  117.     {}
  118. };
  119.  
  120. struct line {
  121.     double A;
  122.     double B;
  123.     double C;
  124.  
  125.     line(double A = 0.0, double B = 0.0, double C = 0.0)
  126.         : A(A), B(B), C(C)
  127.     {}
  128. };
  129.  
  130. struct missile_n_sys_coordinates {
  131.     double x;
  132.     double y;
  133.     double z;
  134. };
  135.  
  136. struct missile_v_proj_n_sys {
  137.     double x;
  138.     double y;
  139.     double z;
  140. };
  141.  
  142. struct obj_n_sys_coordinates {
  143.     double x;
  144.     double y;
  145.     double z;
  146. };
  147.  
  148. struct missing_mp_time_proj_n_sys {
  149.     double x;
  150.     double y;
  151.     double z;
  152. };
  153.  
  154. struct missing_nsm_time_proj_n_sys {
  155.     double x;
  156.     double y;
  157.     double z;
  158. };
  159.  
  160. struct missing_dov_time_proj_n_sys {
  161.     double x;
  162.     double y;
  163.     double z;
  164. };
  165.  
  166. struct bank_angle_mistakes {
  167.     double inf;
  168.     double exec;
  169.     double sum;
  170. };
  171.  
  172. struct trans_matrix {
  173.     double c11;
  174.     double c12;
  175.     double c13;
  176.  
  177.     double c21;
  178.     double c22;
  179.     double c23;
  180.  
  181.     double c31;
  182.     double c32;
  183.     double c33;
  184. };
  185.  
  186. struct raw_data {
  187.     //1
  188.     int n;
  189.     bool pr_c;
  190.     double epr;
  191.     int pr_r;
  192.     bool kim;
  193.     bool dov;
  194.     bool rbv;
  195.  
  196.     //2
  197.     double time_to_mp;
  198.     double rel_v;
  199.     double beta_ast;
  200.     double time_start_homing;
  201.  
  202.     //3
  203.     missile_n_sys_coordinates mis_coord_n;
  204.     missile_v_proj_n_sys mis_v_proj_n;
  205.  
  206.     //4
  207.     double yaw_angle;
  208.     double pitch_angle;
  209.     double bank_angle;
  210.     double angle_of_attack;
  211.     double flow_angle;
  212.  
  213.     //5
  214.     double v_obj;
  215.     double path_obj;
  216.     double pitch_obj;
  217.     obj_n_sys_coordinates coord_n_obj;
  218.  
  219.     //6
  220.     missing_mp_time_proj_n_sys proj_mp_miss;
  221.     double rel_v_n;
  222.     double tau_kin;
  223.  
  224.     //7
  225.     double nc_y;
  226.     double nc_z;
  227.     double t_dov;
  228.     double t_bv;
  229.     double t_sbv;
  230.  
  231.     //8
  232.     missing_nsm_time_proj_n_sys proj_nsm_miss;
  233.     double delta_V01;
  234.     double delta_V02;
  235.     double beta_y;
  236.  
  237.     //9
  238.     missing_dov_time_proj_n_sys proj_dov_miss;
  239.  
  240.     //10
  241.     double bank;
  242.     double pitch;
  243.     double ant_course;
  244.     bank_angle_mistakes delta_gamma;
  245.  
  246.     //11
  247.     trans_matrix from_n_to_apa;
  248.  
  249.     //additional
  250.     double h;
  251.     int i;
  252. };
  253.  
  254. double GetVelocityValue(velocity T) {
  255.     return std::sqrt(std::pow(T.x, 2) + std::pow(T.y, 2) + std::pow(T.z, 2));
  256. }
  257.  
  258. #endif
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement