The invention relates in general to methods for determining positions of transducers (e.g., antennas) configured for receiving and/or transmitting wave signals, as well as related devices and systems. In particular, it is directed to methods for designing phased-arrays according to a specified, target beamshape. It also relates to beamforming techniques, i.e., methods for beamforming signals or computing beamformed signals, by explicitly targeting designed regions of interest.
Beamforming combines networks of antennas or sensors coherently so as to achieve a beamshape with desirable properties such as high directivity, reduced side-lobes, and improved signal-to-noise ratio (SNR).
Beamforming is often thought of as steering the array to focus on a particular point. This conception, however, has a number of drawbacks. It cannot adjust for small errors in direction of interest estimates, nor cope well with moving devices. Additionally, often a region or regions is what is desired, e.g., to scan the sky in radio astronomy or an organ in ultrasound.
The so-called flexibeam framework [P. Hurley and M. Simeoni, “Beamforming towards regions of interest for multi-site mobile networks,” in International Zurich Seminar on Communications, 2016, p. 94] was developed to determine, in a data independent fashion, beamforming weights so as to target a general spatial region. The framework takes as input fixed antenna locations, and approximates the target beamshapes.
According to a first aspect, the present invention is embodied as a method for determining positions {pi}i=1, . . . , N of transducers {Ai}i=1, . . . , N of an apparatus. The transducers are assumed to be configured for receiving wave signals from and/or transmitting wave signals to one or more regions {Rm}m=1, . . . , M of interest in an n-dimensional space, with n=2 or 3. The method relies on an n-dimensional spatial filter function {circumflex over (ω)}e(r), which is determined so as to match projections {Pm}m=1, . . . , M of the one or more regions {Rm}m=1, . . . , M of interest onto an n−1-dimensional sphere centered on the apparatus. Then, a density function ƒb(p) is obtained, based on a Fourier transform ω(p) of the determined spatial filter function {circumflex over (ω)}e(r). Finally, a position pi is determined, within said n-dimensional space, for each of N transducers, based on the obtained density function ƒb(p) and a prescribed number N of the transducers.
According to another aspect, the invention is embodied as a system comprising an apparatus with a set of N transducers {Ai}i=1, . . . , N. The transducers are configured, in the apparatus, for receiving wave signals from and/or transmitting wave signals to one or more regions {Rm}m=1, . . . , M of interest in an n-dimensional space, with n=2 or 3. Moreover, and consistently with the above method, the transducers are arranged at positions {pi}i=1, . . . , N within said n-dimensional space, wherein said positions {pi}i=1, . . . , N corresponds to arguments of values {ƒb(pi)}i=1, . . . , N of a density function ƒb(p) obtained based on the Fourier transform ω(p) of the n-dimensional spatial filter function {circumflex over (ω)}e(r). As said above, the latter is determined so as to match projections {Pm}m=1, . . . , M of the one or more regions {Rm}m=1, . . . , M of interest onto the n−1-dimensional sphere, centered on the apparatus.
Finally, and according to a further aspect, the invention can be embodied as a computer program product for determining positions of such transducers. The computer program product comprises a computer readable storage medium having program instructions embodied therewith, wherein the program instructions are executable by a computerized system to cause the latter to implement steps according to the present methods.
Devices, apparatuses, systems, methods and computer program products embodying the present invention will now be described, by way of non-limiting examples, and in reference to the accompanying drawings.
In
The accompanying drawings show simplified representations of devices and components (e.g., transducers) thereof, as involved in embodiments. Similar or functionally similar elements in the figures have been allocated the same numeral references, unless otherwise indicated. Density plots represented in the figures have been purposely applied a high contrast, for the sake of depiction.
The present Inventors noticed that the existing beamforming techniques, although powerful, gave no hints on where to place the transducers. For instance, The flexibeam framework evoked in the background section takes as input fixed antenna locations to approximate the target beamshapes. Therefore, the Inventors took up the challenge to provide solutions to the problem of transducer positioning. They have accordingly achieved methods for designing transducer layouts based on given, specified target regions, wherein transducer locations are obtained from a probabilistic density function. Such methods are all the more suited for applications to phased-arrays, taking as input a given, target beamshape.
The following description is structured as follows. First, general embodiments and high-level variants are described (sect. 1). The next sections (sect. 2-4) describe specific embodiments, examples of applications, and technical implementation details, respectively.
In reference to
Generally speaking, the transducers are devices configured for receiving wave signals from and/or transmitting wave signals to one or more regions {Rm}m=1, . . . , M of interest. The devices {Ai}i=1, . . . , N may be receivers, transmitters or transceivers. In all cases, such devices convert a signal in one form of energy to a signal in another form of energy. In particular, the transducers might be bidirectional, e.g., like antennae, which can convert electrical signals to or from propagating electromagnetic waves, and ultrasound coils, which convert electrical signals into/from ultrasounds. In general, the signals received by and/or transmitted from the transducers will be waves, e.g., electromagnetic waves or mechanical waves, like sound waves.
The regions {Rm}m=1, . . . , M are defined in an n-dimensional space (or n-space), where n=2 or 3. Each of the transducers need be positioned in the n-space. That is, the position p; of each device {Ai}i=1, . . . , N must be determined in n, i.e., in the three dimensional space (if n=3) or a plane (if n=2).
To that aim, the present methods first determine an n-dimensional spatial filter function {circumflex over (ω)}e(r), as, e.g., in steps S12-S15 of
The n−1-sphere is assumed to be centered on the apparatus 10, 10a. For instance, this sphere may, eventually, be centered on the barycenter of the positions {pi}i=1, . . . , N of the transducers (yet to be determined). The above concepts of n-space, n−1-sphere, regions of interest and projections are discussed below in detail.
Next, a density function ƒb(p) is obtained S16, based on a Fourier transform ω(p) of the previously determined spatial filter function {circumflex over (ω)}e(r). As it may be realized, the Fourier transform of {circumflex over (ω)}e(r) may indeed be interpreted as a distribution function, for reason that will become apparent later. The density function ƒb(p) may for instance be obtained S16 as a function proportional to the absolute value of the Fourier transform ω(p) of the S15 spatial filter function {circumflex over (ω)}e(r). Furthermore, the density function ƒb(p) is preferably suitably normalized. Additional mathematical details are given in sect. 2.
Finally, assuming a prescribed number N of transducers, a position pi can be determined S17-S18, within the n-space, for each of the N transducers, based on the obtained density function ƒb(p), e.g., by suitably sampling the latter. A key point to enable this procedure is to make sure that {circumflex over (ω)}e(r) is defined in the n-space, i.e., that {circumflex over (ω)}e(r) take values for r in the n-space, and not in the n−1-space.
Consider for instance an array of N receiving transducers {Ai}i=1, . . . , N: application of the present methods allow positions {pi}i=1, . . . , N of the transducers to be determined, given specified regions of interest, where {p1, . . . , pN}∈n. When n=3, the positions determined lie in the 3D space, and when n=2, they lie on a plane. That the space the transducers lie in is allowed to vary permits different embodiments, leading to different spatial arrangements of the transducers, depending on the application at hand.
The present methods can advantageously be applied to phased arrays, for which the optimization and design of the layout of the transducers will critically impact the performance. For example, the beamshape of an antenna array depends both on the geometrical (layout) and electrical (gain and phase at each antenna) properties of the array. While the geometrical (layout) properties of the array is usually considered as a fixed input, i.e., a constraint, the present approach makes it possible to design a layout for the transducers according to specified targets, located in regions of interest. Projecting such regions onto the n−1-sphere (centered on the apparatus) allows a spatial filter to be designed and, in turn, a density function to be achieved, from which the positions of each transducer are derived. In fine, an apparatus can be designed and built, whose transducers are arranged according to positions determined thanks to present methods.
During a second phase (i.e., after having determined the positions {pi}i=1, . . . , N of the transducers), apparatuses designed and built thanks to the present methods may be used for beamforming signals (for transmission purposes) or compute beamformed signals (for reception purposes). Such signals are to be respectively transmitted or received non-uniformly in a 2- or 3-dimensional space, i.e., according to the particular regions of interest. To that aim, delays and gains may suitably be introduced in the signals, by weighting time-series according to beamforming weights ω(pi).
That is, the beamforming weights ω(pi) are easily be computed thanks to the determined positions and the Fourier transform ω(p) of {circumflex over (ω)}e(r), by evaluating ω(p) for each position pi. Then, delays and gains are introduced, by weighting time-series from or for the devices {Ai}i=1, . . . , N, using beamforming weights ω(pi). Namely, each time series received from or to be transmitted to a distinct one Ai of the devices is weighted by a beamforming weight ω(pi) as determined for said distinct one Ai of the devices.
The core principle remains the same, that signals be transmitted or received. For example, in a transmission case, signals are beamformed by introducing delays and gains as described above, i.e., by weighting time-series which can then be forwarded to respective transmitters (e.g., antennas of a Wifi router), for subsequent transmission to final receivers (e.g., end-users or signals consumers, such as laptops, smartphones, etc.). In reception, signals are sent by initial transmitters (e.g., the same end-users) to receivers (e.g., the same antennas).
Interestingly, the present approach makes it possible to focus on specific regions of interest. Aiming for regions (or areas) rather than points minimizes the required update rate and reduces the requirement for communication. The techniques used herein allow wider ranges of directions to be covered than with matched beamforming techniques. That is, for matched beamforming to cover a same range as with the present approach (all things being otherwise equal), one would have to steer matched beamforming toward many directions within that range. Moreover, and as illustrated in the accompanying drawings, the present solution typically gives rise to less aliasing artifacts (e.g., side-lobes) in the beamshapes.
The present solution can advantageously be used in various applications, including mobile telecommunication networks, Wifi, radio astronomy and ultrasound apparatuses, with, the devices {Ai}i=1, . . . , N being receivers, transmitters or transceivers.
In embodiments, the spatial filter {circumflex over (ω)}e(r) is obtained based on a preference function (step S12,
As the regions of interest may evolve, the preference function may change accordingly, thereby triggering a re-configuration S10-S11, leading to updated beamforming weights ω(pi). That is, the system 1, 10, 10a is preferably reconfigurable, i.e., the layout of the transducers may be dynamically changed. In that case, the configuration of the system may be monitored S10-S11. If the configuration of the targets happens to change S11, the updated configuration may be captured in an updated preference function, which gets loaded into the system and new positions can be calculated according to principles discussed above. In variants, even if the system is not reconfigurable, the beamshapes may nevertheless be reconfigured base on the (non-reconfigurable layout of antennas). Obviously, such a system is less performant, though more simple. In all cases, the present methods allow some versatility, compared to prior art approaches.
Having identified S12 one or more regions thanks to the preference function, the regions can then be projected S13 onto the n−1-sphere. This way, an angular filter function, also referred to as “target filter” in this document, can be obtained S14, based on the projections. The angular filter function is denoted by {circumflex over (ω)}(θ) in
Note that:
Projecting one or more regions of interest onto an n−1-sphere gives rise to one or more “surface portions”, respectively. Thus, the projections {Pm}m=1, . . . , M correspond to respective “surface portions”, where a surface portion is an arc of a circle if n=2 or a surface portion of an ordinary sphere if n=3.
For completeness, projections on an n−1-sphere correspond to n−1-dimensional angles that the regions subtend at the center of the n−1-sphere. Such angles are planar angles when n=2 or solid angles when n=3. The projected regions correspond to projections (or equivalently surface portions) as the set of transducers “see” them from within the n−1-sphere, assuming that this sphere is large enough to contain each of the transducers. However, the actual size of this sphere has little importance, for reasons that will become apparent later. Thus, an n−1-sphere as considered herein is typically a unit sphere (i.e., an object defined in the n−1-space).
The angular filter function {circumflex over (ω)}(θ, . . . ) can be seen as an optional intermediate between the projections of the regions on the n−1-sphere and the extended filter {circumflex over (ω)}e(r). The angular filter {circumflex over (ω)}(θ, . . . ) is constructed based on such projections, so as to reflect values taken by the projections on the n−1-sphere. As per its construction, {circumflex over (ω)}(θ, . . . ) is defined on the sole n−1-sphere. Yet, the spatial filter function {circumflex over (ω)}e(r) can easily be obtained by extending the angular filter function {circumflex over (ω)}(θ, . . . ) to n.
As a result, {circumflex over (ω)}e(r) as obtained at step S15 extends (i.e., takes values) in n while the projections are n−1-dimensional objects. That is, the function {circumflex over (ω)}e(r) “extends” the projections {Pm}m=1, . . . , M over n and, as such, are “thicker” objects, defined in a space of larger dimension than the projections.
The spatial filter function {circumflex over (ω)}e(r) plays an important role. It need be designed so as to match the projections of the regions onto the n−1-sphere, i.e., so as to approximate these projections on the n−1-sphere, it being noted that {circumflex over (ω)}e(r) is not only defined on this sphere but also in the n-space. For instance, the function {circumflex over (ω)}e(r) may be constrained to take the same values as the angular filter {circumflex over (ω)}(θ, . . . ) on the n−1-sphere. The function {circumflex over (ω)}e(r) will otherwise typically exhibit peaks that coincide with maxima of such projections, on the n−1-sphere. When considering such peaks as objects extending in n (which they are, as opposed to the angular filter that is restricted to the n−1-sphere), then such peaks typically circumscribe or tightly encompass the projections on the n−1-sphere, as seen in
In other words, {circumflex over (ω)}e(r) “extends” the angular function {circumflex over (ω)}(θ, . . . ) in n, notably radially (i.e., perpendicular to the n−1-sphere) and is a “thicker” object than {circumflex over (ω)}(θ, . . . ). As present inventors have realized, {circumflex over (ω)}e(r) indeed need be “thicker” than {circumflex over (ω)}(θ, . . . ) because an object restricted to the sole n−1-sphere (like (θ, . . . )) would make it impossible to recover a beamforming function or, even, to obtain a meaningful layout for the transducers.
As explained below in detail, one or more peaks of {circumflex over (ω)}e(r) may be used to match projections of the regions of interest. Here, the terminology “peak” is to be understood broadly: a peak reflects values taken by {circumflex over (ω)}e(r) in a given portion of the 2- or 3-space, where {circumflex over (ω)}e(r) takes higher values than around this portion. A peak may even be a 2-dimensional rectangular (or boxcar) function, i.e., involve an infinite number of local maxima.
Preferably, {circumflex over (ω)}e(r) is a L2-function, i.e., it is square-integrable over n and is finite, which implies that |{circumflex over (ω)}e(r)|→0 as |r|−∞. As a L2-function, {circumflex over (ω)}e(r) suitably behave for it to potentially match projected regions. More preferably, the function {circumflex over (ω)}e(r) is one that satisfies all Dirichlet conditions, for it to be Fourier transformable. While {circumflex over (ω)}e(r) may, in some cases, be always positive, ∀r in n, it may, in other cases, be chosen to be partly negative. I.e., negativity could be desirable in some cases, for example when using the present methods to expand an incoming signal in a desired basis, whose elements may be negative. More generally, the function {circumflex over (ω)}e(r) may be complex.
The positions of the transducers are preferably determined S17-S18 by sampling S17 values {ƒb,j}j=1, . . . , N of the density function ƒb(p) obtained at step S16. From the sampled values {ƒb,i}i=1, . . . , N, one may then identify S18 corresponding arguments pi corresponding to the sampled values, i.e., such that ƒb(pi)=ƒb,i ∀i. The final positions of the N transducers are then determined based on the identified arguments {pi}i=1, . . . , N. note that the final positions of the N transducers may simply be equated to the identified arguments {pi}i=1, . . . , N. Yet, additional (e.g., design) constraints may need be taken into account, which may lead to small deviation from the ideal positions {pi}i=1, . . . , N.
The geometry of the transducers can for instance be constructed from the quantile function of the density function ƒb(p). By appropriately sampling this function, the resulting beamshape will closely resemble the target.
Preferably, the spatial filter function {circumflex over (ω)}e(r) is determined S15 as a function having a defined, analytical Fourier transform, such that the density function ƒb(p) can next be obtained S16 based on this analytical Fourier transform. E.g., the spatial filter function {circumflex over (ω)}e(r) may be constructed based on known, well-defined analytical functions, for which analytical Fourier transforms are known, such that no explicit Fourier transformation need be involved. Thus, the function ω(p) can be obtained based on readily available, analytical Fourier transforms. All the more, no numerical Fourier transformation is involved in that case, which avoids numerical instabilities as typically caused by numerical transforms. In less preferred variants though, the present methods may also be implemented thanks to numerical transforms.
Using filter functions that have defined, analytical Fourier transforms allows a procedure that is numerically stable, computationally efficient and flexible, which, in turn, offers analysts a powerful tool for designing beamshapes in a much more controlled manner. That the transducers layout is optimized allows the quality of the subsequent beamshapes to be substantially improved. In that respect, and as seen in
Depending on the complexity desired for the spatial filter function {circumflex over (ω)}e(r), one or more auxiliary functions may be involved in its construction, where each auxiliary function has a defined, analytical Fourier transform. Namely, in embodiments, the function {circumflex over (ω)}e(r) is determined S15 as a sum of auxiliary functions that have, each, a defined, analytical Fourier transform. In that case, the density function ƒb(p) is obtained S16 based on a sum of analytical Fourier transforms that correspond, each, to a respective one of the auxiliary functions.
Using a sum of auxiliary functions makes it possible to closely fit a variety of target functions, even functions having cusps or edges. The spatial filter function {circumflex over (ω)}e(r) may for instance be determined as a sum of Gaussian functions. This is advantageous as contractions of even a few Gaussians can be used to fit a wide range of target functions, including functions having cusps, and, this, to a reasonable approximation. Furthermore, Gaussian functions allow for an easy representation in each of the direct space and the transformed space. A Gaussian function that is localized in one space, will be diffuse in the transformed space. However, as the transform of a Gaussian is still a Gaussian, the transformed function is still well-behaved; this not only eases the transforms but also avoids spurious effects when computing the weight coefficients and simplifies the computation of such coefficients. In other words, well-behaved coefficients can be obtained, which lead to clean beams.
In variants, ball indicator functions may be used. Other examples of functions can be contemplated, as discussed in sect. 2. The auxiliary functions used need not form a complete basis. On the contrary, a combination of different types of functions may possibly be used (in a weighted sum of such functions). E.g., one may simultaneously use ball indicator functions, Gaussian functions, Slater functions, etc., where some of the Gaussian/Slater functions may, if necessary, be parameterized so as to approach a Dirac distributions. This, in turn, allow more complex filters to be approximated.
In still other variants, however, one may rely on auxiliary functions, which do not satisfy Dirichlet conditions, but which locally behave well, e.g., take the same (or almost the same) values as known, transformable functions. The function {circumflex over (ω)}e(r) may for instance be written as a weighted (finite) sum of sine and/or cosine functions, fitting to a target angular filter {circumflex over (ω)}(θ), see explanations below, on the n−1-sphere, while the transform of {circumflex over (ω)}e(r) is taken as an integral over a finite domain (which again yields analytical formula). More generally, the one skilled in the art will appreciate that many types of auxiliary functions may be contemplated.
The auxiliary functions used to construct {circumflex over (ω)}e(r) may further be extrapolated from the auxiliary functions used to construct the target angular filter, as illustrated in
Where {circumflex over (ω)}e(r) is taken as a sum of auxiliary functions, the density function ƒb(p) is preferably obtained as the absolute value of the sum of the sum of the Fourier transforms of each individual auxiliary function, for reasons that will become apparent in sect. 2.
In simple embodiments, M auxiliary functions are used, which corresponds to the number of regions {Rm}m=1, . . . , M of interest. I.e., the auxiliary functions are chosen so as to match projections {Pm}m=1, . . . , M of the regions {Rm}m=1, . . . , M onto the n−1-sphere, as illustrated in
More generally, {circumflex over (ω)}e(r) may be devised so as to exhibit, on the n−1-sphere, maxima that match the maxima of the projections {Pm}m=1, . . . , M, so as to suitably reflect the angular distribution of the regions {Rm}m=1, . . . , M onto the n−1-sphere. Now, and depending on the auxiliary functions used, {circumflex over (ω)}e(r) may have more (or less) local maxima than the projections {Pm}m=1, . . . , M of the regions on the n−1-sphere.
In simple cases, the angular filter {circumflex over (ω)}(θ, . . . ) may take on the value 1 on certain “arcs”, i.e., portions of the n−1-sphere (corresponding to projected regions), and 0 outside, e.g., if regions are initially identified in a binary way rather than with a density map. In such cases too, the auxiliary functions may be suitably chosen so as for {circumflex over (ω)}e(r) to faithfully reflect the angular filter on the n−1-sphere. For instance, the spatial filter {circumflex over (ω)}e(r) may, in that case, be designed so as to have, on a circle (n=2) or on a sphere (n=3), one or more maxima (or a constant value) within each of the one or more arcs or surface portions corresponding to the projections {Pm}m=1, . . . , M of the regions of interest.
Referring now more specifically to
In addition, the transducers are arranged at specific positions {pi}i=1, . . . , N, i.e., as obtained thanks to the present methods. For example, the positions of the transducers may correspond to arguments of values of the density function ƒb(p), the latter obtained based on the Fourier transform ω(p) of {circumflex over (ω)}e(r), as described above. The resulting layout is atypical, as seen in
As evoked earlier, the system 1 is optionally reconfigurable. To that aim, the transducers may be movably mounted in the apparatus 10, 10a, or, at least, the transducers are re-positionable (as typically is the case during fabrication). A reconfigurable system need be suitably equipped (with movable parts, stages, etc.) for (re-)positioning the transducers according to positions determined based on given targets.
The present systems will typically comprise computerized modules, configured to perform the following tasks (one or more modules may be involved, having one or more functions each):
In addition, the present systems may comprise:
Such a system may notably be embodied as: a transmitter apparatus; a receiver; a transceiver (e.g., a wireless access point such as a Wifi router, as in
The system may comprises more than one set of transducers, the sets possibly including receivers, transmitters and/or transceivers, which may possibly form distinct modules, located in distinct regions of space. The transducers of at least one of these sets will be arranged at specific positions {pi}i=1, . . . , N, i.e., as obtained thanks to the present methods. One or more of these sets of transducers may form “targets”, i.e., be located in said regions of interest (and yet forming part of the system), whereas another one of the set may comprise transducers arranged at said specific positions {pi}i=1, . . . , N, so as to efficiently transmit signals to the targets.
The above embodiments have been succinctly described in reference to the accompanying drawings and may accommodate a number of variants. Several combinations of the above features may be contemplated. Examples are given in the next section.
This section describes a method that is useful for designing phased-arrays according to a given, analytically-specified, target beamshape. Building on the flexibeam framework, antenna locations are sampled from a probabilistic density function. Naturally scalable with the number of antennas, it is also computationally efficient and numerically stable, as it relies on analytical derivation.
It is further shown that, under mild conditions, the achieved beamshapes converge uniformly to the target beamshapes as the number of antennas increases. The technique is illustrated through a number of examples. For instance, by use of the Laplace filter, beams with extremely fast decay away from the center of focus are achieved.
The procedure is numerically stable, computationally efficient and versatile, offering the analyst a very powerful tool for designing beamshapes, as well as insight into how an array will scale with ever increasing numbers of antennas. Matched beamforming weights may, for a given layout, achieve beamshapes targeting regions, rather than isolated directions as commonly believed.
As the beamforming weights all have unit modulus, this translates into a delay, allowing existing hardware to be used to achieve a given beam, and has the advantage of treating noise uniformly across antennas. In contrast, prior approaches like the so-called “flexibeam” technique modify the magnitude of the weights at the cost of non-uniform noise distribution.
Additionally, the convergence analysis can be used to forecast the growth of future, large phased arrays such as the Square Kilometer Array (SKA).
For simplicity in explanation, this description merely considers circularly symmetric filters and 2D beamforming. Extension to 3D beamforming readily follows.
2.1 Preliminaries
2.1.1 Beamforming
Consider an array of N receiving antennas, which, without loss of generality, have unit gains and an omni-directional field of view. In mathematical terms, “beamforming” translates into a linear combination of the antenna signals xi(t):
where ωi∈ are beamforming coefficients.
Under the non-limiting assumptions of far-field and narrowband signals,
The function b(θ) is called the beamshape of the beamformed antenna array and is defined as:
b(θ)=Σi=1Nωiej2πp
It describes the sensitivity of the antenna array relative to various directions θ, and hence acts as an angular filter.
2.1.2 Beamforming with Flexibeam
The so-called flexibeam framework (see also P. Hurley and M. Simeoni, “Flexibeam: analytic spatial filtering by beamforming,” in International Conference on Acoustics, Speech and Signal Processing (ICASSP), IEEE, March 2016) permits to achieve a wide range of analytically-specified beamshapes. In this section, some important notions and notations borrowed from this framework are briefly recalled.
One innovation of Flexibeam was to consider a notional continuous field of antennas, with an associated beamforming function ω: 2→, describing the gains and delays to be applied at each location (p, φ)∈(p, ϕ)∈+×[0,2π] so as to achieve an analytically specified target beamshape {circumflex over (ω)}: [0,2π]→:
{circumflex over (ω)}(θ)=∫0∞∫02πω(p,ϕ)ej2πp cos(θ-ϕ)pdϕdp. (3)
The beamforming function can be computed as
ω(p,ϕ)=∫0∞∫02π{circumflex over (ω)}e(r,θ)e−j2πrp cos(θ-ϕ)rdθdr (4)
where {circumflex over (ω)}e: 2→ is the extended filter introduced in the previous section, which can be constrained such that {circumflex over (ω)}e(1, θ)={circumflex over (ω)}(θ). For N given antenna locations, the corresponding beamforming weights are then obtained by sampling ω:
where β is a normalizing constant to avoid noise magnification. The resulting beamshape then approximates the target beamshape, with accuracy dependent on the specific layout under consideration.
2.2 “Flexarray”
In this section, a new framework is proposed, termed “flexarray”, to generate random layouts so as to approximate analytically-specified target beamshapes. To do so, we leverage the flexibeam framework and construct a probability density function from the beamforming function. In the specific case of circularly symmetric extended filters, we link this density function to the Hankel transform of order zero of the extended filter. We finally show that the empirical beamshapes obtained when sampling this density converge uniformly almost surely to the target beamshape as the number of antennas grows to infinity.
2.2.1 Beamforming with Circularly Symmetric Extended Filters
This section is concerned with extended filters that are real and, when translated to the origin, circularly symmetric, namely:
{circumflex over (ω)}e(r)=ĝ(∥r−r0∥),∀r∈2,
where ĝ is a function defined over +, and r0=(cos θ0, sin θ0)∈1 is the focus direction. Eq. (4) shows that the beamforming function is the 2D Fourier transform of the target filter. Leveraging the shift property of Fourier transforms, we can hence express the beamforming function in terms of the zeroth order Hankel transform of ĝ:
where J0 is the zeroth order Bessel function of the first kind. Then,
g(p)=2π∫0∞rĝ(r)J0(2πrp)dr, (6)
is the Hankel transform of order zero of ĝ.
2.2.2 Beamforming in a Probabilistic Setup
Assuming that the beamforming function is such that ω∈1 (2), its relationship to the target beamshape from Eq. (4) can be re-written using Eq. (5), as
where:
∥g∥1=∫0∞|g(p)|dp
and
σg(p)=sign(g(p))
Now, ƒb can be interpreted as a probability density function, corresponding to the beamforming density function introduced in sect. 1, which in polar coordinates is defined as
Let P: Ω→2 be a random vector with polar coordinates (P, Φ) and probability density function ƒb, see eq. (8). The angular filter function is then
{circumflex over (ω)}(r)=αP[σg(∥P∥)e−j2πr
with α=∥g∥1, r0=(cos θ0, sin θ0) and .,. the Cartesian inner product. An expression for the extended filter {circumflex over (ω)}e follows directly by extending Eq. (9) to 2, that is,
{circumflex over (ω)}e(r)=αP[σg(∥P∥)e−j2πr
Notice that when α=1 and g≥0, this can be seen as the Fourier transform of the density function ƒb, modulated by an exponential term e−j2πr
{circumflex over (ω)}e(r+r0)=P[ej2πr,P]:=φP(r),∀r∈2,
which is the characteristic function of the random vector P.
In conclusion, in the specific case where α=1 and g≥0, the extended filter {circumflex over (ω)}e can be seen as the characteristic function of the random vector P, centered on r0, the steering direction. Similarly, the target beamshape {circumflex over (ω)} can be seen as the characteristic function of the random vector P, centered on r0, and evaluated on the unit circle.
2.2.3 Empirical Beamshapes and Asymptotic Convergence
Assume that for a target beamshape {circumflex over (ω)}, with circularly symmetric extended filter {circumflex over (ω)}e, we computed the density beamforming function ƒb as described in Section 2.2.2, and sampled N independent polar coordinates from this density
If we place antennas at these locations, and impose beamforming weights ωi for each antenna, the resulting array will have a beamshape given by
Choosing the beamforming weights as
leads to the empirical beamshape, finite-sample version of Eq. (9):
Notice that when σg=1, the beamforming weights in Eq. (11) are simply matched beamforming weights, which steer the beamshape around θ0. The empirical beamshape is an unbiased estimate of the target beamshape {circumflex over (ω)}. Moreover, depending on the function g, this estimate can also be shown to be consistent. This follows from the uniform strong law of large numbers.
The resulting empirical beamshape writes as
where
ψ(Pi,θ):=ασg(pi)e−j2πp
Then, if the function ψ(·, θ) is continuous and measurable for all θ∈[0, 2π]:
as the number of antennas N grows to infinity.
A study of the function ψ reveals that a sufficient condition for bN to be a consistent estimate of {circumflex over (ω)} is for the function g to be either strictly positive or strictly negative. For functions g that switch signs, we can still use the classical strong law of large numbers to show point-wise convergence. The empirical beamshapes for the Laplace, Sombrero and Gaussian functions, investigated in sections 2.3 and 2.4, converge extremely quickly, approximately as 1/N.
2.3 Examples of Layout Distributions
We first discuss the traditional case, targeting one individual point, before the case of targeting whole regions. Following the framework, for a given target {circumflex over (ω)}(θ), we need to design an extended filter {circumflex over (ω)}e(r, θ) defined on the whole plane, and determine an appropriate distribution ƒb for achieving the target. The derived beamforming density functions are a consequence of known Hankel transform pairs.
2.3.1 Focusing on a Single Point
To target a single direction θ0, a simple example of filter would be {circumflex over (ω)}e(r, θ)=δ(θ−θ0)δ(r−1). The resulting beamforming function is
ω(p,ϕ)=ej2πp cos(θ
Yet, as one may realize, such a function has unbounded support, and thus no beamforming density function exists. In practice, we may instead sample over a finite disc, which is effectively achieved by an array that targets matched beamforming.
2.3.1.1 Sombrero Function
Consider the so-called Sombrero function,
where σ>0. The beamforming density function is then, up to rescaling, a uniform distribution over the disc of radius 1/σ:
From this we can conclude that for matched beamforming, a uniformly distributed array across a given area will get us close to the Sombrero function, which as the array diameter increases, converges to a Dirac.
2.3.1.2. Radial Laplace
Instead of trying to approximate a Dirac, it may be wiser to target a better behaved function, with an explicit control on the beamshape, which decays around the focus point θ0. This can be achieved by the radial Laplace function: ĝ(r)=e−π where σ>0. The beamforming density function is then, up to a rescaling function,
Example Sombrero and radial Laplace beamshapes are shown in
2.4 Targeting Regions
We now present the beamforming density functions associated to the ball indicator function and the circularly symmetric Gaussian function.
2.4.1. Ball Indicator
Consider the following disc of radius R:
The beamforming density function is then, up to a rescaling function,
It is interesting to note that, due to the Hankel pair relationship, approximating a region with the ball achieves a Sombrero beamforming density, while approximating a Sombrero requires a uniform density in a disc.
2.4.2. Bi-Dimensional Gaussian
An alternative way to cover a region is to use a bi-dimensional Gaussian filter:
where σ>0. The beamforming density function is then given by, up to a rescaling function
Example ball indicator and Gaussian beamshapes are shown in
3.1 Wifi
We now describe an embodiment for the transmission and receipt of data using a Wifi router. To simplify, but without limiting the scope of the invention, we assume the router and all the devices broadcasting in the room lie on a plane, e.g., the plane of
A Wifi route with multiple antennas, carefully positioned, is used for transmission. As input a preference function ƒ: 3→ is accessed, which identify regions of interest. To that aim, any pattern described a desired irradiation may be used, e.g., a density map. In variants, the preference function accessed may already be in the form of an angular function. I.e., the preference function may be the angular filter {circumflex over (ω)}(r) itself.
For example, function ƒ can indicate how each location in a living room should be irradiated by the router's signal based on user's preferences. In variants, the preference function may be automatically learned, using newer Wifi standards (802.11n, 802.11ac), whereby preferences (or average positions) may be automatically learned from instant locations of devices (either passively detected or with help of explicit status communication).
Consider for example a room as in
Based on the preference function accessed, an optimal layout is obtained and, subsequently, an optimal beamshape is achieved, which covers well the preferential areas, while compensating for signal attenuation when travelling in the area of interest.
Preferred embodiments would approximate the preference function in terms of Gaussian functions, so as to enable analytical calculation of the beamforming function.
Note that most embodiments evoked herein assume the devices to lie in the far field. Indeed, no beamforming would be necessary if the devices were in the near field. This assumption is believed to hold for all reasonable modes of operation. For example for a frequency of operation of ƒ0=2.4 GHz (as typical for Wifi signals), and for a single antenna of length l=15 cm, every device located at a distance from the antenna greater than d0=2l2/λ≈3.6 mm can be considered as lying in the far field.
An example of The Wifi router 10 is depicted in
An example radial filter {circumflex over (ω)}(θ) is shown in
We can compute the beamforming function ω(p) by taking the (well-defined) Fourier transform of {circumflex over (ω)}e(r). The function {circumflex over (ω)}e is designed so as to extrapolate {circumflex over (ω)} to the plane assuming one has, radially, essentially the same characteristic extension as tangentially. Yet, other approaches would convene as well, provided that the extended filter {circumflex over (ω)}e is “thicker” than {circumflex over (ω)}. As a general rule though, {circumflex over (ω)}e may suitably extend {circumflex over (ω)} radially by assuming the radial deviation equal to the tangential deviation. Note that in the above example, {circumflex over (ω)}e is not exactly equal to {circumflex over (ω)} on the circle. In variants, one may, however, constrain it to take exactly the same values as {circumflex over (ω)} on the circle, while giving it a given thickness on each side of the circle, as in the case of the ball indicator function.
In general, a characteristic radial extension of {circumflex over (ω)}e will delimit a circular region with radius less than 1 (i.e., think of a ball indicator function of radius less than 1, the value of unit-circle radius). However, in exceptional cases (large regions), the characteristic radial extension of {circumflex over (ω)}e may delimit a circular region with radius larger than 1, but always less than 2 (i.e., the critical radius for which the entire unit-circle would be contained in the extension. Hence, larger radii (although theoretically conceivable) would not provide any substantial benefit. For example, when using the ball indicator function, a radius of 2 or greater would always lead to the same beamshape, filtering uniformly across all possible directions.
Assuming L antennas in the router. β is the normalization factor, i.e.,
to avoid noise magnification due to beamforming. Because the beamshape as defined above is an aliased version of the target angular filter, small side-lobes may result in the radiation pattern (see
3.2 Mobile Phone
Here we briefly describe embodiments for beamforming using a collection of 3G/4G (or in the future 5G) transmitters. The goal is to determine what beamshape should be used at each transmitter. For a given transmitter of a set, a preferred embodiment is as follows:
For example, one may wish to beamform so as to cover optimally a part of a city, based on a priori knowledge of the probable positions of clients.
The beamshapes obtained according to the above procedure approximate very well the associated angular filter. With this technique, the network's users will have a better signal's reception, as less power is dissipated in unnecessary areas of the city. This is a huge advantage compared to current technologies in use, where broadcasting is isotropic and independent from the device distribution.
3.3 Ultrasound
Ultrasound consists of transmit beamforming (beamforming to target the ultrasound output at a certain point) and receive beamforming (beamforming the resultant echoes). Two concurrent operations are thus needed, one of the transmit and one of the receive type. The transmitted and received signals are linked in that case because the echoes are shaped by the transmit beamforming.
Ultrasound phased arrays are often 1D (with all transducers aligned on a single axis, as assumed in
The potential benefits of present embodiments for ultrasound include:
The general (known) method for transmit beamforming consists of inducing delays (a delay law) between the pulses emitted by each of the transducers. The goal is to achieve a narrow focus a certain distance away for a desired angle. This is equivalent to performing a focused beamforming for a given angle each time. The echoes from the resultant beam are then received by each transducer. They are then combined by a weighted sum to produce a single image, using the receive beam. The final image can be obtained by scanning across many angles. In this mode of operation, the whole image is desired, and focused beamforming is just a means to obtain it. Each sweep has high SNR at the point of focus, and reduced SNR around it, with side-lobes also distorting the resultant image.
Embodiments of the invention modify this known method by allowing for variation in the delays and magnitudes at each transducer, thus inducing phase and magnitude changes in the resultant beamforming.
3.4 Radio Astronomy
Modern radio telescope correlate the signals measured by thousands of antennas at various location on the ground, in order to infer an image of the sky. To reduce the amount of data sent to the central processor and increase the signal to noise ratio, the antennas are grouped together in stations and beamformed via matched beamforming. As we have seen previously, matched beamforming maximizes the power coming from one direction in the sky, but sees little about the rest of the sky. Hence, surveying large portions of the sky with matched beamforming requires multiple observations, where matched beamforming is steered towards various locations on the sky in order to cover a whole portion of interest. This is suboptimal and time consuming, and one would benefit much more from a beamshape which could capture the power of the signals coming from a wider range of directions.
Thus, an example of application to radio astronomy, for a given collection of antennas that have a modifiable layout, is:
These weights are then applied to beamform at each time-instance.
4.2 Computerized Units and Apparatuses
Computerized systems and devices can be suitably designed for implementing embodiments of the present invention as described herein. In that respect, it can be appreciated that the methods described herein are largely non-interactive and automated. In exemplary embodiments, the methods described herein can be implemented either in an interactive, partly-interactive or non-interactive system. The methods described herein can be implemented in software (e.g., firmware), hardware, or a combination thereof. In exemplary embodiments, the methods described herein are implemented in software, as an executable program, the latter executed by suitable digital processing devices. More generally, embodiments of the present invention can be implemented wherein general-purpose digital computers, such as personal computers, workstations, etc., are used.
For instance, the system 100 depicted in
In exemplary embodiments, in terms of hardware architecture, as shown in
The processor 105 is a hardware device for executing software, particularly that stored in memory 110. The processor 105 can be any custom made or commercially available processor, a central processing unit (CPU), an auxiliary processor among several processors associated with the computer 101, a semiconductor based microprocessor (in the form of a microchip or chip set), or generally any device for executing software instructions.
The memory 110 can include any one or combination of volatile memory elements (e.g., random access memory) and nonvolatile memory elements. Moreover, the memory 110 may incorporate electronic, magnetic, optical, and/or other types of storage media. Note that the memory 110 can have a distributed architecture, where various components are situated remote from one another, but can be accessed by the processor 105.
The software in memory 110 may include one or more separate programs, each of which comprises an ordered listing of executable instructions for implementing logical functions. In the example of
The methods described herein may be in the form of a source program, executable program (object code), script, or any other entity comprising a set of instructions to be performed. When in a source program form, then the program needs to be translated via a compiler, assembler, interpreter, or the like, as known per se, which may or may not be included within the memory 110, so as to operate properly in connection with the OS 111. Furthermore, the methods can be written as an object oriented programming language, which has classes of data and methods, or a procedure programming language, which has routines, subroutines, and/or functions.
Possibly, a conventional keyboard and mouse can be coupled to the input/output controller 135. Other I/O devices 140-155 may include or be connected to other hardware devices 10, as noted earlier.
In addition, the I/O devices 140-155 may further include or be connected to devices 10 that communicate both inputs and outputs. The system 100 can further include a display controller 125 coupled to a display 130. In exemplary embodiments, the system 100 can further include a network interface or transceiver 160 for coupling to a network 165, to enable, in turn, data communication to/from other, external components.
The network 165 transmits and receives data between the unit 101 and external systems. The network 165 is possibly implemented in a wireless fashion, e.g., using wireless protocols and technologies, such as Wifi, WiMax, etc. The network 165 may be a fixed wireless network, a wireless local area network (LAN), a wireless wide area network (WAN) a personal area network (PAN), a virtual private network (VPN), intranet or other suitable network system and includes equipment for receiving and transmitting signals.
The network 165 can also be an IP-based network for communication between the unit 101 and any external server, client and the like via a broadband connection. In exemplary embodiments, network 165 can be a managed IP network administered by a service provider. Besides, the network 165 can be a packet-switched network such as a LAN, WAN, Internet network, etc.
If the unit 101 is a PC, workstation, intelligent device or the like, the software in the memory 110 may further include a basic input output system (BIOS). The BIOS is stored in ROM so that the BIOS can be executed when the computer 101 is activated.
When the unit 101 is in operation, the processor 105 is configured to execute software stored within the memory 110, to communicate data to and from the memory 110, and to generally control operations of the computer 101 pursuant to the software. The methods described herein and the OS 111, in whole or in part are read by the processor 105, typically buffered within the processor 105, and then executed. When the methods described herein are implemented in software, the methods can be stored on any computer readable medium, such as storage 120, for use by or in connection with any computer related system or method.
4.2 Computer Program Product
The present invention may be an apparatus, a method, and/or a computer program product. The computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present invention.
The computer readable storage medium can be a tangible device that can retain and store instructions for use by an instruction execution device. The computer readable storage medium may be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination of the foregoing. A non-exhaustive list of more specific examples of the computer readable storage medium includes the following: 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), a static random access memory (SRAM), a portable compact disc read-only memory (CD-ROM), a digital versatile disk (DVD), a memory stick, a floppy disk, a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon, and any suitable combination of the foregoing. A computer readable storage medium, as used herein, is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire.
Computer readable program instructions described herein can be downloaded to respective computing/processing devices from a computer readable storage medium or to an external computer or external storage device via a network, for example, the Internet, a local area network, a wide area network and/or a wireless network. The network may comprise copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers. A network adapter card or network interface in each computing/processing device receives computer readable program instructions from the network and forwards the computer readable program instructions for storage in a computer readable storage medium within the respective computing/processing device.
Computer readable program instructions for carrying out operations of the present invention may be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Smalltalk, C++ or the like, and conventional procedural programming languages, such as the C programming language or similar programming languages. The computer readable program instructions 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). In some embodiments, electronic circuitry including, for example, programmable logic circuitry, field-programmable gate arrays (FPGA), or programmable logic arrays (PLA) may execute the computer readable program instructions by utilizing state information of the computer readable program instructions to personalize the electronic circuitry, in order to perform aspects of the present invention.
Aspects of the present invention are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems), and computer program products according to embodiments of the invention. 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 readable program instructions.
These computer readable 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 readable program instructions may also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
The computer readable program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
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 of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which comprises one or more executable instructions for implementing the specified logical function(s). 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 carry out combinations of special purpose hardware and computer instructions.
While the present invention has been described with reference to a limited number of embodiments, variants and the accompanying drawings, it will be understood by those skilled in the art that various changes may be made and equivalents may be substituted without departing from the scope of the present invention. In particular, a feature (device-like or method-like) recited in a given embodiment, variant or shown in a drawing may be combined with or replace another feature in another embodiment, variant or drawing, without departing from the scope of the present invention. Various combinations of the features described in respect of any of the above embodiments or variants may accordingly be contemplated, that remain within the scope of the appended claims. In addition, many minor modifications may be made to adapt a particular situation or material to the teachings of the present invention without departing from its scope. Therefore, it is intended that the present invention not be limited to the particular embodiments disclosed, but that the present invention will include all embodiments falling within the scope of the appended claims. In addition, many other variants than explicitly touched above can be contemplated. For example, other applications than those explicitly mentioned may benefit from beamforming methods as described herein.
Number | Name | Date | Kind |
---|---|---|---|
4894795 | Whitehouse | Jan 1990 | A |
5329286 | Lammers | Jul 1994 | A |
5613039 | Wang | Mar 1997 | A |
6067861 | Shekarriz | May 2000 | A |
6556916 | Waite | Apr 2003 | B2 |
8344945 | Craig | Jan 2013 | B2 |
9537214 | Corman | Jan 2017 | B2 |
20060251200 | Miller | Nov 2006 | A1 |
20070136012 | Miller | Jun 2007 | A1 |
20100003991 | Pao | Jan 2010 | A1 |
20130057432 | Rajagopal | Mar 2013 | A1 |
20140104107 | Mangenot | Apr 2014 | A1 |
20160050007 | Lee | Feb 2016 | A1 |
20160315391 | Bosshard | Oct 2016 | A1 |
20170033458 | Haziza | Feb 2017 | A1 |
20180329009 | James | Nov 2018 | A1 |
Entry |
---|
Nezihe Merve Guerel, et al., unpublished U.S. Appl. No. 15/859,398, filed Dec. 30, 2017, Determining Positions of Transducers for Receiving and/or Transmitting Wave Signals, pp. 1-41 plus 7 sheets of drawings. |
Paul J. Otterstedt, List of IBM Patents or Patent Applications Treated As Related, Jun. 14, 2018, pp. 1-2. |
Nour El-Din Ismail et al, Design and analysis of a phased-MIMIO array antenna with frequency diversity. Progress in Electromagnetics Research Symposium Proceedings, Jul. 6-9, 2015. pp. 1745-1750. |
Paul Hurley et al, Flexibeam: Analytic Spatial Filtering by Beamforming. Acoustics, Speech and Signal Processing (ICASSP), 2016 IEEE International Conference on Mar. 20-25, 2016. pp. 1-4. |
Paul Hurley et al, Beamforming towards regions of interest for multi-site mobile networks. International Zurich Seminar on Communications (IZS), Mar. 2-4, 2016. pp. 94-98. |
Number | Date | Country | |
---|---|---|---|
20180292508 A1 | Oct 2018 | US |