Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
WIRELESS BACKHAUL SYSTEM
Document Type and Number:
WIPO Patent Application WO/2014/082114
Kind Code:
A1
Abstract:
Disclosed is a method of transmitting data over a plurality of wireless frequency bands between a transmitter and a receiver during one of a plurality of rounds, the method comprising: computing a target spacing in time between a start time of transmission in a first band and a start time of transmission in a second band dependent on a first data rate in the one round and in the first band; commencing transmitting, by the transmitter, a first frame of data over the first band at the first data rate; waiting for the computed target spacing to elapse, and then commencing transmitting, by the transmitter, a second frame of data over the second hand at a second data rate.

Inventors:
LIU REN PING (AU)
CANTONI ANTONIO (AU)
MATTHEWS JOHN (AU)
Application Number:
PCT/AU2012/001470
Publication Date:
June 05, 2014
Filing Date:
November 30, 2012
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
COMMW SCIENT IND RES ORG (AU)
International Classes:
H04W72/04; H04B1/02; H04L27/00
Domestic Patent References:
WO2010093862A12010-08-19
Foreign References:
US20120243638A12012-09-27
US8265096B22012-09-11
US20120243638A12012-09-27
Other References:
See also references of EP 2926609A4
Attorney, Agent or Firm:
SPRUSON & FERGUSON et al. (Sydney, New South Wales 2001, AU)
Download PDF:
Claims:
CLAIMS

1. A method of transmitting data over a plurality of wireless frequency bands between a transmitter and a receiver during one of a plurality of rounds, the method comprising: a. computing a target spacing in time between a start time of transmission in a first · band and a start time of transmission in a second band dependent on a first data rate in the one round and in the first band; b. commencing transmitting, by the transmitter, a first frame of data over the first band at the first data rate; c. waiting for the computed target spacing to elapse, and then commencing transmitting, by the transmitter, a second frame of data over the second band at a second data rate.

2. The method of claim 1 , wherein the size of each frame in the round is equal to a constant slot length multiplied by the data rate in the round and in the band over which the frame is transmitted,

3. The method of claim 2, further comprising, simultaneously with the commencing transmitting the first frame, commencing loading a next frame to be transmitted in the next round over the first band at a loading rate.

4. The method of claim 3, wherein the constant slot length is at least the ratio of the maximum over all rounds of the sum over all bands of the frame sizes to the minimum of the loading rate and an unloading rate of received frames at the receiver.

5. The method of claim 2, wherein the computing the target spacing comprises computing the maximum data rate in the first band over all rounds, divided by the sum over all bands of the maximum data rate in each band over all rounds, multiplied by the constant slot length.

6. The method of any of claims 1 to 5, wherein the waiting comprises: a. waiting until the transmission of a previous frame of data over the second band is complete; b. computing a target delay as the difference between: i. the sum of the start time of transmission in the first band and the

computed target spacing; and ii. the current time; and c. waiting for the computed target delay to elapse.

7. The method of claim 6, further comprising determining whether the computed target delay is less than a slot tolerance in the first band in the previous round, wherein the waiting is performed dependent on the determining, and wherein the slot tolerance in a band and a round is equal to the ratio of a frame size granularity to the data rate in the band in the round.

8. The method of claim 7, wherein, when the computed target delay is less than the slot tolerance, the size of the first frame is equal to the sum of a constant slot length and the computed target delay, multiplied by the data rate in the round and in the corresponding band, rounded to the nearest multiple of the frame size granularity, and the waiting is not performed.

9. The method of claim 7, wherein, when the computed target delay is not less than slot tolerance, the size of the first frame is equal to a constant slot length multiplied by the data rate in the round and in the corresponding band, rounded to the nearest multiple of the frame size granularity.

10. A transmitter comprising: a. a processor configured to compute a target spacing in time between a start time of transmission in a first band and a start time of transmission in a second band dependent on a first data rate in the first band; and b. a switch configured to: i. commence transmitting a first frame of data from a first buffer over the first band at the first data rate; ii. wait for the computed target spacing to elapse, and then commence

transmitting a second frame of data from a second buffer over the second band at a second data rate.

1 1. The transmitter of claim 10, further comprising a switch configured to, simultaneously with the commencement of transmitting of the first frame, commence loading the second frame of data into the second buffer.

12. Computer program code configured to cause a computing device to perform a method of transmitting data over a plurality of wireless frequency bands between a transmitter and a receiver during one of a plurality of rounds, the code comprising: a. code for computing a target spacing in time between a start time of transmission in a first band and a start time of transmission in a second band dependent on a first data rate in the one round and in the first band; b. code for commencing transmitting, by the transmitter, a first frame of data over the first band at the first data rate; c. code for waiting for the computed target spacing to elapse, and then commencing transmitting, by the transmitter, a second frame of data over the second band at a second data rate.

Description:
WIRELESS BACKHAUL SYSTEM Field

[0001] The present invention relates generally to wireless communications and in particular to multi-band backhaul arrangements in wireless communication systems.

Background

