1. Technical Field
The present invention relates to multicasts and, in particular, assignment of resources and modulation and coding schemes to layers of multicast data streams.
2. Description of the Related Art
Next generation cellular wireless networks, such as 4G, are expected to deliver a much higher spectrum efficiency and bandwidth than existing networks. The International Telecommunication Union (ITU) requires that 4G technology should provide peak data rate of 100 Mbps for high mobility applications and 1 Gbps for low mobility applications. Such a high bandwidth enables the provision of real-time video services, such as Internet Protocol Television (IPTV) services, live video streaming and online telecast of sports.
Nevertheless, due to the fact that the available wireless spectrum is typically shared by many users and that each streaming video service may have very large bandwidth and stringent delay requirements, efficient resource allocation is an important aspect in developing cellular wireless network technology.
Adaptive modulation and coding schemes are currently used in wireless networks to provide efficient resource allocation. Here, the transmitters, such as base stations providing video streaming services, can adaptively select the modulation and coding scheme (MCS) to be applied when transmitting data to receivers. In particular, the MCSs employed can be receiver-specific in that they are based on different channel qualities measured at a receiver and on different receiver device capabilities. However, in wireless multicast services, the receivers can have fading channel conditions, various instantaneous channel conditions due to their different respective distances from the base station, etc. Adaptive modulation and coding schemes enable the determination of which MCS should be used for a multicast frame. Normally, a robust modulation and coding scheme that is receivable by all wireless clients in the multicast group is typically employed to accommodate all receivers. As a result, the multicast data rate and video quality are limited by the users with the worst channel conditions.
To address this limitation in a wireless video multicast scenario, scalable video coding (SVC) schemes have been developed. Scalable video coding schemes divide a video stream into multiple sub-streams, denoted as layers. An SVC stream has one base layer and one or multiple enhancement layers. The base layer provides a minimum quality, frame rate and resolution of the video and the enhancement layers represent the same video at gradually increasing quality and/or frame rate and/or resolution. Therefore, by applying different MCSs on different layers of the scalable video sequence, essential video service can be provided to all the users via the base layer with a low rate MCS while the enhancement layers with a high rate MCS can help improve the video quality for the users having good channel conditions.
While scalable video coding provides flexibility and high performance, scalable video coding also presents great challenges in designing an efficient resource allocation scheme. Recently, a fast greedy resource allocation algorithm was developed for both single-session and multi-session video multicast services. This algorithm uses a utility function that is the logarithm of the received throughput to achieve user fairness. A strong assumption is made in this algorithm that all the enhancement layers have the same size, which limits its applicability in practice. Another approach generalizes the model with the support of flexible layer rates and a general utility function. An optimal pseudo-polynomial algorithm based on dynamic programming has been proposed for both single-session and multi-session scenarios.
Exemplary embodiments of the present invention provide efficient utilization of resources to multicast data streams via a plurality of layers by collectively allocating resource slots to layers assigned a common modulation and coding scheme. In particular, exemplary embodiments provide a means to determine a maximal utility that is achievable using the collective resource allocation and to assign modulation and coding schemes to layers to obtain the maximal utility.
One embodiment is directed to a method for transmitting layers of a data stream over wireless resources partitioned into slots. The method may include receiving feedback indicating channel state information from a set of receiver devices. Further, a maximal utility for the set of receiver devices can be determined based on the received feedback by determining the utilities of potential assignments of a set of modulation and coding schemes to a set of layers such that data from different layers correlated to a common modulation and coding scheme in an assignment is allocated resource slots jointly. In addition, MCS assignments may be selected based on the maximal utility and the set of layers may be transmitted to the set of receiver devices in accordance with the selected MCS assignments.
Another embodiment is drawn towards a method for transmitting layers of a data stream over wireless resources partitioned into slots. The method may include receiving feedback indicating channel state information from a set of receiver devices. Based on the received feedback, a maximal utility for the set of receiver devices can be determined by determining values of the minimum number of slots utilized for potential assignments of a set of modulation and coding schemes to a set of layers to achieve the maximal utility such that data from different layers correlated to a common modulation and coding scheme in an assignment is allocated a common resource slot. Further, MCS assignments can be selected based on the maximal utility and the set of layers may be transmitted to the set of receiver devices in accordance with the selected MCS assignments.
An alternative embodiment is directed to a system for transmitting layers of a data stream over wireless resources partitioned into slots. The system may include a receiver configured to receive feedback indicating channel state information from a set of receiver devices. In addition, the system may include a controller configured to determine a maximal utility for the set of receiver devices based on the received feedback by determining values of the minimum number of slots utilized for potential assignments of a set of modulation and coding schemes to a set of layers to achieve the maximal utility such that data from different layers correlated to a common modulation and coding scheme in an assignment is allocated a common resource slot. Moreover, the system may also include a scheduler and a transmitter. The scheduler can be configured to select MCS assignments based on the maximal utility and the transmitter can be configured to transmit the set of layers to the set of receiver devices in accordance with the selected MCS assignments.
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:
Prior to discussing exemplary embodiments in detail, it is important to note that previously known resource allocation schemes allocate resources separately for each layer in a video session, even when several layers are modulated with the same MCS. However, allocating resources separately can result in a low utilization ratio of bandwidth resources in some scenarios. As an example, a multicast video session which has 10 layers with the same data rate of 32 kbps is considered, where each layer is transmitted with Quadrature Amplitude Modulation (QAM)16¾. If resources are allocated separately and one slot can provide a 28.8 kbps data rate with QAM16¾, then [32/28.8]=2 slots are needed to transmit one video layer and 20 total slots are needed for this video session. Thus, the utilization ratio is 32*10/28.8*20=55.6%.
To improve utilization of the bandwidth resources, exemplary embodiments of the present invention introduce the notion of Joint Layer Resource Allocation, which permits systems to jointly allocate bandwidth resources for several layers which are assigned with the same MCS. For the example provided above, where all layers are assigned with QAM16¾, the total bandwidth budget for the 10 layers in accordance with Joint Layer Resource Allocation is [10*32/28.8]=12 slots and the utilization ratio is 32*10/28.8*12=92.6%, which is an improvement of 37%.
In exemplary embodiments discussed herein below, a novel model including a combination of Adaptive Modulation and Coding (AMC) and Joint Layer Resource Allocation can be applied to scalable video multicast sessions in broadband wireless networks, in addition to other applications. To the knowledge of the inventors, no previous work considers joint layer allocation with AMC for scalable video multicast or indicates any way of implementing it. Therefore, not only are results and processes described herein below novel, but so is the problem itself. Moreover, the model permits a flexible layer rate and can use a general utility which can be both user-dependent and session-dependent for non-negative and non-decreasing received data rates. Additionally, an optimal pseudo-polynomial MCS assignment scheme based on dynamic programming for a single-session video multicast can be employed. Further, Fully Polynomial Time Approximation Schemes (FPTAS) for both single-session and multi-session scenario can be utilized to implement efficient resource allocation, as discussed further herein below.
Referring now in detail to the figures in which like numerals represent the same or similar elements and initially to
With reference now to
To better illustrate exemplary processes and systems that can be implemented in one or more base stations 102 to perform resource allocation, a model on which the processes and systems are based is described herein below. Here, it is assumed that there are T slots in a frame available for multicast data streaming, such as 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. The possible modulation and coding schemes (MCS) are denoted and indexed as m=1, . . . , M. For example, MCS m=1 represents QPSK-½, and so on. Rm is the data rate provided by a single slot with MCS m. A higher MCS index indicates a higher corresponding data rate. N is the set of users serviced by a base station. Each user has a set of decodable MCS which can be periodically reported by the user when a frame starts. Generally a user can decode all the MCS lower than m if MCS m is decodable for him. Nm denotes the set of users for whom MCS m is the highest decodable MCS. Some notations used herein are summarized in Table 1 below.
(l)
(m)
(Φ)
As indicated above, a scalable video sequence is composed of multiple video layers with flexible layer rates. L is denoted as the number of layers and λl is denoted as the data rate of the layer l. A layer l is valid for a user only when this user has correctly received all the layers below l, i.e., from layer 1 to l−1. (m) is denoted as the number of valid layers for the users in set Nm. As a result, (m) should be the maximum number of continuous layers which are modulated with MCS 1 to m starting from the base layer. (l) is denoted as the MCS assigned for layer l. It should be noted that if layer l is not transmitted, (l) is set as (l)=∞ and accordingly R∞ is set as R∞=∞ and N∞ is set as N∞=φ. As such, (m)=max{l|0<(l′)≦m} for all l′ε{1, 2, . . . , l}, 1≦l≦L. It should be noted that the maximum over an empty set is zero. In addition, (0) is set to zero for some special cases as discussed further herein below. Thus, the received rate for the users in set Nm, can be obtained, e.g.,
The utility for user j is defined here to be a general function of the use rate rj, denoted as Uj(rj). This utility function can be an arbitrary non-decreasing non-negative function and can be both user dependent and session dependent when applied in the multiple video session scenario. For example, it can be a weighted peak signal-to-noise ratio (PSNR): Uj(rj)=wjPSNR(rj) where wj is the weight of user j and PSNR(rj) is the PSNR of the video if only rate rj is received. If wj is set to wj=1 for every user j, an objective here is to maximize the sum of PSNR of all multicast users in the video session.
μj,l denotes the utility of the user j that can receive l valid layers. Thus,
The system utility U is defined to be the sum of the utility of all the users:
An objective of exemplary embodiments of the present invention is to determine the optimal MCS assignment strategy that can maximize the total system utility U under the system constraint T. In other words, exemplary embodiments decide the values of all (l) for 1≦l≦L, in order to
As mentioned above, in order to improve bandwidth utilization, the notion of Joint Layer Resource Allocation for this problem is introduced. Here, the system is permitted to combine several continuous video layers that are assigned with the same MCS and jointly allocate resources for them. τl
If l1>l2, we set τl
Based on this notion, a key property for the optimal MCS assignment strategy is introduced in Lemma 1, below. The proof is omitted here for brevity purposes.
Lemma 1: There exists an optimal solution for (2), in which for all 1≦l≦L we have (l+1)>(l).
According to Lemma 1, for the optimal solutions claimed by Lemma 1, the MCS should be assigned in an ascending order from the base layer to the topmost enhancement layer. As such, the system constraint can be expressed as
where (0) is initialized as 0.
The objective of determining the optimal solution claimed by Lemma 1 under the system constraint (3) can be clearly established and the solutions referred to herein below are claimed by Lemma 1.
It should be noted that it is not assumed that the base layer is required to be received by all users as in previous approaches. Instead, exemplary embodiments can aim to maximize the total system utility of all video multicast sessions. Therefore, it is possible that some video sessions are completely dropped or some users cannot decode any layers (e.g. in an overloaded system) in order to maximize the overall video quality. As a result, when the system is overloaded, admission control can be automatically provided based on the utility maximization.
However, alternative embodiments can enforce the base layer requirement when the maximum number of slots are sufficient to modulate all base layers using an MCS that can be received by all users in each session. For example, each base layer can be initially transmitted using the highest MCS that is decodable by all users in each session, can allocate an appropriate number of slots for each base layer and can then run resource allocation processes described herein below on the remaining slots and on all enhancement video layers.
Returning to
The optimal process can be implemented as a dynamic programming algorithm that can be used to solve the problem (2). As an example, a scenario of a video session with layers 1 to l with t slots used to transmit this session is considered. Here, each layer is modulated with one MCS chosen from 1˜m. An auxiliary function u(l,m,t) is denoted to be the maximal utility the users in set ∪m′=1mNm′ can achieve with this session. It should be noted that if there are not enough slots to modulate all the layers, u(l,m,t) will be set to −∞. An objective here is to recursively compute the values of u(l,m,t) from the base layer to the highest enhancement layer. In the optimal solution claimed by Lemma 1, several topmost layers maybe left un-modulated. As such, the optimal solution should be the one with the maximum utility among u(l,M,T) for all 1≦l≦L, i.e., U*=max{u(l,M,T):1≦l≦L}. By convention, the maximum over an empty set is 0 for non-negative utilities. The recurrence relation of u(l,m,t) is shown in Recursion 1 in Table 2 below.
The correctness of the recurrence relation can be proven by induction. The ranges for the parameters in u(l,m,t) are 0≦l≦L, 0≦m≦M and t≦T. The utility of the invalid scenarios is set to −∞ in order to ensure that they will not be present in the final optimal solution. There are several base scenarios for u(l,m,t), as defined in the initial conditions in Table 2. When l=0 and 0≦t≦T, t slots are available to transmit 0 layers. Thus, u (0,m,t)=0. When m=0, l≧1 and 0≦t≦T, a nonexistent MCS is assigned to the layers below 1. This is an invalid scenario, as the layers must be modulated with MCS 1 to m. Therefore, u(l,0,t)=−∞. When t<0, another invalid scenario is reached in which negative slots are used to transmit the layers. Similarly, u(l,m,t)=−∞ for t<0.
A general scenario u(l,m,t) is now considered in which 1≦l≦L, 1≦m≦M, and 0≦t≦T, assuming all the values of u(l−1,m′,t′) are obtained for all 1≦m′≦M, t≦T and u(l,m′,t′) for all 0≦m′≦m, t≦T. It is assumed in the optimal solution specified by u(l,m,t) that there are only δ layers modulated with MCS m, 0≦δ≦l. In accordance with Lemma 1, these δ layers distribute from layer l−δ to l. The resources needed for them is denoted as τl−δ+1,l,m. Further, the layers from 1 to l−δ are modulated with an MCS index that is lower than m. Therefore, when t≧τl−δ+1,l,m, then u(l,m,t)=u(l−k, m−1, t−τl−δ+1,l,m)+ΣJεN
u(l,m,t)=u(l−δ,m−1,t−τl−δ+1,l,m)+ΣJεN
Therefore, u(l−δ,m−1,t−τl−δ+1,l,m)+ΣJεN
As the number δ of layers modulated with MCS m can be from 0 to l, u(l,m,t) is the maximum value among all possible choices of δ such that 0≦δ≦l. Thus,
With regard to the complexity of this joint layer MCS assignment algorithm, the values of μj,l can be pre-computed together before the recursion procedure in O(LJ), where J is the number of users in set N. In addition, the values of τl
The recursion algorithm in Table 2 discussed above was applied for the single session case. In the multi-session scenario, for example, if there is more than one session in one scheduling frame, then resources should be optimally allocated among sessions. For example, it can be assumed that there are S sessions in the system. Based on the algorithm in Table 2, the maximum system utility for each session with a resource constraint of t, i.e., ũ[s]=max{u[s](l,M,t):1≦l≦L[s]}, can be computed. Using the values of ũ[s](t) for all 1≦s≦S, 0≦t≦T as the input for the inter-session resource allocation algorithm described in co-pending, commonly assigned U.S. patent application Ser. No. 12/696,703, filed on Jan. 29, 2010, which is incorporated herein by reference, the maximum system utility for multiple sessions can be obtained. One implementation of the inter-session resource allocation algorithm is discussed further herein below with respect to
Referring now to
At step 304, the base station 102 can determine a maximal utility for the set of receiver devices based on the received feedback to assign MCS to the layers in each session using the optimal single session process. For example, the base station 102 can employ Recursion 1 in Table 2 to find the maximum utility for the set of receiver devices and to assign MCS to the layers in each session. In particular, a method 350 that utilizes Recursion 1 of Table 2 can be performed to implement step 304.
Method 350 can begin at step 352 in which the base station 102 may pre-compute slots used to transmit blocks of layers and may pre-compute utilities based on the user-feedback. For example, the base station 102 can pre-compute the value of the slots needed
when transmitting the layers from l1 to l2 with MCS m for all l and m indices. Thus, the base station 102 may pre-compute a number of slots for layer transmission for each potential assignment of blocks of layer indices (l1 to l2) a common MCS m. In addition, the base station may pre-compute the utility
for user j (for all possible l indices) if the video layers 1, 2, . . . , l are decodable for this user.
At step 354, the base station 102 can pre-determine a set of initial conditions for the utilities of potential assignments. For example, as indicated above in Table 2, the base station 102 can compute
u(0,m,t)=0 for all m≧0 and 0≦t≦T
u(l,0,t)=−∞ for all l≧1 and 0≦t≦T
u(l,m,t)=−∞ for all l,m≧0 and t<0
The initial condition for p(l,m,t), discussed further herein below, can be determined as
p(0,m,t)=0 for all m≧0, 0≦t≦T.
At step 356, the base station 102 can recursively determine the utilities of potential assignments. For example, as discussed above with regard to Recursion 1 of Table 2, the base station 102 can recursively compute the maximal utility of the users in set ∪m′=1mNm′ when transmitting layers 1 to l using MCS chosen from 1 to m with the resource constraint t:
for all 1≦l≦L, 1≦m≦M, and 0≦t≦T. In particular, as indicated by the factor τl−δ+1,l,m, data from different layers (ie. layers within the set l−δ+1 to l) correlated to a common MCS, m, in an assignment can be allocated a common resource slot. For example, as discussed above with regard to the example contrasting Joint Layer Resource Allocation with separate allocation of resources, if resources are allocated separately and one slot can provide a 28.8 kbps data rate with QAM16¾, then [32/28.8]=2 slots are needed to transmit one video layer and 20 total slots are needed for this video session. Thus, in separate allocation of prior methods, 2 slots are allocated to a layer with unutilized resources remaining within a slot. However, in accordance with Joint Layer Resource Allocation, where all layers are assigned with QAM16¾, the total bandwidth budget for the 10 layers is [10*32/28.8]=12 slots. Thus, because layers having a common MCS are allocated resources jointly, one slot may include data from more than one layer. Indeed, data from all layers (l−δ+1 to l) correlated to a common MCS, m, in an assignment can be allocated contiguous slot resources. As discussed above, joint layer allocation can significantly improve the utilization ratio of bandwidth resources.
In addition, it should be noted that a recursive determination step for a particular MCS determines a maximal utility for a particular layer index such that the recursive determination step for the particular MCS is constrained to assign to the particular MCS a block of layer indices commencing from the particular layer index. For example, for MCS m, the recursion step assigns m a block of layers l−δ+1 to l, with 0≦δ≦l, commencing from l. Moreover, the recursion step for MCS m recursively determines corresponding utilities for the particular layer index l by successively expanding the block until the lowest index for the set of layers is processed. For example, by successively varying δ from 0 to l, the block of layers commencing from l is expanded until the lowest layer index, 1, is reached.
Further, it should also be noted that the recursion computation performed for
for all 1≦l≦L, 1≦m≦M, and 0≦t≦T, can begin from the initial conditions for each particular MCS m such that each successive iteration of u(l,m,t) can obtain the value of maxδ=0l(u(1−δ, m−1, t−τl−δ+1,l,m)) from a previous iteration. For example, for l=1, for any value of m, the value of u(l−δ, m−1, t−τl−δ+1,l,m) is zero from the initial conditions and u(l,m,t) is based only on
which is obtained from the user-feedback in step 254 of method 250. Thus, as
is determined for all 1≦l≦L, 1≦m≦M, and 0≦t≦T, the factor u(l−δ, m−1, t−τl−δ+1,l,m) can be determined for each m, l or t from a previous iteration, which is based on user utilities μj,l. Accordingly, for a recursion step for a particular MCS m for a particular layer index l, utility values obtained while varying δ can be determined in a previous recursion step for an MCS (m−1) preceding the particular MCS.
To permit the assignments of MCS to layers, as discussed further herein below, while recursively determining the utility values u(l,m,t) at step 356, the base station 102 can record the number of layers modulated with MCS m to achieve the utility u(l,m,t) with resources t. This number of layers is denoted here as p(l,m,t) and the base station can compute p(l,m,t) for each corresponding computation of u(l,m,t) as follows:
arg maxδ=0l(u(l−δ,m−1,t−τl−δ+1,l,m)), for all 1≦l≦L, 1≦m≦M, and 0≦t≦T.
At step 358, the base station 102 can compute the maximal utility of this session with the resource constraint of T slots: U*=max{u(l,m,T):1≦l≦L}. Here, if the utility of only a single session is sought to be optimized, the assignments of MCS to layers having the highest utility U* can be employed to transmit the data streams to the receivers 104. However, as noted above, optionally, the slot resources can be allocated between sessions to maximize overall utility using the methods disclosed in U.S. patent application Ser. No. 12/696,703, filed on Jan. 29, 2010.
Thus, optionally, at step 306, the multi-session scheme disclosed in the co-pending application can be employed to allocate resources among sessions based on the results of the intra-session process performed at step 304. For example, the values of ũ[s](t) for all 1≦s≦S, 0≦t≦T can be used as the input for the inter-session resource allocation algorithm, as discussed above. In one implementation of the inter-session algorithm, a dynamic programming approach can be employed to determine the maximum system utility. To illustrate the approach, ũ[s](t) is used to represent the output results of session s obtained at step 304 while T(s) denotes the resources allocated to video session s. Here, an auxiliary function v(s,t) can be defined, where v(s,t) denotes 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. In addition, to permit tracking of resource slots allocated to each session to achieve maximum system utility, a function q(s,t) is defined, where q(s,t) is the optimal number of resource slots allocated to a session, under a resource constraint of t for session s and sessions with lower indices. First, initial conditions, v(1,t)=ũ[1](t) and g(1,t)=t for all 0≦t≦T, can be computed. Second, using the initial conditions, the values of v(s,t) and q(s,t) can be computed recursively from the first session to all the S sessions. The recursion for v(s,t) is as follows.
v(s,t)=maxt′=0t(ũ[s](t′)+v(s−1,t−t′)) for all 1≦s≦S, 0≦t≦T
Simultaneously, the values of q(s,t) can be determined recursively as follows:
q(s,t)=arg maxt′=0t(ũ[s](t′)+v(s−1,t−t′)) for all 1≦s≦S, 0≦t≦T
Third, the optimal system utility for multiple sessions can be computed as U*=v(S,T) for the total number of sessions S and the total number of available resource slots T.
At step 308, the base station 102 can select the MCS assignments to layers based on the results of the intra-/inter-session processes in step 304 or steps 304 and 306. In addition, the base station 102 can schedule multicast data transmission based on the results of the intra-/inter-session process in step 304 or steps 304 and 306.
For example, at step 308, for a single session scenario, the base station 102 can employ the maximum system utility U*=max{u(l,M,T):1≦l≦L} to recursively determine the highest layer index allocated to each MCS m corresponding to a maximum system utility and thereby determine the MCS assignments. For example, let L(M) denote the highest layer index allocated to MCS M. First, the initial condition for the recursion can be obtained using the results from step 356:L(M)=arg maxl=1Lu(l,M,T). Second, the base station 102 can perform the recursion as follows:
L(m−1)=L(m)−p(L(m),m,T−Σc=m+1MτL(c−1)+1,L(c),c), for m=M, m−1, . . . , 2
As indicated above, the term p(L(m),m,t) denotes the number of consecutive layer indices (δ) from layer index L(m) that is allocated to MCS m under the resource constraint t. The term T−Σc=m+1MτL(c−1)+1,L(c),c denotes this resource constraint, as it provides the number slots remaining for MCS m and lower indices after the allocation of slots to MCS indices m+1 to M. Third, the MCS assignments can be made by assigning an MCS m to layer indices layers between the MCS m's highest layer index L(m) and the highest layer index below L(m) that is allocated to another MCS: M(l)=∞, for all l>L(M); and M(l)=m, for all L(m−1)<l<L(m).
Alternatively, if a multi-session scenario is considered, the base station 102 can determine the MCS assignments using the maximum system utility U*=v(S,T) determined at step 306. For example, the base station 102 may first compute the optimal resource allocation among the users. Let q*(s) denote the optimal number of slots allocated to session s. q*(s) can be computed recursively as follows
Thus, starting from q(S,T), which is known to the base station 102 from the recursion performed in step 306, the base station 102 can recursively compute the optimal number of slots allocated to each session s until the lowest session index is reached. In particular, the term
denotes the number of resource slots remaining for session s and lower session indices after the allocation of slots to session indices s+1 to S, and, with a known number of available slots, q*(s) can be computed using the values of q(s,t) determined at step 306.
To determine the MCS assignments for each session s in the multi-session scenario using the optimal approach, the single-session algorithm employed at step 304 can be applied. Here, the total number of available slots T in L(m−1)=L(m)−p(L(m),m,T−Σc=m+1MτL(c−1)+1,L(c),c) in the single-session algorithm is replaced with q*(s). It should be noted that steps 352-356 need not be repeated, as all values of all values of p(l,m,t) were recorded at step 356 when performed initially.
Returning to
As indicated above, although the optimal process achieves optimal system utility in pseudo-polynomial time, the approximation processes discussed herein below are less complex and have an acceptable degree of performance. Thus, the approximation processes may be a more suitable choice, depending on the processing capability of the base station. In the approximation processes discussed herein below, the single session scenario will be described followed by a description of approximation processes in the multi-session scenario.
In the approximation approach, vl,m is denoted as the utility of all the users in set Nm when they can receive layers 1 to l, i.e., vl,m=ΣJεN
Lemma 2: Define
then {tilde over (v)} is a lowerbound and M{tilde over (v)} is a trivial upperbound for the optimal system utility that can be achieved by any solution.
The proof of Lemma 2 is omitted for brevity purposes.
Here, it is assumed that the values of vl,m for all 1≦l≦L and 1≦m≦M are integers. As a result, all the possible values of system utility are also integers. According to Lemma 2, the utility ranges within the set {0, 1, . . . , M{tilde over (v)}}. A scenario of a sub-session with 1 layers is considered, where each layer needs to be modulated with MCS 1 to m. For each uε{0, 1, . . . , M{tilde over (v)}}, the approximation approach attempts to find a solution whose total system utility for the users in set ∪m′=1mNm′ is exactly u and whose total number of consumed slots are minimized. Let t(l,m,u) denote this minimum Number of Slots (NoS) for this scenario and t(l,m,u) is set t(l,m,u)=+∞ if no such solution exists. The recurrence relation of t(l,m,u) is shown in Recursion 2 in Table 3.
The correctness of the recurrence relation in Table 3 can be proven by induction. The ranges for the parameters in t(l,m,u) are 1≦l≦L, 1≦m≦M and u≦M{tilde over (v)}. It should be noted that the NoS of the invalid scenarios is set to +∞ in order to ensure that they will not be present in the final optimal solution. There are several base scenarios for t(l,m,u), as defined in the initial conditions in Table 3. l=0 corresponds to the 0 layer, which can generate no utility. Thus, the only valid value of the utility is 0 and its minimum NoS is 0. Then t(0,m,0)=0 and t(0,m,u)=+∞ for u>0. When m=0, l≧1 and u>0, a nonexistent MCS is assigned to the layers below l. This is an invalid scenario as the layers need to be modulated with MCS 1 to m. Therefore, t(l,0,u)=+∞ for l≧1 and u>0. When u<0, another invalid scenario is obtained in which a negative utility is generated. Similarly u(l,m,t)=−∞ for t<0.
A general scenario t(l,m,u) is now considered in which 1≦l≦L, 1≦m≦M and 0≦u≦M{tilde over (v)}, assuming that all the values of t(l−1,m′,u′) for all 0≦m′≦M, u≦M{tilde over (v)} and u(l,m′,u′) for all 0≦m′<m, u≦M{tilde over (v)} have been obtained. It is assumed in the optimal solution specified by t(l,m,u) that there are only δ layers modulated with MCS m, 0≦δ≦l. According to Lemma 1, these δ layers distribute from layer l−δ to l. The NoS needed for them is τl−δ+1,l,m. In addition, the utility of the users in set Nm is vl,m. The layers from 1 to l−δ are modulated with MCS lower than m. Therefore, t(l,m,u)=t(l−δ,m−1,u−vl,m)+τl−δ+1,l,m.
As the number δ of layers modulated with MCS m can be from 0 to l, t(l,m,u) is the minimum value among all possible choices of δ such that 0≦δ≦l. Thus,
Based on the results of the recursion, the maximum system utility with the total NoS bounded by T can be obtained:
U*=max{u|t(l,M,u)≦T, 1≦l≦L} (4)
Regarding the complexity of this dynamic programming algorithm, the values of τl
Based on the dynamic programming algorithm described above with respect to Table 3, a fully polynomial time approximation scheme (FPRAS) for the problem (2) is introduced and provided as Algorithm 1 in Table 4 below.
Theorem 1: Algorithm 1 is a fully polynomial time approximation scheme for problem (2) within an approximation factor of 1−ε and with complexity O(LJ+L2M3/ε).
The proof for Theorem 1 is omitted for brevity purposes.
Turning now to the multiple sessions scenario in the approximation approach, it is assumed that there are a total of S sessions in the system. To differentiate the variables in different sessions, a superscript ‘[s]’ is added after the variables to specify their sessions. Then the system utility in the multi-session scenario can be expressed as
Lemma 3: Define
Then {circumflex over (v)} is a lowerbound and SM{circumflex over (v)} is a trivial upperbound for the optimal system utility that can be achieved by any solution.
The proof of Lemma 3 is also omitted for brevity purposes.
It is assumed the values of vl,m[s] for all 1≦s≦S, 1≦l≦L[s] and 1≦m≦M are integers. Thus, all the possible values of system utility are also integers and, according to Lemma 3, the utility ranges within the set {0, 1, . . . , SM{tilde over (v)}}.
Let {tilde over (t)}[s](u) denote the minimum required NoS when the system utility of session s is exactly u. Based on the results of the single session Algorithm 1 in Table 4, {tilde over (t)}[s](u)=minl=1L
A scenario with sessions from 1 to s is considered where for each uε{0, 1, . . . , SM{circumflex over (v)}}, a solution whose total system utility of these sessions is exactly u and whose total number of consumed slots are minimized is sought. Let h(s,u) denote this minimum NoS for this scenario. The recurrence relation of h(s,u) is shown in Recursion 3 in Table 5.
The correctness of the recurrence relation in Table 5 can be proved by induction. In the base scenario, there is only session 1. Clearly, when 0≦u≦M{tilde over (v)}[1], h(1,u)={tilde over (t)}[1](u). According to Lemma 2, M{tilde over (v)}[1] is a trivial upperbound of the maximum utility for session 1 under the resource constraint of T. Therefore, when u>M{tilde over (v)}[1], h(1,u)>T. As it is a meaningless result for the final solution, h(1,u) is set to h(1,u)=+∞ for u>M{tilde over (v)}[1].
A generic scenario of h(s,u) is now considered in which 2≦s≦S and 0≦u≦SM{circumflex over (v)}, assuming that all the values of h(s′,u) for all 1≦s′<s and 0≦u≦SM{circumflex over (v)} have been attained. It is assumed in the optimal solution specified by h(s,u), session s generates utility u′, 0≦u′≦u. The minimum NoS needed by session s to generate utility u′ is independent from the sessions from 1 to s−1. Thus, h(s,u)=h(s−1,u−u′)+{tilde over (t)}[s](u′). As indicated above, u′ can only range from 0 to M{tilde over (v)}[s] while u varies from 0 to SM{tilde over (v)}. Accordingly, the actual range of u′ should be from 0 to max{u,M{tilde over (v)}[s]}. h(s,u) is the minimum value among all possible values of u′ such that 0≦u′≦max{u,M{tilde over (v)}[s]}. Thus,
Based on the results of the recursion, the maximum system utility with the total NoS bounded by T can be obtained
U*=max[({u|h(S,u)≦T})] (5)
Turning now to the complexity of this multi-session dynamic programming algorithm, the values of {tilde over (t)}[s](u) and {circumflex over (v)} can be obtained based on the dynamic programming algorithm in Table 3, discussed above. {circumflex over (L)} can be defined as {circumflex over (L)}=maxs=1SL[s], and J is defined as J=Σs=1SJ[s], then the complexity is O(Σs=1S(L[s]J[s]+L[s]
Based on the dynamic programming algorithm discussed above with regard to Table 4, a fully polynomial time approximation scheme for the problem (2) is provided herein below as Algorithm 2 in Table 6.
Theorem 2: Algorithm 2 is a fully polynomial time approximation scheme for multi-session problem (2) within an approximation factor of 1−εS and with complexity O({circumflex over (L)}J+S{circumflex over (L)}2M3/ε+S2M4/ε2). The proof has been omitted for brevity purposes.
Referring now to
At step 404, the base station 102 can determine a maximal utility for the set of receiver devices based on the received feedback to assign MCS to the layers in each session using the approximation process. For example, the base station 102 can employ any one or more of Recursion 2 of Table 3, Algorithm 1 of Table 4, Recursion 3 of Table 5 and/or Algorithm 2 of Table 6 to find the maximum utility for the set of receiver devices and to assign MCS to the layers in each session. In particular, a method 450 can be performed to implement step 404.
Method 450 can begin at step 452 in which the base station 102 may pre-compute slots used to transmit blocks of layers and may pre-compute utilities based on the user-feedback received at step 254. For example, as indicated above, the base station 102 may compute the values of the slots needed
to transmit the layers from l1 to l2 with MCS m for each value of m, l1 and l2 for each session s. In addition, by employing the received user-feedback, the base station 102 may further compute the utility
for each user j in each session s if the video layers 1, 2, . . . , l are decodable for the user and may further compute the utility vl,m[s] of all the users in set Nm[s] for each session s when they can receive layers 1 to l. Alternatively, if only a single session is considered, these slot and utility values can be computed for only one session.
At optional step 454, the base station 102 may select a factor s and may compute {circumflex over (v)} and K, as discussed above, for example, with respect to Algorithm 2 of Table 6. Here, the base station 102 may select the factor ε>0, compute {circumflex over (v)} and obtain the trivial upper bound for the optimal system utility as SM{circumflex over (v)}. For example, the base station 102 may compute
and may then compute factor
Alternatively, if only a single session is considered, at optional step 454, the base station 102 may select a factor ε and may compute {circumflex over (v)} and K, as discussed above, for example, with respect to Algorithm 1 of Table 4, where
At optional step 456, the base station 102 may convert utility values as discussed above, for example, with respect to Algorithm 2 of Table 6. Here, vl,m[s] may be set to
for use in Recursion 2 for each session s. It should be noted that steps 454 and 456 can be omitted if Recursion 2 of Table 3 in the single session case or Recursion 3 of Table 5 in the multi-session case are only employed or are employed with a different approximation scheme.
At step 458, the base station 102 may compute values for t(l,M,u). As discussed above, t(l,m,u) can correspond to the minimum number of slots utilized for potential MCS assignments where the total system utility for users in the set ∪m′=1mNm′ is exactly u, where uε{0, 1, . . . , M{tilde over (v)}}. For example, in the multi-session scenario, for each sε{1, 2, . . . , S}, the single-session dynamic programming algorithm (Algorithm 1 of Table 4) can be used to compute all the values of t(l,M,u) for 1≦l≦L[s] and
Alternatively, if only a single session is considered, then the base station 102 can compute all the values of t(l,M,u) for 1≦l≦L and
Further, if a fully polynomial time approximation scheme is not employed, then {tilde over (v)}[s] and {circumflex over (v)} can be employed in place of
respectively, as discussed above with respect to recursions 3 and 2.
At step 458a, to compute values for t(l,m,u), the base station 102 may compute the initial conditions for t(l,m,u) and q(l,m,u), which is described in detail below. For example, as discussed above with respect to Recursion 2, the set of initial conditions may be defined as follows: t(0,m,0)=0 for all m≦0, t(0,m,u)=∞ for all m≧0 and 0≦u≦M{tilde over (v)} (where {tilde over (v)} can be replaced with {tilde over (v)}[s],
t(l,0,u)=∞ for all l≦1 and 0≦u≦M{tilde over (v)} (where {tilde over (v)} can be replaced with {tilde over (v)}[s],
and t(l,m,u)=∞ for all l, m≦0 and u<0. Finally, q(0,m,u)=0 for all m≧0, u≧0.
At step 458b, the base station 102 may recursively determine values of the minimum number of slots utilized for potential assignments based on the initial conditions and on the received feedback. For example, as discussed above with respect to Recursion 2, the base station 102 may recursively determine t(l,m,u)=minδ=0l(t(l−δ, m−1, u−vl,m)+τl−δ+1,l,m), for all 1≦l≦L, 1≦m≦M, and 0≦u≦M{tilde over (v)} (where {tilde over (v)} can be replaced with {tilde over (v)}[s],
and L can be replaced with L[s]). Similar to the discussion provided above with respect to step 356, as indicated by the factor τl−δ+1,l,m, data from different layers (i.e. layers within the set l−δ+1 to l) correlated to a common MCS, m, in an assignment can be allocated a common slot.
In addition, it should be noted that a recursive determination step for a particular MCS determines a minimal number of slots for a particular layer index such that the recursive determination step for the particular MCS is constrained to assign to the particular MCS a block of layer indices commencing from the particular layer index. For example, for MCS m, the recursion step assigns m a block of layers l−δ+1 to l, with 0≦δ≦l, commencing from l. Moreover, the recursion step for MCS m recursively determines corresponding values of minimum number of slots for the particular layer index l by successively expanding the block until the lowest index for the set of layers is processed. For example, by successively varying δ from 0 to l, the block of layers commencing from l is expanded until the lowest layer index, 0 or 1, is reached.
Further, a recursive determination step for a particular MCS determines values of minimum numbers of slots utilized by allocating the particular MCS to a particular layer index to achieve each utility value within a pre-determined set of utility values. For example, as noted above, t(l,m,u)=minδ=0l(t(l−δ, m−1, u−vl,m)+τl−δ+1,l,m) can be determined for utility values u, where u is within the set 0≦u≦M{tilde over (v)} (where {tilde over (v)} can be replaced with {tilde over (v)}[s],
In addition, the recursive determination step for t(l,m,u) is based on the utility vl,m, which denotes the maximum utility achievable by all users in the set Nm, which are capable of utilizing MCSs only up to MCS m when they can receive or process layers 1 to l. As discussed above with respect to Algorithm 1 of Table 1, vl,m can be replaced with vl,m/K, where K=ε{circumflex over (v)}/M. It should be noted that a fully polynomial time approximation scheme produces a solution that is within a factor ε>0 of being optimal. Accordingly, here, ε is a pre-determined factor within which the values of the minimum number of slots t(l,m,u) obtained are optimal.
To permit the assignments of MCS to layers, as discussed further herein below while recursively determining the utility values t(l,m,u) at step 458b, the base station 102 can record the number of layers modulated with MCS m to achieve the minimum number of resources t(l,m,u) employed by users that can employ MCSs with indices that are at most m or lower (∪m′=1mNm′), can achieve utility u, and can receive at most layers of index l or lower. This number of layers is denoted here as q(l,m,u) and the base station can compute q(l,m,u) for each corresponding computation of t(l,m,u) as follows: q(l,m,u)=arg minδ=0l(t(l−δ, m−1, u−vl,m)+τl−δ+1,l,m), for all 1≦l≦L, 1≦m≦M, and 0≦u≦M{tilde over (v)}. In other words, q(l,m,u) corresponds to the length of the block of layers l−δ+1 to l corresponding to the minimum number of slots t(l,m,u). Furthermore, q(l,m,u) can be computed for each possible triplet of l, m and u, where 1≦l≦L, 1≦m≦M, and 0≦u≦M{tilde over (v)}. As stated above, {tilde over (v)} can be replaced with {tilde over (v)}[s],
L can be replaced with L[s], and vl,m can be replaced with vl,m/K in various exemplary embodiments.
At optional step 460, the base station 102 can compute h(S,u) using a multi-session dynamic programming process if multiple sessions are considered. For example, the base station 102 can use the multi-session dynamic programming algorithm (Algorithm 2 of Table 6) to compute all the values of h(S,u) for
Alternatively, the base station 102 can use Recursion 3 of Table 5 to compute all the values of h(S,u) for 0≦u≦SM{circumflex over (v)}), if the fully polynomial time approximation scheme is not employed.
At step 460a, to compute values for h(s,u), as discussed above with respect to Recursion 3 of Table 5, the base station 102 may pre-compute {tilde over (t)}[s](u), which is the minimum number of slots needed when the utility of session s is exactly u: {tilde over (t)}[s](u)=minl=1L
At step 460b, the base station 102 can compute another set of initial conditions for the minimum number of slots utilized in the multi-session scenario. For example, as discussed above with regard to Recursion 3 of Table 5, the minimum number of slots needed for achieving utility u with video session 1 can be computed:
As discussed above, {tilde over (v)}[1] can be replaced with {tilde over (v)}[1]/K in various exemplary embodiments.
Further, it should also be noted that, to permit the assignment of MCSs to layers of one or more sessions, the base station 102 can compute the initial condition for another function, g(s,u). Here, g(s,u) denotes the utility provided by session s corresponding to the minimum number of slots employed by sessions 1 to s to achieve the utility u provided by sessions 1 to s. The initial condition for g(s,u) is as follows g(1, u)=u for 0≦u≦M{tilde over (v)}[1] or 0≦u≦M{tilde over (v)}[1]/K.
At step 460c, the base station 102 can recursively determine values of the minimum number of slots utilized for each successively incremented session and for each utility value within a set of pre-determined utility values based on the set of initial conditions. For example, as discussed above with respect to Recursion 3 of Table 5, the base station 102 can compute the minimum number of slots needed to achieve the exact utility u with video sessions 1 to (1≦s≦S), where S is the total number of sessions: h(s,u)=minu′=0min{u,M{tilde over (v)}
Moreover, to permit the base station to determine MCS assignments, the base station 102 can recursively compute and record g(s,u) at step 460c during the computation of h(s,u). For example, the base station 102 can compute and record the following:
g(s,u)=arg minu′=0min{u,M{tilde over (v)}
As noted above, g(s,u) denotes the utility (u′) provided by session s corresponding to the minimum number of slots (h(s,u)) employed by sessions 1 to s to achieve the utility u provided by sessions 1 to s. As discussed further herein below with regard to step 406, the term g(s,u) is employed to determine the number of layers utilized in the session s and thereby recursively determine the highest layer index assigned to each MCS used in session s.
It should also be noted that step 460c can optionally be implemented in accordance with Algorithm 2 of Table 6. For example, vl,m[s] may be set to
and the range of utilities evaluated to compute t(l,M,u) in Recursion 2 can be set to 0≦u≦M└{tilde over (v)}[s]/K┘. Further, the range of utilities evaluated to compute all the values of h(s,u) and g(s,u) can be set to 0≦u≦SM└{circumflex over (v)}/K┘.
At step 462, the base station 102 can compute the maximum system utility U*. For example, as discussed above, the maximum system utility can be computed in the multi-session scenario by determining U*=max[({u|h(S,u)≦T})]. Alternatively, if only the single session scenario is considered, the maximum system utility can be computed by determining U*=max{u|t(l,M,u)≦T, 1≦l≦L}.
At step 406, the base station 102 can select the MCS/layer assignments based on the maximum system utility U* obtained at step 404 and can schedule multicast data transmission for each video session. For example, in the multi-session scenario, the base station 102 can compute the utility G(s) provided by each session s to achieve the maximum utility U*, where G(s)=g(s,U*−Σs′=s+1SG(s′)) for all 1≦s≦S. Here, G(s) can be recursively determined for all 1≦s≦S by using g(S,U*) as the initial condition, the value of which is determined at step 460c. The term U*−Σs′=s+1SG(s′) denotes the utility (u) provided by sessions 1 to s to achieve the maximum utility U* and, for each s, the base station 102 recursively determines the utility u′ provided by the session s to achieve the maximum utility U* by using g(s,u) determined at step 460c.
After obtaining the utility G(s) provided by session s to achieve the maximum utility U*, the base station 102 can thereafter determine, for each session s, the highest layer index allocated to each MCS m to achieve utility G(s) and thereby determine the MCS assignments. For example, let L[s](M) denote the highest layer index, which is assigned to the highest MCS index M used in session s in accordance with Lemma 1. The base station 102 can determine the highest layer index L[s](M) by selecting the index l corresponding to the minimum number of slots employed to achieve the utility G(s) provided by session s: L[s](M)=arg minl=1L
for all m=M, M−1, . . . , 2. As indicated above, the term q(L[s](m), m, u) denotes the number of consecutive layer indices (δ) from layer index L[s](m) that is allocated to MCS m when the users ∪m′=1mNm′ provide utility u. The term
denotes this utility, as it accounts for the utility provided by users that can employ MCSs with indices that are at most higher than m and subtracts this utility from the utility G(s) provided by the session s, thereby indicating the utility provided by the remaining users ∪m′=1mNm′.
Similar to the MCS assignments determined in accordance with the optimal approach in step 308, the MCS assignments can be made by assigning an MCS m to layer indices layers between the MCS m's highest layer index L[s](m) and the highest layer index below L[s](m) that is allocated to another MCS: M[s](l)=∞, for all l>L[s](M), l≦s≦S; and M[s](l)=m, for all L[s](m−1)<l<L[s](m), 1≦s≦S.
For the single session scenario, the base station 102 can determine MCS assignments in the same manner as in the multi-session case except that the maximum system utility U* is given by U*=max{u|t(l,M,u)≦T, 1≦l≦L}, and the term G(s) is replaced with this maximum utility U* in the expressions for L[s](m) and L[s](m−1).
Returning to
Referring now to
It should be understood that embodiments described herein may be entirely hardware, entirely software or including both hardware and software elements. In a preferred embodiment, the present invention is implemented in hardware and 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 storage 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.
A data processing system suitable for storing and/or executing program code may include at least one processor coupled directly or indirectly to memory elements through a system bus. The memory elements can include local memory employed during actual execution of the program code, bulk storage, and cache memories which provide temporary storage of at least some program code to reduce the number of times code is retrieved from bulk storage during execution. Input/output or I/O devices (including but not limited to keyboards, displays, pointing devices, etc.) may be coupled to the system either directly or through intervening I/O controllers.
Network adapters may also be coupled to the system to enable the data processing system to become coupled to other data processing systems or remote printers or storage devices through intervening private or public networks. Modems, cable modem and Ethernet cards are just a few of the currently available types of network adapters.
Having described preferred embodiments of a methods and systems for allocating resources and assigning MCSs to layers of a data stream (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/229,999 filed on Jul. 30, 2009, incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
61229999 | Jul 2009 | US |