DISTRIBUTED PROCESS STATE AND INPUT ESTIMATION FOR HETEROGENEOUS ACTIVE/PASSIVE SENSOR NETWORKS

Information

  • Patent Application
  • 20220390480
  • Publication Number
    20220390480
  • Date Filed
    August 01, 2022
    2 years ago
  • Date Published
    December 08, 2022
    2 years ago
Abstract
Systems and methods are described for estimating a state of a process and an input to the process using a sensor network. Each sensor node in the sensor network is directly to one or more adjacent sensor nodes and indirectly coupled to the remaining sensor nodes through the one or more adjacent sensor nodes. Each sensor node iteratively calculates a new estimated state based on estimations of the state and the input to the process calculated by the sensor node in a previous iteration. The new estimated state is then adjusted based on a difference between a predicted and actual output of a sensor and is further adjusted based on differences between a previous estimated state calculated by the sensor node and estimated states calculated by adjacent sensor nodes.
Description
BACKGROUND

The present invention relates to sensing technology and, in particular, relates to sensor networks.


SUMMARY

A distributed input and state estimation architecture is introduced and analyzed for heterogeneous sensor networks. Specifically, nodes of a sensor network are allowed to have heterogeneous information roles. In addition, these nodes are allowed to have nonidentical sensor modalities. A feature of the framework described herein is that it utilizes local information not only during the execution of the proposed distributed input and state estimation architecture, but also in its design in that global stability is guaranteed once each node satisfies given local stability conditions independent from the graph topology and neighboring information of these nodes. Several illustrative numerical examples are further provided to demonstrate the efficacy of the proposed architecture. For example, a subset of nodes can be active (i.e., subject to observations of a process of interest) and the rest can be passive (i.e., subject to no observations of the process of interest). Both fixed and time-varying active and passive roles of sensor nodes in the network are investigated under the common underlying assumption that they have complementary properties distributed over the sensor network to achieve observability.


In one embodiment, the invention provides a method for estimating an observed process using a sensor network that includes a plurality of active sensor nodes and a plurality of passive sensor nodes. An electronic processor receives an output signal from a sensor of a first sensor node indicative of a measurement of an observed process. The electronic processor calculates a new estimated state of the observed process based at least in part on a previous estimation of the state calculated for the first sensor node and a previous estimation of an input to the observed process calculated for the first sensor node. In some implementations, the previous estimation of the state and the input were calculated by the electronic processor in a previous iteration. The electronic processor then adjusts the new estimated state based on an observed difference between a predicted output of the sensor of the first sensor node and an actual output of the sensor of the first sensor node and further adjusts the new estimated state based on a calculated difference between the previous estimation of the state calculated for the first sensor node and an estimation of the state calculated for a second sensor node that is adjacent to the first sensor node in the sensor network. The adjusted new estimated state of the observed process is then output to at least one adjacent sensor node in the sensor network.


In another embodiment, the invention provides a sensor network that includes a plurality of sensor nodes arranged in an undirected and connected graph topology. Each sensor node is communicatively coupled directly to one or more adjacent sensor nodes and is indirectly coupled to the remaining sensor nodes through the one or more adjacent sensor nodes. The sensor network includes a subset of active sensors that are able to observe a process of interest and a subset of passive sensor nodes that are not able to observe the process of interest. Each sensor node includes a sensor and an electronic processor configured to iteratively repeat a process for estimating a state of the process of interest. The electronic processor of each sensor node receives an output signal from its corresponding sensor indicative of a measurement of the observed process. A new estimated state is calculated based at least in part on estimations of the state of the process and an input to the process calculated by the sensor node in a previous iteration. The new estimated state is then adjusted based on a difference between a predicted output of the sensor and an actual output of the sensor and is further adjusted based on calculated differences between the estimation of the state calculated for the sensor node in the previous iteration and an estimation of the state calculated for each adjacent sensor node. The adjusted new estimated state of the observed process is then output to each adjacent sensor node.


In some embodiments, the invention provides a heterogeneous sensor network including a first subset of sensors, a second subset of sensors, and an electronic processor. The first subset of sensors includes active sensors while the second subset of sensors includes passive sensors. The electronic processor is configured to estimate an input for a sensor in one selected from a group consisting of the first subset of sensors and the second subset of sensors using only local information, and estimate a state for the sensor using only local information by satisfying a local stability condition.


Other aspects of the invention will become apparent by consideration of the detailed description and accompanying drawings.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a block diagram of a sensor node in a sensor network according to one embodiment.



FIG. 2 is a block diagram of a first example of a sensor network including four active sensor nodes and eight passive sensor nodes.



FIG. 3 is a block diagram of a second example of a sensor network including eight active sensor nodes and four passive sensor nodes.



FIG. 4A is a flowchart of a method for estimating a state of a process observed by one or more sensor nodes in a sensor network using the sensor node of FIG. 1.



FIG. 4B is a flowchart of a method for estimating an input to the process observed by the one or more sensor nodes in the sensor network using the sensor node of FIG. 1.



FIG. 5 is a graph illustrating the effect of γ∈(0,2] and α∈{0.25, 1, 2.5, 5, 10, 50} to an ultimate bound ψ in a mathematical estimation performed by the sensor node of FIG. 1.



FIG. 6 is a graph illustrating examples of state estimates of the sensor network of FIG. 2 using the method of FIG. 4A.



FIG. 7 is a graph illustrating examples input estimates of the sensor network of FIG. 2 using the method of FIG. 4B.



FIG. 8 is a graph illustrating examples of state estimates of the sensor network of FIG. 3 using the method of FIG. 4A.



FIG. 9 is a graph illustrating examples of input estimates of the sensor network of FIG. 3 using the method of FIG. 4B.



FIG. 10 is a graph illustrating examples of state estimates of a sensor network of FIG. 3 using the method of FIG. 4A with system output matrices that are different than those used in the example of FIG. 8.



FIG. 11 is a graph illustrating examples of input estimates of the sensor network of FIG. 3 using the method of FIG. 4B with system output matrices that are different than those used in the example of FIG. 9.



FIG. 12 is a block diagram of another example of a sensor network including twelve sensor nodes where the active and passive role of each node is varying over time.



FIG. 13 is a graph illustrating examples of state estimates of the sensor network of FIG. 12 using the method of FIG. 4A.



FIG. 14 is a graph illustrating examples of positions of an object estimated by the sensor network of FIG. 12 determined based on the estimated states of FIG. 13.



FIG. 15 is a graph illustrating examples of input estimates of the sensor network of FIG. 12 using the method of FIG. 4B.



FIG. 16 is a graph illustrating examples of state estimates of the sensor network of FIG. 12 using the method of FIG. 4A after decreasing the value of a positive design coefficient σi.



FIG. 17 is a graph illustrating examples of input estimates of the sensor network of FIG. 12 using the method of FIG. 4B after decreasing the value of the positive design coefficient σi.





DETAILED DESCRIPTION

Before any embodiments of the invention are explained in detail, it is to be understood that the invention is not limited in its application to the details of construction and the arrangement of components set forth in the following description or illustrated in the following drawings. The invention is capable of other embodiments and of being practiced or of being carried out in various ways.


As technological advances have boosted the development of integrated microsystems that combine sensing, computing, and communication on a single platform, we are rapidly moving toward a future in which large numbers of integrated microsensors have the capability to operate in both civilian and military environments. Such large-scale sensor networks will support applications with dramatically increasing levels of complexity including situational awareness, environment monitoring, scientific data gathering, collaborative information processing, and search and rescue; to name but a few examples. One of the important areas of research in sensor networks is the development of distributed estimation algorithms for dynamic information fusion. Systems and algorithms, such as those described in the examples below, can continue to operate reliably even when subsets of nodes in the sensor network and/or communication links between some of the nodes are lost. These systems are flexible in the sense that nodes can be added and removed by making only local changes to the sensor network.


Heterogeneity in sensor networks is unavoidable in real-world applications. To elucidate this fact, consider the example of a system configured to estimate the position and/or speed of a moving target. Nodes of a sensor network configured to monitor the moving target can have heterogeneous information roles such that some nodes are subject to observations of the target object (i.e., active nodes) while the rest are not (i.e., passive nodes). Furthermore, in some implementations, the nodes of a sensor network can also have different sensor modalities. For example, some nodes in the sensor network can be configured to sense/measure the position of the target object while other nodes in the network are configured to sense/measure the velocity of the target object.


Dealing with these classes of heterogeneity in sensor networks to achieve correct and reliable dynamic information fusion is a challenging task using distributed estimation algorithms. In some implementations, dynamic consensus algorithms might be implemented in sensor networks where all nodes are active nodes. However, in many cases, a subset of nodes in a given sensor network can be passive in that they may not be able to sense and collect information about a process of interest (e.g., a position or velocity of a target object). Similar problems arise for sensor networks in which individual sensor nodes are configured to sense/measure in different modalities (e.g., position vs. velocity).


