From ed85b3edef85310f75973b85f1fde84156ae7749 Mon Sep 17 00:00:00 2001 From: MateusStano Date: Wed, 13 Nov 2024 14:07:17 +0100 Subject: [PATCH 1/4] BUG: Corrected calculation of beta angle in aerodynamic computations Co-authored-by: kevin-alcaniz --- rocketpy/rocket/aero_surface/generic_surface.py | 8 ++++---- rocketpy/simulation/flight.py | 2 +- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/rocketpy/rocket/aero_surface/generic_surface.py b/rocketpy/rocket/aero_surface/generic_surface.py index 1a0e1015d..372f9fcc1 100644 --- a/rocketpy/rocket/aero_surface/generic_surface.py +++ b/rocketpy/rocket/aero_surface/generic_surface.py @@ -273,7 +273,7 @@ def compute_forces_and_moments( # Angles of attack and sideslip alpha = np.arctan2(stream_velocity[1], stream_velocity[2]) - beta = np.arctan2(-stream_velocity[0], stream_velocity[2]) + beta = np.arctan2(stream_velocity[0], stream_velocity[2]) # Compute aerodynamic forces and moments lift, side, drag, pitch, yaw, roll = self._compute_from_coefficients( @@ -283,9 +283,9 @@ def compute_forces_and_moments( beta, stream_mach, reynolds, - omega[0], - omega[1], - omega[2], + omega[0], # q + omega[1], # r + omega[2], # p ) # Conversion from aerodynamic frame to body frame diff --git a/rocketpy/simulation/flight.py b/rocketpy/simulation/flight.py index 706bcf534..a43ec15de 100644 --- a/rocketpy/simulation/flight.py +++ b/rocketpy/simulation/flight.py @@ -2699,7 +2699,7 @@ def angle_of_sideslip(self): # Stream velocity in standard aerodynamic frame stream_velocity = -self.stream_velocity_body_frame beta = np.arctan2( - -stream_velocity[:, 0], + stream_velocity[:, 0], stream_velocity[:, 2], ) # x-z plane return np.column_stack([self.time, np.rad2deg(beta)]) From 9bf6db1f5f783175d356b0b7e0fdc534da4b5152 Mon Sep 17 00:00:00 2001 From: MateusStano Date: Wed, 13 Nov 2024 14:08:14 +0100 Subject: [PATCH 2/4] BUG: fix damping coefficients sign in linear model Co-authored-by: kevin-alcaniz --- .../aero_surface/linear_generic_surface.py | 30 +++++++++---------- 1 file changed, 15 insertions(+), 15 deletions(-) diff --git a/rocketpy/rocket/aero_surface/linear_generic_surface.py b/rocketpy/rocket/aero_surface/linear_generic_surface.py index fba2b1db8..65ad72cb1 100644 --- a/rocketpy/rocket/aero_surface/linear_generic_surface.py +++ b/rocketpy/rocket/aero_surface/linear_generic_surface.py @@ -62,22 +62,22 @@ def __init__( Coefficient of lift derivative with respect to yaw rate. Default is 0.\n cQ_0: callable, str, optional - Coefficient of pitch moment at zero angle of attack. + Coefficient of side force at zero angle of attack. Default is 0.\n cQ_alpha: callable, str, optional - Coefficient of pitch moment derivative with respect to angle of + Coefficient of side force derivative with respect to angle of attack. Default is 0.\n cQ_beta: callable, str, optional - Coefficient of pitch moment derivative with respect to sideslip + Coefficient of side force derivative with respect to sideslip angle. Default is 0.\n cQ_p: callable, str, optional - Coefficient of pitch moment derivative with respect to roll rate. + Coefficient of side force derivative with respect to roll rate. Default is 0.\n cQ_q: callable, str, optional - Coefficient of pitch moment derivative with respect to pitch rate. + Coefficient of side force derivative with respect to pitch rate. Default is 0.\n cQ_r: callable, str, optional - Coefficient of pitch moment derivative with respect to yaw rate. + Coefficient of side force derivative with respect to yaw rate. Default is 0.\n cD_0: callable, str, optional Coefficient of drag at zero angle of attack. Default is 0.\n @@ -258,11 +258,11 @@ def total_coefficient( ): return ( c_p(alpha, beta, mach, reynolds, pitch_rate, yaw_rate, roll_rate) - * pitch_rate + * roll_rate + c_q(alpha, beta, mach, reynolds, pitch_rate, yaw_rate, roll_rate) - * yaw_rate + * pitch_rate + c_r(alpha, beta, mach, reynolds, pitch_rate, yaw_rate, roll_rate) - * roll_rate + * yaw_rate ) return Function( @@ -372,38 +372,38 @@ def _compute_from_coefficients( # Compute aerodynamic forces lift = dyn_pressure_area * self.cLf( alpha, beta, mach, reynolds, pitch_rate, yaw_rate, roll_rate - ) - dyn_pressure_area_damping * self.cLd( + ) + dyn_pressure_area_damping * self.cLd( alpha, beta, mach, reynolds, pitch_rate, yaw_rate, roll_rate ) side = dyn_pressure_area * self.cQf( alpha, beta, mach, reynolds, pitch_rate, yaw_rate, roll_rate - ) - dyn_pressure_area_damping * self.cQd( + ) + dyn_pressure_area_damping * self.cQd( alpha, beta, mach, reynolds, pitch_rate, yaw_rate, roll_rate ) drag = dyn_pressure_area * self.cDf( alpha, beta, mach, reynolds, pitch_rate, yaw_rate, roll_rate - ) - dyn_pressure_area_damping * self.cDd( + ) + dyn_pressure_area_damping * self.cDd( alpha, beta, mach, reynolds, pitch_rate, yaw_rate, roll_rate ) # Compute aerodynamic moments pitch = dyn_pressure_area_length * self.cmf( alpha, beta, mach, reynolds, pitch_rate, yaw_rate, roll_rate - ) - dyn_pressure_area_length_damping * self.cmd( + ) + dyn_pressure_area_length_damping * self.cmd( alpha, beta, mach, reynolds, pitch_rate, yaw_rate, roll_rate ) yaw = dyn_pressure_area_length * self.cnf( alpha, beta, mach, reynolds, pitch_rate, yaw_rate, roll_rate - ) - dyn_pressure_area_length_damping * self.cnd( + ) + dyn_pressure_area_length_damping * self.cnd( alpha, beta, mach, reynolds, pitch_rate, yaw_rate, roll_rate ) roll = dyn_pressure_area_length * self.clf( alpha, beta, mach, reynolds, pitch_rate, yaw_rate, roll_rate - ) - dyn_pressure_area_length_damping * self.cld( + ) + dyn_pressure_area_length_damping * self.cld( alpha, beta, mach, reynolds, pitch_rate, yaw_rate, roll_rate ) From 5d0f6435f6e1662c508180ad40ca7debc365f33d Mon Sep 17 00:00:00 2001 From: MateusStano Date: Wed, 13 Nov 2024 16:24:44 +0100 Subject: [PATCH 3/4] DEV: changelog --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 271c3a2bf..f47eab880 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -36,7 +36,7 @@ Attention: The newest changes should be on top --> ### Changed -- +- BUG: Sideslip Angle and Damping Coefficient Calculation [#729](https://github.com/RocketPy-Team/RocketPy/pull/729) ### Fixed From 1574aeafde14ae279d833858869c09ce1b39e56f Mon Sep 17 00:00:00 2001 From: MateusStano Date: Fri, 15 Nov 2024 22:32:56 +0100 Subject: [PATCH 4/4] DEV: changelog --- CHANGELOG.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index f47eab880..d4d083a77 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -36,11 +36,11 @@ Attention: The newest changes should be on top --> ### Changed -- BUG: Sideslip Angle and Damping Coefficient Calculation [#729](https://github.com/RocketPy-Team/RocketPy/pull/729) +- ### Fixed -- +- BUG: Sideslip Angle and Damping Coefficient Calculation [#729](https://github.com/RocketPy-Team/RocketPy/pull/729) ## [v1.6.2] - 2024-11-08