The present invention relates to satellite communication systems, and more particularly to a method for computing beamforming weights that optimize communication between a satellite and remote communication devices.
Modern telecommunication satellites use antenna arrays and beamforming techniques to improve the link quality. The antenna array comprises multiple antenna elements. A signal from a remote communication device (terrestrial-based or airborne-based) is detected at each of these elements and the resulting signals are linearly (weighted and) combined to achieve the optimum performance for a link between the satellite and the remote communication device. The beamforming weights take into account the position of the user, the position of the satellite, calibration data for the antenna elements, satellite attitude, etc. The remote communication device is often referred to as a “user”.
When the user and/or the satellite are moving, the optimal beamforming weights vary in time, and must be recomputed with some periodicity to stay current with the position of the user with respect to the satellite. The beamforming weights also must be recomputed for each new user. If a satellite serves multiple, dynamic (moving) users, the required electronic circuitry and the computational burden become a serious obstacle in performing satellite beamforming onboard. This resulted in the introduction of the ground-based beamforming.
In a ground-based beamforming (GBBF) system, signals from the antenna elements of the satellite are transmitted over downlink channels to a ground-based terminal (gateway), and then subsequently combined to ensure a quality link to each user. Ground-based beamforming is virtually free from the resource limitations of the satellite onboard beamforming; however, it faces limitations of a different kind. Transmission of signals from multiple antenna elements requires a significant amount of bandwidth between the satellite and the gateway.
An amalgamation of these two methods forms some number of antenna beams onboard, and transmits the resulting signals to the ground-based gateway, where they are further combined to form one beam for each user. In this method, the onboard beamforming involves the use of fixed, pre-computed weights, which relieves the onboard satellite systems of all the computations required to form beams for multiple, dynamic users. The number of beams formed by the satellite is smaller than the number of antenna elements. This relaxes the bandwidth requirements for the downlink channels to the gateway. Thus, a combination of the onboard beamforming and ground-based beamforming produces a compromise, which may be suitable for some applications.
At one bandwidth extreme, if signals from all of the elements are downlinked to the ground-base gateway, the ground-based beamforming will have enough flexibility to achieve maximum performance for each user. The downside of this approach is that a substantial amount of bandwidth is required to downlink a large number of signals. At the opposite extreme, if the onboard beamforming forms and downlinks just a few signals, the required bandwidth is low, but the ground-based beamforming may not achieve acceptable quality. What is needed is a technique for selecting a compromise configuration that has moderate bandwidth requirements and achieves an acceptable link quality.
Briefly, a method is provided for determining beamforming weights used onboard a satellite and ground-based beamforming weights used in a ground-based station as part of a satellite communication system. This beamforming method is a two-stage beamforming process that uses a reduced downlink bandwidth between the satellite and the ground-based station yet achieves optimal signal-to-noise ratio for the bandwidth allocated for the downlink. The satellite has an antenna array having M plurality of antenna elements. The antenna array detects a signal transmitted from any one or more of a plurality of remote communication devices in the field of view of the satellite and produces M plurality of receive signals. A set of fixed (onboard) beamforming weights are applied to the M plurality of receive signals to produce L plurality of weighted signals, where L is less than M. The satellite transmits the L plurality of weighted signals on corresponding ones of L downlink channels to the ground-based station.
At the ground-based station, the plurality of L downlink channel signals are received and position-dependent ground-based beamforming weights are applied to them. The weighted downlink channel signals are then combined to produce a beamformed receive signal corresponding to the signal received at the satellite for each of the plurality of remote communication devices. For any position of a remote communication device with respect to the satellite, the ground-based beamforming weights are set to values that maximize a signal-to-noise ratio of the beamformed receive signal and the fixed onboard beamforming weights are selected to maximize a minimum signal-to-noise ratio of the received beamformed signal with respect to position of a remote communication device. More specifically, values for the fixed onboard beamforming weights are computed to yield a maximum,
where the maximum is computed over all possible fixed weights A represented by an L×M matrix, the minimum is computed over all possible positions of remote communication devices U, and the signal-to-noise ratio (S/N) is computed for the optimal set of ground-based beamforming weights W={hacek over (W)}.
With reference to
The satellite 100 detects at each of the M plurality of antenna elements the signal transmitted to it from one of the remote communication devices 300(1) to 300(N), thereby producing M plurality of receive signals. The satellite 100 includes sufficient processing or computing capabilities to apply a set of fixed onboard beamforming weights to the M plurality of receive signals to produce L (reduced) number of plurality of weighted signals, where L is less than M. The satellite transmits the L plurality of signals on each of a corresponding one of L plurality of downlink channels to the ground-based gateway 200. The ground-based gateway device 200 receives the L downlink signals and applies a set of variable (user-dependent and position-dependent) beamforming weights to produce a received beamformed signal (single beam) for each remote communication device corresponding to the L weighted signals produced at the satellite 100.
According to the present invention, the fixed onboard beamforming weights used by the satellite 100 and the variable user position-dependent ground-based beamforming (GBBF) weights used by the ground-based gateway unit 200 are computed so as to ensure optimal service to users in some area subject to a reduced downlink channel bandwidth. Thus, as shown in
The beamforming weights on the satellite 100 are fixed during operation, and the beamforming weights at the ground-based station are dynamically adjusted depending on a particular user and the user's position (angle) with respect to the satellite 100. In order for the satellite 100 to serve several users, the onboard beamforming weights need to be selected in such way, that they (in a combination with the GBBF weights) are suitable for any user location within the region of interest (e.g., a cone in the nadir direction) with respect to the satellite. The GBBF weights are applied to the downlink signals and can “customize” the total effect of the two-stage beamforming for each user.
Turning next to
Moving to
The beamforming weights are optimized using the following criterion:
For a user located anywhere in the region of interest, the optimal GBBF weights are computed to maximize the signal-to-noise (S/N) ratio. This procedure defines S/N as a function of the onboard beamforming weights and of the user location (note that this function does not depend on GBBF weights since they are set to optimal values for each case). The onboard weights are selected in such a way that the minimum value of this function with respect to user location is maximized. Mathematically, the set of onboard weights are found that yield the following maximum:
where the maximum is computed over all possible onboard weights A, the minimum is computed over all possible user locations U, and the signal-to-noise ratio is computed for the optimal set of GBBF weights W={hacek over (W)}.
The following describes a technique for finding the optimal GBBF weights for a given set of onboard weights.
Optimal GBBF Weights
Nominal Case
At the input to the ground-based beamforming computation, there is an L-vector {right arrow over (y)}+{right arrow over (N)} of signal and correlated noise. The goal is to find the weights {right arrow over ({hacek over (W)} that maximize the signal-to-noise (S/N) ratio:
where the horizontal bar denotes the mathematical expectation. The maximum of this value is found by requiring
After computing the derivative, a system of L equations results; the j-th equation is as follows:
where the notation σik=
This system of equations is solved for Wi. It has an important feature: if Wi is a solution, then const·Wi is also a solution (the system is homogeneous). This feature is exploited as described hereinafter.
Solving for
and computing the complex conjugate of the result yields the following:
The important fact is that C does not depend on j. This means that C is a scaling factor, and (in view of the homogeneity of the system of equations) can be set to any fixed value, e.g. to 1. This selects one solution of the system of equations represented by equation (2.3); all other solutions can be obtained by scaling this one solution. With this consideration, the system of equations for Wi becomes linear:
Its solution is trivial:
where a hat denotes a matrix. The result can be used in (2.1) to compute the optimal signal-to-noise ratio. Substitution of the solution for Wk* in the denominator of (2.1) yields:
Both the signal {right arrow over (y)} and the covariance noise matrix {circumflex over (σ)} depend on the onboard weights. It is necessary to compute {right arrow over (y)} and {circumflex over (σ)} for any set of onboard weights and for any user position or location. The computation of equation (2.8) becomes relatively easy. The only non-trivial operation is the inversion of an L×L matrix, but there are several very good methods for inverting positive-definite matrices (e.g., LUD decomposition) if the matrix is non-singular and is not close to a singular one.
To reiterate: the final goal is to find the minimum of
over locations of the user, and then the maximum of the result over onboard beamforming weights.
Any maximum-finding algorithm successively tries multiple values of the arguments (in this case, onboard beamforming weights) to find a maximum of the goal function. At each step, the goal function computes the optimum ground-based beamforming weights and the optimal S/N ratio by applying the above formulas. Over the course of numerous matrix computations, this procedure is bound to produce some singular or nearly singular matrices {circumflex over (σ)}, which cannot be reliably inverted for use in equation (2.8). Thus, the straightforward algorithm described above needs to be patched to account for having a singularity (or almost singularity) in matrix {circumflex over (σ)}. The following describes an algorithm for dealing with this essential, albeit not nominal case.
A Case of a Singular Matrix
A singularity occurs when one or more of matrix eigenvalues is zero. This means that a linear operator associated with matrix {circumflex over (σ)} has the following properties:
Thus, a general solution for {right arrow over ({hacek over (W)} of the system of equations (2.6) comprises two terms:
For any value of this second, arbitrary term, equations (2.6) are satisfied, which means that the S/N ratio has a maximum there. Thus, the maximum is not unique, and the problem can be visualized as shown in
This literally puts a new dimension on the problem. To proceed, we should recognize that all these maxima are completely equivalent, and therefore it is necessary to find any one of them (i.e., any point on the line indicated on the surface shown in
To compute {circumflex over (σ)}+{right arrow over (y)}, {right arrow over (y)} is split into two parts; one part lies in the subspace, where {circumflex over (σ)}−1 is defined, and the other part is complementary. We apply {circumflex over (σ)}−1 to the first part; but instead of adding an arbitrary vector in the complementary subspace, we set this arbitrary vector to zero (or do not add it). The result has the feature of being the smallest solution (in the Euclidian sense) of all possible solutions.
This procedure can be translated to the language of eigenvalues and eigenvectors:
Since all eigenvalues and eigenvectors of the pseudoinverse operator {circumflex over (σ)}+ are defined, this procedure defines the operator itself. Now the pseudoinverse operator can be applied to compute the desired set of weights using the following formula:
where eigenvectors are assumed to be normalized (i.e., |{right arrow over (e)}q|2=1), and the summation is carried over all q, which correspond to non-zero eigenvalues.
If we now use this expression in the formula for S/N (see equation (2.8)), the result is as follows:
The matrix {circumflex over (σ)} is Hermitian (formulas for which are described hereinafter), and therefore all of its eigenvalues are real. From equation (2.10) we can see that the signal-to-noise ratio is also real.
The computation of the pseudoinverse operator looks like an illegal trick since we substitute a zero in place of λq−1 when this quantity cannot be computed due to the zero value of λq. However, this so-called trick is in fact completely legitimate and accomplishes the goal of getting values of GBBF weights that produce one particular maximum for the S/N ratio.
A Case of a Nearly Singular Matrix
In the realm of numerical computation, an exact singularity presents the same problems for matrix inversion as a case when one or more of the eigenvalues is very small compared to others. The numerical solution is ill-defined, and its accuracy may suffer tremendously if small eigenvalues are encountered in matrix {circumflex over (σ)}.
Thus, the problem may conceivably arise for small, yet non-zero values of eigenvalues λq. In this case, a strict adherence to the above procedure would require us not to discard this eigenvalue, and its inverse λq−1 for operator {circumflex over (σ)}+ will be very large. Coupled with numerical round-off errors, a large contribution from λq−1 can ruin the quality of computation for the right-hand side of equation (2.10).
Judging from the expression for the right-hand side of equation (2.10), a contribution from small λq may indeed be expected to be large if vector {right arrow over (y)} is selected in some arbitrary way. However, vector {right arrow over (y)} is not independent of eigenvectors and eigenvalues of matrix {circumflex over (σ)}. Indeed, vector {right arrow over (y)} is computed by applying matrix  to vector {right arrow over (x)}, and matrix {circumflex over (σ)} is formed from matrix  too (see below for explicit expressions). It happens that whenever λq is small, the large value of λq−1 in equation (2.10) is more than compensated by a small value of |{right arrow over (y)}·{right arrow over (e)}q*|2 in the product. This curious feature allows for the treatment of small eigenvalues λq in the same way as zero ones, i.e., to exclude the corresponding terms from the summation.
Computation of Vector y
The starting point is the original M-vector {right arrow over (x)} at the input of the satellite antenna. Vector {right arrow over (y)} is formed by applying onboard beamforming weights Aij as follows:
{right arrow over (y)}=·{right arrow over (x)} (3.1)
where A is an L×M matrix.
Correlations s Between Components of Vector y
Vector {right arrow over (x)} has some input noise. Each application of a weight Aij adds another noise component (which is dependent on the value of Aij itself), and finally more noise is added for each of the components of {right arrow over (y)}. Thus, the noise in {right arrow over (y)} can be described by the following model:
where δxj stands for the noise component of the corresponding signal. So far, the different components of δxj are treated as independent. The math does not change significantly if we decide to account for correlations in δxj.
We proceed to computing σik=
In this equation, it is assumed that noise variance for all components of x has the same value; if this assumption is not true (i.e., the M antenna elements are not identical) the resulting equation will be slightly more complex and more computationally intensive. The same is true if δxj are not independent. In this case, the expression for σkn is more complex. Increased complexity in computing σkn will have little effect on the overall complexity of the algorithm for the beamforming. Indeed, σkn needs to be computed only once, and then used in the beamforming computation as an input.
This computation uses onboard beamforming weights Akj and noise figures at different stages to compute σkn. It feeds into equation (2.8).
Numerical Approach
Maximum Search
The max/min problem described above may use commonly available numerical methods. Any numerical method requires that the goal function can be computed for any values of its arguments. In the beamforming application described above, the arguments comprise fixed onboard beamforming weights Akj. With reference to
are computed using equation (2.8) and the corresponding optimal ground-based beamforming weights W for that user position are stored. At 450, the S/N computed at that user position is compared with P and if it is less than P, then at 455 P is updated with that S/N value, essentially updating the worse S/N for the user positions cycled through to this point. Otherwise, at 460 it is determined whether all user positions have been investigated, and if not the process repeats from 420. The goal of the loop 420-460 is to find the lowest value of
over all trial user positions.
After the user position loop is completed, then at 465, it is determined whether a change in the onboard beamforming weights can improve the current value of P. If the determination is positive at 465, then the process repeats from 410 with a new set of onboard beamforming weights. Modern multivariable optimization methods implicitly keep track of the history of changes in the optimized variable, and employ sophisticated criteria to decide if further optimization is warranted. Though these techniques are well known, one can illustrate the principle of their operation on the simplest one-dimensional optimization method, which is called the golden section optimization. In this method, the location of the maximum (or the minimum) is confined to an interval of values of the independent variable, and this interval is reduced by approximately a factor of 1.6 at each iteration. When the interval becomes small enough, the optimization ends. For constrained multivariable optimization, the principles to end optimization are more complex, but in some cases they may be viewed as an extension of those employed by the golden section method. If the determination is negative at 465, then the current set of onboard beamforming weights are selected and are fixed for use on the satellite.
The maximization algorithm takes care of modifying a set of arguments Akj to achieve the maximum value of the goal function. Numerical methods commonly permit imposing constraints on the arguments; for example, the absolute value of Akj may be limited by some upper and/or lower limit due to hardware limitations.
To summarize, the algorithm 400 involves placing test user positions in a circle; for any set of onboard weights, cycle through the test user positions; compute optimal GBBF weights and the S/N ratio at each test user position; select the worst S/N ratio from all test user positions, which defines the goal function for the optimization; and adjust the onboard weights in such way that this goal function is maximized.
For the purposes of illustrating the algorithm 400, the NASA Telecommunications and Data Relay Satellite (TDRS) is discussed below. This satellite has an array of M=32 antenna elements. The algorithm 400 combines the 32 beams in an optimal way for each user position. This means that L GBBF weights are computed separately for each user position and are generally different.
Tradeoff: Number of Channels vs. Antenna Gain
There is a tradeoff for satellite beamforming in order to balance the beamforming performance (i.e., S/N ratio) and the downlink bandwidth. Indeed, there are two limit cases in beamforming system design. At one extreme, the beamforming is done exclusively onboard the satellite and there is only one downlink signal. This option would require the least amount of downlink bandwidth, but would produce mediocre S/N performance (if the onboard beamforming weights cannot be dynamically changed). At the other extreme, all of the M receive signals are downlinked to the ground-based gateway so that the beamforming computations are performed exclusively on the ground. This would produce the best possible S/N performance but would require a large amount of downlink bandwidth. A tradeoff study investigates possible designs that are between these two opposite cases, and provides a quantitative assessment of the beamforming performance and bandwidth requirements.
In this example, there are M=32 antenna elements at the satellite. When the number of downlink channels is the same as the number of antenna elements (i.e., L=M=32), optimal S/N values are trivial to compute, and sophisticated computer methods are not required. Computational methods are required when L is less than M. Results are presented for L=10, 16, and 24 channels.
The S/N ratio as a function of the number L of channels is shown in
The plot in
The system and methods described herein may be embodied in other specific forms without departing from the spirit or essential characteristics thereof. The foregoing embodiments are therefore to be considered in all respects illustrative and not meant to be limiting.
Number | Name | Date | Kind |
---|---|---|---|
4135156 | Sanders, Jr. et al. | Jan 1979 | A |
5917446 | Greenspan | Jun 1999 | A |
6687492 | Sugar et al. | Feb 2004 | B1 |
7260141 | Bierly et al. | Aug 2007 | B2 |
20040259497 | Dent | Dec 2004 | A1 |
20060292990 | Karabinis et al. | Dec 2006 | A1 |
Number | Date | Country | |
---|---|---|---|
20070232227 A1 | Oct 2007 | US |