The present invention relates to a method and apparatus for transmitting data from a transmitter device to a plurality of receiver devices, and in particular to a method and apparatus for transmitting and receiving data signals over pairs of wires. Such methods include all of the various Digital Subscriber Line (DSL) methods as specified in various International Telecommunications Union (ITU) standards and as being further developed in the ITU at present. Typically each such pair of wires comprises a twisted metallic pair (usually copper) as commonly found within telephone access networks throughout the world.
DSL technology takes advantage of the fact that although a legacy twisted metallic pair (which was originally installed to provide merely a Plain Old Telephone Services (POTS) telephony connection) might only have been intended to carry signals using differential mode at frequencies of up to a few Kilohertz, in fact such a line can often reliably carry signals at much greater frequencies. Moreover, the shorter the line, the greater is the range of frequencies over which signals can be reliably transmitted (especially with the use of technologies such as Discrete Multi-Tone (DMT), etc.). Thus as access networks have evolved, telecommunications network providers have expanded their fibre optic infrastructure outwards towards the edges of the access network, making the lengths of the final portion of each connection to an end user subscriber (which is still typically provided by a metallic twisted pair) shorter and shorter, giving rise to correspondingly greater and greater bandwidth potential over the increasingly short twisted metallic pair connections without having to bear the expense of installing new optic fibre connections to each subscriber.
In the separate field of wireless communication, as the frequency response of a given wireless channel varies aggressively, flat transmitting power spectral density (PSD) tends to become increasingly inefficient, for example since power density per Hertz does not fully compensate for associated channel loss at a given frequency. Subsequently, this degrades the efficiencies of system energy and the channel capacity. As a solution, so-called “water-filling/pouring” was first suggested by Claude Shannon in 1949. Since then, there have been a lot studies trying to derive the optimal solutions for various wireless channels.
The present inventors have realised that, as the bandwidth of DSL systems keep expanding, the encountered loss will tend to become steeper than earlier DSL generations. Thus, flat PSD will tend to become extremely inefficient. This may be due, for example, to non-optimal power allocation to some frequencies. Aspects of the present invention provide a fast converging analytical water-filling algorithm that tend to overcome this problem.
The present inventors have further realised that, unlike slow/fast time varying wireless channels, Twisted Metallic Pair (TMP) channels tend to be semi-static. Thus, variability of the frequency response of TMP channels over time tends to be negligible. The present inventors have further realised that, however, with TMP channels the loss across the system bandwidth tends to be much steeper compared to wireless channels, and, as a result, aggressive signal shaping of the channel frequency response for TMP channels can be avoided. The present inventors have realised that this can be exploited to minimise the complexity of any water-filling solution.
In a first aspect, the present invention provides a method of transmitting data from a transmitter device to one or more receiver devices, each of the one or more receiver devices being connected to the transmitter device via a respective wire connection, the transmitter device being operable to transmit signals onto the wire connections over one or more different channels. The method comprises, for each of the one or more different channels: determining a value of a function {tilde over (s)}j,jm, the function being:
where: j is a channel index; bmax is an upper bound for a channel capacity of the one or more channels; and γj,jm is a gain of the jth channel; determining a transmission power sj,jm for transmitting data along that channel, wherein the transmission power sj,jm is:
s
j,j
m=min{pm,{tilde over (s)}j,jm}
where: pm is a power mask for transmitting the data over the one or more different channels; and transmitting, by the transmitter device, data over that channel to one or more of the receiver devices, the data being transmitted at the transmission power sj,jm determined for that channel.
The one or more channels may comprise one or more channels selected from the group of channels consisting of: a direct channel, an indirect channel, a channel provided by a change over time of a potential difference between a pair of the wire connections, a phantom channel, a common mode channel.
An available spectrum for the transmission of the data over the one or more channels may comprise a plurality of tones. The steps of determining a value of a function and determining a transmission power may be performed for each tone, thereby to determine a transmission power for each tone and for each of one or more of the channels. The step of transmitting may comprise, for one or more of the plurality of tones and for one or more of the channels, transmitting, by the transmitter device, data over that channel on that tone to one or more of the receiver devices, the data being transmitted at the transmission power determined for that channel and that tone.
The method may further comprise: iteratively performing steps (i) to (iii) until, at step (iii), it is determined that one or more criteria are satisfied, thereby determining, for each of the one or more different channels, a new transmission power for transmitting data over that channel, wherein: step (i) comprises determining a value of a further function, the further function being a function of a maximum power for transmitting the data over the one or more different channels; step (ii) comprises, using the determined value of the further function, determining, for each of the one or more different channels, a respective new transmission power for transmitting data along that channel; and step (iii) comprises determining whether or not the one or more determined new transmission powers satisfy one or more criteria; and, for each of the one or more channels, switching from transmitting data over that channel at the transmission power sj,jm to transmitting data over that channel at the new transmission power determined for that channel. For second and subsequent iterations of steps (i) to (iii), the further function may be determined at step (i) by modifying a value of the further function of the preceding iteration. The further function may additionally be a function of one or more parameters selected from the group of parameters consisting of: a total number of different tones, frequency separation between tones, and a gain of the one or more channels, the gain of a channel being a ratio of a power coupling coefficient to a noise level on that channel. The further function may be given by:
where: j is a channel index; M is the number of different tones; Δf is a frequency spacing between adjacent tones; PT is the maximum power for transmitting the data over the one or more different channels; and γj,jm is a gain of the jth channel.
Step (ii) may comprise: using the determined value of the further function, determining, for each of the one or more different channels, an initial transmission power {umlaut over (s)}j,jm for that channel; for each of the one or more different channels, determining whether the determined initial transmission power {umlaut over (s)}j,jm for that channel satisfies the criterion: log2(1+{umlaut over (s)}j,jm>γj,jm)>ε1, where: j is a channel index; ε1 is a numerical value; and γj,jm is a gain of the jth channel; setting equal to zero each initial transmission power Jm,j that does not satisfy the criterion log2(1+{umlaut over (s)}j,jmγj,jm)>ε1; and maintaining the value of each initial transmission power {umlaut over (s)}j,jm that does satisfy the criterion log2(1+{umlaut over (s)}j,jmγj,jm)>ε1.
The one or more criteria may comprise one or more criteria selected from the group of criteria consisting of: the criterion that: log2(1+{umlaut over (s)}j,jmγj,jm)≤bmax−ε2, and the criterion that
wherein: j is a channel index; {umlaut over (s)}j,jm denotes the one or more determined new transmission powers; γj,jm is a gain of the jth channel; bmax is the upper bound for the channel capacity of the one or more channels; PT is the maximum power for transmitting the data over the one or more different channels; and ε2 and ε3 are numerical values.
The method may further comprise, for each of the one or more channels: determining a value of a first function, the first function being a function of a power mask for transmitting the data over the one or more different channels; determining a value of a second function, the second function being a function of an upper bound for a channel capacity of the one or more channels; determining a value of a third function, the third function being a function of the value of the first function and the value of the second function; using the determined value of the third function, determining a new transmission power for transmitting data along that channel; and switching from transmitting data over that channel at the transmission power sj,jm to transmitting data over that channel at the new transmission power determined for that channel.
The first function may be:
The second function may be:
where: j is a channel index; pm is the power mask for transmitting the data over the one or more different channels; bmax is the upper bound for the channel capacity of the one or more channels; and γj,jm is the gain of the jth channel. The third function,
may be a function selected from the group of functions consisting of
where λ1m is the first function and λ2m is the second function.
A transmission power, sj,jm, may be determined using:
where:
is the third function; and γj,jm is the gain of the jth channel.
In a further aspect, the present invention provides a transmitting device for transmitting data to one or more receiver devices, each of which is connected to the transmitter device via a respective wire connection, the transmitter device being operable to transmit signals onto the wire connections over one or more different channels. The transmitting device is configured to, for each of the one or more different channels: determine a value of a function {tilde over (s)}j,jm, the function being
where: j is a channel index; bmax is an upper bound for a channel capacity of the one or more channels; and γj,jm is a gain of the jth channel; determine a transmission power sj,jm for transmitting data along that channel, wherein the transmission power is:
s
j,j
m=min{pm,{tilde over (s)}j,jm}
where: pm is a power mask for transmitting the data over the one or more different channels; and transmit data over that channel to one or more of the receiver devices, the data being transmitted at the transmission power sj,jm determined for that channel.
In a further aspect, the present invention provides a program or plurality of programs arranged such that when executed by a computer system or one or more processors it/they cause the computer system or the one or more processors to operate in accordance with the method of any preceding aspect.
In a further aspect, the present invention provides a machine readable storage medium storing a program or at least one of the plurality of programs according to the previous aspect.
In order that the present invention may be better understood, embodiments thereof will now be described with reference to the accompanying drawings in which:
In the below description, reference will be made to modes of communication. Herein, the term “mode” is used to indicate the nature of the manner in which signals are transmitted between transmitter and receiver. In particular, as will be appreciated by persons skilled in the art, there are three principal such modes of communication: differential mode, phantom mode, and common mode. In all three of these modes the signal is transmitted (excited) and received (observed) as the (changing) potential difference (voltage differential) between two voltages (or equivalently between one “live” voltage and one “reference” voltage). In the differential mode the signal is transmitted/observed as the difference in potential between two wires (typically between two wires of a twisted metallic pair). In the phantom mode at least one of the voltages is the average voltage of a pair of wires (note that such average can vary without impacting on a signal carried in the differential mode across that same pair of wires—in this sense the phantom mode can be orthogonal to signals carried in the differential mode if carefully chosen); the term pure phantom mode may be used to specify that both voltages being compared with each other are average voltages, each average voltage being the average or common voltage of at least one pair of wires. Second and higher order phantom modes can also be obtained by using the average voltage of two or more average voltages as one of the voltages to be compared, etc. Finally, the common mode refers to the case where one of the voltages being compared is the “Earth” or ground reference voltage (or something substantially similar for telecommunications purposes). Naturally, it is possible for various mixed modes to also be used for carrying signals. For example, one reference voltage could be a common ground and the other could be the average between the voltages of two wires in a twisted metallic pair (to generate a mixed mode of phantom and common modes). However, in general, reference to a differential mode in this specification is used to refer to a pure differential mode, i.e. it does not include any phantom or common mode component so a mode comprising a comparison between the voltage on a single wire and the average voltage between the voltages of two other wires may be referred to as an impure phantom mode rather than a mixed phantom and differential mode, etc.
Phantom channels can be constructed from different combinations of TMPs. For instance, a first and a second TMP can together generate a single unique phantom channel which has a similar behaviour to that of each directly coupled differential mode channel formed across each pair in terms of channel directivity. However, phantom modes, as mentioned earlier, are due to the variation of the average voltages of the pairs. For more than two coupled pairs, the pairs may couple to each other in the phantom mode in various orthogonal and non-orthogonal manners, e.g. two distinct (but non-orthogonal) phantom mode channels may be exploited which share one common pair. Preferred embodiments of the invention select and construct only orthogonal phantom channels.
Reference is also made throughout the below description to direct and indirect coupling and direct and indirect channels. A direct channel is one in which the same physical medium and the same mode of transmission is used for both the transmission of the signal and for the reception of the signal. Thus a normal differential mode transmission across a single TMP from transmitter to receiver would constitute a direct (differential mode) channel between the transmitter and the receiver. By contrast, a channel in which the transmitter transmitted a signal onto a second TMP in differential mode but was received by a receiver from a first TMP in differential mode (the signal having “crosstalked” across from the second to the first pair) is an example of an indirect channel, as is a case in which a signal is transmitted by a transmitter in a phantom mode across the averages of the voltages of the wires in each of a first and second TMP and received (having “crosstalked/mode” converted) by a receiver connected to just the first TMP in differential mode.
Moreover, where there are multiple TMPs emanating from a single transmitter (e.g. an Access Node (AN) or Digital Subscriber Line Access Multiplexor (DSLAM), etc.) in such a way that multiple direct and indirect channels are formed between the transmitter and multiple receivers, the set of twisted metallic channel pairs and their derivative channels (direct and indirect and of various different modes) can be considered as forming a “unified” dynamic shared or composite channel over which a number of virtual channels may be overlaid (i.e. the virtual channels are overlaid over the underlying common shared channel). In this context, a virtual channel can be considered as an overlay channel by which data can be directed to individual receivers even though a single common underlying signal is transmitted onto the underlying common channel; this can be achieved for example by means of a suitable multiple access technique such as Frequency Division Multiple Access (FDMA), Code Division Multiple Access (CDMA), Time Division Multiple Access (TDMA) or simply be using suitable encryption techniques, etc.
Referring now to the Figures,
In this example, the deployment comprises a Distribution Point Unit (DPU) 10 which is connected to three user premises 31,32, 33 (which in this example are flats within a single building 30) via respective Twisted Metallic Pair (TMP) connections 21, 22, 23 which connect between an Access Node (AN) 16 (which may, for example, be a DSLAM) within the DPU 10 and respective Customer Premises Equipment (CPE) modems 51, 52 via respective network termination points 41, 42 within the respective user premises 31, 32. The DPU 10 additionally includes an Optical Network Termination (ONT) device 14 which provides a backhaul connection from the DPU 10 to a local exchange building via an optical fibre connection such as a Passive Optic-fibre Network (PON) and a controller 12 which co-ordinates communications between the AN 16 and the ONT 14, and which may perform some management functions such as communicating with a remote Persistent Management Agent (PMA).
As will be apparent to a person skilled in the art, the illustrated deployment involving an optical fibre backhaul connection from a distribution point and a twisted metallic pair connection from the distribution point to the “customer” premises is a sort of deployment for which the G.FAST standard is intended to be applicable. In such a situation, the TMP connections may be as short as a few hundred metres or less, for example possibly a few tens of metres only, and because of this it tends to be possible to use very high frequency signals (e.g. up to a few hundred Megahertz) to communicate over the short TMPs because the attenuation of high frequency signals is insufficient to prevent them from carrying useful information because of the shortness of the channels. However, at such high frequencies crosstalk can become a significant issue. This tends to be the case where the cross-talking channels travel alongside each other for part of their extent (as in the situation illustrated in
In some embodiments, by accessing at the DPU 10 (for example, at the AN 16) phantom channels, it is possible to exploit signals transmitted onto phantom channels which will “crosstalk” onto the conventional differential mode channels associated with each of the end user receivers (the termination point and CPE modem combinations 41/51, 42/52, 43/53) and change the signals received (compared to a conventional case where the phantom channels are not exploited in this way). Since there are three TMP connections 21-23, there are 3 possible (first order, pure) phantom channels which could be exploited in this way, formed by using the differential voltage signal between: the average voltage of TMP 21 and that of TMP 22; the average voltage of TMP 21 and that of TMP 23; and the average of TMP 22 and that of TMP 23. However, since there is no possible set of two of these possible (first order, pure) phantom channels which does not include at least one common TMP, only one of these can be used at the same time without having non-orthogonal (and hence complexly interfering) phantom channels being used simultaneously. Thus the present embodiment includes a Phantom Channel—Multiple Optimisation Problem device (PC-MOP) which, as is explained in greater detail below, acts to choose a single one out of the three possible phantom channels to use—the selection being performed such as to try to achieve a particular set of two (or more) objectives (e.g. to try to obtain the maximum benefit for two of the three receivers).
The AN 16 comprises first, second, and third Data Source, Data Encoder and Serial to Parallel converter (DSDESP) modules 1611, 1612 and 1613. These are essentially conventional functions within a DSL modem and will not be further described here except to point out that each one's output is a set of data values d1-dM each of which can be mapped to both a set of one or more bits and to a point within a modulation signal constellation associated with a respective tone on which the data value is to be transmitted. For example, if a tone t1 is determined to be able to carry 3 bits of data, a corresponding data value will be set to one of 23=8 different values (e.g. to a decimal number between 0 and 7) each of which corresponds to a different constellation point within an associated signal constellation having 8 different constellation points. The data values for a single symbol can be thought of as forming a vector of data values (one for each data-carrying tone) and together carry the user data to be transmitted to the end user associated with a respective end user modem 51, 52, 53 together with any overhead data (e.g. Forward Error Correction data etc.).
The data values leaving each DSDESP module 1611, 1612, 1613 are then passed (in an appropriate order) to respective Multiple bit level Quadrature Amplitude Modulation (M-QAM) modulators 1621, 1622, 1623 which convert each input data value to a respective complex number x11 to xM1, x12 to xM2, and x13 to xM3 each of which represents a complex point within a complex number constellation diagram. For example, a data value d11=7 (=111 in binary) might be mapped by the M-QAM modulator 1621 to the complex number 1-i for tone 1 where tone 1 has been determined (by say modem 51) to be able to carry 3 bits of data each.
Each of these complex numbers x11 to xM1, x12 to xM2, and x13 to xM3 is then entered into a vectoring precoder module 1630 (which in the present embodiment is a single common vectoring precoder module 1630) which performs a largely conventional vectoring operation in order to precode the transmissions to be sent using a combination of predetermined vectoring coefficients and information about the signals to be transmitted onto the other channels within the relevant vector group in a manner, which is well known to those skilled in the art, to compensate for the expected effects of cross-talk from the other channels in the vector group.
In some embodiments, the vectoring precoder module 1630 is operable to additionally precode the transmissions in such a way as to cause them to be pre-compensated for the expected crosstalk effects produced not only by the neighbouring channels operating in a direct differential mode (as per standard vectoring), but also for the effects of crosstalk coming from any signals being transmitted onto one or more phantom channels (or other channels which are not direct differential mode channels). In order to do this, the vectoring precoder module 1630 may receive information about channel estimations of the respective phantom channel(s) (or other channels which are not direct differential mode channels) and also information about any weighting values used to combine signals to be transmitted over the phantom channel(s) (or other channels which are not direct differential mode channels).
An ability of the vectoring precoder module 1630 to receive the weighting values and channel estimation values, which it may use to perform its precoding functions, is illustrated in
In this embodiment, the output from the vectoring precoder module 1630 is a set of further modified complex numbers {circumflex over (x)}11 to {circumflex over (x)}M1, {circumflex over (x)}12 to {circumflex over (x)}M2, and {circumflex over (x)}13 to {circumflex over (x)}M3. These complex numbers are then passed to a Mixed-Integer Convex Optimisation Problem and Maximal Ratio Combiner (MICOP and MRC) precoder module 1640 (hereinafter referred to as the MICOP and MRC precoder module 1640) which, in the present embodiment, uses weighting values together with channel estimation values provided to it by the PC-MOP module 1690 to calculate, from the modified complex numbers received from the vectoring pre-coder module 1640 (and the weighting values and channel estimation values from the PC-MOP module 1690), further modified (or further pre-distorted) values for the complex numbers to be passed to the IFFTs 1651-1652. Thus, MICOP and MRC precoder module 1640 modifies the received numbers {circumflex over (x)}11 to {circumflex over (x)}M1, {circumflex over (x)}12 to {circumflex over (x)}M2, and {circumflex over (x)}13 to {circumflex over (x)}M3 to generate corresponding further modified complex numbers {umlaut over (x)}11 to {umlaut over (x)}M1, {umlaut over (x)} to {umlaut over (x)}M2, and {umlaut over (x)}13 to {umlaut over (x)}M3 which form (ultimately) the signals to be used in driving the respective TMPs 21, 22, 23 in direct differential mode. Also, the MICOP and MRC precoder module 1640 may additionally generate a new set of complex numbers {umlaut over (x)}14 to {umlaut over (x)}M4 for forming (ultimately) the signals to be used to drive a (single ended) phantom mode channel to be accessed via the MPAD module described below. Any appropriate way of doing this may be performed. For example, the method of transmitting data in differential and phantom modes that is described in WO 2016/139156 A1, which is incorporated herein in its entirety, may be implemented. Once these values have been calculated by the MICOP and MRC precoder 1640 they are passed to the respective IFFT modules 1651-1654, with super-script 1 values going to IFFT 1651, superscript 2 values going to IFFT 1652, and so on. The next two steps of the processing are conventional and not relevant to the present invention. Thus, each set of generated values (e.g. {umlaut over (x)}11 to {umlaut over (x)}M1) is formed by the respective IFFT module into a quadrature time domain signal in the normal manner in Orthogonal Frequency Division Multiplexing (OFDM)/DMT systems. The time domain signals are then processed by a suitable Analogue Front End (AFE) module 1661 to 1664 again in any suitable such manner including any normal conventional manner. After processing by the AFE module 1650, the resulting analogue signals are passed to a Multiple Phantom Access device (MPAD) module 1670. In overview, the MPAD module 1670 provides switchable access to centre taps of any of the TMPs such that any of the possible phantom channels associated with the connected channels can be driven by the incoming signal arriving from AFE 1664 as well as directly passing on the signals from AFE's 1661-1663 directly to TMPs 21-23 for driving in the normal direct differential mode.
During transmission over the TMP connections 21, 22, 23 the signals will be modified in the normal way according to the channel response of the channel and due to external noise impinging onto the connections. In particular, there will typically be cross-talking (including, for example, far-end cross-talking) between the three direct channels (the direct channels being one from the transmitter 16 to the modems 41-43 via the TMPs 21-23) and the phantom channel. However, the effect of the precoding is to largely precompensate for the effects of the cross talk. Additionally, the targeted receivers may benefit from increased SNR of the received signal destined for them arriving via cross talk from the phantom channel.
After passing over the TMP connections 21, 22, 23 the signals are received by the modems 41-43 at a respective Analogue Front End (AFE) module 5150, 5250, 5350 which performs the usual analogue front end processing. The thus processed signals are then each passed to a respective Fast Fourier Transform (FFT) module 5140, 5240, 5340 which performs the usual conversion of the received signal from the time domain to the frequency domain. The signals leaving the FFT modules 5140, 5240, 5340, y11 to yM1, y12 to yM2, and y13 to yM3, are then each passed, in the present embodiment, to a respective Frequency domain EQualiser (FEQ) module 5130, 5230, 5330. The operation of such frequency domain equaliser modules 5130, 5230, 5330 is well-known in the art and will not therefore be further described herein. It should be noted however, that any type of equalisation could be performed here, such as using a simple time-domain linear equalizer, a decision feedback equaliser, etc. For further information on equalisation in OFDM systems, the reader is referred to: “Zero-Forcing Frequency—Domain Equalization for Generalized DMT Transceivers with Insufficient Guard Interval,” by Tanja Karp, Steffen Trautmann, Norbert J. Fliege, EURASIP Journal on Applied Signal Processing 2004:10, 1446-1459.
Once the received signal has passed through the AFE, FFT and FEQ modules, the resulting signals {umlaut over (x)}11 to {umlaut over (x)}M1, {umlaut over (x)} to {umlaut over (x)}M2, and {umlaut over (x)}13 to {umlaut over (x)}M3 tend to be similar to the complex numbers x11 to xM1, x12 to xM2, and x13 to xM3 originally output by the M-QAM modules 1621-1623, except that there may be some degree of error resulting from imperfect equalisation of the channel and the effect of external noise impinging onto the channels during transmission of the signals between the AN 16 and the modems 51, 52, 53. This error will in general differ from one receiving modem to the next. This can be expressed mathematically as {umlaut over (x)}m1=xm1+em1 etc. Provided the error however is sufficiently small the signal should be recoverable in the normal way after processing by the M-QAM demodulator modules 5120-5320 where a corresponding constellation point is selected for each value {umlaut over (x)}mi depending on its value (e.g. by selecting the constellation point closest to the point represented by the value {umlaut over (x)}mi unless trellis coding is being used, etc.). The resulting values {umlaut over (d)}11 to {umlaut over (d)}M1, {umlaut over (d)}12 to {umlaut over (d)}M2, and {umlaut over (d)}13 to {umlaut over (d)}M3 should mostly correspond to the data values d11 to dM1, d12 to dM2, and d13 to dM3 originally entered to the corresponding M-QAM modules 1621, 1622, 1623 respectively within the AN 16. These values are then entered into a respective decoder (and received data processing) module 5110, 5210 and 5230 which reassembles the detected data and performs any necessary forward error correction etc. and then presents the recovered user data to whichever service it is addressed to in the normal manner, thus completing the successful transmission of this data.
Following now from the above overview of
The MPAD 1670 is a component configured to determine, for each of the TMPs 21, 22, 23, and for each tone on which data is transmitted on the TMPs 21, 22, 23, a bit and power allocation with which to transmit data signals. In particular, the MPAD 1670 is configured to determine bit and power allocation such that the maximum capacities of the channels (i.e. the maximum transmission bit rates) are substantially achieved.
Apparatus, including the MPAD 1670, for implementing the above arrangement, and performing the method steps to be described later below, may be provided by configuring or adapting any suitable apparatus, for example one or more computers or other processing apparatus or processors, and/or providing additional modules. The apparatus may comprise a computer, a network of computers, or one or more processors, for implementing instructions and using data, including instructions and data in the form of a computer program or plurality of computer programs stored in or on a machine readable storage medium such as computer memory, a computer disk, ROM, PROM etc., or any combination of these or other storage media.
What follows is a mathematical explanation of the functioning of certain elements of the above described system. This mathematical explanation is useful in the understanding of the embodiments of methods of determining the transmission powers for transmitting signals on the TMPs 21, 22, 23, which embodiments are described in more detail later below with reference to
Considering a system comprising a bundle of k TMPs and/or phantom channels, the full transmission characteristics for a single frequency of the channel may be represented as:
where hi,j indicates a channel transfer function, a value of which is dependent on crosstalk transmissions from the jth TMP/phantom channel onto the ith TMP/phantom channel. In other words, hi,j is a measure of the electromagnetic coupling of the jth channel to the ith channel. For example, hi,j may be indicative of the extent of coupling between the jth channel and the ith channel. Values of hi,j may be dependent on an attenuation on the amplitude of signals on the ith channel caused by the jth channel. Values of hi,j may be dependent on a delay and/or phase shift on the phase of signals on the ith channel caused by the jth channel.
In this embodiment, the channel transfer matrix H is known i.e. measured. For example, the channel transfer matrix H may be determined using known channel estimation techniques.
Values of hi,j may be measured, for example, using test signals, by the MPAD 1670. Measurement of the hi,j values may comprise, or be regarded as equivalent to, measuring one or more of the following parameters selected from the group of parameters consisting of: a channel response of the ith channel under conditions in which the jth channel (e.g. only the jth channel) is transmitting crosstalk interference onto the ith channel, an impulse response of the ith channel under conditions in which the jth channel (e.g. only the jth channel) is transmitting crosstalk interference onto the ith channel, and a frequency response of the ith channel under conditions in which the jth channel (e.g. only the jth channel) is transmitting crosstalk interference onto the ith channel.
The bundle of k TMPs and/or phantom channels may be contained in a common binder.
In this example, there is little to no interaction between different TMPs/phantom channels, for example as a result of the above described vectoring process. Thus, the non-diagonal element of Hare relatively small compared to the diagonal elements of Hand can therefore be assumed to be zero.
As mentioned above, in operation, the MPAD 1670 determines a bit and power allocation for the TMPs/phantom channels to attempt to achieve maximum channel capacity.
The maximum capacity of a channel (which may also be referred to as Shannon's capacity limit) is expressed as:
where: C is the maximum capacity of the channel (in bits/second) for the given channel; B is the bandwidth of the channel (in Hertz); S is the signal power (in Watts); and N is the noise power (in Watts). The ratio S/N is called the Signal to Noise Ratio (SNR).
Thus, the bit and power allocation problem that is solved by the MPAD 1670 is that of, for each of the j TMPs/phantom channels, maximising the following objective function:
In this embodiment, the above objective function (equation (1)) is optimised with respect to the following constraints:
The above objective function (equation (1)) is a concave objective function that is to be maximised subject to the constraints in equations (2)-(5). Since the objective function (equation (1)) is concave, its optimisation is tractable. The optimisation of the objective function (equation (1)) proceeds with the Lagrangian as follows:
where Ωj,j, ηj,jm, μj,jm,
are Lagrangian multipliers.
To solve (6) and to show its optimality, in this embodiment the Karush Kuhn Tucker (KKT) conditions are satisfied. These conditions are as follows:
1. Feasibility of the primal constraints as well as the multipliers, i.e. Ωj,j, ηj,jm, μj,jm,
2. The gradient of the Lagrangian (equation (6)) with respect to s, and the gradient of the Lagrangian (equation (6)) with respect to ρ both become zero.
Differentiating the Lagrangian (equation (6)) with respect to s, i.e. d/ds=0, and rearranging for s gives the optimal power formula:
Differentiating the Lagrangian (equation (6)) with respect to ρ, i.e. d/dρ=0, and rearranging for μ gives:
What will now be described with reference to
In this embodiment, bmin=0. Thus, also
However, in some embodiments, bmin may have a different, non-zero value. Also, in some embodiments,
may have a different, non-zero value.
The process shown in
At step s2, for each tone m,
and ηj,jm are initialised to zero, and ρj,jm is initialised to one. That is to say:
At step s4, for the jth channel, a value of Ωj,j is computed. In this embodiment, Ωj,j is computed by using equations (7) and (2), with the parameters initialised as in step s2. In particular, equation (7) is plugged into equation (2) to give:
In this embodiment, the value of Ωj,j is computed using a measured value of hj,j.
At step s6, for each tone m, a value for ηm is computed. In this embodiment, ηm is computed by using equation (7) and the value for Ω computed at step s4. In particular, equation (7) is set equal to pm (i.e. the transmission power mask for tone m), and the rearranged for ηm to give:
At step s8, for each tone m, a value for
is computed. In this embodiment,
is computed using equation (7) and the equation log2(1+si,jmγi,jm)=bmax. In particular, equation (7) is plugged into log2(1+si,jmγi,jm)=bmax and rearranged for
to give:
At step s10, for each tone m, a value for sj,jm is computed. In this embodiment, sj,jm is computed by using equation (4) and the values for Ωj,j, ηj,jm and
computed at steps s4, s6, and s8 respectively.
At step s12, for each tone m, it is determined whether or not the calculated value of sj,jm for that tone m satisfies a first criterion. In this embodiment, the first criterion is:
log2(1+sj,jmγj,jm)>0 (12)
At step s14, for each tone m for which sj,jm satisfies the first criterion (i.e. that satisfies log2 (1+sj,jmγj,jm)>0 in this embodiment), the values for sj,jm and ρj,jm of that tone are maintained.
At step s15, for each tone m for which sj,jm fails to satisfy the first criterion (i.e. for which, in this embodiment, log2(1+sj,jm γj,jm)≤0 (and in practice=0)), the values for sj,jm and ρj,jm of that tone are zeroed. That is to say, step s15 comprises setting sj,jm=ρj,jm=0 for each tone m for which log2(1+sj,jmγj,jm)≤0.
At step s16, for each tone m for which sj,jm satisfies the first criterion (i.e. that satisfies log2(1+sj,jmγj,jm)>0 in this embodiment), it is determined whether or the calculated value of sj,jm for that tone m satisfies a second criterion. In this embodiment, the second criterion is:
log2(1+sj,jmγj,jm)≤bmax (13)
If, at step s16, it is determined that all of the sj,jm values which satisfy the first criterion (equation (12)) also satisfy the second criterion (equation (13)), then the method proceeds to step s22. Step s22 will be described in more detail later below, after a description of method steps s18 to s20.
However, if, at step s16, it is determined that not all of the sj,jm values which satisfy the first criterion (equation (12)) also satisfy the second criterion (equation (13)), then the method proceeds to step s18.
At step s18, it is determined whether or not the current values of sj,jm satisfy a third criterion. In this embodiment, the third criterion is:
If, at step s18, it is determined that the third criterion (equation (14)) is satisfied, then the method proceeds to step s22. Step s22 will be described in more detail later below, after a description of method steps s20.
In some embodiments, equation (14) is deemed to be satisfied if
is within a predetermined tolerance range of PT, for example within 10−3 or 10−4 of PT.
If, at step s18, it is determined that the third criterion (equation (14)) is not satisfied (i.e. it is determined instead that
then the method proceeds to step s20.
At step s20, for each tone m, the value of Ω is increased. In some embodiments, for one or more of the tones m, Ω is increased by f(Ω). By way of example, f(Ω) may be equal to about Ω/20, Ω/10, or Ω/5. In some embodiments, Ω is increased by a predetermined value. In some embodiments, for each tone m, the value of Ω is decreased instead of being increased.
After step s20, the method proceeds back to step s6, at which point the values for ηj,jm are updated, in turn leading to revised/updated values for sj,jm and ρj,jm. Thus, the process of
Returning now the case where either 1) it is determined at step s16 that every tone m which did satisfy the first criterion (equation (12)) also satisfies the second criterion (equation (13)); or 2) it is determined at step s18 that the third criterion (equation (14)) is satisfied, the method proceeds to step s22.
At step s22, the iterative process of steps s6 to s20 is stopped. Also, each tone m (m=1, . . . , M) for the jth TMP/phantom channel is allocated its respective current power value sj,jm. It is worth noting that some tones may be not allocated any power, i.e. due to sj,jm and ρj,jm for those tones having been set to zero.
At step s24, the AN 16 transmits signals in accordance with power values allocated at step s22. For example, for each tone m, the AN 16 may transmit a signal having transmission power sj,jm at tone m along the jth TMP/phantom channel.
As noted earlier above, the process shown in
Thus, an embodiment of the bit and power allocation process is provided.
Advantageously, the method shown in
A further advantage provided by the method shown in
What will now be described, with reference to
The process shown in
In this embodiment, bmin=0. Thus, also
However, in some embodiments, bmin may have a different, non-zero value. Also, in some embodiments,
may have a different, non-zero value. For instance, if b<bmin then
forcing the power allocation to become zero.
The process shown in
At step s30, the tone index m is initialised to 1, i.e. m=1.
At step s32, for tone m,
and ηj,jm are initialised to zero, and ρj,jm is initialised to one. That is to say:
At step s34, for tone m, a value of a first function,
is computed. In this embodiment, the first function is:
In this embodiment,
is computed by using equation (7), with the parameters initialised as in step s32, and with sj,jm set to pm. In particular, equation (7), with the parameters initialised as in step s32 and with sj,jm set equal to Pm is rearranged for Ω to give:
At step s36, for tone m, a value of a second function,
is computed. In this embodiment, the second function is:
The computed value of
may be considered to be a second estimate of the parameter Ω. In this embodiment,
is computed by using equations (7) and (13), with the parameters initialised as in step s32. In particular, equation (7) with the parameters initialised as in step s32, is plugged into equation (13) and rearranged for Ω to give:
At step s38, for tone m, a value of a third function,
is computed. In this embodiment, the third function is:
However, in other embodiments the third function is a different function, e.g. a different function of the first and second functions,
For example, the third function
may be
At step s40, for tone m, a value for sj,jm is computed. In this embodiment, sj,jm is computed as follows:
At step s42, it is determined whether or not a value of sj,jm has been computed for each tone m=1, . . . , M.
If, at step s42, it is determined that a value of sj,jm has not been computed for each tone m=1, . . . , M, the method proceeds to step s44.
However, if, at step s42, it is determined that a value of sj,jm has been computed for each tone m=1, . . . , M, the method proceeds to step s46.
At step s44, the tone index m is incremented by 1, i.e. m=m+1.
After step s44, the methods proceeds back to step s32, thereby to determine a value of sj,jm for the updated tone value.
Returning now to the case where, at step s42, it is determined that a value of sj,jm has been computed for each tone m=1, . . . , M, at step s46 it is determined whether or not the determined values for sj,jm, m=1, . . . , M satisfy the third criterion (i.e. equation 14), which is described in more detail earlier above with reference to step s18 of
In this embodiment, at step s46, if it is determined that the third criterion (equation (14)) is satisfied, then the method proceeds to step s52. Step s52 will be described in more detail later below, after a description of method steps s48 and s50.
However, if, at step s46, it is determined that the third criterion (equation (14)) is not satisfied (i.e. it is determined instead that
then the method proceeds to step s48.
At step s48, the value of m that gives
is determined. This determined value of m is denoted {circumflex over (m)}.
In other words, the tone {circumflex over (m)} that corresponds to the minimum signal-to-noise ratio (SNR) is determined.
At step s50, the power allocation factor corresponding to the determined tone {circumflex over (m)} is set equal to zero and/or the power allocated to the determined tone m is set equal to zero. In other words, ρj,j{circumflex over (m)}=0 and/or sj,j{circumflex over (m)}=0.
After step s50, the method returns to step s46 whereat the third criterion (equation 14) is retested.
Returning now to the case where, at step s46, it is determined that the third criterion (equation (14)) is satisfied, then at step s52, each tone m (m=1, . . . , M) for the jth TMP/phantom channel is allocated its respective current power value sj,jm.
At step s54, the AN 16 transmits signals in accordance with power values allocated at step s52. For example, for each tone m, the AN 16 may transmit a signal having transmission power sj,jm at tone m along the jth TMP/phantom channel.
As noted earlier above, the process shown in
Thus, an embodiment of a further bit and power allocation process is provided.
Advantageously, the method shown in
Furthermore, the method shown in
In the method shown in
What will now be described, with reference to
The process shown in
The process shown in
At step s60, the tone index m is initialised to 1, i.e. m=1.
At step s62, for tone m, a value of a power function, {tilde over (s)}j,jm, is computed. In this embodiment, the power function, {tilde over (s)}j,jm, is determined based on equation (13). In particular, sj,jm in equation (13) is set to be equal to {tilde over (s)}j,jm and then rearranged for {tilde over (s)}j,jm to give:
At step s64, for each tone m, a value for sj,jm is computed. In this embodiment, sj,jm is computed as follows:
s
j,j
m=min{pm,{tilde over (s)}j,jm} (20)
At step s66, it is determined whether or not a value of sj,jm has been computed for each tone m=1, . . . , M.
If, at step s66, it is determined that a value of sj,jm has not been computed for each tone m=1, . . . , M, the method proceeds to step s68.
However, if, at step s66, it is determined that a value of sj,jm has been computed for each tone m=1, . . . , M, the method proceeds to step s70.
At step s68, the tone index m is incremented by 1, i.e. m=m+1.
After step s68, the methods proceeds back to step s62, thereby to determine a value of sj,jm for the updated tone value.
Returning now to the case where, at step s66, it is determined that a value of sj,jm has been computed for each tone m=1, . . . , M, at step s70 it is determined whether or not the determined values for sj,jm, m=1, . . . , M satisfy the third criterion (i.e. equation 14), which is described in more detail earlier above with reference to step s18 of
In this embodiment, at step s70, if it is determined that the third criterion (equation (14)) is satisfied, then the method proceeds to step s76. Step s76 will be described in more detail later below, after a description of method steps s72 and s74.
However, if, at step s70, it is determined that the third criterion (equation (14)) is not satisfied (i.e. it is determined instead that
then the method proceeds to step s72.
At step s72, the value of m that gives
is determined. This determined value of m is denoted {circumflex over (m)}.
In other words, the tone {circumflex over (m)} that corresponds to the minimum signal-to-noise ratio (SNR) is determined.
At step s74, the power allocation factor corresponding to the determined tone {circumflex over (m)} is set equal to zero and/or the power allocated to the determined tone {circumflex over (m)} is set equal to zero. In other words, ρj,j{circumflex over (m)}=0 and/or sj,j{circumflex over (m)}=0.
After step s74, the method returns to step s70 whereat the third criterion (equation 14) is retested.
Returning now to the case where, at step s70, it is determined that the third criterion (equation (14)) is satisfied, then at step s76, each tone m (m−1, . . . , M) for the jth TMP/phantom channel is allocated its respective current power value sj,jm.
At step s78, the AN 16 transmits signals in accordance with power values allocated at step s76. For example, for each tone m, the AN 16 may transmit a signal having transmission power sj,jm at tone m along the jth TMP/phantom channel.
As noted earlier above, the process shown in
Thus, a further embodiment of a bit and power allocation process is provided.
Advantageously, the method shown in
Furthermore, the method shown in
In the method shown in
The above described methods and apparatus advantageously tend to provide fast converging “water filling” algorithms for performing equalisation on communication channels. Advantageously, the solutions provided by the above described algorithms tend to shape the transmitted signals according to the channel response to improve data transmission, e.g. to maximise the delivered data. Also, the above described methods and apparatus tend to take into account the maximum available power and the hardware limitations in transceiver design.
The above described methods and apparatus advantageously tend to provide improved use of power budget, and also match the power budget to channel behaviour.
Advantageously, it tends to be possible to tune the gap between the more optimal solution (provided by the process described above with reference to
Advantageously, it tends to be possible to implement the above described methods and apparatus for G.fast and XG.fast at all frequencies.
Advantageously, any complex functionality for implementing certain preferred embodiments of the invention can reside solely in the access network (e.g. at an AN or DSLAM, etc.) rather than requiring any special Customer Premises Equipment (CPE), in certain preferred embodiments of the invention.
It should be noted that certain of the process steps depicted in the flowcharts of
It should be noted that the described embodiments are couched in terms of the downstream direction of data only (i.e. from an Access Node/DSLAM to Customer Premises Equipment (CPE) devices). However, in a practical implementation the “transmitter” of the above embodiments (e.g. the Access Node) also, naturally, functions as a receiver for upstream transmissions from the various CPE devices (which are also therefore in practice operating as transceivers rather than just receivers). Embodiments of the invention may operate in an entirely conventional manner in the upstream direction.
In the above embodiments, the DPU is connected to three user premises via respective TMP connections which connect between the AN within the DPU and respective CPE modems within the respective user premises. However, in other embodiments, the DPU is connected to a different number of user premises (e.g. more than three) via respective one or more TMP connections. In some embodiments, the DPU is connected to a different number of CPE modems via respective one or more TMP connections. In some embodiments, one or more user premises comprises multiple CPE modems.
In the above embodiments, the first criterion is:
log2(1+sj,jmγj,jm)>0
However, in other embodiments, the first criterion is a different criterion, or is an equivalent criterion expressed in a different way. By way of example, an alternative first criterion is:
log2(1+sj,jmγj,jm)>ε1
where ε1 may be non zero. For example ε1 may be a positive value, e.g. a small value such as less than or equal to 10−2, less than or equal to 10−3, or less than or equal to 10−4. In some embodiments, ε1 is a constant value. In some embodiments, ε1 is a variable that may be dependent on one or more parameters of the broadband deployment.
In the above embodiments, the second criterion is:
log(1+sj,jmγj,jm)≤bmax
However, in other embodiments, the second criterion is a different criterion, or is an equivalent criterion expressed in a different way. By way of example, an alternative second criterion is:
log(1+sj,jmγj,jm)≤bmax−ε2
where ε2 may be non zero. For example ε2 may be a positive value, e.g. a small value such as less than or equal to 10−2, less than or equal to 10−3, or less than or equal to 10−4. In some embodiments, ε2 is a constant value. In some embodiments, ε2 is a variable that may be dependent on one or more parameters of the broadband deployment.
In the above embodiments, the third criterion is:
However, in other embodiments, the third criterion is a different criterion, or is an equivalent criterion expressed in a different way. By way of example, an alternative third criterion is:
where ε3 may be non zero. For example ε3 may be a positive value, e.g. a small value such as less than or equal to 10−2, less than or equal to 10−3, or less than or equal to 10−4. In some embodiments, ε3 is a constant value. In some embodiments, ε3 is a variable that may be dependent on one or more parameters of the broadband deployment.
Number | Date | Country | Kind |
---|---|---|---|
17164435.4 | Mar 2017 | EP | regional |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/EP2018/057976 | 3/28/2018 | WO | 00 |