1. Field of the Invention
The present invention relates to scheduling of communication resources in a communications system.
2. Description of the Related Art
A communication system can be seen as a facility that enables communication between two or more entities such as user equipment and/or other nodes associated with the system. The communication may comprise, for example, communication of voice, data, multimedia and so on. The communication system may be circuit switched or packet switched. The communication system may be configured to provide wireless communication.
There may be a number of users who wish to use communication resources of a communication system. Typically the number of active users may change over time, and the amount of data to be transmitted may be very different from one user to another. Furthermore, the users may pose different quality requirements on data transmission. These requirements may relate, for example, to a transmission delay or to occurrence of transmission errors.
The communication resources need to be divided between these users, preferably taking into account the user-specific amounts of data to be transmitted and quality requirements. The allocation of the resources to different users can be done in time, frequency, code or spatial dimensions. Scheduling refers to time multiplexing communication resources across multiple active users. Typically communication resources are allocated to users in consequent scheduling periods. The users and the number of users, for whom communication resources are allocated, typically change from one scheduling period to another.
Communication resource scheduling in radio systems is a widely researched domain with a multitude of available solutions and variants. A good scheduler is fair, while maximizing the radio interface efficiency. These two requirements are often contradictory, as can be seen in the deficiencies of two basic scheduler examples.
A round-robin scheduler, in the basic form, gives an equal amount of time for each user who has data to transmit. This scheduler is always fair, but if it is applied to systems with link adaptation, it results in poor air interface efficiency. The poor air interface efficiency is due to the following. Link adaptation allows choosing of transmission method, for example, a coding scheme and a modulation alphabet for the transmission, based on the quality of the allocated radio channel. With link adaptation, it is thus possible to use a higher data rate on a radio channel having good quality and a lower data rate on a worse-quality radio channel. The overall radio interface efficiency would therefore benefit from taking users' channel qualities into account in scheduling. By allocating equal amounts of time for each user, the round-robin scheduler is insensitive to the quality of radio channels.
A second example of a scheduler is based on maximum carrier to interference ratio (C/I). This scheduler prioritizes the user who has the best communication channel in the scheduling period, and in many cases this scheduler gives the benchmark for data throughput. The maximum C/I scheduler is not usable in the basic configuration, because it does not allocate any communication resources to user with inferior communication channels.
A well-known and studied attempt to improve over these basic scheduling schemes is the proportional fairness scheduler. This scheduler has been incorporated into 1xEV-DO by Qualcomm, and it is discussed by A. Jalali, R. Padovani, and R. Pankaj, in “Data Throughput of CDMA-HDR: A High-Efficiency High-Data Rate Personal Communication Wireless System,” Proceedings of the IEEE VTC, 2000.
The proportional fairness scheduler is based on the following ideas. For each user, an estimate of the channel quality (for example, C/I) is calculated and a sliding average of the channel quality is separately computed in a water-filling fashion. The instantaneous channel quality is divided with the average channel quality, and the user with the highest ratio at any given time instant gets the communication resource. This approach succeeds in giving the communication resource to users when their channel is better than average, but due to wireless channel characteristics it favors users who are physically moving fast.
It is appreciated that both the maximum C/I scheduler and the proportional fairness scheduler rely on the idea that there is a channel quality measure for each user. Also other traditional scheduling solutions rely on a single quality metric for the quality of the communication channel between a transmitter and a receiver.
In modern wireless systems multiple means are exploited to increase the throughput, for example by using multiple parallel data streams or by obtaining better error performance from diversity. For example, multiple antennas and/or multicarrier transmission over a wide transmission bandwidth may be used to create multiple parallel channels between the transmitter and the receiver. In these wireless systems, the channel characteristics between a transmitter and receiver can be different for different parts of the transmission medium. The channel from one antenna branch can be excellent, while the channel form another antenna branch is deeply faded. A group of subcarriers allocated to a user can be excellent, while another group of subcarriers allocated to the same user is performing badly.
It is possible to measure characteristics of different antenna branches, for example. Communication resource scheduling should therefore be able to take into account all measured channel information, not just one quality metric, for efficiently scheduling the communication resources.
A problem is, however, that scheduling requires information about the communication resource properties and about the requirements the users pose on the data transmission. All this information needs to be communicated to the scheduler. Typically channel properties are measured in the physical layer (L1), whereas the link layer (L2) knows at least some quality requirements. In a radio system, where multiple transmission channels are offered on the physical layer and comprehensive quality of service (QoS) provision mechanisms are offered towards the higher layers, a large amount of parameters need to be transported across protocol layers to the layer responsible for scheduling. This results in increased interlayer communications which increases complexity in specifications and implementation and can, depending on implementation architecture, also cause extra delay. Furthermore, a single scheduling algorithm becomes complex, if it needs to take into account all measured channel property information and QoS requirements. Such a complex scheduler increases processing power requirements for the processor on which the scheduler is run.
Embodiments of the present invention aim to provide communication resource scheduling which may be used with various types of communication resources and which is able to take into account available information about communications resources quality and quality requirements.
A first aspect of the invention provides a method for scheduling communication resources, the method comprising
A second aspect of the invention provides a method for scheduling communication resources, the method comprising
A third aspect of the invention provides a method for scheduling communication resources, the method comprising
A fourth aspect of the invention provides a device for scheduling communication resources, said device being configured to
A fifth aspect of the invention provides a communications system configured to
A sixth aspect of the invention provides a device for scheduling communication resources, said device being configured to
A seventh aspect of the invention provides a device for scheduling communication resources, said device being configured to
An eighth aspect of the invention provides a computer program comprising program instructions for causing a computing device to perform a method in accordance with the invention.
A ninth aspect of the invention provides a method for scheduling communication resources, the method comprising
A tenth aspect of the invention provides a device configured to
Embodiments of the present invention will now be described by way of example only with reference to the accompanying drawings, in which:
a shows a schematic block diagram of a first embodiment of the invention;
b shows a schematic block diagram of a first alternative of the first embodiment of the invention;
c shows a schematic block diagram of a second alternative of the first embodiment of the invention;
Scheduling of communication resources in the following description and in the appended claims refers to time multiplexing communication resources to active data flows. A user may have multiple data flows. The number of active data flows typically changes over time. Scheduling is typically performed by allocating communication resources to data flows in consecutive scheduling periods. Multiple data flows may be scheduled to transmit during a scheduling period. In this description and in the appended claims, a scheduling period typically refers to a duration of time for which physical communication resource allocations are signaled jointly.
It is appreciated that the duration of the scheduling periods is typically constant, but it is possible that the duration of the scheduling periods varies over time.
The set of data flows, to which communication resources are allocated in a first scheduling period, may be different than the set of data flows, to which communication resources are allocated in a second scheduling period. These sets may be different, because the set of active data flows changes. Alternatively, the scheduling process may decide to allocate communication resources to different data flows among the active data flows.
It is appreciated that communication resources are typically divided into channels. Scheduling of communication resource thus typically refers to scheduling of channels to data flows. In communications, a channel is the path or route which a message follows, as the message is transmitted between a communication source and a receiver, distinguished from other parallel paths. In a time division multiplex system, for example, a channel is typically defined as a certain time slot. In a frequency division multiplex system, a channel is defined by a certain frequency. In a code division multiplex system, a channel is defined by a certain code.
With respect to multiple antenna transmissions, it is appreciated that the scheduled communication resources may comprise any of the following: single-input-single-output (SISO) channels, single-input-multiple-output (SIMO) channels, multiple-input-single-output (MISO) channels, and multiple-input-multiple-output channels (MIMO).
In the following embodiments, the communication resource scheduling functionality is split into two functional parts: a first part relates to managing the data to be transmitted using a set of communication resources and a second part relates to determining properties of the set of communication resources and to allocating the set of communication resources to users according to the communication resource properties and information about the data to be transmitted.
a shows a schematic block diagram relating to a first embodiment of the invention. Typically the data to be transmitted is received from an upper protocol layer and the data to be transmitted is stored temporarily when awaiting transmission (blocks 31, 32). Blocks 31 and 32 are typically part of the second (link) protocol layer L2.
The first entity 10 determines data-flow-specific information relating to a next scheduling period for a set of data flows (block 11). In determining the data-flow-specific information, the amount of data awaiting transmission is typically checked. As discussed below, the data-flow-specific information may contain, for example, data-flow-specific minimum amounts of data to be transmitted in the next scheduling period and/or data-flow-specific available amounts of data awaiting transmission. It is, however, possible that other data-flow-specific parameters are determined in block 11. The data-flow-specific information is submitted (block 12) to the second entity 20.
In the second entity 20, communication resource properties are estimated (block 21). As the second entity 20 is typically part of the physical protocol layer, it has access to various information about the communication resources. The physical protocol layer L1 typically has access to all available information about the communication resource properties. The communication resources are allocated based on said data-flow-specific information and the determined communication resource properties (block 22). If the second entity 20 (that is, typically, a physical protocol layer entity) does not have direct access to the temporarily stored data in block 32, allocation information relating to the next scheduling period is communicated to block 33 (typically part of the link protocol layer entity L2) having access to the temporarily stored data. In block 33, scheduled outward data is then submitted to the physical protocol layer L1, and in block 34 the scheduled data is transmitted in the next scheduling period.
It is appreciated that when the second entity 20 is part of the physical protocol layer L1 and the temporary storage of outward data in block 32 is implemented so that the physical protocol layer L1 has access to the temporarily stored data, blocks 23 and 33 may be discarded.
b shows a schematic block diagram of a first alternative of the first embodiment of the invention. A network node 100 contains a first entity 110 and a second entity 120. The first entity 110 is configured to determine information about the amounts of data to be transmitted. These amounts of data to be transmitted are typically data-flow-specific minimum amounts of data to be transmitted within the next scheduling period. In addition, information about data-flow-specific amounts of available data may be determined and used in scheduling. Information about the amounts of data to be transmitted is submitted to the second entity 120. The second entity 120 is configured to estimate communication resource properties and to allocate communication resources to data flows based on at least the received information about the amounts of data to be transmitted and on the estimated communication resource properties.
It is appreciated that the allocation of communication resources in the second entity 120 may take into account further information than only data-flow-specific minimum amounts of data to be transmitted within the next scheduling period and estimated communication resource properties. As a first example, taking into account the data-flow-specific amounts of available data is mentioned above. This information is useful especially when the minimum amounts of data to be transmitted do not consume all transmission capacity within the next scheduling period. As a second example, for allocating sufficient quality communication resources to data flows, the second entity 120 may need information about error performance requirements of the data flows. As a third example, for ignoring low-priority data flows if not all minimum data requirements can be satisfied, information about priorities of the data flows may be needed in the second entity 120. As the error performance requirements and priority information typically does not change very rapidly, this information generally need not be communicated between the first entity 110 and the second entity 120 separately for each scheduling period. It is typically sufficient that the second entity 120 is informed, for example when transmitting first data packets relating to a data flow or when setting up a data flow, about error performance requirements and priority. Information about data-flow-specific amounts of information available for transmission and about data-flow-specific minimum amounts of information to be transmitted in the next scheduling period may change rapidly, so this information may be submitted to the second entity 120 for each scheduling period.
c shows a schematic block diagram of a second alternative of a first embodiment of the invention. In this second alternative, the first entity 110 is in a first network node 101 and the second entity 120 is in a second network node 102. The first network node 101 may be, for example, a base station of a communications system, and the second network node 102 may be a relay station. As a relay station is often connected to a base station with a radio interface, it is appreciated that it is not needed to transmit all possible quality requirement information to the second entity 120 for scheduling or, vice versa, to transmit information on estimated communication resource properties to the first entity 110.
Base station usually refers to a cellular communication system, but it is appreciated that embodiments of the present invention are applicable in any communications systems. Access nodes of wireless local area networks are one example of transceiver network elements, where the embodiments are applicable.
Information on communication resource quality is measured, stored and processed typically in the physical layer (L1). Quality of service information relevant to scheduling of traffic flows, on the other hand, is typically managed at the link layer (L2). The quality of service information includes e.g. priorities, delay budgets, queue lengths and/or packet error requirements. The proposed split of the scheduler functionality does not need excessive control information exchange between L1 and L2 layers.
Furthermore, the physical layer and the link layer are in practice often implemented on different processing platforms. The proposed split of the scheduler functionality supports this architecture and enables parallel processing on these two processing platforms.
As the instantaneous channel allocation decisions between users are made on the physical layer, or in the entity responsible for estimating communication resource properties, all available information on the communication resource properties is available for the scheduling decision.
In accordance with embodiments of the invention, the scheduling functionality is split between two entities, more particularly between two protocol layers. This proposed split enables implementation of different parts of the scheduler to different physical network nodes in a communication system.
Furthermore, in some embodiments of the invention it is possible to implement the proposed scheduling functionality within a single entity. In this case, at least block 12 in
In
Based on the QoS parameters and the arrival order of data packets from upper protocol layers, the data packets can be arranged into queues 202. These queues may be specific to sets of QoS parameters, and therefore data packets in one queue have the same quality requirements. If priority information is to be taken into account in scheduling, each queue may have a specific combination of QoS parameters and priority.
Knowing the time each packet has spent in the queue and the delay budget specified by the quality requirements, the minimum amount of data to be transmitted for each data flow within the next scheduling period (block 205 in
The physical layer L1 estimates the communication resource properties (block 211). As an example of handling transmission diversity or multiplexing, it is possible to measure channel qualities relating to a first path/carrier and to a second path/carrier for a specific data flow. The allocation of communication resource may then take into account, for example, five possibilities to transmit information relating to the data flow: the first path/carrier, the second path/carrier, multiplexing data through both paths/carriers, a diversity transmission using both the first and the second path/carrier, or some transmission combining the elements of multiplexing and diversity.
The allocation of communication resource for the next scheduling period (block 212) is based at least on estimated communication resource properties and on data-flow-specific minimum amounts of data to be transmitted within the next transmission period. Typically also the data-flow-specific amounts of data available for transmission are also used as input to the allocation. As discussed above in connection with
Once the scheduling for the next scheduling period is determined, the physical layer L1 sends the information about the scheduled amounts of data (arrow 221) to the data link layer L2. These scheduled amounts of data are typically queue specific. The data link layer L2 sends data (arrow 222) from the queues in accordance with the scheduled amounts to the physical layer L1. Based on the scheduled amounts of data, on new incoming data and on other relevant information (for example, quality requirements 201 and system limitations 203) the data link layer L2 then determines corresponding input parameters 204, 205 for the following scheduling period.
It is appreciated that the specific way how the physical layer L1 allocates communication resources for the next scheduling period depends on the communications system. The scheduling should be optimized depending, for example, on possible multicarrier modulation, multiple access scheme, duplexing, frame structure, used modulation alphabets and/or coding schemes, or propagation environments.
It is appreciated that although
In the following some possible modifications to embodiments of the invention are discussed. The minimum amount of data to be transmitted within the next scheduling period, in other words the bit rate, may be set to zero, even for all data flows, if all the packets in the queues are still within the set delay limits during the next scheduling period in question. In this case the allocation for the next scheduling period can use, for example, capacity, throughput, error rate or power optimized scheduling between the users. One example of throughput optimized scheduling is the maximum C/I scheduling discussed above in connection with the related background art.
It would be possible to indicate in the link layer L2 a small minimum amount of data to be transmitted within the next scheduling period even for best-effort data. This way a continued data flow would be created for best-effort data even when higher-priority data exists to by-pass the non-real-time information.
The L2 scheduling can be also set up so that it selects only some subset of data flows to be scheduled for the scheduling period in question. This decision can be done for example based on: delay requirements, amount of data in the queues, and/or error performance requirements. For example, a set of data flows with similar delay requirements or error performance requirements may be selected from a larger number of data flows. This can be useful because there usually exists some upper limit on the number of data flows who can be served during one scheduling period. Alternatively or additionally, selecting a subset of data flows may be useful to reduce the complexity of the L1 scheduling between excessively many data flows, and to reduce the signaling required to inform the users on when they are scheduled for transmission or reception.
When calculating the minimum bit rate requirements for the next scheduling period the link layer L2 can also take into account not only the delay requirements but also the amount of data in the buffer. This is to avoid situations where satisfying only the minimum requirements will lead into a congested situation later on. Also the realized bit rates for each user (that is the scheduled amounts of data), averaged over some suitable time period, could be used in L2 to estimate the future capacity of each user's channel or at least of one of the user's channel. This could be useful in trying to optimize the L2 processing.
In communication systems with multi-hop network topology the distributed scheduling can be particularly useful. As an example, in systems with base stations (BS) and relay stations (RS) the L2 part of the scheduling can be done only in the base station, which sends information required for the L1 scheduling discussed above to the relay station via a radio interface. The relay station can then do the L1 scheduling as deemed suitable without requiring knowledge of all the L2 parameters. In these types of situations where either the control information on L2 or the channel information on L1 will have to be sent over air the distributed scheduling saves radio resources and makes delays shorter, while allowing for the channel qualities to be used as basis for scheduling.
The specific way on how the L1 processing is done depends crucially on the particular radio interface used. In particular the single/multicarrier modulations, spatial structure of the channel (for example, MIMO vs. SISO transmissions), multiple access scheme and frame structure need to be taken into account. Some examples of implementation are discussed below.
A fourth embodiment of the invention relates to a system where single carrier modulation is used and where no spatial multiplexing is used. This means that the system uses single-input-single-output (SISO) or single-input-multiple-output (SIMO) transmission. The channel quality, and therefore the bit rate for the channel, are determined by the carrier to interference ratio C/I of the channel. With a single carrier, the users for the next scheduling period can be multiplexed either in time direction or by using spreading codes.
In discussing this fourth embodiment, it is assumed that there is at most one data flow relating to each user. It is evident to a skilled person how to modify this fourth embodiment to cover also the possibility of multiple data flows relating to a user.
In this fourth embodiment the L1 scheduling first tries to multiplex all the users with non-vanishing minimum amounts of data to be transmitted within the next scheduling period using the resources available. After satisfying the non-vanishing minimum requirements, the rest of the resources (time instants, spreading codes) are allocated to the users with best channels and/or largest amounts of available data to be transmitted.
For example, all the users (even those without minimum amounts of data to be transmitted within this scheduling period) can now be ordered according to their channel quality, and resources may be allocated in that order, trying to satisfy the maximum amounts of data, possibly using adaptive modulation. It is appreciated that depending, for example, on the modulation and frame structure, there might be some preferred granularity in the amounts of data that can be allocated. This granularity should be taken into account to avoid gaps.
It is appreciated that various modifications to the implementation shown in
Regarding multicarrier modulation, which means that multiplexing can be done in time and in frequency/subcarriers, there may be need to develop existing allocation methods further. Existing capacity/throughput optimized multicarrier allocation methods satisfying minimum data rates for users may be applied, but they usually do not take into account the fact that there can also be upper limits on the amounts of data. Moreover, the optimal solutions may be computationally very complex for a large number of subcarriers, so effective suboptimal algorithms with minimum and maximum constraints may need to be developed.
It is appreciated that in addition to downlink and other systems controlled by the transmitting entity, a more restricted version of the scheduler functionality may be implemented in uplink or otherwise in a node, which is not in control of communication resource allocation.
It is appreciated that any method in accordance with the embodiments of the present invention may be implemented in devices, more particularly in network elements or in communications devices for use with communications systems.
It is appreciated that embodiments of the invention may be implemented using software, hardware or a suitable combination of these. For example, embodiments of the invention may be implemented using Application-Specific Integrated Circuits (ASICs), designed for particular applications. As a second example, embodiments of the invention may be implemented using program code for programmable Digital Signal Processing (DSP) chips.
It is appreciated that the term data flow in this description and in the appended claims is to be understood to refer to a set of data, for example to a connection, with specific quality requirements. As mentioned above, there may be multiple data flows relating to a single user.
It is furthermore appreciated that the term user need not refer to human users. The term may refer to any process or equipment having data to transmit.
As mentioned also above, it is appreciated that the specific way how the scheduling of communication resources is carried out given the minimum amounts of data to be transmitted within a scheduling period and the available amounts of data to be transmitted depends on the set of communication resources.
It is appreciated that a part of the communication resources may be left unallocated during a scheduling period, especially if the amounts of data available for transmission are not sufficient to use all available communication resources.
It is furthermore appreciated that the term communication resource properties may refer to various properties. For example, when a single carrier modulation is used together with no spatial multiplexing, the communication resource properties are defined by the carrier to interference ratio C/I of a channel. It is evident to a skilled person that communication resource properties for diversity schemes or, for example, for MIMO systems may be defined by a number of quality factors.
It is appreciated that the term data-flow-specific information relating to a next scheduling period typically refers to sets of parameters, the parameters having data-flow-specific values.
Embodiments of the invention would have merits in any environment, where due to diversity multiple more or less independent channels are created between two transceiver stations. These environments include all present and future multicarrier systems and possible other not-yet-specified systems using e.g. antenna diversity approaches. Some example of multicarrier systems are 802.11a and some other branches of WLAN; WiMax; WiBro; possible multicarrier extensions in 3GPP and 3GPP2; and Ultra Wideband (UWB) family.
It is appreciated that although this description refers in many instances to two entities involved in the scheduling, and more specifically to L1 and L2 layers, the scheduling functionality may be implemented in a single entity.
In the appended claims term submitting information refers to delivering information to a further entity, either within the same device (for example, between protocol layer entities) or to a further device. An example of submitting information within one device is information delivery between protocol entities in the given device. Some examples of submitting information between devices are, firstly, the base station and relay station combination and, secondly, the communications device and a network element of a communications system in the restricted version of scheduler functionality.
Although preferred embodiments of the apparatus and method embodying the present invention have been illustrated in the accompanying drawings and described in the foregoing detailed description, it will be understood that the invention is not limited to the embodiments disclosed, but is capable of numerous rearrangements, modifications and substitutions without departing from the spirit of the invention as set forth and defined by the following claims.
Number | Date | Country | Kind |
---|---|---|---|
20041465 | Nov 2004 | FI | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/FI2005/000223 | 5/17/2005 | WO | 00 | 11/8/2007 |