Skip to main content

PerMetrics: A framework of PERformance METRICS for machine learning models

Project description

A framework of PERformance METRICS (PerMetrics) for artificial intelligence models

GitHub release Documentation Status Wheel PyPI version DOI License


"Knowledge is power, sharing it is the premise of progress in life. It seems like a burden to someone, but it is the only way to achieve immortality." --- Thieu Nguyen


Introduction

  • PerMetrics is a python library for performance metrics of machine learning models.

  • The goals of this framework are:

    • Combine all metrics for regression, classification and clustering models
    • Helping users in all field access to metrics as fast as possible
    • Perform Qualitative Analysis of models.
    • Perform Quantitative Analysis of models.
  • Metrics

Problem STT Metric Metric Fullname Characteristics
Regression 1 EVS Explained Variance Score Larger is better (Best = 1)
2 ME Max Error Smaller is better (Best = 0)
3 MAE Mean Absolute Error Smaller is better (Best = 0)
4 MSE Mean Squared Error Smaller is better (Best = 0)
5 RMSE Root Mean Squared Error Smaller is better (Best = 0)
6 MSLE Mean Squared Log Error Smaller is better (Best = 0)
7 MedAE Median Absolute Error Smaller is better (Best = 0)
8 MRE Mean Relative Error Smaller is better (Best = 0)
9 MAPE Mean Absolute Percentage Error Smaller is better (Best = 0)
10 SMAPE Symmetric Mean Absolute Percentage Error Smaller is better (Best = 0)
11 MAAPE Mean Arctangent Absolute Percentage Error Smaller is better (Best = 0)
12 MASE Mean Absolute Scaled Error Smaller is better (Best = 0)
13 NSE Nash-Sutcliffe Efficiency Coefficient Larger is better (Best = 1)
14 WI Willmott Index Larger is better (Best = 1)
15 R Pearson’s Correlation Index Larger is better (Best = 1)
16 CI Confidence Index Larger is better (Best = 1)
17 R2 Coefficient of Determination Larger is better (Best = 1)
18 R2s (Pearson’s Correlation Index) ^ 2 Larger is better (Best = 1)
19 DRV Deviation of Runoff Volume Smaller is better (Best = 0)
20 KGE Kling-Gupta Efficiency Larger is better (Best = 1)
21 GINI Gini Coefficient
22 GINI_WIKI Gini Coefficient in Wiki
23 PCD Prediction of Change in Direction
24 E Entropy
25 CE Cross Entropy
26 KLD Kullback Leibler Divergence
27 JSD Jensen Shannon Divergence
28 VAF Variance Accounted For
29 RAE Relative Absolute Error
30 A10 A10 Index
31 A20 A20 Index
32 NRMSE Normalized Root Mean Square Error
33
Single Loss 1 RE Relative error Smaller is better (Best = 0)
2 AE Absolute error Smaller is better (Best = 0)
3 SE Squared error Smaller is better (Best = 0)
4 SLE Squared log error Smaller is better (Best = 0)
5 LL Log likelihood Smaller is better (Best = 0)
6
Classification 1 MLL Mean Log Likelihood Smaller is better (Best = 0)
2
Clustering 1
2

Dependencies

  • Python (>= 3.6)
  • Numpy (>= 1.15.1)

User installation

Install the current PyPI release:

pip install permetrics

Or install the development version from GitHub:

pip install git+https://github.com/thieu1995/permetrics

Example

  • All you need to do is: (Make sure your y_true and y_pred is a numpy array)
