Method and System of Correcting Data Imbalance in a Dataset Used in Machine-Learning

Information

  • Patent Application
  • 20200380309
  • Publication Number
    20200380309
  • Date Filed
    May 28, 2019
    5 years ago
  • Date Published
    December 03, 2020
    4 years ago
Abstract
A method and system for correcting imbalanced distribution of data that may signal bias in a dataset associated with training a machine-learning (ML) model includes receiving a request to perform a data imbalance correction on a dataset associated with training a machine-learning (ML) model, identifying a feature of the dataset for which data imbalance correction is to be performed, identifying a desired distribution for the identified feature, selecting a subset of the dataset that corresponds with the selected feature and the desired distribution, and using the subset to train a ML model.
Description
BACKGROUND

In recent years, machine learning techniques are increasingly used in training machine learning models that provide functionalities in everyday life. These functionalities may have consumer related applications or may be used by institutions and organizations in automating decisions that were traditionally made by humans. For example, banks may use machine learning models to determine loan approvals, credit scoring or interest rates. Other institutions may utilize machine learning models to make hiring decisions, salary and bonus determinations and the like. Machine learning models may be used in making decisions in many other instances that have significant implications in people's lives. These machine learning models are often trained using large datasets that are collected in a variety of different manners by people or institutions. For example, researchers conducting research or organizations that are in the business of collecting data are some of the entities that may provide datasets for training machine leaning models.


The process of collecting data, however, often introduces bias in the dataset. For example, most datasets are skewed heavily towards a certain type of demographic. This may be because of bias in the way data is collected by the data collector or simply because data relating to certain demographics are more readily available. Regardless of how bias is introduced in a dataset, the results can be harmful. For example, if the dataset does not include as many female datapoints as male datapoints, the machine leaning model trained based on this dataset may produce results that are more favorable to males. When machine learning models are used to make important decisions, such biases can have significant implications for people.


Hence, there is a need for improved systems and methods of correcting bias in datasets associated with machine learning techniques.


SUMMARY

In one general aspect, this disclosure presents a device having a processor and a memory in communication with the processor wherein the memory stores executable instructions that, when executed by the processor, cause the device to perform multiple functions. The functions may include receiving a request to perform a data imbalance correction on a dataset associated with training a machine-learning (ML) model, identifying a feature of the dataset for which data imbalance correction is to be performed, identifying a desired distribution for the identified feature, selecting a subset of the dataset that corresponds with the selected feature and the desired distribution, and using the subset to train a ML model.


In yet another general aspect, the instant application describes a method for correcting data imbalance in a dataset associated with training a ML model. The method may include receiving a request to perform a data imbalance correction on a dataset associated with training a machine-learning (ML) model, identifying a feature of the dataset for which data imbalance correction is to be performed, identifying a desired distribution for the identified feature, selecting a subset of the dataset that corresponds with the selected feature and the desired distribution, and using the subset to train a ML model.


In a further general aspect, the instant application describes a non-transitory computer readable medium on which are stored instructions that when executed cause a programmable device to receive a request to perform a data imbalance correction on a dataset associated with training a machine-learning (ML) model, identify a feature of the dataset for which data imbalance correction is to be performed, identify a desired distribution for the identified feature, select a subset of the dataset that corresponds with the selected feature and the desired distribution, and use the subset to train a ML model.


This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter. Furthermore, the claimed subject matter is not limited to implementations that solve any or all disadvantages noted in any part of this disclosure.





BRIEF DESCRIPTION OF THE DRAWINGS

The drawing figures depict one or more implementations in accord with the present teachings, by way of example only, not by way of limitation. In the figures, like reference numerals refer to the same or similar elements. Furthermore, it should be understood that the drawings are not necessarily to scale.



FIG. 1 depicts a simplified example system architecture for detecting and addressing data imbalance in machine learning operations.



FIG. 2 depicts an example environment upon which aspects of this disclosure may be implemented.



FIG. 3A-3C depict example bar charts for displaying distribution in data.



FIG. 4 depicts an example bar chart displaying a distribution of data across the gender spectrum in a corrected subset of data.



FIGS. 5A-5B depict more example methods of visualizing bias in a dataset.



FIG. 6 is a flow diagram depicting an example method for correcting data imbalance in a dataset associated with training a ML model.



FIG. 7 is a block diagram illustrating an example software architecture, various portions of which may be used in conjunction with various hardware architectures herein described.



FIG. 8 is a block diagram illustrating components of an example machine configured to read instructions from a machine-readable medium and perform any of the features described herein.





DETAILED DESCRIPTION

In the following detailed description, numerous specific details are set forth by way of examples in order to provide a thorough understanding of the relevant teachings. It will be apparent to persons of ordinary skill, upon reading this description, that various aspects can be practiced without such details. In other instances, well known methods, procedures, components, and/or circuitry have been described at a relatively high-level, without detail, in order to avoid unnecessarily obscuring aspects of the present teachings.


Large datasets are increasingly used in training machine learning models that provide a variety of functionalities. With the significant increase in use of machine learning models in business and personal arenas to automate decision making functions, the contents of such large datasets can significantly affect different aspects of people's everyday lives. As a result, uncorrected bias in a dataset used for training a machine learning model can have significant negative implications on people or institutions the dataset was biased against. For example, if a dataset has a substantially larger number of datapoints for a particular population, the training performed based on such a dataset may heavily skew the trained model in favor of that particular population. This can introduce undesired and at times unknown discrimination against certain populations in the way the trained model makes decisions. Furthermore, a biased dataset and/or one that includes imbalanced data may result in a model that produces incorrect results. For example, if a dataset has one or more features that have missing values for a large number of datapoints, it may be difficult to correlate those features with accurate outcomes. Thus, data imbalance may include biased data or data that otherwise contains some imbalance that may cause inaccuracies in outcome.


However, even after data imbalance is detected in a dataset, it may be difficult to correct it. That is because often data imbalance is introduced as a result of gaps in the dataset. In other words, data imbalance may be introduced when the dataset does not include enough datapoints for a certain demographic. To address this, more data associated with the certain demographic may need to be obtained to close the gaps. However, in many cases, additional data is too expensive and challenging to obtain. For example, human medical data used in training models related to the medical field may take years (e.g., longitudinal data on smoking risks) or be impossible to obtain. In another example, additional data cannot be obtained for correlating local pollution involving a toxic chemical with health risks, where the toxin is no longer being manufactured. In such cases, obtaining a new dataset or even additional datapoints intended to correct data imbalance in the dataset may not be an option. Furthermore, the process of obtaining a new dataset may introduce new unintended data imbalance. Addressing such a bias by obtaining more or new data may result in a continuous search for more data which can be inefficient and highly expensive. As a result, data imbalance in training a machine learning model may be difficult to correct.


