This invention relates to adaptive communication for mobile router systems.
Providing radio communication services to a distributed set of clients can be challenging in the face of these clients moving in an environment and/or requiring varying communication capacity over a wireless medium, for example, for radio frequency communication over the air. One approach is to use a set of movable “routers” and to position those routers to satisfy the client requirements, or at least to approach full satisfaction of those requirements in a best possible manner according to an overall cost function that depends on the degrees to which the clients' requirements are satisfied.
In this description, the references to “routers” should be understood broadly as devices that route communication, without implication that they perform any particular type of processing or that they operate at any particular layer of a communication protocol stack. For example, in certain example that addresses wireless radio frequency data communication, the described routers function as WiFi access points (or repeaters) functioning at layer 2, and in other embodiments, the also router perform layer 3 functions. However, it should be understood that no particular processing of communication is essential for a device providing communication services to be considered to be a “router”. Similarly “client” should be understood broadly to be a communication node in communication with the router. For example, a client may be a computer, smartphone, or other fixed location or mobile device.
Examples in which positioning mobile routers can be important is in swarm robotic systems, which perform many complex tasks through coordination, such as cooperative search of an environment, consensus, rendezvous, and formation control. For example, Google's Project Loon, Facebook's Connectivity Lab, and similar projects envision using a network of controllable routers to provide wireless communication infrastructure in remote areas of the world. Beyond simply maintaining connectivity, reliable communication may include supporting heterogeneous and possibly time-varying communication rates amongst different pairs of agents. For example, some agents may need to use the network for transmitting video while others may simply wish to transmit status information.
The general problem of optimal placement of routers to service a set of spatially distributed clients has been address in previous work in Multi-Robot Coordination. Past work on this topic includes two classes of approaches.
The Euclidean Disk Model approach employs Euclidean disk assumptions where signal quality is assumed to be deterministic and mapped perfectly to the Euclidean distance between the communication nodes. A Euclidean metric allows for quadratic cost for the edges of the network and enables a geometric treatment of an otherwise complex problem. However, this approach can be limited because, in reality, signal strength suffers from large variations over small displacements.
More recently, efforts have focused on giving the communication quality over each link in the network a more realistic treatment by sampling the signal strength and building closed-loop controllers using this feedback. Stochastic Sampling Methods includes methods that either supplement theoretical models for signal strength with a stochastic component based on the collected samples, or use the collected samples to design stochastic gradient controllers However, in general, these approaches suffer inefficiencies associated with sampling, and associated router movement, needed to estimate the gradient, and suffer from local minimum problems inherent with such gradient approaches.
In other domains, direction of arrival information has been estimated for wireless clients using a variation of a Synthetic Aperture Approach, for example, as described in International (PCT) Patent Pub. WO2015/100237, titled “LOCALIZATION WITH NON-SYNCHRONOUS EMISSION AND MULTIPATH TRANSMISSION,” which is incorporated herein by reference. However, this or other approaches to acquiring direction or arrival information have not been applied to the problem of positioning mobile routers.
In a general aspect, an approach to adaptively positioning a set of mobile routers to provide communication services to a set of clients does not rely on a Euclidean model in which communication characteristics (e.g., signal strength, data rate, etc.) depend on distance between communicating nodes, as is assumed in general in Euclidean Disk Model approaches. Furthermore, one or more embodiments of the approach do not require sampling of communication characteristics in unproductive directions in order to move the routers to preferable locations as is done in certain Stochastic Sampling approaches.
In another aspect, in general, a method for adaptively locating a set of mobile routers provides wireless communication services to a plurality of clients. The method includes, at a first mobile router of the set of mobile routers, for each client of a set of clients of the plurality of clients that are in wireless communication with the first router, (a) determining a direction profile characterizing direction-dependence of one or more signal paths between the first router and the client, and determining using the direction profile directional information comprising at least one or a communication direction between the router and the client and a spread of the direction profile, (b) computing a deficiency in communication service associate with the client and the first router, and (c) providing the directional information and the deficiency in communication for determining a location for the first router. The determined location for the first router is then used to adapt the location of said router. In some examples, the router is caused to travel toward the determined location. This method can be performed at each mobile router of the set of mobile routers, and performed repeatedly to repeatedly update the location.
In another aspect, in general, software stored on a non-transitory machine readable medium includes instructions that when executed on a processor of a mobile router cause the processor to perform the method.
In another aspect, in general, software stored on non-transitory machine-readable media cause multiple processors, including processors of the mobile routers, to act together to adaptively updated locations of the set of mobile routers.
In another aspect, in general, a mobile router is configured to perform adaptively update its location according to a method specified above. In some examples, the mobile router comprises at least one of a robot, an unmanned vehicle, and aerial vehicle.
Other features and advantages of the invention are apparent from the following description, and from the claims.
Referring to
It should be understood that in the example shown in
In some embodiments, the overall quality of communication service is based on the service that can be provided to a particular client j by a particular router i. (To aid in the exposition below, in general, routers are index by the letter i and clients are indexed by the letter j). For a pair of nodes (i, j) the following real quantities relate to the service that can be provided between the nodes:
ρij>0 represents the available service to the client j from the the router i, for example, representing the Effective Signal to Noise Ratio (ESNR), which has a direct mapping to data rate.
Given the importance weighted fractional service deficiencies, an overall “max-min” cost is defined as
As introduced above, a goal is to reduce or minimize G by controlling the locations of the routers:
Another property of the system in a particular configuration relates to the directional characteristics communication between a particular client j by a particular router j. In general, in free space with no obstruction, reflections, or other factors that affect signal quality or propagation (e.g., attenuating walls, etc), the router would expect the signal from the client to be arriving in a direction θdir in the vector direction of pj−ci. However, in the presence other factors a router may observe a direction-dependent signal strength, which may or may not have a peak in the θdir direction, and that may also have multiple peaks, for example, due to multipath effects in the environment, with the direct path not necessarily corresponding to the strongest peak. As discussed below, for each a router-client pair (i, j) the following, the system maintains a direction estimate of
A number of related embodiments are described below to solve the problem for updating the desired locations of the routers. Based on information known at time t, including the current positions of the routers C(t), the system determines desired new locations for the routers, C*. These approaches are outlined below, and explained more fully later in this document.
Referring to
C*=arg minC{maxp
in which the minimization over C is over all tuples C=(c1, c2, . . . , cK) of joint router locations, and the minimization over ci ∈ C is effectively the assignment of the router to service the jth client. In at least some implementations, this computation is performed at a single node to which the required quantities (e.g., the locations of the routers and clients, and the service deficiencies) have been communicated.
The solution to the optimization of equation (1) is a variant of the well known and studied “K-centers” problem (also referred to as the “Facility Location” problem), which in its optimal form is known to be an NP-hard problem. Efficient solutions, including in the case of large numbers of clients, are described in D. Feldman, S. Gil, R. Knepper, B. Julian, and D. Rus. “K-robots clustering of moving sensors using coresets”, in ICRA, 2013, and in S. Gil, D. Feldman, and D. Rus. “Communication coverage for independently moving robots,” in IROS, 2012, which are incorporated herein by reference.
Note that an alternative to solving equation (1) in an optimal manner, a gradient approach may be used in which the gradient of the term in the brackets { } is computed with respect to each ci, and the routers are then moved in the most negative gradient direction.
Referring to
C*=arg minC {maxp
Referring to
The updated locations are then determined using the router location computation 320 (as in
C*=arg min
C {maxj∈[1, . . . , L] minc
As introduced above, the second and the third approaches make used of direction spread/certainties ρij, and in the case of the third approach, also make use of the direction estimates θijmax.
As introduced above, alternative versions of these three approaches make use of computation of the gradient of the bracketed term ∇c
c*
j
=c
i(t)+α2wijMij(pj−ci(t))
for a particular client j, and an optional positive value α, which determines a length of the position updates of the routers.
A number of approaches for computing a direction profile fij(θ) for a particular router-client (i, j) pair, for use in determining C* at time t make use of multiple transmissions between that router-client pair prior to time t. In some such embodiments, these transmissions occur during the travel of router from location ci(t−Δt) to location ci(t). In general, the system determines complex channel estimates hij(t) (i.e., representing magnitude and phase) at an increasing sequence to times t0=t−Δt, t1, t2, . . . , tm=t (which are in general different for each (i, j) pair). Using an approach described in detail in International (PCT) Patent Pub. WO2015/100237, titled “LOCALIZATION WITH NON-SYNCHRONOUS EMISSION AND MULTIPATH TRANSMISSION,” the direction profile is formed as
where assuming that the path from ci(t−Δt) to ci(t) is a straight line at an absolute angle θi=∠(ci(t)−ci(t−Δt)), d(τ) is the scalar distance along that line. Note that it is not essential that the router travel in a straight line, and vector displacements {right arrow over (d)}(τ) can be used instead of scalar displacements in an expression {right arrow over (d)}(τ)·{circumflex over (v)}θ instead of d(τ)cos(θ), where {circumflex over (v)}θ is a unit vector in the θ direction. Also note that in situations in which the router has multiple antennas (e.g., for a Multiple-Input Multiple-Output, MIMO, communication approach), each antenna contributes separately to the direction profile.
As introduced in Patent Pub. WO2015/100237, the routers and clients are independent in that they have local oscillators that, in general, exhibit frequency offsets. Unfortunately, even a small offset Δf in the frequency of the oscillators introduces a time varying phase to the wireless channel. For instance, let h(t0), h(t1), . . . , h(tm) be the actual wireless channel from the robotic client to the robotic router at times t0, t1, . . . , tm. The channel observed by the router (to with a constant unit magnitude term) from its client ĥ(t0), ĥ(t1), . . . , ĥ(tm) are given by:
ĥ(t0)=h(t0), ĥ(t1)=h(t1)e−2πΔ
One approach to addressing this time-varying phase is presented in Patent Pub. WO2015/100237 through the use of a stationary antenna in conjunctions with a moving antenna, each demodulated by a same local oscillator. In the use cases introduced above, in general, a moving router cannot take advantage of such a stationary antenna. Note that in general, the phase offsets will not be precisely the result of a constant frequency difference Δf, and the terms 2πΔf(tm−t0) are replaced with φm without any change in the procedure.
In another approach to addressing the time varying phase is rather than having a fixed antenna, each router has a rotating antenna, and a fixed antenna that is maintained in a fixed relative position to center of rotation of the rotating antenna. In the case that the relative position is in or fixed relative to the direction of travel of the router, then the prior approach can be used directly. Similarly, two or more moving antennas on the router (e.g., two rotating antennas 180 degrees offset in rotation) can be used to acquire transmissions from the clients to determine directional information while compensating for frequency and phase offset between the router and the clients.
Direct application of the techniques presented in WO2015/100237 that use moving antennas on the routers may increase the complexity, cost, weight, etc., of the router, and also do not directly take advantage of the motion the router itself A new approach permits the router to have a single antenna (or multiple antennas is a configuration that has a relatively fixed orientation) and to take advantage of the motion of the router itself, while also addressing the frequency (and phase) offsets described above. It should be understood that although this approach is particularly applicable to the case of controlling mobile routers as described herein, the approach has much wider applicability, for example, to situations described in Patent Pub. WO2015/100237, including in situations that address multipath and identification of most direct directions of arrival.
Referring to
ej2πft
while the LO of the client generates a signal
ej(2π(f+Δf)t+ψ)
for a frequency offset Δf, and a phase offset ψ, which is not assume constant between the pairs of transmissions 510-520.
Referring to
B=|h
f
|Ae
−j(2πfΔT+ψ)
=|h
f
|Ae
−j2πfΔT
−jψ
where |hf| is the magnitude of the channel, and ΔT is the propagation time between the router 110 and the client 120. Therefore, the client estimates the channel from the router to the client as
h
f
=|h
f|e
−j2πfΔT
e
−ψ
which as can be seen differs from a desired channel estimate by e−jψ.
Within a fixed (or alternatively known) time δt, client sends a packet 630, with a known signal C 632, to the router, which receives it as packet 640, and demodulates the received symbol D 642. We assume in this example, that the client 120 communicates its estimate hf, or one or more quantities that permit the router to compute hf (e.g., by transmitting B or a function of B). The router then makes an estimate of the reverse channel as
h
r
=|h
r
|e
−j2πfΔT
e
+jψ
which as can be seen differs from a desired channel estimate by e+jψ.
In this example, the router uses the computed reverse channel, and an assumption that |hr|=γ|hf| and the client's estimate of hf to compute a channel estimate as
h=√{square root over (hfhr/γ)}=√{square root over ((B/A)(D/C)/γ)}{square root over ((B/A)(D/C)/γ)}=√{square root over (|hf∥hr/γ)}e−j2πfΔT
This channel estimate is used as h(t) in the sum of the m terms to form f(θ) as set forth above (see equation (4)). For simplicity, the quantity γ is dropped (or assumed equal to 1) because it does not enter into further computations.
Referring to
h=√{square root over (hfhr/γ)}=√{square root over ((B/A)(D/C)/γ)}{square root over ((B/A)(D/C)/γ)}=√{square root over (|hr∥hr|γ)}e−j2πfΔTe+δtΔf/2
This channel estimate is used as h(t) in the sum of the m terms to form f(θ) as set forth above (see equation (4)). To the extent that δt and Δf are relatively constant over the m exchanges between the router and the client, this phase term does not affect the resulting directional profile f(θ).
As an alternative to computing f(θ) as described above, a “squared” version can be computed as
thereby avoiding the necessity of computing the square root above.
In some implementations, the profile f(θ) is evaluated only at a representative set of D directions (e.g., θk=2πk/D) by accumulating the complex sums at each of these directions, and after the m transmissions, determining the D magnitudes.
It should be understood that this way of using reciprocity is only one example. For instance, using m interchanges between a router and a client, the client may send C=B and the router the uses √{square root over (D/A)} to compute the estimated channel. In other examples, a router does not necessarily have to have a direct interchange with a client to estimate the channel using reciprocity. For example, a second router may overhear the transmission of C (i.e., receiving D′) and knowledge (e.g., prior knowledge, or by receiving them from the first router) of the quantities A, B, C, D as well as an exchange of messages with the first router to determine a phase correction for a channel estimated using D′/C.
As introduced above, for example as illustrated in
As discussed above, each router i and for a number of clients j, the router collects channel estimates hij at a number of points along its trajectory. For a particular (i, j) pair, the router collects m channel estimates hij at corresponding distances di along its trajectory, for example, as illustrated in
In the implementation shown in
Each profile is also evaluated to determine a quantity characterizing a spread or certainty of the determined maximum direction, with is denoted using the variable σ. One approach to computing this quantity uses the following sequence of calculations:
Alternative to the continuous integration, equivalent discretized summations may be used. Note that σ can range from close to zero for a direction profile with a single very sharp peak, to one for a uniform direction profile, to quantities greater than one for example, in the case of multiple peaks (e.g., as a result of multi paths).
There are alternative approaches to computing the spread or certainty. For example, a second moment of {tilde over (f)}(θ), a circular distribution, can be used. Other alternatives may consider the “mass” for the direction profile in the vicinity of the maximum direction, or equivalent percentile ranges.
As introduced above, in some embodiments, the spread quantities σ are used to form weighted distances. Recall that in the first approach (i.e., equation (1)), a Euclidean distance between a router at location ci and a client a location pj is computed as
∥ci−pj∥2=(ci−pj)T(ci−j)
while in the second and third approaches a weighted (Mahalanobis Distance) approach quantity
(ci−pj)T Mij(ci−pi)
is used in place of the Euclidean distance.
One approach to computing M (omitting the ij subscript) uses θmax and σ. A unit vector {circumflex over (v)}max is in the direction between the router and the client in the (ci−pj) direction. A unit vector {circumflex over (v)}⊥max is perpendicular to {circumflex over (v)}max. The weighting matrix M is selected to not scale distances in directions perpendicular to {circumflex over (v)}max, and to scale Euclidean distance by 1/σ2 in the {circumflex over (v)}max direction. This type of scaling is achieved with the computation
M=QΛQT
where
Note that if σ=1, no directional weighting is performed. When the direction profile is peaked and σ<1, the optimization preferably moves routers towards the such clients. When the direction profile is multi-peaked and σ>1, the optimization de-weights distances to those clients.
As introduced above, in the thirds approach, which is illustrated in
p′
ij
=c
i(t)+γwij {circumflex over (v)}ijmax
which is a point at a distance γwij away from the router in the maximum direction to the client. Recall that wij is larger if there is a greater deficiency in the service to the client, and therefore the optimization will preferentially move the router toward that client. The constant γ is chosen to be greater to cause greater changes in desired locations for the routers.
As introduced above, the approach can be implemented as a two-dimensional or a three-dimensional solution. Two-dimensional solutions are appropriate, for example, for a ground based situation for example, in locating robot-based routers in a factory with many obstructions and moving robot and/or human-based clients. Three-dimensional clients are appropriate, for example, in locating aerial routers to service ground-based or aerial clients. Although specific equations are presented, in general, for a two-dimensional implementation, analogous three-dimensional forms can be used. For example, as described in WO2015/100237, three-dimensional direction profiles, which depend on two scalar angular quantities, are formed. In the three-dimensional case, in some embodiments multiple antennas and/or non-linear (e.g., arced) trajectories are used to mitigate ambiguity in the maximum angle in the direction profile.
Referring to
Implementations of the approaches described above may use software stored on machine-readable media. The software can include instructions for causing processors, for example, processors in the routers and in some embodiments in the client nodes. In some implementations, some of the processing, for example channel estimation using reciprocity, is implemented in a processor in a software-based radio. In some implementations, the router location updating is performed at a central server, while in other implementations, each router computes part of the router repositioning optimization in a distributed manner. Some embodiments implement at least part of the functions (e.g., channel estimation) in hardware, for example, using Application Specific Integrated Circuits (ASICs).
It is to be understood that the foregoing description is intended to illustrate and not to limit the scope of the invention, which is defined by the scope of the appended claims. Other embodiments are within the scope of the following claims.
This application claims the benefit of U.S. Provisional Application No. 62/069,496 filed Oct. 28, 2014, which is incorporated herein by reference.
This invention was made with Government support under Contract No. FA8721-05-C-0002 awarded by the U.S. Air Force and under Grant No. W911NF-08-2-0004 awarded by the Army Research Laboratory. The Government has certain rights in the invention.
Number | Date | Country | |
---|---|---|---|
62069496 | Oct 2014 | US |