COOPERATIVE TARGET EXECUTION SYSTEM FOR UNMANNED AERIAL VEHICLE NETWORKS

Information

  • Patent Application
  • 20190289469
  • Publication Number
    20190289469
  • Date Filed
    November 29, 2018
    6 years ago
  • Date Published
    September 19, 2019
    5 years ago
Abstract
An integrated decision making and communication system includes a memory to store a list of resources necessary to execute a mission; a transceiver to send and receive data between communicatively linked devices; and a processor to identify a set of available resources capable of executing the mission based on the data received from the devices; compare the list of resources necessary to execute the mission from the memory with the set of available resources; and identify a combination of the devices to execute the mission based on the comparison of the list of resources necessary to execute the mission and the set of available resources.
Description
BACKGROUND
Field of the Invention

The embodiments herein generally relate to coalition formation techniques, and more particularly to target detection and subsequent task completion in a coalition of devices.


Background of the Invention

Recent advancements in communication and computation systems allow deployment of large teams of Unmanned Aerial Vehicles (UAVs) to cooperatively accomplish complex missions that often cannot be performed by a single. Several features including task coordination and reliable communications are typically required to enable interoperability within the heterogeneous airborne networks, particularly for autonomous operations and providing on-board data processing during the mission. These heterogeneous autonomous vehicle systems could provide a great flexibility to complete compound tasks which are distributed in time and space.


The task allocation problem in multi-agent systems is defined as the process of allocating a set of tasks to groups of agents to ensure timely and efficient task completions, noting the individual capabilities of the agents. Previous solutions to the complex problem of task assignment have involved using different approaches including mixed integer linear programming, dynamic network flow optimization, market-based strategy, finite state machine, and multiple-choice knapsack problem. While in the majority of the aforementioned solutions, the tasks are centrally assigned to the agents by a base station that has complete knowledge about the tasks and often the agents' capabilities; in many dynamic systems, tasks may appear at unpredictable locations and times (e.g., target detection in military settings, as well as search and rescue operations).


Hence, a priori knowledge about these tasks is not always available to the base station. Even when such centralized task allocation techniques exist, they often require computationally intensive solutions even in homogeneous networks and are not easily scalable to systems with a large number of tasks or agents. Noting the computation and communication capabilities of modern devices, the agents can be considered as smart entities with decision-making capabilities. Such cognitive capability may facilitate the implementation of distributed task allocation mechanisms by allowing the agents to observe the environment and monitor the operation of other agents and properly respond to the observed situations.


Coalition formation game is a class of games, in which the players cooperate with each other by forming various sub-groups called coalitions. This class of games has been recently used in various applications such as task assignment in multi-agent systems, and communication networks. In conventional solutions of coalition formation for task allocation, the objective is to enhance the efficiency of the formed groups in task performance noting the different capabilities available at the coalition members. Therefore, the agents often consider a solution to be optimal when it maximizes the total utilities of the group in executing the existing tasks with minimum resources. In these solutions, it is assumed that all the agents are fully trustable, and they are obligated to cooperate with one another by utilizing their initially claimed resources to complete the tasks. However, this assumption is far too optimistic since cooperation is not an inherent characteristic of cognitive but potentially self-interested agents. Accordingly, a new solution to cooperative coalition formation is desirable.


BRIEF SUMMARY OF THE INVENTION

In view of the foregoing, an embodiment herein provides an integrated decision making and communication system comprising a memory to store a list of resources necessary to execute a mission; a transceiver to send and receive data between communicatively linked devices; and a processor to identify a set of available resources capable of executing the mission based on the data received from the devices; compare the list of resources necessary to execute the mission from the memory with the set of available resources; and identify a combination of the devices to execute the mission based on the comparison of the list of resources necessary to execute the mission and the set of available resources.


The processor may instruct the transceiver to send messages to the identified combination of the devices to execute the mission. The system may further comprise a first device containing the memory, the transceiver, and the processor to autonomously store, transceive, and process the data without control by a centralized base station; and a plurality of other functionally similar devices communicatively linked to the first device. The processor of the first device groups the plurality of other functionally similar devices based on possible combinations of devices comprising resources capable of executing the mission. The processor of the first device selects the group of the plurality of other functionally similar devices comprising a most efficient utilization of the available resources to execute the mission in a predetermined period of time.


The transceiver of the first device may transmit a proposal to the plurality of other functionally similar devices to request the plurality of other functionally similar devices to combine their available resources to execute the mission; and receives responses from the plurality of other functionally similar devices of whether to they agree to utilize their available resources to execute the mission. The devices may comprise unmanned aerial vehicles (UAVs).


Another embodiment provides a machine-readable storage medium comprising computer-executable instructions that when executed cause a processor of a first UAV to determine resources used to execute a mission; generate a set of available resources capable of executing the mission from a group of UAVs in communication with the first UAV; compare the resources used for executing the mission with the set of available resources; and identify a combination of the UAVs to assist in executing the mission based on the comparison of the resources used for executing the mission and the set of available resources.


In the machine-readable storage medium, wherein the instructions, when executed, further cause the processor to identify the group of UAVs; and transmit a request to the group of UAVs to send to the first UAV the available resources for each of the UAVs in order to generate the set of available resources capable of executing the mission. In the machine-readable storage medium, wherein the instructions, when executed, further cause the processor to generate the set of available resources capable of executing the mission based on an assessment of which combination of the available resources from the group of UAVs best maximizes an efficiency in executing the mission.


In the machine-readable storage medium, wherein the instructions, when executed, further cause the processor to filter out any UAVs from the group of UAVs based on a past performance of executing other missions. In the machine-readable storage medium of claim 8, wherein the instructions, when executed, further cause the processor to filter out any UAVs from the group of UAVs based on a real-time assessment of a performance of any of the UAVs utilization of its available resources in executing the mission.


In the machine-readable storage medium, wherein the instructions, when executed, further cause the processor to filter out any UAVs from the group of UAVs that decline to offer available resources in executing the mission. In the machine-readable storage medium, wherein the instructions, when executed, further cause the processor to select the combination of the UAVs to assist in executing the mission; and transmit a coalition message to the selected UAVs to execute the mission. In the machine-readable storage medium, wherein the instructions, when executed, further cause the processor to generate the set of available resources capable of executing the mission based on assigning a predetermined value to each of the available resources provided by each of the UAVs; and determine which combination of UAVs corresponds to the predetermined value of the available resources to complete the mission without overspending the available resources.


Another embodiment provides a method of autonomously assessing a cooperative performance of a task, the method comprising operating a first UAV to search for a target; upon locating the target, assessing a requirement for the first UAV to perform the task relating to the target; transmitting a first electronic message to other UAVs capable of assisting the first UAV in performing the task; receiving at least one second electronic message from the other UAVs identifying available resources from each of the other UAVs to perform the task; and determining which combination of the other UAVs is best capable of assisting the first UAV in performing the task based on a predefined criterion.


The method may further comprise selecting the combination of the other UAVs that is best capable of assisting the first UAV in performing the task; and transmitting a third electronic message to the other UAVs requesting the selected combination of the other UAVs to assist the first UAV in performing the task. The method may further comprise performing the task using the first UAV with the selected combination of the other UAVs. The method may further comprise selecting the combination of the other UAVs based on any of a time required to perform the task, resource allocation capable of being provided by the other UAVs, a trust factor associated with the other UAVs, and a likelihood of performance of the task based on the available resources from each of the other UAVs. Each of the other UAVs may comprise a different available resource to assist the first UAV in performing the task.


These and other aspects of the embodiments herein will be better appreciated and understood when considered in conjunction with the following description and the accompanying drawings. It should be understood, however, that the following descriptions, while indicating preferred embodiments and numerous specific details thereof, are given by way of illustration and not of limitation. Many changes and modifications may be made within the scope of the embodiments herein without departing from the spirit thereof, and the embodiments herein include all such modifications.





BRIEF DESCRIPTION OF THE DRAWINGS

The embodiments herein will be better understood from the following detailed description with reference to the drawings, in which:



FIG. 1 is a block diagram illustrating an integrated decision making and communication system, according to an embodiment herein;



FIG. 2 is a block diagram illustrating transmission of messages from the transceiver of the integrated decision making and communication system of FIG. 1, according to an embodiment herein;



FIG. 3 is a block diagram illustrating multiple devices communicatively linked together in the integrated decision making and communication system of FIG. 1 and without a controlling base station, according to an embodiment herein;



FIG. 4 is a block diagram illustrating grouping of devices capable of executing a mission in the integrated decision making and communication system of FIG. 1, according to an embodiment herein;



FIG. 5 is a block diagram illustrating selection of a group of devices to execute a mission based on a manner of utilizing available resources in the integrated decision making and communication system of FIG. 1, according to an embodiment herein;



FIG. 6 is a block diagram illustrating a first device transmitting a proposal to other devices in the integrated decision making and communication system of FIG. 1, according to an embodiment herein;



FIG. 7A is a block diagram illustrating a coalition of UAVs grouped to perform a mission, according to an embodiment herein;



FIG. 7B is state diagram illustrating a coalition formation process, according to an embodiment herein;



FIG. 8A is a block diagram illustrating a system for executing a mission, according to an embodiment herein;



FIG. 8B is a block diagram illustrating a system for communicating between a group of UAVs, according to an embodiment herein;



FIG. 8C is a block diagram illustrating a system for filtering out the selection of UAVs from a group of UAVs based on different factors, according to an embodiment herein;



FIG. 8D is a block diagram illustrating a system for selecting a combination of UAVs to execute a mission and communicating with the selected UAVs, according to an embodiment herein;



FIG. 8E is a block diagram illustrating a system for generating a set of available resources to execute a mission and determining a combination of UAVs with the resources to execute the mission, according to an embodiment herein;



FIG. 9A is a flow diagram illustrating a method of autonomously assessing a cooperative performance of a task, according to an embodiment herein;



