Skip to content

xjjiang/om-Aviary

This branch is 85 commits ahead of OpenMDAO/Aviary:main.

Folders and files

NameName
Last commit message
Last commit date
Jan 16, 2025
Jan 25, 2025
Mar 27, 2024
Jan 16, 2025
Dec 21, 2023
Sep 16, 2024
Dec 20, 2023
Jan 16, 2025
Dec 21, 2023
Aug 7, 2024
Jan 24, 2024
Dec 21, 2023
Jan 16, 2025

Repository files navigation

Aviary -- NASA's aircraft design tool

All Contributors

Check out the Aviary documentation.

NASA's Aviary Takes Flight (Presented at EAA AirVenture 2024)

Get in touch with the Aviary team at [email protected]

Description

This repository is an OpenMDAO-based aircraft modeling tool that incorporates aircraft sizing and weight equations from its predecessors GASP (General Aviation Synthesis Program) and FLOPS (Flight Optimization System). It also incorporates aerodynamic calculations from GASP and FLOPS and has the capability to use an aerodynamics deck as well as an aircraft engine deck. There are two options for the mission analysis portion of this code, a 2 degrees-of-freedom (2DOF) approach, and a energy-height approach. The user can select which type of mission analysis to use, as well as whether to use the FLOPS-based code or the GASP-based code for the weight, sizing, and aerodynamic relations.

Installation

The simplest installation method for users is to install via pip:

pip install om-aviary

Please see the installation doc page for more detailed instructions. The minimum supported Python version for Aviary is 3.9.

Documentation

The Aviary documentation is located here.

Validation

This code has been validated using output and data from the GASP and FLOPS codes themselves. The GASP-based weight calculations in this code include in their comments which versions of the GASP standalone weights module were used in validation. The aero and EOM subsystem validations were based on runs of the entire GASP and FLOPS code as they stood in the summer of 2021 and the summer of 2022 respectively.

Quick testing

The repository installation can be tested using the command testflo . at the top-level Aviary folder. If you have both SNOPT and IPOPT installed the output should look something like this:

    OK

    Passed:  706
    Failed:  0
    Skipped: 3


    Ran 709 tests using 16 processes
    Wall clock time:   00:00:16.97

Full testing

In addition to all of the quicker tests, we include multiple integration tests within Aviary. These have also been known as "benchmarks". Due to their length, these tests are not run when using the above command. Instead, you can use the run_all_benchmarks.py file in the Aviary/aviary folder, which is just a light wrapper around the testflo call. This will run all of the longer tests in parallel using all of your available CPU cores.

Package versions

Information on the versions of the packages required for Aviary can be found in the most recent GitHub Actions runs. We have also provided a static version of the environment.yml at the top level of the Aviary repo.

Planned future features

Aviary is in active development. We plan to expand its capabilities and have provided a non-exhaustive list of future features.

Contributors ✨

Thanks goes to these wonderful people (emoji key):

Jeff Chapman
Jeff Chapman

πŸ’» πŸ’‘
crecine
crecine

πŸ’» πŸ”£ πŸ‘€
dlcaldwelljr-ama-inc
dlcaldwelljr-ama-inc

πŸ’» πŸš‡ πŸ§‘β€πŸ« πŸ‘€
Eliot Aretskin-Hariton
Eliot Aretskin-Hariton

πŸ’» πŸ” πŸ‘€
Erik Olson
Erik Olson

πŸ’»
DP
DP

πŸ’‘
gawrenn
gawrenn

πŸ’» πŸ’‘
hschilling
hschilling

πŸ’» 🎨
Kenneth Lyons
Kenneth Lyons

πŸ’» πŸ‘€
Jennifer Gratz
Jennifer Gratz

πŸ’» πŸ“– πŸ“† πŸ‘€
Jason Kirk
Jason Kirk

πŸ’» πŸ”£ πŸ“– πŸ‘€
John Jasa
John Jasa

πŸ’» πŸ“– πŸ’‘ πŸ‘€ πŸ“Ή
Kenneth Moore
Kenneth Moore

πŸ’» πŸš‡ πŸ‘€
Rob Falck
Rob Falck

πŸš‡ πŸ§‘β€πŸ«
Ben Margolis
Ben Margolis

πŸ’» πŸš‡
swryan
swryan

πŸ’» πŸš‡
Xun Jiang
Xun Jiang

πŸ’»

This project follows the all-contributors specification. Contributions of any kind welcome!

About

No description, website, or topics provided.

Resources

License

Citation

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 87.7%
  • Jupyter Notebook 12.0%
  • JavaScript 0.2%
  • HTML 0.1%
  • PLSQL 0.0%
  • CSS 0.0%