Embodiments presented in this disclosure generally relate to controlling network Access Points (APs) in communication networks. More specifically, though not exclusively, embodiments disclosed herein relate to dynamically clustering APs based on radio frequency (RF) constellations.
Many wireless communication networks use one or more controllers to manage APs in the network. For example, one or more Wireless Local Area Network (LAN) Controllers (WLCs) can be used to manage various RF properties of the network, including the AP channels, AP transmit power, etc. In some cases, the controller(s) can optimize various RF properties for APs in an RF neighborhood. As one example, a controller (or group of controllers working together) can iteratively compare RF properties of one AP to the RF properties of other nearby APs, and use these comparisons to change and optimize the RF properties of the APs.
But as the size of the RF domain (e.g., the number of radios in a given RF group) increases, so does the complexity of coordinating power and channels. To address this, some vendors set a maximum complexity limit beyond which a given group cannot scale. For example, a vendor could set a limit of 1000 APs and 20 controllers in a group. Beyond this max number of APs, coordination of RF properties may not work. This can be a problem for large wireless deployments.
So that the manner in which the above-recited features of the present disclosure can be understood in detail, a more particular description of the disclosure, briefly summarized above, may be had by reference to embodiments, some of which are illustrated in the appended drawings. It is to be noted, however, that the appended drawings illustrate only typical embodiments of this disclosure and are therefore not to be considered limiting of its scope, for the disclosure may admit to other equally effective embodiments.
To facilitate understanding, identical reference numerals have been used, where possible, to designate identical elements that are common to the figures. It is contemplated that elements disclosed in one embodiment may be beneficially utilized on other embodiments without specific recitation.
Overview
Embodiments described herein include a method of assigning APs to wireless network controllers. The method includes generating one or more RF constellations for a plurality of APs in a wireless network. The RF constellations are organized based on estimated RF distances among the plurality of APs. The method further includes clustering, based on the RF constellations and the estimated RF distances, the plurality of APs into a plurality of groups of one or more APs. The method further includes assigning each group, of the plurality of groups, to a wireless network controller.
Embodiments described herein further include a system. The system includes a processor and a memory storing a program, which, when executed on the processor, performs an operation. The operation includes generating one or more RF constellations for a plurality of APs in a wireless network. The RF constellations are organized based on estimated RF distances among the plurality of APs. The operation further includes clustering, based on the RF constellations and the estimated RF distances, the plurality of APs into a plurality of groups of one or more APs. The operation further includes assigning each group, of the plurality of groups, to a wireless network controller.
Embodiments described herein further include computer program product for assigning APs to wireless network controllers. The computer program product includes a computer-readable storage medium having computer-readable program code embodied therewith, the computer-readable program code executable by one or more computer processors to perform an operation. The operation includes generating one or more RF constellations for a plurality of APs in a wireless network. The RF constellations are organized based on estimated RF distances among the plurality of APs. The operation further includes clustering, based on the RF constellations and the estimated RF distances, the plurality of APs into a plurality of groups of one or more APs. The operation further includes assigning each group, of the plurality of groups, to a wireless network controller.
As discussed above, coordinating relatively large groups of APs in RF neighborhoods can be very challenging. In a wireless network based on discrete groups, where no location would expect more than an upper limit of APs in range of one another, this may not be a problem. In an embodiment, in this scenario controllers can create sub-groups of APs in which the APs in each group are within range of each other, but are not within range of other groups of APs.
As AP density increases, however, creating isolated groups may be impossible. Today, a WLAN Controller can support thousands of APs that can cover a small city with a blanket of contiguous wireless network coverage. A deployment encompassing these access points can manifest various levels of RF densities and therefore, RF grouping mechanisms that put all APs under one controller (or a group of controllers) face scale challenges, with multiple adjoined sites resulting in a continuous RF neighborhood. For example, public venues like large stadiums, convention centers, or conference centers can include such a wireless deployment. In this type of deployment, the RF domain is contiguous. Each AP can hear some others, and there is no clear point where an RF network boundary should be set.
Techniques disclosed herein address this problem through dynamic RF clustering that is aware of RF presence between the APs. That way, small sets of collocated APs that reside in the same RF space can form localized RF clusters on which RF optimizations can be performed. In order to prevent cascading effects due to subsector optimization, the clustering algorithms maintain tradeoffs between including too many neighboring access points and neglecting strong RF neighbors that should be included in optimizations. In one or more embodiments disclosed herein this can be achieved by automatically creating an AP constellation, organized by respective RF distance, and then dynamically clustering the APs based on their RF proximity in the constellation. This also allows for the allocation of groups to different controllers so as to share the RF optimization computing load across multiple units, while still allowing for optimization of the deployment as a whole.
The radio components 220 include the components necessary for the AP to act as an Access Point in a wireless network. For example, the radio components 220 can includes two radios, where the first radio is a dedicated 5 GHz radio that transmits signals in the 5 GHz frequency band and the second radio is a XOR radio that can dynamically switch between the 2.4 GHz and 5 GHz frequency bands. That is, the second radio can transmit signals in either the 2.4 GHz frequency band or the 5 GHz frequency band. The two radios in an AP can be active simultaneously on the same frequency band or on different frequency bands. For example, the XOR radio and the dedicated 5 GHz radio in an AP can simultaneously transmit signals in the 5 GHz frequency band by using different channels of the 5 GHz frequency band.
Although memory 210 is shown as a single entity, memory 210 may include one or more memory devices having blocks of memory associated with physical addresses, such as random access memory (RAM), read only memory (ROM), flash memory or other types of volatile and/or non-volatile memory. The memory 210 generally includes program code for performing various functions related to use of the AP. The program code is generally described as various functional “applications” or “modules” within the memory 210, although alternate implementations may have different functions and/or combinations of functions. Within the memory 210, the radio discovery module 212 is generally configured to identify nearby APs as part of generating an RF constellation.
The WLC 250 includes a processor 252, a memory 260, and radio components 270. The processor 252 generally retrieves and executes programming instructions stored in the memory 260. The processor 252 is included to be representative of a single central processing unit (CPU), multiple CPUs, a single CPU having multiple processing cores, graphics processing units (GPUs) having multiple execution paths, and the like.
Although memory 260 is shown as a single entity, memory 260 may include one or more memory devices having blocks of memory associated with physical addresses, such as random access memory (RAM), read only memory (ROM), flash memory or other types of volatile and/or non-volatile memory. The memory 260 generally includes program code for performing various functions related to use of the AP. The program code is generally described as various functional “applications” or “modules” within the memory 260, although alternate implementations may have different functions and/or combinations of functions.
Within the memory 260, the constellation module 262 generates RF constellations of APs. The clustering module 264 clusters APs based on the constellations. In an embodiment, the constellation module 262, the clustering module 264, or both, can be implemented in an AP (e.g., stored in the memory 210 for execution by the processor 202) or in another suitable network component. For example, the constellation module 262, the clustering module 264, or both can be implemented in any component that receives RF information from the APs. Implementing the constellation module 262 and the clustering module 264 in a WLC 250 is merely one example embodiment.
The radio components 270 include the components necessary for the WLC to communicate with APs and other network components.
At block 304, a clustering module (e.g., the clustering module 264 illustrated in
At block 404, the constellation module estimates the RF distance of the selected anchor AP to its neighbors based on RF signal level. In an embodiment, an AP can learn about its RF neighbors (e.g., APs within RF communication distance) through neighbor messages. For example, some wireless networks APs are configured to send neighbor discovery messages to facilitate this knowledge. In other networks, beacons or messages resulting from each AP's normal activity are used. The discussion related to block 404 focuses on the use of neighbor discovery messages, but any other suitable discovery technique can be used.
In an embodiment, a radio discovery module (e.g., the radio discovery module 212 in
At block 406 the radio discovery module in the anchor AP locates neighbors using angle of arrival (AoA) information. In some circumstances, AoA information is available for the discovery message received at the anchor AP from the neighboring AP. If AoA information is available, the constellation module can combine this information with the RF distance estimate and use it to locate the neighboring AP. The neighboring AP is then marked or saved as fully located (e.g., in a table or database stored in the anchor AP, in a WLC, or in another suitable location), meaning that further location processing (e.g., the trilateration techniques discussed below) is not necessary for that neighboring AP.
At block 408, the radio discovery module in the anchor AP locates the remaining neighbors (e.g., neighbors for which AoA information is not available). In an embodiment, the radio discovery module does this using trilateration techniques. This is discussed further with regard to
While techniques disclosed herein can provide for generally accurate RF constellations of APs, as RF distance increases between APs, the accuracy of the relative distance and position determination can decrease. According to one or more techniques disclosed herein, however, this effect is limited for APs with a higher number of neighbors (as this provides more reference points to compute from). Thus, the less accurate estimates are likely to occur for APs with a relatively low number of neighbors—but the cluster to which these APs should be assigned is likely to be less ambiguous (since they have relatively fewer neighbors), and so the less accurate constellation estimates should not affect the eventual clustering.
At block 410, the constellation module determines whether the last anchor AP has been analyzed. If not, the flow returns to block 402 and the constellation module selects the next anchor AP. If so, the constellation module merges the constellations from the various anchor APs.
In an embodiment, after block 410 the constellation module has generated a constellation for each selected anchor APs. But the constellation module has not determined the relative locations and distances between these constellations. In an embodiment, the constellation module does this by first identifying shared APs across constellations and merging the constellations in 2-D space. The constellation module then constructs the distance between non-neighboring APs (e.g., across constellations) in 2-D space. This can be done by identifying paths between APs using intermediate, neighboring APs. This is discussed further in relation to
At block 504, a constellation module (e.g., the constellation module 262 illustrated in
For example, the constellation module can identify a number of candidate positions for each un-located AP. Where AoA is available but distance is unreliable, this set will be located on a line moving radially outwards from the candidate AP at the measured angle of arrival. Where AoA is not available but a distance estimate is available, this set will be located on a circle surrounding the candidate AP at the estimated radius. For each set of given locations for the APs being located, a cost metric can be derived from a joint Gaussian distribution based on the distance difference among all neighbors. The variance can be derived from the absolute distance of the neighbor AP to the anchor AP (e.g., a closer distance results in a smaller likely error). The constellation module can then perform either a direct search or a gradient descent search among the possible locations to identify the likely location.
At block 602, a constellation module (e.g., the constellation module 262 illustrated in
At block 606, the constellation module maps the first AP to the origin of the constellation (e.g., the 0,0 point). This is illustrated in
In an embodiment, a constellation module (e.g., the constellation module 262 illustrated in
In an embodiment, the constellation module finds the shortest piece-wise path of neighborhoods that connects the two APs. For example, since AP3 and AP5 are not neighbors, the piecewise path may be AP3→AP1→AP5, each of which are neighbors. If no such path exists, then the distance between AP3 and AP5 is assumed to be infinite. For each AP in the middle (e.g., AP1), the constellation (e.g., the constellation 806) is super-imposed on the neighboring AP's constellations. After the completion of the constellation super-imposition process, a piecewise linear shape is formed that connects the two APs (AP3 and AP5). The constellation module can then compute the shape of this piecewise-linear connection, and can use that to deduce the direct distance between the end points AP3 and AP5.
In an embodiment, the cluster size can be determined based on a computing constraint to be put to the system. For example, a system administrator (or a dynamic system component) can determine that clustering should attempt to limit the number of APs in a group to a limit (e.g., 800), or to a range (e.g., 400 to 800 APs). If the number of APs across WLCs in a given RF domain exceeds the limit, the clustering algorithm is triggered to create two groups of less than the maximum number of allowed APs (and more than the minimum, if a range is used). In another embodiment, a clustering module (e.g., the clustering module 264 illustrated in
In an embodiment, the cluster determination attempts to find groups of APs with the lowest RF boundary region. In this embodiment, the number of APs in each group may be different. In another embodiment, the cluster determination attempts to create groups of equal sizes (e.g. 3 groups of 800 APs), so as to spread the computing load equally. In another embodiment, the cluster determination creates groups of APs with the lowest RF boundary region, but also limits the cluster size based on the target supporting WLC capabilities. In an embodiment, some WLCs may have more computing capabilities than others, and may therefore be able to handle coordination of more APs.
For example, consider 2400 APs spread across three WLCs (two powerful models and one relatively weaker model of WLC). The clustering module could be configured allocate 1000 APs to each of the more powerful WLC platforms and 400 to the less powerful WLC platform, based on capability weights allocated by the vendor, the administrator, or any other entity. Any variation around these three embodiments is possible. It should also be noted that, for all embodiments, the number of APs allocated to each WLC does not need be a strict number, but can be a range, as explained above, in order to find the best group boundary within a range of APs.
At block 902, a clustering module (e.g., the clustering module 264 illustrated in
At block 904, the clustering module removes neighbors with a signal strength below a threshold. As discussed above in relation to
At block 906, the clustering module constructs groups of neighboring AP. In an embodiment, the clustering module picks an AP for each initial group—for example, if three groups are selected at block 902, the clustering module can select three APs. In an embodiment, the clustering module selects these APs at random. Alternatively, the clustering module selects the APs with largest number of neighbors.
The clustering module then constructs a group of neighbors APs based on RF signal metric (e.g., RSSI) proximity. In an embodiment, the clustering module constructs a Voronoi diagram by initiating K cluster centroids. This can be represented by the equation μc
At block 908, the clustering module moves APs between groups based on the distance of the APs from the group centroid. In an embodiment, the clustering module determines the Euclidian distance of each xi from each group centroid. For each xi, the clustering module chooses the cluster centroid at the smallest Euclidian distance. For example, let c(i) be the index of that nearest centroid μc
minc
Once the clustering module has associated each xi with the nearest μc
minμΣi=1kΣx∈c
The result of this iterative process is a set of clusters, with K groups of APs organized around their smallest RF distance. The techniques discussed above are merely one example implementation. Other techniques can be used instead of, or in addition, to these techniques to generate a set of clusters organized around RF distance.
If a specific number of clusters is desired, organized to minimize RF distances, the flow stops after block 908. Each resulting cluster could have a different number of participating APs. The boundary between groups is based on the largest RF distance between groups. In other words, each member of each group is close (from an RF standpoint) to the other members of the same group, but each group is far (from an RF standpoint) from the other groups and their members.
But as discussed above, the clustering can also be configured to generate clusters with the same number of APs in each cluster, or with the number of APs in each cluster configured for the capabilities of the WLCs. At block 910, the clustering module adapts cluster sizes to meet these requirements. For example, if each cluster is required to have a number of APs falling within a range (e.g., 400-800 APs in each cluster), the size of each cluster can be adjusted to meet this requirement.
For example, the clustering module can sort the clusters by the initially computed sizes. Then, for each cluster larger than the target final size, the clustering module can select each member of the cluster, and calculate the Euclidian distance to the cluster centroid. The clustering module can then build a heap, and compute the distance of each of the members above the target group population threshold to the next nearest cluster. The clustering module can swap one extra member to the next nearest cluster (based on the smallest sum of Euclidian distance to the current cluster and the neighboring cluster centroids), then re-compute the cluster. The clustering module can repeat this until the group reaches the target population number.
In addition, the techniques disclosed herein can be used to provide further functionality to the network controllers. For example, the controllers could be configured to compute RF properties in an order based on the constellation and clustering. For example, the controllers could be configured to first re-compute the channel and power plan for the cluster with the highest number of APs, the cluster associated to the WLC of highest capacity, or the cluster of smallest Euclidian diameter. The controllers could then exchange messages and re-compute the next group in line, which will in turn take into account the resulting first group RF results (e.g., the new RF map) to compute its own power/channel plan.
In the preceding, reference is made to embodiments presented in this disclosure. However, the scope of the present disclosure is not limited to specific described embodiments. Instead, any combination of the described features and elements, whether related to different embodiments or not, is contemplated to implement and practice contemplated embodiments. Furthermore, although embodiments disclosed herein may achieve advantages over other possible solutions or over the prior art, whether or not a particular advantage is achieved by a given embodiment is not limiting of the scope of the present disclosure. Thus, the preceding aspects, features, embodiments and advantages are merely illustrative and are not considered elements or limitations of the appended claims except where explicitly recited in a claim(s).
As will be appreciated by one skilled in the art, the embodiments disclosed herein may be embodied as a system, method or computer program product. Accordingly, aspects may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, aspects may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.
Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium is any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus or device.
A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
Computer program code for carrying out operations for aspects of the present disclosure may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
Aspects of the present disclosure are described below with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments presented in this disclosure. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
These computer program instructions may also be stored in a computer readable medium that can direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or other devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
Embodiments of the invention may be provided to end users through a cloud computing infrastructure. Cloud computing generally refers to the provision of scalable computing resources as a service over a network. More formally, cloud computing may be defined as a computing capability that provides an abstraction between the computing resource and its underlying technical architecture (e.g., servers, storage, networks), enabling convenient, on-demand network access to a shared pool of configurable computing resources that can be rapidly provisioned and released with minimal management effort or service provider interaction. Thus, cloud computing allows a user to access virtual computing resources (e.g., storage, data, applications, and even complete virtualized computing systems) in “the cloud,” without regard for the underlying physical systems (or locations of those systems) used to provide the computing resources.
Typically, cloud computing resources are provided to a user on a pay-per-use basis, where users are charged only for the computing resources actually used (e.g. an amount of storage space consumed by a user or a number of virtualized systems instantiated by the user). A user can access any of the resources that reside in the cloud at any time, and from anywhere across the Internet. In context of the present invention, a user may access applications (e.g., the constellation module 262 or the clustering module 264) or related data available in the cloud. For example, the constellation module or the clustering module could execute on a computing system in the cloud and generate the constellation and clusters for the APs.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality and operation of possible implementations of systems, methods and computer program products according to various embodiments. In this regard, each block in the flowchart or block diagrams may represent a module, segment or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
In view of the foregoing, the scope of the present disclosure is determined by the claims that follow.
Number | Name | Date | Kind |
---|---|---|---|
9673515 | Crowley | Jun 2017 | B2 |
20100141483 | Thacher | Jun 2010 | A1 |
20140204841 | Ruiz Delgado | Jul 2014 | A1 |
20180045821 | Lee | Feb 2018 | A1 |
20180048349 | Sun | Feb 2018 | A1 |
20180338324 | Kela | Nov 2018 | A1 |
20190007079 | Zhang | Jan 2019 | A1 |
20190028318 | Chakraborty | Jan 2019 | A1 |
20190149199 | Ferrante | May 2019 | A1 |
20190349224 | Chiskis | Nov 2019 | A1 |
20190372710 | Chen | Dec 2019 | A1 |
Entry |
---|
RF Management 802.11a and 802.11g RF Management Profiles [Accessed Online] <https://www.arubanetworks.com/techdocs/ArubaOS_63_Web_Help/Content/ArubaFrameStyles/AP_Config/RF_Management.htm>. |
Aerohiive Networks, “Cooperative Control Wireless LAN Architecture,” 52 pages, 2012. |
Radio Resource Management White Paper, RF Grouping, 18 pages. |
Huawei Technologies Co., LTD, “WLAN High-Density Coverage Technology White Paper,” 23 pages, 2014. |
Number | Date | Country | |
---|---|---|---|
20200092793 A1 | Mar 2020 | US |