[0002] High speed broadband networks have been growing rapidly in the last few decades. With the advance of wireless communications technologies, new broadband wireless access (BWA) networks offering 100 Megabits per second (Mbps) to 1 Gigabits per second (Gbps) data rates are on the horizon. The emerging BWA networks pose major challenges to backhaul; that is, the connection of the wireless access points for users of the BWA network to a larger wired network (such as the Internet). In countries with large geographical areas of low population density, such as Australia, high data rate wireless backhaul is necessary to bring broadband services to remote areas economically.

[0003] One of the major challenges in wireless backhaul is to achieve both high data rates and long distance. The former demands a large bandwidth in the order of GHz, and the latter requires that the system operate at microwave frequencies rather than the higher millimetre- wave frequencies. Whilst a large contiguous bandwidth is rarely available at microwave frequencies for use in wireless backhaul, there are usually some disjoint bands and sub-bands available. For example, in Australia, such bands are presently available at 6, 6.7, 8, and 1 1 GHz. These bands may be aggregated to increase transmission capacity and thus obtain the required GHz bandwidth. Link aggregation, or striping, was originally employed for wired digital circuit aggregation, and was soon integrated in ATM, Ethernet, IP, and TCP networks. More recently, there has been interest in wireless striping.

[0004] One requirement of striping is that it be transparent to upper communication layers in the Open Systems Interconnection (OSI) model. Preservation of data order is one of the most important transparency requirements. However, when a traffic stream is striped across multiple links, its data may be received out of order at the receiver because of different delays in different stripe links. Most previous approaches deal with out-of-order arrivals by numbering the data packets at the transmitter node with a sequence number. This sequence number can then be used at the receiver node to sort the packets back into order. However, such reordering significantly increases the upper bound on the overall striping delay.

Additionally, data packets need to be modified to carry sequence numbers, and a reordering buffer has to be used to store out-of-order packets, significantly increasing cost. Moreover, in certain applications, sequence numbers cannot be added due to packet size or hardware restrictions.

[0005] In-sequence striping, or FIFO delivery, can avoid the costs of reordering. However, existing FIFO delivery techniques are unable to achieve "work-conserving". Work-conserving means that no link is idle when there is data that could be sent through that link. Since link aggregation is often used to overcome communication bottlenecks, it is advantageous that all the links are fully utilized to maximize the throughput and minimize the delay through the aggregated channel.

[0006] There are additional difficulties for implementing striping in multi-band wireless backhaul systems. First, the band data rate may be different (heterogeneous) for different bands depending on the available spectrum bandwidth on that band. Second, the band data rate may be time varying, since the modulation and coding level in a band is often made adaptive to time-varying channel quality.

Summary of Invention

[0007] It is an object of the present invention to overcome, or at least ameliorate, one or more of the above disadvantages of a siriped wireless backhaul communication link.

[0008] Disclosed is a striped wireless backhaul communication system that achieves both work-conserving and in-sequence (WIS) performance under heterogeneous time-varying conditions. The disclosed system uses a parallel processing architecture, and utilises timing controls that balance efficiency and performance, and minimize scheduling conflicts. The disclosed system can operate under conditions of infinite divisibility of data, and a variant version of the disclosed system can operate under the more practical conditions of finite data granularity. The disclosed system operates at the physical layer of the OSI model. [0009] In accordance with one aspect of the invention, there is provided a method of transmitting data over a plurality of wireless frequency bands between a transmitter and a receiver during one of a plurality of rounds, the method comprising: computing a target spacing in time between a start time of transmission in a first band and a start time of transmission in a second band dependent on a first data rate in the one round and in the first band; commencing transmitting, by the transmitter, a first frame of data over the first band at the first data rate; waiting for the computed target spacing to elapse, and then commencing transmitting, by the transmitter, a second frame of data over the second band at a second data rate.

[00010] In accordance with a second aspect of the invention, there is provided a transmitter comprising: a processor configured to compute a target spacing in time between a start time of transmission in a first band and a start time of transmission in a second band dependent on a first data rate in the first band; and a switch configured to: commence transmitting a first frame of data from a first buffer over the first band at the first data rate; wait for the computed target spacing to elapse, and then commence transmitting a second frame of data from a second buffer over the second band at a second data rate.

[0001 1] In accordance with a third aspect of the invention, there is provided computer program code configured to cause a computing device to perform a method according to the first aspect.

Brief Description of Drawings

[00012] At least one embodiment of the present invention will now be described with reference to the drawings, in which:

[00013] Fig. 1 is a block diagram of a multi-band wireless backhaul system according to one embodiment;

[00014] Figs. 2a and 2b are block diagrams of circuits that may be used to implement the band transmitters and the band receivers respectively in the system of Fig. 1 ; [00015] Fig. 3 is a timing diagram illustrating an exemplary timing of loading, transmitting, and unloading over different bands and rounds within the system of Fig. 1 ;

[00016] Fig. 4 contains a flow chart illustrating a scheduling process carried out by each band transmitter in the system of Fig. 1 according to one embodiment;