To address these issues and more, in an example, this description provides techniques used for correcting data imbalance in datasets associated with training of a machine learning model. In an example, data imbalance can be corrected by selecting subsets of the original dataset that reduce or eliminate bias and/or data imbalance. This can be done by enabling a user or the system to select feature(s) of the dataset for which a specific distribution is desired to reduce bias and/or data imbalance, and then identifying the specific distribution for the selected feature(s). A subset of the dataset that introduced bias and/or data imbalance may then be selected based on the selected feature(s) and desired distributions. The subset may then be examined for and/or data imbalance and if imbalance associated with bias or inaccurate output is detected, the process may be repeated iteratively until a desired result is achieved. As a result, the solution provides a method of easily and efficiently correcting bias and/or data imbalance in large datasets associated with training of machine learning models.


As will be understood by persons of skill in the art upon reading this disclosure, benefits and advantages provided by such implementations can include, but are not limited to, a solution to the technical problems of inaccurate and biased training of machine learning models. Technical solutions and implementations provided here optimize the process of correcting imbalance distribution of certain features of a database that may result in biased ML models by trimming the dataset until a desired distribution is achieved. The benefits provided by these solutions provide efficient and timely correction of bias and/or data imbalance in ML training which can increase accuracy and fairness and provide machine learning models that comply with ethical and legal standards.


As a general matter, the methods and systems described herein may relate to, or otherwise make use of, machine-trained models. Machine learning (ML) generally involves various algorithms that can automatically learn over time. The foundation of these algorithms is generally built on mathematics and statistics that can be employed to predict events, classify entities, diagnose problems, and model function approximations. As an example, a system can be trained in order to identify patterns in user activity, determine associations between various datapoints and make decisions based on the patterns and associations. Such determination may be made following the accumulation, review, and/or analysis of data from a large number of users over time, that may be configured to provide the ML algorithm (MLA) with an initial or ongoing training set.


In different implementations, a training system may be used that includes an initial ML model (which may be referred to as an “ML model trainer”) configured to generate a subsequent trained ML model from training data obtained from a training data repository. The generation of this ML model may be referred to as “training” or “learning.” The training system may include and/or have access to substantial computation resources for training, such as a cloud, including many computer server systems adapted for machine learning training. In some implementations, the ML model trainer is configured to automatically generate multiple different ML models from the same or similar training data for comparison. For example, different underlying ML algorithms may be trained, such as, but not limited to, decision trees, random decision forests, neural networks, deep learning (for example, convolutional neural networks), support vector machines, regression (for example, support vector regression, Bayesian linear regression, or Gaussian process regression). As another example, size or complexity of a model may be varied between different ML models, such as a maximum depth for decision trees, or a number and/or size of hidden layers in a convolutional neural network.


Moreover, different training approaches may be used for training different ML models, such as, but not limited to, selection of training, validation, and test sets of training data, ordering and/or weighting of training data items, or numbers of training iterations. One or more of the resulting multiple trained ML models may be selected based on factors such as, but not limited to, accuracy, computational efficiency, and/or power efficiency. In some implementations, a single trained ML model may be produced.


The training data may be continually updated, and one or more of the models used by the system can be revised or regenerated to reflect the updates to the training data. Over time, the training system (whether stored remotely, locally, or both) can be configured to receive and accumulate more and more training data items, thereby increasing the amount and variety of training data available for ML model training, resulting in increased accuracy, effectiveness, and robustness of trained ML models.



FIG. 1 illustrates system architecture 100 for detecting and correcting bias in machine learning operations. The system 100 may include a dataset repository 110 which includes one or more datasets for training a ML model. Each dataset may include a significant number of datapoints. In an example the datasets may include tens of thousands of datapoints. The datasets may be provided by one or more organizations. For example, organizations that collect consumer data as part of their applications may provide data collected by the applications for training ML models. In another example, a dataset may be provided by a researcher conducting research on a population or a scientific subject. For example, health related data may be provided by researches that conduct research in the medical field and provide their findings in a dataset. Other types of data collection may be employed. For example, polling data may be collected and provided by pollsters, or data relating to specific outcomes may be collected and provided by organizations that wish to use the outcomes to train models that predict more desirable outcomes. For example, banks may collect data on loan defaults and circumstances that lead to defaults to train a ML model that determines if a person qualifies for a loan. In another example, non-human data may be collected and provided by organizations that work in a field. For example, temperature readings from a large set of automated sensors may be collected in a dataset and used to train a ML model for predicting conditions that correspond with temperature changes. In one implementation, the training datasets may be continually updated as more data becomes available. It should be noted that the dataset can include tabular and non-tabular data. For example, datasets including image or voice data may be used to train facial recognition or voice recognition ML models. The dataset repository 110 may be stored in a cloud environment or one or more local computers or servers.


To comply with privacy and security regulations and ethical guidelines, the datasets may be anonymized and generalized to ensure they do not expose a person's private information. However, even if a dataset does include some private information, the bias detection and correction system 120 may only retain facets of the data that are anonymized and generalized such that there is no connection between the final results and any specific data point that contributed to it.


Once a dataset is ready to be used in training a ML model, the data included in the dataset may be divided into training and validation sets 115. That is because when a model is trained on a certain set of data, the data may be split into a training subset and a validation subset. This is to determine whether the model is accurately processing data it has not seen before. The process may involve training the model on the training subset of data, and then providing the trained model the validation subset of data as input to determine how accurately the model predicts and classifies the validation data. The predictions and classifications may then be compared to the labels already determined by the validation dataset to determine their accuracy.


Once the subsets have been prepared, the dataset 110 may be examined by a bias detection and correction system 120 to determine if any undesired bias exists in the dataset. The bias detection system 120 may be provided as a service that can access and statistically examine a dataset to identify bias and/or imbalanced data. Furthermore, the bias detection and correction system 120 may be provided as a tool integrated into one or more applications that process data. The bias detection and correction system 120 may be accessible via a computer client device 180 by enabling a user 170 to provide input, execute a bias detection operation, view the results of the bias detection operation via one or more user interfaces, and execute one or more imbalanced data correction operations. The user 170 may be a person(s) responsible for managing the ML training or any other user of a dataset in the dataset repository 110.


The bias detection and correction system 120 may be used to detect bias in the original dataset in addition to identifying bias in other subsets of data, such as the training and validation subsets 115 used to train a model. That is because while many automated techniques for splitting the data set into training and validation datasets make an attempt to provide a good distribution of data in both datasets, the techniques do not check for or ensure that no imbalanced data is introduced during the splitting process. Checking for imbalanced data before training is thus an important part of producing low-bias ML models, as bias or imbalance in the training data may introduce outcome bias or outcome inaccuracy in the model, and bias in the validation data may miss or overemphasize bias in the outcomes.


