Simple Variable Mass 3DOF (Wind Axes)
Implement three-degrees-of-freedom equations of motion of simple variable mass with respect to wind axes
Libraries:
      Aerospace Blockset / 
      Equations of Motion / 
      3DOF
   
Description
The Simple Variable Mass 3DOF (Wind Axes) block implements three-degrees-of-freedom equations of motion of simple variable mass with respect to wind axes. The block considers the rotation in the vertical plane of a wind-fixed coordinate frame about a flat Earth reference frame. For more information about the rotation and equations of motion, see Algorithms.
Ports
Input
Applied force along the wind x-axis, specified as a scalar, in the units selected in Units.
Data Types: double
Applied force along the wind z-axis, specified as a scalar.
Data Types: double
Applied pitching moment, specified as a scalar, in the units selected in Units.
Data Types: double
Rate of change of mass (positive if accreted, negative if ablated), specified as a scalar.
Dependencies
To enable this port, select Include mass flow relative velocity.
Data Types: double
Gravity, specified as a scalar.
Dependencies
To enable this port, set Gravity source to
                    External.
Data Types: double
Relative velocity at which mass is accreted to or ablated from the body in body-fixed axes, specified as a two-element vector.
Dependencies
To enable this port, select Include mass flow relative velocity.
Data Types: double
Output
Flight path angle, within ±pi, returned as a scalar, in radians.
Data Types: double
Pitch angular rate, returned as a scalar, in radians per second.
Data Types: double
Pitch angular acceleration, returned as a scalar, in radians per second squared.
Data Types: double
Location of the body in the flat Earth reference frame, (Xe, Ze), returned as a two-element vector.
Data Types: double
Velocity of the body resolved into the wind-fixed coordinate frame, (V, 0), returned as a two-element vector.
Data Types: double
Acceleration of the body with respect to the body-fixed coordinate frame, (Ax, Az), returned as a two-element vector, in the units selected in Units.
Data Types: double
Angle of attack, returned as a scalar, in radians.
Data Types: double
Fuel tank status, returned as:
- 1— Tank is full.
- 0— Tank is neither full nor empty.
- -1— Tank is empty.
Dependencies
To enable this port, set Mass type to Simple Variable.
Data Types: double
Accelerations of the body with respect to the inertial (flat Earth) coordinate frame, returned as a two-element vector. You typically connect this signal to the accelerometer.
Dependencies
To enable this port, select the Include inertial acceleration check box.
Data Types: double
Parameters
Main
Input and output units, specified as Metric (MKS), English (Velocity in ft/s), or English (Velocity in kts).
| Units | Forces | Moment | Acceleration | Velocity | Position | Mass | Inertia | 
|---|---|---|---|---|---|---|---|
| Metric (MKS) | Newton | Newton-meter | Meters per second squared | Meters per second | Meters | Kilogram | Kilogram meter squared | 
| English (Velocity in ft/s) | Pound | Foot-pound | Feet per second squared | Feet per second | Feet | Slug | Slug foot squared | 
| English (Velocity in kts) | Pound | Foot-pound | Feet per second squared | Knots | Feet | Slug | Slug foot squared | 
Programmatic Use
| Block Parameter: units | 
| Type: character vector | 
| Values: Metric (MKS)|English (Velocity in ft/s)|English (Velocity in kts) | 
| Default: Metric (MKS) | 
Body or wind axes, specified as Wind or
								Body.
Programmatic Use
| Block Parameter: axes | 
| Type: character vector | 
| Values: Wind|Body | 
| Default: Wind | 
Mass type, specified according to the following table.
| Mass Type | Description | Default For | 
|---|---|---|
| Fixed | Mass is constant throughout the simulation. | |
| Simple Variable | Mass and inertia vary linearly as a function of mass rate. | |
| Custom Variable | Mass and inertia variations are customizable. | 
The Simple Variable selection conforms to the
							equations of motion described in Algorithms.