FIG. 9B is a flow diagram illustrating a method of selecting a combination of UAVs to perform a task, according to an embodiment herein;



FIG. 9C is a flow diagram illustrating a method of performing a task with a selected combination of UAVs, according to an embodiment herein;



FIG. 9D is a flow diagram illustrating a method of selecting a combination of UAVs to perform a task based on different factors, according to an embodiment herein;



FIG. 10 is a graphical representation illustrating experimentally simulated stable formed coalitions used to complete two identified tasks with two leader and six follower UAVs, according to an embodiment herein;



FIG. 11 is a graphical representation illustrating the efficiency factor for the coalition formation method provided by the embodiments herein compared to the case of selecting the closest UAVs; and



FIG. 12 is a graphical representation illustrating the change in cooperative credit of UAVs based on their cooperative/selfish behavior in resource sharing, according to an embodiment herein.





DETAILED DESCRIPTION OF THE INVENTION

Embodiments of the disclosed invention, its various features and the advantageous details thereof, are explained more fully with reference to the non-limiting embodiments that are illustrated in the accompanying drawings and detailed in the following description. Descriptions of well-known components and processing techniques are omitted to not unnecessarily obscure what is being disclosed. Examples may be provided and when so provided are intended merely to facilitate an understanding of the ways in which the invention may be practiced and to further enable those of skill in the art to practice its various embodiments. Accordingly, examples should not be construed as limiting the scope of what is disclosed and otherwise claimed.


According to various examples, the embodiments herein provide a leader-follower coalition system in a UAV network that identifies the required resources necessary to carry out a task; e.g., perform a mission. The mission may be any suitable type of mission including military tasks related to targets, search-and-rescue and surveillance, etc. A leader UAV sends a call out to other UAVs in the network asking them to form a coalition based on the available resources that the other UAVs have to assist in completing the task/mission. The leader UAV determines which group of other UAVs can most efficiently complete the task/mission based on comparing the available resources of the other UAVs and the required resources necessary to complete the task/mission. The leader UAV then selects the group of UAVs that meets the efficiency criteria.


Referring now to the drawings, and more particularly to FIGS. 1 through 12, where similar reference characters denote corresponding features consistently throughout, there are shown exemplary embodiments. In the drawings, the size and relative sizes of components, layers, and regions may be exaggerated for clarity.


In some examples, the various devices and processors described herein and/or illustrated in the figures may be embodied as hardware-enabled modules and may be configured as a plurality of overlapping or independent electronic circuits, devices, and discrete elements packaged onto a circuit board to provide data and signal processing functionality within a computer. An example might be a comparator, inverter, or flip-flop, which could include a plurality of transistors and other supporting devices and circuit elements. The modules that are configured with electronic circuits process computer logic instructions capable of providing digital and/or analog signals for performing various functions as described herein. As used herein, the modules may refer to any component or set of components that perform the functionality attributed to the module, and may include a physical processor to execute processor-readable instructions. Additionally, the modules may include the processor, the processor readable instructions, circuitry, hardware, storage media, other components, and combinations thereof. The various functions can further be embodied and physically saved as any of data structures, data paths, data objects, data object models, object files, database components. For example, the data objects could be configured as a digital packet of structured data. The data structures could be configured as any of an array, tuple, map, union, variant, set, graph, tree, node, and an object, which may be stored and retrieved by computer memory and may be managed by processors, compilers, and other computer hardware components. The data paths can be configured as part of a computer CPU that performs operations and calculations as instructed by the computer logic instructions. The data paths could include digital electronic circuits, multipliers, registers, and buses capable of performing data processing operations and arithmetic operations (e.g., Add, Subtract, etc.), bitwise logical operations (AND, OR, XOR, etc.), bit shift operations (e.g., arithmetic, logical, rotate, etc.), complex operations (e.g., using single clock calculations, sequential calculations, iterative calculations, etc.). The data objects may be configured as physical locations in computer memory and can be a variable, a data structure, or a function. In the embodiments configured as relational databases (e.g., such Oracle® relational databases), the data objects can be configured as a table or column. Other configurations include specialized objects, distributed objects, object-oriented programming objects, and semantic web objects, for example. The data object models can be configured as an application programming interface for creating HyperText Markup Language (HTML) and Extensible Markup Language (XML) electronic documents. The models can be further configured as any of a tree, graph, container, list, map, queue, set, stack, and variations thereof. The data object files are created by compilers and assemblers and contain generated binary code and data for a source file. The database components can include any of tables, indexes, views, stored procedures, and triggers.



FIG. 1 illustrates an integrated decision making and communication system 10 comprising a memory 15 to store a list of resources 20 necessary to execute a mission 25. In some examples, the memory 15 may be Random Access Memory (RAM), Read-Only Memory (ROM), a cache memory, hard drive storage, flash memory, or other type of storage mechanism, according to an example. The list of resources 20 may include a description of components, mechanisms, chemicals, or any other type of item or material used to perform a task. In this regard, the mission 25 may comprise any type of task, and may be of a commercial, non-commercial, or military task such as target detection, data collection, target tracking and prosecution, imaging, and surveillance. For example, in one setting, the mission 25 may be to provide supplies through aerial drop-off to people living in a remote location, and the resources 20 may include food, water, medicine, building supplies, etc. Accordingly, the memory 15 stores a list of such resources 20 that are necessary to perform/execute the mission 25. In some examples, the mission 25 may be a predefined static task such that the resources 20 are also similarly predefined/static; i.e., prior to carrying out the mission 25 the resources 20 are set and will not change. However, in other examples the mission 25 may be dynamic and based on real-time effects due to other factors (e.g., environment, third-party influence, technical issues, etc.) the mission 25 may change and as such the resources 20 necessary to execute the mission 25 may also change in real-time. For example, initially the mission 25 may be to supply food to people in a remote location. However, during the course of performing the mission 25, an earthquake may take place requiring the delivery of medicine and building supplies also. Accordingly, the list of resources 20 may change to accommodate the execution of the changing mission 25.


The system 10 comprises a transceiver 30 to send and receive data 35 between communicatively linked devices 401 . . . 40x. As used herein, the subscript x refers to any positive integer. In an example, the transceiver 30 may be an electronic device, circuit, or module that is part of a cellular system, and which enables the exchange of data 35 from among networked devices; e.g., devices 401 . . . 40x. The data 35 may comprise any type of qualitative and quantitative data capable of being transmitted through wired or wireless transfer protocols, and the data 35 may be encrypted.


The communication that occurs in the system 10 may occur through wired communication or wirelessly, in some examples, in an integrated network of the devices 401 . . . 40x. In some examples, the devices 401 . . . 40x may be operatively linked via one or more electronic communication links. For example, such electronic communication links may be established, at least in part, via a communication network such as the Internet and/or other communication networks.


The system 10 further comprises a processor 45. In some examples, the processor 45 may comprise a central processing unit (CPU) of the one or more devices 401 . . . 40x. In other examples the processor 45 may be a discrete component independent of other processing components in the one or more devices 401 . . . 40x. In other examples, the processor 45 may be a microprocessor, microcontroller, hardware engine, hardware pipeline, and/or other hardware-enabled device suitable for receiving, processing, operating, and performing various functions required by the one or more of the devices 401 . . . 40x. Furthermore, the processor 45 may be configured to execute modules by software, hardware, firmware, or combinations thereof, or other mechanisms for configuring processing capabilities. In some examples, the processor 45 may be programmable and may be updated in real-time. In accordance with the embodiments herein, the memory 15, transceiver 30, and processor 45 are contained within any of the devices 401 . . . 40x. In some examples, each of the devices 401 . . . 40x comprise their own memory 15, transceiver 30, and processor 45 and are each capable of performing the functions associated with these mechanisms as described herein.


The processor 45 is configured to identify a set of available resources 50 capable of executing the mission 25 based on the data 35 received from the devices 401 . . . 40x. For example, the transceiver 30 may receive the data 35 from the devices 401 . . . 40x which contains all of the collective available resources 50 from the devices 401 . . . 40x. This data 35 is directly or indirectly transmitted to the processor 45 either by wired or wireless transmission. The processor 45 analyzes the data 35 to determine which of the available resources 50 are capable of executing the mission 25. Moreover, the processor 45 is configured to compare the list of resources 20 necessary to execute the mission 25 from the memory 15 with the set of available resources 50. In this regard, the processor 45 retrieves the list of resources 20 from the memory 15 and compares it with the set of available resources 50 provided by the devices 401 . . . 40x. Accordingly, the processor 45 is to determine the resources 20 that are required to execute the mission 25 and compares it with the set of available resources 50 from the devices 401 . . . 40x to determine whether the devices 401 . . . 40x are capable of providing the necessary resources 50 to accomplish the mission 25. Since the list of resources 20 indicate what is necessary (e.g., which resources are required) to perform the mission 25, the processor 45 compares the data 35 containing the available resources 50 with the list of resources 20.


As an alternative to the static configuration described above, in an example of a dynamic or real-time configuration, when the mission 25 changes and the list of resources 20 necessary to perform the mission 25 also changes, or when the devices 401 . . . 40x begin utilizing and/or exhausting the available resources 50 in performing the mission 25, then the transceiver 30 may continue to receive data 35 from the devices 401 . . . 40x and transmit the data 35 to the processor 45 to allow the processor 45 to compare the changing list of resources 20 with the changing set of available resources 50.


Furthermore, in either the static or dynamic configuration, the processor 45 is configured to identify a combination of the devices 40a to execute the mission 25 based on the comparison of the list of resources 20 necessary to execute the mission 25 and the set of available resources 50. In this regard, the combination of devices 40a may be any combination of the devices 401 . . . 40x based on the ability to execute the mission 25 in view of the set of available resources 50 of the devices 401 . . . 40x and the list of resources 20 necessary to execute the mission 25. In one example, the combination of devices 40a may be only one of the devices 401 . . . 40x and in another example, the combination of devices 40a may be the entire set of devices 401 . . . 40x, and in still another example, the combination of devices 40a may be only some of the devices 401 . . . 40x.



FIG. 2, with reference to FIG. 1, illustrates that the processor 45 instructs the transceiver 30 to send messages 55 to the identified combination of the devices 40a to execute the mission 25. The messages 55 may be electronic messages wirelessly transmitted, which may be encrypted in an example. In an example, the transceiver sends the messages 55 to only the identified combination of devices 40a in order to inform the devices 40a to execute the mission 25. In another example, the transceiver 30 sends the messages 55 to all of the devices 401 . . . 40x and identifies the combination of devices 40a to execute the mission 25. According to an example, only one message 55 is transmitted to the devices 401 . . . 40x and/or the combination of devices 40a. According to another example, separate messages 55 are transmitted to the devices 401 . . . 40x and/or the combination of devices 40a.



FIG. 3, with reference to FIGS. 1 and 2, illustrates that the system 10 may comprise a first device 401 containing the memory 15, the transceiver 30, and the processor 45 to autonomously store, transceive, and process, respectively, the data 35 without control by a centralized base station 60. In an example, the first device 401 may be considered to be the leader device in the coalition of devices 401 . . . 40x. Contrary to the solutions of the conventional systems, the embodiments herein do not rely on the control of a centralized base station 60. A centralized base station 60 may exist in the system 10; however, the centralized base station 60 is not utilized to control the storage by the memory 15, transceiving by the transceiver 30, and/or the processing by the processor 45. Accordingly, the functionality of the first device 401 is autonomous in terms of storing the list of resources 20 necessary to execute a mission 25, sending and receiving data 35 between the communicatively linked devices 401 . . . 40x, identifying the set of available resources 50 capable of executing the mission 25 based on the data 35 received from the devices 401 . . . 40x, comparing the list of resources 20 necessary to execute the mission 25 from the memory 15 with the set of available resources 50, and identifying a combination of the devices 40a to execute the mission 25 based on the comparison of the list of resources 20 necessary to execute the mission 25 and the set of available resources 50.


The system 10 may comprise a plurality of other functionally similar devices 402 . . . 40x communicatively linked to the first device 401. In this regard, the devices 402 . . . 40x are functionally similar to the first device 401. Additionally, the other functionally similar devices 402 . . . 40x may each comprise a similar memory 15, transceiver 30, and processor 45 as the first device 401. Accordingly, any of the devices 401 . . . 40x may be considered as the leader device in the coalition of the devices 401 . . . 40x. The first device 401 together with the other functionally similar devices 402 . . . 40x may collectively form the coalition of devices 401 . . . 40x such that each of the devices 401 . . . 40x may be communicatively linked with each other. As such, communicatively linking the devices 401 . . . 40x may include wired or wireless linking of the devices 401 . . . 40x, and may further include direct or indirect connections therebetween. Regardless, of the type of connection between the devices 401 . . . 40x, the devices 401 . . . 40x are configured to send/receive data 35 and messages 55 to one another autonomously; i.e., without control by a centralized base station 60.



FIG. 4, with reference to FIGS. 1 through 3, illustrates that the processor 45 of the first device 401 groups the plurality of other functionally similar devices 402 . . . 40x based on possible combinations of devices 40b comprising resources 20b capable of executing the mission 25. In this example, the first device 401 acts as a leader device in the group of devices 401 . . . 40x, and based on the data 35 containing the set of available resources 50 received from the other functionally similar devices 402 . . . 40x, the first device 401 determines which combination of devices 40b of the other functionally similar devices 402 . . . 40x including the first device 401 contains the resources 20b capable of executing the mission 25. The processor 45 of the first device 401 may create the possible combinations of the devices 40b by comparing the available resources 20b of each possible combination of the devices 40b with the list of resources 20 stored in memory 15 to ensure that the resources 20b are capable of executing the mission 25. Accordingly, there may be one or more possible combinations of devices 40b capable of executing the mission 25.



FIG. 5, with reference to FIGS. 1 through 4, illustrates that the processor 45 of the first device 401 selects the group of the plurality of other functionally similar devices 402 . . . 40x comprising a most efficient utilization of the available resources 50 to execute the mission 25 in a predetermined period of time T. In addition to the first device 401 selecting the group of the plurality of other functionally similar devices 402 . . . 40x, the first device 401 may include itself with the group of the plurality of other functionally similar devices 402 . . . 40x in order to execute the mission 25. As such, as the leader device in the overall devices 401 . . . 40x, the first device 401 may autonomously determine whether to include itself in the combination of devices 40b that will execute the mission 25. The processor 45 of the first device 401 may consider any of several factors in order to establish the combination of devices 40b that will execute the mission 25. In the example of FIG. 5, one such factor is for the processor 45 to consider which combination of devices 40b, possibly including the first device 401, comprises the available resources 50 to perform the mission 25 within the predetermined period of time T, which may be initially established by the processor 45 prior to identifying the set of available resources 50 capable of executing the mission 25 based on the data 35 received from the devices 401 . . . 40x, or which may be established in real-time as the other functionally similar devices 402 . . . 40x are in the process of completing the mission 25 or based on real-time status changes of any of the other functionally similar devices 402 . . . 40x. Moreover, the processor 45 is configured to consider not only which of the combination of devices 40b comprises available resources 50 capable of executing the mission 25 within the predetermined period of time T, but also factors into the decision, which combination of devices 40b will most efficiently utilize its available resources 50 within the predetermined period of time T such that some of the other functionally similar devices 402 . . . 40x may have functional or performance characteristics (i.e., speed, accuracy, dependability, strength, etc.) that is relayed in the data 35 received by the transceiver 30 and transmitted to the processor 45 of the first device 401, and which the processor 45 of the first device 401 considers in making the selection of the group of devices 40b.



FIG. 6, with reference to FIGS. 1 through 5, illustrates that the transceiver 30 of the first device 401 may transmit a proposal 65 to the plurality of other functionally similar devices 402 . . . 40x to request the plurality of other functionally similar devices 402 . . . 40x to combine their available resources 502 . . . 50x to execute the mission 25. In this example, the first device 401 acts as the leader device in the group of devices 401 . . . 40x; however, because each of the devices 401 . . . 40x are individually autonomous, the first device 401 does not control any of the other functionally similar devices 402 . . . 40x, and thus the first device 401 transmits the proposal 65, which may be sent with the electronic message 55, to the other functionally similar devices 402 . . . 40x requesting that one or more of the other functionally similar devices 402 . . . 40x combine their respective available resources 502 . . . 50x to execute the mission 25 with or without the first device 401 participating. The transceiver 30 of the first device 401 may receive responses 66 from the plurality of other functionally similar devices 402 . . . 40x of whether to they agree to utilize their available resources 502 . . . 50x to execute the mission 25. Accordingly, although one or more of the other functionally similar devices 402 . . . 40x comprises available resources 502 . . . 50x, respectively, to execute the mission 25, any of the autonomous other functionally similar devices 402 . . . 40x may elect not to participate in executing the mission 25 and thus may elect not to combine its available resources 502 . . . 50x, respectively, in order to execute the mission 25. As such, the other functionally similar devices 402 . . . 40x transmit their respective responses 66, which may be in the form of electronic messages sent with the data 35, to the first device 401, in reply to the proposal 65 transmitted by the first device 401.



FIG. 7, with reference to FIGS. 1 through 6, illustrates that the devices 401 . . . 40x may comprise a coalition of UAVs 701 . . . 70x in a network 75 such that UAV 701 may be considered a leader UAV and UAVs 702 . . . 70x may be considered follower UAVs as it relates to performing a task or mission 25 on a target 80. There may be one or multiple leader UAVs according to some examples. The target 80 may be any physical item, component, structure, animal, person, mechanism, etc., or combinations thereof, that is/are the subject of the task or mission 25. Furthermore, the target 80 may be multiple targets and may change in real-time. The UAVs 701 . . . 70x may be individually autonomous; i.e., are not controlled by any other device or any other UAV. The processor 45 may identify a combination of the UAVs (e.g., a coalition) 70a to assist in executing the mission 25. The mission 25 may involve performing a task such as searching for a target 80, etc. In this regard, the combination of UAVs 70a may include a first UAV 701 and any other combination of the other UAVs 702 . . . 70x. Each of the other UAVs 702 . . . 70x may comprise a different available resource 501 . . . 50x to assist the first UAV 701 in performing the mission 25. The first UAV 701 comprises the processor 45 and may communicate with the other UAVs 702 . . . 70x by transmitting electronic messages 85 (e.g., a first electronic message 851, a second electronic message 852, a third electronic message 853, etc.). The electronic messages 85 may be analogous to the message 55 or proposal 65 described above, or may constitute other messages and/or forms of communication. Any of the UAVs 71 (e.g., UAV 703, for example) from the group of UAVs 701 . . . 70x may be excluded from consideration of contributing to execute the mission 25 for any predetermined reason such as how the UAVs 71 performed in other missions 25a and the status of the UAVs 71 available resources 51 in executing the mission 25.



FIG. 7A is an example of a commercial scenario of the integrated decision making and communication system 10 of FIGS. 1 through 6 in which the UAVs 701 . . . 70x are communicatively connectable in a network 75 such that the UAVs 701 . . . 70x can belong to different vendors, and they can collect some sort of monetary benefits for participation in each mission 25. In the leader-follower coalition formation integrated decision making and communication system 10 both the efficiency in task performance considering the resource constraints during the coalition formation from the leader's perspective (e.g., first UAV 701), as well as the individual preferences of the followers (e.g., UAVs 702 . . . 70x) are considered during the followers' (e.g., UAVs 702 . . . 70x) decision making to join the available coalitions 70a. In such a commercial setting, the UAVs 701 . . . 70x may exhibit selfish behaviors by not utilizing the available resources 501 . . . 50x that they originally committed during the coalition formation, with the incentive of saving these resources for future missions to obtain higher benefits. In the system 10, a reputation-based process is considered that keeps the record of the UAVs' 701 . . . 70x cooperative behaviors. The cumulative credits for UAVs 701 . . . 70x are used to identify the trustable UAVs during the member selection procedure in coalition formation. This process involves a trade-off scenario for the UAVs 701 . . . 70x. On one hand, they prefer to avoid resource sharing with others to save their limited available resources 501 . . . 50x, while on the other hand they need to cooperate with other agents and sustain a good reputation in order to be selected for future missions.


