Multirotor

Libraries:
      Aerospace Blockset / 
      Propulsion
   
Description
The Multirotor block computes the aerodynamic forces and moments generated by multiple rotating propellers or rotors, such as quadcopters, in all three dimensions. You can also include simplified flap, or steady state, aerodynamics.
Limitations
- The block follows a simplified approach with the option to include steady state flap effects. It does not model dynamic flap, lag, or feathering motion of blade. 
- The block outputs have been verified against the algorithms used, for input and parameter values within reasonable limits (as observed from literature). 
- The block uses Twist distribution to model only linear or ideal twist distributions. The block assumes that the blade chord and lift curve slope are constant. 
- The block does not include interference effects (between rotors) in the model. 
- The effect of collective pitch input and drag coefficient is incorporated in the block through the thrust and torque coefficients alone. Hence, the collective input port and the drag coefficient is active only when CT and CQ Source dropdown is set to - Compute using BEMT.
Ports
Input
Rotor speed, specified as an N-element vector in rad/sec in body frame. The ordering of the rotors for the two quadcopter configurations (N = 4) considered in the block are as shown in Arm Computations.
Data Types: double
Air density, specified as a positive scalar in specified units.
Data Types: double
Velocity of rotor, specified as a 3-by-1 or 1-by-3 vector in body frame. To perform a multisystem analysis, consider connecting output from a State-Space or Integrator block to this port.
Dependencies
To enable this input, set Modeling to With flap
                    effects.
The unit of velocity depends on the value of the Units
                parameter.
Data Types: double
Angular velocity of entire vehicle, specified as a 3-by-1 or 1-by-3 vector in rad/s in body frame.
Dependencies
To enable this input, set Modeling to With flap
                    effects.
Data Types: double
Collective blade pitch angle, specified as an N-element vector.
Dependencies
To enable this input port, select the Include pitch angle
                    inputs check box and set the CT and CQ Source
                dropdown to Compute using BEMT.
Data Types: double
Lateral cyclic pitch angle, specified as an N-element vector.
Dependencies
To enable this input port,
- Select the Include pitch angle inputs check box. 
- Set Modeling to - With flap effects.
Data Types: double
Longitudinal cyclic pitch angle, specified as an N-element vector.
Dependencies
To enable this input port,
- Select the Include pitch angle inputs check box. 
- Set Modeling to - With flap effects.
Data Types: double
Input thrust coefficient, specified as a nonzero positive scalar or M-by-1 vector.
If scalar, all rotors are assumed to have same value of
                  CT.
Dependencies
To enable this input port, set the CT and CQ Source
                dropdown to 'Ports'.
Data Types: double
Input torque coefficient, specified as a nonzero positive scalar or N-by-1 vector.
If scalar, all rotors are assumed to have same value of
                  CQ.
Dependencies
To enable this output port, set the CT and CQ Source
                dropdown to 'Ports'.
Data Types: double
Output
Total force, returned as a three-element vector in body frame. Units depend on the Units parameter.
Data Types: double
Net moment in the x-y-z direction, returned as a three-element vector in body frame. Units depend on the Units parameter.
Data Types: double
Computed thrust coefficient, returned as a positive vector of N elements.
Dependencies
To enable this output port, select the Output computed CT and
                    CQ check box and set the CT and CQ Source
                dropdown to Compute using BEMT.
Computed torque coefficient, returned as a positive vector of N elements.
Dependencies
To enable this output port, select the Output computed CT and
                    CQ check box and set the CT and CQ Source
                dropdown to Compute using BEMT.
Parameters
Main
| Units | Velocity | Density | Force | Moment | Arm Length | Height | Radius | Chord | Hinge offset | 
|---|---|---|---|---|---|---|---|---|---|
| Metric (MKS) | Meters per second | kg/m3 | Newtons | Newton-meter | Meters | Meters | Meters | Meters | Meters | 
| English (Velocity in ft/s) | Feet per second | slug/ft3 | Pound force | Pound force-feet | Feet | Feet | Feet | Feet | Feet | 
| English (Velocity in kts) | Knots | slug/ft3 | Pound force | Pound force-feet | Feet | Feet | Feet | Feet | Feet | 
Programmatic Use
| Block Parameter: units | 
| Type: character vector | 
| Values: 'Metric (MKS)'|'English (Velocity in ft/s)'|'English (Velocity in kts)' | 
| Default: 'Metric (MKS)' | 
Rotor thrust calculation method, specified as:
- Without flap effects— Model rotor thrust using force and moment calculations. For more information, see Force and Moment.
- With flap effects— Effect of tilt in rotor disc due to flap motion, while in forward flight, is included. The steady state lateral and longitudinal flap angles are calculated using the equations from [1] and used in the computation of forces and moments [2]. For more information, see Force and Moment.
Programmatic Use
| Block Parameter: modelMode | 
| Type: character vector | 
| Values: 'Without flap
                    effects'|'With flap effects' | 
