Skip to main content

Beyond apriori. Cleverminer is the package for enhanced association rule mining (eARM). Comparing to standard association rules, it is very enhanced, because the package implements the GUHA procedures that generalises apriori and association rules in many ways. Rules are based on categorical data that can be easily visualized and interpreted. Their if-then with probability allows easy deployment by human realized processes. Trully explainable knowledge mining.

Project description

CleverMiner

PyPI - Python Version PyPI - Wheel PyPI - Status PyPI - Downloads

The CleverMiner is an enhanced association rule mining library

Beyond apriori. Cleverminer is the package for enhanced association rule mining (eARM), that are INTERPRETABLE, so by definition one of few intristic methods of explainable AI (XAI). Comparing to standard association rules, it is very enhanced, because the package implements the GUHA procedures that generalises apriori and association rules in many ways. Rules are based on categorical data that can be easily visualized and interpreted. Their if-then with probability allows easy deployment by human realized processes. Trully explainable knowledge mining.

The CleverMiner in more detail

In general, apriori is looking for rules {ItemSet} -> {Item} (Base, prob). GUHA goes further and instead of items (boolean attributes), list of categorial attributes and combination of values (nominal and several strategies for ordinal -- joining categories) is searched on left and right hand side. Moreover, GUHA has much more possibilites and several other procedures, like mining interesting histograms, finding couples of rules etc.

To run cleverminer procedures, use dataframe with categorical variables only. Cleverminer prepares all variables and values for future reuse.

Optimized in many ways

CleverMiner has optimized space search in several ways.

  • first, it encodes dataframe into internal format that is optimized for frequent querying for similar pattern, then it queries the dataframe many (typically several thousand or tens/hunderds thousand) times.
  • the algorithm has also optimizations by the derived properties of individual procedures (e.g. when procedure A finds that expanding rule will in every case lead into rules that does not meet requirements, it skips entire branch). This optimization typically reduces the mining time significantly.

CleverMiner documentation

Documentation for CleverMiner can be found at cleverminer.org

What's new

1.1.0 (cumulative feature update)

  • support for displaying charts for rules (.draw_rule() method)
  • procedures fully documented (docstrings available)
  • UIC Miner supports relevant base lift and relevant cat base quantifiers
  • support for lambda quantifiers
  • support for list literal type
  • improved detection of ordered categories

1.0.12

  • fixed problem with .mine method ("row_count" issue)

1.0.11

  • fixed wording in UIC miner output
  • fixed bug in dataset description

1.0.10

  • get_ruletext method
  • result contains rowcont of original dataframe to increase possibilities of post-processing

1.0.9

  • fixed bugs - error message when displaying of results that has not been calculated
  • Python 3.12 regression tests passed ok

1.0.8

  • data preparation enhanced in many ways
  • able to work with series like 1,2,3, 4-20, 21 and more, 0.0,1.0, ..., Temp 17-25oC,...

1.0.7

  • CF miner supports step size and range between relmax & relmin
  • categories printed in CF output
  • bugfix: checking number of categories fixed
  • can return also adjusted df (ordered categories, ...) - functionality not guaranteed to future

1.0.6

  • progressbar

1.0.5

  • supports missing pandas functionalities and implements several automated data preprocessing
  • listing of variables, ordering and labels
  • automatically process conversion to numeric, integers and order float & integer variables
  • fixed verbosity level prints

1.0.4

  • sorting output rules

1.0.3

  • UIC Miner introduced

1.0.2

  • merge changes from 0.91 (data structure checks; as 1.0.0 was build from 0.0.90 so remaining features are merged now)

1.0.1

  • new procedures get4fold, gethist, getquantifiers, getrulecount

1.0.0 - Major release, major rebuild from all views:

  • data import reworked and fastened significantly
  • much faster calculation (rule mining) in Py3.10 + next optimizations for rule mining are in place
  • output structure is enhanced, fully structured output is available for post-processing (trace_cedent, cedent_struct in output)
  • data can be read once and multiple tasks can be performed (.mine method)
  • optimizations for sd4ft miner
  • verbosity options available (run progress output has been changed)
  • additional options available (able to override maximum number of categories)
  • better formatting outputs (bugfix)
  • data structure in output has changed

0.0.91 - detect error in datatypes in input data and correctly report it

0.0.90 - fix in displaying rules for 4ft-Miner, in CF-Miner: allowing relmax to be bounded from both sides (leq introduced), in SD4ft-Miner: allowing ratioconf to be bounded from both sides (leq introduced)

0.0.89 - quantifiers and output dictionary names change in favor of rules terminology (output: hypotheses->rules; hypo_id -> rule_id, quantifiers kept for compatibility old and new names, including variability (like frstbase -> also base1 is possible)

0.0.88 - print of task summary, hypo listing and individual hypothesis

0.0.87 - support for 'one category' added

0.0.86 - bugfixes (space search for optimized branch, able to switch off optimization, minimal cedent length bug for optimized search)

0.0.85 - bugfixes (row_count), checking input structure

0.0.84 - optimizations for conjunctions

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cleverminer-1.1.0.tar.gz (30.2 kB view details)

Uploaded Source

Built Distribution

cleverminer-1.1.0-py3-none-any.whl (28.6 kB view details)

Uploaded Python 3

File details

Details for the file cleverminer-1.1.0.tar.gz.

File metadata

  • Download URL: cleverminer-1.1.0.tar.gz
  • Upload date:
  • Size: 30.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.5

File hashes

Hashes for cleverminer-1.1.0.tar.gz
Algorithm Hash digest
SHA256 c0623979395633b0965d1bdc68d396f9a0f4e8636f914f46d8156e536025df7f
MD5 319ba215d84d90903373d881c8448daf
BLAKE2b-256 dda2666e20f215e350abb73d761ff8b69e192dc35e2f66a260a858cc07c5eb03

See more details on using hashes here.

File details

Details for the file cleverminer-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: cleverminer-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 28.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.5

File hashes

Hashes for cleverminer-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 98cd7d6ba01361d372e02a2c9eb68cfbbef8af162f67badddb5204511cf55b06
MD5 19fafc4278e75d34b93c85a65fead7be
BLAKE2b-256 bf655822d48c13e376d7e6ea0d4583d4255a44889680a9b85dcbdf0709813ce4

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page