Attitude Profile (Nadir Pointing)
Calculate shortest quaternion rotation

Libraries:
      Aerospace Blockset / 
      Spacecraft / 
      Spacecraft Dynamics
   
Alternative Configurations of Attitude Profile (Nadir Pointing) Block: 
Attitude Profile (Geographic Pointing) | Attitude Profile (Sun Tracking)
Description
The Attitude Profile blocks calculate the shortest quaternion rotation that aligns the primary alignment vector with the primary constraint vector. A quaternion is defined using the scalar-first convention. Aerospace Blockset™ uses quaternions that are defined using the scalar-first convention.
Provide the primary constraint as either a pointing mode:
- Point at nadir
- Point at celestial body
- Point at LatLonAlt
or via a custom constraint vector. The block then aligns secondary alignment and constraint vectors as much as possible without breaking primary alignment.
The library contains three versions of the Attitude Profile block preconfigured for these common attitude control modes:
- Attitude Profile (Nadir Pointing) — - Point at nadir
- Attitude Profile (Geographic Pointing) — - Point at LatLonAlt
- Attitude Profile (Sun Tracking) — - Point at celestial bodywith Sun as the celestial target
For more information on the coordinate systems the Attitude Profile blocks use, see Algorithms.
Examples
Hohmann Transfer with the Spacecraft Dynamics Block
Model a Hohmann transfer of a spacecraft between two circular coplanar orbits.
Analyzing Spacecraft Attitude Profiles with Satellite Scenario
Propagate orbit and attitude states in Simulink® and visualize computed trajectory and attitude profile in a satellite scenario.
Ports
Input
Position state vector of spacecraft at time tutc.
Data Types: double
Velocity state vector of spacecraft at time tutc, specified as a 3-element vector.
Dependencies
To enable this port, set Constraint coordinate frame (CCF)
                to LVLH.
Data Types: double
Attitude of the spacecraft at tutc, represented as a quaternion from body frame to port coordinate frame, specified as a 4-element vector.
Data Types: double
Current date or time, specified as a scalar, as a Julian date.
Dependencies
To enable this port, perform one of these:
- Set Pointing mode to - Point at celestial bodyor- Point at LatLonAlt
- Select the Allow pointing mode change during run check box. 
Data Types: double
Geodetic latitude and longitude (deg) of a terrestrial point of interest,
              specified as a 1-D array of size 2. This port is used together with altitude when
                Pointing mode is Point at
              LatLongAlt. This location is used as the primary constraint.
Dependencies
To enable this port, do one of these:
- Set Pointing mode to - LatLonAlt.
- Select the Allow pointing mode change during run check box. 
Data Types: double
Altitude of terrestrial point of interest, specified as a scalar. This port is
              used together with geodetic latitude and longitude when Pointing
                mode is Point at LatLongAlt. This location is
              used as the primary constraint. 
Dependencies
To enable this port, do one of these:
- Set Pointing mode to - LatLonAlt.
- Select the Allow pointing mode change during run check box. 
Data Types: double
Primary alignment vector (in body frame), specified as a 3-element vector.
Dependencies
To enable this port, set Primary alignment (body-frame) to
                  Port.
Data Types: double
Secondary alignment vector (in body frame), specified as a 3-element vector.
Dependencies
To enable this port, set Secondary alignment (Body-frame)
                to Port.
Data Types: double
Primary constraint vector, specified as a 3-element vector, in constraint coordinate frame.
Dependencies
To enable this port, set:
- Pointing mode to - Custom.
- Primary constraint (CCF) to - Port.
Data Types: double
Secondary constraint vector, specified as a 3-element vector.
Dependencies
To enable this port, set Secondary constraint (CCF) to
                  Port.