| Default: 'Without flap
                    effects' | 
Select this check box to enable the pitch angle (swash plate) input ports.
Dependencies
To enable this checkbox
- Set the CT and CQ Source dropdown to - Compute using BEMT
and/or
- Set Modeling to - 'With flap effects'
Programmatic Use
| Block Parameter: controlInput | 
| Type: character vector | 
| Values: 'on'|'off' | 
| Default: 'off' | 
Vehicle
Quadcopter configuration, specified as:
- Quadcopter X— Propellers configured as an- Xshape, considered as more stable than the- Quadcopter +configuration.
- Quadcopter +— Propellers configured as a- +shape.
For more information, see Arm Computations.
Programmatic Use
| Block Parameter: config | 
| Type: character vector | 
| Values: 'Quadcopter X'|'Quadcopter +' | 
| Default: 'Quadcopter
                  X' | 
Vehicle arm length, specified as a nonzero positive scalar. This length is the rotor displacement from the center of mass of the vehicle. For more information on arm lengths, see Algorithms.
Programmatic Use
| Block Parameter: armLength | 
| Type: character vector | 
| Values: '0.0624'|
                  nonzero positive scalar | 
| Default: '0.0624' | 
Vertical offset from vehicle center of gravity, specified as a nonzero scalar.
Programmatic Use
| Block Parameter: rotorHeight | 
| Type: character vector | 
| Values: '-0.0159'|
                  nonzero positive scalar | 
| Default: '-0.0159' | 
Rotor
Select the source of the thrust coefficient and torque coefficient values, specified as a
      character vector of value 'Dialog', 'Compute using BEMT'
      or 'Ports'. The block assumes the aerodynamic and structural parameters to
      be constant.
- Select - 'Dialog'to manually enter the thrust and torque coefficient values.
- Select - 'Compute using BEMT'to compute the values using Blade Element Momentum Theory (BEMT). For more information on BEMT, see Thrust Coefficient and Torque Coefficient Calculations.
- Select - 'Ports'to accept the thrust and torque coefficient values as inputs.
Programmatic Use
| Block Parameter: CTCQMode | 
| Type: character vector | 
| Values: 'Dialog'|'Compute using BEMT' | 
| Default: 'Dialog' | 
Thrust coefficient, specified as a nonzero positive scalar or N-by-1 vector.
If you define Thrust coefficient (CT) as a scalar, all the
              rotors are assumed to have same values for CT. If vector, the
              ordering of the rotors is as shown in Arm Computations.
Dependencies
To enable this parameter, set the CT and CQ Source dropdown
                to 'Dialog'.
Programmatic Use
| Block Parameter: CT | 
| Type: character vector | 
| Values: '0.0107'|
                  nonzero positive scalar | 
| Default: '0.0107' | 
Torque coefficient, specified as a nonzero positive scalar or N-by-1 element vector.
If you define Torque coefficient (CQ) as a scalar, all the
              rotors are assumed to have same values for CQ. If vector, the
              ordering of the rotors is as shown in Arm Computations.
Dependencies
To enable this parameter, set the CT and CQ Source dropdown
                to 'Dialog'.
Programmatic Use
| Block Parameter: CQ | 
| Type: character vector | 
| Values: '7.8263e-4'|
                  nonzero positive scalar | 
| Default: '7.8263e-4' | 
Number of blades per rotor, specified as a nonzero positive scalar.
Dependencies
To enable this checkbox,
- Set the CT and CQ Source dropdown to - Compute using BEMT
and/or
- Set Modeling to - 'With flap effects'
Programmatic Use
| Block Parameter: Nb | 
| Type: character vector | 
| Values: '2'| nonzero
                  positive scalar | 
