MULTI-ROBOTS cooperation technique can use the
advantages of group collaboration to deal with the
disadvantages of individual robot and complete the tasks that
individual robot cannot complete. It is an inevitable trend for
robots to imitate human society. It is also an important topic in
the research field of artificial intelligence and robotics
Service-oriented technology concept comes from the application
of Web
To research multi-robot systems,from small groups to large groups,even a robots’s society,the best reference is on the basis of interpersonal behavior and activities of human society. Service is one of the basic behavioral activities of human society. Regardless of the human species,in addition to the diversity of object and form,all human behaviors can be attributed essentially to provide services and consume services. So,it is significant to bring service-oriented architecture (SOA) into multi-robot cooperation.
Compared with the traditional object-oriented robot
architecture
In this paper,combined with the human social service, the service of multi-robot has been elaborated in detail. The service definition,classification,stratification and data model are proposed. The concept of minimum service is defined. The relational operators and logic algorithms for robot services are established. For a practical application purpose,the serviceoriented multi-robot layered architecture has been designed. In this architecture,the interaction process of robot service registry,service pretreatment,and service scheduling method are all designed in detail. Finally,the specific multi-robot service cases are organized to illustrate the superiority of our architecture theory.
Ⅱ. RELATED WORKSMany types of architectures have been constructed to meet
the commands of multi-robotic cooperation. A multi-level
service-oriented robotic swarm framework is designed in
Beside these,there are many other robotics researches
focusing on service-oriented method
From the existing research achievements,a phenomenon is found that SOA concept has been gradually combined with multi-robot cooperation technology. There are several advantages of SOA compared to traditional multi-robot architectures which are described in next section.
Ⅲ. SERVICES IN MULTI-ROBOTS WORLD A. The Technical Advantages of SOASOA is a particular kind of software architectures which is
designed to create a dynamically organized environment of services
that are decomposable and inter-operable
Services of SOA have the following characteristics
1) Services are self-contained and modular;
2) Services support interoperability;
3) Services are loosely coupled;
4) Services are location-transparent;
5) Services are composite modules,comprised of components.
The state-of-the-art SOA infrastructure is illustrated in
Download:
|
|
Fig. 1. The state-of-the-art SOA infrastructure. |
In SOA,individual function in application is modularized and presented as a service to consumers. Researchers can construct an application by combining one or more services without paying attention to their underlying implementation.
Since,SOA has been a new concept to robot and lacking of uniform standard definitions so far. If we like to introduce SOA into robotics,some robot SOA basic concepts should be unified.
B. Service Definition and ClassificationDefinition 1. Service is a kind of behavior or a set of behaviours for robots to get help or other benefits from each other,which can be transferred among robots.
According to the development of current research,the robot service can be divided into four types: information service,behavioral service,functional service,and intermediary service.
Information service refers to that the robots or modules of robots exchange information among themselves. Most robots cooperation includes this service,which involves multi-robots information fusion,cloud computing and other technologies.
Behavioral service refers to interactive spatial behaviors through the mechanism of transmission among robots or robot modules,which exists in cooperative transportation, collaborative formation,and so on.
Functional service is due to integrated service requirements, which need the robot provide some functional modules to participate in the cooperation,every functional module is required to provide its specified service,but do not need the entire robot to work in it. This service is usually in distributed web robotics,smart sensor networks.
Intermediary service is to gather all kinds of service information and transmit them among robots. This service does not have explicit form of service goods,which appears in service registry center in SOA,the central management unit in the central cluster architecture.
In the process of multi-robots cooperation,one or more kinds of above services will be included. There is no strict distinction among them.
Assuming that: the information service is defined as S$_{ a}$,behavior service S$_{ b}$,functional service S$_{ c}$ and intermediary service S$_{ d}$.
Theorem 1. For any form of service set S occurred during multi-robots cooperation,${ S}=\bigcup \nolimits_{i \in a,b,c,d}{ S_i}$. C.Service Layers
As shown in
Download:
|
|
Fig. 2. Hierarchical representation of service. |
The atomic state is the minimal existing form,which cannot be split continually. It retains all feature attributes of the minimal service sub-items. Any form of split will destroy its essential character. The set of atomic services form the bottom service granular layer.
On the basis of atomic state,molecular state gathers some minimal service sub-items to meet the needs of special service properties, which forms the service convergence layer and meets the needs of a simple small-scale collaboration service. Services in molecular state have more flexible aggregation form. The particle activity and diversity are stronger than those services in atomic state.
The entity service is a physical space polymer of molecular services,which must be attached to certain functional entities. The entity service is not only a simple aggregation of molecular services,but also orderly assembled in physical space according to certain regulations. If the regular contact among molecular services in the entity service is constructed,this entity service can meet the needs of simple robots collaboration.
Logic state in service application layer is the highly existent form of service,which has exceeded the constraints of physical space. It considers the overall demands of users,the abstract relationship among entity services and the final existence,so as to accurately undertake most complex collaboration tasks.
As shown in
Download:
|
|
Fig. 3. Active state migration of service. |
A full service mathematical form is defined as follows:
1) ID: service ID (SID);
2) ActiveType: death,dormant,ready,active (SAT);
3) ServiceType: information,behavioral,functional,intermediary (SST);
4) ServiceScale: atomic,molecular,entity,logic (SSS);
5) SubServiceIDSetNumber: the element number of sub-SID set (SISN);
6) SubServiceIDSet: the set of the sub-SID (SIS);
7) PropertySetNumber: the element number of service feature attributes set (SPSN);
8) PropertySet: the service feature attributes set (SPS).
Any services $S$ corresponding to the items of above service mathematical model are abbreviated as: SID,SAT,SST,SSS,SISN, SIS,SPSN and SPS.
In the following,the corresponding service attributes abbreviated
name is formed with the service name plus an attribute name
abbreviation in
Given a service $S$: SID is 0x662f; the active state is ready state, SAT is 0x02; the service is a mobile manipulator removal service, which belongs to behavioral service,SST is 0x02; this is a physical manipulator,so it is a entity service,SSS is 0x03; it consists of five sub-services,SISN is 5; SIS{0x0105,0x0112,0x0211,0x13fe, 0x1380},0x0105 means tactile sensing service,0x0112 means binocular vision service,0x0211 means range finder service,0x13fe means robotic manipulation service and 0x1380 means universal mobile platform service; S has five feature attributes,SPSN is 5, SPS{0x03,0x05,0x20,0x33,0x54},0x03 means tactile,0x05 means vision,0x20 means laser detection,0x33 means two-finger clamp manipulation and 0x54 means small tracked mobile platform. Then the only unique identification is given: 0x662f0202030501050112021113fe1380050305203354.
The bit length of $S$ can be flexibly expanded according to the actual situation,such as collaboration size,number of robots and complexity degree of collaboration.
E.Relational Operators of Service1)The relationship of "Contain"
Definition 2. For any services $A$ and $B$,if AIS is the (true) subset of BIS,APS is the (true) subset of BPS,we call service $B$ (true) contains service $A$,denoted as $B \supseteq A$(contain) and $B\supset A$ (true contain).
Theorem 2. For any services $A$ and $B$,if AIS is the (true) subset of BIS,APS is the (true) subset of BPS.
If AIS is an empty set,APS is not empty,then service $A$ is called atomic state service.
If the APSN of the atomic state service $A$ is equal to 0,APS is an empty set,then $A$ is called pseudo service,denoted by $\Phi _s$.
2) The relationship of "Belong"
Definition 3. For any service $A$ and $B$,if $A$ is an element of BIS,it will be called $A$ "service belongs to" $B$, denoted as $A \in B$.
For any service characteristic property p,if p is an element of BPS,it will be called p "property belongs to" $B$,denoted as $p$ $\tilde{\in}$ $B$.
Theorem 3. For any services $A$ and $B$,if $A \in B$,for any $p$,$ p$ $\tilde{\in}$ $A$,there must be $p$ $\tilde{\in}$ $B$.
This property belonging relationship caused by service belonging relationship is called inheritance relationship. If $A$ $\in$ $B$, $A$ is called parent service,$B$ is called son service,son service inherits all of parent's characteristic properties.
3) The relationship of "Common"
Definition 4. For any services $B$ and $C$,if there is a non-pseudo service $A$,$A \in B$ and $A \in C$,it is called $B$ is "service common" with $C$,denoted as $B \otimes C$.
For any service $B$ and $C$,if there is a characteristic property $p$,$p$ $\tilde{\in}$ $B$ and $ p$ $\tilde{\in}$ $C$,then we may call $B$ is "property common" with $C$,denoted as $B \tilde{\otimes} C$.Theorem 4. For any services $B$ and $C$,if there is a non-pseudo service $A$ which causes $B$ $\otimes$ $C$,there must be a property $p$ which causes $B$ $\tilde{\otimes}$ $C$.
Corollary 1. For any services $B$ and $C$,if $B\subseteq C$ or $B \in C$,then $B \otimes C$ and $B$ $\tilde{\otimes}$ $C$.
4) The relationship of "Exclusion"
Definition 5. For any services $B$,$C$ and non-pseudo service $A$,if $A \in B$ then $A \notin C$; if $A \in C$ then $A \notin B$,we define that $B$ "service excludes" $C$,denoted as $B \propto C$ or $C \propto B$.
For any services $B$,$C$ and property $ p$,if $p$ $\tilde{\in}$ $B$ and $p$ $\tilde{\notin}$ $C$; if $ p$ $\tilde{\in}$ $C$ and $p$ $\tilde{\notin}$ $ B$; we define that $B$ "property excludes" $C$,denoted as $B$ $\tilde{\propto}$ $C$ or $C$ $\tilde{\propto}$ $B$.
Theorem 5. For any services $B$ and $C$,if $B$ $\tilde{\propto}$ $C$,then $B$ $\propto$ $C$.
F.Logical Operators of Service1) "And" operator
Definition 6. The "and" operation of service means that if and only if the sub-service and its characteristic properties both are involved in two computing services,those will be retained in the resulting service. $C=F(A,B)=AB =$ {CID,CAT,CST,CSS, CISN,CIS(AIS $\cap$ BIS),CPSN,CPS(APS $\cap$ BPS)}.
2) "Or" operator
Definition 7. The "or" operation of service means that any sub-service and its properties involved in any one of the two computing services will be retained in the resulting service. $C=F(A,B)=A+B=$ {CID,CAT,CST,CSS,CISN,CIS(AIS $\cup$ BIS), CPSN,CPS(APS $\cup$ BPS)}.
3) "Subtract" operator
Definition 8. The "subtract" operation of service indicates that if and only if the sub-service is existing in minuend service and not in subtrahend service,this sub-service will be retained in the result service. $C=F(A,B)=A-B=$ {CID,CAT,CST, CSS,CISN,CIS(AIS $-$ (AIS $\cap$ BIS),CPSN,CPS (inherit from CIS)}.
4) Arithmetic laws
a) Commutative law
$ \begin{align} &AB = BA,\end{align} $ | (1) |
$ \begin{align} &A+B = B+A. \end{align} $ | (2) |
b) Associative law
$ \begin{align} &(AB)C = A(BC),\end{align} $ | (3) |
$ \begin{align} &(A+B)+C = A+(B+C),\end{align} $ | (4) |
$ \begin{align} &A-B-C = (A-C)-B = A-(B+C),\end{align} $ | (5) |
$ \begin{align} &A+B-C = (A-C)+(B-C).\end{align} $ | (6) |
c) Distributive law
$ \begin{align}&A+BC = (A+B)(A+C),\end{align} $ | (7) |
$ \begin{align}&A(B+C) = AB+AC,\end{align} $ | (8) |
$ \begin{align}&A(B-C)=AB-AC. \end{align} $ | (9) |
On the basis of the research results of the cooperative layered
architecture of individual robot,a layered multi-robots cooperative
architecture is developed with SOA. As shown in
Download:
|
|
Fig. 4. Illustration of layered multi-robots cooperative architecture based on SOA. |
The multi-robot cooperative serving process in SOA is described as follows:
Step 1. Robots broadcast their service information to service registry center (who am I,where I am,what time I can provide what services).
Step 2. The service applicant submits its descriptions of application service characteristics to service translation layer to get standard descriptions.
Step 3. Service translation layer submits the standard descriptions to SOA interface layer,where the descriptions and the other application information will be packaged and submitted to service registry center to apply for the specified services.
Step 4. When service registry center receives the application, it will query the service list and find the most convenient service providers for this application by efficient scheduling algorithm, then,the service providers' information and the service licenses are sent to the service applicant.
Step 5. The service applicant tries to connect with service providers by information received from service registry center. When the attempt is successful,the service applicant will give the service providers its service licenses,and inform that it will enjoy their services in a certain period of time.
Step 6. The service providers accept the licenses,obey the applicant's commands and supply the certain services.
Step 7. At the end of the service,the applicant releases the permission for service providers. The service licenses are automatically invalid. The service applicant and providers broadcast their latest information to the service registry center separately.
B.Protocols of Multi-robot SOA InterfacesSOA needs a set of protocols to support it. In this study,a set of
simple SOA protocols are designed (
1) Service physical minterm
Service is just an abstract concept,its existence form and activity behavior must be attached to a substance entity,it cannot be alive alone separated from objective entity. The basic elements of service behavior include service content,service entity and service received entity. When a service entity supplies its service,it sometimes is able to provide more than one service. Assuming that the service entity can provide a set of services,when one service is supplied,the other service belonging to same service entity may not have an effect,but service entity cannot physically peel off them,therefore,these set of services that rely on the same service entity are called service physical minterm.
The service physical minterm is different from the atomic service,
which may contain any one or more of the four states that are
illustrated in
Download:
|
|
Fig. 5. Schematic diagram of service physical minterm. |
The service physical minterm of robot is used to check the reusability and cost-effectiveness of services. Each service has its own corresponding physical minterm.
2) Service logic minterm
There are various relationships among services,such as causal
relationship,dependencies,inheritance relationship and coupling
relationship. Due to the presence of a variety of relationships,
when using a service,it has to involve other related services.
Download:
|
|
Fig. 6. Schematic diagram of service logic minterm. |
Therefore,when a robot service is applied for,the service
applicant or service registry center must identify all related
services,and through recursive search,find all needed and related
services layer by layer.
Robot service logic minterm is used to ensure the integrity of the service. Each service has its corresponding logic minterm.
B.Service RegistryIn this section,service registration process is specifically
standardized according to the robot service mathematical model. As
shown in
Download:
|
|
Fig. 7. Flowchart of service registry interaction. |
Studies have shown that if the service registry center provides the pretreatment for newly registered service and gives reasonable suggestions and tips,when the service consumers are applying for services,to improve the overall quality and utilization of services and reduce service costs.
The newly registered service pretreatments consist of service fragmentation and reassembly,priority assessment & sorting, minterms marked,features extraction,and multi-index construction. The flexibility of services combination will be improved by a detailed breakdown of the composition of the structure. The accuracy of services selection will be improved by features extraction. The hit rate of searching quality services will be enhanced by multi-index. The ultimate goal of service pretreatments is to accurately and quickly find the most reasonable services combination and achieve the equivalent service effect with the least and most economical resources.
Here a simple method of service pretreatment is briefly described. Assumed that,the service registry center already has a registered service set $S$,there just comes a new registered service $A$,for any service $B$ in set $S$,the following process steps are proposed.
Step 1. FIND all $B$ where $A \in B$or $A \subseteq B$,if the set $B$ is not empty,the items of $A$ will be lumped into the search index of set $B$,and sorted by minterm size. RETURN. Otherwise jump to Step 2.
Step 2. FIND all $B$ where $B \in A$ or $B \subseteq A$,if $B$ is present,$A$ will be split into sub-services by $A-B$ under the constraints of service minterm algorithm rules. If a solution exists,$A-B=A'$,$A'$ is a new service object which will be processed back to Step 1; if no B satisfies the condition, the process will jump to Step 3.
Step 3. DO ${AB=C}$,if C is not a pseudo one,A will be split into sub-services by $A-C=A'$ under the constraints of service minterm algorithm rules. If a solution exists,$A'$ is a new service object which will be processed back to Step 1; if no $C$ satisfies the condition,the process will jump to Step 4.
Step 4. ADD item of service $A$ into the primary index,ADD the characteristic attributes into sub-index. RETURN.
D.Service Schedulingi) Regional entities scheduling
The regional entities scheduling refers to that,in the designated area,mobilizing some service providers (the physical minterms) to participate in a specific mission,providing specified services and completing the assigned tasks. In the process of regional entities scheduling,the service provider usually needs to move a distance to service locations. So the geographical distances are as an important reference factor in service selection and scheduling.
In addition,to provide the same service,the number of service entities should be as little as possible. The following steps describe a simple service entity selection method. Assuming that, the service registry center has received a request for service $A$:
1) The service registry center uses a geographical filter to pick out a service set $S$ whose services are all close to the serving area. These services will take precedence over the other service.
2) In accordance with the logic minterm principles,the service $A$ will be split into $n$ sub-services $\{A_1,A_2,...,A_n\}$,and $S=A_1+A_2+\cdots+A_n$.
3) Search from $S$ to get service physical minterm set $\{S_1$, $S_2,... S_m\}$,any $S_i$ contains the number of elements of $\{A_1$,$A_2,...,A_n\}$ more than $N$.
4) Calculate the percentage of the number of $A_i$ that $S_i$ contains than the total number of SIS of $S$,and select the $S_j$ with the largest percentage.
5) Remove the elements that ${ S_j}$ have from $\{A_1,A_2,...$, $A_n\}$,$S=S-S_j$; if $ S$ is a pseudo service,the process stops, or goes back to 3).
By above five steps,the service registry center can provide the number of service entities as little as possible to cover all asked service items. This method can reduce the service cost and improve utilization of services. There are other better regional entities scheduling optimization methods to create and improve in practical applications.
ii) Cloud service scheduling
Cloud service is different from regional entity service,in which the service consumer does not take care of the service provider's physical location. It can use network communication to achieve transparent service provision. Consumers cannot see the serving process and only the results in cloud service provisions. All intermediate interactive processes are transparent for consumers.
As shown in
Download:
|
|
Fig. 8. Multi-robot cloud service schematic. |
1) In accordance with the logic minterm principles,the service $A$ will be split into $n$ sub-services $\{A_1,A_2,...,A_n\}$,and $S=A_1+A_2+\cdots+A_n$.
2) Find $n$ services $\{S_1,S_2,...,S_n\}$,corresponding to $A_i \in S_i$ or $A_i \subseteq S_i$.
3) Set an intermediary service $B$.
4) $B$is responsible for receiving all users' requests and return the service results to them.
iii) Scheduling algorithm designing
Several rules of the algorithm are formulated: a) Current service consumer robot (SCR) cannot be as a service provider robot (SPR) for other SCRs simultaneously. b) One SPR can be only invoked by one SCR simultaneously. c) SCR can invoke more than one services from one SPR or invoke more than one service from more than one SPRs simultaneously. d) SCR can reject the service allocation scheme of the service registry center (SRC) and also SPR can reject the SCR's service requirements. e) To prevent deadlock and resource monopolies,the same service cannot be consecutively requested two times and the time of the service that the SCR takes up should not exceed Tout. f) Each robot has the right to apply for services and the obligation to provide services.
Download:
|
|
Fig. 9. Illustration of service dispatch algorithm of SRC. |
Step 1. a) Waiting robot RI for a service connection request SI. b) Checking the service request record in free time to find the items with recording time less than $Tr$,and if the related service is free then send the SPR's ID and the license. The item is then deleted. c) Have a search on the recording table and delete all time-out items.
Step 2. Accept the request of SCR and determine the type of the request: a) Request for releasing the service SI: release the SI and record the assessment of QoS,modify the state parameters of RI and RII,back to Step 1. b) Request for services: go to Step 3.
Step 3. Check the existence of SI: a) No: Add the request into record table; tell RI no SI exists,back to Step 1. b) Yes: list all existing SIs; go to Step 4.
Step 4. Check that whether robots RIIs who supply the service SI all are busy? a) Yes: add the request into record table; tell RI SIs are all busy. b) No: list all idle RIIs; go to Step 5.
Step 5. Calculate the service cost,combined with QoS records, find the RII with lower cost and better QoS; Send RII's ID and service license to RI; establish the association between RI and RII; modify the state parameters of them; back to Step 1.
Ⅵ. SERVICE CASE I A.Evaluation of Service CostCurrently,our research focuses on ground mobile robots,especially tracked robots. The service cost can be generated by distance through the serving process.
The odometer distance can be translated into following equation:
$ \begin{align} \begin{cases} u_t = (v_L,v_R)^{\rm T},\\ D_L = v_L{\rm d}t,&v_L \ge 0,\\ D_R = v_R{\rm d}t,&v_R \ge 0. \end{cases} \end{align} $ | (10) |
Here $u_t$ denotes the control vector,$v_L$ and $v_R$ are the velocities of the left and right wheels. After the termination of the iteration algorithm,the total service cost will be achieved according to the number of the iterations.
$ {T_{{\rm{cost}}}} = \sum\limits_{i = 1}^N {\frac{{{v_{i,L}} + {v_{i,R}}}}{2}} \Delta {t_i}. $ | (11) |
As shown in
Download:
|
|
Fig. 10. Illustration of the simulation scenario. |
In MRCO-SLAM,$A$ receives GPS data,gyro data and relative observation LIDAR data from $B$ and image data from $C$. By the fusion of these extra sensors data,$A$can reduce its observation errors and get more accurate posterior estimations of mapping.
In the mission process,$C$ has a sudden mechanical failure and cannot move any more,$C$must exit from the mission. Then $A$ needs another one to replace $C$ for environment image data. $A$ sends its requirement to SRC again; SRC finds robot $E$ meets the requirement. But $E$ is far from $A$ and in front of $A$. Then $E$ is ordered to wait in the designated place until $A$ arrives.
Robot $D$ is a spy robot,who has been familiar to the situation of the 2nd street. When $A$ is coming,$D$ reports what he knows about $A$ to complete the global map. When $A$ arrives at the other end of the street,the mission is accomplished. All localization and mapping data will be processed in detail offline.
C.Results AnalysisVC++ 6.0 is used as the software platform for our simulation. Each robot is represented by one independent process. These processes are running in different computers. The main robot is set to perform the mission of SLAM. The other robots would like to supply their services and follow the hypothesis circumstances illustrated in the mission model to test the flexibility of the architecture. The independent processes communicate with each other by TCP/IP protocol. The main information stream is consisted of LIDAR data, GPS data,gyroscope data and especially image data.
The system delay caused by large amount of data transmission in
general centralized architecture will seriously affect the system
real-time performance. It is shown in our simulation results that
the system timeliness is affected by the QoS of the network and the
capability of the center server. As shown in
Download:
|
|
Fig. 11. Comparison of data stream between SRC and general centralized server. |
The micro-ground-tracked robots are used for the physical test. Each robot is equipped with LIDAR LMS291、gyroscope odometer and differential GPS. For the experimental conditions,the test is divided into three parts: a) $C$ is released from the formation for its mechanical failure. b) $E$ is invoked to wait to serve in the designated area. c) The spy $D$ reports its map of the 2nd street to $A$. The experimental results show that,under the coordination of SRC,the SLAM member robots accomplish their individual task successfully. And the system has greater flexibility and practicality.
Ⅶ. SERVICE CASE II A.Illustration of Mission ModelThis chapter focuses on testing handling functions and operational flow of the service registry center. The simulation test is similar to analog strategic game running in a normal PC. The service operation process is simulated through scheduling algorithm,player roles and tasks setting. Suppose there is a large number of services managed by the service registry center: I-reconnaissance services A-Visible,B-Infrared,II-positioning and navigation services C-GPS/Beidou,D-navigation,E-target ranging,III-combat service F-sniper,G-grenade,H-rocket,I-machine gun,IV-fuel security services J-electric power,K-oil,V-communication support services L-microwave communication,M-satellite communication, VI-ammunition transportation and loading service,VII-combat assessment service,VIII-IFF service.
As shown in
Download:
|
|
Fig. 12. Scenario of multi-robot cooperation. |
First,the commander robot applies for the new service "collaboration attack". The service registry center accepts the request and split the service by logic minimization principles into five logic state child services: reconnaissance,positioning, attack,attack assessment and support. According to the service description for the environment,more explicit sub-services are determined: I-A-visible light reconnaissance service, I-B-infrared imaging reconnaissance,III-H-rocket service, VII-combat assessment services,IV-J-power service and VL-distance wireless communication service. The service registry center attempts to find some service entities that contain all the above listed services and the maximum services utilization entities. All selected service entities must be in their effective combat radius. Assuming that following four robots are determined: Robot $A$ and $B$ with III-H-rocket,Robot $C$ with I-A-visible camera, I-B-infrared camera,II-C-GPS,II-E-distance detection and V-L-long range wireless communication,robot $D$ with attack assessment.
The reconnaissance Robot $C$ first arrived at the designated area
and located the target. Robots $A$ and $B$ reached the designated
areas and announced $C$ their coordinates and headings. Then Robot
$C$ tells $A$,$B$ and $D$ the target coordinate. Robots $A$ and $B$
adjust their shoot states and angles. After receiving the fire order
from
We uses another five self-developed tracked robots to test this case. Thanks to the research results of other projects,each robot is equipped with different equipments.
As shown in
Download:
|
|
Fig. 13. Universal tracked robot. |
Due to the limitations of the number and function of robots,our study has only tested the basic functions of service-oriented multi-robots cooperation. From the process and results,it can be seen that service-oriented multi-robots system has better flexibility and scalability in free combinations.
Ⅷ. CONCLUSIONIn this paper,service of multi-robots cooperation is deeply researched in theory and engineering,to find a robot social service architecture like human society. In this robot society,all of the collaborations are presented and operated through service consumption.
We presented a new multi-robots architecture named robot SOA. This architecture is constructed by the service-based concept of SOA and the loosely coupled center service scheduling strategy. These methods make robot underlying function realization be transparent in cooperation. The impact of robots heterogeneous characteristics is avoided,that will be beneficial to the system construction, expansion,restructuring and maintenance.
In the architecture,all sensor data and communication commands are treated as the basic service units of function realization. The SRC is only responsible for service scheduling,and do not act as a data transit center like it does in the centralized architecture. The process time of SRC then will not affect the cooperative timeliness between two robots,and it can avoid huge amounts of computation and system delay. So it is beneficial to improve the system stability. The dependency between robots and SRC is weakened. When SRC crashes,the system will automatically degenerate into a distributed architecture. When a robot is in trouble,it will be automatically released from serving or consuming and removed from the system until it is repaired. From the above advantages,we may see,this loosely coupled system construction method is ideal for multi-robots systems.
In the service-oriented cooperative architecture,resources can be further deeply split in logic on the basis of service centralized process. The traditional concept that physical entities are treated as smallest unit has been broken out. Any robots cooperation will all be translated into service optimal combination problems.
The development of object-oriented and middleware technique gives birth to the platform. The development of platform provides necessary conditions to the rise of SOA. Currently,robot operating system has been developed,which will provide the best basic condition for SOA. On the general-purpose robot platforms,just like ROS,researchers and developers can create variety of robot applications to form a robot "apple store". All of these applications will eventually form various colorful services. All above will prompt us to go further.
[1] | Fierro R, Das A, Spletzer J, Esposito J, Kumar V, Ostrowski J P, Pappas G, Taylor C J, Hur Y, Alur R, Lee I, Grudic G, Southall B. A framework and architecture for multi-robot coordination. The International Journal of Robotics Research, 2002, 21(10-11):977-995 |
[2] | Tan M, Wang S, Cao Z Q. Multi-robot Systems. Beijing:Tsinghua Press, 2005. 5-10(in Chinese) |
[3] | Starke G, Kunkel T, Hahn D. Flexible collaboration and control of heterogeneous mechatronic devices and systems by means of an eventdriven, SOA-based automation concept. In:Proceedings of the 2013 IEEE International Conference on Industrial Technology. Cape Town, South Africa:IEEE, 2013. 1982-1987 |
[4] | Becker L B, Pereira C E. SIMOO-RT-An object-oriented framework for the development of real-time industrial automation systems. IEEE Transactions on Robotics and Automation, 2002, 18(4):421-430 |
[5] | Zhou G, Zhang Y S, Bastani F, Yen I L. Service-oriented robotic swarm systems:model and structuring algorithms. In:Proceedings of the 2012 IEEE 15th International Symposium on Object/Component/Service-Oriented Real-Time Distributed Computing. Guangdong, China:IEEE, 2012. 95-102 |
[6] | Insaurralde C C. Service-oriented agent architecture for unmanned air vehicles. In:Proceedings of the 33rd IEEE/AIAA Digital Avionics Systems Conference. Colorado Springs, CO:IEEE, 2014. 8B1-1-8B1-14 |
[7] | Christo C, Cardeira C. Service oriented architecture for mobile robot localization. In:Proceedings of the 2007 IEEE Conference on Emerging Technologies and Factory Automation. Patras, Greece:IEEE, 2007. 888-891 |
[8] | Chen Y N, Bai X Y. On robotics applications in service-oriented architecture. In:Proceedings of the 28th International Conference on Distributed Computing SystemsWorkshops. Beijing, China:IEEE, 2008. 551-556 |
[9] | Mohamed N, Al-Jaroodi J. Service-oriented middleware for collaborative UAVs. In:Proceedings of the 14th IEEE International Conference on Information Reuse and Integration. San Francisco, USA:IEEE, 2013. 185-192 |
[10] | Amoretti M, Zanichelli F, Conte G. A service-oriented approach for building autonomic peer-to-peer robot systems. In:Proceedings of the 16th IEEE International Workshops on Enabling Technologies:Infrastructure for Collaborative Enterprises. Evry:IEEE, 2007. 137-142 |
[11] | Morariu C, Morariu O, Borangiu T. Modeling and simulation for serviceoriented agent based manufacturing systems. In:Proceedings of the 2012 IEEE International Conference on Automation Quality and Testing Robotics. Cluj-Napoca, Romania:IEEE, 2012. 44-49 |
[12] | Doriya R, Chakraborty P, Nandi G C. "Robot-cloud":a framework to assist heterogeneous low cost robots. In:Proceedings of the 2012 International Conference on Communication, Information and Computing Technology. Mumbai, India:IEEE, 2012. 1-5 |
[13] | Xie D, Ying S, Zhang T, Jia X Y, Liang Z Q, Yao J F. An approach for describing SOA. In:Proceedings of the 2006 International Conference on Wireless Communications, Networking and Mobile Computing. Wuhan, China:IEEE, 2006. 1-4 |
[14] | Li H Q, Wu Z. Research on distributed architecture based on SOA. In:Proceedings of the 2009 International Conference on Communication Software and Networks. Macau, China:IEEE, 2009. 670-674 |
[15] | Colan M. Service-oriented architecture expands the vision of web services, Part 1. http://www.ibm.com/developerworks/webservices/library/ws-soaintro.html. IBM Corporation, USA, 2004. |