Content Tags

There are no tags.

Data Validation in Machine Learning is Imperative, Not Optional

Authors
Aditya Aggarwal, Arnab Bose

(This article originally appeared on KDNuggets.com here. For more, visit https://www.kdnuggets.com/)

Before we reach model training in the pipeline, there are various components like data ingestion, data versioning, data validation, and data pre-processing that need to be executed. In this article, we will discuss data validation, why it is important, its challenges, and more.

Operationalizing a Machine Learning (ML) model in production needs a lot more than just creating and validating models like in academia or research. The ML application in production can be a pipeline with multiple components running consecutively as shown in Fig 1. Before we reach model training in the pipeline, there are various components like Data Ingestion, Data versioning, Data validation, and Data pre-processing that need to be executed. Here, we will discuss the Data Validation and have arranged this article as below:

  1. What is data validation?
  2. Why is data validation required?
  3. What are the challenges with data validation?
  4. How does the data validation component work?
  5. Examples of data validation components available in the market.​​​​​​​​​​​​​​

Figure
Figure 1: Components in machine learning pipelines

1) What is data validation?

​​​​​​​Data validation means checking the accuracy and quality of source data before training a new model version. It ensures that anomalies that are infrequent or manifested in incremental data are not silently ignored. It focuses on checking that the statistics of the new data are as expected (e.g. feature distribution, number of categories, etc). Different types of validation can be performed depending on objectives and constraints. Examples of such objectives in the machine learning pipeline are below - ​​​​​​​

  1. Are there any anomalies or data errors in the incremental data? If yes, raise an alert to the team for investigation.
  2. Are there any assumptions on data that are taken during model training and are getting violated during serving? If yes, raise an alert to the team for investigation.
  3. Are there significant differences between training and serving data? Or, Are there differences between successive data that are getting added into training data? If yes, raise an alert to investigate differences in training and serving code stack.​​​​​​​​​​​​​​

Output from the data validation step should be informative enough that a data engineer can take action on it. Also, it needs to have high precision as too many false alarms will easily be lost credibility.

2) Why is data validation required?​​​​​​​

Machine learning models are vulnerable to poor data quality as per the old adage "garbage in garbage out". 

In production, the model gets re-trained with a fresh set of incremental data added on a periodic basis (as frequent as daily) and the updated model is pushed to the serving layer. The model makes predictions with new incoming data while serving and the same data is added with actual labels and used for retraining. This ensures that the newly generated model adapts to the changes in data characteristics.  ​​​​​​​

However, the new incoming data in the serving layer can change due to various reasons like changes in code that introduces errors in the serving data ingestion component or the difference between training and serving stacks. With time, the erroneous ingested data​​​​​​​ will become part of the training data and this will start degrading the model accuracy. Since In each iteration, newly added data is generally a small fraction of overall training data, hence, the changes in model accuracy will be easily missed and the errors will keep adding with time. ​​​​​​​ ​​​​​​​​​​​​​​

Thus, catching the data errors at an early stage is very important because it will reduce the cost of data error which is bound to increase as the error propagates further in the pipeline (as shown in fig 2). ​​​​​​​​​​​​​​​​​​​​​

Figure
Figure 2: Cost of data error in machine learning pipelines

3) What are the challenges with the data validation?

There are various challenges that a data scientist faces while developing a data validation component, such as

  1. Creating data validation rules for a dataset with few columns does sound simple. However, when the number of columns in datasets increases, it becomes a humongous task.
  2. Tracking and comparing metrics from the historical datasets to find anomalies in historical trends for each column needs a good amount of recurring time from a data scientist.
  3. Today applications are expected to run 24-by-7 and in such scenarios, data validation needs to be automated. The data validation component should be smart enough to refresh validation rules.

4) How does the data validation component work?

Think of the data validation component as a guard post of the ML application that does not let bad quality data in. It keeps a check on each and every new data entry that is going to add to the training data. As shown in Fig 3, the data validation framework can be summarised in 5 steps:

  1. ​​​​Calculate the statistics from the training data against a set of rules
  2. Calculate the statistics of the ingested data that has to be validated
  3. Compare the statistics of the validation data with the statistics from the training data  
  4. Store the validation results and takes automated actions like removing the row, capping, or flooring the values
  5. Sending the notification and alerts for approval​​​​​​​

Figure
Figure 3: Data validation workflow (click to enlarge)

