Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Enh/dispersion class/review #267

Merged
merged 73 commits into from
Jan 16, 2023
Merged
Changes from all commits
Commits
Show all changes
73 commits
Select commit Hold shift + click to select a range
789c8e2
MAINT: Remove unused function
Gui-FernandesBR Oct 6, 2022
187a0fe
DOC: Adding docstring formats to be filled
Gui-FernandesBR Oct 6, 2022
cbd2ec6
MAINT: Refresh init docstring
Gui-FernandesBR Oct 6, 2022
fe710dc
MAINT: converting some variables to snake_case
Gui-FernandesBR Oct 6, 2022
4b704b5
MAINT: Modify variable names, start def properties
Gui-FernandesBR Oct 8, 2022
f26eb3b
Merge branch 'enh/class_dispersion' into enh/dispersion_class/review
Gui-FernandesBR Oct 9, 2022
a273350
MAINT: Moving functions from utilities to suppleme
Gui-FernandesBR Oct 10, 2022
623c954
FIX: adjust environment attributes names at Flight
Gui-FernandesBR Oct 10, 2022
6ba9e31
MAINT: Refactor some of the functions
Gui-FernandesBR Oct 10, 2022
d1ce648
MAINT: moving inputs dictionaries inside the class
Gui-FernandesBR Oct 10, 2022
bb2548e
MAINT: minor comments on dispersion.py
Gui-FernandesBR Oct 10, 2022
f5e134e
MAINT: Moving the new notebook to docs
Gui-FernandesBR Oct 10, 2022
a57b0a7
MAINT: improve run_dispersion initialization
Gui-FernandesBR Oct 10, 2022
a652af9
FIX: adjust railLength attribute
Gui-FernandesBR Oct 10, 2022
5fdf869
MAINT: Deleting duplicated functions of supplement
Gui-FernandesBR Oct 10, 2022
1e21f78
MAINT: saving instance of thrustSource
Gui-FernandesBR Oct 10, 2022
df5afe6
MAINT: adjust railLength at Flight.py
Gui-FernandesBR Oct 10, 2022
27b9b88
DOC: adding TODO on EnvAnalysis
Gui-FernandesBR Oct 10, 2022
f316d60
DOC: Updating dispersion class notebook
Gui-FernandesBR Oct 10, 2022
7a1f173
MAINT: Minor changes at dispersion.py
Gui-FernandesBR Oct 10, 2022
1df459a
ADD: new json with historical data by Env Analysis
Gui-FernandesBR Oct 10, 2022
80fc2f0
FIX: saving rocket attributes
Gui-FernandesBR Oct 10, 2022
be6597c
MAINT: adding checking initial object
Gui-FernandesBR Oct 10, 2022
415292d
MAINT: updating notebook
Gui-FernandesBR Oct 10, 2022
12ac1db
MAINT: Introducing AeroSurfaces classes
Gui-FernandesBR Oct 23, 2022
ce35ddc
MAINT: adapting attributes names at AeroSurfaces
Gui-FernandesBR Oct 23, 2022
48fb7da
MAINT: temporary saving rail buttons parameters
Gui-FernandesBR Oct 23, 2022
75f6ca7
ENH: adding static margin properties at flight
Gui-FernandesBR Oct 23, 2022
695d63f
MAINT: removing cLift unused definition
Gui-FernandesBR Oct 23, 2022
9b5f785
MAINT: sort imports
Gui-FernandesBR Oct 23, 2022
a2740c0
ENH: improving self.__inputs dictionaries
Gui-FernandesBR Oct 23, 2022
ad8cc9f
ENH: reorganize __process_dispersion_dict
Gui-FernandesBR Oct 23, 2022
f55a0fa
ENH: Adding process rail buttons
Gui-FernandesBR Oct 23, 2022
c90898f
ENH: deal with n number of nose cones
Gui-FernandesBR Oct 23, 2022
910e0a7
ENH: deal with n number of finsets
Gui-FernandesBR Oct 23, 2022
2c85773
ENH: deal with n number of tails
Gui-FernandesBR Oct 23, 2022
427aa29
MAINT: updating comments and docs
Gui-FernandesBR Oct 23, 2022
fc8cc2c
MAINT: New check initial objects
Gui-FernandesBR Oct 23, 2022
d2ce453
ENH: abstract adding aero surfaces and parachutes
Gui-FernandesBR Oct 23, 2022
3cdfabf
MAINT: New import_results method, more flexible
Gui-FernandesBR Oct 23, 2022
2680c8e
ENH: process, print, and plot abstract methods
Gui-FernandesBR Oct 23, 2022
84e35b6
MAINT: refactoring process parachutes
Gui-FernandesBR Oct 23, 2022
312644a
MAINT: improving error raises
Gui-FernandesBR Oct 23, 2022
35206f5
ENH: flexible export data seelection
Gui-FernandesBR Oct 23, 2022
8366a56
MAINT: new __export_flight_data_error method
Gui-FernandesBR Oct 23, 2022
6489e21
ENH: open_mode options added
Gui-FernandesBR Oct 23, 2022
e8430e6
MAINT: initializing or saving variables
Gui-FernandesBR Oct 23, 2022
835d253
MAINT: info and allInfo refactored
Gui-FernandesBR Oct 23, 2022
c539da0
MAINT: refreshing comments and TODOs
Gui-FernandesBR Oct 23, 2022
7129cda
MAINT: improving warnings again
Gui-FernandesBR Oct 23, 2022
e3bc3c9
MAINT: adjusting variables names and inputs
Gui-FernandesBR Oct 23, 2022
bb71818
MAINT: updating class usage notebook
Gui-FernandesBR Oct 23, 2022
7972077
Merge branch 'master' into enh/dispersion_class/review
Gui-FernandesBR Oct 25, 2022
c12eb04
ENH: get_parachute_by_name
Gui-FernandesBR Nov 2, 2022
79938f1
BUG: insert missing inputs ar dictionary as list
Gui-FernandesBR Nov 2, 2022
fb59377
MAINT: update docstrings
Gui-FernandesBR Nov 3, 2022
0b8286e
FIX: wrong argument on exportEllipsesToKML
Gui-FernandesBR Nov 3, 2022
09b7d60
MAINT: Update notebook
Gui-FernandesBR Nov 3, 2022
3493fde
Merge 'develop' into enh/dispersion_class/review
Gui-FernandesBR Nov 3, 2022
daa19d0
Merge branch 'enh/class_dispersion' into enh/dispersion_class/review
Gui-FernandesBR Nov 3, 2022
a45ab48
Fix code style issues with Black
lint-action Nov 3, 2022
0689859
Merge enh/class_dispersion into dispersion/review
Gui-FernandesBR Nov 3, 2022
0618afd
MAINT: cleaning TODOs and fixing warnings
Gui-FernandesBR Nov 12, 2022
7c8f5c0
MAINT: removed unused .json file
Gui-FernandesBR Nov 12, 2022
469e281
ENH: class_inputs dict to one inputs_dict,
MateusStano Jan 15, 2023
304de07
ENH: change __export_flight_data
MateusStano Jan 15, 2023
398c453
BUG: Aerosurfaces dictionary check
MateusStano Jan 15, 2023
b0086b2
ENH: add try except in __create_initial_objects
MateusStano Jan 15, 2023
f2eb098
ENH: adapted run_dispersion
MateusStano Jan 15, 2023
88aeadb
ENH: remove uncessary check
MateusStano Jan 15, 2023
3aab22c
MAINT: improved/added docs
MateusStano Jan 15, 2023
5de9043
MAINT: add TODOs
MateusStano Jan 15, 2023
eba0060
ENH: necessary notebook changes
MateusStano Jan 15, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
649 changes: 649 additions & 0 deletions docs/notebooks/dispersion_analysis/dispersion_class_usage.ipynb

