Skip to main content

A suite of visual analysis and diagnostic tools for machine learning.

Project description

Yellowbrick

Visualizers

Yellowbrick is a suite of visual analysis and diagnostic tools designed to facilitate machine learning with scikit-learn. The library implements a new core API object, the Visualizer that is an scikit-learn estimator — an object that learns from data. Similar to transformers or models, visualizers learn from data by creating a visual representation of the model selection workflow.

Visualizer allow users to steer the model selection process, building intuition around feature engineering, algorithm selection and hyperparameter tuning. For instance, they can help diagnose common problems surrounding model complexity and bias, heteroscedasticity, underfit and overtraining, or class balance issues. By applying visualizers to the model selection workflow, Yellowbrick allows you to steer predictive models toward more successful results, faster.

The full documentation can be found at scikit-yb.org and includes a Quick Start Guide for new users.

Visualizers

Visualizers are estimators — objects that learn from data — whose primary objective is to create visualizations that allow insight into the model selection process. In scikit-learn terms, they can be similar to transformers when visualizing the data space or wrap a model estimator similar to how the ModelCV (e.g. RidgeCV, LassoCV) methods work. The primary goal of Yellowbrick is to create a sensical API similar to scikit-learn. Some of our most popular visualizers include:

Classification Visualization

  • Classification Report: a visual classification report that displays a model's precision, recall, and F1 per-class scores as a heatmap
  • Confusion Matrix: a heatmap view of the confusion matrix of pairs of classes in multi-class classification
  • Discrimination Threshold: a visualization of the precision, recall, F1-score, and queue rate with respect to the discrimination threshold of a binary classifier
  • Precision-Recall Curve: plot the precision vs recall scores for different probability thresholds
  • ROCAUC: graph the receiver operator characteristic (ROC) and area under the curve (AUC)

Clustering Visualization

  • Intercluster Distance Maps: visualize the relative distance and size of clusters
  • KElbow Visualizer: visualize cluster according to the specified scoring function, looking for the "elbow" in the curve.
  • Silhouette Visualizer: select k by visualizing the silhouette coefficient scores of each cluster in a single model

Feature Visualization

  • Manifold Visualization: high-dimensional visualization with manifold learning
  • Parallel Coordinates: horizontal visualization of instances
  • PCA Projection: projection of instances based on principal components
  • RadViz Visualizer: separation of instances around a circular plot
  • Rank Features: single or pairwise ranking of features to detect relationships

Model Selection Visualization

  • Cross Validation Scores: display the cross-validated scores as a bar chart with the average score plotted as a horizontal line
  • Feature Importances: rank features based on their in-model performance
  • Learning Curve: show if a model might benefit from more data or less complexity
  • Recursive Feature Elimination: find the best subset of features based on importance
  • Validation Curve: tune a model with respect to a single hyperparameter

Regression Visualization

  • Alpha Selection: show how the choice of alpha influences regularization
  • Cook's Distance: show the influence of instances on linear regression
  • Prediction Error Plots: find model breakdowns along the domain of the target
  • Residuals Plot: show the difference in residuals of training and test data

Target Visualization

  • Balanced Binning Reference: generate a histogram with vertical lines showing the recommended value point to the bin data into evenly distributed bins
  • Class Balance: show the relationship of the support for each class in both the training and test data by displaying how frequently each class occurs as a bar graph the frequency of the classes' representation in the dataset
  • Feature Correlation: visualize the correlation between the dependent variables and the target

Text Visualization

  • Dispersion Plot: visualize how key terms are dispersed throughout a corpus
  • PosTag Visualizer: plot the counts of different parts-of-speech throughout a tagged corpus
  • Token Frequency Distribution: visualize the frequency distribution of terms in the corpus
  • t-SNE Corpus Visualization: uses stochastic neighbor embedding to project documents
  • UMAP Corpus Visualization: plot similar documents closer together to discover clusters

... and more! Yellowbrick is adding new visualizers all the time so be sure to check out our examples gallary — or even the develop branch — and feel free to contribute your ideas for new Visualizers!

Affiliations

District Data Labs NumFOCUS Affiliated Project

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

yellowbrick-1.0.tar.gz (17.8 MB view details)

Uploaded Source

Built Distribution

yellowbrick-1.0-py2.py3-none-any.whl (378.4 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file yellowbrick-1.0.tar.gz.

File metadata

  • Download URL: yellowbrick-1.0.tar.gz
  • Upload date:
  • Size: 17.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.35.0 CPython/3.7.3

File hashes

Hashes for yellowbrick-1.0.tar.gz
Algorithm Hash digest
SHA256 b45036d08a7a2d8fe895f6402924c6d308a666ac7f68bb30cc98258e5682a8fd
MD5 1188fab82d3d08123a5452cb4273c988
BLAKE2b-256 3ce56e2c0ad4b4520b3aad204010246934b5175b45d17e41cb7c8d164c605be3

See more details on using hashes here.

File details

Details for the file yellowbrick-1.0-py2.py3-none-any.whl.

File metadata

  • Download URL: yellowbrick-1.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 378.4 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.35.0 CPython/3.7.3

File hashes

Hashes for yellowbrick-1.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 005c44d78248d779ff5e0353daf122ea00c2c15a1b39e78ebf62f26e0e902a83
MD5 894dee844fea18f376340cac4754880a
BLAKE2b-256 f471c63c404f718fdb2f69ff1c16d4e6c92384483c3616929977fff4cb082593

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