[00017] Fig. 5 is a schematic block diagram representation of a computing device as which the band transmitters and the band receivers in the system of Fig. 1 may be implemented;

[00018] Fig. 6 contains a flow chart illustrating a variant scheduling process carried out by each band transmitter in the system of Fig. 1 according to one embodiment;

[00019] Fig. 7 contains a graph illustrating the transmit and receive sequence numbers of sample frames in a simulation of the system of Fig. 1 ; and

[00020] Fig. 8 contains a graph illustrating the striping delay in a simulation of the system of Fig. 1.

Description of Embodiments

[00021 ] Fig. 1 is a block diagram of a multi-band wireless backhaul system 100 according to one embodiment. The system 100 uses N disjoint frequency bands of, in general, different band data rates. The data rate of each band may be different from that of other bands due to different available spectrum bandwidth for the band. The N bands are used to implement N wireless data transmission channels 160-0, ..., 160-(N-l) that are "striped" to form a wireless link between the transmitter 1 10 and the receiver 120. Adaptive Modulation and Coding (AMC) is employed on each channel 160-/ (/ = 0, ... , N-l) with modulation level ranging from QPS to 256-QAM, depending on the quality of the corresponding band.

[00022] Time is divided into intervals referred to as "rounds", indexed byy > 0. The band data rates not only vary between channels /, but also vary between rounds j depending on the modulation level used in a round as determined by the AMC scheme in use. [00023] The system 100 is illustrated as uni-directional; however the same components as illustrated in Fig. 1 and the corresponding processes, described below, may be used to implement a "striped" link in the reverse direction, that is from the receiver 120 to the transmitter 1 10.

[00024] Incoming data is first stored in an input buffer 130 in the transmitter 1 10. A striping scheduler 140 arbitrates the data loading from the input buffer 130 to the band transmitters 150-/ using a scheduling process described in detail below. The data are transmitted from the band transmitters 150-/ through the respective channels 160-/ to respective band receivers 170-/ at the receiver 120. As the scheduling process guarantees in-sequence delivery, there is no need for a complicated receive scheduler or reorder buffer at the receiver 120. The receiver 120 simply unloads the data from the band receivers 170-/ to an output buffer 180 on a first- come-first-served (FCFS) basis, thereby combining the traffic into a single output stream from the output buffer 180.

[00025] Table 1 shows the meaning of the notation that is used throughout the present disclosure. The meanings in Table 1 will be further elaborated below.

Notation Meaning

/V Total number of bands (or channels) i band (channel) number, / ' e [0, N - 1 ] j round number, j e (0,∞)

Data frame in band / round j

Size of data frame f j j

■ A, Loading time of data frame f j Time slot in band i round j

Start time of time slot s,■■

Length of time slot s,. . συ propagation delay of band i in round j

U ,i Unloading time of data frame .

Exit time of data frame f i . i Transmission rate (or data rate) of band ; ' in round j

Striping delay of band / ' in round j

Loading rate

Unloading rate

Sc Target constant time slot length or round time p, Target spacing of transmit times between band and band i-\

A,, Target delay of band i in round j

Table 1 : Notation

[00026] Figs. 2a and 2b are block diagrams of circuits 200 and 250 that may be used to implement the band transmitters 150-/ and the band receivers 170-/ ' respectively in the system 100 of Fig. 1 according to one embodiment. The circuit 200 of Fig. 2a has a dual buffer parallel processing architecture containing two buffers 210 and 220, labelled as TxBuff-0 and TxBuff-1. A switch (multiplexer) 240 is configured to transmit the contents of the first buffer TxBuff-0 210, denoted as data frame f t j , via the channel 160-/ at the transmission rate R t / , commencing at time Ί ί } during round j. Also commencing at time T tJ , a switch

(demultiplexer) 230 is configured to load a portion of incoming data, data frame f I J+ , at the loading rate R, into the second buffer TxBuff-l 220, taking L, /+) seconds. Once transmission of the data frame f j is complete, the multiplexer 240 returns a "ready" signal 245 to the demultiplexer 230. During the following round the multiplexer 240 is configured to transmit the contents of the second buffer TxBuff- 1 220 (data frame J] - +1 ) via the channel

160-/ at the transmission rate , while the demultiplexer 230 is configured to load a further portion of incoming data, data frame f I J+2 , at the loading rate R, into the first buffer TxBuff-0 210, taking L i j+1 seconds. The demultiplexer 230 is also configured to relay the ready signal 245 back to its input stage (the striping scheduler 140) via a control line 235 to inform the striping scheduler 140 that the circuit 200 is ready to load the next data frame.

[00027] Similarly, the circuit 250 of Fig. 2b has a dual buffer parallel processing architecture containing two buffers 260 and 270, labelled as RxBuff-0 and RxBuff-1. A switch

(demultiplexer) 280 is configured to receive the data frame f t ■ into the first buffer RxBuff-0