In one implementation, a user 190 may be notified of bias and/or imbalanced data detected by the bias detection and correction system 120 via for example the user 170. The user 190 may represent a researcher or any other person or organization responsible for collecting data as part of a dataset used in the system 100. The notification may include information about the types of bias identified in the dataset to enable the user 190 to collect data that fills the gaps identified by the bias detection and correction system 120. For example, if the bias detection system determines that the dataset does not include enough data entries for people of color, user 190 may be notified of this imbalanced distribution such that they can begin collecting more data that represents people of color. Thus, the bias detection system 120 may operate as a feedback mechanism to help researchers and data collectors collect more inclusive data. The more inclusive data may then be added to the dataset which may once again be examined via the bias detection and correction 120 system to ensure a more balanced distribution has been achieved and/or some other bias was not introduced in the process.


However, as discussed above, it may often be too challenging and/or expensive to obtain addition data. In such cases, the bias detection and correction system 120 may be used to select a subset of the original data in a way that reduces or eliminates the detected bias. For example, the bias detection and correction system 120 may be used to iteratively select a subset of the initial dataset (or, alternatively, subsets for training and validation) that reduce each or all of the identified biases (e.g., bias in the original dataset, bias in the split training and validation subsets of data, bias in labeling, and output bias) to under a given threshold or to match a given desired distribution.


Once a dataset in the dataset repository 110 is examined by the bias detection and correction system 120 and identified bias is corrected to a desired threshold, then the dataset may be used by a model trainer 130 to train a trained model 140. The model trainer 130 can be any supervised learning machine learning training mechanism known in the art and used for training ML models. After the training process is complete, then the trained model 140 may be used to generate output data 150, which may then be examined by the bias detection and correction system 120 to ensure the outcome does not show signs of bias or inaccuracy. That is because, even with unbiased input data, a model may be trained to deliver biases in outcome. For example, even if the input dataset includes an equal number of men and women, a trained model may rate more men than women good credit risks because of hidden associations in the data, because of a label imbalance (e.g., more men in the input dataset are labeled as good risks even though overall there are just as many good risks as bad risks in the input data), or because the validation dataset has a different distribution in key features than the training dataset. Thus, even if the input dataset is examined, corrected and approved as unbiased, it may be important to examine the outcome data to ensure that the outcome is also unbiased or low-biased. As a result, the output data 150 may be provided to the bias detection and correction system 120 to identify bias in the outcome. If and when undesired bias is identified in the output data 150, the bias detection and correction system 120 may be used to select a subset of the input data to correct the bias. In one implementation, the user 170 may determine what changes can be made to the input dataset to better train the model to address the identified bias and initiate correcting the bias by selecting a different subset of the data. Once the model is determined to be unbiased or low-biased within a threshold of desired distribution, then the trained model may be deployed for use in the real-world via deployment mechanism 160.



FIG. 2 illustrates an example environment 200 upon which aspects of this disclosure may be implemented. The environment 200 may include a server 210 which may be connected to or include a data store 212 that may function as a repository in which datasets used for training ML models may be stored. The server 210 may operate as a shared resource server located at an enterprise accessible by various computer client devices such as client device 230. The server may also operate as a cloud-based server for bias detection and correction services in one or more applications such as applications 236.


The server 210 may also include and/or execute a bias detection and correction service 214 which may provide intelligent bias detection and correction for users utilizing applications that include data processing and visualization or access to ML training mechanisms on their client devices such as client device 230. The bias detection and correction service 214 may operate to examine data processed or viewable by a user via an application (e.g., applications 222 or applications 236), identify bias in specific features of the data, report the detected bias to the user, and correct the detected bias. In one implementation, the process of detecting bias in a dataset is performed by a bias detection engine 216, while the process of correcting bias is performed via a bias correction engine 218. In one implementation, the bias detection engine 216 and bias correction engine 218 may be combined into one logical unit.


Datasets for which bias is examined, detected, and corrected by the bias detection and correction service may be used for training ML models by a training mechanism 224. The training mechanism 224 may use training datasets stored in the datastore 212 to provide initial and/or ongoing training for ML models. In one implementation, the training mechanism 224 may use labeled training data from the data store 212 train the ML models. The initial training may be performed in an offline or online stage. In another example, the training mechanism 224 may utilize unlabeled training data from the datastore 212 to train the ML model via an unsupervised learning mechanism. Unsupervised learning may allow the ML model to create and/or output its own labels. In an example, an unsupervised learning mechanism may apply reinforcement learning to maximize a given value function or achieve a desired goal.


The client device 230 may be connected to the server 210 via a network 220. The network 220 may be a wired or wireless network(s) or a combination of wired and wireless networks that connect one or more elements of the environment 200. The client device 230 may be a personal or handheld computing device having or being connected to input/output elements that enable a user to interact with various applications (e.g., applications 222 or applications 236) and services. Examples of suitable client devices 230 include but are not limited to personal computers, desktop computers, laptop computers, mobile telephones; smart phones; tablets; phablets; smart watches; wearable computers; gaming devices/computers; televisions; and the like. The internal hardware structure of a client device is discussed in greater detail in regard to FIGS. 7 and 8. It should be noted that client device 230 is representative of one example client device for simplicity. Many more client devices may exist in real-world environments.


The client device 230 may include one or more applications 236. Each application 236 may be a computer program executed on the client device that configures the device to be responsive to user input to allow a user to interact with a dataset. The interactions may include viewing, editing and/or examining data in a dataset. Examples of suitable applications include, but are not limited to, a spreadsheet application, a business analytics application, a report generating application, ML training applications, and any other application that collects and provides access to data. Each of the applications 236 may provide bias detection either via the local bias detection engine 234 or via the bias detection service 214. Applications 236 may also provide bias and/or imbalanced data correction via the local bias correction engine 238 or via the bias correction service 218. Bias detection may be integrated into any of the applications 236 as a tool, for example via an application programming interface (API), that can be provided via the applications 236.


In some examples, applications used for processing, collecting or editing data may be executed on the server 210 (e.g., applications 222) and be provided via an online service. In one implementation, web applications may communicate via the network 220 with a user agent 232, such as a browser, executing on the client device 230. The user agent 232 may provide a user interface that allows the user to interact with applications 222 and may enable applications 222 to provide bias detection and correction as part of the service. In other examples, applications used to process, collect, or edit data with which bias detection and correction can be provided may be local applications such as applications 236 that are stored and executed on the client device 230 and provide a user interface that allows the user to interact with the applications. Applications 236 may have access to or display datasets in the data store 212 via the network 220 for example for user review and bias detection and correction. In another example, data stored on the client device 230 and used by applications 236 may be utilized by the training mechanism 224 to train a ML model. In either scenario, bias detection and correction may be provided to examine a dataset, identify imbalanced data, and/or correct it.



FIGS. 3A-3B depict example bar charts for displaying distribution in data to show how bias can be present in a dataset and affect outcome of a model. FIG. 3A displays a bar chart 300A that depicts an ideal distribution of data in a dataset based on a gender attribute of the dataset. This assumes that one of the attributes of a datapoint in the dataset is gender and gender is categorized by three categories: female, male and non-binary. The example also assumes that the dataset is used to train a model for determining loan approvals. For such a dataset, an ideal distribution based on gender may result in a female bar 310 that has an equal distribution to the male bar 320 and the non-binary bar 330. This means the number of datapoints that represent each of the categories of the gender attribute may be equal or be within a predetermined distribution threshold. As a result, the percentage of loans approved for people falling into each category may also be equal. Thus, the model trained by this dataset may generate outcomes that are consistent across the gender spectrum (e.g. 10% of loans submitted by applicants in each category are approved).


