Metadata-Version: 2.1
Name: whylogs
Version: 0.6.29
Summary: Profile and monitor your ML data pipeline end-to-end
Home-page: https://docs.whylabs.ai
License: Apache-2.0
Keywords: machine learning,data profiling,data quality,data logging
Author: WhyLabs.ai
Author-email: support@whylabs.ai
Requires-Python: >=3.6.1,<3.10
Classifier: Development Status :: 3 - Alpha
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Requires-Dist: boto3 (>=1.14.1)
Requires-Dist: botocore (>=1.17.44)
Requires-Dist: click (>=7.1.2)
Requires-Dist: dataclasses (>=0.6); python_version < "3.7"
Requires-Dist: jsonschema (>=3.2.0)
Requires-Dist: marshmallow (>=3.7.1)
Requires-Dist: matplotlib (>=3.0.3,<4.0.0)
Requires-Dist: numpy (>=1.18.0)
Requires-Dist: pandas (>=1.0.0)
Requires-Dist: protobuf (>=3.15.5)
Requires-Dist: puremagic (>=1.10,<2.0)
Requires-Dist: python-dateutil (>=2.8.1)
Requires-Dist: pyyaml (>=5.3.1)
Requires-Dist: requests (>=2.22.0)
Requires-Dist: scipy (>=1.5.4,<2.0.0)
Requires-Dist: smart-open (>=4.1.2)
Requires-Dist: tqdm (>=4.60.0,<5.0.0)
Requires-Dist: whylabs-client (>=0.3.0,<0.4.0)
Requires-Dist: whylabs-datasketches (>=2.2.0b1)
Project-URL: Repository, https://github.com/whylabs/whylogs
Description-Content-Type: text/markdown

<img src="https://static.scarf.sh/a.png?x-pxid=bc3c57b0-9a65-49fe-b8ea-f711c4d35b82" /><p align="center">
    <img src="https://i.imgur.com/nv33goV.png" width="35%"/>
    </br>
    <h1 align="center">The open source standard for data logging
 </h1>
  <h3 align="center">
   <a href="https://docs.whylabs.ai/docs/"><b>Documentation</b></a> &bull;
   <a href="https://bit.ly/whylogsslack"><b>Slack Community</b></a> &bull;
   <a href="https://github.com/whylabs/whylogs#python-quickstart"><b>Python Quickstart</b></a>
 </h3>




