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

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

# ----------------------------------------------------------------------------------------------------------------------  
#  IMPORT 
# ----------------------------------------------------------------------------------------------------------------------  
# RCAIDE imports 
import RCAIDE

# pacakge imports 
import numpy as np

# ----------------------------------------------------------------------------------------------------------------------  
#  Initialize Conditions
# ----------------------------------------------------------------------------------------------------------------------  
[docs] def initialize_conditions(segment): """ Initializes conditions for constant equivalent airspeed descent at fixed rate Parameters ---------- segment : Segment The mission segment being analyzed - descent_rate : float Rate of descent [m/s] - equivalent_air_speed : float Equivalent airspeed to maintain [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 Returns ------- None Notes ----- This function sets up the initial conditions for a descent segment with constant equivalent airspeed (EAS) and constant descent rate. It handles the conversion between EAS and true airspeed accounting for density variations with altitude. Updates segment conditions directly with velocity_vector [m/s], altitude [m], and position_vector [m]. **Calculation Process** 1. Discretize altitude profile 2. Get atmospheric properties at each altitude 3. Convert EAS to true airspeed: V = EAS/sqrt(ρ/ρ0) where: - ρ is local density - ρ0 is sea level density 4. Decompose velocity into components using: - Fixed descent rate - Sideslip angle - Computed true airspeed **Major Assumptions** * Constant equivalent airspeed * Constant descent rate * Standard atmosphere model * Small angle approximations * Quasi-steady flight See Also -------- RCAIDE.Framework.Mission.Segments RCAIDE.Library.Mission.Common.Update.atmosphere """ # unpack descent_rate = segment.descent_rate eas = segment.equivalent_air_speed alt0 = segment.altitude_start altf = segment.altitude_end beta = segment.sideslip_angle 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 altitude before updating atmosphere conditions.freestream.altitude[:,0] = alt[:,0] # positive altitude in this context # determine airspeed from equivalent airspeed RCAIDE.Library.Mission.Common.Update.atmosphere(segment) # get density for airspeed density = conditions.freestream.density[:,0] MSL_data = segment.analyses.atmosphere.compute_values(0.0,0.0) # 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: air_speed = eas/np.sqrt(density/MSL_data.density[0]) # process velocity vector v_mag = air_speed v_z = descent_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