As used in the nomenclature herein, vectors and matrices are represented by lower-case and upper-case underlined letters, respectively. The notations (.)*, (.)T and (.)H demonstrate the conjugate, transpose and conjugate transpose (Hermitian) operations, respectively. The real value and imaginary values are shown by custom-character{.} and ℑ{.}. The diagonal matrix A=diag{a} is a matrix whose diagonal elements are the elements of the vector a. Finally, the function γL,ϵ(x) for x>0 is defined as:






{




x




x


1
+








L


Otherwise



,





for a given value of L and small value of ∈, giving: γL,ϵ(x)=γL,O(x).


A heterogeneous system of NUAVs, U={U1, U2, . . . , UN} is considered, where the UAVs (e.g., UAVs 701 . . . 70x) can form various coalitions 70a to accomplish the dynamic tasks in the network 75. Suppose that the ith UAV is assigned with a capability vector r=[ri1, ri2 . . . , riNrr]T with rij≥0, j=1, 2, . . . , Nr, that identifies the available resources at this agent assuming that there are Nr different types of resources in the network 75. Each resource can be either consumable or non-consumable. If the ith UAV does not have resource j, then rij=0, and if resource j is non-consumable, then rij=∞. This vector can vary over time based on the amount of resources the UAVs (e.g., UAVs 701 . . . 70x) consume to complete the tasks.


A coalition of users, named Sk, is a non-empty subset of UAVs, Sk⊂U that handles task k. It is assumed that each coalition of UAVs (e.g., coalition of UAVs 70a) will handle one target 80 at a time. Moreover, a sparse distribution of targets 80 in the environment is considered, hence noting the potential distances among the formed coalitions 70a, it is assumed that each UAV (e.g., UAVs 701 . . . 70x) can be only a member of one of these coalitions 70a at a certain time. Hence, the coalitions 70a are non-overlapping, meaning that Sk∩Sl=ϕ. The coalition of all UAVs, U is the grand coalition and a coalition that only contains one UAV is called a singleton coalition. Each coalition Sk is associated with a vector of available resources which is shown by Rk=[Rk1, Rk2, . . . , RkNr]T with Rkj≥0, j=1, 2, . . . , Nr. For simplicity, one may assume that the vector Rk is additive over the elements' resource vectors in the coalition; i.e., Rkj∈Skri.


It is assumed that the UAVs 701 . . . 70x operate in an unpredictable environment, where targets 80 of various types with different resource requirements appear in random time and locations and move freely afterwards. Therefore, a base station 60 is not aware of the potential targets 80. It is assumed that all the UAVs have the capability of searching for new targets in a limited geographical field, and the target detection is performed by the UAVs independent (i.e., autonomous) of the base station 60. The procedure of prosecuting a target 80 is defined as a compound task to be accomplished by a coalition, such that the term task can refer to a set of multiple sub-tasks required to prosecute a target 80. The tasks can differ inherently based on the characteristics of their corresponding targets 80; hence the number, duration, and location of tasks vary over time. Since each task is associated to a target 80, the terms target and task may be used interchangeably herein.


When a UAV (e.g., UAV 701) detects a task k, it determines the type and amount of the resources 20 required to carry out this task; i.e., Γk=[τk1, τk2, . . . , τkNr]T, where τk1≥0. If this UAV (e.g., UAV 701) does not have sufficient resources 501 to perform the detected task, it calls for a coalition formation and serves as the coalition leader. Since the base station 60 has no information regarding the existing targets 80 in the network 75, the member UAVs (e.g., UAV 701 . . . 70x) of each coalition 70a are configured to listen to the radio communication of a target 80 and forward it to the base station 60. In other words, a coalition of UAVs 70a is supposed to relay the target's message sk with E{sk*sk}=1 to the base station 60. According to the embodiments herein, first each leader UAV 701 forms an initial coalition of the available UAVs UAV 701 . . . 70x to maximize the efficiency in task performance for the encountered target 80, and send a request (e.g., proposal 65) to join the coalition to the selected followers. Then, the follower UAVs 702 . . . 70x observe the formed coalitions 70a by different leaders and decide to join the coalition 70a that benefits them the most. The details of the coalition formation procedure are further described below. In order for a leader (e.g., UAV 701) to form a coalition 70a, it takes into account several factors including i) collecting the required resources 20 to perform a task, ii) traveling time of the UAVs 701 . . . 70x to the task, and iii) the quality of service (QoS) of target message's communication at the base station 60. The goal of this combinational complex optimization problem is to perform the tasks in timely and resource efficient manner. This goal suggests that the members of a newly formed coalitions 70a should collectively have all the required resources 50 to perform the encountered task, while minimally surpassing the task requirements. Other associated costs to coalition formation include a higher chance of UAVs' collisions when having more UAVs in a coalition 70a, as well as heavier signaling loads for the members to exchange the necessary information.


Another criterion in coalition formation from the perspective of the leaders (e.g., UAV 701) is the deadline to complete a task. Hence, the leaders (e.g., UAV 701) take into account the traveling time of the UAVs 701 . . . 70x to the task in order to choose the members of the coalition 70a. For this purpose, δi,k is defined as the traveling time of the ith member of the coalition to target k location that should be less than or equal to a preferred threshold fδ(ρ) as a function of field radius ρ.


One aspect of the embodiments herein is to identify the reliable UAVs (e.g., UAVs in coalition 70a) in the network 75 by the leaders (e.g., UAV 701) to join the coalition(s) and filter out any UAVs (e.g., UAV 71) with selfish behavior. Such networks 75 may be prone to suffer from both malicious/intruding UAVs as well as selfish ones. Accordingly, the technique provided by the embodiments herein prevent potential selfish behavior of legitimate non-altruistic UAVs in not spending their resources after joining a coalition to encourage cooperation among them. This is facilitated by defining a cumulative cooperation credit for each UAV that indicates its cooperative behavior in terms of resource sharing during task completion over the course of time. On one hand, since the leaders (e.g., UAV 701) prefer to select the potential followers (e.g., UAVs 702 . . . 70x) with higher credits, the UAVs 702 . . . 70x are motivated to maintain a good cooperative credit, as further described below. On the other hand, the follower UAVs 702 . . . 70x similar to other types of cognitive agents may act selfishly and avoid consuming their resources after joining a coalition 70a. The incentive behind this behavior is to save their limited available resources for future missions to earn more monetary benefits.


The coalition formation process may occur as follows: First, the coalition leader (e.g., UAV 701) broadcasts a proposal 65 to form a coalition 70a. Then, the UAVs who possess at least one of the required resources 20 can provide a response 66 to this request by reporting their available resources 50 as well as their current positions. This may be referred to as the bid process. The coalition leader (e.g., UAV 701) then evaluates all the bids by assessing the resources offered by the volunteer UAVs (e.g., UAVs 702 . . . 70x), their estimated arrival time, their cooperative credits as well as the provided QoSs for the relaying services during the formation process to determine if a coalition 70a can be formed to complete the encountered task. If a coalition 70a cannot be formed, the coalition leader (e.g., UAV 701) informs the UAVs (e.g., UAVs 702 . . . 70x), otherwise the coalition leader (e.g., UAV 701) provides the selected UAVs in the coalition 70a with information about the tasks (e.g., required resources and location of the target 80). The UAVs 71 that are not selected by the coalition leader (e.g., UAV 701) go back to the search mode. When a UAV receives multiple coalition formation requests, it considers two factors of expected increase in its cooperative credit based on information it received from the leaders (e.g., UAV 701) about required resources 20 for the tasks as well as its distance to the targets 80 in order to decide which coalition 70a to join. The coalition formation process is summarized in FIG. 7B, with reference to FIGS. 1 through 7A. Next, the cooperative communication method to relay a message from the target 80 to the base station 60 is described.


Amplify-and-Forward (AF) is a widely used relaying method in communication networks due to its simplicity and low-complexity. Beamforming is a technique based on AF relaying, where a set of relay nodes amplify and shift the phase of a transmitter's signal and rebroadcast it such that they add up constructively, while interfering signals add up destructively. In order to relay the message from the target 80 to the ground or base station 60, a beamforming scenario is provided in which each UAV in the coalition 70a multiplies the received target's signal to a complex weight number and rebroadcasts it (e.g., AF relaying). A common assumption of knowledge of Channel State Information (CSI) in the system 10 is followed in this technique. It is assumed that








h
_

TU

=


[


h

TU
0


,

h

TU
1


,





,

h

TU

N
S




]

T





is the vector of instantaneous channel coefficients between the target and the coalition members, where NS=|S|−1. Likewise,








h
_

UB

=



[


h


U
0


B


,

h


U
1


B


,





,

h


U

N
S



B



]

T






is





the vector of channel coefficients between the coalition members and the base station 60. Here, the index 0 represents the leader and the indices i=1, 2, . . . , NS represent the members of the coalition 70a. It is assumed that the leader (e.g., UAV 701) has the knowledge of instantaneous reciprocal channel vectors; i.e., hTU and hUB) and is responsible for calculating the optimum beamforming and notifying the members of its coalition 70a.


If ST denotes the transmit signal, the vector of the received signal at the coalition can be written as:






x=h
TU
s
T
+n  (1)


