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

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

# ----------------------------------------------------------------------------------------------------------------------  
#  IMPORT 
# ----------------------------------------------------------------------------------------------------------------------  
# package imports 
import numpy as np

# ----------------------------------------------------------------------------------------------------------------------  
#  Initialize Conditions
# ----------------------------------------------------------------------------------------------------------------------  
[docs] def initialize_conditions(segment): """ Initializes conditions for constant speed descent at fixed angle Parameters ---------- segment : Segment The mission segment being analyzed - descent_angle : float Fixed descent angle [rad] - air_speed : float True 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 Returns ------- None Notes ----- This function sets up the initial conditions for a descent segment with constant true airspeed and constant descent angle. The vertical speed is determined by the descent angle. Updates segment conditions directly with velocity_vector [m/s], altitude [m], and position_vector [m]. **Calculation Process** 1. Discretize altitude profile 2. Decompose velocity into components using: - Fixed descent angle - Sideslip angle - Constant true airspeed 3. Components calculated as: - v_x = V * cos(β) * cos(-γ) - v_y = V * sin(β) * cos(-γ) - v_z = -V * sin(-γ) where: - V is true airspeed - β is sideslip angle - γ is descent angle **Major Assumptions** * Constant true airspeed * Fixed descent angle * Small angle approximations * Quasi-steady flight * No wind effects See Also -------- RCAIDE.Framework.Mission.Segments """ # unpack descent_angle= segment.descent_angle air_speed = segment.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] # check for initial velocity vector if air_speed is None: if not segment.state.initials: raise AttributeError('initial airspeed not set') air_speed = np.linalg.norm(segment.state.initials.conditions.frames.inertial.velocity_vector[-1,:]) # discretize on altitude alt = t_nondim * (altf-alt0) + alt0 # process velocity vector v_mag = air_speed v_x = np.cos(beta)* v_mag * np.cos(-descent_angle) v_y = np.sin(beta)* v_mag * np.cos(-descent_angle) v_z = -v_mag * np.sin(-descent_angle) # 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 conditions.freestream.altitude[:,0] = alt[:,0] # positive altitude in this context