1. Field of Invention
Embodiments of the present invention pertain to wireless communication, and in particular, to communicating network characteristic information to non-network apparatuses.
2. Background
Wireless communication has evolved from being a means for verbal information to being more focused on total digital interactivity. Enhancements in wireless technology have substantially improved communication abilities, quality of service (QoS), speed, etc., which has contributed to an insatiable desire for new device functionality. As a result, portable wireless apparatuses are no longer just tasked with making telephone calls. They have become integral, and in some cases essential, tools for managing the professional and/or personal life of users.
In order to support the desired expansion of electronic communication, more and more applications that did not incorporate any communication functionality are being redesigned to support wired and/or wireless communication. Such wireless communication support may, in some instances, include the ability to send monitored or observed data to other apparatuses via wireless communication. Example usage scenarios may include natural resource monitoring, biometric sensors, systems for supporting financial transactions, personal communication and/or location devices, etc. Apparatuses such activities and subsequent communications often operate using limited resources. For example, these apparatuses may be simple (e.g., may have limited processing resources), may be small (e.g., may have space constraints due to size limitations imposed in retrofit applications), may have power constraints (e.g., battery powered), etc.
Link establishment and maintenance processes defined in existing communication protocols may not be appropriate for apparatuses operating with resource constraints such as set forth above. For example, standards for existing wireless communication protocols may require periodic interaction in order to keep apparatuses participating in the network synchronized with other apparatuses. These requirements may not take into consideration the burden that periodic network communication places upon resource-constrained devices. As a result, it may become difficult to operate such resource-constrained apparatuses in accordance with these standards.
Example embodiments of the present invention may be directed to a method, apparatus, computer program and system for facilitating apparatus interaction while conserving apparatus resources. In accordance with at least one example implementation, apparatuses may stay synchronized with a network utilizing a reduced or diluted beacon interval that is an integer multiple of a network beacon period signal being transmitted at a set interval. Diluted beacon intervals may reduce communication burden for apparatuses since the need to communicate is less frequent. Scanning opportunities, which are instances where apparatuses may perform either passive scanning or network communication activities like beaconing, may also have start times and/or durations that are based upon an integer multiple of the network beacon signal interval.
During scanning opportunities apparatuses may opt to passively scan for beacon signals broadcast from other apparatuses, the receipt of which may trigger the transmission of network information messages from the scanning apparatuses. Network information messages may comprise connectivity information usable by apparatuses that wish to join the network. In accordance with at least one embodiment of the present invention, apparatuses outside of the network that receive network information messages may determine whether participation in the network described in the received network information message (e.g., other network) is desired. If the apparatus desires to interact with apparatuses in the other network, then further decisions may be made with respect to how communication between these entities should be established.
For example, apparatuses that receive network information messages may already be active in one or more networks. A decision to also participate in additional networks, or to move all operations from the one or more networks to a new network, may force some or all of the networks to be reconfigured. For example, apparatuses that enter into new networks while still participating in existing networks may force synchronization (e.g., timing changes) to occur in the networks. Problems may result when larger networks are forced to synchronize to smaller networks, which may worsen the impact of disruptions that may be caused by synchronization.
In accordance with at least one embodiment of the present invention, network information messages may comprise network size information. Network size information may be encoded in a fixed position in a message frame (e.g., such as in a basic service set identifier) and may inform receiving apparatuses of an approximate size for the network corresponding to the network information message. Network sizes may then be compared by apparatuses when determining whether to maintain clock timing or to synchronize to the timing of a new network.
The above summarized configurations or operations of various embodiments of the present invention have been provided merely for the sake of explanation, and therefore, are not intended to be limiting. Moreover, inventive elements associated herein with a particular example embodiment of the present invention can be used interchangeably with other example embodiments depending, for example, on the manner in which an embodiment is implemented.
The disclosure will be further understood from the following description of various exemplary embodiments, taken in conjunction with appended drawings, in which:
While the present invention has been described herein in terms of a multitude of example embodiments, various changes or alterations can be made therein without departing from the spirit and scope of the present invention, as set forth in the appended claims.
I. General System with which Embodiments of the Present Invention May be Implemented
An example system usable as a basis for explaining the various embodiments of the present invention is disclosed in
Computing device 100 may correspond to various processing-enabled apparatuses including, but not limited to, micro personal computers (UMPC), netbooks, laptop computers, desktop computers, engineering workstations, personal digital assistants (PDA), computerized watches, wired or wireless terminals/nodes/etc., mobile handsets, set-top boxes, personal video recorders (PVR), automatic teller machines (ATM), game consoles, or the like. Elements that represent basic example components comprising functional elements in computing device 100 are disclosed at 102-108. Processor 102 may comprise one or more components configured to execute instructions, for instance, wherein a group of instructions may constitute program code. In at least one scenario, the execution of program code may include receiving input information from other elements in computing device 100 in order to formulate an output (e.g., data, event, activity, etc). Processor 102 may be a dedicated (e.g., monolithic) microprocessor device, or may be part of a composite device such as an ASIC, gate array, multi-chip module (MCM), etc.
Processor 102 may be electronically coupled to other functional components in computing device 100 via a wired and/or wireless bus. For example, processor 102 may access memory 102 in order to obtain stored information (e.g., program code, data, etc.) for use during processing. Memory 104 may generally include removable or imbedded memories that operate in a static or dynamic mode. Further, memory 104 may include read only memories (ROM), random access memories (RAM), and rewritable memories such as Flash, EPROM, etc. Examples of removable storage media based on magnetic, electronic and/or optical technologies are shown at 100 I/O in
One or more interfaces 106 may also be coupled to various components in computing device 100. These interfaces may allow for inter-apparatus communication (e.g., a software or protocol interface), apparatus-to-apparatus communication (e.g., a wired or wireless communication interface) and even apparatus to user communication (e.g., a user interface). These interfaces allow components within computing device 100, other apparatuses and users to interact with computing device 100. Further, interfaces 106 may communicate machine-readable data, such as electronic, magnetic or optical signals embodied on a computer readable medium, or may translate the actions of users into activity that may be understood by computing device 100 (e.g., typing on a keyboard, speaking into the receiver of a cellular handset, touching an icon on a touch screen device, etc.) Interfaces 106 may further allow processor 102 and/or memory 104 to interact with other modules 108. For example, other modules 108 may comprise one or more components supporting more specialized functionality provided by computing device 100.
Computing device 100 may interact with other apparatuses via various networks also shown in
Further, interaction with remote devices may be supported by various providers of short and long range wireless communication 140. These providers may use, for example, long range terrestrial-based cellular systems and satellite communication, and/or short-range wireless access points in order to provide a wireless connection to Internet 120. For example, personal digital assistant (PDA) 142 and cellular handset 144 may interact with computing device 100 over Internet 120 as facilitated by wireless communication 140. Similar functionality may be also be included in other apparatuses, such as laptop computer 146, in the form of hardware and/or software resources configured to allow short and/or long range wireless communication.
Wireless-enabled apparatuses 200 are labeled “A” to “G” in
An example communication between apparatuses in accordance with at least one embodiment of the present invention is disclosed at 300 in
Additional detail with respect to communication example 300 is disclosed further in
Network establishment and media access control (MAC) management messages 304 may be utilized to establish and maintain an underlying wireless network architecture within an operating space that may be utilized to convey data type communication messages 302. In accordance with various example embodiments of the present invention, messages containing apparatus configuration, operation and status information may be exchanged to transparently establish wireless network connections when, for example, an apparatus enters an operating space. Network connections may exist between any or all apparatuses existing within the operating space, and may be in existence for the entire time that an apparatus resides in the operating space. In this way, data-type communication messages 302 may be conveyed between apparatuses using existing networks (new network connections do not need to be negotiated each time messages are sent), which may reduce response delay and increase quality of service (QoS).
In accordance with at least one embodiment of the present invention, an example of distributed local network formation via automated network establishment and MAC management messages 304 is disclosed in
An example of information that may be communicated in network establishment and MAC management messages 304 (e.g., using information elements), in accordance with at least one example embodiment of the present invention, is disclosed in
The WLAN logical architecture comprises stations (STA), wireless access points (AP), independent basic service sets (IBSS), basic service sets (BSS), distribution systems (DS), and extended service sets (ESS). Some of these components map directly to hardware devices, such as stations and wireless access points. For example wireless access points may function as bridges between stations and a network backbone (e.g., in order to provide network access). An independent basic service set is a wireless network comprising at least two stations. Independent basic service sets are also sometimes referred to as an ad hoc wireless network. Basic service sets are wireless networks comprising a wireless access point supporting one or multiple wireless clients. Basic service sets are also sometimes referred to as infrastructure wireless networks. All stations in a basic service set may interact through the access point. Access points may provide connectivity to wired local area networks and provides bridging functionality when one station initiates communication to another station or with a node in a distribution system (e.g., with a station coupled to another access point that is linked through a wired network backbone).
In wireless network architectures like WLAN, beacon signals may be utilized to synchronize the operation of networked apparatuses. In situations where new ad hoc networks are being created, the initiating apparatus may establish standard network beaconing based on it owns clock, and all apparatuses that join the network may conform to this standard beacon. Similarly, apparatuses that desire to join an existing wireless network may synchronize to the existing beacon. In the case of WLAN, apparatuses may synchronize to beacon signals utilizing a timing synchronization function (TSF). The timing synchronization function is a clock function that is local to an apparatus that synchronizes to and tracks the beacon period.
An example of a beacon signal is shown in
In accordance with at least one embodiment of the present invention, functionality may be introduced utilizing the example distributed wireless network described above to allow apparatuses to operate at a standard beaconing rate that has been established in the network, or alternatively, using a “diluted” beaconing rate. “Diluted” beaconing may comprise a beaconing mode operating at a lower frequency than the standard beaconing rate originally established in the network. Diluted beaconing may be based on information (e.g., information elements) that is included in network beacon frames, wherein the included information may express one or more diluted beacon rates as multiples of the beacon. Using the beacon and the one or more associated diluted beacon period indications contained within beacon frames, networked apparatuses may elect to operate (e.g., via random contention) based either on the standard beacon or a diluted beacon period. In particular, all apparatuses may synchronize to the same initial target beacon transmission time (TBTT), for example when TSF=0, and may then count the number periods that occur after the initial TBTT based on the internal TSF function. In this way, apparatuses operating using a diluted beacon period may be active on TBTT counts that corresponds to the multiple defined by the diluted beaconing period.
An example diluted beacon interval of every 10th TBTT is disclosed in
For example, in a network comprising four apparatuses where devices 1, 2 and 4 operate using a diluted beaconing mode having a beacon interval (e.g., a time period between beacon transmissions) of every 6th TBTT, all apparatuses may remain synchronized even though only device 3 may be active (e.g., “competing”) in all beaconing periods 1, 2, 3, 4 and 5 (e.g., all apparatuses may participate in TBTT 0, TBTT 6, TBTT 12, etc.) Therefore, there can be at least two different beacon periods among the apparatuses, and possibly further diluted beacon periods as other groups of apparatuses may have selected their own diluted beaconing period based on the original beaconing period and the one or more associated diluted beacon period indications transmitted therewith.
In accordance with at least one example embodiment of the present invention, beacons will contain a diluted beacon period parameter. The diluted beacon period parameter may, for example, be carried in vendor-specific information elements (IEs). Diluted beacon period parameter values may remain the same for the lifetime of the network. However, should there be need for more flexibility, other beacon intervals may be defined, and all of the defined beacon intervals may be signaled in a manner similar to the diluted beacon interval.
Possible awake windows for an apparatus that is participating in the network are further shown in
The behavior of another example apparatus in accordance with at least one embodiment of the present invention is further disclosed at 650. While all apparatuses in the network will operate based on the same origin point (e.g., TSF=0) and normal beacon period (e.g., as set forth by the TBTT), each apparatus may select an operational mode based upon the one or more diluted beacon period indications that are transmitted in the beacon. For example, the apparatus corresponding to the activity disclosed at 650 is operating utilizing diluted beacon period 652, which is a multiple “4” in this scenario. Therefore, diluted beacon period 652 may involve beacon transmissions per every four TBTTs. Awake windows, for example as shown at 654, may also occur in accordance with the diluted beacon period 652. In at least one example implementation, the awake windows may begin just prior to the commencement of the diluted beacon period.
The duration of awake windows, while configured at constant duration by a predetermined information element (IE) in the beacon, may end up being variable in actual practice. For example, the awake window may be based on a MAC parameter that is similar to the beacon interval and diluted beacon period parameters. A host in the beaconing apparatus may determine it and provides it to the modem for transmission in the beacon. It may be communicated using, for example, a general or vendor specific information element (IE) as with the beacon interval and diluted beacon period. Upon awake window expiration apparatuses may attempt to transition to a “doze” or sleep state. However, the transition to doze state may, in actuality, happen earlier or later in accordance with control methodologies that will be discussed with respect to
The N-EQC state may comprise optional implementations: “Legacy” 700 and “Beacon Prioritized” 750. Using Legacy implementation 700, upon receiving or transmitting a beacon channel contention may be executed as in legacy devices, for example, as defined by the channel access rules specified in the particular wireless communication medium. Legacy implementation 700 represents an example of channel contention in accordance with an existing set of access control rules between 702 and 704. Once the apparatus gains access to media at 704 it will obtain a transmission opportunity (TXOP) during which it may transmit frames to the network (e.g., if one or more frames are queued for transmission. “TX” as shown between 704 and 706 in
In Beacon Prioritized implementation 750, the apparatus that has transmitted the network beacon is permitted to continue transmitting any frames that are queued for transmission in its transmit buffers. The apparatus obtains a TXOP for beacon transmission, and once it has transmitted the beacon at 752 it may automatically obtain a new TXOP, as shown at 754, to transmit any frames that are pending in its transmit buffers. In the disclosed example the new TXOP may start after a short interframe space (SIFS) period following the end of the beacon frame, which is represented in example 750 by the space shown between 752 and 754.
Once the apparatus has completed transmission (e.g., emptied its transmission buffers), it shall enter into an EQC state as shown in implementations 700 and 750 at 706 and 756, respectively. If an apparatus has no frames for transmission during a beacon interval, the device transition directly into an EQC state after the beacon reception/transmission (e.g., at 702, 752). When in the EQC state apparatuses may try to obtain a TXOP for a given number of times (determined, for example, by a “RepeatEmptyQueueContention” parameter). Upon obtaining a TXOP, apparatuses without pending messages may attempt to obtain a new TXOP as shown at 708/710 and 758/760 in implementations 700 and 750, respectively, instead of initiating the transmission of a frame sequence. Devices that obtain a number of TXOPs that is equal to a predetermined threshold value (e.g., RepeatEmptyQueueContention times) during a beacon interval may enter into doze or sleep state. In example implementations 700 and 750 in
The previous discussion addressed awake periods that may occur in accordance with a diluted beacon period according to at least one embodiment of the present invention. A diluted beacon period may allow apparatuses in the network to operate less frequently, which may lessen resource usage and extend operational life. Another periodic operation that may operate alone or in conjunction with diluted beacon periods involves scanning opportunities.
The duration of scanning opportunity 800 may also be defined based on an integer multiple of the network beacon signal interval. In the example embodiment of
An opportunity for an apparatus to be active in a network (e.g., for beaconing in accordance with the standard or diluted beacon period) may be presented during the same TBTT as scanning opportunity 800. However, in accordance with various embodiments of the present invention, apparatuses may opt not to participate in active network operations like beaconing in order to perform passive scanning. Example scanning operations, such as will be described below, may facilitate network expansion through scanning coupled with a response mechanism for conveying connectivity information to other apparatuses that may want to join the network.
An example of scanning opportunity operation is disclosed with respect to
As opposed to the operation described with respect to device A in
Further to the above example, apparatuses such as device A and B disclosed in
Using scanning opportunity 902 disclosed in
For example, network information messages may comprise network information such as contained in beacon frames including network size, basic service set identifiers (BSSID), network operating frequency, etc. Apparatuses in a network to which this packet is transmitted by a scanning device may process this frame in a manner similar to the processing of in-network scanning reports. Devices may individually decide whether to react to the discovery of the new network. If an apparatus decides to react to the discovery, the apparatus will begin operating in the found network. Apparatuses may either also continue operating in the old network or move all its operations to the new network. In the case of the former, the apparatus may form a kind of gateway between the two networks. In the case of the latter, the apparatus informs the other devices in the old network about its decision to leave the network.
An example of activities that may occur during scanning opportunity 902 is also described in
The above process may also apply if a dedicated management frame is specified. Normal frame reception rules may apply when receiving MyNetwork frames, since by default the transaction would involve normal data type frames. Apparatuses would not be expected to handle MyNetwork frames any differently from other data type frames. Further, the frames may be delivered to the host for further processing similar to other data type frames. Alternatively, a new management frame may be specified for this purpose. Operation may continue in the manner shown at 1004 and 1006 in
Apparatuses utilizing scanning opportunities to passively scan for other networks may transmit MyNetwork frames (e.g., 1002 and 1006) upon receiving beacon frames from other networks (e.g., a beacon with the same service set identifier (SSID) as the network in which the apparatus is operating). When scanning is initiated, apparatuses may first prepare a MyNetwork frame ready for transmission and then enter into the non-empty queue contention state. Beacon frames received from other networks may trigger normal channel access procedures, as defined by the wireless communication protocol being used, that may then conclude with MyNetwork frame transmission. Once an apparatus has broadcasted a MyNetwork frame, it may resume passive scanning and prepare another MyNetwork frame for the next encounter (e.g., further beacons received from other networks). After a scanning opportunity expires, the apparatus may reset channel access states and flush remaining MyNetwork frames from transmission queues.
In various embodiments of the present invention, scanning opportunities may be utilized by apparatuses within a network in order to advertise information about the network to apparatuses outside of the network. An obvious example where the benefit of such functionality would be apparent is when apparatuses enter operational spaces where previously undiscovered apparatuses and/or networks reside. However, this operation may also prove useful in situations where apparatuses were members of the larger network prior to the network losing integrity. For instance, an apparatus may be active in a large network. Links between some of the apparatuses that are participating in the large network may then become severed for a multitude of reasons (e.g., user walks out of range, public transportation such as bus or train enters a tunnel or goes below ground, etc.). Multiple networks may then result comprising members of the original large network: Initially, the network members whose link was severed from the apparatus may continue to operate in the original network. Then, network members that remain available to the apparatus (e.g., peripherals) may create a new smaller network (e.g., a local network). The new networks may operate as separate entities, but may retain the network identifier (e.g., BSSID) from the original network. As a result, it may appear to individual apparatuses within each of these networks that they are still operating in the original network, just with fewer apparatuses. Communication activities may then, such as in the examples described above, allow the two networks to recreate the original network when the apparatuses are again able to communicate.
The latter situation may correspond to the more general scenario disclosed in
Given the scenario presented in
In view of the problems that may be caused by network synchronization, it may prove beneficial to utilize a more informed determination when merging separate networks. The separate networks to be merged may actually be parts of a previously existing network, and thus, may use the same network identifier (the identifier from the previously existing network). An example tool that may be utilized to support such determinations is disclosed in
The BSSID is a 48-bit identifier corresponding to a particular Basic Service Set (BSS). In terms of the various embodiments of the present invention, the BSSID is used for the sake of example herein as network identification information provided by beacon signals that may be used to determine from which network a beacon signal was transmitted. As shown at 1202, the BSSID field is currently comprised of two defined indicator bits (“I/G” at bit 0 and “U/L” at bit 1) followed by 46 random bits. However, in accordance with at least one embodiment of the present invention it is proposed that the constitution of the BSSID field may be altered slightly in order to support network size indication without impacting the intended functionality of BSS identification. In the example proposed format shown at 1204, bits 2 through 5 have been reassigned for conveying network size while the remaining 42 random bits are utilized to identify the BSS. The four bits may be used to delineate sixteen states (e.g., “0” indicated by 0000 to “14” indicated by 1111). In accordance with at least one embodiment of the present invention, seven states are defined in chart 1206 found on the bottom of
In accordance with at least one embodiment of the present invention,
Instead of just considering device-level factors that may ignore what is happening at the network level, the various embodiments of the present invention seek to minimize impacts from one apparatus participating in a new network by considering relative network size. In the example of
A flowchart of an example communication process in accordance with at least one embodiment of the present invention is disclosed in
While the process disclosed in
However, if in step 1402 the network identifier of at least one network in which the apparatus is participating is determined to be the same as the network identifier included in the received network information message, then in step 1406 a further determination may be made as to whether the network information message that was received includes size information for the other network. If the network information message omits size information, then size cannot be utilized as a criteria for making a decision about how to manage inter-network synchronization. As a result, decisions regarding how to adjust timing may be made in step 1408 based on apparatus factors instead of network factors. For example, an apparatus entering a network may simply adopt the timing of the new network. Otherwise, an apparatus with operational limitations such as power and/or processing constraints may request that the network adopt its current timing in order to conserve resources. The process may then terminate in step 1404 and return to step 1400 in preparation for the next network information message.
If the network information message does comprise size information, then in step 1410 a further determination may be made as to whether the size of the other network is larger than the size of any network that currently includes the apparatus. A determination that the apparatus' existing network is larger than the other network may result in no action, wherein the apparatus does not synchronize to the other network. As a result, the process may be complete in step 1412 and may return to step 1400 in preparation for further network information messages. Alternatively, if the other network is deemed to be bigger that the current network of the apparatus, then in step 1410 the apparatus may synchronize its timing to the timing of the other network. For example, if the apparatus is not currently operating in a network, the other network would be considered larger (e.g., since it takes at least two apparatuses to form a network). The process may then terminate in step 1412 and return to step 1400 in preparation for further network information messages.
Further to the above, the various example embodiments of the present invention are not strictly limited to the above implementations, and thus, other configurations are possible.
For example, apparatuses in accordance with at least one embodiment of the present invention may comprise means for receiving a wireless message in an apparatus, means for determining if the received wireless message comprises a network identifier corresponding to a network in which the apparatus is participating, means for, if the received wireless message comprises a network identifier corresponding to a network in which the apparatus is participating, determining whether the received wireless message also comprises network size information, means for, if the received wireless message comprises network size information, comparing the network size indicated in the received wireless message to the network size the apparatus indicates in its own transmissions, and means for, if the network size indicated in the received wireless message is determined to be larger than the network size the apparatus indicates in its own transmissions, synchronizing timing in the apparatus to timing of the received wireless message.
At least one other example embodiment of the present invention may include electronic signals that cause apparatuses to receive a wireless message in an apparatus, determine if the received wireless message comprises a network identifier corresponding to a network in which the apparatus is participating, if the received wireless message comprises a network identifier corresponding to a network in which the apparatus is participating, determine whether the received wireless message also comprises network size information, if the received wireless message comprises network size information, compare the network size indicated in the received wireless message to the network size the apparatus indicates in its own transmissions, and if the network size indicated in the received wireless message is determined to be larger than the network size the apparatus indicates in its own transmissions, synchronize timing in the apparatus to timing of the received wireless message.
Accordingly, it will be apparent to persons skilled in the relevant art that various changes in form a and detail can be made therein without departing from the spirit and scope of the invention. The breadth and scope of the present invention should not be limited by any of the above-described exemplary embodiments, but should be defined only in accordance with the following claims and their equivalents.