where n˜custom-character(0, Σ1/2), with diagonal covariance matrix Σ, is an additive zero mean Gaussian noise vector at the coalition members. It is assumed that each UAV 701 . . . 70x is aware of its local noise characteristics and performs the whitening transformation process before the beamforming. Hence, the whitened received signal at the UAVs 701 . . . 70x can be written as:






{tilde over (x)}=Σ
−1/2
x=Σ
−1/2
h
TU
s
T−1/2n,  (2)


The ith coalition member, i=0, 1, . . . , NS, multiplies the received target signal by a complex weight wi* and then relays it. The broadcasted signal by the members of the coalition 70a can be written as follows, assuming w=[w0, w1, . . . , wNs]T:






t=W
H
{tilde over (x)}=W
HΣ−1/2hTUsT+WHΣ−1/2n  (3)


where W=diag(w). The received signal at the base station 60 is:














y
B

=






h
_

UB
H




W
_

H






_



-
1

/
2






h
_

TU



s
T




+



h
_

UB
H




W
_

H






_



-
1

/
2




n
_



+
v












=






w
_

H




H
_

UB
H






_



-
1

/
2






h
_

TU



s
T




+



w
_

H




H
_

UB
H






_



-
1

/
2




n
_



+
v








(
4
)







where, HUB=diag(hUB) and v˜custom-characterM(0, σ2) is white Gaussian noise at the base station receiver. Therefore, the Signal-to-Noise Ratio (SNR) at the base station 60 can be expressed by:











SNR
B

=




w
_

H




kk
_

H



w
_






w
_

H




H
_

UB
H




H
_

UB



w
_


+

σ
2




,




(
5
)







where k=HUBHΣ−1/2hTU. Each UAV 701 . . . 70x (including the leader UAV 701) has a limited energy to forward the target's signal. Using Equation (3), the power consumption at each member of the coalition 70a for relaying the target's signal can be written as:






P
i,R=[wH]i−1/2]i,i[hTU]i[hTUH]i−1/2]i,i[w]i+[wH]i[w]i  (6)


where i=0, 1, 2, . . . , NS. It is assumed that the individual transmission power of UAV i is below a certain threshold, denoted by pimax.


To monitor the cooperative behavior of the UAVs 701 . . . 70x, a cumulative cooperative credit is defined for each UAV 701 . . . 70x based on the amount of resources 501 . . . 50x that it utilizes for a specific task. It is assumed that the credit of all UAVs 701 . . . 70x are initialized to an equal initial credit Ci(0)=C>0, i=1, 2, . . . , N. After completing a task, each UAV's credit is calculated using the following steps:


First, the credit of UAV i at time n is updated as:











C
~

i

(
n
)


=

{





C
i

(

n
-
1

)







C
i

(

n
-
1

)





+

Δ






C
i

(
n
)








If
Otherwise




k

|


U
i



S
k



,









(
7
)







Here, the change in credit Ci(n) is defined by:










Δ






C
i

(
n
)



=



τ
k





l


S
k





a
l





a
i






(
8
)







where τkj=1Nrτkj represents a value of task k and







a
i

=




j
=
1


N
r





γ
1



(


r
i
j


τ
k
j


)







denotes the effective resource contribution of each UAV 701 . . . 70x.


Second, if all {tilde over (C)}i(n) for I=1, 2, . . . , N are equal, then the process sets Ci(n)=C to reset the credits. Otherwise:










C
i

(
n
)


=

C





C
~

i

(
n
)


-


C
~

min





C
~

max

-


C
~

min








(
9
)







where {tilde over (C)}max=maxi=1, 2, . . . , N{{tilde over (C)}i(n)} and {tilde over (C)}min=mini=1, 2, . . . , N{{tilde over (C)}i(n)}.


Therefore, the credits in each step are scaled to values within [0,C] range. After the completion of each task, the updated credits are broadcasted by the coalition leader (e.g., UAV 701) to be used for future coalition formations. For the sake of simplicity, the superscripts (n) are dropped hereafter.


In the coalition formation method provided by the embodiments herein, first the leaders (e.g., UAV 701) select their coalition members (e.g., UAVs 70a) among the available candidates (e.g., UAV 701 . . . 70x) to maximize their corresponding coalition's utility function to enhance the efficiency in completing their encountered task noting the resource constraints. The coalition value for the kth leader is defined in such a way to: i) assure the existence of required resources 20 to handle a task, ii) avoid over-spending the resources 50 on a specific task, iii) guarantee the timely completion of the task, iv) provide the required quality of communication to relay target's message, and also v) select the reliable UAVs as follows:










v
|

(

S
k

)


=



α
1






i
=
1


N
S








C
i



+


α
2




γ

(

-
L

)




(


SNR
Thr


SNR

S
k



)



+


α
3






j
=
1


N
r







γ


-

L


(


R
k
j


τ
k
j


)


-


γ
L



(


max

i
|


U
i




S
k



{

δ

i
,
k


}







f
δ



(
ρ
)



)







(
10
)







for a large enough positive value of L. Here, the design parameters α1, α2, and α3>0 represent the importance of the credit and quality of communication compared to the resource optimization goal for the leader UAV 701. Also, SNRThr represents the minimum required SNRSk to successfully relay the target's message to the base station 60. The maximum function in the last term of Equation (10) is used to ensure that even the UAV with the latest time of arrival will be at task position in time. The kth leader is a member of the coalition Sk.


In order to find the optimal coalition which maximizes the leader's utility function in Equation (10), a search over all 2Lk possible coalitions is utilized, where Lk denotes the number of potential follower UAVs who responded to the proposal of leader k. To avoid such extensive search, a low complexity merge-and-split technique is provided. In this method, each leader k separately starts from an initial state where the set of UAVs who responded to its proposal is partitioned into Lk singleton coalitions. Afterward, in each step, two chosen coalitions Ski and Skj are merged if v(Ski∪Skj)>v(Ski)+v(Skj). Here, since the value of the coalitions 70a which does not include the leader (e.g., UAV 701) is zero, the only possible merge happens if a singleton coalition {u} and the coalition Sk which contains the kth leader satisfy the condition v(Sk∪{u})>v(Sk). Also, if for a non-singleton coalition S there exists a partition of two coalitions Ski and Skj such that v(S=Ski∪Skj)<v(Ski)+v(Skj), then S splits into Ski and Skj, whereby each leader considers itself as a constant member of all coalitions under evaluation. At each step of the merge-and-split process, the optimum value of the SNRB in the utility function of Equation (10) for the coalitions may be calculated, as further described below. The merge-and-split process is used to obtain a suboptimal coalition solution of Equation (10) with lower complexity. When the changes in coalition values over consequent rounds become below a threshold, the coalition with highest coalition value would be selected from the leader's perspective and the members (e.g., UAVs 701 . . . 70x) are notified.


The coalition formation process may comprise:















 1:
Initializing coalitions   custom-character  Each leader k starts



from a partition of the singleton coalitions of UAVs who responded to its proposal


 2:
Merge-and-split coalition formation algorithm by the leader   custom-character  for all available



UAVs for this task


 3:
while Change in coalition values is greater than ∈ do


 4:
 while Si and Sj exist with υ(Si ∪ Sj) > υ(Si) + υ(Sj) do


 5:
  Merge Si and Sj.


 6:
 end while


 7:
 while Si and Sj exist such that: υ(S = Si ∪ Sj) < υ(Si) + υ(Sj) do


 8:
  Split S into partitions Si and Sj.


 9:
 end while


10:
 if  There is a split then


11:
  go to 4.


12:
 end if


13:
end while


14:
Select the coalition with highest coalition value, notify the UAVs of this selected



coalition


15:
if All selected potential followers said Yes then


16:
 Terminate


17:
else


18:
 Exclude the ones with No response, go to 3


19:
end if


20:
Selecting the best formation request from different leaders by each selected



follower


21:
if Received only one formation request then


22:
 Say Yes to that leader


23:
else


24:
 Say Yes to the leader of coalition that maximizes Equation (11),



say No to other leaders


25:
end if









When the optimal coalitions from the leaders' perspective are formed, the formation requests will be sent out to the selected UAVs. If a potential follower receives multiple requests from different leaders, it prefers to join the coalition which benefits it the most. The utility function of the followers is defined as:






v
p(U|i,Sk)=ΔCi−α4δi,k,  (11)


where ΔCi and δi,k are the expected credit (knowing the required resources for the encountered task) and traveling time to task k if user Ui joins the coalition Sk, respectively. Here, α4 is a design parameter that indicates the importance of the traveling cost compared to the change in credit.


The coalition formation process includes a series of merge-and-split coalition formation steps. After each stage of merge-and-split coalition formation, the leader (e.g., UAV 701) sends out the requests 55 and collects the followers' responses. If all responses are affirmative, the coalition formation process stops; otherwise, a new merge-and-split is executed that keeps the current members with positive responses, and evaluates the new available UAVs.


As such, in order to show the stability of the process, it is sufficient to show that: i) the number of sequential rounds of the process is finite, and ii) each merge-and-split stage is stable. The first is ensured, because at each round, the members with no interest in joining the formed coalition 70a are excluded, and therefore after at most ms iterations the process stops, where ms is the number of UAVs with a negative response to join a coalition 70a. The second condition is also satisfied since the formed coalitions by the leaders (e.g., UAV 701) are Dhp-stable. This is due to the fact that the only type of allowed membership changes are based on single or possibly multiple merge-and-splits (i.e., a UAV or a group of them are only allowed to leave a partition by means of merges or splitting).


The optimization from the leaders' perspective is to maximize the coalition value in Equation (10) by searching over the coalitions (i.e., S) and determine the optimum beamforming scheme; i.e., w to optimize SNRB. For each coalition, the optimal value of Equation (5), SNRSopt can be obtained via the following inner optimization problem:












max

w
_










w
_

H




kk
_

