From 1d7818a71ec481cf03594d1611b12cb45d4511f3 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Wed, 15 May 2024 09:54:02 -0700 Subject: [PATCH 1/7] For battery example, added ExtendedMetaData as meta_data because input deck csv file may contain battery variables. Fixed a typo. --- .../docs/getting_started/onboarding_ext_subsystem.ipynb | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/aviary/docs/getting_started/onboarding_ext_subsystem.ipynb b/aviary/docs/getting_started/onboarding_ext_subsystem.ipynb index 4db2ba9d4..2b05d08c5 100644 --- a/aviary/docs/getting_started/onboarding_ext_subsystem.ipynb +++ b/aviary/docs/getting_started/onboarding_ext_subsystem.ipynb @@ -205,6 +205,7 @@ "source": [ "from aviary.examples.external_subsystems.battery.battery_builder import BatteryBuilder\n", "from aviary.examples.external_subsystems.battery.battery_variables import Aircraft\n", + "from aviary.examples.external_subsystems.battery.battery_variable_meta_data import ExtendedMetaData\n", "\n", "battery_builder = BatteryBuilder(include_constraints=False)\n", "\n", @@ -231,7 +232,8 @@ "source": [ "prob = av.AviaryProblem()\n", "\n", - "prob.load_inputs('models/test_aircraft/aircraft_for_bench_FwFm.csv', phase_info)" + "prob.load_inputs('models/test_aircraft/aircraft_for_bench_FwFm.csv',\n", + " phase_info, meta_data=ExtendedMetaData)" ] }, { @@ -239,8 +241,9 @@ "id": "96ebdf23", "metadata": {}, "source": [ + "Note that we have set `meta_data` to `ExtendedMetaData` so that we can set battery related variables in the model .csv file.\n", "\n", - "In the battery subsystem, the type of battery cell we use is `18650`. The option is not set in `input_file`, instead is is controlled by importing the correct battery map [here](https://github.com/OpenMDAO/Aviary/blob/1fca1c03cb2e1d6387442162e8d7dabf83eee197/aviary/examples/external_subsystems/battery/model/reg_thevenin_interp_group.py#L5)." + "In the battery subsystem, the type of battery cell we use is `18650`. The option is not set in `input_file`, instead it is controlled by importing the correct battery map [here](https://github.com/OpenMDAO/Aviary/blob/1fca1c03cb2e1d6387442162e8d7dabf83eee197/aviary/examples/external_subsystems/battery/model/reg_thevenin_interp_group.py#L5)." ] }, { @@ -755,7 +758,7 @@ "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", - "version": "3.8.17" + "version": "3.9.18" } }, "nbformat": 4, From 176edc0d89e4089a508b54eb209564647f9a4609 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Wed, 15 May 2024 09:58:11 -0700 Subject: [PATCH 2/7] Changed the upper bound and the initial value of Aircraft.Battery.Cell.DISCHARGE_RATE to 2.0 A --- .../examples/external_subsystems/battery/battery_builder.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/aviary/examples/external_subsystems/battery/battery_builder.py b/aviary/examples/external_subsystems/battery/battery_builder.py index bb554b73a..20ab9e1bf 100644 --- a/aviary/examples/external_subsystems/battery/battery_builder.py +++ b/aviary/examples/external_subsystems/battery/battery_builder.py @@ -173,7 +173,7 @@ def get_design_vars(self): Aircraft.Battery.Cell.DISCHARGE_RATE: { 'units': 'A', 'lower': 0.0, - 'upper': 1.0, + 'upper': 2.0, }, } @@ -250,7 +250,7 @@ def preprocess_inputs(self, aviary_inputs): In this case, it sets the values battery performance based on the battery cell type. ''' battery_cell_info_18650 = { - Aircraft.Battery.Cell.DISCHARGE_RATE: [10.5, 'A'], + Aircraft.Battery.Cell.DISCHARGE_RATE: [2.0, 'A'], Aircraft.Battery.Cell.ENERGY_CAPACITY_MAX: [3.5, 'A*h'], Aircraft.Battery.Cell.HEAT_CAPACITY: [1020.0, 'J/(kg*K)'], Aircraft.Battery.Cell.MASS: [0.045, 'kg'], From a34b5a00dd71c06afefe8e4370ad8f2f66f8f5b9 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Wed, 15 May 2024 10:02:02 -0700 Subject: [PATCH 3/7] added meta_data=ExtendedMetaData to load_inputs --- aviary/examples/external_subsystems/battery/run_cruise.py | 4 +++- .../external_subsystems/battery/run_multiphase_mission.py | 3 ++- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/aviary/examples/external_subsystems/battery/run_cruise.py b/aviary/examples/external_subsystems/battery/run_cruise.py index 0e8a4c7bb..0b0ddb6d0 100644 --- a/aviary/examples/external_subsystems/battery/run_cruise.py +++ b/aviary/examples/external_subsystems/battery/run_cruise.py @@ -3,6 +3,7 @@ from aviary.examples.external_subsystems.battery.battery_builder import BatteryBuilder from aviary.examples.external_subsystems.battery.battery_variables import Aircraft, Mission +from aviary.examples.external_subsystems.battery.battery_variable_meta_data import ExtendedMetaData battery_builder = BatteryBuilder() @@ -16,7 +17,8 @@ # Load aircraft and options data from user # Allow for user overrides here -prob.load_inputs('models/test_aircraft/aircraft_for_bench_FwFm.csv', phase_info) +prob.load_inputs('models/test_aircraft/aircraft_for_bench_FwFm.csv', + phase_info, meta_data=ExtendedMetaData) # Preprocess inputs prob.check_and_preprocess_inputs() diff --git a/aviary/examples/external_subsystems/battery/run_multiphase_mission.py b/aviary/examples/external_subsystems/battery/run_multiphase_mission.py index 975dc7ef5..ceb6b46aa 100644 --- a/aviary/examples/external_subsystems/battery/run_multiphase_mission.py +++ b/aviary/examples/external_subsystems/battery/run_multiphase_mission.py @@ -4,6 +4,7 @@ from aviary.examples.external_subsystems.battery.battery_builder import BatteryBuilder from aviary.examples.external_subsystems.battery.battery_variables import Aircraft +from aviary.examples.external_subsystems.battery.battery_variable_meta_data import ExtendedMetaData from aviary.api import default_height_energy_phase_info as phase_info @@ -22,7 +23,7 @@ # Load aircraft and options data from user # Allow for user overrides here -prob.load_inputs(input_file, phase_info) +prob.load_inputs(input_file, phase_info, meta_data=ExtendedMetaData) # Preprocess inputs From fc43dcf290d3222bb0897b4e238d2e518e490833 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Wed, 15 May 2024 10:08:46 -0700 Subject: [PATCH 4/7] added meta_data=ExtendedMetaData to load_inputs --- .../engine_NPSS/define_simple_engine_problem.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/aviary/examples/external_subsystems/engine_NPSS/define_simple_engine_problem.py b/aviary/examples/external_subsystems/engine_NPSS/define_simple_engine_problem.py index 9afd3eda0..9fdd37440 100644 --- a/aviary/examples/external_subsystems/engine_NPSS/define_simple_engine_problem.py +++ b/aviary/examples/external_subsystems/engine_NPSS/define_simple_engine_problem.py @@ -7,6 +7,7 @@ import aviary.api as av from aviary.examples.external_subsystems.engine_NPSS.table_engine_builder import TableEngineBuilder as EngineBuilder +from aviary.examples.external_subsystems.engine_NPSS.engine_variable_meta_data import ExtendedMetaData def define_aviary_NPSS_problem(): @@ -20,7 +21,7 @@ def define_aviary_NPSS_problem(): # Allow for user overrides here # add engine builder prob.load_inputs('models/test_aircraft/aircraft_for_bench_FwFm.csv', - phase_info, engine_builder=EngineBuilder()) + phase_info, engine_builder=EngineBuilder(), meta_data=ExtendedMetaData) prob.check_and_preprocess_inputs() From 24f20c8415dfcdff53fb34bafc5d445cb9f4b6c9 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Wed, 15 May 2024 10:11:10 -0700 Subject: [PATCH 5/7] added a new attribute meta_data to load_inputs --- aviary/interface/methods_for_level2.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/aviary/interface/methods_for_level2.py b/aviary/interface/methods_for_level2.py index 1109d6bb0..a3bacb914 100644 --- a/aviary/interface/methods_for_level2.py +++ b/aviary/interface/methods_for_level2.py @@ -234,7 +234,7 @@ def __init__(self, analysis_scheme=AnalysisScheme.COLLOCATION, **kwargs): self.regular_phases = [] self.reserve_phases = [] - def load_inputs(self, aviary_inputs, phase_info=None, engine_builder=None, verbosity=Verbosity.BRIEF): + def load_inputs(self, aviary_inputs, phase_info=None, engine_builder=None, verbosity=Verbosity.BRIEF, meta_data=BaseMetaData): """ This method loads the aviary_values inputs and options that the user specifies. They could specify files to load and values to @@ -251,7 +251,7 @@ def load_inputs(self, aviary_inputs, phase_info=None, engine_builder=None, verbo # Create AviaryValues object from file (or process existing AviaryValues object # with default values from metadata) and generate initial guesses aviary_inputs, initial_guesses = create_vehicle( - aviary_inputs, verbosity=verbosity) + aviary_inputs, verbosity=verbosity, meta_data=meta_data) # pull which methods will be used for subsystems and mission self.mission_method = mission_method = aviary_inputs.get_val( From 0973e6eef0817b1847c4832d21167ffa2d213338 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Wed, 15 May 2024 10:13:11 -0700 Subject: [PATCH 6/7] added a new attribute to create_vehicle --- aviary/utils/process_input_decks.py | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/aviary/utils/process_input_decks.py b/aviary/utils/process_input_decks.py index 62cf5f9d1..672da5bed 100644 --- a/aviary/utils/process_input_decks.py +++ b/aviary/utils/process_input_decks.py @@ -36,7 +36,7 @@ 'alternate': ProblemType.ALTERNATE, 'fallout': ProblemType.FALLOUT} -def create_vehicle(vehicle_deck='', verbosity=Verbosity.BRIEF): +def create_vehicle(vehicle_deck='', verbosity=Verbosity.BRIEF, meta_data=_MetaData): """ Creates and initializes a vehicle with default or specified parameters. It sets up the aircraft values and initial guesses based on the input from the vehicle deck. @@ -65,7 +65,8 @@ def create_vehicle(vehicle_deck='', verbosity=Verbosity.BRIEF): initial_guesses = {} else: vehicle_deck = get_path(vehicle_deck) - aircraft_values, initial_guesses = parse_inputs(vehicle_deck, aircraft_values) + aircraft_values, initial_guesses = parse_inputs( + vehicle_deck, aircraft_values, meta_data=meta_data) return aircraft_values, initial_guesses From a66eee1b26f6b82b457a4f1479f06903c76ec32c Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Thu, 16 May 2024 09:41:14 -0700 Subject: [PATCH 7/7] reworded one paragraph --- aviary/docs/getting_started/onboarding_ext_subsystem.ipynb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/aviary/docs/getting_started/onboarding_ext_subsystem.ipynb b/aviary/docs/getting_started/onboarding_ext_subsystem.ipynb index 2b05d08c5..aa9bd8752 100644 --- a/aviary/docs/getting_started/onboarding_ext_subsystem.ipynb +++ b/aviary/docs/getting_started/onboarding_ext_subsystem.ipynb @@ -241,7 +241,7 @@ "id": "96ebdf23", "metadata": {}, "source": [ - "Note that we have set `meta_data` to `ExtendedMetaData` so that we can set battery related variables in the model .csv file.\n", + "Since this example contains new variables in the aircraft hierarchy, the metadata for those variables was added to an extended metadata dictionary. We need to pass that into load_inputs so that it can load susbsystem-specific inputs from the csv file.\n", "\n", "In the battery subsystem, the type of battery cell we use is `18650`. The option is not set in `input_file`, instead it is controlled by importing the correct battery map [here](https://github.com/OpenMDAO/Aviary/blob/1fca1c03cb2e1d6387442162e8d7dabf83eee197/aviary/examples/external_subsystems/battery/model/reg_thevenin_interp_group.py#L5)." ]