Decentralized Robot-Cloud Architecture for an Autonomous Transportation System in a Smart Factory Jon Martı́n, Stefan May Sebastian Endres Itziar Cabanes Faculty of Electrical Engineering, Faculty of Mechanical Engineering Department of Automatic Control Precision Engineering and and Building Services Engineering and System Engineering in the Information Technology in the in the Technische Hochschule University of the Basque Country Technische Hochschule Nuernberg Nuernberg Georg Simon Ohm, (UPVEHU), Bilbao, Spain Georg Simon Ohm, Germany Germany Bilbao 48013 Nuremberg 90489 Nuremberg 90489 jon.martingarechana@ th-nuernberg.de ABSTRACT The aim of this paper is to present a decentralized control architecture for an autonomous transportation system in the manufacturing facility of the future. Each component in the factory (machine, robot, operator...) is represented as an in- dividual agent on the cloud and makes autonomous decisions based on the information exchanged with other agents. Pro- 1 INTRODUCTION duction machines control their own material replenishment Modern factories are constantly changing and optimizing by contracting the services of Autonomous Transportation to adapt to the rapid fluctuations on the markets: Shorter Vehicles (ATV) over the cloud. Moreover, two control panels product life cycles, mass customization and the rising speed for human synergy on strategical and operational layers for of delivery. In the classical hierarchical and highly structured monitoring and interacting with the system have been pro- industrial environments changes are difficult to implement vided. Based on new trends on the industry 4.0 revolution, and involve time and financial costs. Therefore, new manufac- this paper develops an intelligent communication architecture turing facilities tend to be highly decentralized systems with between machines, robots and humans. This novel architec- self-organized modules that grant flexibility and improve the ture makes the system robust, flexible and scalable. The adaptability to changes. requirements for such an architecture have been first defined New trends such as Industry 4.0, the Internet of Things and then validated via a series of theoretical cases and two ex- (IoT) and Cloud Robotics lead the path to the future smart periments where communication and hardware failures have factories. Every component in the factory –such as production been triggered. machines, robotic components (Autonomous Transportation Vehicles (ATVs), Industrial Robots, etc.) and operators (via CCS CONCEPTS PDAs or smart tablets) – will be represented as individual ˆ Computer systems organization  Distributed ar- software agents in the cloud. All of them are interconnected chitectures; Robotics; Reliability; ˆ Human-centered and have the ability to make their own decisions. In this way, computing  Human computer interaction (HCI); the current hierarchical control structures will be replaced by decentralized mesh-like control architectures. Moreover, the cloud concept offers additional services such as outsourcing KEYWORDS computational power and data storage. The main benefits of Decentralized Architecture, Autonomous transportation Sys- the smart factories are: tem, Industry 4.0, MRTA Robustness: The decentralization of the control system avoids the single point of failure problem. Modularity: The independence between modules increases the flexibility by making it easier to update or replace them (when obsolete or when a failure occurs) without affecting other modules. The factory does not have to stop for hardware or software updates. Scalability: It is easier to adapt the factory by for example increasing the robot units during peak-workloads or as the market grows. © 2017 Copyright held by the author/owners. High information flow [1]: In most cases the material flow SEMANTiCS 2017 workshops proceedings: LIDARI is still controlled by cyclical analog systems such as kanban September 11-14, 2017, Amsterdam, Netherlands cards. Thanks to the digitalization of the system, electronic SEMANTiCS’2017, Amsterdam, J. Martin et al. kanban cards offer real time information. This huge data This paper is structured as follows: Section 2 presents provided by every single component in the factory can then related works on smart factories and autonomous transporta- be used for forecasting, learning and optimizing the system. tion systems. In section 3, the decentralized cloud architecture Connects People to the factory: Through smart devices, is presented. Section 4 introduces the use cases and the ex- for instance mobile phones, tablets or PCs, information in periments done for the requirements validation of such an real time is accessible over the cloud for maintenance and architecture. Finally, the conclusions are summarized and diagnosis operation but also for the clients to inform about the future work is discussed. the current status of their product. 2 RELATED WORK New research on smart factories have been focused on the effort to connect humans, machines and infrastructure over the network for sharing data and processing. Works on mod- ularized systems, the IoT and cloud computing that pushes this new industrial 4.0 revolution are presented here. Further- more, prior work on Multi Robot Task Allocation (MRTA) problem is introduced. The cooperation of single modules within one logistic sys- tem has been summarized in [1] as Cyber Physical Logis- tic Systems (CPLS): a concept defined between embedded systems and the vision of the IoT and the Internet of Ser- vices [2], [3]. During the last years, the modularization on autonomous transport systems has been proven in several research and industrial projects such as flexible conveyor systems [4], [5] or Autonomous Transport Vehicles [6], [7], [2]. Also the RoboCup Industrial @Work league competition [8] pushes the idea of a mobile platform integrated with and in- dustrial arm that autonomously schedules a series of picking up - delivery tasks received from a referee system. The cloud architecture offers several advantages on robotic and automation systems and can be divided into two comple- Figure 1: The factory layout contains the following mentary tiers as in [9]: In the first machine-to-cloud (M2C) components: source and delivery warehouses (bot- communication level, computing and storage resources can be tom left/top right corners); interim storages and moved to servers in the cloud, reducing costs in the robot but charging stations (on the sides); working stations providing them with an almost infinite power. Some examples with production machines (center and right side); are DavinCi [10] or Amazon Web Services [11]. Moreover, ATVs spread all over the factory. the stored information can be shared with other robots for a common learning: Projects such as RoboEarth [12] have demonstrated that the robots can learn new abilities and This paper presents a decentralized control architecture share them with others over the cloud. However, these sys- for a robust transportation task on a Smart Factory. The tems are based on central servers where the information and control is divided into a strategical layer, where global pro- the computing power are available. A failure in the agent- duction goals are defined, and an operational layer, where cloud connection or directly in the server prevents the agent individual intelligent modules (production machines, ATVs, from making decisions and leads to inoperability. To ensure Operators...) make decisions based on the information ex- the necessary robustness in industrial applications, agents changed with each other. The ATVs offer a transportation should be self-sufficient to perform primary tasks on their service over the cloud that is used by the production ma- own and only outsource secondary, less urgent, tasks. chines to replenish their material reserves. At the same time Within the second tier, the machine-to-machine (M2M) the operators can interact over the cloud with both, machines communication level, a group of robots communicate via and robots for a more secure and reliable functionality. wireless links to form a collaborative computing factory. The Figure 1 presents an intermediate layout between the cur- benefits of a cooperative factory are: First, the computing rent and the future factory layout. The material is first trans- capability from individual robots can be pooled together to ported from the warehouse to local storage areas and from form a virtual ad hoc cloud infrastructure. Second, among there to the machines by ATVs. In the future, hundreds of the collaborative computing units, information can be ex- robots could transport the material directly from warehouses changed for synergetic decision making. Moreover, operators to machines avoiding the intermediate step, as well as freeing can access the cloud to obtain information or to interact valuable space in the factory. SEMANTiCS’2017, Amsterdam, Decentralized Robot-Cloud Architecture for an Autonomous Transportation System in a Smart Factory with robot agents by for example decreasing their velocity 3.2 Decentralized Control Architecture on security issues. In order to ensure the required autonomy and modulariza- The MRTA problem consists of the efficient assignment of tion, the current hierarchical control structure is replaced a set of tasks to a set of robots. Its taxonomy has been well by a mesh-like decentralized structure. This limits the top defined in [13] and our system corresponds to a decentral- management layer to a strategical goal definition and super- ized version of the “Single-Task Robots, Single-Robot Tasks, vision of the factory, rather than the control of the complete Instantaneous Assignment (STSRIA)” classification. system. Centralized control approaches were used more likely in The production machines are integrated with embedded the past as they provide optimal solutions to the MRTA systems to endow intelligence and connexion to the cloud problem. However, as explained in [14] and due to robustness allowing an autonomous control of their material replenish- and scalability problems, the tendency is now turning to ment. Thereby, robots and machines interact over the cloud decentralized approaches. In this paper, Khamis presents a and self-organize the factory according to the global specifi- decentralized market-based approach, where robots bid for cations. Moreover, operators have the possibility to supervise tasks based on their capabilities. For the bidding process and interact with the system in case of failure or hazard via the Contract Net Protocol (CNP) [15] has been used. This smart devices. multi-agent task-sharing protocol is divided into 4 stages: For the communication, the Robot Operating System Task announcement by an agent that takes the role of the (ROS) [16] middleware has been used. ROS provides compre- coordinator; Bid submission by individual agents; evaluation hensive and well-structured libraries and drivers for several and winner selection; and finally the contract stage of the robots and sensor devices and a well defined structure for winning agent. communication. For the communication between agents, it Our task allocation approach is based on this protocol, is possible to share information on the cloud for any other whereat the machine fulfills the role of the coordinator and agent that is interested (Publisher/Subscriber) or arrange a the ATVs participate as bidders. However, in order to increase point to point information exchange (Service/Client). the robustness, besides assigning a primary robot to perform Figure 2 shows the two main layers that compose this the task, an additional secondary robot will be assigned. decentralized architecture. Between them, the cloud assures It will supervise the primary robot and assume its task in the correct connectivity between modules and offers the case of failure. Moreover, the auction process is run locally possibility to outsource services such as computing power or between machines and the ATVs nearby. This simplifies the Data-Base services. approach, reducing the information exchanged and allowing Strategical layer the scalability. The strategical layer is responsible for long term operations and has three main functionalities: - Setting strategical goals: Based on incoming sales orders, 3 DECENTRALIZED CLOUD the strategical layer defines global goals (e.g. manufacturing ARCHITECTURE of a certain product in predefined quantity) that will be trans- mitted to the machines. It will not control the organization 3.1 Requirements of the agents in the operational layer, but supervise them In this section the requirements for a novel automatic trans- and interact with them only if there is a change in the global portation logistic architecture that contain most of the prop- plans. erties of the previously mentioned Industry 4.0 are presented: - Monitoring: Supervises the current state of the factory and saves historical data for learning, forecasting and sum- ∙ Agents are independent from each other. A failure ming up, to help building a more intelligent factory in the or complete removal of an agent must not affect any future. other entity (unless there is a direct co-working in this - Connecting clients and factory: Via a web application, moment). The addition of new agents on the system the customer could directly track the progress of his order. does also not affect other agents. Operational layer ∙ Every agent is able to connect to the cloud and ex- The operational layer is composed of cooperating machines, change information with other agents. Based on this robots and operators that execute the middle-term operations information exchange, agents make autonomous deci- of the factory. Based on strategical goals defined on the top sions allowing a decentralized control architecture. layer, these individual agents cooperate with each other to ∙ It is assumed that point to point connection can suffer autonomously organize the factory. delays or be temporarily interrupted. The system must As focusing on the automations of the transportation sys- be able to prevent and endure these situations. tem, the agents presented in this work are: production ma- ∙ It is assumed that ATVs could have problems during chines, that produce according to specifications from the the performance of their tasks (obstacles on the way, strategical layers; ATVs, that bring the materials from the connection lost...). There must be a rapid response of interim storage areas to the machines and final products to the system to react and solve these problems. SEMANTiCS’2017, Amsterdam, J. Martin et al. system. Therefore, the operator can only see information about the area he is working in. Strategical Cloud communication Define Layer Strategical goals Monitoring As explained in section 2, the cloud offers several advan- tages such as resources outsourcing, shared learning and a communication middleware between agents. This work fo- Real Time Interconnected Autonomous Agents cuses on this communication level. As in the future hundreds Middleware of robots, machines, operators, etc. will be connected to the cloud, it is important to create an intelligent communication Offer Transportation Publish tasks Monitoring network not to overload the cloud. service Control robots status Intervene if failure Some information can be directly sent to an specific entity ATV Operational while some other information will be shared with several Layer entities. ROS provides a message passing interface with two Machine Operator information exchange possibilities for these cases: the service- client and the publisher-subscriber. On the one hand, the Figure 2: Proposed Decentralized Control Architec- service-client semantic permits the direct communication ture. Strategical Layer containing the visualization between agents. The sender contacts a determined agent panel (top). Operational layer containing ATVs, Ma- and receives back a response from it. The sender knows if chines and Operators (bottom) the message has been received or not. Moreover, no other agent will notice this information exchange. A machine can thereby create a point to point communication with a desired ATV to receive a material supply. On the other hand, the delivery areas; and operators, that interact with the system publisher-subscriber semantic allows the diffusion (publica- in case a hazard is detected. tion) of information on the cloud. Every agent interested in - Machine: Represents the point of use provider or produc- this message can subscribe to it. There is no response implicit tion line. Provided with an embedded system that endues in this type of communication and therefore the sender does its intelligence and the possibility to connect to the cloud, it not know who received the information. This communication autonomously manages its material replenishment. When the option will be used for example by the machines and robots machine requires new material provisions, it sends a request to publish their Heart Beat on the cloud. Even though this to the cloud to contract the services of the most suitable Heart Beat is limited to a small quantity of bytes, the publi- ATV for the replenishment. cation rate will be limited to the smallest required in order The machine updates on the cloud brief information about not to saturate the cloud its internal status named Machine Heart Beat (MHB). This In general a single, central roscore master manages all the information contains its ID, status, IDs of robots contracted communications between all the ROS nodes. To allow the for the transportation, material type required and deadline decentralization, there are several multi-master packages, e.g. for the task to be finished. The machines can be connected multimaster fkie [17], that allow every agent to be its own to the cloud via LAN or WLAN. master and exchange information between nodes without the - ATV : Provides a transportation service on the cloud need of a central server. which is used by the Machines to replenish their material reserves. Each ATV is equipped with an own computational 4 IMPLEMENTATION AND system running on Ubuntu and using the Robot Operating DEPLOYMENT System (ROS) as middleware. Its intelligence depends on an own developed singleton pattern based state machine. Laser 4.1 Scenario explanation and simulation scanner data is used for the autonomous localization and In order to test the software, the system has been recreated navigation in the factory. Robots are necessarily connected into the ROS environment and released in the github reposi- to the cloud via WLAN. tory [18]. The factory layout (see figure 1) has been integrated As well as the machine, the ATV updates continually on in the management panel as shown in figure 4. Qt has been the cloud a few internal information named Robot Heart used for both the creation of the Management Panel and Beat (RHB). This information contains its ID, status (IDLE, the Operators Panel as it is platform-independent. Further- WORKING, ERROR...), localization and brief enlightenment more, it is open source, easy to use and has a comprehensive in case a task has been assigned to them. This information documentation. can be used by the machines that are utilizing their services, The strategical layer defines overarching objectives, based by other robots in case they have to cooperate or by the on market requirements or incoming sales orders, providing management panel to supervise the system. the respective machines with all data (e.g. bills of material - Operators: Using a tablet like device, the operator inter- (BoM), CAD-/CAM-Data, etc.) necessary to fulfill these goals. acts with ATVs in his surroundings. Though, he must not Considering the provided BoMs and CAD-/CAM-data, the be able to see or manipulate information about the whole machines calculate the necessary amount of material. SEMANTiCS’2017, Amsterdam, Decentralized Robot-Cloud Architecture for an Autonomous Transportation System in a Smart Factory For the simulation, the material is supposed to be au- a SECONDARY robot by following the same process (in this tomatically distributed from the warehouse to the interim case ATV1). The function of the secondary robot, is to be storage areas close to the machines. Therefore, this paper the backup of the primary. In case the primary robot has a focuses on the autonomous transportation of material from problem the secondary one will overtake its task. Once the these smaller storages to the machines. Fig 3 represents in task is assigned, the ATV navigates to the closest material a sequence diagram the course of events between machines storage area, performs an autonomous loading maneuver [19] and ATVs for the MRTA: (here simulated) and transports the material to the machine. After fulfilling the task, the robot starts subscribing again for new transportation tasks. On the bottom of the diagram it can be appreciated how the elected primary robot ATV2 updates its unique RHB2 introduced in the subsection 3.2. The heartbeat allows the interested agents, in this case the machine and the secondary ATV3, to receive a status of the primary robot current situa- tion. 4.2 Validation Two different control panel prototypes have been developed for the validation of the system. Firstly, a management panel responsible for the strategical order generation and monitor- ing the entire systems. Secondly, a human-robot interaction panel that displays information of interest to the respective worker and allows him interaction with the robots/ATVs in case of hazard or failure. The Management Panel (fig. 4) is mainly used for surveil- lance purposes. It visualizes the fabrication plant (center) with the machines represented as rectangular blue shapes and the ATVs as circular black shapes. Furthermore, it displays general information about the factory (top left corner), a chosen machine (top right corner) and a chosen ATV (bottom right corner). In addition and for testing purposes, the user is given the opportunity to define and publish the product Figure 3: Task allocation sequence diagram for an to be manufactured (bottom left corner). This option should autonomous machine-ATV material replenishment be replaced in the future by an automatic system that reads the incoming orders and publishes the respective answers in The ATVs subscribe to the middleware and wait for new the system. transportation tasks. When the machine reaches a specified The Human-Robot-Interaction Panel (fig. 5) runs on a minimum fill state of raw parts, it publishes a new replen- tablet-like device and provides the operator with information ishment task on the cloud. The available ATVs receive now about the working station he is at, and enables the interaction the new task directly from the machine and calculate their with the ATVs nearby. This interaction includes modification own specific costs for fulfilling it. These costs consist of the of ATVs behavior in case of failures such as in case 5 below. path (ATV-material source-machine), the robot’s battery In order to validate the architecture and ensure that it status, and their suitability for the respective type of task meets the requirements introduced in section 3.1, several (in case diverse ATVs with different abilities are available). cases and the reaction of the system to them are presented Calculated the cost, the robots check if they can perform the below. task within the given task dead line and, if affirmative, they Case 1: Failure on a determined machine: In this case, send the cost directly to the machine. After a certain bidding an operator intervenes and solves the fault by for example period, the machine shorts the biddings and tries to contract updating the machines software or repairing a hardware the services of the ATV with the lowest cost. It is important component. If it is possible, the machines orders will be for the machine to know if the elected robot receives the distributed between the other machines in the factory. If not, request and if it is still available. As shown in figure 3, the only its orders will be affected while the rest of the production ATV3 was the robot with the lowest cost but by the time the system proceeds as usual. bidding time finished, it has already been elected by a differ- Case 2: Peak workload season: In order to react to ent machine. As ATV2 has the second lowest cost and is still peak workload seasons it is sufficient to add more agents to available, it becomes the PRIMARY robot for the task. To the system. The agents that are already on the system will increase the robustness of the system, the machine will select not be affected as every agent makes its own decisions. SEMANTiCS’2017, Amsterdam, J. Martin et al. Figure 4: Management Panel is used for surveillance purposes by visualizing the plant in ROS (center ) and displaying several information about the plant (top left), the machines (top right) and the ATVs (bottom right). Additionally, it is used to define and publish global production targets (bottom left). will be evaluated first. If there is the possibility to solve it within a reasonable time, an operator may be requested to intervene. Otherwise, the secondary ATV could assume the task, or the machine could publish another task request starting a new bidding process. Case 5: Autonomous loading maneuver fails: The material box might get shifted during loading maneuvers, which could cause damage on the environment, the ATV itself, or in worst case the operators. Therefore, operators must be able to interact with robots by adjusting their speed Figure 5: Operator at the machine connects to and or completely stopping their current activity. After solving interacts with an ATV via handheld device the problem, the operator can confirm the elimination of the fault and allow the ATV to continue its operation. Case 3: Network connection problems: A connection Case 6: Software Updates: In the current factories up- problem could on the one hand prevent the ATV from bidding dates require to stop a partial area or even the complete fac- for new tasks. To solve this issue, enduring bidding periods are tory for long time. Moreover, it may be difficult to determine permitted. This extends the time from the task publication if the new software contains failures until it is implemented to the contract of the ATV. However, it is enough to consider and tested. Modularized agents permit a scalar update of it in the replenishment time estimation and publish the order the factory. It is not necessary to stop the whole factory but on ahead. On the other hand, a network problem can prevent single agents can be introduced and tested bit by bit before the ATV from publishing its RHB. If this occurs during a the whole system is updated. transportation task, the system could react (assuming there is a failure on the primary ATV) and start a new duplicated 4.3 Experiments transportation task. To avoid this problem, an additional The system has been mainly tested into a simulated environ- ad-hoc network could be implemented on the ATVs. Thus, if ment. However, in order to prove the cases 3 and 4 above, an ATV has WLAN connection problem (e.g. too far from an two experiments have been performed whereat the machine access point, or huge latencies), it will still have the possibility 8 is represented by a single-board computer and 3 ATVs to communicate its status to nearby ATVs (that have WLAN are represented by Kobukis (see figure 7). Each Kobuki is connection) that would transmit the information into the equipped with an ODROID-XU4 single-board computer to cloud. endow intelligence, a RP-LIDAR laser scanner for localization Case 4: A busy ATV has issues that prevent it from and mapping, a TP-LINK router that provides WLAN con- fulfilling its current task: An unavoidable obstacle in nection and a NeoCortec NC2400 module [20] to generate the the way or an important hardware issue makes it impossible additional wireless mesh network communication introduced for the ATV to reach its destination. In this case, the problem in case 3. SEMANTiCS’2017, Amsterdam, Decentralized Robot-Cloud Architecture for an Autonomous Transportation System in a Smart Factory Figure 6: Experiments. Machine 8 publishes a new task and selects ATV3 as primary and ATV1 as secondary robots (left); WLAN connection failure in ATV3 that transmits its RHB via the NeoCortec module (center); Failure in ATV3 represented as disconnected (right). has been finished to allow the ATV3 participating in future NeoCortec bidding processes. To prove the case 4, a hardware issue is simulated by LIDAR Odroid switching off the primary robot (ATV3). In this case, the XU4 ATV1 notices that the primary robot is no longer in the system (neither WLAN, nor NeoCortec RHB). Therefore, ATV1 assumes the task and executes it itself. Figure 6 (right) shows the ATV3 as disconnected and the secondary ATV1 starting to perform its task. In this case, the operators notice the disconnection and remove the ATV3 from the factory in order to repair it. TPLINK 5 CONCLUSIONS This paper presents and validates a decentralized control Figure 7: Kobuki platform that represents the ATV architecture for an autonomous transportation system that for validation tests includes the concepts of the IoT, modularized agents and cloud robotics that compose the future smart factories. We defined a set of requirements and challenges to ensure the robustness, flexibility and scalability that this decentralized We settled a similar environment to fig. 1, created a map architecture offers and validated them over a series of cases from it and let the three robots localize themselves on it. We and experiments. conducted a use case in which the machine 8 publishes a new The proposed MRTA has been kept simple and local, al- material replenishment task on the cloud. The three ATVs lowing a massive scalability of the factory. When a machine send their bidding costs to the machine and once the bidding offers a new task, the ATVs nearby are preferred to partic- period finishes, the machine selects the two ATVs with the ipate in the bidding process. This is limited by a distance lowest costs. In this case the ATV3 is selected as primary parameter. In case the machine does not obtain any answer and the ATV1 as the backup secondary robot. Figure 6 (left) from the robots nearby during the bidding period, the param- shows: the machine 8 with the selected primary (ATV3) and eter value is increased so more distant ATVs can participate secondary (ATV1) robots; all three ATVs connected to the in the bidding. Moreover, each ATV estimates its own cost cloud via WLAN; and the ATV3 leaving the charging station and sends it to the machine, avoiding complex algorithms to and thus initializing the transportation task. run in any agent. In order to test the WLAN connection failure in case 3, In the future we plan to move forward with the tests by the router cable is unplugged from the ATV3 inhibiting the extending the experiments in the replicated factory layout in direct connection of the robot to the cloud. As shown in our laboratory. The aim is to observe the influence of com- figure 6 (center), the ATV3 appears to be connected via Neo- munication problems such as latencies, test the robustness, Cortec (NC). Even though the TPLINK wireless connection and in conclusion observe the reaction of a not simulated is removed, the robot can yet broadcast its RHB3 through system to long working periods. We also plan to increase the the NeoCortec module to other robots. These robots will now number of machines, robots and simultaneously performed forward RHB3 to the cloud, informing the machine that the tasks in the simulation in order to prove the scalability of task is still being processed. The operators can in any case the system in complex situations. detect the connection failure and repair it once the delivery SEMANTiCS’2017, Amsterdam, J. Martin et al. REFERENCES [1] C. Prasse, A. Nettstraeter, and M. T. Hompel, “How IoT will change the design and operation of logistics systems,” 2014 Int. Conf. Internet Things, IOT 2014, pp. 55–60, 2014. [2] A. Kamagaew, J. Stenzel, A. Nettstrater, and M. Ten Hompel, “Concept of cellular transport systems in facility logistics,” ICARA 2011 - Proc. 5th Int. Conf. Autom. Robot. Appl., pp. 40–45, 2011. [3] C. A. Biffi and A. Tuissi, Stato dell’arte sulle tecniche di pro- duzione additiva per metalli. Springer Publishing Company, Incorporated, 2017, vol. 109, no. 1. [4] K. Furmans, C. Nobbe, and M. Schwab, “Future of Material Handling - modular, flexible and efficient,” Proc. IEEE/RSJ Int. Conf. Intell. Robot. Syst., p. 6, 2011. [5] K. Furmans, F. Schönung, and K. R. Gue, “Plug and work material handling systems,” Prog. Mater. Handl. Res., no. 1, pp. 132–142, 2010. [6] I. Spectrum, “Three Engineers , Hundreds of Robots , One Ware- house,” Spectrum, no. July, pp. 26–34, 2008. [7] R. D. Andrea and P. Wurman, “Future Challenges of Coordinating Hundreds of Autonomous Vehicles in Distribution Facilities,” pp. 80–83, 2008. [8] “RoboCup Industrial @Work League.” [Online]. Available: http://www.robocupatwork.org/ [9] G. Hu, W. P. Tay, and Y. Wen, “Cloud robotics: Architecture, challenges and applications,” IEEE Netw., vol. 26, no. 3, pp. 21–28, 2012. [10] R. Arumugam, V. R. Enti, Liu Bingbing, Wu Xiaojun, K. Baskaran, Foong Foo Kong, A. S. Kumar, Kang Dee Meng, and Goh Wai Kit, “DAvinCi: A cloud computing framework for service robots,” 2010 IEEE Int. Conf. Robot. Autom., pp. 3084–3089, 2010. [11] Amazon, “Amazon Web Services,” 2006. [Online]. Available: https://aws.amazon.com/ [12] M. Waibel, M. Beetz, J. Civera, R. D’Andrea, J. Elfring, D. Gálvez- López, K. Häussermann, R. Janssen, J. Montiel, A. Perzylo, B. Schießle, M. Tenorth, O. Zweigle, and R. De Molengraft, “RoboEarth,” IEEE Robot. Autom. Mag., vol. 18, no. 2, pp. 69–82, 2011. [13] B. P. Gerkey and M. J. Matarić, “A Formal Analysis and Tax- onomy of Task Allocation in Multi-Robot Systems,” Int. J. Rob. Res., vol. 23, no. 9, pp. 939–954, 2004. [14] A. Khamis, A. Hussein, and A. Elmogy, Multi-robot task al- location: A review of the state-of-the-art. Cham: Springer International Publishing, 2015, vol. 604, pp. 31–51. [15] R. G. Smith, “Correction to The Contract Net Protocol: High- Level Communication and Control in a Distributed Problem Solver,” IEEE Trans. Comput., vol. C-30, no. 5, p. 372, 1981. [16] “Robot Operating System (ROS).” [Online]. Available: http: //wiki.ros.org/ [17] A. Tiderko, “Multimaster Fkie,” 2016. [Online]. Available: http://wiki.ros.org/multimaster{ }fkie/ [18] “Kobuki fleet repository.” [Online]. Available: https://github. com/Jonmg/kobuki{ }fleet/ [19] J. Martin, T. Fink, S. May, C. Ochs, and I. Cabanes, “An Au- tonomous Transport Vehicle in an existing manufacturing facility with focus on the docking maneuver task - IEEE Xplore Doc- ument,” in 3rd Int. Conf. Control. Autom. Robot. (ICCAR), 2017, 2017. [20] “NeoCortec.” [Online]. Available: http://neocortec.com