H



w
_






w
_

H




H
_

UB
H




H
_

UB



w
_


+

σ
2







[


w
_

H

]

i





(









[




-
1

/
2


]


i
,
i






[


h
_

TU

]

i



[


h
_

TU
H

]


i



[




-
1

/
2


]



i
,
i


+
1

)



[

w
_

]


i





P
i
max


,





i
=
0

,
1
,





,

N
c





(
12
)







A bisection method may be used to solve the fractional Quadratically Constrained Quadratic Program (QCQP)s such as the optimization problem in Equation (12) that can be rewritten as:













max


w
_

,
t










t




[


w
_

H

]

i





(









[




-
1

/
2


]


i
,
i






[


h
_

TU

]

i



[


h
_

TU
H

]


i



[




-
1

/
2


]



i
,
i


+
1

)



[

w
_

]


i





P
i
max


,





i
=
0

,
1
,





,

N
c












w
_

H




kk
_

H



w
_





t







w
_

H




H
_

UB
H




H
_

UB



w
_


+

t






σ
2




,





(
13
)







where t is an auxiliary variable. In the bisection method, given the value of t≥0, the following feasibility check problem is investigated:





Find w[wH]i([Σ−1/2]i,i[hTU]i[hTUH]i−1/2]i,i+1)[w]i≤Pimax,i=0,1, . . . ,NcwHkkHw≥twHHUBHHUBw+tσ2.  (14)


If the problem described in Equation (14) is feasible, then the optimal solution of the problem in Equation (13); i.e., SNRSopt, is less than or equal to t; otherwise SNRSopt≥t. The variable t is up limited by tup which is obtained in the following Lemma:


Lemma: tup=kHQ−1k is an up limit for objective in optimization problem Equation (12). The optimization problem becomes feasible if and only if the matrix kkH−tHUBHHUB is non-negative definite. Since the matrix Q=HUBHHUB is positive semi-definite, the matrix Q−1/2(kkH−tHUBHHUB)Q−1/2=Q−1/2kkHQ−1/2−tI must be non-negative definite. That results in t≤λmax(Q−1/2kkHQ−1/2)=kHQ−1k.


Using the above Lemma and by assuming δ as the absolute precision of the final objective function value, the iteration's complexity order of the bisection method can be written as







O


(

log


(


t
up

σ

)


)


.




The feasibility problem of Equation (14) can be solved using the Semi-Definite Programming (SDP) relaxation method. One point to notice is whether wopt is an optimal solution to the feasibility problem of Equation (14), then for any arbitrary real number θ, {tilde over (w)}=woptej<θ is also an optimal solution. Therefore, it is possible to assume that wHHUBΣ−1/2hTU is a non-negative real number. By considering this constraint, the feasibility problem of Equation (14) can be rewritten as the following SOCP problem for a given t≥0:





Find w[wH]i([Σ−1/2]i,i[hTU]i[hTUH]i−1/2]i,i+1)[w]i≤Pimax,i=0,1, . . . ,NcwHk≥√{square root over (twHHUBHHUBw+tσ2)}custom-character{wHHUBHΣ−1/2hTU}≥0I{wHHUBHΣ−1/2|hTU}=0.  (15)


The feasibility check problem in Equation (15) can be effectively solved using the cvx convex optimization toolbox. By considering the cubic complexity order of the SOCP method, the complexity order of the communication optimization can be expressed as







(




S


3



log


(


t
up

δ

)



)

.





FIGS. 8A through 8E, with reference to FIGS. 1 through 7B, illustrates an example system 100 to identify, by a first UAV 701, a combination of UAVs 701 . . . 70x to execute a mission 25. Processor 45 may include a central processing unit, microprocessors, microcontroller, hardware engines, and/or other hardware devices suitable for retrieval and execution of computer-executable instructions 115, 120, 125, 130, 135, 140, 145, 150, 155, 160, 165, 170, 175, and 180 stored in a machine-readable storage medium 110.


Processor 45 may fetch, decode, and execute computer-executable instructions 115, 120, 125, 130, 135, 140, 145, 150, 155, 160, 165, 170, 175, and 180 to enable execution of locally-hosted applications for controlling action of the first UAV 701. As an alternative or in addition to retrieving and executing instructions, processor 45 may include one or more electronic circuits including a number of electronic components for performing the functionality of one or more of the instructions 115, 120, 125, 130, 135, 140, 145, 150, 155, 160, 165, 170, 175, and 180.


The machine-readable storage medium 110 may be any electronic, magnetic, optical, or other physical storage device that stores computer-executable instructions 115, 120, 125, 130, 135, 140, 145, 150, 155, 160, 165, 170, 175, and 180. Thus, the machine-readable storage medium 110 may be, for example, Random Access Memory, an Electrically-Erasable Programmable Read-Only Memory, volatile memory, non-volatile memory, flash memory, a storage drive (e.g., a hard drive), a solid-state drive, optical drive, any type of storage disc (e.g., a compact disc, a DVD, etc.), and the like, or a combination thereof. In one example, the machine-readable storage medium 110 may include a non-transitory computer-readable storage medium.


In an example, the processor 45 of the first UAV 701 executes the computer-executable instructions 115, 120, 125, 130, 135, 140, 145, 150, 155, 160, 165, 170, 175, and 180. In FIG. 8A, the determining instructions 115 may determine resources 20 used to execute a mission 25. These resources 20 may be the minimal amount or type of resources necessary to execute the mission 25. Moreover, the mission 25 may be a predefined mission or may be a dynamic mission that changes in real-time. The generating instructions 120 may generate a set of available resources 50 capable of executing the mission 25 from a group of UAVs 701 . . . 70x in communication with the first UAV 701. The communication from amongst the group of UAVs 701 . . . 70x may occur using any type of communication system and through any type of communication network. In an example, the communication between the group of UAVs 701 . . . 70x may occur directly and without any intermediary or centralized base station 60. The set of available resources 50 capable of executing the mission 25 may include any combination of resources available from the UAVs 701 . . . 70x including the first UAV 701. The comparing instructions 125 may compare the resources 20 used for executing the mission 25 with the set of available resources 50. The comparison of the resources 20 that are necessary to execute the mission 25 and the set of available resources 50 may occur in real-time, according to an example, as any of the resources 20 and the set of available resources 50 changes due to updates or changes to the requirements for performing the mission 25, and the status or availability of the available resources 50 due to the exhaustion of the available resources 50 overtime. The identifying instructions 130 may identify a combination of the UAVs 70a to assist in executing the mission 25 based on the comparison of the resources 20 used for executing the mission 25 and the set of available resources 50. The combination of the UAVs 70a may include any suitable combination of the UAVs 701 . . . 70x including the first UAV 701.


In FIG. 8B, the identifying instructions 135 may identify the group of UAVs 701 . . . 70x, which are available in the coalition and which are in communication with at least the first UAV 701. The group of UAVs 701 . . . 70x may be geographically dispersed in any location(s), and the identifying instructions 135 utilize the inter-communication between the group of UAVs 701 . . . 70x to identify the coalition of UAVs 701 . . . 70x that may potentially assist in executing the mission 25. Transmitting instructions 140 may transmit a request (e.g., message 55) to the group of UAVs 701 . . . 70x to send to the first UAV 701 the available resources 50 for each of the UAVs 701 . . . 70x in order to generate the set of available resources 50 capable of executing the mission 25. The first UAV 701 determines what the available resources 50 are of the group of UAVs 701 . . . 70x to consider whether the mission 25 can be executed based on the resources 20 that are necessary to execute the mission 25. Generating instructions 145 may generate the set of available resources 50 capable of executing the mission 25 based on an assessment of which combination of the available resources 50 from the group of UAVs 701 . . . 70x best maximizes an efficiency in executing the mission 25. According to an example, the first UAV 701 may consider many factors in assembling a team from amongst the group of UAVs 701 . . . 70x to execute the mission 25, and one such factor may be to consider how efficiently the mission 25 may be executed if performed by a particular combination of available resources 50 from a particular combination of the group of UAVs 701 . . . 70x.


As shown in FIG. 8C, the filtering instructions 150 may filter out any UAVs 71 from the group of UAVs 701 . . . 70x based on a past performance of executing other missions 25a. In this regard, filtering out may refer to removing the UAVs 71 from consideration for executing the mission 25. One factor in considering which of the UAVs 71, if any, to remove from consideration (i.e., filtering out) is the performance of UAVs 701 . . . 70x in executing other missions 25a. Accordingly, if the UAVs 71 did not perform to a predetermined standard on another mission 25a or did not execute the mission 25a, then the filtering instructions 150 considers this in its analysis. Filtering instructions 155 may filter out any UAVs 71 from the group of UAVs 701 . . . 70x based on a real-time assessment of a performance of any of the UAVs' 71 utilization of its available resources 51 in executing the mission 25. In this regard, the UAVs 71 may be removed from consideration for executing the mission 25 if the real-time performance of the UAVs 71 in executing the mission 25 is below a predefined standard. In this regard, even if the UAVs 71 were initially selected to execute the mission 25, the real-time performance assessment may result in removal of the UAVs 71 from continuing in performing the mission 25. For example, while on route to performing the mission 25, the UAVs 71 may experience a technical failure in payload delivery or guidance system malfunction, or any other deterioration or impedance of utilizing its available resources 51, and thus the filtering instructions 155 may determine that these UAVs 71 are no longer practical for executing the mission 25, and thus are removed from consideration (i.e., filtered out) for continuing with the mission 25. Filtering instructions 160 may filter out any UAVs 71 from the group of UAVs 701 . . . 70x that decline to offer its available resources 51 in executing the mission 25. Each of the UAVs 701 . . . 70x may be autonomous (i.e., not controlled by any other system or device), and therefore any of the UAVs 701 . . . 70x may determine that it will not execute the mission 25 or provide its available resources 51, and thus such UAVs 71 are removed from consideration (i.e., filtered out) for performing the mission 25.


