Socket
Socket
Sign inDemoInstall

@asymmetrik/akin

Package Overview
Dependencies
49
Maintainers
7
Versions
5
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    @asymmetrik/akin

Recommendation Engine based on Collaborative Filtering


Version published
Weekly downloads
1
decreased by-75%
Maintainers
7
Install size
4.61 MB
Created
Weekly downloads
 

Readme

Source

@asymmetrik/akin

Build Status Code Climate Test Coverage standard-readme compliant

Recommendation Engine Library based on Collaborative Filtering. Node.js implementation using MongoDB via Mongoose.

Provides hooks for logging user activity on items referenced by an ObjectID and an optional item type. Additional methods provide execution of a scalable, collaborative filtering algorithm that outputs recommendation results for each user into a namespaced Mongo collections. These results can then be retrieved and integrated into the application as desired.

Table of Contents

Install

Include this module as a dependency of your application in the package.json file. It also requires that MongooseJS is available as a peer dependency. For example:

{
  ...
  dependencies: {
    "mongoose": "~4.6",
    "@asymmetrik/akin": "latest"
  }
  ...
}

Usage

Include the module via require wherever applicable:

var akin = require('@asymmetrik/akin');

The most fundamental use case of logging user activity, running the engine, and retrieving recommendations for a user is achieved via:

akin.activity.log(userId, itemId, { type: 'itemType' }, 'action');
...
akin.run();
...
akin.recommendation.getAllRecommendationsForUser(userId);

There are four classes that allow for managing activity logs and recalculating recommendations at a more granular level:

akin.model

Manages query execution for schemas

akin.activity

  1. Manage (add or remove) a user's activity for any item.
  2. Calculates the first phase of the recommendation engine: user's weighted scores on items

akin.similarity

  1. Calculates the second phase of the recommendation engine: user's similarity to other users

akin.recommendation

  1. Calculates the third and final phase of the recommendation engine: collaborative filtering to generate recommendations
  2. Allows for retrieval of all or a weighted random sample of recommendations
  3. Marking items as do not recommend for a user to stop them from returning in the sampling query

API

recalculate all recommendations

Execute the recommendation engine based on the data supplied to the activity.log() API

akin.run();

activity

Add a user's activity on an item

akin.activity.log(userId, itemId, { type: 'itemType' }, 'actionType');

Remove a user's activity on an item

akin.activity.removeLog(userId, itemId, 'actionType');

retrieve recommendations

Get all recommendations created for a user

akin.recommendation.getAllRecommendationsForUser(userId);

Get a sampling of recommendations created for a user based on a weighted cumulative distribution function

akin.recommendation.sampleRecommendationsForUser(userId, numberOfSamples);

Contribute

PRs accepted.

Small note: If editing the README, please conform to the standard-readme specification.

License

@asymmetrik/akin is MIT licensed.

FAQs

Last updated on 30 Apr 2018

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc