From 157e986fde625f323a5e6a1bc81c734a71fd7401 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Wed, 18 Dec 2024 19:49:47 -0800 Subject: [PATCH 01/22] In add_aviary_input and add_aviary_output, set val = 0.0 if val is None. --- aviary/variable_info/functions.py | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/aviary/variable_info/functions.py b/aviary/variable_info/functions.py index 8c28147a0..9f96833ff 100644 --- a/aviary/variable_info/functions.py +++ b/aviary/variable_info/functions.py @@ -1,4 +1,5 @@ import dymos as dm +import numpy as np import openmdao.api as om from dymos.utils.misc import _unspecified from openmdao.core.component import Component @@ -34,6 +35,11 @@ def add_aviary_input(comp, varname, val=None, units=None, desc=None, shape_by_co input_desc = meta['desc'] if val is None: val = meta['default_value'] + if val is None: + if shape is None: + val = 0.0 + else: + val = np.zeros(shape) comp.add_input(varname, val=val, units=input_units, desc=input_desc, shape_by_conn=shape_by_conn, shape=shape) @@ -58,6 +64,10 @@ def add_aviary_output(comp, varname, val, units=None, desc=None, shape_by_conn=F output_desc = desc else: output_desc = meta['desc'] + if val is None: + val = meta['default_value'] + if val is None: + val = 0.0 comp.add_output(varname, val=val, units=output_units, desc=output_desc, shape_by_conn=shape_by_conn) From 6bf20659fc91a9bb47f22e3296d2cf10314ecfa1 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Wed, 18 Dec 2024 19:51:44 -0800 Subject: [PATCH 02/22] set Aircraft.Hydraulics.SYSTEM_PRESSURE = 0 instead of 3000 as default. --- aviary/variable_info/variable_meta_data.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/aviary/variable_info/variable_meta_data.py b/aviary/variable_info/variable_meta_data.py index 6ef0e83de..ea20de153 100644 --- a/aviary/variable_info/variable_meta_data.py +++ b/aviary/variable_info/variable_meta_data.py @@ -3778,7 +3778,7 @@ }, units='psi', desc='hydraulic system pressure', - default_value=3000.0, + default_value=0.0, ) # From 03b14b62711151d1fb912cf86fe111662d00c424 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Wed, 18 Dec 2024 19:56:06 -0800 Subject: [PATCH 03/22] work in progress: Remove value from setup() so that the value is taken from default in metadata. --- .../mass/flops_based/air_conditioning.py | 17 +++---- .../subsystems/mass/flops_based/anti_icing.py | 17 +++---- aviary/subsystems/mass/flops_based/apu.py | 7 ++- .../subsystems/mass/flops_based/avionics.py | 10 ++-- aviary/subsystems/mass/flops_based/canard.py | 10 ++-- aviary/subsystems/mass/flops_based/cargo.py | 17 ++++--- .../mass/flops_based/cargo_containers.py | 11 ++--- aviary/subsystems/mass/flops_based/crew.py | 10 ++-- .../subsystems/mass/flops_based/electrical.py | 12 ++--- .../mass/flops_based/empty_margin.py | 13 ++--- aviary/subsystems/mass/flops_based/engine.py | 14 ++---- .../mass/flops_based/engine_controls.py | 6 +-- .../subsystems/mass/flops_based/engine_oil.py | 11 ++--- .../subsystems/mass/flops_based/engine_pod.py | 25 +++++----- aviary/subsystems/mass/flops_based/fin.py | 10 ++-- .../mass/flops_based/fuel_capacity.py | 42 ++++++++-------- .../mass/flops_based/fuel_system.py | 14 +++--- .../mass/flops_based/furnishings.py | 48 +++++++------------ .../subsystems/mass/flops_based/fuselage.py | 10 ++-- .../mass/flops_based/horizontal_tail.py | 18 ++++--- .../subsystems/mass/flops_based/hydraulics.py | 30 +++++------- .../mass/flops_based/instruments.py | 4 +- .../mass/flops_based/landing_gear.py | 40 ++++++---------- 23 files changed, 167 insertions(+), 229 deletions(-) diff --git a/aviary/subsystems/mass/flops_based/air_conditioning.py b/aviary/subsystems/mass/flops_based/air_conditioning.py index 894ca14dd..a20a32214 100644 --- a/aviary/subsystems/mass/flops_based/air_conditioning.py +++ b/aviary/subsystems/mass/flops_based/air_conditioning.py @@ -21,15 +21,12 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.AirConditioning.MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.AirConditioning.MASS_SCALER) + add_aviary_input(self, Aircraft.Avionics.MASS) + add_aviary_input(self, Aircraft.Fuselage.MAX_HEIGHT) + add_aviary_input(self, Aircraft.Fuselage.PLANFORM_AREA) - add_aviary_input(self, Aircraft.Avionics.MASS, val=0.0) - - add_aviary_input(self, Aircraft.Fuselage.MAX_HEIGHT, val=0.0) - - add_aviary_input(self, Aircraft.Fuselage.PLANFORM_AREA, val=0.0) - - add_aviary_output(self, Aircraft.AirConditioning.MASS, val=0.0) + add_aviary_output(self, Aircraft.AirConditioning.MASS) def setup_partials(self): self.declare_partials('*', '*') @@ -91,9 +88,9 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.AirConditioning.MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.AirConditioning.MASS_SCALER) - add_aviary_output(self, Aircraft.AirConditioning.MASS, val=0.0) + add_aviary_output(self, Aircraft.AirConditioning.MASS) def setup_partials(self): self.declare_partials(of=Aircraft.AirConditioning.MASS, wrt='*') diff --git a/aviary/subsystems/mass/flops_based/anti_icing.py b/aviary/subsystems/mass/flops_based/anti_icing.py index 779fc3ca0..ae82a546a 100644 --- a/aviary/subsystems/mass/flops_based/anti_icing.py +++ b/aviary/subsystems/mass/flops_based/anti_icing.py @@ -26,18 +26,13 @@ def setup(self): num_engine_type = len(self.options['aviary_options'].get_val( Aircraft.Engine.NUM_ENGINES)) - add_aviary_input(self, Aircraft.AntiIcing.MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.AntiIcing.MASS_SCALER) + add_aviary_input(self, Aircraft.Fuselage.MAX_WIDTH) + add_aviary_input(self, Aircraft.Nacelle.AVG_DIAMETER, shape=num_engine_type) + add_aviary_input(self, Aircraft.Wing.SPAN) + add_aviary_input(self, Aircraft.Wing.SWEEP) - add_aviary_input(self, Aircraft.Fuselage.MAX_WIDTH, val=0.0) - - add_aviary_input(self, Aircraft.Nacelle.AVG_DIAMETER, - val=np.zeros(num_engine_type)) - - add_aviary_input(self, Aircraft.Wing.SPAN, val=0.0) - - add_aviary_input(self, Aircraft.Wing.SWEEP, val=0.0) - - add_aviary_output(self, Aircraft.AntiIcing.MASS, val=0.0) + add_aviary_output(self, Aircraft.AntiIcing.MASS) def setup_partials(self): self.declare_partials("*", "*") diff --git a/aviary/subsystems/mass/flops_based/apu.py b/aviary/subsystems/mass/flops_based/apu.py index 3a8fec051..217f553a7 100644 --- a/aviary/subsystems/mass/flops_based/apu.py +++ b/aviary/subsystems/mass/flops_based/apu.py @@ -18,11 +18,10 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.APU.MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.APU.MASS_SCALER) + add_aviary_input(self, Aircraft.Fuselage.PLANFORM_AREA) - add_aviary_input(self, Aircraft.Fuselage.PLANFORM_AREA, val=0.0) - - add_aviary_output(self, Aircraft.APU.MASS, val=0.0) + add_aviary_output(self, Aircraft.APU.MASS) def setup_partials(self): self.declare_partials('*', '*') diff --git a/aviary/subsystems/mass/flops_based/avionics.py b/aviary/subsystems/mass/flops_based/avionics.py index 0c6e54522..9b2b2d61b 100644 --- a/aviary/subsystems/mass/flops_based/avionics.py +++ b/aviary/subsystems/mass/flops_based/avionics.py @@ -19,13 +19,11 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Avionics.MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.Avionics.MASS_SCALER) + add_aviary_input(self, Aircraft.Fuselage.PLANFORM_AREA) + add_aviary_input(self, Mission.Design.RANGE) - add_aviary_input(self, Aircraft.Fuselage.PLANFORM_AREA, val=0.0) - - add_aviary_input(self, Mission.Design.RANGE, val=0.0) - - add_aviary_output(self, Aircraft.Avionics.MASS, val=0.0) + add_aviary_output(self, Aircraft.Avionics.MASS) def setup_partials(self): self.declare_partials('*', '*') diff --git a/aviary/subsystems/mass/flops_based/canard.py b/aviary/subsystems/mass/flops_based/canard.py index 9223872f1..a8ea05f47 100644 --- a/aviary/subsystems/mass/flops_based/canard.py +++ b/aviary/subsystems/mass/flops_based/canard.py @@ -18,12 +18,12 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Mission.Design.GROSS_MASS, val=0.0) - add_aviary_input(self, Aircraft.Canard.AREA, val=0.0) - add_aviary_input(self, Aircraft.Canard.TAPER_RATIO, val=00) - add_aviary_input(self, Aircraft.Canard.MASS_SCALER, val=1.0) + add_aviary_input(self, Mission.Design.GROSS_MASS) + add_aviary_input(self, Aircraft.Canard.AREA) + add_aviary_input(self, Aircraft.Canard.TAPER_RATIO) + add_aviary_input(self, Aircraft.Canard.MASS_SCALER) - add_aviary_output(self, Aircraft.Canard.MASS, val=0.0) + add_aviary_output(self, Aircraft.Canard.MASS) def setup_partials(self): self.declare_partials("*", "*") diff --git a/aviary/subsystems/mass/flops_based/cargo.py b/aviary/subsystems/mass/flops_based/cargo.py index 8ac83f493..ad047f6e7 100644 --- a/aviary/subsystems/mass/flops_based/cargo.py +++ b/aviary/subsystems/mass/flops_based/cargo.py @@ -22,15 +22,14 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_output(self, Aircraft.CrewPayload.PASSENGER_MASS, 0.) - add_aviary_output(self, Aircraft.CrewPayload.BAGGAGE_MASS, 0.) - add_aviary_output(self, Aircraft.CrewPayload.PASSENGER_PAYLOAD_MASS, 0.) - - add_aviary_input(self, Aircraft.CrewPayload.WING_CARGO, 0.) - add_aviary_input(self, Aircraft.CrewPayload.MISC_CARGO, 0.) - - add_aviary_output(self, Aircraft.CrewPayload.CARGO_MASS, 0.) - add_aviary_output(self, Aircraft.CrewPayload.TOTAL_PAYLOAD_MASS, 0.) + add_aviary_input(self, Aircraft.CrewPayload.WING_CARGO) + add_aviary_input(self, Aircraft.CrewPayload.MISC_CARGO) + + add_aviary_output(self, Aircraft.CrewPayload.PASSENGER_MASS) + add_aviary_output(self, Aircraft.CrewPayload.BAGGAGE_MASS) + add_aviary_output(self, Aircraft.CrewPayload.PASSENGER_PAYLOAD_MASS) + add_aviary_output(self, Aircraft.CrewPayload.CARGO_MASS) + add_aviary_output(self, Aircraft.CrewPayload.TOTAL_PAYLOAD_MASS) def setup_partials(self): diff --git a/aviary/subsystems/mass/flops_based/cargo_containers.py b/aviary/subsystems/mass/flops_based/cargo_containers.py index df0967439..74639c5ec 100644 --- a/aviary/subsystems/mass/flops_based/cargo_containers.py +++ b/aviary/subsystems/mass/flops_based/cargo_containers.py @@ -20,14 +20,11 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input( - self, Aircraft.CrewPayload.CARGO_CONTAINER_MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.CrewPayload.CARGO_CONTAINER_MASS_SCALER) + add_aviary_input(self, Aircraft.CrewPayload.CARGO_MASS) + add_aviary_input(self, Aircraft.CrewPayload.BAGGAGE_MASS) - add_aviary_input(self, Aircraft.CrewPayload.CARGO_MASS, val=0.0) - - add_aviary_input(self, Aircraft.CrewPayload.BAGGAGE_MASS, val=0.0) - - add_aviary_output(self, Aircraft.CrewPayload.CARGO_CONTAINER_MASS, val=0.0) + add_aviary_output(self, Aircraft.CrewPayload.CARGO_CONTAINER_MASS) def setup_partials(self): self.declare_partials('*', '*') diff --git a/aviary/subsystems/mass/flops_based/crew.py b/aviary/subsystems/mass/flops_based/crew.py index 60030710b..491567189 100644 --- a/aviary/subsystems/mass/flops_based/crew.py +++ b/aviary/subsystems/mass/flops_based/crew.py @@ -20,10 +20,9 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input( - self, Aircraft.CrewPayload.NON_FLIGHT_CREW_MASS_SCALER, 1.) + add_aviary_input(self, Aircraft.CrewPayload.NON_FLIGHT_CREW_MASS_SCALER) - add_aviary_output(self, Aircraft.CrewPayload.NON_FLIGHT_CREW_MASS, 0) + add_aviary_output(self, Aircraft.CrewPayload.NON_FLIGHT_CREW_MASS) def setup_partials(self): self.declare_partials( @@ -84,10 +83,9 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input( - self, Aircraft.CrewPayload.FLIGHT_CREW_MASS_SCALER, 1.) + add_aviary_input(self, Aircraft.CrewPayload.FLIGHT_CREW_MASS_SCALER) - add_aviary_output(self, Aircraft.CrewPayload.FLIGHT_CREW_MASS, 0.) + add_aviary_output(self, Aircraft.CrewPayload.FLIGHT_CREW_MASS) def setup_partials(self): self.declare_partials( diff --git a/aviary/subsystems/mass/flops_based/electrical.py b/aviary/subsystems/mass/flops_based/electrical.py index 1430945f7..b76f53b22 100644 --- a/aviary/subsystems/mass/flops_based/electrical.py +++ b/aviary/subsystems/mass/flops_based/electrical.py @@ -20,11 +20,11 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Fuselage.LENGTH, 0.0) - add_aviary_input(self, Aircraft.Fuselage.MAX_WIDTH, 0.0) - add_aviary_input(self, Aircraft.Electrical.MASS_SCALER, 1.0) + add_aviary_input(self, Aircraft.Fuselage.LENGTH) + add_aviary_input(self, Aircraft.Fuselage.MAX_WIDTH) + add_aviary_input(self, Aircraft.Electrical.MASS_SCALER) - add_aviary_output(self, Aircraft.Electrical.MASS, 1.0) + add_aviary_output(self, Aircraft.Electrical.MASS) def setup_partials(self): self.declare_partials(of='*', wrt='*') @@ -85,9 +85,9 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Electrical.MASS_SCALER, 1.0) + add_aviary_input(self, Aircraft.Electrical.MASS_SCALER) - add_aviary_output(self, Aircraft.Electrical.MASS, 1.0) + add_aviary_output(self, Aircraft.Electrical.MASS) def setup_partials(self): self.declare_partials(of='*', wrt='*') diff --git a/aviary/subsystems/mass/flops_based/empty_margin.py b/aviary/subsystems/mass/flops_based/empty_margin.py index 4c4b5cf33..91fee5fe4 100644 --- a/aviary/subsystems/mass/flops_based/empty_margin.py +++ b/aviary/subsystems/mass/flops_based/empty_margin.py @@ -16,15 +16,12 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Propulsion.MASS, val=0.) + add_aviary_input(self, Aircraft.Propulsion.MASS) + add_aviary_input(self, Aircraft.Design.STRUCTURE_MASS) + add_aviary_input(self, Aircraft.Design.SYSTEMS_EQUIP_MASS) + add_aviary_input(self, Aircraft.Design.EMPTY_MASS_MARGIN_SCALER) - add_aviary_input(self, Aircraft.Design.STRUCTURE_MASS, val=0.) - - add_aviary_input(self, Aircraft.Design.SYSTEMS_EQUIP_MASS, val=0.) - - add_aviary_input(self, Aircraft.Design.EMPTY_MASS_MARGIN_SCALER, val=0.0) - - add_aviary_output(self, Aircraft.Design.EMPTY_MASS_MARGIN, val=0.0) + add_aviary_output(self, Aircraft.Design.EMPTY_MASS_MARGIN) def setup_partials(self): self.declare_partials('*', '*') diff --git a/aviary/subsystems/mass/flops_based/engine.py b/aviary/subsystems/mass/flops_based/engine.py index ac9644327..613abf343 100644 --- a/aviary/subsystems/mass/flops_based/engine.py +++ b/aviary/subsystems/mass/flops_based/engine.py @@ -24,16 +24,12 @@ def setup(self): num_engine_type = len(self.options['aviary_options'].get_val( Aircraft.Engine.NUM_ENGINES)) - add_aviary_input(self, Aircraft.Engine.SCALED_SLS_THRUST, - val=np.zeros(num_engine_type)) + add_aviary_input(self, Aircraft.Engine.SCALED_SLS_THRUST, shape=num_engine_type) + add_aviary_input(self, Aircraft.Engine.MASS_SCALER, shape=num_engine_type) - add_aviary_input(self, Aircraft.Engine.MASS_SCALER, - val=np.zeros(num_engine_type)) - - add_aviary_output(self, Aircraft.Engine.MASS, val=np.zeros(num_engine_type)) - add_aviary_output(self, Aircraft.Engine.ADDITIONAL_MASS, - val=np.zeros(num_engine_type)) - add_aviary_output(self, Aircraft.Propulsion.TOTAL_ENGINE_MASS, val=0.0) + add_aviary_output(self, Aircraft.Engine.MASS, shape=num_engine_type) + add_aviary_output(self, Aircraft.Engine.ADDITIONAL_MASS, shape=num_engine_type) + add_aviary_output(self, Aircraft.Propulsion.TOTAL_ENGINE_MASS) def compute(self, inputs, outputs): aviary_options: AviaryValues = self.options['aviary_options'] diff --git a/aviary/subsystems/mass/flops_based/engine_controls.py b/aviary/subsystems/mass/flops_based/engine_controls.py index c17868c1f..1a4931b74 100644 --- a/aviary/subsystems/mass/flops_based/engine_controls.py +++ b/aviary/subsystems/mass/flops_based/engine_controls.py @@ -30,11 +30,9 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input( - self, Aircraft.Propulsion.TOTAL_SCALED_SLS_THRUST, val=0.0, units='lbf') + add_aviary_input(self, Aircraft.Propulsion.TOTAL_SCALED_SLS_THRUST) - add_aviary_output( - self, Aircraft.Propulsion.TOTAL_ENGINE_CONTROLS_MASS, val=0.0, units='lbm') + add_aviary_output(self, Aircraft.Propulsion.TOTAL_ENGINE_CONTROLS_MASS) def setup_partials(self): self.declare_partials(Aircraft.Propulsion.TOTAL_ENGINE_CONTROLS_MASS, diff --git a/aviary/subsystems/mass/flops_based/engine_oil.py b/aviary/subsystems/mass/flops_based/engine_oil.py index d82cd8e63..8af91bd3b 100644 --- a/aviary/subsystems/mass/flops_based/engine_oil.py +++ b/aviary/subsystems/mass/flops_based/engine_oil.py @@ -27,11 +27,10 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Propulsion.ENGINE_OIL_MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.Propulsion.ENGINE_OIL_MASS_SCALER) + add_aviary_input(self, Aircraft.Propulsion.TOTAL_SCALED_SLS_THRUST) - add_aviary_input(self, Aircraft.Propulsion.TOTAL_SCALED_SLS_THRUST, val=0.0) - - add_aviary_output(self, Aircraft.Propulsion.TOTAL_ENGINE_OIL_MASS, val=0.0) + add_aviary_output(self, Aircraft.Propulsion.TOTAL_ENGINE_OIL_MASS) def setup_partials(self): self.declare_partials('*', '*') @@ -77,9 +76,9 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Propulsion.ENGINE_OIL_MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.Propulsion.ENGINE_OIL_MASS_SCALER) - add_aviary_output(self, Aircraft.Propulsion.TOTAL_ENGINE_OIL_MASS, val=0.0) + add_aviary_output(self, Aircraft.Propulsion.TOTAL_ENGINE_OIL_MASS) def setup_partials(self): self.declare_partials('*', '*') diff --git a/aviary/subsystems/mass/flops_based/engine_pod.py b/aviary/subsystems/mass/flops_based/engine_pod.py index 256c26d26..393daaab3 100644 --- a/aviary/subsystems/mass/flops_based/engine_pod.py +++ b/aviary/subsystems/mass/flops_based/engine_pod.py @@ -26,21 +26,20 @@ def setup(self): num_engine_type = len(self.options['aviary_options'].get_val( Aircraft.Engine.NUM_ENGINES)) - add_aviary_input(self, Aircraft.Electrical.MASS, val=0.0) - add_aviary_input(self, Aircraft.Fuel.FUEL_SYSTEM_MASS, val=0.0) - add_aviary_input(self, Aircraft.Hydraulics.MASS, val=0.0) - add_aviary_input(self, Aircraft.Instruments.MASS, val=0.0) - add_aviary_input(self, Aircraft.Nacelle.MASS, val=np.zeros(num_engine_type)) - add_aviary_input(self, Aircraft.Propulsion.TOTAL_ENGINE_CONTROLS_MASS, val=0.0) - add_aviary_input(self, Aircraft.Engine.MASS, val=np.zeros(num_engine_type)) - add_aviary_input(self, Aircraft.Propulsion.TOTAL_STARTER_MASS, val=0.0) + add_aviary_input(self, Aircraft.Electrical.MASS) + add_aviary_input(self, Aircraft.Fuel.FUEL_SYSTEM_MASS) + add_aviary_input(self, Aircraft.Hydraulics.MASS) + add_aviary_input(self, Aircraft.Instruments.MASS) + add_aviary_input(self, Aircraft.Nacelle.MASS, shape=num_engine_type) + add_aviary_input(self, Aircraft.Propulsion.TOTAL_ENGINE_CONTROLS_MASS) + add_aviary_input(self, Aircraft.Engine.MASS, shape=num_engine_type) + add_aviary_input(self, Aircraft.Propulsion.TOTAL_STARTER_MASS) add_aviary_input(self, Aircraft.Engine.THRUST_REVERSERS_MASS, - val=np.zeros(num_engine_type)) - add_aviary_input(self, Aircraft.Engine.SCALED_SLS_THRUST, - val=np.zeros(num_engine_type)) - add_aviary_input(self, Aircraft.Propulsion.TOTAL_SCALED_SLS_THRUST, val=0.0) + shape=num_engine_type) + add_aviary_input(self, Aircraft.Engine.SCALED_SLS_THRUST, shape=num_engine_type) + add_aviary_input(self, Aircraft.Propulsion.TOTAL_SCALED_SLS_THRUST) - add_aviary_output(self, Aircraft.Engine.POD_MASS, val=np.zeros(num_engine_type)) + add_aviary_output(self, Aircraft.Engine.POD_MASS, shape=num_engine_type) def setup_partials(self): self.declare_partials('*', '*') diff --git a/aviary/subsystems/mass/flops_based/fin.py b/aviary/subsystems/mass/flops_based/fin.py index 989ee1ee2..5eef4aac8 100644 --- a/aviary/subsystems/mass/flops_based/fin.py +++ b/aviary/subsystems/mass/flops_based/fin.py @@ -18,12 +18,12 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Mission.Design.GROSS_MASS, val=0.0) - add_aviary_input(self, Aircraft.Fins.AREA, val=0.0) - add_aviary_input(self, Aircraft.Fins.TAPER_RATIO, val=0.0) - add_aviary_input(self, Aircraft.Fins.MASS_SCALER, val=1.0) + add_aviary_input(self, Mission.Design.GROSS_MASS) + add_aviary_input(self, Aircraft.Fins.AREA) + add_aviary_input(self, Aircraft.Fins.TAPER_RATIO) + add_aviary_input(self, Aircraft.Fins.MASS_SCALER) - add_aviary_output(self, Aircraft.Fins.MASS, val=0.0) + add_aviary_output(self, Aircraft.Fins.MASS) def setup_partials(self): self.declare_partials("*", "*") diff --git a/aviary/subsystems/mass/flops_based/fuel_capacity.py b/aviary/subsystems/mass/flops_based/fuel_capacity.py index 98d50b2e9..dca9358ad 100644 --- a/aviary/subsystems/mass/flops_based/fuel_capacity.py +++ b/aviary/subsystems/mass/flops_based/fuel_capacity.py @@ -45,9 +45,9 @@ class FuselageFuelCapacity(om.ExplicitComponent): """ def setup(self): - add_aviary_input(self, Aircraft.Fuel.TOTAL_CAPACITY, 0.0), - add_aviary_input(self, Aircraft.Fuel.WING_FUEL_CAPACITY, 0.0), - add_aviary_output(self, Aircraft.Fuel.FUSELAGE_FUEL_CAPACITY, 0.0), + add_aviary_input(self, Aircraft.Fuel.TOTAL_CAPACITY), + add_aviary_input(self, Aircraft.Fuel.WING_FUEL_CAPACITY), + add_aviary_output(self, Aircraft.Fuel.FUSELAGE_FUEL_CAPACITY), def setup_partials(self): self.declare_partials( @@ -69,10 +69,10 @@ class AuxFuelCapacity(om.ExplicitComponent): """ def setup(self): - add_aviary_input(self, Aircraft.Fuel.TOTAL_CAPACITY, 0.0), - add_aviary_input(self, Aircraft.Fuel.WING_FUEL_CAPACITY, 0.0), - add_aviary_input(self, Aircraft.Fuel.FUSELAGE_FUEL_CAPACITY, 0.0), - add_aviary_output(self, Aircraft.Fuel.AUXILIARY_FUEL_CAPACITY, 0.0), + add_aviary_input(self, Aircraft.Fuel.TOTAL_CAPACITY), + add_aviary_input(self, Aircraft.Fuel.WING_FUEL_CAPACITY), + add_aviary_input(self, Aircraft.Fuel.FUSELAGE_FUEL_CAPACITY), + add_aviary_output(self, Aircraft.Fuel.AUXILIARY_FUEL_CAPACITY), def setup_partials(self): self.declare_partials( @@ -98,10 +98,10 @@ class TotalFuelCapacity(om.ExplicitComponent): """ def setup(self): - add_aviary_input(self, Aircraft.Fuel.WING_FUEL_CAPACITY, 0.0), - add_aviary_input(self, Aircraft.Fuel.FUSELAGE_FUEL_CAPACITY, 0.0), - add_aviary_input(self, Aircraft.Fuel.AUXILIARY_FUEL_CAPACITY, 0.0), - add_aviary_output(self, Aircraft.Fuel.TOTAL_CAPACITY, 0.0), + add_aviary_input(self, Aircraft.Fuel.WING_FUEL_CAPACITY), + add_aviary_input(self, Aircraft.Fuel.FUSELAGE_FUEL_CAPACITY), + add_aviary_input(self, Aircraft.Fuel.AUXILIARY_FUEL_CAPACITY), + add_aviary_output(self, Aircraft.Fuel.TOTAL_CAPACITY), def setup_partials(self): self.declare_partials( @@ -132,20 +132,20 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Fuel.DENSITY_RATIO, 1.0) - add_aviary_input(self, Aircraft.Fuel.WING_REF_CAPACITY, 0.0) - add_aviary_input(self, Aircraft.Fuel.WING_REF_CAPACITY_AREA, 0.0) - add_aviary_input(self, Aircraft.Fuel.WING_REF_CAPACITY_TERM_A, 0.0) - add_aviary_input(self, Aircraft.Fuel.WING_REF_CAPACITY_TERM_B, 0.0) + add_aviary_input(self, Aircraft.Fuel.DENSITY_RATIO) + add_aviary_input(self, Aircraft.Fuel.WING_REF_CAPACITY) + add_aviary_input(self, Aircraft.Fuel.WING_REF_CAPACITY_AREA) + add_aviary_input(self, Aircraft.Fuel.WING_REF_CAPACITY_TERM_A) + add_aviary_input(self, Aircraft.Fuel.WING_REF_CAPACITY_TERM_B) add_aviary_input(self, Aircraft.Fuel.CAPACITY_FACTOR, 23.0) - add_aviary_input(self, Aircraft.Wing.AREA, 0.0) - add_aviary_input(self, Aircraft.Wing.SPAN, 0.0) - add_aviary_input(self, Aircraft.Wing.TAPER_RATIO, 0.0) - add_aviary_input(self, Aircraft.Wing.THICKNESS_TO_CHORD, 0.0) + add_aviary_input(self, Aircraft.Wing.AREA) + add_aviary_input(self, Aircraft.Wing.SPAN) + add_aviary_input(self, Aircraft.Wing.TAPER_RATIO) + add_aviary_input(self, Aircraft.Wing.THICKNESS_TO_CHORD) - add_aviary_output(self, Aircraft.Fuel.WING_FUEL_CAPACITY, 0.0) + add_aviary_output(self, Aircraft.Fuel.WING_FUEL_CAPACITY) def setup_partials(self): self.declare_partials('*', '*') diff --git a/aviary/subsystems/mass/flops_based/fuel_system.py b/aviary/subsystems/mass/flops_based/fuel_system.py index a78851fe2..6a3f5c978 100644 --- a/aviary/subsystems/mass/flops_based/fuel_system.py +++ b/aviary/subsystems/mass/flops_based/fuel_system.py @@ -21,11 +21,10 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Fuel.FUEL_SYSTEM_MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.Fuel.FUEL_SYSTEM_MASS_SCALER) + add_aviary_input(self, Aircraft.Fuel.TOTAL_CAPACITY) - add_aviary_input(self, Aircraft.Fuel.TOTAL_CAPACITY, 0.0) - - add_aviary_output(self, Aircraft.Fuel.FUEL_SYSTEM_MASS, val=0.0) + add_aviary_output(self, Aircraft.Fuel.FUEL_SYSTEM_MASS) def setup_partials(self): self.declare_partials('*', '*') @@ -71,11 +70,10 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Fuel.TOTAL_CAPACITY, val=0.0) - - add_aviary_input(self, Aircraft.Fuel.FUEL_SYSTEM_MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.Fuel.TOTAL_CAPACITY) + add_aviary_input(self, Aircraft.Fuel.FUEL_SYSTEM_MASS_SCALER) - add_aviary_output(self, Aircraft.Fuel.FUEL_SYSTEM_MASS, val=0.0) + add_aviary_output(self, Aircraft.Fuel.FUEL_SYSTEM_MASS) def setup_partials(self): self.declare_partials('*', '*') diff --git a/aviary/subsystems/mass/flops_based/furnishings.py b/aviary/subsystems/mass/flops_based/furnishings.py index 3dfa8416b..b70b5af2d 100644 --- a/aviary/subsystems/mass/flops_based/furnishings.py +++ b/aviary/subsystems/mass/flops_based/furnishings.py @@ -19,15 +19,12 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Furnishings.MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.Furnishings.MASS_SCALER) + add_aviary_input(self, Aircraft.Fuselage.PASSENGER_COMPARTMENT_LENGTH) + add_aviary_input(self, Aircraft.Fuselage.MAX_WIDTH) + add_aviary_input(self, Aircraft.Fuselage.MAX_HEIGHT) - add_aviary_input(self, Aircraft.Fuselage.PASSENGER_COMPARTMENT_LENGTH, val=0.0) - - add_aviary_input(self, Aircraft.Fuselage.MAX_WIDTH, val=0.0) - - add_aviary_input(self, Aircraft.Fuselage.MAX_HEIGHT, val=0.0) - - add_aviary_output(self, Aircraft.Furnishings.MASS, val=0.0) + add_aviary_output(self, Aircraft.Furnishings.MASS) def setup_partials(self): self.declare_partials(of=Aircraft.Furnishings.MASS, wrt='*') @@ -114,19 +111,13 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Furnishings.MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.Furnishings.MASS_SCALER) + add_aviary_input(self, Aircraft.BWB.CABIN_AREA) + add_aviary_input(self, Aircraft.Fuselage.MAX_WIDTH) + add_aviary_input(self, Aircraft.Fuselage.MAX_HEIGHT) + add_aviary_input(self, Aircraft.BWB.PASSENGER_LEADING_EDGE_SWEEP) - add_aviary_input(self, Aircraft.BWB.CABIN_AREA, val=100.0) - - add_aviary_input(self, Aircraft.Fuselage.MAX_WIDTH, val=30.0) - - add_aviary_input(self, Aircraft.Fuselage.MAX_HEIGHT, val=15.0) - - add_aviary_input( - self, Aircraft.BWB.PASSENGER_LEADING_EDGE_SWEEP, val=45.0 - ) - - add_aviary_output(self, Aircraft.Furnishings.MASS, val=0.0) + add_aviary_output(self, Aircraft.Furnishings.MASS) def setup_partials(self): self.declare_partials(of=Aircraft.Furnishings.MASS, wrt='*') @@ -267,9 +258,9 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Furnishings.MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.Furnishings.MASS_SCALER) - add_aviary_output(self, Aircraft.Furnishings.MASS_BASE, val=0.0) + add_aviary_output(self, Aircraft.Furnishings.MASS_BASE) def setup_partials(self): self.declare_partials(of=Aircraft.Furnishings.MASS_BASE, wrt='*') @@ -309,15 +300,12 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Furnishings.MASS_BASE, val=0.0) - - add_aviary_input(self, Aircraft.Design.STRUCTURE_MASS, val=0.0) - - add_aviary_input(self, Aircraft.Propulsion.MASS, val=0.0) - - add_aviary_input(self, Aircraft.Design.SYSTEMS_EQUIP_MASS_BASE, val=0.0) + add_aviary_input(self, Aircraft.Furnishings.MASS_BASE) + add_aviary_input(self, Aircraft.Design.STRUCTURE_MASS) + add_aviary_input(self, Aircraft.Propulsion.MASS) + add_aviary_input(self, Aircraft.Design.SYSTEMS_EQUIP_MASS_BASE) - add_aviary_output(self, Aircraft.Furnishings.MASS, val=0.0) + add_aviary_output(self, Aircraft.Furnishings.MASS) def setup_partials(self): self.declare_partials( diff --git a/aviary/subsystems/mass/flops_based/fuselage.py b/aviary/subsystems/mass/flops_based/fuselage.py index 6b349ec20..61d6b5216 100644 --- a/aviary/subsystems/mass/flops_based/fuselage.py +++ b/aviary/subsystems/mass/flops_based/fuselage.py @@ -21,13 +21,11 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Fuselage.LENGTH, val=0.0) + add_aviary_input(self, Aircraft.Fuselage.LENGTH) + add_aviary_input(self, Aircraft.Fuselage.MASS_SCALER) + add_aviary_input(self, Aircraft.Fuselage.AVG_DIAMETER) - add_aviary_input(self, Aircraft.Fuselage.MASS_SCALER, val=1.0) - - add_aviary_input(self, Aircraft.Fuselage.AVG_DIAMETER, val=0.0) - - add_aviary_output(self, Aircraft.Fuselage.MASS, val=0.0) + add_aviary_output(self, Aircraft.Fuselage.MASS) def setup_partials(self): self.declare_partials(Aircraft.Fuselage.MASS, "*") diff --git a/aviary/subsystems/mass/flops_based/horizontal_tail.py b/aviary/subsystems/mass/flops_based/horizontal_tail.py index 3c182a5b2..9c0a2595a 100644 --- a/aviary/subsystems/mass/flops_based/horizontal_tail.py +++ b/aviary/subsystems/mass/flops_based/horizontal_tail.py @@ -18,15 +18,14 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.HorizontalTail.AREA, val=0.0) + add_aviary_input(self, Aircraft.HorizontalTail.AREA) - add_aviary_input(self, Aircraft.HorizontalTail.TAPER_RATIO, val=0.352) + add_aviary_input(self, Aircraft.HorizontalTail.TAPER_RATIO) - add_aviary_input(self, Mission.Design.GROSS_MASS, val=0.0) + add_aviary_input(self, Mission.Design.GROSS_MASS) + add_aviary_input(self, Aircraft.HorizontalTail.MASS_SCALER) - add_aviary_input(self, Aircraft.HorizontalTail.MASS_SCALER, val=1.0) - - add_aviary_output(self, Aircraft.HorizontalTail.MASS, val=0.0) + add_aviary_output(self, Aircraft.HorizontalTail.MASS) def setup_partials(self): self.declare_partials("*", "*") @@ -76,11 +75,10 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.HorizontalTail.AREA, val=0.0) - - add_aviary_input(self, Aircraft.HorizontalTail.MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.HorizontalTail.AREA) + add_aviary_input(self, Aircraft.HorizontalTail.MASS_SCALER) - add_aviary_output(self, Aircraft.HorizontalTail.MASS, val=0.0) + add_aviary_output(self, Aircraft.HorizontalTail.MASS) def setup_partials(self): self.declare_partials("*", "*") diff --git a/aviary/subsystems/mass/flops_based/hydraulics.py b/aviary/subsystems/mass/flops_based/hydraulics.py index aed93313f..ff1527e3d 100644 --- a/aviary/subsystems/mass/flops_based/hydraulics.py +++ b/aviary/subsystems/mass/flops_based/hydraulics.py @@ -28,17 +28,15 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Fuselage.PLANFORM_AREA, val=0.0) + add_aviary_input(self, Aircraft.Fuselage.PLANFORM_AREA) - add_aviary_input(self, Aircraft.Hydraulics.SYSTEM_PRESSURE, val=0.0) + add_aviary_input(self, Aircraft.Hydraulics.SYSTEM_PRESSURE) - add_aviary_input(self, Aircraft.Hydraulics.MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.Hydraulics.MASS_SCALER) + add_aviary_input(self, Aircraft.Wing.AREA) + add_aviary_input(self, Aircraft.Wing.VAR_SWEEP_MASS_PENALTY) - add_aviary_input(self, Aircraft.Wing.AREA, val=0.0) - - add_aviary_input(self, Aircraft.Wing.VAR_SWEEP_MASS_PENALTY, val=0.0) - - add_aviary_output(self, Aircraft.Hydraulics.MASS, val=0.0) + add_aviary_output(self, Aircraft.Hydraulics.MASS) def setup_partials(self): self.declare_partials('*', '*') @@ -117,17 +115,13 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Wing.AREA, val=0.0) - - add_aviary_input(self, Aircraft.HorizontalTail.WETTED_AREA, val=0.0) - - add_aviary_input(self, Aircraft.HorizontalTail.THICKNESS_TO_CHORD, val=0.0) - - add_aviary_input(self, Aircraft.VerticalTail.AREA, val=0.0) - - add_aviary_input(self, Aircraft.Hydraulics.MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.Wing.AREA) + add_aviary_input(self, Aircraft.HorizontalTail.WETTED_AREA) + add_aviary_input(self, Aircraft.HorizontalTail.THICKNESS_TO_CHORD) + add_aviary_input(self, Aircraft.VerticalTail.AREA) + add_aviary_input(self, Aircraft.Hydraulics.MASS_SCALER) - add_aviary_output(self, Aircraft.Hydraulics.MASS, val=0.0) + add_aviary_output(self, Aircraft.Hydraulics.MASS) def setup_partials(self): self.declare_partials('*', '*') diff --git a/aviary/subsystems/mass/flops_based/instruments.py b/aviary/subsystems/mass/flops_based/instruments.py index 3b0c50f84..db0efd247 100644 --- a/aviary/subsystems/mass/flops_based/instruments.py +++ b/aviary/subsystems/mass/flops_based/instruments.py @@ -23,8 +23,8 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Fuselage.PLANFORM_AREA, 0.0) - add_aviary_input(self, Aircraft.Instruments.MASS_SCALER, 1.0) + add_aviary_input(self, Aircraft.Fuselage.PLANFORM_AREA) + add_aviary_input(self, Aircraft.Instruments.MASS_SCALER) add_aviary_output(self, Aircraft.Instruments.MASS, 0.0) diff --git a/aviary/subsystems/mass/flops_based/landing_gear.py b/aviary/subsystems/mass/flops_based/landing_gear.py index db87a4aee..e5adedee2 100644 --- a/aviary/subsystems/mass/flops_based/landing_gear.py +++ b/aviary/subsystems/mass/flops_based/landing_gear.py @@ -25,19 +25,14 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.LandingGear.MAIN_GEAR_OLEO_LENGTH, val=0.0) - - add_aviary_input(self, Aircraft.LandingGear.MAIN_GEAR_MASS_SCALER, val=1.0) - - add_aviary_input(self, Aircraft.LandingGear.NOSE_GEAR_OLEO_LENGTH, val=0.0) - - add_aviary_input(self, Aircraft.LandingGear.NOSE_GEAR_MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.LandingGear.MAIN_GEAR_OLEO_LENGTH) + add_aviary_input(self, Aircraft.LandingGear.MAIN_GEAR_MASS_SCALER) + add_aviary_input(self, Aircraft.LandingGear.NOSE_GEAR_OLEO_LENGTH) + add_aviary_input(self, Aircraft.LandingGear.NOSE_GEAR_MASS_SCALER) + add_aviary_input(self, Aircraft.Design.TOUCHDOWN_MASS) - add_aviary_input(self, Aircraft.Design.TOUCHDOWN_MASS, val=0.0) - - add_aviary_output(self, Aircraft.LandingGear.MAIN_GEAR_MASS, val=0.0) - - add_aviary_output(self, Aircraft.LandingGear.NOSE_GEAR_MASS, val=0.0) + add_aviary_output(self, Aircraft.LandingGear.MAIN_GEAR_MASS) + add_aviary_output(self, Aircraft.LandingGear.NOSE_GEAR_MASS) # TODO landing weight is not a landing_gear component level variable # self.add_input('aircraft:landing_gear:weights:landing_weight', val=0.0, desc='design landing weight', units='lbf') @@ -142,19 +137,14 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.LandingGear.MAIN_GEAR_OLEO_LENGTH, val=0.0) - - add_aviary_input(self, Aircraft.LandingGear.MAIN_GEAR_MASS_SCALER, val=1.0) - - add_aviary_input(self, Aircraft.LandingGear.NOSE_GEAR_OLEO_LENGTH, val=0.0) - - add_aviary_input(self, Aircraft.LandingGear.NOSE_GEAR_MASS_SCALER, val=1.0) - - add_aviary_input(self, Mission.Design.GROSS_MASS, val=0.0) - - add_aviary_output(self, Aircraft.LandingGear.MAIN_GEAR_MASS, val=0.0) - - add_aviary_output(self, Aircraft.LandingGear.NOSE_GEAR_MASS, val=0.0) + add_aviary_input(self, Aircraft.LandingGear.MAIN_GEAR_OLEO_LENGTH) + add_aviary_input(self, Aircraft.LandingGear.MAIN_GEAR_MASS_SCALER) + add_aviary_input(self, Aircraft.LandingGear.NOSE_GEAR_OLEO_LENGTH) + add_aviary_input(self, Aircraft.LandingGear.NOSE_GEAR_MASS_SCALER) + add_aviary_input(self, Mission.Design.GROSS_MASS) + + add_aviary_output(self, Aircraft.LandingGear.MAIN_GEAR_MASS) + add_aviary_output(self, Aircraft.LandingGear.NOSE_GEAR_MASS) def setup_partials(self): self.declare_partials(Aircraft.LandingGear.MAIN_GEAR_MASS, [ From d3de229f68c8eca0af51b0d18503f5365e7d8cb8 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Fri, 20 Dec 2024 15:54:21 -0800 Subject: [PATCH 04/22] update add_aviary_input and add_aviary_output functions. --- aviary/variable_info/functions.py | 27 +++++++++++++++++++-------- 1 file changed, 19 insertions(+), 8 deletions(-) diff --git a/aviary/variable_info/functions.py b/aviary/variable_info/functions.py index 9f96833ff..a214a2e13 100644 --- a/aviary/variable_info/functions.py +++ b/aviary/variable_info/functions.py @@ -34,17 +34,21 @@ def add_aviary_input(comp, varname, val=None, units=None, desc=None, shape_by_co else: input_desc = meta['desc'] if val is None: - val = meta['default_value'] - if val is None: - if shape is None: + if shape is None: + val = meta['default_value'] + if val is None: val = 0.0 - else: + else: + val = meta['default_value'] + if val is None: val = np.zeros(shape) + else: + val = np.ones(shape) * val comp.add_input(varname, val=val, units=input_units, desc=input_desc, shape_by_conn=shape_by_conn, shape=shape) -def add_aviary_output(comp, varname, val, units=None, desc=None, shape_by_conn=False, meta_data=_MetaData): +def add_aviary_output(comp, varname, val=None, units=None, desc=None, shape_by_conn=False, meta_data=_MetaData, shape=None): ''' This function provides a clean way to add variables from the variable hierarchy into components as Aviary outputs. It takes @@ -65,9 +69,16 @@ def add_aviary_output(comp, varname, val, units=None, desc=None, shape_by_conn=F else: output_desc = meta['desc'] if val is None: - val = meta['default_value'] - if val is None: - val = 0.0 + if shape is None: + val = meta['default_value'] + if val is None: + val = 0.0 + else: + val = meta['default_value'] + if val is None: + val = np.zeros(shape) + else: + val = np.ones(shape) * val comp.add_output(varname, val=val, units=output_units, desc=output_desc, shape_by_conn=shape_by_conn) From 670b545427cac07f7d2202cb158cec9609d3fda9 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Fri, 20 Dec 2024 15:54:46 -0800 Subject: [PATCH 05/22] update variable_meta_data.py --- aviary/variable_info/variable_meta_data.py | 126 +++++++++++++-------- 1 file changed, 77 insertions(+), 49 deletions(-) diff --git a/aviary/variable_info/variable_meta_data.py b/aviary/variable_info/variable_meta_data.py index ea20de153..37be4b91d 100644 --- a/aviary/variable_info/variable_meta_data.py +++ b/aviary/variable_info/variable_meta_data.py @@ -70,7 +70,7 @@ }, units='lbm', desc='air conditioning system mass', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -122,7 +122,7 @@ }, units='lbm', desc='mass of anti-icing system (auxiliary gear)', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -163,7 +163,7 @@ }, units='lbm', desc='mass of auxiliary power unit', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -204,7 +204,7 @@ }, units='lbm', desc='avionics mass', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -493,7 +493,7 @@ }, units='lbm', desc='mass of canards', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -519,7 +519,7 @@ }, units='unitless', desc='canard theoretical taper ratio', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -645,6 +645,7 @@ }, units='lbm', desc='mass of passenger baggage', + default_value=0.0, # added ) add_meta_data( @@ -677,7 +678,7 @@ }, units='lbm', desc='mass of cargo containers', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -708,6 +709,7 @@ }, units='lbm', desc='total mass of cargo', + default_value=0.0, # added ) add_meta_data( @@ -799,7 +801,7 @@ }, units='lbm', desc='total mass of the flight crew and their baggage', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -859,7 +861,7 @@ }, units='lbm', desc='total mass of the non-flight crew and their baggage', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -1006,6 +1008,7 @@ }, units='lbm', desc='TBD: total mass of all passengers without their baggage', + default_value=0.0, # added ) add_meta_data( @@ -1029,6 +1032,7 @@ }, units='lbm', desc='mass of passenger payload, including passengers, passenger baggage', + default_value=0.0, # added ) add_meta_data( @@ -1047,7 +1051,7 @@ }, units='lbm', desc='mass of passenger service equipment', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -1241,7 +1245,7 @@ }, units='lbm', desc='empty mass margin', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -1256,7 +1260,7 @@ }, units='unitless', desc='empty mass margin scaler', - default_value=0.0, + default_value=0.0, # Note: not 1.0 here ) add_meta_data( @@ -1269,6 +1273,7 @@ meta_data=_MetaData, units='lbm', desc='total mass of all user-defined external subsystems', + default_value=0.0, # added ) add_meta_data( @@ -1347,7 +1352,7 @@ }, units='unitless', desc='ratio of maximum landing mass to maximum takeoff mass', - default_value=0.9, + default_value=0.0, ) add_meta_data( @@ -1413,6 +1418,7 @@ }, units='lbm', desc='operating mass empty of the aircraft', + default_value=0.0, # added ) add_meta_data( @@ -1489,6 +1495,7 @@ }, units='lbm', desc='Total structural group mass', + default_value=0.0, # added ) add_meta_data( @@ -1539,6 +1546,7 @@ }, units='lbm', desc='Total systems & equipment group mass', + default_value=0.0, # added ) add_meta_data( @@ -1550,6 +1558,7 @@ historical_name={"GASP": None, "FLOPS": None, "LEAPS1": None}, units='lbm', desc='Total systems & equipment group mass without additional 1% of ' 'empty mass', + default_value=0.0, # added ) add_meta_data( @@ -1574,6 +1583,7 @@ }, units='ft**2', desc='total aircraft wetted area', + default_value=0.0, # added ) add_meta_data( @@ -1595,7 +1605,7 @@ }, units='lbm', desc='design landing mass', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -1656,6 +1666,7 @@ }, units='lbm', desc='zero fuel mass', + default_value=0.0, # added ) add_meta_data( @@ -1715,7 +1726,7 @@ }, units='lbm', desc='mass of the electrical system', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -2558,7 +2569,7 @@ }, units='lbm', desc='mass of vertical fins', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -2599,7 +2610,7 @@ }, units='unitless', desc='vertical fin theoretical taper ratio', - default_value=None, + default_value=0.0, # changed from None ) # ______ _ @@ -2620,7 +2631,7 @@ }, units='lbm', desc='fuel capacity of the auxiliary tank', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -2641,7 +2652,7 @@ }, units='unitless', desc='fuel capacity factor', - default_value=23.0, + default_value=1.0, # changed from 23.0 ) add_meta_data( @@ -2695,7 +2706,7 @@ }, units='lbm', desc='fuel system mass', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -2734,7 +2745,7 @@ }, units='lbm', desc='fuel capacity of the fuselage', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -2767,7 +2778,7 @@ desc='Total fuel capacity of the aircraft including wing, fuselage and ' 'auxiliary tanks. Used in generating payload-range diagram (Default = ' 'wing_capacity + fuselage_capacity + aux_capacity)', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -2785,6 +2796,7 @@ }, units='galUS', # need to check this desc='Total fuel volume', + default_value=0.0, # added ) add_meta_data( @@ -2803,7 +2815,7 @@ }, units='lbm', desc='unusable fuel mass', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -2839,7 +2851,7 @@ }, units='lbm', desc='fuel capacity of the auxiliary tank', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -2968,7 +2980,7 @@ }, units='lbm', desc='Total furnishings system mass', - default_value=None, + default_value=0.0, # changed form None ) add_meta_data( @@ -2977,6 +2989,7 @@ historical_name={"GASP": None, "FLOPS": None, "LEAPS1": None}, units='lbm', desc='Base furnishings system mass without additional 1% empty mass', + default_value=0.0, # added ) add_meta_data( @@ -3025,6 +3038,7 @@ }, units='ft', desc='average fuselage diameter', + default_value=0.0, # added ) add_meta_data( @@ -3187,7 +3201,7 @@ }, units='lbm', desc='mass of the fuselage structure', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -3222,6 +3236,7 @@ }, units='ft', desc='maximum fuselage height', + default_value=0.0, # added ) add_meta_data( @@ -3351,6 +3366,7 @@ }, units='ft**2', desc='fuselage planform area', + default_value=0.0, # added ) add_meta_data( @@ -3408,7 +3424,7 @@ }, units='ft**2', desc='fuselage wetted area', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -3551,7 +3567,7 @@ }, units='lbm', desc='mass of horizontal tail', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -3691,7 +3707,7 @@ }, units='ft**2', desc='horizontal tail wetted area', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -3751,7 +3767,7 @@ }, units='lbm', desc='mass of hydraulic system', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -3806,7 +3822,7 @@ }, units='lbm', desc='instrument group mass', - default_value=None, + default_value=0.0, ) add_meta_data( @@ -3907,6 +3923,7 @@ }, units='lbm', desc='mass of main landing gear', + default_value=0, # added ) add_meta_data( @@ -3968,7 +3985,7 @@ }, units='lbm', desc='mass of nose landing gear', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -4046,6 +4063,7 @@ }, units='ft', desc='Average diameter of engine nacelles for each engine model', + default_value=0.0, # added ) add_meta_data( @@ -4060,6 +4078,7 @@ }, units='ft', desc='Average length of nacelles for each engine model', + default_value=0.0, # added ) add_meta_data( @@ -4161,7 +4180,7 @@ }, units='lbm', desc='estimated mass of the nacelles for each engine model', - default_value=None, + default_value=0.0, ) add_meta_data( @@ -4256,6 +4275,7 @@ }, units='lbm', desc='mass of paint for all wetted area', + default_value=0.0, # added ) add_meta_data( @@ -4310,6 +4330,7 @@ }, units='lbm', desc='Total propulsion group mass', + default_value=0.0, # added ) # TODO clash with per-engine scaling, need to resolve w/ heterogeneous engine @@ -4334,6 +4355,7 @@ historical_name={"GASP": None, "FLOPS": None, "LEAPS1": None}, units='lbm', desc='total estimated mass of the engine controls for all engines on aircraft', + default_value=0.0, # added ) add_meta_data( @@ -4342,6 +4364,7 @@ historical_name={"GASP": 'INGASP.WEP', "FLOPS": None, "LEAPS1": None}, units='lbm', desc='total mass of all engines on aircraft', + default_value=0.0, # added ) add_meta_data( @@ -4360,7 +4383,7 @@ }, units='lbm', desc='engine oil mass', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -4380,7 +4403,7 @@ units='lbm', desc='sum of engine control, starter, and additional mass for all engines ' 'on aircraft', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -4452,7 +4475,7 @@ historical_name={"GASP": None, "FLOPS": None, "LEAPS1": None}, units='lbm', desc='total mass of thrust reversers for all engines on aircraft', - default_value=None, + default_value=0.0, # changed from None ) # _____ _ _ @@ -4716,7 +4739,7 @@ }, units='lbm', desc='mass of vertical tail', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -4813,7 +4836,7 @@ }, units='unitless', desc='vertical tail theoretical taper ratio', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -4984,6 +5007,7 @@ }, units='unitless', desc='Reference aspect ratio, used for detailed wing bending.', + default_value=0.0, # added ) add_meta_data( @@ -5004,6 +5028,7 @@ }, units='unitless', desc='wing bending factor', + default_value=0.0, # added ) add_meta_data( @@ -5018,7 +5043,7 @@ }, units='lbm', desc='wing mass breakdown term 1', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -5046,7 +5071,7 @@ }, units='lbm', desc='wing mass breakdown term 4', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -5118,7 +5143,7 @@ units='unitless', desc='chord lengths as fractions of semispan at station locations; ' 'overwrites station_chord_lengths', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -5153,6 +5178,7 @@ }, units='ft**2', desc='area of wing control surfaces', + default_value=0.0, # added ) add_meta_data( @@ -5167,7 +5193,7 @@ units='unitless', desc='Defines the ratio of total moveable wing control surface areas ' '(flaps, elevators, spoilers, etc.) to reference wing area.', - default_value=0.333, + default_value=0.0, # changed from 0.333 ) add_meta_data( @@ -5208,6 +5234,7 @@ }, units='unitless', desc='engine inertia relief factor', + default_value=0.0, # added ) add_meta_data( @@ -5523,7 +5550,7 @@ desc='Define the sweep of load path at station locations. Typically ' 'parallel to rear spar tending toward max t/c of airfoil. The Ith value ' 'is used between wing stations I and I+1.', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -5565,7 +5592,7 @@ }, units='lbm', desc='wing total mass', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -5674,7 +5701,7 @@ }, units='lbm', desc='wing mass breakdown term 3', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -5766,7 +5793,7 @@ }, units='lbm', desc='wing mass breakdown term 2', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -5893,7 +5920,7 @@ }, units='lbm', desc='mass of surface controls', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -6005,7 +6032,7 @@ }, units='unitless', desc='the thickeness-chord ratios at station locations', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -6703,6 +6730,7 @@ units='lbm', desc='fuel carried by the aircraft when it is on the ramp at the ' 'beginning of the design mission', + default_value=0.0, # added ) add_meta_data( @@ -6733,7 +6761,7 @@ }, units='lbm', desc='design gross mass of the aircraft', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( From a8b5456d0e07988e5ba3ca06c24273897cb9ce80 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Fri, 20 Dec 2024 15:56:58 -0800 Subject: [PATCH 06/22] work in progress. --- aviary/subsystems/mass/flops_based/cargo.py | 3 +- .../mass/flops_based/fuel_capacity.py | 4 +- .../mass/flops_based/furnishings.py | 2 + .../mass/flops_based/horizontal_tail.py | 4 +- .../subsystems/mass/flops_based/hydraulics.py | 2 - .../mass/flops_based/landing_gear.py | 18 +-- .../mass/flops_based/landing_mass.py | 14 +- .../mass/flops_based/mass_summation.py | 143 +++++++++--------- .../mass/flops_based/misc_engine.py | 12 +- aviary/subsystems/mass/flops_based/nacelle.py | 17 +-- aviary/subsystems/mass/flops_based/paint.py | 7 +- .../mass/flops_based/passenger_service.py | 19 +-- aviary/subsystems/mass/flops_based/starter.py | 5 +- .../mass/flops_based/surface_controls.py | 10 +- .../mass/flops_based/test/test_furnishings.py | 17 ++- .../mass/flops_based/test/test_wing_common.py | 1 + .../mass/flops_based/thrust_reverser.py | 8 +- .../mass/flops_based/unusable_fuel.py | 21 +-- .../mass/flops_based/vertical_tail.py | 9 +- .../mass/flops_based/wing_common.py | 73 ++++----- .../mass/flops_based/wing_detailed.py | 40 ++--- .../mass/flops_based/wing_simple.py | 30 ++-- 22 files changed, 202 insertions(+), 257 deletions(-) diff --git a/aviary/subsystems/mass/flops_based/cargo.py b/aviary/subsystems/mass/flops_based/cargo.py index ad047f6e7..6d0e4738c 100644 --- a/aviary/subsystems/mass/flops_based/cargo.py +++ b/aviary/subsystems/mass/flops_based/cargo.py @@ -7,7 +7,7 @@ from aviary.utils.aviary_values import AviaryValues from aviary.variable_info.functions import add_aviary_input, add_aviary_output -from aviary.variable_info.variables import Aircraft, Mission +from aviary.variable_info.variables import Aircraft class CargoMass(om.ExplicitComponent): @@ -24,7 +24,6 @@ def initialize(self): def setup(self): add_aviary_input(self, Aircraft.CrewPayload.WING_CARGO) add_aviary_input(self, Aircraft.CrewPayload.MISC_CARGO) - add_aviary_output(self, Aircraft.CrewPayload.PASSENGER_MASS) add_aviary_output(self, Aircraft.CrewPayload.BAGGAGE_MASS) add_aviary_output(self, Aircraft.CrewPayload.PASSENGER_PAYLOAD_MASS) diff --git a/aviary/subsystems/mass/flops_based/fuel_capacity.py b/aviary/subsystems/mass/flops_based/fuel_capacity.py index dca9358ad..02db66343 100644 --- a/aviary/subsystems/mass/flops_based/fuel_capacity.py +++ b/aviary/subsystems/mass/flops_based/fuel_capacity.py @@ -137,9 +137,7 @@ def setup(self): add_aviary_input(self, Aircraft.Fuel.WING_REF_CAPACITY_AREA) add_aviary_input(self, Aircraft.Fuel.WING_REF_CAPACITY_TERM_A) add_aviary_input(self, Aircraft.Fuel.WING_REF_CAPACITY_TERM_B) - - add_aviary_input(self, Aircraft.Fuel.CAPACITY_FACTOR, 23.0) - + add_aviary_input(self, Aircraft.Fuel.CAPACITY_FACTOR) add_aviary_input(self, Aircraft.Wing.AREA) add_aviary_input(self, Aircraft.Wing.SPAN) add_aviary_input(self, Aircraft.Wing.TAPER_RATIO) diff --git a/aviary/subsystems/mass/flops_based/furnishings.py b/aviary/subsystems/mass/flops_based/furnishings.py index b70b5af2d..5bc5d22b2 100644 --- a/aviary/subsystems/mass/flops_based/furnishings.py +++ b/aviary/subsystems/mass/flops_based/furnishings.py @@ -113,7 +113,9 @@ def initialize(self): def setup(self): add_aviary_input(self, Aircraft.Furnishings.MASS_SCALER) add_aviary_input(self, Aircraft.BWB.CABIN_AREA) + add_aviary_input(self, Aircraft.Fuselage.MAX_WIDTH) + add_aviary_input(self, Aircraft.Fuselage.MAX_HEIGHT) add_aviary_input(self, Aircraft.BWB.PASSENGER_LEADING_EDGE_SWEEP) diff --git a/aviary/subsystems/mass/flops_based/horizontal_tail.py b/aviary/subsystems/mass/flops_based/horizontal_tail.py index 9c0a2595a..9665aac32 100644 --- a/aviary/subsystems/mass/flops_based/horizontal_tail.py +++ b/aviary/subsystems/mass/flops_based/horizontal_tail.py @@ -19,9 +19,7 @@ def initialize(self): def setup(self): add_aviary_input(self, Aircraft.HorizontalTail.AREA) - - add_aviary_input(self, Aircraft.HorizontalTail.TAPER_RATIO) - + add_aviary_input(self, Aircraft.HorizontalTail.TAPER_RATIO, val=0.352) add_aviary_input(self, Mission.Design.GROSS_MASS) add_aviary_input(self, Aircraft.HorizontalTail.MASS_SCALER) diff --git a/aviary/subsystems/mass/flops_based/hydraulics.py b/aviary/subsystems/mass/flops_based/hydraulics.py index ff1527e3d..60b699237 100644 --- a/aviary/subsystems/mass/flops_based/hydraulics.py +++ b/aviary/subsystems/mass/flops_based/hydraulics.py @@ -29,9 +29,7 @@ def initialize(self): def setup(self): add_aviary_input(self, Aircraft.Fuselage.PLANFORM_AREA) - add_aviary_input(self, Aircraft.Hydraulics.SYSTEM_PRESSURE) - add_aviary_input(self, Aircraft.Hydraulics.MASS_SCALER) add_aviary_input(self, Aircraft.Wing.AREA) add_aviary_input(self, Aircraft.Wing.VAR_SWEEP_MASS_PENALTY) diff --git a/aviary/subsystems/mass/flops_based/landing_gear.py b/aviary/subsystems/mass/flops_based/landing_gear.py index e5adedee2..0f1313b12 100644 --- a/aviary/subsystems/mass/flops_based/landing_gear.py +++ b/aviary/subsystems/mass/flops_based/landing_gear.py @@ -251,8 +251,8 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.LandingGear.MAIN_GEAR_OLEO_LENGTH, val=0.0) - add_aviary_output(self, Aircraft.LandingGear.NOSE_GEAR_OLEO_LENGTH, val=0.0) + add_aviary_input(self, Aircraft.LandingGear.MAIN_GEAR_OLEO_LENGTH) + add_aviary_output(self, Aircraft.LandingGear.NOSE_GEAR_OLEO_LENGTH) def setup_partials(self): self.declare_partials(Aircraft.LandingGear.NOSE_GEAR_OLEO_LENGTH, @@ -280,16 +280,16 @@ def setup(self): num_wing_engines = self.options['aviary_options'].get_val( Aircraft.Engine.NUM_WING_ENGINES) - add_aviary_input(self, Aircraft.Fuselage.LENGTH, val=0.0) - add_aviary_input(self, Aircraft.Fuselage.MAX_WIDTH, val=0.0) - add_aviary_input(self, Aircraft.Nacelle.AVG_DIAMETER, - val=np.zeros(num_engine_type)) + add_aviary_input(self, Aircraft.Fuselage.LENGTH) + add_aviary_input(self, Aircraft.Fuselage.MAX_WIDTH) + add_aviary_input(self, Aircraft.Nacelle.AVG_DIAMETER, shape=num_engine_type) + # XJ: shape=(num_engine_type, int(num_wing_engines[0]/2)) add_aviary_input(self, Aircraft.Engine.WING_LOCATIONS, val=np.zeros((num_engine_type, int(num_wing_engines[0]/2)))) - add_aviary_input(self, Aircraft.Wing.DIHEDRAL, val=0.0) - add_aviary_input(self, Aircraft.Wing.SPAN, val=0.0) + add_aviary_input(self, Aircraft.Wing.DIHEDRAL) + add_aviary_input(self, Aircraft.Wing.SPAN) - add_aviary_output(self, Aircraft.LandingGear.MAIN_GEAR_OLEO_LENGTH, val=0.0) + add_aviary_output(self, Aircraft.LandingGear.MAIN_GEAR_OLEO_LENGTH) def setup_partials(self): self.declare_partials('*', '*') diff --git a/aviary/subsystems/mass/flops_based/landing_mass.py b/aviary/subsystems/mass/flops_based/landing_mass.py index c34686fbe..d24324a79 100644 --- a/aviary/subsystems/mass/flops_based/landing_mass.py +++ b/aviary/subsystems/mass/flops_based/landing_mass.py @@ -17,11 +17,10 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Mission.Summary.CRUISE_MACH, val=0.0) + add_aviary_input(self, Mission.Summary.CRUISE_MACH) + add_aviary_input(self, Mission.Design.RANGE) - add_aviary_input(self, Mission.Design.RANGE, val=0.0) - - add_aviary_output(self, Aircraft.Design.LANDING_TO_TAKEOFF_MASS_RATIO, val=0.0) + add_aviary_output(self, Aircraft.Design.LANDING_TO_TAKEOFF_MASS_RATIO) def setup_partials(self): self.declare_partials('*', '*') @@ -64,11 +63,10 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Mission.Design.GROSS_MASS, val=0.0) - - add_aviary_input(self, Aircraft.Design.LANDING_TO_TAKEOFF_MASS_RATIO, val=0.0) + add_aviary_input(self, Mission.Design.GROSS_MASS) + add_aviary_input(self, Aircraft.Design.LANDING_TO_TAKEOFF_MASS_RATIO) - add_aviary_output(self, Aircraft.Design.TOUCHDOWN_MASS, val=0.0) + add_aviary_output(self, Aircraft.Design.TOUCHDOWN_MASS) def setup_partials(self): self.declare_partials('*', '*') diff --git a/aviary/subsystems/mass/flops_based/mass_summation.py b/aviary/subsystems/mass/flops_based/mass_summation.py index d1294985e..0fdab13c3 100644 --- a/aviary/subsystems/mass/flops_based/mass_summation.py +++ b/aviary/subsystems/mass/flops_based/mass_summation.py @@ -87,18 +87,18 @@ def setup(self): num_engine_type = len(self.options['aviary_options'].get_val( Aircraft.Engine.NUM_ENGINES)) - add_aviary_input(self, Aircraft.Canard.MASS, val=0.0) - add_aviary_input(self, Aircraft.Fins.MASS, val=0.0) - add_aviary_input(self, Aircraft.Fuselage.MASS, val=0.0) - add_aviary_input(self, Aircraft.HorizontalTail.MASS, val=0.0) - add_aviary_input(self, Aircraft.LandingGear.MAIN_GEAR_MASS, val=0.0) - add_aviary_input(self, Aircraft.LandingGear.NOSE_GEAR_MASS, val=0.0) - add_aviary_input(self, Aircraft.Nacelle.MASS, val=np.zeros(num_engine_type)) - add_aviary_input(self, Aircraft.Paint.MASS, val=0.0) - add_aviary_input(self, Aircraft.VerticalTail.MASS, val=0.0) - add_aviary_input(self, Aircraft.Wing.MASS, val=0.0) - - add_aviary_output(self, Aircraft.Design.STRUCTURE_MASS, val=0.0) + add_aviary_input(self, Aircraft.Canard.MASS) + add_aviary_input(self, Aircraft.Fins.MASS) + add_aviary_input(self, Aircraft.Fuselage.MASS) + add_aviary_input(self, Aircraft.HorizontalTail.MASS) + add_aviary_input(self, Aircraft.LandingGear.MAIN_GEAR_MASS) + add_aviary_input(self, Aircraft.LandingGear.NOSE_GEAR_MASS) + add_aviary_input(self, Aircraft.Nacelle.MASS, shape=num_engine_type) + add_aviary_input(self, Aircraft.Paint.MASS) + add_aviary_input(self, Aircraft.VerticalTail.MASS) + add_aviary_input(self, Aircraft.Wing.MASS) + + add_aviary_output(self, Aircraft.Design.STRUCTURE_MASS) def setup_partials(self): num_engine_type = len(self.options['aviary_options'].get_val( @@ -133,13 +133,12 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Fuel.FUEL_SYSTEM_MASS, val=0.0) - add_aviary_input(self, Aircraft.Propulsion.TOTAL_MISC_MASS, val=0.0) - add_aviary_input( - self, Aircraft.Propulsion.TOTAL_THRUST_REVERSERS_MASS, val=0.0) - add_aviary_input(self, Aircraft.Propulsion.TOTAL_ENGINE_MASS, val=0.0) + add_aviary_input(self, Aircraft.Fuel.FUEL_SYSTEM_MASS) + add_aviary_input(self, Aircraft.Propulsion.TOTAL_MISC_MASS) + add_aviary_input(self, Aircraft.Propulsion.TOTAL_THRUST_REVERSERS_MASS) + add_aviary_input(self, Aircraft.Propulsion.TOTAL_ENGINE_MASS) - add_aviary_output(self, Aircraft.Propulsion.MASS, val=0.0) + add_aviary_output(self, Aircraft.Propulsion.MASS) def setup_partials(self): prop_wrt = [ @@ -168,18 +167,18 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.AirConditioning.MASS, val=0.0) - add_aviary_input(self, Aircraft.AntiIcing.MASS, val=0.0) - add_aviary_input(self, Aircraft.APU.MASS, val=0.0) - add_aviary_input(self, Aircraft.Avionics.MASS, val=0.0) - add_aviary_input(self, Aircraft.Electrical.MASS, val=0.0) - add_aviary_input(self, Aircraft.Furnishings.MASS, val=0.0) - add_aviary_input(self, Aircraft.Hydraulics.MASS, val=0.0) - add_aviary_input(self, Aircraft.Instruments.MASS, val=0.0) - add_aviary_input(self, Aircraft.Wing.SURFACE_CONTROL_MASS, val=0.0) - add_aviary_input(self, Aircraft.Design.EXTERNAL_SUBSYSTEMS_MASS, val=0.0) - - add_aviary_output(self, Aircraft.Design.SYSTEMS_EQUIP_MASS, val=0.0) + add_aviary_input(self, Aircraft.AirConditioning.MASS) + add_aviary_input(self, Aircraft.AntiIcing.MASS) + add_aviary_input(self, Aircraft.APU.MASS) + add_aviary_input(self, Aircraft.Avionics.MASS) + add_aviary_input(self, Aircraft.Electrical.MASS) + add_aviary_input(self, Aircraft.Furnishings.MASS) + add_aviary_input(self, Aircraft.Hydraulics.MASS) + add_aviary_input(self, Aircraft.Instruments.MASS) + add_aviary_input(self, Aircraft.Wing.SURFACE_CONTROL_MASS) + add_aviary_input(self, Aircraft.Design.EXTERNAL_SUBSYSTEMS_MASS) + + add_aviary_output(self, Aircraft.Design.SYSTEMS_EQUIP_MASS) def setup_partials(self): self.declare_partials(Aircraft.Design.SYSTEMS_EQUIP_MASS, '*', val=1) @@ -210,18 +209,18 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.AirConditioning.MASS, val=0.0) - add_aviary_input(self, Aircraft.AntiIcing.MASS, val=0.0) - add_aviary_input(self, Aircraft.APU.MASS, val=0.0) - add_aviary_input(self, Aircraft.Avionics.MASS, val=0.0) - add_aviary_input(self, Aircraft.Electrical.MASS, val=0.0) - add_aviary_input(self, Aircraft.Furnishings.MASS_BASE, val=0.0) - add_aviary_input(self, Aircraft.Hydraulics.MASS, val=0.0) - add_aviary_input(self, Aircraft.Instruments.MASS, val=0.0) - add_aviary_input(self, Aircraft.Wing.SURFACE_CONTROL_MASS, val=0.0) - add_aviary_input(self, Aircraft.Design.EXTERNAL_SUBSYSTEMS_MASS, val=0.0) - - add_aviary_output(self, Aircraft.Design.SYSTEMS_EQUIP_MASS_BASE, val=0.0) + add_aviary_input(self, Aircraft.AirConditioning.MASS) + add_aviary_input(self, Aircraft.AntiIcing.MASS) + add_aviary_input(self, Aircraft.APU.MASS) + add_aviary_input(self, Aircraft.Avionics.MASS) + add_aviary_input(self, Aircraft.Electrical.MASS) + add_aviary_input(self, Aircraft.Furnishings.MASS_BASE) + add_aviary_input(self, Aircraft.Hydraulics.MASS) + add_aviary_input(self, Aircraft.Instruments.MASS) + add_aviary_input(self, Aircraft.Wing.SURFACE_CONTROL_MASS) + add_aviary_input(self, Aircraft.Design.EXTERNAL_SUBSYSTEMS_MASS) + + add_aviary_output(self, Aircraft.Design.SYSTEMS_EQUIP_MASS_BASE) def setup_partials(self): self.declare_partials(Aircraft.Design.SYSTEMS_EQUIP_MASS_BASE, '*', val=1) @@ -252,11 +251,11 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Design.SYSTEMS_EQUIP_MASS_BASE, val=0.0) - add_aviary_input(self, Aircraft.Design.STRUCTURE_MASS, val=0.0) - add_aviary_input(self, Aircraft.Propulsion.MASS, val=0.0) + add_aviary_input(self, Aircraft.Design.SYSTEMS_EQUIP_MASS_BASE) + add_aviary_input(self, Aircraft.Design.STRUCTURE_MASS) + add_aviary_input(self, Aircraft.Propulsion.MASS) - add_aviary_output(self, Aircraft.Design.SYSTEMS_EQUIP_MASS, val=0.0) + add_aviary_output(self, Aircraft.Design.SYSTEMS_EQUIP_MASS) def setup_partials(self): self.declare_partials( @@ -289,12 +288,12 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Design.EMPTY_MASS_MARGIN, val=0.0) - add_aviary_input(self, Aircraft.Design.STRUCTURE_MASS, val=0.0) - add_aviary_input(self, Aircraft.Propulsion.MASS, val=0.0) - add_aviary_input(self, Aircraft.Design.SYSTEMS_EQUIP_MASS, val=0.0) + add_aviary_input(self, Aircraft.Design.EMPTY_MASS_MARGIN) + add_aviary_input(self, Aircraft.Design.STRUCTURE_MASS) + add_aviary_input(self, Aircraft.Propulsion.MASS) + add_aviary_input(self, Aircraft.Design.SYSTEMS_EQUIP_MASS) - add_aviary_output(self, Aircraft.Design.EMPTY_MASS, val=0.0) + add_aviary_output(self, Aircraft.Design.EMPTY_MASS) def setup_partials(self): self.declare_partials(Aircraft.Design.EMPTY_MASS, '*', val=1) @@ -317,12 +316,12 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Design.EMPTY_MASS_MARGIN, val=0.0) - add_aviary_input(self, Aircraft.Design.STRUCTURE_MASS, val=0.0) - add_aviary_input(self, Aircraft.Propulsion.MASS, val=0.0) - add_aviary_input(self, Aircraft.Design.SYSTEMS_EQUIP_MASS_BASE, val=0.0) + add_aviary_input(self, Aircraft.Design.EMPTY_MASS_MARGIN) + add_aviary_input(self, Aircraft.Design.STRUCTURE_MASS) + add_aviary_input(self, Aircraft.Propulsion.MASS) + add_aviary_input(self, Aircraft.Design.SYSTEMS_EQUIP_MASS_BASE) - add_aviary_output(self, Aircraft.Design.EMPTY_MASS, val=0.0) + add_aviary_output(self, Aircraft.Design.EMPTY_MASS) def setup_partials(self): self.declare_partials(Aircraft.Design.EMPTY_MASS, @@ -352,15 +351,15 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.CrewPayload.CARGO_CONTAINER_MASS, val=0.0) - add_aviary_input(self, Aircraft.CrewPayload.NON_FLIGHT_CREW_MASS, val=0.0) - add_aviary_input(self, Aircraft.CrewPayload.FLIGHT_CREW_MASS, val=0.0) - add_aviary_input(self, Aircraft.CrewPayload.PASSENGER_SERVICE_MASS, val=0.0) - add_aviary_input(self, Aircraft.Design.EMPTY_MASS, val=0.0) - add_aviary_input(self, Aircraft.Fuel.UNUSABLE_FUEL_MASS, val=0.0) - add_aviary_input(self, Aircraft.Propulsion.TOTAL_ENGINE_OIL_MASS, val=0.0) + add_aviary_input(self, Aircraft.CrewPayload.CARGO_CONTAINER_MASS) + add_aviary_input(self, Aircraft.CrewPayload.NON_FLIGHT_CREW_MASS) + add_aviary_input(self, Aircraft.CrewPayload.FLIGHT_CREW_MASS) + add_aviary_input(self, Aircraft.CrewPayload.PASSENGER_SERVICE_MASS) + add_aviary_input(self, Aircraft.Design.EMPTY_MASS) + add_aviary_input(self, Aircraft.Fuel.UNUSABLE_FUEL_MASS) + add_aviary_input(self, Aircraft.Propulsion.TOTAL_ENGINE_OIL_MASS) - add_aviary_output(self, Aircraft.Design.OPERATING_MASS, val=0.0) + add_aviary_output(self, Aircraft.Design.OPERATING_MASS) def setup_partials(self): self.declare_partials(Aircraft.Design.OPERATING_MASS, '*', val=1) @@ -387,12 +386,12 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.CrewPayload.PASSENGER_MASS, val=0.0) - add_aviary_input(self, Aircraft.CrewPayload.BAGGAGE_MASS, val=0.0) - add_aviary_input(self, Aircraft.CrewPayload.CARGO_MASS, val=0.0) - add_aviary_input(self, Aircraft.Design.OPERATING_MASS, val=0.0) + add_aviary_input(self, Aircraft.CrewPayload.PASSENGER_MASS) + add_aviary_input(self, Aircraft.CrewPayload.BAGGAGE_MASS) + add_aviary_input(self, Aircraft.CrewPayload.CARGO_MASS) + add_aviary_input(self, Aircraft.Design.OPERATING_MASS) - add_aviary_output(self, Aircraft.Design.ZERO_FUEL_MASS, val=0.0) + add_aviary_output(self, Aircraft.Design.ZERO_FUEL_MASS) def setup_partials(self): self.declare_partials(Aircraft.Design.ZERO_FUEL_MASS, '*', val=1) @@ -415,10 +414,10 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Mission.Design.GROSS_MASS, val=0.0) - add_aviary_input(self, Aircraft.Design.ZERO_FUEL_MASS, val=0.0) + add_aviary_input(self, Mission.Design.GROSS_MASS) + add_aviary_input(self, Aircraft.Design.ZERO_FUEL_MASS) - add_aviary_output(self, Mission.Design.FUEL_MASS, val=0.0) + add_aviary_output(self, Mission.Design.FUEL_MASS) def setup_partials(self): self.declare_partials(Mission.Design.FUEL_MASS, diff --git a/aviary/subsystems/mass/flops_based/misc_engine.py b/aviary/subsystems/mass/flops_based/misc_engine.py index dba079072..9d2436515 100644 --- a/aviary/subsystems/mass/flops_based/misc_engine.py +++ b/aviary/subsystems/mass/flops_based/misc_engine.py @@ -1,6 +1,5 @@ import numpy as np import openmdao.api as om -import numpy as np from aviary.utils.aviary_values import AviaryValues from aviary.variable_info.functions import add_aviary_input, add_aviary_output @@ -28,13 +27,12 @@ def setup(self): num_engine_type = len(self.options['aviary_options'].get_val( Aircraft.Engine.NUM_ENGINES)) - add_aviary_input( - self, Aircraft.Engine.ADDITIONAL_MASS, val=np.zeros(num_engine_type)) - add_aviary_input(self, Aircraft.Propulsion.MISC_MASS_SCALER, val=0.0) - add_aviary_input(self, Aircraft.Propulsion.TOTAL_ENGINE_CONTROLS_MASS, val=0.0) - add_aviary_input(self, Aircraft.Propulsion.TOTAL_STARTER_MASS, val=0.0) + add_aviary_input(self, Aircraft.Engine.ADDITIONAL_MASS, shape=num_engine_type) + add_aviary_input(self, Aircraft.Propulsion.MISC_MASS_SCALER) + add_aviary_input(self, Aircraft.Propulsion.TOTAL_ENGINE_CONTROLS_MASS) + add_aviary_input(self, Aircraft.Propulsion.TOTAL_STARTER_MASS) - add_aviary_output(self, Aircraft.Propulsion.TOTAL_MISC_MASS, val=0.0) + add_aviary_output(self, Aircraft.Propulsion.TOTAL_MISC_MASS) self.declare_partials( of=Aircraft.Propulsion.TOTAL_MISC_MASS, diff --git a/aviary/subsystems/mass/flops_based/nacelle.py b/aviary/subsystems/mass/flops_based/nacelle.py index 398d8f0af..7cf64d7d9 100644 --- a/aviary/subsystems/mass/flops_based/nacelle.py +++ b/aviary/subsystems/mass/flops_based/nacelle.py @@ -29,19 +29,12 @@ def setup(self): num_engine_type = len(self.options['aviary_options'].get_val( Aircraft.Engine.NUM_ENGINES)) - add_aviary_input(self, Aircraft.Nacelle.AVG_DIAMETER, - val=np.zeros(num_engine_type)) + add_aviary_input(self, Aircraft.Nacelle.AVG_DIAMETER, shape=num_engine_type) + add_aviary_input(self, Aircraft.Nacelle.AVG_LENGTH, shape=num_engine_type) + add_aviary_input(self, Aircraft.Nacelle.MASS_SCALER, shape=num_engine_type) + add_aviary_input(self, Aircraft.Engine.SCALED_SLS_THRUST, shape=num_engine_type) - add_aviary_input(self, Aircraft.Nacelle.AVG_LENGTH, - val=np.zeros(num_engine_type)) - - add_aviary_input(self, Aircraft.Nacelle.MASS_SCALER, - val=np.ones(num_engine_type)) - - add_aviary_input(self, Aircraft.Engine.SCALED_SLS_THRUST, - val=np.zeros(num_engine_type)) - - add_aviary_output(self, Aircraft.Nacelle.MASS, val=np.zeros(num_engine_type)) + add_aviary_output(self, Aircraft.Nacelle.MASS, shape=num_engine_type) def setup_partials(self): # derivatives w.r.t vectorized engine inputs have known sparsity pattern diff --git a/aviary/subsystems/mass/flops_based/paint.py b/aviary/subsystems/mass/flops_based/paint.py index 7e1df471a..211287d0c 100644 --- a/aviary/subsystems/mass/flops_based/paint.py +++ b/aviary/subsystems/mass/flops_based/paint.py @@ -16,11 +16,10 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Design.TOTAL_WETTED_AREA, val=0.0) + add_aviary_input(self, Aircraft.Design.TOTAL_WETTED_AREA) + add_aviary_input(self, Aircraft.Paint.MASS_PER_UNIT_AREA) - add_aviary_input(self, Aircraft.Paint.MASS_PER_UNIT_AREA, val=0.0) - - add_aviary_output(self, Aircraft.Paint.MASS, val=0.0) + add_aviary_output(self, Aircraft.Paint.MASS) def setup_partials(self): self.declare_partials('*', '*') diff --git a/aviary/subsystems/mass/flops_based/passenger_service.py b/aviary/subsystems/mass/flops_based/passenger_service.py index 7d1688085..ceddd868d 100644 --- a/aviary/subsystems/mass/flops_based/passenger_service.py +++ b/aviary/subsystems/mass/flops_based/passenger_service.py @@ -23,23 +23,10 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input( - self, - Aircraft.CrewPayload.PASSENGER_SERVICE_MASS_SCALER, - val=1., - ) + add_aviary_input(self, Aircraft.CrewPayload.PASSENGER_SERVICE_MASS_SCALER) + add_aviary_input(self, Mission.Design.RANGE) - add_aviary_input( - self, - Mission.Design.RANGE, - val=0.0, - ) - - add_aviary_output( - self, - Aircraft.CrewPayload.PASSENGER_SERVICE_MASS, - val=0.0, - ) + add_aviary_output(self, Aircraft.CrewPayload.PASSENGER_SERVICE_MASS) def setup_partials(self): self.declare_partials('*', '*') diff --git a/aviary/subsystems/mass/flops_based/starter.py b/aviary/subsystems/mass/flops_based/starter.py index e7b06a4d9..49eec2bc9 100644 --- a/aviary/subsystems/mass/flops_based/starter.py +++ b/aviary/subsystems/mass/flops_based/starter.py @@ -25,10 +25,9 @@ def setup(self): num_engine_type = len(self.options['aviary_options'].get_val( Aircraft.Engine.NUM_ENGINES)) - add_aviary_input(self, Aircraft.Nacelle.AVG_DIAMETER, - val=np.zeros(num_engine_type)) + add_aviary_input(self, Aircraft.Nacelle.AVG_DIAMETER, shape=num_engine_type) - add_aviary_output(self, Aircraft.Propulsion.TOTAL_STARTER_MASS, val=0.0) + add_aviary_output(self, Aircraft.Propulsion.TOTAL_STARTER_MASS) def setup_partials(self): self.declare_partials("*", "*") diff --git a/aviary/subsystems/mass/flops_based/surface_controls.py b/aviary/subsystems/mass/flops_based/surface_controls.py index 441a7fcde..b3207eda0 100644 --- a/aviary/subsystems/mass/flops_based/surface_controls.py +++ b/aviary/subsystems/mass/flops_based/surface_controls.py @@ -18,12 +18,12 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Wing.SURFACE_CONTROL_MASS_SCALER, val=1.0) - add_aviary_input(self, Mission.Design.GROSS_MASS, val=0.0) - add_aviary_input(self, Aircraft.Wing.CONTROL_SURFACE_AREA_RATIO, val=0.0) - add_aviary_input(self, Aircraft.Wing.AREA, val=0.0) + add_aviary_input(self, Aircraft.Wing.SURFACE_CONTROL_MASS_SCALER) + add_aviary_input(self, Mission.Design.GROSS_MASS) + add_aviary_input(self, Aircraft.Wing.CONTROL_SURFACE_AREA_RATIO) + add_aviary_input(self, Aircraft.Wing.AREA) - add_aviary_output(self, Aircraft.Wing.SURFACE_CONTROL_MASS, val=10) + add_aviary_output(self, Aircraft.Wing.SURFACE_CONTROL_MASS) add_aviary_output(self, Aircraft.Wing.CONTROL_SURFACE_AREA, val=2) self.declare_partials(Aircraft.Wing.SURFACE_CONTROL_MASS, '*') diff --git a/aviary/subsystems/mass/flops_based/test/test_furnishings.py b/aviary/subsystems/mass/flops_based/test/test_furnishings.py index b6885b17b..7d64c6388 100644 --- a/aviary/subsystems/mass/flops_based/test/test_furnishings.py +++ b/aviary/subsystems/mass/flops_based/test/test_furnishings.py @@ -127,7 +127,10 @@ def test_case(self): flops_inputs = get_flops_inputs("N3CC", preprocess=True) flops_inputs.update({ Aircraft.Fuselage.MILITARY_CARGO_FLOOR: (False, 'unitless'), - Aircraft.BWB.NUM_BAYS: (5, 'unitless') + Aircraft.BWB.NUM_BAYS: (5, 'unitless'), + Aircraft.BWB.CABIN_AREA: (100, 'ft**2'), + Aircraft.Fuselage.MAX_WIDTH: (30, 'ft'), + Aircraft.Fuselage.MAX_HEIGHT: (15, 'ft'), }) prob.model.add_subsystem( 'furnishings', @@ -135,6 +138,12 @@ def test_case(self): promotes_outputs=['*'], promotes_inputs=['*'] ) + prob.model.set_input_defaults( + Aircraft.BWB.CABIN_AREA, val=100., units="ft**2") + prob.model.set_input_defaults( + Aircraft.Fuselage.MAX_WIDTH, val=30., units="ft") + prob.model.set_input_defaults( + Aircraft.Fuselage.MAX_HEIGHT, val=15., units="ft") prob.setup(check=False, force_alloc_complex=True) partial_data = prob.check_partials(out_stream=None, method="cs") @@ -215,4 +224,8 @@ def test_IO(self): if __name__ == '__main__': - unittest.main() + #unittest.main() + test = BWBFurnishingsGroupMassTest2() + test.setUp() + test.test_case() + diff --git a/aviary/subsystems/mass/flops_based/test/test_wing_common.py b/aviary/subsystems/mass/flops_based/test/test_wing_common.py index 69134fa47..0469987b4 100644 --- a/aviary/subsystems/mass/flops_based/test/test_wing_common.py +++ b/aviary/subsystems/mass/flops_based/test/test_wing_common.py @@ -215,6 +215,7 @@ def test_case(self): prob.set_val(Aircraft.Wing.SHEAR_CONTROL_MASS, 4000, 'lbm') prob.set_val(Aircraft.Wing.SPAN, 100, 'ft') prob.set_val(Aircraft.Wing.SWEEP, 20, 'deg') + prob.set_val(Aircraft.Wing.ULTIMATE_LOAD_FACTOR, 3.75, 'unitless') partial_data = prob.check_partials(out_stream=None, method="cs") assert_check_partials(partial_data, atol=1e-12, rtol=1e-12) diff --git a/aviary/subsystems/mass/flops_based/thrust_reverser.py b/aviary/subsystems/mass/flops_based/thrust_reverser.py index 028c2969c..b8cea8872 100644 --- a/aviary/subsystems/mass/flops_based/thrust_reverser.py +++ b/aviary/subsystems/mass/flops_based/thrust_reverser.py @@ -32,14 +32,14 @@ def setup(self): Aircraft.Engine.NUM_ENGINES)) add_aviary_input( - self, Aircraft.Engine.THRUST_REVERSERS_MASS_SCALER, val=np.zeros(num_engine_type)) + self, Aircraft.Engine.THRUST_REVERSERS_MASS_SCALER, shape=num_engine_type) add_aviary_input( - self, Aircraft.Engine.SCALED_SLS_THRUST, val=np.zeros(num_engine_type)) + self, Aircraft.Engine.SCALED_SLS_THRUST, shape=num_engine_type) add_aviary_output( - self, Aircraft.Engine.THRUST_REVERSERS_MASS, val=np.zeros(num_engine_type)) + self, Aircraft.Engine.THRUST_REVERSERS_MASS, shape=num_engine_type) add_aviary_output( - self, Aircraft.Propulsion.TOTAL_THRUST_REVERSERS_MASS, val=0) + self, Aircraft.Propulsion.TOTAL_THRUST_REVERSERS_MASS) def setup_partials(self): # derivatives w.r.t vectorized engine inputs have known sparsity pattern diff --git a/aviary/subsystems/mass/flops_based/unusable_fuel.py b/aviary/subsystems/mass/flops_based/unusable_fuel.py index 6b994718a..8e0f927b1 100644 --- a/aviary/subsystems/mass/flops_based/unusable_fuel.py +++ b/aviary/subsystems/mass/flops_based/unusable_fuel.py @@ -27,19 +27,14 @@ def initialize(self): def setup(self): add_aviary_input( - self, Aircraft.Fuel.UNUSABLE_FUEL_MASS_SCALER, val=1.0) - - add_aviary_input(self, Aircraft.Fuel.DENSITY_RATIO, 1.0) - - add_aviary_input(self, Aircraft.Fuel.TOTAL_CAPACITY, 0.0) - - add_aviary_input(self, Aircraft.Propulsion.TOTAL_SCALED_SLS_THRUST, val=0.0) - - add_aviary_input(self, Aircraft.Wing.AREA, val=0.0) - - add_aviary_output(self, Aircraft.Fuel.TOTAL_VOLUME, val=0.0) - - add_aviary_output(self, Aircraft.Fuel.UNUSABLE_FUEL_MASS, val=0.0) + self, Aircraft.Fuel.UNUSABLE_FUEL_MASS_SCALER) + add_aviary_input(self, Aircraft.Fuel.DENSITY_RATIO) + add_aviary_input(self, Aircraft.Fuel.TOTAL_CAPACITY) + add_aviary_input(self, Aircraft.Propulsion.TOTAL_SCALED_SLS_THRUST) + add_aviary_input(self, Aircraft.Wing.AREA) + add_aviary_output(self, Aircraft.Fuel.TOTAL_VOLUME) + + add_aviary_output(self, Aircraft.Fuel.UNUSABLE_FUEL_MASS) def setup_partials(self): diff --git a/aviary/subsystems/mass/flops_based/vertical_tail.py b/aviary/subsystems/mass/flops_based/vertical_tail.py index 68df78b73..a43b51ca6 100644 --- a/aviary/subsystems/mass/flops_based/vertical_tail.py +++ b/aviary/subsystems/mass/flops_based/vertical_tail.py @@ -19,14 +19,11 @@ def initialize(self): def setup(self): add_aviary_input(self, Aircraft.VerticalTail.AREA, val=0.0) - add_aviary_input(self, Aircraft.VerticalTail.TAPER_RATIO, val=0.0) + add_aviary_input(self, Aircraft.VerticalTail.MASS_SCALER) + add_aviary_input(self, Mission.Design.GROSS_MASS) - add_aviary_input(self, Aircraft.VerticalTail.MASS_SCALER, val=1.0) - - add_aviary_input(self, Mission.Design.GROSS_MASS, val=0.0) - - add_aviary_output(self, Aircraft.VerticalTail.MASS, val=0.0) + add_aviary_output(self, Aircraft.VerticalTail.MASS) def setup_partials(self): self.declare_partials("*", "*") diff --git a/aviary/subsystems/mass/flops_based/wing_common.py b/aviary/subsystems/mass/flops_based/wing_common.py index e810dad45..744374201 100644 --- a/aviary/subsystems/mass/flops_based/wing_common.py +++ b/aviary/subsystems/mass/flops_based/wing_common.py @@ -19,23 +19,23 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Mission.Design.GROSS_MASS, val=0.0) - add_aviary_input(self, Aircraft.Wing.AEROELASTIC_TAILORING_FACTOR, val=0.0) - add_aviary_input(self, Aircraft.Wing.BENDING_FACTOR, val=0.0) - add_aviary_input(self, Aircraft.Wing.BENDING_MASS_SCALER, val=1.0) - add_aviary_input(self, Aircraft.Wing.COMPOSITE_FRACTION, val=0.0) - add_aviary_input(self, Aircraft.Wing.ENG_POD_INERTIA_FACTOR, val=0.0) - add_aviary_input(self, Aircraft.Wing.LOAD_FRACTION, val=0.0) - add_aviary_input(self, Aircraft.Wing.MISC_MASS, val=0.0) - add_aviary_input(self, Aircraft.Wing.MISC_MASS_SCALER, val=1.0) - add_aviary_input(self, Aircraft.Wing.SHEAR_CONTROL_MASS, val=0.0) - add_aviary_input(self, Aircraft.Wing.SHEAR_CONTROL_MASS_SCALER, val=1.0) - add_aviary_input(self, Aircraft.Wing.SPAN, val=0.0) - add_aviary_input(self, Aircraft.Wing.SWEEP, val=0.0) - add_aviary_input(self, Aircraft.Wing.ULTIMATE_LOAD_FACTOR, val=3.75) - add_aviary_input(self, Aircraft.Wing.VAR_SWEEP_MASS_PENALTY, val=0.0) - - add_aviary_output(self, Aircraft.Wing.BENDING_MASS, val=0.0) + add_aviary_input(self, Mission.Design.GROSS_MASS) + add_aviary_input(self, Aircraft.Wing.AEROELASTIC_TAILORING_FACTOR) + add_aviary_input(self, Aircraft.Wing.BENDING_FACTOR) + add_aviary_input(self, Aircraft.Wing.BENDING_MASS_SCALER) + add_aviary_input(self, Aircraft.Wing.COMPOSITE_FRACTION) + add_aviary_input(self, Aircraft.Wing.ENG_POD_INERTIA_FACTOR) + add_aviary_input(self, Aircraft.Wing.LOAD_FRACTION) + add_aviary_input(self, Aircraft.Wing.MISC_MASS) + add_aviary_input(self, Aircraft.Wing.MISC_MASS_SCALER) + add_aviary_input(self, Aircraft.Wing.SHEAR_CONTROL_MASS) + add_aviary_input(self, Aircraft.Wing.SHEAR_CONTROL_MASS_SCALER) + add_aviary_input(self, Aircraft.Wing.SPAN) + add_aviary_input(self, Aircraft.Wing.SWEEP) + add_aviary_input(self, Aircraft.Wing.ULTIMATE_LOAD_FACTOR) + add_aviary_input(self, Aircraft.Wing.VAR_SWEEP_MASS_PENALTY) + + add_aviary_output(self, Aircraft.Wing.BENDING_MASS) self.A1 = 8.80 self.A2 = 6.25 @@ -200,15 +200,12 @@ def initialize(self): desc='Aircfaft type: Tranpsport, HWB, or GA') def setup(self): - add_aviary_input(self, Aircraft.Wing.COMPOSITE_FRACTION, val=0.0) + add_aviary_input(self, Aircraft.Wing.COMPOSITE_FRACTION) + add_aviary_input(self, Aircraft.Wing.CONTROL_SURFACE_AREA) + add_aviary_input(self, Mission.Design.GROSS_MASS) + add_aviary_input(self, Aircraft.Wing.SHEAR_CONTROL_MASS_SCALER) - add_aviary_input(self, Aircraft.Wing.CONTROL_SURFACE_AREA, val=0.0) - - add_aviary_input(self, Mission.Design.GROSS_MASS, val=0.0) - - add_aviary_input(self, Aircraft.Wing.SHEAR_CONTROL_MASS_SCALER, val=1.0) - - add_aviary_output(self, Aircraft.Wing.SHEAR_CONTROL_MASS, val=0.0) + add_aviary_output(self, Aircraft.Wing.SHEAR_CONTROL_MASS) if ( (self.options['aircraft_type'] == 'Transport') @@ -281,13 +278,11 @@ def initialize(self): desc='Aircfaft type: Tranpsport, HWB, or GA') def setup(self): - add_aviary_input(self, Aircraft.Wing.COMPOSITE_FRACTION, val=0.0) - - add_aviary_input(self, Aircraft.Wing.AREA, val=0.0) - - add_aviary_input(self, Aircraft.Wing.MISC_MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.Wing.COMPOSITE_FRACTION) + add_aviary_input(self, Aircraft.Wing.AREA) + add_aviary_input(self, Aircraft.Wing.MISC_MASS_SCALER) - add_aviary_output(self, Aircraft.Wing.MISC_MASS, val=0.0) + add_aviary_output(self, Aircraft.Wing.MISC_MASS) if ( (self.options['aircraft_type'] == 'Transport') @@ -336,17 +331,13 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Wing.BENDING_MASS, val=0.0) - - add_aviary_input(self, Aircraft.Wing.SHEAR_CONTROL_MASS, val=0.0) - - add_aviary_input(self, Aircraft.Wing.MISC_MASS, val=0.0) - - add_aviary_input(self, Aircraft.Wing.BWB_AFTBODY_MASS, val=0.0) - - add_aviary_input(self, Aircraft.Wing.MASS_SCALER, val=1.0) + add_aviary_input(self, Aircraft.Wing.BENDING_MASS) + add_aviary_input(self, Aircraft.Wing.SHEAR_CONTROL_MASS) + add_aviary_input(self, Aircraft.Wing.MISC_MASS) + add_aviary_input(self, Aircraft.Wing.BWB_AFTBODY_MASS) + add_aviary_input(self, Aircraft.Wing.MASS_SCALER) - add_aviary_output(self, Aircraft.Wing.MASS, val=0) + add_aviary_output(self, Aircraft.Wing.MASS) def setup_partials(self): self.declare_partials("*", "*") diff --git a/aviary/subsystems/mass/flops_based/wing_detailed.py b/aviary/subsystems/mass/flops_based/wing_detailed.py index 521f3c9d0..7b7cb5f21 100644 --- a/aviary/subsystems/mass/flops_based/wing_detailed.py +++ b/aviary/subsystems/mass/flops_based/wing_detailed.py @@ -34,36 +34,24 @@ def setup(self): # wing_location_default[:] = [np.array([0]*int(num)) for num in num_wing_engines/2] add_aviary_input(self, Aircraft.Wing.LOAD_PATH_SWEEP_DIST, - val=np.zeros(num_input_stations - 1)) - + shape=num_input_stations - 1) add_aviary_input(self, Aircraft.Wing.THICKNESS_TO_CHORD_DIST, - val=np.zeros(num_input_stations)) - + shape=num_input_stations) add_aviary_input(self, Aircraft.Wing.CHORD_PER_SEMISPAN_DIST, - val=np.zeros(num_input_stations)) - - add_aviary_input(self, Mission.Design.GROSS_MASS, val=0.0) - - add_aviary_input(self, Aircraft.Engine.POD_MASS, val=np.zeros(num_engine_type)) - - add_aviary_input(self, Aircraft.Wing.ASPECT_RATIO, val=0.0) - - add_aviary_input(self, Aircraft.Wing.ASPECT_RATIO_REF, val=0.0) - - add_aviary_input(self, Aircraft.Wing.STRUT_BRACING_FACTOR, val=0.0) - - add_aviary_input(self, Aircraft.Wing.AEROELASTIC_TAILORING_FACTOR, val=0.0) - + shape=num_input_stations) + add_aviary_input(self, Mission.Design.GROSS_MASS) + add_aviary_input(self, Aircraft.Engine.POD_MASS, shape=num_engine_type) + add_aviary_input(self, Aircraft.Wing.ASPECT_RATIO) + add_aviary_input(self, Aircraft.Wing.ASPECT_RATIO_REF) + add_aviary_input(self, Aircraft.Wing.STRUT_BRACING_FACTOR) + add_aviary_input(self, Aircraft.Wing.AEROELASTIC_TAILORING_FACTOR) add_aviary_input(self, Aircraft.Engine.WING_LOCATIONS, - val=np.zeros(int(total_num_wing_engines/2))) - - add_aviary_input(self, Aircraft.Wing.THICKNESS_TO_CHORD, val=0.0) - - add_aviary_input(self, Aircraft.Wing.THICKNESS_TO_CHORD_REF, val=0.0) - - add_aviary_output(self, Aircraft.Wing.BENDING_FACTOR, val=0.0) + shape=int(total_num_wing_engines/2)) + add_aviary_input(self, Aircraft.Wing.THICKNESS_TO_CHORD) + add_aviary_input(self, Aircraft.Wing.THICKNESS_TO_CHORD_REF) - add_aviary_output(self, Aircraft.Wing.ENG_POD_INERTIA_FACTOR, val=0.0) + add_aviary_output(self, Aircraft.Wing.BENDING_FACTOR) + add_aviary_output(self, Aircraft.Wing.ENG_POD_INERTIA_FACTOR) def setup_partials(self): # TODO: Analytic derivs will be challenging, but possible. diff --git a/aviary/subsystems/mass/flops_based/wing_simple.py b/aviary/subsystems/mass/flops_based/wing_simple.py index 180c8f3de..2c3d1d283 100644 --- a/aviary/subsystems/mass/flops_based/wing_simple.py +++ b/aviary/subsystems/mass/flops_based/wing_simple.py @@ -18,25 +18,17 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Wing.AREA, val=0.0) - - add_aviary_input(self, Aircraft.Wing.SPAN, val=0.0) - - add_aviary_input(self, Aircraft.Wing.TAPER_RATIO, val=0.0) - - add_aviary_input(self, Aircraft.Wing.THICKNESS_TO_CHORD, val=0.0) - - add_aviary_input(self, Aircraft.Wing.STRUT_BRACING_FACTOR, val=0.0) - - add_aviary_input(self, Aircraft.Wing.AEROELASTIC_TAILORING_FACTOR, val=0.0) - - add_aviary_input(self, Aircraft.Wing.ASPECT_RATIO, val=0.0) - - add_aviary_input(self, Aircraft.Wing.SWEEP, val=0.0) - - add_aviary_output(self, Aircraft.Wing.BENDING_FACTOR, val=0.0) - - add_aviary_output(self, Aircraft.Wing.ENG_POD_INERTIA_FACTOR, val=0.0) + add_aviary_input(self, Aircraft.Wing.AREA) + add_aviary_input(self, Aircraft.Wing.SPAN) + add_aviary_input(self, Aircraft.Wing.TAPER_RATIO) + add_aviary_input(self, Aircraft.Wing.THICKNESS_TO_CHORD) + add_aviary_input(self, Aircraft.Wing.STRUT_BRACING_FACTOR) + add_aviary_input(self, Aircraft.Wing.AEROELASTIC_TAILORING_FACTOR) + add_aviary_input(self, Aircraft.Wing.ASPECT_RATIO) + add_aviary_input(self, Aircraft.Wing.SWEEP) + + add_aviary_output(self, Aircraft.Wing.BENDING_FACTOR) + add_aviary_output(self, Aircraft.Wing.ENG_POD_INERTIA_FACTOR) def setup_partials(self): self.declare_partials(of=Aircraft.Wing.BENDING_FACTOR, From 4530aba50c9a5b74ae6e52dc1c0af484c4e4a540 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Fri, 20 Dec 2024 15:58:04 -0800 Subject: [PATCH 07/22] work in progress. --- aviary/subsystems/mass/flops_based/fuselage.py | 13 +++++-------- 1 file changed, 5 insertions(+), 8 deletions(-) diff --git a/aviary/subsystems/mass/flops_based/fuselage.py b/aviary/subsystems/mass/flops_based/fuselage.py index 61d6b5216..d1852b417 100644 --- a/aviary/subsystems/mass/flops_based/fuselage.py +++ b/aviary/subsystems/mass/flops_based/fuselage.py @@ -88,15 +88,12 @@ def initialize(self): desc='collection of Aircraft/Mission specific options') def setup(self): - add_aviary_input(self, Aircraft.Fuselage.MASS_SCALER, 1.0) - - add_aviary_input(self, Aircraft.Fuselage.WETTED_AREA, 0.0) - - add_aviary_input(self, Aircraft.Fuselage.MAX_HEIGHT, 0.0) - - add_aviary_input(self, Aircraft.Fuselage.MAX_WIDTH, 0.0) + add_aviary_input(self, Aircraft.Fuselage.MASS_SCALER) + add_aviary_input(self, Aircraft.Fuselage.WETTED_AREA) + add_aviary_input(self, Aircraft.Fuselage.MAX_HEIGHT) + add_aviary_input(self, Aircraft.Fuselage.MAX_WIDTH) - add_aviary_output(self, Aircraft.Fuselage.MASS, 1.0) + add_aviary_output(self, Aircraft.Fuselage.MASS) def setup_partials(self): self.declare_partials(of='*', wrt='*') From 3dbec3a89ff10ce0ea1a7888deeb86456398cbe0 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Mon, 23 Dec 2024 09:45:20 -0800 Subject: [PATCH 08/22] Change TAPER_RATIO to 0.0 from 0.352 in horizontal_tail.py --- aviary/subsystems/mass/flops_based/horizontal_tail.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/aviary/subsystems/mass/flops_based/horizontal_tail.py b/aviary/subsystems/mass/flops_based/horizontal_tail.py index 9665aac32..5df097acb 100644 --- a/aviary/subsystems/mass/flops_based/horizontal_tail.py +++ b/aviary/subsystems/mass/flops_based/horizontal_tail.py @@ -19,7 +19,7 @@ def initialize(self): def setup(self): add_aviary_input(self, Aircraft.HorizontalTail.AREA) - add_aviary_input(self, Aircraft.HorizontalTail.TAPER_RATIO, val=0.352) + add_aviary_input(self, Aircraft.HorizontalTail.TAPER_RATIO) add_aviary_input(self, Mission.Design.GROSS_MASS) add_aviary_input(self, Aircraft.HorizontalTail.MASS_SCALER) From 9e6ca82b27f11cc5b34a3d80578683c331860e82 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Mon, 23 Dec 2024 09:45:54 -0800 Subject: [PATCH 09/22] minor update --- aviary/subsystems/mass/flops_based/test/test_furnishings.py | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/aviary/subsystems/mass/flops_based/test/test_furnishings.py b/aviary/subsystems/mass/flops_based/test/test_furnishings.py index 7d64c6388..d1da0a395 100644 --- a/aviary/subsystems/mass/flops_based/test/test_furnishings.py +++ b/aviary/subsystems/mass/flops_based/test/test_furnishings.py @@ -224,8 +224,5 @@ def test_IO(self): if __name__ == '__main__': - #unittest.main() - test = BWBFurnishingsGroupMassTest2() - test.setUp() - test.test_case() + unittest.main() From bea43565a16ebacba9c3a171688b949a832c9331 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Mon, 23 Dec 2024 09:47:30 -0800 Subject: [PATCH 10/22] autopep8 --- aviary/subsystems/mass/flops_based/test/test_furnishings.py | 1 - 1 file changed, 1 deletion(-) diff --git a/aviary/subsystems/mass/flops_based/test/test_furnishings.py b/aviary/subsystems/mass/flops_based/test/test_furnishings.py index d1da0a395..d519ac77c 100644 --- a/aviary/subsystems/mass/flops_based/test/test_furnishings.py +++ b/aviary/subsystems/mass/flops_based/test/test_furnishings.py @@ -225,4 +225,3 @@ def test_IO(self): if __name__ == '__main__': unittest.main() - From 0f455eb4b5f2ccc4d385e8775907fd7768f88955 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Mon, 23 Dec 2024 10:31:30 -0800 Subject: [PATCH 11/22] have to set Aircraft.HorizontalTail.TAPER_RATIO, val=0.352 in horizontal_tail.py for now because it generates conflicts with other subsystem. --- aviary/subsystems/mass/flops_based/horizontal_tail.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/aviary/subsystems/mass/flops_based/horizontal_tail.py b/aviary/subsystems/mass/flops_based/horizontal_tail.py index 5df097acb..9665aac32 100644 --- a/aviary/subsystems/mass/flops_based/horizontal_tail.py +++ b/aviary/subsystems/mass/flops_based/horizontal_tail.py @@ -19,7 +19,7 @@ def initialize(self): def setup(self): add_aviary_input(self, Aircraft.HorizontalTail.AREA) - add_aviary_input(self, Aircraft.HorizontalTail.TAPER_RATIO) + add_aviary_input(self, Aircraft.HorizontalTail.TAPER_RATIO, val=0.352) add_aviary_input(self, Mission.Design.GROSS_MASS) add_aviary_input(self, Aircraft.HorizontalTail.MASS_SCALER) From b317a4c8f67555e71c361a01a72610e99a1b5f6a Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Tue, 31 Dec 2024 16:19:22 -0800 Subject: [PATCH 12/22] autopep8 --- aviary/subsystems/mass/flops_based/wing_detailed.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/aviary/subsystems/mass/flops_based/wing_detailed.py b/aviary/subsystems/mass/flops_based/wing_detailed.py index b3aee85d0..d42920eda 100644 --- a/aviary/subsystems/mass/flops_based/wing_detailed.py +++ b/aviary/subsystems/mass/flops_based/wing_detailed.py @@ -57,7 +57,7 @@ def setup(self): add_aviary_input(self, Aircraft.Wing.THICKNESS_TO_CHORD) add_aviary_input(self, Aircraft.Wing.THICKNESS_TO_CHORD_REF) - + add_aviary_output(self, Aircraft.Wing.BENDING_MATERIAL_FACTOR) add_aviary_output(self, Aircraft.Wing.BENDING_FACTOR) add_aviary_output(self, Aircraft.Wing.ENG_POD_INERTIA_FACTOR) From 9984e255622290a03059e91713f5a8897dead483 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Tue, 31 Dec 2024 16:30:28 -0800 Subject: [PATCH 13/22] remove BENDING_FACTOR --- aviary/subsystems/mass/flops_based/wing_detailed.py | 1 - 1 file changed, 1 deletion(-) diff --git a/aviary/subsystems/mass/flops_based/wing_detailed.py b/aviary/subsystems/mass/flops_based/wing_detailed.py index d42920eda..af6b5861a 100644 --- a/aviary/subsystems/mass/flops_based/wing_detailed.py +++ b/aviary/subsystems/mass/flops_based/wing_detailed.py @@ -59,7 +59,6 @@ def setup(self): add_aviary_input(self, Aircraft.Wing.THICKNESS_TO_CHORD_REF) add_aviary_output(self, Aircraft.Wing.BENDING_MATERIAL_FACTOR) - add_aviary_output(self, Aircraft.Wing.BENDING_FACTOR) add_aviary_output(self, Aircraft.Wing.ENG_POD_INERTIA_FACTOR) def setup_partials(self): From 31bbd86b6433b4ad0442836c1d99b3e49f15510c Mon Sep 17 00:00:00 2001 From: jkirk5 Date: Tue, 7 Jan 2025 18:12:23 -0500 Subject: [PATCH 14/22] increment to 0.9.6 --- .bumpversion.cfg | 2 +- .github/ISSUE_TEMPLATE/bug_report.yml | 2 +- aviary/__init__.py | 2 +- setup.py | 8 ++++---- 4 files changed, 7 insertions(+), 7 deletions(-) diff --git a/.bumpversion.cfg b/.bumpversion.cfg index a3a4c1790..7a9118486 100644 --- a/.bumpversion.cfg +++ b/.bumpversion.cfg @@ -1,5 +1,5 @@ [bumpversion] -current_version = 0.9.4-dev +current_version = 0.9.6 commit = False tag = False parse = (?P\d+)\.(?P\d+)\.(?P\d+)(\-(?P[a-z]+))? diff --git a/.github/ISSUE_TEMPLATE/bug_report.yml b/.github/ISSUE_TEMPLATE/bug_report.yml index cd237761c..f8fa1143e 100644 --- a/.github/ISSUE_TEMPLATE/bug_report.yml +++ b/.github/ISSUE_TEMPLATE/bug_report.yml @@ -21,7 +21,7 @@ body: attributes: label: Aviary Version description: What version of Aviary is being used. - placeholder: "0.9.4-dev" + placeholder: "0.9.6" validations: required: true - type: textarea diff --git a/aviary/__init__.py b/aviary/__init__.py index 7f33873b3..50533e307 100644 --- a/aviary/__init__.py +++ b/aviary/__init__.py @@ -1 +1 @@ -__version__ = "0.9.4-dev" +__version__ = "0.9.6" diff --git a/setup.py b/setup.py index 143676dd5..e6b14555c 100644 --- a/setup.py +++ b/setup.py @@ -31,7 +31,7 @@ version=__version__, packages=find_packages(), install_requires=[ - "openmdao>=3.33.0", + "openmdao>=3.36.0", "dymos>=1.8.1", "hvplot", "importlib_resources", @@ -68,7 +68,7 @@ "models/small_single_aisle/*", "models/test_aircraft/*", "visualization/assets/*", - "visualization/assets/aviary_vars/*" + "visualization/assets/aviary_vars/*", ], f"{pkgname}.docs": [ "*.py", @@ -87,6 +87,6 @@ ], 'openmdao_report': [ 'aviary_reports=aviary.interface.reports:register_custom_reports', - ] - } + ], + }, ) From 8f1c884e6a13ea5f1fab888cdbe26d679b7f1d79 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Thu, 9 Jan 2025 14:12:23 -0800 Subject: [PATCH 15/22] in add_aviary_output, set val=None by default --- aviary/variable_info/functions.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/aviary/variable_info/functions.py b/aviary/variable_info/functions.py index 26cae4acb..fbdd77a53 100644 --- a/aviary/variable_info/functions.py +++ b/aviary/variable_info/functions.py @@ -73,7 +73,7 @@ def add_aviary_input(comp, varname, val=None, units=None, desc=None, shape_by_co desc=input_desc, shape_by_conn=shape_by_conn, shape=shape) -def add_aviary_output(comp, varname, val, units=None, desc=None, shape_by_conn=False, +def add_aviary_output(comp, varname, val=None, units=None, desc=None, shape_by_conn=False, meta_data=_MetaData, shape=None): """ This function provides a clean way to add variables from the From 773ebb3f23f84c803f02e3c072998b0b76df81e6 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Thu, 9 Jan 2025 19:14:59 -0800 Subject: [PATCH 16/22] minor update --- aviary/variable_info/variable_meta_data.py | 1 + 1 file changed, 1 insertion(+) diff --git a/aviary/variable_info/variable_meta_data.py b/aviary/variable_info/variable_meta_data.py index 4c5984b80..46018b3c4 100644 --- a/aviary/variable_info/variable_meta_data.py +++ b/aviary/variable_info/variable_meta_data.py @@ -619,6 +619,7 @@ historical_name={"GASP": 'INGASP.WFC', "FLOPS": None, "LEAPS1": None}, units='lbm', desc='total mass of cockpit controls, fixed wing controls, and SAS', + default_value=0.0, # added ) # _____ _____ _ _ From 27e0d84318f1ad2dd05d028608d143ec28dafb29 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Thu, 9 Jan 2025 19:40:46 -0800 Subject: [PATCH 17/22] minor update again. --- aviary/variable_info/variable_meta_data.py | 1 + 1 file changed, 1 insertion(+) diff --git a/aviary/variable_info/variable_meta_data.py b/aviary/variable_info/variable_meta_data.py index 46018b3c4..f61783840 100644 --- a/aviary/variable_info/variable_meta_data.py +++ b/aviary/variable_info/variable_meta_data.py @@ -1170,6 +1170,7 @@ historical_name={"GASP": 'INGASP.SKCC', "FLOPS": None, "LEAPS1": None}, units="unitless", desc='mass trend coefficient of cockpit controls', + default_value=0.0, # added ) add_meta_data( From 972f2062ee0e7a3d7fd05d763d46d476604269ee Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Fri, 10 Jan 2025 08:24:23 -0800 Subject: [PATCH 18/22] testing --- aviary/variable_info/variable_meta_data.py | 86 ++++++++++++++++------ 1 file changed, 63 insertions(+), 23 deletions(-) diff --git a/aviary/variable_info/variable_meta_data.py b/aviary/variable_info/variable_meta_data.py index f61783840..af25ed5b6 100644 --- a/aviary/variable_info/variable_meta_data.py +++ b/aviary/variable_info/variable_meta_data.py @@ -418,7 +418,7 @@ }, units='unitless', desc='canard theoretical aspect ratio', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -434,6 +434,7 @@ }, units='ft', desc='Reynolds characteristic length for the canard', + default_value=0.0, # added ) add_meta_data( @@ -449,6 +450,7 @@ }, units='unitless', desc='canard fineness ratio', + default_value=0.0, # added ) add_meta_data( @@ -553,7 +555,7 @@ }, units='ft**2', desc='canard wetted area', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -1253,7 +1255,7 @@ add_meta_data( # Note users must enable this feature, or the associated calculation is - # discarded + # discarded. Default to 0.0 Aircraft.Design.EMPTY_MASS_MARGIN_SCALER, meta_data=_MetaData, historical_name={ @@ -1263,7 +1265,7 @@ }, units='unitless', desc='empty mass margin scaler', - default_value=0.0, # Note: not 1.0 here + default_value=0.0, ) add_meta_data( @@ -1716,6 +1718,7 @@ historical_name={"GASP": 'INGASP.LCABLE', "FLOPS": None, "LEAPS1": None}, units='ft', desc='length of cable for hybrid electric augmented system', + default_value=0.0, # added ) add_meta_data( @@ -2160,7 +2163,7 @@ historical_name={"GASP": 'INGASP.DIAM_REF', "FLOPS": None, "LEAPS1": None}, units='ft', desc='engine reference diameter', - default_value=0.0, + default_value=0.0, # In geometry/gasp_based/engine.py, it was 5.8 ) # NOTE This unscaled turbine (engine) weight is an input provided by the user, and is not @@ -2367,6 +2370,7 @@ units='unitless', desc='Engine wing mount locations as fractions of semispan; (NUM_WING_ENGINES)/2 values ' 'are input', + # In mass/gasp_based/fixed.py and geometry/gasp_based/electric.py, default was [0.35] default_value=np.array([0.0]), ) @@ -2887,6 +2891,8 @@ historical_name={"GASP": 'INGASP.SKWF', "FLOPS": None, "LEAPS1": None}, units='unitless', desc='fraction of total theoretical wing volume used for wing fuel', + # added. In geometry/gasp_based/wing.py, it was 0.6. In /mass/gasp_based/equipment_and_useful_load.py, it was 0.5. + default_value=0.0, ) add_meta_data( @@ -2969,6 +2975,7 @@ historical_name={"GASP": 'INGASP.FVOLW_GEOM', "FLOPS": None, "LEAPS1": None}, units='ft**3', desc='wing tank fuel volume based on geometry', + default_value=0.0, # added ) add_meta_data( @@ -3065,7 +3072,7 @@ }, units='ft', desc='average fuselage diameter', - default_value=0.0, # added + default_value=0.0, # added. In several components, it was set to 10 or 13.1. ) add_meta_data( @@ -3081,6 +3088,7 @@ }, units='ft', desc='Reynolds characteristic length for the fuselage', + default_value=0.0, # added ) add_meta_data( @@ -3101,7 +3109,7 @@ historical_name={"GASP": 'INGASP.HCK', "FLOPS": None, "LEAPS1": None}, units='ft', desc='mean fuselage cabin diameter minus mean fuselage nose diameter', - default_value=4.5, + default_value=0.0, # In geometry/gasp_based/fuselage.py, it was 4.5. ) add_meta_data( @@ -3114,6 +3122,7 @@ }, units='unitless', desc='fuselage diameter to wing span ratio', + default_value=0.0, # added ) add_meta_data( @@ -3129,6 +3138,7 @@ }, units='unitless', desc='fuselage fineness ratio', + default_value=0.0, # added ) add_meta_data( @@ -3197,7 +3207,7 @@ desc='Define the Fuselage total length. If total_length is not input for a ' 'passenger transport, LEAPS will calculate the fuselage length, width and ' 'depth and the length of the passenger compartment.', - default_value=0.0, + default_value=0.0, # in several components, it was set to 129.4 or 200. ) add_meta_data( @@ -3210,6 +3220,7 @@ }, units='unitless', desc='fuselage length to diameter ratio', + default_value=0.0, # added ) add_meta_data( @@ -3381,6 +3392,7 @@ historical_name={"GASP": 'INGASP.ELPC', "FLOPS": None, "LEAPS1": None}, units='ft', desc='length of the pilot compartment', + default_value=0.0, # added. # In geometry/gasp_based/fuselage.py, it was 9.5 ) add_meta_data( @@ -3502,7 +3514,7 @@ }, units='unitless', desc='horizontal tail theoretical aspect ratio', - default_value=None, + default_value=4.75, # changed from None ) add_meta_data( @@ -3526,6 +3538,7 @@ }, units='ft', desc='Reynolds characteristic length for the horizontal tail', + default_value=0.0, # added ) add_meta_data( @@ -3541,6 +3554,7 @@ }, units='unitless', desc='horizontal tail fineness ratio', + default_value=0.0, # added ) add_meta_data( @@ -3676,7 +3690,8 @@ }, units='unitless', desc='horizontal tail theoretical taper ratio', - default_value=None, + # In geometry/flops_based/prep_geom.py and mass/gasp_based/empennage.py, it was 0.352. + default_value=0.0, # changed from None. ) add_meta_data( @@ -3706,7 +3721,7 @@ 'tail is mounted. Defaults: 0.0 == for body mounted (default for ' 'transport with all engines on wing); 1.0 == for T tail ' '(default for transport with multiple engines on fuselage)', - default_value=None, + default_value=0.0, # added ) add_meta_data( @@ -3821,7 +3836,7 @@ }, units='psi', desc='hydraulic system pressure', - default_value=0.0, + default_value=0.0, # changed from 3000.0 ) # @@ -4121,6 +4136,7 @@ }, units='ft', desc='Reynolds characteristic length for nacelle for each engine model', + default_value=0.0, # added ) add_meta_data( @@ -4138,7 +4154,7 @@ historical_name={"GASP": 'INGASP.DNQDE', "FLOPS": None, "LEAPS1": None}, units="unitless", desc='ratio of nacelle diameter to engine core diameter', - default_value=1.25, + default_value=1.25, # In geometry/gasp_based/engine.py, it was 1.25 ) add_meta_data( @@ -4154,6 +4170,7 @@ }, units='unitless', desc='nacelle fineness ratio', + default_value=0.0, # added. # In geometry/gasp_based/engine.py, it was 2. ) add_meta_data( @@ -4251,6 +4268,7 @@ }, units='ft**2', desc='total nacelles wetted area', + default_value=0.0, # added ) add_meta_data( @@ -4266,6 +4284,7 @@ }, units='ft**2', desc='wetted area of a single nacelle for each engine model', + default_value=0.0, # added ) add_meta_data( @@ -4528,6 +4547,7 @@ historical_name={"GASP": 'INGASP.SSTQSW', "FLOPS": None, "LEAPS1": None}, units='unitless', desc='ratio of strut area to wing area', + default_value=0.0, # added. In geometry/gasp_based/strut.py, it was set to .2. ) add_meta_data( @@ -4540,6 +4560,7 @@ }, units='ft', desc='attachment location of strut the full attachment-to-attachment span', + default_value=0.0, # added ) # related to Aircraft.Strut.ATTACHMENT_LOCATION @@ -4549,6 +4570,7 @@ historical_name={"GASP": None, "FLOPS": None, "LEAPS1": None}, units='unitless', desc='attachment location of strut as fraction of the half-span', + default_value=0.0, # added ) add_meta_data( @@ -4557,6 +4579,7 @@ historical_name={"GASP": 'INGASP.STRTCHD', "FLOPS": None, "LEAPS1": None}, units='ft', desc='chord of the strut', + default_value=0.0, # added ) add_meta_data( @@ -4674,7 +4697,7 @@ }, units='unitless', desc='vertical tail theoretical aspect ratio', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -4698,6 +4721,7 @@ }, units='ft', desc='Reynolds characteristic length for the vertical tail', + default_value=0.0, # added ) add_meta_data( @@ -4713,6 +4737,7 @@ }, units='unitless', desc='vertical tail fineness ratio', + default_value=0.0, # added ) add_meta_data( @@ -4906,7 +4931,7 @@ }, units='ft**2', desc='vertical tails wetted area', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -4996,7 +5021,7 @@ }, units='ft**2', desc='reference wing area', - default_value=0.0, + default_value=0.0, # In several components, it was set to 100, 150, 200, 1370.3 etc. ) add_meta_data( @@ -5022,7 +5047,7 @@ }, units='unitless', desc='ratio of the wing span to its mean chord', - default_value=0.0, + default_value=0.0, # in several components, it was 1 or 10.13. ) add_meta_data( @@ -5044,6 +5069,7 @@ historical_name={"GASP": 'INGASP.CBARW', "FLOPS": None, "LEAPS1": None}, units='ft', desc='mean aerodynamic chord of the wing', + default_value=0.0, # added ) add_meta_data( @@ -5055,7 +5081,8 @@ "LEAPS1": 'aircraft.outputs.L0_wing.bending_material_factor', }, units='unitless', - desc='Wing bending material factor with sweep adjustment. Used to compute', + desc='Wing bending material factor with sweep adjustment. Used to compute ', + 'Aircraft.Wing.BENDING_MATERIAL_MASS', default_value=0.0, # added ) @@ -5121,6 +5148,7 @@ historical_name={"GASP": 'INGASP.CRCLW', "FLOPS": None, "LEAPS1": None}, units='ft', desc='wing chord at fuselage centerline', + default_value=0.0, # added ) add_meta_data( @@ -5145,6 +5173,7 @@ }, units='ft', desc='Reynolds characteristic length for the wing', + default_value=0.0, # added ) add_meta_data( @@ -5279,6 +5308,7 @@ }, units='unitless', desc='wing fineness ratio', + default_value=0.0, # added ) add_meta_data( @@ -5380,7 +5410,8 @@ historical_name={"GASP": 'INGASP.YWFOLD', "FLOPS": None, "LEAPS1": None}, units='ft', desc='folded wingspan', - default_value=118, + # In geometry/gasp_based/non_dimensional_conversion.py and geometry/gasp_based/wing.py, it was 25. + default_value=0, # changed from 118 ) add_meta_data( @@ -5539,6 +5570,7 @@ historical_name={"GASP": 'INGASP.SWPLE', "FLOPS": None, "LEAPS1": None}, units='rad', desc='sweep angle at leading edge of wing', + default_value=0.0, # added ) add_meta_data( @@ -5593,6 +5625,7 @@ }, units='lbf/ft**2', desc='wing loading', + default_value=0.0, # added. In several components, it was 128. ) add_meta_data( @@ -5809,6 +5842,7 @@ }, units='ft', desc='wing chord length at wing root', + default_value=0.0, # added ) add_meta_data( @@ -5884,6 +5918,7 @@ }, units='ft', desc='span of main wing', + # in several components, it was set to 128, or 117.8 but there are other values. default_value=0.0, ) @@ -5998,7 +6033,8 @@ }, units='deg', desc='quarter-chord sweep angle of the wing', - default_value=0.0, # TODO required + # In several components, it was 0.436 (rad) or 25 (deg). + default_value=0.0, # TODO required. ) add_meta_data( @@ -6023,7 +6059,7 @@ }, units='unitless', desc='taper ratio of the wing', - default_value=0.0, # TODO required + default_value=0.0, # TODO required. In several components, it was .33. ) add_meta_data( @@ -6084,6 +6120,7 @@ historical_name={"GASP": 'INGASP.TCR', "FLOPS": None, "LEAPS1": None}, units='unitless', desc='thickness-to-chord ratio at the root of the wing', + default_value=0.0, # added. In several components, it was 0.11 or 0.15. ) add_meta_data( @@ -6092,6 +6129,7 @@ historical_name={"GASP": 'INGASP.TCT', "FLOPS": None, "LEAPS1": None}, units='unitless', desc='thickness-to-chord ratio at the tip of the wing', + default_value=0.0, # added. In geometry/gasp_based/wing.py, it was 0.1 ) add_meta_data( @@ -6100,6 +6138,7 @@ historical_name={"GASP": 'INGASP.TC', "FLOPS": None, "LEAPS1": None}, units='unitless', desc='wing thickness-chord ratio at the wing station of the mean aerodynamic chord', + default_value=0.0, # added. In geometry/gasp_based/wing.py, it was 0.1. ) add_meta_data( @@ -6147,7 +6186,7 @@ }, units='ft**2', desc='wing wetted area', - default_value=None, + default_value=0.0, # changed from None ) add_meta_data( @@ -6782,7 +6821,8 @@ }, units='lbm', desc='design gross mass of the aircraft', - default_value=0.0, # changed from None + # changed form None. In several components, it was set to 20000, 152000 or 175400. + default_value=0.0, ) add_meta_data( From e4d4802d148c4bb336fc9f6db7d1764e7c5969fa Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Fri, 10 Jan 2025 08:34:33 -0800 Subject: [PATCH 19/22] roll back --- aviary/variable_info/variable_meta_data.py | 88 ++++++---------------- 1 file changed, 23 insertions(+), 65 deletions(-) diff --git a/aviary/variable_info/variable_meta_data.py b/aviary/variable_info/variable_meta_data.py index af25ed5b6..4c5984b80 100644 --- a/aviary/variable_info/variable_meta_data.py +++ b/aviary/variable_info/variable_meta_data.py @@ -418,7 +418,7 @@ }, units='unitless', desc='canard theoretical aspect ratio', - default_value=0.0, # changed from None + default_value=None, ) add_meta_data( @@ -434,7 +434,6 @@ }, units='ft', desc='Reynolds characteristic length for the canard', - default_value=0.0, # added ) add_meta_data( @@ -450,7 +449,6 @@ }, units='unitless', desc='canard fineness ratio', - default_value=0.0, # added ) add_meta_data( @@ -555,7 +553,7 @@ }, units='ft**2', desc='canard wetted area', - default_value=0.0, # changed from None + default_value=None, ) add_meta_data( @@ -621,7 +619,6 @@ historical_name={"GASP": 'INGASP.WFC', "FLOPS": None, "LEAPS1": None}, units='lbm', desc='total mass of cockpit controls, fixed wing controls, and SAS', - default_value=0.0, # added ) # _____ _____ _ _ @@ -1172,7 +1169,6 @@ historical_name={"GASP": 'INGASP.SKCC', "FLOPS": None, "LEAPS1": None}, units="unitless", desc='mass trend coefficient of cockpit controls', - default_value=0.0, # added ) add_meta_data( @@ -1255,7 +1251,7 @@ add_meta_data( # Note users must enable this feature, or the associated calculation is - # discarded. Default to 0.0 + # discarded Aircraft.Design.EMPTY_MASS_MARGIN_SCALER, meta_data=_MetaData, historical_name={ @@ -1265,7 +1261,7 @@ }, units='unitless', desc='empty mass margin scaler', - default_value=0.0, + default_value=0.0, # Note: not 1.0 here ) add_meta_data( @@ -1718,7 +1714,6 @@ historical_name={"GASP": 'INGASP.LCABLE', "FLOPS": None, "LEAPS1": None}, units='ft', desc='length of cable for hybrid electric augmented system', - default_value=0.0, # added ) add_meta_data( @@ -2163,7 +2158,7 @@ historical_name={"GASP": 'INGASP.DIAM_REF', "FLOPS": None, "LEAPS1": None}, units='ft', desc='engine reference diameter', - default_value=0.0, # In geometry/gasp_based/engine.py, it was 5.8 + default_value=0.0, ) # NOTE This unscaled turbine (engine) weight is an input provided by the user, and is not @@ -2370,7 +2365,6 @@ units='unitless', desc='Engine wing mount locations as fractions of semispan; (NUM_WING_ENGINES)/2 values ' 'are input', - # In mass/gasp_based/fixed.py and geometry/gasp_based/electric.py, default was [0.35] default_value=np.array([0.0]), ) @@ -2891,8 +2885,6 @@ historical_name={"GASP": 'INGASP.SKWF', "FLOPS": None, "LEAPS1": None}, units='unitless', desc='fraction of total theoretical wing volume used for wing fuel', - # added. In geometry/gasp_based/wing.py, it was 0.6. In /mass/gasp_based/equipment_and_useful_load.py, it was 0.5. - default_value=0.0, ) add_meta_data( @@ -2975,7 +2967,6 @@ historical_name={"GASP": 'INGASP.FVOLW_GEOM', "FLOPS": None, "LEAPS1": None}, units='ft**3', desc='wing tank fuel volume based on geometry', - default_value=0.0, # added ) add_meta_data( @@ -3072,7 +3063,7 @@ }, units='ft', desc='average fuselage diameter', - default_value=0.0, # added. In several components, it was set to 10 or 13.1. + default_value=0.0, # added ) add_meta_data( @@ -3088,7 +3079,6 @@ }, units='ft', desc='Reynolds characteristic length for the fuselage', - default_value=0.0, # added ) add_meta_data( @@ -3109,7 +3099,7 @@ historical_name={"GASP": 'INGASP.HCK', "FLOPS": None, "LEAPS1": None}, units='ft', desc='mean fuselage cabin diameter minus mean fuselage nose diameter', - default_value=0.0, # In geometry/gasp_based/fuselage.py, it was 4.5. + default_value=4.5, ) add_meta_data( @@ -3122,7 +3112,6 @@ }, units='unitless', desc='fuselage diameter to wing span ratio', - default_value=0.0, # added ) add_meta_data( @@ -3138,7 +3127,6 @@ }, units='unitless', desc='fuselage fineness ratio', - default_value=0.0, # added ) add_meta_data( @@ -3207,7 +3195,7 @@ desc='Define the Fuselage total length. If total_length is not input for a ' 'passenger transport, LEAPS will calculate the fuselage length, width and ' 'depth and the length of the passenger compartment.', - default_value=0.0, # in several components, it was set to 129.4 or 200. + default_value=0.0, ) add_meta_data( @@ -3220,7 +3208,6 @@ }, units='unitless', desc='fuselage length to diameter ratio', - default_value=0.0, # added ) add_meta_data( @@ -3392,7 +3379,6 @@ historical_name={"GASP": 'INGASP.ELPC', "FLOPS": None, "LEAPS1": None}, units='ft', desc='length of the pilot compartment', - default_value=0.0, # added. # In geometry/gasp_based/fuselage.py, it was 9.5 ) add_meta_data( @@ -3514,7 +3500,7 @@ }, units='unitless', desc='horizontal tail theoretical aspect ratio', - default_value=4.75, # changed from None + default_value=None, ) add_meta_data( @@ -3538,7 +3524,6 @@ }, units='ft', desc='Reynolds characteristic length for the horizontal tail', - default_value=0.0, # added ) add_meta_data( @@ -3554,7 +3539,6 @@ }, units='unitless', desc='horizontal tail fineness ratio', - default_value=0.0, # added ) add_meta_data( @@ -3690,8 +3674,7 @@ }, units='unitless', desc='horizontal tail theoretical taper ratio', - # In geometry/flops_based/prep_geom.py and mass/gasp_based/empennage.py, it was 0.352. - default_value=0.0, # changed from None. + default_value=None, ) add_meta_data( @@ -3721,7 +3704,7 @@ 'tail is mounted. Defaults: 0.0 == for body mounted (default for ' 'transport with all engines on wing); 1.0 == for T tail ' '(default for transport with multiple engines on fuselage)', - default_value=0.0, # added + default_value=None, ) add_meta_data( @@ -3836,7 +3819,7 @@ }, units='psi', desc='hydraulic system pressure', - default_value=0.0, # changed from 3000.0 + default_value=0.0, ) # @@ -4136,7 +4119,6 @@ }, units='ft', desc='Reynolds characteristic length for nacelle for each engine model', - default_value=0.0, # added ) add_meta_data( @@ -4154,7 +4136,7 @@ historical_name={"GASP": 'INGASP.DNQDE', "FLOPS": None, "LEAPS1": None}, units="unitless", desc='ratio of nacelle diameter to engine core diameter', - default_value=1.25, # In geometry/gasp_based/engine.py, it was 1.25 + default_value=1.25, ) add_meta_data( @@ -4170,7 +4152,6 @@ }, units='unitless', desc='nacelle fineness ratio', - default_value=0.0, # added. # In geometry/gasp_based/engine.py, it was 2. ) add_meta_data( @@ -4268,7 +4249,6 @@ }, units='ft**2', desc='total nacelles wetted area', - default_value=0.0, # added ) add_meta_data( @@ -4284,7 +4264,6 @@ }, units='ft**2', desc='wetted area of a single nacelle for each engine model', - default_value=0.0, # added ) add_meta_data( @@ -4547,7 +4526,6 @@ historical_name={"GASP": 'INGASP.SSTQSW', "FLOPS": None, "LEAPS1": None}, units='unitless', desc='ratio of strut area to wing area', - default_value=0.0, # added. In geometry/gasp_based/strut.py, it was set to .2. ) add_meta_data( @@ -4560,7 +4538,6 @@ }, units='ft', desc='attachment location of strut the full attachment-to-attachment span', - default_value=0.0, # added ) # related to Aircraft.Strut.ATTACHMENT_LOCATION @@ -4570,7 +4547,6 @@ historical_name={"GASP": None, "FLOPS": None, "LEAPS1": None}, units='unitless', desc='attachment location of strut as fraction of the half-span', - default_value=0.0, # added ) add_meta_data( @@ -4579,7 +4555,6 @@ historical_name={"GASP": 'INGASP.STRTCHD', "FLOPS": None, "LEAPS1": None}, units='ft', desc='chord of the strut', - default_value=0.0, # added ) add_meta_data( @@ -4697,7 +4672,7 @@ }, units='unitless', desc='vertical tail theoretical aspect ratio', - default_value=0.0, # changed from None + default_value=None, ) add_meta_data( @@ -4721,7 +4696,6 @@ }, units='ft', desc='Reynolds characteristic length for the vertical tail', - default_value=0.0, # added ) add_meta_data( @@ -4737,7 +4711,6 @@ }, units='unitless', desc='vertical tail fineness ratio', - default_value=0.0, # added ) add_meta_data( @@ -4931,7 +4904,7 @@ }, units='ft**2', desc='vertical tails wetted area', - default_value=0.0, # changed from None + default_value=None, ) add_meta_data( @@ -5021,7 +4994,7 @@ }, units='ft**2', desc='reference wing area', - default_value=0.0, # In several components, it was set to 100, 150, 200, 1370.3 etc. + default_value=0.0, ) add_meta_data( @@ -5047,7 +5020,7 @@ }, units='unitless', desc='ratio of the wing span to its mean chord', - default_value=0.0, # in several components, it was 1 or 10.13. + default_value=0.0, ) add_meta_data( @@ -5069,7 +5042,6 @@ historical_name={"GASP": 'INGASP.CBARW', "FLOPS": None, "LEAPS1": None}, units='ft', desc='mean aerodynamic chord of the wing', - default_value=0.0, # added ) add_meta_data( @@ -5081,8 +5053,7 @@ "LEAPS1": 'aircraft.outputs.L0_wing.bending_material_factor', }, units='unitless', - desc='Wing bending material factor with sweep adjustment. Used to compute ', - 'Aircraft.Wing.BENDING_MATERIAL_MASS', + desc='Wing bending material factor with sweep adjustment. Used to compute', default_value=0.0, # added ) @@ -5148,7 +5119,6 @@ historical_name={"GASP": 'INGASP.CRCLW', "FLOPS": None, "LEAPS1": None}, units='ft', desc='wing chord at fuselage centerline', - default_value=0.0, # added ) add_meta_data( @@ -5173,7 +5143,6 @@ }, units='ft', desc='Reynolds characteristic length for the wing', - default_value=0.0, # added ) add_meta_data( @@ -5308,7 +5277,6 @@ }, units='unitless', desc='wing fineness ratio', - default_value=0.0, # added ) add_meta_data( @@ -5410,8 +5378,7 @@ historical_name={"GASP": 'INGASP.YWFOLD', "FLOPS": None, "LEAPS1": None}, units='ft', desc='folded wingspan', - # In geometry/gasp_based/non_dimensional_conversion.py and geometry/gasp_based/wing.py, it was 25. - default_value=0, # changed from 118 + default_value=118, ) add_meta_data( @@ -5570,7 +5537,6 @@ historical_name={"GASP": 'INGASP.SWPLE', "FLOPS": None, "LEAPS1": None}, units='rad', desc='sweep angle at leading edge of wing', - default_value=0.0, # added ) add_meta_data( @@ -5625,7 +5591,6 @@ }, units='lbf/ft**2', desc='wing loading', - default_value=0.0, # added. In several components, it was 128. ) add_meta_data( @@ -5842,7 +5807,6 @@ }, units='ft', desc='wing chord length at wing root', - default_value=0.0, # added ) add_meta_data( @@ -5918,7 +5882,6 @@ }, units='ft', desc='span of main wing', - # in several components, it was set to 128, or 117.8 but there are other values. default_value=0.0, ) @@ -6033,8 +5996,7 @@ }, units='deg', desc='quarter-chord sweep angle of the wing', - # In several components, it was 0.436 (rad) or 25 (deg). - default_value=0.0, # TODO required. + default_value=0.0, # TODO required ) add_meta_data( @@ -6059,7 +6021,7 @@ }, units='unitless', desc='taper ratio of the wing', - default_value=0.0, # TODO required. In several components, it was .33. + default_value=0.0, # TODO required ) add_meta_data( @@ -6120,7 +6082,6 @@ historical_name={"GASP": 'INGASP.TCR', "FLOPS": None, "LEAPS1": None}, units='unitless', desc='thickness-to-chord ratio at the root of the wing', - default_value=0.0, # added. In several components, it was 0.11 or 0.15. ) add_meta_data( @@ -6129,7 +6090,6 @@ historical_name={"GASP": 'INGASP.TCT', "FLOPS": None, "LEAPS1": None}, units='unitless', desc='thickness-to-chord ratio at the tip of the wing', - default_value=0.0, # added. In geometry/gasp_based/wing.py, it was 0.1 ) add_meta_data( @@ -6138,7 +6098,6 @@ historical_name={"GASP": 'INGASP.TC', "FLOPS": None, "LEAPS1": None}, units='unitless', desc='wing thickness-chord ratio at the wing station of the mean aerodynamic chord', - default_value=0.0, # added. In geometry/gasp_based/wing.py, it was 0.1. ) add_meta_data( @@ -6186,7 +6145,7 @@ }, units='ft**2', desc='wing wetted area', - default_value=0.0, # changed from None + default_value=None, ) add_meta_data( @@ -6821,8 +6780,7 @@ }, units='lbm', desc='design gross mass of the aircraft', - # changed form None. In several components, it was set to 20000, 152000 or 175400. - default_value=0.0, + default_value=0.0, # changed from None ) add_meta_data( From 1ee5445b4855bc89f88cd89be7a9ce93c57a8ea8 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Fri, 10 Jan 2025 12:10:10 -0800 Subject: [PATCH 20/22] remove temperary comments. --- aviary/variable_info/variable_meta_data.py | 151 +++++++++++---------- 1 file changed, 76 insertions(+), 75 deletions(-) diff --git a/aviary/variable_info/variable_meta_data.py b/aviary/variable_info/variable_meta_data.py index 4c5984b80..8b8919fb4 100644 --- a/aviary/variable_info/variable_meta_data.py +++ b/aviary/variable_info/variable_meta_data.py @@ -70,7 +70,7 @@ }, units='lbm', desc='air conditioning system mass', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -122,7 +122,7 @@ }, units='lbm', desc='mass of anti-icing system (auxiliary gear)', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -163,7 +163,7 @@ }, units='lbm', desc='mass of auxiliary power unit', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -204,7 +204,7 @@ }, units='lbm', desc='avionics mass', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -493,7 +493,7 @@ }, units='lbm', desc='mass of canards', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -519,7 +519,7 @@ }, units='unitless', desc='canard theoretical taper ratio', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -645,7 +645,7 @@ }, units='lbm', desc='mass of passenger baggage', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -678,7 +678,7 @@ }, units='lbm', desc='mass of cargo containers', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -709,7 +709,7 @@ }, units='lbm', desc='total mass of cargo', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -805,7 +805,7 @@ }, units='lbm', desc='total mass of the flight crew and their baggage', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -865,7 +865,7 @@ }, units='lbm', desc='total mass of the non-flight crew and their baggage', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -1012,7 +1012,7 @@ }, units='lbm', desc='TBD: total mass of all passengers without their baggage', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -1033,7 +1033,7 @@ historical_name={"GASP": 'INGASP.WPL', "FLOPS": None, "LEAPS1": None}, units='lbm', desc='mass of passenger payload, including passengers, passenger baggage', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -1052,7 +1052,7 @@ }, units='lbm', desc='mass of passenger service equipment', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -1246,7 +1246,7 @@ }, units='lbm', desc='empty mass margin', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -1261,7 +1261,7 @@ }, units='unitless', desc='empty mass margin scaler', - default_value=0.0, # Note: not 1.0 here + default_value=0.0, ) add_meta_data( @@ -1274,7 +1274,7 @@ meta_data=_MetaData, units='lbm', desc='total mass of all user-defined external subsystems', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -1421,7 +1421,7 @@ }, units='lbm', desc='operating mass empty of the aircraft', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -1501,7 +1501,7 @@ }, units='lbm', desc='Total structural group mass', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -1552,7 +1552,7 @@ }, units='lbm', desc='Total systems & equipment group mass', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -1564,7 +1564,7 @@ historical_name={"GASP": None, "FLOPS": None, "LEAPS1": None}, units='lbm', desc='Total systems & equipment group mass without additional 1% of ' 'empty mass', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -1589,7 +1589,7 @@ }, units='ft**2', desc='total aircraft wetted area', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -1611,7 +1611,7 @@ }, units='lbm', desc='design landing mass', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -1672,7 +1672,7 @@ }, units='lbm', desc='zero fuel mass', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -1732,7 +1732,7 @@ }, units='lbm', desc='mass of the electrical system', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -2594,7 +2594,7 @@ }, units='lbm', desc='mass of vertical fins', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -2635,7 +2635,7 @@ }, units='unitless', desc='vertical fin theoretical taper ratio', - default_value=0.0, # changed from None + default_value=0.0, ) # ______ _ @@ -2656,7 +2656,7 @@ }, units='lbm', desc='fuel capacity of the auxiliary tank', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -2677,7 +2677,7 @@ }, units='unitless', desc='fuel capacity factor', - default_value=1.0, # changed from 23.0 + default_value=1.0, ) add_meta_data( @@ -2731,7 +2731,7 @@ }, units='lbm', desc='fuel system mass', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -2770,7 +2770,7 @@ }, units='lbm', desc='fuel capacity of the fuselage', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -2803,7 +2803,7 @@ desc='Total fuel capacity of the aircraft including wing, fuselage and ' 'auxiliary tanks. Used in generating payload-range diagram (Default = ' 'wing_capacity + fuselage_capacity + aux_capacity)', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -2821,7 +2821,7 @@ }, units='galUS', # need to check this desc='Total fuel volume', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -2840,7 +2840,7 @@ }, units='lbm', desc='unusable fuel mass', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -2876,7 +2876,7 @@ }, units='lbm', desc='fuel capacity of the auxiliary tank', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -3005,7 +3005,7 @@ }, units='lbm', desc='Total furnishings system mass', - default_value=0.0, # changed form None + default_value=0.0, ) add_meta_data( @@ -3014,7 +3014,7 @@ historical_name={"GASP": None, "FLOPS": None, "LEAPS1": None}, units='lbm', desc='Base furnishings system mass without additional 1% empty mass', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -3063,7 +3063,7 @@ }, units='ft', desc='average fuselage diameter', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -3226,7 +3226,7 @@ }, units='lbm', desc='mass of the fuselage structure', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -3261,7 +3261,7 @@ }, units='ft', desc='maximum fuselage height', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -3391,7 +3391,7 @@ }, units='ft**2', desc='fuselage planform area', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -3449,7 +3449,7 @@ }, units='ft**2', desc='fuselage wetted area', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -3592,7 +3592,7 @@ }, units='lbm', desc='mass of horizontal tail', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -3732,7 +3732,7 @@ }, units='ft**2', desc='horizontal tail wetted area', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -3792,7 +3792,7 @@ }, units='lbm', desc='mass of hydraulic system', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -3948,7 +3948,7 @@ }, units='lbm', desc='mass of main landing gear', - default_value=0, # added + default_value=0, ) add_meta_data( @@ -4010,7 +4010,7 @@ }, units='lbm', desc='mass of nose landing gear', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -4088,7 +4088,7 @@ }, units='ft', desc='Average diameter of engine nacelles for each engine model', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -4103,7 +4103,7 @@ }, units='ft', desc='Average length of nacelles for each engine model', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -4300,7 +4300,7 @@ }, units='lbm', desc='mass of paint for all wetted area', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -4355,7 +4355,7 @@ }, units='lbm', desc='Total propulsion group mass', - default_value=0.0, # added + default_value=0.0, ) # TODO clash with per-engine scaling, need to resolve w/ heterogeneous engine @@ -4380,7 +4380,7 @@ historical_name={"GASP": None, "FLOPS": None, "LEAPS1": None}, units='lbm', desc='total estimated mass of the engine controls for all engines on aircraft', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -4389,7 +4389,7 @@ historical_name={"GASP": 'INGASP.WEP', "FLOPS": None, "LEAPS1": None}, units='lbm', desc='total mass of all engines on aircraft', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -4408,7 +4408,7 @@ }, units='lbm', desc='engine oil mass', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -4428,7 +4428,7 @@ units='lbm', desc='sum of engine control, starter, and additional mass for all engines ' 'on aircraft', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -4500,7 +4500,7 @@ historical_name={"GASP": None, "FLOPS": None, "LEAPS1": None}, units='lbm', desc='total mass of thrust reversers for all engines on aircraft', - default_value=0.0, # changed from None + default_value=0.0, ) # _____ _ _ @@ -4764,7 +4764,7 @@ }, units='lbm', desc='mass of vertical tail', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -4861,7 +4861,7 @@ }, units='unitless', desc='vertical tail theoretical taper ratio', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -5033,7 +5033,7 @@ }, units='unitless', desc='Reference aspect ratio, used for detailed wing mass estimation.', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -5053,8 +5053,9 @@ "LEAPS1": 'aircraft.outputs.L0_wing.bending_material_factor', }, units='unitless', - desc='Wing bending material factor with sweep adjustment. Used to compute', - default_value=0.0, # added + desc='Wing bending material factor with sweep adjustment. Used to compute ' + 'Aircraft.Wing.BENDING_MATERIAL_MASS', + default_value=0.0, ) add_meta_data( @@ -5069,7 +5070,7 @@ }, units='lbm', desc='wing mass breakdown term 1', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -5097,7 +5098,7 @@ }, units='lbm', desc='wing mass breakdown term 4', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -5169,7 +5170,7 @@ units='unitless', desc='chord lengths as fractions of semispan at station locations; ' 'overwrites station_chord_lengths', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -5204,7 +5205,7 @@ }, units='ft**2', desc='area of wing control surfaces', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -5219,7 +5220,7 @@ units='unitless', desc='Defines the ratio of total moveable wing control surface areas ' '(flaps, elevators, spoilers, etc.) to reference wing area.', - default_value=0.0, # changed from 0.333 + default_value=0.0, ) add_meta_data( @@ -5261,7 +5262,7 @@ units='unitless', desc='Engine inertia relief factor for wingspan inboard of engine locations. Used ' 'to compute Aircraft.Wing.BENDING_MATERIAL_MASS', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -5578,7 +5579,7 @@ desc='Define the sweep of load path at station locations. Typically ' 'parallel to rear spar tending toward max t/c of airfoil. The Ith value ' 'is used between wing stations I and I+1.', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -5620,7 +5621,7 @@ }, units='lbm', desc='wing total mass', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -5729,7 +5730,7 @@ }, units='lbm', desc='wing mass breakdown term 3', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -5821,7 +5822,7 @@ }, units='lbm', desc='wing mass breakdown term 2', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -5948,7 +5949,7 @@ }, units='lbm', desc='mass of surface controls', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -6060,7 +6061,7 @@ }, units='unitless', desc='the thickeness-chord ratios at station locations', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( @@ -6749,7 +6750,7 @@ units='lbm', desc='fuel carried by the aircraft when it is on the ramp at the ' 'beginning of the design mission', - default_value=0.0, # added + default_value=0.0, ) add_meta_data( @@ -6780,7 +6781,7 @@ }, units='lbm', desc='design gross mass of the aircraft', - default_value=0.0, # changed from None + default_value=0.0, ) add_meta_data( From 352e99983b1bad181ae7442cac646fd5b7695cb4 Mon Sep 17 00:00:00 2001 From: jkirk5 Date: Thu, 16 Jan 2025 15:10:52 -0500 Subject: [PATCH 21/22] update internal version to 0.9.7 --- .bumpversion.cfg | 2 +- .github/ISSUE_TEMPLATE/bug_report.yml | 2 +- CITATION.cff | 2 +- aviary/__init__.py | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/.bumpversion.cfg b/.bumpversion.cfg index 7a9118486..7540c21bd 100644 --- a/.bumpversion.cfg +++ b/.bumpversion.cfg @@ -1,5 +1,5 @@ [bumpversion] -current_version = 0.9.6 +current_version = 0.9.7 commit = False tag = False parse = (?P\d+)\.(?P\d+)\.(?P\d+)(\-(?P[a-z]+))? diff --git a/.github/ISSUE_TEMPLATE/bug_report.yml b/.github/ISSUE_TEMPLATE/bug_report.yml index f8fa1143e..4669664c0 100644 --- a/.github/ISSUE_TEMPLATE/bug_report.yml +++ b/.github/ISSUE_TEMPLATE/bug_report.yml @@ -21,7 +21,7 @@ body: attributes: label: Aviary Version description: What version of Aviary is being used. - placeholder: "0.9.6" + placeholder: "0.9.7" validations: required: true - type: textarea diff --git a/CITATION.cff b/CITATION.cff index c44eee143..4a174317b 100644 --- a/CITATION.cff +++ b/CITATION.cff @@ -27,4 +27,4 @@ identifiers: repository-code: 'https://github.com/OpenMDAO/Aviary' repository: 'https://github.com/OpenMDAO/Aviary_Community' license: Apache-2.0 -version: 0.9.3 +version: 0.9.7 diff --git a/aviary/__init__.py b/aviary/__init__.py index 50533e307..f5b77301f 100644 --- a/aviary/__init__.py +++ b/aviary/__init__.py @@ -1 +1 @@ -__version__ = "0.9.6" +__version__ = "0.9.7" From 87c488c06686b84fc564bc3c72296f6188ca1caa Mon Sep 17 00:00:00 2001 From: jkirk5 Date: Thu, 16 Jan 2025 15:24:16 -0500 Subject: [PATCH 22/22] 0.9.7-dev increment --- .bumpversion.cfg | 2 +- .github/ISSUE_TEMPLATE/bug_report.yml | 2 +- aviary/__init__.py | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/.bumpversion.cfg b/.bumpversion.cfg index 7540c21bd..e7775a430 100644 --- a/.bumpversion.cfg +++ b/.bumpversion.cfg @@ -1,5 +1,5 @@ [bumpversion] -current_version = 0.9.7 +current_version = 0.9.7-dev commit = False tag = False parse = (?P\d+)\.(?P\d+)\.(?P\d+)(\-(?P[a-z]+))? diff --git a/.github/ISSUE_TEMPLATE/bug_report.yml b/.github/ISSUE_TEMPLATE/bug_report.yml index 4669664c0..ef04da1be 100644 --- a/.github/ISSUE_TEMPLATE/bug_report.yml +++ b/.github/ISSUE_TEMPLATE/bug_report.yml @@ -21,7 +21,7 @@ body: attributes: label: Aviary Version description: What version of Aviary is being used. - placeholder: "0.9.7" + placeholder: "0.9.7-dev" validations: required: true - type: textarea diff --git a/aviary/__init__.py b/aviary/__init__.py index f5b77301f..b336982d3 100644 --- a/aviary/__init__.py +++ b/aviary/__init__.py @@ -1 +1 @@ -__version__ = "0.9.7" +__version__ = "0.9.7-dev"