Programmatic Use
| Block Parameter: mtype | 
| Type: character vector | 
| Values: Fixed|Simple Variable|Custom Variable | 
| Default: 'Simple Variable' | 
Initial speed of the body, (V0), specified as a scalar.
Programmatic Use
| Block
                                                  Parameter: V_ini | 
| Type: character vector | 
| Values: '100'| scalar | 
| Default: '100' | 
Initial flight path angle of the body, (γ0), specified as a scalar.
Programmatic Use
| Block Parameter: gamma_ini | 
| Type: character vector | 
| Values: '0'| scalar | 
| Default: '0' | 
Initial pitch rotation rate, (q0), specified as a scalar.
Programmatic Use
| Block
                                                  Parameter: q_ini | 
| Type: character vector | 
| Values: '0'| scalar | 
| Default: '0' | 
Initial angle between the velocity vector and the body, (α0), specified as a scalar.
Programmatic Use
| Block Parameter: alpha_ini | 
| Type: character vector | 
| Values: '0'| scalar | 
| Default: '0' | 
Initial location of the body in the flat Earth reference frame, specified as a two-element vector.
Programmatic Use
| Block Parameter: pos_ini | 
| Type: character vector | 
| Values: '[0 0]'| two-element vector | 
| Default: '[0 0]' | 
Initial mass of the rigid body, specified as a scalar.
Programmatic Use
| Block Parameter: mass | 
| Type: character vector | 
| Values: '1.0'| scalar | 
| Default: '1.0' | 
Mass of body when fuel tank is empty, specified as a scalar.
Programmatic Use
| Block Parameter: mass_e | 
| Type: character vector | 
| Values: '0.5'| scalar | 
| Default: '0.5' | 
Mass of body when fuel tank is full, specified as a scalar.
Programmatic Use
| Block Parameter: mass_f | 
| Type: character vector | 
| Values: '3.0'| scalar | 
| Default: '3.0' | 
Inertia of body when fuel tank is empty, specified as a scalar.
Dependencies
To enable this parameter, set Mass type to
                    Simple Variable.
Programmatic Use
| Block Parameter: Iyy_e | 
| Type: character vector | 
| Values: '1.0'| scalar | 
| Default: '1.0' | 
Body inertia when the fuel tank is full, specified as a scalar.
Dependencies
To enable this parameter, set Mass type to
                    Simple Variable.
Programmatic Use
| Block Parameter: Iyy_f | 
| Type: character vector | 
| Values: '3.0'| scalar | 
| Default: '3.0' | 
Gravity source, specified as:
| External | Variable gravity input to block | 
| Internal | Constant gravity specified in mask | 
Programmatic Use
| Block Parameter: g_in | 
| Type: character vector | 
| Values: 'Internal'|'External' | 
| Default: 'Internal' | 
Acceleration due to gravity, specified as a double scalar and used if internal gravity source
            is selected. If gravity is to be neglected in the simulation, this value can be set to
                0. 
Dependencies
- To enable this parameter, set Gravity Source to - Internal.
Programmatic Use
| Block Parameter: g | 
| Type: character vector | 
| Values: '9.81'| scalar | 
| Default: '9.81' | 
Select this check box to add a mass flow relative velocity port. This is the relative velocity at which the mass is accreted or ablated.
Programmatic Use
| Block Parameter: vre_flag | 
| Type: character vector | 
| Values: off|on | 
| Default: 'off' | 
Select this check box to limit the input mass flow rate when one of these is true:
- Fuel tank is full and input mass flow rate is positive. 
- Fuel tank is empty and input mass flow rate is negative. 
When the input mass flow rate might cause the mass to exceed its limits, the block uses a zero mass flow rate value in the equations of motion. For more information, see Algorithms.
If you do not want to limit the input mass flow rate, clear this check box.
Dependencies
To enable this parameter, set Mass type to
									Simple Variable.
