This document describes work on rapidly integrating web APIs into the linked data cloud. The researchers developed techniques for building semantic models of APIs, representing API descriptions in RDF, and creating linked APIs that can be invoked using RDF. They evaluated their approach on the Geonames API, generating a semantic model and linked description for several Geonames services in an average of 4 minutes per service. The work aims to help expose more web APIs as linked data to facilitate discovery and composition.
A Graph-Based Approach to Learn Semantic Descriptions of Data SourcesMohsen Taheriyan
油
The document presents a new graph-based approach to learn semantic descriptions of data sources. It constructs a graph from existing source models in a domain, and leverages the relationships in this graph to generate candidate semantic models for a new source, by mapping its semantic types to the graph and computing minimal subgraphs. This allows the approach to exploit common patterns across source models for automating the learning of semantic descriptions.
際際滷s of my "Open Innovation in Software Means Open Source Software" talk, OSS Watch, Oxford Dec.12th, 2009 (http://www.oss-watch.ac.uk/events/2009-12-07_business/programme.xml). Also at http://transfersummit.com/programme/60 and accompanying article on the H online, http://x42.ch/03.10.01
際際滷s of my presentation at TransferSummit 2010, "Open innovation in software means Open Source", http://transfersummit.com/programme/60 . See accompanying article on the H online, http://x42.ch/03.10.01
Presentation give on the Mobile Campus Assistant software and MyMobileBristol project at "Open Source Junction: cross-platform mobile apps", 30 March 2011, Trinity College, Oxford
EventMedia Live: Exploring Events Connections in Real-Time to Enhance ContentRaphael Troncy
油
"EventMedia Live: Exploring Events Connections in Real-Time to Enhance Content" presented at the Semantic Web Challenge, Open Track, of the 11th International Semantic Web Conference, Boston, USA, November 2012
These slides explain (1) the motivation for using RDFa, for embedding structured data on web pages, (2) RDF as the foundation of RDFa, and (3) RDFa through examples.
Web services provide programmatic interfaces to online services and tools, allowing for machine-to-machine communication across the web. They have become widely used in the life sciences, with major providers like EMBL-EBI, DDBJ, and NCBI offering hundreds of services. However, ensuring the sustainability, usability, and reliability of web services remains an ongoing challenge. Catalogs aim to help users discover and understand available services, but require community involvement to maintain accurate and up-to-date information.
The project aims to integrate local area time and location sensitive data for delivery to mobile devices. It is a 12 month project funded by JISC in collaboration with Bristol City Council and other third parties. The project supports a 'beta' mobile service at m.bristol.ac.uk, extending software from a previous Mobile Campus Assistant project. Next steps include further system integrations, user experience workshops, and discussions with the Council about their data.
Open innovation in software means Open Source (2011 remix)Bertrand Delacretaz
油
This document discusses open innovation and open source software. Open innovation means using both internal and external ideas and paths to market to advance technology. Open source refers to meritocratic communities that use open processes like open code and crowdsourcing. Open innovation and open source are complementary as innovation benefits from fast feedback, which open source provides through tools like issue trackers, mailing lists and real-time collaboration. Concrete examples of open source projects that enable fast feedback and collaboration are discussed.
This document provides an overview of Shubhra Kar's presentation on using Node.js to build APIs and hyperscale the API economy. The presentation discusses using Node.js for mobile/omni-channel backends, high performance ESBs, and IoT. It also covers why Node.js is well-suited for APIs, which Node.js framework to choose, design patterns, and how to code and deploy an API in 10 minutes. The document includes graphs comparing Node.js performance to other solutions and discusses trends around microservices and decomposing monolithic APIs.
This document discusses using RESTful web services and resource-oriented architecture for geospatial data and workflows. It provides examples of how NASA uses hyperspectral imagery from satellites to detect wildfires and task sensors. It also discusses the Open Geospatial Consortium's standards for geospatial web services and a potential opportunity to transition from SOAP-based services to RESTful services and resource-oriented architecture to improve interoperability across organizations.
Aggregating Social Media for Enhancing Conference ExperiencesHouda khrouf
油
The document describes a system called Confomaton that aggregates social media to enhance conference experiences. Confomaton collects media items and event data from various sources, models the data semantically, and reconciles items to events in real-time. It provides a web interface and APIs to browse conferences and associated media. Future work aims to integrate more media sources, enrich event descriptions, refine reconciliation, and improve the user interface performance.
This document discusses RDF stream processing and the role of semantics. It begins by outlining common sources of streaming data on the internet of things. It then discusses challenges of querying streaming data and existing approaches like CQL. Existing RDF stream processing systems are classified based on their query capabilities and use of time windows and reasoning. The role of linked data principles and HTTP URIs for representing streaming sensor data is discussed. Finally, requirements for reactive stream processing systems are outlined, including keeping data moving, integrating stored and streaming data, and responding instantaneously. The document argues that building relevant RDF stream processing systems requires going beyond existing requirements to address data heterogeneity, stream reasoning, and optimization.
Getting started with entity framework revised 9 09manisoft84
油
- LINQ to SQL provides a lighter-weight ORM focused only on SQL Server, while Entity Framework supports multiple databases.
- LINQ to SQL uses a code-first approach and only supports simple 1-to-1 mapping, while Entity Framework uses a model-first approach and supports more complex mapping scenarios.
- Entity Framework has richer modeling capabilities through the Entity Data Model (EDM), while LINQ to SQL has more limited modeling.
- Entity Framework is the recommended Microsoft ORM going forward, while LINQ to SQL is considered a predecessor and will be maintained but not actively developed.
CocoaPods is a dependency manager for Objective-C projects. It automates the process of adding third-party libraries to projects by resolving dependencies, downloading source code, and generating an Xcode project. It aims to simplify library integration and management. The future of CocoaPods includes improving the command line experience, supporting multiple targets and configurations, translating API documentation for RubyMotion, and growing library availability.
The document provides 10 tips for new developers working with Alfresco. It discusses the key technologies used in Alfresco including Java versions, Spring Framework, Angular, SOLR, BPM, REST APIs, Docker, and Kubernetes. For each tip it highlights the relevant technologies and concepts a new developer should understand when working with Alfresco.
GraphQL Will Do To REST What JSON Did To XMLRoy Derks
油
Why GraphQL will become the new standard for accessing external data in your React Native app. I will show how using GraphQL instead of REST services the development process becomes even more declarative as GraphQL will take away the (imperative) hassle of tying data from multiple endpoints together. This will increase the level of complexity in React Native development, while also increasing the performance of the application.
Building Node.js based APIs in minutes. Achieve full-stack JavaScript, Offline Sync, Geolocation, REST API / JSON, ORM and API Management in open source. Write your own connectors, work on express.js. Create MEAN stack applications connecting Angular to Node to MongoDB. Presented at the Connect.js conference in Atlanta
A Provenance-Aware Linked Data Application for Trip Management and OrganizationBoris Villaz坦n-Terrazas
油
A Provenance-Aware Linked Data Application for Trip Management and Organization, presented at the Triplification Challenge, I-Semantics 2011.
We present, an application for exploiting, managing and organizing Linked Data in the domain of news and blogs about travelling. El Viajero makes use of several heterogeneous datasets to help users to plan future trips, and relies on the Open Provenance Model for modelling the provenance information of the resources.
Node.js is a JavaScript runtime environment built on Chrome's V8 JavaScript engine. It allows JavaScript to be used for server-side scripting and is primarily used for real-time web applications and extensive I/O applications. Node.js uses an event-driven, non-blocking I/O model that makes it lightweight and efficient for data-intensive real-time applications that run across distributed devices.
The document introduces a semantic wiki that aims to reduce the steep learning curve of developing and deploying semantic web applications. The semantic wiki allows for easy publishing and smart data propagation for end users, as well as fast prototyping in the browser and lightweight concept modeling for developers. It integrates semantic technologies like RDF, OWL, and SPARQL to enable knowledge management, data organization, data sharing, personalization, privacy protection, and provenance tracking within wikis. Challenges addressed include ontology modeling, relational modeling with rules, semantic querying across multiple wikis, and annotation extensions.
Realtime Analytics with MongoDB Counters (mongonyc 2012)Scott Hernandez
油
This document discusses pre-aggregating data with counters in MongoDB to enable dashboard-style reports. It involves defining metrics and aggregations upfront, and using the $inc operator to increment values in aggregation collections during write operations. This allows generating real-time aggregated data without requiring map-reduce or the aggregation framework, providing better performance for dashboard queries.
LA RubyConf 2009 Waves And Resource-Oriented ArchitectureDan Yoder
油
Resource-Oriented Architecture (ROA) is an architectural style based on REST constraints that solves problems of past distributed computing approaches like RPC, CORBA, and SOA. It defines resources that can be manipulated through HTTP methods like GET, PUT, POST, and DELETE. The Waves framework makes it easy to build ROA applications in Ruby by providing a DSL for defining resources and handling HTTP requests through a uniform interface.
These slides were presented as part of a W3C tutorial at the CSHALS 2010 conference (http://www.iscb.org/cshals2010). The slides are adapted from a longer introduction to the Semantic Web available at http://www.slideshare.net/LeeFeigenbaum/semantic-web-landscape-2009 .
A PDF version of the slides is available at http://thefigtrees.net/lee/sw/cshals/cshals-w3c-semantic-web-tutorial.pdf .
More Related Content
Similar to Rapidly Integrating Services into the Linked Data Cloud (20)
Open innovation in software means Open Source (2011 remix)Bertrand Delacretaz
油
This document discusses open innovation and open source software. Open innovation means using both internal and external ideas and paths to market to advance technology. Open source refers to meritocratic communities that use open processes like open code and crowdsourcing. Open innovation and open source are complementary as innovation benefits from fast feedback, which open source provides through tools like issue trackers, mailing lists and real-time collaboration. Concrete examples of open source projects that enable fast feedback and collaboration are discussed.
This document provides an overview of Shubhra Kar's presentation on using Node.js to build APIs and hyperscale the API economy. The presentation discusses using Node.js for mobile/omni-channel backends, high performance ESBs, and IoT. It also covers why Node.js is well-suited for APIs, which Node.js framework to choose, design patterns, and how to code and deploy an API in 10 minutes. The document includes graphs comparing Node.js performance to other solutions and discusses trends around microservices and decomposing monolithic APIs.
This document discusses using RESTful web services and resource-oriented architecture for geospatial data and workflows. It provides examples of how NASA uses hyperspectral imagery from satellites to detect wildfires and task sensors. It also discusses the Open Geospatial Consortium's standards for geospatial web services and a potential opportunity to transition from SOAP-based services to RESTful services and resource-oriented architecture to improve interoperability across organizations.
Aggregating Social Media for Enhancing Conference ExperiencesHouda khrouf
油
The document describes a system called Confomaton that aggregates social media to enhance conference experiences. Confomaton collects media items and event data from various sources, models the data semantically, and reconciles items to events in real-time. It provides a web interface and APIs to browse conferences and associated media. Future work aims to integrate more media sources, enrich event descriptions, refine reconciliation, and improve the user interface performance.
This document discusses RDF stream processing and the role of semantics. It begins by outlining common sources of streaming data on the internet of things. It then discusses challenges of querying streaming data and existing approaches like CQL. Existing RDF stream processing systems are classified based on their query capabilities and use of time windows and reasoning. The role of linked data principles and HTTP URIs for representing streaming sensor data is discussed. Finally, requirements for reactive stream processing systems are outlined, including keeping data moving, integrating stored and streaming data, and responding instantaneously. The document argues that building relevant RDF stream processing systems requires going beyond existing requirements to address data heterogeneity, stream reasoning, and optimization.
Getting started with entity framework revised 9 09manisoft84
油
- LINQ to SQL provides a lighter-weight ORM focused only on SQL Server, while Entity Framework supports multiple databases.
- LINQ to SQL uses a code-first approach and only supports simple 1-to-1 mapping, while Entity Framework uses a model-first approach and supports more complex mapping scenarios.
- Entity Framework has richer modeling capabilities through the Entity Data Model (EDM), while LINQ to SQL has more limited modeling.
- Entity Framework is the recommended Microsoft ORM going forward, while LINQ to SQL is considered a predecessor and will be maintained but not actively developed.
CocoaPods is a dependency manager for Objective-C projects. It automates the process of adding third-party libraries to projects by resolving dependencies, downloading source code, and generating an Xcode project. It aims to simplify library integration and management. The future of CocoaPods includes improving the command line experience, supporting multiple targets and configurations, translating API documentation for RubyMotion, and growing library availability.
The document provides 10 tips for new developers working with Alfresco. It discusses the key technologies used in Alfresco including Java versions, Spring Framework, Angular, SOLR, BPM, REST APIs, Docker, and Kubernetes. For each tip it highlights the relevant technologies and concepts a new developer should understand when working with Alfresco.
GraphQL Will Do To REST What JSON Did To XMLRoy Derks
油
Why GraphQL will become the new standard for accessing external data in your React Native app. I will show how using GraphQL instead of REST services the development process becomes even more declarative as GraphQL will take away the (imperative) hassle of tying data from multiple endpoints together. This will increase the level of complexity in React Native development, while also increasing the performance of the application.
Building Node.js based APIs in minutes. Achieve full-stack JavaScript, Offline Sync, Geolocation, REST API / JSON, ORM and API Management in open source. Write your own connectors, work on express.js. Create MEAN stack applications connecting Angular to Node to MongoDB. Presented at the Connect.js conference in Atlanta
A Provenance-Aware Linked Data Application for Trip Management and OrganizationBoris Villaz坦n-Terrazas
油
A Provenance-Aware Linked Data Application for Trip Management and Organization, presented at the Triplification Challenge, I-Semantics 2011.
We present, an application for exploiting, managing and organizing Linked Data in the domain of news and blogs about travelling. El Viajero makes use of several heterogeneous datasets to help users to plan future trips, and relies on the Open Provenance Model for modelling the provenance information of the resources.
Node.js is a JavaScript runtime environment built on Chrome's V8 JavaScript engine. It allows JavaScript to be used for server-side scripting and is primarily used for real-time web applications and extensive I/O applications. Node.js uses an event-driven, non-blocking I/O model that makes it lightweight and efficient for data-intensive real-time applications that run across distributed devices.
The document introduces a semantic wiki that aims to reduce the steep learning curve of developing and deploying semantic web applications. The semantic wiki allows for easy publishing and smart data propagation for end users, as well as fast prototyping in the browser and lightweight concept modeling for developers. It integrates semantic technologies like RDF, OWL, and SPARQL to enable knowledge management, data organization, data sharing, personalization, privacy protection, and provenance tracking within wikis. Challenges addressed include ontology modeling, relational modeling with rules, semantic querying across multiple wikis, and annotation extensions.
Realtime Analytics with MongoDB Counters (mongonyc 2012)Scott Hernandez
油
This document discusses pre-aggregating data with counters in MongoDB to enable dashboard-style reports. It involves defining metrics and aggregations upfront, and using the $inc operator to increment values in aggregation collections during write operations. This allows generating real-time aggregated data without requiring map-reduce or the aggregation framework, providing better performance for dashboard queries.
LA RubyConf 2009 Waves And Resource-Oriented ArchitectureDan Yoder
油
Resource-Oriented Architecture (ROA) is an architectural style based on REST constraints that solves problems of past distributed computing approaches like RPC, CORBA, and SOA. It defines resources that can be manipulated through HTTP methods like GET, PUT, POST, and DELETE. The Waves framework makes it easy to build ROA applications in Ruby by providing a DSL for defining resources and handling HTTP requests through a uniform interface.
These slides were presented as part of a W3C tutorial at the CSHALS 2010 conference (http://www.iscb.org/cshals2010). The slides are adapted from a longer introduction to the Semantic Web available at http://www.slideshare.net/LeeFeigenbaum/semantic-web-landscape-2009 .
A PDF version of the slides is available at http://thefigtrees.net/lee/sw/cshals/cshals-w3c-semantic-web-tutorial.pdf .
Rapidly Integrating Services into the Linked Data Cloud
1. Information Sciences Institute
Rapidly Integrating Services into the Linked
Data Cloud
Mohsen Taheriyan, Craig Knoblock,
Pedro Szekely, Jose Luis Ambite
11th International Semantic Web Conference (ISWC 2012)
Boston, USA
3. Not in dbpedia.org
Current temperature 73属F
Wind
Humidity
10 mph SW
51%
Live weather
Dew Point 54属
3
4. Not in dbpedia.org
Current temperature 73属F
Wind 10 mph SW
Humidity 51%
Dew Point 54属
Events Transparent Cities 5/1/2012 REDCAT
Events
Theater
Saving Our Sons : A Community
Conversatio
4
5. Not in dbpedia.org
Current temperature 73属F
Wind 10 mph SW
Humidity 51%
Dew Point 54属
Events Transparent Cities 5/1/2012 REDCAT Theater
Saving Our Sons : A Community Conversatio
Twitter Feed Los Angeles becomes the largest U.S. city to ban..
Plastic grocery bags will now be banned in Live Twitter Feed
5
6. The information is
available in Web APIs
Current temperature 73属F
Wind 10 mph SW
Humidity 51%
Dew Point 54属
Events Transparent Cities 5/1/2012 REDCAT Theater
Saving Our Sons : A Community Conversatio
Twitter Feed Los Angeles becomes the largest U.S. city to ban..
Plastic grocery bags will now be banned in
6
7. Web APIs
7000 APIs: growth all times versus last year
API Growth, 08/23/2012
2011 2012
65 RDF
(Oct 2012)
JSON XML
API Protocols, 02/10/2012
API Data Formats, 03/08/2011
7
9. Motivation Example
For most of the Web APIs, only a textual description is available
neighbourhood?
RDF Input
<http://sws.geonames.org/5145067/>
a gn:Feature ;
wgs84:lat "40.78343" ;
wgs84:long "-73.96625" .
Invocation Example
9
10. Motivation Example
For most of the Web APIs, only a textual description is available
Most of the Web APIs do not consume or produce linked data (RDF)
<http://sws.geonames.org/5145067/>
RDF Input
<http://sws.geonames.org/5145067/>
Linked RDF
gn:neighbour [
a gn:Feature ;
a gn:Feature ; gn:name "Woodside";
wgs84:lat "40.78343" ;
gn:nearby [
wgs84:long "-73.96625" .
a gn:Feature ; gn:name -Queens";
gn:parentCountry [
Lowering
Lifting
Invocation Example
XML Response
10
11. Outline
Rapidly Integrating APIs with the LD
Building API Semantic Model
Representing API Descriptions
Building Linked APIs
Evaluation
Related Work
Conclusion & Future Work
12. Outline
Rapidly Integrating APIs with the LD
Building API Semantic Model
Representing API Descriptions
Building Linked APIs
Evaluation
Related Work
Conclusion & Future Work
13. The Semantic Model
wgs84 lat fcode nearb
geonames y
neighbour
long SpatialThing Feature
SubClass
Data Property parentFeature
Object Property alt countryCode name parentCountry
http://api.geonames.org/neighbourhood?
lat=40.78343&lng=-73.96625&username=demo
wgs84:lat wgs84:long
<geonames>
Feature Feature <neighbourhood>
gn:name
gn:neighbour <name>Central Park</name>
gn:nearby
gn:name
<city>New York City-Manhattan</city>
<countryCode>US</countryCode>
Feature
gn:countryCode <countryName>United States</countryName>
gn:parentCountry gn:name </neighbourhood>
</geonames>
Feature
14
14. The Semantic Model
wgs84 lat fcode nearb
geonames y
neighbour
long SpatialThing Feature
SubClass
Data Property parentFeature
Object Property alt countryCode name parentCountry
http://api.geonames.org/neighbourhood?
lat=40.78343&lng=-73.96625&username=demo
wgs84:lat wgs84:long
v2 <geonames>
Feature Feature <neighbourhood>
gn:name
gn:neighbour <name>Central Park</name>
v1 gn:nearby
gn:name
<city>New York City-Manhattan</city>
<countryCode>US</countryCode>
v3 Feature
gn:countryCode <countryName>United States</countryName>
gn:parentCountry gn:name </neighbourhood>
</geonames>
Feature
v4 15
15. Semi-Automatically Modeling APIs
Invoking
APIs
Examples of
Annotating
API Request
URLs
Karma Attributes
Previous
Modeling Work on
Modeling
Extracting Static
Domain Relationships Sources
Ontology
API
Semantic
Model
16
16. Invoking APIs
User provides examples of the API request URLs
Karma extracts the input values from the sample request URLs
Karma invokes the API and extracts the output attributes from the
API response (XML/JSON)
Examples of API
Input Attributes Output Attributes
Invocation URLs
17
17. Annotating Inputs and Outputs
[Goel, Knoblock, Lerman, 2012]
A CRF-based model to assign a Semantic Type to each
column from its data
Semantic Type lat
long alt
Ontology Class SpatialThing nearb
y
Data Property + Domain name
neighbour
parentFeature
Feature
(wgs84:lat, gn:Feature) parentCountry
countryCode fcode
SubClass
Data Property
Object Property
wgs84
geonames
(wgs84:long,
(gn:name, gn:Feature)
gn:Feature)
(gn:countryCode, gn:Feature) 18
18. Extracting Relationships
[Knoblock et al., ESWC 2012]
Construct a graph from semantic types and ontology graph
Select minimal tree that connects all semantic types
A customized Steiner tree algorithm
nearby
SpatialThing neighbour
parentFeature
parentCountry
wgs84:lat
gn:name
Feature Feature
wgs84:long
gn:countryCode
Feature Feature
gn:name gn:name
19. Extracting Relationships
[Knoblock et al., ESWC 2012]
Construct a graph from semantic types and ontology graph
Select minimal tree that connects all semantic types
A customized Steiner tree algorithm
nearby
SpatialThing neighbour
parentFeature
parentCountry
wgs84:lat
neighbour
gn:name
Feature Feature
wgs84:long
nearby
gn:countryCode
Feature Feature
parentCountry
gn:name gn:name
21. Outline
Rapidly Integrating APIs with the LD
Building API Semantic Model
Representing API Descriptions
Building Linked APIs
Evaluation
Related Work
Conclusion & Future Work
23. Example: Service Description
atom1 .../neighbourhood?lat={p1}&... GET neighbourhood
v1 hasMethod
hasAddress hasName
atom5
km:Service
http://<karma server>/services/ km:Output
atom2
atom3
v2
5C5CB6AB-1689-4A96-0B70- output
atom4
96C6A54F3D70#
hasModel hasAttribute
km:Input
input km:Model km:Attribute
outputModel out_name
hasAttribute hasModel name
hasAtom
arg2
lat
km:Attribute km:Model
inputModel swrl:PAtom property gn:name
p1 in_lat
atom4 arg1 swrl:Variable
hasAtom
arg2 v2
wgs84:lat arg1
swrl:CAtom
property
swrl:PAtom atom3 class gn:Feature
swrl:Variable arg1 atom2 arg2
v1
arg1 swrl:CAtom swrl:PAtom gn:neighbour
property
gn:Feature class atom1 atom5
links the output to the input
arg1 by neighbour relationship
24
24. Service Discovery
Find services that return the neighbor feature
given the latitude and longitude
SELECT ?s WHERE {
?s km:hasInput [km:hasAttribute ?i1, ?i2].
?s km:hasOutput [km:hasAttribute ?o1].
?s km:hasInput [km:hasModel [km:hasAtom
[swrl:classPredicate gn:Feature; swrl:arg1 ?f1],
[swrl:propertyPredicate wgs84:lat; swrl:arg1 ?f1; swrl:arg2 ?i1],
[swrl:propertyPredicate wgs84:long; swrl:arg1 ?f1; swrl:arg2 ?i2]]].
?s km:hasOutput [km:hasModel [km:hasAtom
[swrl:classPredicate gn:Feature; swrl:arg1 ?f2],
[swrl:propertyPredicate gn:neighbour; swrl:arg1 ?f1; swrl:arg2 ?f2]]]}
27
25. Outline
Rapidly Integrating APIs with the LD
Building API Semantic Model
Representing API Descriptions
Building Linked APIs
Evaluation
Related Work
Conclusion & Future Work
27. Lowering
:inputModel a km:Model; <http://sws.geonames.org/5145067/>
km:hasAtom a gn:Feature ;
[ a swrl:ClassAtom ; wgs84:lat "40.74538" ;
swrl:argument1 :v1 ; wgs84:long "-73.90541" .
swrl:classPredicate gn:Feature ] ;
km:hasAtom Input Data (RDF)
[ a swrl:IndividualPropertyAtom ;
swrl:argument1 :v1 ;
Attribute Value
swrl:argument2 :in_lat ;
swrl:propertyPredicate wgs84:lat ] ; in_lat 40.74538
... in_lng -73.90541
:in_lat a km:Attribute;
km:hasName "lat" ; Attribute Value GroundedIn
hrests:isGroundedIn "p1
... in_lat 40.74538 p1
in_lng -73.90541 p2
...
hrests:hasAddress
http://api.geonames.org/neighbourhood? http://api.geonames.org/neighbourhood?
lat={p1}&lng={p2} lat40.74538&lng=-73.90541
Invocation URL
API Description (RDF)
31
28. Lifting
:out_countryCode a km:Attribute; <geonames>
API Response XML
km:hasName countryCode" ; <neighbourhood>
.... <countryCode>US</countryCode>
<countryName>United States</countryName>
<city>New York City-Queens</city>
:outputModel a km:Model; <name>Woodside</name>
km:hasAtom ...
[ a swrl:IndividualPropertyAtom ; </neighbourhood>
swrl:argument1 :v1 ; </geonames>
swrl:argument2 :v2;
swrl:propertyPredicate Attribute Value URI
gn:neighbour ] ;
countryCode US :out_countryCode
km:hasAtom
[ a swrl:ClassAtom ; countryName United States :out_countryName
swrl:argument1 :v2 ; city ...-Queens :out_city
swrl:classPredicate gn:Feature ] ;
name Woodside :out_name
km:hasAtom
[ a swrl:IndividualPropertyAtom ;
<http://sws.geonames.org/5145067/>
Linked Output
swrl:argument1 :v2 ; gn:neighbour [
swrl:argument2 :out_name; a gn:Feature ; gn:name "Woodside";
swrl:propertyPredicate gn:name ] ; gn:nearby [
a gn:Feature ; gn:name -Queens";
gn:parentCountry [
API Description (RDF)
33
29. Outline
Rapidly Integrating APIs with the LD
Building API Semantic Model
Representing API Descriptions
Building Linked APIs
Evaluation
Related Work
Conclusion & Future Work
30. Evaluation
Geonames API #Examples #Columns Time (min)
neighbourhood 3 10 6
neighbours 2 9 5
children 2 10 3
sibling 1 9 3
ocean 2 3 1
findNearby 3 11 3
findNearbyPostalCodes 3 11 7
findNearbyPOIsOSM 3 7 3
findNearestAddress 3 14 6
findNearestIntersectionOSM 3 8 3
postalCodeCountryInfo 1 5 2
Total 26 97 42
Average 4 minutes to build a linked API
35
31. Related Work
Linked Services [Pedrinaci & Domingue, 2010]
Annotates inputs and outputs by concepts from
ontologies
Publishes service descriptions into the LOD cloud using
Minimal Service Model (MSM)
Cannot represent relationships between service
attributes
Linked Open Services (LOS) [Krummenacher & Norton & Marte, 2010]
, Linked Data Services (LIDS) [Speiser & Harth, 2010]
SPARQL graph patterns to describe inputs and outputs
Service discovery is not straightforward
RESTdesc [Verborgh et at, 2012]
N3 logical rules to capture API functionality
36
32. Related Work
Linked Services [Pedrinaci & Domingue, 2010]
Annotates inputs and outputs by concepts from
ontologies
Publishes service descriptions into the LOD cloud using
Minimal Service Model (MSM)
Karma semi-automatically builds service
Cannot represent relationships between service
attributes
descriptions and the modeling process does not
Linkedrequire expertise in SW technologies
Open Services (LOS) [Krummenacher & Norton & Marte, 2010]
, Linked Data Services (LIDS) [Speiser & Harth, 2010]
SPARQL graph patterns to describe inputs and outputs
Service discovery is not straightforward
RESTdesc [Verborgh et at, 2012]
N3 logical rules to capture API functionality
37
33. Discussion
Rapidly build rich semantic models of services
Publish service descriptions into the LD cloud
Provide strong support for service discovery
and composition
Build linked APIs that consume and produce
linked data
38
34. Future Work
Apply our approach on REST-like URLs
http://www.ex.com/weather/CA/Los Angeles
Compose data and services in Karma
S1(address street, city, state, zipcode,) Composition
S2(city, state temperature, windspeed, )
S3(zipcode, distance hotel, ranking)
39
35. More Information
More information/papers/software/demos:
http://www.isi.edu/integration/karma/
Contact
Mohsen Taheriyan: mohsen@isi.edu
Craig Knoblock: knoblock@isi.edu
Pedro Szekely: pszekely@isi.edu
Jose Luis Ambite: ambite@isi.edu
40
Editor's Notes
#8: http://blog.programmableweb.com/2012/08/23/7000-apis-twice-as-many-as-this-time-last-year/http://www.bogotobogo.com/WebTechnologies/OpenAPI_RESTful.phphttp://www.webmonkey.com/2011/03/thousand-of-apis-paint-a-bright-future-for-the-web/Only 69 APIs use RDF as data format (According to Programmable Web API Directory, Oct 20, 2012)Not all data sources will be published as fully materialized datasetsReasonsData is changing constantly (e.g., sensor data, stock quotes)Data is calculated based on infinitely many inputs (e.g., route between two geographical locations)Provider does not want arbitrary access (e.g., flight ticket prices, social networks)
#19: Steiner minimal tree (SMT) G=(V,E) , S V, c: E (S: Steiner Nodes)Shortest network connecting vertices of SApproximation Alg. [Kou & Markowsky, 1981]O(|V|2|S|) , Approximation Ratio: less than 2Approximation ratio bounded by 2(1 1/l), where l is the number of leaves in the optimal Steiner tree.
#20: Steiner minimal tree (SMT) G=(V,E) , S V, c: E (S: Steiner Nodes)Shortest network connecting vertices of SApproximation Alg. [Kou & Markowsky, 1981]O(|V|2|S|) , Approximation Ratio: less than 2Approximation ratio bounded by 2(1 1/l), where l is the number of leaves in the optimal Steiner tree.
#23: A simple RDF vocabulary that represents both syntax and semantic of APIsKarma automatically generates service descriptions and stores them in a triple store called Linked API RepositoryService descriptions can be published into the Linked Data cloud
#40: datasets of this paper:http://isi.edu/integration/karma/data/iswc2012
#42: In the second step, instead of selecting MST ((v1, v4) (v1, v2)- (v2-v3)), if we select another MST like ((v1, v4) (v1, v2)- (v1-v3)), we would get another Steiner tree as result.MST = Minimum Spanning Tree