The ideal distribution depicted in FIG. 3A, however, rarely occurs in the real world. Often the dataset is representative of one category more than others. FIG. 3B depicts a bar chart 300B displaying a more realistic real-world distribution of data across the gender spectrum in a dataset. The bar chart 300B shows the female bar 340 represents 35% of the data, while the male bar 350 represents 55% of the data and the non-binary bar chart 360 represents only 10% of data. This shows a clear imbalanced distribution of data across the three categories. When such an imbalanced dataset is used to train a ML mode, the outcome is often severely biased. FIG. 3C depicts a bar chart 300C displaying such an outcome. The female bar 370 of bar chart 300C shows that the ML model rejects 97% of female applicants, while the male bar 380 displays how only 3% of the male applicants are rejected by the ML model. As the non-binary bar 390 shows, the percentage of people falling into the non-binary category that are rejected is even higher than the female applicants, with a 99% rejection rate. As such, imbalanced or biased distribution of input data in a dataset can significantly impact the outcome produced by a ML model trained with the imbalanced dataset.


To address such imbalanced distributions, the input dataset may be trimmed to select a subset of the dataset that represents a more balanced distribution. For example, the subset may be selected based on the size of the category having the smallest distribution. Referring to the imbalanced distribution of FIG. 3B, this may mean choosing the size of the non-binary category as the measuring point and selecting a dataset that corresponds with data in each of the female and male categories in numbers that are equal to or within a desired distribution of the non-binary category. For example, if the non-binary category includes 1000 datapoints from a total of 10,000 datapoints for the entire dataset, a subset may be selected such that each of the female, male and non-binary categories has 1000 datapoints. This is illustrated in FIG. 4 which depicts a bar chart 400 displaying a distribution of data across the gender spectrum in a corrected subset of data. As shown in FIG. 4, because of trimming of the dataset, the resulting subset shows a balanced distribution of data across the three categories of the spectrum. As a result, each of the categories of the corrected subset has about 33% of the data. In one implementation, after a correction is performed, the bias detection tool may be executed again to ensure that the new subset achieves its purposes and it does not generate new undesired imbalance in data. The process may be repeated iteratively until an acceptable corrected dataset is achieved.


In one implementation, after the bias detection system identifies a bias or data imbalance in a feature of the dataset, the results are reported to a user via one or more mechanisms such as those discussed in the co-pending, commonly-owned U.S. patent application Ser. No. (not yet assigned) entitled “Method and System of Correcting Bias in a Dataset Used in Machine-Learning,” filed concurrently herewith under Attorney Docket No. 406443-US-NP/170101-328. Once the results are reported to the user, the user can choose how to address any detected imbalance. For example, the user may choose to trim the original input dataset to reduce the imbalance in the data by selecting a subset of the original dataset. The selection of a corrected subset of the original dataset may be performed by a semi-manual process involving the user, or may be achieved via a fully automatic mechanism, as discussed further below. FIGS. 5A-5B depict example user interfaces for enabling the user to select a subset of the dataset to correct one or more detected imbalances in distribution.


Data imbalance correction may be available as a standalone application, as a combined data imbalance detection and correction standalone application or as a tool integrated into and provided as part of another application or service. In either case, the user may have the option of initiating data imbalance correction by selecting a menu option on a user interface of the designated application. Upon receiving the selection, the application or service may display a user interface such as user interface 500A of FIG. 5A to enable the user to choose a feature based on which the dataset can be trimmed. The user interface 500A may include a pop-menu 510 which may be displayed once the application receives a request to perform bias correction. The pop-menu 510 may include a dropdown menu 520 for displaying a list of all features in the input dataset. For example, the dropdown menu 520 may display the features race, gender, age, income, and zip code for a dataset in which the data includes each of those features.


Additionally, the dropdown menu 520 may include an option for selecting label(s) for instances in which data imbalance is introduced in labeling. That is because bias can easily be introduced in ML training via an imbalanced label. In general, in order for ML models to classify or predict binary or multi-class information, such as whether a face is male or female, or whether a given person is a good credit risk for an unsecured loan, the training data may include a label that specifies which class a given record falls into. This data may then be used to teach the ML model which category to apply to new input. In other words, the label data may teach the ML model which label to apply to new input. Thus, an imbalanced label may result in an inaccurate or biased ML model. For example, for an ML model designed to distinguish cats from dogs in pictures, having too few datapoints that are labeled as cats in the training dataset may result in the trained model not being able to accurately classify cats. Thus, label may be presented as one of the options available for which bias may be corrected.


The user may then select one of the presented options (e.g., gender) from the dropdown menu 520 to select a subset. In another example, two or more features may be selected from the dropdown menu 520. It should be noted that the pop-menu 510 and dropdown menu 520 are merely example user interface elements that can be used to enable the user to select a feature. Many other user interface elements or other mechanism may be used to achieve this purpose.


Once the user selects a feature (e.g., gender) from the dropdown menu 520, a second user interface such as user interface 500B of FIG. 5B may be displayed to enable the user to select a desired distribution for the feature. The user interface 500B may display a list of possible categories for the selected feature (e.g., female, male, non-binary) and present a percentage bar 540 having a slidable bar 530 for each of the categories. The percentage bars 540 may include markers that display percentages associated with each category. By moving the slidable bar 530 on each of the percentage bars 540, the user may be able to select the percentage of datapoints that fall into each category in the subset of the data. For example, to ensure a balanced distribution, the user may move the slidable bar 530 to select 33% of each of the three female, male and non-binary categories. Once the selections are made, a create subset menu button 550 may be pressed to enable creation of a subset of the dataset to correct bias. After the subset is created, the user may be able to perform another bias detection operation on the newly created subset to determine if the new subset reduces or eliminates bias as desired and to ensure the new subset does not create new bias. It should be noted that the percentage bars 540 and slidable bars 530 are merely example user interface elements. Many other user interface elements and controls may be used to enable the user to select the desired percentages.


In one implementation, the user may be provided an option to select another feature for which a distribution change may be needed. For example, after choosing the percentages for each categories of gender in user interface 500B and pressing on create subset button 550, the user may be presented with a pop-menu or another user interface element that asks the user whether he/she desires to select another feature to correct. Once the user communicates a positive response, the user may be presented the user interface 500A again to select another feature. In an alternative implementation, the user may initially select more than one feature from the dropdown menu 520 upon which successive user interfaces such as user interface 500B may be displayed to enable to user to select the desired distributions for each feature.