Data Types: double
Output
Quaternion rotation by which to rotate from the spacecraft current orientation to the desired orientation (in body frame), returned as a 4-element vector.
Dependency
To enable this port, select the Output rotation from current to updated attitude check box.
Data Types: double
Updated spacecraft attitude with respect to Port Coordinate Frame following the quaternion rotation, returned as a 4-element vector.
Dependency
To enable this port, select the Output attitude check box.
Data Types: double
Parameters
To output the rotation, select this check box. Otherwise, clear this check box.
Programmatic Use
| Block Parameter:  outputError | 
| Type: character vector | 
| Values: 'on'|'off' | 
| Default: 'on' | 
To output the updated spacecraft attitude as a quaternion rotation from the body frame to the Port coordinate frame, select this check box. Otherwise, clear this check box.
Programmatic Use
| Block Parameter:  outputFinalAttitude | 
| Type: character vector | 
| Values: 'on'|'off' | 
| Default: 'off' | 
Coordinate frame for position, velocity, and attitude (q) ports. For more information about coordinate systems, see Algorithms.
Programmatic Use
| Block Parameter:  portFrame | 
| Type: character vector | 
| Values: 'ICRF'|'Fixed-frame' | 
| Default: 'ICRF' | 
Primary vector alignment pointing mode, specified as Point at
              nadir, Point at celestial body,
              Point at LatLonAlt, or Custom. 
Programmatic Use
| Block Parameter: pointingMode | 
| Type: character vector | 
| Values: 'Point at nadir'|'Point at celestial body'|'Point at LatLonAlt'|'Custom' | 
| Default: 'Point at nadir' | 
To allow pointing mode change during run, select this check box. Otherwise, clear this check box.
Programmatic Use
| Block Parameter: tunablePointing | 
| Type: character vector | 
| Values: 'on'|'off' | 
| Default: 'on' | 
Celestial body with which to align primary alignment vector.
Dependencies
To enable this parameter, set Pointing mode to
                Point at celestial body.
Programmatic Use
| Block Parameter: celestialTarget | 
| Type: character vector | 
| Values: 'Sun'|'Mercury'|'Venus'|'Moon'|'Mars'|'Jupiter'|'Saturn'|'Uranus'|'Neptune'|'Pluto'|'Solar'|'Solar system
                  barycenter'|'Earth-Moon barycenter' | 
| Default: 'Sun' | 
Primary alignment vector source, specified as Port or
              Dialog.
- Port— Specify port alignment array through the A1b port.
- Dialog— Specify port alignment 3-element vector in the accompanying text box (default value of- [0 0 1]).
Dependencies
To specify the port alignment array in a text box, set this parameter to
                Dialog. 
Programmatic Use
| Block Parameter: primaryAlignmentSrc| whenprimaryAlignmentSrcis'Dialog', useprimaryAlignmentto set the
                primary alignment vector | 
| Type: character vector | 
| Values: 'Port'|'Dialog'| primary alignment vector,
                specified 3-element vector | 
| Default: 'Dialog' | 
Secondary alignment vector source, specified as Port or
              Dialog.
- Port— Specify port alignment array through the A2b port.
- Dialog— Specify port alignment 3-element vector in the accompanying text box (default value of- [1 0 0]).
Dependencies
To specify the port alignment array in a text box, set this parameter to
                Dialog. 
Programmatic Use
| Block Parameter: secondaryAlignmentSrc| whensecondaryAlignmentSrcis'Dialog', usesecondaryAlignmentto set the secondary alignment
                vector | 
| Type: character vector | 
| Values: 'Port'|'Dialog'| secondary alignment
                vector, specified as a 3-element vector | 
| Default: 'Dialog' | 
Coordinate frame in which constraint vectors are provided, specified as
              ICRF, Fixed-frame,
              LVLH, NED, or
              Body-fixed. For more information about coordinate systems,
            see Algorithms.
Programmatic Use
| Block Parameter: constraintFrame | 
| Type: character vector | 
| Values: 'ICRF'|'Fixed-frame'|'LVLH'|'NED'|'Body-fixed' | 
| Default: 'ICRF' | 
Primary constraint vector source, specified as Port or
              Dialog.
