collective.portlet.similarcontent (1.4)
- collective.portlet.similarcontent download link: http://plone.org/products/collective.portlet.similarcontent/releases
- Homepage of collective.portlet.similarcontent: http://plone.org/products/collective.portlet.similarcontent
- collective.portlet.similarcontent repository: https://svn.plone.org/svn/collective/collective.portlet.similarcontent/
- Description source: https://svn.plone.org/svn/collective/collective.portlet.similarcontent/trunk/README.txt
A Plone portlet that uses the catalog internals to find 'similar' content to the page you are looking at
This portlet uses some deep dark data structures within the ZCatalog and ZCTextindex, so it could be brittle in the future if those structures are changed. Then again, they have been the same for the past 8 years or so ;)
This portlet also runs in linear time relative to the number for documents you have in your site, so it could well slow things down. That said I've tried to make it pretty efficient.
How it Works
In a nutshell, this portlet compares the text content of an object with all other objects on the site to find other objects with a similar content. The steps are as follows:
- Find the path of this document
- Look up the record_id (docid) of this path in the catalog
- Look in the SearchableText index to find all word ids (wids) in this document
- Work out the top 20 most 'important' words in this document [*]
- For each of the top 20 words, find all documents containing any of those words
- Use a vector space model to measure similarity of each candidate document to our top 20 words
- Return the top 10 most similar documents.