The present disclosure is related to augmentation of a feature-set for machine learning and in particular to feature-set augmentation using a knowledge engine.
In machine learning, a model, such as a linear or polynomial function is fit to a set of training data. The training data may consist of records with values for a feature set selected from known data and include a desired output or result for each record in the training data. A feature is a measurable property of something being observed. Choosing a comprehensive set of features can help optimize machine learning. The set of features may be used to train a machine learning system by associating a result with each record in the set of features. The machine learning system will configure itself with programming that learns to derive the associated result correctly, and then be applied to data that is not in the feature set to provide results.
For example, if a machine learning system is being trained to recognize US coins, the features may include a name of a building on one side of the coin, such as Monticello, and name of a head shot on the other side, such as Thomas Jefferson, which corresponds to a US nickel. An initial set of features may not be sufficient, such as in the case of US quarters, where each state may have a different image on one side of the coin, or may be too redundant or large to be optimal for machine learning related to a particular domain.
The selection of features to facilitate machine learning has previously been done utilizing knowledge of a domain expert.
A method includes receiving an original feature-set for training a machine learning system, the feature-set including multiple records each having a set of original features with original feature values and a result, querying a knowledge base based on the set of original features, receiving a set of knowledge features with knowledge feature values responsive to the querying of the networked knowledge base, generating a first augmented feature-set that includes the multiple records of the original feature set and the knowledge features for the multiple records, and training the machine learning system based on the first augmented feature-set.
A non-transitory machine readable storage device has instructions for execution by a processor of the machine to perform operations. The operations include receiving an original feature-set for training a machine learning system, the feature-set including multiple records each having a set of original features with original feature values and a result, querying a knowledge base based on the set of original features, receiving a set of knowledge features with knowledge feature values responsive to the querying of the knowledge base, generating a first augmented feature-set that includes the multiple records of the original feature set and the knowledge features for the multiple records, and training the machine learning system based on the first augmented feature-set.
A device comprises a processor and a memory device coupled to the processor and having a program stored thereon for execution by the processor to perform operations. The operations include receiving an original feature-set for training a machine learning system, the feature-set including multiple records each having a set of original features with original feature values and a result, querying a knowledge base based on the set of original features, receiving a set of knowledge features with knowledge feature values responsive to the querying of the knowledge base, generating a first augmented feature-set that includes the multiple records of the original feature set and the knowledge features for the multiple records, and training the machine learning system based on the first augmented feature-set.
In the following description, reference is made to the accompanying drawings that form a part hereof, and in which is shown by way of illustration specific embodiments which may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the invention, and it is to be understood that other embodiments may be utilized and that structural, logical and electrical changes may be made without departing from the scope of the present invention. The following description of example embodiments is, therefore, not to be taken in a limited sense, and the scope of the present invention is defined by the appended claims.
The functions or algorithms described herein may be implemented in software in one embodiment. The software may consist of computer executable instructions stored on computer readable media or computer readable storage device such as one or more non-transitory memories or other type of hardware based storage devices, either local or networked. Further, such functions correspond to modules, which may be software, hardware, firmware or any combination thereof. Multiple functions may be performed in one or more modules as desired, and the embodiments described are merely examples. The software may be executed on a digital signal processor, ASIC, microprocessor, a multi-core processing system, or other type of processor operating on a computer system, such as a personal computer, server or other computer system, turning such computer system into a specifically programmed machine.
An original feature set derived from a dataset for training a machine learning engine is enhanced by searching an external network for additional features. The additional features may be added to the original feature set to form an augmented feature set. Hierarchical clustering of the additional features may be performed to generate higher level features, which may be added to form a further augmented feature set.
The original feature set may be obtained from an internal database with the use of a domain expert. Some features in the original feature set may not be well correlated to the proper categorization, which can lead to overfitting. Overfitting occurs when a statistical model or function is excessively complex, and may describe random noise instead of an underlying relationship to a desired result. In other cases, there may be too few features that were available in a data set used to generate the features, leading to inaccurate results of the trained machine learning system, such as a neural network, for example.
Some features sets may contain too many features, leading to overfitting. In machine learning, when there are too many features in the set of training data, the model that results from the training may describe random errors or noise, leading to inconsistent results when the model is applied to data outside the training set. A model that has been overfit will generally have a poorer predictive performance, as it can exaggerate minor fluctuations in the training data.
At a level 2 420, the small and medium values of level 1 are combined into level 2 small values cluster, while the large values of level 1 remain large values cluster in level 2. Thus, eight values in level 0 have been converted into one of two cluster values, small and large, simplifying the feature set.
A table 650 show three original feature values a, c, and f, and how their values changed or did not change at each of the hierarchical levels. Original feature value, a, maintained the same real value of 10 at each of the four levels. Original feature value, c, also had a real value that changed in each of the higher levels. The original real value of f, changed from 280, to 270 in level 2 and 240 in level 3.
The various levels in
At 730, a set of knowledge features is received from the knowledge engine, with knowledge feature values responsive to the querying of the networked knowledge base. A first augmented feature-set 735 is generated that includes records of the original feature set 710 and the knowledge features 730 for the multiple records. In one embodiment, the machine learning system 740 is trained based on the first augmented feature-set 735.
Hierarchical clustering, or other clustering techniques, may be used to expand the number of representations of a feature or group of features. In one embodiment, a hierarchy engine 745 may be used to create different levels of a feature. One or more of such levels may be added to the augmented feature set 735 to produce a further augmented feature set 750, which may also be used to train the machine learning system 740. The high level feature values of the further augmented feature set 750 may comprise numeric or nominal values. In another embodiment, a set of features are first grouped or mathematically combined, then clustering is applied to this group of features or the combined feature to create higher level features.
With hierarchical clustering, a series of levels may be generated, with each level having an entire set of observations residing in a number of clusters. Each level represents a different granularity. In other words, the higher levels have fewer clusters that contain the entire set of observations. In order to decide which clusters should be formed and/or combined if forming cluster from a bottom up approach, a measure of dissimilarity or distance between observations may be used. In one example, clusters may first be formed by pairing observations that are closest to each other, followed in a further level by combining clusters that are closest to each other. There are many different ways that clusters may be formed. In addition to the bottom up approach, which is referred to as agglomerative clustering, a top down, or divisive approach may also be used such that all observations start in one cluster and are split recursively moving down the hierarchy of levels. When clustered, the value of a given feature may be a median or mean of the values that are clustered at each hierarchical level.
The formation of clusters is also affected by the method used to determine the distance of observations from each other. Various distance functions that may be used in different embodiments include a median distance function, a Euclidean distance function, a Manhattan distance function, a Cosine distance function, or a Hamming distance function.
In one embodiment, there may be a known number of values (say S/M/L, or XS/S/M/L/XL, or S/L), K-means may be used for clustering where K is the known number of different values (3 for S/M/L, or 5 for XS/S/M/L/XL). Other clustering techniques may be used in further embodiments. Note that in this scenario, only one higher-level feature is generated.
In one embodiment, multiple feature values may be mathematically combined to produce a further feature. One example may include multiplying the width and length feature values to produce an area feature. In one embodiment related to determining user churn of wireless carrier network services, the multiple knowledge features comprises a length and width of various cell phones, wherein the length and width are multiplied to produce an area of the cell phone as the further knowledge feature.
Once the machine learning system 740 is trained with one or more of the feature sets, the machine learning system 740 may be used to predict results on records that are not yet in the feature sets, designated as input 755, used to train system 740. System 740 processes the input in accordance with algorithms generated based on the training feature set, and provides a result as an output 760. The output may indicate whether or not a potential new customer is likely to change carriers often. Such an output may be used to offer incentives or different cell phone plans to the potential new customer based on business objectives.
In one embodiment, the system 800 may output an importance or significance value of each feature. The features may be sorted based on the value and top features, or those features having values exceeding a threshold may be selected for inclusion in some embodiments. In further embodiment, a feature pruning step may be applied based on one or more methods commonly used in feature selection, such as testing subsets of features to find those that minimize error rates, or wrapper methods, filter methods, embedded methods, or others.
An original feature and its expanded higher level representations may be referred to as a feature family. Via feature pruning, one best level per feature family (similar to choosing the best granularity for a feature) may be selected to be included in the final model. By performing feature selection following generation of higher level features via augmentation as described above, potentially useful higher level features are not excluded prior to being generated.
A feature application programming interface (API) 830 may be used interact with the set of new features to select features to augment. The selected features may be provided to a hierarchical feature-set augmentation function 840, which may operate to create one or more hierarchical levels as previously described. The level in each family to include in a further augmented feature set may be selected via the knowledge engine 230 via feature pruning, or may be specifically selected by a user at 850 by selecting a feature level, resulting in a further augmented hierarchical feature set.
An interface for selecting and editing new features and hierarchical features to add to the original feature-set is illustrated at 900 in
The feature listing may be alphabetical based on a feature name, and screen size limits show only features that begin with the letter “A” up to a partial listing of features that begin with the letter “C”. Some of the features may have names of active_user, age, alert_balance, alertdelay, answer_count, etc.
Memory 1003 may include volatile memory 1014 and non-volatile memory 1008. Computer 1000 may include—or have access to a computing environment that includes—a variety of computer-readable media, such as volatile memory 1014 and non-volatile memory 1008, removable storage 1010 and non-removable storage 1012. Computer storage includes random access memory (RAM), read only memory (ROM), erasable programmable read-only memory (EPROM) & electrically erasable programmable read-only memory (EEPROM), flash memory or other memory technologies, compact disc read-only memory (CD ROM), Digital Versatile Disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices capable of storing computer-readable instructions for execution to perform functions described herein.
Computer 1000 may include or have access to a computing environment that includes input 1006, output 1004, and a communication connection 1016. Output 1004 may include a display device, such as a touchscreen, that also may serve as an input device. The input 1006 may include one or more of a touchscreen, touchpad, mouse, keyboard, camera, one or more device-specific buttons, one or more sensors integrated within or coupled via wired or wireless data connections to the computer 1000, and other input devices. The computer 1000 may operate in a networked environment using the communication connection 1016 to connect to one or more remote computers, such as database servers, including cloud based servers and storage. The remote computer may include a personal computer (PC), server, router, network PC, a peer device or other common network node, or the like. The communication connection 1016 may include a Local Area Network (LAN), a Wide Area Network (WAN), cellular, WiFi, Bluetooth, or other networks.
Computer-readable instructions stored on a computer-readable storage device are executable by the processing unit 1002 of the computer 1000. A hard drive, CD-ROM, and RAM are some examples of articles including a non-transitory computer-readable medium such as a storage device. The terms computer-readable medium and storage device do not include carrier waves or signals. For example, a computer program 1018 capable of providing a generic technique to perform access control check for data access and/or for doing an operation on one of the servers in a component object model (COM) based system may be included on a CD-ROM and loaded from the CD-ROM to a hard drive. The computer-readable instructions allow computer 1000 to provide generic access controls in a COM based computer network system having multiple users and servers.
1. In example 1, a method includes receiving an original feature-set for training a machine learning system, the feature-set including multiple records each having a set of original features with original feature values and a result, querying a knowledge base based on the set of original features, receiving a set of knowledge features with knowledge feature values responsive to the querying of the networked knowledge base, generating a first augmented feature-set that includes the multiple records of the original feature set and the knowledge features for the multiple records, and training the machine learning system based on the first augmented feature-set.
2. The method of example 1 and further comprising combining multiple values of a single feature to create at least one higher level feature having at least two clusters of higher level feature values.
3. The method of example 2 and further comprising selecting at least one higher level feature from a number of higher level features for a physical feature for inclusion in the first augmented feature set for training the machine learning system.
4. The method of any of examples 2-3 wherein a feature value of each cluster is a function of a mean or median value of the feature values in the cluster.
5. The method of any of examples 1-4 and further comprising creating high level feature values from mathematically combined knowledge features, or a group of knowledge features
6. The method of any of examples 4-5 wherein the mathematically combined features comprises a length and width, and wherein the length and width are multiplied to produce an area as the further feature value.
7. The method of any of examples 4-5 wherein the high level feature values comprise numeric or nominal values.
8. The method of any of examples 1-7 wherein the knowledge base comprises a networked knowledge base.
9. The method of any of examples 1-8 wherein multiple feature values are combined into clusters of higher level feature values based on one or more of a Euclidean distance function, a Manhattan distance function, a Cosine distance function, or a Hamming distance function.
10. The method of any of examples 1-9 wherein the networked knowledge base comprises the Internet, and wherein the original features comprise cellular phone information and the result comprises a carrier churn value.
11. The method of any of examples 1-10 and further comprising providing an interface to select features to include in the augmented feature set.
12. In example 12, a non-transitory machine readable storage device has instructions for execution by one or more processors to perform operations. The operations include receiving an original feature-set for training a machine learning system, the feature-set including multiple records each having a set of original features with original feature values and a result, querying a knowledge base based on the set of original features, receiving a set of knowledge features with knowledge feature values responsive to the querying of the knowledge base, generating a first augmented feature-set that includes the multiple records of the original feature set and the knowledge features for the multiple records, and training the machine learning system based on the first augmented feature-set.
13. The non-transitory machine readable storage device of example 12 wherein the operations further comprise combining multiple values of a single feature to create at least one higher level feature having at least one cluster of higher level feature values.
14. The non-transitory machine readable storage device of any of examples 12-13 wherein multiple feature values are combined into clusters of higher level feature values based on one or more of a Euclidean distance function, a Manhattan distance function, a Cosine distance function, or a Hamming distance function to produce a further knowledge feature.
15. The non-transitory machine readable storage device of any of examples 12-14 wherein the networked knowledge base comprises the Internet, and wherein the original features comprise cellular phone information and the result comprises a carrier churn value.
16. In example 16, a device includes a processor and a memory device coupled to the processor and having a program stored thereon for execution by the processor to perform operations. The operations include receiving an original feature-set for training a machine learning system, the feature-set including multiple records each having a set of original features with original feature values and a result, querying a knowledge base based on the set of original features, receiving a set of knowledge features with knowledge feature values responsive to the querying of the knowledge base, generating a first augmented feature-set that includes the multiple records of the original feature set and the knowledge features for the multiple records, and training the machine learning system based on the first augmented feature-set.
17. The device of example 16 wherein the operations further comprise combining multiple values of a single feature to create at least one higher level feature having at least one cluster of higher level feature values.
18. The device of example 17 wherein the multiple feature values are combined into clusters of higher level feature values based on one or more of a Euclidean distance function, a Manhattan distance function, a Cosine distance function, or a Hamming distance function to produce a further knowledge feature.
19. The device of any of examples 16-18 wherein the operations further comprise creating high level feature values from mathematically combined knowledge features, wherein the mathematically combined features comprises a length and width, and wherein the length and width are multiplied to produce an area as the further feature value.
20. The device of any of any of examples 16-19 wherein the knowledge base comprises the Internet, and wherein the original features comprise cellular phone information and the result comprises a carrier churn value.
Although a few embodiments have been described in detail above, other modifications are possible. For example, the logic flows depicted in the figures do not require the particular order shown, or sequential order, to achieve desirable results. Other steps may be provided, or steps may be eliminated, from the described flows, and other components may be added to, or removed from, the described systems. Other embodiments may be within the scope of the following claims.