In FIG. 8D, the selecting instructions 165 may select the combination of the UAVs 70a to assist in executing the mission 25. Once the available resources 50 are compared with the necessary resources 20 to complete the mission 25, the combination of UAVs 70a that are capable of completing the mission 25 is selected. In an example, the first UAV 701 performs the selection process. The transmitting instructions 170 may transmit a coalition message 55 to the selected UAVs 70a to execute the mission 25. In an example, the first UAV 701 transmits the message 55 to the selected UAVs 70a either separate to each of the UAVs 70a or collectively to the group of UAVs 701 . . . 70x.


As indicated in FIG. 8E, the generating instructions 175 may generate the set of available resources 50 capable of executing the mission 25 based on assigning a predetermined value to each of the available resources 50 provided by each of the UAVs 701 . . . 70x. In this regard, the predetermined value may be any of a qualitative and quantitative value of importance, necessity, or efficiency with regard to the available resources 50 capable of executing the mission 25. This predetermined value is used to select the UAVs 70a to execute the mission 25 by determining which of the group of UAVs 701 . . . 70x has the requisite combination of available resources 50 to execute the mission 25. The determining instructions 180 may determine which combination of UAVs 70a corresponds to the predetermined value of the available resources 50 to complete the mission 25 without overspending the available resources 50. This allows for the efficient utilizing of the available resources 50 from amongst the group of UAVs 701 . . . 70x. Accordingly, the overspending of the available resources 50 may involve duplicating or overusing the available resources 50 for executing the mission 25. In an example, the predetermined value may be the highest value or the optimum value attributed to the available resources 50 by the processor 45. In other examples, the predetermined value may be the lowest value or may be set to any suitable threshold or scale.



FIGS. 9A through 9D, with reference to FIGS. 1 through 8E, are flow diagrams illustrating a method 200 of autonomously assessing a cooperative performance of a task (i.e., mission 25). The problem of cooperative task completion in a network 75 of heterogeneous UAVs 701 . . . 70x with constrained individual resources in considered for implementing the method 200, according to an example. It may be assumed that a number of targets 80 are distributed in an unknown environment, where no prior information about the targets' time of appearance and location is available. It may also be assumed that there is one compound task (i.e., mission 25) associated with each target 80. The tasks (i.e., missions 25) can differ intrinsically based on the characteristics of their encountered targets 80 in terms of mobility, speed, position, and the required resources 20. For example, prosecution of a fighter tank or a long-range missile in a battlefield require different sets of equipment and resources 20. The objectives of the method 200 include: i) locating the distributed targets 80, ii) identifying their associated tasks (i.e., missions 25) and required resources 20, and iii) completing the identified tasks (i.e., missions 25). In order to accomplish these objectives, the method 200 forms one or more coalitions of UAVs 70a using the above-described coalition formation method, in which each coalition will complete a task (i.e., mission 25) associated to one target 80. The coalition formation technique provided by the embodiments herein with a leader-follower structure is configured to ensure providing adequate resources 50 to complete each encountered task (i.e., mission 25) while not exceeding, or at the very least, minimally exceeding the minimum required resources 20. The dynamic coalition formation technique implemented by method 200 enables the UAVs 701 . . . 70x to overcome the limitations of their individual capabilities such as limited payload and computation, and communication resources. The formation of a coalition(s) of UAVs 70a can also extend the coverage area in target tracking and surveillance applications compared to utilizing individual UAVs only. The traveling distances of the UAVs 701 . . . 70x to the tasks (i.e., missions 25) are also taken into account in forming optimal coalitions of UAVs 70a to complete the tasks (i.e., missions 25) in a timely manner. Furthermore, in order to get more detailed information about the identified targets 80 (e.g., an adversary object in a battlefield, etc.), each coalition of UAVs 70a may forward the broadcast messages by their encountered target 80 to a base station 60 using a beamforming technique.


The method 200 in FIG. 9A comprises operating (205) a first UAV 701 to search for a target 80. The searching may occur by the first UAV 701 moving towards the target 80 or by the first UAV 701 using signal detection to locate the target 80 while the first UAV 701 is in a hovering state of operation. Upon locating the target, the method 200 comprises assessing (210) a requirement for the first UAV 701 to perform the task (i.e., mission 25) relating to the target 80. In this regard, the task (i.e., mission 25) may require some action related to the target 80. Next, the method 200 comprises transmitting (215) a first electronic message 851 to other UAVs 702 . . . 70x capable of assisting the first UAV 701 in performing the task (i.e., mission 25). The first electronic message 851 may be transmitted directly from the first UAV 701 to the other UAVs 702 . . . 70x or through a base station 60. Furthermore, the first electronic message 851 may comprise any of wired or wireless communications, and the first electronic message 851 may be encrypted. Thereafter, the method 200 may comprise receiving (220) at least one second electronic message 852 from the other UAVs 702 . . . 70x identifying available resources 50 from each of the other UAVs 702 . . . 70x to perform the task (i.e., mission 25). The second electronic message 852 may be transmitted directly to the first UAV 701 from the other UAVs 702 . . . 70x or through a base station 60. Furthermore, the second electronic message 852 may comprise any of wired or wireless communications, and the second electronic message 852 may be encrypted. Upon completion of this, the method 200 comprises determining (225) which combination of the other UAVs 702 . . . 70x is best capable of assisting the first UAV 701 in performing the task (i.e., mission 25) based on a predefined criterion. In an example, the first UAV 701 may not join in performing the task (i.e., mission 25). According to some examples, the predefined criterion may be changed based on the dynamic nature of the required task (i.e., whether the mission 25 changes after determining (225) which combination of the other UAVs 702 . . . 70x is best capable of assisting the first UAV 701 in performing the task, etc.). Other predefined criterion are described further below with reference to FIG. 9D.


As shown in FIG. 9B, the method 200 may further comprise selecting (230) the combination of the other UAVs 702 . . . 70x that is best capable of assisting the first UAV 701 in performing the task (i.e., mission 25). Accordingly, the coalition formation involves selecting the other UAVs 702 . . . 70x to establish the coalition of UAVs 70a. The method 200 further comprises transmitting (235) a third electronic message 853 to the other UAVs 702 . . . 70x requesting the selected combination of the other UAVs 702 . . . 70x to assist the first UAV 701 in performing the task (i.e., mission 25). Due to the autonomous configuration of each of the UAVs 701 . . . 70x, the first UAV 701 transmits the third electronic message 853 to the other UAVs 702 . . . 70x requesting their assistance in performing the task (i.e., mission 25). The third electronic message 853 may be transmitted directly from the first UAV 701 to the other UAVs 702 . . . 70x or through a base station 60. Furthermore, the third electronic message 853 may comprise any of wired or wireless communications, and the third electronic message 853 may be encrypted.


As shown in FIG. 9C, the method 200 may further comprise performing (240) the task (i.e., mission 25) using the first UAV 701 with the selected combination of the other UAVs 702 . . . 70x. In another example, the coalition or combination of UAVs 70a performing the task (i.e., mission 25) may or may not include the first UAV 701. As shown in FIG. 9D, the method 200 may further comprise selecting (245) the combination of the other UAVs 702 . . . 70x based on any of a time T required to perform the task (i.e., mission 25), resource allocation capable of being provided by the other UAVs 702 . . . 70x, a trust factor associated with the other UAVs 702 . . . 70x, and a likelihood of performance of the task (i.e., mission 25) based on the available resources 50 from each of the other UAVs 702 . . . 70x.


In this regard, the first UAV 701 may consider several of these predefined criterion, among others, to create the coalition or combination of UAVs 70a to perform the task (i.e., mission 25). The time T may be set based on a desired time established by the first UAV 701, base station 60, or system programmer associated with the system 10. The resource allocation may include the available resources 502 . . . 50x associated with the other UAVs 702 . . . 70x as well as the available resources 501 of the first UAV 701 and what the optimum resource allocation is amongst the available resources 501 . . . 50x to satisfy the required or necessary resources 20 without overspending (i.e., overusing, duplication, or otherwise wasting) the available resources 501 . . . 50x or with only a minimal amount of overspending of the available resources 501 . . . 50x. The trust factor may involve the reputation of the other UAVs 702 . . . 70x, which may be based on their respective performance(s) on prior missions 25a, and the extent that the first UAV 701 can trust that the other UAVs 702 . . . 70x will be able to perform the current task (i.e., mission 25). The likelihood of performance of the task (i.e., mission) may involve the first UAV 701 determining that the task (i.e., mission 25) will likely be successfully accomplished based on the available resources 501 . . . 50x and a comparison to the required or necessary resources 20 for performing the task (i.e., mission 25).


Furthermore, each of the other UAVs 702 . . . 70x may comprise a different available resource 502 . . . 50x compared to one another to assist the first UAV 701 in performing the task (i.e., mission 25). Alternatively, the other UAVs 702 . . . 70x may comprise the same or an overlapping set of available resource 502 . . . 50x compared to one another to assist the first UAV 701 in performing the task (i.e., mission 25). Moreover, the first UAV 701 may comprise available resources 501 that are the same, different, or overlapping to the available resources 502 . . . 50x associated with any of the other UAVs 702 . . . 70x.


In order to validate the performance of the method 200, a simulated experiment of two leader (i.e., two UAVs 701) and six follower (i.e., six other UAVs 702 . . . 70x) is considered. The UAVs 701 . . . 70x are uniformly located in a custom-character3 region. It is assumed that the leaders (UAVs 701) do not carry out the required resources 20 to perform the identified tasks (i.e., missions 25) individually and they call out to form coalitions of UAVs 70a. Five types of resources are considered and the amount of each resource at each UAV 701 . . . 70x as well as the required resources 20 for each task (i.e., mission 25) are generated randomly. The traveling time is generated proportional to the distance of the UAVs 701 . . . 70x to the corresponding target 80. All communication channels are generated by zero mean Gaussian variables with variance proportional to the inverse distance between the corresponding transmitter and receiver antennas.



FIG. 10, with reference to FIGS. 1 through 9D, demonstrates the positions of UAVs 701 . . . 70x in the network 75 and the formed coalitions of UAVs 70a in a numerical experiment. For this example, the stable formed coalitions are as S1={U1, U3, U5, U6} and S2={U2, U4, U7, U8}, where coalitions S1 and S2 complete the tasks 1 and 2, respectively. In FIG. 10, the UAVs are shown by a notation of Si{Uj} that refers to the UAV number j is in coalition Si. The method 200 is considered for different scenarios, where the stable coalitions are formed after a few rounds. The available resources in coalition S1 provided by each UAV as well as the required resources to complete T1 are listed in FIG. 10.


Table 1 shows the comparison of available resources in coalition S1 versus the required resources to complete the task encountered by this coalition. As shown in Table 1, the summation of available resources in coalition S1 are higher than the required resources for task 1 which guarantees that this task can be completed by the members of coalition S1. Moreover, to evaluate the efficiency of the coalition formation method provided by the embodiments herein in a resource constraint network, an Efficiency Factor is defined as E.F.=Σj=1Nri∈S1rij1j}/Nr. This factor evaluates the performance of the formed coalitions in terms of resource allocation efficiency, where the closer value of E.F. to 1 means the more efficient the method is in terms of not overspending the resources for a particular task. In an example, the average E.F. value is 1.11, which is fairly close to 1.









TABLE 1







Comparison of the Available Resources and the Required


Resources in Coalition S1










Available resources in S1iS1rij
Required resources for T11j)








i


S
1












r
i
j




τ
1
j












i


S
1










r
i
j


τ
1
j











resource 1: 2.37
2.37

1.00


resource 2: 2.87
2.78

1.03


resource 3: 2.90
2.51

1.16


resource 4: 1.36
1.33

1.02


resource 5: 1.53
1.15

1.33







E.F. = Σj=1Nr {Σi∈S1rij/τ1j}/Nr = 1.11









In FIG. 11, with reference to FIGS. 1 through 10, the efficiency factor of the method 200 after forming stable coalitions is compared to the scenario in which the closest UAVs are assigned to the targets without considering the resources offered by these UAVs. As shown in FIG. 11, method 200 outperforms the case of distance-based UAVs selection for different system settings over the course of time.



FIG. 12, with reference to FIGS. 1 through 11, evaluates the performance of the coalition formation method 200 in identifying the potential selfish UAVs by showing the change in cooperative credit of six follower-UAVs over time. The credits are normalized to be in the range of [0, 1]. In this scenario, it is assumed that UAVs, U5 and U6 are selfish in the sense that they do not consume the resources they initially committed after joining a coalition. As seen in FIG. 12, the credits of these selfish UAVs, C5 and C6 significantly decrease over time, meaning that these selfish users will not be selected by the leaders in the next rounds of coalition formation. Moreover, other factors including changes in the UAVs' location and the dynamic nature of the task requirements can also play a role in small variations in agents' credits that may result in credit reduction for trustable agents. The slight reduction of credits of U3 and U4 is an example of this.


The leader-follower coalition formation method 200 may be utilized for distributed task allocation and optimizing the cooperative communication between the detected targets 80 and the base station 60 in a heterogeneous network 75 of UAVs 701 . . . 70x. A reputation-based approach is provided to monitor the cooperative behavior of UAVs 701 . . . 70x and filter out the selfish UAVs 71 who have not accumulated sufficient collaboration credits. The systems 10, 100 and method 200 enable optimizing several factors including the timely completion of the tasks and preserving the available resources 50 in the network 75 from the perspective(s) of the leader(s) (i.e., device 401 and/or UAV 701), while it benefits follower devices 402 . . . 40x and/or UAVs 702 . . . 70x by lowering their travel times to join the coalitions or combinations of devices 40a or UAVs 70a. The simulation results show the convergence of the method 200 in forming stable coalitions of devices 40a or UAVs 70a with high resource efficiency factors to complete the encountered tasks (i.e. missions 25).


The foregoing description of the specific embodiments will so fully reveal the general nature of the embodiments herein that others can, by applying current knowledge, readily modify and/or adapt for various applications such specific embodiments without departing from the generic concept, and, therefore, such adaptations and modifications should and are intended to be comprehended within the meaning and range of equivalents of the disclosed embodiments. It is to be understood that the phraseology or terminology employed herein is for the purpose of description and not of limitation. Those skilled in the art will recognize that the embodiments herein can be practiced with modification within the spirit and scope of the appended claims.

Claims
  • 1. An integrated decision making and communication system comprising: a memory to store a list of resources necessary to execute a mission;a transceiver to send and receive data between communicatively linked devices; anda processor to: identify a set of available resources capable of executing the mission based on the data received from the devices;compare the list of resources necessary to execute the mission from the memory with the set of available resources; andidentify a combination of the devices to execute the mission based on the comparison of the list of resources necessary to execute the mission and the set of available resources.
  • 2. The system of claim 1, wherein the processor instructs the transceiver to send messages to the identified combination of the devices to execute the mission.
  • 3. The system of claim 1, further comprising: a first device containing the memory, the transceiver, and the processor to autonomously store, transceive, and process the data without control by a centralized base station; anda plurality of other functionally similar devices communicatively linked to the first device.
  • 4. The system of claim 3, wherein the processor of the first device groups the plurality of other functionally similar devices based on possible combinations of devices comprising resources capable of executing the mission.
  • 5. The system of claim 4, wherein the processor of the first device selects the group of the plurality of other functionally similar devices comprising a most efficient utilization of the available resources to execute the mission in a predetermined period of time.
  • 6. The system of claim 3, wherein the transceiver of the first device: transmits a proposal to the plurality of other functionally similar devices to request the plurality of other functionally similar devices to combine their available resources to execute the mission; andreceives responses from the plurality of other functionally similar devices of whether to they agree to utilize their available resources to execute the mission.
  • 7. The system of claim 1, wherein the devices comprise unmanned aerial vehicles (UAVs).
  • 8. A machine-readable storage medium comprising computer-executable instructions that when executed cause a processor of a first unmanned aerial vehicle (UAV) to: determine resources used to execute a mission;generate a set of available resources capable of executing the mission from a group of UAVs in communication with the first UAV;compare the resources used for executing the mission with the set of available resources; andidentify a combination of the UAVs to assist in executing the mission based on the comparison of the resources used for executing the mission and the set of available resources.
  • 9. The machine-readable storage medium of claim 8, wherein the instructions, when executed, further cause the processor to: identify the group of UAVs; andtransmit a request to the group of UAVs to send to the first UAV the available resources for each of the UAVs in order to generate the set of available resources capable of executing the mission.
  • 10. The machine-readable storage medium of claim 8, wherein the instructions, when executed, further cause the processor to generate the set of available resources capable of executing the mission based on an assessment of which combination of the available resources from the group of UAVs best maximizes an efficiency in executing the mission.
  • 11. The machine-readable storage medium of claim 8, wherein the instructions, when executed, further cause the processor to filter out any UAVs from the group of UAVs based on a past performance of executing other missions.
  • 12. The machine-readable storage medium of claim 8, wherein the instructions, when executed, further cause the processor to filter out any UAVs from the group of UAVs based on a real-time assessment of a performance of any of the UAVs utilization of its available resources in executing the mission.
  • 13. The machine-readable storage medium of claim 8, wherein the instructions, when executed, further cause the processor to filter out any UAVs from the group of UAVs that decline to offer available resources in executing the mission.
  • 14. The machine-readable storage medium of claim 8, wherein the instructions, when executed, further cause the processor to: select the combination of the UAVs to assist in executing the mission; andtransmit a coalition message to the selected UAVs to execute the mission.
  • 15. The machine-readable storage medium of claim 8, wherein the instructions, when executed, further cause the processor to: generate the set of available resources capable of executing the mission based on assigning a predetermined value to each of the available resources provided by each of the UAVs; anddetermine which combination of UAVs corresponds to the predetermined value of the available resources to complete the mission without overspending the available resources.
  • 16. A method of autonomously assessing a cooperative performance of a task, the method comprising: operating a first unmanned aerial vehicle (UAV) to search for a target;upon locating the target, assessing a requirement for the first UAV to perform the task relating to the target;transmitting a first electronic message to other UAVs capable of assisting the first UAV in performing the task;receiving at least one second electronic message from the other UAVs identifying available resources from each of the other UAVs to perform the task; anddetermining which combination of the other UAVs is best capable of assisting the first UAV in performing the task based on a predefined criterion.
  • 17. The method of claim 16, further comprising: selecting the combination of the other UAVs that is best capable of assisting the first UAV in performing the task; andtransmitting a third electronic message to the other UAVs requesting the selected combination of the other UAVs to assist the first UAV in performing the task.
  • 18. The method of claim 17, further comprising performing the task using the first UAV with the selected combination of the other UAVs.
  • 19. The method of claim 16, further comprising selecting the combination of the other UAVs based on any of a time required to perform the task, resource allocation capable of being provided by the other UAVs, a trust factor associated with the other UAVs, and a likelihood of performance of the task based on the available resources from each of the other UAVs.
  • 20. The method of claim 16, wherein each of the other UAVs comprise a different available resource to assist the first UAV in performing the task.
CROSS-REFERENCE TO RELATED APPLICATION(S)

This application claims the benefit of U.S. Provisional Patent Application No. 62/642,631 filed on Mar. 14, 2018, which is incorporated herein by reference in its entirety.

GOVERNMENT INTEREST

The invention described herein may be manufactured and used by or for the Government of the United States for all government purposes without the payment of any royalty.

Provisional Applications (1)
Number Date Country
62642631 Mar 2018 US