Programmatic Use
| Block Parameter: mdot_flag | 
| Type: character vector | 
| Values: 'off'|'on' | 
| Default: 'on' | 
Data Types: double
Select this check box to add an inertial acceleration in flat Earth frame output port. You typically connect this signal to the accelerometer.
Dependencies
To enable the AxeAze port, select this parameter.
Programmatic Use
| Block Parameter: abi_flag | 
| Type: character vector | 
| Values: 'off'|'on' | 
| Default: 'off' | 
State Attributes
Assign a unique name to each state. You can use state names instead of block paths during linearization.
- The number of names must match the number of states, as shown for each item, or be empty. Set all or none of the block states. 
- To assign names to single-variable states, enter unique names between quotes, for example, - 'q'or- "q".
- To assign names to two-variable states, enter a comma-separated list surrounded by braces, for example, - {'Xe','Ze'}.
- If a state parameter is empty ( - ' '), no name is assigned.
- To assign state names with a variable in the MATLAB® workspace, enter the variable without quotes. A variable can be a character vector, cell array of character vectors, or string. 
Velocity state name, specified as a character vector or string.
Programmatic Use
| Block Parameter: V_statename | 
| Type: character vector | string | 
| Values: ''| scalar | 
| Default: '' | 
Position state names, specified as a comma-separated list surrounded by braces.
Programmatic Use
| Block Parameter: pos_statename | 
| Type: character vector | 
| Values: ''| comma-separated list surrounded by braces | 
| Default: '' | 
Body rotation rate state names, specified as a character vector or string.
Programmatic Use
| Block Parameter: q_statename | 
| Type: character vector | string | 
| Values: ''| scalar | 
| Default: '' | 
Flight path angle state name, specified as a character vector or string.
Programmatic Use
| Block Parameter: gamma_statename | 
| Type: character vector | string | 
| Values: ''| scalar | 
| Default: '' | 
Incidence angle state name, specified as a character vector or string.
Programmatic Use
| Block
                                                  Parameter: alpha_statename | 
| Type: character vector | string | 
| Values: ''| scalar | 
| Default: '' | 
Mass state name, specified as a character vector or string.
Programmatic Use
| Block Parameter: mass_statename | 
| Type: character vector | string | 
| Values: ''| scalar | 
| Default: '' | 
Algorithms
The block considers the rotation in the vertical plane of a wind-fixed coordinate frame about a flat Earth reference frame.

The equations of motion are
where the applied forces are assumed to act at the center of gravity of the body. Input variables are wind-axes forces Fx and Fz, body moment My, and . ure, wre, and g are optional input variables. Mass m is limited between mempty and mfull. Whenever mass is saturated at empty or full, for consistency, limit within the equations of motion.
References
[1] Stevens, Brian, and Frank Lewis. Aircraft Control and Simulation. Hoboken, NJ: John Wiley & Sons, 1992.
Extended Capabilities
C/C++ Code Generation
 Generate C and C++ code using Simulink® Coder™.
Version History
Introduced in R2006aThe 3DOF equations of motion have been updated. Existing models created prior to R2021b that contain 3DOF equations of motion blocks continue to run. If you replace a pre-R2021b version of a 3DOF equation of motion block with an R2021b or later version, your updated model might have a higher tendency for algebraic loops. For an example of how to remove algebraic loops using unit delays, see Remove Algebraic Loops. For further information about algebraic loops, see Identify Algebraic Loops in Your Model.
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Sélectionner un site web
Choisissez un site web pour accéder au contenu traduit dans votre langue (lorsqu'il est disponible) et voir les événements et les offres locales. D’après votre position, nous vous recommandons de sélectionner la région suivante : .
Vous pouvez également sélectionner un site web dans la liste suivante :
Comment optimiser les performances du site
Pour optimiser les performances du site, sélectionnez la région Chine (en chinois ou en anglais). Les sites de MathWorks pour les autres pays ne sont pas optimisés pour les visites provenant de votre région.
Amériques
- América Latina (Español)
- Canada (English)
- United States (English)
Europe
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)
