-
Notifications
You must be signed in to change notification settings - Fork 356
API
This page has not yet been updated for ConceptNet 5.3.
There are three methods for accessing data through the ConceptNet 5 API: lookup, search, and association.
- Lookup is for when you know the URI of an object in ConceptNet, and want to see a list of edges that include it.
- Search finds a list of edges that match certain criteria.
- Association is for finding concepts similar to a particular concept or a list of concepts.
To look up an object by its URI, go to http://conceptnet5.media.mit.edu/data/5.2 followed by the URI. For example, the concept "toast", with URI /c/en/toast, can be found at: http://conceptnet5.media.mit.edu/data/5.2/c/en/toast
You can set the following GET arguments to modify the returned results:
- limit = n: change the number of results from the default of 50.
- offset = n: skip the first n results.
- filter=core: filter the returned results to only those in the ConceptNet 5 Core (no Creative Commons ShareAlike-licensed results).
In English, the terms you supply in URIs should be normalized to their WordNet roots, and in any language, the terms should have spaces replaced by underscores. The conceptnet5.nodes.normalized_concept_name
function applies these transformation.
To get the 6th through 10th highest-weight edges for "toast", you could go to: http://conceptnet5.media.mit.edu/data/5.2/c/en/toast?offset=5&limit=5
To see 50 statements submitted by user "rspeer", go to: http://conceptnet5.media.mit.edu/data/5.2/s/contributor/omcs/rspeer
The base URL for searching is http://conceptnet5.media.mit.edu/data/5.2/search. You add GET arguments to this to specify what to search for.
The following arguments are supported:
- { id, uri, rel, start, end, context, dataset, license } = URI: giving a ConceptNet URI for any of these parameters will return edges whose corresponding fields start with the given path.
- nodes = URI: returns edges whose rel, start, or end start with the given URI.
- { startLemmas, endLemmas, relLemmas } = word: returns edges containing the given lemmatized word anywhere in their start, end, or rel respectively.
- text = word: matches any of startLemmas, endLemmas, or relLemmas.
- surfaceText = word: matches edges with the given word in their surface text. The word is not lemmatized, but it is a case-insensitive match.
- minWeight = weight: filters for edges whose weight is at least weight.
- limit = n: change the number of results from the default of 50.
- offset = n: skip the first n results.
- features = str: Takes in a feature string (an assertion with one open slot), and returns edges having exactly that string as one of their features. Look at the features field of returned results for examples.
- filter=core: filter the returned results to only those in the ConceptNet 5 Core (no Creative Commons ShareAlike-licensed results).
To find 10 things that are parts of a car, you can do this: http://conceptnet5.media.mit.edu/data/5.2/search?rel=/r/PartOf&end=/c/en/car&limit=10
To get 50 facts about bagels, including when "bagel" appears in phrases such as "onion bagel": http://conceptnet5.media.mit.edu/data/5.2/search?text=bagel
The result is a JSON data structure containing:
- maxScore: the Solr score of the best match.
- numFound: an estimate of how many matches there are total.
- edges: the list of edges. Each edge is a JSON data structure containing all the fields of a ConceptNet edge, as well as a score. The score is a combination of the absolute value of the edge weight and a factor for how good a match it is for your query, according to Solr. The results are sorted by descending score.
The base URL is http://conceptnet5.media.mit.edu/data/5.2/assoc . This URL can be followed by:
- A concept URI, in which case it will show you the most similar concepts to that concept.
- A path of the form
/list/<language>/<term list>
, which finds the most similar concepts to a list of terms, as described below.
You can set the following GET arguments to modify the returned results:
- limit = n: change the number of results from the default of 10.
- filter = URI: return only results that start with the given URI. For example, filter=/c/en returns results in English.
A term list is a comma-separated list of components. A component is a word or phrase in natural language, optionally followed by an @ sign and a weight, which changes the relative importance of that concept from its default of 1. For example, the term list "dog,[email protected]" counts an association with the phrase "dog food" half as much as it counts an association with "dog".
Every term in the term list will be normalized according to the language you specify, so for example /list/en/dogs is the same as /list/en/dog.
To measure how similar cats and dogs are: http://conceptnet5.media.mit.edu/data/5.2/assoc/c/en/cat?filter=/c/en/dog&limit=1
To see 20 terms with the most positive affect: http://conceptnet5.media.mit.edu/data/5.2/assoc/list/en/happy,sad@-1?limit=20
To see 20 things in English with the most positive affect: http://conceptnet5.media.mit.edu/data/5.2/assoc/list/en/happy,sad@-1?limit=20&filter=/c/en
To see terms associated with breakfast foods: http://conceptnet5.media.mit.edu/data/5.2/assoc/list/en/toast,cereal,juice,egg
The ConceptNet API endpoints have remained unchanged since ConceptNet 5.1. The ConceptNet 5.0 API is no longer available, and 5.1 now redirects to 5.2.
ConceptNet 5.2 promoted assertions (made from multiple edges) as the things that the API would return, instead of the individual edges plus occasional assertions that 5.1 would give you. The assertions follow the same general format as the edges in 5.1, with extra fields such as source_uri
.
We're working on deploying the 5.3 API.
Starting points
Reproducibility
Details