Requirements and Specifications for Robots, Linked Data and all the REST René Schubotz, Christian Vogelgesang, André Antakli, Dmitri Rubinstein, Torsten Spieldenner German Research Center for Artificial Intelligence Saarbrücken, Germany ABSTRACT Consequently, the Robotics community is exploring and adopting The use of autonomous robots in both industry and every day life REST (Representational State Transfer) architectural principles and has increased significantly in the recent years. A growing number considers the use of Linked Data technologies as fruitful next step. of robots is connected to and operated from networks, including the However, we observe a lack of concise and stable specifications of World Wide Web. Consequently, the Robotics community is explor- how to properly leverage the RESTful paradigm and Linked Data ing and adopting REST (Representational State Transfer) architec- concepts in the Robotics domain. tural principles and considers the use of Linked Data technologies In the scope of this paper, we identify a set of desiderata that we as fruitful next step. However, we observe a lack of concise and consider vital for successfully implementing Linked Data-driven stable specifications of how to properly leverage the RESTful para- robotic systems and applications. Introducing the notion of Linked digm and Linked Data concepts in the Robotics domain. Introducing Robotic Things, we provide a minimalistic, yet well-defined specifi- the notion of Linked Robotic Things, we provide a minimalistic, yet cation covering a minimal set of requirements with respect to the well-defined specification covering a minimal set of requirements desiderata identified. Our contributions include in particular: with respect to the use of HTTP and RDF. (1) the Robotic Thing Model, a minimalistic core specification for truly RESTful “Web Robotics”. (2) the notion of Linked Robotic Things as a semantic extension of Web-enabled robots. (3) the Linked Robotic Thing Model, a basic contract allowing clients to automatically discover and interoperate with Linked Robotic Things. The remainder of this paper is organized as follows. We outline the development of “Web Robotics” and report on recent research in the Linked Data community (cf. Section 2). Next, several high-level 1 INTRODUCTION desiderata for Linked Data-driven robotic systems and applications Robotic systems are widely used in modern society and have sig- (cf. Section 3) are discussed. Section 4 presents a minimal speci- nificant impact to economics and social aspects. However, most fication of Web-enabled robots meeting the criteria for level 3 of of these robots are not able to act in a context aware manner. For the Richardson Maturity Model. We propose a semantic extension example, many industry robots execute hard coded programs in a of Web-enabled robots in Section 5, and define the Linked Robotic caged working space. With the increasing demand for flexibility Thing Model in Section 6. Future work is outlined in Section 7 , and in production processes and enhanced human-robot collaboration, we conclude with summary in Section 8. robotic systems have to interact naturally with their environment, other robots and humans. To achieve this, robotic systems must 2 FROM TELELABS TO WEB ROBOTICS acquire deeper knowledge about their environment, for example Active since 1994, the UWA Telelabs Project offers remote access to by tapping into other software and information systems. an industrial robot for tele-manipulations in a blocks world and initi- In this respect, Kamei et al. [17] argue that for the successful ated the subfield of “Internet Robotics” [40]. Evolving from internet- design of flexible, extendable, re-usable applications, robots are based interfaces to robotic systems [7, 16, 29], to networked control required to be provided as abstracted resource in a “cloud of robots”. middlewares [1, 5, 46], service-oriented approaches using various Subsequently, parts of the robots, the actions that can be performed, instantiations of the web service protocol stack [4, 6, 22, 23, 28] and and tasks that are to be fulfilled by performing the described actions finally to RESTful services for robotic applications [23, 34, 42, 45], need to be provided in a unified format. researchers in the field consider the use of the World Wide Web and its associated technologies as a scalable robotics application platform [18, 36, 53, 55]. Rather than exposing real-world data and functionality through vertical system designs, proponents of “Web Robotics” suggest to apply the REST architectural style [11, 37] to Web-enabled robots in the physical world and thus to make them an integral part of the Web. © 2017 Copyright held by the author/owners. Following the very same line of argument, the Linked Data com- SEMANTiCS 2017 workshops proceedings: LIDARI munity explores the relationship between software and information September 11-14, 2017, Amsterdam, Netherlands systems and the Web. Initially focusing on aligning SPARQL with LIDARI’17, September 2017, Amsterdam, Netherlands René Schubotz et al. REST architectural principles [54], interest quickly revolves around patterns and, therefore, seemingly violate some core require- the notion of Linked Services. Coining the nomenclature, Pedrinaci ments of Robotics. Yet, there is a number of established REST- et al. [33] anticipate RESTful services that process and generate conformant techniques for providing event-triggered call- Linked Data and concomitantly expose their “inputs and outputs, backs and protocol upgrades to full-duplex streaming com- their functionality, and their non-functional properties” following munication. We believe these techniques to be potentially Linked Data principles. After discussion and refutation [30] of the suitable, but they require further evaluation and elaboration potential impedance mismatch between RESTful services and the in the Robotics domain. Resource Description Framework (RDF), considerable effort has D4 Semantic descriptions of robotic configurations and been dedicated to the formal description of Linked Services (cf. scenarios: With Linked Data we have the ability to integrate [48]). all addressable web resources with the Web representation However, facing the lack of any standardization or widespread of robotic systems. A real added value results from exposing adoption of Linked Services, a fatum shared with Semantic Web Ser- the entire robotic world model with configurations, abilities, vices [50], the scientific community currently favours addressing sensor data, knowledge about the environment and the cur- more utile techniques for data integration and system interopera- rent tasks of a robot in a semantically useful way. Additional tion. To name a few, we briefly list RDF constraint languages for resources can be integrated to provide a better understanding describing and constraining the contents of RDF graphs [21, 32, 35, of the robotic world model for other Web-based systems. 38, 44], novel RESTful Linked Data interfaces as well as client-side D5 Unifying binary and semantic robotic data: The seman- query execution techniques [47, 49, 51, 52], the specification of tic description of robotic configurations and scenarios has integration and interaction patterns for building resource-oriented received some attention [25, 27, 41, 43], yet, the issue is far Linked Data applications [13–15, 26, 39], or high-performance pro- from resolved. The Linked Data Community is working in- cessing techniques for dynamic Linked Data [19, 20]. cessantly on techniques for mapping existing data in the RDF data model in order to lower the barrier for generating 3 TOWARDS LINKED ROBOTICS Linked Data. While there is tremendous progress in map- Recent developments in Linked Data and Hypermedia research ping structured data [8] and semi-structured data [9], there might help in setting priorities for a roadmap towards Linked Data is a surprising gap with respect to binary data, e.g. robotic in Robotics. In the following, we discuss several high-level desider- perception data, that necessitates further thought. ata for Linked Data-driven robotic systems and applications that D6 Declarative integration: We aim to use declarative means we feel free to coin Linked Robotics. to describe robotic data and functionality, and wish to achieve an ecosystem in which providers of data and functionality D1 Level 3 Richardson Maturity Model: The larger share of interlink without the need for direct coordination. An ideal RESTful interface designs in industry and academia is fo- system would automatically determine how to combine data cused on devising resource identifier schemes and discussing and functionality to ultimately arrive at the stated goal of a the semantics of HTTP verbs in context thereof. Such designs user. However, such a system has proven elusive [24, 50]. We are oftentimes in violation with the “URI Opacity Axiom” thus opt for a declarative coordination of distributed data [2] and usually neglect the principle of “Hypermedia As The and functionality into coherent Linked Data-driven robotic Engine Of Application State” (HATEOAS) [31]. Hence they applications. rarely meet the criteria for level 3 of the Richardson Maturity Model [12]. Since we aim to provide a core specification for Despite considerable uptake of REST architectural principles “Linked Robotics”, we must assume clients with no or limited in the Robotics community [23, 34, 42, 45], guidelines or specifi- prior knowledge and consequently establish 3-RMM1 . cations for building RESTful robotic systems and applications are D2 Well-defined interaction patterns: The cornerstones for missing. In the following sections, we outline a minimalistic core successful distributed systems are well-defined protocol in- specification for Linked Robotics (cf. overview in Figure 1) and terfaces and interaction patterns. In this respect, some com- envision its usage in conjunction with one or more domain-specific munities provide guidelines and specifications for their do- refinements. main, e.g. the Richardson Maturity Model [12] details on the mandatory properties of RESTful systems, Berners-Lee 4 ROBOTIC THING MODEL [3] suggests a cumulative “5 Star” deployment scheme for Linked Data systems, Guinard et al. [13, 14] offer guidelines Robotic Things (RT) are digital representations of robotic systems for the Web of Things, and Speicher et al. [39] define a set or applications accessible via RESTful interfaces. HTTP requests of rules for read-write Linked Data on the Web. We are not to access, modify, create or delete Robotic Things are accepted and aware of equipollent work in the “Web Robotics” community. processed by Robotic Thing servers. Such servers can manage two D3 Event-drivenness and real-time data: Real-time and event- kinds of Robotic Things, those resources whose state is represented based computing play major roles in various topics in Ro- using RDF (cf. Section 5) and those using other formats. In the botics including real-time control, human-robot interactions following, we specify the use of HTTP for accessing, updating, or sensor perception and fusion. REST architectural princi- creating and deleting resources from servers that expose Robotic ples, however, enforce stateless request-response messaging Things. 1 We use X-RMM as a shorthand for Level-X Richardson Maturity Model. Robots, Linked Data and all the REST LIDARI’17, September 2017, Amsterdam, Netherlands Figure 1: Overview of the Linked Robotic Thing Model. R0.1 A RT server must at least be HTTP/1.1 conformant server. R0.13 A RT server should implement a HTTP callback mechanism, R0.2 A RT server should support secure connections with HTTP e.g. WebHooks2 or RestHooks3 . over TLS. RT servers that are exposed on the Internet must R0.14 A RT server must support the request Upgrade header field always implement HTTPS or other security mechanisms in for subscription creation. addition or in place of HTTPS. R0.15 A request Upgrade header field value of ‘websocket’ must R0.3 A Robotic Thing must have a URI endpoint for itself and all result in the creation of a WebSocket-based communication of its sub-resources. as specified in [10]. R0.4 A RT server must support GET on its root resource. R0.16 A request Upgrade header field value of ‘callback’ must result R0.5 A RT server must support GET for retrieving resource rep- in the creation of a HTTP callback, and requires the request resentations, POST for resource creation, PUT for resource Callback header field to specify a callback URI. updates or state changes, and DELETE for resource removal. R0.17 A RT server should support the Accept header field in sub- R0.6 A RT server must implement HTTP status codes 200, 400 scription creation requests to allow for content-negotiation. and 500 providing at least generic indications for successful Discussion. Starting with basic requirements (R0.1-R0.3) for actions, client-side errors or server-side errors. reaching 1-RMM, we satisfy the criteria for 2-RMM with (R0.4-R0.7), R0.7 A RT server should return a HTTP status code 204 for all and employ best practices (R0.8-R0.10) in order to provide hyper- successful PUT, POST, and DELETE requests. media controls at the protocol level. On the whole, we establish a R0.8 A RT server must use the response Location header field to maturity level of 3-RMM (D1). The semantics of HTTP operations is provide information about the location of a newly created clarified (R.05), and their admissibility is either specified by default resource for all successful POST requests. (R0.4) or advertised via the Options Header (R0.10). In conjunction R0.9 A Robotic Thing must advertise associated sub-resources us- with the definition of expectable HTTP return and error codes ing the HTTP response Link header field, and a link relation (R0.6-R0.7), we provide a simple, yet well-defined interaction model type of related (that is, rel="related"). (D2). The ETag header (R0.11) is widely used for cache validation R0.10 A RT server must support OPTIONS for each of its exposed and conditional requests, and can be used for performance improve- resources and must advertise permitted resource interactions ments of polling algorithms (D3). With the potential for protocol in the response Allow header field. upgrades or event-triggered callback mechanisms (R0.12-R0.17), we R0.11 A RT server must use entity tags as response ETag header strive for communication paradigms more suitable for event-driven values for all responses that contain representations and for and real-time data (D3). The remaining desiderata (D4-D6) can not responses to HEAD requests. be fulfilled within the Robotic Thing Model. We therefore extend R0.12 A RT server must implement the WebSocket protocol [10]. the notion of Robotic Things in the next section. 2 http://www.webhooks.org/ 3 http://resthooks.org/ LIDARI’17, September 2017, Amsterdam, Netherlands René Schubotz et al. ros : RevoluteJointShape @ base < http :// example . org / baxter / > . rdf : type sh : NodeShape ; sh : targetClass ros : RevoluteJoint ; < right_s1 / rotation > sh : property [ rdf : type spatial : AxisAngle , spatial : Rotation3D , hybrit : Property ; sh : path [ sh : alternativePath ( ros : rotation hybrit : property ) ] ; rdfs : seeAlso < right_s1 > ; sh : minCount " 1 " ^^ xsd : integer ; spatial : rotationAngle [ sh : maxCount " 1 " ^^ xsd : integer ; rdf : type maths : Scalar ; sh : class hybrit : Property ; vom : numericalValue " 0 " ^^ xsd : float ; sh : node spatial : AxisAngleShape ; vom : unit maths : Radian ] ; ] ; sh : property [ spatial : rotationAxis [ sh : path [ sh : alternativePath ( ros : jointReferenceFrame hybrit : property ) ] ; rdf : type maths : Vector3D ; sh : minCount " 1 " ^^ xsd : integer ; maths : x " 0 " ^^ xsd : float ; sh : maxCount " 1 " ^^ xsd : integer ; maths : y " 0 " ^^ xsd : float ; sh : class hybrit : Property ; maths : z " 1 " ^^ xsd : float sh : node maths : CoordinateSystemShape ; ] . ] ; sh : property [ sh : path ros : preceedingLink ; sh : minCount " 1 " ^^ xsd : integer ; Figure 3: A Property describing a joint’s rotation parameter. sh : maxCount " 1 " ^^ xsd : integer ; sh : class ros : Link ; ] ; sh : property [ Unfortunately, the formulation and validation of such interface sh : path ros : succeedingLink ; sh : minCount " 1 " ^^ xsd : integer ; constraints using RDF(S) or OWL2 is ineligible due to the Open sh : maxCount " 1 " ^^ xsd : integer ; World Assumption adopted by RDF(S) and OWL2, and the lack of a Unique Name Assumption. In fact, neither RDF(S) nor OWL2 sh : class ros : Link ; ] ; provide constraint validation semantics in our sense. However, RDF shape constraint languages [21, 32, 35, 38, 44] pro- Figure 2a: A SHACL-based Blueprint specifying a joint. vide just enough expressiveness and, first and foremost, constraint validation semantics for our purposes. We intend to use RDF shape @ base < http :// example . org / baxter / > . expressions to describe the topology of Linked Robotics Things, to specify and validate constraints on HTTP message bodies, and < right_s1 > rdf : type hybrit : RoboticThing , ros : RevoluteJoint ; besides description and validation, for code generation and data hybrit : blueprint ros : RevoluteJointShape ; hybrit : subscriptions < right_s1 / subscriptions > ; integration. hybrit : action < right_s1 / actions / rotate > ; We collect a number of such RDF shape expressions using a hybrit : property < right_s1 / friction > , dereferenceable (sub-) resource of a Linked Robotic Thing, called < right_s1 / rotation > , its Blueprint. Blueprints provide completely machine-processable < right_s1 / jointReferenceFrame > ; rdfs : seeAlso <> ; documentation about a Linked Robotic Thing and its interfaces. For dcterms : title " right_s1 " ; illustrational purposes, we give a simple SHACL-based blueprint ros : friction < right_s1 / friction > ; ros : jointReferenceFrame < right_s1 / jointReferenceFrame > ; of a revolute joint (cf. Figure 2a) that can be used to validate the ros : rotation < right_s1 / rotation > ; xhv : prev < right_upper_shoulder > ; Linked Robotic Thing instance of Figure 2b. xhv : next < right_lower_shoulder > ; ros : preceedingLink < right_upper_shoulder > ; ros : succeedingLink < right_lower_shoulder > . 5.2 Properties Linked Robotic Things typically expose a collection of configuration Figure 2b: A Blueprint-conformant Linked Robotic Thing. parameters and dynamic variables governing overall behaviour and execution. Such configuration parameters and dynamic variables are essential components of a robotic system, hence, we make them uniquely identifiable and resolvable in form of so-called Properties. 5 LINKED ROBOTIC THINGS A Property is a dereferenceable (sub-) resource of a Linked Robotic Linked Robotic Things are Robotics Things, but have the unique Thing that describes and keeps track of a specific parameter or vari- quality that at least one of their representations is based on RDF. able, e.g. a joint’s rotation (cf. Figure 3) or a link’s moment of mass Furthermore, Linked Robotic Things are often associated with a inertia, and enables clients to automatically inspect and potentially number of specific sub-resources that a client can use to learn about manipulate state and behaviour. Properties may detail on the type the Linked Robotic Thing’s topology and interface constraints, to of the exposed quantity, its time-stamped values, units of measure- discover and execute available actions, to access and manipulate a ment, dimensions or data types. Implementers are encouraged to set of parameters, or to subscribe for event notifications in order to re-use existing vocabularies such as QUDT4 , VOM5 or UO6 . observe particular state changes. 5.3 Subscriptions 5.1 Blueprints Besides plain GET requests on Robotic Things and their potentially Any useful interface definition for a Linked Robotic Thing should time-varying Properties (cf. Section 5.2), a Robotic Thing server enable the definition of its RDF graph topology, allow to express allows clients to subscribe to event notifications via the HTTP structural constraints on its RDF representations, and communicate 4 http://qudt.org/ expected and expectable graph patterns for admissible RESTful 5 http://vocab.arvida.de/2015/06/vom interactions. 6 http://purl.bioontology.org/ontology/UO Robots, Linked Data and all the REST LIDARI’17, September 2017, Amsterdam, Netherlands @ base < http :// example . org / baxter / right_s1 / subscriptions > . @ base < http :// example . org / baxter / > . <> _ : body rdf : type http - core : Body . rdf : type ldp : Container ; ldp : contains <840 c14b0 -6 def -11 e7 -907 b - a6006ad3dba0 > . < right_s1 / action / rotate > rdf : type hybrit : Action , hybrit : AsynchronousAction ; <840 c14b0 -6 def -11 e7 -907 b - a6006ad3dba0 > hybrit : consumes [ rdf : type hybrit : Subscription , hybrit : WebCallback ; rdf : type sh : NodeShape ; hybrit : onResource < right_s1 / rotation > ; sh : targetNode _ : body ; hybrit : callbackURL " http :// www . example . org / receiver " ^^ xsd : anyURI ; sh : targetClass maths : Scalar ; hybrit : mediaType " text / turtle " ; sh : property [ dcterms : identifier " 840 c14b0 -6 def -11 e7 -907 b - a6006ad3dba0 " . sh : path vom : numericalValue ; sh : minCount " 1 " ^^ xsd : integer ; sh : maxCount " 1 " ^^ xsd : integer ; sh : datatype xsd : float ; Figure 4: A subscription on a joint rotation parameter. ] ; sh : property [ sh : path vom : unit ; sh : minCount " 1 " ^^ xsd : integer ; protocol upgrade mechanism. New subscriptions are created by sh : maxCount " 1 " ^^ xsd : integer ; issuing a GET request on the respective resource with the request sh : minInclusive 0 ; sh : maxExclusive 360 ; Upgrade header field value set to ‘websocket’ or ‘callback’, and sh : hasValue maths : Degree ; the request Accept header field set for proper content-negotiation. ] ; ] ; In case of creating a ‘callback’ subscription, the request Callback hybrit : produces < right_s1 / action / rotate / producesshape > ; header field must specify a callback URI. hybrit : binding [ rdf : type http - core : Request ; A Linked Robotic Thing provides minimalistic support for the http - core : mthd http - methods : PUT ; http - core : requestURI < right_s1 / action / rotate > ; management of subscriptions via a dereferenceable Subscriptions http - core : body _ : body ; (sub-) resource. The Subscriptions resource is a Linked Data Plat- ] . form container and allows to list current subscriptions using a GET request as well as cancelling a subscription using a DELETE re- Figure 5a: An Action allowing to rotate a joint. quest. For each current subscription, the Subscriptions resource must provide a RDF description (cf. Figure 4), e.g. detailing on the POST / baxter / right_s1 / action / rotate HTTP /1.1 subscription type, additional protocol specific information, and the Host : http :// example . org resource being subscribed to. <> rdf : type maths : Scalar ; 5.4 Actions vom : numericalValue " 43.6 " ^^ xsd : float ; vom : unit vom : Degree . An Action enables a Linked Robotic Thing to advertise its potential resource state transitions to a client. These advertisements are Figure 5b: An Action execution rotating the joint. exposed in dereferenceable Action (sub-) resources that provide the information necessary for a client to select and execute an appropriate Action so that a certain desired goal is achieved. Since we aim to exchange this information in a machine-processable way at runtime instead of being hardcoded into the client at design time, 6 LINKED ROBOTIC THING MODEL clients can be decoupled from the RT server and adapt to changes The Linked Robotic Thing model is intended as a contract between more easily. clients and Linked Robotic Things exposed on the Web, thus, al- An Action must effectively describe and constrain the data it lowing clients to automatically discover and use their properties may consume for and produce upon a successful invocation. Such and action possibilities. In the following, we specify a set of simple specifications may link to a Linked Robotic Thing’s Blueprint (cf. rules and conventions for Linked Robotic Things. Section 5.1), or directly given using a RDF shape expression (cf. R1.1 A Linked Robotic Thing is a Robotic Thing. Figure 5a). Regardless of the specific formulation, the client must R1.2 A RT server must respond with a Turtle representation7 of expect the server to validate the client-provided input against the the requested Linked Robotic Thing, unless HTTP content- expressed constraints. The server may reject an invocation if this negotiation requires a different outcome. validation fails. The server may ignore any additional triples not R1.3 Linked Robotic Things must have at least one rdf:type set covered by the formulated constraints. explicitly in their RDF representations. A Binding describes a means that the client can use to execute R1.4 In the absence of special knowledge of the application or an Action using a specific communication protocol stack. In the domain, clients must assume that any RDF representation scope of this paper, Bindings are restricted to HTTP requests. The of a Linked Robotic Thing can have multiple rdf:type triples predicate hybrit:binding is used to a link an Action to one or more with different objects. Bindings. Based on a chosen Binding, a client may employ sim- R1.5 RDF representations of Linked Robotic Things should reuse ple code generation techniques in order to execute the associated existing vocabularies instead of creating their own duplicate Action (cf. Figure 5b). vocabulary terms. Standard vocabularies such as RDF and As a final remark, we point out that Actions can be offered at any level of abstraction, thus, they can be summarised to higher 7 We prefer Turtle syntax for its legibility as default representation. Implementers are level Actions. free to support more RDF surface syntaxes via HTTP content-negotiation. LIDARI’17, September 2017, Amsterdam, Netherlands René Schubotz et al. RDF Schema, Dublin Core or Linked Data Platform, should Robotic applications make heavy use of binary data, but there is be used whenever possible. surprisingly little work on generic mappings between application- R1.6 Clients should always assume that different Linked Robotic specific binary data and RDF. We see possible research contributions Things of the same type may not all have the same set of on how to lower the barrier between binary data and Linked Data predicates in their RDF representations, and the set of pred- (cf. D5, Section 3). icates that are used in the state of any one Linked Robotic The primary focus of this paper is on the design of Linked Robotic Thing is not limited to any pre-defined set. Thing servers. While we are convinced that our specifications will R1.7 A RT server must not require clients to implement inferenc- help to simplify the implementation of clients, we feel that the ing in order to recognize the subset of content defined by a actual design of such clients, and how they efficiently integrate in Linked Robotic Thing’s RDF representation. Other specifica- a heterogeneous environment of Linked Robotic Things and other tions built on top of this may require clients to implement Web resources, should receive more attention. inferencing. The Linked Robotic Things Model does not make strong assump- R1.8 A Linked Robotic Thing must expose a Subscriptions con- tions (R0.2) regarding any security or privacy concerns. At this tainer resource using a RDF triple whose subject is the Linked point, we rely on the standard Web security mechanisms, such Robotic Thing’s URI, whose predicate is hybrit:subscriptions as HTTPS, and standard Web infrastructure. We thus see future and whose object is the URI for the Subscriptions container research in how to include security and privacy aspects into the resource. Linked Robotic Things Model. R1.9 A Linked Robotic Thing should expose a collection of Prop- erty resources using RDF triples whose subject is the Linked 8 CONCLUSION Robotic Thing’s URI, whose predicate is hybrit:property and Considering developments in the field of networked robotics, from whose objects are the URIs for the Property resources. first tele-operated systems in the 1990’s, to nowadays cloud-based R1.10 A Linked Robotic Thing should expose a collection of Action RESTful Robotics applications, we have identified how these REST- resources using RDF triples whose subject is the Linked ful Robotics applications may benefit from Linked Data approaches. Robotic Thing’s URI, whose predicate is hybrit:action and Such have already been investigated in the Linked Service commu- whose objects are the URIs for the Action resources. nity, and have also been considered to be applied to Web Robotics R1.11 A Linked Robotic Thing may expose a Blueprint resource applications. To overcome the lack of clear and concise specifica- using an RDF triple whose subject is the Linked Robotic tions of how to employ Linked Data concepts in the field of Robotics, Thing’s URI, whose predicate is hybrit:blueprint and whose in this paper, we have made the following contributions: object is the URI for the Blueprint resource. We have proposed a number of desiderata for robotic systems in R1.12 A Linked Robotic Thing may provide additional meta data to Linked Data Environments and have proposed a multi-layer model precisely describe the meaning of individual building blocks to address these: A protocol layer to ensure basic communication, of a model in a machine-understandable way. and a (machine-readable) semantic layer that provides additional Discussion. Linked Robotic Things are - by definition (R1.1- information about the resource. To ensure the basic communication R1.2) - a semantic extension of Robotic Things (D4). We specify on the protocol layer, we proposed a definition of a Robotic Thing. some minimal expectations (R1.3-R1.6) regarding a Linked Robotic Building on that, we have defined a set of requirements on the Thing’s description (D4), and furthermore provide a light-weight, semantic level to create a common understanding, how server and intuitive conceptual model with standardized link relations (R1.8- clients interact with each other and how we can explore the world R1.11). This not only allows to (re-)use vocabularies and ontolo- model of a Linked Robot Thing in an efficient and simple way. Thus, gies suitable for a more refined semantic descriptions (D4), but the implementation and communication between systems using also serves as a minimalistic interaction model (D2) offering hy- this model are much more robust, simpler and testable. permedia controls (D1) in addition to (R0.8-R0.10). Using HTTP We have discussed the requirements on both levels, compared content-negotiation (R1.2), a Linked Robotic Thing may be avail- them to the previously stated desiderata, and shown that all desider- able in several different representations (R1.1) including binary ata can be fulfilled by the given requirements. We thus present an formats (D5). We explicitly reflect the semantic aspects (R1.8, R0.12- exhaustive, concise, well-defined specification for Linked Robotic R.017) of available event-based and real-time interfaces (D3). Using Things as building blocks for Linked Robotic applications on the Blueprints as machine-processable descriptions of Linked Robotics World Wide Web. Things (R1.11) and Actions (R1.10) as advertisements of their poten- tial state transitions, we aim for improved system interoperation ACKNOWLEDGMENTS (D6). This work is supported by the Federal Ministry of Education and Research of Germany in the project Hybr-iT (Förderkennzeichen 7 FUTURE WORK 01IS16026A). With HTTP/2 and Google QUIC8 , a number of interesting protocols for event-driven and real-time communication arise. We intend a more detailed investigation and evaluation of these protocols in the context of the Linked Robotic Things (cf. D3, Section 3). 8 https://datatracker.ietf.org/wg/quic/documents/ Robots, Linked Data and all the REST LIDARI’17, September 2017, Amsterdam, Netherlands REFERENCES Architecture+for+Virtualizing+Robots+in+Robot-as-a-Service+Clouds&ots= [1] Noriaki Ando, Takashi Suehiro, Kosei Kitagaki, Tetsuo Kotoku, and Woo-Keun B10oKSPyTT&sig=VP6Hz54Rs6J9SOHiJ4pj01_K6kE Yoon. 2005. RT-middleware: distributed component middleware for RT (robot [23] Anis Koubaa. 2015. ROS as a service: web services for robot technology). In Intelligent Robots and Systems, 2005.(IROS 2005). 2005 IEEE/RSJ operating system. Journal of Software Engineering for Robot- International Conference on. IEEE, 3933–3938. http://ieeexplore.ieee.org/abstract/ ics 6, 1 (2015), 1–14. https://www.researchgate.net/profile/Anis_ document/1545521/ Koubaa/publication/309668701_ROS_As_a_Service_Web_Services_ [2] Tim Berners-Lee. 1996. Univeral Resource Identifiers – Axioms of Web architec- for_Robot_Operating_System/links/581c59c508aeccc08aec5689/ ture. (Dec. 1996). https://www.w3.org/DesignIssues/Axioms.html ROS-As-a-Service-Web-Services-for-Robot-Operating-System.pdf [3] Tim Berners-Lee. 2010. Is your linked open data 5 star. https://www. w3. org/De- [24] Reto Krummenacher, Martin Hepp, Axel Polleres, Christoph Bussler, and Dieter signIssues/LinkedData. html (2010). Fensel. 2005. WWW or What is Wrong with Web services. In Web Services, 2005. [4] Radhia Bouziane, Labib Sadek Terrissa, Soheyb Ayad, and Jean-Franois Breth. ECOWS 2005. Third IEEE European Conference on. IEEE, 9–pp. http://ieeexplore. 2016. A ROS-based approach for robot as a service (Web services based solution). ieee.org/abstract/document/1595733/ (2016). https://www.researchgate.net/profile/Labib_Sadek_Terrissa2/publication/ [25] Lars Kunze, Tobias Roehm, and Michael Beetz. 2011. Towards semantic robot 311583836_Web_services_based_solution_for_robot_as_a_service_in_the_ description languages. In Robotics and Automation (ICRA), 2011 IEEE Interna- cloud/links/584f0ef208aed95c25099630.pdf tional Conference on. IEEE, 5589–5595. http://ieeexplore.ieee.org/xpls/abs_all.jsp? [5] Herman Bruyninckx. 2001. Open robot control software: the OROCOS project. arnumber=5980170 In Robotics and Automation, 2001. Proceedings 2001 ICRA. IEEE International Con- [26] Markus Lanthaler and Christian Gütl. 2013. Hydra: A Vocabulary for Hypermedia- ference on, Vol. 3. IEEE, 2523–2528. http://ieeexplore.ieee.org/abstract/document/ Driven Web APIs. LDOW 996 (2013). https://pdfs.semanticscholar.org/6f29/ 933002/ 4df1ea316c73e68ebaaf7966661daa13cfe2.pdf [6] Yinong Chen, Zhihui Du, and Marcos García-Acosta. 2010. Robot as a service in [27] Gi Hyun Lim, Il Hong Suh, and Hyowon Suh. 2011. Ontology-based unified cloud computing. In Service Oriented System Engineering (SOSE), 2010 Fifth IEEE robot knowledge for service robots in indoor environments. IEEE Transactions on International Symposium on. IEEE, 151–158. http://ieeexplore.ieee.org/abstract/ Systems, Man, and Cybernetics-Part A: Systems and Humans 41, 3 (2011), 492–509. document/5570010/ http://ieeexplore.ieee.org/abstract/document/5605259/ [7] Barney Dalton and Ken Taylor. 2000. Distributed robotics over the internet. IEEE [28] Sachiko Nakagawa, Noboru Igarashi, Yosuke Tsuchiya, Masahiko Narita, and Robotics & Automation Magazine 7, 2 (2000), 22–27. http://ieeexplore.ieee.org/ Yuka Kato. 2012. An implementation of a distributed service framework for abstract/document/848264/ cloud-based robot services. In IECON 2012-38th Annual Conference on IEEE In- [8] Souripriya Das, Seema Sundara, and Richard Cyganiak. 2012. R2RML: RDB to dustrial Electronics Society. IEEE, 4148–4153. http://ieeexplore.ieee.org/abstract/ RDF mapping language. (2012). http://www.citeulike.org/group/14833/article/ document/6389225/ 11522782 [29] Lung Ngai, Wyatt S. Newman, and Vincenzo Liberatore. 2002. An experiment [9] Anastasia Dimou, Miel Vander Sande, Pieter Colpaert, Ruben Ver- in internet-based, human-assisted robotics. In Robotics and Automation, 2002. borgh, Erik Mannens, and Rik Van de Walle. 2014. RML: A Generic Proceedings. ICRA’02. IEEE International Conference on, Vol. 2. IEEE, 2190–2195. Language for Integrated RDF Mappings of Heterogeneous Data.. In http://ieeexplore.ieee.org/abstract/document/1014864/ LDOW. https://www.researchgate.net/profile/Ruben_Verborgh/publication/ [30] Kevin R. Page, David C. De Roure, and Kirk Martinez. 2011. REST and Linked 264274087_RML_A_Generic_Language_for_Integrated_RDF_Mappings_of_ Data: a match made for domain driven development?. In Proceedings of the Second Heterogeneous_Data/links/53d8fd2b0cf2631430c38a7b.pdf International Workshop on RESTful Design. ACM, 22–25. http://dl.acm.org/citation. [10] Ian Fette. 2011. The websocket protocol. (2011). https://tools.ietf.org/html/rfc6455 cfm?id=1967435 [11] Roy Thomas Fielding. 2000. Architectural styles and the design of [31] Savas Parastatidis, Jim Webber, Guilherme Silveira, and Ian S. Robinson. 2010. network-based software architectures. Ph.D. Dissertation. University The role of hypermedia in distributed system development. In Proceedings of the of California, Irvine. http://jpkc.fudan.edu.cn/picture/article/216/35/4b/ First International Workshop on RESTful Design. ACM, 16–22. http://dl.acm.org/ 22598d594e3d93239700ce79bce1/7ed3ec2a-03c2-49cb-8bf8-5a90ea42f523.pdf citation.cfm?id=1798379 [12] Martin Fowler. 2010. Richardson Maturity Model: steps toward the glory of REST. [32] Peter F. Patel-Schneider. 2017. ASHACL: Alternative Shapes Constraint Lan- Online at http://martinfowler. com/articles/richardsonMaturityModel. html (2010). guage. arXiv:1702.01795 [cs] (Feb. 2017). http://arxiv.org/abs/1702.01795 arXiv: [13] Dominique Guinard, Vlad Trifa, Friedemann Mattern, and Erik Wilde. 2011. From 1702.01795. the internet of things to the web of things: Resource-oriented architecture and [33] Carlos Pedrinaci and John Domingue. 2010. Toward the Next Wave of Ser- best practices. Architecting the Internet of things (2011), 97–129. http://link. vices: Linked Services for the Web of Data. J. ucs 16, 13 (2010), 1694– springer.com/content/pdf/10.1007/978-3-642-19157-2.pdf#page=129 1719. http://www.jucs.org/jucs_16_13/toward_the_next_wave/jucs_16_13_1694_ [14] Dominique Guinard, Vlad Trifa, and Erik Wilde. 2010. A resource oriented 1719_pedrinaci.pdf architecture for the web of things. In Internet of Things (IOT), 2010. IEEE, 1–8. [34] Steffen Planthaber. 2015. Rocks new http-based API for robot control. In Proceed- http://ieeexplore.ieee.org/abstract/document/5678452/ ings of the RIC Project Day Workgroup "Framework & Standardization". RIC Project [15] Michael Hausenblas. 2009. Linked data applications. First Community Draft, DERI Day, March 19, Bremen (DFKI Documents, D), Vol. 15-01. Selbstverlag, 44–51. (2009). https://wtlab.um.ac.ir/images/e-library/linked_data/Linked%20Data% [35] Eric Prud’hommeaux, Jose Emilio Labra Gayo, and Harold Solbrig. 2014. Shape 20Applications.pdf expressions: an RDF validation and transformation language. In Proceedings [16] Huosheng Hu, Lixiang Yu, Pui Wo Tsui, and Quan Zhou. 2001. Internet-based of the 10th International Conference on Semantic Systems. ACM, 32–40. http: robotic systems for teleoperation. Assembly Automation 21, 2 (2001), 143–152. //dl.acm.org/citation.cfm?id=2660523 http://www.emeraldinsight.com/doi/pdf/10.1108/01445150110388513 [36] Partha Pratim Ray. 2016. Internet of Robotic Things: Concept, Technologies, and [17] Koji Kamei, Shuichi Nishio, Norihiro Hagita, and Miki Sato. 2012. Cloud net- Challenges. IEEE Access 4 (2016), 9489–9500. http://ieeexplore.ieee.org/abstract/ worked robotics. IEEE Network 26, 3 (2012), 28–34. http://dblp.uni-trier.de/db/ document/7805273/ journals/network/network26.html#KameiNHS12 [37] Leonard Richardson and Sam Ruby. 2008. RESTful web services. " O’Reilly Media, [18] B. Kehoe, S. Patil, P. Abbeel, and K. Goldberg. 2015. A Survey of Research Inc.". https://books.google.de/books?hl=de&lr=&id=XUaErakHsoAC& on Cloud Robotics and Automation. IEEE Transactions on Automation Science oi=fnd&pg=PP1&dq=Richardson+L,+Ruby+S+(2007)+RESTful+Web+ and Engineering 12, 2 (April 2015), 398–409. https://doi.org/10.1109/TASE.2014. Services.+O%27Reilly+Media,+Inc&ots=5keoGiuHsw&sig=KCGDIn0ps0S70f_ 2376492 OgLtcWsavP5M [19] Felix Leif Keppmann, Tobias Käfer, Steffen Stadtmüller, René Schubotz, and [38] Arthur G. Ryman, Arnaud Le Hors, and Steve Speicher. 2013. OSLC Resource Andreas Harth. 2014. High performance linked data processing for virtual reality Shape: A language for defining constraints on Linked Data. LDOW 996 (2013). environments. In Proceedings of the 2014 International Conference on Posters & http://ceur-ws.org/Vol-996/papers/ldow2013-paper-02.pdf Demonstrations Track-Volume 1272. CEUR-WS. org, 193–196. http://dl.acm.org/ [39] Steve Speicher, John Arwe, and Ashok Malhotra. 2015. Linked data platform 1.0. citation.cfm?id=2878502 W3C Recommendation, February 26 (2015). [20] Felix Leif Keppmann, Tobias Käfer, Steffen Stadtmüller, Rene Schubotz, and [40] Kenneth Taylor and Barney Dalton. 2000. Internet robots: A new robotics niche. Andreas Harth. 2014. Integrating highly dynamic RESTful linked data APIs in a IEEE Robotics & Automation Magazine 7, 1 (2000), 27–34. http://ieeexplore.ieee. virtual reality environment. In Mixed and Augmented Reality (ISMAR), 2014 IEEE org/abstract/document/833572/ International Symposium on. IEEE, 347–348. http://ieeexplore.ieee.org/abstract/ [41] Moritz Tenorth and Michael Beetz. 2013. KnowRob: A knowledge processing document/6948482/ infrastructure for cognition-enabled robots. The International Journal of Robotics [21] Holger Knublauch and Dimitris Kontokostas. 2017. Shapes Constraint Language Research 32, 5 (2013), 566–590. http://journals.sagepub.com/doi/abs/10.1177/ (SHACL). (2017). https://www.w3.org/TR/shacl/ 0278364913481635 [22] Anis Koubâa. 2014. A Service-Oriented Architecture for Virtualizing Robots in [42] Moritz Tenorth, Ulrich Klank, Dejan Pangercic, and Michael Beetz. 2011. Web- Robot-as-a-Service Clouds.. In ARCS. 196–208. https://books.google.de/books?hl= enabled robots. IEEE Robotics & Automation Magazine 18, 2 (2011), 58–68. http: de&lr=&id=U8O6BQAAQBAJ&oi=fnd&pg=PA196&dq=A+Service-Oriented+ //ieeexplore.ieee.org/abstract/document/5876223/ LIDARI’17, September 2017, Amsterdam, Netherlands René Schubotz et al. [43] M. Tenorth, A. C. Perzylo, R. Lafrenz, and M. Beetz. 2013. Representation and Exchange of Knowledge About Actions, Objects, and Environments in the RoboEarth Framework. IEEE Transactions on Automation Science and Engineering 10, 3 (July 2013), 643–651. https://doi.org/10.1109/TASE.2013.2244883 [44] Dominik Tomaszuk. 2017. RDF Validation: A Brief Survey. In Beyond Databases, Architectures and Structures. Towards Efficient Solutions for Data Analysis and Knowledge Representation (Communications in Computer and Information Science). Springer, Cham, 344–355. https://doi.org/10.1007/978-3-319-58274-0_28 [45] Russell Toris, Julius Kammerl, David V. Lu, Jihoon Lee, Odest Chadwicke Jenkins, Sarah Osentoski, Mitchell Wills, and Sonia Chernova. 2015. Robot Web Tools: Efficient messaging for cloud robotics. In 2015 IEEE/RSJ International Conference on Intelligent Robots and Systems (IROS). 4530–4537. https://doi.org/10.1109/IROS. 2015.7354021 [46] Hans Utz, Stefan Sablatnog, Stefan Enderle, and Gerhard Kraetzschmar. 2002. Miro-middleware for mobile robot applications. IEEE Transactions on Robotics and Automation 18, 4 (2002), 493–497. http://ieeexplore.ieee.org/abstract/document/ 1044362/ [47] Joachim Van Herwegen, Ruben Verborgh, Erik Mannens, and Rik Van de Walle. 2015. Query execution optimization for clients of triple pattern fragments. In European Semantic Web Conference. Springer, 302–318. http://link.springer.com/ chapter/10.1007/978-3-319-18818-8_19 [48] Ruben Verborgh, Andreas Harth, Maria Maleshkova, Steffen Stadtmüller, Thomas Steiner, Mohsen Taheriyan, and Rik Van de Walle. 2014. Survey of semantic de- scription of rest APIs. In rest: Advanced Research Topics and Practical Applications. Springer, 69–89. http://link.springer.com/chapter/10.1007/978-1-4614-9299-3_5 [49] Ruben Verborgh, Olaf Hartig, Ben De Meester, Gerald Haesendonck, Laurens De Vocht, Miel Vander Sande, Richard Cyganiak, Pieter Colpaert, Erik Mannens, and Rik Van de Walle. 2014. Low-cost queryable linked data through triple pattern fragments. In Proceedings of the 2014 International Conference on Posters & Demonstrations Track-Volume 1272. CEUR-WS. org, 13–16. http://dl.acm.org/ citation.cfm?id=2878457 [50] Ruben Verborgh, Erik Mannnens, and Rik Van de Walle. 2015. Bottom- up Web apis with self-descriptive responses. In Proceedings of the First Karlsruhe Service Summit Workshop-Advances in Service Research, Karl- sruhe, Germany, February 2015, Vol. 7692. KIT Scientific Publishing, 143. https://books.google.de/books?hl=de&lr=&id=z24GBwAAQBAJ&oi=fnd&pg= PA143&ots=QK-W8Fpc0b&sig=-JMS6Sa4fJbqD4592PnG64woRUo [51] Ruben Verborgh, Miel Vander Sande, Pieter Colpaert, Sam Coppens, Erik Mannens, and Rik Van de Walle. 2014. Web-Scale Querying through Linked Data Fragments.. In LDOW. https://www.researchgate.net/profile/Ruben_ Verborgh/publication/264274086_Web-Scale_Querying_through_Linked_ Data_Fragments/links/53f498b10cf2fceacc6e918d.pdf [52] Ruben Verborgh, Miel Vander Sande, Olaf Hartig, Joachim Van Herwegen, Lau- rens De Vocht, Ben De Meester, Gerald Haesendonck, and Pieter Colpaert. 2016. Triple Pattern Fragments: A low-cost knowledge graph interface for the Web. Web Semantics: Science, Services and Agents on the World Wide Web 37 (2016), 184–206. http://www.sciencedirect.com/science/article/pii/S1570826816000214 [53] Markus Waibel, Michael Beetz, Javier Civera, Raffaello D’Andrea, Jos Elfring, Dorian Gálvez-López, Kai Häussermann, Rob Janssen, J.M.M. Montiel, Alexander Perzylo, Björn Schieçle, Moritz Tenorth, Oliver Zweigle, and René De Molen- graft. 2011. RoboEarth. IEEE Robotics & Automation Magazine 18, 2 (June 2011), 69–82. https://doi.org/10.1109/MRA.2011.941632 [54] Erik Wilde and Michael Hausenblas. 2009. RESTful SPARQL? You name it!: aligning SPARQL with REST and resource orientation. In WEWST ’09. ACM Press, 39–43. https://doi.org/10.1145/1645406.1645412 [55] Oliver Zweigle, René van de Molengraft, Raffaello d’Andrea, and Kai Häusser- mann. 2009. RoboEarth: connecting robots worldwide. In Proceedings of the 2nd International Conference on Interaction Sciences: Information Technology, Culture and Human. ACM, 184–191. http://dl.acm.org/citation.cfm?id=1655958