Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

slot-filler

Package Overview
Dependencies
Maintainers
1
Versions
7
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

slot-filler

Fill in the slots in a phrase template given a matching phrase.

  • 1.0.6
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
10
decreased by-96.6%
Maintainers
1
Weekly downloads
 
Created
Source

SlotFiller

slot-filler is used in combination with sentence-similarity to fill in slots. Slots are defined using a phrase template such as "What (keyword) is the (item) in?". The slot-filler can then take a sentence such as "Hi, what aisle is the bacon in?" and fill in the slots keyword="aisle" and item = "bacon". The slot filler will often work even when the sentence does not exactly match the phrase template including when words are missing, added or misspelled. A user defined word similarity measure give the user flexibility, one could even include a synonym search in the word similarity measure if desired. The slot-filler is used as part of the clockmaker bot framework (in the process of release).

Example 1, exact match

let slotFiller = require('slot-filler')
let ss = require('sentence-similarity')

let stdOpts = { f: ss.similarityScore.metaphoneDl, options : {threshold: 0.3} }

let a = ['Hello', 'my', 'name', 'is', 'John', 'Jacob']
let b = ['Hello', '(pronoun)', 'name', 'is', '(name)']
let ans = ss.sentenceSimilarity(a,b,stdOpts) 	

console.log(ans)

let slots = slotFiller.getWildcards(b, a, ans.matched, null)
console.log(slots)

gives output

{ wildcards: { matched: true, pronoun: 'my', name: 'John Jacob' },
  score: { score: 1, count: 2 } }

so that now the slotFiller has estimated the slots for (pronoun) and (name). Note, the names inside the wildcards (pronoun),(name) are arbitrary, the slotFiller would not behave any differently if the names were changed.

Example 2, inexact match

The template sentence does not need to exactly match the stated sentence, but the slot-filler will try and figure out the correct slots anyway. This can help you from having to state every variation of a given template.

let slotFiller = require('slot-filler')
let ss = require('sentence-similarity')

let a = ['my', 'is', 'John', 'Jacob']
let b = ['Hello,', '(pronoun)', 'name', 'is', '(name)']
let ans = ss.sentenceSimilarity(a,b,stdOpts) 	

let slots = slotFiller.getWildcards(b, a, ans.matched, null)
console.log(slots)

produces

{ wildcards: { matched: true, pronoun: 'my', name: 'John Jacob' },
  score: { score: 1, count: 2 } }

Example 3, reconstruction

Given a phrase with slots and a set of slot values, the slot filler can also fill in the slots

let slotFiller = require('slot-filler')

let wc = {pronoun : "your", name : "kai"}
let phrase = 'Hello, (pronoun) name is (name)'
	
let res = slotFiller.reconstructPhrase(phrase, wc)
console.log(res)

produces

{ phrase: 'Hello, your name is kai', success: true, score: 2 }

Keywords

FAQs

Package last updated on 04 May 2017

Did you know?

Socket

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
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc