The following presents a simplified summary of one or more aspects of the present disclosure, to provide a basic understanding of such aspects. This summary is not an extensive overview of all contemplated features of the disclosure and is intended neither to identify key or critical elements of all aspects of the disclosure nor to delineate the scope of any or all aspects of the disclosure. Its sole purpose is to present some concepts of one or more aspects of the disclosure in a simplified form as a prelude to the more detailed description that is presented later.
In some aspects of the present disclosure, methods, systems, and apparatus for networked multiagent system control are disclosed. These methods, systems, and apparatus can include steps or components for identifying a plurality of possible misbehaving vehicles among a plurality of vehicles in the networked multiagent system, determining a directed sub-network of a subset of the plurality of vehicles based on a first directed communication path of a first possible misbehaving vehicle of the plurality of possible misbehaving vehicles to a first vehicle and a second directed communication path of a driver vehicle of the plurality of vehicles to the first vehicle; and implementing a proportional-integral controller for suppressing an effect of the misbehaving vehicle on the networked multiagent system.
These and other aspects of the disclosure will become more fully understood upon a review of the drawings and the detailed description, which follows. Other aspects, features, and embodiments of the present disclosure will become apparent to those skilled in the art, upon reviewing the following description of specific, example embodiments of the present disclosure in conjunction with the accompanying figures. While features of the present disclosure may be discussed relative to certain embodiments and figures below, all embodiments of the present disclosure can include one or more of the advantageous features discussed herein. In other words, while one or more embodiments may be discussed as having certain advantageous features, one or more of such features may also be used in accordance with the various embodiments of the disclosure discussed herein. Similarly, while example embodiments may be discussed below as devices, systems, or methods embodiments it should be understood that such example embodiments can be implemented in various devices, systems, and methods.
The detailed description set forth below in connection with the appended drawings is intended as a description of various configurations and is not intended to represent the only configurations in which the subject matter described herein may be practiced. The detailed description includes specific details to provide a thorough understanding of various embodiments of the present disclosure. However, it will be apparent to those skilled in the art that the various features, concepts and embodiments described herein may be implemented and practiced without these specific details. In some instances, well-known structures and components are shown in block diagram form to avoid obscuring such concepts.
The control of multiagent networks with misbehaving vehicles or nodes in an active research area. Prior research generally requires applying feedback control signals to every vehicle or node for suppressing the effect of misbehaving vehicles or nodes on the overall multiagent network. However, this requirement can be impractical for multiagent networks having a large number of nodes due to economical reasons and multiagent networks having a certain number of inaccessible nodes due to the fact that feedback control signals cannot be physically applied to such nodes. Proposed herein are proportional-integral feedback controllers which stabilize the overall multiagent network in the sense of input-to-state stability. Further, a graph=theoretical approach is used to allow users to find stead-state values of critical nodes without requiring the knowledge of the Laplacian matrix of the overall multiagent network. The results presented in this paper pave the way in understanding how the driver nodes need to be selected for suppressing the effect of misbehaving nodes on the neighborhood of the critical nodes.
The contribution set forth is to study multiagent networks over directed graph topologies with a number of nodes subject to exogenous disturbances (i.e., misbehaving nodes0, where the number of nodes that feedback control signals are applied (i.e., driver nodes) can be less than the total number of nodes in the overall multiagent network. To this end, proportional-integral feedback controllers are proposed for driver nodes. It is shown that these controllers make the resulting closed-loop system matrix Hurwitz, and therefore, stabilize the overall multiagent network in the sense of input-to state stability. In addition, a graph-theoretical approach is used to determine steady-state values of critical nodes without requiring the knowledge of the Laplacian matrix of the overall multiagent network. The results presented in this paper pave the way in understanding how the driver nodes need to be selected for suppressing the effect of misbehaving nodes on the neighborhood of the critical nodes, which is further illustrated herein.
In some examples, each vehicle or node 130, 132, 134, 136 can communicate each other, and communicate from or to a server 110 (e.g., before performing a task) over a communication network 140. In some examples, the communication network 140 can be any suitable communication network or combination of communication networks. For example, the communication network 140 can include a Wi-Fi network (which can include one or more wireless routers, one or more switches, etc.), a peer-to-peer network (e.g., a Bluetooth network), a cellular network (e.g., a 3G network, a 4G network, a 5G network, etc., complying with any suitable standard, such as CDMA, GSM, LTE, LTE Advanced, NR, etc.), a wired network, etc. In some embodiments, communication network 140 can be a local area network, a wide area network, a public network (e.g., the Internet), a private or semi-private network (e.g., a corporate or university intranet), any other suitable type of network, or any suitable combination of networks. Communications links between vehicles or nodes 130, 132, 134, 136 and/or the server 110 can be any suitable communications link or combination of communications links, such as wired links, fiber optic links, Wi-Fi links, Bluetooth links, cellular links, etc.
In further examples, the vehicle or node 110, 130, 132, 134 can be a node (e.g., a ground node, an aerial node, an underwater node, a ship, a space node, an autonomous node, a motor node, a space node, car, a train, an unmanned aerial node, a rocket, or a missile, etc.) or any other suitable apparatus or means (e.g., a computing/circuit/electrical node). The vehicle or node 110, 130, 132, 134 can include any suitable computing device or combination of devices, such as a processor (including an ASIC, DSP, PFGA, or other processing component) desktop computer, a laptop computer, a smartphone, a tablet computer, a wearable computer, a server computer, a computing device integrated into the node, a camera, a robot, a virtual machine being executed by a physical computing device, etc. In some examples, the driver vehicle or node 136 can receive feedback control signals, the misbehaving vehicle or node 130 is subject to exogenous disturbances, the floating vehicle or node 132 is subject to neither exogenous disturbances nor feedback control signals, and the critical vehicle or node 134 is a node that can affect the structure and function of the multiagent system to a greater extent. In some example, the critical vehicle or node 134 can be a node where a given tasks may not be accomplished without the node. For example, consider that the multiagent system can have a group of unmanned aerial nodes, and they are performing a task. The main purpose of these aerial nodes to attack certain locations. Non-critical nodes are utilized for distracting enemy defensive system but only the critical nodes have sufficient equipment to perform the task such as bombing a location.
In some examples, the server 110 can include a processor 112, a display 114, one or more inputs 116, one or more communication systems 118, and/or memory 120. In some embodiments, the processor 112 can be any suitable hardware processor or combination of processors, such as a central processing unit (CPU), a graphics processing unit (GPU), an application specific integrated circuit (ASIC), a field-programmable gate array (FPGA), a digital signal processor (DSP), a microcontroller (MCU), etc. In some embodiments, the display 114 can include any suitable display devices, such as a computer monitor, a touchscreen, a television, an infotainment screen, etc. In some embodiments, the input(s) 116 can include any suitable input devices and/or sensors that can be used to receive user input, such as a keyboard, a mouse, a touchscreen, a microphone, etc.
In further examples, the communications system 118 can include any suitable hardware, firmware, and/or software for communicating information over communication network 140 and/or any other suitable communication networks. For example, the communications system 118 can include one or more transceivers, one or more communication chips and/or chip sets, etc. In a more particular example, the communications system 118 can include hardware, firmware and/or software that can be used to establish a Wi-Fi connection, a Bluetooth connection, a cellular connection, an Ethernet connection, etc. to communicate with other node, server, or any other suitable computing device.
In further examples, the memory 120 can include any suitable storage device or devices that can be used to store a directed graph of the multiagent system 100, a proportional-integral controlling algorithm, data, instructions, values, etc., that can be used, for example, by the processor 112 to perform information exchange tasks via communications system 118, etc. The memory 120 can include any suitable volatile memory, non-volatile memory, storage, or any suitable combination thereof. For example, memory 120 can include random access memory (RAM), read-only memory (ROM), electronically-erasable programmable read-only memory (EEPROM), one or more flash drives, one or more hard disks, one or more solid state drives, one or more optical drives, etc. In some embodiments, the memory 120 can have encoded thereon a computer program for controlling operation of computing device 110. For example, in such embodiments, the processor 112 can execute at least a portion of the computer program to perform one or more data processing tasks described herein, transmit/receive information via the communications system 118, etc. As another example, processor 112 can execute at least a portion of process 200 described below in connection with
In some examples, the multiagent system can include the misbehaving node 130, the floating node, 132, the critical node 134, and/or the driving node 136. The misbehaving node 130, the floating node, 132, the critical node 134, and/or the driving node 136 can include system components (e.g., a processor, a display, an input, a communications system, and/or memory) similar to those in the server 110. In other examples, each node 130, 132, 134, 136 may have a fewer system components than the server 110 (e.g., as an embedded or sensor device). further examples, a type of node can become a different type at any suitable time. For example, a driver node 110 in the multiagent system 100 can be a misbehaving node 130, a floating node 132, or a critical node 134 at any suitable time, or vice versa.
Before describing the process 200, the notation and some basic definitions used throughout the process 200 are explained. and >0 respectively denote the sets of real numbers and positive real numbers; and respectively denote the sets of n×1 real column vectors and n×m real matrices; 1n denotes the n×1 vector of all ones; diag(a1, . . . , an) denotes a diagonal matrix with scalar entries a1, . . . , an on its diagonal; (⋅)−1 and (⋅)T respectively denote the inverse of a (nonsingular) matrix and the transpose of a matrix; and “” denotes the equality by definition.
Additionally, =(V(), ε()) is used to denote a fixed, connected, and directed graph with ()={v1, . . . , vp} being a nonempty finite set of n nodes and ε()⊂()×() being a set of edges. There is an edge rooted at node vj and ended at node vi (i.e., (vj, vi)∈ε()) if and only if vi receives information from vj. Furthermore, =[aij]∈ denotes the adjacency matrix of the graph , where aij=1 if (vj, vi)∈ε() and aij=0 otherwise (self-loops are not allowed; that is, aii=0, i=1, . . . , n). In-degree and Laplacian matrices of the graph are respectively defined as =diag(d1, . . . , dn) with di=Σi−jaij for all vi∈() and =− ( has zero row sums; that is, 1n=0). Finally, a directed path from node vi to node vj is a sequence of successive edges in the form (vi, vp), (vp, vq), . . . , (vr, vj) (a directed path can consist of a single node), where a directed graph has a spanning tree in the union of the root nodes has a directed path to every other node in the graph .
At step 210, the process 200 for multiagent system control can identify or determine multiple possible misbehaving vehicles or nodes among multiple vehicles or nodes in a networked multiagent system. In some examples, the process 200 can identify or determine the possible misbehaving vehicles or nodes based on a predetermined susceptible region. In some examples, some regions in the network are more susceptible to cyber-attacks and they can contain more misbehaving nodes compared to other regions. In such examples, the process 200 can know that some vehicles or nodes passing through the susceptible region may misbehave (e.g., due to signal disturbances, cyber-attacks, obstacles, etc.). Then, the process 200 can determine or identify those vehicles or nodes, which pass by or through or next to the predetermined susceptible region as possible misbehaving vehicles or nodes. In some examples, the determination or identification of the possible misbehaving vehicle or nodes can be performed in a designing phase of the multiagent system. In other examples, In some examples, the determination or identification of the misbehaving vehicle or nodes can be performed at any other phases (e.g., the runtime phase). In other examples, the process 200 can identify or determine the multiple possible misbehaving nodes based on one or more measured exogenous disturbances affected to the plurality of misbehaving nodes. In further examples, the process 200 can determine or identify possible misbehaving vehicles or nodes in any other suitable techniques.
At step 220, the process 200 can determine a directed sub-network (e.g., a directed sub-graph) of a subset of the multiple nodes based on a first directed communication path of a possible misbehaving vehicle or node of the multiple possible misbehaving nodes to a first vehicle or node of the multiple vehicles or nodes and a second directed communication path of a driver node of the multiple nodes to the first vehicle or nodes. In some examples, the multiple vehicle or nodes can be represented as a directed network (e.g., a directed graph). In some examples, the directed sub-network can represent communication directions between vehicles or nodes in the subset of the multiple nodes or vehicles. In some examples, to determine the directed sub-network or sub-graph of subset of the multiple vehicles or nodes, the process 200 can determine the first directed communication path between the first node to the possible misbehaving node of the multiple possible misbehaving nodes and include multiple first communication path nodes on the first directed communication path in the directed graph. In some examples, the first communication path nodes on the first directed communication path can include at least one of: a second possible misbehaving node of the multiple possible misbehaving nodes or a floating node of the plurality of nodes. In some examples, the first vehicle or node can be a critical vehicle or node in the networked multiagent system.
In further examples, to determine the directed sub-network of the subset of the multiple nodes, the process 200 can determine the second directed communication path between the first node to the driver node of the multiple nodes and include multiple second communication path nodes on the second directed communication path in the directed graph. In some examples, the second communication path nodes on the second directed communication path can include at least one of: a second misbehaving node of the plurality of nodes or a floating node of the plurality of nodes. In some examples, the first node can be a critical vehicle or node in the networked multiagent system.
For example, the directed sub-network of the subset of multiple nodes can be determined based on the following conditions: i) driver vehicle/node(s) having at least one directed path to the first vehicle/node (e.g., the critical vehicle/node), where no other driver vehicle/node(s) on such directed path(s), ii) misbehaving vehicle/node(s) having at least one directed path to the first node, where no driver vehicle/node(s) on such directed path(s), iii) floating or misbehaving vehicle/node(s) on the directed path(s) from driver vehicle/node(s) (respectively, misbehaving vehicle/node(s)) satisfying i) (respectively, ii)) to the first vehicle/node, where no other driver vehicle/node(s) on such directed path(s), and/or iv) floating vehicle/node(s) on the directed path(s) between vehicle/nodes satisfying condition iii), where no driver vehicle/node(s) on such directed path(s). Thus, the directed sub-network can include vehicles or nodes, which only can affect the critical vehicle or node. By reducing the size of the directed network, the process 200 can effectively save computing resources and improve efficiency and computing speed by not processing other possible misbehaving vehicles outside of the directed sub-network.
At step 230, the process 200 can implement a proportional-integral controller for suppressing an effect of the possible misbehaving node on the networked multiagent system. In some examples, the proportional-integral controller can produce a control signal based on a global command and an integrator state. For examples, the proportional-integral controller for a driver node or a misbehaving node included in the directed graph can produce a control input (u(t)) defined by: u(t)=−γ1(γ(t)−1mc(t))−γ2z(t) and the integrator state (z(t)) defined by: ż(t)=y(t)−1mc(t), z(0)=z0, t≥0. Here, y(t) denotes the output of driver vehicle(s)/node(s) and denotes a column vector composed of all ones. The integrator state denotes the difference between the output of driver nodes and the desired command. In some examples, the integrator state can be used to suppress undesired effects of misbehaving nodes. In some examples, the proportional-integral controller is implemented to the misbehaving node. In further examples, the proportional-integral controller is implemented to a neighbor node to the misbehaving node. For example, if the controller is not able to be implemented to the misbehaving node, the process can implement the controller to a neighbor node, which is a next node to the misbehaving node in the directed graph. Thus, the process 200 can suppress the negative effects of misbehaving nodes on the neighbor node. In some examples, the process 200 can implement the proportional-integral controller to a vehicle or node to suppress effects of multiple possible misbehaving vehicles or nodes. For example, referring to
In further examples, the process 200 can determine a steady-state indication of each node of the subset of the multiple nodes. In some examples, to determine the steady-state indication of each node of the subset of the multiple nodes, the process 200 can use the equation, x*r=1n
In the foregoing specification, a multiagent network is described, and the multiagent network includes n scalar nodes exchanging their relative state information within each other according to a fixed, connected, and directed graph topology . This network has three types of nodes: namely, misbehaving nodes, driver nodes, and floating nodes. Specifically, misbehaving nodes are subject to exogenous disturbances, driver nodes receive feedback control signals, and floating nodes are subject to neither exogeneous disturbances nor feedback control signals. Here, the focus is on suppressing the effects of misbehaving nodes on the multiagent network.
To address this problem, proportional-integral feedback controllers are disclosed to be executed by the driver nodes where the number of driver nodes can be less than the total number of all nodes. In particular, the structure of the proposed feedback controllers allows the stability of the overall multiagent network in the sense of input-to-state stability to be shown, where the steady-state values of all nodes are also provided. Next, considering large-scale, complex multiagent networks, the fact that it may be a challenge to obtain the Laplacian matrix of the overall multiagent network is acknowledged. To this end, a graph-theoretical approach to obtain steady-state value of critical nodes over sub-Laplacian matrices in the theoretical approach is provided herein. The graph-theoretical approach further paves the way in understanding how the driver nodes need to be selected for suppressing the effect of misbehaving nodes on the neighborhood of the critical nodes. Mathematically speaking, the dynamics of the overall multiagent network can be compactly given by:
{dot over (x)}(t)=−x(t)+Bu(t)+Dw(t), x(0)=x0, t≥0 (1)
y(t)=BTx(t) (2)
where x(t)=[x1(t), . . . , xn(t)]T∈ is the state of nodes, u(t)=[u1(t), . . . , um(t)]T∈ is the aggregated control inputs applied to the driver nodes, and w(t)=[w1(t), . . . , w1(t)]T∈ is the aggregated bounded exogenous disturbances with bounded time derivatives that affect misbehaving node. Here, B=[b1, . . . , bm)]∈ and D=[d1, . . . , d1)]∈ respectively represent the driver and misbehaving nodes in , where bi∈ is a unit vector with its jth element being 1 to receive a control input ui(t) (i.e., jth node is a driver node in ) and di∈ is a unit vector with its kth element being 1 that is affected by an exogeneous disturbance wi(t) (i.e., kth node is a misbehaving node in ).
Now, the proportional-integral controller for driver nodes is disclosed, given by
u(t)=−γ1(y(t)−1mc(t))−γ2z(t) (3)
ż(t)=y(t)−1mc(t), z(0)=z0, t≥0 (4)
where γ1, γ2∈R>0 denote the controller parameters, z(t)∈ denotes the integrator states, and c(t)∈ denotes the desired command.
The proposed controller (3) and (4) for the multiagent network (1) and (2) solve the problem described above when the graph contains a spanning tree with the root nodes being the driver nodes (Condition 1). For the control of multiagent networks over directed graph topologies, this assumption is standard, and it implies that the union of the driver nodes has a directed path to every other node in the graph .
The multiagent network (1) and (2) subject to the proposed controller (3) and (4) satisfies the dynamics given by
{dot over (x)}(t)=−Jx(t)−γ2Bz(t)+γ1B1mc(t)+Dw(t), x(0)=x0, t≥0 (5)
ż(t)=BTx(t)−1mc(t), z(0)=z0, t≥0 (6)
where J+γ1BBT. To show the stability of the closed-loop multiagent network given by (5) and (6), first, the following definition of the Z-matrix and the following lemma is needed.
Let F=[fij]∈ be a Z-matrix if fij≤0 for all i,j=1, . . . , n such that i≠j. The following two conditions are then equivalent: i) The eigenvalues of F have positive real parts and ii) there exists a positive diagonal matrix S such that ES+SET is positive-definite (Lemma 1). Based on this, the definition of matrix J can be considered. Then, JTS+SJ is positive definite (Lemma 2).
It can be observed that γ1BBT is a square matrix full of zeros except some positive elements on its diagonal, and therefore, J is a Z-matrix by definition. In addition, J matrix is nonsingular and all of its eigenvalues are located in the open right-half plane. It can also be observed that JT is also a Z-matrix and has the same eigenvalues as matrix J. Hence, from ii) Lemma 1, there exists a positive diagonal matrix S such that JTS+SJ is positive definite.
Now, define η(t)[xT(t), zT(t)]T. Using (5) and (6), one can write
{dot over (η)}(t)=Agη(t)+Bgu*(t), η(0)=η0, t≥0 (7)
where
and u*(t)=[c(t), wT(t)]T. In what follows, it can be considered that u*(t) is composed of bounded functions having bounded derivatives. If Condition 1 holds, the closed-loop multiagent network (7) is then input-to-state stable (Theorem 1).
It can be observed that u*(t) is a bounded function of time, since c(t) and w(t) are bounded functions of time by their definitions. To provide input-to-state stability of the closed-loop multiagent network (7), it is then sufficient to show that Ag is asymptotically stable, meaning that Ag is Hurwitz; hence, let u*(t)=0 in (7) to show Ag being Hurwitz.
Next, without loss of generality, enumerate nodes in the network in such a way that the first m nodes represent the driver nodes. From Lemma 2, there exists a positive diagonal matrix S (i.e., S=diag(s1, . . . , sn) and s1>0 for all i=1, . . . , n) such that JTS+SJ is positive definite. Let
Finally, define a set S{η(t)∈Rn+m:x(t)=0}. If {dot over (V)}(η(t))=0, then x(t) must be zero since JTS+SJ is positive definite. Therefore, S={η(t)∈:x(t)=0}. Suppose that η(t) is a solution that belongs identically to S. Since x(t)≡0, then {dot over (x)}(t)≡0. It can be deduced from (5) that γ2Bz(t)≡0, or equivalently, Bz(t)≡0 since γ2 is a positive real number. From the structure of B, it is clear that BTB is nonsingular, and therefore, Bz(t)≡0 implies z(t)≡0. Hence the trivial solution η(t)≡0 is the only solution, which identically stay in S. As a consequence, the origin is globally asymptotically stable, and therefore, Ag is Hurwitz.
Theorem 1 not only shows input-to-state stability of the closed-loop multiagent network (7) but also implies η(t) to asymptotically approach (respectively, approximately approach) to its equilibrium point when u*(t) is constant (respectively, time-varying).
Let Condition 1 hold and BTJ−1B be non-singular. Then, J−1B(BTJ−1B)−11m=1n (Lemma 3). Consider (BTJ−1B)−11m=1n. Define θ=γ11m. One can show that (BTJ−1B)−11m=θ, or equivalently, (BTJ−1B)θ=1m holds, which is a linear equation. Since BTJ−1B is nonsingular, then θ=γ11m is the unique solution of the linear equation. Now, one can also write J−1B(BTJ−1B)−11m as γ1J−1B1m. Define s1n. One can show that γ1J−1B1m=s, or equivalently, γ1B1m=Js holds, which is a linear equation. Since J is nonsingular from Condition 1, then s1n is the unique solution of the foregoing linear equation.
Let Condition 1 hold. Consider the closed-loop system given by (7) and let u*(t) be a constant vector denoted by ū*(t)=[
can be used, where
x*=1n
y*=1m
An assistant state can be defined as
ζ(t)η(t)+Ag−1Bgū* (10)
where the time derivative of (10) along with (7) yields
{dot over (ζ)}(t)=Agζ(t), ζ(0)=ζ0, t≥0 (11)
for all ζ0∈, since Ag is Hurwitz by Theorem 1, or equivalently, η*=−Ag−1Bgū* using (10) with “−Ag−1Bgū*” being the equilibrium point of (7), where
Rearranging η*=−Ag−1Bgū* as 0=Agη*Bgū* and noting η*=[x*T,z*T]T, the following is obtained:
x*=J
−1(−γ2Bz*+γ1B1m
B
T
x*=1m
where (13) directly yields (9). To show (8), multiply both sides of (12) from left by BT and use (13) to arrive
Inserting this equation into (12) now yields
x*=J
−1
B(BTJ−1B)−11m
Hence, (8) follows from (14) using Lemma 3.
The expression (8) can be used to understand the steady-state values of all nodes in the multiagent network. Specifically, while
The expression (8) is established for any number of driver and misbehaving nodes in the multiagent network. For the special case of a single driver node and a single misbehaving node, its simplified version is yet possible. In this case, the dynamics of the multiagent network becomes
x*(t)=−x(t)+bu(t)+dw(t), x(0)=x0, t≥0 (15)
y(t)=bTx(t) (16)
where b∈ and d∈ are unit vectors for respectively choosing the driver node and misbehaving node in the multiagent network. Before presenting the steady-state values of all nodes for the special case of a single driver node and a single misbehaving node, introduced in the next lemma. Note that for the special case (i.e., single driver node and single misbehaving node), the J matrix is defined as J+γ1bbT.
Let Condition 1 hold. Then J−1b=γ1−11n. Define rγ1−11n. One can write J−1b=γ1−11n as Jr=b. It can now be easily shown that r=γ1−11n satisfies Jr=b. Since J is nonsingular, r=γ1−11n is the unique solution of the foregoing linear equation (Lemma 4).
Let Condition 1 hold. Consider the closed-loop system given by (7) and let u*(t) be a constant vector denoted by u*(t)=ū* (Corollary 1). For the case of a singular driver node and a single misbehaving node, (8) becomes
x*(t)=1n
If, in addition, b=d, then (17) becomes x*=1n
x*=J
−1(−γ2bz*+γ1b
b
T
x*=
for the case of a single driver node and a single misbehaving node. Next, multiplying both sides of (18) from left by bT, and using (19) and Lemma 3, one can obtain z*=γ1γ2−1bTJ−1d
Revisiting Theorem 2, the following remark provides a discussion for the case when u*(t) is not constant. In Theorem 2 and Corollary 1, the steady-state values of nodes in the multiagent network are established when u*(t) is constant (i.e., u*(t)≡ū*). Now, consider that u*(t) is time-varying. When ū* is replaced in (10) with u*(t), one can obtain the time-derivative of the assistant state (1) as
{dot over (ζ)}(t)=Agζ(t)+Ag−1Bg{dot over (u)}*(t), ζ(0)=ζ0, t≥0 (20)
Since Ag is Hurwitz, (20) is input-to-state stable with regard to {dot over (u)}*(t) being as input. Observe that when the time rate of change in {dot over (u)}*(t) is small, the closed-loop system trajectories of (7) stay close to its equilibrium point, which is given by (8) and (9) for the multiple driver nodes and the multiple misbehaving nodes case, and (17) for a single driver node and a single misbehaving node case. Finally, if
then (8) and (9) of Theorem 2, and (17) of Corollary 1 still hold.
While the previous paragraphs investigate how to find the steady-state of nodes in the multiagent network, it uses the knowledge of the Laplacian matrix in (8) of Theorem 2 for the multiple driver nodes and multiple misbehaving nodes case and in (17) of Corollary 1 for the single driver node and single misbehaving node case. Acknowledging the face that it may be a challenge to obtain the complete Laplacian matrix of large-scale complex multiagent networks, the following provides a graph-theoretical approach to find the steady-state values of the critical nodes with minimum number of nodes in the multiagent network over sub-Laplacian matrices. Specifically, nodes needed to be take into account for this calculation are characterized. Once these nodes are chosen, a low-dimensional version of (8) (or (17)) can then be used to obtain the steady-state values of the critical nodes. To this end, the following conditions are made.
Let vc denote a critical node in the multiagent network over a fixed, connected and directed graph . There exists a fixed, connected, and directed subgraph r containing nr<n nodes that satisfy any conditions: i) driver node(s) having at least one directed path to vc, where no other driver node(s) on such directed path(s), ii) misbehaving node(s) having at least one directed path to vc, where no driver node(s) on such directed path(s), iii) floating or misbehaving node(s) on the directed path(s) from driver node(s) (respectively, misbehaving node(s)) satisfying i) (respectively, ii)) to vc, where no other driver node(s) on such directed path(s), and iv) floating node(s) on the directed path(s) between nodes satisfying condition iii), where no driver node(s) on such directed path(s) (Condition 2).
Let xr* denote the steady-state values of nodes contained in r, including the steady-state value of vc. Without loss of generality, the nodes are enumerated in starting first with the nodes belonging to r. One can then partition as
where 1∈ denotes a portion of corresponding to nodes in . Now r1+diag(Σj=n
Consider the conditions in Theorem 2. In addition, let Condition 2 hold.
x*
r=1n
represents the case of multiple driver nodes and multiple misbehaving nodes, and
x*
r=1n
for the special case of a single driver node and a single misbehaving node, where x*r denotes the steady-state values of nodes in r including the steady-state value of vc (Theorem 3).
Now it is shown that one can find an expression for understanding the steady-state value of vc with only nodes satisfying Condition 2. For the first part, assume on the contrary that some driver nodes and misbehaving nodes in do not have any directed paths from themselves to vc, where there are no other driver node(s) on such directed paths. To help visualize this, consider the case shown in
Now, consider nodes vk+1 and vk+2 (driver and misbehaving nodes in Vb). They do not have a directed path without containing a driver node except themselves to nodes satisfying ii), iii), and iv) in Condition 2. Otherwise this contradicts the fact that nodes vk+1 and vk+2 do not satisfy i) and ii), respectively. Specifically, misbehaving nodes satisfying ii) have a directed path to vc without containing a driver node. If nodes vk+1 and/or vk+2 have a directed path containing no driver node except themselves to these misbehaving nodes, then nodes vk+1 and/or vk+2 satisfy i) and ii), respectively. Similarly, vk+1 and vk+2 do not have a directed path containing no driver node except themselves to any nodes satisfying iii); because, these nodes are on the directed path between nodes satisfying i) and ii) (i.e., driver and misbehaving nodes in Va) and vc, which means that nodes satisfying iii) have a directed path without containing a driver node to vc. Moreover, vk+1 and vk+2 do not have a directed path to nodes satisfying iv) since these nodes have a directed path without containing a driver node to nodes satisfying iii), which also have directed path to vc without containing a driver node. Hence, nodes vk+1 and vk+2 have no directed path without containing driver nodes except themselves to nodes satisfying ii), iii), and iv) in Va; but, they may have the directed path(s) to nodes satisfying i) (i.e., driver nodes in Va). Thus, there is no incoming information from driver and/or misbehaving nodes (i.e., vk+1, vk+2) in Vb to nodes in Va except the driver nodes (i.e., vk) in Va.
Based on the definition given in Condition 2, r is a fixed, connected and directed graph. Note that r is composed of nodes in Va. Since has a spanning tree by Condition 1 and driver nodes in Vb do not have a directed path to nodes in Va without containing driver nodes in Va, then the subgraph r composed of nodes in Va has a spanning tree by driver nodes in Va. In addition, observe that all driver nodes in follow the desired command irrespective of their neighboring nodes when has a spanning tree, which can be obtained from the equation (9). Similarly r has a spanning tree by driver nodes in Va and these driver nodes follow the desired command when only r was considered. This means that one can ignore the connections from all nodes in Vb to the driver nodes in Va. Consider the rows in 1 corresponding to the driver nodes in Va. Note that 2 denotes the links between nodes in Vb and nodes in Va. For the purpose of network partitioning (i.e., obtaining sub-Laplacian matrix r), the sum of nonzero values in 2 corresponding to each driver nodes in Va is reducing from the degree value of each driver node in 1.
Consider the case shown in
Focusing on the case shown in
First, consider node v6 (connection type a)). Note that v6 does not have a directed path from itself to vc from its unknown section (without containing a driver node) shown in the figure by three dots. Otherwise, v6 satisfies iii) and violated the condition since there exists at least a directed path from a driver node (i.e., v5) in to v6 as a result of Condition 1. Note that node v2 satisfying iii) have a directed path to v6. Since node v6 does not satisfy iv), then there must not exist a directed path(s) from v6 to another node satisfying iii) (i.e., nodes v3 and v4) without having a driver node on the directed path(s). Hence, it is clear that node v6 does not have a directed path to node v7, v8, and v9. In addition, node v6 does not have a directed path(s) to floating nodes satisfying iv); because these nodes have a directed path to nodes satisfying iii). Moreover, node v6 does not have a directed path(s) to misbehaving nodes satisfying ii) since they have a directed path to vc, which also satisfies iii). To summarize, one can conclude that node v6 does not have a directed path to nodes satisfying ii), iii), and iv). Lastly, v6 may have a directed path(s) from its unknown section to driver nodes satisfying i) (i.e., v5). As previously discussed, there is no effect of incoming information to driver nodes. Hence, one can separate v6 from nodes in Va.
Second, consider node v7 (connection type b)). Note that any driver nodes and/or misbehaving nodes in do not have a directed path to v7 over the unknown section of node v7. Otherwise, v7 satisfies iii) and violates the condition because node v7 has a directed path from itself to vc without containing a driver node. However, if there is not directed path to v7 from any driver nodes in through the unknown section of node v7, then has no spanning tree, which contradicts Condition 1. To summarize, if a floating node(s) (in Vb) has only a connection((s) type b) to nodes in Va as shown in
Third, consider node v8 (connection type c)). Note that v8 does not have a directed path(s) to vc from its unknown section (without containing a driver node). Otherwise, it satisfies iii) and contradicts the condition since there exists at least a directed path from a driver node (i.e., v5) to v8 by Condition 1. Note that there are no driver node(s) and/or misbehaving node(s) having a directed path to v8 from the unknown section of v8. Otherwise v8 satisfies iii) and contradicts the condition as well. In addition, node v4 satisfying iii) have a directed path to v8. Since node v8 does not satisfy iv), then v8 does not have a directed path(s) from its unknown section to nodes satisfy in iv), iii), and ii). To summarize, node v8 does not have a directed path(s) from its unknown section to any nodes satisfying ii), iii), and iv) in Va (i.e., v1, v2, v3, v4, and v9) except nodes satisfying i) (i.e., driver nodes in Va). Observe that this directed path(s) does not affect the steady-state value of these driver nodes. Next, the floating nodes (with connection type c)) is demonstrated as not satisfying both iii) and iv) and do not play a role in the steady-state value of nodes (i.e., v4) in Va. This helps to separate nodes in Va from these nodes (i.e., v8) to obtain the steady-state value of vc with minimum number of nodes. Recall that Ag is Hurwitz when Condition 1 holds. When u*(t) is constant, nodes in reach their steady-state value. From the previous discussion, it is clear that neither driver nodes nor misbehaving nodes do not have a directed path to v8 from the unknown section of v8. If there are nodes in the unknown section of v8 having a directed path(s) to v8, then they must be floating nodes. In addition, v8 must have a directed path(s) to these nodes in its unknown section because of Condition 1. Now, consider a subgraph , which is composed of v4, v8, and all nodes from the unknown section of v8 having a directed path to v8. It is clear that is a fixed connected, and undirected graph. If v4 is considered as a virtual leader in , then one can show that all nodes in follow node v4. This means that all nodes in approach the same steady-state values. Consider (7) together with the result
given in Theorem 1. Then, one can write the row corresponding to node v4 in (7) as
0=x*8−x*4+x*5−x*4+x*3−x*4 (23)
when time goes to infinity. Since the steady-state values of nodes v4 and v8 are the same, they cancel out each other. Hence, v8 can be separated from nodes in Va since it does not affect the steady-state value of nodes in Va. Note that if there does not exist an (optional) edge from v3 to v3, then the term x*3−x*4 can be ignored given in (23), which does not change the result.
To summarize, if driver node(s) (respectively, misbehaving node(s)) does not satisfy i) (respectively, ii)), then they do not have a directed path(s) to nodes satisfying ii), iii), and iv) but they may have a directed path(s) to nodes satisfying i) (i.e., driver nodes in Va). In addition, r has a spanning tree by the driver nodes in Va. (i.e., the subgraph r). Next, if floating nodes (in Vb) do not satisfy both iii) and iv), they (connection type a)) either do not have a directed path(s) to nodes in Va (i.e., the subgraph r) except driver nodes (i.e., v5) in Va or they (connection type c)) have a directed path(s) to nodes in Va without affecting the steady-state value of nodes in Va. Note that is also explained that floating nodes (in Vb) not satisfying both iii) and iv) cannot have only a connection(s) type b) with nodes in Va. For the purpose of the network partitioning, the sum of nonzero values in 2 corresponding to each node in Va communication with floating nodes in Vb (connection type c)) is reduced from the degree value of each node in Va. Hence, one can obtain the sub-Laplacian matrix r as defined before in Theorem 3, which represents the graph topology of subgraph r. As a consequence, (21) for the case of multiple driver nodes and multiple misbehaving nodes in r or (22) for the special case of a single driver node and a single misbehaving nodes in r can be used toward x*r in r, where x*r also includes the steady-state value of vc.
Consider the subgraph r and recall from Theorem 3 that it has a spanning tree. If there is no misbehaving node(s) in r, then Dr
An additional example to demonstrate how to use the graph-theoretical approach in Theorem 3 in suppressing the negative effect of misbehaving nodes on the neighborhood of the critical node vc (i.e., v2) in is now shown. In particular, observe that only misbehaving nodes v8 and v13 affect the neighborhood of the critical node. If it is desired for all nodes in r to follow the desired command, then the proposed controller needs to be implemented to only nodes v8 and v13 in addition to other existing driver nodes in . If this controller cannot be implemented directly to misbehaving nodes v8 and v13, then nodes v6 and v11 can also be chosen as the driver nodes, which paves the way for preventing misbehaving nodes v8 and v13 in r from satisfying conditions ii) and iii) in Condition 2 anymore. Hence, negative affects of misbehaving nodes v8 and v13 on the neighborhood of vc (i.e., r) can be suppressed). To this end, the time response of nodes in r is respectively shown in
In the foregoing specification, implementations of the disclosure have been described with reference to specific example implementations thereof. It will be evident that various modifications may be made thereto without departing from the broader spirit and scope of implementations of the disclosure as set forth in the following claims. The specification and drawings are, accordingly, to be regarded in an illustrative sense rather than a restrictive sense.
This application claims the benefit of U.S. Provisional Patent Application Ser. No. 63/401,045, filed Aug. 25, 2022, the disclosure of which is hereby incorporated by reference in its entirety, including all figures, tables, and drawings
This invention was made with government support under Grant Number CMMI-1657637 granted by National Science Foundation. The government has certain rights in the invention.
Number | Date | Country | |
---|---|---|---|
63401045 | Aug 2022 | US |