5) Examples of data validation components available in the market 

​​​​​​​​​​​​Amazon Research [1] and Google Research [2] proposed a very similar approach to building a data validation component. Overall, both approaches follow the same workflow as given in Fig 2. We will discuss both approaches here.

5.1) Unit-test approach for data validation by Amazon Research (Deequ)

In software engineering, engineers write unit tests to test their code. Similarly, unit tests should also be defined to test the incoming data. Authors have defined a framework to define this component that follows the below principles -

a) Declare constraints: User defines how their data should look like. It works by declaring checks on their data by composing constraints on various columns. A list of constraints is shown in Table 1 below.

b) Compute metrics: Based on the declared constraint, translate them to measurable metrics as shown in Table 2 below. These metrics can be computed and compared between the data in hand and the incremental data.

c) Analyze and report: Based on the collected metrics over time, predict if the metric on the incremental data is an anomaly or not. As a rule, the user can have the system issue "a warning" if the new metric is more than three standard deviations away from the previous mean or throw "an error" if it is more than four standard deviations away. Basis the analysis, report the constraints that fail including the value(s) that made the constraint fail. ​​​​​​

Table 1: Constraints available for composing user-defined data quality checks
Figure

Table 2: Computable metrics to based constraints on
Figure

5.2) Data schema approach for data validation by Google Research (Tensorflow data validation)

​​​​​​Google Research has come up with a very similar technique but adopted "battle-tested" principles from the data management system and customized it for ML. This technique first codifies the expectation from correct data and then using these expected statistics along with user-defined validation schema performs data validation.​​​​​​​ This data validation framework consists of 3 sub-component as also shown in Fig 4. 

  1. Data Analyzer - computes a predefined set of data statistics required to define the data
  2. Data Validator - checks for properties of data as specified through a schema. This schema is a precursor for a data validator to perform. This schema list out all the constraints on the features for basic checks and ML-related checks.  
  3. Model Unit Tester - checks for errors in training code using synthetic data generated through the schema

This framework gives the user the ability to

  1. validate a single batch of incremental data by detecting anomalies in it
  2. Detect significant changes between successive batches of incremental training data. Few anomalies are not visible when checking only a single batch but manifest when we look at successive batches.​​​​​​​
  3. Find assumptions in the training code that are not reflected in the data (e.g. if a feature is expected to have log() in the training code should not have -ve value or string values). The goal here is to cover those constraints that are missed to add into the schema. It happens in 2 steps
    1. ​​​​​Synthetic training examples that adhere to the schema constraints are generated 
    2. This generated data is iterated through the training code for checking errors

Figure
Figure 4: Data validation for machine learning by Google Research

Both Amazon Research and Google Research approaches provide users with suggestions such as constraints in the Amazon framework and recommendations to update schema in the google framework. Both approaches treat data as a first-class citizen in ML pipelines and do data validation before putting data into the system. However, there are few differences worth noting.

Table 3: Differences between data validation libraries

  Deequ (Amazon) Tensorflow data validation (Google)
1 No visualization available Provides visualization using Google Facets. It summarises statistics for each feature and compares the training and validation data.
2 Recalculates training statistics by aggregating prior saved training statistics and new data statistics.   Calculates statistics on whole training data in every run unless specified. This may become computationally expensive.
3 Provides capability to do anomaly detection based on running average and standard deviation in addition to the threshold or absolute/relative difference from training data. Provides capability to do anomaly detection based on the threshold or absolute/relative difference from training data.
4 Supports data only in SparkDataFrame. Supports pandas dataframe, csv, and best works with TFRecord.

References

  1. S. Schelter, D. Lange, P. Schmidt, M. Celikel, F. Biessmann and A. Grafberger, "Automating Large-Scale Data Quality Verification" in Proceedings of the VLDB endowment, volume 11, Issue 12: 1781-1794, 2018. Available: http://www.vldb.org/pvldb/vol11/p1781-schelter.pdf​​​​​​​
  2. E. Breck, M. Zinkevich, N. Polyzotis, S. Whang and S. Roy, "Data validation for machine learning", in Proceedings of the 2nd SysML Conference, Palo Alto, CA, USA, 2019. Available: https://mlsys.org/Conferences/2019/doc/2019/167.pdf

Stay in the loop.

Subscribe to our newsletter for a weekly update on the latest podcast, news, events, and jobs postings.