Generally, the present application relates to audio signal processing. In particular, the present application relates to a sound processing node of an arrangement of sound processing nodes, a system comprising a plurality of sound processing nodes and a method of operating a sound processing node within an arrangement of sound processing nodes.
In the field of speech processing, one of the major challenges faced by engineers is how to maintain the quality of speech intelligibility in environments containing noise and interference. This occurs in many practical scenarios such as using a cellphone on a busy street or the classic example of trying to understand someone at a cocktail party. A common way to address this issue is by exploiting spatial diversity of both the sound sources and multiple recording devices to favor particular directions of arrival over others, a process referred to as beam-forming.
Whilst more traditional beam-formers, for acoustic processes, are comprised of physically connected arrays of microphones, the improvement in both sensor and battery technologies over the last few decades has made it practical to also use wireless sensor networks (WSNs) for the same purpose. Such systems are comprised of a large number of small, low cost sound processing nodes which are capable of both recording incoming acoustic signals and then transmitting this information throughout the network.
The use of such wireless sound processing nodes makes it possible to deploy varying sizes of networks without the need to redesign the hardware for each application. However, unlike dedicated systems, such WSNs have their own set of particular design considerations. The major drawback of WSNs is that, due to the decentralized nature of data collection, there is no one location in which the beam-former output can be calculated. This also affects the ability of WSNs to estimate covariance matrices which are needed in the design of statistically optimal beamforming methods.
A simple approach to solving this issue is to add an additional central point or fusion center to which all data is transmitted for processing. This central point though suffers from a number of drawbacks. Firstly, if it should fail, the performance of the entire network is compromised which means that additional costs need to be taken to provide redundancy to address this. Secondly, the specifications of the central location, such as memory requirements and processing power, vary with the size of the network and thus should be over specified to ensure that the network can operate as desired. And thirdly, for some network topologies such a centralized system can also introduce excessive transmission costs, which can cause the depletion of each node's battery life.
An alternative to these centralized topologies is to exploit the computation power of the nodes themselves and to solve the same problem from within the network. Such distributed topologies have the added benefit of removing the single point of failure whilst providing computation scalability, as adding additional nodes to the network also increases the processing power available. The main challenge with distributed approaches stems back to the lack of a central point where all system data is available which requires the design of alternative and typically iterative algorithms.
Although a number of approaches for providing a distributed beamforming algorithm already exist in the literature, they are not without their limitations. The most notable of these is that hardware based requirements, such as memory use, often still scale with the size of the network making it impractical to deploy these algorithms using the same hardware platform in ad-hoc or varying size networks. Such a constraint relates to the need of these “distributed” algorithms to have access to some form of global data, be it in a compressed form or not. Thus there is a current need in the art for a truly distributed, statistically optimal beamforming approach, in particular for use in wireless sensor networks.
It is an object of the application to provide a distributed, statistically optimal beamforming approach, in particular for use in wireless sensor networks.
The foregoing and other objects are achieved by the subject matter of the independent claims. Further implementation forms are apparent from the dependent claims, the description and the figures.
According to a first aspect, the application relates to a sound processing node for an arrangement of sound processing nodes, the sound processing nodes being configured to receive a plurality of sound signals, wherein the sound processing node comprises a processor configured to determine a beamforming signal on the basis of the plurality of sound signals weighted by a plurality of weights, wherein the processor is configured to determine the plurality of weights using a transformed version of a linearly constrained minimum variance approach, the transformed version of the linearly constrained minimum variance approach being obtained by applying a convex relaxation to the linearly constrained minimum variance approach.
Using a convex relaxed version of the linearly constrained minimum variance approach allows determining the plurality of weights defining the beamforming signal by each sound processing node of the arrangement of sound processing nodes in a fully distributed manner.
In an implementation form, the sound processing node can comprise a single microphone configured to receive a single sound signal or a plurality of microphones configured to receive a plurality of sound signals. Generally, the number of sound signals received by the sound processing node determines the number of weights. The plurality of weights are usually complex valued, i.e. including a time/phase shift. In an implementation form, the processor is configured to determine the plurality of weights for a plurality of different frequency bins. The linearly constrained minimum variance approach minimizes the noise power of the beamforming signal, while adhering to linear constraints which maintain desired responses for the plurality of sound signals.
In a first possible implementation form of the sound processing node according to the first aspect, the linearly constrained minimum variance approach is a robust linearly constrained minimum variance approach, wherein the processor is configured to determine the plurality of weights using a transformed version of the robust linearly constrained minimum variance approach parametrized by a parameter α, wherein the parameter α provides a tradeoff between the minimization of the magnitude of the weights and the energy of the beamforming signal.
This implementation form allows the processor to provide robust values for the plurality of weights by allowing an adjustment of the parameter α.
In a second possible implementation form of the sound processing node according to the first implementation form of the first aspect, the processor is configured to determine the plurality of weights using the transformed version of the robust linearly constrained minimum variance approach on the basis of the following equation and constraints:
wherein
wi denotes the i-th weight of the plurality of weights,
Yi(l) denotes the vector of sound signals received by i-th sound processing node in the frequency domain,
V denotes the set of all sound processing nodes,
M denotes the total number of microphones of all sound processing nodes, i.e. M=Σi=1Nmi,
N denotes the total number of sound processing nodes,
Di(p) defines a channel vector associated with a p-th direction,
P denotes the total number of directions and
s(p) denotes the desired response for the p-th direction.
This implementation form allows for an efficient determination of the plurality of weights defining the beamforming signal by the processor of the sound processing node.
In a third possible implementation form of the sound processing node according to the first implementation form of the first aspect, the processor is configured to determine the plurality of weights using a further transformed version of the linearly constrained minimum variance approach, the further transformed version of the linearly constrained minimum variance approach being obtained by further transforming the transformed version of the linearly constrained minimum variance approach to the dual domain.
By exploiting strong duality this implementation form allows for an efficient determination of the plurality of weights defining the beamforming signal by the processor of the sound processing node.
In a fourth possible implementation form of the sound processing node according to the third implementation form of the first aspect, the processor is configured to determine the plurality of weights using the further transformed version of the linearly constrained minimum variance approach on the basis of the following equation using the dual variable A:
wherein the plurality of weights wi are defined by a vector yi defined by the following equation:
y
i
=[t
i
(1)
,t
i
(2)
, . . . ,t
i
(M)
,w
i
(1)
,w
i
(2)
, . . . ,w
i
(m
)]T, (2)
wherein
t
j
(l)=Σi∈VYi(l)Hwi,
Yi(l) denotes the vector of sound signals received by i-th sound processing node in the frequency domain,
V denotes the set of all sound processing nodes,
mi denotes the number of microphones of the i-th sound processing node, and
the dual variable λ is related to the vector yi by means of the following equation:
y
i
*=A
i
−1
B
i*λ*
and wherein Ai, Bi and C are defined by the following equations:
wherein
N denotes the total number of sound processing nodes,
M denotes the total number of microphones of all sound processing nodes, i.e. M=Σi=1Nmi,
Di(p) defines a channel vector associated with a p-th direction,
P denotes the total number of directions and
s(p) denotes the desired response for the p-th direction.
This implementation form allows for an efficient determination of the plurality of weights defining the beamforming signal by the processor of the sound processing node, because the optimal λ can be determined by inverting a (M+P) dimensional matrix which, for large arrangements of sound processing nodes, is much smaller than the N dimension matrix needed by conventional approaches.
In a fifth possible implementation form of the sound processing node of the third implementation form of the first aspect, the processor is configured to determine the plurality of weights using the further transformed version of the linearly constrained minimum variance approach on the basis of the following equation and the following constraint using the dual variable λ:
wherein
λi defines a local estimate of the dual variable λ at the i-th sound processing node,
Dij=−Dji=±I with I denoting the identity matrix,
E defines the set of sound processing nodes defining an edge of the arrangement of sound processing nodes and
the plurality of weights wi are defined by a vector yi defined by the following equation:
y
i
=[t
i
(1)
,t
i
(2)
, . . . ,t
i
(M)
,w
i
(1)
,w
i
(2)
, . . . ,w
i
(m
)]T, (2)
wherein
t
j
(l)=Σi∈VYi(l)Hwi,
Yi(l) denotes the vector of sound signals received by i-th sound processing node in the frequency domain,
V denotes the set of all sound processing nodes,
mi denotes the number of microphones of the i-th sound processing node, and
the dual variable λ is related to the vector yi by means of the following equation:
y
i
*=A
i
−1
B
i*λ*
and wherein Ai, Bi and C are defined by the following equations:
wherein
N denotes the total number of sound processing nodes,
M denotes the total number of microphones of all sound processing nodes, i.e. M=Σi=1Nmi,
Di(p) defines a channel vector associated with a p-th direction,
P denotes the total number of directions and
s(p) denotes the desired response for the p-th direction.
This implementation form is especially useful for arrangement of sound processing nodes defining an ad-hoc network of sound processing nodes, as new sound processing nodes can be added with only some of the rest of the nodes of the network having to be updated.
In a sixth possible implementation form of the sound processing node according to the fifth implementation form of the first aspect, the processor is configured to determine the plurality of weights on the basis of a distributed algorithm, in particular the primal dual method of multipliers.
This implementation form allows for a very efficient computation of the plurality of weights by the processor of a sound processing node of an arrangement of sound processing nodes defining a cyclic network topology.
In a seventh possible implementation form of the sound processing apparatus according to the sixth implementation form of the first aspect, the processor is configured to determine the plurality of weights on the basis of a distributed algorithm by iteratively solving the following equations:
wherein
(i) defines the set of sound processing nodes neighboring the i-th sound processing node and
Rpij denotes a positive definite matrix that determines the convergence rate and that is defined ∀(i, j)∈E by the following equation:
This implementation form allows for an efficient computation of the plurality of weights by the processor of a sound processing node of an arrangement of sound processing nodes defining a cyclic network topology. In an implementation form, the sound processing node can be configured to distribute the variables λi,k+1 and φij,k+1 to neighboring sound processing nodes via any wireless broadcast or directed transmission scheme.
In an eighth possible implementation form of the sound processing node according to the fifth implementation form of the first aspect, the processor is configured to determine the plurality of weights on the basis of a min-sum message passing algorithm.
This implementation form allows for an efficient computation of the plurality of weights by the processor of a sound processing node of an arrangement of sound processing nodes defining an acyclic network topology.
In a ninth possible implementation form of the sound processing node according to the eighth implementation form of the first aspect, the processor is configured to determine the plurality of weights on the basis of a min-sum message passing algorithm using the following equation:
wherein mji denotes a message received by the sound processing node i from another sound processing node j and wherein the message mji is defined by the following equation:
wherein (j) defines the set of sound processing nodes neighboring the j-th sound processing node.
This implementation form allows for a very efficient computation of the plurality of weights by the processor of a sound processing node of an arrangement of sound processing nodes defining an acyclic network topology. In an implementation form, the sound processing node can be configured to distribute the message mji to neighboring sound processing nodes via any wireless broadcast or directed transmission scheme.
In a tenth possible implementation form of the sound processing node according to the first aspect as such or any one of the first to ninth possible implementation form thereof, the linearly constrained minimum variance approach is based on a covariance matrix R and wherein the processor is configured to approximate the covariance matrix R using an unbiased covariance of the plurality of sound signals.
This implementation form allows for a distributed estimation of the covariance matrix, for instance, in the presence of time varying noise fields.
In an eleventh possible implementation form of the sound processing node according to the tenth implementation form of the first aspect, the unbiased covariance of the plurality of sound signals is defined by the following equation:
wherein
Yi(l) denotes the vector of sound signals received by i-th sound processing node in the frequency domain and
M denotes the total number of microphones of all sound processing nodes.
According to a second aspect the application relates to a sound processing system comprising a plurality of sound processing nodes according to the first aspect, wherein the plurality of sound processing nodes are configured to exchange variables for determining the plurality of weights using a transformed version of the linearly constrained minimum variance approach.
According to a third aspect the application relates to a method of operating a sound processing node of an arrangement of sound processing nodes, the sound processing nodes being configured to receive a plurality of sound signals. The method comprises determining a beamforming signal on the basis of the plurality of sound signals weighted by a plurality of weights by determining the plurality of weights using a transformed version of a linearly constrained minimum variance approach, the transformed version of the linearly constrained minimum variance approach being obtained by applying a convex relaxation to the linearly constrained minimum variance approach.
The method according to the third aspect of the application can be performed by the sound processing node according to the first aspect of the application. Further features of the method according to the third aspect of the application result directly from the functionality of the sound processing node according to the first aspect of the application and its different implementation forms.
More specifically, in a first possible implementation form of the method according to the third aspect, the linearly constrained minimum variance approach is a robust linearly constrained minimum variance approach and the step of determining comprises the step of determining the plurality of weights using a transformed version of the robust linearly constrained minimum variance approach parametrized by a parameter α, wherein the parameter α provides a tradeoff between the minimization of the magnitude of the weights and the energy of the beamforming signal.
This implementation form allows the processor to provide robust values for the plurality of weights by allowing an adjustment of the parameter α.
In a second possible implementation form of the method according to the first implementation form of the third aspect, the step of determining comprises the step of determining the plurality of weights using the transformed version of the robust linearly constrained minimum variance approach on the basis of the following equation and constraints:
wherein
wi denotes the i-th weight of the plurality of weights,
Yi(l) denotes the vector of sound signals received by i-th sound processing node in the frequency domain,
V denotes the set of all sound processing nodes,
M denotes the total number of microphones of all sound processing nodes, i.e. M=Σi=1Nmi,
N denotes the total number of sound processing nodes,
Di(p) defines a channel vector associated with a p-th direction,
P denotes the total number of directions and
s(p) denotes the desired response for the p-th direction.
This implementation form allows for an efficient determination of the plurality of weights defining the beamforming signal by the processor of the sound processing node.
In a third possible implementation form of the method according to the first implementation form of the third aspect, the step of determining comprises the step of determining the plurality of weights using a further transformed version of the linearly constrained minimum variance approach, the further transformed version of the linearly constrained minimum variance approach being obtained by further transforming the transformed version of the linearly constrained minimum variance approach to the dual domain.
By exploiting strong duality this implementation form allows for an efficient determination of the plurality of weights defining the beamforming signal by the processor of the sound processing node.
In a fourth possible implementation form of the method according to the third implementation form of the third aspect, the step of determining comprises the step of determining the plurality of weights using the further transformed version of the linearly constrained minimum variance approach on the basis of the following equation using the dual variable λ:
wherein the plurality of weights wi are defined by a vector yi defined by the following equation:
y
i
=[t
i
(1)
,t
i
(2)
, . . . ,t
i
(M)
,w
i
(1)
,w
i
(2)
, . . . ,w
i
(m
)]T,
wherein
t
j
(l)=Σi∈VYi(l)Hwi,
Yi(l) denotes the vector of sound signals received by i-th sound processing node in the frequency domain,
V denotes the set of all sound processing nodes,
mi denotes the number of microphones of the i-th sound processing node, and
the dual variable λ is related to the vector yi by means of the following equation:
y
i
*=A
i
−1
B
i*λ*
and wherein Ai, Bi and C are defined by the following equations:
wherein
N denotes the total number of sound processing nodes,
M denotes the total number of microphones of all sound processing nodes, i.e. M=Σi=1Nmi,
Di(p) defines a channel vector associated with a p-th direction,
P denotes the total number of directions and
s(p) denotes the desired response for the p-th direction.
This implementation form allows for an efficient determination of the plurality of weights defining the beamforming signal by the processor of the sound processing node, because the optimal λ can be determined by inverting a (M+P) dimensional matrix which, for large arrangements of sound processing nodes, is much smaller than the N dimension matrix needed by conventional approaches.
In a fifth possible implementation form of the method of the third implementation form of the third aspect, the step of determining comprises the step of determining the plurality of weights using the further transformed version of the linearly constrained minimum variance approach on the basis of the following equation and the following constraint using the dual variable λ:
wherein
λi defines a local estimate of the dual variable λ at the i-th sound processing node,
Dij=Dji=±I with I denoting the identity matrix,
E defines the set of sound processing nodes defining an edge of the arrangement of sound processing nodes and
the plurality of weights wi are defined by a vector yi defined by the following equation:
y
i
=[t
i
(1)
,t
i
(2)
, . . . ,t
i
(M)
,w
i
(1)
,w
i
(2)
, . . . ,w
i
(m
)]T,
wherein
t
j
(l)=Σi∈VYi(l)Hwi,
Yi(l) denotes the vector of sound signals received by i-th sound processing node in the frequency domain,
V denotes the set of all sound processing nodes,
mi denotes the number of microphones of the i-th sound processing node, and
the dual variable λ is related to the vector yi by means of the following equation:
y
i
*=A
i
−1
B
i*λ*
and wherein Ai, Bi and C are defined by the following equations:
wherein
N denotes the total number of sound processing nodes,
M denotes the total number of microphones of all sound processing nodes, i.e. M=Σi=1Nmi,
Di(p) defines a channel vector associated with a p-th direction,
P denotes the total number of directions and
s(p) denotes the desired response for the p-th direction.
This implementation form is especially useful for arrangement of sound processing nodes defining an ad-hoc network of sound processing nodes, as new sound processing nodes can be added with only some of the rest of the nodes of the network having to be updated.
In a sixth possible implementation form of the method according to the fifth implementation form of the third aspect, the step of determining comprises the step of determining the plurality of weights on the basis of a distributed algorithm, in particular the primal dual method of multipliers.
This implementation form allows for a very efficient computation of the plurality of weights by the processor of a sound processing node of an arrangement of sound processing nodes defining a cyclic network topology.
In a seventh possible implementation form of the method according to the sixth implementation form of the third aspect, the step of determining comprises the step of determining the plurality of weights on the basis of a distributed algorithm by iteratively solving the following equations:
wherein
(i) defines the set of sound processing nodes neighboring the i-th sound processing node and
Rpij denotes a positive definite matrix that determines the convergence rate and that is defined ∀(i, j)∈E by the following equation:
This implementation form allows for an efficient computation of the plurality of weights by the processor of a sound processing node of an arrangement of sound processing nodes defining a cyclic network topology. In an implementation form, the sound processing node can be configured to distribute the variables λi,k+1 and φij,k+1 to neighboring sound processing nodes via any wireless broadcast or directed transmission scheme.
In an eighth possible implementation form of the method according to the fifth implementation form of the third aspect, the step of determining comprises the step of determining the plurality of weights on the basis of a min-sum message passing algorithm.
This implementation form allows for an efficient computation of the plurality of weights by the processor of a sound processing node of an arrangement of sound processing nodes defining an acyclic network topology.
In a ninth possible implementation form of the method according to the eighth implementation form of the third aspect, the step of determining comprises the step of determining the plurality of weights on the basis of a min-sum message passing algorithm using the following equation:
wherein mji denotes a message received by the sound processing node i from another sound processing node j and wherein the message mji is defined by the following equation:
wherein (j) defines the set of sound processing nodes neighboring the j-th sound processing node.
This implementation form allows for a very efficient computation of the plurality of weights by the processor of a sound processing node of an arrangement of sound processing nodes defining an acyclic network topology. In an implementation form, the sound processing node can be configured to distribute the message mji to neighboring sound processing nodes via any wireless broadcast or directed transmission scheme.
In a tenth possible implementation form of the method according to the third aspect as such or any one of the first to ninth possible implementation form thereof, the linearly constrained minimum variance approach is based on a covariance matrix R and the method comprises the further step of approximating the covariance matrix R using an unbiased covariance of the plurality of sound signals.
This implementation form allows for a distributed estimation of the covariance matrix, for instance, in the presence of time varying noise fields.
In an eleventh possible implementation form of the method according to the tenth implementation form of the third aspect, the unbiased covariance of the plurality of sound signals is defined by the following equation:
wherein
Yi(l) denotes the vector of sound signals received by i-th sound processing node in the frequency domain and
M denotes the total number of microphones of all sound processing nodes.
According to a fourth aspect the application relates to a computer program comprising program code for performing the method or any one of its implementation forms according to the third aspect of the application when executed on a computer.
The application can be implemented in hardware and/or software, and further, e.g. by a processor.
Further embodiments of the application will be described with respect to the following figures, in which:
In the various figures, identical reference signs will be used for identical or at least functionally equivalent features.
In the following detailed description, reference is made to the accompanying drawings, which form a part of the disclosure, and in which are shown, by way of illustration, specific aspects in which the present application may be practiced. It is understood that other aspects may be utilized and structural or logical changes may be made without departing from the scope of the present application. The following detailed description, therefore, is not to be taken in a limiting sense, as the scope of the present application is defined by the appended claims.
For instance, it is understood that a disclosure in connection with a described method may also hold true for a corresponding device or system configured to perform the method and vice versa. For example, if a specific method step is described, a corresponding device may include a unit to perform the described method step, even if such unit is not explicitly described or illustrated in the figures. Further, it is understood that the features of the various exemplary aspects described herein may be combined with each other, unless specifically noted otherwise.
In the exemplary embodiment shown in
The processor 103a of the sound processing node 101a is configured to determine a beamforming signal on the basis of the plurality of sound signals weighted by a plurality of weights. The processor 103a is configured to determine the plurality of weights using a transformed version of a linearly constrained minimum variance approach, the transformed version of the linearly constrained minimum variance approach being obtained by applying a convex relaxation to the linearly constrained minimum variance approach.
Generally, the number of sound signals received by the sound processing node 101a, i.e. the number of microphones 105 of the sound processing node 101a determines the number of weights to be determined. The plurality of weights defining the beamforming signal are usually complex valued, i.e. including a time/phase shift. In an embodiment, the processor 103 is configured to determine the plurality of weights for a plurality of different frequency bins. In an embodiment, the beamforming signal is a sum of the sound signals received by the sound processing node 101a weighted by the plurality of weights. The linearly constrained minimum variance approach minimizes the noise power of the beamforming signal, while adhering to linear constraints which maintain desired responses for the plurality of sound signals. Using a convex relaxed version of the linearly constrained minimum variance approach allows processing by each node of the arrangement of sound processing nodes 101a-c in a fully distributed manner.
In the following, further implementation forms, embodiments and aspects of the sound processing node 101a, the arrangement 100 of sound processing nodes 101a-c and the method 200 will be described.
In an embodiment, the linearly constrained minimum variance approach is a robust linearly constrained minimum variance approach and wherein the processor is configured to determine the plurality of weights using a transformed version of the robust linearly constrained minimum variance approach parametrized by a parameter α, wherein the parameter α provides a tradeoff between the minimization of the magnitude of the weights and the energy of the beamforming signal. Mathematically, the robust linearly constrained minimum variance approach parametrized by a parameter α for determining the plurality of weights for a particular frequency bin can be expressed in the form of an optimization problem as follows:
where R∈ is the covariance matrix, D∈×P denotes a set of P channel vectors from particular directions defined by the target sources, s∈P×1 is the desired response in those directions, w∈×1 is a weight vector having as components the plurality of weights to be determined and denotes to the total number of microphones 105a-c of the sound processing nodes 101a-c. It will be appreciated that in the limit α→0 the robust linearly constrained minimum variance approach defined by equation (1) turns into the linearly constrained minimum variance approach.
As information about the true covariance matrix R might not always be available, in an embodiment the processor 103a is configured to approximate the covariance matrix R using an unbiased covariance of the plurality of sound signals. In an embodiment, the unbiased covariance of the plurality of sound signals is defined by the following equation:
wherein Y(l) denotes the vector of sound signals received by the sound processing nodes 101a-c and M denotes the total number of microphones 105a-c of the sound processing nodes 101a-c. Each Y(l) may represent a noisy or noiseless frame of frequency domain audio. In practical applications, due to the length of each frame of audio (˜20 ms), in addition to the time varying nature of the noise field, it is often only practical to use a very small number of frames before they become significantly uncorrelated. Thus, in an embodiment each Y(l) can represent a noisy frame of audio containing both the target source speech as well as any interference signals. In an embodiment, M can be restricted to approximately 50 frames which implies that the noise field is “stationary” for at least half a second (due a frame overlap of 50%). In many scenarios, significantly less frames may be able to be used due to quicker variance in the noise field, such as one experiences when driving in a car.
By splitting the objective and constraints over the set of node based variables (denoted by a subscript i) equation 1 can be rewritten as:
where wi∈m
where Yi(l)∈μ
The Lagrangian of the primal problem defined by equation 4 has the following form:
where vj(l) are the dual variables associated with each tj(l)=Σi∈VYi(l)wi and μ(p) is the dual variable associated with the constraint Σi∈VDi(p)Hwi=s(p). As the primal problem is convex and explicitly feasible, the present application proposes to solve this problem in the dual domain by exploiting strong duality. Taking complex partial derivatives with respect to each tj(l) one finds that:
For a solution point to be primal feasible then each tj(l)=ti(l)=t(l)=Σi∈VYi(l)Hwi. Thus at optimality vj(l)=vi(l)={circumflex over (v)}(l), where {circumflex over (v)}(l) denotes the optimal dual variable. By restricting the form of the dual variables such that all vi(l)={circumflex over (v)}(l)∀i∈V, one retains the same optimal solution at consensus whilst reducing the number of dual variables which need to be introduced. This allows one to construct an equivalent primal Lagrangian of the form:
Thus, it is possible to construct an equivalent convex optimization problem to that in equation 5 which only introduces M dual constraints. This has the form:
Thus, in an embodiment the processor 103a of the sound processing node 101a is configured to determine the plurality of weights wi on the basis of equation 8.
Above equation 8 can be rewritten in the following form:
with a primal Lagrangian given by:
In an embodiment, the matrix Bi can also be written in the following simplified way:
The dual problem can be found by calculating the complex partial derivatives of equation 11 with respect to each yi and equating these derivatives to 0, i.e.
The resulting dual problem can be therefore shown to be:
Thus, in an embodiment the processor 103a of the sound processing node 101a is configured to determine the plurality of weights wi on the basis of equations 13, 12 and 10. Given equation 13 the optimal λ can be found by inverting a (M+P) dimension matrix which, for arrangements with a large number of sound processing nodes, is much smaller than the N dimension matrix usually needed. As the inversion of a dimension D matrix is a O(D3) operation embodiments of the present application also provides a considerable reduction in computational complexity when M+P<N.
By introducing local estimates λi at each sound processing node 101a-c and adding the constraint that along each edge of the arrangement 100 of sound processing nodes λi=λj should hold, equation 13 can be shown to be equivalent to the following distributed optimization problem:
Thus, in an embodiment the processor 103a of the sound processing node 101a is configured to determine the plurality of weights wi on the basis of equations 14, 12 and 10. In this case the restriction Dij=−Dji=±I is made, where I denotes the identity matrix. It should be noted that the edges of the corresponding arrangement 100 of sound processing nodes 101a-c can be completely self-configuring and not known to anyone except for the sound processing nodes at either end of them. Thus, in an embodiment a sound processing node simply can monitor from which other sound processing nodes it can receive packets from (given a particular transmission range and/or packet quality) and from this infers who its neighboring sound processing nodes are independent of the remainder of the network structure defined by the arrangement 100 of sound processing nodes. This is particularly useful for an ad-hoc formation of a network of sound processing nodes as new sound processing nodes can be added to the network without the remainder of the network needing to be updated in any way.
If in alternative embodiments greater restrictions on the network topology, such as an acyclic or tree shaped topology, are to be imposed, additional “offline” processing prior to the use of the arrangement 100 of sound processing nodes 101a-c might become necessary.
One of the major benefits of the above described embodiments in comparison to conventional approaches is that they provide a wide range of flexibility in terms of how to solve the distributed problem as well any of the aforementioned restrictions to be imposed upon the underlying network topology of the arrangement 100 of sound processing nodes 101a-c. For instance, the most general class of undirected network topologies is those which may contain cyclic paths, a common feature in wireless sensor networks particularly when ad-hoc network formation methods are used. In contrast to conventional optimal distributed approaches, where cyclic network topologies are often ignored, the introduction of cycles has no effect on the ability of the different embodiments disclosed herein to solve the robust LCMV problem. For instance, the problem defined by equation 14 is in a standard form to be solved by a distributed algorithm such as the primal dual method of multipliers (BiADMM), as described in Zhang, Guoqiang, and Richard Heusdens, “Bi-alternating direction method of multipliers over graphs” in Acoustics, Speech and Signal Processing (ICASSP), 2015 IEEE International Conference, pp. 3571-3575, IEEE, 2015. Therefore, using a simplified dual update method it can be shown that one way to iteratively solve equation 14 in cyclic networks of sound processing nodes 101a-c is given by a BiADMM update scheme defined as:
wherein (i) defines the set of sound processing nodes neighboring the i-th sound processing node and Rpij denotes a positive definite matrix that determines the convergence rate and that is defined ∀(i,j)∈E by the following equation:
Thus, in an embodiment the processor 103a of the sound processing node 101a is configured to determine the plurality of weights on the basis of iteratively solving equations 15.
In the embodiment shown in
In the embodiment shown in
As already described above, the processor 103a can be configured to determine the plurality of weights in the frequency domain. Thus, in an embodiment the processor 103a can be further configured to transform the plurality of sound signals received by the plurality of microphones 105a into the frequency domain using a Fourier transform.
In the embodiment shown in
In an alternative embodiment, especially suitable for enforcing a greater restriction on the topology of the network of sound processing nodes by removing the presence of all cyclic paths, an approach can be adopted which guarantees convergence within a finite number of transmissions between the sound processing nodes. This embodiment makes use of the fact that it is not necessary to store each BiHAi−1Bi at every sound processing node to solve equation 13, rather only a global summation can be stored. Thus, by aggregating data along the network of sound processing nodes via a min-sum message passing algorithm, it is possible to uniquely reconstruct the global problem at each sound processing node using only locally transferred information. Thus, in an embodiment the processor of each sound processing node, for instance the processor 103a of the sound processing node 101a, is configured to generate the solution to the distributed problem by solving the following equation:
wherein each message from a sound processing node i to another sound processing node j is defined as:
Each message is comprised of a (M+P) dimension positive semi-definite matrix which has only
unique variables which need to be transmitted. However, by considering a parameterized form of each BiHAi−1Bi where:
it can be shown that
Therefore, due to the reuse of M−1 frames of data between audio blocks, only M+P new variables are introduced into the final matrix in the case of stationary target sources. This means that by reusing those values that are repeated the amount of data which needs to be transmitted between sound processing nodes can be reduced. If, however, varying target sources between blocks are allowed for as well, which may be the case if the location of a target source is estimated in real time, then a further
variables need to be transmitted resulting in a total of
values. Although this increases the number of values to transmit per node-to-node communication, one has the benefit that the min-sum algorithm in tree shaped graphs requires only 2N transmissions to reach consensus. This makes the acyclic message passing embodiment attractive in contrast to the iterative based embodiment described above, as we can exactly bound the time needed to reach consensus for each audio block and a known number of sound processing nodes.
In the embodiment shown in
In the embodiment shown in
As already described above, the processor 103a can be configured to determine the plurality of weights in the frequency domain. Thus, in an embodiment the processor 103a can be further configured to transform the plurality of sound signals received by the plurality of microphones 105a into the frequency domain using a Fourier transform.
Embodiments of the application can be implemented in the form of automated speech dictation systems, which are a useful tool in business environments for capturing the contents of a meeting. A common issue though is that as the number of users increases so does the noise within audio recordings due to the movement and additional talking that can take place within the meeting. This issue can be addressed in part through beamforming however having to utilize dedicated spaces equipped with centralized systems or attaching personal microphone to everyone to try and improve the SNR of each speaker can be an invasive and irritating procedure. In contrast, by utilizing existing microphones present at any meeting, namely those attached to the cellphones of those present, embodiments of the application can be used to form ad-hoc beamforming networks to achieve the same goal. Additionally the benefit of this type of approach is that it achieves a naturally scaling architecture as when more members are present in the meeting the number of nodes (cellphones) increases in turn. When combined with the network size independence of the embodiments of this application this leads to a very flexible solution to providing automated speech beamforming as a front end for automated speech dictation systems.
In the case of arrangement of sensor nodes in the form of fixed structure wireless sensor networks, embodiments of the application can provide similar transmission (and hence power consumption), computation (in the form of a smaller matrix inversion problem) and memory requirements as other conventional algorithms, which operate in tree type networks, while providing an optimal beamformer per block rather than converging to one over time. In particular, for arrangements with a large numbers of sound processing nodes, which may be used in the case of speech enhancement in large acoustic spaces, the above described embodiments especially suited for acyclic networks provide a significantly better performance than fully connected implementations of conventional algorithms. For this reason embodiments of the present application are a potential tool for any existing distributed beamformer applications where a block-optimal beamformer is desired.
Moreover, embodiments of the application provide amongst others for the following advantages. Embodiments of the application allow large scale WSNs to be used to solve robust LCMV problems in a fully distributed manner without the need to vary the operating platform given different network sizes. Embodiments of the application do not provide approximation of the robust LCMV solution as given the same input data, but rather solve the same problem as a centralized implementation. As the basis algorithm is a LCMV type beamformer, embodiments of the application gain the same increased flexibility noted over MVDR based methods by allowing for multiple constraint functions at one time. Additionally, as the covariance matrix can be re-estimated at each audio block, embodiments of the application can track non-stationary noise fields without additional modification. The non-scaling distributed nature provided by embodiments of the application makes it practical to design, at the hardware level, a sound processing node architecture which can be used for acoustic beam-forming via WSNs regardless of the scale of deployment needed. These sound processing nodes can also contain varying numbers of on node microphones which allows for the mixing and matching of different specification node architectures should networks need to be augmented with more nodes (assuming the original nodes are unavailable). The distributed nature of the arrangement of sound processing nodes provided by embodiments of the application also has the benefit of removing the need for costly centralized systems and the scalability issues associated with such components. Finally, the generalized nature of the distributed optimization formulation offers designers a wide degree of flexibility in how they choose to implement embodiments of the application. This allows them to trade off different performance metrics when choosing aspects such as the distributed solvers they want to use, the communication algorithms they implement between nodes or if they want to apply additional restrictions to the network topology to exploit finite convergence methods.
While a particular feature or aspect of the disclosure may have been disclosed with respect to only one of several implementations or embodiments, such feature or aspect may be combined with one or more other features or aspects of the other implementations or embodiments as may be desired and advantageous for any given or particular application. Furthermore, to the extent that the terms “include”, “have”, “with”, or other variants thereof are used in either the detailed description or the claims, such terms are intended to be inclusive in a manner similar to the term “comprise”. Also, the terms “exemplary”, “for example” and “e.g.” are merely meant as an example, rather than the best or optimal. The terms “coupled” and “connected”, along with derivatives may have been used. It should be understood that these terms may have been used to indicate that two elements cooperate or interact with each other regardless whether they are in direct physical or electrical contact, or they are not in direct contact with each other.
Although specific aspects have been illustrated and described herein, it will be appreciated by those of ordinary skill in the art that a variety of alternate and/or equivalent implementations may be substituted for the specific aspects shown and described without departing from the scope of the present disclosure. This application is intended to cover any adaptations or variations of the specific aspects discussed herein.
Although the elements in the following claims are recited in a particular sequence with corresponding labeling, unless the claim recitations otherwise imply a particular sequence for implementing some or all of those elements, those elements are not necessarily intended to be limited to being implemented in that particular sequence.
Many alternatives, modifications, and variations will be apparent to those skilled in the art in light of the above teachings. Of course, those skilled in the art readily recognize that there are numerous applications of the application beyond those described herein. While the present application has been described with reference to one or more particular embodiments, those skilled in the art recognize that many changes may be made thereto without departing from the scope of the present application. It is therefore to be understood that within the scope of the appended claims and their equivalents, the application may be practiced otherwise than as specifically described herein.
This application is a continuation of International Application No. PCT/EP2015/073907, filed on Oct. 15, 2015, the disclosure of which is hereby incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/EP2015/073907 | Oct 2015 | US |
Child | 15940635 | US |