[![License](http://img.shields.io/:license-Apache%202-blue.svg)](https://github.com/whylabs/whylogs-python/blob/mainline/LICENSE)
[![PyPI version](https://badge.fury.io/py/whylogs.svg)](https://badge.fury.io/py/whylogs)
[![Coverage Status](https://coveralls.io/repos/github/whylabs/whylogs/badge.svg?branch=mainline)](https://coveralls.io/github/whylabs/whylogs?branch=mainline)
[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/python/black)
[![CII Best Practices](https://bestpractices.coreinfrastructure.org/projects/4490/badge)](https://bestpractices.coreinfrastructure.org/projects/4490)
[![PyPi Downloads](https://pepy.tech/badge/whylogs)](https://pepy.tech/project/whylogs)
![CI](https://github.com/whylabs/whylogs-python/workflows/whylogs%20CI/badge.svg)
[![Maintainability](https://api.codeclimate.com/v1/badges/442f6ca3dca1e583a488/maintainability)](https://codeclimate.com/github/whylabs/whylogs-python/maintainability)

## What is whylogs

whylogs is the open source standard for logging your data. With whylogs, users are able to generate summaries of their datasets (called *whylogs profiles*) which they can use to:
1. Track changes in their dataset
2. Create *data constraints* to know whether their data looks they way it should
3. Quickly visualize key summary statistics about their datasets

These three functionalities enable a variety of use cases for data scientists, machine learning engineers, and data engineers:
* Detecting data drift (and resultant ML model performance degradation)
* Data quality validation
* Exploratory data analysis via data profiling
* Tracking data for ML experiments
* And many more

whylogs can be run in Python or [Apache Spark](https://docs.whylabs.ai/docs/spark-integration) (both PySpark and Scala) environments on a variety of [data types](#data-types). We [integrate](#integrations) with lots of other tools including Pandas, [AWS Sagemaker](https://aws.amazon.com/blogs/startups/preventing-amazon-sagemaker-model-degradation-with-whylabs/), [MLflow](https://docs.whylabs.ai/docs/mlflow-integration), [Flask](https://whylabs.ai/blog/posts/deploy-and-monitor-your-ml-application-with-flask-and-whylabs), [Ray](https://docs.whylabs.ai/docs/ray-integration), [RAPIDS](https://whylabs.ai/blog/posts/monitoring-high-performance-machine-learning-models-with-rapids-and-whylogs), [Apache Kafka](https://docs.whylabs.ai/docs/kafka-integration), and more.

If you have any questions, comments, or just want to hang out with us, please join [our Slack Community](http://join.slack.whylabs.ai/). In addition to joining the Slack Community, you can also help this project by giving us a ⭐ in the upper right corner of this page.


## Python Quickstart<a name="python-quickstart" />


### Install whylogs

Install whylogs using the pip package manager by running

```
pip install whylogs
```

### Log some data

whylogs is easy to get up and runnings

```python
from whylogs import get_or_create_session
import pandas as pd

session = get_or_create_session()

df = pd.read_csv("path/to/file.csv")

with session.logger(dataset_name="my_dataset") as logger:
    
    #dataframe
    logger.log_dataframe(df)

    #dict
    logger.log({"name": 1})

    #images
    logger.log_image("path/to/image.png")
```

## Table of Contents

- [whylogs Profiles](#whylogs-profiles)
- [Visualizing Profiles](#visualizing-profiles)
- [Features](#features)
- [Data Types](#data-types)
- [Integrations](#integrations)
- [Examples](#examples)
- [Community](#community)
- [Roadmap](#roadmap)
- [Contribute](#contribute)

## whylogs Profiles<a name="whylogs-profiles" />

whylogs profiles are the core of the whylogs library. They capture key statistical properties of data, such as the distribution (far beyond simple mean, median, and standard deviation measures), the number of missing values, and a wide range of configurable custom metrics. By capturing these summary statistics, we are able to accurately represent the data and enable all of the use cases described in the introduction.

whylogs profiles have three properties that make them ideal for data logging: they are **descriptive**, **lightweight**, and **mergeable**.

<img align="left" src="data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iOTIiIGhlaWdodD0iOTIiIHZpZXdCb3g9IjAgMCA5MiA5MiIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPGcgb3BhY2l0eT0iMC41Ij4KPGcgb3BhY2l0eT0iMC41Ij4KPHJlY3QgeD0iMTQiIHk9IjI1LjI0OTUiIHdpZHRoPSI0Ny4xMjU4IiBoZWlnaHQ9IjEyLjc3NjgiIHJ4PSIyIiBmaWxsPSIjRkY2OTRGIi8+CjxyZWN0IHg9IjE0IiB5PSI0MC40OTEyIiB3aWR0aD0iNDcuMTI1OCIgaGVpZ2h0PSIxMi43NzY4IiByeD0iMiIgZmlsbD0iI0ZGNjk0RiIvPgo8cmVjdCB4PSIxNCIgeT0iNTUuNzMzNCIgd2lkdGg9IjQ3LjEyNTgiIGhlaWdodD0iMTIuNzc2OCIgcng9IjIiIGZpbGw9IiNGRjY5NEYiLz4KPC9nPgo8L2c+CjxnIGZpbHRlcj0idXJsKCNmaWx0ZXIwX2QpIj4KPHJlY3QgeD0iMjcuMTAxNiIgeT0iMzUiIHdpZHRoPSI0MyIgaGVpZ2h0PSIzOCIgcng9IjIiIGZpbGw9InVybCgjcGFpbnQwX2xpbmVhcikiLz4KPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik0zNC45NTg3IDQyQzM1LjQzMjEgNDIgMzUuODE1OCA0Mi4zODM4IDM1LjgxNTggNDIuODU3MVY2My44NTcxSDYzLjI0NDRDNjMuNzE3OCA2My44NTcxIDY0LjEwMTYgNjQuMjQwOSA2NC4xMDE2IDY0LjcxNDNDNjQuMTAxNiA2NS4xODc3IDYzLjcxNzggNjUuNTcxNCA2My4yNDQ0IDY1LjU3MTRIMzQuMTAxNlY0Mi44NTcxQzM0LjEwMTYgNDIuMzgzOCAzNC40ODUzIDQyIDM0Ljk1ODcgNDJaIiBmaWxsPSJ3aGl0ZSIvPgo8cmVjdCB4PSIzNy4xMDE2IiB5PSI0OCIgd2lkdGg9IjciIGhlaWdodD0iMTciIHJ4PSIwLjg1NzE0MyIgZmlsbD0id2hpdGUiLz4KPHJlY3QgeD0iNDYuMTAxNiIgeT0iNTciIHdpZHRoPSI3IiBoZWlnaHQ9IjgiIHJ4PSIwLjg1NzE0MyIgZmlsbD0id2hpdGUiLz4KPHJlY3QgeD0iNTUuMTAxNiIgeT0iNTMiIHdpZHRoPSI3IiBoZWlnaHQ9IjEyIiByeD0iMC44NTcxNDMiIGZpbGw9IndoaXRlIi8+CjwvZz4KPHJlY3QgeD0iMSIgeT0iLTEiIHdpZHRoPSIyNiIgaGVpZ2h0PSIyNiIgcng9IjEiIHRyYW5zZm9ybT0ibWF0cml4KDEgMCAwIC0xIDUwLjEwMTYgNDUuOTk5NSkiIGZpbGw9IndoaXRlIiBzdHJva2U9IiNGRkE3NzYiIHN0cm9rZS13aWR0aD0iMiIvPgo8cGF0aCBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGNsaXAtcnVsZT0iZXZlbm9kZCIgZD0iTTU3LjE3MjIgMzguNDk5NUM1Ny4xNzIyIDM4Ljc3NTcgNTYuOTQ4MyAzOC45OTk1IDU2LjY3MjIgMzguOTk5NUg1NS42OTI0QzU1LjQxNjIgMzguOTk5NSA1NS4xOTI0IDM4Ljc3NTcgNTUuMTkyNCAzOC40OTk1QzU1LjE5MjQgMzguMjIzNCA1NS40MTYyIDM3Ljk5OTUgNTUuNjkyNCAzNy45OTk1SDU2LjY3MjJDNTYuOTQ4MyAzNy45OTk1IDU3LjE3MjIgMzguMjIzNCA1Ny4xNzIyIDM4LjQ5OTVaIiBmaWxsPSIjRjA3MDI4Ii8+CjxwYXRoIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIiBkPSJNNzMuMDExNSAzOC40OTk1QzczLjAxMTUgMzguNzc1NyA3Mi43ODc3IDM4Ljk5OTUgNzIuNTExNSAzOC45OTk1SDYwLjY0MjhDNjAuMzY2NyAzOC45OTk1IDYwLjE0MjggMzguNzc1NyA2MC4xNDI4IDM4LjQ5OTVDNjAuMTQyOCAzOC4yMjM0IDYwLjM2NjcgMzcuOTk5NSA2MC42NDI4IDM3Ljk5OTVINzIuNTExNUM3Mi43ODc3IDM3Ljk5OTUgNzMuMDExNSAzOC4yMjM0IDczLjAxMTUgMzguNDk5NVoiIGZpbGw9IiNGMDcwMjgiLz4KPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik01Ny4xNzIyIDQxLjQ5OTVDNTcuMTcyMiA0MS43NzU3IDU2Ljk0ODMgNDEuOTk5NSA1Ni42NzIyIDQxLjk5OTVINTUuNjkyNEM1NS40MTYyIDQxLjk5OTUgNTUuMTkyNCA0MS43NzU3IDU1LjE5MjQgNDEuNDk5NUM1NS4xOTI0IDQxLjIyMzQgNTUuNDE2MiA0MC45OTk1IDU1LjY5MjQgNDAuOTk5NUg1Ni42NzIyQzU2Ljk0ODMgNDAuOTk5NSA1Ny4xNzIyIDQxLjIyMzQgNTcuMTcyMiA0MS40OTk1WiIgZmlsbD0iI0YwNzAyOCIvPgo8cGF0aCBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGNsaXAtcnVsZT0iZXZlbm9kZCIgZD0iTTY3LjkxOTggNDEuNDk5NUM2Ny45MTk4IDQxLjc3NTcgNjcuNjk2IDQxLjk5OTUgNjcuNDE5OCA0MS45OTk1SDYwLjc4MzRDNjAuNTA3MyA0MS45OTk1IDYwLjI4MzQgNDEuNzc1NyA2MC4yODM0IDQxLjQ5OTVDNjAuMjgzNCA0MS4yMjM0IDYwLjUwNzMgNDAuOTk5NSA2MC43ODM0IDQwLjk5OTVINjcuNDE5OEM2Ny42OTYgNDAuOTk5NSA2Ny45MTk4IDQxLjIyMzQgNjcuOTE5OCA0MS40OTk1WiIgZmlsbD0iI0YwNzAyOCIvPgo8cGF0aCBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGNsaXAtcnVsZT0iZXZlbm9kZCIgZD0iTTU3LjE3MjIgMzUuNDk5NUM1Ny4xNzIyIDM1Ljc3NTcgNTYuOTQ4MyAzNS45OTk1IDU2LjY3MjIgMzUuOTk5NUg1NS42OTI0QzU1LjQxNjIgMzUuOTk5NSA1NS4xOTI0IDM1Ljc3NTcgNTUuMTkyNCAzNS40OTk1QzU1LjE5MjQgMzUuMjIzNCA1NS40MTYyIDM0Ljk5OTUgNTUuNjkyNCAzNC45OTk1SDU2LjY3MjJDNTYuOTQ4MyAzNC45OTk1IDU3LjE3MjIgMzUuMjIzNCA1Ny4xNzIyIDM1LjQ5OTVaIiBmaWxsPSIjRjA3MDI4Ii8+CjxwYXRoIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIiBkPSJNNzEuMDMxNyAzNS40OTk1QzcxLjAzMTcgMzUuNzc1NyA3MC44MDc5IDM1Ljk5OTUgNzAuNTMxNyAzNS45OTk1SDYwLjY0MjhDNjAuMzY2NyAzNS45OTk1IDYwLjE0MjggMzUuNzc1NyA2MC4xNDI4IDM1LjQ5OTVDNjAuMTQyOCAzNS4yMjM0IDYwLjM2NjcgMzQuOTk5NSA2MC42NDI4IDM0Ljk5OTVINzAuNTMxN0M3MC44MDc5IDM0Ljk5OTUgNzEuMDMxNyAzNS4yMjM0IDcxLjAzMTcgMzUuNDk5NVoiIGZpbGw9IiNGMDcwMjgiLz4KPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik01Ny4xNzIyIDMyLjQ5OTVDNTcuMTcyMiAzMi43NzU3IDU2Ljk0ODMgMzIuOTk5NSA1Ni42NzIyIDMyLjk5OTVINTUuNjkyNEM1NS40MTYyIDMyLjk5OTUgNTUuMTkyNCAzMi43NzU3IDU1LjE5MjQgMzIuNDk5NUM1NS4xOTI0IDMyLjIyMzQgNTUuNDE2MiAzMS45OTk1IDU1LjY5MjQgMzEuOTk5NUg1Ni42NzIyQzU2Ljk0ODMgMzEuOTk5NSA1Ny4xNzIyIDMyLjIyMzQgNTcuMTcyMiAzMi40OTk1WiIgZmlsbD0iI0YwNzAyOCIvPgo8cGF0aCBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGNsaXAtcnVsZT0iZXZlbm9kZCIgZD0iTTcxLjAzMTcgMzIuNDk5NUM3MS4wMzE3IDMyLjc3NTcgNzAuODA3OSAzMi45OTk1IDcwLjUzMTcgMzIuOTk5NUg2MC42NDI4QzYwLjM2NjcgMzIuOTk5NSA2MC4xNDI4IDMyLjc3NTcgNjAuMTQyOCAzMi40OTk1QzYwLjE0MjggMzIuMjIzNCA2MC4zNjY3IDMxLjk5OTUgNjAuNjQyOCAzMS45OTk1SDcwLjUzMTdDNzAuODA3OSAzMS45OTk1IDcxLjAzMTcgMzIuMjIzNCA3MS4wMzE3IDMyLjQ5OTVaIiBmaWxsPSIjRjA3MDI4Ii8+CjxwYXRoIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIiBkPSJNNTcuMTcyMiAyOS40OTk1QzU3LjE3MjIgMjkuNzc1NyA1Ni45NDgzIDI5Ljk5OTUgNTYuNjcyMiAyOS45OTk1SDU1LjY5MjRDNTUuNDE2MiAyOS45OTk1IDU1LjE5MjQgMjkuNzc1NyA1NS4xOTI0IDI5LjQ5OTVDNTUuMTkyNCAyOS4yMjM0IDU1LjQxNjIgMjguOTk5NSA1NS42OTI0IDI4Ljk5OTVINTYuNjcyMkM1Ni45NDgzIDI4Ljk5OTUgNTcuMTcyMiAyOS4yMjM0IDU3LjE3MjIgMjkuNDk5NVoiIGZpbGw9IiNGMDcwMjgiLz4KPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik02Ny45MTk4IDI5LjQ5OTVDNjcuOTE5OCAyOS43NzU3IDY3LjY5NiAyOS45OTk1IDY3LjQxOTggMjkuOTk5NUg2MC43ODM0QzYwLjUwNzMgMjkuOTk5NSA2MC4yODM0IDI5Ljc3NTcgNjAuMjgzNCAyOS40OTk1QzYwLjI4MzQgMjkuMjIzNCA2MC41MDczIDI4Ljk5OTUgNjAuNzgzNCAyOC45OTk1SDY3LjQxOThDNjcuNjk2IDI4Ljk5OTUgNjcuOTE5OCAyOS4yMjM0IDY3LjkxOTggMjkuNDk5NVoiIGZpbGw9IiNGMDcwMjgiLz4KPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik01Ny4xNzIyIDI2LjQ5OTVDNTcuMTcyMiAyNi43NzU3IDU2Ljk0ODMgMjYuOTk5NSA1Ni42NzIyIDI2Ljk5OTVINTUuNjkyNEM1NS40MTYyIDI2Ljk5OTUgNTUuMTkyNCAyNi43NzU3IDU1LjE5MjQgMjYuNDk5NUM1NS4xOTI0IDI2LjIyMzQgNTUuNDE2MiAyNS45OTk1IDU1LjY5MjQgMjUuOTk5NUg1Ni42NzIyQzU2Ljk0ODMgMjUuOTk5NSA1Ny4xNzIyIDI2LjIyMzQgNTcuMTcyMiAyNi40OTk1WiIgZmlsbD0iI0YwNzAyOCIvPgo8cGF0aCBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGNsaXAtcnVsZT0iZXZlbm9kZCIgZD0iTTcxLjAzMTcgMjYuNDk5NUM3MS4wMzE3IDI2Ljc3NTcgNzAuODA3OSAyNi45OTk1IDcwLjUzMTcgMjYuOTk5NUg2MC42NDI4QzYwLjM2NjcgMjYuOTk5NSA2MC4xNDI4IDI2Ljc3NTcgNjAuMTQyOCAyNi40OTk1QzYwLjE0MjggMjYuMjIzNCA2MC4zNjY3IDI1Ljk5OTUgNjAuNjQyOCAyNS45OTk1SDcwLjUzMTdDNzAuODA3OSAyNS45OTk1IDcxLjAzMTcgMjYuMjIzNCA3MS4wMzE3IDI2LjQ5OTVaIiBmaWxsPSIjRjA3MDI4Ii8+CjxkZWZzPgo8ZmlsdGVyIGlkPSJmaWx0ZXIwX2QiIHg9IjcuMTAxNTYiIHk9IjE3IiB3aWR0aD0iNjkiIGhlaWdodD0iNjQiIGZpbHRlclVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgY29sb3ItaW50ZXJwb2xhdGlvbi1maWx0ZXJzPSJzUkdCIj4KPGZlRmxvb2QgZmxvb2Qtb3BhY2l0eT0iMCIgcmVzdWx0PSJCYWNrZ3JvdW5kSW1hZ2VGaXgiLz4KPGZlQ29sb3JNYXRyaXggaW49IlNvdXJjZUFscGhhIiB0eXBlPSJtYXRyaXgiIHZhbHVlcz0iMCAwIDAgMCAwIDAgMCAwIDAgMCAwIDAgMCAwIDAgMCAwIDAgMTI3IDAiIHJlc3VsdD0iaGFyZEFscGhhIi8+CjxmZU9mZnNldCBkeD0iLTciIGR5PSItNSIvPgo8ZmVHYXVzc2lhbkJsdXIgc3RkRGV2aWF0aW9uPSI2LjUiLz4KPGZlQ29sb3JNYXRyaXggdHlwZT0ibWF0cml4IiB2YWx1ZXM9IjAgMCAwIDAgMC44MjA4MzMgMCAwIDAgMCAwLjM1MzE2NiAwIDAgMCAwIDAuMjcxNTU5IDAgMCAwIDAuNSAwIi8+CjxmZUJsZW5kIG1vZGU9Im5vcm1hbCIgaW4yPSJCYWNrZ3JvdW5kSW1hZ2VGaXgiIHJlc3VsdD0iZWZmZWN0MV9kcm9wU2hhZG93Ii8+CjxmZUJsZW5kIG1vZGU9Im5vcm1hbCIgaW49IlNvdXJjZUdyYXBoaWMiIGluMj0iZWZmZWN0MV9kcm9wU2hhZG93IiByZXN1bHQ9InNoYXBlIi8+CjwvZmlsdGVyPgo8bGluZWFyR3JhZGllbnQgaWQ9InBhaW50MF9saW5lYXIiIHgxPSIyMi42NzI2IiB5MT0iMzEuNjYwMSIgeDI9Ijc0LjUwMDMiIHkyPSIzNS45MTU3IiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSI+CjxzdG9wIHN0b3AtY29sb3I9IiNFQTVCNEYiLz4KPHN0b3Agb2Zmc2V0PSIxIiBzdG9wLWNvbG9yPSIjRjlDNDUyIi8+CjwvbGluZWFyR3JhZGllbnQ+CjwvZGVmcz4KPC9zdmc+Cg=="></img>

**Descriptive**: whylogs profiles describe the dataset that they represent. This high fidelity representation of datasets is what enables whylogs profiles to be effective snapshots of the data. They are better at capturing the characteristics of a dataset than a sample would be, as discussed in our [Data Logging: Sampling versus Profiling](https://whylabs.ai/blog/posts/data-logging-sampling-versus-profiling) blog post. 

<img align="left" src="data:image/svg+xml;base64,<svg width="92" height="95" viewBox="0 0 92 95" fill="none" xmlns="http://www.w3.org/2000/svg">
<g opacity="0.5">
<rect x="14" y="23.8096" width="47.1258" height="12.7768" rx="2" fill="#F07028"/>
<rect x="14" y="39.0513" width="47.1258" height="12.7768" rx="2" fill="#F07028"/>
<rect x="14" y="54.2935" width="47.1258" height="12.7768" rx="2" fill="#F07028"/>
</g>
<g filter="url(#filter0_d)">
<path d="M51.6913 54.2418C52.4817 53.8816 53.3895 53.8816 54.1799 54.2418L72.8466 62.7504C73.6269 63.1061 73.627 64.2146 72.8466 64.5702L54.1799 73.0788C53.3895 73.439 52.4817 73.439 51.6913 73.0788L33.0246 64.5702C32.2443 64.2146 32.2443 63.1061 33.0246 62.7504L51.6913 54.2418Z" fill="white"/>
<path d="M51.6913 45.8951C52.4817 45.5348 53.3895 45.5348 54.1799 45.8951L72.8466 54.4036C73.6269 54.7593 73.627 55.8678 72.8466 56.2235L54.1799 64.732C53.3895 65.0923 52.4817 65.0923 51.6913 64.732L33.0246 56.2235C32.2443 55.8678 32.2443 54.7593 33.0246 54.4036L51.6913 45.8951Z" fill="url(#paint0_linear)"/>
<path d="M51.6913 37.5672C52.4817 37.2069 53.3895 37.2069 54.1799 37.5672L72.8466 46.0757C73.6269 46.4314 73.627 47.5399 72.8466 47.8956L54.1799 56.4041C53.3895 56.7644 52.4817 56.7644 51.6913 56.4041L33.0246 47.8956C32.2443 47.5399 32.2443 46.4314 33.0246 46.0757L51.6913 37.5672Z" fill="white"/>
</g>
<circle cx="62.8828" cy="32.5" r="13.5" fill="white" stroke="#FFA776" stroke-width="2"/>
<g clip-path="url(#clip0)">
<path d="M53.6702 37.5587C53.6687 37.562 53.6682 37.5656 53.6668 37.5692C53.6607 37.5843 53.6553 37.5997 53.6517 37.6157C53.6516 37.6158 53.6515 37.6162 53.6514 37.6164C53.6514 37.6166 53.6513 37.6168 53.6513 37.617C53.6499 37.6239 53.6495 37.6308 53.6489 37.6377C53.6471 37.6496 53.6448 37.6612 53.6447 37.6734C53.6447 37.674 53.6444 37.6744 53.6444 37.675C53.6444 37.6752 53.6445 37.6755 53.6445 37.6756C53.6444 37.6767 53.645 37.6774 53.645 37.6783C53.6448 37.696 53.6458 37.7141 53.649 37.7323C53.6525 37.7523 53.658 37.7714 53.6651 37.7897C53.6655 37.7906 53.6658 37.7915 53.6664 37.7925C53.6805 37.8278 53.7011 37.8594 53.7264 37.886C53.7267 37.8867 53.7268 37.8876 53.7273 37.8881C53.728 37.8887 53.7287 37.8891 53.7294 37.8897C53.7466 37.9074 53.7665 37.922 53.7877 37.935C53.7939 37.9387 53.8 37.9424 53.8066 37.9456C53.8294 37.9575 53.8535 37.9673 53.8792 37.9729C53.8795 37.973 53.8801 37.9734 53.8805 37.9735C60.0335 39.3145 62.7117 37.8873 63.7182 36.9996L63.7422 37.8074L64.055 37.7838C65.5851 37.6691 66.6452 36.229 66.6898 36.1679C66.7868 36.0338 66.7568 35.8465 66.6231 35.7491C66.5923 35.727 66.5593 35.7113 66.5247 35.702C66.4082 35.6708 66.2793 35.7119 66.2043 35.8152C66.196 35.8268 65.4127 36.8853 64.3227 37.1372L64.3028 36.4647C64.2983 36.3038 64.1967 36.1662 64.0438 36.1147C63.8924 36.0621 63.7279 36.1104 63.6267 36.2353C63.1756 36.7936 61.4464 38.3515 56.5941 37.8174C61.6529 37.0871 64.9671 34.046 66.9378 31.416C67.5439 30.607 68.0559 29.7998 68.4849 29.0392C68.9122 29.859 69.6047 31.7676 68.2581 33.8558L67.6357 32.4568L67.0722 32.6578C67.0745 32.6669 67.3119 33.5994 66.7062 35.0162C66.6409 35.1685 66.7117 35.3448 66.8639 35.4098C67.0158 35.4752 67.1925 35.4045 67.2575 35.2521C67.4636 34.7704 67.5832 34.3366 67.6491 33.9633L68.1281 35.0404L68.4354 34.643C70.6402 31.7895 69.2439 29.1026 68.8213 28.4222C69.9002 26.3671 70.3413 24.7837 70.3674 24.6886C70.411 24.5289 70.3168 24.3641 70.1571 24.3203C70.1565 24.3201 70.1561 24.32 70.1556 24.3198C69.9964 24.2772 69.8322 24.3713 69.7885 24.5304C69.7795 24.5634 68.8597 27.8569 66.4457 31.0717C63.7369 34.6795 60.326 36.7477 56.2875 37.2547C56.7093 37.036 56.9018 36.8602 56.9173 36.8453C57.0371 36.732 57.0423 36.5444 56.9301 36.4236C56.8906 36.3811 56.8413 36.3526 56.7891 36.3386C56.6929 36.3128 56.5858 36.3355 56.507 36.4076C56.5001 36.414 55.783 37.0549 53.8928 37.385C53.8924 37.3851 53.8919 37.3854 53.8914 37.3854C53.8908 37.3855 53.8902 37.3855 53.8895 37.3856C53.8756 37.3882 53.8623 37.3928 53.8491 37.3973C53.8441 37.3991 53.8387 37.3999 53.8338 37.4017C53.8338 37.4017 53.8337 37.4016 53.8336 37.4018C53.8238 37.4058 53.8148 37.4111 53.8057 37.4163C53.7708 37.4347 53.7403 37.4595 53.7156 37.4891C53.7137 37.4915 53.7115 37.4936 53.7096 37.496C53.7064 37.5001 53.7024 37.5036 53.6994 37.5079C53.6977 37.5104 53.6967 37.5132 53.6951 37.5155C53.6856 37.5293 53.677 37.5435 53.6702 37.5587Z" fill="#F07028" stroke="#F07028" stroke-width="0.65" stroke-linejoin="round"/>
<path d="M57.74 35.9971C58.0964 35.7458 58.606 35.2033 58.8151 34.9744L61.7117 35.0467L59.8889 33.8433L61.2191 32.2694L63.9938 31.7504C64.1435 31.7224 64.2575 31.6022 64.2777 31.4512C64.298 31.3003 64.2197 31.1545 64.0828 31.0882L62.6302 30.384C64.4311 27.9382 67.068 28.1333 67.1833 28.143C67.348 28.1573 67.4934 28.0358 67.5083 27.8711C67.5215 27.7237 67.4259 27.5916 67.2875 27.5545C67.2709 27.5501 67.2539 27.547 67.2363 27.5454C67.1025 27.5333 63.9339 27.2858 61.9327 30.3365L61.7454 30.622L63.1423 31.2992L60.8986 31.7189L58.9946 33.9723L59.6351 34.3951L58.553 34.3679L58.4604 34.4723C58.2743 34.6823 57.7199 35.2775 57.3939 35.5072C57.2586 35.6027 57.2263 35.7899 57.3217 35.9252C57.4173 36.0599 57.6042 36.0926 57.74 35.9971Z" fill="#F07028" stroke="#F07028" stroke-width="0.65" stroke-linejoin="round"/>
</g>
<defs>
<filter id="filter0_d" x="17.4395" y="28.297" width="70.9922" height="66.052" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB">
<feFlood flood-opacity="0" result="BackgroundImageFix"/>
<feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"/>
<feOffset dy="6"/>
<feGaussianBlur stdDeviation="7.5"/>
<feColorMatrix type="matrix" values="0 0 0 0 0.964706 0 0 0 0 0.505882 0 0 0 0 0.192157 0 0 0 0.44 0"/>
<feBlend mode="normal" in2="BackgroundImageFix" result="effect1_dropShadow"/>
<feBlend mode="normal" in="SourceGraphic" in2="effect1_dropShadow" result="shape"/>
</filter>
<linearGradient id="paint0_linear" x1="26.5155" y1="43.5726" x2="78.367" y2="51.827" gradientUnits="userSpaceOnUse">
<stop stop-color="#EA5B4F"/>
<stop offset="1" stop-color="#F9C452"/>
</linearGradient>
<clipPath id="clip0">
<rect width="14.2011" height="17.6013" fill="white" transform="translate(67.0996 41.6768) rotate(-165)"/>
</clipPath>
</defs>
</svg>
"></img>

**Lightweight**: In addition to being a high fidelity representation of data, whylogs profiles also have high information density. You can easily profile terabytes or even petabytes of data in profiles that are only megabytes large. Because whylogs profiles are lightweight, they are very inexpensive to store, transport, and interact with.


<img align="left" src="data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iOTIiIGhlaWdodD0iOTUiIHZpZXdCb3g9IjAgMCA5MiA5NSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPGcgb3BhY2l0eT0iMC41Ij4KPHJlY3QgeD0iMTQiIHk9IjIzLjgwOTYiIHdpZHRoPSI0Ny4xMjU4IiBoZWlnaHQ9IjEyLjc3NjgiIHJ4PSIyIiBmaWxsPSIjRjA3MDI4Ii8+CjxyZWN0IHg9IjE0IiB5PSIzOS4wNTEzIiB3aWR0aD0iNDcuMTI1OCIgaGVpZ2h0PSIxMi43NzY4IiByeD0iMiIgZmlsbD0iI0YwNzAyOCIvPgo8cmVjdCB4PSIxNCIgeT0iNTQuMjkzNSIgd2lkdGg9IjQ3LjEyNTgiIGhlaWdodD0iMTIuNzc2OCIgcng9IjIiIGZpbGw9IiNGMDcwMjgiLz4KPC9nPgo8ZyBmaWx0ZXI9InVybCgjZmlsdGVyMF9kKSI+CjxwYXRoIGQ9Ik01MS42OTEzIDU0LjI0MThDNTIuNDgxNyA1My44ODE2IDUzLjM4OTUgNTMuODgxNiA1NC4xNzk5IDU0LjI0MThMNzIuODQ2NiA2Mi43NTA0QzczLjYyNjkgNjMuMTA2MSA3My42MjcgNjQuMjE0NiA3Mi44NDY2IDY0LjU3MDJMNTQuMTc5OSA3My4wNzg4QzUzLjM4OTUgNzMuNDM5IDUyLjQ4MTcgNzMuNDM5IDUxLjY5MTMgNzMuMDc4OEwzMy4wMjQ2IDY0LjU3MDJDMzIuMjQ0MyA2NC4yMTQ2IDMyLjI0NDMgNjMuMTA2MSAzMy4wMjQ2IDYyLjc1MDRMNTEuNjkxMyA1NC4yNDE4WiIgZmlsbD0idXJsKCNwYWludDBfbGluZWFyKSIvPgo8cGF0aCBkPSJNNTEuNjkxMyA0NS44OTUxQzUyLjQ4MTcgNDUuNTM0OCA1My4zODk1IDQ1LjUzNDggNTQuMTc5OSA0NS44OTUxTDcyLjg0NjYgNTQuNDAzNkM3My42MjY5IDU0Ljc1OTMgNzMuNjI3IDU1Ljg2NzggNzIuODQ2NiA1Ni4yMjM1TDU0LjE3OTkgNjQuNzMyQzUzLjM4OTUgNjUuMDkyMyA1Mi40ODE3IDY1LjA5MjMgNTEuNjkxMyA2NC43MzJMMzMuMDI0NiA1Ni4yMjM1QzMyLjI0NDMgNTUuODY3OCAzMi4yNDQzIDU0Ljc1OTMgMzMuMDI0NiA1NC40MDM2TDUxLjY5MTMgNDUuODk1MVoiIGZpbGw9IndoaXRlIi8+CjxwYXRoIGQ9Ik01MS42OTEzIDM3LjU2NzJDNTIuNDgxNyAzNy4yMDY5IDUzLjM4OTUgMzcuMjA2OSA1NC4xNzk5IDM3LjU2NzJMNzIuODQ2NiA0Ni4wNzU3QzczLjYyNjkgNDYuNDMxNCA3My42MjcgNDcuNTM5OSA3Mi44NDY2IDQ3Ljg5NTZMNTQuMTc5OSA1Ni40MDQxQzUzLjM4OTUgNTYuNzY0NCA1Mi40ODE3IDU2Ljc2NDQgNTEuNjkxMyA1Ni40MDQxTDMzLjAyNDYgNDcuODk1NkMzMi4yNDQzIDQ3LjUzOTkgMzIuMjQ0MyA0Ni40MzE0IDMzLjAyNDYgNDYuMDc1N0w1MS42OTEzIDM3LjU2NzJaIiBmaWxsPSJ1cmwoI3BhaW50MV9saW5lYXIpIi8+CjwvZz4KPGNpcmNsZSBjeD0iNjIuODgyOCIgY3k9IjMyLjUiIHI9IjEzLjUiIGZpbGw9IndoaXRlIiBzdHJva2U9IiNGRkE3NzYiIHN0cm9rZS13aWR0aD0iMiIvPgo8cGF0aCBkPSJNNTcgMzUuNzVWMzNDNTcgMzIuNDQ3NyA1Ny40NDc3IDMyIDU4IDMySDY4QzY4LjU1MjMgMzIgNjkgMzIuNDQ3NyA2OSAzM1YzNyIgc3Ryb2tlPSIjRjA3MDI4IiBzdHJva2Utd2lkdGg9IjEuMjUiLz4KPHBhdGggZD0iTTYzIDI4TDYzIDM2IiBzdHJva2U9IiNGMDcwMjgiIHN0cm9rZS13aWR0aD0iMS4yNSIvPgo8Y2lyY2xlIGN4PSI2MyIgY3k9IjM3IiByPSIyIiBmaWxsPSIjRjA3MDI4Ii8+CjxjaXJjbGUgY3g9IjU3IiBjeT0iMzciIHI9IjIiIGZpbGw9IiNGMDcwMjgiLz4KPGNpcmNsZSBjeD0iNjkiIGN5PSIzNyIgcj0iMiIgZmlsbD0iI0YwNzAyOCIvPgo8cGF0aCBkPSJNNjMgMjRMNjUuNTk4MSAyOC41SDYwLjQwMTlMNjMgMjRaIiBmaWxsPSIjRjA3MDI4Ii8+CjxkZWZzPgo8ZmlsdGVyIGlkPSJmaWx0ZXIwX2QiIHg9IjE3LjQzOTUiIHk9IjI4LjI5NyIgd2lkdGg9IjcwLjk5MjIiIGhlaWdodD0iNjYuMDUyIiBmaWx0ZXJVbml0cz0idXNlclNwYWNlT25Vc2UiIGNvbG9yLWludGVycG9sYXRpb24tZmlsdGVycz0ic1JHQiI+CjxmZUZsb29kIGZsb29kLW9wYWNpdHk9IjAiIHJlc3VsdD0iQmFja2dyb3VuZEltYWdlRml4Ii8+CjxmZUNvbG9yTWF0cml4IGluPSJTb3VyY2VBbHBoYSIgdHlwZT0ibWF0cml4IiB2YWx1ZXM9IjAgMCAwIDAgMCAwIDAgMCAwIDAgMCAwIDAgMCAwIDAgMCAwIDEyNyAwIiByZXN1bHQ9ImhhcmRBbHBoYSIvPgo8ZmVPZmZzZXQgZHk9IjYiLz4KPGZlR2F1c3NpYW5CbHVyIHN0ZERldmlhdGlvbj0iNy41Ii8+CjxmZUNvbG9yTWF0cml4IHR5cGU9Im1hdHJpeCIgdmFsdWVzPSIwIDAgMCAwIDAuOTY0NzA2IDAgMCAwIDAgMC41MDU4ODIgMCAwIDAgMCAwLjE5MjE1NyAwIDAgMCAwLjQ0IDAiLz4KPGZlQmxlbmQgbW9kZT0ibm9ybWFsIiBpbjI9IkJhY2tncm91bmRJbWFnZUZpeCIgcmVzdWx0PSJlZmZlY3QxX2Ryb3BTaGFkb3ciLz4KPGZlQmxlbmQgbW9kZT0ibm9ybWFsIiBpbj0iU291cmNlR3JhcGhpYyIgaW4yPSJlZmZlY3QxX2Ryb3BTaGFkb3ciIHJlc3VsdD0ic2hhcGUiLz4KPC9maWx0ZXI+CjxsaW5lYXJHcmFkaWVudCBpZD0icGFpbnQwX2xpbmVhciIgeDE9IjI2LjUxNTUiIHkxPSI1MS45MTk0IiB4Mj0iNzguMzY3IiB5Mj0iNjAuMTczOCIgZ3JhZGllbnRVbml0cz0idXNlclNwYWNlT25Vc2UiPgo8c3RvcCBzdG9wLWNvbG9yPSIjRUE1QjRGIi8+CjxzdG9wIG9mZnNldD0iMSIgc3RvcC1jb2xvcj0iI0Y5QzQ1MiIvPgo8L2xpbmVhckdyYWRpZW50Pgo8bGluZWFyR3JhZGllbnQgaWQ9InBhaW50MV9saW5lYXIiIHgxPSIyNi41MTU1IiB5MT0iMzUuMjQ0NyIgeDI9Ijc4LjM2NyIgeTI9IjQzLjQ5OTEiIGdyYWRpZW50VW5pdHM9InVzZXJTcGFjZU9uVXNlIj4KPHN0b3Agc3RvcC1jb2xvcj0iI0VBNUI0RiIvPgo8c3RvcCBvZmZzZXQ9IjEiIHN0b3AtY29sb3I9IiNGOUM0NTIiLz4KPC9saW5lYXJHcmFkaWVudD4KPC9kZWZzPgo8L3N2Zz4K"></img>

**Mergeable**: One of the most powerful features of whylogs profiles is their mergeability. Mergeability means that whylogs profiles can be combined together to form new profiles which represent the aggregate of their constituent profiles. This enables logging for distributed and streaming systems, and allows users to view aggregated data across any time granularity.


## Visualizing Profiles<a name="visualizing-profiles" />

### Multiple profile plots

To view your logger profiles you can use, methods within `whylogs.viz`: 

```python
vizualization = ProfileVisualizer()
vizualization.set_profiles([profile_day_1, profile_day_2])
figure= vizualization.plot_distribution("<feature_name>")
figure.savefig("/my/image/path.png")
```

Individual profiles are saved to disk, AWS S3, or WhyLabs API, automatically when loggers are closed, per the configuration found in the Session configuration.

Current profiles from active loggers can be loaded from memory with:
```python
profile = logger.profile()
```

### Profile viewer

You can also load a local profile viewer, where you upload the `json` summary file. The default path for the json files is set as `output/{dataset_name}/{session_id}/json/dataset_profile.json`.

```python
from whylogs.viz import profile_viewer
profile_viewer()
```

This will open a viewer on your default browser where you can load a profile json summary, using the `Select JSON profile` button:
Once the json is selected you can view your profile's features and 
associated and statistics.

<img src="https://whylabs-public.s3-us-west-2.amazonaws.com/assets/whylogs-viewer.gif" title="whylogs HTML viewer demo">

## Features


whylogs collects approximate statistics and sketches of data on a column-basis into a statistical profile. These metrics include:

- Simple counters: boolean, null values, data types.
- Summary statistics: sum, min, max, median, variance.
- Unique value counter or cardinality: tracks an approximate unique value of your feature using HyperLogLog algorithm.
- Histograms for numerical features. whyLogs binary output can be queried to with dynamic binning based on the shape of your data.
- Top frequent items (default is 128). Note that this configuration affects the memory footprint, especially for text features.

Some other key features about whylogs:

- Accurate data profiling: whylogs calculates statistics from 100% of the data, never requiring sampling, ensuring an accurate representation of data distributions
- Lightweight runtime: whylogs utilizes approximate statistical methods to achieve minimal memory footprint that scales with the number of features in the data
- Any architecture: whylogs scales with your system, from local development mode to live production systems in multi-node clusters, and works well with batch and streaming architectures
- Configuration-free: whylogs infers the schema of the data, requiring zero manual configuration to get started
- Tiny storage footprint: whylogs turns data batches and streams into statistical fingerprints, 10-100MB uncompressed
- Unlimited metrics: whylogs collects all possible statistical metrics about structured or unstructured data


## Data Types<a name="data-types" />
Whylogs supports both structured and unstructured data, specifically: 

| Data type  | Features | Notebook Example |
| --- | --- | ---|
|Structured Data | Distribution, cardinality, schema, counts, missing values | [Getting started with structured data](https://github.com/whylabs/whylogs-examples/blob/mainline/python/GettingStarted.ipynb) | 
| Images | exif metadata, derived pixels features,  bounding boxes | [Getting started with images](https://github.com/whylabs/whylogs-examples/blob/mainline/python/Logging_Images.ipynb) |
| Video  | In development  | [Github Issue #214](https://github.com/whylabs/whylogs/issues/214) |
| Tensors | derived 1d features (more in developement) | [Github Issue #216](https://github.com/whylabs/whylogs/issues/216) |
| Text | top k values, counts, cardinality | [String Features](https://github.com/whylabs/whylogs/blob/mainline/examples/String_Features.ipynb) |
| Audio | In developement | [Github Issue #212](https://github.com/whylabs/whylogs/issues/212) | 


## Integrations

![current integration](images/integrations.001.png)
| Integration | Features | Resources |
| --- | --- | ---  | 
| Spark | Run whylogs in Apache Spark environment|  <ul><li>[Code Example](https://github.com/whylabs/whylogs-examples/blob/mainline/scala/src/main/scala/WhyLogsDemo.scala)</li></ul> | 
| Pandas | Log and monitor any pandas dataframe |  <ul><li>[Notebook Example](https://github.com/whylabs/whylogs-examples/blob/mainline/python/logging_example.ipynb)</li><li>[whylogs: Embrace Data Logging](https://whylabs.ai/blog/posts/whylogs-embrace-data-logging)</li></ul>  |
| Kafka | Log and monitor Kafka topics with whylogs| <ul><li>[Notebook Example](https://github.com/whylabs/whylogs-examples/blob/mainline/python/Kafka.ipynb)</li><li> [Integrating whylogs into your Kafka ML Pipeline](https://whylabs.ai/blog/posts/integrating-whylogs-into-your-kafka-ml-pipeline) </li></ul>|
| MLflow | Enhance MLflow metrics with whylogs:  | <ul><li>[Notebook Example](https://github.com/whylabs/whylogs-examples/blob/mainline/python/MLFlow%20Integration%20Example.ipynb)</li><li>[Streamlining data monitoring with whylogs and MLflow](https://whylabs.ai/blog/posts/on-model-lifecycle-and-monitoring)</li></ul> |
| Github actions | Unit test data with whylogs and github actions| <ul><li>[Notebook Example](https://github.com/whylabs/whylogs-examples/tree/mainline/github-actions)</li></ul> |
| RAPIDS |  Use whylogs in RAPIDS environment | <ul><li>[Notebook Example](https://github.com/whylabs/whylogs-examples/blob/mainline/python/RAPIDS%20GPU%20Integration%20Example.ipynb)</li><li>[Monitoring High-Performance Machine Learning Models with RAPIDS and whylogs](https://whylabs.ai/blog/posts/monitoring-high-performance-machine-learning-models-with-rapids-and-whylogs)</li></ul> |
| Java | Run whylogs in Java environment| <ul><li>[Notebook Example](https://github.com/whylabs/whylogs-examples/blob/mainline/java/demo1/src/main/java/com/whylogs/examples/WhyLogsDemo.java)</li></ul>  |
| Docker | Run whylogs as in Docker |  <ul><li>[Rest Container](https://docs.whylabs.ai/docs/integrations-rest-container)</li></ul>| 
| AWS S3 |  Store whylogs profiles in S3 | <ul><li>[S3 example](https://github.com/whylabs/whylogs-examples/blob/mainline/python/S3%20example.ipynb)</li></ul>

## Examples
For a full set of our examples, please check out [whylogs-examples](https://github.com/whylabs/whylogs-examples).

Check out our example notebooks with Binder: [![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/whylabs/whylogs-examples/HEAD)
- [Getting Started notebook](https://github.com/whylabs/whylogs-examples/blob/mainline/python/GettingStarted.ipynb)
- [Logging Example notebook](https://github.com/whylabs/whylogs-examples/blob/mainline/python/logging_example.ipynb)
- [Logging Images](https://github.com/whylabs/whylogs-examples/blob/mainline/python/Logging_Images.ipynb)
- [MLflow Integration](https://github.com/whylabs/whylogs-examples/blob/mainline/python/MLFlow%20Integration%20Example.ipynb)


## Roadmap

whylogs is maintained by [WhyLabs](https://whylabs.ai).

## Community

If you have any questions, comments, or just want to hang out with us, please join [our Slack channel](http://join.slack.whylabs.ai/).

## Contribute

We welcome contributions to whylogs. Please see our [contribution guide](https://github.com/whylabs/whylogs/blob/mainline/CONTRIBUTING.md) and our [development guide](https://github.com/whylabs/whylogs/blob/mainline/DEVELOPMENT.md) for details.