- Port— Specify primary constraint array through the C1b port.
- Dialog— Specify port constraint 3-element vector in the accompanying text box (default value of- [1 0 0]).
Dependencies
- To specify the port alignment array in a text box, set this parameter to - Dialog.
- This parameter is affected when Constraint coordinate frame (CCF) is set to - Custom.
Programmatic Use
| Block Parameter:  primaryConstraintSrc| whenprimaryConstraintSrcis'Dialog', useprimaryConstraintto set the primary constraint vector | 
| Type: character vector | 
| Values: 'Port'|'Dialog'| primary constraint vector,
                specified as a 3-element vector | 
| Default: 'Dialog' | 
Secondary constraint vector source, specified as Port or
              Dialog.
- Port— Specify secondary constraint array through the C1b port.
- Dialog— Specify port constraint 3-element vector in the accompanying text box (default value of- [0 1 0]).
After the primary alignment vector is aligned with the primary constraint vector, to fully define the rotation, the block attempts to align the secondary alignment vector with the rotation vector. The rotation vector should be the secondary constraint vector.
Whereas the primary constraint is enabled only for the custom pointing mode, the secondary constraint is always enabled.
Dependencies
To specify the port alignment array in a text box, set this parameter to
                Dialog. 
Programmatic Use
| Block Parameter:  secondaryConstraintSrc| whensecondaryConstraintSrcis'Dialog', usesecondaryConstraintto set the secondary constraint
                vector | 
| Type: character vector | 
| Values: 'Port'|'Dialog'| secondary constraint
                vector, specified as a 3-element vector | 
| Default: 'Dialog' | 
Alternative Configurations
The Attitude Profile (Geographic Pointing) block calculates the
            shortest quaternion rotation using the Point at LatLonAlt
            mode.
Libraries:
      Aerospace Blockset / 
      Spacecraft / 
      Spacecraft Dynamics
   
The Attitude Profile (Sun Tracking) block calculates the shortest
            quaternion rotation using the Point at celestial body mode,
            which uses the Sun as the celestial target.
Libraries:
      Aerospace Blockset / 
      Spacecraft / 
      Spacecraft Dynamics
   
Algorithms
The Attitude Profile blocks use Earth-centric and vehicle-centric coordinate systems.
The Earth-centric coordinate system uses the ICRF and fixed-frame coordinate systems:
- International Celestial Reference Frame. This frame can be treated as equal to the ECI coordinate system realized at J2000 (Jan 1 2000 12:00:00 TT). For more information, see ECI Coordinates. 
- Fixed-frame — The fixed-frame for Earth this block uses is the International Terrestrial Reference Frame (ITRF). This reference frame is realized by the IAU2000/2006 reduction from the ICRF coordinate system. This frame is often described as the Earth-centered Earth-fixed reference frame. 
The vehicle-centric coordinate system works in the Body frame, north-east-down (NED), and local vertical, local horizontal (LVLH) coordinate systems.
- Body frame — Fixed in both origin and orientation to the moving craft. For more information, see Body Coordinates. 
- North-east-down — Noninertial system with its origin fixed at the aircraft or spacecraft center of gravity. For more information, see ECI Coordinates. 
- Local vertical, local horizontal — Also known as the spacecraft coordinate system, Gaussian coordinate system, or the orbit frame. LVLH is a rotating, accelerating frame commonly used in studies of relative motion, such as vehicle maneuvering. The axes of this frame are: - R-axis — Points outward from the spacecraft origin along its position vectors (with respect to the center of Earth). Measurements along this axis are referred to as radial. 
- S-axis — Completes the right hand coordinate system. This axis points in the direction of the velocity vector, but is only parallel to it for circular orbits. Measurements along this axis are referred to as along-track or transverse. 
- W-axis — Points normal to the orbital plane. Measurements along this axis are referred to as cross-track. 
 
Version History
Introduced in R2020bTo support idealized attitude control workflows, the Attitude Profile blocks have new parameters and an output port:
- Output rotation from current to updated attitude parameter 
- Output attitude parameter 
- qnew port 
See Also
Attitude Dynamics | CubeSat Vehicle | Orbit Propagator | juliandate
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)

