1. Technical Field
The present invention relates to optimizing utility in broadband wireless systems, and more particularly, to allocating resources and assigning modulation and coding schemes to a scalable video multicast in wireless data systems.
2. Description of the Related Art
Next generation cellular wireless networks (i.e. 4G) are expected to deliver a much higher spectrum efficiency and bandwidth. International Telecommunication Union (ITU) requires that a 4G technology should provide a peak data rate of 100 Mbps for high mobility applications and 1 Gbps for low mobility applications. Consequently, 4G networks can provide real-time video services, including internet protocol television (IPTV) services, live video streaming, and online telecast of sports.
Nevertheless, due to the fact that the wireless spectrum is shared by many users and that each streaming video service may have very large bandwidth and stringent delay requirements, efficient resource allocation is still necessity in such a network. When multiple users attempt to access the same video content simultaneously (e.g., during a live sport or entertainment event), wireless multicast provides an efficient mechanism to support such services because of the shared nature of the wireless medium.
In nearly all wireless networks, a transmitter (i.e., the base stations in the video streaming services) can choose a modulation and coding scheme (MCS) based on the channel quality and the device capability at the receivers. An issue with modulation and coding schemes in prior art wireless multicast services is that, when multiple receivers experience heterogeneous channel conditions (e.g., due to their distance to the cellular towers or their locations), a robust modulation and coding scheme that is receivable by all wireless clients in the multicast group is normally employed to accommodate all receivers. Although scalable video coding (SVC) helps to rectify this problem in some respect, problems still exist with regard to allocating radio resources and assigning modulation and coding schemes.
In accordance with the present principles, a method is provided for optimizing utility in a wireless data system. According to this method, a connection is first established with a plurality of receiver devices. After the connection has been established, feedback is received from the receiver devices at periodic intervals, wherein the feedback includes channel quality information. A map is computed for each of a plurality of modulation and coding schemes (MCSs) using the received feedback, wherein the map associated with each MCS reflects the set of receiver devices capable of receiving that particular MCS. Once the MCSs have been mapped, one of the MCSs is assigned to each of a plurality of variable-sized layers of at least one video session with the aim of optimizing total system utility.
In accordance with the present principles, a system is also provided. The system contains a session negotiation unit for establishing a connection with a plurality of receiver devices and a channel feedback unit for receiving feedback from each of the plurality of receiver devices at periodic intervals, wherein the feedback includes channel quality information. In addition, the system includes a resource allocation unit configured to compute a map for each of a plurality of modulation and coding schemes using the received feedback, wherein the map associated with each modulation and coding scheme reflects the set of receiver devices capable of receiving that particular MCS. The system is also configured to assign an MCS to each of a plurality of variable-sized layers of at least one video session with the aim of optimizing total system utility.
These and other features and advantages will become apparent from the following detailed description of illustrative embodiments thereof, which is to be read in connection with the accompanying drawings.
The disclosure will provide details in the following description of preferred embodiments with reference to the following figures wherein:
The description provided herein is directed to utility optimization in wireless systems with scalable video encoding. As explained in further detail below, the present principles provide both a single-session scheme for optimizing utility in a wireless system with a single video session, and a multi-session scheme for optimizing utility in a wireless system with a plurality of sessions.
To maximize system utility in the single-session scenario, a connection is first established between a base station and a plurality of receiver devices which can potentially receive the video session. At each frame, the base station receives channel state information from the connected receiver devices which includes the average signal-to-interference-and-noise ratio (SINR). Using this information, the base station is able to map each MCS to the set of receiver devices which can receive that MCS. Then, the base station uses an intra-session MCS assignment scheme to assign the appropriate MCS to each layer of the video session in such a way that maximizes utility of users. The intra-session MCS assignment scheme uses dynamic programming to assign a MCS to each layer of the video session such that total system utility of all users is maximized. After a MCS has been assigned to each layer of the video session, a multicast data transmission is scheduled for the video session.
The present principles also provide a method for optimizing utility in a multi-session scenario. More specifically, after connections have been setup and MCS mapping is complete, the above-mentioned intra-session MCS assignment method can be used to assign a MCS to each layer of each video session in the system. However, unlike in the single session scenario, the allocation of resources among the multiple video sessions should also be considered in the multi-session scenario. Therefore, after the appropriate MCSs have been assigned to the layers of each video session, an inter-session resource allocation scheme is used to allocate resources among the multiple video sessions. Like the intra-session MCS assignment scheme, the inter-session resource allocation aims at optimizing system utility. By combining the intra-session MCS assignment scheme with the inter-session resource allocation scheme, a two-step dynamic programming scheme is provided which maximizes the utility of all receiver devices in a wireless system.
Three particular points should be noted regarding the schemes described herein. First, the utility function provided is quite general. It can be both user-dependent and session-dependent and it only needs to be non-negative and non-decreasing with respect to the received data rate. Second, it is not required that all video layers have equal length. This allows for more flexibility at the video encoding process. Finally, it is not required that the base layer be received by all wireless clients. An advantage of such a choice is that it can provide an automatic admission control at both the session level and the user level. For example, if accepting a new session or a new user's request may dramatically reduce the utilities of other existing users, it is probably better not to accept the new session or the new user. Moreover, if it is required to accommodate all users with at least the base layers, the proposed algorithms can be applied on the enhancement layers after allocating slots for the base layers of all multicast sessions.
Embodiments described herein may be entirely hardware, entirely software or they may include both hardware and software elements. In a preferred embodiment, the present invention is implemented in software, which includes but is not limited to firmware, resident software, microcode, etc.
Embodiments may include a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system. A computer-usable or computer readable medium may include any apparatus that stores, communicates, propagates, or transports the program for use by or in connection with the instruction execution system, apparatus, or device. The medium can be magnetic, optical, electronic, electromagnetic, infrared, or semiconductor system (or apparatus or device) or a propagation medium. The medium may include a computer-readable medium such as a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk and an optical disk, etc.
Referring now in detail to the figures in which like numerals represent the same or similar elements and initially to
As can be seen in
When a mobile user 60 is interested in joining a multicast session or would like to open a new video session, the user sends a request to the base station 80. Upon receiving the request, the session negotiation unit 83 establishes a new session for the user or allows a user to join an existing session. The session negotiation unit 83 then updates the collection of sessions as well as the set of users in each session. Ideally, the mobile user should include its utility as a function of the received rate as well as its channel SINR in the request. The utility function can be simplified. For example, if the base station and the user have agreed that the utility function is the weighted peak signal-to-noise ratio (PSNR) of the video clip, the user only needs to send its weight, which can reflect how much the user is willing to pay for each unit of PSNR values the user receives. In this case, the objective of the base station is to maximize the total profit it can make.
When a mobile user 60 determines to leave a multicast session, the user sends an exit request to base station 80. Upon receiving the exit request, the request is forwarded to the session negotiation unit 83 which terminates the session for that user. Accepting a user's exit request also requires the session negotiation unit 83 to update its collection of sessions as well as the set of users in each session. It should be noted that whenever the collection of sessions or the set of users in each session is updated (whether such updating is done in response to a user creating a new session, joining an existing session, or exiting a session), the base station should re-run the optimization scheme to ensure that total utility is maximized in the system. Of course, such updating can be deferred at the cost of some performance loss.
After a user either joins an existing session or requests a new session, the user should periodically report its channel quality to the base station. This channel quality information will be received by the channel feedback unit 82 at the base station. The channel quality information may comprise the user's SINR value or can reflect the highest MCS the user can correctly receive. When the base station obtains such information from all users, the resource allocation unit 81 constructs a mapping from each MCS m to the set Nm of users that can receive MCS m. When a change in the SINR of some users leads to the change of any set Nm, the base station should once again update the collection of sessions and/or the set of users in each session and re-run the multicast resource allocation algorithm. Once again, this updating can be deferred at the cost of some performance loss.
Upon receiving utility and channel quality information from each user, the resource allocation unit 81 determines the resource allocation as well as the MCS selection for each video layer, with the purpose of optimizing the system utility. As explained in further detail below, the system utility is the sum of the session utilities. Therefore, the problem of optimizing utility will depend upon whether the optimization scheme is being applied to a system with a single video session or a system with multiple video sessions.
In the multi-session scenario, the problem can be decomposed into two sub-problems: intra-session and inter-session resource allocation. For the intra-session resource allocation, dynamic programming is used to assign a modulation and coding scheme for each layer in a session under any given resource constraint t (t=0, 1, . . . , T). For the inter-session allocation, dynamic programming is used to allocate resources among video sessions using the results obtained from the intra-session method. Both algorithms find the optimal solution but have pseudo-polynomial complexity.
In the alternate single-session scenario, the problem of inter-session resource allocation is irrelevant since it is not necessary to allocate resources among a plurality of sessions. Hence, in this scenario, only the problem of intra-session resource allocation applies.
Now that a description of the above-described system architecture and protocol has been provided with reference to
Referring to
As shown in block 21, each MCS is mapped to the set of users that are able to receive that particular MCS. The mapping of each MCS can be computed using the channel state information (e.g., SINR information for each receiver device) being received by the base station at each frame. Based on the MCS mapping, an optimal MCS is assigned to each layer of the video session such that system utility is maximized (block 22). To select the optimal MCS for each layer, an intra-session MCS assignment algorithm (discussed in further detail below) is applied. Finally, in block 23, a multicast data transmission is scheduled for the video session.
Application of the above-described method will now be illustrated in further detail. A description of the problem is provided first. After the problem has been described, it is explained how a single-session MCS assignment scheme can be used to solve this problem. For convenience of the readers, Table 1 summarizes the notations used below.
A “slot” is used as the minimum allocable resource unit in the system, where a slot can refer to an allocation unit in the time domain, frequency domain, or in the joint space of time domain and frequency domain. Assume there are T slots in a frame available for multicast video streaming. The possible modulation and coding schemes (MCS) are m=1, . . . , M (for example, MCS m=1 represents QPSK-1/2, and so on). Rm is the data rate provided by a single slot with MCS m. A higher MCS index indicates a higher data rate. N is the set of users in the system. {circumflex over (N)}m is the set of users who can decode MCS m, while Nm is the set of users who can decode MCS up to in but not in+1. As the user who can decode MCS m can also decode all the MCS lower than m, we can get {circumflex over (N)}m=Um′=mMNm′. The scalable video session is composed of L layers. The data rate of the layer l is λ and if it is modulated with MCS m, it requires τl,m=┌λl/Rm┐ slots.
Assume that layer l is transmitted with MCSM(l) in a solution, and if l is not transmitted, then set M(l)=∞, R∞=∞ and N∞=Ø. Then the system constraint can be expressed as
Στ=1Lτl,M(l)≦T (1)
For the scalable video sequence, a received layer can be used to refine the video quality only when the user has received all the lower layers. In such a case, the received layer is said to be “valid” for the user. Denote Γ(m) as the number of valid layers for the users in set Nm. Since Γ(m) is the maximum number of continuous layers which are modulated with MCS 1 to m starting from the base layer, i.e.,
Γ(m)=max{l,0<M(l′)≦m, for all l′ε{1, 2 . . . , l}, 1≦l≦L}, then the received rate for a user j in set Nm can be expressed as rj=Σl=1Γ(m)λ1.
As mentioned earlier, the utility of user j is defined to be a generic function of its received rate rj, denoted as Uj(rj). This utility function can be an arbitrary non-decreasing non-negative function which is not only user dependent but also session dependent when applied in the scenario of multiple video sessions. Denote μj,l as the utility of user j when the layers 1 to l are correctly received, i.e., μj,l==UjΣl′=11λl′. The system utility U is defined as the sum of the utility of all the users, then we have
U=Σ
jεN
U
j(rj)=Σm=1MΣjεN
The objective is to find out the optimal MCS assignment strategy which can maximize the total system utility U in the constraint of Equation (1). In other words, the values of all M(l) for 1≦l≦L must be determined, in order to
Maximize U=Σm=1MΣjεN
Equation (3) represents the problem which is to be solved. In order to solve the problem in Equation (3), two intra-session MCS assignment algorithms are proposed.
The first intra-session algorithm is described in
Lemma 1: If the jth layer of a multicast session is modulated with MCS m, the (j+1)th layer is either not transmitted or is modulated with MCS m′≧m.
The algorithm has a complexity of O(LJ+LMT), where J is the number of users, L is the number of video layers, M is the number of Modulation and Coding Schemes (MCS), and T is the maximum number of available resource units (e.g., slots). A selectable uniform utility function is used for each user. Any non-negative and non-decreasing function with respect to the received data rate can be adopted.
Consider a scenario of a video session with layers 1˜l and we have t slots to transmit this session. Each layer must be modulated with one MCS chosen from 1˜m. Denote an auxiliary function u(l,m,t) to be the maximal utility the users can achieve with this session. Note that if there are not enough slots to modulate all the layers, u(l,m,t) will be set to −∞. The procedure of this algorithm is shown in
Referring to
Next, in block 36, the maximal utility of the users in a session is computed with layers 1 to l (1≦l≦L) and each layer must be modulated with one MCS chosen from 1 to m. The resource constraint for this session is t. In the scenario of u(l,m,t), layer l must be modulated with one MCS chosen from 1 to m, so the optimal solution specified by u(l,m,t) has two possible cases according to the MCS assigned for layer l, as illustrated in block 36. Case 1 represents the first possible case. In this case, the lth layer should be modulated with MCS 1 to m−1. Therefore, the total utility is u(l,m,t)=u(l,m−1,t). Alternatively, case 2 represents the case where layer l is modulated with MCS M(l)=m. In this case, the utility for layer l is Σjε{circumflex over (N)}
Finally, in block 38, the maximal utility of the video session with the resource constraint of T slots is computed. Using the above-described procedure, an optimal MCS can be assigned to each layer of a video session such that the utility of all receiver devices is maximized.
If the first intra-session MCS assignment algorithm described above is used in conjunction with the inter-session resource allocation algorithm in the multi-session context, an additional computation would be necessary which is not shown either in
The second intra-session algorithm will now be described with reference to
Lemma 2: The value of u (l,m,t) depends only on the MCS assignment of the video layers higher than l.
In applying the second intra-session algorithm, the values of u(l,m,t) are recursively computed for the top layer L to the base layer. The recursion for u(l,m,t) is as
u(l,m,t)=max(ΣjεN
where u′(l,m,m′,t)=u(l+1,m′,t−τl+1,m′)+ΣjεN
Given the initial condition:
u(L,m,t)=ΣjεN
the optimal utility for one video session can be recursively computed:
u*=max{u(1,m,T=τl,m):1≦m≦M, τl,m≦T}, (6)
For use with the inter-session resource allocation algorithm, it is also necessary to compute the value of ũ(t)=max{u(1,m,t−τ1,m): 1≦m≦M, τ1,m≦t} for all 0≦t≦T, which is the maximum total utility for a single session with t available slots.
The complexity of this second intra-session MCS assignment algorithm in the multi-session context is now provided. The values of μj,l and ΣjεN mμj,l can be precomputed together before the recursion procedure in O(JL), where J is the number of users in this session. For the worst-case of the recursion procedure, we should compute the values of u(l,m,t) for all 1≦l≦L, 1≦m≦M, 1≦t≦T, and every step of the recursion has a maximum complexity of O(M) so the worst-case complexity of the recursion is O(LM2T). Therefore, the complexity for this intra-session algorithm is O(JL+LM2T)=O(JL+LM2T).
Referring to
Now that a description of the two different intra-session MCS assignment schemes has been provided, it will be explained how these schemes can be combined with an inter-session resource allocation scheme to provide a two-step dynamic programming scheme for optimizing utility in a system with multiple video sessions. This two-step dynamic programming scheme is described with reference to
Referring to
Blocks 51-54 explains the particulars of block 50 in further detail. First, in block 51, the mapping is computed from each MCS to the set of users who can receive that MCS. Next, in block 52, the intra-session MCS assignment algorithm (discussed above) can be applied to each video session such that each layer of each session is assigned a MCS. (As briefly mentioned above and explained in further detail below, the intra-session MCS assignment algorithm is applied in a slightly different manner in this multi-session scenario than it had been applied above in the single-session scenario.) Based on the results of the intra-session algorithm, resources are then allocated among the multiple video sessions such that the utility of all users is maximized (block 53). To allocate resources in such a manner, an inter-session resource allocation algorithm (discussed in further detail below) is applied. The results of the inter-session algorithm are then used to schedule a multicast data transmission for each video session in block 54.
A more detailed explanation of the above-described method will now be provided in further detail. The explanation of the problem is first provided, and then it is explained how two-step scheme can be used to solve this problem. For convenience of the readers, a Table 2 provides a summary of the notations used below. It should be noted that the notations used in this example are similar to the notations used in the first example provided above. However, many of the notations used in this example include an additional index to account for the fact that there are multiple sessions in this example.
Consider the following problem formulation. It once again assumed that there are T slots in a frame available for multicast video streaming, where a slot can refer to a minimum allocation unit in the time domain, frequency domain, or in the joint space of time domain and frequency domain. S is the number of multicast sessions. N[s] is the set of users in session s. The possible modulation and coding schemes (MCS) are m=1, . . . , M (for example, MCS m=1 represents QPSK-1/2, and so on). Rm is the data rate provided by a single slot with MCS m. A higher MCS index indicates a higher data rate. Mj is the maximum MCS that can be received by user j. A video session s has L[s] layers. The data rate of layer l of video session s is λl[s] and if it is modulated with MCS m, it requires τl,m[s]=┌λl[s]/Rm┐ slots. Denote Xl,m[s] as an indicator function that is 1 if layer l of session s is modulated with MCS m and 0 otherwise.
The rate of user j in session s is rj[s], which can change with different assignment of the modulation coding schemes for the video layers. Denote Mj the maximum MCS that can be received by user j and Xl,m[s] si as an indicator function that is 1 if layer l of session s is modulated with MCS m and 0 otherwise. Then, the data rate of user j for session s is:
rj[s]=Σl=1L
A generic utility function Uj[s](rj[s]) is used for user j in session s. The function can be an arbitrary non-decreasing non-negative function that can be both session dependent and user dependent.
Our objective is to maximize the sum of all the user utilities in all video sessions subject to the constraint that T slots are available for the downlink multicast in the system, as shown below.
MaximizeΣs=1SΣjεN
where rj[s] is defined in Equation (7), subject to the constraints
Σm=1MXl,m[s]≦1, l=1, . . . L and Σs=1SΣm=1MΣi−1LXl,m[s]τl,m[s]≦T
where the first set of constraints states that for a given video layer l, it can be modulated and coded with at most one MCS, and the second set of constraints dictates that the total number of available slots for all video sessions is T. Note that a layer l may not be modulated with any MCS, i.e. Σm=1MXl,m[s]=0. In that case, layer l is not transmitted.
This is an integer programming problem where the variables to be optimized are Xl,m[s]. In other words, we need to determine, for each layer of each session, whether it needs to be transmitted, and if so, what modulation and coding scheme should be used for that layer.
To compute the maximum utility, a two step-dynamic programming scheme is used. In the first step, one of the intra-session MCS assignment schemes (which were explained above) is used to assign a MCS to each layer of each video session. In the second step, the inter-session resource allocation scheme is used to allocate resources among the multiple sessions. Both the intra-session and inter-session schemes aim at maximizing the total utility of all users in the system. The two step-dynamic programming scheme uses a pseudo-polynomial algorithm based on dynamic programming for both single-session and multi-session services. The complexity of the algorithm for the multi-session services is, 0(S
The objective of the inter-session algorithm is to maximize the system utility in Equation (8) by optimally allocating resources for all the layers among all the video sessions. Let T(s) denote the resources allocated to video session s, 0≦T(s)≦T. A two-step decomposition technique is used to optimize the system-wide resource allocation based on the results of intra-session algorithm.
Define ũ[s](t) as the maximum utility for session s if t slots are allocated to the session. Although it was not necessary in the single session scenario, the value of ũ[s](t) for all 0≦t≦T should also be computed here. The results of ũ[s](t) for all 0≦t≦T are then used by the inter-session algorithm as explained below in further detail.
The inter-session utility optimization problem in Equation (8) can be equivalently formulated as
We can also use a dynamic programming algorithm to solve this sub-problem.
First, an auxiliary function v(s,t) is defined to be the maximum utility of the video sessions from 1 to s with the total available resources t left for the sessions from 1 to s. The objective is to recursively compute v(S,T) which is the solution for this sub-problem and also for the optimization problem in Equation (8).
Consider a generic scenario of v(s,t) (1≦s≦S) in the recursive procedure. All the values of v(s′,t) for all 1≦s′≦s and 0≦t≦T were computed in the past procedure. It is assumed that the utility of session s depends only on its resource constraint and is independent of other sessions. Further assume that the resource allocated to session s is t′(0≦t′≦t) then the maximum utility of sessions from 1 to j should be ũ[s](t′)+v(s−1,t−t′). Therefore, in order to obtain the value of v(s,t), we only need to check all the possible values of t′. Then we can get the following recursion for v(s,t).
v(s,t)=maxt′=0t((ũ[s](t′)+v(s−1,t−t′))) (9)
The recursion is started from the scenario of v(1,t), in which there is only one video session under the resource constraint t for the enhancement layers. This initial condition can be computed based on the results of the intra-session algorithm:
v(1,t)={tilde over (μ)}[1](t) for all 0≦t≦T, (10)
After the recursive procedure, the maximum system utility U*=v(S,T) can be determined for the optimization problem in Equation (8).
Referring to
The complexity of this inter-session resource allocation algorithm is now discussed. The values of ũ[s](t) for all 1≦S, 1≦t≦T can be pre-computed using the intra-session algorithm and the complexity is O└Σs=1S(L[s](J+M2T))┘. Let
The integrated algorithm is pseudo-polynomial due to the factor T In practical systems, the value of T is limited by the available physical resources in a wireless frame, and is normally bounded by a reasonable value. Therefore, the complexity is acceptable for most practical systems.
Furthermore, if T exceeds a threshold {tilde over (T)}, we can solve the optimization problem in Equation (8) in a very simple way. If there are enough resources for all the layers of all sessions to be transmitted using the most robust MCS (i.e., MCS 1), all users in the system achieve the highest possible video rate. As the utility function Uj(rj) is a monotonic non-increasing function of the received rate rj, each user achieves the maximum utility and the maximum system utility is also obtained. The resource requirement for this scenario is
The maximum utility for the system in this case is
Having described preferred embodiments of a system and method for optimizing utility in broadband wireless systems (which are intended to be illustrative and not limiting), it is noted that modifications and variations can be made by persons skilled in the art in light of the above teachings. It is therefore to be understood that changes may be made in the particular embodiments disclosed which are within the scope of the invention as outlined by the appended claims. Having thus described aspects of the invention, with the details and particularity required by the patent laws, what is claimed and desired protected by Letters Patent is set forth in the appended claims.
This application claims priority to provisional application Ser. No. 61/169,870 filed on Apr. 16, 2009 and provisional application Ser. No. 61/239,854 filed on Sep. 4, 2009, both of which are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
61169870 | Apr 2009 | US | |
61239854 | Sep 2009 | US |