260 via the channel 160-/ at the transmission rate R i ; during round /. Commencing at the same instant, a switch (multiplexer) 290 is configured to unload the data frame /, , to its output stage (the output buffer 180) at the unloading rate R (l from the second buffer RxBuff-1

270, taking U, seconds and ending at time £, . . During the following round the demultiplexer 280 is configured to receive the data frame f, · + , into the second buffer

RxBuff-1 270 via the channel 160-/ at the transmission rate R, J+l , while the multiplexer 290 is configured to unload the data frame f tJ to its output stage at the unloading rate R tJ from the first buffer RxBuff-1 260, taking U j j seconds and ending at time E i ■ .

[00028] The striping delay r, y is defined as the delay between when a frame . . starts being loaded into the band / band transmitter 150-/ at the transmitter 1 10 and when the frame , finishes being unloaded out of the band / band receiver 170-/ at the receiver 120 (in other words the difference between £,. and T, ),

[00029] The band transmitters 150-/ and band receivers 170-/ require high speed processing. In one implementation, the buffers 210, 220, 260, and 270 are implemented in block RAM, which is a limited resource in FPGA hardware. The input buffer 130 requires a much larger capacity to store backlogged data, and in one implementation is implemented in more abundant, though slower, flash memory.

[00030] As mentioned above, the scheduling process loads the data frame , of size / , from the input buffer 130 to the band transmitter 150-/. The size F t . . of the frame f t J is determined as part of the scheduling process, described in detail below.

[00031] The loading of the data frame f i } to the band transmitter 150-/ is carried out as a memory access operation within the transmitter 1 10. The loading rate R, is constant across all band transmitters 150-/. The loading time L t of data frame f i f satisfies

[00032] The transmission of frame f t occupies time slot s t , of length S i seconds. As mentioned above, within band / , the transmission rate R j stays constant within a time slot -, . , but may vary between rounds j depending on the AMC level.

[00033] The time slot length S t satisfies

[00034] As the N bands implement parallel point-to-point channels 160-/, their propagation delays, σ,.■ , are bounded with insignificant variations compared to the slot length S Kj . The propagation delays in all the channels i over all rounds j are therefore treated as equal, i.e.

[00035] At the receiver 120, the received data frame f i ; is unloaded from the corresponding band receiver 170-/ ' to the output buffer 180 at an unloading rate of R t! . The unloading is carried out as a memory access operation within the receiver 120. The unloading rate R u is therefore constant across all band receivers 170-/, The unloading time U, / satisfies

(3)

[00036] The band transmitter 150-/ ' controls the timing of the transmit operation in each band / ' . More precisely, the band transmitter 150-/ ' , according to the the scheduling process described below, computes a time T f at which to start transmitting the data frame f l t over the channel 160-/ ' , and to start loading the data frame , from the input buffer 130.

[00037] P t denotes the target spacing in time between the start of the transmit time on band / and the start of the transmit time on the preceding band M , i.e.

R = T f i - T, l n Q < i < N - \

[00038] The band transmitter 150-/ ' computes the times T j by first computing the target spacing P t in the manner described below. Note that the target spacings /> are independent of the round j.

[00039] Fig. 3 is a timing diagram illustrating an exemplary timing 300 of loading, transmitting, receiving, and unloading over different bands / ' and rounds j in the system 100 of Fig. 1. Each row represents one of the N bands, indexed from top to bottom by 0 to N-l . Band 0, represented by the first row 310, is defined to be the reference band, and its time slots s 0 f define the rounds j , where j increases from left to right. The start of each round j is therefore at time T 0 / . [00040] In the first round (j=\) of the first row 310, data frame / 0 2 is loaded, taking L 0 2 seconds, into the band transmitter 150-0, where it is stored while the band transmitter 150-0 transmits data frame f 0 , in time slot s 0A , taking 5" 0ι1 seconds. After a propagation delay of σ seconds, the data frame f 0 , starts to be received by the band receiver 170-0, taking S Q , seconds. Meanwhile, the previously received data frame f 00 is unloaded from the band receiver 170-0 to the output buffer 180 in U 00 seconds, ending at time Ε .

[00041] At time T 0 2 , the start of the second round (j-2), the band transmitter 150-0 starts transmitting data frame f 02 in time slot s 0 2 , taking S 02 seconds, and loading data frame /„ 3 , taking L Q 3 seconds. After a propagation delay of σ seconds, the data frame f 0 2 starts to be received by the band receiver 170-0, taking S 02 seconds. Meanwhile, the received data frame f 0 , is unloaded from the band receiver 170-0 to the output buffer 180 in U 0 , seconds, ending at time E 0 , .

[00042] In the second row 320 corresponding to band / ' = 1, the same operations take place, except delayed within each round / by the time T j . Likewise, operations in all subsequent bands (up to / = N-l) are delayed within each round j relative to band 0 by the time T t J .

[00043] To achieve work-conserving, the band transmitter 150-/ computes a constant slot length S c in accordance with the constraints described in detail below, and controls the data frame sizes F J such that the lengths S : j of all time slots s, ; across all bands / ' and rounds j are made equal to S c :