In one implementation, choosing desired distributions for more than one feature may not be possible as the percentages selected for each feature may create a conflict. For example, if the user chooses to have a subset of data that includes 33% female datapoints and 25% African Americans, those requirements may be in conflict with one another. In other words, it may be impossible to have both 33% female datapoints and 25% African American datapoints. In such situations, the user may be notified of the conflict and asked to adjust the percentages until a possible combination can be achieved. Alternatively, the bias detection and correction system may automatically choose the closest possible combination to the requested combination.


In one implementation, in addition to specifying the feature and the percentages, the user may also be able to choose the type of dataset from which the subset should be selected. For example, the user may be presented with an option to select the original input dataset, the training dataset, the validation dataset or the outcome dataset. In another example, the bias detection and correction system may automatically choose which dataset to select the subset from. For example, the bias detection and correction system may have a default of selecting the original dataset, unless specified otherwise. Alternatively, the bias detection and correction system may intelligently choose the dataset which may have the highest chances of positively affecting the trained model to eliminate or reduce bias.


Once the feature, percentages, and dataset are all selected, the bias detection and correction system may determine how to select a subset from the chosen dataset. For example, to select a subset based on the requirements of user interface 500B, the system may calculate the number of datapoints required from each of the categories to create a subset that corresponds with 33% female, 33% male and 33% non-binary. Once the number of required datapoints for each category is calculated, the system may randomly select data from the dataset that corresponds with the required numbers. In addition to random selection, other methods of selecting the datapoints that correspond with the required numbers are also contemplated.



FIG. 6 is a flow diagram depicting an exemplary method 600 for correcting data imbalance in a dataset associated with training a ML model. The method 600 may begin, at 605, and proceed to receive a request to perform a data imbalance correction operation, at 610. The request may be received via a user interface of an application or service that provides a data imbalance correction tool. For example, it may be received via a menu button of a user interface associated with a data processing application (e.g., a spreadsheet application such as Microsoft Excel®) that provides bias detection and/or correction capabilities. This may be done, by a user after a bias detection operation has been performed and one or more areas of bias have been detected. In one implementation, the request may be received via a user interface of a standalone data bias detection and correction service or application. In another example, the request may be received as one of the initial steps of ML training. For example, an ML training algorithm may automatically include a stage for correction of bias once bias is detected in a dataset associated with training the ML model.


In one implementation, the request may include an indication identifying the dataset or subset(s) of the dataset for which bias correction is requested. For example, if the request is received via a standalone local bias detection and/or correction application, it may identify a dataset stored locally or in a data store to which the bias detection and/or correction application has access for performing the bias detection and correction operations. The bias detection and/or correction application may provide a user interface element for enabling the user to identify the datasets for performing bias correction. For example, a list of available datasets may be presented to the user as part of initiating the bias correction process. In one implementation, the user may be able to select the original input dataset or a subset of it. For example, the user may be able to select the training and validation subsets of data for a dataset for which a split in data has already been performed for model training. Alternatively, the dataset for which data imbalance correction is performed may be chosen automatically without user input.


Once the request for performing data imbalance correction is received, method 600 may proceed to identify one or more features of the dataset for which data imbalance correction should be performed, at 615. In one implementation, the one or more features may be selected by a user. For example, the data imbalance detection and/or correction application may provide a user interface for choosing features of the dataset based on which data imbalance correction may be performed. This may be presented as a list of options (based on available features of the dataset) for the user to choose from. Alternatively, the user may enter (e.g., by typing the name of the feature, or by clicking on a column heading of the dataset for a column displaying a desired feature, and the like) the desired feature(s) in a user interface element. In an example, the user may specify two or more features based on which bias correction will be performed. In addition to identifying the feature(s), the user may also specify a desired threshold of similarity to a desired distribution for the corrected dataset. The desired threshold may be the same or it may be different for each identified feature.


In an alternative implementation, the features may be automatically and/or intelligently identified by the bias detection and/or correction application. For example, the bias and/or correction application may examine the results of a data imbalance detection operation and determine if any imbalanced distributions indicative of bias in the dataset were detected. For example, the bias and/or correction application may determine if commonly biased features such as gender, race, sexual orientation, and age exhibit an imbalance distribution.


It should be noted that features for which data imbalance correction is performed may not be actual fields in the dataset. In an example, a balanceable feature may be a feature that the ML model derives by itself. For example, the initial dataset may have patient locations and air mile distances to the local hospital. During training, the ML model may derive a feature such as transit time to the local hospital that is not explicit in the original dataset based on the patient locations and air mile distances to the local hospital. Such features may be presentable and balanceable as well, as typically a modeler can get numeric feature values for the ML model derived features for a given input record.


Once the features for which data imbalance should be corrected are identified, method 600 may proceed to identify a desired distribution for the selected feature(s), at 620. In one implementation, the desired distribution may be selected by the user. For example, the bias detection and/or correction application may provide a user interface for choosing the desired distribution for each of the categories applicable to the selected feature(s). This may be presented as a set of slidable controls for choosing a percentage for each of the categories of the selected feature(s), as discussed above. Alternatively, the user may enter (e.g., by typing the desired distribution, or by choosing from a dropdown menu, and the like) the desired feature(s) in a user interface element. In an alternative implementation, the desired distributions may be selected automatically by the bias detection and/or correction application. For example, the bias detection and/or correction application may identify an imbalance in a feature indicative of bias, may determine or receive from a user an ideal distribution for the feature, and may calculate how the ideal distribution can be achieved. Machine leaning algorithms may be used to determine the desired distributions. Correction of bias and/or imbalance in data may include identifying feature values that stand out as uncharacteristic or unusual as these values could indicated problems that occurred during data collection. In one implementation, any indication that certain groups or characteristics may be under or overrepresented relative to their real-world prevalence can point to bias or imbalance in data.


Once the desired distributions for the feature(s) are identified, method 600 may proceed to select a subset of data that satisfies the desired distributions for the identified feature(s) from the original dataset, at 625. This may be done by calculating the number of datapoints associated with the desired feature(s) that need to be chosen from the original dataset and choosing a subset of data from the original dataset that satisfies this requirement. Method 600 may then proceed to select a subset of data that satisfies the desired distributions for the identified feature(s) from each of the training and validation datasets, at 630. This may be done to ensure that training and validation datasets do not introduce bias in model training. In one implementation, method 600 may utilize a trained ML component to select the subset(s) in a manner that converges more quickly than involving a human.


Once the new subset(s) are selected, method 600 may proceed to examine the new subsets for bias, at 635. This may be performed to ensure that the new subsets achieved their desired purpose and/or they do not introduce new bias. To perform this step, statistical analysis of the data in the new subsets may be performed to categorize and identify a distribution across multiple categories of one or more features. In one implementation, commonly biased features may be examined. Additionally, features based on which bias correction was performed may be examined to ensure bias correction has been achieved. Once bias detection is performed, method 600 may proceed to determine if bias is detected in the new subset(s), at 640. If no bias is detected or detected bias satisfies a predetermined threshold, method 600 may proceed to train the model based on the new datasets, at 645. In an example, once the model is trained based on the new subset, outcome of the model may be examined for output bias, and the process may be iterated, if needed.


