The present disclosure relates to aerospace vehicles and controlling the attitude of an aerospace vehicle, and more particularly to on-line inertia estimation for use in controlling an attitude of an aerospace vehicle.
Aerospace vehicles, such as spacecraft, including satellites and other space vehicles, orbit the earth performing a multitude of different functions and operations, such as links in telecommunications systems, photographing selected geographical areas, sensing or measuring different conditions on the earth, and monitoring weather patterns and conditions, to name a few. The attitude of these spacecraft or orientation relative to some reference, such as the earth, sun, etc., is critical to the proper performance of these spacecraft. The stability and accuracy of a satellite rotating about a given axis is a concern in many known aerospace applications. For example, some known spacecraft, such as geosynchronous communication satellites, spin about a geometric axis during transfer orbit. The performance of spin axis control directly impacts procedures such as attitude determination, thermal control, propellant management, fuel-efficient velocity increment maneuvers, command and telemetry linkage and solar power collection. While operating a spacecraft with attitude only measurements (e.g. from a star tracker) during transfer orbit, the ability of a closed-loop control system on board the spacecraft to regulate the cone angle is limited by a priori knowledge of the spacecraft's moments of inertia. The system relies upon ground-based off-line inertia estimates computed based on painstaking and time consuming modeling. These ground-based estimates of inertia, especially products of inertia, typically have errors that can result as cone angle errors. Such errors can also adversely effect orientation or pointing accuracy of the satellite, apogee thruster inefficiency, increased operation of reaction wheels or other momentum conserving actuators resulting in increased power usage and thermal loads as well as other adverse effects.
In accordance with an embodiment, a system for controlling an aerospace vehicle using on-line inertia estimation may include a processor on board the aerospace vehicle. An inertia estimator operable on the processor may generate an on-line estimate of the aerospace vehicle inertia. A rate and attitude estimator operable on the processor may determine an angular position and angular velocity of the aerospace vehicle using an attitude measurement and the on-line inertia estimate for controlling movement and orientation of the aerospace vehicle without measurement of any rates of rotation of the aerospace vehicle being required.
In accordance with another embodiment, an aerospace vehicle may include a plurality of actuators for controlling an attitude of the aerospace vehicle. The aerospace vehicle may also include a system for controlling the plurality of actuators using on-line inertia estimation. The system for controlling the plurality of actuators using on-line inertia estimation may include a processor on board the aerospace vehicle. An inertia estimator operable on the processor may generate an on-line inertia estimate of the aerospace vehicle. A rate and attitude estimator operable on the processor may determine an angular position (or attitude) and angular velocity (or angular rates of rotational motion) of the aerospace vehicle using the attitude measurement and the on-line inertia estimate for controlling movement and orientation of the aerospace vehicle.
In accordance with another embodiment, a method for controlling an aerospace vehicle using on-line inertia estimation may include measuring an attitude of the aerospace vehicle. The method may additionally include determining an on-line inertia estimate of the aerospace vehicle. The method may also include determine an angular position and angular velocity of the aerospace vehicle using the attitude measurement and on-line inertia estimate. The method may further include controlling movement and orientation of the aerospace vehicle based on the estimated angular position and angular velocity of the aerospace vehicle.
In accordance with another embodiment, a computer program product for controlling an aerospace vehicle using on-line inertia estimation may include a computer readable storage medium having computer readable program code embodied therewith. The computer readable program code may include computer readable program code configured to determine an on-line inertia estimate of the aerospace vehicle. The computer readable program code may also include computer readable program code configured to determine an angular position and angular velocity of the aerospace vehicle using an attitude measurement and the on-line inertia estimate. The computer readable program code may additionally include computer readable program code configured to control movement and orientation of the aerospace vehicle based on the estimated angular position and angular velocity of the aerospace vehicle.
Other aspects and features of the present disclosure, as defined solely by the claims, will become apparent to those ordinarily skilled in the art upon review of the following non-limited detailed description of the disclosure in conjunction with the accompanying figures.
The following detailed description of embodiments refers to the accompanying drawings, which illustrate specific embodiments of the disclosure. Other embodiments having different structures and operations do not depart from the scope of the present disclosure.
The following detailed description of embodiments refers to the accompanying drawings, which illustrate specific embodiments of the disclosure. Other embodiments having different structures and operations do not depart from the scope of the present disclosure.
As will be appreciated by one of skill in the art, features of the present disclosure may be embodied as a method, system, or computer program product. Accordingly, the present disclosure may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, the present disclosure may take the form of a computer program product on a computer-usable storage medium having computer-usable program code embodied in the medium.
Any combination of one or more computer-readable medium(s) may be utilized. The computer-readable medium may be a computer readable signal medium or a computer readable storage medium. A computer-readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, a device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer-readable storage medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. Note that the computer-readable storage medium could even be paper or another suitable medium upon which a program is printed, as the program can be electronically captured, via, for instance, optical scanning of the paper or other medium, then compiled, interpreted, or otherwise processed in a suitable manner, if necessary, and then stored in a computer memory. In the context of this document, a computer-readable storage medium may be any medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
A computer readable signal medium may include a propagated data signal with computer-usable program code embodied therein, for example, in base band or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof, A computer readable signal medium may be any computer-readable medium that can contain, store, communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
Program code embodied on a computer-readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc.
Computer program code for carrying out operations of the present disclosure may be written in an object oriented programming language such as Java, Smalltalk, C++ or the like. However, the computer program code for carrying out operations of the present disclosure may also be written in conventional procedural programming languages, such as the “C” programming language or similar programming languages, or in functional programming languages, such as Haskell, Standard Meta Language (SML) or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
Aspects of the present disclosure are described below with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the disclosure. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
These computer program instructions may also be stored in a computer-readable memory that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory produce an article of manufacture including instruction means which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide steps for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
The inertia estimator 106 may be adapted to generate the on-line inertia estimate without requiring information from an angular rate sensor. The inertia estimator 106 may also operate in parallel with the rate and attitude estimator 108. The on-line inertia estimate from the inertia estimator 106 provides improved accuracy of the angular position and angular velocity estimate of the aerospace vehicle 100 to permit reduced aerospace vehicle power use and thermal loading for active nutation control of a spinning aerospace vehicle.
As described in more detail herein, the inertia estimator 106 may generate the on-line inertia estimate by generating an on-line estimate of an inertia matrix (Îb) about a center of mass of the aerospace vehicle 100 using an estimated angular velocity ({circumflex over (ω)}) of the aerospace vehicle 100 and a measured or estimated momentum (hW) of an attitude control actuator 110. The inertia estimator 106 may generate the inertia estimate by defining a gyroscopic moment term derived from the estimated angular velocity and the estimated momentum of the aerospace vehicle 100. The gyroscopic moment term may be driven to zero to obtain convergence of the angular velocity of the vehicle 100. The gyroscopic moment term may be driven to zero by defining a cost function incorporating the gyroscopic moment term and then optimizing the cost function. The cost function is driven to zero to cause an angular velocity estimate of the aerospace vehicle 100 to converge to a true angular velocity of the aerospace vehicle.
A feed-forward determination module 112 or calculation module may receive the inertia estimate or estimated inertia matrix (Îb) from the inertia estimator 106. The feed-forward determination module may determine or compute an estimated angular acceleration (αff) in response to a control torque command signal (τw) and coupling between the angular velocity (ω) and the momentum (h) of the aerospace vehicle 100. The coupling between the angular velocity (co) and the momentum (h) may be determined or computed based on the estimated inertia (Îb) from inertia estimator 106, the estimated angular velocity ({circumflex over (ω)}), and measured or estimated wheel momentum (hW) or momentum of attitude control actuators 110.
The rate and attitude estimator 108 may determine the angular position and angular velocity ({circumflex over (ω)}) of the aerospace vehicle 100 by propagating the equations of motion based on estimated angular accelerations (αff) from the feed-forward determination module 112. When attitude measurement data is available, the difference between the measured and estimated attitude may be used to update angular position and angular velocity estimates. The aerospace vehicle 100 may include attitude sensors 114 that may sense an attitude of the aerospace vehicle 100 and other information related to orientation or movement of the aerospace vehicle 100. The attitude measurement data (qm) may be provided by the attitude sensor 114 or sensors to the rate and attitude estimator 108.
The aerospace vehicle 100 may also include an attitude control module 116. The attitude control module may receive the estimated angular rate or angular velocity ({circumflex over (ω)}) from the rate and attitude estimator 108. The attitude control module 116 may include a spin stabilizing control law for active nutation control of the aerospace vehicle using attitude control actuators 110 which may include reaction wheels or other momentum conserving actuators. The attitude control module 116 may determine or compute the control torque command signal (τw) for controlling operation of the attitude control actuators 110 and for use by the feed-forward determination module 112 in determining the estimated angular acceleration (αff) for the attitude and rate estimator 108.
As previously discussed, the inertia estimator 106 generates an on-line or real-time inertia estimate that is autonomously and automatically generated as described herein and does not need a priori knowledge or information from an angular rate sensor, such as a gyroscope or similar device. Euler's equations for rotation of a rigid spacecraft or aerospace vehicle with reaction wheels (or momentum wheel, control momentum gyros, etc.) may be written as equation 1:
is the angular velocity (or rates) of the aerospace vehicle 100 represented in the vehicle coordinate system, hw, is the composite wheel momentum represented in the vehicle coordinate system, and
is the composite inertia matrix of the vehicle about the center of mass. {dot over (x)} represents the time derivative of variable x. u={dot over (h)}w is the control torque, ωx is a skew-symmetric matrix based on three elements of ω, defined as
ωx is the matrix form of a vector cross product, i.e.,
ω×(Ibω+hw)=ωx(Ibω+hw) Eq. 2
Letting {circumflex over (ω)} be the estimated angular velocity, Îb be the estimated inertia matrix of the aerospace vehicle, {circumflex over (ω)} may be propagated based on Eq. 1 by substituting ω and Ib by {circumflex over (ω)} and Îb, respectively. Assuming u is a stabilizing control law for spinning about a given axis, generated based on the estimated angular velocity. At steady-state, both the angular velocity ω and the estimated angular velocity {circumflex over (ω)} will converge to a constant. At steady-state, Equation 1 reduces to Equation 2A, which is the condition with no transverse torques:
ωx(Ibω+hw)=0 Eq. 2A
However, {circumflex over (ω)}x(Îb{circumflex over (ω)}+hw) may not be zero if the estimated inertia matrix is not equal to the true inertia matrix. Inaccuracy of {circumflex over (ω)}x(Îb{circumflex over (ω)}+hw) can lead to errors in attitude and rate estimate. In order to break this, {circumflex over (ω)}x(Îb{circumflex over (ω)}+hw) is driven to zero. This can be achieved by updating Îb on-line. The following notation is defined:
The body momentum vector can be written as Ibω=Ωv. Additionally, {circumflex over (v)} and {circumflex over (Ω)} may represent estimates for v and Ω, respectively. A gyroscopic moment term may now be defined as equation 5:
G({circumflex over (v)})={circumflex over (ω)}x({circumflex over (Ω)}{circumflex over (v)}+hw) Eq. 5
The gyroscopic moment term may be driven to zero in order to obtain convergence of the angular velocity and attitude estimates for the vehicle 100. Driving the gyroscopic moment term to zero may be achieved by optimizing {circumflex over (v)} for a cost function. A cost function J({circumflex over (v)}) may be defined as in Equation 6:
Then the cost function can be minimized by updating {circumflex over (v)} along the gradient of J({circumflex over (v)}) with respect to {circumflex over (v)}, i.e.
{circumflex over ({dot over (v)}=−Γ∇J{circumflex over (v)}T−Γ({circumflex over (ω)}x{circumflex over (Ω)})T{circumflex over (ω)}x({circumflex over (Ω)}{circumflex over (v)}+hw) Eq. 7
Where Γ is a positive definite or a positive semi-definite gain matrix for the inertia estimator 106.
Since J({circumflex over (v)})≧0 at t=0, and J({circumflex over (v)}) is decreasing by virtue of Equation 7, then J({circumflex over (v)})→0 as t→∞, which implies that G({circumflex over (v)})={circumflex over (ω)}x({circumflex over (Ω)}{circumflex over (v)}+hw)→0. In addition, the convergence in estimated angular velocity in Equation 6 implies that the equilibrium condition is for
ω0x(Ω0{circumflex over (v)}+hw0)=0 Eq. 8
In the case of z-spin, ω0=[0 0 ωs]T the equilibrium conditions for Equation 1 implies that hw10=−I13ωs, and hw20=−I23ωs. Substituting these expressions for equilibrium angular velocity and wheel momentum in Equation 8 finally yields Î13→I13 and Î23→I23. Accordingly, a conclusion may be made that the inertia estimator 106 will converge to the correct value for the products of inertia I13 and I23.
In block 202, momentum of an attitude control actuator or actuators may be measured or estimated. Similar to that previously described the attitude control actuator or actuators may include a reaction wheel or other momentum conserving actuator.
In block 204, attitude information or data may be measured or estimated. For example the angular position of the aerospace vehicle may be determined using attitude sensors.
In block 206, attitude and angular velocity of the aerospace vehicle or spacecraft may be determined or estimated relative to S-axes of motion of the vehicle. As previously discussed, propagating equations of motion based on estimated angular accelerations may be used to estimate the attitude and angular velocity of the vehicle. A difference between the measured and estimated attitude may be used to update the attitude and angular velocity estimates when the attitude measurement data is available.
In block 208, a vehicle inertia matrix may be determined or estimated about a center of mass using the estimated angular velocity and measure or estimated momentum of the attitude control actuator.
In block 210, a feed-forward angular acceleration due to control torque and coupling between angular velocity and momentum of the vehicle may be determined or estimated using estimated angular velocity and estimated inertia of vehicle.
In block 212, a control torque command may be determined for the attitude control actuators based on determined or estimated angular velocity. Similar to that previously described, a stabilization control law may be used for active nutation control about a given spin axis of the vehicle using reaction wheels or other momentum conserving actuators.
Although specific embodiments have been illustrated and described herein, those of ordinary skill in the art appreciate that any arrangement which is calculated to achieve the same purpose may be substituted for the specific embodiments shown and that the embodiments herein have other applications in other environments. This application is intended to cover any adaptations or variations of the present disclosure. The following claims are in no way intended to limit the scope of the disclosure to the specific embodiments described herein.
Number | Name | Date | Kind |
---|---|---|---|
5452869 | Basuthakur et al. | Sep 1995 | A |
5749545 | Gnatjuk | May 1998 | A |
5984238 | Surauer et al. | Nov 1999 | A |
6000661 | Price et al. | Dec 1999 | A |
6062512 | Wang et al. | May 2000 | A |
6260805 | Yocum et al. | Jul 2001 | B1 |
6263264 | Herman et al. | Jul 2001 | B1 |
6285928 | Tilley et al. | Sep 2001 | B1 |
6317662 | Li et al. | Nov 2001 | B1 |
6341249 | Xing et al. | Jan 2002 | B1 |
6471161 | D'Ambrosio et al. | Oct 2002 | B1 |
7076341 | Holt et al. | Jul 2006 | B2 |
7076342 | Fukuda et al. | Jul 2006 | B2 |
7110915 | Wilson | Sep 2006 | B2 |
7149610 | Wang et al. | Dec 2006 | B2 |
7248948 | Shiho et al. | Jul 2007 | B2 |
20020148930 | Yamashita | Oct 2002 | A1 |
20030216864 | Fukuda et al. | Nov 2003 | A1 |
20100019092 | Liu et al. | Jan 2010 | A1 |
20110024571 | Tsao et al. | Feb 2011 | A1 |
Number | Date | Country |
---|---|---|
2 279 947 | Feb 2011 | EP |
2000296800 | Oct 2000 | JP |
Number | Date | Country | |
---|---|---|---|
20110153122 A1 | Jun 2011 | US |