[00044] The data in the input buffer 130 is first assumed to be infinitely divisible, i.e. F j can be controlled to any length. Using divisible load theory (DLT), fundamental constraints, timing controls, and hence the scheduling process described below, may be derived. A variant of the scheduling process, also described below, may also be derived based on the practical case of finite divisibility, or granularity, of the data in the input buffer 130. [00045] Across different bands i, within a given round j, the starts T, of the time slots s j are scheduled in ascending order of band number :

T o,j≤T tJ < T l j < T 0 J+I , fi,j. (6) [00046] This condition is equivalent to requiring positive target spacings P,.

[00047] An unintelligent scheduling process would space the starts T t f o{ the time slots s ( j evenly across all the bands. However, such an unintelligent schedule would not guarantee in- sequence delivery for heterogeneous systems.

[00048] The necessary conditions for the system 100 of Fig. 1 to achieve work-conserving in- sequence striping (WIS) are now described. At the transmitter 1 10 and receiver 120, the loading rate R L and the unloading rate R v are required to satisfy the following conditions. * f/ ≥max j∑* ( / } (8) je(0,co) o J

[00049] That is, the loading and unloading rates R, and R,, must both be greater than or equal to the maximum over all rounds of the sum of the transmission rates R, y within each round over all bands. Equations (7) and (8) govern the choice of hardware used to implement the buffers 210, 220, 260, and 270 in the circuits 200 and 250 respectively.

[00050] The next design parameter is the constant slot length S c . It may be shown that the striping delay r t is approximately proportional to the constant slot length S c . There is thus an incentive to minimize the constant slot length S c . It may also be shown that the lower bound on the constant slot length S c is given by

YF. [00051 ] That is, the constant slot length S c must be at least the ratio of the maximum over all rounds of the sum over all bands of the frame sizes F t } to the minimum of the loading rate

R, and the unloading rate R v . The upper bound of the constant slot length S c is determined by the resources of the system 100 by taking the maximum possible size of each band transmitter or band receiver 150-/ and 170-/ and dividing by the maximum transmission rate R t . The final choice of the constant slot length S c , balancing system performance, efficiency, and resource requirements, is between these lower and upper bounds.

[00052] In one exemplary implementation, the transmitter and 1 10 receiver 120 operate to a system clock of 156.25 MHz and an internal data width of 64 bits. This gives the loading and unloading rates of R, - R u = 10 Gbps : The transmit buffers 210 and 220 in each band / are each implemented in the block RAM of an FPGA with capacity of 15 Mbits. Half of the 15 Mbits of block RAM (i.e. 7.5 MBits) is allocated for the two transmit buffers 210 and 220 on each of the N bands, so each buffer 210 or 220 has at most 7.5/(2N) Mbits capacity. For N = 3 bands, the maximum capacity for each transmit buffer is therefore 1.25 Mbits. The receive buffers 260 or 270 are implemented in the same way. Under a maximum transmission rate R i . of 3.77 Gbps, and a frame size of 1.25 Mbits, the upper bound on the constant slot length

S c is 331 β. In order to achieve a reasonable level of system efficiency, the minimum frame size F, j is set to 500 kbits. Using equation (9), this gives a lower bound of S c of 150 /vs.

The constant slot length S c is therefore set to 200 jus, between the upper and lower bounds.

[00053] The band transmitter 150-/ also needs to compute the times T t at which to start transmitting data frames f i / over the channels 160-/, and to start loading the data frames f i J+l from the input buffer 130, subject to equation (6). To do this, the band transmitter 150-/ cofnputes the target spacing P t between transmit times in band / and transmit times in its preceding band dependent on the transmission rate R M j in the preceding band i-l , such that:

• each band transmitter 150-/ has enough time to finish loading its frame before the next band transmitter 150-(/+l) starts its loading process, and • each band receiver 170-/ has enough time to finish loading its frame before the next band receiver 170-(/+l) starts its unloading process.

[00054] The loading and unloading processes in all the bands can, in this implementation, be executed consecutively without overlapping, thereby realizing in-sequence striping.

[00055] In one implementation, the target spacing P t between the transmit times in band / and the preceding band i- l is set to the maximum transmission rate in band i-l over all rounds, divided by the sum over all bands of the maximum transmission rate within each band over all rounds, multiplied by the constant slot length S c :

[00056] In the case where transmission rates are constant over all rounds j, the spacing in a band as a proportion of the constant slot length S c is the same as the transmission rate in the preceding band as a proportion of the sum of the transmission rates over all bands.

[00057] Fig. 4 contains a flow chart illustrating a scheduling process 400 carried out by each band transmitter 150-/ (/ = 0, N-l) in the system 100 of Fig. 1 according to one embodiment.

[00058] Fig. 5 is a schematic block diagram of a general purpose computing device 501 including embedded components, as which the band transmitters 150-/ and the band receivers 170-/ in the system 100 of Fig. 1 may be implemented.

[00059] As seen in Fig. 5, the computing device 501 comprises an embedded controller 502. Accordingly, the computing device 501 may be referred to as an "embedded device." In the present example, the controller 502 has a processing unit (or processor) 505 which is bi- directionally coupled to an internal storage module 509. The storage module 509 may be formed from non-volatile semiconductor read only memory (ROM) 560 and semiconductor random access memory (RAM) 570, as seen i Fig. 5. The RAM 570 may be volatile, nonvolatile or a combination of volatile and non- volatile memory. When the computing device 501 is implementing the band transmitters 150-i and the band receivers 170-/, the buffers 210, 220, 260, and 270 ' are implemented within the RAM 570, while the switches 230, 240, 280, and 290 are emulated by the processor 505.

[00060] The scheduling processes described hereinafter may be implemented using the embedded controller 502, as one or more software programs 533 executable within the embedded controller 502. In particular, with reference to Fig. 5, the steps of the described processes are effected by instructions in the software 533 that are carried out within the embedded controller 502. The software instructions may be formed as one or more code modules, each for performing one or more particular tasks.

[00061] The software 533 of the embedded controller 502 is typically stored in the nonvolatile ROM 560 of the internal Storage module 509. The software 533 stored in the ROM 560 can be updated when required from a computer readable medium. The software 533 can be loaded into and executed by the processor 505. In some instances, the processor 505 may execute software instructions that are located in RAM 570. Software instructions may be loaded into the RAM 570 by the processor 505 initiating a copy of one or more code modules from ROM 560 into RAM 570. Alternatively, the software instructions of one or more code modules may be pre-installed in a non-volatile region of RAM 570 by a manufacturer. After one or more code modules have been located in RAM 570, the processor 505 may execute software instructions of the one or more code modules.

[00062] The program 533 is typically pre-installed and stored in the ROM 560 by a manufacturer, prior to distribution of the computing device 501. The use of such a program 533 in the computing device 501 effects an apparatus for scheduling transmissions in the transmitter 1 10 of Fig. 1.

[00063] The internal storage 509 comprises read only memory (ROM) 560 and random access memory (RAM) 570. The processor 505 is able to execute the programs 533 stored in one or both of the connected memories 560 and 570. When the computing device 501 is initially powered up, a system program resident in the ROM 560 is executed. The program 533 permanently stored in the ROM 560 is sometimes referred to as "firmware". Execution of the firmware by the processor 505 may fulfil various functions, including processor management, memory management, device management, storage management and user interface.

[00064] The processor 505 typically includes a number of functional modules including a control unit (CU) 551, an arithmetic logic unit (ALU) 552 and a local or internal memory comprising a set of registers 554 which typically contain atomic data elements 556, 557, along with internal buffer or cache memory 555. One or more internal buses 559 interconnect these functional modules. The processor 505 typically also has one or more interfaces 558 for communicating with external devices via system bus 581, using a connection 561.

[00065] The program 533 includes a sequence of instructions 562 through 563 that may include conditional branch and loop instructions. The program 533 may also include data, which is used in execution of the program 533. This data may be stored as part of the instruction or in a separate location 564 within the ROM 560 or RAM 570.

[00066] In general, the processor 505 is given a set of instructions, which are executed therein. This set of instructions may be organised into blocks, which perform specific tasks or handle specific events that occur in the computing device 501. Typically, the program 533 waits for events and subsequently executes the block of code associated with that event.

Events may be triggered in response to other sensors and interfaces in the computing device 501.

[00067] The execution of a set of the instructions may require numeric variables to be read and modified. Such numeric variables are stored in the RAM 570. The disclosed method uses input variables 571 that are stored in known locations 572, 573 in the memory 570. The input variables 571 are processed to produce output variables 577 that are stored in known locations 578, 579 inthe memory 570. Intermediate variables 574 may be stored in additional memory locations in locations 575, 576 of the memory 570. Alternatively, some intermediate variables may only exist in the registers 554 of the processor 505.

[00068] The execution of a sequence of instructions is achieved in the processor 505 by repeated application of a fetch-execute cycle. The control unit 551 of the processor 505 maintains a register called the program counter, which contains the address in ROM 560 or RAM 570 of the next instruction to be executed. At the start of the fetch execute cycle, the contents of the memory address indexed by the program counter is loaded into the control unit 551. The instruction thus loaded controls the subsequent operation of the processor 505, causing for example, data to be loaded from ROM memory 560 into processor registers 554, the contents of a register to be arithmetically combined with the contents of another register, the contents of a register to be written to the location stored in another register and so on. At the end of the fetch execute cycle the program counter is updated to point to the next instruction in the system program code. Depending on the instruction just executed this may involve incrementing the address contained in the program counter or loading the program counter with a new address in order to achieve a branch operation.

[00069] Each step or sub-process in the processes described below is associated with one or more segments of the program 533, and is performed by repeated execution of a fetch-execute cycle in the processor 505 or similar programmatic operation of other independent processor blocks in the computing device 501.

[00070] The scheduling processes may alternatively be implemented in dedicated hardware such as one or more integrated circuits performing the functions or sub-functions of the scheduling processes. Such dedicated hardware may include graphic processors, digital signal processors, field programmable gate arrays (FPGAs), or one or more microprocessors and associated memories.

[00071 ] The scheduling process 400 illustrated in Fig. 4 will now be described. In the implementation in which the band / band transmitter 150-/ is implemented as the computing device 501 , the steps of the scheduling process 400 are carried out by the processor 505 controlled by the software 533.

[00072] The scheduling process 400 starts at step 410, at which the band transmitter 150-/ computes the constant slot length S c between the lower bound given in equation (9) and the upper bound set by the resources of the system 100, as described above. Step 415 follows, at which the band transmitter 150-/ computes the target spacing P, using equation (10). At the next step 420, the band transmitter 150-/ sets the preceding band index / to (/-l ) mod N, which is equal to /-l except when / = 0, when / is N-l . The scheduling process 400 then enters a loop in which the round number j increments from 1 at each iteration. [00073] At the first step 430 in the loop, the band transmitter 150-/ waits for a global variable BJS (for "band just started") to be equal to the index / of the preceding band, and for the "ready" signal 245 to arrive from the multiplexer 240. The band transmitter 150-/ is then ready to transmit its stored frame /,· . However, when the system 100 starts from idle, or is under unsaturated load, the current time, now, (provided by a clock within the band transmitter 150-/), may be early compared to the target start time of T t + P, . Therefore, the band transmitter 150-/ at step 440 computes a target delay of D, . to maintain the spacing of

Pi from the start time T t of the transmit time of the preceding band /. The band transmitter

150-/ computes the target delay D, . at step 440 as follows:

D i f = T + P, - now,0 < i < N - 1 (1 1 )

[00074] Also at step 440, the band transmitter 150-/ waits for the target delay D J to elapse.

At the next step 460, the band transmitter 150-/ sets the start time 7) . to the current time now, and proceeds to, at step 470, start transmitting its stored frame . , and, simultaneously at step 480, compute the next frame size F i +) using equation (5), and start loading the next frame /, +1 . The simultaneous loading and transmitting by the band transmitter 150-/ is described above with reference to Fig. 2. As part of step 480, the band transmitter 150-/ relays the ready signal 245 back to the striping scheduler 140 via the control line 235 to inform the striping scheduler 140 that the band transmitter 150-/ is ready to load the next data frame f l J+x .