The examples presented below provide a new distributed input and state estimation architecture for heterogeneous sensor networks. Specifically, the systems and methods described herein can be applied to a sensor network with a first subset of nodes that are active nodes and a second subset of nodes that are passive nodes. In different implementations, the role of each individual nodes as an active node or a passive node can be fixed or varying. Furthermore, the systems and methods described below can be adapted and applied to sensor networks that include nodes with non-identical sensor modalities under the common underlying assumption that they have complimentary properties distributed over the sensor network to achieve collective observability. The systems and method described below utilize local information, not only during the execution of the proposed distributed input and state estimation, but also in its design. Accordingly, global stability is guaranteed once each node satisfies given local stability conditions independent from the graph topology and neighboring information of the nodes in the sensor network.



FIG. 1 illustrates an example of a sensor node 101 in a sensor network 100. The sensor node 101 includes a sensor 103 configured to sensor/measure a condition of an observable process. For example, in an implementation where the sensor network 100 is configured to observe movement of an object in space, the sensor 103 may be configured to measure a position and/or a velocity of the target object. The sensor node 101 also includes an electronic processor 105 and a non-transitory, computer-readable memory 107. The memory 107 stores data and computer-executable instructions that are executed by the electronic processor 105 to provide the functionality of the sensor node 101 including, for example, the functionality described in the examples below. The electronic processor 105 receives an output signal from the sensor 103 indicative of a measured condition of the target process (e.g., indicative of movement and/or position of the object in space). The electronic processor 105 executes instructions accessed from the memory 107 in order to determine an estimate of a state of the observed process and an estimate of an “input” to the observed process (e.g., a command controlling movement of the target object). The electronic processor 105 is also communicatively coupled to a plurality of other sensor nodes in the sensor network while other sensor nodes in the sensor network are not directly coupled to the sensor node 101. Accordingly, sensor nodes that are in direct communication with the sensor node 101 are referred to herein as “adjacent nodes” (e.g., adjacent nodes 109, 111, and 113 in the example of FIG. 1).



FIG. 2 illustrates an example of a sensor network 200 including twelve sensor nodes (such as, for example, the sensor node 101 of FIG. 1). In the sensor network 200 of FIG. 2, four nodes are active nodes (i.e., Node 1, Node 2, Node 5, and Node 6) while the remaining eight sensor nodes are passive nodes. In the network topology of the example of FIG. 2, Node 1 is in direct communication with Node 2, Node 5, and Node 6. Accordingly, Nodes 2, 5, & 6 are “adjacent” to Node 1. Similarly, Node 7 is coupled in direct communication with (i.e., “adjacent to”) Nodes 3, 6, 8, and 11.



FIG. 3 illustrates another example of a sensor network 300 including twelve sensor nodes. However, unlike the example of FIG. 2, in the example of FIG. 3 eight sensor nodes are active nodes while only four nodes are passive nodes. As discussed in further detail below, a sensor node can be fixedly “passive” by design such that, for example, the node does not include a sensor that is capable of observing/measuring a particular process or the sensing capabilities of the node have been actively disabled. Alternatively, in some implementations, some or all of the sensor nodes in the sensor network can be varyingly active or passive. For example, a sensor node can become an “active node” when an object under observation moves within range of the sensor node and can become a “passive node” when the object moves beyond range of the sensor node.


In some implementations, each node in the sensor network (or a select subset of nodes) is individually configured to determine an estimated state of a process under observation as well as an estimated “input” to the process under observation based on the output of the local sensor (i.e., sensor 103 of sensor node 101), previously stored information, and information received from adjacent sensor nodes. In at least some implementations, the process enables each individual node to determine the estimated state and input without requiring sensor information from all of the sensor nodes in the sensor network.



FIG. 4A illustrates an example of a method executed by a sensor node (such as sensor node 101 of FIG. 1) for determining an estimated state of the process under observation. First, the electronic processor 105 receives a signal from the sensor 103 indicative of a measured output of the sensor (step 401), accesses a previously calculated estimation of the state and input (e.g., stored to memory 107) (steps 403 and 405), and receives a previous local estimate of the state and the input as determined by the adjacent nodes in the sensor network (step 407). As described in further detail below, the electronic processor 105 calculates an initial new estimated state based on the estimated state and the estimate input calculated by the electronic processor 105 in a previous iteration (i.e., the values accessed from the memory 107) (step 409).


If the sensor node 101 is an “active node” (step 415), then the electronic processor 105 adjusts the initial estimated state based on observed differences between an expected output of the sensor 103 and an actual output of the sensor 103 (step 417). In particular, as described in further detail below, the electronic processor calculates an estimated sensor output based at least in part on the estimated state from the previous iteration (step 411). In other words, the electronic processor 105 determines what the output of the sensor 103 would be if the state and input of the process were unchanged since the last iteration. The electronic processor 105 then calculates a difference between the estimated sensor output and the actual output of the sensor 103 (step 413) and adjusts the new estimated state based at least in part on the difference (step 415). However, if the sensor node 101 is not an “active node,” then the sensor 103 will not produce an output indicative of the observed process and, therefore, the new estimated state cannot be adjusted based on a difference between the expected sensor output and the actual sensor output (i.e., step 415 is skipped if the sensor node is a passive node).


Next, the new estimated state is adjusted by the electronic processor 105 based on differences between previous local estimations of the state of the observed process (step 419). For example, as described in further detail below, the electronic processor 105 may be configured in some implementations to calculate a difference between the estimated state calculated by the sensor node in the previous iteration and the estimated state calculated by each adjacent node.


After the new estimated state is calculated (step 409) and adjusted for observed differences in the sensor output (step 417) and/or differences in local estimations of the state (step 419), the new estimation of the process state is transmitted to adjacent nodes in the sensor network (step 421) and saved to the memory 107 to be used in the next iteration of the state estimation (i.e., step 403).


In the example of FIG. 4A, one of the inputs used to calculate a new current state of the observed process is a previously calculated estimate of a process input (step 405). FIG. 4B illustrates an example of a method implemented by the sensor node 101 for estimating the process input state. Again, as discussed above in reference to the example of FIG. 4A, the electronic processor 105 receives a measured output from the sensor 103 (step 401), accesses from the memory 107 estimated values of the state and input for the observed process from a previous iteration (step 403 and 405), and receives estimated values of the state and input from other adjacent nodes (step 407). The electronic processor 105 calculates a new estimate of the process input based at least in part on the previous estimate of the input accessed from memory (step 431). In some implementations, the electronic processor 105 is configured to calculate an updated “input” estimate for the process based at least in part on design coefficients for the particular sensor node (as discussed in further detail below). In some implementations, the electronic processor is configured to simply assume initially that the input has not changed since the previous iteration and, accordingly, the initial new estimate of the input is determined to be equal to the estimated input from the previous iteration.


Similar to the example of FIG. 4A, if the sensor node 101 is an “active node” (step 433), then the electronic processor 105 adjusts the initial estimated input based on the observed differences between an expected output of the sensor 103 and an actual output of the sensor 103 (step 435). More specifically, and as discussed in further detail below, the electronic processor 105 is configured to calculate an estimated sensor output based on the estimated state from the previous iteration (step 411) and to calculate a difference between the estimated sensor output and the actual sensor output (step 413). The electronic processor 105 is also configured to adjust the new estimated process input based on differences between the process input estimated by the sensor node 101 in the previous iteration and the process input as estimated by the adjacent nodes in direct communication with the sensor node 101 (step 437).


After the new estimated process input is calculated (step 431) and adjusted for observed differences in the sensor output (step 435) and/or differences in local estimations of the process input (step 437), the new estimation of the process input is transmitted to adjacent nodes in the sensor network (step 439) and saved to the memory 107 to be used in the next iteration of the process input estimation (i.e., step 405).


A series of specific numerical examples are provided below to further illustrate the details of certain implementations of the methods and systems described above. In the examples below, custom-character denotes the set of real numbers, custom-charactern denotes the set of n×1 real column vectors, custom-charactern×m denotes the set of n×m real matrices, custom-character+n×n (resp., custom-character+n×n) denotes the set of n×n positive-definite (resp., positive-semidefinite) real matrices, 0n denotes the n×1 vector of all zeros, 1n denotes the n×1 vector of all ones, and In denotes the n×n identity matrix. In addition, we write (⋅)T for transpose, (⋅) for generalized inverse, λmin(A) and λmax(A) for the minimum and maximum eigenvalue of the Hermitian matrix A, respectively, λi (A) for the i-th eigenvalue of A, where A is Hermitian and the eigenvalues are ordered from least to greatest value, diag(a) for the diagonal matrix with the vector a on its diagonal, [x]i for the entry of the vector x on the i-th row, and [A]ij for the entry of the matrix A on the i-th row and j-th column.


Graphs are broadly adopted in the description of sensor networks to encode interactions between nodes. An undirected graph custom-character is defined by a set custom-character={1, . . . , N} of nodes and a set εcustom-charactercustom-character×custom-character of edges. If (i, j)∈εcustom-character, then the nodes i and j are neighbors (i.e., adjacent nodes) and the neighboring relation is indicated with i˜j. The degree of a node is given by the number of its neighbors. Letting di be the degree of node i, then the degree matrix of a graph custom-character,custom-character(custom-character)∈custom-characterN×N, is given by






custom-character(custom-character)custom-characterdiag(d),d=[d1, . . . ,dN]T.  (1)


A path i0 i1 . . . iL is a finite sequence of nodes such that ik−1˜ik, k=1, . . . , L, and a graph custom-character is connected if there is a path between any pair of distinct nodes. The adjacency matrix of a graph custom-character,custom-character(custom-character)∈custom-characterN×N, is given by











[

𝒜

(
𝒢
)

]


i

j



=



{





1
,





if



(

i
,
j

)





𝒢







0
,



otherwise



.






(
2
)







The Laplacian matrix of a graph custom-character(custom-character)∈custom-character+N×N, playing a central role in many graph-theoretic treatments of sensor networks, is given by






custom-character(custom-character)custom-charactercustom-character(custom-character)−custom-character(custom-character).  (3)


The spectrum of the Laplacian of an undirected and connected graph can be ordered as





0=λ1(custom-character(custom-character))<λ2(custom-character(custom-character))≤ . . . ≤λN(custom-character(custom-character)),  (4)


with 1N as the eigenvector corresponding to the zero eigenvalue λ1(custom-character(custom-character)) and custom-character(custom-character)1N=0N and custom-character=1N. Throughout this description we assume that the graph custom-character of a given sensor network is undirected and connected.


To develop some of the results of this system, the following lemmas are used:


Lemma 1 (see, e.g., Dennis S. Bernstein, Matrix Mathematics: Theory, Facts, and Formulas, Princeton University Press, 2009, Proposition 8.1.2): Let A∈custom-charactern×n and B∈custom-charactern×n. If A≥0 and B>0 then A+B>0.


Lemma 2 (see, e.g., Dennis S. Bernstein, Matrix Mathematics: Theory, Facts, and Formulas, Princeton University Press, 2009, Proposition 8.2.4): Let A∈custom-charactern×n, B∈custom-charactern×m, C∈custom-characterm×m, and






X
=


[



A


B





B
T



C



]

.





Then, X≥0 if and only if one or both of the conditions given by






A≥0,C−BTAB≥0,(I−AA)B=0,  (5)






C≥0,A−BCBT≥0,(I−CC)BT=0,  (6)


hold.


Finally, CoΩ is defined as a polytope or a bounded polyheron, which is the intersection of a finite number of halfspace and hyperplanes. For the following lemma, let P∈custom-charactern×nA(t)∈custom-charactern×n, CoΩcustom-characterCo{A1, . . . , AL} where Co denotes the convex hull and Aicustom-charactern×n are the vertices of the polytope.


Lemma 3 (see, e.g., Stephen P Boyd, Laurent El Ghaoui, Eric Fenton, and Venkataramanan Balakrishnan, Linear Matrix Inequalities in System and Control Theory, volume 15, SIAM 1994): If P>0, AiTP+PAi≤0 holds, then P>0, AT(t)P+PA(t)≤0 holds.


By letting P=In, it follows from Lemma 3 that AT(t)+A(t)≤0 holds, when AiT+Ai≤0 holds. If, in addition, A(t) is symmetric, then it further follows that A(t)≤0 holds, if Ai≤0.


The examples discussed below relate to a process of interest with open-loop or closed-loop dynamics given by






{dot over (x)}(t)=Ax(t)+Bw(t),x(0)=x0  (7)


where x(t)∈custom-charactern denotes an unmeasurable process state vector, w(t)∈custom-characterp denotes an unknown bounded input (e.g., command) to the process x with a bounded time rate of change, A∈custom-charactern×n denotes the Hurwitz system matrix necessary for internal process stability, and B∈custom-charactern×p denotes the system input matrix.


Next, consider a sensor network with N nodes exchanging information among each other using their local measurements according to an undirected and connected graph custom-character. If a node i, i=1, . . . , N, is subject to observations of the process (7) given by






y
i(t)=Cix(t),  (8)


where yi(t)∈custom-characterm and Cicustom-characterm×n denote the measurable process output and the system output matrix for node i, i=1, . . . , N, respectively, then we say that it is an active node. Similarly, if a node i, i=1, . . . , N, has no observations, then we say that it is a passive node. Notice that the above formulation allows for nonidentical sensor modalities since Ci of active nodes can be different. In the examples described below, each active node has complimentary properties distributed over the sensor network to guarantee collective observability, although the pairs (A, Ci), i=1, . . . , N may not be locally observable.


Here, we are interested in the problem of distributive estimating the unmeasureable state x(t) and the unknown input w(t) of the process given by (7) using a sensor network, where active nodes are subject to the observations given by (8). For node i, i=1, . . . , N, consider the distributed estimation algorithm (i.e., the methods of FIGS. 4A and 4B) given by














x
^

.

i

(
t
)

=



(

A
-

γ


P
i

-
1




)





x
^

i

(
t
)


+

B




w
^

i

(
t
)


+


g
i




L
i

(



y
i

(
t
)

-


C
i





x
^

i

(
t
)



)


-

α


P
i

-
1







i

j




(




x
^

i

(
t
)

-



x
^

j

(
t
)


)





,




x
^

i

(
0
)

=


x
^


i

0







(
9
)

















w
^

.

i

(
t
)

=



g
i




J
i

(



y
i

(
t
)

-


C
i





x
^

i

(
t
)



)


-


(



σ
i



K
i


+

γ


I
p



)





w
^

i

(
t
)


-

α





i

j




(




w
^

i

(
t
)

-



w
^

j

(
t
)


)





,




w
^

i

(
0
)

=


w
^


i

0







(
10
)







where {circumflex over ({dot over (x)})}(t)∈custom-charactern is a local state estimate of x(t) for node i, ŵicustom-characterp is a local input estimate of w(t) for node i, Licustom-charactern×m and jicustom-characterp×m are design matrices of node i with Ki being symmetric and positive definite, and α, γ, and σicustom-character are positive design coefficients for node i. Here, gi=1 for active nodes and otherwise gi=0. In addition, Pi>0 is the consensus gain satisfying the linear matrix inequality given by











R
i

=


[







A
_

i
T



P
i


+


P
i




A
_

i








-

P
i



B

+


g
i



C
i
T



J
i
T










-

B
T




P
i


+


g
i



J
i



C
i







-
2



σ
i



K
i





]


0


,




(
11
)







where






Ā
i
custom-character
A−g
i
L
i
C
i.  (12)


The local condition given by (11) for node i, i=1, . . . , N, plays a central role in the stability analysis described below. Specifically, if the proposed input and state estimation architecture given by (9) and (10) satisfies the local condition given by (11) for each node, then the global stability is guaranteed for the overall sensor network. In addition, note that the local condition given by (11) is well-posed. To see this, for example, let Pi satisfy the linear matrix inequality given by ĀiTPi+PiĀi<0, i−1, . . . , N. Then, it can be readily shown that there can exist a sufficiently large σi, i=1, . . . , N, such that (11) holds. As a special case, if all nodes are active and a condition PiB=CiTJiT holds, then it can be easily seen that (11) holds even for small values of σi, i=1, . . . , N. From this standpoint, it should be also mentioned that (11) relaxes this condition PiB=CiTJiT. Finally, once again, for the special case when all nodes are active, if custom-character(s)custom-characterJiCi(sI−Āi)−1B+σiKi is passive, i=1, . . . , N, then (11) is feasible and vice versa.


To illustrate this stability analysis in further detail, let {tilde over (x)}i(t)custom-characterx(t)−{circumflex over (x)}i(t) and {tilde over (w)}i(t)custom-characterŵi(t)−w(t). Then, based on (9) and (10),














x
~

.

i

(
t
)

=



A


x

(
t
)


+

B


w

(
t
)


-


(

A
-

γ


P
i

-
1




)





x
^

i

(
t
)


-

B




w
^

i

(
t
)


-


g
i




L
i

(



y
i

(
t
)

-


C
i





x
^

i

(
t
)



)


+

α


P
i

-
1







i

j




(




x
^

i

(
t
)

-



x
^

j

(
t
)


)




=




(

A
-


g
i



L
I



C
i



)





x
~

i

(
t
)


-

B




w
~

i

(
t
)


+

α


P
i

-
1







i

j




(




x
^

i

(
t
)

-



x
^

j

(
t
)


)



+

γ


P
i

-
1






x
^

i

(
t
)



=




A
_

i





x
~

i

(
t
)


-

B




w
~

i

(
t
)


-

α


P
i

-
1







i

j




(




x
~

i

(
t
)

-



x
~

j

(
t
)


)



-

γ



P
i

-
1


(




x
~

i

(
t
)

-

x

(
t
)


)






,




x
~

i

(
0
)

=


x
~


i

0







(
13
)

















w
~

.

i

(
t
)

=



g
i



J
i



C
i





x
~

i

(
t
)


-


σ
i




J
i

(




w
~

i

(
t
)

+

w

(
t
)


)


-

α





i

j




(




w
~

i

(
t
)

-



w
~

j

(
t
)


)



-

γ

(




w
~

i

(
t
)

+

w

(
t
)


)

-


w
.

(
t
)



,




w
~

i

(
0
)

=


w
~


i

0







(
14
)







Now, considering the aggregated vectors given by






{tilde over (x)}(t)custom-character[{tilde over (x)}1(t),{tilde over (x)}2(t), . . . ,{tilde over (x)}N(t)]∈custom-characterNn,  (15)






{tilde over (w)}(t)custom-character[{tilde over (w)}1(t),{tilde over (w)}2(t), . . . ,{tilde over (w)}N(t)]∈custom-characterNp,  (16)


We can write the error dynamics as












x
~

.

(
t
)

=



[





A
_

1



0





0




0




A
_

2






0


















0


0







A
_

N




]




x
~

(
t
)


-


[



B


0





0




0


B





0


















0


0





B



]




w
~

(
t
)


-


α
[






11



P
2

-
1








12



P
2

-
1












1

N




P
1

-
1










21



P
2

-
1








22



P
2

-
1












2

N




P
2

-
1

























1

N




P
N

-
1









N

2




P
N

-
1











NN



P
N

-
1






]




x
~

(
t
)


-


γ
[




P
1

-
1




0





0




0



P
2

-
1







0


















0


0






P
N

-
1





]




x
~

(
t
)


+


γ
[




P
1

-
1







P
2

-
1












P
N

-
1





]



x

(
t
)







(
17
)
















w
~

.

(
t
)

=



[





g
1



J
1



C
1




0





0




0




g
2



J
2



C
2







0


















0


0







g
N



J
N



C
N





]




x
~

(
t
)


-


[





σ
1



K
1




0





0




0




σ
2



K
2







0


















0


0







σ
N



K
N





]




w
~

(
t
)


-


[





σ
1



K
1








σ
2



K
2













σ
N



K
N





]



w

(
t
)


-


α
[






11



I
p







12



I
p











1

N




I
p









21



I
p







22



I
p











2

N




I
p
























N

1




I
p








N

2




I
p










NN



I
p





]




w
~

(
t
)


-


γ
[




I
p



0





0




0



I
p






0


















0


0






I
p




]




w
~

(
t
)


+

[






-
γ



w

(
t
)


-


w
.

(
t
)









-
γ



w

(
t
)


-


w
.

(
t
)














-
γ



w

(
t
)


-


w
.

(
t
)





]



,




(
18
)







where custom-characterijcustom-character is the entry in the i-th and j-th column of the Laplacian matrix


The error dynamics now can be written a compact form as





{tilde over ({dot over (x)})}(t)=Ā{tilde over (x)}(t)−(IN⊗B){tilde over (w)}(t)−P−1(F⊗In){tilde over (x)}(t)+γP−1(1N⊗In)x(t),  (19)





{tilde over ({dot over (w)})}(t)=M{tilde over (x)}(t)−{tilde over (K)}({tilde over (w)}(t)+(1N⊗Ip)w(t))−(F⊗Ip){tilde over (w)}(t)−γ(1N⊗Ip)w(t)−(1N⊗Ip){dot over (w)}(t),  (20)





where






Ā
custom-characterdiag([Ā1,A2, . . . ,ĀN]),  (21)






M
custom-characterdiag([g1J1C1,g2J2C2, . . . ,gNJNCN]),  (22)







K

custom-characterdiag([σ1K12K2, . . . ,σNKN])  (23)






F
custom-characterαcustom-character(custom-character)+γIN,  (24)






P
custom-characterdiag([P1,P2, . . . ,PN]),  (25)


with custom-character(custom-character) being the Laplacian matrix. Note that P>0 readily follows from Pi>0.


Consider the process given by (7) and the distributed input and the state estimation architecture given by (9) and (10). Assume (11) holds and nodes exchange information using local measurements subject to an undirected and connected graph custom-character. Then, the error dynamics given by (19) and (20) are uniformly bounded.


To demonstrate this, consider the Lyapunov function candidate given by






V({tilde over (x)},{tilde over (w)})={tilde over (x)}TP{tilde over (x)}+{tilde over (w)}T{tilde over (w)}.  (26)


Note that V(0,0)=0 and V({tilde over (x)},{tilde over (w)})>0 for all ({tilde over (x)},{tilde over (w)})≠(0,0). Taking time-derivative of V({tilde over (x)},{tilde over (w)}) along the trajectories of (19) and (20) yields












V
.

(
·
)

=






x
~

T

(
t
)



(




A
_

T


P

+

P


A
_



)




x
~

(
t
)


-

2




x
~

T

(
t
)



P

(


I
N


B

)




w
~

(
t
)


-

2




x
~

T

(
t
)



(

F


I
n


)




x
~

(
t
)


+

2

γ




x
~

T

(
t
)



(


1
N



I
n


)



x

(
t
)


+

2




w
~

T

(
t
)


M



x
~

(
t
)


-

2



w
~

T



K
_




w
~

(
t
)


-

2




w
~

T

(
t
)



F

(



I
p


)




w
~

(
t
)


-

2




w
~

T

(
t
)



(


K
_

+

γ


I

N

p




)



(


1
N



I
p


)



w

(
t
)


-

2




w
~

T

(
t
)



(


1
N



I
p


)




w
.

(
t
)



=

[






x
~

T

(
t
)






w
~

T

(
t
)




]






[







A
_

T


P

+

P


A
_







-

P

(


I
N


B

)


+

M
T









(


-

I
N




B
T


)


P

+
M





-
2



K
_





]






[





x
~

(
t
)







w
~

(
t
)




]

+



[






x
~

T

(
t
)






w
~

T

(
t
)




]

[





-
2



(

F


I
n


)




0




0




-
2



F


I
p






]

[





x
~

(
t
)







w
~

(
t
)




]

+


2
[






x
~

T

(
t
)






w
~

T

(
t
)




]

[




γ


(


1
N



I
n


)



x

(
t
)









-

(


K
_

+

γ


I

N

p




)




(


1
N



I
p


)



w

(
t
)


-


(


1
N



I
p


)




w
.

(
t
)






]


=




z
T



R
A



z

(
t
)


+



z
T

(
t
)



R
B



z

(
t
)


+

2



z
T

(
t
)


ϕ


=




z
T

(
t
)


R


z

(
t
)


+

2



z
T

(
t
)


ϕ








(
27
)










where













z

(
t
)


=




[




x
~

T

(
t
)

,



w
~

T

(
t
)


]

T


,





(
28
)
















R
A


=



[







A
_

T


P

+

P


A
_







-

P

(


I
N


B

)


+

M
T









-

(


I
N



B
T


)



P

+
M





-
2



K
_





]


,





(
29
)
















R
B


=



[





-
2



(

F


I
n


)




0




0




-
2



(

F


I
p


)





]


,





(
30
)















R

=





R
A

+

R
B


=

[







A
_

T


P

+

P


A
_


-

2


(

F


I
n


)







-

P

(


I
N


B

)


+

M
T









-

(


I
n



B
T


)



P

+
M






-
2



K
_


-

2


(

F


I
p


)






]



,





(
31
)















ϕ

=



[





γ

(


1
N



I
n


)



x

(
t
)









-

(


K
_

+

γ


I

N

p




)




(


1
N



I
p


)



w

(
t
)


-


(


1
N



I
p


)




w
.

(
t
)






]


,





(
32
)







Note that (F⊗In)>0 and (F⊗Ip)>0 readily follow from F>0, and hence RB<0.


Next, since the linear matrix inequality given by (11) holds, it follows that






Ā
i
T
P
i
+P
i
Ā
i≤0,  (33)






N
i
custom-character−2σiKi−(−BTPi+gijiCi)(ĀiTPi+PiĀi)(−PiB+giCiTJiT)≤0,  (34)






Qi
custom-character(In−(ĀiTPi+PiĀi)(ĀiTPi+PiĀi))(−PiB+giCiTJiT)=0,  (35)


by applying Lemma 2 to (11). Note that














A
_

T


P

+

P


A
_



=


[





A
^

1



0





0




0




A
^

2






0


















0


0







A
^

N




]


0


,




(
36
)







as a consequence of (33), where Âicustom-characterĀiTPi+PiĀi for i=1, . . . , N. Furthermore, it follows from (34) that










N

=






-
2


K

-


(



-

(


I
N



B
T


)



P

+
M

)




(




A
_

T


P

+

P


A
_



)





(


-

P

(


I
N


B

)


+

M
T


)



=



[




N
1



0





0




0



N
2






0


















0


0






N
N




]


0



,




(
37
)







holds. Finally, (35) leads to









Q

=





(


I

N

n


-


(




A
_

T


P

+

P


A
_



)




(




A
_

T


P

+

P


A
_



)





)



(


-

P

(


I
N


B

)


+

M
T


)


=


[




Q
1



0





0




0



Q
2






0


















0


0






Q
N




]

=
0.






(
38
)







Now, by Lemma 2, RA≤0 as direct consequence of (36), (37) and (38). Thus by Lemma 1, R=RA+RB<0.


Note that since A is Hurwitz, and ∥w(t)∥2w, we have ∥x(t)∥2≤{tilde over (x)}. With this and ∥{dot over (w)}(t)∥2≤{dot over (w)}, we have ∥ϕ∥2ϕ with










ϕ
¯


=
Δ






γ
2







1
N



I
n




2
2




x
˜

2


+






K
¯

+

γ


I
Np





2
2







1
N



I
p




2
2




w
¯

2


+






1
N



I
p




2
2





w
.

¯

2




=



N


γ
2




x
˜

2


+






K
¯

+

γ


I
Np





2
2




w
¯

2


+

N




w
.

¯

2









(
39
)







Now, one can write






{dot over (V)}(⋅)=zT(t)Rz(t)+2zT(t)ϕ≤λmax(R)∥z(t)∥22∥z(t)∥2ϕ≤(1−θ)λmax(R)∥z(t)∥22+θλmax(R)∥z(t)∥22+2∥z(t)∥2ϕ,  (40)


with λmax(R)<0 and θ∈(0,1). Letting








μ
1


=
Δ






-
2



ϕ
¯



θ



λ
max

(
R
)



>

0


and



Ω
1




=
Δ


{



z

(
t
)

:




z

(
t
)



2




μ
1


}



,




it follows that {dot over (V)}(⋅)≤(1−θ)λmax(R)∥z(t)∥22<0 outside the compact set Ω1, and hence, the error dynamics given by (19) and (20) are uniformly bounded.


Consider also the process given by (7) and the distributed input and state estimation architecture given by (9) and (10). Assume (11) holds the nodes exchange information using local measurements subject to an undirected and connected graph custom-character. Then, for all z(0)∈custom-characterN(n+p), there exists T=T(z(0),μ1)≥0 such that
















x
˜

(
t
)



2



ξ
1



=
Δ






λ
max

(

P
¯

)



λ
min

(

P
¯

)




max


{






z

(
0
)



2




e

(



(

1
-
θ

)




λ
max

(
R
)



2



λ
max

(

P
¯

)



)

t


,

μ
1


}



,



t

0


,




(
41
)




















w
~

(
t
)



2



ξ
1


,



t

0


,





(
42
)







where











P
¯

=

[



P


0




0



I

N

P





]


,




(
43
)








and















x
˜



(
t
)




2



ψ
1



=
Δ






λ
max

(

P
¯

)



λ
min

(

P
¯

)





μ
1



,

t

T





(
44
)



















w
~



(
t
)




2



ζ
1



=
Δ






λ
max

)



(

P
¯

)





μ
1



,

t


T
.






(
45
)







Note that










V

(
·
)

=






x
˜

T

(
t
)


P



x
˜

(
t
)


+




w
~

T

(
t
)




w
~

(
t
)



=




[






x
˜

T



(
t
)









w
~

T



(
t
)






]

[



P


0




0



I

N

P





]

[





x
˜

(
t
)







w
~

(
t
)




]

=



z
T

(
t
)



P
¯




z

(
t
)

.








(
46
)







Let c1custom-characterλmin(P), c2custom-characterλmax(P) and c3custom-character−(1−θ)λmax(R). From (46) we have






c
1
∥z(t)∥22≤V(⋅)≤c2∥z(t)∥22.  (47)


In addition, V(⋅)≤−c3∥z(t)∥22. By Theorem 4.5 of [16], since the domain D=custom-characterN(n+p), for every initial state z(0), the bound of the overall system is















z

(
t
)



2






c
2


c
1




max


{






z

(
0
)



2



e


(



-

c
3


/
2



c
2


)


t



,

μ
1


}



=

ξ
1


,



t

0.






(
48
)







Using the fact that ∥{tilde over (x)}(t)∥2≤∥z(t)∥2 and ∥{tilde over (w)}(t)∥2≤∥z(t)∥2, (41) and (42) follow immediate.


