Source code for RCAIDE.Library.Mission.Segments.Climb.Constant_EAS_Constant_Rate

# RCAIDE/Library/Missions/Segments/Climb/Constant_EAS_Constant_Rate.py
# 
# 
# Created:  Jul 2023, M. Clarke

# ----------------------------------------------------------------------------------------------------------------------
#  IMPORT
# ----------------------------------------------------------------------------------------------------------------------
# RCAIDE 
from RCAIDE.Library.Mission.Common.Update.atmosphere import atmosphere

# Package imports  
import numpy as np
 
# ----------------------------------------------------------------------------------------------------------------------
#  Initialize Conditions
# ----------------------------------------------------------------------------------------------------------------------
[docs] def initialize_conditions(segment): """ Initializes conditions for constant equivalent airspeed climb segment Parameters ---------- segment : Segment The mission segment being analyzed Notes ----- This function sets up the initial conditions for a climb segment with constant equivalent airspeed (EAS) and constant rate of climb. It handles the conversion between EAS and true airspeed accounting for density variations with altitude. **Required Segment Components** segment: - climb_rate : float Rate of climb [m/s] - equivalent_air_speed : float Equivalent airspeed [m/s] - altitude_start : float Initial altitude [m] - altitude_end : float Final altitude [m] - sideslip_angle : float Aircraft sideslip angle [rad] - state: numerics.dimensionless.control_points : array Discretization points [-] conditions : Data State conditions container - analyses: atmosphere : Model Atmospheric model for property calculations **Conversion Process** 1. Compute atmospheric properties at altitude 2. Convert EAS to true airspeed (TAS) using density ratio 3. Decompose TAS into velocity components **Major Assumptions** * Constant equivalent airspeed * Constant rate of climb * Standard atmosphere model * Small angle approximations * Incompressible flow Returns ------- None Updates segment conditions directly: - conditions.frames.inertial.velocity_vector [m/s] - conditions.frames.inertial.position_vector [m] - conditions.freestream.altitude [m] See Also -------- RCAIDE.Framework.Mission.Segments RCAIDE.Library.Mission.Common.Update.atmosphere """ # unpack climb_rate = segment.climb_rate eas = segment.equivalent_air_speed beta = segment.sideslip_angle alt0 = segment.altitude_start altf = segment.altitude_end t_nondim = segment.state.numerics.dimensionless.control_points conditions = segment.state.conditions # check for initial altitude if alt0 is None: if not segment.state.initials: raise AttributeError('initial altitude not set') alt0 = -1.0 * segment.state.initials.conditions.frames.inertial.position_vector[-1,2] # discretize on altitude alt = t_nondim * (altf-alt0) + alt0 # pack conditions conditions.freestream.altitude[:,0] = alt[:,0] # positive altitude in this context # check for initial velocity vector if eas is None: if not segment.state.initials: raise AttributeError('initial equivalent airspeed not set') air_speed = np.linalg.norm(segment.state.initials.conditions.frames.inertial.velocity_vector[-1,:]) else: # determine airspeed from equivalent airspeed atmosphere(segment) # get density for airspeed density = conditions.freestream.density[:,0] MSL_data = segment.analyses.atmosphere.compute_values(0.0,0.0) air_speed = eas/np.sqrt(density/MSL_data.density[0]) # process velocity vector v_mag = air_speed v_z = -climb_rate # z points down v_xy = np.sqrt( v_mag**2 - v_z**2 ) v_x = np.cos(beta)*v_xy v_y = np.sin(beta)*v_xy # pack conditions conditions.frames.inertial.velocity_vector[:,0] = v_x conditions.frames.inertial.velocity_vector[:,1] = v_y conditions.frames.inertial.velocity_vector[:,2] = v_z conditions.frames.inertial.position_vector[:,2] = -alt[:,0] # z points down