[00075] Finally, at step 490, the band transmitter 150-/ sets the global variable BJS to /, and the scheduling process 400 then returns to step 430.

[00076] It may be shown that the scheduling process 400 guarantees work-conserving and in- sequence striping under conditions of infinite data divisibility. No re-ordering of received frames is therefore required at the band / band receiver 170-/, and, assuming sufficient data is always present in the input buffer 130, all transmission channels 160-/ are fully occupied at all times. [00077] To demonstrate the work-conserving and in-sequence striping of the scheduling process 400, the system 100 has been implemented in a VHDL behavior model and simulated using ModelSim. The simulated system 100 operates with N = 3 wireless channels 160-/, in the 6 GHz, 6.7 GHz, and 8 GHz frequency bands respectively. AMC with modulation level ranging from QPS to 256QAM depending on the link quality was used. The maximum transmission rates are achieved with 256QAM under excellent channel conditions as max R 0 = 2794.5278 >/«·

j max R, , = 3770.0208M¾/«

j

. max R 2,j = 3193.7462Mbps

j

[00078] A system clock of 156.25 MHz and a data width of 64 bits gave loading and unloading rates of /? . = Ru = 10 Gbps, which satisfy equations (7) and (8). The constant slot length is set at S c = 200μ? , based on the buffer capacities and frame sizes in the example implementation described above. The target spacings P t are determined by Equation ( 10) as