As explained above, V(⋅) cannot grow outside the compact set Ω1, thus (44) follows from λmin(P)∥{tilde over (x)}(t)∥22≤V({tilde over (x)}(t),{tilde over (w)}(t))≤λmax(P)∥z(t)∥22≤λmax(P12. Identically, (45) follows from ∥{tilde over (w)}(t)∥22≤V({tilde over (x)}(t),{tilde over (w)}(t))≤λmax(P)∥z(t)∥22≤λmax(P12. The proof is now complete.


Since the ultimate bounds given by (44) and (45) depend on the design parameters of the proposed distributed input and state estimation architecture, they can be used as design metrics such that the design parameters can be judiciously selected to make (44) and (45) small. However, unlike the stability of our framework that is guaranteed once each node satisfies the local condition given by (11), such a performance characterization requires global information. However, one can further analyze the effect of each specific design parameter to these ultimate bounds and make conclusions without possibly requiring global information, which will be considered as a future research direction.


Note that the terms “−γPi−1{circumflex over (x)}i(t)” and “−(σiKi+γIpi(t)” appearing respectively in (9) and (10) are often referred as leakage terms. If the gains “γPi−1” and “σi Ki+γIp” respectively multiplying these terms are not small, then they may result in poor overall system performance and hence, these multiplier gains are chosen to be small. However, as noted in above, in some implementations, σi may not be chosen as small unless all nodes are active and the condition PiB=CiTKiT. Therefore, we cast (11) as an optimization problem given by





minimize σ1,  (49)





subject to (11),  (50)


for all nodes i=1, . . . , N.


To elucidate the effect of design parameters to the ultimate bound given by (44), we consider, for example, a system with 4 sensors (1 and 3 are active nodes, and 2 and 4 are passive nodes) tracking a target with dynamics












x
˙

(
d
)

=



[



0


1





-
1





-

0
.
2



5




]



x

(
t
)


+


[



0




1



]



w

(
t
)




,




(
51
)







where w(t)=sin (0.25t). Node 1 is subject to C1=[1 0], and node 3 is subject to C3=[0 1]. We design σi by solving the linear matrix inequality (11). As a result, with K1=K2=K3=K4=50, we have σ1=0.03, σ24=0.05, and σ3=0.03 with








P
1

=

[




2


6
.
3


1





-

2
.
6



7







-

2
.
6



7





4
.
0


1




]


,


P
2

=


P
4

=

[





1
.
5


4





0
.
0


8







0
.
0


8





1
.
6


2




]



,


and



P
3


=


[





4
.
6


0





4
.
0


2







4
.
0


2




2


5
.
6


2




]

.






We then vary α and γ to see the effect of these parameters to the ultimate bound ψ given by (44). FIG. 5 shows the effect of the variation in α and γ to (44). From the graph of FIG. 5, we can see that one can pick a small value for γ and a large value for α to reduce the ultimate bound.


For the specific numerical examples provided below, consider a process composed of two decoupled systems with the dynamics given by (7), where










A
=

[



0


1


0


0





-

ω

n

1

2






-
2



ω

n

1




ξ
1




0


0




0


0


0


1




0


0




-
2



ω

n

2

2






-
2



ω

n

2




ξ
2





]


,




(
52
)













B
=

[



0


0





ω

n

1

2



0




0


0




0



ω

n

2

2




]


,




(
53
)







ωn1=1.2, ξ1=0.9, ωn2=0.5, and ξ2=0.6. This process, for example, can represent a linearized vehicle model with the first and third states corresponding to the positions in the x and y directions, respectively, while the second and fourth states corresponding to the velocities in the x and y directions, respectively. The initial conditions are set to x0T=[−3, 0.5, 2.5, 0.25]. In addition, we consider the input is given by










w

(
t
)

=

[





2
.
5



sin

(
t
)







4


cos

(

1.
2

t

)





]





(
54
)







For a first example, we consider the sensor network with 12 nodes exchanging information over an undirected and connected graph topology, where there are 4 active nodes and 8 passive nodes as shown in FIG. 2. Each node's sensing capability is represented by (8) with the output matrices











C
i

=

[



1


0


0


0




0


0


1


0



]


,




(
55
)







for the odd index nodes and











C
i

=

[



0


1


0


0




0


0


0


1



]


,




(
56
)







for the even index nodes. In addition, all nodes are subject to zero initial conditions and we set Ki=diag([100;100]), α=50, and γ=0.1. For the observer gain Li, the odd index nodes are subject to











L
i

=

[




1


8
.
9


6

9





-

1
.
9



0

7







-

0
.
4



8

7





-

0
.
0



7

6







-

1
.
9



3

9




1


9
.
1


3

0







-

0
.
2



8

5





2
.
4


9

2




]


,




(
57
)







while the even index nodes are subject to










L
i

=


[





-

2
.
3



8

8





0
.
3


5

8







5
.
8


3

1





-

0
.
8



0

4







0
.
4


2

8





-

2
.
3



9

8







-

1
.
0



3

8





6
.
7


6

5




]

.





(
58
)







By solving the linear matrix inequality (11) for each node, σi and Pi>0 are obtained as σ15=0.0021, σ26=1.80×10−6, σ34789101112=0.0024, and











P
1

=

1


0
3

×

[





1
.
4


4

0





-

0
.
0



3

4





0
.
0


5

5





-

0
.
0



0

5







-

0
.
0



3

4





0
.
0


0

4





0
.
0


0

4



0






0
.
0


5

5





0
.
0


0

4





0
.
9


7

7





-

0
.
0



5

4







-

0
.
0



0

5



0




-

0
.
0



5

4





0
.
0


2

6




]



,




(
59
)














P
2

=

1


0
2

×

[





0
.
2


9

9



0




0
.
0


3

6



0




0




0
.
6


9

6



0




-

0
.
0



0

1







0
.
0


3

6



0




0
.
2


9

8



0




0




-

0
.
0



0

1



0




3
.
9


9

9




]



,




(
60
)













P

1

2


=


[





1
.
4


4



0


0


0




0


1


0


0




0


0




1
.
3


4

2





0
.
5


2

9





0


0




0
.
5


2

9





3
.
4


9

6




]

.





(
61
)







Note that P1=P5, P2=P6 and P3=P4=P7=P8=P9=P10=P11=P12. Under the proposed distributed estimation architecture (9) and (10), nodes are able to closely estimate the process states and inputs as shown in FIGS. 6 and 7, respectively. Note that the dashed lines of FIG. 6 denote the states of the actual process and the solid lines of FIG. 6 denote the state estimates of nodes. Also, the dashed lines of FIG. 7 denote the inputs of the actual process and the solid lines of FIG. 7 denote the input estimates of nodes).


As a second example, we consider a sensor network with 12 total nodes with eight active nodes and four passive nodes as depicted in the example of FIG. 3. The sensing capability of each agent is the same as in the first example above. Note that, because of the change in the number of active nodes, the design parameters are adjusted accordingly as σ1357=0.0021, σ2468=1.83×10−6, σ9101112=0.0024, and P1=P3=P5=P7, P2=P4=P6=P8, P9=P10=P11=P12, where P1, P2 and P12 are the same as (59), (60), and (61), respectively. Other parameters and gains are also kept the same. FIGS. 8 and 9 show the performance of the sensor network for the proposed distributed estimation architecture. Note that the dashed lines of FIG. 8 denote the states of the actual process and the solid lines denote the state estimates of nodes. Similarly, the dashed lines of FIG. 9 denote the inputs of the actual process and the solid lines denote the input estimates of nodes. It can be seen that the estimates in this case are slightly better than the ones in first example (i.e., as illustrated in the graphs of FIGS. 6 and 7) as a result of increasing the number of active nodes in the sensor network.


As a third example, we consider a sensor network that, like the second example, includes 8 active nodes and 4 passive nodes as illustrated in FIG. 3. However, the system output matrices for each node are changed as follows











C
1

=

[



1


0


0


0




0


0


0


0



]


,




(
62
)














C
2

=

[



0


1


0


0




0


0


0


0



]


,




(
63
)














C
3

=

[



0


0


0


0




0


0


1


0



]


,




(
64
)







where C1=C5=C9, C2=C4=C6=C8=C10=C12 and C3=C7=C11. Note that for the odd index nodes, the pair (A, Ci) is not observable. We also choose Ki=diag([100; 100]), α=50, and γ=0.1.


Here, the observer gain Li is chosen such that











L
1

=

[




1


9
.
0


6

9





-

3
.
8



1

4







-

0
.
4



8

6





0
.
0


9

7





0


0




0


0



]


,




(
65
)














L
2

=

[





-

2
.
3



8

8





0
.
3


5

8







5
.
8


3

1





-

0
.
8



0

4







0
.
4


2

8





-

2
.
3



9

8







-

1
.
0



3

8





6
.
7


6

5




]


,




(
66
)














L
3

=

[



0


0




0


0






-

3
.
8



4

5




1


9
.
2


2

5

0







-

0
.
5



0

1





2
.
5


0

6




]


,




(
67
)







with L1=L5=L9, L2=L4=L6=L8=L10=L12 and L3=L7=L11. By solving the linear matrix inequality (11) for each node σi and Pi>0 are obtained as σ15=0.0024, σ2468=1.83×10−6, σ37=0.002, σ9101112=0.0024, and











P
1

=

[





1
.
4


4

0



0


0


0




0




1
.
0


0

0



0


0




0


0



6

9


7
.
8


2

7





-
2



3
.
0


1

8





0


0




-
2



3
.
0


1

8




1


8
.
8


3

2




]


,




(
68
)














P
3

=

1


0
3

×

[





1
.
4


7

8





-

0
.
0



3

4



0


0






-

0
.
0



3

4





0
.
0


0

4



0


0




0


0




0
.
0


0

2



0




0


0


0




0
.
0


0

6




]



,




(
69
)







with P1=P5, P2=P4=P6=P8, P3=P7, and P9=P10=P11=P12, where P2 and P12 are the same as (60) and (61) in the first example above, respectively. FIGS. 10 and 11 show that under the proposed distributed estimation architecture, nodes are able to closely estimate the process states and inputs, although some active nodes are not able to fully observe the process. Note that the dashed lines in FIG. 10 denote the states of the actual process and the solid lines denote the state estimates of nodes. Similarly, the dashed lines in FIG. 11 denote the inputs of the actual process and the solid lines denote the input estimates of nodes.


In the three numeric examples presented above, the role of each node as active or passive is fixed. However, as noted above, the methods and systems described herein can be extended to sensor networks where the active and passive role of each sensor node is varying over time. For this purpose, once again, we consider an observed process given by (7). In addition, if a node in the sensor network is active for some time instant, then it is subject to the observations of the process given by (8) on that time instant, otherwise it is a passive node and has no observation. Note that, in the examples below, a node is assumed to be smoothly changed back and forth between active and passive mode.


For the examples described below regarding nodes with a varying status as active and passive, consider the distributed estimation algorithm for node i, i=1, N, given by





{circumflex over ({dot over (x)})}i(t)=(A−γPi−1){circumflex over (x)}i(t)+i(t)+gi(t)Li(yi(t)−Ci{circumflex over (x)}i(t))−αPi−1Σi˜j({circumflex over (x)}i(t)−{circumflex over (x)}j(t)),{circumflex over (x)}i(0)={tilde over (x)}i0,  (70)





{circumflex over ({dot over (w)})}i(t)=gi(t)Jii(t)−Ci{circumflex over (x)}i(t))−(σiKi+γIp)ŵi(t)−αΣi˜j(ŵi(t)−ŵj(t)),ŵi(0)={tilde over (w)}i0.  (71)


where {circumflex over (x)}i(t)∈custom-charactern is a local state estimate of x(t) for node i, ŵicustom-characterp is a local input estimate of w(t) for node i, Licustom-charactern×m and Jicustom-characterp×m are design matrices of node i with Ki being symmetric and positive definite, and α, γ, and σicustom-character Are positive design coefficients for node i. Note that the parameter gi(t) in this section is time-varying and gi(t)∈[0,1]. In addition, Pi>0 is the consensus gain satisfying the two linear matrix inequalities given by













R

i

1



=









[






A
T



P
i


+


P
i


A






-

P
i



B







-

B
T




P
i






-
2



σ
i



K
i





]


0


,





(
72
)














R

i

2



=








[







(

A
-


L
i



C
i



)

T



P
i


+


P
i

(

A
-


L
i



C
i



)







-

P
i



B

+


C
i
T



J
i
T










-

B
T




P
i


+


J
i



C
i







-
2



σ
i



K
i





]


0


,

i
,


,

N
.





(
73
)







For the stability analysis, let {tilde over (x)}i(t)custom-characterx(t)−{circumflex over (x)}i(t) and {tilde over (w)}i(t)custom-characterŵi(t)−w(t). Then, similar to (13) and (14), one can write:














x
~

.

i

(
t
)

=





A
¯

i

(
t
)





x
˜

i

(
t
)


-

B




w
~

i

(
t
)


-

α


P
i

-
1







i

j



(




x
˜

i

(
t
)

-



x
˜

j

(
t
)


)



-

γ



P
i

-
1


(




x
˜

i

(
t
)

-

x

(
t
)


)




,



x
~

i

=


x
~


i

0







(
74
)

















w
~

.

i

(
t
)

=




g
i

(
t
)



K
i



C
i





x
˜

i

(
t
)


-


σ
i




K
i

(




w
~

i

(
t
)

+

w

(
t
)


)


-

α





i
~
j



(




w
~

i

(
t
)

-



w
~

j

(
t
)


)



-

γ

(




w
~

i

(
t
)

+

w

(
t
)


)

-


w
˙

(
t
)



,




w
¯

i

(
0
)

=


w
~


i

0







(
75
)







where






Ā
i(t)custom-characterA−gi(t)LiCi.  (76)


Therefore, as discussed above, the compact form of the error dynamics are given by





{tilde over ({dot over (x)})}(t)=Ā(t){tilde over (x)}(t)−(IN⊗B){tilde over (w)}(t)−P−1(F⊗In){tilde over (x)}(t)+γP−1(IN⊗In)x(t),  (77)





{tilde over ({dot over (w)})}(t)=M(t){tilde over (x)}(t)−{tilde over (K)}({tilde over (w)}(t)+(IN⊗Ip)w(t))−(F⊗Ip){tilde over (w)}(t)−γ(IN⊗Ip)w(t)−(IN⊗Ip){dot over (w)}(t),  (78)





where






Ā(t)custom-characterdiag([Ā1(t),A2(t), . . . ,ĀN(t)]),  (79)






M(t)custom-characterdiag([g1(t)J1C1,g2(t)K2C2, . . . ,gN(t)JNCN]),  (80)


and K, F and P are the same as (23), (24), and (25), respectively.


Consider the process given by (7) and the distributed input and state estimation architecture given by (70) and (71). Assume (72) and (73) hold and nodes exchange information using local measurements subject to an undirected and connected graph G. Then, the error dynamics given by (77) and (78) are uniformly bounded. To further demonstrate this, consider the Lyapunov function candidate given by (26). Following the steps from the proof of Theorem 1, differentiating (26) along the trajectories of (77) and (78) yields






{dot over (V)}(⋅)=zT(t)RA(t)z(t)+zT(t)RBz(t)+2zT(t)ϕ,  (81)


where z(t), RB and ϕ are defined in (28), (30), and (32), respectively. In addition,











R
A

(
t
)


=








[








A
_

(
t
)

T


P

+

P



A
_

(
t
)







-

P

(


I
N


B

)


+


M
T

(
t
)








-

(


I
N



B
T


)


+

M

(
t
)






-
2



K
¯





]

.





(
82
)







Note that for this varying case of active and passive node roles, Ri in (11) becomes











R
i

(
t
)

=



[







(

A
-



g
i

(
t
)



L
i



C
i



)

i
T



P
i


+


P
i

(

A
-



g
i

(
t
)



L
i



C
i



)







-

P
i



B

+



g
i

(
t
)



C
i
T



K
i
T










-

B
T




P
i


+



g
i

(
t
)



K
i



C
i







-
2



σ
i



K
i





]

=



[






A
T



P
i


+


P
i


A






-

P
i



B







-

B
T




P
i






-
2



σ
i



K
i





]

+



g
i

(
t
)

[







(


-

L
i




C
i


)

T



P
i


+


P
i

(


-

L
i




C
i


)






C
i
T



K
i
T








K
i



C
i




0



]







(
83
)







Since gi(t)∈[0, 1], Ri1 in (72) and Ri2 in (73) corresponds to gi(t)=0 and gi(t)=1 in (83), respectively. Therefore Ri1 and Ri2 are the vertices of the polytope. By Lemma 3, when the linear matrix inequalities (72) and (73) hold, Ri(t)≤0 for all gi(t)∈[0, 1]. Consequently, using the same argument as discussed above in reference to the examples with nodes having a fixed status as active or passive, we have RA(t)≤0. Hence, (81) becomes






{dot over (V)}(⋅)=zT(t)RA(t)z(t)+zT(t)RBz(t)z(t)+2zT(t)ϕ≤λmax(RB)∥z(t)∥222∥z(t)∥2ϕ≤(1−θ)λmax(RB)∥z(t)∥22+θλmax(RB)∥z(t)∥22+2∥z(t)∥2ϕ,  (84)


with λmax(RB)<0 and θ∈(0, 1). Letting







μ
2


=











-
2



ϕ
_



0



λ
max

(

R
B

)



>

0


and



Ω
2




=







{


z

(
t
)

:







∥z(t)∥2≤μ2}, it follows that {dot over (V)}(⋅)≤(1−θ)λmax(RB)∥z(t)∥22<0 outside the compact set Ω2, and hence the error dynamics given by (74) and (75) are uniformly bounded.


Consider the process given by (7) and the distributed input and state estimation architecture given by (70) and (71). Assume (72) and (73) hold and nodes exchange information using local measurements subject to an undirected and connected graph custom-character. Then, for all z(0)∈custom-characterN(n+p), there exists T=T(z(0),μ2)≥0 such that
















x
˜

(
t
)



2



ξ
2



=











λ
max

(

P
¯

)



λ
min

(

P
¯

)




max


{






z

(
0
)



2



e


(



(

1
-
θ

)




λ
max

(

R
B

)



2



λ
max

(

P
¯

)



)


t



,

μ
2


}



,



t

0


,




(
85
)




















w
~

(
t
)



2



ξ
2


,



t

0


,


where





(
86
)
















P
_

=

[



P


0




0



I
NP




]


,


and





(
87
)





















x
˜

(
t
)



2



ψ
2



=











λ
max

(

P
¯

)



λ
min

(

P
¯

)





μ
2



,


t

T

,





(
88
)





















w
~

(
t
)



2



ζ
2



=










λ
max

(

P
¯

)




μ
2



,


t


T
.







(
89
)







As a numeric example of a sensor network with nodes that varying between active nodes and passive nodes, we consider a process as the vehicle model described in the first, second, and third examples above with the dynamics given by (7), where A and B are defined in (52) and (53), respectively. The initial conditions are set to x0T=[−3, 0.5, 2.5, 0.25]. In addition, we consider the input is given by










w

(
t
)

=


[




2.5

sin

(
t
)







3.5

cos

(


1
.
2


t

)





]

.





(
90
)







We now consider an active-passive sensor network with 12 nodes exchanging information over an undirected and connected graph topology as presented in FIG. 12, where the active and passive role of each node is varying overtime. In the example of FIG. 12, the sensors are distributed over an area, and each sensor position is shown in FIG. 12. In this example, each sensor has a sensing range in the shape of a circle with the radius r=3. As described in the examples above, the first and third states of the process (or the vehicle) correspond to the positions in the x-axis and y-axis directions, respectively. If the vehicle's position is within a sensor sensing range, then that sensor becomes smoothly active. On the other hand, if the vehicle's position is out of the sensor sensing range, then it becomes smoothly passive. The network has two types of sensors, and each node's sensing capability is represented by (8) with the output matrices











C
i

=

[



1


0


0


0




0


0


1


0



]


,




(
91
)







for the odd index nodes and











C
i

=

[



0


1


0


0




0


0



1

0



1



]


,




(
92
)







for the even index nodes. All nodes are subjected to zero initial conditions and we set Ki=diag [100; 100] α=50, and γ=0.1. For the observer gain Li, the odd index nodes are subject to











L
i

=

[




7


1
.
7


8

4

0





-

7
.
2



5

3

0







-

1
.
3



5

8

6





0
.
0


0

0

5







-

7
.
2



5

6

5




7


1
.
8


0

1

8







-

0
.
0



1

1

6





-

0
.
1



2

8

7




]


,




(
93
)







while the even index nodes are subject to











L
i

=

[





-
2



1
.
7


2

4

8





2
.
2


5

6

2






7


0
.
0


9

8

2





-

7
.
1



3

4

5







2
.
3


6

9





-
2



1
.
7


3

2

0







-

7
.
3



7

3

6




7


1
.
2


9

3

5




]


,




(
94
)







By solving the linear matrix inequalities (72) and (73) simultaneously for each node, σi and Pi>0 ae obtained α1357911=0.0434, α24681012=0.0275, and











P
1

=

[




1


5
.
3


6

6





0
.
2


8

8





2
.
8


9

1





-

0
.
5



1

9







0
.
2


8

8





8
.
0


5

8





0
.
4


9

0





1
.
7


9

6







2
.
8


9

1





0
.
4


9

0




2


0
.
9


0

0





0
.
9


8

1







-

0
.
5



1

9





1
.
7


9

6





0
.
9


8

1




7


6
.
6


9

3




]


,




(
95
)














P
2

=

[




1

1


0
.
0


2

6





2
.
1


9

5





0
.
2


8

1





-

1
.
2



1

6







2
.
1


9

5




1


0
.
1


7

0





0
.
0


6

6





1
.
0


9

0







0
.
2


8

1





0
.
0


6

6





9
.
4


7

3





2
.
8


3

4







-

1
.
2



1

6





1
.
0


9

0





2
.
8


3

4




2


5
.
5


8

5




]


,




(
96
)







Note that P1=P3=P5=P7=P9=P11 and P2=P4=P6=P8=P10=P12.


Under the proposed distributed estimation architecture (70) and (71), nodes are able to closely estimate the process states as shown in FIG. 13. In FIG. 13, the dashed lines denote the states of the actual process and the solid lines denote the state estimates of nodes. FIG. 14 illustrates that the sensor network is able to estimate the trajectory of the vehicle (the first and third state of the process). However, as illustrated in FIG. 15, the system's ability to estimate the process input is not as accurate as the case for fixed node roles described in the other examples above. This can be explained by the conservatism of the solution of the linear matrix inequalities (72) and (73). In FIG. 14, the dashed lines denote the trajectory of the actual process (i.e., the combination of the first and third state) and the solid lines denote the state estimates of nodes). In FIG. 15, the dashed lines denote the inputs of the actual process and the solid lines denote the input estimates of nodes.


Furthermore, the accuracy of the input and state estimation can be improved in the sensor network of FIG. 13 by reducing the σi values such that σ1357911=0.001, σ24681012=0.001, while keeping Pi and other parameters the same, as illustrated in FIGS. 16 and 17, respectively. In FIG. 16, the dashed lines denote the states of the actual process and the solid lines denote the state estimates of nodes. In FIG. 17, the dashed lines denote the inputs of the actual process and the solid lines denote the input estimates of nodes. Numerical methods to reduce such conservatism in linear matrix inequality computations will be investigated for (72) and (73) as a future research.


Thus, the invention provides among other things, systems and methods for estimating a state and an input of an observed process using local sensor node estimation. Various features and advantages of the invention are set forth in the following claims.

Claims
  • 1. A method for observed process estimation, comprising: receiving an output signal from a sensor of a first sensor node indicative of a measurement of an observed process, wherein the first sensor node is varyingly active or passive depending on whether the observed process is occurring within a defined range of the first sensor node;calculating a new estimated state of the observed process based at least in part on a previous estimation of a state calculated for the first sensor node and a previous estimation of an input to the observed process calculated for the first sensor node;adjusting the new estimated state of the observed process based on a calculated difference between the previous estimation of the state calculated for the first sensor node and an estimation of a state calculated for a second sensor node; andoutputting the adjusted new estimated state of the observed process to at least one adjacent sensor node.
  • 2. The method of claim 1, wherein the second sensor node is adjacent to the first sensor node in a sensor network.
  • 3. The method of claim 1, further comprising: adjusting the new estimated state of the observed process based on an observed difference between a predicted output of the sensor of the first sensor node and an actual output of the sensor of the first sensor node.
  • 4. The method of claim 3, further comprising: determining whether the first sensor node is an active node or a passive node, andwherein the adjusting the new estimated state of the observed process based on the observed difference between the predicted output of the sensor of the first sensor node and the actual output of the sensor of the first sensor node includes: adjusting the new estimated state of the observed process based on the observed difference between the predicted output of the sensor of the first sensor node and the actual output of the sensor of the first sensor node only in response to determining that the first sensor node is an active node.
  • 5. The method of claim 3, further comprising: calculating a new estimated input of the observed process based at least in part on the previous estimation of the input to the observed process;adjusting the new estimated input of the observed process based on the observed difference between the predicted output of the sensor of the first sensor node and the actual output of the sensor of the first sensor node;further adjusting the new estimated input of the observed process based on a calculated difference between the previous estimation of the input calculated for the first sensor node and an estimation of the input calculated for the second sensor node; andoutputting the adjusted new estimated input of the observed process to the at least one adjacent sensor node in a sensor network.
  • 6. The method of claim 1, wherein a sensor network includes a plurality of sensor nodes adjacent to the first sensor node that are communicative coupled directly to the first sensor node and a plurality of other sensor nodes that are indirectly coupled to the first sensor node through at least one sensor that is adjacent to the first sensor node.
  • 7. The method of claim 6, wherein adjusting the new estimated state of the observed process further includes adjusting the new estimated state of the observed process based on calculated differences between the previous estimation of the state calculated for the first sensor node and an estimation of a state for each adjacent sensor node of the plurality of sensor nodes that are communicative coupled directly to the first sensor node.
  • 8. The method of claim 1, further comprising iteratively repeating the steps of receiving the output signal, calculating the new estimated state, adjusting the new estimated state, and further adjusting the new estimated state, wherein the adjusted new estimated state of the observed process that is output to the at least one adjacent sensor node is also used as the previous estimation of the state calculated for the first sensor node in a next subsequent iteration.
  • 9. The method of claim 1, wherein a sensor network is configured to estimate the observed process by estimating movement of an object, wherein calculating a new estimated state of the observed process includes calculating at least one state including at least one of a location of the object and a velocity of the object, and wherein calculating a new estimated input of the observed process includes calculating an estimated command that controls the movement of the object.
  • 10. The method of claim 1, further comprising: receiving an output signal from a sensor of the second sensor node indicative of a measurement of the observed process;calculating a new estimated state of the observed process for the second sensor node based at least in part on a previous estimation of a state calculated for the second sensor node and a previous estimation of an input to the observed process calculated for the second sensor node;adjusting the new estimated state of the observed process for the second sensor node based on an observed difference between a predicted output of the sensor of the second sensor node and an actual output of the sensor of the second sensor node;further adjusting the new estimated state of the observed process for the second sensor node based on a calculated difference between the previous estimation of the state calculated for the second sensor node and an estimation of a state calculated for the first sensor node; andoutputting the adjusted new estimated state of the observed process for the second sensor node to at least one adjacent sensor node in a sensor network.
  • 11. The method of claim 10, wherein a sensor network includes a first subset of sensor nodes configured for a first sensing modality and a second subset of sensor nodes configured for a second sensing modality, wherein receiving the output signal from the sensor of the first sensor node indicative of the measurement of the observed process includes receiving an output signal from the sensor of the first sensor node indicative of a measurement of the observed process in the first sensing modality, andwherein receiving the output signal from the sensor of the second sensor node indicative of the measurement of the observed process includes receiving an output signal from the sensor of the second sensor node indicative of a measurement of the observed process in the second sensing modality.
  • 12. The method of claim 10, wherein receiving the output signal from the sensor of the first sensor node indicative of the measurement of the observed process includes receiving an output signal from a position sensor indicative of a position of a moving object, and wherein receiving the output signal from the sensor of the second sensor node indicative of the measurement of the observed process includes receiving an output signal from a velocity sensor indicative of a velocity of the moving object.
  • 13. The method of claim 1, further comprising: determining whether the first sensor node is an active node or a passive node by determining whether the sensor of the first sensor node is able to sense the observed process.
  • 14. The method of claim 13, wherein a sensor node of a plurality of active sensor nodes in a sensor network is configured to have a fixed status as an active sensor node, and wherein a sensor node of a plurality of passive sensor nodes in the sensor network is configured to have a fixed status as a passive sensor node.
  • 15. A sensor network comprising a plurality of sensor nodes, wherein the plurality of sensor nodes includes a subset of active sensor nodes that are able to observe a process and a subset of passive sensor nodes that are not able to observe the process, wherein at least one of the sensor nodes is a varying sensor node that is varyingly active or passive depending on whether the observed process of interest is occurring within a defined range of such varying sensor node, andwherein each sensor node is configured to: sense a signal indicative of a measurement of the observed process;calculate a new estimated state of the observed process based at least in part on an estimation of a state calculated by the sensor node in a previous iteration and a previous estimation of an input to the observed process calculated by the sensor node;adjust the new estimated state of the observed process for the sensor node based on calculated differences between the estimation of the state calculated by the sensor node in the previous iteration and an estimation of a state calculated by each adjacent sensor node; andoutput the adjusted new estimated state of the observed process to each adjacent sensor node.
  • 16. The sensor network of claim 15, wherein each sensor node of the plurality of sensor nodes in the sensor network is further configured to: adjust the new estimated state of the observed process based on an observed difference between a predicted output of the sensor node and an actual output of the sensor node, wherein the predicted output of the sensor is determined based at least in part on the estimation of the state calculated by the sensor node in the previous iteration.
  • 17. The sensor network of claim 16, wherein each sensor node of the plurality of sensor nodes in the sensor network is further configured to: calculate a new estimated input of the observed process for the sensor node based at least in part on the previous estimation of the input to the observed process for the sensor node, wherein the previous estimation of the input to the observed process for the sensor node is an estimation of the input to the observed process calculated for the sensor node in the previous iteration;adjust the new estimated input of the observed process based on the observed difference between the predicted output of the sensor node and the actual output of the sensor node;further adjust the new estimated input of the observed process based on calculated differences between the previous estimation of the input calculated for the sensor node and an estimation of the input calculated for each adjacent sensor node; andoutput the adjusted new estimated input of the observed process for the sensor node to each adjacent sensor node.
  • 18. The sensor network of claim 16, wherein each sensor node of the plurality of sensor nodes in the sensor network is further configured to: determine whether the sensor node is an active node or a passive node, andwherein adjusting the new estimated state of the observed process based on the observed difference between the predicted output of the sensor of the sensor node and the actual output of the sensor of the sensor node includes: adjusting the new estimated state of the observed process based on the observed difference between the predicted output of the sensor of the sensor node and the actual output of the sensor node only in response to determining that the sensor node is an active node.
  • 19. The sensor network of claim 15, wherein the plurality of sensor nodes comprises a first subset of the plurality of sensor nodes and a second subset of the plurality of sensor nodes, wherein the first subset is adjacent to the sensor node,wherein the first subset is communicatively coupled directly to the sensor node, andwherein the second subset is indirectly coupled to the sensor node through at least one sensor that is adjacent to the sensor node.
  • 20. The sensor network of claim 19, wherein adjusting the new estimated state of the observed process further includes adjusting the new estimated state of the observed process based on calculated differences between the previous estimation of the state calculated for the sensor node and an estimation of the state for each sensor node of the first subset.
CROSS-REFERENCE TO RELATED APPLICATIONS

This application is a continuation of U.S. patent application Ser. No. 16/106,506 filed Aug. 21, 2018, which claims the benefit of U.S. Provisional Patent Application No. 62/576,367, filed Oct. 24, 2017, and entitled “DISTRIBUTED INPUT AND STATE ESTIMATION FOR SENSOR NETWORKS,” the entire contents of which is incorporated herein by reference.

STATEMENT REGARDING FEDERALLY SPONSORED RESEARCH OR DEVELOPMENT

This invention was made with government support under FA9550-17-1-0303 awarded by the Air Force. The government has certain rights in the invention.

Provisional Applications (1)
Number Date Country
62576367 Oct 2017 US
Continuations (1)
Number Date Country
Parent 16106506 Aug 2018 US
Child 17878262 US