When bias is detected, at 640, method 600 may return to step 615 to repeat the process. In one implementation, steps of method 600 may be performed iteratively until a low-bias dataset is generated. In one implementation, once the first trimmed dataset is generated via the steps of method 600, the newly generated subset may be used as the basis for the next iteration. Alternatively, the original dataset or any of the intervening datasets may be selected. In an example, the bias detection and correction application can be used to create snapshots of each correction attempt and allow selection of any particular corrected dataset for testing and additional correction. The same may be true for the training and validation datasets. Each iteration may use the original subset, latest generated subset or any intervening subsets.


It should be noted that the bias detection and correction tool may be hosted locally on the client (e.g., local bias detection engine) or remotely in the cloud (e.g., bias detection service). In one implementation, a local bias detection and/or correction engine is hosted locally, while others are stored in the cloud. This enables the client device to provide some bias detection and/or correction operations even when the client is not connected to a network. Once the client connects to the network, however, the application may be able to provide better and more complete bias detection and correction.


Thus, methods and systems for correcting imbalance in datasets associated with training a ML model are disclosed. By enabling a user to correct imbalance associated with bias in a dataset or performing an automatic correction, the methods and systems may quickly and efficiently eliminate or reduce bias. This can improve the overall quality of ML models in addition to ensuring they comply with ethical, fairness, regulatory and policy standards.



FIG. 7 is a block diagram 700 illustrating an example software architecture 702, various portions of which may be used in conjunction with various hardware architectures herein described, which may implement any of the above-described features. FIG. 7 is a non-limiting example of a software architecture and it will be appreciated that many other architectures may be implemented to facilitate the functionality described herein. The software architecture 702 may execute on hardware such as client devices, native application provider, web servers, server clusters, external services, and other servers. A representative hardware layer 704 includes a processing unit 706 and associated executable instructions 708. The executable instructions 708 represent executable instructions of the software architecture 702, including implementation of the methods, modules and so forth described herein.


The hardware layer 704 also includes a memory/storage 710, which also includes the executable instructions 708 and accompanying data. The hardware layer 704 may also include other hardware modules 712. Instructions 708 held by processing unit 708 may be portions of instructions 708 held by the memory/storage 710.


The example software architecture 702 may be conceptualized as layers, each providing various functionality. For example, the software architecture 702 may include layers and components such as an operating system (OS) 714, libraries 716, frameworks 718, applications 720, and a presentation layer 724. Operationally, the applications 720 and/or other components within the layers may invoke API calls 724 to other layers and receive corresponding results 726. The layers illustrated are representative in nature and other software architectures may include additional or different layers. For example, some mobile or special purpose operating systems may not provide the frameworks/middleware 718.


The OS 714 may manage hardware resources and provide common services. The OS 714 may include, for example, a kernel 728, services 730, and drivers 732. The kernel 728 may act as an abstraction layer between the hardware layer 704 and other software layers. For example, the kernel 728 may be responsible for memory management, processor management (for example, scheduling), component management, networking, security settings, and so on. The services 730 may provide other common services for the other software layers. The drivers 732 may be responsible for controlling or interfacing with the underlying hardware layer 704. For instance, the drivers 732 may include display drivers, camera drivers, memory/storage drivers, peripheral device drivers (for example, via Universal Serial Bus (USB)), network and/or wireless communication drivers, audio drivers, and so forth depending on the hardware and/or software configuration.


The libraries 716 may provide a common infrastructure that may be used by the applications 720 and/or other components and/or layers. The libraries 716 typically provide functionality for use by other software modules to perform tasks, rather than rather than interacting directly with the OS 714. The libraries 716 may include system libraries 734 (for example, C standard library) that may provide functions such as memory allocation, string manipulation, file operations. In addition, the libraries 716 may include API libraries 736 such as media libraries (for example, supporting presentation and manipulation of image, sound, and/or video data formats), graphics libraries (for example, an OpenGL library for rendering 2D and 3D graphics on a display), database libraries (for example, SQLite or other relational database functions), and web libraries (for example, WebKit that may provide web browsing functionality). The libraries 716 may also include a wide variety of other libraries 738 to provide many functions for applications 720 and other software modules.


The frameworks 718 (also sometimes referred to as middleware) provide a higher-level common infrastructure that may be used by the applications 720 and/or other software modules. For example, the frameworks 718 may provide various GUI functions, high-level resource management, or high-level location services. The frameworks 718 may provide a broad spectrum of other APIs for applications 720 and/or other software modules.


The applications 720 include built-in applications 720 and/or third-party applications 722. Examples of built-in applications 720 may include, but are not limited to, a contacts application, a browser application, a location application, a media application, a messaging application, and/or a game application. Third-party applications 722 may include any applications developed by an entity other than the vendor of the particular system. The applications 720 may use functions available via OS 714, libraries 716, frameworks 718, and presentation layer 724 to create user interfaces to interact with users.


Some software architectures use virtual machines, as illustrated by a virtual machine 728. The virtual machine 728 provides an execution environment where applications/modules can execute as if they were executing on a hardware machine (such as the machine 800 of FIG. 8, for example). The virtual machine 728 may be hosted by a host OS (for example, OS 714) or hypervisor, and may have a virtual machine monitor 726 which manages operation of the virtual machine 728 and interoperation with the host operating system. A software architecture, which may be different from software architecture 702 outside of the virtual machine, executes within the virtual machine 728 such as an OS 750, libraries 752, frameworks 754, applications 756, and/or a presentation layer 758.



FIG. 8 is a block diagram illustrating components of an example machine 800 configured to read instructions from a machine-readable medium (for example, a machine-readable storage medium) and perform any of the features described herein. The example machine 800 is in a form of a computer system, within which instructions 816 (for example, in the form of software components) for causing the machine 800 to perform any of the features described herein may be executed. As such, the instructions 816 may be used to implement methods or components described herein. The instructions 816 cause unprogrammed and/or unconfigured machine 800 to operate as a particular machine configured to carry out the described features. The machine 800 may be configured to operate as a standalone device or may be coupled (for example, networked) to other machines. In a networked deployment, the machine 800 may operate in the capacity of a server machine or a client machine in a server-client network environment, or as a node in a peer-to-peer or distributed network environment. Machine 800 may be embodied as, for example, a server computer, a client computer, a personal computer (PC), a tablet computer, a laptop computer, a netbook, a set-top box (STB), a gaming and/or entertainment system, a smart phone, a mobile device, a wearable device (for example, a smart watch), and an Internet of Things (loT) device. Further, although only a single machine 800 is illustrated, the term “machine” include a collection of machines that individually or jointly execute the instructions 816.