Po = 65.457 fjs, P \ = 57:275 ^s, and P 2 = 77.268 /s.

[00079] The average band utilization p, for band i is defined as

[00080] where R t J is the measured data rate on band in round j, and N s is the number of measured sample frames. Under saturated load conditions, the average utilization for each band was measured over N s = 100 sample frames as ¾ = 1.000098, p \ = 0.9998630, and ¾ = 0.9998791. All three bands are thus fully utilized within the error margin of the simulation, demonstrating the load sharing and work-conserving properties of the scheduling process 400.

[00081 ] To demonstrate the in-sequence property of the delivery sequence of the scheduling process 400, the transmit sequence number for each sample frame was recorded at the transmitter 1 10 of the simulated system 100 before the loading starts. The sequence numbers for the received frames were then recorded at the receiver 120 after the unloading finished. Fig. 7 contains a graph 700 illustrating the recorded transmit and receive sequence numbers. The upper trace 710 shows the transmit sequence numbers over time, and the lower trace 720 shows the received sequence numbers over time. Fig. 7 shows that that both transmit and receive sequence numbers increase monotonically with time. The frame sequence is therefore strictly maintained at both transmitter and receiver of the simulated system 100, thereby demonstrating the in-sequence striping property of the scheduling process 400.

[00082] The performance of the simulated system 100 was evaluated in terms of striping delay To evaluate the relationship between striping delay ¾ and constant slot length S c , the simulation was run for a range of constant slot lengths S c and the measured striping delay averaged over 100 sample frames for each constant slot length S c . Fig. 8 contains a graph 800 illustrating the average striping delay plotted against constant slot length S c . It can be seen from the graph 800 that the average striping delay is proportional to the constant slot length Sc, as expected. In addition, the average striping delay was shown to be independent of the number N of bands, in contrast with a reordering-based sy stem, in which the the average striping delay increases with the number N of bands.

