Metadata-Version: 2.1
Name: aeroutils
Version: 22.2
Summary: Importable utilities for aerospace problem solving.
Home-page: https://github.com/MattCJones/aeroutils
Author: Matthew C. Jones
Author-email: matt.c.jones.aoe@gmail.com
License: MIT License
Keywords: utility aerospace engineering design problem solving
Platform: UNKNOWN
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Science/Research
Classifier: License :: OSI Approved :: MIT License
Classifier: Natural Language :: English
Classifier: Operating System :: OS Independent
Classifier: Topic :: Scientific/Engineering
Classifier: Topic :: Utilities
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
License-File: LICENSE

*******************
Aerospace Utilities
*******************

About
=====

This module contains commonly-used aerospace utilities for problem solving.

    * **Flight Condition**: input altitude to compute common flight condition
      data.  Easily swap between Mach number, true airspeed, calibrated
      airspeed, and equivalent airspeed.  Includes atmospheric data.
    * **Atmosphere**: input altitude to compute 1993 International Standard
      Atmosphere data.  Many relevant, derived quantities are included.


Author
======

Matthew C. Jones <matt.c.jones.aoe@gmail.com>

Installation
============

Install Commands
----------------

Install using the :code:`pip` package-management system.  The easiest method is to
open the terminal and run:

.. code-block:: bash

    pip install aeroutils

Alternatively, manually download the `source code
<https://github.com/MattCJones/aeroutils>`_, unpack, and run:

.. code-block:: bash

    pip install <path/to/aeroutils>

Dependencies
------------

* `numpy <https://numpy.org>`_: widely-used package for scientific computing.
* `pint <https://pint.readthedocs.io>`_: package for dealing with units.

Usage
=====
In a Python script or an ipython notebook, import all utilities with:

.. code-block:: python

    from aeroutils import *

Flight Condition Package
------------------------

The :code:`flightcondition` package can be used to compute and interact with
common flight condition data.

Outputs include:

    * Mach number :code:`mach`
    * True airspeed :code:`TAS`
    * Calibrated airspeed :code:`CAS`
    * Equivalent airspeed :code:`EAS`
    * Dynamic pressure :code:`q_inf`
    * Reynolds number :code:`reynolds_number(ell)`
    * Reynolds number per-unit-length
      :code:`reynolds_number_per_unit_length(length_unit)`
    * Atmosphere data :code:`atm` (see :code:`atmosphere` below) 

Usage:

.. code-block:: python

    from aeroutils import FlightCondition, unit, dimless

    # Compute flight conditions for a scalar or array of altitudes
    altitudes = [0, 10e3, 33.5e3] * unit('ft')
    fc = FlightCondition(altitudes, EAS=300*unit('knots'))

    # Print flight condition data:
    print(f"{fc}")

    # Print extended output in Imperial units:
    print(f"\n{fc.tostring(full_output=True, imperial_units=True)}")

    # Access flight speed formats individually
    M_inf, U_inf, U_CAS, U_EAS = fc.mach, fc.TAS, fc.CAS, fc.EAS

    # Access atmospheric data alone (see Atmosphere class for options)
    atm = fc.atm  # access Atmosphere object 'atm'
    p, T, rho, nu, a = atm.p, atm.T, atm.rho, atm.nu, atm.a

    # Input true/calibrated/equivalent airspeed or Mach number
    fc_TAS = FlightCondition(altitudes, TAS=300*unit('knots'))
    fc_CAS = FlightCondition(altitudes, CAS=300*unit('knots'))
    fc_EAS = FlightCondition(altitudes, EAS=300*unit('knots'))
    fc_mach = FlightCondition(altitudes, mach=0.4535*dimless)

    # Specify desired units on input and output
    altitudes_in_km = [0, 3.048, 10.2108] * unit('km')
    fc_other_units = FlightCondition(altitudes, EAS=154.33*unit('m/s'))
    U_TAS = fc_other_units.TAS
    print(f"\nThe true airspeed in m/s is {U_TAS.to('m/s'):.5g}")
    print(f"The true airspeed in km/s is {U_TAS.to('km/s'):.5g}")

    # Compute additional derived quantities (see class for all options)
    print(f"\nThe dynamic pressure in psi is {fc.q_inf.to('psi'):.5g}")
    ell = 60 * unit('in')  # arbitrary length scale of interest
    print(f"The Reynolds number is {fc.reynolds_number(ell):.5g}")
    print(f"The Reynolds number per-unit-length [1/in] is "
        f"{fc.reynolds_number_per_unit_length('in'):.5g}")

Atmosphere Package
------------------------

The :code:`atmosphere` package can be used to compute and interact with common
standard atmosphere data and derived quantities.

Outputs include:

    * Pressure :code:`p`
    * Temperature :code:`T`
    * Density :code:`rho`
    * Sound speed :code:`a`
    * Dynamic viscosity :code:`mu`
    * Kinematic viscosity :code:`nu`
    * Thermal conductivity :code:`k`
    * Layer name :code:`layer.name`
    * Geometric altitude :code:`h`
    * Geopotential altitude :code:`H`
    * Acceleration due to gravity :code:`g`
    * Mean free path :code:`mean_free_path`

Usage:

.. code-block:: python

    from aeroutils import Atmosphere, unit

    # Compute atmospheric data for a scalar or array of altitudes
    h = [0.0, 12.7, 44.2, 81.0] * unit('km')
    atm = Atmosphere(h)

    # Print abbreviated output:
    print(f"\n{atm}")

    # Print extended output in Imperial units:
    print(f"\n{atm.tostring(full_output=True, imperial_units=True)}")

    # See also the linspace() function from numpy, e.g.
    # h = linspace(0, 81.0, 82) * unit('km')

    # Access individual properties and convert to desired units: "
    p, T, rho, nu, a = atm.p, atm.T, atm.rho, atm.nu, atm.a
    print(f"\nThe pressure in psi is {p.to('psi'):.5g}")

    # Compute additional properties such as thermal conductivity,
    # mean free path, and more (see class for all options)
    print(f"\nThe thermal conductivity is {atm.k:.5g}"
        f"\nThe mean free path = {atm.mean_free_path:.5g}")

License
=======

:code:`aeroutils` is licensed under the MIT LICENSE. See the `LICENSE <https://github.com/MattCJones/aeroutils/blob/main/LICENSE>`_ document.

Disclaimer
==========
The software is provided "as is", without warranty of any kind, express or
implied, including but not limited to the warranties of merchantability,
fitness for a particular purpose and noninfringement. In no event shall the
authors or copyright holders be liable for any claim, damages or other
liability, whether in an action of contract, tort or otherwise, arising from,
out of or in connection with the software or the use or other dealings in the
software.


