The present invention relates generally to communication devices, and more particularly to a system and method for decoupling communication rates across a communication channel.
With the many continued advancements in communications technology, more and more devices are being introduced in both the consumer and commercial sectors with advanced communications capabilities. Additionally, advances in processing power and low-power consumption technologies, as well as advances in data coding techniques have led to the proliferation of wired and wireless communications capabilities on a more widespread basis.
For example, communication networks, both wired and wireless, are now commonplace in many home and office environments. Such networks allow various heretofore independent devices to share data and other information to enhance productivity or simply to improve their convenience to the user. One such communication network that is gaining widespread popularity is an exemplary implementation of a wireless network such as that specified by the WiMedia-MBOA (Multiband OFDM Alliance). Other exemplary networks include the Bluetooth® communications network and various IEEE standards-based networks such as 802.11 and 802.16 communications networks, to name a few.
Architects of these and other networks, and indeed communications channels in general, have long struggled with the challenge of managing multiple communications across a limited channel. For example, in some environments, more than one device may share a common carrier channel and thus run the risk of encountering a communication conflict between the one or more devices on the channel.
Over the years, network architects have come up with various solutions to arbitrate disputes or otherwise delegate bandwidth among the various communicating devices, or clients, on the network. Schemes used in well known network configurations such as token rings, Ethernet, and other configurations have been developed to allow sharing of the available bandwidth. In addition to these schemes, other techniques have been employed, including for example CDMA (code division multiple access) and TDMA (time division multiple access) for cellular networks.
FDM (Frequency Division Multiplexing) is another technology that enables multiple devices to transmit their signals simultaneously over a communication channel in a wired or wireless setting. The devices' respective signals travel within their designated frequency band (carrier), onto which the data (text, voice, video, or other data.) is modulated. With adequate separation in frequency band spacing, multiple devices can simultaneously communicate across the same communication channel (network or point-to-point).
Orthogonal FDM (OFDM) spread spectrum systems distribute the data over a plurality of carriers that are spaced apart at precise frequencies. The spacing is chosen so as to provide orthogonality among the carriers. Thus, a receiver's demodulator recovers the modulated data with little interference from the other carrier signals. The benefits of OFDM are high spectral efficiency, resiliency to RF interference, and lower multi-path distortion or inter symbol interference (ISI). OFDM systems can be combined with other techniques (such as time-division multiplexing) to allow sharing of the individual carriers by multiple devices as well, thus adding another dimension of multiplexing capability.
However, even with various multiplexing schemes available to network and other communication channel designers, there can still be inefficiencies in bandwidth allocation due to various factors. For example, many network and communication channels specify symmetric data rates for two way communications. That is, a given network device is implemented such that it conducts transmit operations at the same data rate at which it conducts receive operations. As just one example of this, the currently specified versions of the MB-OFDM (WiMedia) system define device physical layer capabilities in terms of symmetrical support of all data rates. In this definition, both transmit and receive data rate capabilities are associated with a single bit in the physical layer (PHY) capability bitmap field. As the current definition of this standard consists of eight data rates, and entire byte (octet) is utilized to define the device capability. Such a configuration provides a relatively straightforward implementation of data rate controls, allowing a minimum of control bits or fields to set the rate at which devices communicate. However, this configuration can in some instances be overly rigid.
In one embodiment of the invention, a network device is provided that is configured to operate on a communication network with decoupled transmit and receive data rates. The network device can include first control logic configured to announce at least one of its transmit and receive data rate parameter; second control logic configured to receive a data rate parameter from a second network device operating on the communication network; and third control logic configured to set at least one of its transmit and receive data rate based on the received data rate parameters. The data rate parameters in one embodiment can be encoded within a PHY capability bitmap octet. Particularly, in one embodiment the data rates can be encoded into an upper and lower nibble of the octet. In one embodiment network devices are configured to announce only their receive rate capability, and the second control logic determines at what rate to transmit based on the receive rate information it receives from a device to which it will be transmitting.
In another embodiment of the invention, a method is provided for selecting a data rate for communication across a communication channel, including the steps of a first network device announcing at least one of its transmit and receive data rate parameter; the first network device receiving a data rate parameter from a second network device operating on the communication network; and the first network device setting at least one of its transmit and receive data rate based on the received data rate parameters. The data rate parameters in one embodiment can be encoded within a PHY capability bitmap octet. Particularly, in one embodiment the data rates can be encoded into an upper and lower nibble of the octet. In one embodiment network devices are configured to announce only their receive rate capability, and the network device determines at what rate to transmit based on the receive rate information it receives from a device to which it will be transmitting.
In yet another embodiment of the invention, a network device is configured to operate on a communication network having decoupled transmit and receive data rates. The network device can include means for announcing at least one of its transmit and receive data rate parameter; means for receiving a data rate parameter from a second network device operating on the communication network; and means for setting at least one of its transmit and receive data rate based on the received data rate parameters. The data rate parameters in one embodiment can be encoded within a PHY capability bitmap octet. Particularly, in one embodiment the data rates can be encoded into an upper and lower nibble of the octet. In one embodiment network devices are configured to announce only their receive rate capability, and the network device determines at what rate to transmit based on the receive rate information it receives from a device to which it will be transmitting.
In a further embodiment of the invention, a computer program product comprises a computer useable medium embodying program code enabling a process for selecting a data rate for communication across a communication channel. The program code can include program code configured to cause a first network device announcing at least one of its transmit and receive data rate parameter; program code configured to cause the first network device receiving a data rate parameter from a second network device operating on the communication network; and program code configured to cause the first network device setting at least one of its transmit and receive data rate based on the received data rate parameters. The data rate parameters in one embodiment can be encoded within a PHY capability bitmap octet. Particularly, in one embodiment the data rates can be encoded into an upper and lower nibbles of the octet. In one embodiment network devices are configured to announce only their receive rate capability, and the network device determines at what rate to transmit based on the receive rate information it receives from a device to which it will be transmitting.
The present invention, in accordance with one or more various embodiments, is described in detail with reference to the following figures. The drawings are provided for purposes of illustration only and merely depict typical or example embodiments of the invention. These drawings are provided to facilitate the reader's understanding of the invention and shall not be considered limiting of the breadth, scope, or applicability of the invention. It should be noted that for clarity and ease of illustration these drawings are not necessarily made to scale.
The present invention is directed toward a system and method for providing decoupling of data rates for a communication channel. In one embodiment, the present invention provides a system and method for allowing devices to operate at different data rates for transmit and receive operations. In one embodiment, the communication channel requirements are relaxed such that transmit rates are not coupled to receive rates, or vice versa. In such embodiments, the device is free to establish the transmit or receive data rate in a manner appropriate for the communication operation or device parameters.
Before describing the invention in detail, it is useful to describe an example environment in which the invention can be implemented. One such example is a wireless beaconing network in which multiple electronic devices (for example, computers and computing devices, cellular telephones, personal digital assistants, motion and still cameras, among others) can communicate and share data, content and other information with one another. One example of such a network is that specified by the WiMedia standard (within WiMedia and Multi-Band OFDM Alliance). From time-to-time, the present invention is described herein in terms of a distributed network or in terms of the WiMedia standard. Description in terms of these environments is provided to allow the various features and embodiments of the invention to be portrayed in the context of an exemplary application. After reading this description, it will become apparent to one of ordinary skill in the art how the invention can be implemented in different and alternative environments. Indeed, applicability of the invention is not limited to a distributed wireless network, nor is it limited to the MB-UWB standard described as one implementation of the example environment.
Most network standards specify policies or rules that govern the behavior of network connected devices. The WiMedia standard specifies the mechanism and policies that are to be followed by W-USB and WiNet compliant devices in order to allow for an ad hoc and distributed network of such devices to operate efficiently. Policies, requirements, protocols, rules, guidelines or other factors used to incentivize, recommend, specify, govern, control or manage the behavior of devices operating in a communication network are generally referred to herein as utilization policies.
In most distributed networks, the network of the devices is maintained by requiring all devices to announce parameters such as their presence, their capabilities and their intentions for reserving transmission slots and so on. For example, with the WiMedia standard, this can be done during what are referred to as beacon period time slots. According to this standard, devices joining the network are expected to monitor the beacon period to learn about the network status and parameters before attempting to use the network. In other network configurations, beacon periods are similarly used to allow management of network devices as described more fully below. Thus, beacon periods are one form of window or network period during which scheduling or other housekeeping activities can be conducted. Beacon periods in the above-referenced standard, and other time periods used for scheduling or other housekeeping chores in other network configurations, are generally referred to as scheduling windows.
Devices are typically allowed to enter a power save mode to conserve power and possibly prolong operation. For example, battery operated devices may enter a sleep mode or even a deep-sleep mode, wherein one or more of their functions are diminished or shut down in order to conserve power. Depending on the environment, devices may be allowed to enter into a sleep mode for short or long periods of time. For example, a sleep mode can be an energy-saving mode of operation in which some or all components are shut down or their operation limited. Many battery-operated devices, such as notebook computers, cell phones, and other portable electronic devices support one or more levels of a sleep mode. For example, when a notebook computer goes into one level of sleep mode, it may turn off the hard drive and still allow the user to perform operations, only powering up the hard drive when access is needed. In a deeper level of sleep, the computer may further turn off the display. In yet a further level of sleep, the computer may enter a hibernate state. Likewise, other electronic devices communicating across a communication channel may have similar sleep states and may power down unnecessary or unused components, including an RF transceiver, depending on a number of factors such as elapsed time, activities and so on. As described below, in accordance with one embodiment, devices may be prompted to enter a sleep mode upon completion of scheduling or other housekeeping activities and be configured to awaken for scheduled activities such as, for example, communication activities.
With many applications, the wireless network 1020 operates in a relatively confined area, such as, for example, a home or an office. The example illustrated in
Also illustrated in the example wireless network 1020 are portable electronic devices such as a cellular telephone 1010 and a personal digital assistant (PDA) 1012. Like the other electronic devices illustrated in
Additionally, the example environment illustrated in
Also illustrated is a personal computer 1060 or other computing device connected to wireless network 1020 via a wireless air interface. As depicted in the illustrated example, personal computer 1060 can also provide connectivity to an external network such as the Internet 1046.
In the illustrated example, wireless network 1020 is implemented so as to provide wireless connectivity to the various electronic devices associated therewith. Wireless network 1020 allows these devices to share data, content, and other information with one another across wireless network 1020. Typically, in such an environment, the electronic devices would have the appropriate transmitter, receiver, or transceiver to allow communication via the air interface with other devices associated with wireless network 1020. These electronic devices may conform to one or more appropriate wireless standards and, in fact, multiple standards may be in play within a given neighborhood. Electronic devices associated with the network typically also have control logic configured to manage communications across the network and to manage the operational functionality of the electronic device. Such control logic can be implemented using hardware, software, or a combination thereof. For example, one or more processors, ASICs, PLAs, and other logic devices or components can be included with the device to implement the desired features and functionality. Additionally, memory or other data and information storage capacity can be included to facilitate operation of the device and communication across the network. Software can include program code that is executable by a processing device to perform the desired functions.
Electronic devices operating as a part of wireless network 1020 are sometimes referred to herein as network devices, members or member devices of the network or devices associated with the network. In one embodiment devices that communicate with a given network may be members or merely in communication with the network.
Some communication networks are divided into periods or frames that can be used for communication and other activities. For example, as discussed above, some networks have a scheduling window such as, for example, a beacon period, for scheduling upcoming communication activities. Also, some networks have a communication window during which such communication activities take place. In the WiMedia-MBOA standard, the bandwidth is divided into superframes, which in turn are divided into time slots for the transmission and reception of data by the various electronic devices associated with the network.
An example of such time slots are illustrated in
Network devices can take on various configurations and architectures and, as the above examples illustrate, can perform a variety of functions, from printers, to web cameras, to modems, to servers, and so on. Network devices typically have some form of control logic that is configured to manage communications across the network and to manage the operational functionality of the network device. Such control logic can be implemented using hardware, software, or a combination thereof. For example, one or more processors, ASICs, PLAs, and other logic devices or components can be included with the device to implement the desired features and functionality. Additionally, memory or other data and information storage capacity can be included to facilitate operation of the device and communication across the network.
One example configuration of a network device that can be used with a wireless network is illustrated in
For external communications, the network device can also include communications capabilities. For instance, the example illustrated in
Device 162 is a black-box representation of the functionality that can be performed by the network device 120. For example, in the case of a web camera, device 162 can include imaging optics, an image sensor, image buffers, and other like functionality. Device 162 can include dedicated processing and memory capabilities, or can use CPU 122, ROM 124, and RAM 126 for some or all of its operation.
Network device 120 may further include secondary storage devices 138, such as but not limited to hard drives, floppy drives, CD and DVD ROM and RWM drives, removable memory or storage devices, or other computer program product interfaces and associated computer program products. Computer program product interfaces can include, for example, devices that access objects (such as information, data, software, and other program code) embodied in computer program products, whether internally or externally to network device 120. Examples of computer program product interfaces can include, for example, hard drives, floppy drives, removable drives, optical storage devices, card slots, wireless or wired communication interfaces, communication ports, and so on. Examples of computer program products include, but are not limited to, disks, memory cards and any other media compatible with the various interfaces. Computer program products can also include signals or other media that transport the computer program code to the device. Thus, the term “computer program product” is not limited to a particular device, but instead generally refers to any device or media in or through which program code is made available to the network device.
Having thus described an example environment in which the invention can be implemented, various features and embodiments of the invention are now described in further detail. Description may be provided in terms of this example environment for ease of discussion and understanding only. After reading the description herein, it will become apparent to one of ordinary skill in the art that the present invention can be implemented in any of a number of different communication environments (including wired or wireless communication environments, and distributed or non-distributed networks) operating with any of a number of different electronic devices and according to various similar or alternative protocols or specifications.
Many networks and communication channels specify that network devices perform transmit operations at the same data rates as receive operations. As one example, at the time of this invention, the specified versions of the MB-OFDM (WiMedia) system define device physical layer capabilities in terms of symmetrical support of all data rates. In this definition both transmit and receive data rate capabilities are associated with a single bit in the PHY Capability Bitmap field. As the current definition of this standard consists of eight data rates, and an entire eight-bit byte (octet) is utilized to define the device capability. As such, the data rates are coupled, in that transmit and receive operations take place at the same data rate. The current definition has two shortcomings, including the requirement that each device support a particular data rate for transmission and reception, and the association of each data rate with a single bit. Furthermore, transmitting all those bits over the air lowers the bandwidth utilization and capacity of the system.
Because network devices are often targeted for cost and power sensitive applications, it is desirable to avoid adding unnecessary complexity. This is especially true for wireless network devices seeking to attain higher performance at lower levels of power consumption. Many network and other communication devices and applications do not require or would not benefit from symmetrical data rates for transmit and receive. Some of these devices may include, for example, web cameras, printers, and so on. For instance, consider a typical web camera device. Such devices capture large amounts of image data and in order to be effective may be required to transmit this captured image data at relatively high data rates. These cameras, however, typically only receive small amounts of control data. Therefore, a web camera may actually utilize a lower (sometimes significantly lower) data rate to receive any necessary or desirable control information. Similarly, with a printing device, high data rates may from time to time be used to receive the information to be printed, while a much lower data rate is needed to return status and control information from the printer to the requesting device.
However, if a device is constrained to the same data rate for transmit and receive operations (i.e., symmetrical data rates), performance is typically impacted if that data rate is chosen at the lower of the two rates. For example, consider how long it would take to transfer image data from a web camera to a server if its data rate were constrained to the rate necessary to send control information to the camera. Therefore, such symmetrical devices are implemented in conventional solutions with both the transmit and receive rates specified at the higher of the two rates. However, complexity of the transmit or receive sections of the device may be unnecessarily increased if requirements constrain both the transmit and receive operations to the higher of the two rates.
The complexity of the device is often directly related to the device cost. For example, utilizing increased data rates can lead to a need for increased size or performance of the logic or other componentry utilized to implement the processing and communication functions. Additionally, increased data rates can also lead to increased power consumption. As such, devices that are implemented in accordance with specifications in MB-OFDM (WiMedia) for symmetrical data rates will likely have a higher cost and greater power consumption associated therewith.
One embodiment of the present invention permits a decoupling of the transmit and receive data rates for devices. This can be implemented so as to allow reduced complexity for one of the transmit or the receive chain relative to the other. In other words, in the example of the camera, the receive componentry (e.g., hardware, software, and/or firmware) that receives the lower data rate control information can be implemented in a less complex manner. Preferably, this can lead to a lower cost and a lower power-consumption implementation than would otherwise be obtainable were that receiver implemented to operate at the higher data rate.
In accordance with another embodiment, of the invention, decoupling of the data rates can be implemented without added unnecessary overhead to the network controls. For example, in term of the example environment, the device transmit and receive data rate capabilities can be encoded within existing PHY Capability Bitmap octet using, for example, the upper and lower nibbles, respectively (or vice versa).
As set forth in section 7.8.15, of the WiMedia (MBOA) specification, the PHY Capability Bitmap field comprises two octets, one defining the data rates and the other the band groups. There are eight data rates defined within the WIMEDIA (MBOA) specification Capability Bitmap field. In one embodiment, data rates for transmit and receive must be the same, and each bit of this field identifies a single data rate. According to an embodiment of the invention, the structure of PHY Capabilities IE can be implemented as illustrated in Table 1.
The Data Rate octet of the PHY Capability field can be further divided in one embodiment into the upper and lower nibbles of the octet as shown in Table 2.
Each nibble being four bits in length can encode a set of up to 16 data rates. The data rates specified for the upper and lower nibbles can be defined the same set of rates (as illustrated below), different rates depending on the nibble, or a hybrid of these two approaches. In one embodiment, the encoding of the four bits are the same for each nibble, such that a given codeword encodes the same data rate for both nibbles. As a specific example, the encoding for each nibble of the data rate octet can be implemented as illustrated in Table 3. As these examples illustrated, the invention can be implemented in such a way as to provide flexibility in assigning or identifying data rates for transmit and receive operations for a given application.
In one embodiment, all data rates up to the maximum rate indicated by the device can be supported. In this embodiment, unused data rate codewords can be utilized for future extensions of data rates. For instance, in the example illustrated in Table 3, codewords 1000 to 1111 are reserved for future use.
In an alternative embodiment, however, not all of the data rates up to the device maximum are supported. Unsupported data rates, or rate holes, can be indicated by the codeword. For example, for unsupported data rates the most significant bit of the codeword associated with the next higher data rate can be set to a ‘1.’ Alternative configurations can be used to indicate unsupported data rates. Additionally, in yet another embodiment, two bytes can be used to define the transmit and receive data rate capabilities without encoding.
In one embodiment of the invention, the receive and transmit capabilities of one or more network devices can be identified during a scheduling window such as, for example, during a Beacon period 111, or during some other initialization period. This can be accomplished in one embodiment through the use of an un-coded (for example, bitfield) mapping of octets. In one embodiment this can be accomplished by mapping two separate octets (bytes), one for receive and one for transmit.
In a further embodiment, the transmit and receive data rates can be decoupled by designating the rate capability of each device for only one of either its transmitter or receiver. For example, in one embodiment, the rate capability of network device receivers is designated, and the devices' transmit rate capabilities are not announced. The transmit rate capability is known to the transmitting device, while the receive rate capability of the receiving device is announced through its beacon 111 or other scheduling window. Hence, the transmitting device can determine at what data rate to transmit based on the information it receives during the beacon period 111. This would decouple the receive and transmit rate capability implicitly.
In a step 206, the network devices check the data rate parameters announced by the other network devices. In one embodiment, this can be performed by each device operating on the network. In other embodiments this can be done selectively. If a network device has particular requirements, the device with which it is communicating can note those requirements in step 206, and then follow those requirements as indicated by steps 208 and 212. Otherwise, the device may make an independent decision regarding its operating rates as indicated by steps 208 and 214. In a step 216, with rates set, the devices can conduct network activities.
To better illustrate the above methodology it is useful to consider a simple example. For example, consider a web camera that may require a very high transmit rate to download image data, yet a relatively low data rate to receive control information. Further consider that the camera is communicating with a video recorder/playback device that has a high data rate for both transmit and receive operations, a monitor that has a high data rate for receive operations and a low data rate for transmitting status information, and a server that has full flexibility in rate setting. In an embodiment where devices disclose their receive requirements only, the camera would disclose its low rate capabilities, the video recorder could announce a desired high receive rate as could the monitor and the server. Thus, devices communicating information to the camera would know that they need to use the camera's lower receive rate for their transmit operations, and could continue to receive information at the higher data rate.
While various embodiments of the present invention have been described above, it should be understood that they have been presented by way of example only, and not of limitation. Thus the breadth and scope of the present invention should not be limited by any of the above-described exemplary embodiments. Additionally, the invention is described above in terms of various exemplary embodiments and implementations. It should be understood that the various features and functionality described in one or more of the individual embodiments are not limited in their applicability to the particular embodiment with which they are described, but instead can be applied, alone or in some combination, to one or more of the other embodiments of the invention, whether or not such embodiments are described and whether or not such features are presented as being a part of a described embodiment.
Terms and phrases used in this document, and variations thereof, unless otherwise expressly stated, should be construed as open ended as opposed to limiting. As examples of the foregoing: the term “including” should be read as mean “including, without limitation” or the like; the term “example” is used to provide exemplary instances of the item in discussion, not an exhaustive or limiting list thereof; and adjectives such as “conventional,” “traditional,” “normal,” “standard,” and terms of similar meaning should not be construed as limiting the item described to a given time period or to an item available as of a given time, but instead should be read to encompass conventional, traditional, normal, or standard technologies that may be available now or at any time in the future. Likewise, a group of items linked with the conjunction “and” should not be read as requiring that each and every one of those items be present in the grouping, but rather should be read as “and/or” unless expressly stated otherwise. Similarly, a group of items linked with the conjunction “or” should not be read as requiring mutual exclusivity among that group, but rather should also be read as “and/or” unless expressly stated otherwise.
This application claims the benefit of priority under 35 U.S.C. § 119(e) to U.S. provisional application Ser. No. 60/674,797, filed on Apr. 25, 2005, and claims the benefit of priority under 35 U.S.C. § 119(e) to U.S. provisional application Ser. No. 60/672,606, filed Apr. 19, 2005, the entirety of which is incorporated by reference herein.
Number | Date | Country | |
---|---|---|---|
60672606 | Apr 2005 | US | |
60674797 | Apr 2005 | US |