The present invention relates to communications in computer networks. More specifically, it relates to a method for dynamically optimizing performance in a data-over-cable system.
Cable television networks such as those provided by Comcast Cable Communications, Inc., of Philadelphia, Pa., Cox Communications of Atlanta Ga., Tele-Communications, Inc., of Englewood Colo., Time-Warner Cable, of Marietta Ga., Continental Cablevision, Inc., of Boston Mass., and others provide cable television service to a large number of subscribers over a large geographical area. The cable television networks typically are interconnected by cables such as coaxial cables or a Hybrid Fiber/Coaxial (“HFC”) cable system. The system can also provide data services having data rates of about 10 Mega-bits-per-second (“Mbps”) to 30+ Mbps per channel.
The Internet, a world-wide-network of interconnected computers, provides multi-media content including audio, video, graphics and text that requires a large bandwidth for downloading and viewing. Most Internet Service Providers (“ISPs”) allow customers to connect to the Internet via a serial telephone line from a public switched telephone network at data rates including 14,400 bps, 28,800 bps, 33,600 bps, 56,000 bps and others that are much slower than the about 10 Mbps to 30+ Mbps available on a coaxial cable or HFC cable system on a cable television network.
With the explosive growth of the Internet, many customers have desired to use the larger bandwidth of a cable television network to connect to the Internet and other computer networks. Cable modems, such as those provided by 3Com Corporation of Santa Clara, Calif., and others offer customers higher-speed connectivity to the Internet, an intranet, local area networks (“LANs”) and other computer networks via cable television networks. These cable modems currently support a data connection to the Internet and other computer networks via a cable television network with a data rate of up to 30+ Mbps which is a much larger data rate than can be supported by a modem used over a serial telephone line.
Background information related to cable modem systems in general is described in the Data-Over-Cable Service Interface Specifications (“DOCSIS”)—Radio Frequency Interface Specifications, Interim Draft, dated Jul. 24, 1998, issued by Cable Television Laboratories, Inc. DOCSIS may be found on the World Wide Web at the Universal Resource Locator (“URL”) “www.cablemodem.com”. This document, known to persons working in the art, is incorporated by reference herein in its entirety.
The basic overall architecture of a data-over-cable system is shown in
The head-end 18 includes a cable modem termination system (“CMTS”) 30. This device provides a network side interface to a wide area network, indicated at 32, and a radio frequency (“RF”) interface between the cable modem termination system and the cable network in both the downstream and upstream directions, indicated at 34 and 36. The term “downstream”, as used in the present document, refers to transmission in the direction from the head-end 18 or cable modem termination system 30 to the cable modem 28 at the customer premises. The term “upstream” refers to transmission in the direction from the cable modem 28 at the customer premises to the cable modem termination system 30.
For transmission in the downstream direction, the cable modem termination system 30 supplies data from the computer 10 to a modulation circuit (“MOD”) and to a combiner 38, where the data is combined with video signals for the cable television system. The combined signals are sent to a transmission module 40 where they are imparted onto the fiber network. In the receiving direction, data from the CPE 14 is received from the fiber network at a receive module 42, sent to a splitter and filter bank 44 and sent to a demodulation circuit (“DEMOD”) in the cable modem termination system 30. The data is processed by a network termination unit 46, sent to the switch or router 20 and routed onto the WAN for transmission to the remote computer 10.
Many cable television networks provide only unidirectional cable systems, supporting only a “downstream” cable data path. A return data path via a telephone network (i.e., a “telephony return”), such as a public switched telephone network provided by AT&T, GTE, Sprint, MCI and others, is typically used for an “upstream” data path. A cable television system with an upstream connection to a telephony network is called a “data-over-cable system with telephony return.” Such a return system is indicated at 48 where the cable modem 28 is also shown connected to the public switched telephone network (“PSTN”).
An exemplary data-over-cable system with telephony return includes customer premises equipment (e.g., a customer computer), a cable modem, a cable modem termination system, a cable television network, a public switched telephone network, a telephony remote access concentrator (“TRAC”) 49 and a backbone data network 12 (e.g., the Internet). The cable modem termination system 30 and the telephony remote access concentrator 49 together are called a “telephony return termination system.”
In a two-way cable system without telephony return, also termed a bi-directional cable system, the customer premises equipment 14 sends data packets to the cable modem 28, which sends the data packets upstream via the cable television network 22 and 26 to the cable modem termination system 30. Such a system is shown in
In a bi-directional cable system, the cable modem termination system 30 can continuously collect information about the level of impairments on the upstream RF path of a cable plant, i.e., the portion of the network between the demodulation circuit in the cable modem termination system 30 and the cable modems 28. Further, a single O/E node 24 may serve multiple channels and cable modems. Measurements such as the noise floor level, and signal-to-noise ratio per cable modem transmission, can be made for the coax and fiber networks, along with the tracking of which cable modems are active during a given measurement interval.
The data-carrying performance of the upstream channels may vary with the conditions for radio frequency propagation on the cable network. Defective radio frequency interfaces may introduce sufficient noise into an upstream channel that the noise significantly impairs the ability of the channel to transport data packets from the cable modems to the cable modem termination system without error. Extraneous sources of radio frequency, such as citizen band or amateur radio broadcasts, may also infiltrate the upstream channels, interfere with the radio frequency carriers for the upstream channels, increase the packet error rate, reduce the data throughput, and generally impair the performance of the data-over-cable network.
Previous methods for improving performance have included switching the frequency of a degraded upstream channel to another part of the upstream radio frequency spectrum on the cable. The cable modems on the degraded upstream channel are all instructed to hop to a clean frequency. However, the methods are ineffective when the degradation is present over the full spectrum of upstream frequencies, as there are no cleaner frequencies than the current operating frequency.
Previous methods also typically retain the same data transmission configurations for the cable modems when there are other configurations of the cable modems that may optimize throughput for the current network conditions. In many instances, static configurations for the cable modems may actually limit throughput relative to what could be achieved. In previous methods, the configurations of the cable modems are determined at the time the cable modems initialize or the configurations are preset at the factory. The configuration parameters include the type of radio frequency modulation, the type and extent of error correction, and the symbol rate. In particular, static configurations cannot compensate for an intermittent degradation or a reconfiguration of the network and network paths. As the degradation impinges on the network, the current configurations of the cable modems may be different from those that give the optimal throughput of data. Dynamic configuration of the cable modems may allow the network to attain its optimal performance.
It is therefore desirable to improve the configuration of the cable modems so that upstream performance is optimized for the present network conditions. Optimizing data throughput may improve the performance of the data-over-cable network.
In accordance with an exemplary preferred embodiment of the present invention, some of the problems associated with optimizing performance are overcome. A method and system for optimizing performance in a data-over-cable system is provided. One aspect of the invention includes a method for optimizing data throughput on an upstream channel at a target packet error ratio. The method includes ascertaining a signal-to-noise ratio on the upstream channel. Parameters for data transmissions by the cable modems on the upstream channel are determined. The determined parameters are associated with the signal-to-noise ratio and the target packet error ratio. The use of the determined parameters in the upstream channel is negotiated.
For example, the method and system of the present invention may provide for optimizing data throughput on an upstream channel at a target packet error ratio. A cable modem termination system may schedule a plurality of quiescent periods on the upstream channel. A quiescent period is when no data is transmitted by the cable modems on the upstream channel. A noise floor value is measured on the upstream channel during at least one of the quiescent periods and converted to a signal-to-noise ratio. Parameters for data transmission on the upstream channel are read from a table. The parameters in the table are associated with the signal-to-noise ratio and the target packet error ratio. An Upstream Channel Descriptor message, based on the parameters, is built and sent to the cable modems. However, the present invention is not limited to cable modems, cable modem termination systems, Upstream Channel Descriptor messages, or tables, and other network devices and parameters could be used.
The foregoing and other features and advantages of preferred embodiments of the present invention will be more readily apparent from the following detailed description, which proceeds with references to the accompanying drawings.
Preferred embodiments of the present invention are described with reference to the following drawings, wherein:
In a bi-directional data-over-cable system, a cable modem (“CM”) 28 will transmit data packets to the cable modem termination system (“CMTS) 30 over one or more upstream channels on the cable television network 22 and 26. A data packet may carry, as its payload, information that is sent from the customer premise equipment (“CPE”) 14 and destined for the CMTS 30. The CM 28 adds overhead to the data packet to maintain the integrity of the payload. Examples of overhead include redundant bits for error correction and preambles. The data packet and overhead are transmitted from and received by the CM 28 in the form of digitally modulated radio frequency carriers on the analog cable network.
Cable Modem Protocol Stack
For data transmission over a bi-directional data-over-cable system, the CM 28 is connected to the cable network 26 in a physical layer via a Radio Frequency (“RF”) Interface 52. In an exemplary preferred embodiment of the present invention, the RF Interface 52 has an operation frequency range of 50 Mega-Hertz (“MHz”) to 1 Giga-Hertz (“GHz”) and a channel bandwidth of 6 MHz on the downstream channels. In another exemplary preferred embodiment of the present invention, the RF Interface 52 has an operation frequency range of 5 MHz to 42 MHz on the upstream channels. However, other operation frequencies and bandwidths may also be used and the invention is not limited to these frequencies and bandwidths. The RF interface 52 uses a signal modulation method of Quadrature Amplitude Modulation (“QAM”). As is known in the art, QAM is used as a means of encoding digital information over radio, wire, or fiber optic transmission links. QAM is a combination of amplitude and phase modulation and is an extension of multiphase phase-shift-keying. QAM can have any number of discrete digital levels typically including 4, 16, 64 or 256 levels. In one embodiment of the present invention, QAM-64 is used in the RF interface 52 for downstream transmission. In another embodiment of the present invention, QAM-16 or Quadrature Phase-Shift-Keying (“QPSK”) is used for upstream transmission. In this embodiment, the symbol rate of upstream transmission may be 160, 320, 640, 1,280, or 2,560 kilo-symbols per second (“ksym/sec”) for 16-QAM, or 160, 320, 640, 1,280, or 2,560 ksym/sec for QPSK. However, other operating frequencies, modulation methods, and symbol rates could also be used. More information may be found in DOCSIS. Other information on the RF interface 52 can be found in the Institute of Electrical and Electronic Engineers (“IEEE”) standard 802.14 for cable modems incorporated herein by reference. IEEE standards can be found on the World Wide Web at the Universal Resource Locator (“URL”) “www.ieee.org.” However, other RF interfaces 52 could also be used and the present invention is not limited to IEEE 802.14.
Above the RF interface 52 in a data-link layer is a Medium Access Control (“MAC”) layer 54. As is known in the art, the MAC layer 54 controls access to a transmission medium via the physical layer. Information on the MAC layer protocol 54 may be found in DOCSIS. Other information can be found in the IEEE 802.14 for cable modems. However, other MAC layer protocols 54 could also be used and the present invention is not limited to IEEE 802.14 MAC layer protocols.
Above both the downstream and upstream protocol layers in a network layer 52 is an Internet Protocol (“IP”) layer 58. The IP layer 58, hereinafter IP 58, roughly corresponds to OSI layer 3, the network layer, but is typically not defined as part of the OSI model. As is known in the art, the IP 58 is a routing protocol designed to route traffic within a network or between networks. For more information on the IP 58 see RFC-791 incorporated herein by reference.
The Internet Control Message Protocol (“ICMP”) layer 56 is used for network management. The main functions of the ICMP layer 56, hereinafter ICMP 56, include error reporting, reachability testing (e.g., “pinging”) congestion control, route-change notification, performance, subnet addressing and others. Since the IP 58 is an unacknowledged protocol, datagrams may be discarded and the ICMP 56 is used for error reporting. For more information on the ICMP 56 see RFC-792 incorporated herein by reference.
Above the IP 58 and the ICMP 56 is a transport layer with a User Datagram Protocol layer 60 (“UDP”). The UDP layer 60, hereinafter UDP 60, roughly corresponds to OSI layer 4, the transport layer, but is typically not defined as part of the OSI model. As is known in the art, the UDP 60 provides a connectionless mode of communications with datagrams. For more information on the UDP 60 see RFC-768 incorporated herein by reference.
Above the network layer are a Simple Network Management Protocol (“SNMP”) layer 62, a Trivial File Protocol (“TFTP”) layer 64, a Dynamic Host Configuration Protocol (“DHCP”) layer 66 and a UDP manager 68. The SNMP layer 62 is used to support network management functions. For more information on the SNMP layer 62 see RFC-1157 incorporated herein by reference. The TFTP layer 64 is a file transfer protocol used to download files and configuration information. For more information on the TFTP layer 64 see RFC-1350 incorporated herein by reference. The DHCP layer 66 is a protocol for passing configuration information to hosts on an IP 54 network. For more information on the DHCP layer 66 see RFC-1541 incorporated herein by reference. The UDP manager 68 distinguishes and routes packets to an appropriate service (e.g., a virtual tunnel). More or few protocol layers could also be used with a data-over-cable system 16.
An operating environment for the CM 28 and other network devices of the present invention includes a processing system with at least one high speed Central Processing Unit (“CPU”) and a memory system. In accordance with the practices of persons skilled in the art of computer programming, the present invention is described below with reference to acts and symbolic representations of operations that are performed by the processing system, unless indicated otherwise. Such acts and operations are sometimes referred to as being “computer-executed”, or “CPU executed.”
It will be appreciated that the acts and symbolically represented operations include the manipulation of electrical signals by the CPU. The electrical signals represent data bits which cause a resulting transformation or reduction of the electrical signal representation, and the maintenance of data bits at memory locations in the memory system to thereby reconfigure or otherwise alter the CPU's operation, as well as other processing of signals. The memory locations where data bits are maintained are physical locations that have particular electrical, magnetic, optical, or organic properties corresponding to the data bits.
The data bits may also be maintained on a computer readable medium including magnetic disks, optical disks, organic disks, and any other volatile or non-volatile mass storage system readable by the CPU. The computer readable medium includes cooperating or interconnected computer readable media, which exist exclusively on the processing system or is distributed among multiple interconnected processing systems that may be local or remote to the processing system.
Upstream Data Transmission
The upstream channel may be viewed as time-divided into a stream of mini-slots. A mini-slot is used as a unit of granularity for upstream transmission opportunities. A CM 28 is permitted to transmit on an upstream channel during a transmission mini-slot allocated by the CMTS 30. When a CM 28 wishes to transmit data it must first request permission from the CMTS 30. The CMTS 30 receives requests from a selection of cable modems that wish to transmit and may allocate one or more transmission mini-slots to each of the cable modems. The cable modems alternately transmit during the mini-slots. Mini-slots are timed to prevent collisions between the transmissions from different cable modems.
A CM 28 that wishes to transmit sends a Request MAC 54 message to the CMTS 30.
The SID 76 is a unique identifier for the CM 28 that is requesting permission to transmit. The SID 76 may be assigned by the CMTS 30 when the CM 28 initializes and registers with the CMTS 30. The REQ 74 field contains a measure of how much bandwidth, i.e. mini-slots, the CM 28 requests for the transmission of its data to the CMTS 30.
In response, the CMTS 30 builds an Upstream Bandwidth Allocation Map message (“MAP”) and transmits it via the downstream channel to all cable modems.
The MAP message 80 informs the cable modems of the allocation of mini-slots for a scheduled upstream usage interval and when to begin the usage interval. In a given upstream usage interval, selections of the CMs 28 alternately transmit on the upstream channel. As is known in the art, each upstream usage interval is composed of transmission intervals, also referred to as “bursts”, which comprise at least one mini-slot.
An identifier for the upstream channel to which the MAP message 80 applies is placed in the Upstream Channel ID field 84. The MAP Information Elements field 100 designates the order and duration of the transmissions from the CMs. Each transmission may be described by one element. The number of elements in the MAP Information Elements field 100 is placed in the Number of Elements field 88.
The IUCs 102 are values that designate the type of transmission that is permitted in each interval. The CMs may be capable of several types of transmission. For example, the transmission may be for the purposes of ranging, allowing the CM 28 to compensate for delay on the cable network. Additionally, the transmission may be for the purpose of delivering a data packet to the CMTS 30. Two types of data transmissions are typically permitted: a short data grant or a long data grant. These data grants have corresponding IUCs 102 as described in DOCSIS. For example, a short data grant may be appropriate when the CPE 14 only has a small amount of data to transmit on the upstream channel, such as a few keystrokes or the opening of a hyperlink on a web page. A long data grant may be appropriate when the CPE 14 requests to transfer a file through the backbone network 12. However, other field settings for the Request message 70, the MAP message 80, and the MAP Information Elements 100 are possible and it should be understood that other field structures and values could be used for the present invention.
Parameters for Data Transmission
Additionally, data packets that are transmitted in adjacent mini-slots may be transmitted according to different transmission formats for the RF interface 52. The formats are associated with parameters for data transmission. In one exemplary preferred embodiment of the present invention, the parameters for upstream data transmission include the symbol rate, the upstream channel frequency, the modulation type, the preamble, and Forward Error Correction (“FEC”) parameters as described in Table 3.
As is known in the art, FEC adds redundant bits to the data packet to detect, locate, and correct transmission errors. The FEC level (“T”) is a measure of the amount of redundant data that must be added to the data packet to allow for error correction. A higher value of T provides a better level of error correction. The FEC data coverage size (“k”) is a measure of the amount of information over which data correction is to be performed. For the same FEC level, an increase in the FEC data coverage size will result in more errors going uncorrected. It should be understood that many more data transmission parameters are possible and that the present invention is not restricted to the parameters described herein.
Each CM 28 transmitting in an upstream usage interval may transmit according to a different transmission format. Additionally, between upstream usage intervals, the CMs may each undergo reconfiguration so that their future transmissions occur according to another format. The CMTS 30 may reconfigure the CMs by issuing an Upstream Channel Descriptor (“UCD”) message.
TLV encoding is known to those skilled in the art. A selection of parameters for the overall channel and the bursts are given in Table 3. These parameters may be encoded as channel or burst descriptors and incorporated into a UCD message 110 to reconfigure cable modems. However, it should be understood that other field structures and values for the UCD message 1110 could be used for the present invention.
When the CMTS 30 changes the data transmission parameters for an upstream channel, it builds a UCD message 110 with channel and/or burst descriptors that correspond to the new parameters. The UCD message 1110 is sent on the downstream channel 26 to the CMs 28. The CMTS 30 also sends out a corresponding MAP message 80. The burst descriptors in the UCD message 1110 correspond to the IUC fields 102 of the MAP Information Elements 100 of the MAP message 80. As each CM 28 transmits on the upstream it may be doing so according to data transmission parameters that are different from other CMs. In this manner, the CMs within an upstream usage interval may alternately transmit data packets to the CMTS 30 according to independent data transmission parameters.
Errors in Data Packets
Data packets, however, may become corrupted during transmission on the upstream channels. The source of the corruption may be noise on the upstream channel or a flaw in the optical or electrical components in the cable television network. When an error in a data packet is detected, the data packet may be discarded or it may be resent by the CM 28. A measure of the throughput of the upstream channel is the “payload data rate”. Payload data rate is a rate at which actual data is sent over an upstream channel. The payload data rate of the cable network will decrease if data packets are corrupted. Even if data packets are resent, the retransmission corresponds to less payload successfully getting through the upstream channel in any give time and the payload data rate correspondingly decreases. The payload data rate depends on the size of the data packet size, or payload size, as shorter payloads may have a better chance of getting through the upstream channel without corruption. Put another way, if a large payload is corrupted then the whole data packet must be discarded or resent whereas splitting the payload into shorter data packets may increase the chance that some portion of the payload gets through the upstream channel. Additionally, the payload data rate is dependent on the FEC parameters T and k, the symbol rate, the size of the preamble, and the modulation type.
Packet-error-ratio (“PER”) is a measure of is the ratio of errored data packets to the total number of data packets transmitted. PER is a more uniform measure of system performance as it may ensure consistent performance no matter what the size of the data packet. Additionally, the PER is independent of whether corrupted data packets are discarded or resent. Some forms of data transmission, such as streaming video or audio, or Internet telephony, may continue to retain integrity if data packets are discarded. Other forms of data transmission, such as data file transfer, may retain integrity if data packets are resent.
Data transmission on an upstream channel may remain consistent if the data-over-cable system maintains a target PER. In one exemplary preferred embodiment, the target PER is a default value. For example, the default value may be selected by the vendor of the data-over-cable system. In another exemplary preferred embodiment of the present invention the target PER is selected by a user. For example, the user may be a technician at the cable plant or a cable system operator. The user may be able to observe the characteristics of data transmission on their configuration of a data-over-cable system and select an appropriate target PER. Alternately, the user may select an appropriate PER based on the type and extent of the services that they provide.
Optimizing Data Throughput at a Target PER
Payload data rate or throughput is affected by PER if it is desired that a target PER be maintained. Lowering the target PER may lower the maximum payload data rate that can be achieved. For example, given a signal-to-noise ratio on the upstream channel, a lower PER may require a lower symbol rate or may require more overhead to correct for errors. However, at a desired target PER there may be a selection of values for the parameters for data transmission that results in an optimal data throughput.
In one exemplary preferred embodiment the parameters for data transmission are selected from a group consisting of symbol rate, modulation type, or error correction levels. Having ascertained the signal-to-noise (“SNR”) on the upstream channel, certain parameters for data transmission may be associated with optimal data throughput given the target PER and the ascertained SNR. Examples of the parameters are provided in Table 3. In another exemplary preferred embodiment the modulation type may be a QAM type such as QPSK or 16-QAM, the error correction level may be a FEC level (T) or a FEC data coverage size (k), and the symbol rate may be a multiple of 160 ksym/sec. Another selection of the parameters may result in a less-than-optimal data throughput for data transmission given the noise condition and desired performance on the upstream channel.
In another exemplary preferred embodiment, the data throughput is optimized for a preconfigured payload size. In this embodiment, the parameters may be determined on the basis of a smallest, largest, or average payload size for data transmission. The payload size that forms the basis may be preconfigured by the user. However, there may be less-than-optimal data throughput for data packets whose payload size is other than the preconfigured payload size.
In yet another exemplary preferred embodiment, the parameters are associated with a payload size for data packets. Larger payloads may require different parameters than smaller payloads in order to have optimal data throughput. For a given target PER, substantially the same number of data packets are corrupted. Discarding data packets with larger payload results in less throughput than if the same amount of payload were distributed among a greater number of data packets with smaller payloads. In another exemplary preferred embodiment, the payload size of a data transmission is ascertained. For example, the payload size may be ascertained from a Request message 70. The REQ field 74 may provide sufficient information to ascertain the amount of data that a CM 28 wishes to transmit to the CMTS 30. Alternately, the SID field 76 may identify a CM 28 that typically transmits data packets with a particular payload size. Furthermore, an IUC field 102 may indicate whether a CM 28 is permitted a short data grant or a long data grant for data transmission and a payload size may be ascertained for that data grant. It should be understood, however, that the present invention is not limited to these embodiments and other data transmission parameters, associations, and methods of ascertaining payload sizes for the data-over-cable system may be used.
In yet another exemplary preferred embodiment, the Step 136 of negotiating the use of the determined parameters in the upstream channel comprises building a UCD message 110 based on the determined parameters and sending the UCD message 110 to the CMs 28. For example, given a target PER and ascertained SNR, the parameters for optimal data throughput may be determined and encoded in channel descriptor 122 and/or burst descriptor 124 fields of a UCD message 110. The UCD message 110 may then be sent on a downstream channel to the CMs 28. In yet another exemplary preferred embodiment, the method further comprises the step of reconfiguring the CMs 28 to transmit data according to the determined parameters. For example, the UCD message 110 may be received by a CM 28. The CM 28 examines the UCD message 110, decodes the information in the channel descriptor field 122, and ascertains the parameters for data transmission on the upstream channel, e.g. symbol rate, preamble, and/or frequency. The CM 28 also decodes the information in the burst descriptor field 124 and ascertains the parameters for each burst as allocated by a MAP message 80 that corresponds to the UCD message 110, e.g. modulation type and/or FEC parameters. However, it should be understood that the present invention is not limited to these embodiments and other methods for negotiating and configuring may be used.
Exemplary Ascertaining of the SNR
In one exemplary preferred embodiment of the present invention, the Step 132 of ascertaining a SNR on the upstream channel is performed on the CMTS 30. For example, the CMTS 30 may have the capability of measuring the noise floor on the upstream channel and converting it to a value for the SNR. Alternately, the CMTS 30 may directly measure the SNR for data transmissions by methods known to those skilled in the art. However, the present invention is not restricted to ascertaining the SNR on the CMTS 30 and the SNR may be ascertained at other points and on other devices in the cable system.
In another exemplary preferred embodiment, the Step 132 of ascertaining a SNR on the upstream channel comprises scheduling multiple quiescent periods on the upstream channel, measuring a noise floor value on the upstream channel during one of the quiescent periods, and converting the measured noise floor value to the SNR. Quiescent periods are where no data is transmitted by the cable modems on the upstream channel. For example, the cable system may be capable of providing a measurement of the noise floor on the upstream channel. The noise floor value is a measure of RF power within the bandwidth for the upstream channel when no data is being transmitted. The CMTS 30 may be designed to operate at a constant upstream carrier power level. The value of the noise floor in combination with the value of the designed carrier power level may be converted to a SNR.
In another exemplary preferred embodiment, the SNR for the upstream bandwidth may be converted to a value for a nominal bandwidth by methods known to those skilled in the art. For example, the bandwidth of the upstream channel may depend on the configuration of the cable system. Some configurations may provide a single upstream channel with a larger bandwidth whereas other configurations may provide multiple upstream channels with smaller bandwidths. Converting the SNRs for each bandwidth to a SNR for a nominal bandwidth may provide for a determination of the parameters for optimal throughput that is not dependent on the configuration of the data-over-cable system.
In yet another exemplary preferred embodiment, the Step 132 of ascertaining a SNR on the upstream channel comprises scheduling a plurality of quiescent periods on the upstream channel, measuring noise floor values on the upstream channel during the quiescent periods, averaging the measured noise floor values to obtain an average noise floor value, and converting the average noise floor value to the SNR. A single noise floor measurement may be insufficient to ascertain a SNR for an upstream channel. As an illustrative example, a data-over-cable system with a plurality of upstream channels may encounter “cross-talk” between upstream channels. A quiescent period for a first upstream channel may coincide with an active period or a quiescent period on a second upstream channel. A measurement of the noise floor on the first upstream channel would vary depending on whether the second upstream channel were active or not. Averaging the noise floor values over a plurality of quiescent periods may provide a more reliable ascertaining of the SNR than would a single noise floor measurement. The ascertained SNR may yield parameters for data transmission that optimize data throughput under less-than-ideal conditions. However, it should be understood that the present invention is not limited to these embodiments of ascertaining SNR values and other methods may be used.
Exemplary Determination of Parameters for Data Transmission
The parameters for data transmission by the CMs 28 optimize the data throughput of the data-over-cable system for a given target PER and ascertained SNR. In one exemplary preferred embodiment, the parameters may be read from a table. Entries in the table comprise values for the parameters, target PER, and SNR. When a SNR is ascertained, the entry in the table with the SNR and target PER is found and the parameters in the entry are read. The use of the parameters in the entry are negotiated in the upstream channel to provide optimal data throughput. In another exemplary preferred embodiment, the parameters are also associated with an ascertained payload size and similarly read from a table. Entries in this table include values for the parameters, target PER, SNR, and payload size. Alternately, there may be multiple tables, one for each payload size, each of whose entries include parameters, target PER, and SNR. However, it should be understood that determining parameters in the present invention is not limited to reading parameters from tables and other methods and structure for tables may be used.
In yet another exemplary preferred embodiment, table entries are predetermined. For example, examination of the characteristics of a data-over-cable system may suggest which parameters optimize data throughput under a variety of operating conditions. In yet another exemplary preferred embodiment, table entries may be predetermined by the method shown in
In yet another exemplary preferred embodiment, the Step 174 of calculating the PER for a combination includes calculating a bit error ratio for the combination, converting the bit error ratio to a byte error ratio, converting the byte error ratio to a codeword error ratio, and converting the codeword error ratio to the PER. For example, by methods well known to those skilled in the art of signal processing, a value of SNR may be translated to a bit-error-ratio (“BER”) for a given symbol rate. From the BER may be derived a value for the ratio of how many times a byte of data will be in error. A codeword may incorporate FEC bytes in addition to a number of bytes of raw data and a codeword-error-ratio is a measure of how many codewords will be in error compared to a total number of codewords. The codeword-error-ratio may depend on the FEC parameters T and/or k, how much payload is included in the codeword, and the byte-error-ratio. The codeword-error-ratio may be converted to a PER.
A value of PER for these parameter and SNR selections is calculated at Step 220. Selections whose calculated PER does not meet the target PER are discarded at Step 222 and Steps 194 to 222 are repeated for another selection of parameters and SNR. At Step 224, selections that do meet the target PER are used as a basis for calculating a payload data rate for the selection. Additionally, the SNR may be converted to a value of SNR at a nominal bandwidth as described above. An illustrative nominal bandwidth may be 4 MHz although other nominal bandwidths are possible and the present method is not limited to a 4 MHz bandwidth. The values for the parameters and SNR at nominal bandwidth are saved at Step 226 and Steps 194 to 222 are repeated for another selection of parameters and SNR.
The saved values are sorted at Step 230 to find a maximum payload data rate for each selection of SNR at the nominal bandwidth. The selection of parameters that correspond to this maximum payload rate optimize the data throughput for the input target PER. At Step 232 a table entry is created. The table entry includes the input target PER, the input payload size, the parameters, and SNR at nominal bandwidth that correspond to the maximum payload data rate. Tables 5 and 6 illustrate the maximum payload data rate that may be achieved for the above method.
For a payload size of 100 Bytes and target PERs ranging from 1E-1 to 1E-8, Table 5 presents the maximum payload data rates that may be achieved under a selection of nominal SNR values for data transmission in the upstream channel. Associated with each entry in Table 5 are data transmission parameters (not shown) that accomplish the maximum throughput. Similarly, Table 6 presents the maximum payload data rates for a payload size of 1550 Bytes.
Many other methods for predetermining table entries are possible and it should be understood that the present invention is not limited to the above embodiments.
Exemplary Methods for Adapting to Variances
The SNR of an upstream channel may not be constant in some data-over-cable systems but may vary with conditions for RF transmission. The Method 240 allows the data-over-cable system to adapt to substantial variances in the SNR. In one exemplary preferred embodiment, a variance in SNR of 5 dB may be considered substantial although it should be appreciated that many other values for a substantial variance in SNR are possible and the present invention is not limited to this value. In addition, a substantial variance that is consistent over a given number of transmission cycles may diminish the effect of an anomalous fluctuation in SNR. In another exemplary preferred embodiment the transmission cycle is an upstream usage interval. In this manner, a recognized change in the conditions for RF transmission on the upstream channel may result in the determination of new parameters for data transmission. These new parameters for data transmission may optimize data throughput for the new conditions.
Payload sizes of the data packets may not be consistent in some data-over-cable systems but may vary with network use. For example, a single CPE 14 may be primarily engaged in web browsing and then have to transfer a large file upstream. The data transmissions from the CPE 14 during web browsing may require short data grants from the CMTS 30 whereas the file transfer may require long data grants. Parameters that optimized data throughput for web browsing may not optimize data throughput for file transfer. Recognizing a substantial variance in the payload size for a selection of data transmissions may allow the data-over-cable system to adapt to the new use of the network. In yet another exemplary preferred embodiment, the selection of data transmissions is associated with a single IUC 102. For example, the CMTS 30 may be allocating short data grants to a CM 28. The payload size is associated with the IUC 102 for a short data grant. The payload for data transmissions may initially be small, the payload may easily be delivered within the short data grant, and the data throughput is optimal at this payload size. When the network use changes, however, the CM 28 may try to deliver more payload in the short data grant. The data throughput at the higher payload size may be less than optimal. The Method 250 allows for a recognized change in the conditions for network use to result in the determination of new parameters for data transmission. These new parameters for data transmission may optimize data throughput for the new conditions.
The PER of data packets may not be consistent in some data-over-cable systems but may vary with the level of error correction. If the payload size of the data transmissions does not change and the cable system has the same SNR, a change in PER only may indicate that the level of error correction is not appropriate. Recognizing a substantial variance in the PER for a selection of data transmissions may allow the data-over-cable system to adapt to a new level of error correction. In yet another exemplary preferred embodiment, the selection of data transmissions is associated with a single IUC 102. For example, short data grants, recognized by their IUC 102, may have a changed PER whereas long data grants are transmitted at the same PER. The Method 270 allows for a recognized change in the performance of the network to result in the determination of a new level of error correction. This new level of error correction may optimize data throughput for the new performance level of the network.
It should be understood that the programs, processes, methods, systems and apparatus described herein are not related or limited to any particular type of computer apparatus (hardware or software), unless indicated otherwise. Various types of general purpose or specialized computer apparatus may be used with or perform operations in accordance with the teachings described herein.
In view of the wide variety of embodiments to which the principles of the invention can be applied, it should be understood that the illustrated embodiments are exemplary only, and should not be taken as limiting the scope of the present invention. For example, the Steps of the flow diagrams may be taken in sequences other than those described, and more or fewer elements or component may be used in the block diagrams.
The claims should not be read as limited to the described order or elements unless stated to that effect. In addition, use of the term “means” in any claim is intended to invoke 35 U.S.C. §112, paragraph 6, and any claim without the word “means” is not so intended. Therefore, all embodiments that come within the scope and spirit of the following claims and equivalents thereto are claimed as the invention.
Number | Name | Date | Kind |
---|---|---|---|
4256925 | Goode | Mar 1981 | A |
4644533 | Braff et al. | Feb 1987 | A |
4881263 | Herbison et al. | Nov 1989 | A |
4996685 | Farese et al. | Feb 1991 | A |
5014234 | Edwards, Jr. | May 1991 | A |
5138712 | Corbin | Aug 1992 | A |
5301273 | Konishi | Apr 1994 | A |
5347304 | Moura | Sep 1994 | A |
5363374 | Zein Al Abedeen et al. | Nov 1994 | A |
5400322 | Hunt et al. | Mar 1995 | A |
5430727 | Callon | Jul 1995 | A |
5442749 | Northcutt et al. | Aug 1995 | A |
5446739 | Nakano | Aug 1995 | A |
5488412 | Majeti | Jan 1996 | A |
5489897 | Inoue | Feb 1996 | A |
5528595 | Walsh et al. | Jun 1996 | A |
5583931 | Schneider | Dec 1996 | A |
5586121 | Moura | Dec 1996 | A |
5598410 | Stone | Jan 1997 | A |
5600717 | Schneider | Feb 1997 | A |
5606606 | Schneider | Feb 1997 | A |
5608446 | Carr | Mar 1997 | A |
5610910 | Focsaneanu et al. | Mar 1997 | A |
5623542 | Schneider | Apr 1997 | A |
5623601 | Vu | Apr 1997 | A |
5636211 | Newlin | Jun 1997 | A |
5675732 | Majeti | Oct 1997 | A |
5675742 | Jain et al. | Oct 1997 | A |
5678041 | Baker et al. | Oct 1997 | A |
5708654 | Arndt et al. | Jan 1998 | A |
5710885 | Bondi | Jan 1998 | A |
5724510 | Arndt et al. | Mar 1998 | A |
5761602 | Wagner et al. | Jun 1998 | A |
5778181 | Hidary et al. | Jul 1998 | A |
5784597 | Chiu et al. | Jul 1998 | A |
5790198 | Roop et al. | Aug 1998 | A |
5790548 | Sistanizadeh et al. | Aug 1998 | A |
5790677 | Fox et al. | Aug 1998 | A |
5790770 | McClure et al. | Aug 1998 | A |
5790806 | Koperda | Aug 1998 | A |
5793747 | Kline | Aug 1998 | A |
5799086 | Sudia | Aug 1998 | A |
5805804 | Laursen et al. | Sep 1998 | A |
5809252 | Beighe et al. | Sep 1998 | A |
5812819 | Rodwin et al. | Sep 1998 | A |
5815664 | Asano | Sep 1998 | A |
5818845 | Moura et al. | Oct 1998 | A |
5819028 | Manghirmalani et al. | Oct 1998 | A |
5819042 | Hansen | Oct 1998 | A |
5828655 | Moura et al. | Oct 1998 | A |
5828666 | Focsaneanu et al. | Oct 1998 | A |
5835720 | Nelson et al. | Nov 1998 | A |
5835727 | Wong et al. | Nov 1998 | A |
5841777 | Cohen | Nov 1998 | A |
5848233 | Radia et al. | Dec 1998 | A |
5852721 | Dillon et al. | Dec 1998 | A |
5859852 | Moura et al. | Jan 1999 | A |
5864679 | Kanai et al. | Jan 1999 | A |
5870134 | Laubach et al. | Feb 1999 | A |
5872523 | Dellaverson et al. | Feb 1999 | A |
5881362 | Eldering et al. | Mar 1999 | A |
5884024 | Lim et al. | Mar 1999 | A |
5892754 | Kompella et al. | Apr 1999 | A |
5894479 | Mohammed | Apr 1999 | A |
5903558 | Jones et al. | May 1999 | A |
5909549 | Compliment et al. | Jun 1999 | A |
5913037 | Spofford et al. | Jun 1999 | A |
5915119 | Cone | Jun 1999 | A |
5922049 | Radia et al. | Jul 1999 | A |
5922051 | Sidey | Jul 1999 | A |
5923659 | Curry et al. | Jul 1999 | A |
5926458 | Yin | Jul 1999 | A |
5929850 | Broadwin et al. | Jul 1999 | A |
5941988 | Bhagwat et al. | Aug 1999 | A |
5943604 | Chen et al. | Aug 1999 | A |
5954797 | Sidey | Sep 1999 | A |
5958007 | Lee et al. | Sep 1999 | A |
5960177 | Tanno | Sep 1999 | A |
5974453 | Andersen et al. | Oct 1999 | A |
5982748 | Yin et al. | Nov 1999 | A |
5987524 | Yoshida et al. | Nov 1999 | A |
5991292 | Focsaneanu et al. | Nov 1999 | A |
5991306 | Burns et al. | Nov 1999 | A |
5996076 | Rowney et al. | Nov 1999 | A |
5999536 | Kawafuji et al. | Dec 1999 | A |
6003077 | Bawden et al. | Dec 1999 | A |
6005851 | Craddock et al. | Dec 1999 | A |
6006264 | Colby et al. | Dec 1999 | A |
6009103 | Woundy | Dec 1999 | A |
6012088 | Li et al. | Jan 2000 | A |
6013107 | Blackshear et al. | Jan 2000 | A |
6014545 | Wu et al. | Jan 2000 | A |
6018767 | Fijolek et al. | Jan 2000 | A |
6031841 | Woundy | Feb 2000 | A |
6032019 | Chen et al. | Feb 2000 | A |
6041041 | Ramanathan et al. | Mar 2000 | A |
6046979 | Bauman | Apr 2000 | A |
6049546 | Ramakrishnan | Apr 2000 | A |
6049825 | Yamamoto | Apr 2000 | A |
6049826 | Beser | Apr 2000 | A |
6052724 | Willie et al. | Apr 2000 | A |
6058421 | Fijolek et al. | May 2000 | A |
6061349 | Coile et al. | May 2000 | A |
6064372 | Kahkoska | May 2000 | A |
6065049 | Beser | May 2000 | A |
6070187 | Subramaniam et al. | May 2000 | A |
6070242 | Wong et al. | May 2000 | A |
6070246 | Beser | May 2000 | A |
6073178 | Wong et al. | Jun 2000 | A |
6075787 | Bobeck et al. | Jun 2000 | A |
6091709 | Harrison et al. | Jul 2000 | A |
6094431 | Yamato et al. | Jul 2000 | A |
6104700 | Haddock et al. | Aug 2000 | A |
6112258 | Miller et al. | Aug 2000 | A |
6122254 | Aydemir et al. | Sep 2000 | A |
6128298 | Wootton et al. | Oct 2000 | A |
6130879 | Liu | Oct 2000 | A |
6130880 | Naudus et al. | Oct 2000 | A |
6137792 | Jonas et al. | Oct 2000 | A |
6137793 | Gorman et al. | Oct 2000 | A |
6148410 | Baskey et al. | Nov 2000 | A |
6157965 | Mohammed et al. | Dec 2000 | A |
6170061 | Beser | Jan 2001 | B1 |
6178455 | Schutte et al. | Jan 2001 | B1 |
6185624 | Fijolek et al. | Feb 2001 | B1 |
6189102 | Beser | Feb 2001 | B1 |
6212563 | Beser | Apr 2001 | B1 |
6216171 | Isono et al. | Apr 2001 | B1 |
6223222 | Fijolek et al. | Apr 2001 | B1 |
6240464 | Fijolek et al. | May 2001 | B1 |
6243369 | Grimwood et al. | Jun 2001 | B1 |
6260072 | Rodriguez-Moral | Jul 2001 | B1 |
6269099 | Borella et al. | Jul 2001 | B1 |
6272150 | Hrastar | Aug 2001 | B1 |
6275853 | Beser et al. | Aug 2001 | B1 |
6289377 | Lalwaney et al. | Sep 2001 | B1 |
6295554 | Karadogan | Sep 2001 | B1 |
6301223 | Hrastar et al. | Oct 2001 | B1 |
6301618 | Sitaraman et al. | Oct 2001 | B1 |
6308328 | Bowcutt et al. | Oct 2001 | B1 |
6321384 | Eldering | Nov 2001 | B1 |
6331987 | Beser | Dec 2001 | B1 |
6332163 | Bowman-Amuah | Dec 2001 | B1 |
6337858 | Petty et al. | Jan 2002 | B1 |
6351773 | Fijolek et al. | Feb 2002 | B1 |
6370147 | Beser | Apr 2002 | B1 |
6385773 | Schwartzman et al. | May 2002 | B1 |
6393478 | Bahlmann | May 2002 | B1 |
6442158 | Beser | Aug 2002 | B1 |
6449291 | Burns et al. | Sep 2002 | B1 |
6453472 | Leano et al. | Sep 2002 | B1 |
6490727 | Nazarathy et al. | Dec 2002 | B1 |
6510162 | Fijolek et al. | Jan 2003 | B1 |
20020122050 | Sandberg | Sep 2002 | A1 |
20020136165 | Ady et al. | Sep 2002 | A1 |
20030028891 | Hardt et al. | Feb 2003 | A1 |
Number | Date | Country |
---|---|---|
0 713 347 | Nov 1995 | EP |
2 232 326 | May 1989 | GB |
2 263 847 | Jul 1992 | GB |
2 270 815 | Sep 1992 | GB |
2 275 588 | Feb 1994 | GB |
2 298 999 | Jul 1995 | GB |
2 303 764 | Jul 1995 | GB |
2 302 485 | Jun 1996 | GB |
08008784 | Jan 1996 | JP |
WO 9108629 | Nov 1990 | WO |
WO 96 08934 | Mar 1996 | WO |
WO 0067385 | Nov 2000 | WO |