| Default: '2' | 
Select this check box to output the calculated thrust coefficient and torque coefficient to CT and CQ output ports. For more information on these calculations, see Thrust Coefficient and Torque Coefficient Calculations. The block assumes the aerodynamic and structural parameters to be constant.
Otherwise, clear this check box.
Dependencies
To enable this parameter, set the CT and CQ Source dropdown
                to 'Compute using BEMT'.
Programmatic Use
| Block Parameter: CTout | 
| Type: character vector | 
| Values: 'on'|'off' | 
| Default: 'off' | 
Blade
Rotor radius, specified as a nonzero positive scalar.
Programmatic Use
| Block Parameter: radius | 
| Type: character vector | 
| Values: '0.0330'| nonzero positive
                    scalar | 
| Default: '0.0330' | 
Blade chord, specified as a nonzero positive scalar.
Dependencies
To enable this checkbox,
- Set the CT and CQ Source dropdown to - 'Compute using BEMT'.
and/or
- Set Modeling to - 'With flap effects'
Programmatic Use
| Block Parameter: chord | 
| Type: character vector | 
| Values: '0.0080'| nonzero positive
                    scalar | 
| Default: '0.0080' | 
Hinge offset, specified as a positive scalar. This value is typically
                0 for propellers.
Dependencies
To enable this checkbox,
- Set the CT and CQ Source dropdown to - 'Compute using BEMT'.
and/or
- Set Modeling to - 'With flap effects'
Programmatic Use
| Block Parameter: hingeOffset | 
| Type: character vector | 
| Values: '0'| positive
                    scalar | 
| Default: '0' | 
Lift curve slope, specified as a nonzero positive scalar. The block assumes the aerodynamic and structural parameters to be constant. The block does not consider variation with respect to angle of attack.
Dependencies
To enable this checkbox,
- Set the CT and CQ Source dropdown to - 'Compute using BEMT'.
and/or
- Set Modeling to - 'With flap effects'
Programmatic Use
| Block Parameter: clalpha | 
| Type: character vector | 
| Values: '5.5'| nonzero positive
                    scalar | 
| Default: '5.5' | 
Mean drag coefficient, specified as a positive scalar. The block does not consider variation with respect to angle of attack.
Dependencies
To enable this parameter, set the CT and CQ Source dropdown
                to 'Compute using BEMT'.
Programmatic Use
| Block Parameter: cd0 | 
| Type: character vector | 
| Values: '0'| positive
                    scalar | 
| Default: '0' | 
Lock number, which is the ratio of aerodynamics forces to inertial forces, specified as a nonzero positive scalar.
Dependencies
To enable this parameter, set Modeling to With flap effects.
Programmatic Use
| Block Parameter: gamma | 
| Type: character vector | 
| Values: '0.6051'| nonzero positive
                                        scalar | 
| Default: '0.6051' | 
Rotor blade twist distribution, specified as:
- Linear— Close approximation of blade twist distribution.
- Ideal— Optimal approximation of blade twist distribution.
where r is the nondimensional radial location along the blade.
Dependencies
To enable this checkbox,
- Set the CT and CQ Source dropdown to - 'Compute using BEMT'.
and/or
- Set Modeling to - 'With flap effects'
Programmatic Use
| Block Parameter: twistType | 
| Type: character vector | 
| Values: 'Linear'|'Ideal' | 
| Default: 'Linear' | 
Blade root pitch angle θroot, specified as a real scalar.
Dependencies
To enable this parameter:
- Set the CT and CQ Source dropdown to - 'Compute using BEMT'.
and/or
- Set Modeling to - 'With flap effects'
- Set Twist distribution to - Linear.
Programmatic Use
| Block Parameter: thetaRoot | 
| Type: real scalar | 
| Values: '0.2548'| nonzero positive
                                        scalar | 
| Default: '0.2548' | 
Blade twist angle θtwist, specified as a real scalar.
Dependencies
To enable this parameter:
- Set the CT and CQ Source dropdown to - 'Compute using BEMT'.
and/or
- Set Modeling to - 'With flap effects'
- Set Twist distribution to - Linear.
Programmatic Use
| Block Parameter: thetaTwist | 
| Type: real scalar | 
| Values: '0.1018'| positive
                    scalar | 
