npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

concept-net

v0.4.0

Published

interface to the ConceptNet semantic network

Downloads

18

Readme

NPM version Build Status Coverage Status Dependencies

ConceptNet

node.js interface to the ConceptNet semantic network API. For further information, consult the website of the project: http://conceptnet5.media.mit.edu/.

Introduction

The ConceptNet package can be easily installed via npm:

npm install concept-net

To require the module in a project, we can use the expression:

var ConceptNet = require( 'concept-net' );

Getting Started

The module exports a single constructor which can be used to open an API connection. Simply call it an store the expression result in a variable:

var conceptNet = ConceptNet();

In case that you are running an own copy of the ConceptNet server, the constructor takes the hostname of the server as an optional argument. The default option evaluates to "conceptnet5.media.mit.edu:80".

ConceptNet( '<hostname>', '<port>', '<conceptnet version number>' );

Example:

var conceptNet = ConceptNet( '10.0.0.1', '10053', '5.3' );

Note you can modify only the version by just passing null to the first two arguments:

var conceptNet = ConceptNet( null, null, '5.3' );

We can then use the following three methods to query the ConceptNet API:

Methods

.lookup( uri[, params], callback )

This method expects a valid ConceptNet URI as its first argument. See the documentation. Params is an (optional) object that specifies the arguments of the GET request. It can have the keys limit, offset and filter. The callback function has two parameters: The err parameter will return error objects in case that something goes wrong during the function invocation. If the query is successful, err is undefined and the result parameter holds the result set from the query.

Example code:

conceptNet.lookup( '/c/en/toast', {
	limit: 10,
	offset: 0,
	filter: 'core'
}, function onDone( err, result ) {
	// insert code here
})

.getURI( text[, language], callback )

This method finds out what the ConceptNet URI is for a given text, applying steps such as reducing English words to their root form. The language parameter can be supplied a code for the language to use. If only two arguments are supplied, language is set to the default value en.

Example code:

conceptNet.getURI( 'ground beef', 'en', function onDone( err, result ) {
	// insert code here
})

.search( params, callback )

The search method takes a parameter object and hands the retrieved results to the callback function. The official ConceptNet API documentation provides a full overview of the possible search parameters: ConceptNet API documentation.

Example code:

conceptNet.search({
	start: '/c/en/donut'
}, function onDone( err, result ) {
	// insert code here
})

.association( input[, params], callback )

The association method takes as its first input either a valid ConceptNet URI or a /list/<language>/<term list> path.

Example code:

conceptNet.association( '/c/en/hotdog', {
	limit: 10,
	filter: '/c/en/donut'
}, function onDone( err, result ){
	// insert code here
})

Unit Tests

Run tests via the command npm test


License

MIT license.