I need to represent sentences in RDF format.
In other words "John likes coke" would be automatically represented as:
Subject : John
Predicate : Likes
Object : Coke
Does anyone know where I should start? Are there any programs which can do this automatically or would I need to do everything from scratch?
Definition: An RDF Document is a serialization of an RDF Graph into a concrete syntax. Definition: An RDF/XML Document is an RDF Document written in the XML syntax for RDF as defined in this document.
An RDF triple is conventionally written in the order subject, predicate, object. The set of nodes of an RDF graph is the set of subjects and objects of triples in the graph. It is possible for a predicate IRI to also occur as a node in the same graph. IRIs, literals and blank nodes are collectively known as RDF terms .
RDF Triple is an actual expression that defines a way in which you can represent a relationship between objects. There are three parts to a triple: Subject, Predicate and Object (typically written in the same order). A predicate relates subject to object.
It looks like you want the typed dependencies of a sentence, e.g. for John likes coke
:
nsubj(likes-2, John-1)
dobj(likes-2, coke-3)
I'm not aware of any dependency parser that directly produces RDF. However, many of them produce parses in a standardized tab limited representation known as CoNLL-X, and it shouldn't be too hard to convert from CoNLL-X to RDF.
Open Source Dependency parsers
There are a number of parsers to choose from that extract typed dependencies, including the following state-of-art open source options:
The Stanford Parser includes a pre-trained model for parsing English. To get typed dependencies you'll need to use the flag -outputFormat typedDependencies
.
For the MaltParser you can download an English model here.
The MSTParser includes a small 200 sentence English training set that you can use to create you're own English parsing model. However, training on this little data will hurt the accuracy of the resulting parser. So, if you decide to use this parser, you are probably better off using the pretrain model available here.
All of the pretrained models linked above produce parses according to the Stanford Dependency formalism (ACL paper, and manual).
Of these three, the Stanford Parser is the most accurate. The MaltParser is the fastest, with some configurations of this package being able to parse 1800 sentences in only 8 seconds.
One option is to use output from Link Parser, available under a GPL-compatible license. You can define a translation layer between these outputs and your RDF nodes as needed.
Check out this demo on your "John likes coke" example!
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With