The machine 800 may include processors 810, memory 830, and I/O components 850, which may be communicatively coupled via, for example, a bus 802. The bus 802 may include multiple buses coupling various elements of machine 800 via various bus technologies and protocols. In an example, the processors 810 (including, for example, a central processing unit (CPU), a graphics processing unit (GPU), a digital signal processor (DSP), an ASIC, or a suitable combination thereof) may include one or more processors 812a to 812n that may execute the instructions 816 and process data. In some examples, one or more processors 810 may execute instructions provided or identified by one or more other processors 810. The term “processor” includes a multi-core processor including cores that may execute instructions contemporaneously. Although FIG. 8 shows multiple processors, the machine 800 may include a single processor with a single core, a single processor with multiple cores (for example, a multi-core processor), multiple processors each with a single core, multiple processors each with multiple cores, or any combination thereof. In some examples, the machine 800 may include multiple processors distributed among multiple machines.


The memory/storage 830 may include a main memory 832, a static memory 834, or other memory, and a storage unit 836, both accessible to the processors 810 such as via the bus 802. The storage unit 836 and memory 832, 834 store instructions 816 embodying any one or more of the functions described herein. The memory/storage 830 may also store temporary, intermediate, and/or long-term data for processors 810. The instructions 916 may also reside, completely or partially, within the memory 832, 834, within the storage unit 836, within at least one of the processors 810 (for example, within a command buffer or cache memory), within memory at least one of I/O components 850, or any suitable combination thereof, during execution thereof. Accordingly, the memory 832, 834, the storage unit 836, memory in processors 810, and memory in I/O components 850 are examples of machine-readable media.


As used herein, “machine-readable medium” refers to a device able to temporarily or permanently store instructions and data that cause machine 800 to operate in a specific fashion. The term “machine-readable medium,” as used herein, does not encompass transitory electrical or electromagnetic signals per se (such as on a carrier wave propagating through a medium); the term “machine-readable medium” may therefore be considered tangible and non-transitory. Non-limiting examples of a non-transitory, tangible machine-readable medium may include, but are not limited to, nonvolatile memory (such as flash memory or read-only memory (ROM)), volatile memory (such as a static random-access memory (RAM) or a dynamic RAM), buffer memory, cache memory, optical storage media, magnetic storage media and devices, network-accessible or cloud storage, other types of storage, and/or any suitable combination thereof. The term “machine-readable medium” applies to a single medium, or combination of multiple media, used to store instructions (for example, instructions 816) for execution by a machine 800 such that the instructions, when executed by one or more processors 810 of the machine 800, cause the machine 800 to perform and one or more of the features described herein. Accordingly, a “machine-readable medium” may refer to a single storage device, as well as “cloud-based” storage systems or storage networks that include multiple storage apparatus or devices.


The I/O components 850 may include a wide variety of hardware components adapted to receive input, provide output, produce output, transmit information, exchange information, capture measurements, and so on. The specific I/O components 850 included in a particular machine will depend on the type and/or function of the machine. For example, mobile devices such as mobile phones may include a touch input device, whereas a headless server or IoT device may not include such a touch input device. The particular examples of I/O components illustrated in FIG. 8 are in no way limiting, and other types of components may be included in machine 800. The grouping of I/O components 850 are merely for simplifying this discussion, and the grouping is in no way limiting. In various examples, the I/O components 850 may include user output components 852 and user input components 854. User output components 852 may include, for example, display components for displaying information (for example, a liquid crystal display (LCD) or a projector), acoustic components (for example, speakers), haptic components (for example, a vibratory motor or force-feedback device), and/or other signal generators. User input components 854 may include, for example, alphanumeric input components (for example, a keyboard or a touch screen), pointing components (for example, a mouse device, a touchpad, or another pointing instrument), and/or tactile input components (for example, a physical button or a touch screen that provides location and/or force of touches or touch gestures) configured for receiving various user inputs, such as user commands and/or selections.


In some examples, the I/O components 850 may include biometric components 856 and/or position components 862, among a wide array of other environmental sensor components. The biometric components 856 may include, for example, components to detect body expressions (for example, facial expressions, vocal expressions, hand or body gestures, or eye tracking), measure biosignals (for example, heart rate or brain waves), and identify a person (for example, via voice-, retina-, and/or facial-based identification). The position components 862 may include, for example, location sensors (for example, a Global Position System (GPS) receiver), altitude sensors (for example, an air pressure sensor from which altitude may be derived), and/or orientation sensors (for example, magnetometers).


The I/O components 850 may include communication components 864, implementing a wide variety of technologies operable to couple the machine 800 to network(s) 870 and/or device(s) 880 via respective communicative couplings 872 and 882. The communication components 864 may include one or more network interface components or other suitable devices to interface with the network(s) 870. The communication components 864 may include, for example, components adapted to provide wired communication, wireless communication, cellular communication, Near Field Communication (NFC), Bluetooth communication, Wi-Fi, and/or communication via other modalities. The device(s) 880 may include other machines or various peripheral devices (for example, coupled via USB).


In some examples, the communication components 864 may detect identifiers or include components adapted to detect identifiers. For example, the communication components 864 may include Radio Frequency Identification (RFID) tag readers, NFC detectors, optical sensors (for example, one- or multi-dimensional bar codes, or other optical codes), and/or acoustic detectors (for example, microphones to identify tagged audio signals). In some examples, location information may be determined based on information from the communication components 862, such as, but not limited to, geo-location via Internet Protocol (IP) address, location via Wi-Fi, cellular, NFC, Bluetooth, or other wireless station identification and/or signal triangulation.


While various embodiments have been described, the description is intended to be exemplary, rather than limiting, and it is understood that many more embodiments and implementations are possible that are within the scope of the embodiments. Although many possible combinations of features are shown in the accompanying figures and discussed in this detailed description, many other combinations of the disclosed features are possible. Any feature of any embodiment may be used in combination with or substituted for any other feature or element in any other embodiment unless specifically restricted. Therefore, it will be understood that any of the features shown and/or discussed in the present disclosure may be implemented together in any suitable combination. Accordingly, the embodiments are not to be restricted except in light of the attached claims and their equivalents. Also, various modifications and changes may be made within the scope of the attached claims.


Generally, functions described herein (for example, the features illustrated in FIGS. 1-6) can be implemented using software, firmware, hardware (for example, fixed logic, finite state machines, and/or other circuits), or a combination of these implementations. In the case of a software implementation, program code performs specified tasks when executed on a processor (for example, a CPU or CPUs). The program code can be stored in one or more machine-readable memory devices. The features of the techniques described herein are system-independent, meaning that the techniques may be implemented on a variety of computing systems having a variety of processors. For example, implementations may include an entity (for example, software) that causes hardware to perform operations, e.g., processors functional blocks, and so on. For example, a hardware device may include a machine-readable medium that may be configured to maintain instructions that cause the hardware device, including an operating system executed thereon and associated hardware, to perform operations. Thus, the instructions may function to configure an operating system and associated hardware to perform the operations and thereby configure or otherwise adapt a hardware device to perform functions described above. The instructions may be provided by the machine-readable medium through a variety of different configurations to hardware elements that execute the instructions.


