From 97ea9aef206ee470ebb225d6c61eb4a5c6ea8226 Mon Sep 17 00:00:00 2001 From: Pedro Bressan Date: Mon, 9 Sep 2024 09:08:44 -0300 Subject: [PATCH 1/3] BUG: Rollback Prandtl-Glauert corrections for Tail and Nose. --- rocketpy/rocket/aero_surface/nose_cone.py | 2 +- rocketpy/rocket/aero_surface/tail.py | 1 - tests/unit/test_flight.py | 37 ++++++++++++----------- 3 files changed, 21 insertions(+), 19 deletions(-) diff --git a/rocketpy/rocket/aero_surface/nose_cone.py b/rocketpy/rocket/aero_surface/nose_cone.py index 8886be8c5..fb73d1562 100644 --- a/rocketpy/rocket/aero_surface/nose_cone.py +++ b/rocketpy/rocket/aero_surface/nose_cone.py @@ -451,7 +451,7 @@ def evaluate_lift_coefficient(self): # It must be set as a Function because it will be called and treated # as a function of mach in the simulation. self.clalpha = Function( - lambda mach: 2 / self._beta(mach) * self.radius_ratio**2, + lambda mach: 2 * self.radius_ratio**2, "Mach", f"Lift coefficient derivative for {self.name}", ) diff --git a/rocketpy/rocket/aero_surface/tail.py b/rocketpy/rocket/aero_surface/tail.py index a5c5cf939..5cacc6d6a 100644 --- a/rocketpy/rocket/aero_surface/tail.py +++ b/rocketpy/rocket/aero_surface/tail.py @@ -169,7 +169,6 @@ def evaluate_lift_coefficient(self): # as a function of mach in the simulation. self.clalpha = Function( lambda mach: 2 - / self._beta(mach) * ( (self.bottom_radius / self.rocket_radius) ** 2 - (self.top_radius / self.rocket_radius) ** 2 diff --git a/tests/unit/test_flight.py b/tests/unit/test_flight.py index 078c682c9..f65af6da3 100644 --- a/tests/unit/test_flight.py +++ b/tests/unit/test_flight.py @@ -167,9 +167,9 @@ def test_out_of_rail_stability_margin(flight_calisto_custom_wind): @pytest.mark.parametrize( "flight_time, expected_values", [ - ("t_initial", (0.17179073815516033, -0.431117, 0)), - ("out_of_rail_time", (0.543760, -1.364593, 0)), - ("apogee_time", (-0.5874848151271623, -0.7563596, 0)), + ("t_initial", (0.171780, -0.431091, 0)), + ("out_of_rail_time", (0.546945, -1.372586, 0)), + ("apogee_time", (-0.587317, -0.756234, 0)), ("t_final", (0, 0, 0)), ], ) @@ -206,10 +206,10 @@ def test_aerodynamic_moments(flight_calisto_custom_wind, flight_time, expected_v @pytest.mark.parametrize( "flight_time, expected_values", [ - ("t_initial", (1.6542528, 0.65918, -0.067107)), - ("out_of_rail_time", (5.05334, 2.01364, -1.7541)), - ("apogee_time", (2.366258, -1.830744, -0.875342)), - ("t_final", (0, 0, 159.2212)), + ("t_initial", (1.654150, 0.659142, -0.067103)), + ("out_of_rail_time", (5.052628, 2.01336, -1.75370)), + ("apogee_time", (2.352518, -1.826998, -0.878729)), + ("t_final", (0, 0, 159.2210)), ], ) def test_aerodynamic_forces(flight_calisto_custom_wind, flight_time, expected_values): @@ -246,9 +246,12 @@ def test_aerodynamic_forces(flight_calisto_custom_wind, flight_time, expected_va "flight_time, expected_values", [ ("t_initial", (0, 0, 0)), - ("out_of_rail_time", (0, 2.248727, 25.703072)), - ("apogee_time", (-13.204789, 15.990903, -0.000138)), - ("t_final", (5, 2, -5.65998)), + ("out_of_rail_time", (0, 2.248540, 25.700928)), + ( + "apogee_time", + (-13.214438, 16.052063, -0.000421), + ), + ("t_final", (5, 2, -5.66015)), ], ) def test_velocities(flight_calisto_custom_wind, flight_time, expected_values): @@ -284,9 +287,9 @@ def test_velocities(flight_calisto_custom_wind, flight_time, expected_values): "flight_time, expected_values", [ ("t_initial", (0, 0, 0)), - ("out_of_rail_time", (0, 7.8068, 89.2325)), - ("apogee_time", (0.07534, -0.058127, -9.614386)), - ("t_final", (0, 0, 0.0017346294117130806)), + ("out_of_rail_time", (0, 7.8067, 89.2315)), + ("apogee_time", (0.07532, -0.0581194, -9.614827)), + ("t_final", (0, 0, 0.0019548)), ], ) def test_accelerations(flight_calisto_custom_wind, flight_time, expected_values): @@ -334,10 +337,10 @@ def test_rail_buttons_forces(flight_calisto_custom_wind): """ test = flight_calisto_custom_wind atol = 5e-3 - assert pytest.approx(3.833613, abs=atol) == test.max_rail_button1_normal_force - assert pytest.approx(1.648938, abs=atol) == test.max_rail_button1_shear_force - assert pytest.approx(1.165307, abs=atol) == test.max_rail_button2_normal_force - assert pytest.approx(0.501229, abs=atol) == test.max_rail_button2_shear_force + assert pytest.approx(3.803078, abs=atol) == test.max_rail_button1_normal_force + assert pytest.approx(1.635804, abs=atol) == test.max_rail_button1_shear_force + assert pytest.approx(1.193331, abs=atol) == test.max_rail_button2_normal_force + assert pytest.approx(0.513283, abs=atol) == test.max_rail_button2_shear_force def test_max_values(flight_calisto_robust): From 4de4c95b7a8b82655daef4b9498ad0b83b8d0ea3 Mon Sep 17 00:00:00 2001 From: Pedro Bressan Date: Mon, 9 Sep 2024 09:11:23 -0300 Subject: [PATCH 2/3] MNT: Add rollback changes to CHANGELOG file. --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 9a833bf37..48b902b6e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -38,7 +38,7 @@ Attention: The newest changes should be on top --> ### Fixed - +- BUG: Rollback Prandtl-Glauert corrections for Tail and Nose. [#685](https://github.com/RocketPy-Team/RocketPy/pull/685) ## [v1.4.2] - 2024-08-03 From 6b1033dd15a890dca98a100c8797d616cb0263a0 Mon Sep 17 00:00:00 2001 From: Pedro Bressan Date: Wed, 11 Sep 2024 15:41:51 -0300 Subject: [PATCH 3/3] REL: Bump versioning to RocketPy v1.4.3. --- CHANGELOG.md | 10 ++++++++++ docs/conf.py | 2 +- docs/user/installation.rst | 2 +- pyproject.toml | 2 +- 4 files changed, 13 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 48b902b6e..c74f453fb 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -36,6 +36,16 @@ Attention: The newest changes should be on top --> ### Changed +### Fixed + +## [v1.4.3] - 2024-09-11 + +You can install this version by running `pip install rocketpy==1.4.3` + +### Changed + +- REL: Bump versioning to RocketPy v1.4.3 [#687](https://github.com/RocketPy-Team/RocketPy/pull/687) + ### Fixed - BUG: Rollback Prandtl-Glauert corrections for Tail and Nose. [#685](https://github.com/RocketPy-Team/RocketPy/pull/685) diff --git a/docs/conf.py b/docs/conf.py index ce4162c1e..a0773e567 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -25,7 +25,7 @@ author = "RocketPy Team" # The full version, including alpha/beta/rc tags -release = "1.4.2" +release = "1.4.3" # -- General configuration --------------------------------------------------- diff --git a/docs/user/installation.rst b/docs/user/installation.rst index d82c6bf29..c0655a2ea 100644 --- a/docs/user/installation.rst +++ b/docs/user/installation.rst @@ -19,7 +19,7 @@ If you want to choose a specific version to guarantee compatibility, you may ins .. code-block:: shell - pip install rocketpy==1.4.2 + pip install rocketpy==1.4.3 Optional Installation Method: ``conda`` diff --git a/pyproject.toml b/pyproject.toml index 93fe7bb93..636f5d473 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [project] name = "rocketpy" -version = "1.4.2" +version = "1.4.3" description="Advanced 6-DOF trajectory simulation for High-Power Rocketry." dynamic = ["dependencies"] readme = "README.md"