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

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

# ----------------------------------------------------------------------------------------------------------------------
#  IMPORT
# ---------------------------------------------------------------------------------------------------------------------- 

# Package imports  
import numpy as np
 
# ----------------------------------------------------------------------------------------------------------------------
#  Initialize Conditions
# ----------------------------------------------------------------------------------------------------------------------
[docs] def initialize_conditions(segment): """ Initializes conditions for linear speed descent at fixed rate Parameters ---------- segment : Segment The mission segment being analyzed - descent_rate : float Rate of descent [m/s] - air_speed_start : float Initial true airspeed [m/s] - air_speed_end : float Final true 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 initials : Data, optional Initial conditions from previous segment Returns ------- None Notes ----- This function sets up the initial conditions for a descent segment with linearly varying true airspeed and constant descent rate. The horizontal velocity components vary with the changing airspeed. Updates segment with velocity vector, altitude, and position vector. **Calculation Process** 1. Discretize altitude profile 2. Calculate true airspeed variation: V = V0 + (Vf - V0)*t where: - V0 is initial airspeed - Vf is final airspeed - t is normalized time/distance 3. Calculate horizontal velocity magnitude: v_xy = sqrt(V^2 - v_z^2) where: - V is local true airspeed - v_z is descent rate 4. Decompose horizontal velocity using sideslip angle: - v_x = v_xy * cos(β) - v_y = v_xy * sin(β) where β is sideslip angle **Major Assumptions** * Linear true airspeed variation * Constant descent rate * Small angle approximations * Quasi-steady flight * No wind effects See Also -------- RCAIDE.Framework.Mission.Segments """ # unpack User Inputs descent_rate = segment.descent_rate v0 = segment.air_speed_start vf = segment.air_speed_end 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 velocity if v0 is None: if not segment.state.initials: raise AttributeError('airspeed not set') v0 = np.linalg.norm(segment.state.initials.conditions.frames.inertial.velocity_vector[-1]) # 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 # process velocity vector v_xy_mag = (vf-v0)*t_nondim + v0 v_z = descent_rate # z points down v_xy_mag = np.sqrt(v_xy_mag**2 - v_z**2 ) v_x = np.cos(beta)*v_xy_mag v_y = np.sin(beta)*v_xy_mag # pack conditions conditions.frames.inertial.velocity_vector[:,0] = v_x[:,0] conditions.frames.inertial.velocity_vector[:,1] = v_y[:,0] 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