While the foregoing has described what are considered to be the best mode and/or other examples, it is understood that various modifications may be made therein and that the subject matter disclosed herein may be implemented in various forms and examples, and that the teachings may be applied in numerous applications, only some of which have been described herein. It is intended by the following claims to claim any and all applications, modifications and variations that fall within the true scope of the present teachings.


Unless otherwise stated, all measurements, values, ratings, positions, magnitudes, sizes, and other specifications that are set forth in this specification, including in the claims that follow, are approximate, not exact. They are intended to have a reasonable range that is consistent with the functions to which they relate and with what is customary in the art to which they pertain.


The scope of protection is limited solely by the claims that now follow. That scope is intended and should be interpreted to be as broad as is consistent with the ordinary meaning of the language that is used in the claims when interpreted in light of this specification and the prosecution history that follows, and to encompass all structural and functional equivalents. Notwithstanding, none of the claims are intended to embrace subject matter that fails to satisfy the requirement of Sections 101, 102, or 103 of the Patent Act, nor should they be interpreted in such a way. Any unintended embracement of such subject matter is hereby disclaimed.


Except as stated immediately above, nothing that has been stated or illustrated is intended or should be interpreted to cause a dedication of any component, step, feature, object, benefit, advantage, or equivalent to the public, regardless of whether it is or is not recited in the claims.


It will be understood that the terms and expressions used herein have the ordinary meaning as is accorded to such terms and expressions with respect to their corresponding respective areas of inquiry and study except where specific meanings have otherwise been set forth herein.


Relational terms such as first and second and the like may be used solely to distinguish one entity or action from another without necessarily requiring or implying any actual such relationship or order between such entities or actions. The terms “comprises,” “comprising,” and any other variation thereof, are intended to cover a non-exclusive inclusion, such that a process, method, article, or apparatus that comprises a list of elements does not include only those elements but may include other elements not expressly listed or inherent to such process, method, article, or apparatus. An element preceded by “a” or “an” does not, without further constraints, preclude the existence of additional identical elements in the process, method, article, or apparatus that comprises the element.


The Abstract of the Disclosure is provided to allow the reader to quickly identify the nature of the technical disclosure. It is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, it can be seen that various features are grouped together in various examples for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that any claim requires more features than the claim expressly recites. Rather, as the following claims reflect, inventive subject matter lies in less than all features of a single disclosed example. Thus, the following claims are hereby incorporated into the Detailed Description, with each claim standing on its own as a separately claimed subject matter.

Claims
  • 1. A data processing system comprising: a processor; anda memory in communication with the processor, the memory comprising executable instructions that, when executed by the processor cause the data processing system to perform functions of:receiving a request to perform a data imbalance correction on a dataset associated with training a machine-learning (ML) model;identifying a feature of the dataset for which data imbalance correction is to be performed;identifying a desired distribution for the identified feature;selecting a subset of the dataset that corresponds with the selected feature and the desired distribution; andusing the subset to train a ML model.
  • 2. The data processing system of claim 1, wherein the request identifies a type of dataset on which data imbalance correction is to be performed.
  • 3. The data processing system of claim 1, wherein identifying the feature includes receiving an indication from a user which identifies the feature.
  • 4. The data processing system of claim 1, wherein identifying the desired distribution includes receiving an indication from a user which identifies the desired distribution.
  • 5. The data processing system of claim 1, wherein the dataset includes at least one of an input training dataset, a training subset of the input training dataset, a validation subset of the input training dataset, and an outcome dataset.
  • 6. The data processing system of claim 1, wherein the feature includes a label feature of the dataset.
  • 7. The data processing system of claim 1, wherein the executable instructions when executed by the processor further cause the data processing system to perform functions of: examining the subset to determine if a data imbalance exists, andupon determining a data imbalance exits, performing a data imbalance correction on the subset until a desired subset is selected.
  • 8. A method for correcting data imbalance in a dataset associated with training a ML model, the method comprising: receiving a request to perform a data imbalance correction on a dataset associated with training a machine-learning (ML) model;identifying a feature of the dataset for which data imbalance correction is to be performed;identifying a desired distribution for the identified feature;selecting a subset of the dataset that corresponds with the selected feature and the desired distribution; andusing the subset to train a ML model.
  • 9. The method of claim 8, wherein the request identifies a type of dataset on which bias correction is to be performed.
  • 10. The method of claim 8, wherein identifying the feature includes receiving an indication from a user which identifies the feature.
  • 11. The method of claim 8, wherein identifying the desired distribution includes receiving an indication from a user which identifies the desired distribution.
  • 12. The method of claim 8, wherein the dataset includes at least one of an input training dataset, a training subset of the input training dataset, a validation subset of the input training dataset, and an outcome dataset.
  • 13. The method of claim 9, wherein the feature includes a label feature of the dataset.
  • 14. The method of claim 9, further comprising: examining the subset to determine if a data imbalance exists, andupon determining a data imbalance exits, performing a data imbalance correction on the subset until a desired subset is selected.
  • 15. A non-transitory computer readable medium on which are stored instructions that, when executed cause a programmable device to: receive a request to perform a data imbalance correction on a dataset associated with training a machine-learning (ML) model;identify a feature of the dataset for which data imbalance correction is to be performed;identify a desired distribution for the identified feature;select a subset of the dataset that corresponds with the selected feature and the desired distribution; anduse the subset to train a ML model.
  • 16. The non-transitory computer readable medium of claim 15, wherein identifying the feature includes receiving an indication from a user which identifies the feature.
  • 17. The non-transitory computer readable medium of claim 15, wherein identifying the desired distribution includes receiving an indication from a user which identifies the desired distribution.
  • 18. The non-transitory computer readable medium of claim 15, wherein the dataset includes at least one of an input training dataset, a training subset of the input training dataset, a validation subset of the input training dataset, and an outcome dataset.
  • 19. The non-transitory computer readable medium of claim 18, the feature includes a label feature of the dataset.
  • 20. The non-transitory computer readable medium of claim 15, wherein the instructions that, when executed cause a programmable device to: examine the subset to determine if a data imbalance exists, andupon determining a data imbalance exits, perform a data imbalance correction on the subset until a desired subset is selected.
CROSS-REFERENCE TO A RELATED APPLICATION

This patent application is related to co-pending, commonly-owned U.S. patent application Ser. No. (not yet assigned) entitled “Method and System of Detecting Data Imbalance in a Dataset Used in Machine-Learning,” filed concurrently herewith under Attorney Docket No. 406443-US-NP/170101-328; U.S. patent application Ser. No. (not yet assigned) entitled “Method and System of Performing Data Imbalance Detection and Correction in Training a Machine-Learning Model,” filed concurrently herewith under Attorney Docket No. 406440-US-NP/170101-330; and U.S. patent application Ser. No. (not yet assigned) entitled “Remote Validation of Machine-Learning Models for Data Imbalance,” filed concurrently herewith under Attorney Docket No. 406439-US-NP/170101-331; which are all incorporated herein by reference in their entirety.