| Default: '0.1018' | 
Blade tip pitch angle θtip for ideal twist distribution, specified as a real scalar.
Dependencies
To enable this parameter:
- Set the CT and CQ Source dropdown to - 'Compute using BEMT'.
and/or
- Set Modeling to - 'With flap effects'
- Set Twist distribution to - Ideal.
Programmatic Use
| Block Parameter: thetaTip | 
| Type: real scalar | 
| Values: '0.06'| nonzero positive
                    scalar | 
| Default: '0.06' | 
Algorithms
p1 = (d,-d,h)
p2 = (d,d,h)
p3 = (-d,d,h)
p4 = (-d,-d,h)
where:
- l is the arm length. 
- h is the offset from the vehicle center of gravity. 
- . 

In this graphic:
- The x-, y-, z-axes are perpendicular to each other. 
- The four arms of the vehicle are perpendicular and equal in length (l). 
- All propellers are at same height (h). 
p1 = (l,0,h)
p2 = (0,l,h)
p3 = (-l,0,h)
p4 = (0,-l,h)
where:
- l is the arm length. 
- h is the offset from the vehicle center of gravity. 

In this graphic:
- The x-, y-, z-axes are perpendicular to each other. 
- The four arms of the vehicle are perpendicular and equal in length (l). 
- All propellers are at same height (h). 
- Without flap effects 
- With flap effects 
where:
- i is the rotor index and pi is the arm location corresponding to the ith rotor. 
- Ω is the rotor speed in rad/s. 
- βc and βs are the steady state flap angles computed using the equations in Chapter 7 of [1]. 
When the Compute CT and CQ check box is selected, the Multirotor block calculates the thrust coefficient and torque coefficient using these equations.
With the inclusion of Prandtl’s tip loss function, the incremental thrust coefficient using blade element momentum theory is:
where F is the correction factor:
For the equations in this section:
- r is the nondimensional radial location. 
- λ is the inflow through the rotor disc. 
- clα is the lift curve slope. 
- σ is the rotor solidity defined as , where c is the chord, R is the radius and Nb is the number of blades. 
According to blade element theory, the incremental thrust coefficient is:
Here, θ(r) will depend on the blade twist distribution and the collective pitch input θ0. Equating the two expressions for dCT returns 4Fλ² = 0.5 σcıα (θ(r)r − λ), which can be iteratively solved for λ.
Sum dСT = 4Fλ²r dr across the blade span, to find the net thrust coefficient CT.
For the torque coefficient CQ, the profile drag component is approximately included as . The net torque coefficient can be calculated by summing dСQ = λdСT across the blade span and adding the profile drag component.
References
[1] Prouty, Raymond W. Helicopter Performance, Stability, and Control Krieger Publishing Company, 1995.
[2] Riether, F. (2016). Agile quadrotor maneuvering using tensor-decomposition-based globally optimal control and onboard visual-inertial estimation (Doctoral dissertation, Massachusetts Institute of Technology).
Version History
Introduced in R2023aStarting R2025a, you can include CT and
            CQ as optional input ports for the
          Multirotor block, when you set the CT and CQ Source
        dropdown to 'Ports'.
- The Multirotor block has been updated to support swashplate inputs. This addition allows for the inclusion of collective and cyclic blade pitch angles in the calculation of Forces and Moments through new optional input ports. 
- Thrust coefficient (CT)and- Torque coefficient (CQ)parameters now also accept N-element vectors as inputs.
- Starting R2024b, the Multirotor block has been updated to include the dropdown CT and CQ Source with two options: - 'Dialog'and- 'Compute using BEMT'.- Select - 'Dialog'to manually enter the thrust and torque coefficient values.
- Select - 'Compute using BEMT'to compute the values using Blade Element Momentum Theory (BEMT). For more information on BEMT, see Thrust Coefficient and Torque Coefficient Calculations. This option is equivalent to the Compute CT and CQ checkbox from previous releases.
 
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.
选择网站
选择网站以获取翻译的可用内容,以及查看当地活动和优惠。根据您的位置,我们建议您选择:。
您也可以从以下列表中选择网站:
如何获得最佳网站性能
选择中国网站(中文或英文)以获得最佳网站性能。其他 MathWorks 国家/地区网站并未针对您所在位置的访问进行优化。
美洲
- América Latina (Español)
- Canada (English)
- United States (English)
欧洲
- 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)