Large diffs are not rendered by default.

1 change: 1 addition & 0 deletions docs/user/index.rst
Original file line number Diff line number Diff line change
@@ -12,6 +12,7 @@ Welcome to RocketPy's user documentation!
../notebooks/environment_analysis_class_usage.ipynb
../notebooks/environment_analysis_EuroC_example.ipynb
../notebooks/dispersion_analysis/dispersion_analysis.ipynb
../notebooks/dispersion_analysis/dispersion_class_usage.ipynb
../notebooks/utilities_usage.ipynb
../matlab/matlab.rst

672 changes: 0 additions & 672 deletions getting_started Dispersion.ipynb

This file was deleted.

19 changes: 19 additions & 0 deletions rocketpy/AeroSurfaces.py
Original file line number Diff line number Diff line change
@@ -215,6 +215,7 @@ class Fins(ABC):
Geometrical relation used to simplify lift and roll calculations
Fins.liftInterferenceFactor : float
Factor of Fin-Body interference in the lift coefficient

"""

def __init__(
@@ -230,14 +231,17 @@ def __init__(
):
"""Initialize Fins class.


Parameters
----------
n : int
Number of fins, from 2 to infinity.

rootChord : int, float
Fin root chord in meters.
span : int, float
Fin span in meters.

distanceToCM : int, float
Fin set position relative to rocket unloaded center of
mass, considering positive direction from center of mass to
@@ -248,6 +252,7 @@ def __init__(
cantAngle : int, float, optional
Fins cant angle with respect to the rocket centerline. Must
be given in degrees.

airfoil : tuple, optional
Default is null, in which case fins will be treated as flat plates.
Otherwise, if tuple, fins will be considered as airfoils. The
@@ -277,10 +282,12 @@ def __init__(
# Store values
self.n = n
self.rocketRadius = rocketRadius

self.airfoil = airfoil
self.distanceToCM = distanceToCM
self.cantAngle = cantAngle
self.rootChord = rootChord

self.span = span
self.name = name
self.d = d
@@ -328,6 +335,7 @@ def evaluateLiftCoefficient(self):
if not self.airfoil:
# Defines clalpha2D as 2*pi for planar fins
clalpha2D = Function(lambda mach: 2 * np.pi / self.__beta(mach))

else:
# Defines clalpha2D as the derivative of the
# lift coefficient curve for a specific airfoil
@@ -792,6 +800,7 @@ def __init__(
+ 4 * (rootChord + 2 * tipChord) * rocketRadius * span**2
+ 6 * (rootChord + tipChord) * span * rocketRadius**2
) / 12

rollDampingInterferenceFactor = 1 + (
((tau - λ) / (tau)) - ((1 - λ) / (tau - 1)) * np.log(tau)
) / (
@@ -855,10 +864,12 @@ def evaluateCenterOfPressure(self):
- self.rootChord * self.tipChord / (self.rootChord + self.tipChord)
)
)

self.cpx = 0
self.cpy = 0
self.cpz = cpz
self.cp = (self.cpx, self.cpy, self.cpz)

return self.cp

def draw(self):
@@ -1024,6 +1035,7 @@ class EllipticalFins(Fins):
Geometrical relation used to simplify lift and roll calculations
Fins.liftInterferenceFactor : float
Factor of Fin-Body interference in the lift coefficient

"""

def __init__(
@@ -1039,9 +1051,11 @@ def __init__(
):
"""Initialize EllipticalFins class.


Parameters
----------
n : int

Number of fins, from 2 to infinity.
rootChord : int, float
Fin root chord in meters.
@@ -1090,9 +1104,11 @@ def __init__(
name : str
Name of fin set.


Returns
-------
None

"""

super().__init__(
@@ -1152,6 +1168,7 @@ def __init__(
* (span / 3 + np.pi * rocketRadius / 4)
* (span**2 - rocketRadius**2)
)

rollForcingInterferenceFactor = (1 / np.pi**2) * (
(np.pi**2 / 4) * ((tau + 1) ** 2 / tau**2)
+ ((np.pi * (tau**2 + 1) ** 2) / (tau**2 * (tau - 1) ** 2))
@@ -1278,6 +1295,7 @@ def draw(self):


class Tail:

"""Class that defines a tail for the rocket. Currently only accepts
conical tails.

@@ -1321,6 +1339,7 @@ class Tail:
Tail.surfaceArea : float
Surface area of the tail. Has the unit of meters squared.


"""

def __init__(
Loading