[00083] A variant of the scheduling process 400 suitable for practical conditions of finite granularity of data in the input buffer 130 will now be described. Under these conditions, the data in the input buffer 130 is divisible to a non-zero (finite) frame size granularity AF, which can be device word size, transmission cell size, or maximum transmission unit (MTU) size in a no-fragmeht transmission system. Such finite granularity may result in the target frame size defined in equation (5) not being strictly observed. Rather, the frame size F t j satisfies

(12)

[00084] where 0 < 5F j . < AF . In order to achieve work-conserving in-sequence striping under such practical frame size granularity, the necessary conditions in equations (7) and (8) on load rate and unload rate respectively have become:

(13)

[00085] to accommodate the variations in frame size allowed by equation (12).

[00086] The increases in the lower bounds on the loading and unloading rates over those given in equations (7) and (8) are greater as the number of bands N and the " frame size granularity AF increase. Equations (13) and (14) can be used to choose device hardware in a system with finite frame size granularity A of word, cell, or packet sizes, such that scheduling conflicts can be avoided and work-conserving in-sequence striping can be achieved.

[00087] In the variant scheduling process, the band transmitter 150-/ controls the time slot length S ;J within a range with end points given by:

S c - AS f J ≤5 (J ≤5 e + AS (J (15) AF

[00088] where AS, f is the "slot tolerance" given by— , The band transmitter 150-/ achieves this in band / and round j by first computing the target delay Z>■ according to equation ( 1 1 ). If the target delay £> . is greater than the slot tolerance S l H , it is likely that the input buffer 130 has run out of data. In this case the band transmitter 150-/ sets a target frame size F mrg for the next round j+\ using equation (5) and waits for the target delay D t f to elapse. If, on the other hand, the target delay £>, y . is less than the slot tolerance AS S ._, , the target frame size F, arg is set to

^ = (S t + ., , > 6)

[00089] and transmission is commenced immediately, i.e. with no waiting. (The need for waiting has been removed by the adjustment to the frame size in accordance with equation (16)). Note that if the target delay ( . . is negative, which occurs if the preceding frame f Kj _ is longer than expected, the target frame size F, arg is reduced from its "ideal" value in accordance with equation (16).

[00090] Fig. 6 contains a flow chart illustrating the variant scheduling process 600 carried out by each band transmitter 150-/ in the system 100 of Fig. 1 according to one embodiment. In the implementation in which the band transmitter 150-/ ' is implemented as the computing device 501 , the steps of the scheduling process 600 are carried out by the processor 505 controlled by the software 533.

[00091 ] Except where otherwise indicated, the steps in the variant scheduling process 600 are the same as those with parallel numbering in the scheduling process 400 of Fig. 4, i.e. steps 610 to 630 and 660 to 690 are the same as the steps 410 to 430 and 460 to 490 respectively. The principal difference from the scheduling process 400 is that steps 635 to 657 are carried out in place of step 440.

[00092] At step 635, the band transmitter 150-/ computes the target delay D, . . using equation (1 1). At the next step 645, the band transmitter 150-/ determines whether the target delay D l . . is less than the slot tolerance &S , . if so, the band transmitter 150-/, at step 650, sets the target frame size F targ using equation ( 16), and then proceeds to step 660.

[00093] If, however, the band transmitter 150-/ determines that the target delay D, f is greater than or equal to the slot tolerance AS, , the band transmitter 150-/, at step 655, sets the target frame size F, arg as follows:

[00094] The band transmitter 150-/ then at step 657 waits for the target delay D Kj to elapse before proceeding to step 660.

[00095] The other difference from the scheduling process 400 is that at step 680, the band transmitter 150-/ computes the next frame size F, , . +1 from the target frame size F, arg computed at step 650 or step 655 by rounding the target frame size F targ to the nearest multiple of the frame size granularity AF, and then commences loading the next frame f j +l , of size F l +l , from the input buffer 130.

[00096] It may be shown that the variant scheduling process 600 guarantees work-conserving and in-sequence striping under conditions of finite frame size granularity. No re-ordering of received frames is therefore required at the band / band receiver 70-/, and, assuming sufficient data is always present in the input buffer 130, all transmission channels 170-/ ' are fully occupied at all times.

[00097] The arrangements described are applicable to the wireless communication industry.

[00098] The foregoing describes only some embodiments of the present invention, and modifications and/or changes can be made thereto without departing from the scope and spirit of the invention, the embodiments being illustrative and not restrictive.

[00099] In the context of this specification, the word "comprising" means "including principally but not necessarily solely" or "having" or "including", and not "consisting only of. Variations of the word "comprising", such as "comprise" and "comprises" have correspondingly varied meanings.