* Simple example:

  ## For example with RMSE:

  from numpy import array
  from permetrics.regression import Metrics

  ## 1-D array
  y_true = array([3, -0.5, 2, 7])
  y_pred = array([2.5, 0.0, 2, 8])

  y_true2 = array([3, -0.5, 2, 7])
  y_pred2 = array([2.5, 0.0, 2, 9])

  ### C1. Using OOP style - very powerful when calculating multiple metrics
  obj1 = Metrics(y_true, y_pred)  # Pass the data here
  result = obj1.root_mean_squared_error(clean=True, decimal=5)
  print(f"1-D array, OOP style: {result}")

  ### C2. Using functional style
  obj2 = Metrics()
  result = obj2.root_mean_squared_error(clean=True, decimal=5, y_true=y_true2, y_pred=y_pred2)  
  # Pass the data here, remember the keywords (y_true, y_pred)
  print(f"1-D array, Functional style: {result}")

  ## > 1-D array - Multi-dimensional Array
  y_true = array([[0.5, 1], [-1, 1], [7, -6]])
  y_pred = array([[0, 2], [-1, 2], [8, -5]])

  multi_outputs = [None, "raw_values", [0.3, 1.2], array([0.5, 0.2]), (0.1, 0.9)]
  obj3 = Metrics(y_true, y_pred)
  for multi_output in multi_outputs:
      result = obj3.root_mean_squared_error(clean=False, multi_output=multi_output, decimal=5)
      print(f"n-D array, OOP style: {result}")

* Or run the simple:
    python examples/RMSE.py

* The more complicated tests in the folder: examples

The documentation includes more detailed installation instructions and explanations.

Changelog

  • See the ChangeLog.md for a history of notable changes to permetrics.

Important links

Contributions

Citation

  • If you use permetrics in your project, please cite my works:
@software{thieu_nguyen_2020_3951205,
  author       = {Thieu Nguyen},
  title        = {A framework of PERformance METRICS (PerMetrics) for artificial intelligence models},
  month        = jul,
  year         = 2020,
  publisher    = {Zenodo},
  doi          = {10.5281/zenodo.3951205},
  url          = {https://doi.org/10.5281/zenodo.3951205}
}

@article{nguyen2019efficient,
  title={Efficient Time-Series Forecasting Using Neural Network and Opposition-Based Coral Reefs Optimization},
  author={Nguyen, Thieu and Nguyen, Tu and Nguyen, Binh Minh and Nguyen, Giang},
  journal={International Journal of Computational Intelligence Systems},
  volume={12},
  number={2},
  pages={1144--1161},
  year={2019},
  publisher={Atlantis Press}
}

Future works

Classification

  • F1 score
  • Multiclass log loss
  • Lift
  • Average Precision for binary classification
  • precision / recall break-even point
  • cross-entropy
  • True Pos / False Pos / True Neg / False Neg rates
  • precision / recall / sensitivity / specificity
  • mutual information

HIGHER LEVEL TRANSFORMATIONS TO HANDLE

  • GroupBy / Reduce
  • Weight individual samples or groups

PROPERTIES METRICS CAN HAVE

  • Min or Max (optimize through minimization or maximization)
  • Binary Classification
    • Scores predicted class labels
    • Scores predicted ranking (most likely to least likely for being in one class)
    • Scores predicted probabilities
  • Multiclass Classification
    • Scores predicted class labels
    • Scores predicted probabilities
  • Regression (More)
  • Discrete Rater Comparison (confusion matrix)

Download files

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

Source Distribution

permetrics-1.1.0.tar.gz (24.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

permetrics-1.1.0-py3-none-any.whl (61.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: permetrics-1.1.0.tar.gz
  • Upload date:
  • Size: 24.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.0.0.post20200309 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.7.5

File hashes

Hashes for permetrics-1.1.0.tar.gz
Algorithm Hash digest
SHA256 8429f06241f8bad6f87a086cd10e6e3d12eebb219cef736d12d4059e44b2799f
MD5 3fd42bc3e93d7311e6f92eec9afdb3ef
BLAKE2b-256 68e400ba9c6a97638362f9cb426cbc6de4768288a37e1a7addf9fb178872067c

See more details on using hashes here.

File details

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

File metadata

  • Download URL: permetrics-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 61.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.0.0.post20200309 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.7.5

File hashes

Hashes for permetrics-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7ffd36c2ace12e4c23d8de3785979f06e0f590e4c35cb0bc6f34503bf4797868
MD5 97724216cf5f5e323cbdb7e5a30943ee
BLAKE2b-256 b2056b6a944deddb400362e923b25eaec99c1fa58755c4b05be166ee9ddf6978

See more details on using hashes here.

Supported by

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